/* ═══════════════════════════════════════════
   VARIABLES & RESET
═══════════════════════════════════════════ */
:root {
  --night:       #03050e;
  --night-alt:   #070a1c;
  --night-card:  #0e1428;
  --night-lift:  #141c32;
  --gold:        #c9a84c;
  --gold-bright: #e8c96d;
  --gold-dim:    rgba(201,168,76,0.45);
  --gold-glow:   rgba(201,168,76,0.20);
  --gold-subtle: rgba(201,168,76,0.10);
  --blue-deep:   #1a2640;
  --text:        #f5f2ea;
  --text-muted:  #cec6ac;
  --text-dim:    #b0a88f;
  --border:      rgba(201,168,76,0.18);
  --border-hover:rgba(201,168,76,0.42);
  --radius:      8px;
  --radius-lg:   14px;
  --transition:  0.35s cubic-bezier(0.4,0,0.2,1);
  --font-display:'Cinzel', serif;
  --font-body:   'Cormorant Garamond', serif;
  --font-ui:     'Inter', sans-serif;
  --success:     #7ea87e;
  --danger:      #c46a5a;
  --online:      var(--gold);
  --online-glow: rgba(201,168,76,0.5);
}

/* ═══ CLASSIQUE THEME — Medieval colors + modern readable fonts ═══ */
[data-theme="classic"] {
  --font-display: 'Space Grotesk', sans-serif;
  --font-body:    'DM Sans', sans-serif;
  --font-ui:      'DM Sans', sans-serif;
}
[data-theme="classic"] .nav-logo-text {
  letter-spacing: 0.25em;
}
[data-theme="classic"] .hero-title {
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: 0.15em;
}

/* ═══ CYBER NEON THEME ═══ */
[data-theme="cyber"] {
  --night:        #050510;
  --night-alt:    #0a0a1e;
  --night-card:   #0c0c24;
  --night-lift:   #12123a;
  --gold:         #00d4e6;
  --gold-bright:  #40e8f0;
  --gold-dim:     rgba(0,212,230,0.40);
  --gold-glow:    rgba(0,212,230,0.20);
  --gold-subtle:  rgba(0,212,230,0.08);
  --blue-deep:    #0a0a2e;
  --text:         #e0e6ff;
  --text-muted:   #8890b0;
  --text-dim:     #505878;
  --border:       rgba(0,212,230,0.15);
  --border-hover: rgba(0,212,230,0.40);
  --font-display: 'Orbitron', sans-serif;
  --font-body:    'Rajdhani', sans-serif;
  --success:      #00e88c;
  --danger:       #ff4d6a;
  --online:       #00d4e6;
  --online-glow:  rgba(0,212,230,0.5);
}
/* Logo */
[data-theme="cyber"] .nav-logo-text {
  background: linear-gradient(to bottom, #b0f0f0 0%, #00d4e6 30%, #0088aa 60%, #00d4e6 80%, #80f0f0 100%);
  -webkit-background-clip: text; background-clip: text;
  filter: drop-shadow(0 0 8px rgba(0,212,230,0.7)) drop-shadow(0 0 20px rgba(0,212,230,0.3));
}
/* Hero title */
/* Hero always stays golden — themes only affect UI, not the sanctuary */
[data-theme="cyber"] .hero-title,
[data-theme="hacker"] .hero-title,
[data-theme="holo"] .hero-title {
  background: linear-gradient(180deg, #fff8dc 0%, #e8c96d 20%, #D4AF37 40%, #c9a84c 60%, #a07830 80%, #D4AF37 100%);
  -webkit-background-clip: text; background-clip: text;
  filter: drop-shadow(0 2px 12px rgba(201,168,76,0.6)) drop-shadow(0 0 40px rgba(201,168,76,0.2));
}
[data-theme="cyber"] .hero-dust i,
[data-theme="holo"] .hero-dust i {
  background: radial-gradient(circle, rgba(232,201,109,0.9) 0%, rgba(232,201,109,0.3) 60%, transparent 100%);
}
/* Pin badge */
[data-theme="cyber"] .news-pin-badge { background: #00f0ff; color: #050510; }
/* Signature footer */
[data-theme="cyber"] .signature-name {
  background: linear-gradient(120deg, #0088aa 0%, #00f0ff 25%, #40ffff 50%, #b388ff 75%, #0088aa 100%);
  background-size: 300% auto;
  -webkit-background-clip: text; background-clip: text;
}
[data-theme="cyber"] .signature-name:hover { filter: drop-shadow(0 0 24px rgba(0,240,255,0.5)); }
[data-theme="cyber"] .signature-name::after {
  background: linear-gradient(90deg, rgba(0,240,255,0.4), #00f0ff);
}
/* Btn primary glow */
[data-theme="cyber"] .btn-primary:hover {
  box-shadow: 0 0 45px rgba(0,240,255,0.3), 0 8px 30px rgba(0,240,255,0.15);
}
[data-theme="cyber"] .btn-primary::before {
  background: radial-gradient(ellipse at center, rgba(0,240,255,0.25), transparent 70%);
}
/* Role badges */
[data-theme="cyber"] .role-president { background: linear-gradient(135deg, #00a0c0, #00f0ff); }
[data-theme="cyber"] .role-vice      { background: linear-gradient(135deg, #3060d0, #60a0ff); }
[data-theme="cyber"] .role-stratege  { background: linear-gradient(135deg, #8040d0, #b388ff); }
[data-theme="cyber"] .role-admin     { background: linear-gradient(135deg, #00b0a0, #00f0d0); }
/* Nav scrolled glow line */
[data-theme="cyber"] .nav.scrolled { border-bottom: 1px solid rgba(0,240,255,0.12); }
/* Cards subtle glow on hover */
[data-theme="cyber"] .news-featured:hover,
[data-theme="cyber"] .news-card:hover {
  box-shadow: 0 0 20px rgba(0,240,255,0.08);
}
/* Theme button */
.theme-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  border: 1px solid var(--border); border-radius: var(--radius);
  font-family: var(--font-ui); font-size: .68rem;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-muted);
  transition: all var(--transition);
}
.theme-btn:hover { color: var(--gold); border-color: var(--border-hover); background: var(--gold-subtle); }
[data-theme="cyber"] .theme-btn {
  box-shadow: 0 0 8px rgba(0,240,255,0.15);
}
/* Search flash */
[data-theme="cyber"] .search-highlight {
  animation-name: cyberSearchFlash;
}
@keyframes cyberSearchFlash {
  0%   { box-shadow: 0 0 0 0px rgba(0,240,255,0); }
  20%  { box-shadow: 0 0 0 3px rgba(0,240,255,0.55), 0 0 30px rgba(0,240,255,0.18); }
  60%  { box-shadow: 0 0 0 2px rgba(0,240,255,0.3), 0 0 18px rgba(0,240,255,0.10); }
  100% { box-shadow: 0 0 0 0px rgba(0,240,255,0); }
}
/* Btn-primary hardcoded glow */
[data-theme="cyber"] .btn-primary { box-shadow: 0 0 18px rgba(0,240,255,0.08); }
[data-theme="cyber"] .btn-primary:hover { box-shadow: 0 0 45px rgba(0,240,255,0.38), 0 8px 30px rgba(0,0,0,0.4); }
/* Donor badge pulse */
[data-theme="cyber"] .donor-badge-icon {
  animation-name: cyberDonorPulse;
}
@keyframes cyberDonorPulse {
  0%, 100% { box-shadow: 0 0 6px 2px rgba(0,240,255,.5), 0 0 14px 4px rgba(0,240,255,.25); }
  50% { box-shadow: 0 0 10px 4px rgba(0,240,255,.8), 0 0 22px 8px rgba(0,240,255,.4), 0 0 36px 12px rgba(0,240,255,.15); }
}
/* Modal/overlay subtle adjustments */
[data-theme="cyber"] .msg-bubble.own { background: var(--night-alt); border: 1px solid var(--border); }
[data-theme="cyber"] .cm-bubble.own  { border-color: rgba(0,240,255,0.22); background: rgba(0,240,255,0.04); }
/* Maintenance shield */
[data-theme="cyber"] .maint-shield svg { filter: drop-shadow(0 0 30px rgba(0,240,255,0.4)); }
/* ═══ END CYBER NEON ═══ */

/* ═══ HACKER / MATRIX THEME ═══ */
[data-theme="hacker"] {
  --night:        #000000;
  --night-alt:    #050805;
  --night-card:   #0a100a;
  --night-lift:   #0f180f;
  --gold:         #00dd44;
  --gold-bright:  #33ff77;
  --gold-dim:     rgba(0,221,68,0.40);
  --gold-glow:    rgba(0,221,68,0.20);
  --gold-subtle:  rgba(0,221,68,0.08);
  --blue-deep:    #001a00;
  --text:         #b8e8b8;
  --text-muted:   #608860;
  --text-dim:     #305030;
  --border:       rgba(0,221,68,0.15);
  --border-hover: rgba(0,221,68,0.40);
  --font-display: 'Share Tech Mono', monospace;
  --font-body:    'Fira Code', monospace;
  --font-ui:      'Fira Code', monospace;
  --success:      #00cc33;
  --danger:       #ff3333;
  --online:       #00dd44;
  --online-glow:  rgba(0,221,68,0.5);
}
/* Scanlines overlay */
[data-theme="hacker"] body::after {
  content: '';
  position: fixed; inset: 0; z-index: 9999;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.08) 2px,
    rgba(0,0,0,0.08) 4px
  );
}
/* CRT vignette */
[data-theme="hacker"] body::before {
  content: '';
  position: fixed; inset: 0; z-index: 9998;
  pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 60%, rgba(0,0,0,0.45) 100%);
}
/* Logo */
[data-theme="hacker"] .nav-logo-text {
  background: linear-gradient(to bottom, #80ff99 0%, #00ff41 30%, #009926 60%, #00ff41 80%, #80ff99 100%);
  -webkit-background-clip: text; background-clip: text;
  filter: drop-shadow(0 0 6px rgba(0,255,65,0.6)) drop-shadow(0 0 16px rgba(0,255,65,0.25));
}
/* Hero title kept golden (override removed) */
[data-theme="hacker"] .hero-dust i {
  background: radial-gradient(circle, rgba(0,255,65,0.9) 0%, rgba(0,255,65,0.3) 60%, transparent 100%);
}
/* Pin badge */
[data-theme="hacker"] .news-pin-badge { background: #00ff41; color: #000; }
/* Signature footer */
[data-theme="hacker"] .signature-name {
  background: linear-gradient(120deg, #009926 0%, #00ff41 25%, #33ff77 50%, #00ff41 75%, #009926 100%);
  background-size: 300% auto;
  -webkit-background-clip: text; background-clip: text;
}
[data-theme="hacker"] .signature-name:hover { filter: drop-shadow(0 0 24px rgba(0,255,65,0.5)); }
[data-theme="hacker"] .signature-name::after {
  background: linear-gradient(90deg, rgba(0,255,65,0.4), #00ff41);
}
/* Btn primary */
[data-theme="hacker"] .btn-primary { box-shadow: 0 0 18px rgba(0,255,65,0.08); }
[data-theme="hacker"] .btn-primary:hover { box-shadow: 0 0 45px rgba(0,255,65,0.38), 0 8px 30px rgba(0,0,0,0.4); }
[data-theme="hacker"] .btn-primary::before {
  background: radial-gradient(ellipse at center, rgba(0,255,65,0.25), transparent 70%);
}
/* Role badges */
[data-theme="hacker"] .role-president { background: linear-gradient(135deg, #009926, #00ff41); }
[data-theme="hacker"] .role-vice      { background: linear-gradient(135deg, #006622, #00cc33); }
[data-theme="hacker"] .role-stratege  { background: linear-gradient(135deg, #004d1a, #00aa2a); }
[data-theme="hacker"] .role-admin     { background: linear-gradient(135deg, #008833, #00ff55); }
/* Nav scrolled */
[data-theme="hacker"] .nav.scrolled { border-bottom: 1px solid rgba(0,255,65,0.12); }
/* Card hover glow */
[data-theme="hacker"] .news-featured:hover,
[data-theme="hacker"] .news-card:hover {
  box-shadow: 0 0 20px rgba(0,255,65,0.06);
}
/* Search flash */
[data-theme="hacker"] .search-highlight { animation-name: hackerSearchFlash; }
@keyframes hackerSearchFlash {
  0%   { box-shadow: 0 0 0 0px rgba(0,255,65,0); }
  20%  { box-shadow: 0 0 0 3px rgba(0,255,65,0.55), 0 0 30px rgba(0,255,65,0.18); }
  60%  { box-shadow: 0 0 0 2px rgba(0,255,65,0.3), 0 0 18px rgba(0,255,65,0.10); }
  100% { box-shadow: 0 0 0 0px rgba(0,255,65,0); }
}
/* Donor badge */
[data-theme="hacker"] .donor-badge-icon { animation-name: hackerDonorPulse; }
@keyframes hackerDonorPulse {
  0%, 100% { box-shadow: 0 0 6px 2px rgba(0,255,65,.5), 0 0 14px 4px rgba(0,255,65,.25); }
  50% { box-shadow: 0 0 10px 4px rgba(0,255,65,.8), 0 0 22px 8px rgba(0,255,65,.4), 0 0 36px 12px rgba(0,255,65,.15); }
}
/* Bubbles */
[data-theme="hacker"] .msg-bubble.own { background: var(--night-alt); border: 1px solid var(--border); }
[data-theme="hacker"] .cm-bubble.own  { border-color: rgba(0,255,65,0.22); background: rgba(0,255,65,0.04); }
/* Maintenance */
[data-theme="hacker"] .maint-shield svg { filter: drop-shadow(0 0 30px rgba(0,255,65,0.4)); }
/* Theme toggle in hacker */
[data-theme="hacker"] .theme-btn {
  box-shadow: 0 0 8px rgba(0,255,65,0.15);
}
/* ═══ END HACKER ═══ */

/* ═══ HOLOGRAPHIC / PASTEL THEME ═══ */
[data-theme="holo"] {
  --night:        #08060e;
  --night-alt:    #0e0a18;
  --night-card:   rgba(18,14,32,0.70);
  --night-lift:   rgba(28,22,48,0.60);
  --gold:         #d4a0e8;
  --gold-bright:  #e8c0f8;
  --gold-dim:     rgba(212,160,232,0.40);
  --gold-glow:    rgba(212,160,232,0.20);
  --gold-subtle:  rgba(212,160,232,0.08);
  --blue-deep:    #100a20;
  --text:         #f2eef8;
  --text-muted:   #b0a0c8;
  --text-dim:     #685880;
  --border:       rgba(212,160,232,0.14);
  --border-hover: rgba(212,160,232,0.38);
  --font-display: 'Space Grotesk', sans-serif;
  --font-body:    'DM Sans', sans-serif;
  --success:      #80d8a8;
  --danger:       #e87098;
  --online:       #d4a0e8;
  --online-glow:  rgba(212,160,232,0.5);
}
/* Glass-morphism cards */
[data-theme="holo"] .news-featured,
[data-theme="holo"] .news-card {
  background: rgba(20,20,40,0.55);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid rgba(200,160,255,0.12);
}
[data-theme="holo"] .news-featured:hover,
[data-theme="holo"] .news-card:hover {
  box-shadow: 0 0 24px rgba(200,160,255,0.10), 0 0 48px rgba(120,180,255,0.06);
  border-color: rgba(200,160,255,0.25);
}
/* Logo — iridescent gradient */
[data-theme="holo"] .nav-logo-text {
  background: linear-gradient(135deg, #ff9ed8 0%, #c8a0ff 20%, #80c8ff 40%, #80ffcc 60%, #ffe080 80%, #ff9ed8 100%);
  background-size: 300% 300%;
  -webkit-background-clip: text; background-clip: text;
  animation: holoGrad 8s ease infinite;
  filter: drop-shadow(0 0 8px rgba(200,160,255,0.4));
}
@keyframes holoGrad {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
/* Hero title kept golden (override removed) */
/* Pin badge */
[data-theme="holo"] .news-pin-badge {
  background: linear-gradient(135deg, #c8a0ff, #80c8ff);
  color: #0a0a14;
}
/* Signature footer — iridescent */
[data-theme="holo"] .signature-name {
  background: linear-gradient(120deg, #ff80b0 0%, #c8a0ff 20%, #80c8ff 40%, #80ffc0 60%, #ffe080 80%, #ff80b0 100%);
  background-size: 300% auto;
  -webkit-background-clip: text; background-clip: text;
}
[data-theme="holo"] .signature-name:hover { filter: drop-shadow(0 0 24px rgba(200,160,255,0.5)); }
[data-theme="holo"] .signature-name::after {
  background: linear-gradient(90deg, rgba(200,160,255,0.4), #80c8ff);
}
/* Btn primary */
[data-theme="holo"] .btn-primary { box-shadow: 0 0 18px rgba(200,160,255,0.08); }
[data-theme="holo"] .btn-primary:hover { box-shadow: 0 0 40px rgba(200,160,255,0.25), 0 0 60px rgba(120,180,255,0.12), 0 8px 30px rgba(0,0,0,0.3); }
[data-theme="holo"] .btn-primary::before {
  background: radial-gradient(ellipse at center, rgba(200,160,255,0.20), transparent 70%);
}
/* Role badges — pastel gradients */
[data-theme="holo"] .role-president { background: linear-gradient(135deg, #c8a0ff, #e0c0ff); }
[data-theme="holo"] .role-vice      { background: linear-gradient(135deg, #80a8ff, #a0c8ff); }
[data-theme="holo"] .role-stratege  { background: linear-gradient(135deg, #ff80b0, #ffb0d0); }
[data-theme="holo"] .role-admin     { background: linear-gradient(135deg, #80d8c0, #a0f0e0); }
/* Nav scrolled — glass */
[data-theme="holo"] .nav.scrolled {
  background: rgba(10,10,20,0.75);
  border-bottom: 1px solid rgba(200,160,255,0.10);
}
/* Search flash */
[data-theme="holo"] .search-highlight { animation-name: holoSearchFlash; }
@keyframes holoSearchFlash {
  0%   { box-shadow: 0 0 0 0px rgba(200,160,255,0); }
  20%  { box-shadow: 0 0 0 3px rgba(200,160,255,0.45), 0 0 30px rgba(120,180,255,0.15); }
  60%  { box-shadow: 0 0 0 2px rgba(200,160,255,0.25), 0 0 18px rgba(120,180,255,0.08); }
  100% { box-shadow: 0 0 0 0px rgba(200,160,255,0); }
}
/* Donor badge */
[data-theme="holo"] .donor-badge-icon { animation-name: holoDonorPulse; }
@keyframes holoDonorPulse {
  0%, 100% { box-shadow: 0 0 6px 2px rgba(200,160,255,.4), 0 0 14px 4px rgba(120,180,255,.2); }
  50% { box-shadow: 0 0 10px 4px rgba(200,160,255,.6), 0 0 22px 8px rgba(120,180,255,.3), 0 0 36px 12px rgba(255,160,200,.1); }
}
/* Bubbles */
[data-theme="holo"] .msg-bubble.own { background: var(--night-alt); border: 1px solid var(--border); }
[data-theme="holo"] .cm-bubble.own  { border-color: rgba(200,160,255,0.20); background: rgba(200,160,255,0.04); }
/* Maintenance */
[data-theme="holo"] .maint-shield svg { filter: drop-shadow(0 0 30px rgba(200,160,255,0.4)); }
/* Theme toggle */
[data-theme="holo"] .theme-btn {
  box-shadow: 0 0 8px rgba(200,160,255,0.15);
}
/* Section divider */
[data-theme="holo"] .hero-divider {
  background: linear-gradient(90deg, transparent, rgba(200,160,255,0.5), rgba(120,200,255,0.5), transparent);
}
/* ═══ END HOLOGRAPHIC ═══ */

/* ═══ THEME PICKER DROPDOWN ═══ */
.theme-picker-wrap { position: relative; display: inline-flex; }
.theme-picker {
  position: absolute; top: 100%; right: 0; margin-top: 8px;
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 6px;
  display: none; flex-direction: column; gap: 2px;
  min-width: 160px; z-index: 200;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
}
.theme-picker.open { display: flex; }
.theme-pick-opt {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: var(--radius);
  font-family: var(--font-ui); font-size: .72rem;
  letter-spacing: .06em; color: var(--text-muted);
  cursor: pointer; transition: all var(--transition);
  white-space: nowrap;
}
.theme-pick-opt:hover { background: var(--gold-subtle); color: var(--text); }
.theme-pick-opt.active { color: var(--gold); font-weight: 600; }
.theme-pick-opt .tp-icon { font-size: 1rem; width: 20px; text-align: center; }
/* ═══ END THEME PICKER ═══ */

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:17px; scroll-padding-top:80px; }
body {
  background: var(--night);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1.1rem;
  line-height: 1.85;
  overscroll-behavior-x: none;
  -webkit-font-smoothing: antialiased;
}
html.panel-lock, html.panel-lock body {
  overflow: hidden !important; position: fixed; width: 100%; touch-action: none;
}
a { color: inherit; text-decoration: none; }
img { max-width:100%; display:block; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
ul { list-style:none; }

/* SCROLLBAR */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background: var(--night); }
::-webkit-scrollbar-thumb { background: var(--gold-dim); border-radius:3px; }

/* ═══════════════════════════════════════════
   CANVAS BACKGROUND
═══════════════════════════════════════════ */
#cosmos {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* ═══════════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════════ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 99992;
  padding: 0 40px;
  transition: var(--transition);
}
.nav.scrolled {
  background: rgba(4,6,15,0.88);
  -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
}
.nav-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  height: 72px;
  gap: 20px;
  overflow: visible;
}
.nav-logo {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-right: auto;
  flex-shrink: 0;
}
.nav-logo-text {
  font-family: 'Cinzel Decorative', 'Cinzel', serif;
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  background: linear-gradient(
    to bottom,
    #fff8d0 0%,
    #f2c642 18%,
    #d49a10 42%,
    #f0c740 62%,
    #b07808 82%,
    #e8b830 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 1px 6px rgba(220,155,8,0.65))
          drop-shadow(0 0 18px rgba(200,130,4,0.35));
}
.nav-logo-badge {
  font-family: var(--font-ui);
  font-size: 0.55rem;
  letter-spacing: 0.4em;
  color: var(--text-muted);
  text-transform: uppercase;
  padding-left: 1px;
}
.nav-links {
  display: none;
}
/* ── Dropdown category triggers ── */
.nav-drop {
  position: relative;
}
.nav-drop-trigger {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  transition: color var(--transition);
  padding: 6px 12px;
  border-radius: var(--radius);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  white-space: nowrap;
}
.nav-drop-trigger::after {
  content: '';
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 3px solid currentColor;
  transition: transform 0.2s;
}
.nav-drop:hover .nav-drop-trigger,
.nav-drop.open .nav-drop-trigger {
  color: var(--gold);
  background: var(--gold-subtle);
}
.nav-drop:hover .nav-drop-trigger::after,
.nav-drop.open .nav-drop-trigger::after {
  transform: rotate(180deg);
}
/* ── Dropdown panels ── */
.nav-drop-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 180px;
  background: rgba(8,10,20,0.96);
  -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 8px;
  padding-top: 16px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
  z-index: 200;
  box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 0 1px rgba(201,168,76,0.1);
}
/* Invisible hover bridge — prevents gap between trigger and menu */
.nav-drop-menu::before {
  content: '';
  position: absolute;
  top: -12px; left: 0; right: 0;
  height: 12px;
}
.nav-drop:hover .nav-drop-menu,
.nav-drop.open .nav-drop-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-drop-menu a {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 9px 14px;
  border-radius: 8px;
  transition: color var(--transition), background var(--transition);
  white-space: nowrap;
}
.nav-drop-menu a:hover, .nav-drop-menu a.nav-active {
  color: var(--gold);
  background: var(--gold-subtle);
}
.nav-drop-menu a.nav-active {
  font-weight: 600;
  border-left: 2px solid var(--gold);
}
/* Legacy flat links (keep for JS querySelectorAll compatibility) */
.nav-links > a {
  display: none;
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-shrink: 0;
}
.nav-actions > *:not(.lang-switch):not(.music-btn) {
  display: none !important;
}
@media (min-width: 769px) {
  .nav-links { display: flex !important; align-items: center; gap: 4px; }
  .nav-actions > .auth-btn,
  .nav-actions > .admin-nav-link,
  .nav-actions > #notif-btn,
  .nav-actions > #chat-nav-btn,
  .nav-actions > .dm-nav-btn { display: flex !important; }
  .nav-actions > #chat-nav-btn .dm-badge { position: absolute; top: -4px; right: -4px; }
  .hamburger { display: flex !important; }
}
.lang-switch {
  display: flex;
  align-items: center;
  gap: 2px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.lang-opt {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  color: var(--text-muted);
  padding: 5px 9px;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all var(--transition);
}
.lang-opt:hover { color: var(--text); background: var(--gold-subtle); }
.lang-opt.active { color: var(--gold); background: var(--gold-subtle); font-weight: 600; }
.lang-divider { color: var(--border); font-size: .65rem; user-select: none; }

.auth-btn {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold);
  border: 1px solid var(--gold-dim);
  border-radius: var(--radius);
  padding: 8px 20px;
  transition: all var(--transition);
  background: transparent;
}
.auth-btn:hover {
  background: var(--gold-glow);
  border-color: var(--gold);
  box-shadow: 0 0 20px var(--gold-glow);
}
.admin-nav-link {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-dim);
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: color var(--transition), border-color var(--transition);
  cursor: pointer;
  white-space: nowrap;
}
.admin-nav-link:hover { color: var(--gold); border-color: var(--gold-dim); }
.nav-icon-btn {
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--gold);
  padding: 6px 10px;
  font-size: 1rem;
  cursor: pointer;
  transition: all var(--transition);
}
.nav-icon-btn:hover { border-color: var(--gold-dim); box-shadow: 0 0 12px var(--gold-glow); }

.hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  border-radius: var(--radius);
  transition: opacity var(--transition);
  background: none;
  border: none;
  cursor: pointer;
  z-index: 10;
  flex-shrink: 0;
}
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text-muted);
  transition: all var(--transition);
}
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(4px,4px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(4px,-4px); }

/* ═══════════════════════════════════════════
   MOBILE MENU
═══════════════════════════════════════════ */
.mm-close-btn {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-size: 1.2rem;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--transition), border-color var(--transition);
  z-index: 1;
}
.mm-close-btn:hover { color: var(--gold); border-color: var(--gold-dim); }
/* Overlay derrière le menu */
.mm-backdrop {
  position: fixed; inset: 0; z-index: 99994;
  background: rgba(0,0,0,0); backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px);
  pointer-events: none; transition: all 0.4s ease;
}
.mm-backdrop.open {
  background: rgba(0,0,0,0.5); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  pointer-events: auto;
}
.mobile-menu {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 65%;
  max-width: 280px;
  z-index: 99995;
  background: linear-gradient(180deg, rgba(6,8,18,0.98) 0%, rgba(3,5,14,0.99) 100%);
  -webkit-backdrop-filter: blur(32px) saturate(1.3); backdrop-filter: blur(32px) saturate(1.3);
  border-left: 1px solid rgba(201,168,76,0.15);
  box-shadow: -12px 0 50px rgba(0,0,0,0.7), -2px 0 20px rgba(201,168,76,0.04);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.16,1,0.3,1);
  padding: 70px 20px 30px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.mobile-menu::-webkit-scrollbar { display: none; }
@media (min-width: 769px) {
  .mobile-menu {
    width: 380px;
    max-width: 30vw;
  }
  .mobile-menu a { text-align: left; font-size: 1rem; padding: 10px 20px; }
  .mm-group-trigger { text-align: left; }
}
.mobile-menu.open {
  transform: translateX(0);
}
/* Animation d'entrée des items */
.mobile-menu.open .mm-group,
.mobile-menu.open .mobile-menu-actions,
.mobile-menu.open > a {
  animation: mmItemIn 0.4s cubic-bezier(0.16,1,0.3,1) backwards;
}
.mobile-menu.open .mm-group:nth-child(6)  { animation-delay: 0.05s; }
.mobile-menu.open .mm-group:nth-child(7)  { animation-delay: 0.1s;  }
.mobile-menu.open .mm-group:nth-child(8)  { animation-delay: 0.15s; }
.mobile-menu.open .mm-group:nth-child(9)  { animation-delay: 0.2s;  }
.mobile-menu.open .mm-group:nth-child(10) { animation-delay: 0.25s; }
.mobile-menu.open .mm-group:nth-child(11) { animation-delay: 0.3s;  }
.mobile-menu.open .mobile-menu-actions { animation-delay: 0.4s; }
@keyframes mmItemIn {
  from { opacity: 0; transform: translateX(30px); }
  to { opacity: 1; transform: translateX(0); }
}
.mobile-menu a {
  font-family: var(--font-ui);
  font-size: 0.88rem;
  letter-spacing: 0.03em;
  color: var(--text);
  padding: 10px 16px;
  width: 100%;
  text-align: left;
  border-bottom: none;
  border-radius: 8px;
  transition: color 0.2s, background 0.2s;
}
.mobile-menu a:hover { color: var(--gold); background: rgba(201,168,76,0.06); }
/* ── Mobile menu grouped sections ── */
.mm-group { width: 100%; }
.mm-group-trigger {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold);
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(201,168,76,0.1);
  border-radius: 0;
  padding: 10px 16px 8px;
  width: 100%;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  transition: background 0.2s, color 0.2s;
}
.mm-group-trigger::after {
  content: '▾';
  font-size: 0.7rem;
  transition: transform 0.25s;
}
.mm-group-trigger:hover { background: rgba(201,168,76,0.04); color: var(--gold-bright); }
.mm-group.open .mm-group-trigger { color: var(--gold-bright); border-bottom-color: rgba(201,168,76,0.2); }
.mm-group.open .mm-group-trigger::after { transform: rotate(180deg); }
.mm-group-items {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
}
.mm-group.open .mm-group-items { max-height: 600px; padding: 6px 0; }
.mm-group-items a {
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  padding: 8px 16px 8px 28px;
  border-bottom: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-align: left;
  position: relative;
  border-radius: 6px;
  transition: background 0.2s, color 0.2s;
}
.mm-group-items a::before {
  content: '›';
  position: absolute;
  left: 14px;
  color: var(--gold-dim);
  font-size: 1.1em;
  transition: color var(--transition), transform var(--transition);
}
.mm-group-items a:hover { background: rgba(201,168,76,0.08); color: var(--gold); }
.mm-group-items a:hover::before { color: var(--gold); transform: translateX(3px); }
.mm-group-items a:last-child { border-bottom: none; }
.mm-group-items .theme-pick-opt {
  width: 100%; text-align: left; font-size: 0.82rem; letter-spacing: 0.02em;
  padding: 8px 16px 8px 28px; border-radius: 6px;
  background: none; border: none; color: var(--text); cursor: pointer;
  transition: background 0.2s, color 0.2s; position: relative;
  font-family: var(--font-ui);
}
.mm-group-items .theme-pick-opt::before {
  content: '›'; position: absolute; left: 14px;
  color: var(--gold-dim); font-size: 1.1em;
  transition: color var(--transition), transform var(--transition);
}
.mm-group-items .theme-pick-opt:hover,
.mm-group-items .theme-pick-opt.active { background: rgba(201,168,76,0.08); color: var(--gold); }
.mm-group-items .theme-pick-opt.active::before,
.mm-group-items .theme-pick-opt:hover::before { color: var(--gold); }
.mm-group-items .theme-pick-opt .tp-icon { display: none; }

/* ── Themes section in burger menu (indépendant de mm-group pour éviter l'animation) ── */
.mm-themes-section { width: 100%; }
.mm-themes-trigger {
  font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); background: transparent;
  border: none; border-bottom: 1px solid rgba(201,168,76,0.1); border-radius: 0;
  padding: 10px 16px 8px; width: 100%; text-align: left; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  transition: background 0.2s, color 0.2s;
}
.mm-themes-trigger::after { content: '▾'; font-size: 0.7rem; transition: transform 0.25s; }
.mm-themes-trigger:hover { background: rgba(201,168,76,0.04); color: var(--gold-bright); }
.mm-themes-section.open .mm-themes-trigger { color: var(--gold-bright); border-bottom-color: rgba(201,168,76,0.2); }
.mm-themes-section.open .mm-themes-trigger::after { transform: rotate(180deg); }
.mm-themes-items {
  max-height: 0; overflow: hidden; transition: max-height 0.35s ease;
  display: flex; flex-direction: row; flex-wrap: wrap; gap: 4px; padding: 0;
}
.mm-themes-section.open .mm-themes-items { max-height: 200px; padding: 8px 6px; }
.mm-themes-items .theme-pick-opt { flex: 1 1 auto; min-width: 90px; }
.mobile-menu-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 32px;
}
#mm-admin-trigger {
  width: 100%;
  text-align: center;
  padding: 12px 24px;
  font-size: 0.78rem;
  background: rgba(201,168,76,0.08);
  border-color: var(--gold-dim);
  color: var(--gold);
}

/* ═══════════════════════════════════════════
   SEARCH
═══════════════════════════════════════════ */
/* ── Notification bell ── */
.notif-bell-btn {
  background: none; border: none;
  color: var(--text-muted); cursor: pointer;
  padding: 6px 8px; display: flex; align-items: center;
  border-radius: var(--radius);
  transition: color var(--transition), background var(--transition);
  position: relative;
}
.notif-bell-btn:hover { color: var(--gold); background: rgba(201,168,76,0.08); }
.notif-bell-btn.notif-active { color: var(--gold); }
.notif-bell-btn .notif-dot {
  position: absolute; top: 4px; right: 4px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--danger); display: none;
}
.notif-bell-btn.notif-unread .notif-dot { display: block; }

/* DM Contact Button (member modal + mercato modal) */
.dm-contact-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, var(--gold), #e8c955);
  color: #0a0a0a; border: none; border-radius: 8px;
  padding: 10px 22px; font-size: .88rem; font-weight: 700;
  font-family: var(--font-ui); cursor: pointer;
  letter-spacing: .03em;
  box-shadow: 0 2px 8px rgba(201,168,76,0.3);
  transition: transform .15s, box-shadow .15s;
}
.dm-contact-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(201,168,76,0.4); }
.dm-contact-btn:active { transform: translateY(0); }

/* DM Nav Button */
.dm-nav-btn {
  background: none; border: none;
  color: var(--text-muted); cursor: pointer;
  padding: 6px 8px; display: flex; align-items: center; gap: 4px;
  border-radius: var(--radius);
  transition: color var(--transition), background var(--transition);
  position: relative; font-size: .8rem;
}
.dm-nav-btn:hover { color: var(--gold); background: rgba(201,168,76,0.08); }
.dm-badge {
  position: absolute; top: -2px; right: -4px;
  min-width: 17px; height: 17px; padding: 0 4px;
  border-radius: 9px; background: #e53e3e;
  color: #fff; font-size: .6rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none; animation: dm-badge-pop .3s ease;
}
@keyframes dm-badge-pop { 0%{transform:scale(0)} 60%{transform:scale(1.2)} 100%{transform:scale(1)} }
.mm-dm-btn { width: 100%; justify-content: center; }
.mm-dm-btn .dm-badge { position: static; margin-left: 6px; }

/* DM Panel */
.dm-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.7); z-index: 100000;
}
.dm-overlay.open { display: block; }
.dm-panel {
  position: fixed; top: 0; right: -700px;
  width: 700px; max-width: 100vw; height: 100dvh;
  background: rgba(10,12,18,0.94);
  border-left: 2px solid rgba(201,168,76,0.18);
  z-index: 100001; display: flex; flex-direction: column;
  transition: right .35s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 40px rgba(0,0,0,0.6), -2px 0 20px rgba(201,168,76,0.04), inset 1px 0 0 rgba(201,168,76,0.06);
  overscroll-behavior: contain;
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
}
.dm-panel.open { right: 0; }
.dm-panel-header {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 20px; border-bottom: 1px solid rgba(201,168,76,0.12);
  min-height: 56px;
  background: linear-gradient(180deg, rgba(201,168,76,0.1) 0%, rgba(10,12,18,0.95) 100%);
  position: relative;
}
.dm-panel-header::after {
  content: ''; position: absolute; bottom: -1px; left: 20px; right: 20px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.3), transparent);
}
.dm-panel-title {
  flex: 1; margin: 0; font-family: var(--font-display);
  font-size: 1rem; letter-spacing: .06em; color: var(--gold);
}
.dm-panel-close, .dm-back-btn {
  background: none; border: 1px solid transparent; color: var(--text-muted);
  cursor: pointer; font-size: 1.2rem; padding: 6px 10px;
  border-radius: 50%;
  transition: all .25s ease;
}
.dm-panel-close:hover, .dm-back-btn:hover { color: var(--gold); background: rgba(201,168,76,0.1); border-color: rgba(201,168,76,0.15); }
.dm-panel-close:hover { transform: rotate(90deg); }
.dm-guild-btn { font-size: 0.75rem; display: flex; align-items: center; gap: 4px; white-space: nowrap; }
.dm-thread-bar {
  display:flex;flex-direction:row;align-items:center;gap:10px;
  padding:8px 18px;
  border-bottom:1px solid rgba(201,168,76,.12);
  background:linear-gradient(180deg,rgba(201,168,76,.08) 0%,rgba(10,12,18,0.95) 100%);
  flex-shrink:0;position:relative;overflow:hidden;
}
.dm-thread-bar::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.5),transparent)}
.dm-bar-av-wrap{position:relative;cursor:pointer;transition:transform .25s;flex-shrink:0}
.dm-bar-av-wrap:hover{transform:scale(1.08)}
.dm-bar-av{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid rgba(201,168,76,.4);box-shadow:0 0 8px rgba(201,168,76,.12)}
.dm-bar-av-ph{width:34px;height:34px;border-radius:50%;background:linear-gradient(145deg,rgba(201,168,76,.18),rgba(201,168,76,.06));display:flex;align-items:center;justify-content:center;color:var(--gold);font-weight:700;font-size:1rem;font-family:var(--font-display);border:2px solid rgba(201,168,76,.4);box-shadow:0 0 8px rgba(201,168,76,.08)}
.dm-bar-dot-online,.dm-bar-dot-offline{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:50%;border:2px solid #0d0f12;z-index:1}
.dm-bar-dot-online{background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.6);animation:dmDotPulse 2s infinite}
.dm-bar-dot-offline{background:#6b6155}
.dm-bar-center{text-align:left;min-width:0;flex:1}
.dm-bar-name{font-family:var(--font-display);font-size:.88rem;font-weight:700;color:#e8dcc8;letter-spacing:.04em;cursor:pointer;line-height:1.2}
.dm-bar-name:hover{color:var(--gold)}
.dm-bar-sub{font-size:.65rem;color:var(--text-muted);display:flex;align-items:center;gap:5px;line-height:1.2}
.dm-bar-online-txt{color:#22c55e;font-weight:600;letter-spacing:.04em}
.dm-bar-custom{font-size:.65rem;color:var(--text-muted);opacity:.5;font-style:italic}
/* ── DM Thread Bar: Enhanced Info ── */
.dm-bar-level{font-size:.65rem;color:var(--gold);font-family:var(--font-display);letter-spacing:.04em;opacity:0;transition:opacity .4s ease;line-height:1.2}
.dm-bar-level.loaded{opacity:1}
.dm-bar-xp-wrap{width:100%;height:2px;background:rgba(201,168,76,.1);border-radius:2px;margin:2px 0 0;overflow:hidden;opacity:0;transition:opacity .4s ease .1s}
.dm-bar-xp-wrap.loaded{opacity:1}
.dm-bar-xp-fill{height:100%;background:linear-gradient(90deg,var(--gold),#e8c252);border-radius:2px;box-shadow:0 0 6px rgba(201,168,76,.4);transition:width .8s cubic-bezier(.4,0,.2,1);width:0}
.dm-bar-badges{display:inline-flex;flex-wrap:wrap;gap:3px;margin-left:6px;opacity:0;transition:opacity .4s ease .2s;vertical-align:middle}
.dm-bar-badges.loaded{opacity:1}
.dm-bar-pill{display:inline-flex;align-items:center;gap:3px;font-size:.6rem;padding:2px 7px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:var(--text-muted);letter-spacing:.02em;white-space:nowrap;transition:background .2s,border-color .2s}
.dm-bar-pill:hover{background:rgba(201,168,76,.1);border-color:rgba(201,168,76,.25)}
.dm-bar-pill-icon{font-size:.7rem;line-height:1}
.dm-bar-pill-house{border-color:rgba(201,168,76,.2)}
.dm-bar-pill-streak{color:#ff6b35}
.dm-bar-pill-msgs{color:#8b9dc3}
.dm-bar-pill-role{color:var(--gold);font-weight:600;text-transform:capitalize}
@media(max-width:600px){
  .dm-bar-badges{gap:3px}
  .dm-bar-pill{font-size:.55rem;padding:1px 5px}
  .dm-bar-xp-wrap{width:90px}
}
.dm-panel-body {
  flex: 1; overflow-y: auto; padding: 0;
  background: rgba(10,12,18,0.6);
  scrollbar-width: thin; scrollbar-color: rgba(201,168,76,0.3) transparent;
}
.dm-panel-body::-webkit-scrollbar { width: 6px; }
.dm-panel-body::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.3); border-radius: 3px; }
.dm-panel-body::-webkit-scrollbar-thumb:hover { background: rgba(201,168,76,0.5); }
.dm-panel-body::-webkit-scrollbar-track { background: transparent; }
/* Inbox list */
.dm-inbox-item {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  border-left: 3px solid transparent;
  transition: all .25s ease;
  position: relative;
}
.dm-inbox-item:hover { background: rgba(201,168,76,0.06); border-left-color: rgba(201,168,76,0.4); transform: translateX(2px); }
.dm-inbox-item.unread { background: rgba(201,168,76,0.06); border-left-color: var(--gold); }
.dm-inbox-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
  border: 2px solid rgba(201,168,76,0.25);
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.dm-inbox-item:hover .dm-inbox-avatar { border-color: rgba(201,168,76,0.5); box-shadow: 0 0 10px rgba(201,168,76,0.15); }
.dm-inbox-avatar-ph {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(201,168,76,0.06));
  border: 2px solid rgba(201,168,76,0.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-weight: 700; font-size: 1.1rem;
  flex-shrink: 0;
}
.dm-inbox-info { flex: 1; min-width: 0; }
.dm-inbox-name {
  font-weight: 600; font-size: .88rem; color: #e8dcc8;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dm-inbox-item.unread .dm-inbox-name { color: var(--gold); }
.dm-online-dot {
  position: absolute; bottom: 1px; right: 1px;
  width: 11px; height: 11px; border-radius: 50%;
  background: #2ecc71; border: 2px solid #0a0c0f;
  box-shadow: 0 0 6px rgba(46,204,113,0.5);
  animation: dmDotPulse 2s ease-in-out infinite;
}
.dm-online-dot-inline {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: #2ecc71; vertical-align: middle; margin-left: 4px;
}
.dm-inbox-preview {
  font-size: .76rem; color: #9a8e7d;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-top: 3px; line-height: 1.4;
}
.dm-inbox-item.unread .dm-inbox-preview { color: #b0a88f; }
.dm-inbox-meta {
  display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0;
}
.dm-inbox-time { font-size: .65rem; color: #8a7e6d; white-space: nowrap; }
.dm-inbox-unread {
  min-width: 20px; height: 20px; padding: 0 6px;
  border-radius: 10px; background: linear-gradient(135deg, var(--gold), #d4af37);
  color: #0a0a0a; font-size: .65rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 8px rgba(201,168,76,0.4);
  animation: unreadPulse 2s ease-in-out infinite;
}
@keyframes unreadPulse {
  0%, 100% { box-shadow: 0 0 8px rgba(201,168,76,0.4); }
  50% { box-shadow: 0 0 14px rgba(201,168,76,0.6); }
}
.dm-empty {
  text-align: center; padding: 50px 24px;
  color: #8a7e6d; font-size: .88rem; line-height: 1.6;
}
.dm-empty svg { display: block; margin: 0 auto 16px; opacity: .25; }
/* DM member search */
.dm-search-wrap {
  padding: 10px 14px 6px; border-bottom: 1px solid rgba(201,168,76,0.1);
}
.dm-search-input {
  width: 100%; padding: 9px 14px 9px 36px;
  border: 1px solid rgba(201,168,76,0.12); border-radius: 12px;
  background: rgba(14,20,40,0.5); color: #e8dcc8;
  transition: border-color .3s ease, box-shadow .3s ease, background .3s ease;
  font-size: .82rem; outline: none; transition: border .2s;
  box-sizing: border-box;
}
.dm-search-input:focus { border-color: rgba(201,168,76,0.4); box-shadow: 0 0 0 3px rgba(201,168,76,0.06); background: rgba(20,28,50,0.5); }
.dm-search-input::placeholder { color: #6a6050; }
.dm-search-wrap svg {
  position: absolute; left: 24px; top: 50%; transform: translateY(-50%);
  opacity: .35; pointer-events: none;
}
.dm-search-results {
  max-height: 260px; overflow-y: auto;
}
.dm-search-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 18px; cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  transition: all .2s ease;
}
.dm-search-item:hover { background: rgba(201,168,76,0.07); transform: translateX(2px); }
.dm-search-item img {
  width: 36px; height: 36px; border-radius: 50%;
  object-fit: cover; border: 2px solid rgba(201,168,76,0.25);
  flex-shrink: 0;
}
.dm-search-item .dm-search-ph {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(201,168,76,0.06));
  border: 2px solid rgba(201,168,76,0.25);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-weight: 700; font-size: .9rem;
  flex-shrink: 0;
}
.dm-search-item-info { flex: 1; min-width: 0; }
.dm-search-item-name {
  font-weight: 600; font-size: .84rem; color: #e8dcc8;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dm-search-item-rank {
  font-size: .7rem; color: #8a7e6d; margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dm-search-empty {
  padding: 18px; text-align: center; color: #6a6050; font-size: .8rem;
}
/* Thread header with avatar */
.dm-thread-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px; border-bottom: 1px solid rgba(201,168,76,0.1);
  background: linear-gradient(180deg, rgba(201,168,76,0.05) 0%, transparent 100%);
}
.dm-thread-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--gold);
}
.dm-thread-avatar-ph {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(201,168,76,0.2), rgba(201,168,76,0.06));
  border: 2px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-weight: 700; font-size: .9rem;
}
.dm-thread-name { font-weight: 700; font-size: .9rem; color: #e8dcc8; }
/* Thread messages */
/* ═══ TELEGRAM-STYLE DM MESSAGES ═══ */
.dm-msg {
  display: flex; gap: 6px; padding: 2px 12px;
  align-items: flex-end; max-width: 82%;
}
.dm-msg > div:last-child { flex: 0 1 auto; max-width: calc(100% - 44px); }
.dm-msg.own { flex-direction: row-reverse; margin-left: auto; }
.dm-msg:not(.own) { margin-right: auto; }
.dm-profile-link { cursor: pointer; }
.dm-profile-link:hover { opacity: 0.85; }
.dm-msg-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
  border: 1.5px solid rgba(201,168,76,0.2);
  transition: border-color 0.2s;
}
.dm-msg-avatar:hover { border-color: var(--gold); }
.dm-msg-avatar-ph {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(201,168,76,0.12), rgba(201,168,76,0.04));
  border: 1.5px solid rgba(201,168,76,0.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-weight: 700; font-size: .7rem;
  flex-shrink: 0; transition: border-color 0.2s;
}
.dm-msg-avatar-ph:hover { border-color: var(--gold); }
.dm-msg-bubble {
  display: inline-block; max-width: 100%; padding: 8px 12px 6px;
  border-radius: 4px 16px 16px 16px; font-size: .88rem;
  line-height: 1.5; word-break: break-word; font-weight: 500;
  background: rgba(20,28,50,0.9); color: var(--text);
  border: none; position: relative;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.dm-msg.own .dm-msg-bubble {
  background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(140,110,40,0.12));
  border-radius: 16px 4px 16px 16px;
  box-shadow: 0 1px 3px rgba(201,168,76,0.1);
}
.dm-msg:not(.own) .dm-msg-bubble::before {
  content: ''; position: absolute; bottom: 0; left: -6px;
  width: 10px; height: 10px; background: rgba(20,28,50,0.9);
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}
.dm-msg.own .dm-msg-bubble::before {
  content: ''; position: absolute; bottom: 0; right: -6px; left: auto;
  width: 10px; height: 10px;
  background: linear-gradient(135deg, rgba(170,140,50,0.15), rgba(140,110,40,0.12));
  clip-path: polygon(0 0, 100% 100%, 0 100%);
}
.dm-msg-time {
  font-size: .58rem; color: rgba(255,255,255,0.35);
  margin-top: 2px; text-align: right; padding: 0 2px;
  letter-spacing: .02em;
}
.dm-msg.own .dm-msg-time { text-align: left; color: rgba(201,168,76,0.4); }
.dm-trans {
  font-size: .78rem; color: #8a8070; font-style: italic;
  margin-top: 4px; word-break: break-word;
}
.dm-voice-transcript {
  font-size: .82rem; color: #c8baa8; margin-top: 6px; word-break: break-word;
}
.dm-msg.own .dm-msg-time { text-align: left; }
.dm-check { font-size: .7rem; margin-left: 4px; letter-spacing: -2px; }
.dm-check.sent { color: #9a8e7d; }
.dm-check.delivered { color: #9a8e7d; }
.dm-check.read { color: #4fc3f7; }
.dm-typing-dots { font-style: italic; color: var(--text-muted); font-size: .75rem; }
.dm-typing-dots span { animation: dm-dot-blink 1.4s infinite; }
.dm-typing-dots span:nth-child(2) { animation-delay: .2s; }
.dm-typing-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes dm-dot-blink { 0%,80%,100% { opacity: 0; } 40% { opacity: 1; } }
.chat-mention { color: var(--gold); background: rgba(201,168,76,.15); padding: 1px 4px; border-radius: 3px; cursor: pointer; font-weight: 600; }
.chat-mention:hover { background: rgba(201,168,76,.3); }
.chat-pinned-badge { display: inline-block; font-size: .65rem; background: rgba(201,168,76,.2); color: var(--gold); padding: 2px 6px; border-radius: 10px; margin-left: 6px; vertical-align: middle; }
.dm-msg-img { max-width: 200px; max-height: 200px; border-radius: 8px; margin-top: 4px; cursor: pointer; }
.dm-date-sep {
  text-align: center; padding: 18px 0 10px;
  font-size: .66rem; color: #6b6155;
  font-weight: 600; letter-spacing: .06em;
  text-transform: uppercase;
}
.dm-date-sep span {
  background: rgba(14,20,40,0.7); padding: 4px 16px;
  border-radius: 12px; border: 1px solid rgba(201,168,76,0.1);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
/* Input bar */
.dm-input-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; border-top: 1px solid rgba(201,168,76,0.1);
  background: rgba(6,8,14,0.9);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  position: relative;
}
.dm-input-bar::before {
  content: ''; position: absolute; top: 0; left: 16px; right: 16px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.2), transparent);
}
.dm-input {
  flex: 1; background: rgba(14,20,40,0.6); border: 2px solid rgba(201,168,76,0.12);
  border-radius: 22px; padding: 10px 18px;
  color: #e8dcc8; font-size: .85rem; outline: none;
  font-family: var(--font-body);
  transition: border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.dm-input::placeholder { color: #6b6155; }
.dm-input:focus { border-color: rgba(201,168,76,0.45); box-shadow: 0 0 0 3px rgba(201,168,76,0.08), 0 0 16px rgba(201,168,76,0.06); background: rgba(20,28,50,0.7); }
.dm-send-btn {
  background: linear-gradient(135deg, var(--gold), #d4af37);
  border: none;
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: #0a0a0a; flex-shrink: 0;
  transition: all .25s ease;
  box-shadow: 0 2px 12px rgba(201,168,76,0.3);
}
.dm-send-btn:hover { transform: scale(1.1); box-shadow: 0 4px 20px rgba(201,168,76,0.45); }
.voice-mic-btn {
  background: none; border: 2px solid rgba(201,168,76,0.25);
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--gold); flex-shrink: 0;
  font-size: 1.1rem; transition: all .2s;
}
.voice-mic-btn:hover { border-color: var(--gold); background: rgba(201,168,76,0.1); }
.voice-mic-btn.recording { border-color: #e53e3e; color: #e53e3e; background: rgba(229,62,62,0.1); animation: micPulse 1s ease infinite; }
@keyframes micPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(229,62,62,0.3); } 50% { box-shadow: 0 0 0 8px rgba(229,62,62,0); } }
@media (max-width: 900px) {
  .dm-msg-bubble { font-size: 0.88rem; font-weight: 500; }
}
.dm-msg-del {
  display: inline-block; cursor: pointer; color: rgba(255,80,80,0.5); font-size: .7rem;
  margin-left: 6px; vertical-align: middle; opacity: 0; transition: opacity .2s;
}
.dm-msg-bubble:hover .dm-msg-del { opacity: 1; }
/* DM Reactions */
.dm-reactions { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 4px; }
.dm-react-pill {
  display: inline-flex; align-items: center; gap: 2px; padding: 2px 7px;
  border-radius: 12px; font-size: 0.7rem; cursor: pointer;
  background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.1);
  color: var(--text-muted); transition: all 0.2s ease; line-height: 1.4;
}
.dm-react-pill:hover { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.35); transform: scale(1.08); }
.dm-react-pill.mine { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.4); color: var(--gold); box-shadow: 0 0 6px rgba(201,168,76,0.1); }
.dm-react-pill .react-count { font-size: 0.58rem; font-weight: 600; }
.dm-react-add {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 16px; font-size: 1.1rem;
  background: rgba(201,168,76,0.18); border: 1px solid rgba(201,168,76,0.4);
  color: var(--gold); cursor: pointer; transition: all 0.2s; opacity: 1;
  padding: 0; line-height: 1; touch-action: manipulation; -webkit-tap-highlight-color: transparent;
}
.dm-react-add:hover, .dm-react-add:active { background: var(--gold-glow); border-color: var(--gold); transform: scale(1.1); }
.dm-react-picker {
  position: absolute; bottom: 100%; left: 0; z-index: 10;
  display: flex; flex-wrap: wrap; gap: 3px; padding: 6px 8px; width: 280px;
  background: var(--night-card); border: 1px solid rgba(201,168,76,0.15);
  border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  animation: bubbleIn 0.15s ease;
}
.dm-react-picker span {
  font-size: 1.1rem; cursor: pointer; padding: 3px 4px; border-radius: 6px;
  transition: all 0.15s;
}
.dm-react-picker span:hover { background: var(--gold-glow); transform: scale(1.2); }
.dm-msg-audio { margin-bottom: 4px; min-width: 220px; }
.dm-msg.own .dm-msg-bubble { min-width: auto; }
.dm-msg-bubble:has(.dm-msg-audio) { min-width: 240px; padding: 8px 10px; }
/* Guild chat audio */
.msg-audio audio { display: block; width: 100%; max-width: 320px; height: 40px; border-radius: 20px; margin: 4px 0; filter: invert(0.85) sepia(0.3) hue-rotate(180deg); }
/* Zolta royal blue glow on avatars */
@keyframes zoltaGlow {
  0%, 100% { box-shadow: 0 0 6px 2px rgba(36,53,150,0.6), 0 0 12px 4px rgba(36,53,150,0.25); }
  50% { box-shadow: 0 0 10px 4px rgba(36,53,150,0.8), 0 0 20px 8px rgba(36,53,150,0.35); }
}
.zolta-glow { animation: zoltaGlow 2s ease-in-out infinite; border-radius: 50%; }

.search-btn {
  background: none; border: none;
  color: var(--text-muted); cursor: pointer;
  padding: 6px 8px; display: flex; align-items: center;
  border-radius: var(--radius);
  transition: color var(--transition), background var(--transition);
}
.search-btn:hover { color: var(--gold); background: var(--gold-subtle); }

/* Music button */
.music-btn {
  background: none; border: none;
  color: var(--text-muted); cursor: pointer;
  padding: 6px 8px; display: flex; align-items: center;
  border-radius: var(--radius);
  transition: color var(--transition), background var(--transition);
  position: relative;
}
.music-btn:hover { color: var(--gold); background: var(--gold-subtle); }
/* OFF : haut-parleur barré visible, note cachée */
.music-btn .music-icon-on { display: none; }
.music-btn .music-icon-off { display: block; }
/* ON : haut-parleur caché, note animée dorée */
.music-btn.playing { color: var(--gold); }
.music-btn.playing .music-icon-off { display: none; }
.music-btn.playing .music-icon-on { display: block; animation: music-pulse 1.2s ease-in-out infinite; }
@keyframes music-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}

/* War music floating badge */
.war-music-bar {
  position: fixed;
  bottom: 80px; right: 16px;
  z-index: 9999;
  display: flex; align-items: center; gap: 8px;
  background: rgba(20, 10, 5, 0.88);
  border: 1px solid rgba(180, 60, 20, 0.55);
  border-radius: 20px;
  padding: 6px 10px 6px 12px;
  color: #e8b870;
  font-size: .72rem;
  letter-spacing: .04em;
  font-family: var(--font-ui);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  box-shadow: 0 2px 14px rgba(180, 60, 20, 0.25);
  animation: war-bar-in .3s ease;
  -webkit-user-select: none;
  user-select: none;
}
@keyframes war-bar-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.war-music-note { opacity: .85; animation: music-pulse 1.2s ease-in-out infinite; flex-shrink: 0; }
.war-music-bar.muted .war-music-note { animation: none; opacity: .4; }
.war-music-title { white-space: nowrap; }
.war-music-toggle {
  background: none; border: none; cursor: pointer;
  color: inherit; padding: 2px 4px; display: flex; align-items: center;
  border-radius: 12px; transition: background .15s;
  margin-left: 2px;
}
.war-music-toggle:hover { background: rgba(255,255,255,.1); }
/* icon states */
.war-music-bar .wm-icon-off { display: none; }
.war-music-bar .wm-icon-on  { display: block; }
.war-music-bar.muted .wm-icon-on  { display: none; }
.war-music-bar.muted .wm-icon-off { display: block; color: #888; }
/* above mobile tab bar */
@media (max-width: 768px) { .war-music-bar { bottom: 72px; } }

/* IA button in navbar */
.nav-ai-btn {
  display: flex; align-items: center; gap: 6px;
  background: none; border: 1px solid var(--gold-dim);
  border-radius: var(--radius);
  padding: 4px 12px 4px 4px;
  cursor: pointer; transition: all 0.25s;
  color: var(--gold);
}
.nav-ai-btn:hover { border-color: var(--gold); background: var(--gold-subtle); box-shadow: 0 0 12px rgba(201,168,76,0.15); }
.nav-ai-avatar { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; object-position: top; }
.nav-ai-label { font-family: var(--font-ui); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em; }
.nav-ai-btn.nav-ai-active { border-color: var(--gold); background: var(--gold-subtle); box-shadow: 0 0 12px rgba(201,168,76,0.2); }
.mm-ai-btn { justify-content: center; }
.auth-ai-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 12px; cursor: pointer;
  background: linear-gradient(135deg, rgba(201,168,76,.10), rgba(201,168,76,.04));
  border: 1px solid var(--gold-dim); border-radius: var(--radius);
  color: var(--gold); font-family: var(--font-ui); font-size: .72rem;
  letter-spacing: .18em; text-transform: uppercase; transition: background .2s, border-color .2s;
}
.auth-ai-btn:hover { background: rgba(201,168,76,.18); border-color: rgba(201,168,76,.5); }
.auth-ai-btn .nav-ai-avatar { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; object-position: top; }

.search-overlay {
  position: fixed;
  top: 72px; left: 0; right: 0;
  z-index: 98;
  background: rgba(4, 6, 15, 0.97);
  -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  padding: 28px clamp(24px, 5vw, 80px) 32px;
  transform: translateY(-110%);
  opacity: 0;
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1), opacity 0.25s ease;
  pointer-events: none;
}
.search-overlay.open {
  transform: translateY(0); opacity: 1; pointer-events: auto;
}
.search-field-wrap {
  display: flex; align-items: center; gap: 14px;
  border-bottom: 1px solid var(--gold-dim); padding-bottom: 16px;
  transition: border-color var(--transition);
}
.search-field-wrap:focus-within { border-bottom-color: var(--gold); }
.search-icon-lead { color: var(--text-dim); flex-shrink: 0; opacity: 0.7; }
.search-field {
  flex: 1; background: none; border: none;
  color: var(--text); font-family: var(--font-ui);
  font-size: 1rem; letter-spacing: 0.06em;
  outline: none; padding: 4px 0; min-width: 0;
}
.search-field::placeholder { color: var(--text-dim); font-style: italic; font-size: 0.9rem; }
.search-esc-hint {
  font-family: var(--font-ui); font-size: 0.62rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-dim); border: 1px solid var(--border);
  border-radius: 3px; padding: 3px 7px; flex-shrink: 0; opacity: 0.7;
}
@media (max-width: 600px) { .search-esc-hint { display: none; } }
.search-close-btn {
  background: none; border: none; color: var(--text-dim);
  cursor: pointer; padding: 4px 10px; font-size: 1.1rem; line-height: 1;
  border-radius: var(--radius); flex-shrink: 0;
  transition: color var(--transition), background var(--transition);
}
.search-close-btn:hover { color: var(--gold); background: var(--gold-subtle); }
.search-results {
  margin-top: 20px; max-height: 55vh; overflow-y: auto;
}
.search-results::-webkit-scrollbar { width: 3px; }
.search-results::-webkit-scrollbar-thumb { background: var(--gold-dim); border-radius: 2px; }
.search-results::-webkit-scrollbar-track { background: transparent; }
.search-status {
  font-family: var(--font-ui); font-size: 0.75rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-dim); text-align: center; padding: 32px 0;
}
.search-group {
  border-top: 1px solid rgba(255,255,255,0.05);
  padding-bottom: 6px;
}
.search-group:first-child { border-top: none; }
.search-group-hd {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 10px 10px;
}
.search-group-ico {
  width: 26px; height: 26px; flex-shrink: 0;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.22);
  border-radius: 3px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; color: var(--gold); line-height: 1;
}
.search-group-name {
  font-family: var(--font-ui); font-size: 0.68rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold); font-weight: 600; flex: 1;
}
.search-group-cnt {
  font-family: var(--font-ui); font-size: 0.58rem;
  letter-spacing: 0.08em; color: var(--text-dim);
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border); border-radius: 10px; padding: 2px 8px;
}
.search-items { padding: 0 0 4px; }
.search-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px 8px 46px; border-radius: 2px; cursor: pointer;
  transition: background var(--transition);
}
.search-item:hover { background: var(--gold-subtle); }
.search-item-title {
  font-family: var(--font-ui); font-size: 0.82rem;
  letter-spacing: 0.05em; color: var(--text); flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: color var(--transition);
}
.search-item:hover .search-item-title { color: var(--gold); }
.search-item-sub {
  font-family: var(--font-ui); font-size: 0.68rem;
  letter-spacing: 0.06em; color: var(--text-dim);
  flex-shrink: 0; max-width: 140px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mm-search-bar {
  width: 100%; display: flex; align-items: center; gap: 10px;
  background: rgba(201,168,76,0.04); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 12px 18px;
  cursor: pointer; margin-bottom: 4px;
  transition: border-color var(--transition), background var(--transition);
}
.mm-search-bar:hover { border-color: var(--gold-dim); background: var(--gold-subtle); }
.mm-search-bar span {
  font-family: var(--font-ui); font-size: 0.8rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--text-dim); transition: color var(--transition);
}
.mm-search-bar:hover span { color: var(--gold); }

@keyframes searchFlash {
  0%   { box-shadow: 0 0 0 0px rgba(201,168,76,0); }
  20%  { box-shadow: 0 0 0 3px rgba(201,168,76,0.55), 0 0 30px rgba(201,168,76,0.18); }
  60%  { box-shadow: 0 0 0 2px rgba(201,168,76,0.3), 0 0 18px rgba(201,168,76,0.10); }
  100% { box-shadow: 0 0 0 0px rgba(201,168,76,0); }
}
.search-highlight {
  animation: searchFlash 2.2s ease forwards;
  position: relative; z-index: 1;
}

/* ═══════════════════════════════════════════
   COMMUNICATION TABS (Chat / DM / Voice)
═══════════════════════════════════════════ */
.comm-tabs {
  display: flex; border-bottom: 1px solid rgba(201,168,76,.15);
  background: rgba(4,6,15,.6);
}
.comm-tab {
  flex: 1; padding: 10px 8px; border: none; background: transparent;
  color: var(--text-muted); font-family: var(--font-ui); font-size: .72rem;
  font-weight: 600; letter-spacing: .06em; cursor: pointer;
  transition: color .2s, background .2s; position: relative;
}
.comm-tab:hover { color: var(--text); background: rgba(201,168,76,.04); }
.comm-tab.active { color: var(--gold); }
.comm-tab.active::after {
  content: ''; position: absolute; bottom: 0; left: 20%; right: 20%;
  height: 2px; background: var(--gold); border-radius: 2px;
}
.comm-tab-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 16px; height: 16px; border-radius: 8px;
  background: var(--danger, #e74c3c); color: #fff; font-size: .55rem;
  font-weight: 700; padding: 0 4px; margin-left: 4px; vertical-align: middle;
}
/* DM tab content (inline in chat panel) */
.comm-dm-tab {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
}
.comm-dm-header {
  flex-shrink: 0; display: none; align-items: center; gap: 10px;
  padding: 10px 14px; border-bottom: 1px solid rgba(201,168,76,.12);
  background: rgba(201,168,76,.03);
}
.comm-dm-body {
  flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: 0; background: rgba(10,12,18,0.6);
  scrollbar-width: thin; scrollbar-color: rgba(201,168,76,0.3) transparent;
}
.comm-dm-body::-webkit-scrollbar { width: 6px; }
.comm-dm-body::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.3); border-radius: 3px; }
.comm-dm-body::-webkit-scrollbar-track { background: transparent; }
.comm-dm-typing {
  padding: 4px 16px; font-size: .75rem; color: var(--text-muted); font-style: italic;
}
.comm-dm-input-wrap {
  flex-shrink: 0; display: flex; flex-direction: column;
  border-top: 1px solid rgba(201,168,76,.12);
  position: relative;
}
/* Voice tab content */
.comm-voice-tab {
  flex: 1; display: flex; flex-direction: column; overflow-y: auto;
  padding: 16px;
}
.cv-header {
  font-family: var(--font-display); font-size: .95rem; font-weight: 600;
  color: var(--gold); letter-spacing: .08em; margin-bottom: 16px; text-align: center;
}
.cv-room {
  background: rgba(201,168,76,.04); border: 1px solid rgba(201,168,76,.1);
  border-radius: 10px; padding: 14px 16px; margin-bottom: 10px;
  cursor: pointer; transition: border-color .2s, background .2s;
}
.cv-room:hover { border-color: rgba(201,168,76,.3); background: rgba(201,168,76,.07); }
.cv-room-active { border-color: rgba(46,204,113,.5); background: rgba(46,204,113,.06); }
.cv-room-header {
  display: flex; align-items: center; gap: 8px;
}
.cv-room-icon { font-size: 1.1rem; }
.cv-room-name { font-family: var(--font-ui); font-size: .82rem; font-weight: 600; color: var(--text); flex: 1; }
.cv-room-count { font-family: var(--font-ui); font-size: .68rem; color: var(--text-muted); }
.cv-room-users {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; padding-top: 8px;
  border-top: 1px solid rgba(201,168,76,.08);
}
.cv-user {
  display: flex; align-items: center; gap: 5px;
}
.cv-user-av {
  width: 24px; height: 24px; border-radius: 50%; object-fit: cover;
  border: 1.5px solid rgba(46,204,113,.4);
}
.cv-user-initials {
  width: 24px; height: 24px; border-radius: 50%;
  background: rgba(201,168,76,.15); display: flex; align-items: center; justify-content: center;
  font-size: .5rem; color: var(--gold); font-weight: 700;
}
.cv-user-name { font-family: var(--font-ui); font-size: .72rem; color: var(--text); }
.cv-join-label {
  display: block; width: 100%; margin-top: 10px; padding: 8px;
  background: rgba(201,168,76,.1); border: 1px solid rgba(201,168,76,.2);
  border-radius: 8px; color: var(--gold); font-family: var(--font-ui);
  font-size: .72rem; font-weight: 600; letter-spacing: .06em;
  text-align: center; transition: background .2s, border-color .2s;
}
.cv-room:hover .cv-join-label { background: rgba(201,168,76,.2); border-color: var(--gold); }

/* ── Discord-like connected view ── */
.cv-connected { padding: 8px 0; }
.cv-connected-header {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px; border-bottom: 1px solid rgba(201,168,76,.1);
  margin-bottom: 12px;
}
.cv-connected-status {
  font-family: var(--font-ui); font-size: .6rem; font-weight: 600;
  color: #2ecc71; letter-spacing: .06em; text-transform: uppercase;
}
.cv-connected-room {
  font-family: var(--font-display); font-size: .9rem; font-weight: 700;
  color: var(--text); letter-spacing: .04em;
}
.cv-connected-grid {
  display: flex; flex-wrap: wrap; gap: 8px; padding: 0 8px;
}
.cv-grid-user {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px 5px 5px; border-radius: 20px;
  background: rgba(201,168,76,.04); border: 1px solid rgba(201,168,76,.08);
  transition: background .2s;
}
.cv-grid-user:hover { background: rgba(201,168,76,.08); }
.cv-grid-me { background: rgba(46,204,113,.06); border-color: rgba(46,204,113,.2); }
.cv-grid-av-wrap {
  position: relative; width: 28px; height: 28px; min-width: 28px; min-height: 28px;
  max-width: 28px; max-height: 28px;
  border-radius: 50%; border: 2px solid rgba(201,168,76,.15);
  overflow: hidden; transition: border-color .3s; flex-shrink: 0;
}
.cv-grid-user.speaking .cv-grid-av-wrap { border-color: #2ecc71; box-shadow: 0 0 8px rgba(46,204,113,.4); }
.cv-grid-av { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.cv-grid-initials {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  background: rgba(201,168,76,.12); font-size: .6rem; font-weight: 700; color: var(--gold);
}
.cv-grid-name {
  font-family: var(--font-ui); font-size: .7rem; font-weight: 600;
  color: var(--text-muted); max-width: 120px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ── Voice controls bar (Discord-style) ── */
.comm-voice-controls {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 12px 16px; border-top: 1px solid rgba(201,168,76,.1);
  margin-top: auto; background: rgba(4,6,15,.5);
}
.cv-ctrl {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 10px 16px; border-radius: 12px; border: none;
  background: rgba(255,255,255,.06); color: var(--text);
  cursor: pointer; transition: all .2s; min-width: 60px;
}
.cv-ctrl:hover { background: rgba(255,255,255,.1); }
.cv-ctrl-icon { font-size: 1.2rem; }
.cv-ctrl-label { font-family: var(--font-ui); font-size: .58rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.cv-ctrl-active { background: rgba(231,76,60,.15); color: #e74c3c; }
.cv-ctrl-active:hover { background: rgba(231,76,60,.25); }
.cv-ctrl-deaf { background: rgba(243,156,18,.15); color: #f39c12; }
.cv-ctrl-deaf:hover { background: rgba(243,156,18,.25); }
.cv-ctrl-leave { background: rgba(231,76,60,.12); color: #e74c3c; }
.cv-ctrl-leave:hover { background: rgba(231,76,60,.3); }
.cv-ctrl-leave .cv-ctrl-icon { transform: rotate(135deg); }
@media (max-width: 600px) {
  .cv-connected-grid { gap: 6px; }
  .cv-grid-user { padding: 4px 10px 4px 4px; }
  .cv-grid-av-wrap { width: 24px; height: 24px; }
  .cv-grid-name { font-size: .62rem; max-width: 80px; }
  .cv-ctrl { padding: 8px 12px; min-width: 50px; }
  .cv-ctrl-icon { font-size: 1rem; }
}
@media (max-width: 600px) {
  .comm-tab { font-size: .65rem; padding: 9px 6px; }
  .cv-header { font-size: .85rem; }
}

/* ═══════════════════════════════════════════
   GUEST CTA BANNER
═══════════════════════════════════════════ */
.guest-cta {
  max-width: 900px; margin: 0 auto 16px; padding: 0 16px;
  animation: fadeIn .5s ease;
}
.guest-cta-inner {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  padding: 14px 24px;
  background: linear-gradient(135deg, rgba(26,58,143,.15), rgba(201,168,76,.08));
  border: 1px solid rgba(201,168,76,.25);
  border-radius: var(--radius-lg);
  flex-wrap: wrap;
}
.guest-cta-icon { font-size: 1.3rem; }
.guest-cta-text {
  font-family: var(--font-display); font-size: .85rem; font-weight: 600;
  color: var(--text); letter-spacing: .06em;
}
.guest-cta-btn {
  padding: 8px 22px;
  background: linear-gradient(135deg, var(--gold), #e8c84a);
  color: #0a0c16; font-family: var(--font-ui); font-size: .75rem;
  font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  border: none; border-radius: 20px; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 2px 12px rgba(201,168,76,.3);
}
.guest-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(201,168,76,.5);
}
@media (max-width: 600px) {
  .guest-cta-inner { flex-direction: column; gap: 10px; text-align: center; padding: 16px; }
  .guest-cta-text { font-size: .78rem; }
  .guest-cta-btn { width: 100%; padding: 12px; font-size: .8rem; }
}

/* ═══════════════════════════════════════════
   BREADCRUMB
═══════════════════════════════════════════ */
.breadcrumb {
  max-width: 900px; margin: 0 auto; padding: 8px 24px;
  font-family: var(--font-ui); font-size: .72rem; letter-spacing: .04em;
  color: var(--text-muted); display: flex; align-items: center; gap: 6px;
  flex-wrap: wrap;
}
.bc-home { color: var(--gold-dim); text-decoration: none; transition: color .2s; }
.bc-home:hover { color: var(--gold); }
.bc-sep { color: var(--border); font-size: .65rem; }
.bc-cat { color: var(--text-muted); font-weight: 600; }
.bc-page { color: var(--gold); font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 50vw; }
@media (max-width: 768px) {
  .breadcrumb { padding: 6px 16px; font-size: .62rem; gap: 4px; margin-top: 2px; }
  .bc-cat { display: none; }
  .bc-sep:first-of-type { display: none; }
  .bc-page { max-width: 65vw; }
}

/* ═══════════════════════════════════════════
   ACTIVE DROPDOWN HIGHLIGHT
═══════════════════════════════════════════ */
.nav-drop-active > .nav-drop-trigger {
  color: var(--gold) !important;
  text-shadow: 0 0 12px rgba(201,168,76,0.4);
}
.nav-drop-active > .nav-drop-trigger::after {
  content: ''; position: absolute; bottom: -2px; left: 20%; right: 20%;
  height: 2px; background: var(--gold); border-radius: 2px;
}
.nav-drop-trigger { position: relative; }

/* ═══════════════════════════════════════════
   PREV/NEXT SECTION NAV
═══════════════════════════════════════════ */
.section-prevnext {
  display: flex; align-items: center; justify-content: space-between;
  max-width: 800px; margin: 40px auto 20px; padding: 16px 24px;
  border-top: 1px solid var(--border); gap: 8px;
}
.section-prevnext a {
  font-family: var(--font-ui); font-size: .78rem; font-weight: 600;
  color: var(--text-muted); text-decoration: none; transition: color .2s;
  letter-spacing: .03em;
}
.section-prevnext a:hover { color: var(--gold); }
.pn-prev, .pn-next { flex: 1; min-width: 0; }
.pn-prev { text-align: left; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pn-next { text-align: right; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pn-home { color: var(--gold-dim); font-size: 1rem; flex-shrink: 0; }
@media (max-width: 600px) {
  .section-prevnext { padding: 14px 12px; margin: 30px auto 80px; gap: 6px; }
  .section-prevnext a { font-size: .65rem; }
  .pn-prev, .pn-next { max-width: 40vw; }
}

/* ═══════════════════════════════════════════
   COMMAND PALETTE (Ctrl+K)
═══════════════════════════════════════════ */
.cmd-palette-overlay {
  position: fixed; inset: 0; z-index: 100000;
  background: rgba(0,0,0,.7); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: min(20vh, 160px);
}
.cmd-palette {
  width: min(520px, 90vw); background: rgba(4,6,15,.97);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: 0 20px 60px rgba(0,0,0,.5); overflow: hidden;
}
#cmd-input {
  width: 100%; padding: 16px 20px; border: none; border-bottom: 1px solid var(--border);
  background: transparent; color: var(--text); font-family: var(--font-ui);
  font-size: .95rem; outline: none; box-sizing: border-box;
}
#cmd-input::placeholder { color: var(--text-muted); }
.cmd-results { max-height: 340px; overflow-y: auto; padding: 6px 0; }
.cmd-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 20px; cursor: pointer; transition: background .15s; gap: 8px;
}
.cmd-item:hover, .cmd-active { background: var(--gold-subtle); }
.cmd-label { font-family: var(--font-ui); font-size: .85rem; font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cmd-cat { font-family: var(--font-ui); font-size: .65rem; color: var(--text-muted); letter-spacing: .08em; text-transform: uppercase; flex-shrink: 0; }
.cmd-hint {
  padding: 8px 20px; border-top: 1px solid var(--border);
  font-family: var(--font-ui); font-size: .65rem; color: var(--text-muted);
  display: flex; align-items: center; gap: 12px;
}
.cmd-hint kbd {
  background: var(--gold-subtle); border: 1px solid var(--border);
  border-radius: 4px; padding: 1px 6px; font-size: .6rem; font-family: var(--font-ui);
  color: var(--gold-dim);
}
@media (max-width: 600px) {
  .cmd-palette-overlay { padding-top: 20px; }
  .cmd-palette { width: 96vw; border-radius: 12px; }
  #cmd-input { padding: 14px 16px; font-size: .88rem; }
  .cmd-results { max-height: 55vh; }
  .cmd-item { padding: 12px 16px; }
  .cmd-label { font-size: .8rem; }
  .cmd-cat { font-size: .58rem; }
  .cmd-hint { padding: 10px 16px; flex-wrap: wrap; gap: 8px; }
}

/* ═══════════════════════════════════════════
   HERO — Sanctuary fullscreen
═══════════════════════════════════════════ */
.hero {
  position: relative;
  min-height: 100dvh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1;
  overflow: hidden;
  background: url('/img/sanctuary-bg.jpg') center center / cover no-repeat;
  background-attachment: fixed;
}
/* Dark vignette overlay */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 30%, rgba(3,5,14,0.55) 75%, rgba(3,5,14,0.85) 100%),
    linear-gradient(to bottom, rgba(3,5,14,0.3) 0%, transparent 25%, transparent 70%, rgba(3,5,14,0.7) 100%);
  z-index: 1;
  pointer-events: none;
}
/* Warm light shaft overlay */
.hero::after {
  content: '';
  position: absolute;
  top: -10%; left: 35%; right: 35%;
  height: 70%;
  background: radial-gradient(ellipse at top center, rgba(232,201,109,0.08) 0%, transparent 70%);
  pointer-events: none;
  z-index: 2;
  animation: lightShaft 6s ease-in-out infinite;
}
@keyframes lightShaft {
  0%,100% { opacity: 0.6; transform: scaleX(1); }
  50%     { opacity: 1;   transform: scaleX(1.15); }
}

.hero-content {
  position: relative;
  z-index: 3;
  text-align: center;
  padding: 0 24px;
  max-width: 900px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: -5vh;
}

/* ── Dust motes floating particles ── */
.hero-dust {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
}
.hero-dust i {
  position: absolute;
  width: 3px; height: 3px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232,201,109,0.9) 0%, rgba(201,168,76,0.3) 60%, transparent 100%);
  animation: dustFloat linear infinite;
  opacity: 0;
}
.hero-dust i:nth-child(1)  { left: 15%; animation-duration: 12s; animation-delay: 0s; width: 2px; height: 2px; }
.hero-dust i:nth-child(2)  { left: 30%; animation-duration: 15s; animation-delay: 2s; width: 3px; height: 3px; }
.hero-dust i:nth-child(3)  { left: 45%; animation-duration: 10s; animation-delay: 4s; width: 2px; height: 2px; }
.hero-dust i:nth-child(4)  { left: 60%; animation-duration: 14s; animation-delay: 1s; width: 4px; height: 4px; }
.hero-dust i:nth-child(5)  { left: 75%; animation-duration: 11s; animation-delay: 3s; width: 2px; height: 2px; }
.hero-dust i:nth-child(6)  { left: 20%; animation-duration: 13s; animation-delay: 5s; width: 3px; height: 3px; }
.hero-dust i:nth-child(7)  { left: 50%; animation-duration: 16s; animation-delay: 7s; width: 2px; height: 2px; }
.hero-dust i:nth-child(8)  { left: 80%; animation-duration: 9s;  animation-delay: 2s; width: 3px; height: 3px; }
.hero-dust i:nth-child(9)  { left: 35%; animation-duration: 14s; animation-delay: 6s; width: 2px; height: 2px; }
.hero-dust i:nth-child(10) { left: 65%; animation-duration: 12s; animation-delay: 4s; width: 3px; height: 3px; }
.hero-dust i:nth-child(11) { left: 10%; animation-duration: 15s; animation-delay: 8s; width: 2px; height: 2px; }
.hero-dust i:nth-child(12) { left: 85%; animation-duration: 11s; animation-delay: 1s; width: 4px; height: 4px; }
@keyframes dustFloat {
  0%   { transform: translateY(100vh) translateX(0); opacity: 0; }
  10%  { opacity: 0.7; }
  50%  { transform: translateY(40vh) translateX(20px); opacity: 0.5; }
  90%  { opacity: 0.3; }
  100% { transform: translateY(-10vh) translateX(-10px); opacity: 0; }
}

.hero-title {
  font-family: 'Cinzel Decorative', 'Cinzel', serif;
  font-size: clamp(3.5rem, 11vw, 8rem);
  font-weight: 900;
  letter-spacing: 0.3em;
  line-height: 1;
  background: linear-gradient(180deg, #fff8dc 0%, #e8c96d 20%, #D4AF37 40%, #c9a84c 60%, #a07830 80%, #D4AF37 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none;
  filter: drop-shadow(0 2px 12px rgba(201,168,76,0.6)) drop-shadow(0 0 40px rgba(201,168,76,0.2));
  margin-bottom: 12px;
  animation: titleGlow 4s ease-in-out infinite;
}
@keyframes titleGlow {
  0%,100% { filter: drop-shadow(0 2px 12px rgba(201,168,76,0.5)) drop-shadow(0 0 40px rgba(201,168,76,0.15)); }
  50%     { filter: drop-shadow(0 2px 20px rgba(201,168,76,0.8)) drop-shadow(0 0 60px rgba(201,168,76,0.3)); }
}
.hero-divider {
  width: 200px;
  height: 2px;
  background: linear-gradient(90deg, transparent, #D4AF37, var(--gold-bright), #D4AF37, transparent);
  margin: 0 auto 20px;
  box-shadow: 0 0 12px rgba(201,168,76,0.4);
}
.hero-subtitle {
  font-family: var(--font-display);
  font-size: clamp(1rem, 2.8vw, 1.6rem);
  font-weight: 400;
  letter-spacing: 0.18em;
  color: #D4AF37;
  line-height: 1.6;
  margin-bottom: 12px;
  text-shadow: 0 1px 8px rgba(0,0,0,0.7), 0 0 20px rgba(201,168,76,0.2);
}
.hero-tagline {
  font-family: var(--font-body);
  font-size: clamp(0.85rem, 1.5vw, 1.05rem);
  font-style: italic;
  color: rgba(212,175,55,0.6);
  letter-spacing: 0.12em;
  margin-bottom: 48px;
  text-shadow: 0 1px 6px rgba(0,0,0,0.6);
}

/* ── CTA Button — Sanctuary style ── */
.hero-cta {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-primary {
  font-family: var(--font-display);
  font-size: clamp(0.7rem, 1.2vw, 0.85rem);
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #fff8dc;
  border: 2px solid #D4AF37;
  padding: 18px 48px;
  border-radius: 3px;
  transition: all 0.45s cubic-bezier(0.4,0,0.2,1);
  position: relative;
  overflow: hidden;
  background: rgba(10, 12, 26, 0.75);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  box-shadow:
    0 0 20px rgba(201,168,76,0.15),
    inset 0 0 20px rgba(201,168,76,0.05),
    0 4px 20px rgba(0,0,0,0.4);
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}
.btn-primary .btn-icon {
  width: 20px; height: 20px;
  flex-shrink: 0;
  opacity: 0.85;
  filter: drop-shadow(0 0 4px rgba(201,168,76,0.4));
}
.btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 0%, rgba(212,175,55,0.12) 50%, transparent 100%);
  transform: translateX(-100%);
  transition: transform 0.6s ease;
}
.btn-primary::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 3px;
  background: linear-gradient(135deg, #D4AF37, #e8c96d, #D4AF37, #a07830);
  z-index: -1;
  opacity: 0;
  transition: opacity 0.45s ease;
}
.btn-primary:hover {
  color: #fff;
  border-color: var(--gold-bright);
  background: rgba(10, 12, 26, 0.9);
  box-shadow:
    0 0 50px rgba(201,168,76,0.35),
    inset 0 0 30px rgba(201,168,76,0.08),
    0 8px 30px rgba(0,0,0,0.5);
  transform: translateY(-2px);
}
.btn-primary:hover::before { transform: translateX(100%); }
.btn-primary:hover::after { opacity: 0.15; }
.btn-primary:hover .btn-icon { opacity: 1; }

.hero-scroll-hint {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  animation: scrollBounce 2.5s ease infinite;
  z-index: 3;
}
.hero-scroll-hint span {
  display: block;
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, transparent, rgba(212,175,55,0.5));
}
@keyframes scrollBounce {
  0%,100% { transform: translateX(-50%) translateY(0); opacity: 0.6; }
  50%      { transform: translateX(-50%) translateY(8px); opacity: 1; }
}

/* ── Mobile hero adjustments ── */
@media (max-width: 768px) {
  .hero {
    background-attachment: scroll;
  }
  .hero-content {
    margin-top: 0;
    padding: 60px 20px;
  }
  .btn-primary {
    padding: 14px 32px;
    font-size: 0.68rem;
  }
}


/* ═══════════════════════════════════════════
   SECTIONS COMMON
═══════════════════════════════════════════ */
.section {
  position: relative;
  z-index: 1;
  padding: clamp(80px,10vw,140px) clamp(24px,5vw,80px);
  max-width: 1400px;
  margin: 0 auto;
  overflow: visible;
}
.standalone-active {
  position: relative;
  z-index: 10;
  min-height: 100dvh;
  padding-top: 80px;
  background: var(--night);
  overflow: visible;
}
.standalone-active > .section {
  opacity: 1 !important;
  transform: none !important;
}
.section-header {
  text-align: center;
  margin-bottom: clamp(48px,6vw,80px);
  cursor: pointer; -webkit-user-select: none; user-select: none; position: relative;
}
.section-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--gold);
  border: 1px solid var(--gold-dim);
  padding: 5px 16px;
  border-radius: 2px;
  margin-bottom: 20px;
  scroll-margin-top: 80px;
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--text);
  position: relative;
  display: inline-block;
}
.section-title::after {
  content: '';
  position: absolute;
  bottom: -12px; left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
/* ── Site-wide micro-animations ── */
.section-badge {
  transition: border-color .3s, color .3s, transform .3s;
}
.section-header:hover .section-badge {
  border-color: var(--gold);
  transform: scale(1.05);
}
.section-title::after {
  transition: width .4s ease;
  width: 60px;
}
.section-header:hover .section-title::after {
  width: 120px;
}
.section.revealed .section-badge {
  animation: badgeReveal .6s ease both;
}
@keyframes badgeReveal {
  from { opacity: 0; transform: translateY(-10px) scale(.9); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
/* Cards hover lift */
.news-card, .literary-card, .ev-card, .member-card, .song-card, .game-card, .araya-card,
.parure-card, .armure-card, .vestigia-card, .artefact-card, .wiki-card, .actu-card {
  transition: transform .25s ease, box-shadow .25s ease;
}
.news-card:hover, .literary-card:hover, .ev-card:hover, .member-card:hover, .song-card:hover,
.game-card:hover, .araya-card:hover, .parure-card:hover, .armure-card:hover, .vestigia-card:hover,
.artefact-card:hover, .wiki-card:hover, .actu-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,.3), 0 0 12px rgba(201,168,76,.08);
}
/* Stat counter glow on hover */
.stat-card { transition: transform .3s ease, border-color .3s; }
.stat-card:hover { transform: translateY(-3px); border-color: var(--gold-dim); }
/* Button pulse on hover */
.btn-primary { transition: transform .2s, box-shadow .2s, background .2s; }
.btn-primary:hover { transform: translateY(-1px); }
/* Smooth section reveal */
.section { transition: opacity .5s ease, transform .5s ease; }
.section:not(.revealed) { opacity: 0; transform: translateY(20px); }
.section.revealed { opacity: 1; transform: translateY(0); }
/* Nav link subtle underline animation */
.nav-drop-menu a { position: relative; }
.nav-drop-menu a::after {
  content: ''; position: absolute; bottom: 0; left: 10%; right: 10%;
  height: 1px; background: var(--gold); transform: scaleX(0);
  transition: transform .25s ease;
}
.nav-drop-menu a:hover::after, .nav-drop-menu a.nav-active::after { transform: scaleX(1); }
/* Online banner entrance */
.online-banner.visible { animation: bannerSlideIn .4s ease both; }
@keyframes bannerSlideIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}
/* Breadcrumb fade */
.breadcrumb { animation: fadeIn .3s ease; }
/* Prev/next hover arrow nudge */
.pn-prev:hover { transform: translateX(-3px); }
.pn-next:hover { transform: translateX(3px); }
.pn-prev, .pn-next { transition: transform .2s ease, color .2s; }

/* Collapsible sections */
.section-toggle {
  display: inline-block; margin-left: 10px; font-size: .6em;
  transition: transform .3s ease; color: var(--gold-dim); vertical-align: middle;
}
.section.collapsed .section-toggle { transform: rotate(-90deg); }
.section.collapsed .section-body {
  max-height: 0; overflow: hidden; opacity: 0;
  transition: max-height .4s ease, opacity .3s ease;
}
.section-body {
  max-height: 9999px; opacity: 1;
  transition: max-height .4s ease, opacity .3s ease;
  -webkit-user-select: text; user-select: text;
}
.section.collapsed { padding-bottom: clamp(20px,3vw,40px); }
.section.collapsed .section-header { margin-bottom: 0; }
/* Expand hint on collapsed sections */
.section-expand-hint {
  display: none; margin-top: 18px;
}
.section.collapsed .section-expand-hint { display: block; }
.section-expand-hint-inner {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 20px; border-radius: 20px;
  border: 1px solid rgba(201,168,76,.2);
  background: rgba(201,168,76,.04);
  font-family: var(--font-body); font-size: .7rem; font-weight: 600;
  color: var(--gold-dim); letter-spacing: .04em;
  transition: all .3s ease;
}
.section-header:hover .section-expand-hint-inner {
  border-color: var(--gold); color: var(--gold);
  background: rgba(201,168,76,.1);
  box-shadow: 0 0 20px rgba(201,168,76,.08);
}
.section-expand-chevron {
  display: inline-block; transition: transform .3s ease;
  font-size: .65rem;
}
.section-header:hover .section-expand-chevron { transform: translateY(2px); }
@keyframes subtlePulse {
  0%, 100% { opacity: .6; }
  50% { opacity: 1; }
}
.section.collapsed .section-expand-hint-inner {
  animation: subtlePulse 3s ease-in-out infinite;
}
.section-header:hover .section-expand-hint-inner { animation: none; opacity: 1; }

/* Collapse button at the bottom of open sections */
.section-collapse-btn {
  display: block;
  margin: 28px auto 0;
  padding: 6px 24px;
  border-radius: 20px;
  border: 1px solid rgba(201,168,76,.2);
  background: rgba(201,168,76,.04);
  font-family: var(--font-body);
  font-size: .7rem;
  font-weight: 600;
  color: var(--gold-dim);
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .3s ease;
}
.section-collapse-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(201,168,76,.1);
  box-shadow: 0 0 20px rgba(201,168,76,.08);
}
.section.collapsed .section-collapse-btn { display: none; }
/* Collapse button in header (top-right) */
.section-collapse-top {
  position: absolute;
  top: 0; right: 0;
  padding: 4px 16px;
  border-radius: 0 0 0 12px;
  border: none;
  border-left: 1px solid rgba(201,168,76,.15);
  border-bottom: 1px solid rgba(201,168,76,.15);
  background: rgba(201,168,76,.04);
  font-family: var(--font-body);
  font-size: .6rem;
  font-weight: 600;
  color: var(--gold-dim);
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .3s ease;
  opacity: 0;
}
.section-header:hover .section-collapse-top { opacity: 1; }
.section-collapse-top:hover {
  color: var(--gold);
  background: rgba(201,168,76,.1);
}
.section.collapsed .section-collapse-top { display: none; }

/* ═══════════════════════════════════════════
   NEWS SECTION
═══════════════════════════════════════════ */
.news-container {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.news-featured {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 0;
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all 0.4s ease;
  cursor: pointer;
  min-height: 380px;
}
.news-featured:hover {
  border-color: var(--gold-dim);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 40px rgba(201,168,76,0.05);
  transform: translateY(-4px);
}
.news-featured-img {
  position: relative;
  overflow: hidden;
  background: var(--night-alt);
}
.news-featured-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
  filter: brightness(0.75);
}
.news-featured:hover .news-featured-img img { transform: scale(1.04); }
.news-featured-img-placeholder {
  width: 100%; height: 100%;
  min-height: 380px;
  background: linear-gradient(135deg, var(--night-alt), var(--blue-deep));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 4rem;
  color: var(--gold-dim);
}
.news-pin-badge {
  position: absolute;
  top: 20px; left: 20px;
  background: var(--gold);
  color: var(--night);
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
  font-weight: 600;
}
.news-featured-body {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-left: 1px solid var(--border);
}
.news-meta {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.news-author {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: none;
}
.news-card-title {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.5vw, 1.7rem);
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 20px;
}
.news-excerpt {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 32px;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-read-more {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  display: flex;
  align-items: center;
  gap: 8px;
  transition: gap var(--transition);
}
.news-read-more::after {
  content: '→';
  transition: transform var(--transition);
}
.news-featured:hover .news-read-more { gap: 14px; }
.news-featured:hover .news-read-more::after { transform: translateX(4px); }

.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.news-card {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all 0.4s ease;
  display: flex;
  flex-direction: column;
}
.news-card:hover {
  border-color: var(--gold-dim);
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(201,168,76,0.05);
}
.news-card-img {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--night-alt);
}
.news-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.75);
  transition: transform 0.5s ease;
}
.news-card:hover .news-card-img img { transform: scale(1.06); }
.news-card-img-placeholder {
  width: 100%; height: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--night-alt), var(--blue-deep));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 2.5rem;
  color: var(--gold-dim);
}
.img-fallback-ph {
  width: 100%; height: 100%;
  min-height: 120px;
  background: linear-gradient(135deg, var(--night-alt), var(--blue-deep));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 2.5rem;
  color: var(--gold-dim);
}
.news-card-body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.news-card-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--text);
  line-height: 1.5;
  margin-bottom: 12px;
}
.news-card-excerpt {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-muted);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-read-more {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--gold);
  margin-top: 8px;
  cursor: pointer;
  transition: color 0.2s;
}
.news-read-more:hover { color: var(--gold-bright); }
.news-empty {
  text-align: center;
  padding: 80px 40px;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-style: italic;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

/* ═══════════════════════════════════════════
   WAR GALLERY
═══════════════════════════════════════════ */
.section-war-wrap {
  background: linear-gradient(180deg, transparent, rgba(7,9,26,0.5), transparent);
}
.war-header-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 16px;
}
.war-counter {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: var(--text-muted);
  border: 1px solid var(--border);
  padding: 5px 16px;
  border-radius: 2px;
}
.war-counter span { color: var(--gold); }
.war-grid {
  columns: 3;
  column-gap: 16px;
  margin-top: clamp(40px,5vw,60px);
}
.war-item {
  break-inside: avoid;
  margin-bottom: 16px;
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.4s ease;
  min-height: 120px;
  background: var(--night-alt);
}
.war-item:hover {
  border-color: var(--gold-dim);
  box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
.war-item img {
  width: 100%;
  display: block;
  filter: brightness(0.8);
  transition: all 0.5s ease;
}
.war-item:hover img {
  transform: scale(1.04);
  filter: brightness(1);
}
.war-item-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(4,6,15,0.8) 0%, transparent 60%);
  display: flex;
  align-items: flex-end;
  padding: 16px;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.war-item:hover .war-item-overlay { opacity: 1; }
.war-item-title {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  color: var(--gold-bright);
}
.war-empty {
  text-align: center;
  padding: 80px;
  color: var(--text-muted);
  font-style: italic;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

/* ═══════════════════════════════════════════
   MEMBERS
═══════════════════════════════════════════ */
.members-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 14px;
}
.members-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
}
.members-search-input {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 5px 10px;
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 0.75rem;
  outline: none;
  width: 140px;
  transition: border-color 0.3s, width 0.3s;
}
.members-search-input:focus {
  border-color: var(--gold-dim);
  width: 200px;
}
.members-count {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--text-dim);
}
.members-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(92px, 1fr));
  gap: 10px;
  overflow: visible;
}
.member-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 16px 8px 14px;
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: all 0.3s ease;
  text-align: center;
  cursor: pointer;
  overflow: visible;
}
.member-card:hover {
  border-color: var(--gold-dim);
  box-shadow: 0 0 24px rgba(201,168,76,0.08), 0 8px 24px rgba(0,0,0,0.28);
  transform: translateY(-3px);
}
.member-avatar-wrap {
  position: relative;
  width: 50px;
  height: 50px;
  overflow: visible;
}
.member-avatar-ring {
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid var(--gold-dim);
  transition: all 0.3s ease;
}
.member-avatar-wrap[class*="frame-"] .member-avatar-ring { display: none; }
.member-card:hover .member-avatar-ring {
  border-color: var(--gold);
  box-shadow: 0 0 12px rgba(201,168,76,0.3);
}
.member-avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--night-lift);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.member-avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
.member-avatar-placeholder {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--night-lift), var(--blue-deep));
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--gold-dim);
}
.member-role-badge {
  position: absolute;
  bottom: -3px;
  right: -3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--night-card);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.44rem;
  font-family: var(--font-ui);
  font-weight: 800;
  color: #fff;
  z-index: 6;
  letter-spacing: 0;
  line-height: 1;
}
.role-president    { background: linear-gradient(135deg, #B8942A, #E8C96A); }
.role-vice         { background: linear-gradient(135deg, #3A6DB5, #5B8FD9); }
.role-stratege     { background: linear-gradient(135deg, #6B4DB5, #9B77E0); }
.role-admin        { background: linear-gradient(135deg, #1E8A82, #3DBBB0); }
/* ── Mourning badge — 🖤 (expires automatically) ── */
.mourning-ribbon {
  position: absolute;
  top: -5px; right: -5px;
  width: 22px; height: 22px;
  background: #06060e;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  line-height: 1;
  pointer-events: none;
  z-index: 4;
  border: 1.5px solid rgba(255,255,255,0.10);
  box-shadow: 0 2px 10px rgba(0,0,0,0.9), 0 0 0 1px rgba(0,0,0,0.5);
}
/* Larger badge in profile modal (96px avatar) */
.mp-avatar-wrap .mourning-ribbon {
  width: 32px; height: 32px;
  font-size: 17px;
  top: -6px; right: -6px;
}
/* Desaturate + darken avatar when mourning badge is present */
.member-avatar-wrap:has(.mourning-ribbon) .member-avatar img,
.member-avatar-wrap:has(.mourning-ribbon) .member-avatar-placeholder {
  filter: grayscale(55%) brightness(0.78);
  transition: filter 0.4s ease;
}
.mp-avatar-wrap:has(.mourning-ribbon) .mp-avatar {
  filter: grayscale(55%) brightness(0.78);
  transition: filter 0.4s ease;
}
/* Online presence dot */
.member-online-dot {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #00e676;
  border: 2.5px solid var(--night-card);
  box-shadow: 0 0 10px rgba(0,230,118,0.7), 0 0 24px rgba(0,230,118,0.4), 0 0 40px rgba(0,230,118,0.2);
  z-index: 6;
  animation: onlinePulse 1.5s ease-in-out infinite;
}
@keyframes onlinePulse {
  0%, 100% { box-shadow: 0 0 10px rgba(0,230,118,0.7), 0 0 24px rgba(0,230,118,0.4), 0 0 40px rgba(0,230,118,0.2); transform: scale(1); }
  50% { box-shadow: 0 0 16px rgba(0,230,118,0.9), 0 0 36px rgba(0,230,118,0.6), 0 0 56px rgba(0,230,118,0.3); transform: scale(1.15); }
}
/* XP & Level */
.member-level-badge {
  position: absolute; bottom: -4px; left: 50%; transform: translateX(-50%);
  background: linear-gradient(135deg, #7c5ce0, #5b3abf); color: #fff;
  font-family: var(--font-ui); font-size: .55rem; font-weight: 700;
  padding: 1px 7px; border-radius: 10px; z-index: 6;
  border: 1.5px solid var(--night-card); letter-spacing: .04em;
  white-space: nowrap;
}
.member-level-badge.lvl-high { background: linear-gradient(135deg, #f7b733, #fc4a1a); }
.member-level-badge.lvl-legend { background: linear-gradient(135deg, #ffd700, #ff6b6b); animation: legendPulse 2s infinite; }
@keyframes legendPulse { 0%,100%{ box-shadow: 0 0 6px rgba(255,215,0,.4); } 50%{ box-shadow: 0 0 14px rgba(255,215,0,.8); } }
.xp-bar-wrap { width: 100%; height: 3px; background: rgba(255,255,255,.08); border-radius: 2px; margin-top: 4px; overflow: hidden; }
.xp-bar-fill { height: 100%; background: linear-gradient(90deg, #7c5ce0, #b57edc); border-radius: 2px; transition: width .6s ease; }
/* Profile XP */
.mp-xp-section { margin-top: 16px; padding: 14px; background: rgba(124,92,224,.06); border: 1px solid rgba(124,92,224,.15); border-radius: var(--radius-lg); }
.mp-xp-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.mp-xp-level { font-family: var(--font-display); font-size: 1rem; color: #b57edc; font-weight: 700; }
.mp-xp-amount { font-family: var(--font-ui); font-size: .72rem; color: var(--text-muted); }
.mp-xp-bar { width: 100%; height: 6px; background: rgba(255,255,255,.08); border-radius: 4px; overflow: hidden; }
.mp-xp-bar-fill { height: 100%; background: linear-gradient(90deg, #7c5ce0, #b57edc); border-radius: 4px; transition: width .8s ease; }
/* Achievements */
.mp-achievements { margin-top: 12px; }
.mp-achievements-title { font-family: var(--font-ui); font-size: .7rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 8px; }
.mp-badges-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.mp-badge { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1rem; border: 1.5px solid rgba(255,255,255,.1); background: rgba(255,255,255,.03); position: relative; cursor: default; transition: all .3s; }
.mp-badge.unlocked { border-color: rgba(124,92,224,.4); background: rgba(124,92,224,.1); }
.mp-badge.locked { opacity: .3; filter: grayscale(1); }
.mp-badge:hover .mp-badge-tip { display: block; }
.mp-badge-tip { display: none; position: absolute; bottom: 110%; left: 50%; transform: translateX(-50%); background: var(--night-card); border: 1px solid var(--border); border-radius: 8px; padding: 6px 10px; font-size: .65rem; white-space: nowrap; z-index: 100; color: var(--text); pointer-events: none; }
/* Top Sections on member profile */
.mp-top-sections { padding: 12px 16px; border-top: 1px solid rgba(255,255,255,.06); }
.mp-top-sections-list { display: flex; flex-direction: column; gap: 4px; }
.mp-top-section-item { display: flex; align-items: center; gap: 8px; padding: 5px 8px; border-radius: 8px; background: rgba(255,255,255,.03); font-family: var(--font-ui); font-size: .75rem; }
.mp-top-section-rank { color: var(--gold); font-weight: 700; min-width: 22px; }
.mp-top-section-icon { font-size: .85rem; }
.mp-top-section-name { flex: 1; color: var(--text); }
.mp-top-section-count { color: var(--text-muted); font-size: .65rem; font-variant-numeric: tabular-nums; }
/* Leaderboard */
.members-view-toggle { display: flex; gap: 4px; }
.members-view-btn { background: rgba(255,255,255,.05); border: 1px solid var(--border); color: var(--text-muted); font-family: var(--font-ui); font-size: .72rem; font-weight: 600; padding: 5px 12px; border-radius: 8px; cursor: pointer; transition: all .2s; }
.members-view-btn.active { background: rgba(124,92,224,.15); border-color: rgba(124,92,224,.4); color: #b57edc; }
.members-view-btn:hover { background: rgba(124,92,224,.1); }
.leaderboard-wrap { display: none; width: 100%; max-width: 600px; margin: 0 auto; }
.leaderboard-wrap.visible { display: block; }
.lb-row { display: flex; align-items: center; gap: 12px; padding: 10px 14px; border-radius: var(--radius-lg); background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.04); margin-bottom: 6px; cursor: pointer; transition: all .2s; }
.lb-row:hover { background: rgba(124,92,224,.07); border-color: rgba(124,92,224,.2); }
.lb-rank { font-family: var(--font-display); font-size: 1.1rem; font-weight: 800; min-width: 32px; text-align: center; color: var(--text-muted); }
.lb-rank-1 { color: #ffd700; text-shadow: 0 0 8px rgba(255,215,0,.5); font-size: 1.3rem; }
.lb-rank-2 { color: #c0c0c0; text-shadow: 0 0 6px rgba(192,192,192,.4); font-size: 1.2rem; }
.lb-rank-3 { color: #cd7f32; text-shadow: 0 0 6px rgba(205,127,50,.4); font-size: 1.15rem; }
.lb-avatar { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,255,255,.08); flex-shrink: 0; }
.lb-avatar-ph { width: 38px; height: 38px; border-radius: 50%; background: var(--night-card); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: .9rem; color: var(--text-muted); border: 2px solid rgba(255,255,255,.08); flex-shrink: 0; }
.lb-info { flex: 1; min-width: 0; }
.lb-name { font-family: var(--font-display); font-size: .85rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lb-detail { font-family: var(--font-ui); font-size: .65rem; color: var(--text-muted); margin-top: 1px; }
.lb-xp-col { text-align: right; flex-shrink: 0; }
.lb-xp { font-family: var(--font-display); font-size: .9rem; font-weight: 800; color: #b57edc; }
.lb-level { font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted); margin-top: 1px; }
.lb-bar { width: 60px; height: 4px; background: rgba(255,255,255,.06); border-radius: 3px; overflow: hidden; margin-top: 3px; }
.lb-bar-fill { height: 100%; background: linear-gradient(90deg, #7c5ce0, #b57edc); border-radius: 3px; }
.lb-row.lb-top1 { background: linear-gradient(135deg, rgba(255,215,0,.06), rgba(255,215,0,.02)); border-color: rgba(255,215,0,.15); }
.lb-row.lb-top2 { background: linear-gradient(135deg, rgba(192,192,192,.05), rgba(192,192,192,.02)); border-color: rgba(192,192,192,.1); }
.lb-row.lb-top3 { background: linear-gradient(135deg, rgba(205,127,50,.05), rgba(205,127,50,.02)); border-color: rgba(205,127,50,.1); }
.lb-medal { font-size: 1.1rem; }
/* Duels */
.duel-section { max-width: 600px; margin: 0 auto; }
.duel-challenge-btn { background: linear-gradient(135deg, #7c5ce0, #5b3abf); color: #fff; border: none; padding: 8px 16px; border-radius: 8px; font-family: var(--font-ui); font-size: .75rem; font-weight: 600; cursor: pointer; transition: all .2s; }
.duel-challenge-btn:hover { transform: scale(1.05); box-shadow: 0 4px 15px rgba(124,92,224,.3); }
.duel-card { background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px; margin-bottom: 10px; }
.duel-card.pending { border-color: rgba(255,215,0,.3); }
.duel-vs { text-align: center; font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; color: #b57edc; margin: 8px 0; }
.duel-players { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.duel-player { text-align: center; flex: 1; }
.duel-player-name { font-family: var(--font-display); font-size: .85rem; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.duel-move { font-size: 2.5rem; margin: 8px 0; min-height: 50px; display: flex; align-items: center; justify-content: center; }
.duel-move-btns { display: flex; gap: 8px; justify-content: center; margin-top: 10px; }
.duel-move-btn { width: 60px; height: 60px; border-radius: 50%; border: 2px solid var(--border); background: rgba(255,255,255,.03); font-size: 1.8rem; cursor: pointer; transition: all .3s; display: flex; align-items: center; justify-content: center; }
.duel-move-btn:hover { border-color: #7c5ce0; background: rgba(124,92,224,.1); transform: scale(1.15); }
.duel-result { text-align: center; font-family: var(--font-display); font-size: 1rem; font-weight: 700; margin-top: 8px; padding: 8px; border-radius: 8px; }
.duel-result.win { color: #4caf50; background: rgba(76,175,80,.08); }
.duel-result.lose { color: #f44336; background: rgba(244,67,54,.08); }
.duel-result.draw { color: #ff9800; background: rgba(255,152,0,.08); }
.duel-anim { animation: duelShake .5s ease-in-out; }
@keyframes duelShake { 0%,100%{transform:rotate(0)} 25%{transform:rotate(-10deg)} 75%{transform:rotate(10deg)} }
.duel-reveal { animation: duelReveal .6s ease-out; }
@keyframes duelReveal { 0%{transform:scale(0);opacity:0} 60%{transform:scale(1.3)} 100%{transform:scale(1);opacity:1} }
.duel-card.win { border-color: rgba(76,175,80,.2); }
.duel-card.lose { border-color: rgba(244,67,54,.15); }
.duel-card.draw { border-color: rgba(255,152,0,.15); }
.duel-choose-label { font-family: var(--font-ui); font-size: .65rem; color: #ffd700; margin-bottom: 6px; font-weight: 600; }
.duel-intro-box { text-align: center; margin-bottom: 24px; padding: 20px; background: linear-gradient(135deg, rgba(124,92,224,.06), rgba(201,168,76,.04)); border: 1px solid rgba(124,92,224,.15); border-radius: var(--radius-lg); }
.duel-intro-text { color: var(--text-muted); font-family: var(--font-ui); font-size: .8rem; margin-bottom: 16px; line-height: 1.5; }
.duel-howto { background: rgba(0,0,0,.15); border-radius: 10px; padding: 16px; text-align: left; }
.duel-howto-title { font-family: var(--font-display); font-size: .85rem; color: var(--text); margin-bottom: 12px; text-align: center; }
.duel-howto-steps { display: flex; flex-direction: column; gap: 8px; }
.duel-howto-step { display: flex; align-items: center; gap: 10px; font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted); line-height: 1.4; }
.duel-step-num { flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%; background: linear-gradient(135deg, #7c5ce0, #b57edc); color: #fff; font-size: .7rem; font-weight: 700; display: flex; align-items: center; justify-content: center; }

/* Quests */
.quests-section { max-width: 600px; margin: 0 auto; }
.quests-tabs { display: flex; gap: 4px; margin-bottom: 16px; }
.quest-tab { background: rgba(255,255,255,.05); border: 1px solid var(--border); color: var(--text-muted); font-family: var(--font-ui); font-size: .72rem; font-weight: 600; padding: 6px 14px; border-radius: 8px; cursor: pointer; transition: all .2s; }
.quest-tab.active { background: rgba(124,92,224,.15); border-color: rgba(124,92,224,.4); color: #b57edc; }
.quest-card { display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.05); border-radius: var(--radius-lg); padding: 12px 14px; margin-bottom: 8px; transition: all .2s; }
.quest-card.completed { border-color: rgba(76,175,80,.2); background: rgba(76,175,80,.03); }
.quest-card.claimed { opacity: .5; }
.quest-icon { font-size: 1.5rem; flex-shrink: 0; width: 40px; text-align: center; }
.quest-info { flex: 1; min-width: 0; }
.quest-name { font-family: var(--font-display); font-size: .82rem; font-weight: 700; color: var(--text); }
.quest-desc { font-family: var(--font-ui); font-size: .65rem; color: var(--text-muted); margin-top: 2px; }
.quest-progress-wrap { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
.quest-progress-bar { flex: 1; height: 5px; background: rgba(255,255,255,.06); border-radius: 3px; overflow: hidden; }
.quest-progress-fill { height: 100%; background: linear-gradient(90deg, #7c5ce0, #b57edc); border-radius: 3px; transition: width .4s ease; }
.quest-progress-text { font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted); white-space: nowrap; }
.quest-reward { flex-shrink: 0; text-align: center; }
.quest-xp { font-family: var(--font-display); font-size: .8rem; font-weight: 700; color: #b57edc; }
.quest-claim-btn { background: linear-gradient(135deg, #4caf50, #2e7d32); color: #fff; border: none; padding: 4px 10px; border-radius: 6px; font-size: .65rem; font-weight: 600; cursor: pointer; margin-top: 4px; animation: questPulse 1.5s infinite; }
@keyframes questPulse { 0%,100%{box-shadow:0 0 4px rgba(76,175,80,.3)} 50%{box-shadow:0 0 12px rgba(76,175,80,.6)} }

/* Quiz */
.quiz-section { max-width: 600px; margin: 0 auto; }
.quiz-start-wrap { text-align: center; padding: 40px 20px; }
.quiz-start-btn { background: linear-gradient(135deg, #7c5ce0, #5b3abf); color: #fff; border: none; padding: 14px 32px; border-radius: 12px; font-family: var(--font-display); font-size: 1rem; font-weight: 700; cursor: pointer; transition: all .3s; }
.quiz-start-btn:hover { transform: scale(1.05); box-shadow: 0 6px 20px rgba(124,92,224,.4); }
.quiz-question-wrap { background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 20px; margin-bottom: 12px; }
.quiz-progress { font-family: var(--font-ui); font-size: .7rem; color: var(--text-muted); margin-bottom: 8px; }
.quiz-question { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--text); margin-bottom: 16px; line-height: 1.4; }
.quiz-choices { display: flex; flex-direction: column; gap: 8px; }
.quiz-choice { background: rgba(255,255,255,.03); border: 1.5px solid rgba(255,255,255,.08); border-radius: 10px; padding: 12px 16px; cursor: pointer; font-family: var(--font-ui); font-size: .82rem; color: var(--text); transition: all .2s; }
.quiz-choice:hover { border-color: rgba(124,92,224,.4); background: rgba(124,92,224,.06); }
.quiz-choice.selected { border-color: #7c5ce0; background: rgba(124,92,224,.12); }
.quiz-choice.correct { border-color: #4caf50; background: rgba(76,175,80,.1); color: #4caf50; }
.quiz-choice.wrong { border-color: #f44336; background: rgba(244,67,54,.08); color: #f44336; }
.quiz-next-btn { display: block; margin: 16px auto 0; background: linear-gradient(135deg, #7c5ce0, #5b3abf); color: #fff; border: none; padding: 10px 24px; border-radius: 8px; font-family: var(--font-ui); font-size: .8rem; font-weight: 600; cursor: pointer; }
.quiz-results { text-align: center; padding: 30px; }
.quiz-score { font-family: var(--font-display); font-size: 2.5rem; font-weight: 800; color: #b57edc; }
.quiz-score-label { font-family: var(--font-ui); font-size: .8rem; color: var(--text-muted); margin-top: 4px; }
.quiz-xp-earned { font-family: var(--font-display); font-size: 1.2rem; color: #4caf50; margin-top: 8px; }

/* Zodiac Houses */
.houses-section { max-width: 800px; margin: 0 auto; }
.houses-map { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 24px; }
@media (max-width: 600px) { .houses-map { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 400px) { .houses-map { grid-template-columns: repeat(2, 1fr); } }
.house-card { background: rgba(255,255,255,.02); border: 2px solid rgba(255,255,255,.06); border-radius: var(--radius-lg); padding: 14px 8px; text-align: center; cursor: pointer; transition: all .3s; position: relative; overflow: hidden; }
.house-card:hover { transform: translateY(-3px); box-shadow: 0 6px 20px rgba(0,0,0,.3); }
.house-card.my-house { border-color: rgba(124,92,224,.5); background: rgba(124,92,224,.06); }
.house-card.top-house::before { content: '👑'; position: absolute; top: 4px; right: 6px; font-size: .7rem; }
.house-icon { font-size: 2rem; margin-bottom: 4px; }
.house-name { font-family: var(--font-display); font-size: .75rem; font-weight: 700; color: var(--text); margin-bottom: 2px; }
.house-guardian { font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted); }
.house-stats { display: flex; justify-content: center; gap: 8px; margin-top: 8px; font-family: var(--font-ui); font-size: .6rem; }
.house-stat { color: var(--text-muted); }
.house-stat strong { color: #b57edc; }
.house-join-btn { background: linear-gradient(135deg, #7c5ce0, #5b3abf); color: #fff; border: none; padding: 4px 12px; border-radius: 6px; font-size: .6rem; font-weight: 600; cursor: pointer; margin-top: 8px; transition: all .2s; }
.house-join-btn:hover { transform: scale(1.05); }
.house-members-list { display: flex; flex-wrap: wrap; gap: 4px; justify-content: center; margin-top: 6px; }
.house-member-avatar { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; border: 1px solid rgba(255,255,255,.1); }
.house-ranking { margin-top: 20px; }
.house-rank-row { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 8px; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.03); margin-bottom: 4px; }
.house-rank-pos { font-family: var(--font-display); font-weight: 800; min-width: 24px; text-align: center; }
.house-rank-icon { font-size: 1.2rem; }
.house-rank-name { font-family: var(--font-display); font-size: .8rem; font-weight: 700; flex: 1; }
.house-rank-xp { font-family: var(--font-ui); font-size: .7rem; color: #b57edc; font-weight: 700; }
.house-rank-members { font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted); }

/* Achievement unlock popup */
#achievement-popup { position: fixed; top: 80px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; pointer-events: none; }
.ach-toast { background: linear-gradient(135deg, rgba(124,92,224,.15), rgba(181,126,220,.1)); border: 1px solid rgba(124,92,224,.4); border-radius: 14px; padding: 12px 18px; display: flex; align-items: center; gap: 10px; font-family: var(--font-ui); box-shadow: 0 8px 32px rgba(0,0,0,.4); animation: achSlideIn .5s ease, achFadeOut .5s ease 4s forwards; pointer-events: auto; -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); }
.ach-toast-icon { font-size: 1.5rem; }
.ach-toast-info { display: flex; flex-direction: column; }
.ach-toast-label { font-size: .6rem; text-transform: uppercase; letter-spacing: .1em; color: #b57edc; font-weight: 600; }
.ach-toast-name { font-size: .85rem; color: var(--text); font-weight: 600; }
@keyframes achSlideIn { from { opacity:0; transform: translateX(60px); } to { opacity:1; transform: none; } }
@keyframes achFadeOut { from { opacity:1; } to { opacity:0; transform: translateX(60px); } }
/* Dashboard */
.dash-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 900px; margin: 0 auto; }
@media(max-width:700px) { .dash-grid { grid-template-columns: 1fr; } }
.dash-card { background: var(--night-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 20px; }
.dash-card-title { font-family: var(--font-ui); font-size: .7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--text-muted); margin-bottom: 12px; }
.dash-xp-big { font-family: var(--font-display); font-size: 2.5rem; color: #b57edc; font-weight: 700; line-height: 1; }
.dash-xp-sub { font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted); margin-top: 4px; }
.dash-xp-bar { width: 100%; height: 8px; background: rgba(255,255,255,.08); border-radius: 4px; margin-top: 10px; overflow: hidden; }
.dash-xp-fill { height: 100%; background: linear-gradient(90deg, #7c5ce0, #b57edc); border-radius: 4px; }
.dash-stat-row { display: flex; justify-content: space-around; text-align: center; margin-top: 12px; }
.dash-stat-num { font-family: var(--font-display); font-size: 1.4rem; color: var(--gold); }
.dash-stat-label { font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .08em; }
.dash-rank-num { font-family: var(--font-display); font-size: 3rem; color: var(--gold); font-weight: 700; }
.dash-badges-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.dash-badge { width: 42px; height: 42px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; border: 1.5px solid rgba(124,92,224,.3); background: rgba(124,92,224,.08); position: relative; cursor: default; }
.dash-badge.locked { opacity: .25; filter: grayscale(1); border-color: rgba(255,255,255,.1); background: rgba(255,255,255,.03); }
.dash-badge:hover .mp-badge-tip { display: block; }
.dash-heatmap { display: flex; gap: 2px; flex-wrap: wrap; justify-content: center; }
.dash-heat-day { width: 12px; height: 12px; border-radius: 2px; background: rgba(255,255,255,.04); }
.dash-heat-day.h1 { background: rgba(124,92,224,.2); }
.dash-heat-day.h2 { background: rgba(124,92,224,.4); }
.dash-heat-day.h3 { background: rgba(124,92,224,.6); }
.dash-heat-day.h4 { background: rgba(124,92,224,.9); }
.dash-recent { max-height: 300px; overflow-y: auto; }
.dash-recent-item { padding: 8px 0; border-bottom: 1px solid var(--border); font-size: .8rem; color: var(--text); }
.dash-recent-item:last-child { border-bottom: none; }
.dash-recent-meta { font-size: .65rem; color: var(--text-muted); }
/* Online members banner */
/* Birthday banner */
.birthday-banner {
  display: none;
  padding: 12px 24px;
  background: linear-gradient(135deg, rgba(255,215,0,0.08), rgba(255,165,0,0.06));
  border: 1px solid rgba(255,215,0,0.25);
  border-radius: var(--radius-lg);
  margin: 0 auto 14px;
  max-width: 900px;
  text-align: center;
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  font-size: 0.9rem;
  color: var(--gold);
  font-weight: 600;
  animation: birthdayGlow 3s ease-in-out infinite;
}
.birthday-banner.visible { display: block; }
@keyframes birthdayGlow {
  0%, 100% { border-color: rgba(255,215,0,0.25); }
  50% { border-color: rgba(255,215,0,0.5); }
}

.online-banner {
  display: none;
  position: sticky;
  top: 64px;
  z-index: 50;
  pointer-events: auto;
  padding: 10px 24px;
  background: rgba(4,6,15,.95);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  margin: 0 auto 18px;
  max-width: 900px;
  text-align: center;
}
.online-banner * { position: relative; z-index: 1; }
.online-banner.visible { display: block; }
.online-banner-title {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.online-banner-title::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--online);
  box-shadow: 0 0 6px var(--online-glow);
  animation: onlinePulse 2s ease-in-out infinite;
}
.online-count {
  font-size: .85rem;
  font-weight: 700;
  color: var(--online);
  text-shadow: 0 0 6px var(--online-glow);
}
.online-banner-names {
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.6;
}
.online-banner-names span {
  display: inline-block;
  padding: 2px 10px;
  margin: 3px 4px;
  background: var(--gold-subtle);
  border: 1px solid var(--border);
  border-radius: 20px;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  position: relative;
  z-index: 2;
  transition: all 0.3s ease;
}
.online-banner-names span * { pointer-events: none; }
.online-banner-names span .activity-badge { pointer-events: auto; cursor: pointer; }
.online-banner-names span .activity-badge:hover { opacity: 0.75; }
.online-banner-names span:hover {
  background: var(--gold-glow);
  border-color: var(--border-hover);
}
/* ═══ Group styles for online banner ═══ */
@keyframes groupShimmer {
  0% { background-position: -200% center; }
  100% { background-position: 200% center; }
}
@keyframes groupFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
@keyframes badgeBounce {
  0%, 100% { transform: scale(1) rotate(0deg); }
  25% { transform: scale(1.15) rotate(-6deg); }
  75% { transform: scale(1.15) rotate(6deg); }
}
.group-badge {
  display: inline-block;
  font-size: .65em;
  margin-left: 5px;
  vertical-align: middle;
  animation: badgeBounce 3s ease-in-out infinite;
}
/* ── Admin: rouge impérial ── */
.online-banner-names span.group-admin {
  position: relative;
  background: linear-gradient(135deg, rgba(26,58,143,.35), rgba(40,80,180,.18), rgba(26,58,143,.35));
  border: 1.5px solid #2850b4;
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .06em;
  padding: 4px 16px 4px 12px;
  text-shadow: 0 1px 4px rgba(0,0,0,.5), 0 0 8px rgba(26,58,143,.6);
  animation: groupFloat 4s ease-in-out infinite;
  box-shadow: 0 0 10px rgba(26,58,143,.4), 0 0 20px rgba(40,80,180,.2);
  transition: all .35s cubic-bezier(.4,0,.2,1);
  overflow: hidden;
  border-radius: 22px;
}
.online-banner-names span.group-admin::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(40,80,180,.12) 40%, rgba(255,255,255,.18) 50%, rgba(40,80,180,.12) 60%, transparent 100%);
  background-size: 200% 100%;
  animation: groupShimmer 3.5s linear infinite;
  border-radius: inherit;
  pointer-events: none;
}
.online-banner-names span.group-admin:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 0 20px rgba(26,58,143,.5), 0 0 40px rgba(40,80,180,.3), 0 4px 15px rgba(0,0,0,.3);
  border-color: #4a7aff;
}
.online-banner-names span.group-admin .group-badge {
  filter: drop-shadow(0 0 4px rgba(26,58,143,.7));
}
/* ── Membre: or doré (guilde) ── */
.online-banner-names span.group-membre {
  background: linear-gradient(135deg, rgba(201,168,76,.2), rgba(201,168,76,.08), rgba(201,168,76,.2));
  border: 1px solid rgba(201,168,76,.4);
  color: #e8dcc8;
  font-weight: 600;
  letter-spacing: .03em;
  text-shadow: 0 1px 3px rgba(0,0,0,.4);
  transition: all .3s ease;
}
.online-banner-names span.group-membre:hover {
  background: linear-gradient(135deg, rgba(201,168,76,.3), rgba(201,168,76,.15), rgba(201,168,76,.3));
  border-color: rgba(201,168,76,.6);
  transform: translateY(-1px);
  box-shadow: 0 0 10px rgba(201,168,76,.2);
}
/* ── Modo: vert émeraude ── */
.online-banner-names span.group-modo {
  position: relative;
  background: linear-gradient(135deg, rgba(16,120,80,.3), rgba(32,160,100,.15), rgba(16,120,80,.3));
  border: 1.5px solid #1abc7c;
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .06em;
  padding: 4px 16px 4px 12px;
  text-shadow: 0 1px 4px rgba(0,0,0,.5), 0 0 8px rgba(26,188,124,.5);
  animation: groupFloat 4.5s ease-in-out infinite;
  box-shadow: 0 0 10px rgba(26,188,124,.3), 0 0 20px rgba(26,188,124,.15);
  transition: all .35s cubic-bezier(.4,0,.2,1);
  overflow: hidden;
  border-radius: 22px;
}
.online-banner-names span.group-modo::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(26,188,124,.12) 40%, rgba(255,255,255,.18) 50%, rgba(26,188,124,.12) 60%, transparent 100%);
  background-size: 200% 100%;
  animation: groupShimmer 4s linear infinite;
  border-radius: inherit;
  pointer-events: none;
}
.online-banner-names span.group-modo:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 0 20px rgba(26,188,124,.5), 0 0 40px rgba(26,188,124,.25), 0 4px 15px rgba(0,0,0,.3);
  border-color: #2edb9a;
}
.online-banner-names span.group-modo .group-badge {
  filter: drop-shadow(0 0 4px rgba(26,188,124,.7));
}
/* ── VIP: violet améthyste ── */
.online-banner-names span.group-vip {
  position: relative;
  background: linear-gradient(135deg, rgba(128,60,180,.3), rgba(160,80,220,.15), rgba(128,60,180,.3));
  border: 1.5px solid #9b59b6;
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .06em;
  padding: 4px 16px 4px 12px;
  text-shadow: 0 1px 4px rgba(0,0,0,.5), 0 0 8px rgba(155,89,182,.5);
  animation: groupFloat 5s ease-in-out infinite;
  box-shadow: 0 0 10px rgba(155,89,182,.3), 0 0 20px rgba(155,89,182,.15);
  transition: all .35s cubic-bezier(.4,0,.2,1);
  overflow: hidden;
  border-radius: 22px;
}
.online-banner-names span.group-vip::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(155,89,182,.12) 40%, rgba(255,255,255,.18) 50%, rgba(155,89,182,.12) 60%, transparent 100%);
  background-size: 200% 100%;
  animation: groupShimmer 4.5s linear infinite;
  border-radius: inherit;
  pointer-events: none;
}
.online-banner-names span.group-vip:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 0 20px rgba(155,89,182,.5), 0 0 40px rgba(155,89,182,.25), 0 4px 15px rgba(0,0,0,.3);
  border-color: #bb77d4;
}
.online-banner-names span.group-vip .group-badge {
  filter: drop-shadow(0 0 4px rgba(155,89,182,.7));
}
/* ── Visiteurs anonymes ── */
.online-visitors {
  margin-top: 8px; text-align: center;
  font-family: var(--font-ui); font-size: .65rem; letter-spacing: .06em;
  color: var(--text-dim);
}
.online-visitors-dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--text-dim); margin-right: 4px; vertical-align: middle;
  animation: visitorPulse 3s ease-in-out infinite;
}
@keyframes visitorPulse {
  0%, 100% { opacity: .4; }
  50% { opacity: .8; }
}
/* ── Site Voice Rooms inside online banner ── */
.sv-section {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(201,168,76,.15);
}
/* ── Discord Voice inside online banner ── */
.dv-section {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(88,101,242,.15);
}
.dv-section-title {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-family: var(--font-ui); font-size: .7rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: #7289da;
  margin-bottom: 8px;
}
.dv-icon { width: 16px; height: 12px; fill: #7289da; }
.dv-section-channels {
  display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap;
}
.dv-chan {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(88,101,242,.06); border: 1px solid rgba(88,101,242,.12);
  border-radius: 20px; padding: 4px 12px 4px 8px;
}
.dv-chan-icon { color: #43b581; font-size: .8rem; }
.dv-chan-name {
  font-family: var(--font-ui); font-size: .68rem; font-weight: 600;
  color: rgba(88,101,242,.8); letter-spacing: .03em;
}
.dv-chan-members { display: flex; align-items: center; gap: 5px; margin-left: 2px; }
.dv-chan-member {
  display: inline-flex; align-items: center; gap: 3px;
  font-family: var(--font-ui); font-size: .72rem; color: var(--text); font-weight: 500;
}
.dv-chan-av {
  width: 18px; height: 18px; border-radius: 50%;
  border: 1.5px solid rgba(88,101,242,.3); object-fit: cover;
}
.dv-chan-no-av {
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(88,101,242,.15); display: flex; align-items: center; justify-content: center;
  font-size: .45rem; color: #7289da; font-weight: 700;
}
.mercuria-badge {
  display: inline-block;
  font-size: 1.3em;
  margin-left: 4px;
  vertical-align: middle;
  filter: drop-shadow(0 0 6px rgba(255,50,50,.8));
  animation: mercuriaGlow 1s ease-in-out infinite;
}
.activity-badge {
  display: inline-block;
  font-size: .85em;
  margin-left: 2px;
  vertical-align: middle;
  opacity: .6;
}
.mercuria-card-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  margin-left: -1rem;
  font-size: 2rem;
  z-index: 5;
  display: inline-block;
  filter: drop-shadow(0 0 6px rgba(255,50,50,.8)) drop-shadow(0 0 14px rgba(255,0,0,.4));
  animation: mercuriaGlow 1s ease-in-out infinite;
}
@keyframes mercuriaGlow {
  0%, 100% { transform: scale(1); filter: drop-shadow(0 0 4px rgba(255,50,50,.5)); }
  50% { transform: scale(1.25); filter: drop-shadow(0 0 10px rgba(255,50,50,.9)) drop-shadow(0 0 20px rgba(255,0,0,.4)); }
}
.member-name {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--text);
  word-break: break-word;
  line-height: 1.3;
}
.member-rank {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
}
.members-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  justify-content: flex-end;
  align-items: center;
  padding: 0 2px 18px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 20px;
}
.ml-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.ml-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.4rem;
  font-family: var(--font-ui);
  font-weight: 800;
  color: #fff;
  letter-spacing: 0;
  line-height: 1;
  flex-shrink: 0;
}
.ml-online {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #00e676;
  box-shadow: 0 0 6px rgba(0,230,118,0.5);
  animation: onlinePulse 2s ease-in-out infinite;
  border: none;
  font-size: 0;
}
.members-empty {
  grid-column: 1/-1;
  text-align: center;
  padding: 80px;
  color: var(--text-muted);
  font-style: italic;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
/* ── Member Profile Modal ── */
.member-modal {
  display: none;
  position: fixed; inset: 0; z-index: 3000;
  background: rgba(4,6,15,0.88);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  padding: 48px 20px 60px;
  overflow-y: auto;
}
.member-modal.open {
  display: flex; align-items: flex-start; justify-content: center;
}
.mp-panel {
  position: relative;
  background: var(--night-card);
  border: 1px solid var(--gold-dim);
  border-radius: var(--radius-lg);
  width: 100%; max-width: 500px;
  padding: 44px 40px 36px;
  animation: mpSlideIn 0.28s cubic-bezier(0.16,1,0.3,1);
  box-shadow: 0 32px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(201,168,76,0.08);
  overscroll-behavior: contain;
}
@keyframes mpSlideIn {
  from { opacity:0; transform:translateY(-18px) scale(0.98); }
  to   { opacity:1; transform:translateY(0)     scale(1); }
}
.mp-close {
  position: absolute; top: 14px; right: 14px;
  background: none; border: none; color: var(--text-dim);
  font-size: 1rem; cursor: pointer; width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; transition: all 0.2s; line-height: 1;
}
.mp-close:hover { color: var(--text); background: var(--night-lift); }
/* Modal — header */
.mp-header {
  display: flex; align-items: center; gap: 22px;
  margin-bottom: 26px; padding-bottom: 22px;
  border-bottom: 1px solid var(--border);
}
.mp-avatar-wrap { position: relative; flex-shrink: 0; }
.mp-avatar {
  width: 96px; height: 96px; border-radius: 50%;
  object-fit: cover; display: block;
}
.mp-avatar-ph {
  width: 96px; height: 96px; border-radius: 50%;
  background: linear-gradient(135deg, var(--night-lift) 0%, var(--blue-deep) 100%);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 2.2rem; color: var(--gold-dim);
}
.mp-avatar-ring {
  position: absolute; inset: -5px; border-radius: 50%;
  border: 1px solid var(--gold-dim); pointer-events: none;
  transition: border-color 0.3s;
}
.mp-identity { min-width: 0; }
.mp-name {
  font-family: var(--font-display); font-size: 1.25rem;
  font-weight: 500; letter-spacing: 0.12em;
  color: var(--text); margin: 0 0 7px; line-height: 1.2;
}
.mp-online-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 6px rgba(34,197,94,0.6);
  margin-left: 8px;
  vertical-align: middle;
  animation: profileOnlinePulse 2s ease-in-out infinite;
}
@keyframes profileOnlinePulse {
  0%, 100% { box-shadow: 0 0 6px rgba(34,197,94,0.4); }
  50% { box-shadow: 0 0 12px rgba(34,197,94,0.8); }
}
.mp-rank {
  font-family: var(--font-ui); font-size: 0.62rem; letter-spacing: 0.25em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 4px;
}
.mp-funzione {
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.1em;
  color: var(--text-muted);
}
/* Modal — info body */
.mp-body { display: flex; flex-direction: column; gap: 18px; }
.mp-section-label {
  font-family: var(--font-ui); font-size: 0.6rem; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--gold-dim); margin-bottom: 9px;
}
.mp-tags { display: flex; flex-wrap: wrap; gap: 7px; }
.mp-tag {
  font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.06em;
  color: var(--text); background: var(--night-lift);
  border: 1px solid var(--border); border-radius: 2px;
  padding: 4px 13px;
}
.mp-info-text {
  font-family: var(--font-body); font-size: 0.85rem;
  color: var(--text-muted); line-height: 1.55;
}
.mp-best-moment {
  font-style: italic;
  color: var(--text);
  border-left: 2px solid var(--gold-dim);
  padding-left: 10px;
  white-space: pre-wrap;
}
.mp-empty {
  font-family: var(--font-body); font-size: 0.85rem;
  color: var(--text-dim); font-style: italic;
  text-align: center; padding: 16px 0;
}
/* Modal — footer / edit button */
.mp-footer {
  margin-top: 24px; padding-top: 18px;
  border-top: 1px solid var(--border);
}
.mp-edit-btn {
  width: 100%;
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gold);
  border: 1px solid var(--gold-dim); background: none;
  padding: 10px 20px; border-radius: 2px; cursor: pointer;
  transition: all 0.3s ease;
}
.mp-edit-btn:hover { background: var(--gold-subtle); border-color: var(--gold); }
/* Modal — edit form */
.mp-edit-form { display: flex; flex-direction: column; gap: 18px; }
.mp-avatar-edit {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding-bottom: 22px; margin-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
.mp-avatar-upload-btn {
  font-family: var(--font-ui); font-size: 0.68rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--text-dim);
  border: 1px dashed var(--border); background: none;
  padding: 6px 18px; border-radius: 2px; cursor: pointer;
  transition: all 0.3s ease; display: inline-block;
}
.mp-avatar-upload-btn:hover { border-color: var(--gold-dim); color: var(--gold-dim); }
.mp-field-group { display: flex; flex-direction: column; gap: 7px; }
.mp-label {
  font-family: var(--font-ui); font-size: 0.6rem; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--gold-dim);
}
.mp-input {
  background: var(--night-deep); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 9px 14px;
  color: var(--text); font-family: var(--font-body); font-size: 0.85rem;
  transition: border-color 0.3s; outline: none;
  width: 100%; box-sizing: border-box;
}
.mp-input:focus { border-color: var(--gold-dim); }
.mp-textarea { resize: vertical; min-height: 68px; }
#mp-best-moment { min-height: 100px; }
.mp-triple { display: flex; flex-direction: column; gap: 6px; }
.mp-five   { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.mp-actions {
  display: flex; gap: 10px;
  padding-top: 14px; border-top: 1px solid var(--border);
}
.mp-cancel-btn {
  flex: 1;
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-muted);
  border: 1px solid var(--border); background: none;
  padding: 10px; border-radius: 2px; cursor: pointer; transition: all 0.2s;
}
.mp-cancel-btn:hover { border-color: var(--text-dim); color: var(--text); }
.mp-save-btn {
  flex: 2;
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--night-deep);
  background: var(--gold); border: none;
  padding: 10px 20px; border-radius: 2px; cursor: pointer; transition: all 0.2s;
}
.mp-save-btn:hover:not(:disabled) { background: #e8c85a; }
.mp-save-btn:disabled { opacity: 0.6; cursor: default; }
@media (max-width: 600px) {
  .mp-panel { padding: 36px 20px 28px; }
  .mp-header { gap: 16px; }
  .mp-avatar, .mp-avatar-ph { width: 72px; height: 72px; }
  .mp-avatar-ph { font-size: 1.6rem; }
}

/* ═══════════════════════════════════════════
   TEAMS / ARAYA / SONGS
═══════════════════════════════════════════ */
.section-coming-soon {
  text-align: center; padding: 80px 40px; color: var(--text-muted);
  font-family: var(--font-body); font-style: italic; font-size: 1.1rem;
  border: 1px solid var(--border); border-radius: var(--radius-lg);
}
.teams-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}
.team-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 0; overflow: hidden; transition: all 0.4s ease;
}
.team-card-body { padding: 28px 24px; }
.team-card-img {
  width: 100%;
  display: block;
  object-fit: contain;
  background: var(--night);
  max-height: 340px;
  border-bottom: 1px solid var(--border);
}
.team-card:hover {
  border-color: var(--gold-dim); transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.3), 0 0 20px rgba(201,168,76,0.05);
}
.team-card-name {
  font-family: var(--font-display); font-size: 1.1rem; font-weight: 600;
  letter-spacing: 0.08em; color: var(--gold); margin-bottom: 10px;
}
.team-card-desc { font-family: var(--font-body); font-size: 0.95rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 14px; }
.team-card-composition {
  font-family: var(--font-ui); font-size: 0.78rem; color: var(--text-dim);
  white-space: pre-wrap; border-top: 1px solid var(--border); padding-top: 12px; line-height: 1.7;
}
/* ─── Literary section ─── */
.literary-empty {
  text-align: center; padding: 80px; color: var(--text-muted);
  font-style: italic; border: 1px solid var(--border); border-radius: var(--radius-lg);
}
.literary-list { display: flex; flex-direction: column; gap: 24px; }
.literary-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; transition: all 0.35s ease;
}
.literary-card:hover { border-color: var(--gold-dim); }
.literary-card-img { width: 100%; max-height: 500px; object-fit: contain; background: var(--night); display: block; }
.literary-card-placeholder {
  display: flex; align-items: center; justify-content: center;
  height: 140px; font-size: 3.5rem; color: var(--gold-dim);
  background: linear-gradient(135deg, var(--night-lift) 0%, var(--night-card) 100%);
  user-select: none;
}
.literary-card-body { padding: 24px 28px; }
.literary-card-meta {
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-dim); margin-bottom: 8px;
}
.literary-card-title {
  font-family: var(--font-display); font-size: 1.15rem; font-weight: 500;
  letter-spacing: 0.06em; color: var(--text); margin-bottom: 10px;
}
.literary-card-excerpt {
  font-family: var(--font-body); font-size: 0.9rem; color: var(--text-muted);
  line-height: 1.7; margin-bottom: 12px; white-space: pre-line;
}
.literary-card-excerpt.clamped {
  display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical;
  overflow: hidden;
}
.literary-read-more {
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); cursor: pointer;
  border-bottom: 1px solid var(--gold-dim); padding-bottom: 2px; transition: 0.3s;
}
.literary-read-more:hover { border-color: var(--gold); }

.literary-new-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-bright);
  background: rgba(201,168,76,0.15);
  border: 1px solid var(--gold-dim);
  padding: 3px 10px;
  border-radius: 3px;
  margin-left: 10px;
  animation: pulse-gold 2s ease-in-out infinite;
}
/* ── Coatto (clone literary) ── */
.coatto-empty {
  text-align: center; padding: 80px; color: var(--text-muted);
  font-style: italic; border: 1px solid var(--border); border-radius: var(--radius-lg);
}
.coatto-list { display: flex; flex-direction: column; gap: 24px; }
.coatto-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; transition: all 0.35s ease;
}
.coatto-card:hover { border-color: var(--gold-dim); }
.coatto-card-img { width: 100%; max-height: 500px; object-fit: contain; background: var(--night); display: block; }
.coatto-card-placeholder {
  display: flex; align-items: center; justify-content: center;
  height: 140px; font-size: 3.5rem; color: var(--gold-dim);
  background: linear-gradient(135deg, var(--night-lift) 0%, var(--night-card) 100%);
  user-select: none;
}
.coatto-card-body { padding: 24px 28px; }
.coatto-card-meta {
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-dim); margin-bottom: 8px;
}
.coatto-card-title {
  font-family: var(--font-display); font-size: 1.15rem; font-weight: 500;
  letter-spacing: 0.06em; color: var(--text); margin-bottom: 10px;
}
.coatto-card-excerpt {
  font-family: var(--font-body); font-size: 0.9rem; color: var(--text-muted);
  line-height: 1.7; margin-bottom: 12px; white-space: pre-line;
}
.coatto-card-excerpt.clamped {
  display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical;
  overflow: hidden;
}
.coatto-read-more {
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); cursor: pointer;
  border-bottom: 1px solid var(--gold-dim); padding-bottom: 2px; transition: 0.3s;
}
.coatto-read-more:hover { border-color: var(--gold); }
.coatto-new-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-bright);
  background: rgba(201,168,76,0.15);
  border: 1px solid var(--gold-dim);
  padding: 3px 10px;
  border-radius: 3px;
  margin-left: 10px;
  animation: pulse-gold 2s ease-in-out infinite;
}
@keyframes pulse-gold {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* ─── Dottore (folders) ─── */
.dottore-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px; padding: 0 12px;
}
.dottore-folder {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
  cursor: pointer; transition: all 0.3s ease;
}
.dottore-folder:hover { border-color: var(--gold-dim); transform: translateY(-2px); }
.dottore-folder-cover {
  width: 100%; height: 180px; object-fit: cover; display: block;
  background: linear-gradient(135deg, var(--night-lift) 0%, var(--night-card) 100%);
}
.dottore-folder-placeholder {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  height: 180px; color: var(--gold);
  background: linear-gradient(135deg, rgba(201,168,76,0.1) 0%, var(--night-card) 50%, rgba(201,168,76,0.06) 100%);
  user-select: none; position: relative; overflow: hidden;
}
.dottore-folder-placeholder::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 40%, rgba(201,168,76,0.12) 0%, transparent 60%);
}
.dfp-initial {
  font-family: var(--font-display); font-size: 3.5rem; font-weight: 700;
  letter-spacing: 0.05em; opacity: 0.25; line-height: 1; position: relative;
}
.dfp-label {
  font-family: var(--font-ui); font-size: 0.65rem; letter-spacing: 0.12em;
  text-transform: uppercase; opacity: 0.5; text-align: center; padding: 0 12px;
  max-width: 90%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; position: relative;
}
.dottore-folder-body { padding: 16px 20px; }
.dottore-folder-name {
  font-family: var(--font-display); font-size: 1.05rem; font-weight: 600;
  letter-spacing: 0.04em; color: var(--gold); margin-bottom: 4px;
}
.dottore-folder-title {
  font-family: var(--font-body); font-size: 0.85rem; color: var(--text-muted);
  margin-bottom: 6px;
}
.dottore-folder-count {
  font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-dim);
}
/* Dottore pagination */
.dottore-pagination {
  display: flex; justify-content: center; align-items: center; gap: 6px;
  margin-top: 24px; padding: 8px 0;
}
.dottore-page-btn {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--night-card);
  color: var(--text-muted); font-family: var(--font-ui); font-size: 0.8rem; font-weight: 600;
  cursor: pointer; transition: all 0.2s ease;
  display: flex; align-items: center; justify-content: center;
}
.dottore-page-btn:hover { border-color: var(--gold-dim); color: var(--gold); }
.dottore-page-btn.active {
  background: var(--gold); color: var(--night); border-color: var(--gold);
}
/* Dottore modal carousel */
.dottore-modal-panel { max-width: 900px; }
.dottore-header { padding: 20px 28px; border-bottom: 1px solid var(--border); }
.dottore-header h2 {
  font-family: var(--font-display); font-size: 1.3rem; color: var(--gold);
  margin: 0 0 4px; letter-spacing: 0.04em;
}
.dottore-header h3 {
  font-family: var(--font-body); font-size: 0.95rem; color: var(--text-muted);
  margin: 0 0 10px; font-weight: 400;
}
.dottore-header p {
  font-family: var(--font-body); font-size: 0.88rem; color: var(--text-dim);
  line-height: 1.7; margin: 0; white-space: pre-line;
}
.dottore-carousel {
  position: relative; background: var(--night);
  display: flex; align-items: center; justify-content: center;
  min-height: 300px; overflow: hidden;
}
.dottore-carousel img {
  max-width: 100%; max-height: 70vh; object-fit: contain; display: block;
  transition: opacity 0.3s;
}
.dottore-carousel-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(0,0,0,0.6); border: 1px solid var(--border);
  color: var(--gold); font-size: 1.2rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; z-index: 2;
}
.dottore-carousel-btn:hover { background: rgba(0,0,0,0.85); border-color: var(--gold); }
.dottore-carousel-btn.prev { left: 12px; }
.dottore-carousel-btn.next { right: 12px; }
.dottore-carousel-counter {
  position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.1em;
  color: var(--gold); background: rgba(0,0,0,0.6); padding: 4px 12px;
  border-radius: 20px; border: 1px solid var(--border);
}
.dottore-empty {
  text-align: center; padding: 80px; color: var(--text-muted);
  font-style: italic; border: 1px solid var(--border); border-radius: var(--radius-lg);
}
.dottore-carousel-media {
  display: flex; align-items: center; justify-content: center;
  min-height: 300px; width: 100%;
}
.dottore-carousel-media img {
  max-width: 100%; max-height: 70vh; object-fit: contain; display: block;
  transition: opacity 0.3s;
}
.dottore-carousel-video {
  max-width: 100%; max-height: 70vh; display: block;
  border-radius: 4px; background: #000;
}
.dottore-link-card {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 14px; padding: 40px 30px; text-align: center;
}
.dottore-link-icon { font-size: 3rem; }
.dottore-link-label {
  font-family: var(--font-ui); font-size: 0.85rem; color: var(--text-muted);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.dottore-link-btn {
  display: inline-block; padding: 10px 24px; border-radius: 6px;
  background: var(--gold); color: var(--night); font-weight: 600;
  font-size: 0.85rem; text-decoration: none; transition: all 0.2s;
}
.dottore-link-btn:hover { filter: brightness(1.15); }
.dottore-link-dl {
  background: var(--night-lift); color: var(--gold);
  border: 1px solid var(--gold-dim);
}

.teams-empty, .araya-empty, .songs-empty {
  text-align: center; padding: 80px; color: var(--text-muted);
  font-style: italic; border: 1px solid var(--border); border-radius: var(--radius-lg);
}
/* ── Mercato ── */
.mercato-filters {
  display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px;
}
.mercato-filter {
  font-family: var(--font-ui); font-size: .72rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text-muted); background: transparent;
  border: 1px solid var(--border); border-radius: 20px; padding: 6px 14px;
  cursor: pointer; transition: all .2s;
}
.mercato-filter:hover { border-color: var(--gold-dim); color: var(--text); }
.mercato-filter.active { color: var(--gold); border-color: var(--gold-dim); background: rgba(201,168,76,.08); }
.mercato-new-btn { font-size: .78rem; padding: 8px 18px; white-space: nowrap; }
#mercato-toolbar {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 12px; margin-bottom: 20px;
}
.mercato-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
}
.mercato-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; transition: all .3s;
  cursor: pointer; position: relative;
}
.mercato-card:hover { border-color: var(--gold-dim); transform: translateY(-2px); }
.mercato-card-badge {
  position: absolute; top: 12px; left: 12px; z-index: 2;
  font-family: var(--font-ui); font-size: .62rem; letter-spacing: .1em;
  text-transform: uppercase; padding: 4px 10px; border-radius: 3px;
  font-weight: 600;
}
.mercato-badge-sell { background: rgba(76,175,80,.2); color: #66bb6a; border: 1px solid rgba(76,175,80,.3); }
.mercato-badge-buy { background: rgba(66,165,245,.2); color: #64b5f6; border: 1px solid rgba(66,165,245,.3); }
.mercato-badge-manage { background: rgba(255,183,77,.2); color: #ffb74d; border: 1px solid rgba(255,183,77,.3); }
.mercato-badge-sold { background: rgba(239,83,80,.2); color: #ef5350; border: 1px solid rgba(239,83,80,.3); }
.mercato-badge-closed { background: rgba(158,158,158,.2); color: #9e9e9e; border: 1px solid rgba(158,158,158,.3); }
.mercato-card-img {
  width: 100%; height: 180px; object-fit: cover; display: block;
  background: linear-gradient(135deg, var(--night-lift), var(--night-card));
}
.mercato-card-placeholder {
  width: 100%; height: 140px; display: flex; align-items: center; justify-content: center;
  font-size: 3rem; color: var(--gold-dim);
  background: linear-gradient(135deg, var(--night-lift) 0%, var(--night-card) 100%);
}
.mercato-card-body { padding: 16px 20px; }
.mercato-card-title {
  font-family: var(--font-display); font-size: 1rem; letter-spacing: .05em;
  color: var(--text); margin-bottom: 6px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mercato-card-desc {
  font-family: var(--font-body); font-size: .82rem; color: var(--text-muted);
  line-height: 1.5; margin-bottom: 10px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.mercato-card-meta {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.mercato-card-tag {
  font-family: var(--font-ui); font-size: .65rem; letter-spacing: .06em;
  color: var(--text-dim); background: rgba(255,255,255,.04);
  border: 1px solid var(--border); border-radius: 3px; padding: 2px 8px;
}
.mercato-card-price {
  font-family: var(--font-display); font-size: .9rem; color: var(--gold);
  letter-spacing: .04em; margin-left: auto;
}
.mercato-card-user {
  font-family: var(--font-ui); font-size: .68rem; color: var(--text-dim);
  margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border);
}
.mercato-card-status-sold .mercato-card-img,
.mercato-card-status-closed .mercato-card-img { opacity: .4; filter: grayscale(.7); }
.mercato-card-status-sold .mercato-card-title,
.mercato-card-status-closed .mercato-card-title { text-decoration: line-through; color: var(--text-dim); }
.mercato-form {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px; margin-bottom: 24px;
}
.mercato-form-title {
  font-family: var(--font-display); font-size: 1rem; letter-spacing: .08em;
  color: var(--gold); margin-bottom: 16px;
}
.mercato-form-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.mercato-form-grid .full { grid-column: 1 / -1; }
.mercato-form-actions {
  display: flex; gap: 10px; justify-content: flex-end; margin-top: 16px;
}
.mercato-modal-gallery {
  display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0;
}
.mercato-modal-gallery img {
  height: 120px; border-radius: 6px; object-fit: cover; cursor: zoom-in;
  border: 1px solid var(--border); transition: .2s;
}
.mercato-modal-gallery img:hover { border-color: var(--gold-dim); }
.mercato-modal-info {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 16px 0;
}
.mercato-modal-info-item {
  font-family: var(--font-ui); font-size: .78rem;
}
.mercato-modal-info-label {
  font-size: .62rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-dim); margin-bottom: 2px;
}
.mercato-modal-info-val { color: var(--text); }
.mercato-empty {
  text-align: center; padding: 60px; color: var(--text-muted);
  font-style: italic; border: 1px solid var(--border); border-radius: var(--radius-lg);
}
.mercato-own-actions {
  display: flex; gap: 8px; margin-top: 16px; padding-top: 12px;
  border-top: 1px solid var(--border);
}
.mercato-own-actions button {
  font-family: var(--font-ui); font-size: .72rem; letter-spacing: .06em;
  padding: 6px 14px; border-radius: var(--radius); cursor: pointer; transition: .2s;
}
.mercato-btn-edit { color: var(--gold); border: 1px solid var(--gold-dim); background: transparent; }
.mercato-btn-edit:hover { background: rgba(201,168,76,.1); }
.mercato-btn-sold { color: #66bb6a; border: 1px solid rgba(76,175,80,.3); background: transparent; }
.mercato-btn-sold:hover { background: rgba(76,175,80,.1); }
.mercato-btn-delete { color: #ef5350; border: 1px solid rgba(239,83,80,.3); background: transparent; }
.mercato-btn-delete:hover { background: rgba(239,83,80,.1); }
@media (max-width: 600px) {
  .mercato-grid { grid-template-columns: 1fr; }
  .mercato-form-grid { grid-template-columns: 1fr; }
  .mercato-modal-info { grid-template-columns: 1fr; }
  #mercato-toolbar { flex-direction: column; align-items: stretch; }
  .mercato-new-btn { width: 100%; text-align: center; }
}

/* ── Famiglia ── */
.famiglia-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px; padding: 8px 0;
}
.famiglia-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden; transition: all 0.35s ease;
}
.famiglia-card:hover { border-color: var(--gold-dim); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.3); }
.famiglia-media { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; cursor: pointer; }
video.famiglia-media { cursor: default; }
.famiglia-caption { padding: 10px 14px 4px; font-family: var(--font-body); font-size: 0.88rem; color: var(--text); }
.famiglia-date { padding: 4px 14px 10px; font-family: var(--font-ui); font-size: 0.72rem; color: var(--text-dim); }
.famiglia-lightbox {
  position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,0.92);
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.famiglia-lightbox-inner { position: relative; max-width: 90vw; max-height: 90vh; cursor: default; }
.famiglia-lightbox-inner img { max-width: 90vw; max-height: 85vh; object-fit: contain; border-radius: 6px; }
.famiglia-lightbox-close {
  position: absolute; top: -12px; right: -12px; width: 36px; height: 36px;
  border-radius: 50%; border: none; background: var(--gold); color: #000;
  font-size: 1.4rem; cursor: pointer; display: flex; align-items: center; justify-content: center;
  line-height: 1; z-index: 1;
}
.famiglia-lightbox-caption { text-align: center; padding: 12px; color: var(--text-muted); font-family: var(--font-body); font-size: 0.9rem; }
@media (max-width: 600px) {
  .famiglia-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
}

.songs-list { display: flex; flex-direction: column; gap: 12px; }
.song-item {
  display: flex; align-items: center; gap: 20px;
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px 24px; transition: all 0.35s ease;
}
.song-item:hover { border-color: var(--gold-dim); background: var(--night-lift); }
.song-number { font-family: var(--font-display); font-size: 0.9rem; color: var(--gold-dim); min-width: 28px; text-align: right; }
.song-info { flex: 1; min-width: 0; }
.song-title { font-family: var(--font-display); font-size: 1rem; font-weight: 500; letter-spacing: 0.06em; color: var(--text); }
.song-artist { font-family: var(--font-body); font-size: 0.88rem; color: var(--text-muted); margin-top: 2px; }
.song-note { font-family: var(--font-ui); font-size: 0.75rem; color: var(--text-dim); margin-top: 4px; }
.song-link {
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); border: 1px solid var(--gold-dim);
  padding: 5px 14px; border-radius: 2px; transition: all 0.3s ease; white-space: nowrap;
}
.song-link:hover { background: var(--gold-subtle); border-color: var(--gold); }
.song-audio {
  height: 32px; max-width: 220px; width: 100%;
  filter: sepia(40%) hue-rotate(10deg) brightness(0.85);
  vertical-align: middle; border-radius: 4px;
}
.song-stats {
  display: flex; gap: 12px; font-family: var(--font-ui);
  font-size: 0.68rem; color: var(--text-dim); margin-top: 6px;
}
.song-stats span { display: inline-flex; align-items: center; gap: 3px; }
/* Sounds section */
.sounds-grid { display: flex; flex-direction: column; gap: 12px; }
.sound-item {
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px 16px;
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 20px; transition: all 0.35s ease;
}
.sound-item:hover { border-color: var(--gold-dim); background: var(--night-lift); }
.sound-icon { font-size: 1.5rem; flex-shrink: 0; }
.sound-info { flex: 1; min-width: 120px; }
.sound-title { font-family: var(--font-display); font-size: 1rem; font-weight: 500; letter-spacing: 0.06em; color: var(--text); }
.sound-desc { font-family: var(--font-body); font-size: 0.85rem; color: var(--text-muted); margin-top: 2px; }
.sound-audio {
  height: 32px; max-width: 220px; width: 100%;
  filter: sepia(40%) hue-rotate(10deg) brightness(0.85);
  vertical-align: middle; border-radius: 4px;
}
.sound-link {
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); border: 1px solid var(--gold-dim);
  padding: 5px 14px; border-radius: 2px; transition: all 0.3s ease; white-space: nowrap;
}
.sound-link:hover { background: var(--gold-subtle); border-color: var(--gold); }
.sounds-empty { text-align: center; color: var(--text-muted); padding: 40px 0; }
.sound-item > .rx-bar { flex-shrink: 0; }
.sound-item > .cm-wrap { width: 100%; }
@media (max-width: 600px) {
  .sound-item { flex-direction: column; align-items: stretch; gap: 10px; padding: 12px 14px; }
  .sound-item > .sound-icon { align-self: flex-start; }
  .sound-audio { max-width: 100%; }
  .sound-item > .rx-bar { align-self: flex-start; }
}
/* ── Games Hub ── */
.game-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,.4); border-color: var(--gold-dim); }
/* ── Tetric (Kaiser Tetris iframe) ── */
.tetric-iframe { width:100%;max-width:500px;height:95vh;max-height:1000px;border:none;overflow:hidden;display:block;margin:0 auto;border-radius:12px }
@media (max-width: 768px) { .tetric-iframe { height:85vh;max-height:none; } }
/* ── Leaderboard ── */
.tetric-tab { padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--night-card);color:var(--text-muted);font-family:var(--font-ui);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s }
.tetric-tab.active { background:var(--gold);color:var(--night);font-weight:bold;border-color:var(--gold) }
.tetric-tab:hover:not(.active) { border-color:var(--gold);color:var(--gold) }
.tetric-lb-row { display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.04) }
.tetric-lb-row:last-child { border-bottom:none }
.tetric-lb-row.is-me { background:rgba(212,175,55,.08) }
.tetric-lb-rank { font-family:var(--font-display);font-size:1rem;min-width:28px;text-align:center }
.tetric-lb-rank.gold { color:#ffd700 } .tetric-lb-rank.silver { color:#c0c0c0 } .tetric-lb-rank.bronze { color:#cd7f32 }
.tetric-lb-name { flex:1;font-family:var(--font-ui);font-size:.85rem;color:var(--text) }
.tetric-lb-score { font-family:var(--font-display);font-size:1rem;color:var(--gold-bright) }
.tetric-lb-games { font-family:var(--font-ui);font-size:.7rem;color:var(--text-muted);letter-spacing:.06em }
.tetric-lb-empty { padding:30px;text-align:center;color:var(--text-muted);font-family:var(--font-ui);font-size:.8rem }

.thanatos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.thanatos-card {
  background: var(--night-card); border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden; transition: transform 0.3s, box-shadow 0.3s;
}
.thanatos-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,.4); }
.thanatos-card-img {
  width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; cursor: pointer;
}
.thanatos-card-body { padding: 18px 20px; }
.thanatos-card-title {
  font-family: var(--font-display); font-size: 1.15rem; color: var(--gold-bright);
  margin: 0 0 6px; letter-spacing: 0.04em;
}
.thanatos-card-subtitle {
  font-family: var(--font-ui); font-size: 0.8rem; color: var(--text-dim);
  letter-spacing: 0.08em; text-transform: uppercase; margin: 0 0 10px;
}
.thanatos-card-excerpt {
  font-size: 0.88rem; color: var(--text-dim); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
  margin: 0 0 12px; white-space: pre-wrap;
}
.thanatos-card-price {
  display: inline-block; font-family: var(--font-display); font-size: 1rem;
  color: var(--gold); background: rgba(201,168,76,.08); border: 1px solid rgba(201,168,76,.2);
  padding: 4px 14px; border-radius: 20px; margin-bottom: 10px;
}
.thanatos-card-materials { font-size: 0.78rem; color: var(--text-muted); letter-spacing: 0.05em; margin-bottom: 10px; }
.thanatos-card-footer { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.thanatos-btn {
  font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold); background: none; border: 1px solid var(--gold); border-radius: 2px;
  padding: 5px 12px; cursor: pointer; transition: all 0.2s;
}
.thanatos-btn:hover { background: var(--gold); color: var(--night); }
.thanatos-empty { text-align: center; color: var(--text-muted); padding: 60px 24px; font-family: var(--font-ui); letter-spacing: 0.08em; }
/* Thanatos modal */
.thanatos-modal-panel { max-width: 820px; }
.thanatos-modal-panel .tm-title { font-family: var(--font-display); font-size: clamp(1.4rem,3vw,2rem); color: var(--gold-bright); margin: 0 0 8px; }
.thanatos-modal-panel .tm-subtitle { font-family: var(--font-ui); font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); margin: 0 0 20px; }
.thanatos-modal-panel .tm-images { display: grid; gap: 10px; margin-bottom: 24px; }
.thanatos-modal-panel .tm-images.count-1 { grid-template-columns: 1fr; }
.thanatos-modal-panel .tm-images.count-2 { grid-template-columns: repeat(2,1fr); }
.thanatos-modal-panel .tm-images.count-3 { grid-template-columns: repeat(3,1fr); }
.thanatos-modal-panel .tm-images.count-4 { grid-template-columns: repeat(2,1fr); }
.thanatos-modal-panel .tm-images img { width: 100%; border-radius: var(--radius); display: block; object-fit: cover; aspect-ratio: 16/9; cursor: zoom-in; }
.thanatos-modal-panel .tm-body { font-size: 0.92rem; line-height: 1.8; color: var(--text); white-space: pre-wrap; margin-bottom: 20px; }
.thanatos-modal-panel .tm-price-big { font-family: var(--font-display); font-size: 1.3rem; color: var(--gold-bright); margin: 0 0 20px; }
.thanatos-modal-panel .tm-materials { margin: 16px 0; }
.thanatos-modal-panel .tm-materials h4 { font-family: var(--font-ui); font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 10px; }
.thanatos-modal-panel .tm-mat-row { display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid var(--border); font-size: 0.88rem; color: var(--text-dim); }
.thanatos-modal-panel .tm-mat-total { display: flex; justify-content: space-between; padding: 10px 0; font-family: var(--font-display); font-size: 1rem; color: var(--gold-bright); border-top: 2px solid var(--gold); margin-top: 4px; }
@media (max-width: 600px) {
  .thanatos-grid { grid-template-columns: 1fr; }
}

.pagination {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 8px; margin-top: 32px; font-family: var(--font-ui);
}
.pagination .pg-btn,
.pagination .pg-num {
  background: var(--night-card); border: 1px solid var(--border);
  color: var(--gold); font-size: 0.78rem; letter-spacing: 0.10em;
  text-transform: uppercase; padding: 6px 14px; border-radius: 2px;
  cursor: pointer; transition: all 0.3s ease;
}
.pagination .pg-num { min-width: 34px; text-align: center; }
.pagination .pg-btn:hover:not(:disabled),
.pagination .pg-num:hover:not(.active) { background: var(--gold-subtle); border-color: var(--gold); }
.pagination .pg-btn:disabled { color: var(--text-dim); border-color: var(--border); cursor: default; opacity: 0.4; }
.pagination .pg-num.active { background: var(--gold-subtle); border-color: var(--gold); color: var(--gold-bright); font-weight: 700; cursor: default; }
.araya-grid { columns: 3; column-gap: 16px; margin-top: clamp(40px,5vw,60px); }
.araya-item {
  break-inside: avoid; margin-bottom: 16px; position: relative;
  border-radius: var(--radius); overflow: hidden; cursor: pointer;
  border: 1px solid transparent; transition: all 0.4s ease;
}
.araya-item:hover { border-color: var(--gold-dim); box-shadow: 0 8px 30px rgba(0,0,0,0.5); }
.araya-item img { width: 100%; display: block; filter: brightness(0.8); transition: all 0.5s ease; }
.araya-item:hover img { transform: scale(1.04); filter: brightness(1); }
.araya-item-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(4,6,15,0.8) 0%, transparent 60%);
  display: flex; align-items: flex-end; padding: 16px; opacity: 0; transition: opacity 0.4s ease;
}
.araya-item:hover .araya-item-overlay { opacity: 1; }
.araya-item-title { font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.12em; color: var(--gold-bright); }

/* ═══════════════════════════════════════════
   PARURES
═══════════════════════════════════════════ */
.parures-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: clamp(32px,5vw,56px);
}
@media (min-width: 901px) {
  .parures-list { grid-template-columns: repeat(3, 1fr); gap: 32px; }
}
.parure-card {
  background: linear-gradient(135deg, rgba(201,168,76,0.04) 0%, transparent 70%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.parure-card:hover {
  border-color: var(--gold-dim);
  box-shadow: 0 6px 40px rgba(0,0,0,0.4);
}
.parure-card-inner { padding: clamp(20px,4vw,36px); }
.parure-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem,2.2vw,1.35rem);
  color: var(--gold-bright);
  letter-spacing: 0.04em;
  margin: 0 0 20px;
}
.parure-images {
  display: grid;
  gap: 10px;
  margin-bottom: 20px;
}
.parure-images.count-1 { grid-template-columns: 1fr; }
.parure-images.count-2 { grid-template-columns: repeat(2,1fr); }
.parure-images.count-3 { grid-template-columns: repeat(3,1fr); }
.parure-images.count-4 { grid-template-columns: repeat(2,1fr); }
.parure-img-wrap {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 16/9;
  cursor: zoom-in;
  background: rgba(201,168,76,0.05);
}
.parure-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease, filter 0.4s ease;
  filter: brightness(0.9);
}
.parure-img-wrap:hover img { transform: scale(1.04); filter: brightness(1.05); }
.parure-subtitle {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 12px;
}
.parure-excerpt {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.75;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 14px;
  white-space: pre-wrap;
}
.parure-read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: color 0.2s;
}
.parure-read-more:hover { color: var(--gold-bright); }
.parure-read-more::after { content: '→'; }
.parure-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 60px 24px;
  font-family: var(--font-ui);
  letter-spacing: 0.08em;
}
/* Parures modal */
.parures-modal-panel {
  max-width: 780px;
}
.parures-modal-panel .pm-title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem,3vw,2rem);
  color: var(--gold-bright);
  margin: 0 0 20px;
}
.parures-modal-panel .pm-images {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}
.parures-modal-panel .pm-images.count-1 { grid-template-columns: 1fr; }
.parures-modal-panel .pm-images.count-2 { grid-template-columns: repeat(2,1fr); }
.parures-modal-panel .pm-images.count-3 { grid-template-columns: repeat(3,1fr); }
.parures-modal-panel .pm-images.count-4 { grid-template-columns: repeat(2,1fr); }
.parures-modal-panel .pm-images img {
  width: 100%; border-radius: var(--radius);
  display: block; object-fit: cover; aspect-ratio: 16/9;
}
.parures-modal-panel .pm-subtitle {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
}
.parures-modal-panel .pm-body {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.8;
  white-space: pre-wrap;
}
@media (max-width: 600px) {
  .parure-images.count-3,
  .parure-images.count-4,
  .parures-modal-panel .pm-images.count-3,
  .parures-modal-panel .pm-images.count-4 {
    grid-template-columns: repeat(2,1fr);
  }
}

/* ═══════════════════════════════════════════
   ARTEFACTS
═══════════════════════════════════════════ */
.section-artefacts { background: linear-gradient(180deg, #0e0e18 0%, #141428 100%); }
.artefacts-filters {
  display: flex; flex-wrap: wrap; gap: 12px; justify-content: center;
  margin: clamp(20px,3vw,40px) auto 0; max-width: 800px;
}
.af-filter-group, .af-quality-group {
  display: flex; gap: 6px; flex-wrap: wrap; justify-content: center;
}
.af-role-btn, .af-qual-btn {
  padding: 6px 14px; border-radius: 20px; border: 1px solid var(--border);
  background: transparent; color: var(--text-dim); font-family: var(--font-body);
  font-size: .78rem; font-weight: 600; cursor: pointer; transition: all .25s;
  white-space: nowrap;
}
.af-role-btn:hover, .af-qual-btn:hover {
  border-color: var(--gold-dim); color: var(--gold);
}
.af-role-btn.active, .af-qual-btn.active {
  background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold);
}
.artefacts-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px; margin-top: clamp(24px,4vw,48px);
}
.artefact-card {
  background: linear-gradient(135deg, rgba(201,168,76,.04), transparent 70%);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: border-color .3s, box-shadow .3s, transform .3s;
  cursor: pointer; position: relative;
}
.artefact-card:hover {
  border-color: var(--gold-dim); box-shadow: 0 8px 40px rgba(201,168,76,.12);
  transform: translateY(-4px);
}
.artefact-card-img {
  width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block;
  background: rgba(201,168,76,.05);
}
.artefact-card-body { padding: 16px 18px 18px; }
.artefact-card-name {
  font-family: var(--font-display); font-size: 1rem; color: var(--gold-bright);
  margin: 0 0 6px; letter-spacing: .03em;
}
.artefact-card-role {
  font-size: .75rem; color: var(--text-dim); margin-bottom: 4px;
}
.artefact-card-quality {
  display: inline-block; padding: 2px 10px; border-radius: 10px;
  font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
}
.artefact-card-quality.q-normal {
  background: rgba(255,255,255,.06); color: var(--text-dim);
}
.artefact-card-quality.q-pro {
  background: linear-gradient(135deg, rgba(201,168,76,.2), rgba(201,168,76,.08));
  color: var(--gold); border: 1px solid rgba(201,168,76,.25);
}
.artefact-card-desc {
  font-size: .82rem; color: var(--text-muted); margin-top: 10px;
  line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 3;
  -webkit-box-orient: vertical; overflow: hidden;
}
/* Artefact modal */
.artefact-modal-panel {
  max-width: 560px; margin: 0 auto;
}
.artefact-modal-panel .am-img {
  width: 100%; max-height: 280px; object-fit: cover; border-radius: var(--radius);
  margin-bottom: 20px; display: block;
}
.artefact-modal-panel .am-name {
  font-family: var(--font-display); font-size: 1.4rem; color: var(--gold-bright);
  margin-bottom: 8px;
}
.artefact-modal-panel .am-meta {
  display: flex; gap: 12px; align-items: center; margin-bottom: 16px; flex-wrap: wrap;
}
.artefact-modal-panel .am-desc {
  color: var(--text-secondary); font-size: .9rem; line-height: 1.7; margin-bottom: 16px;
  white-space: pre-line;
}
.artefact-modal-panel .am-field-label {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .8px;
  color: var(--gold-dim); font-weight: 700; margin: 16px 0 6px;
}
.artefact-modal-panel .am-field-val {
  color: var(--text-secondary); font-size: .88rem; line-height: 1.6;
  white-space: pre-line;
}
.artefacts-empty {
  text-align: center; padding: 3rem 1rem; color: var(--text-muted);
  font-size: .9rem; font-style: italic;
}
@media (max-width: 600px) {
  .artefacts-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════
   ARAYA (Arayashikis) — card grid
═══════════════════════════════════════════ */
.section-araya { background: linear-gradient(180deg, #0d0d1c 0%, #131326 100%); }
.araya-filters {
  display: flex; gap: 6px; flex-wrap: wrap; justify-content: center;
  margin: clamp(20px,3vw,40px) auto 0; max-width: 700px;
}
.ay-qual-btn {
  padding: 6px 14px; border-radius: 20px; border: 1px solid var(--border);
  background: transparent; color: var(--text-dim); font-family: var(--font-body);
  font-size: .78rem; font-weight: 600; cursor: pointer; transition: all .25s;
  white-space: nowrap;
}
.ay-qual-btn:hover { border-color: var(--gold-dim); color: var(--gold); }
.ay-qual-btn.active { background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold); }
.araya-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px; margin-top: clamp(20px,3vw,36px);
}
.araya-card {
  background: linear-gradient(135deg, rgba(100,120,200,.04), transparent 70%);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: border-color .3s, box-shadow .3s, transform .3s;
  cursor: pointer; position: relative; text-align: center; padding: 14px;
}
.araya-card:hover {
  border-color: var(--gold-dim); box-shadow: 0 6px 32px rgba(201,168,76,.1);
  transform: translateY(-3px);
}
.araya-card-img {
  width: 80px; height: 80px; object-fit: contain; display: block; margin: 0 auto 10px;
  border-radius: 8px; background: rgba(255,255,255,.03);
}
.araya-card-name {
  font-family: var(--font-display); font-size: .88rem; color: var(--gold-bright);
  margin: 0 0 6px; letter-spacing: .02em;
}
.araya-card-stats { font-size: .72rem; color: var(--text-dim); line-height: 1.4; }
.araya-qual-badge {
  display: inline-block; padding: 2px 10px; border-radius: 10px;
  font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: 6px;
}
.araya-qual-badge.q-gris   { background: rgba(150,150,150,.15); color: #999; }
.araya-qual-badge.q-bleu   { background: rgba(70,130,220,.15); color: #6ba3e8; }
.araya-qual-badge.q-violet  { background: rgba(160,80,220,.15); color: #b56ee8; }
.araya-qual-badge.q-or     { background: rgba(201,168,76,.15); color: var(--gold); border: 1px solid rgba(201,168,76,.25); }
.araya-qual-badge.q-rouge  { background: rgba(220,60,60,.15); color: #e85858; border: 1px solid rgba(220,60,60,.2); }
.araya-empty { text-align: center; padding: 3rem 1rem; color: var(--text-muted); font-style: italic; }
.araya-modal-panel { max-width: 500px; margin: 0 auto; text-align: center; }
.araya-modal-panel .aym-img { width: 120px; height: 120px; object-fit: contain; margin: 0 auto 16px; display: block; }
.araya-modal-panel .aym-name { font-family: var(--font-display); font-size: 1.3rem; color: var(--gold-bright); margin-bottom: 8px; }
.araya-modal-panel .aym-stats { color: var(--text-secondary); font-size: .9rem; margin-bottom: 12px; }
.araya-modal-panel .aym-desc { color: var(--text-muted); font-size: .85rem; line-height: 1.6; white-space: pre-line; text-align: left; }
.araya-modal-panel .aym-field-label {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .8px;
  color: var(--gold-dim); font-weight: 700; margin: 14px 0 4px; text-align: left;
}
.araya-modal-panel .aym-field-val { color: var(--text-secondary); font-size: .85rem; line-height: 1.5; white-space: pre-line; text-align: left; }
@media (max-width: 600px) { .araya-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }

/* ═══════════════════════════════════════════
   VESTIGIA — card grid
═══════════════════════════════════════════ */
.section-vestigia { background: linear-gradient(180deg, #100d1a 0%, #161228 100%); }
.vestigia-filters {
  display: flex; gap: 6px; flex-wrap: wrap; justify-content: center;
  margin: clamp(20px,3vw,40px) auto 0; max-width: 500px;
}
.vg-qual-btn {
  padding: 6px 14px; border-radius: 20px; border: 1px solid var(--border);
  background: transparent; color: var(--text-dim); font-family: var(--font-body);
  font-size: .78rem; font-weight: 600; cursor: pointer; transition: all .25s;
}
.vg-qual-btn:hover { border-color: var(--gold-dim); color: var(--gold); }
.vg-qual-btn.active { background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold); }
.vestigia-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px; margin-top: clamp(20px,3vw,36px);
}
.vestigia-card {
  background: linear-gradient(135deg, rgba(160,80,220,.04), transparent 70%);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: border-color .3s, box-shadow .3s, transform .3s;
  cursor: pointer; padding: 18px; text-align: center;
}
.vestigia-card:hover {
  border-color: rgba(160,80,220,.4); box-shadow: 0 6px 32px rgba(160,80,220,.1);
  transform: translateY(-3px);
}
.vestigia-card-img {
  width: 100px; height: 100px; object-fit: contain; display: block; margin: 0 auto 12px;
  border-radius: 12px; background: rgba(160,80,220,.05);
}
.vestigia-card-name {
  font-family: var(--font-display); font-size: .95rem; color: var(--gold-bright);
  margin: 0 0 6px;
}
.vestigia-qual-badge {
  display: inline-block; padding: 2px 10px; border-radius: 10px;
  font-size: .65rem; font-weight: 700; text-transform: uppercase; margin-bottom: 8px;
}
.vestigia-qual-badge.q-epique { background: rgba(160,80,220,.15); color: #b56ee8; }
.vestigia-qual-badge.q-legendaire { background: rgba(201,168,76,.15); color: var(--gold); border: 1px solid rgba(201,168,76,.2); }
.vestigia-card-skill { font-size: .78rem; color: var(--text-dim); line-height: 1.4; margin-top: 6px; }
.vestigia-empty { text-align: center; padding: 3rem 1rem; color: var(--text-muted); font-style: italic; }
.vestigia-modal-panel { max-width: 560px; margin: 0 auto; }
.vestigia-modal-panel .vgm-img { width: 120px; height: 120px; object-fit: contain; margin: 0 auto 16px; display: block; }
.vestigia-modal-panel .vgm-name { font-family: var(--font-display); font-size: 1.3rem; color: var(--gold-bright); margin-bottom: 8px; text-align: center; }
.vestigia-modal-panel .vgm-skill-title { font-size: .9rem; font-weight: 700; color: var(--gold); margin: 14px 0 4px; }
.vestigia-modal-panel .vgm-skill-desc { color: var(--text-secondary); font-size: .85rem; line-height: 1.6; white-space: pre-line; }
@media (max-width: 600px) { .vestigia-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════
   STATUES — card grid
═══════════════════════════════════════════ */
.section-statues { background: linear-gradient(180deg, #0e0e18 0%, #141428 100%); }
.statues-filters {
  display: flex; gap: 6px; flex-wrap: wrap; justify-content: center;
  margin: clamp(20px,3vw,40px) auto 0; max-width: 500px;
}
.st-cat-btn {
  padding: 6px 14px; border-radius: 20px; border: 1px solid var(--border);
  background: transparent; color: var(--text-dim); font-family: var(--font-body);
  font-size: .78rem; font-weight: 600; cursor: pointer; transition: all .25s;
}
.st-cat-btn:hover { border-color: var(--gold-dim); color: var(--gold); }
.st-cat-btn.active { background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold); }
.statues-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px; margin-top: clamp(20px,3vw,36px);
}
.statue-card {
  background: linear-gradient(135deg, rgba(201,168,76,.04), transparent 70%);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: border-color .3s, box-shadow .3s, transform .3s;
  cursor: pointer; padding: 20px; text-align: center;
}
.statue-card:hover {
  border-color: var(--gold-dim); box-shadow: 0 6px 32px rgba(201,168,76,.1);
  transform: translateY(-3px);
}
.statue-card-img {
  width: 100px; height: 100px; object-fit: contain; display: block; margin: 0 auto 12px;
}
.statue-card-name {
  font-family: var(--font-display); font-size: 1rem; color: var(--gold-bright); margin: 0 0 6px;
}
.statue-card-cat {
  display: inline-block; padding: 2px 10px; border-radius: 10px;
  font-size: .65rem; font-weight: 700; text-transform: uppercase; margin-bottom: 8px;
  background: rgba(201,168,76,.12); color: var(--gold-dim);
}
.statue-card-heroes { font-size: .75rem; color: var(--text-dim); line-height: 1.4; }
.statues-empty { text-align: center; padding: 3rem 1rem; color: var(--text-muted); font-style: italic; }
.statue-modal-panel { max-width: 560px; margin: 0 auto; }
.statue-modal-panel .stm-img { width: 120px; height: 120px; object-fit: contain; margin: 0 auto 16px; display: block; }
.statue-modal-panel .stm-name { font-family: var(--font-display); font-size: 1.3rem; color: var(--gold-bright); margin-bottom: 8px; text-align: center; }
.statue-modal-panel .stm-field-label {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .8px;
  color: var(--gold-dim); font-weight: 700; margin: 14px 0 4px;
}
.statue-modal-panel .stm-field-val { color: var(--text-secondary); font-size: .85rem; line-height: 1.6; white-space: pre-line; }
@media (max-width: 600px) { .statues-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════
   TEAM BUILDER
═══════════════════════════════════════════ */
.section-teambuilder { background: linear-gradient(180deg, #0a0e1a 0%, #0f1528 100%); }
/* 5-team grid */
.tb-teams-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px;
  max-width: 1200px; margin: 0 auto;
}
.tb-team-card {
  background: rgba(201,168,76,.03); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 10px 8px 12px; text-align: center;
}
.tb-team-card-hdr {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; padding: 0 2px;
}
.tb-team-card-hdr span {
  font-family: var(--font-display); font-size: .78rem; color: var(--gold);
  letter-spacing: .04em;
}
.tb-team-reset-btn {
  font-size: .6rem; color: var(--text-dim); cursor: pointer;
  border: none; background: none; padding: 2px 6px; border-radius: 8px;
  transition: color .2s;
}
.tb-team-reset-btn:hover { color: #e66; }
/* Character slots row */
.tb-card-chars {
  display: flex; justify-content: center; gap: 3px; flex-wrap: wrap;
  margin-bottom: 6px;
}
.tb-slot {
  width: 48px; text-align: center; cursor: pointer; transition: transform .2s;
}
.tb-slot:hover { transform: translateY(-2px); }
.tb-slot-img-wrap {
  width: 44px; height: 44px; margin: 0 auto 2px;
  border-radius: 50%; border: 2px solid var(--border);
  overflow: hidden; background: rgba(201,168,76,.06);
  display: flex; align-items: center; justify-content: center;
  transition: border-color .3s;
}
.tb-slot.filled .tb-slot-img-wrap { border-color: var(--gold-dim); }
.tb-slot-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.tb-slot-empty { color: var(--text-dim); font-size: 1rem; }
.tb-slot-name {
  font-size: .5rem; color: var(--text-muted); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; max-width: 48px; margin: 0 auto;
}
/* Vestige area */
.tb-vestige-sep {
  border: none; border-top: 1px solid var(--border); margin: 6px 0;
}
.tb-vestige-label {
  font-size: .48rem; text-transform: uppercase; letter-spacing: .5px;
  color: var(--gold-dim); font-weight: 700; margin-bottom: 3px;
}
.tb-slot.vestige .tb-slot-img-wrap {
  border-radius: var(--radius); width: 48px; height: 48px;
}
/* Mini stats per team */
.tb-card-stats {
  display: flex; justify-content: center; gap: 6px; margin-top: 6px; flex-wrap: wrap;
}
.tb-mini-stat { text-align: center; }
.tb-mini-stat-label {
  font-size: .45rem; text-transform: uppercase; color: var(--gold-dim);
  letter-spacing: .3px; font-weight: 700;
}
.tb-mini-stat-val {
  font-size: .7rem; color: var(--gold-bright); font-weight: 700;
  font-family: var(--font-display);
}
/* Global actions */
.tb-global-actions {
  display: flex; justify-content: center; gap: 10px; margin-top: 16px;
}
.tb-btn {
  padding: 6px 18px; border-radius: 20px; font-size: .78rem; font-weight: 600;
  cursor: pointer; transition: all .25s; border: 1px solid var(--border);
  background: transparent; color: var(--text-muted); font-family: var(--font-body);
}
.tb-btn:hover { border-color: var(--gold); color: var(--gold); }
.tb-btn-share { background: rgba(201,168,76,.12); color: var(--gold); border-color: var(--gold-dim); }
.tb-btn-share:hover { background: rgba(201,168,76,.25); }
/* Picker modal */
.tb-picker-panel {
  max-width: 720px; width: 95vw; margin: 0 auto;
  max-height: 85vh; overflow-y: auto;
  padding: clamp(16px,2vw,28px);
}
.tb-picker-header {
  font-family: var(--font-display); font-size: 1.1rem; color: var(--gold-bright);
  text-align: center; margin-bottom: 16px;
}
.tb-filters {
  display: flex; gap: 8px; flex-wrap: wrap; justify-content: center;
  margin: 0 auto 16px; align-items: center;
}
.tb-filter-group { display: flex; gap: 4px; flex-wrap: wrap; justify-content: center; }
.tb-filter-sep { width: 1px; height: 24px; background: var(--border); margin: 0 4px; align-self: center; }
.tb-fbtn {
  padding: 5px 12px; border-radius: 16px; border: 1px solid var(--border);
  background: transparent; color: var(--text-dim); font-family: var(--font-body);
  font-size: .72rem; font-weight: 600; cursor: pointer; transition: all .25s;
}
.tb-fbtn:hover { border-color: var(--gold-dim); color: var(--gold); }
.tb-fbtn.active { background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold); }
.tb-search {
  padding: 5px 14px; border-radius: 16px; border: 1px solid var(--border);
  background: rgba(255,255,255,.03); color: var(--text); font-family: var(--font-body);
  font-size: .78rem; width: 180px; outline: none; transition: border-color .25s;
}
.tb-search:focus { border-color: var(--gold-dim); }
.tb-search::placeholder { color: var(--text-dim); }
.tb-char-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 8px; max-width: 900px; margin: 0 auto;
}
.tb-char-card {
  background: rgba(201,168,76,.03); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 8px 4px 6px; text-align: center;
  cursor: pointer; transition: all .25s; position: relative;
}
.tb-char-card:hover { border-color: var(--gold-dim); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(201,168,76,.08); }
.tb-char-card.selected { border-color: var(--gold); background: rgba(201,168,76,.1); }
.tb-char-card.selected::after {
  content: '✓'; position: absolute; top: 4px; right: 6px;
  color: var(--gold-bright); font-size: .7rem; font-weight: 700;
}
.tb-char-img {
  width: 56px; height: 56px; border-radius: 50%; object-fit: cover;
  display: block; margin: 0 auto 4px; border: 1px solid var(--border);
}
.tb-char-name { font-size: .62rem; color: var(--text); line-height: 1.2; margin-bottom: 3px; }
.tb-char-role {
  font-size: .52rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: .3px;
}
.tb-char-type {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  margin-right: 3px; vertical-align: middle;
}
.tb-type-1 { background: #4da6ff; }
.tb-type-2 { background: #ff6644; }
.tb-type-3 { background: #66cc77; }
.tb-type-4 { background: #cc9944; }
.tb-type-5 { background: #ffdd55; }
.tb-type-6 { background: #9966cc; }
/* Vestige cards in picker */
.tb-vest-card {
  background: rgba(201,168,76,.03); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 10px 6px 8px; text-align: center;
  cursor: pointer; transition: all .25s; position: relative;
}
.tb-vest-card:hover { border-color: var(--gold-dim); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(201,168,76,.08); }
.tb-vest-card-img {
  width: 60px; height: 60px; border-radius: var(--radius); object-fit: cover;
  display: block; margin: 0 auto 4px; border: 1px solid var(--border);
}
.tb-vest-card-name { font-size: .62rem; color: var(--text); line-height: 1.2; margin-bottom: 2px; }
.tb-vest-card-qual { font-size: .5rem; color: var(--gold-dim); text-transform: uppercase; }
.tb-empty-msg { text-align: center; padding: 2rem; color: var(--text-muted); font-style: italic; grid-column: 1/-1; }
@media (max-width: 1100px) {
  .tb-teams-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .tb-teams-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .tb-teams-grid { grid-template-columns: 1fr 1fr; gap: 6px; }
  .tb-slot { width: 38px; }
  .tb-slot-img-wrap { width: 34px; height: 34px; }
  .tb-slot.vestige .tb-slot-img-wrap { width: 36px; height: 36px; }
  .tb-char-grid { grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: 6px; }
  .tb-char-img { width: 44px; height: 44px; }
}

/* ═══════════════════════════════════════════
   ARMURES
═══════════════════════════════════════════ */
.armures-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: clamp(32px,5vw,56px);
}
@media (min-width: 901px) {
  .armures-list { grid-template-columns: repeat(3, 1fr); gap: 32px; }
}
.armure-card {
  background: linear-gradient(135deg, rgba(201,168,76,0.04) 0%, transparent 70%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.armure-card:hover {
  border-color: var(--gold-dim);
  box-shadow: 0 6px 40px rgba(0,0,0,0.4);
}
.armure-card-inner { padding: clamp(20px,4vw,36px); }
.armure-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem,2.2vw,1.35rem);
  color: var(--gold-bright);
  letter-spacing: 0.04em;
  margin: 0 0 20px;
}
.armure-images {
  display: grid;
  gap: 10px;
  margin-bottom: 20px;
}
.armure-images.count-1 { grid-template-columns: 1fr; }
.armure-images.count-2 { grid-template-columns: repeat(2,1fr); }
.armure-images.count-3 { grid-template-columns: repeat(3,1fr); }
.armure-images.count-4 { grid-template-columns: repeat(2,1fr); }
.armure-img-wrap {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 16/9;
  cursor: zoom-in;
  background: rgba(201,168,76,0.05);
}
.armure-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease, filter 0.4s ease;
  filter: brightness(0.9);
}
.armure-img-wrap:hover img { transform: scale(1.04); filter: brightness(1.05); }
.armure-subtitle {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 12px;
}
.armure-excerpt {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.75;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 14px;
  white-space: pre-wrap;
}
.armure-read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: color 0.2s;
}
.armure-read-more:hover { color: var(--gold-bright); }
.armure-read-more::after { content: '→'; }
.armure-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 60px 24px;
  font-family: var(--font-ui);
  letter-spacing: 0.08em;
}
/* Armures modal */
.armures-modal-panel {
  max-width: 780px;
}
.armures-modal-panel .am-title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem,3vw,2rem);
  color: var(--gold-bright);
  margin: 0 0 20px;
}
.armures-modal-panel .am-images {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}
.armures-modal-panel .am-images.count-1 { grid-template-columns: 1fr; }
.armures-modal-panel .am-images.count-2 { grid-template-columns: repeat(2,1fr); }
.armures-modal-panel .am-images.count-3 { grid-template-columns: repeat(3,1fr); }
.armures-modal-panel .am-images.count-4 { grid-template-columns: repeat(2,1fr); }
.armures-modal-panel .am-images img {
  width: 100%; border-radius: var(--radius);
  display: block; object-fit: cover; aspect-ratio: 16/9;
}
.armures-modal-panel .am-subtitle {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
}
.armures-modal-panel .am-body {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.8;
  white-space: pre-wrap;
}
@media (max-width: 600px) {
  .armure-images.count-3,
  .armure-images.count-4,
  .armures-modal-panel .am-images.count-3,
  .armures-modal-panel .am-images.count-4 {
    grid-template-columns: repeat(2,1fr);
  }
}

/* ═══════════════════════════════════════════
   VESTIGIA DEGLI DEI
═══════════════════════════════════════════ */
.section-vestigia-wrap {
  background: linear-gradient(180deg,
    transparent 0%,
    rgba(18,10,30,0.45) 30%,
    rgba(14,8,24,0.55) 60%,
    transparent 100%);
}
/* ═══════════════════════════════════════════
   FORTEZZA DEGLI DEI
═══════════════════════════════════════════ */
.fortezza-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  margin-top: clamp(32px,5vw,56px);
}
@media (min-width: 901px) {
  .fortezza-list { grid-template-columns: repeat(3, 1fr); gap: 36px; }
}
.fortezza-card {
  background: linear-gradient(145deg,
    rgba(40,180,120,0.06) 0%,
    rgba(201,168,76,0.04) 50%,
    transparent 100%);
  border: 1px solid rgba(40,180,120,0.18);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
  position: relative;
}
.fortezza-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(40,180,120,0.04) 0%, transparent 60%);
  pointer-events: none;
  border-radius: inherit;
}
.fortezza-card:hover {
  border-color: rgba(60,200,140,0.42);
  box-shadow: 0 8px 48px rgba(30,160,100,0.15), 0 2px 16px rgba(0,0,0,0.4);
  transform: translateY(-3px);
}
.fortezza-card-inner { padding: clamp(20px,4vw,36px); }
.fortezza-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem,2.2vw,1.35rem);
  background: linear-gradient(120deg, #a0f0c0 0%, var(--gold-bright) 55%, #80e0a0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: 0.05em;
  margin: 0 0 18px;
}
.fortezza-images {
  display: grid;
  gap: 10px;
  margin-bottom: 20px;
}
.fortezza-images.count-1 { grid-template-columns: 1fr; }
.fortezza-images.count-2 { grid-template-columns: repeat(2,1fr); }
.fortezza-images.count-3 { grid-template-columns: repeat(3,1fr); }
.fortezza-images.count-4 { grid-template-columns: repeat(2,1fr); }
.fortezza-img-wrap {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 16/9;
  cursor: pointer;
  background: rgba(40,180,120,0.08);
}
.fortezza-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(8,36,18,0.35) 100%);
  pointer-events: none;
}
.fortezza-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease, filter 0.4s ease;
  filter: brightness(0.88) saturate(1.05);
}
.fortezza-img-wrap:hover img { transform: scale(1.04); filter: brightness(1.05) saturate(1.1); }
.fortezza-subtitle {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(80,220,150,0.9);
  margin: 0 0 12px;
}
.fortezza-excerpt {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.75;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 14px;
  white-space: pre-wrap;
}
.fortezza-read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(80,220,150,0.9);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: color 0.2s;
}
.fortezza-read-more:hover { color: #a0f0c0; }
.fortezza-read-more::after { content: '\2192'; }
.fortezza-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 60px 24px;
  font-family: var(--font-ui);
  letter-spacing: 0.08em;
}
/* Fortezza modal */
.fortezza-modal-panel {
  max-width: 780px;
}
.fortezza-modal-panel .vm-title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem,3vw,2rem);
  background: linear-gradient(120deg, #a0f0c0 0%, var(--gold-bright) 55%, #80e0a0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 20px;
}
.fortezza-modal-panel .vm-images {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}
.fortezza-modal-panel .vm-images.count-1 { grid-template-columns: 1fr; }
.fortezza-modal-panel .vm-images.count-2 { grid-template-columns: repeat(2,1fr); }
.fortezza-modal-panel .vm-images.count-3 { grid-template-columns: repeat(3,1fr); }
.fortezza-modal-panel .vm-images.count-4 { grid-template-columns: repeat(2,1fr); }
.fortezza-modal-panel .vm-images img {
  width: 100%; border-radius: var(--radius);
  display: block; object-fit: cover; aspect-ratio: 16/9;
}
.fortezza-modal-panel .vm-subtitle {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(80,220,150,0.9);
  margin: 0 0 14px;
}
.fortezza-modal-panel .vm-body {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.8;
  white-space: pre-wrap;
}
@media (max-width: 600px) {
  .fortezza-images.count-3,
  .fortezza-images.count-4,
  .fortezza-modal-panel .vm-images.count-3,
  .fortezza-modal-panel .vm-images.count-4 {
    grid-template-columns: repeat(2,1fr);
  }
}

.vestigia-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  margin-top: clamp(32px,5vw,56px);
}
@media (min-width: 901px) {
  .vestigia-list { grid-template-columns: repeat(3, 1fr); gap: 36px; }
}
.vestigia-card {
  background: linear-gradient(145deg,
    rgba(160,120,255,0.06) 0%,
    rgba(201,168,76,0.04) 50%,
    transparent 100%);
  border: 1px solid rgba(160,120,255,0.18);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
  position: relative;
}
.vestigia-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(160,120,255,0.04) 0%, transparent 60%);
  pointer-events: none;
  border-radius: inherit;
}
.vestigia-card:hover {
  border-color: rgba(180,140,255,0.42);
  box-shadow: 0 8px 48px rgba(140,80,255,0.15), 0 2px 16px rgba(0,0,0,0.4);
  transform: translateY(-3px);
}
.vestigia-card-inner { padding: clamp(20px,4vw,36px); }
.vestigia-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem,2.2vw,1.35rem);
  background: linear-gradient(120deg, #e0d0ff 0%, var(--gold-bright) 55%, #c8b0ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: 0.05em;
  margin: 0 0 18px;
}
.vestigia-images {
  display: grid;
  gap: 10px;
  margin-bottom: 20px;
}
.vestigia-images.count-1 { grid-template-columns: 1fr; }
.vestigia-images.count-2 { grid-template-columns: repeat(2,1fr); }
.vestigia-images.count-3 { grid-template-columns: repeat(3,1fr); }
.vestigia-images.count-4 { grid-template-columns: repeat(2,1fr); }
.vestigia-img-wrap {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 16/9;
  cursor: pointer;
  background: rgba(120,80,200,0.08);
}
.vestigia-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(18,8,36,0.35) 100%);
  pointer-events: none;
}
.vestigia-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease, filter 0.4s ease;
  filter: brightness(0.88) saturate(1.05);
}
.vestigia-img-wrap:hover img { transform: scale(1.04); filter: brightness(1.05) saturate(1.1); }
.vestigia-subtitle {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(180,150,255,0.9);
  margin: 0 0 12px;
}
.vestigia-excerpt {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.75;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 14px;
  white-space: pre-wrap;
}
.vestigia-read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(180,150,255,0.9);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: color 0.2s;
}
.vestigia-read-more:hover { color: #e0d0ff; }
.vestigia-read-more::after { content: '→'; }
.vestigia-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 60px 24px;
  font-family: var(--font-ui);
  letter-spacing: 0.08em;
}
/* Vestigia modal */
.vestigia-modal-panel {
  max-width: 780px;
}
.vestigia-modal-panel .vm-title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem,3vw,2rem);
  background: linear-gradient(120deg, #e0d0ff 0%, var(--gold-bright) 55%, #c8b0ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 20px;
}
.vestigia-modal-panel .vm-images {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}
.vestigia-modal-panel .vm-images.count-1 { grid-template-columns: 1fr; }
.vestigia-modal-panel .vm-images.count-2 { grid-template-columns: repeat(2,1fr); }
.vestigia-modal-panel .vm-images.count-3 { grid-template-columns: repeat(3,1fr); }
.vestigia-modal-panel .vm-images.count-4 { grid-template-columns: repeat(2,1fr); }
.vestigia-modal-panel .vm-images img {
  width: 100%; border-radius: var(--radius);
  display: block; object-fit: cover; aspect-ratio: 16/9;
}
.vestigia-modal-panel .vm-subtitle {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(180,150,255,0.9);
  margin: 0 0 14px;
}
.vestigia-modal-panel .vm-body {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-dim);
  line-height: 1.8;
  white-space: pre-wrap;
}
@media (max-width: 600px) {
  .vestigia-images.count-3,
  .vestigia-images.count-4,
  .vestigia-modal-panel .vm-images.count-3,
  .vestigia-modal-panel .vm-images.count-4 {
    grid-template-columns: repeat(2,1fr);
  }
}

/* ═══════════════════════════════════════════
   EVENTS — CALENDRIER
═══════════════════════════════════════════ */
.events-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 40px;
  align-items: start;
}
@media (max-width: 900px) {
  .events-layout { grid-template-columns: 1fr; }
}

/* ── Calendar grid ── */
.ev-calendar {
  background: rgba(201,168,76,0.03);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.ev-cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
}
.ev-cal-month {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  color: var(--gold);
}
.ev-cal-nav {
  background: none;
  border: none;
  color: var(--gold-dim);
  font-size: 1.4rem;
  cursor: pointer;
  padding: 4px 10px;
  border-radius: 6px;
  transition: color 0.2s, background 0.2s;
}
.ev-cal-nav:hover { color: var(--gold-bright); background: rgba(201,168,76,0.08); }
.ev-cal-days-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: rgba(201,168,76,0.04);
  border-bottom: 1px solid var(--border);
}
.ev-cal-day-name {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-align: center;
  padding: 8px 0;
}
.ev-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.ev-cal-cell {
  min-height: 52px;
  padding: 6px 4px 4px;
  border-right: 1px solid rgba(201,168,76,0.06);
  border-bottom: 1px solid rgba(201,168,76,0.06);
  cursor: default;
  position: relative;
  transition: background 0.15s;
}
.ev-cal-cell:nth-child(7n) { border-right: none; }
.ev-cal-cell.other-month { opacity: 0.3; }
.ev-cal-cell.today .ev-day-num {
  background: var(--gold);
  color: var(--bg-deep);
  border-radius: 50%;
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.ev-cal-cell.has-events { cursor: pointer; }
.ev-cal-cell.has-events:hover { background: rgba(201,168,76,0.06); }
.ev-cal-cell.selected { background: rgba(201,168,76,0.10); }
.ev-day-num {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  color: var(--text-dim);
  margin-bottom: 4px;
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
}
.ev-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}
.ev-dot             { background: #5aae8a; }
.ev-dot.war        { background: var(--danger); }
.ev-dot.raid       { background: #c97e3a; }
.ev-dot.meeting    { background: #5a9be0; }
.ev-dot.tournament { background: #9b5ae0; }

/* ── Range bars ── */
.ev-bars { display: flex; flex-direction: column; gap: 2px; margin-top: 3px; }
.ev-range-bar {
  height: 5px;
  overflow: hidden;
  position: relative;
}
/* start: round gauche, bord plat droit — déborde sur la border droite */
.ev-range-bar.ev-range-start  { border-radius: 3px 0 0 3px; margin-right: -4px; }
/* milieu: plat des deux côtés, déborde sur les deux borders */
.ev-range-bar.ev-range-mid    { border-radius: 0; margin-left: -4px; margin-right: -4px; }
/* fin: bord plat gauche, round droit */
.ev-range-bar.ev-range-end    { border-radius: 0 3px 3px 0; margin-left: -4px; }
/* événement sur une seule journée */
.ev-range-bar.ev-range-single { border-radius: 3px; }
/* couleurs par type */
.ev-range-bar             { background: rgba(90,174,138,0.55); }
.ev-range-bar.war        { background: rgba(220,53,69,.55); background: color-mix(in srgb, var(--danger) 55%, transparent); }
.ev-range-bar.raid       { background: rgba(201,126,58,0.55); }
.ev-range-bar.meeting    { background: rgba(90,155,224,0.55); }
.ev-range-bar.tournament { background: rgba(155,90,224,0.55); }

/* ── Day detail panel ── */
.ev-day-panel {
  margin-top: 12px;
  padding: 16px 20px;
  background: rgba(201,168,76,0.04);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  min-height: 60px;
}
.ev-day-panel-title {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-dim);
  margin: 0 0 12px;
}
.ev-day-event {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-top: 1px solid rgba(201,168,76,0.08);
}
.ev-day-event:first-of-type { border-top: none; padding-top: 0; }
.ev-day-event-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-top: 5px;
  flex-shrink: 0;
  background: #5aae8a;
}
.ev-day-event-dot.war        { background: var(--danger); }
.ev-day-event-dot.raid       { background: #c97e3a; }
.ev-day-event-dot.meeting    { background: #5a9be0; }
.ev-day-event-dot.tournament { background: #9b5ae0; }
.ev-day-event-info { flex: 1; }
.ev-day-event-title {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--text);
  margin: 0 0 3px;
}
.ev-day-event-meta {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  color: var(--text-muted);
  letter-spacing: 0.05em;
}

/* ── Upcoming sidebar ── */
.ev-upcoming {
  background: rgba(201,168,76,0.03);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.ev-upcoming-hd {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-dim);
}
.ev-upcoming-list { padding: 8px 0; }
.ev-upcoming-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 12px 20px;
  border-bottom: 1px solid rgba(201,168,76,0.06);
  transition: background 0.15s;
  cursor: default;
}
.ev-upcoming-item:last-child { border-bottom: none; }
.ev-upcoming-date {
  width: 38px;
  text-align: center;
  flex-shrink: 0;
}
.ev-upcoming-date-day {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--gold);
  line-height: 1;
}
.ev-upcoming-date-mon {
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 2px;
}
.ev-upcoming-info { flex: 1; min-width: 0; }
.ev-upcoming-title {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--text);
  margin: 0 0 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ev-upcoming-type {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.ev-no-upcoming {
  padding: 28px 20px;
  text-align: center;
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--text-muted);
  letter-spacing: 0.06em;
}

/* ═══════════════════════════════════════════
   AVAILABILITY POLLS
═══════════════════════════════════════════ */
.avail-list { display: flex; flex-direction: column; gap: 20px; }
.avail-card {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  transition: border-color var(--t);
}
.avail-card:hover { border-color: var(--border-hover); }
.avail-card.expired { position: relative; opacity: 0.55; }
.avail-card.expired::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  background:
    linear-gradient(to top right, transparent calc(50% - 1.5px), var(--danger) calc(50% - 1.5px), var(--danger) calc(50% + 1.5px), transparent calc(50% + 1.5px)),
    linear-gradient(to bottom right, transparent calc(50% - 1.5px), var(--danger) calc(50% - 1.5px), var(--danger) calc(50% + 1.5px), transparent calc(50% + 1.5px));
  border-radius: var(--radius-lg);
  opacity: 0.45;
}
.avail-card.expired .avail-vote-btn { pointer-events: none; opacity: 0.35; cursor: not-allowed; }
.avail-expired-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 12px;
  font-family: var(--font-ui);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: rgba(220,53,69,.15); background: color-mix(in srgb, var(--danger) 15%, transparent);
  color: var(--danger);
  margin-left: 10px;
  vertical-align: middle;
}
.avail-card-hdr { margin-bottom: 16px; }
.avail-card-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.06em;
}
.avail-card-date {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 4px;
}
.avail-card-desc {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--text);
  line-height: 1.5;
  margin-bottom: 16px;
}
.avail-votes {
  display: flex;
  gap: 8px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.avail-vote-btn {
  flex: 1;
  min-width: 120px;
  padding: 10px 14px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all var(--t);
  color: var(--text-muted);
  background: transparent;
  text-align: center;
}
.avail-vote-btn:hover { border-color: var(--gold-dim); color: var(--text); }
.avail-vote-btn.active-present {
  background: rgba(40,167,69,.15); background: color-mix(in srgb, var(--success) 15%, transparent);
  border-color: var(--success);
  color: var(--success);
}
.avail-vote-btn.active-absent {
  background: rgba(220,53,69,.15); background: color-mix(in srgb, var(--danger) 15%, transparent);
  border-color: var(--danger);
  color: var(--danger);
}
.avail-vote-btn.active-uncertain {
  background: var(--gold-glow);
  border-color: var(--gold-dim);
  color: var(--gold);
}
.avail-results { margin-top: 12px; }
.avail-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
}
.avail-bar-label {
  width: 100px;
  text-align: right;
  flex-shrink: 0;
  color: var(--text-muted);
}
.avail-bar-track {
  flex: 1;
  height: 18px;
  background: rgba(255,255,255,0.04);
  border-radius: 4px;
  overflow: hidden;
  position: relative;
}
.avail-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.5s ease;
  min-width: 0;
}
.avail-bar-fill.present  { background: rgba(40,167,69,.6); background: color-mix(in srgb, var(--success) 60%, transparent); }
.avail-bar-fill.absent   { background: rgba(220,53,69,.6); background: color-mix(in srgb, var(--danger) 60%, transparent); }
.avail-bar-fill.uncertain { background: var(--gold-dim); }
.avail-bar-pct {
  width: 48px;
  text-align: left;
  color: var(--text-muted);
  font-size: 0.75rem;
}
.avail-details {
  margin-top: 14px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
}
.avail-details-toggle {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  color: var(--gold-dim);
  cursor: pointer;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: none;
  background: none;
  padding: 4px 0;
}
.avail-details-toggle:hover { color: var(--gold); }
.avail-details-list {
  display: none;
  margin-top: 10px;
}
.avail-details-list.open { display: block; }
.avail-group-title {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 10px 0 4px;
}
.avail-group-title:first-child { margin-top: 0; }
.avail-names {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--text);
  line-height: 1.7;
}
.avail-names .present  { color: var(--success); }
.avail-names .absent   { color: var(--danger); }
.avail-names .uncertain { color: var(--gold); }
.avail-names .not-voted { color: var(--text-dim); font-style: italic; }
.avail-voter-count {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  color: var(--text-dim);
  margin-top: 6px;
}
.avail-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 14px;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  color: var(--text-muted);
  align-items: center;
}
.avail-summary-item { display: inline-flex; align-items: center; gap: 4px; }
.avail-summary-item strong { color: var(--text); }
.avail-summary-item.present { color: var(--success); font-weight: 600; }
.avail-summary-item.absent { color: var(--danger); font-weight: 600; }
.avail-summary-item.uncertain { color: var(--gold); font-weight: 600; }
.avail-summary-item.not-voted { color: var(--text-dim); font-style: italic; }
.not-voted-title { color: var(--text-dim) !important; }

/* ═══════════════════════════════════════════
   WAR SELECTION
═══════════════════════════════════════════ */
.warsel-list { display: flex; flex-direction: column; gap: 18px; }
.warsel-card {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(212,175,55,0.12);
  border-radius: 10px;
  padding: 20px;
  transition: border-color .3s;
}
.warsel-card:hover { border-color: rgba(212,175,55,0.3); }
.warsel-card-hdr { margin-bottom: 10px; }
.warsel-card-title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  color: var(--gold);
  letter-spacing: 0.08em;
}
.warsel-card-date {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  color: var(--text-dim);
  margin-top: 4px;
  letter-spacing: 0.04em;
}
.warsel-members-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}
.warsel-member {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: rgba(212,175,55,0.08);
  border: 1px solid rgba(212,175,55,0.18);
  border-radius: 8px;
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--text-light);
  letter-spacing: 0.04em;
}
.warsel-avatar-wrap {
  position: relative;
  flex-shrink: 0;
}
.warsel-avatar-wrap .member-online-dot {
  width: 12px; height: 12px;
  top: -1px; right: -1px;
}
.warsel-member-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(212,175,55,0.3);
}
.warsel-member-placeholder {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.7rem;
}
.warsel-empty {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--text-muted);
  text-align: center;
  padding: 40px 20px;
  letter-spacing: 0.06em;
}

/* ═══════════════════════════════════════════
   VIGNETTE + GRAIN
═══════════════════════════════════════════ */
#vignette {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(ellipse 90% 90% at 50% 50%,
    transparent 35%,
    rgba(4,6,15,0.30) 65%,
    rgba(4,6,15,0.72) 100%);
}
#grain {
  position: fixed; inset: -30%; z-index: 2; pointer-events: none;
  width: 160%; height: 160%;
  opacity: 0.028;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 220px 220px;
}

/* ═══════════════════════════════════════════
   MESSAGES WIDGET
═══════════════════════════════════════════ */
#msg-widget {
  position: fixed; bottom: 32px; right: 32px; z-index: 150;
  display: flex; flex-direction: column; align-items: flex-end; gap: 12px;
}
#msg-toggle {
  display: none;
}
#msg-toggle:hover {
  border-color: var(--gold);
  box-shadow: 0 4px 24px rgba(0,0,0,0.55), 0 0 32px rgba(201,168,76,0.28);
  transform: scale(1.06);
}
.msg-unread {
  position: absolute; top: -4px; right: -4px;
  background: var(--danger); color: #fff;
  font-family: var(--font-ui); font-size: 0.58rem; font-weight: 700;
  border-radius: 50%; min-width: 18px; height: 18px; padding: 0 3px;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--night-card);
  animation: badgePop 0.3s cubic-bezier(0.34,1.56,0.64,1);
  pointer-events: none;
}
@keyframes badgePop {
  from { transform: scale(0); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}
.msg-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.6); z-index: 99989;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.msg-overlay.open { display: block; animation: overlayFadeIn 0.25s ease; }
@keyframes overlayFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes harmoniaSpinPaused { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.msg-panel {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 99990;
  width: 700px; max-width: 100vw; height: 100dvh;
  background: rgba(3,5,14,0.92);
  border-left: 2px solid rgba(201,168,76,0.2);
  border-radius: 0;
  backdrop-filter: blur(32px) saturate(1.2); -webkit-backdrop-filter: blur(32px) saturate(1.2);
  display: none; flex-direction: column; overflow: hidden;
  overscroll-behavior: contain;
  box-shadow: -8px 0 40px rgba(0,0,0,0.6), -2px 0 20px rgba(201,168,76,0.04), inset 1px 0 0 rgba(201,168,76,0.08);
}
.msg-panel-body {
  display: flex; flex: 1; min-height: 0; overflow: hidden;
}
.msg-panel-main {
  flex: 1; display: flex; flex-direction: column; min-width: 0; overflow: hidden;
}
.msg-panel.open { display: flex; animation: msgIn 0.3s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes msgIn {
  from { opacity:0; transform: scale(0.95) translateX(20px); }
  to   { opacity:1; transform: scale(1) translateX(0); }
}
.msg-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid rgba(201,168,76,0.15);
  background: linear-gradient(180deg, rgba(201,168,76,0.1) 0%, rgba(3,5,14,0.95) 100%);
  position: relative;
}
.msg-panel-header::after {
  content: ''; position: absolute; bottom: -1px; left: 20px; right: 20px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.3), transparent);
}
.msg-panel-title {
  font-family: var(--font-display); font-size: 0.72rem;
  letter-spacing: 0.25em; text-transform: uppercase; color: var(--gold);
}
.msg-back-btn {
  display: none; width: 32px; height: 32px; border-radius: 50%;
  background: none; border: 1px solid transparent; color: var(--gold);
  font-size: 1.1rem; cursor: pointer; align-items: center; justify-content: center;
  transition: background 0.2s; margin-right: 6px; flex-shrink: 0;
}
.msg-back-btn:hover { background: rgba(201,168,76,0.1); }
.msg-panel-close {
  font-size: 0.85rem; color: var(--text-dim); transition: all 0.25s ease;
  width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; border: 1px solid transparent; background: none; cursor: pointer;
}
.msg-panel-close:hover { color: var(--gold); background: rgba(201,168,76,0.1); border-color: rgba(201,168,76,0.15); transform: rotate(90deg); }

/* ── Rank colors for chat author names ── */
.msg-author.group-admin { color: #6699ff; font-weight: 700; }
.msg-author.group-modo  { color: #1abc7c; font-weight: 700; }
.msg-author.group-vip   { color: #b06ad4; font-weight: 700; }

/* ── Back-to-site button in channel list (mobile only) ── */
.msg-ch-site-back {
  display: none;
}

/* ── Channel sidebar ── */
.msg-channels {
  display: flex; flex-direction: column;
  border-right: 1px solid rgba(201,168,76,0.1);
  background: rgba(7,10,28,0.8);
  overflow-y: auto; scrollbar-width: none;
  padding: 6px; width: 250px; flex-shrink: 0; gap: 2px;
}
.msg-channels:empty { display: none; }
.msg-channels.collapsed { width: 0 !important; padding: 0 !important; overflow: hidden; border: none; }
.msg-ch-toggle {
  display: none;
  position: absolute; left: 140px; top: 50%; transform: translateY(-50%);
  z-index: 5; width: 22px; height: 44px; cursor: pointer;
  background: rgba(201,168,76,.15); border: 1px solid rgba(201,168,76,.3);
  border-left: none; border-radius: 0 8px 8px 0;
  color: var(--gold); font-size: .9rem; font-weight: 700;
  align-items: center; justify-content: center;
  transition: background .2s, left .25s ease;
  -webkit-user-select: none; user-select: none;
  box-shadow: 2px 0 8px rgba(0,0,0,.3);
}
.msg-ch-toggle:active { background: rgba(201,168,76,.3); }
.msg-ch-toggle.collapsed { left: 0; }
.msg-channels::-webkit-scrollbar { display: none; }
/* ═══ TELEGRAM-STYLE CHANNEL LIST ═══ */
.msg-ch-btn {
  width: 100%; padding: 8px 12px;
  border: none; background: none; outline: none; -webkit-appearance: none; appearance: none;
  color: var(--text-muted); font-family: var(--font-ui);
  cursor: pointer; transition: background 0.15s; position: relative;
  display: flex; flex-direction: row; align-items: center; gap: 10px;
  pointer-events: auto; margin: 0; border-radius: 8px;
}
.msg-ch-btn:hover { background: rgba(201,168,76,0.06); }
.msg-ch-btn.active {
  background: rgba(201,168,76,0.1);
}
.ch-icon-wrap {
  width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
  background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.15);
  display: flex; align-items: center; justify-content: center;
}
.msg-ch-btn.active .ch-icon-wrap { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.3); }
.msg-ch-btn .ch-icon { font-size: 1rem; }
.ch-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.msg-ch-btn .ch-name {
  display: block; font-size: 0.82rem; font-weight: 600; color: var(--text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.msg-ch-btn.active .ch-name { color: var(--gold); }
.ch-preview {
  display: block; font-size: 0.68rem; color: var(--text-dim);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 100%; line-height: 1.3;
}
.ch-preview b { color: var(--text-muted); font-weight: 600; }
.ch-meta {
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0;
}
.ch-time { font-size: 0.58rem; color: var(--text-dim); white-space: nowrap; }
.msg-ch-badge {
  min-width: 18px; height: 18px; border-radius: 10px; padding: 0 5px;
  background: var(--gold); color: var(--night); font-size: 0.6rem; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 0 8px rgba(220,38,38,0.5);
  animation: badgePop 0.3s cubic-bezier(0.34,1.56,0.64,1), badgePulse 2s ease-in-out infinite 0.3s;
  position: absolute; top: 8px; right: 8px;
}
@keyframes badgePulse {
  0%, 100% { box-shadow: 0 0 6px rgba(220,38,38,0.5); }
  50% { box-shadow: 0 0 12px rgba(220,38,38,0.7); }
}

/* ── Messages ── */
.msg-list {
  flex: 1; overflow-y: auto; padding: 12px 14px;
  display: flex; flex-direction: column; gap: 4px;
}
.msg-list::-webkit-scrollbar { width: 6px; opacity: 0; transition: opacity 0.3s; }
.msg-list:hover::-webkit-scrollbar { opacity: 1; }
.msg-list::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.3); border-radius: 3px; transition: background 0.2s; }
.msg-list::-webkit-scrollbar-thumb:hover { background: rgba(201,168,76,0.5); }
.msg-list::-webkit-scrollbar-track { background: rgba(0,0,0,0.15); border-radius: 3px; }
.msg-list { scrollbar-width: thin; scrollbar-color: rgba(201,168,76,0.3) transparent; }
/* ═══ TELEGRAM-STYLE CHAT BUBBLES ═══ */
.msg-list {
  background: rgba(3,5,14,0.4);
  background-image: radial-gradient(circle at 20% 50%, rgba(201,168,76,0.02) 0%, transparent 50%);
}
.msg-row {
  display: flex; gap: 6px; align-items: flex-end;
  max-width: 80%; animation: bubbleIn 0.15s ease;
}
.msg-row.own { margin-left: auto; flex-direction: row-reverse; }
.msg-row:not(.own) { margin-right: auto; }
@keyframes bubbleIn {
  from { opacity:0; transform: translateY(4px); }
  to   { opacity:1; transform: translateY(0); }
}
/* Avatar à côté de la bulle */
.msg-avatar {
  width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, rgba(201,168,76,0.15), rgba(201,168,76,0.05));
  display: flex; align-items: center; justify-content: center;
  font-size: 0.65rem; color: var(--gold); font-weight: 700;
  font-family: var(--font-display); letter-spacing: 0.05em;
  border: 1.5px solid rgba(201,168,76,0.2); overflow: hidden;
  cursor: pointer; transition: border-color 0.2s, box-shadow 0.2s;
  margin-bottom: 2px;
}
.msg-avatar:hover { border-color: var(--gold); box-shadow: 0 0 8px rgba(201,168,76,0.3); }
.msg-avatar img { width: 100%; height: 100%; object-fit: cover; }

/* Bulle des AUTRES (gauche) */
.msg-bubble {
  background: rgba(20,28,50,0.9); border: none;
  border-radius: 4px 18px 18px 18px; padding: 8px 12px 6px;
  position: relative; min-width: 60px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
/* Queue de bulle gauche */
.msg-row:not(.own) .msg-bubble::before {
  content: ''; position: absolute; bottom: 0; left: -6px;
  width: 12px; height: 12px;
  background: rgba(20,28,50,0.9);
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}

/* Bulle PROPRE (droite) — style Telegram doré */
.msg-row.own .msg-bubble {
  background: linear-gradient(135deg, rgba(201,168,76,0.18) 0%, rgba(140,110,40,0.12) 100%);
  border-radius: 18px 4px 18px 18px;
  box-shadow: 0 1px 3px rgba(201,168,76,0.1);
}
/* Queue de bulle droite */
.msg-row.own .msg-bubble::before {
  content: ''; position: absolute; bottom: 0; right: -6px; left: auto;
  width: 12px; height: 12px;
  background: linear-gradient(135deg, rgba(170,140,50,0.15), rgba(140,110,40,0.12));
  clip-path: polygon(0 0, 100% 100%, 0 100%);
}

/* Header : nom de l'auteur (caché pour ses propres messages) */
.msg-bubble-header {
  display: flex; align-items: center; gap: 6px; margin-bottom: 3px;
}
.msg-user-info { display: flex; align-items: center; gap: 0; }
.msg-user-info.msg-clickable { cursor: pointer; }
.msg-user-info.msg-clickable:hover .msg-author { text-decoration: underline; text-underline-offset: 2px; }
.msg-author {
  font-family: var(--font-ui); font-size: 0.72rem;
  font-weight: 700; color: var(--gold); transition: all 0.2s;
}
.msg-row.own .msg-bubble-header { display: none; }

/* Actions (répondre, supprimer) — apparaissent au hover */
.msg-bubble-actions {
  display: flex; gap: 3px; align-items: center; opacity: 0; transition: opacity 0.15s;
  position: absolute; top: -8px;
  background: rgba(3,5,14,0.9); border-radius: 8px; padding: 2px 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3); z-index: 2;
}
.msg-row:not(.own) .msg-bubble-actions { right: -4px; }
.msg-row.own .msg-bubble-actions { left: -4px; }
.msg-bubble:hover .msg-bubble-actions { opacity: 1; }
.msg-del, .msg-reply-btn {
  font-size: 0.6rem; color: var(--text-dim); cursor: pointer; padding: 3px 5px;
  border-radius: 4px; transition: all 0.15s;
}
.msg-del:hover { color: var(--danger); background: rgba(200,50,50,0.15); }
.msg-reply-btn:hover { color: var(--gold); background: rgba(201,168,76,0.1); }

/* Texte et liens */
.auto-link { color: var(--gold-dim); text-decoration: underline; text-underline-offset: 2px; word-break: break-all; transition: color 0.2s; }
.auto-link:hover { color: var(--gold-bright); }
.msg-text {
  font-family: var(--font-body); font-size: 0.88rem; color: var(--text);
  line-height: 1.5; word-break: break-word; font-weight: 500;
}
.msg-row.own .msg-text { color: var(--text); }
.msg-row.own .auto-link { color: var(--gold); }

/* Messages groupés (même auteur) */
.msg-row.grouped { margin-top: -2px; }
.msg-row.grouped .msg-bubble { border-radius: 4px 18px 18px 4px; }
.msg-row.grouped.own .msg-bubble { border-radius: 18px 4px 4px 18px; }
.msg-row.grouped .msg-bubble::before { display: none; }
.msg-avatar-spacer { width: 34px; flex-shrink: 0; }

/* Timestamp dans la bulle (style Telegram) */
.msg-time {
  font-family: var(--font-ui); font-size: 0.55rem; color: rgba(255,255,255,0.35);
  float: right; margin: 4px -4px -2px 12px; letter-spacing: 0.02em;
}
.msg-row.own .msg-time { color: rgba(201,168,76,0.45); }

/* Traduction */
.msg-translation {
  font-family: var(--font-body); font-size: 0.82rem; color: var(--text-dim);
  font-style: italic; margin-top: 3px; word-break: break-word;
  padding-left: 8px; border-left: 2px solid rgba(201,168,76,0.15);
}
.msg-state {
  text-align: center; padding: 48px 20px; color: var(--text-muted);
  font-family: var(--font-body); font-style: italic; font-size: 0.85rem;
  opacity: 0.7;
}

/* ── Input zone ── */
.msg-input-zone {
  border-top: 1px solid rgba(201,168,76,0.12); padding: 12px 16px;
  display: none; flex-direction: column; gap: 6px;
  background: rgba(3,5,14,0.85);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  position: relative;
}
.msg-input-zone::before {
  content: ''; position: absolute; top: 0; left: 16px; right: 16px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.2), transparent);
}
.msg-input-zone.show { display: flex; }
.msg-input-row { display: flex; gap: 6px; align-items: flex-end; }
/* Input column layout — textarea row + icons row below */
.msg-input-col{display:flex;flex-direction:column;gap:6px;flex:1}
.msg-input-icons{display:flex;gap:10px;align-items:center;padding:0 2px}
.msg-ico-btn{background:rgba(201,168,76,.04);border:1px solid rgba(201,168,76,.12);color:var(--text-dim);cursor:pointer;padding:8px 16px;border-radius:10px;font-size:1.15rem;transition:all .25s ease;line-height:1;display:flex;align-items:center;justify-content:center}
.msg-ico-btn:hover{background:rgba(201,168,76,.12);border-color:rgba(201,168,76,.35);color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 12px rgba(201,168,76,0.1)}
.msg-ico-btn svg{width:20px;height:20px}
@media(max-width:600px){.msg-input-icons{gap:8px}.msg-ico-btn{padding:7px 12px;font-size:1rem}}
/* Legacy — keep for DM and other uses */
.msg-photo-btn {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  background: rgba(201,168,76,0.06); color: var(--text-dim); border: 1px solid rgba(201,168,76,0.12);
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  transition: all 0.25s ease; font-size: .8rem;
}
.msg-photo-btn svg { width: 18px; height: 18px; }
.msg-photo-btn:hover { background: rgba(201,168,76,0.12); border-color: rgba(201,168,76,0.3); color: var(--gold); transform: translateY(-1px); }
.msg-img-preview {
  position: relative; display: inline-block; max-width: 120px; border-radius: 8px; overflow: hidden;
  border: 1px solid rgba(201,168,76,0.2);
}
.msg-img-preview img { display: block; max-width: 120px; max-height: 80px; object-fit: cover; border-radius: 8px; }
.msg-img-remove {
  position: absolute; top: 2px; right: 2px; width: 20px; height: 20px;
  background: rgba(0,0,0,0.7); color: #fff; border: none; border-radius: 50%;
  font-size: 14px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.msg-bubble-img { margin-top: 8px; max-width: 100%; border-radius: 10px; overflow: hidden; border: 1px solid rgba(201,168,76,0.08); }
.msg-video-preview { position: relative; display: inline-block; margin-top: 8px; max-width: 160px; border-radius: 10px; overflow: hidden; border: 1px solid rgba(201,168,76,0.2); cursor: pointer; background: #111; }
.msg-video-preview:hover .msg-video-play { background: rgba(201,168,76,0.85); transform: translate(-50%,-50%) scale(1.1); }
.msg-video-thumb { display: block; width: 160px; height: 100px; object-fit: cover; }
.msg-video-fallback .msg-video-thumb { display: none; }
.msg-video-fallback { height: 160px; }
.msg-video-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 48px; height: 48px; background: rgba(0,0,0,0.65); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 20px; pointer-events: none; transition: background 0.2s, transform 0.2s; padding-left: 4px; box-shadow: 0 2px 8px rgba(0,0,0,0.5); }
.msg-bubble-img img {
  display: block; max-width: 280px; max-height: 300px; border-radius: 10px;
  cursor: zoom-in; object-fit: contain; transition: opacity 0.3s ease, transform 0.3s ease;
}
.msg-bubble-img img:hover { opacity: 0.92; transform: scale(1.02); }

/* ── Reactions ── */
.msg-reactions {
  display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px;
}
.msg-react-pill {
  display: inline-flex; align-items: center; gap: 3px; padding: 3px 8px;
  border-radius: 14px; font-size: 0.72rem; cursor: pointer;
  background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.12);
  color: var(--text-muted); transition: all 0.2s ease; line-height: 1.4;
}
.msg-react-pill:hover { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.35); transform: scale(1.08); }
.msg-react-pill.mine { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.4); color: var(--gold); box-shadow: 0 0 8px rgba(201,168,76,0.1); }
.msg-react-pill .react-count { font-size: 0.6rem; font-weight: 600; }
.msg-react-add {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 22px; border-radius: 12px; font-size: 0.7rem;
  background: rgba(201,168,76,0.05); border: 1px dashed rgba(201,168,76,0.15);
  color: var(--text-dim); cursor: pointer; transition: all 0.2s; opacity: 0;
}
.msg-bubble:hover .msg-react-add { opacity: 1; }
.msg-react-add:hover { background: var(--gold-glow); border-style: solid; color: var(--gold); }
.msg-react-picker {
  position: absolute; bottom: 100%; left: 0; z-index: 10;
  display: flex; flex-wrap: wrap; gap: 3px; padding: 8px 10px; width: 280px;
  background: rgba(14,20,40,0.95); border: 1px solid rgba(201,168,76,0.15);
  border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,0.6), 0 0 0 1px rgba(201,168,76,0.05);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  animation: bubbleIn 0.15s ease;
}
.msg-react-picker span {
  font-size: 1.1rem; cursor: pointer; padding: 3px 4px; border-radius: 6px;
  transition: all 0.15s;
}
.msg-react-picker span:hover { background: var(--gold-glow); transform: scale(1.2); }

/* ── Reply quote (in bubble) ── */
.msg-reply-quote {
  display: flex; align-items: stretch; gap: 0; padding: 0;
  background: rgba(201,168,76,0.03); border-left: 3px solid var(--gold);
  border-radius: 0 8px 8px 0; margin-bottom: 8px; font-size: 0.88rem;
  color: inherit; line-height: 1.4; cursor: pointer; overflow: hidden; font-weight: 600;
  transition: background 0.2s ease;
}
.msg-reply-quote:hover { background: rgba(201,168,76,0.06); }
.msg-reply-quote > div { padding: 6px 10px; }
.msg-reply-quote .rq-name { font-weight: 700; font-size: 0.78rem; letter-spacing: 0.03em; margin-bottom: 1px; display: block; opacity: 0.7; }
.msg-reply-quote .rq-icon { opacity: 0.5; font-size: 0.9rem; padding: 6px 8px 6px 10px; display: flex; align-items: center; }
.msg-reply-quote .rq-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 280px; opacity: 0.7; font-size: 0.85rem; }
/* ── Reply bar (above input) ── */
.msg-reply-bar {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: none; border-left: 3px solid var(--gold);
  border-radius: 0 8px 8px 0; margin-bottom: 4px;
  font-size: 0.78rem; color: var(--text-muted); line-height: 1.3;
}
.msg-reply-bar .rb-icon { color: var(--gold); opacity: 0.6; font-size: 0.85rem; flex-shrink: 0; }
.msg-reply-bar .rb-name { color: var(--gold); font-weight: 700; }
.msg-reply-bar .rb-text { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; opacity: 0.8; }
.msg-reply-bar .rb-close { cursor: pointer; color: var(--text-dim); font-size: 1.1rem; padding: 0 4px; transition: color 0.2s; flex-shrink: 0; }
.msg-reply-bar .rb-close:hover { color: var(--danger); }
/* ── Reply button (on bubble hover) ── */
.msg-reply-btn {
  font-size: 0.8rem; color: var(--text-dim); cursor: pointer;
  transition: all 0.2s; opacity: 0; padding: 2px 4px; border-radius: 4px;
}
.msg-bubble:hover .msg-reply-btn { opacity: 0.6; }
.msg-reply-btn:hover { color: var(--gold); opacity:1 !important; background: rgba(201,168,76,0.1); }

/* ── @mentions ── */
.msg-mention { color: var(--gold); font-weight: 600; background: rgba(201,168,76,0.1); padding: 0 3px; border-radius: 3px; cursor: pointer; }
.msg-mention:hover { background: rgba(201,168,76,0.2); }
.mention-dropdown {
  position: absolute; bottom: 100%; left: 0; right: 0; z-index: 20;
  max-height: 180px; overflow-y: auto;
  background: rgba(14,20,40,0.95); border: 1px solid rgba(201,168,76,0.12);
  border-radius: 12px; box-shadow: 0 -8px 32px rgba(0,0,0,0.6);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  padding: 4px; display: none;
}
.mention-dropdown.show { display: block; animation: bubbleIn 0.15s ease; }
.mention-item {
  display: flex; align-items: center; gap: 8px; padding: 7px 10px;
  border-radius: 6px; cursor: pointer; font-size: 0.78rem;
  color: var(--text); transition: background 0.15s;
}
.mention-item:hover, .mention-item.active { background: var(--gold-subtle); }
.mention-item img { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; }
.mention-item .mi-ph { width: 22px; height: 22px; border-radius: 50%; background: var(--gold-glow); display: flex; align-items: center; justify-content: center; font-size: 0.55rem; color: var(--gold); font-weight: 700; }
.mention-item .mi-name { font-weight: 500; }

/* ── Search ── */
.msg-search-bar {
  display: none; padding: 8px 14px; border-bottom: 1px solid rgba(201,168,76,0.08);
  background: rgba(11,15,31,0.5);
}
.msg-search-bar.show { display: flex; gap: 8px; align-items: center; }
.msg-search-bar input {
  flex: 1; background: rgba(20,24,48,0.6); border: 1px solid rgba(201,168,76,0.1);
  border-radius: 8px; color: var(--text); font-family: var(--font-body); font-size: 0.8rem;
  padding: 6px 10px; outline: none; transition: border-color 0.2s;
}
.msg-search-bar input:focus { border-color: rgba(201,168,76,0.3); }
.msg-search-bar .search-close { color: var(--text-dim); cursor: pointer; font-size: 0.85rem; transition: color 0.2s; border: none; background: none; }
.msg-search-bar .search-close:hover { color: var(--gold); }

/* ── Advanced Search Panel ── */
.chat-search-panel {
  display: none; flex-direction: column;
  background: rgba(11,15,31,0.95); border-bottom: 1px solid var(--border);
  max-height: 0; overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1), padding 0.3s ease;
}
.chat-search-panel.open {
  display: flex; max-height: 70vh; overflow-y: auto;
  padding: 12px 14px;
}
.chat-search-filters {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: flex-end;
  padding-bottom: 10px; border-bottom: 1px solid rgba(201,168,76,0.08);
}
.chat-search-filters .csf-group {
  display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.chat-search-filters .csf-group.csf-text { flex: 1 1 200px; }
.chat-search-filters .csf-group.csf-author { flex: 0 1 140px; }
.chat-search-filters .csf-group.csf-date { flex: 0 1 130px; }
.chat-search-filters label {
  font-size: 0.6rem; font-family: var(--font-ui); color: var(--text-dim);
  text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
}
.chat-search-input {
  background: rgba(20,24,48,0.6); border: 1px solid rgba(201,168,76,0.1);
  border-radius: 8px; color: var(--text); font-family: var(--font-body); font-size: 0.78rem;
  padding: 6px 10px; outline: none; transition: border-color 0.2s; width: 100%;
}
.chat-search-input:focus { border-color: rgba(201,168,76,0.3); }
.chat-search-input::placeholder { color: var(--text-muted); font-size: 0.72rem; }
.csf-types {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center; padding-top: 2px;
}
.csf-types label {
  display: flex; align-items: center; gap: 3px; cursor: pointer;
  font-size: 0.68rem; color: var(--text-dim); text-transform: none; letter-spacing: 0;
  font-weight: 500; transition: color 0.2s;
}
.csf-types label:hover { color: var(--text); }
.csf-types input[type="checkbox"] {
  accent-color: var(--gold); width: 13px; height: 13px; cursor: pointer;
}
.csf-channel-toggle {
  display: flex; align-items: center; gap: 6px;
}
.csf-channel-toggle label {
  font-size: 0.68rem; text-transform: none; letter-spacing: 0; font-weight: 500; cursor: pointer;
}
.csf-channel-toggle input[type="checkbox"] {
  accent-color: var(--gold); width: 13px; height: 13px; cursor: pointer;
}
.csf-actions {
  display: flex; gap: 6px; align-items: flex-end; padding-top: 2px;
}
.csf-search-btn {
  padding: 6px 16px; border: 1px solid var(--gold); background: var(--gold-glow);
  color: var(--gold); font-family: var(--font-ui); font-size: 0.72rem; font-weight: 600;
  border-radius: 8px; cursor: pointer; transition: all 0.2s; white-space: nowrap;
  letter-spacing: 0.03em;
}
.csf-search-btn:hover { background: var(--gold); color: var(--night); }
.csf-clear-btn {
  padding: 6px 12px; border: 1px solid var(--border); background: none;
  color: var(--text-dim); font-family: var(--font-ui); font-size: 0.68rem;
  border-radius: 8px; cursor: pointer; transition: all 0.2s; white-space: nowrap;
}
.csf-clear-btn:hover { color: var(--text); border-color: var(--text-dim); }

.chat-search-count {
  font-size: 0.68rem; color: var(--text-dim); padding: 8px 0 4px;
  font-family: var(--font-ui); letter-spacing: 0.02em;
}
.chat-search-count b { color: var(--gold); font-weight: 600; }

.chat-search-results {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 45vh; overflow-y: auto; padding: 4px 0;
}
.chat-search-results::-webkit-scrollbar { width: 3px; }
.chat-search-results::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.2); border-radius: 2px; }
.chat-search-results::-webkit-scrollbar-track { background: transparent; }

.chat-search-result {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 8px 10px; border-radius: 8px;
  background: rgba(20,24,48,0.4); border: 1px solid rgba(201,168,76,0.06);
  cursor: pointer; transition: all 0.2s; overflow: hidden;
}
.chat-search-result:hover {
  background: rgba(201,168,76,0.06); border-color: rgba(201,168,76,0.15);
}
.csr-avatar {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--gold-glow), var(--gold-subtle));
  display: flex; align-items: center; justify-content: center;
  font-size: 0.6rem; color: var(--gold); font-weight: 700;
  font-family: var(--font-display); border: 1px solid var(--border); overflow: hidden;
}
.csr-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.csr-body { flex: 1; min-width: 0; }
.csr-header {
  display: flex; align-items: center; gap: 6px; margin-bottom: 2px;
}
.csr-name {
  font-size: 0.72rem; font-weight: 600; color: var(--text);
  font-family: var(--font-ui);
}
.csr-channel {
  font-size: 0.6rem; color: var(--gold-dim); background: rgba(201,168,76,0.08);
  padding: 1px 6px; border-radius: 4px; font-family: var(--font-ui); white-space: nowrap;
}
.csr-time {
  font-size: 0.6rem; color: var(--text-muted); margin-left: auto; white-space: nowrap;
  font-family: var(--font-ui);
}
.csr-preview {
  font-size: 0.72rem; color: var(--text-dim); line-height: 1.35;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-family: var(--font-body);
}
.csr-type-badge {
  font-size: 0.58rem; color: var(--text-muted); background: rgba(201,168,76,0.06);
  padding: 1px 5px; border-radius: 3px; margin-left: 4px; font-family: var(--font-ui);
}

.chat-search-empty {
  text-align: center; padding: 20px 10px; color: var(--text-dim);
  font-size: 0.78rem; font-family: var(--font-body); font-style: italic;
}

@media (max-width: 600px) {
  .chat-search-panel.open { padding: 8px 10px; }
  .chat-search-filters { gap: 6px; }
  .chat-search-filters .csf-group { flex: 1 1 100%; }
  .chat-search-filters .csf-group.csf-date { flex: 1 1 45%; }
  .chat-search-results { max-height: 35vh; }
  .chat-search-result { padding: 6px 8px; gap: 8px; }
  .csr-avatar { width: 26px; height: 26px; }
}

/* ── Audio messages (custom player) ── */
.msg-audio { margin-top: 6px; }
.voice-player { display:flex; align-items:center; gap:8px; padding:6px 10px; border-radius:20px; background:rgba(255,255,255,0.06); max-width:280px; min-width:200px; user-select:none; }
.voice-play-btn { width:32px; height:32px; border-radius:50%; border:none; background:rgba(255,215,0,0.2); color:#ffd700; font-size:14px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background 0.2s; }
.voice-play-btn:hover { background:rgba(255,215,0,0.35); }
.voice-play-btn.loading { opacity:0.5; pointer-events:none; }
.voice-track { flex:1; display:flex; flex-direction:column; gap:2px; min-width:0; }
.voice-bar-wrap { width:100%; height:6px; background:rgba(255,255,255,0.1); border-radius:3px; cursor:pointer; position:relative; }
.voice-bar { height:100%; background:linear-gradient(90deg,#ffd700,#ff8c00); border-radius:3px; width:0%; transition:width 0.15s linear; pointer-events:none; }
.voice-time { font-size:0.65rem; color:rgba(255,255,255,0.5); font-variant-numeric:tabular-nums; white-space:nowrap; min-width:58px; text-align:right; }

/* ── Typing indicator ── */
.msg-typing {
  padding: 2px 14px 4px; font-size: 0.7rem; color: var(--text-dim);
  font-style: italic; font-family: var(--font-body);
  min-height: 18px; transition: opacity 0.3s;
}
.msg-typing:empty { opacity: 0; }
.typing-dots { display: inline-flex; gap: 2px; margin-left: 4px; vertical-align: middle; }
.typing-dots span {
  width: 4px; height: 4px; border-radius: 50%; background: var(--text-dim);
  animation: typingBounce 1.2s infinite;
}
.typing-dots span:nth-child(2) { animation-delay: 0.2s; }
.typing-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingBounce { 0%,60%,100% { transform: translateY(0); } 30% { transform: translateY(-4px); } }

/* ── Link preview ── */
.msg-link-preview {
  display: flex; gap: 10px; margin-top: 6px; padding: 8px 10px;
  background: rgba(20,24,48,0.6); border: 1px solid rgba(201,168,76,0.08);
  border-radius: 8px; cursor: pointer; transition: border-color 0.2s;
  text-decoration: none; overflow: hidden;
}
.msg-link-preview:hover { border-color: rgba(201,168,76,0.2); }
.msg-link-preview img {
  width: 60px; height: 60px; border-radius: 6px; object-fit: cover; flex-shrink: 0;
}
.msg-lp-info { flex: 1; min-width: 0; overflow: hidden; }
.msg-lp-title { font-size: 0.75rem; font-weight: 600; color: var(--gold); line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.msg-lp-desc { font-size: 0.68rem; color: var(--text-dim); line-height: 1.3; margin-top: 2px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.msg-lp-url { font-size: 0.6rem; color: var(--text-muted); margin-top: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#msg-input {
  flex: 1; min-width: 0; background: rgba(14,20,40,0.6); border: 1.5px solid rgba(201,168,76,.1);
  border-radius: 22px; color: var(--text);
  font-family: var(--font-body); font-size: 0.88rem;
  padding: 10px 18px; resize: none; line-height: 1.4; min-height: 40px; max-height: 100px;
  transition: border-color .3s ease, box-shadow .3s ease, background .3s ease;
  box-sizing: border-box;
}
#msg-input:focus { outline: none; border-color: rgba(201,168,76,.45); background: rgba(20,28,50,0.7); box-shadow: 0 0 0 3px rgba(201,168,76,0.08), 0 0 16px rgba(201,168,76,0.06); }
#msg-input::placeholder { color: var(--text-dim); font-style: italic; font-size: 0.82rem; }
.msg-input-zone { position: sticky; bottom: 0; z-index: 5; background: rgba(3,5,14,0.95); }
.msg-send {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(201,168,76,0.2), rgba(201,168,76,0.08));
  color: var(--gold); font-size: 1.15rem;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.3s ease; flex-shrink: 0; border: 1px solid rgba(201,168,76,0.2);
}
.msg-send:hover { background: linear-gradient(135deg, var(--gold), #d4af37); color: var(--night); border-color: var(--gold); box-shadow: 0 4px 20px rgba(201,168,76,0.35); transform: scale(1.05); }
.msg-send:disabled { opacity: 0.2; cursor: not-allowed; transform: none; box-shadow: none; }
.msg-locked-zone {
  border-top: 1px solid rgba(201,168,76,0.1); padding: 24px 20px;
  text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px;
  color: var(--text-muted); font-family: var(--font-body); font-size: 0.85rem;
  background: rgba(3,5,14,0.6);
}
@media (max-width: 900px) {
  #msg-widget { bottom: 18px; right: 14px; }
  #msg-toggle { width: 48px; height: 48px; font-size: 1.1rem; }
  .msg-panel {
    position: fixed !important; inset: 0 !important; z-index: 99991 !important;
    width: 100vw !important; height: 100dvh !important; max-height: none !important;
    border-radius: 0 !important; border: none !important; box-shadow: none !important;
    overscroll-behavior: contain;
  }
  .dm-panel {
    width: 100vw !important; right: -100vw !important;
    border-left: none !important; box-shadow: none !important;
  }
  .dm-panel.open { right: 0 !important; }
  .msg-panel.open { animation: msgInMobile 0.2s ease-out; }
  @keyframes msgInMobile {
    from { opacity:0; transform: translateY(100%); }
    to   { opacity:1; transform: translateY(0); }
  }
  /* ── Header compact mobile ── */
  .msg-panel-header { padding: 10px 14px; }
  .msg-panel-title { font-size: .65rem; letter-spacing: .15em; }
  .msg-panel-close { width: 36px; height: 36px; font-size: 1.15rem !important; }
  .streak-display { font-size: 0.85rem !important; padding: 4px 10px; }
  .streak-lb-btn { font-size: 1.15rem !important; }
  /* ── Comm tabs compact ── */
  .comm-tabs { flex-shrink: 0; }
  .comm-tab { padding: 8px 6px; font-size: .68rem; }
  /* ── TELEGRAM MOBILE LAYOUT : channels OU conversation, jamais les deux ── */
  .msg-panel-body {
    display: flex; flex-direction: row; flex: 1; min-height: 0;
    position: relative; overflow: hidden;
  }
  /* Channels = plein écran par défaut */
  .msg-channels {
    position: absolute; inset: 0; z-index: 2;
    flex-direction: column; width: 100% !important; border: none;
    overflow-y: auto; overflow-x: hidden;
    padding: 6px; gap: 2px;
    background: var(--night-alt);
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
    transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
  }
  .msg-channels::-webkit-scrollbar { display: none; }
  /* Quand on ouvre une conversation, les channels glissent à gauche */
  .msg-channels.chat-open {
    transform: translateX(-100%);
    pointer-events: none;
  }
  .msg-ch-site-back {
    display: flex; align-items: center; gap: 8px; width: 100%;
    padding: 11px 14px; background: none; border: none;
    border-bottom: 1px solid rgba(201,168,76,0.12);
    color: var(--text-dim); font-size: 0.85rem; cursor: pointer;
    margin-bottom: 4px; font-family: var(--font-ui);
    transition: color 0.2s;
  }
  .msg-ch-site-back:hover { color: var(--gold); }
  .msg-ch-site-back .site-back-arrow { font-size: 1.1rem; }
  .ch-icon-wrap { width: 40px; height: 40px; }
  .msg-ch-btn { padding: 10px 12px; gap: 10px; border-radius: 10px; margin: 0; border: none; }
  .msg-ch-btn .ch-name { font-size: 0.85rem; }
  .ch-preview { font-size: 0.7rem; }
  .msg-ch-btn.active { background: rgba(201,168,76,0.1); }
  .msg-ch-toggle { display: none !important; }

  /* Conversation = cachée par défaut, apparaît quand on sélectionne un channel */
  .msg-panel-main {
    position: absolute; inset: 0; z-index: 3;
    min-width: 0; min-height: 0; overflow: hidden;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
    background: rgba(3,5,14,0.98);
  }
  .msg-panel-main.chat-open {
    transform: translateX(0);
  }

  /* Bouton retour ← dans la conversation */
  .msg-back-btn {
    display: flex !important;
  }

  /* ── Messages ── */
  .msg-list { padding: 6px 8px; gap: 3px; flex: 1; }
  .msg-row { max-width: 88%; }
  .msg-bubble { padding: 6px 10px 4px; }
  .msg-text { font-size: 0.88rem; }
  .msg-author { font-size: 0.7rem; }
  .msg-avatar { width: 30px; height: 30px; font-size: .6rem; }
  .msg-avatar-spacer { width: 30px; }
  .msg-bubble-actions { top: 2px; right: 2px; }
  /* ── Input zone ── */
  .msg-input-zone {
    padding: 6px 8px; flex-shrink: 0;
    position: sticky; bottom: 0;
    background: rgba(3,5,14,.95);
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  }
  .msg-input-row { gap: 5px; }
  .msg-photo-btn { width: 30px; height: 30px; }
  #msg-input { font-size: 0.84rem; padding: 7px 10px; border-radius: 8px; }
  .msg-input-icons { gap: 6px; padding: 2px 0; }
  .msg-ico-btn { padding: 5px 10px; font-size: .9rem; }
  .msg-bubble-img img { max-width: 200px; max-height: 200px; }
  /* ── GIF/Emoji picker mobile ── */
  .gif-picker, .emoji-picker { max-height: 200px; }
  .gif-results { grid-template-columns: repeat(3, 1fr) !important; }
  /* ── Reply bar compact ── */
  .msg-reply-bar { padding: 4px 10px; font-size: .72rem; }
  /* ── DM inline mobile ── */
  .comm-dm-tab { flex: 1; min-height: 0; }
  .comm-dm-body { flex: 1; min-height: 0; }
  .comm-dm-input-wrap { flex-shrink: 0; }
}

/* ═══════════════════════════════════════════
   GALLERY
═══════════════════════════════════════════ */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
  padding: 8px 0;
}
.gallery-item {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: var(--radius);
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--surface);
  transition: transform 0.2s ease, border-color 0.2s ease;
}
.gallery-item:hover {
  transform: scale(1.03);
  border-color: var(--gold-dim);
}
.gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.3s ease;
}
.gallery-item-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(4,6,15,0.85));
  padding: 20px 8px 8px;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.gallery-item:hover .gallery-item-overlay { opacity: 1; }
.gallery-item-caption {
  font-size: 0.7rem;
  color: var(--text-dim);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gallery-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 60px 20px;
  font-family: var(--font-body);
}
.gallery-age-badge {
  display: inline-block;
  background: var(--danger, #c0392b);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 2px 8px;
  border-radius: 4px;
  margin-bottom: 4px;
  vertical-align: middle;
}
@media (max-width: 600px) {
  .gallery-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 8px; }
}

/* ═══════════════════════════════════════════
   DONATE BANNER
═══════════════════════════════════════════ */
.donate-banner {
  max-width: 520px;
  margin: 0 auto 64px;
  padding: 32px 36px;
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: 4px;
  background: linear-gradient(160deg, rgba(201,168,76,0.04) 0%, rgba(201,168,76,0.02) 100%);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.donate-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.donate-icon {
  font-size: 1.5rem;
  letter-spacing: 0.4em;
  margin-bottom: 14px;
  opacity: 0.7;
}
.donate-title {
  font-family: var(--font-display);
  font-size: clamp(1rem, 3vw, 1.25rem);
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: linear-gradient(120deg, #a07830 0%, var(--gold) 40%, var(--gold-bright) 60%, #a07830 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 10px;
}
.donate-tagline {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  font-style: italic;
  margin-bottom: 16px;
}
.donate-body {
  font-family: var(--font-body);
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 22px;
}
.donate-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 24px;
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 2px;
  background: rgba(201,168,76,0.07);
  color: var(--gold);
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 0.25s, border-color 0.25s, box-shadow 0.25s, color 0.25s;
  cursor: pointer;
}
.donate-btn:hover {
  background: rgba(201,168,76,0.14);
  border-color: rgba(201,168,76,0.6);
  box-shadow: 0 0 18px rgba(201,168,76,0.12);
  color: var(--gold-bright);
}
.donate-btn[href*="revolut"]:hover {
  background: rgba(0,186,255,0.15) !important;
  border-color: rgba(0,186,255,0.6) !important;
  box-shadow: 0 0 18px rgba(0,186,255,0.15);
  color: #4dd4ff !important;
}
.donate-disclaimer {
  font-family: var(--font-ui);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  margin-top: 12px;
  opacity: 0.6;
}
/* Donor badge on member card — glowing gold */
@keyframes donor-glow {
  0%, 100% { box-shadow: 0 0 6px 2px rgba(232,201,106,.5), 0 0 14px 4px rgba(201,168,76,.25); }
  50% { box-shadow: 0 0 10px 4px rgba(232,201,106,.8), 0 0 22px 8px rgba(201,168,76,.4), 0 0 36px 12px rgba(201,168,76,.15); }
}
@keyframes donor-sparkle {
  0%, 100% { opacity: 0; transform: scale(.5) rotate(0deg); }
  50% { opacity: 1; transform: scale(1) rotate(180deg); }
}
.donor-badge {
  position: absolute;
  top: -6px; left: -6px;
  width: 24px; height: 24px;
  background: linear-gradient(135deg, #B8942A 0%, #F5E08C 40%, #E8C96A 60%, #B8942A 100%);
  background-size: 200% 200%;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  line-height: 1;
  pointer-events: none;
  z-index: 6;
  border: 2px solid var(--night-card);
  animation: donor-glow 2.5s ease-in-out infinite, donor-shimmer 3s ease-in-out infinite;
  filter: drop-shadow(0 0 3px rgba(232,201,106,.6));
}
@keyframes donor-shimmer {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
.donor-badge::after {
  content: '✦';
  position: absolute;
  top: -5px; right: -5px;
  font-size: 8px;
  color: #F5E08C;
  animation: donor-sparkle 2s ease-in-out infinite;
  pointer-events: none;
}
/* Donor halo — orbiting golden bead with sparkle trail */
@keyframes donor-orbit {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes donor-sparkle-glow {
  0%, 100% { opacity: 1; box-shadow: 0 0 4px 1px rgba(245,224,140,0.5); }
  50%      { opacity: .5; box-shadow: 0 0 10px 4px rgba(255,240,160,0.9), 0 0 20px 6px rgba(245,224,140,0.3); }
}
@keyframes donor-trail {
  0%, 100% { opacity: .6; box-shadow: 0 0 3px 1px rgba(245,224,140,0.3); }
  50%      { opacity: 0; box-shadow: 0 0 6px 3px rgba(255,240,160,0.6); }
}
.donor-halo {
  position: relative;
}
/* Main bead */
.donor-halo::after {
  content: '';
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #FFF8DC, #F5E08C 40%, #B8942A);
  top: -4px;
  left: 50%;
  margin-left: -3.5px;
  transform-origin: 3.5px 29px;
  animation: donor-orbit 3s linear infinite, donor-sparkle-glow 0.8s ease-in-out infinite;
  pointer-events: none;
  z-index: 3;
}
/* Trailing sparkle particle (follows behind) */
.donor-halo::before {
  content: '';
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: radial-gradient(circle, #FFF8DC, #F5E08C);
  top: -4px;
  left: 50%;
  margin-left: -2px;
  transform-origin: 2px 29px;
  animation: donor-orbit 3s linear infinite, donor-trail 0.6s ease-in-out infinite;
  animation-delay: -0.4s, 0s;
  pointer-events: none;
  z-index: 3;
}
/* Modal avatar (96px) — bigger bead, wider orbit */
.mp-avatar-wrap.donor-halo::after {
  width: 9px;
  height: 9px;
  top: -5px;
  margin-left: -4.5px;
  transform-origin: 4.5px 53px;
}
.mp-avatar-wrap.donor-halo::before {
  width: 5px;
  height: 5px;
  top: -5px;
  margin-left: -2.5px;
  transform-origin: 2.5px 53px;
}
.donor-legend {
  background: linear-gradient(135deg, #B8942A, #E8C96A);
  font-size: 9px;
}

/* ── Tournament Frames (CSS-only, premium) ── */
/* Gold — 1st place: thick gradient border + warm glow */
.member-avatar-wrap.frame-gold .member-avatar,
.mp-avatar-wrap.frame-gold .mp-avatar {
  border: 4px solid #ffd700;
  border-image: linear-gradient(135deg, #fff8d0, #f2c642, #d49a10, #f0c740, #b07808) 1;
  border-image: none; border-color: #ffd700;
  outline: 2px solid rgba(255,215,0,0.3);
  outline-offset: 2px;
  box-shadow:
    0 0 8px rgba(255,215,0,0.6),
    0 0 20px rgba(255,200,0,0.35),
    inset 0 0 8px rgba(255,215,0,0.15);
  animation: glowGold 2.5s ease-in-out infinite;
}
@keyframes glowGold {
  0%,100% {
    box-shadow: 0 0 8px rgba(255,215,0,0.5), 0 0 20px rgba(255,200,0,0.25), inset 0 0 8px rgba(255,215,0,0.1);
    outline-color: rgba(255,215,0,0.25);
  }
  50% {
    box-shadow: 0 0 16px rgba(255,215,0,0.9), 0 0 40px rgba(255,200,0,0.5), inset 0 0 12px rgba(255,215,0,0.25);
    outline-color: rgba(255,215,0,0.5);
  }
}
/* Silver — 2nd place: icy moonlight aura */
.member-avatar-wrap.frame-silver .member-avatar,
.mp-avatar-wrap.frame-silver .mp-avatar {
  border: 5px solid #c8d4f0;
  outline: 3px solid rgba(160,190,255,0.4);
  outline-offset: 3px;
  box-shadow:
    0 0 0 8px rgba(160,190,255,0.15),
    0 0 12px rgba(160,190,255,0.7),
    0 0 28px rgba(140,170,240,0.4),
    0 0 50px rgba(120,150,220,0.2),
    inset 0 0 10px rgba(160,190,255,0.15);
  animation: glowSilver 2.5s ease-in-out infinite;
}
@keyframes glowSilver {
  0%,100% {
    box-shadow: 0 0 0 8px rgba(160,190,255,0.12), 0 0 12px rgba(160,190,255,0.6), 0 0 28px rgba(140,170,240,0.3), 0 0 50px rgba(120,150,220,0.15), inset 0 0 10px rgba(160,190,255,0.1);
    outline-color: rgba(160,190,255,0.35);
  }
  50% {
    box-shadow: 0 0 0 10px rgba(160,190,255,0.22), 0 0 20px rgba(160,190,255,1), 0 0 42px rgba(140,170,240,0.55), 0 0 64px rgba(120,150,220,0.3), inset 0 0 14px rgba(160,190,255,0.25);
    outline-color: rgba(160,190,255,0.65);
  }
}
/* Bronze — 3rd place: forged ember aura */
.member-avatar-wrap.frame-bronze .member-avatar,
.mp-avatar-wrap.frame-bronze .mp-avatar {
  border: 5px solid #cd7f32;
  outline: 3px solid rgba(220,140,50,0.4);
  outline-offset: 3px;
  box-shadow:
    0 0 0 8px rgba(205,127,50,0.15),
    0 0 12px rgba(205,127,50,0.7),
    0 0 28px rgba(220,140,50,0.4),
    0 0 50px rgba(180,100,20,0.2),
    inset 0 0 10px rgba(205,127,50,0.15);
  animation: glowBronze 2.5s ease-in-out infinite;
}
@keyframes glowBronze {
  0%,100% {
    box-shadow: 0 0 0 8px rgba(205,127,50,0.12), 0 0 12px rgba(205,127,50,0.6), 0 0 28px rgba(220,140,50,0.3), 0 0 50px rgba(180,100,20,0.15), inset 0 0 10px rgba(205,127,50,0.1);
    outline-color: rgba(220,140,50,0.35);
  }
  50% {
    box-shadow: 0 0 0 10px rgba(205,127,50,0.22), 0 0 20px rgba(205,127,50,1), 0 0 42px rgba(220,140,50,0.55), 0 0 64px rgba(180,100,20,0.3), inset 0 0 14px rgba(205,127,50,0.25);
    outline-color: rgba(220,140,50,0.65);
  }
}
/* Champion — permanent: double ring, thick border, divine aura */
.member-avatar-wrap.frame-champion .member-avatar,
.mp-avatar-wrap.frame-champion .mp-avatar {
  border: 5px solid #ffd700;
  outline: 3px solid rgba(255,215,0,0.5);
  outline-offset: 3px;
  box-shadow:
    0 0 0 8px rgba(255,215,0,0.15),
    0 0 14px rgba(255,215,0,0.8),
    0 0 32px rgba(255,200,0,0.45),
    0 0 56px rgba(255,180,0,0.2),
    inset 0 0 12px rgba(255,215,0,0.2);
  animation: glowChampion 2s ease-in-out infinite;
}
@keyframes glowChampion {
  0%,100% {
    box-shadow: 0 0 0 8px rgba(255,215,0,0.12), 0 0 14px rgba(255,215,0,0.7), 0 0 32px rgba(255,200,0,0.35), 0 0 56px rgba(255,180,0,0.15), inset 0 0 12px rgba(255,215,0,0.15);
    outline-color: rgba(255,215,0,0.4);
  }
  50% {
    box-shadow: 0 0 0 10px rgba(255,215,0,0.2), 0 0 22px rgba(255,215,0,1), 0 0 48px rgba(255,200,0,0.6), 0 0 72px rgba(255,180,0,0.3), inset 0 0 16px rgba(255,215,0,0.3);
    outline-color: rgba(255,215,0,0.7);
  }
}
/* Crown badge on member card */
.member-crown-badge {
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 1px;
  font-size: 0.65rem;
  line-height: 1;
  z-index: 6;
  pointer-events: none;
}
.member-crown-badge .crown-icon { font-size: 0.75rem; }
.member-crown-badge .crown-count { color: var(--gold); font-weight: 700; font-size: 0.6rem; }
/* Frame selector in profile */
.frame-picker { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.frame-pick-btn {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 8px 10px; border-radius: var(--radius); border: 2px solid var(--border);
  background: var(--night-card); cursor: pointer; font-size: .68rem; color: var(--text-muted);
  transition: border-color 0.2s, background 0.2s; min-width: 70px;
}
.frame-pick-btn:hover { border-color: var(--gold); background: rgba(201,168,76,0.08); }
.frame-pick-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(201,168,76,0.12); }
.frame-pick-btn .fpb-preview {
  width: 36px; height: 36px; border-radius: 50%; background: var(--night-alt);
  display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
}
.frame-pick-btn.fpb-gold .fpb-preview { outline: 3px solid #ffd700; box-shadow: 0 0 8px rgba(255,215,0,0.5); }
.frame-pick-btn.fpb-silver .fpb-preview { outline: 3px solid #c0c0c0; box-shadow: 0 0 8px rgba(192,192,192,0.4); }
.frame-pick-btn.fpb-bronze .fpb-preview { outline: 3px solid #cd7f32; box-shadow: 0 0 8px rgba(205,127,50,0.4); }
.frame-pick-btn.fpb-champion .fpb-preview { outline: 3px solid #ffd700; box-shadow: 0 0 12px rgba(255,215,0,0.7); animation: frameChampionPulse 2.5s ease-in-out infinite; outline-offset: 2px; }
/* Latest donors in donate banner */
.donate-latest {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(201,168,76,0.12);
}
.donate-latest-title {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-dim);
  margin-bottom: 8px;
}
.donate-latest-item {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  color: rgba(201,168,76,0.7);
  line-height: 1.9;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.donate-latest-item .donor-name { color: var(--gold); font-weight: 600; }

/* ═══════════════════════════════════════
   LITERARY SUMMARY (TL;DR IA)
═══════════════════════════════════════ */
.lit-summary-wrap { margin: 8px 0 18px; }
.lit-summary-btn {
  background: linear-gradient(135deg, rgba(201,168,76,0.15), rgba(150,100,200,0.15));
  border: 1px solid rgba(201,168,76,0.35);
  color: var(--gold);
  font-family: var(--font-ui);
  font-size: .72rem;
  letter-spacing: .1em;
  padding: 8px 14px;
  border-radius: 8px;
  cursor: pointer;
  transition: background .2s, border-color .2s;
  text-transform: uppercase;
  font-weight: 600;
}
.lit-summary-btn:hover:not(:disabled) { background: linear-gradient(135deg, rgba(201,168,76,0.25), rgba(150,100,200,0.22)); border-color: var(--gold); }
.lit-summary-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.lit-summary-box {
  margin-top: 10px;
  background: rgba(30,10,60,0.25);
  border: 1px solid rgba(201,168,76,0.15);
  border-left: 3px solid var(--gold);
  border-radius: 6px;
  padding: 12px 14px;
  font-family: var(--font-ui);
}
.lit-summary-title { font-size: .68rem; letter-spacing: .15em; color: var(--gold); text-transform: uppercase; margin-bottom: 6px; opacity: .85; }
.lit-summary-text { font-size: .85rem; color: var(--text); line-height: 1.6; white-space: pre-line; }
.lit-summary-other { margin-top: 10px; }
.lit-summary-other summary { cursor: pointer; color: var(--text-dim); font-size: .7rem; padding: 4px 0; }
.lit-summary-other summary:hover { color: var(--gold-dim); }
.lit-summary-other .lit-summary-text { margin-top: 6px; font-size: .78rem; opacity: .85; }
.lit-summary-loading { color: var(--text-dim); font-size: .8rem; font-style: italic; }
.lit-summary-err { color: #e05555; font-size: .8rem; }

/* ═══════════════════════════════════════
   ACTIVITY HEATMAP (member profile)
═══════════════════════════════════════ */
.mp-heatmap-wrap { margin-top: 18px; padding: 12px; background: rgba(30,10,60,0.2); border: 1px solid rgba(201,168,76,0.12); border-radius: 10px; }
.mp-heatmap-stats { font-size: .7rem; color: var(--text-dim); margin-bottom: 10px; font-style: italic; }
.mp-heatmap-loading { font-size: .7rem; color: var(--text-dim); }
.mp-heatmap-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; overscroll-behavior: contain; }
.mp-heatmap-scroll::-webkit-scrollbar { height: 4px; }
.mp-heatmap-scroll::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.2); border-radius: 2px; }
.mp-heatmap-grid { display: flex; gap: 2px; min-width: min-content; padding-bottom: 4px; }
.mp-heatmap-col { display: flex; flex-direction: column; gap: 2px; }
.mp-heatmap-cell {
  width: 11px; height: 11px; border-radius: 2px;
  background: rgba(255,255,255,0.04);
  flex-shrink: 0;
  transition: transform .12s, outline .12s;
}
.mp-heatmap-cell:hover { outline: 1px solid var(--gold); transform: scale(1.25); }
.mp-heatmap-pad { background: transparent; }
.mp-heatmap-l0 { background: rgba(255,255,255,0.04); }
.mp-heatmap-l1 { background: rgba(201,168,76,0.25); }
.mp-heatmap-l2 { background: rgba(201,168,76,0.5); }
.mp-heatmap-l3 { background: rgba(255,195,85,0.75); }
.mp-heatmap-l4 { background: #ffd978; box-shadow: 0 0 4px rgba(255,217,120,0.5); }
.mp-heatmap-legend {
  display: flex; align-items: center; gap: 4px;
  margin-top: 10px; font-size: .62rem; color: var(--text-dim);
  justify-content: flex-end;
}
.mp-heatmap-legend .mp-heatmap-cell { pointer-events: none; }

/* ═══════════════════════════════════════
   RECENT LOGIN RANKING (under Members)
═══════════════════════════════════════ */
.recent-login-wrap { margin: 28px auto 12px; max-width: 760px; padding: 0 16px; width: 100%; box-sizing: border-box; overflow: hidden; }
.recent-login-box {
  background: linear-gradient(135deg, rgba(30,10,60,0.38), rgba(10,5,25,0.4));
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: var(--radius-lg, 12px);
  padding: 16px 18px 14px;
  backdrop-filter: blur(6px);
  box-sizing: border-box;
  width: 100%;
  overflow: hidden;
}
.recent-login-title {
  font-family: var(--font-display);
  font-size: .8rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
  text-align: center;
}
.recent-login-count { color: var(--text-dim); font-size: .7rem; letter-spacing: .05em; }
.recent-login-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
  max-height: 480px;
  overflow-y: auto;
  /* Prevent scroll chaining to the page on mobile swipe */
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}
.recent-login-list::-webkit-scrollbar { width: 6px; }
.recent-login-list::-webkit-scrollbar-thumb { background: rgba(201,168,76,.25); border-radius: 3px; }
.recent-login-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(255,255,255,0.015);
  cursor: pointer;
  transition: background-color .15s, box-shadow .15s;
  font-family: var(--font-ui);
  box-sizing: border-box;
  width: 100%;
  min-width: 0; /* allow flex children to shrink */
}
.recent-login-item:hover { background: rgba(201,168,76,0.08); }
.rl-medal { font-size: 1rem; width: 28px; text-align: center; flex-shrink: 0; }
.rl-rank { color: var(--text-dim); font-size: .7rem; font-weight: 600; }
.rl-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--gold-dim);
  flex-shrink: 0;
}
.rl-avatar-ph {
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--night-lift), var(--blue-deep));
  font-family: var(--font-display);
  color: var(--gold-dim);
  font-size: .75rem;
  font-weight: 700;
}
.rl-name { flex: 1 1 auto; min-width: 0; color: var(--text); font-size: .82rem; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rl-time { color: var(--text-dim); font-size: .68rem; font-style: italic; white-space: nowrap; flex-shrink: 0; }
.rl-time-signup { color: rgba(160,140,90,.7); font-size: .62rem; }
.recent-login-item.rl-never { opacity: .55; }
.recent-login-item.rl-never .rl-name { font-weight: 400; }
.rl-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #4cd080;
  box-shadow: 0 0 8px rgba(76,208,128,.6);
  animation: rl-online-pulse 1.8s ease-in-out infinite;
  flex-shrink: 0;
}
.recent-login-item.rl-online .rl-name { color: #bff1d0; }
.recent-login-item.rl-online .rl-avatar { border-color: #4cd080; box-shadow: 0 0 10px rgba(76,208,128,.35); }
@keyframes rl-online-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: .4; }
}
@media (max-width: 640px) {
  .recent-login-title { font-size: .72rem; }
  .rl-avatar { width: 26px; height: 26px; }
  .rl-name { font-size: .76rem; }
  .rl-time { font-size: .62rem; }
}

/* Recent donors (< 30 days) — subtle pulse with golden glow */
.donate-latest-item.donate-recent {
  color: var(--gold);
  padding: 4px 10px;
  margin: 2px 0;
  border-radius: 6px;
  background: linear-gradient(90deg, rgba(201,168,76,0) 0%, rgba(201,168,76,0.12) 50%, rgba(201,168,76,0) 100%);
  animation: donate-recent-pulse 2.2s ease-in-out infinite;
  position: relative;
}
.donate-latest-item.donate-recent .donor-name {
  color: #ffd978;
  text-shadow: 0 0 8px rgba(255,217,120,0.55);
}
.donate-latest-item.donate-recent .donor-avatar {
  border-color: var(--gold);
  box-shadow: 0 0 10px rgba(255,217,120,0.45);
}
.donate-latest-item.donate-recent::before {
  content: '✦';
  color: #ffd978;
  font-size: 0.7rem;
  margin-right: 4px;
  animation: donate-recent-sparkle 1.6s ease-in-out infinite;
}
@keyframes donate-recent-pulse {
  0%, 100% { box-shadow: 0 0 0 rgba(255,217,120,0); opacity: 1; }
  50%      { box-shadow: 0 0 14px rgba(255,217,120,0.35); opacity: 0.85; }
}
@keyframes donate-recent-sparkle {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.25); }
}
@media (prefers-reduced-motion: reduce) {
  .donate-latest-item.donate-recent,
  .donate-latest-item.donate-recent::before { animation: none; }
}
.donor-avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  object-fit: cover;
  vertical-align: middle;
  margin-right: 4px;
  border: 1px solid var(--gold-dim);
}
.donor-avatar-ph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--night-lift), var(--blue-deep));
  font-family: var(--font-display);
  font-size: 0.55rem;
  color: var(--gold-dim);
}
.donate-pagination {
  display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 10px;
}
.donate-pagination button {
  background: rgba(201,168,76,.08); border: 1px solid rgba(201,168,76,.2); border-radius: 2px;
  color: var(--gold-dim); font-size: .65rem; padding: 3px 10px; cursor: pointer; font-family: var(--font-ui); transition: all .2s;
}
.donate-pagination button.active { background: var(--gold); color: var(--night); border-color: var(--gold); }
.donate-pagination button:disabled { opacity: .3; cursor: default; }
@media (max-width: 600px) {
  .donate-banner { padding: 24px 20px; margin-bottom: 48px; }
}

/* ═══════════════════════════════════════════
   FOOTER SIGNATURE
═══════════════════════════════════════════ */
/* ═══ Mobile bottom tab bar ═══ */
.mobile-tab-bar {
  display: none;
  position: fixed;
  bottom: 0 !important; left: 0; right: 0;
  z-index: 99990;
  background: rgb(4,6,15);
  border-top: 1px solid var(--border);
  padding: 6px 0 max(env(safe-area-inset-bottom, 0px), 6px);
  padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 6px);
  justify-content: space-around;
  align-items: center;
  -webkit-transform: translateZ(0); transform: translateZ(0);
}
@media (max-width: 768px) {
  .mobile-tab-bar { display: flex; }
  .site-footer { padding-bottom: 70px; }
  #msg-widget { bottom: 64px; }
  .nav-chat-desktop { display: none !important; }
}
.tab-bar-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  background: none;
  border: none;
  color: var(--text-dim);
  font-family: var(--font-ui);
  font-size: 0.55rem;
  letter-spacing: 0.06em;
  padding: 4px 12px;
  cursor: pointer;
  transition: color 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.tab-bar-btn .tab-icon { font-size: 1.2rem; line-height: 1; }
.tab-bar-btn.active,
.tab-bar-btn:hover { color: var(--gold); }
.tab-bar-btn .tab-badge {
  position: absolute;
  top: -2px; right: -6px;
  background: #ef4444;
  color: #fff;
  font-size: 0.55rem;
  font-weight: 700;
  min-width: 14px;
  height: 14px;
  line-height: 14px;
  border-radius: 7px;
  text-align: center;
  padding: 0 3px;
}

.site-footer {
  position: relative;
  z-index: 1;
  padding: 80px 40px 60px;
  text-align: center;
}
.site-testimonials {
  max-width: 600px;
  margin: 60px auto 50px;
  padding: 0 20px;
}
.testimonial-item {
  position: relative;
}
.testimonial-quote {
  font-family: var(--font-ui);
  font-size: .95rem;
  font-style: italic;
  line-height: 1.7;
  color: var(--text-muted);
  margin: 0;
  quotes: none;
}
.testimonial-author {
  display: block;
  margin-top: 14px;
  font-family: var(--font-ui);
  font-size: .8rem;
  font-style: normal;
  color: var(--gold-dim);
  letter-spacing: .08em;
}
.footer-rule {
  width: 300px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-dim), transparent);
  margin: 0 auto 60px;
}
.signature {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.signature-pre {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--text-dim);
}
.signature-name {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  background: linear-gradient(120deg, #a07830 0%, var(--gold) 25%, var(--gold-bright) 50%, var(--gold) 75%, #a07830 100%);
  background-size: 300% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 14s ease infinite;
  will-change: background-position;
  display: inline-block;
  transition: filter 0.4s ease;
  position: relative;
}
.signature-name::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 100%;
  height: 1px;
  background: linear-gradient(90deg, var(--gold-dim), var(--gold));
  transition: right 0.5s ease;
}
.signature-name:hover { filter: drop-shadow(0 0 24px rgba(201,168,76,0.5)); }
.signature-name:hover::after { right: 0; }

@keyframes shimmer {
  0%   { background-position: 200% center; }
  50%  { background-position: -100% center; }
  100% { background-position: 200% center; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-radial, .hero-knight-wrap::before, .hero-knight, .signature-name,
  .scroll-cue, .orbit { animation: none !important; display: none; }
}

/* ═══════════════════════════════════════════
   LOCKED SECTION OVERLAY
═══════════════════════════════════════════ */
.section-locked {
  position: relative;
  pointer-events: none;
}
.section-locked::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(4,6,15,0.6);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  border-radius: var(--radius-lg);
  z-index: 5;
}
.section-lock-overlay {
  position: absolute;
  inset: 0;
  z-index: 6;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  pointer-events: all;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.lock-icon {
  font-size: 2.5rem;
  color: var(--gold-dim);
}
.lock-text {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  text-align: center;
}

/* ═══════════════════════════════════════════
   NEWS MODAL
═══════════════════════════════════════════ */
.modal {
  position: fixed;
  inset: 0;
  z-index: 99993;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  overscroll-behavior: contain;
}
.modal.open {
  opacity: 1;
  pointer-events: all;
}
.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4,6,15,0.85);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  cursor: pointer;
}
.modal-panel {
  position: relative;
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  max-width: 760px;
  width: 100%;
  max-height: 88vh;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  transform: scale(0.92) translateY(20px);
  transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
.modal.open .modal-panel {
  transform: scale(1) translateY(0);
}
.modal-close {
  position: absolute;
  top: 16px; right: 20px;
  font-size: 1.1rem;
  color: var(--text-muted);
  padding: 8px;
  border-radius: var(--radius);
  transition: color var(--transition);
  z-index: 10;
}
.modal-close:hover { color: var(--gold); }
.modal-content { padding: 40px; }
.modal-content .news-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: var(--radius);
  margin-bottom: 32px;
  filter: brightness(0.8);
  cursor: zoom-in;
  transition: filter 0.3s;
}
.modal-content .news-img:hover {
  filter: brightness(1);
}
.modal-content h2 {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 12px;
}
.modal-content .news-body {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--text-muted);
  line-height: 1.8;
  white-space: pre-line;
  overflow-wrap: break-word;
  word-break: break-word;
}

/* ─── Reader Mode (Literary) — page blanche ─── */
.reader-mode-btn, .tts-btn {
  cursor: pointer; background: none; border: 1px solid var(--border);
  border-radius: 4px; padding: 3px 8px; font-size: .75rem;
  color: var(--text-dim); transition: all .3s; vertical-align: middle; margin-left: 10px;
}
.reader-mode-btn:hover, .tts-btn:hover { color: var(--gold); border-color: var(--gold-dim); }
.tts-btn.tts-playing { color: var(--gold); border-color: var(--gold); background: var(--gold-subtle); }
.tts-btn:disabled { opacity: 0.5; cursor: wait; }
.tts-controls { display: inline-flex; gap: 4px; align-items: center; }
.tts-ctrl-btn { padding: 4px 8px !important; font-size: 0.9rem !important; min-width: 32px; }
.tts-timer {
  display: none; margin-top: 14px; margin-bottom: 10px;
  align-items: center; gap: 14px; justify-content: center;
}
.tts-timer.visible { display: flex; }
.tts-timer-ring {
  position: relative; width: 44px; height: 44px;
}
.tts-timer-ring svg { transform: rotate(-90deg); }
.tts-timer-ring circle {
  fill: none; stroke-width: 3;
}
.tts-timer-ring .tts-ring-bg { stroke: var(--border); }
.tts-timer-ring .tts-ring-fg {
  stroke: var(--gold); stroke-linecap: round;
  transition: stroke-dashoffset 0.3s ease;
}
.tts-timer-count {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-ui); font-size: 0.8rem; font-weight: 600; color: var(--gold);
}
.tts-timer-label {
  font-family: var(--font-ui); font-size: 0.75rem; color: var(--text-dim);
}
.tts-timer-label .tts-status { display: block; margin-top: 2px; font-size: 0.68rem; color: var(--text-muted); }
.reader-mode .tts-ring-bg { stroke: #e0ddd6; }
.reader-mode .tts-ring-fg { stroke: #b8942a; }
.reader-mode .tts-timer-count { color: #b8942a; }
.reader-mode .tts-timer-label { color: #888; }
.reader-mode .tts-timer-label .tts-status { color: #aaa; }
.reader-mode .modal-panel {
  max-width: 100%; width: 100%; max-height: 100dvh; height: 100dvh;
  border-radius: 0; border: none;
  background: #faf9f6;
}
.reader-mode .modal-content {
  padding: 60px 40px 80px; max-width: 640px; margin: 0 auto;
}
.reader-mode .modal-content h2 {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  line-height: 1.35; margin-bottom: 16px;
  color: #1a1a1a;
}
.reader-mode .modal-content .news-meta,
.reader-mode .modal-content .reader-meta-row {
  color: #888; border-bottom: 1px solid #e0ddd6; padding-bottom: 16px; margin-bottom: 28px;
}
.reader-mode .modal-content .news-body {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 1.1rem; line-height: 2; color: #2a2a2a; letter-spacing: 0.01em;
  overflow-wrap: break-word;
  word-break: break-word;
}
.reader-mode .modal-content .news-body a { color: #6a5a3a; }
.reader-mode .modal-content .news-img {
  border-radius: 4px; filter: none;
}
.reader-mode .modal-close {
  position: fixed; top: 20px; right: 24px; z-index: 210;
  color: #888; background: rgba(0,0,0,.05); border-radius: 50%;
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
}
.reader-mode .modal-close:hover { color: #333; background: rgba(0,0,0,.1); }
.reader-mode .modal-backdrop { background: rgba(250,249,246,.95); -webkit-backdrop-filter: none; backdrop-filter: none; }
@media (max-width: 600px) {
  .reader-mode .modal-content { padding: 40px 20px 60px; }
}

/* ═══════════════════════════════════════════
   LIGHTBOX
═══════════════════════════════════════════ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 100010; /* above .modal (99993) so images opened from within a modal are on top */
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.lightbox.open {
  opacity: 1;
  pointer-events: all;
}
.lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4,6,15,0.95);
  cursor: pointer;
}
.lightbox-panel {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 0 60px;
  max-width: 100vw;
}
.lightbox-img {
  max-width: 80vw;
  max-height: 85vh;
  object-fit: contain;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: opacity 0.3s ease;
}
.lightbox-close {
  position: fixed;
  top: 24px; right: 32px;
  font-size: 1.3rem;
  color: var(--text-muted);
  padding: 10px;
  transition: color var(--transition);
}
.lightbox-close:hover { color: var(--gold); }
.lightbox-prev, .lightbox-next {
  font-size: 2.5rem;
  color: var(--text-muted);
  padding: 16px;
  transition: all var(--transition);
  border: 1px solid transparent;
  border-radius: var(--radius);
  flex-shrink: 0;
  line-height: 1;
}
.lightbox-prev:hover, .lightbox-next:hover {
  color: var(--gold);
  border-color: var(--border);
}
.lightbox-caption {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  color: var(--text-muted);
}
@media (max-width: 768px) {
  .lightbox-panel {
    padding: 0;
    width: 100vw;
    justify-content: center;
  }
  .lightbox-img {
    max-width: 100vw;
    max-height: 82vh;
  }
  .lightbox-close {
    top: 16px;
    left: 16px;
    right: auto;
    background: rgba(4,6,15,0.65);
    border-radius: 50%;
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    padding: 0;
  }
  .lightbox-prev,
  .lightbox-next {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    font-size: 2rem;
    padding: 10px 14px;
    background: rgba(4,6,15,0.55);
    border-radius: 50%;
    border: 1px solid var(--border);
  }
  .lightbox-prev { left: 8px; }
  .lightbox-next { right: 8px; }
}

/* ═══════════════════════════════════════════
   ADMIN DASHBOARD
═══════════════════════════════════════════ */
.admin-panel {
  position: fixed;
  inset: 0;
  z-index: 400;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.admin-panel.open {
  pointer-events: all;
  opacity: 1;
}
.admin-overlay {
  position: absolute;
  inset: 0;
  background: rgba(4,6,15,0.6);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  cursor: pointer;
}
.admin-sidebar {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: min(420px, 100vw);
  background: var(--night-alt);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.5s cubic-bezier(0.77,0,0.175,1);
}
.admin-panel.open .admin-sidebar {
  transform: translateX(0);
}
.admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 28px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.admin-title {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.2em;
  color: var(--gold);
}
.admin-close-btn {
  color: var(--text-muted);
  font-size: 1rem;
  padding: 6px;
  transition: color var(--transition);
}
.admin-close-btn:hover { color: var(--gold); }
.admin-nav {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  border-bottom: 1px solid var(--border);
  padding: 8px 0;
}
.admin-nav-item {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 12px 28px;
  text-align: left;
  transition: all var(--transition);
  border-left: 2px solid transparent;
}
.admin-nav-item:hover { color: var(--text); background: var(--night-card); }
.admin-nav-item.active { color: var(--gold); border-left-color: var(--gold); }

.admin-content {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 24px;
  min-height: 0; /* crucial : permet à flex: 1 de limiter la hauteur au lieu de l'étendre */
}
.admin-section { display: none; }
.admin-section.active { display: block; }

/* ── Admin panel mobile ── */
@media (max-width: 768px) {
  .admin-sidebar {
    width: 100vw;
    /* Le sidebar occupe tout l'écran en portrait */
  }
  .admin-header {
    padding: 16px 20px;
  }
  .admin-nav {
    flex-direction: row;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    border-bottom: 1px solid var(--border);
    padding: 0;
    flex-shrink: 0;
  }
  .admin-nav::-webkit-scrollbar { display: none; }
  .admin-nav-item {
    flex-shrink: 0;
    padding: 11px 16px;
    border-left: none;
    border-bottom: 2px solid transparent;
    font-size: 0.68rem;
  }
  .admin-nav-item.active {
    border-left-color: transparent;
    border-bottom-color: var(--gold);
  }
  .admin-content {
    padding: 16px;
  }
}

.btn-gold {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--night);
  background: var(--gold);
  border: none;
  padding: 10px 24px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition);
  font-weight: 600;
  margin-bottom: 20px;
}
.btn-gold:hover { background: var(--gold-bright); box-shadow: 0 4px 20px rgba(201,168,76,0.3); }

.btn-outline {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-muted);
  border: 1px solid var(--border);
  padding: 7px 16px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition);
  background: transparent;
}
.btn-outline:hover { color: var(--gold); border-color: var(--gold-dim); }

.btn-danger {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--danger);
  border: 1px solid rgba(220,53,69,.25); border: 1px solid color-mix(in srgb, var(--danger) 25%, transparent);
  padding: 7px 16px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition);
  background: transparent;
}
.btn-danger:hover { background: rgba(220,53,69,.1); background: color-mix(in srgb, var(--danger) 10%, transparent); border-color: var(--danger); }

/* Admin list items */
.admin-list-item {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  margin-bottom: 12px;
  transition: border-color var(--transition);
}
.admin-list-item:hover { border-color: var(--gold-dim); }
.admin-list-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.admin-list-item-title {
  font-family: var(--font-display);
  font-size: 0.9rem;
  color: var(--text);
  letter-spacing: 0.06em;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-right: 8px;
}
.admin-list-item-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.admin-list-item-meta {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  text-transform: uppercase;
  display: flex;
  gap: 12px;
}
.status-badge {
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 2px;
}
.status-published { background: rgba(40,167,69,.15); background: color-mix(in srgb, var(--success) 15%, transparent); color: var(--success); }
.status-draft     { background: rgba(100,100,140,0.2); color: #8888aa; }
.status-pinned    { background: rgba(201,168,76,0.2); color: var(--gold); }

/* Admin forms */
.admin-form {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-bottom: 20px;
}
.form-group {
  margin-bottom: 16px;
}
.form-label {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.form-input, .form-textarea, .form-select {
  width: 100%;
  background: var(--night-alt);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1rem;
  transition: border-color var(--transition);
  outline: none;
  appearance: none;
}
.form-input:focus, .form-textarea:focus { border-color: var(--gold-dim); }
select.form-input, select.form-select {
  appearance: auto; -webkit-appearance: menulist;
  cursor: pointer; padding-right: 30px;
}
.form-textarea { min-height: 120px; resize: vertical; }
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
}

/* ─── Access Admin — Group Cards ─── */
.access-groups { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; }
.access-group {
  border: 2px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.access-group--admin { border-color: rgba(201,168,76,.35); }
.access-group--modo  { border-color: rgba(100,180,255,.3); }
.access-group--membre { border-color: rgba(150,150,150,.25); }
.access-group-header {
  padding: 14px 18px;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-ui); font-size: .78rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
}
.access-group--admin .access-group-header { background: rgba(201,168,76,.08); color: var(--gold); }
.access-group--modo  .access-group-header { background: rgba(100,180,255,.06); color: #78b8ff; }
.access-group--membre .access-group-header { background: rgba(150,150,150,.06); color: #aaa; }
.access-group-body { padding: 12px 18px; background: var(--night-lift); }
.access-member-chips { display: flex; flex-wrap: wrap; gap: 8px; min-height: 32px; }
.access-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-ui); font-size: .72rem;
  padding: 5px 12px; border-radius: 20px;
  background: var(--night-card); border: 1px solid var(--border);
  color: var(--text); transition: border-color .2s;
}
.access-chip:hover { border-color: var(--gold-dim); }
.access-chip .chip-remove {
  font-size: .6rem; color: var(--text-muted); cursor: pointer;
  opacity: .5; transition: all .2s;
}
.access-chip .chip-remove:hover { opacity: 1; color: var(--danger); }
.access-group-footer {
  padding: 10px 18px; border-top: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px;
  background: var(--night-lift);
}
.access-add-select {
  flex: 1; font-family: var(--font-ui); font-size: .7rem;
  padding: 6px 10px; background: var(--night-card); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius);
  cursor: pointer;
}
.access-add-select:focus { border-color: var(--gold-dim); outline: none; }
.access-unassigned-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; border-bottom: 1px solid var(--border);
}
.access-unassigned-row:last-child { border-bottom: none; }
.access-unassigned-name {
  font-family: var(--font-ui); font-size: .75rem; color: var(--text);
}

/* ═══════════════════════════════════════════
   AUTH OVERLAY
═══════════════════════════════════════════ */
.auth-overlay {
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(4,6,15,0.98);
  -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.auth-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.auth-panel {
  position: relative;
  background: linear-gradient(180deg, var(--night-card) 0%, var(--night) 100%);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px 36px;
  max-width: 440px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  overscroll-behavior: contain;
  transform: translateY(20px);
  transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 32px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(201,168,76,0.08);
}
.auth-overlay.open .auth-panel {
  transform: translateY(0);
}
.auth-close {
  position: sticky;
  top: 0; float: right;
  font-size: 1rem;
  color: var(--text-muted);
  padding: 0;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 50%;
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 2;
  transition: all 0.25s;
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
}
.auth-close:hover { color: var(--gold); border-color: var(--gold-dim); background: var(--gold-subtle); transform: rotate(90deg); }
.auth-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  letter-spacing: 0.15em;
  color: var(--gold);
  text-align: center;
  margin-bottom: 8px;
}
.auth-sub {
  font-family: var(--font-body);
  font-style: italic;
  color: var(--text-muted);
  font-size: 0.95rem;
  text-align: center;
  margin-bottom: 32px;
}
.auth-form { display: flex; flex-direction: column; gap: 16px; }
.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 8px 0;
}
.auth-divider-line { flex: 1; height: 1px; background: var(--border); }
.auth-divider-text {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  color: var(--text-dim);
  text-transform: uppercase;
}
.auth-switch {
  text-align: center;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  color: var(--text-muted);
}
.auth-switch button {
  color: var(--gold);
  text-decoration: underline;
  font-size: inherit;
  cursor: pointer;
}

/* ── Member space panel (logged-in) ── */
.auth-member-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
  padding: 20px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(201,168,76,0.06) 0%, rgba(201,168,76,0.02) 100%);
  border: 1px solid rgba(201,168,76,0.1);
}
.auth-member-avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 2px solid var(--gold);
  object-fit: cover;
  flex-shrink: 0;
  box-shadow: 0 0 16px rgba(201,168,76,0.2);
}
.auth-member-avatar-ph {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 2px solid var(--gold);
  background: linear-gradient(135deg, rgba(201,168,76,0.22), rgba(201,168,76,0.08));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--gold);
  flex-shrink: 0;
  box-shadow: 0 0 16px rgba(201,168,76,0.2);
}
.auth-member-info { flex: 1; min-width: 0; }
.auth-member-name {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.auth-member-email {
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--text-dim);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.auth-member-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 20px;
  margin-top: 6px;
}
.auth-member-badge.badge-admin {
  background: linear-gradient(135deg, rgba(201,168,76,0.25), rgba(201,168,76,0.1));
  color: var(--gold);
  border: 1px solid var(--gold-dim);
}
.auth-member-badge.badge-modo {
  background: rgba(100,180,255,0.12);
  color: #7cb8f0;
  border: 1px solid rgba(100,180,255,0.25);
}
.auth-member-badge.badge-membre {
  background: rgba(180,180,180,0.08);
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.auth-section-label {
  font-family: var(--font-ui);
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin: 20px 0 10px;
}
.auth-action-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 16px;
  background: none;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all 0.25s;
  text-decoration: none;
}
.auth-action-btn:hover {
  background: rgba(201,168,76,0.08);
  border-color: var(--gold-dim);
  transform: translateX(4px);
}
.auth-action-btn .aa-icon {
  font-size: 1.1rem;
  width: 24px;
  text-align: center;
  flex-shrink: 0;
}
.auth-action-btn.aa-gold { color: var(--gold); }
.auth-action-btn.aa-danger {
  color: var(--text-muted);
  background: rgba(255,80,80,0.04);
  border-color: rgba(255,80,80,0.12);
}
.auth-action-btn.aa-danger:hover {
  background: rgba(255,80,80,0.1);
  border-color: rgba(255,80,80,0.3);
  color: #ff6b6b;
}
.auth-section-label {
  font-family: var(--font-ui); font-size: .68rem; letter-spacing: .15em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 12px;
  display: flex; align-items: center; gap: 10px;
}
.auth-section-label::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, var(--gold-dim), transparent);
}
.auth-nav-group { margin-bottom: 14px; }
.auth-nav-group-title {
  font-family: var(--font-ui); font-size: .62rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-dim); margin-bottom: 8px; padding-left: 2px;
}
.auth-nav-group-links { display: flex; flex-wrap: wrap; gap: 6px; }
.auth-nav-link {
  display: inline-block; padding: 6px 13px;
  border-radius: 8px; border: 1px solid rgba(255,255,255,0.06);
  font-family: var(--font-ui); font-size: .72rem; font-weight: 500;
  color: var(--text-muted); letter-spacing: .03em;
  transition: all .2s; text-decoration: none;
  background: rgba(255,255,255,0.02);
}
.auth-nav-link:hover {
  color: var(--gold); border-color: var(--gold-dim);
  background: rgba(201,168,76,0.08); transform: translateY(-1px);
}
@media (max-width: 480px) {
  .auth-panel { padding: 24px 18px; margin: 8px; border-radius: 16px; }
  .auth-member-header { gap: 12px; padding: 16px; }
  .auth-member-avatar, .auth-member-avatar-ph { width: 50px; height: 50px; font-size: 1.1rem; }
  .auth-member-name { font-size: 0.95rem; }
  .auth-member-email { font-size: 0.72rem; }
  .auth-action-btn { padding: 11px 14px; font-size: 0.76rem; gap: 10px; }
  .auth-action-btn .aa-icon { font-size: 1rem; width: 20px; }
  .auth-section-label { font-size: 0.6rem; margin: 16px 0 8px; }
}

/* ═══════════════════════════════════════════
   TOASTS
═══════════════════════════════════════════ */
.toast-container {
  position: fixed;
  bottom: 32px; right: 32px;
  z-index: 600;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}
.toast {
  font-family: var(--font-ui);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 20px;
  color: var(--text);
  max-width: 320px;
  animation: toastIn 0.4s ease forwards;
  pointer-events: all;
}
.toast.success { border-left: 3px solid var(--success); }
.toast.error   { border-left: 3px solid var(--danger); }
.toast.info    { border-left: 3px solid var(--gold); }
.toast.out     { animation: toastOut 0.4s ease forwards; }
@keyframes toastIn {
  from { opacity: 0; transform: translateX(40px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastOut {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(40px); }
}

/* ═══════════════════════════════════════════
   LOADING
═══════════════════════════════════════════ */
.news-loading {
  display: flex;
  justify-content: center;
  padding: 80px;
}
.loading-orb {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--gold);
  border-right-color: var(--gold-dim);
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Reveal animations */
.reveal-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.reveal-up.revealed {
  opacity: 1;
  transform: translateY(0);
}
.section {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.9s ease, transform 0.9s ease;
}
.section.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ═══════════════════════════════════════════
   PERMISSIONS FORM
═══════════════════════════════════════════ */
.perm-groups { display: flex; flex-direction: column; gap: 14px; margin: 14px 0; }
.perm-group-title {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.perm-group-items { display: flex; flex-wrap: wrap; gap: 5px; }
.perm-pill {
  font-family: var(--font-ui);
  font-size: 0.64rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 4px 12px;
  border: 1px solid var(--border);
  border-radius: 20px;
  cursor: pointer;
  transition: border-color 0.18s, color 0.18s, background 0.18s;
  user-select: none;
}
.perm-pill:hover { border-color: var(--gold-dim); color: var(--text); }
.perm-pill.checked { border-color: var(--gold); color: var(--gold); background: rgba(201,168,76,0.1); }


/* ═══════════════════════════════════════════
   HARMONIA — Radio Cosmo
═══════════════════════════════════════════ */
.harmonia-player {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 900px;
  margin: 0 auto;
}
@media (max-width: 700px) {
  .harmonia-player { grid-template-columns: 1fr; }
}
.harmonia-now {
  background: linear-gradient(135deg, rgba(201,168,76,0.08), rgba(201,168,76,0.02));
  border: 1px solid rgba(201,168,76,0.15);
  border-radius: var(--radius);
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.harmonia-vinyl {
  width: 160px; height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, var(--night-card) 30%, rgba(201,168,76,0.15) 60%, var(--night-card) 100%);
  border: 3px solid rgba(201,168,76,0.3);
  display: flex; align-items: center; justify-content: center;
  animation: harmoniaSpinPaused 0s linear infinite;
  position: relative;
}
.harmonia-vinyl.spinning { animation: harmoniaSpin 4s linear infinite; }
.harmonia-vinyl::after {
  content: '🎵'; font-size: 2.5rem;
}
@keyframes harmoniaSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.harmonia-track-name {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--gold);
  text-align: center;
  letter-spacing: 0.05em;
  min-height: 1.4em;
}
.harmonia-track-cat {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  color: var(--text-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.harmonia-controls {
  display: flex; align-items: center; gap: 12px;
}
.harmonia-controls button {
  background: none; border: 1px solid rgba(201,168,76,0.2);
  border-radius: 50%; width: 42px; height: 42px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text); font-size: 1.1rem; cursor: pointer;
  transition: all 0.2s;
}
.harmonia-controls button:hover { border-color: var(--gold); color: var(--gold); }
.harmonia-controls button.hm-play {
  width: 52px; height: 52px; font-size: 1.3rem;
  border-color: var(--gold); color: var(--gold);
}
.harmonia-controls button.hm-play:hover { background: rgba(201,168,76,0.1); }
.harmonia-vol {
  display: flex; align-items: center; gap: 8px; margin-top: 4px;
}
.harmonia-vol span { font-size: 0.85rem; color: var(--text-muted); }
.harmonia-vol input[type="range"] {
  width: 100px; accent-color: var(--gold);
}
.harmonia-list {
  max-height: 480px;
  overflow-y: auto;
  border: 1px solid rgba(201,168,76,0.1);
  border-radius: var(--radius);
  scrollbar-width: thin;
  scrollbar-color: var(--gold-dim) transparent;
}
.harmonia-list-header {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-dim);
  padding: 12px 16px 8px;
  position: sticky; top: 0;
  background: var(--night);
  z-index: 1;
}
.harmonia-cat-label {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 10px 16px 4px;
  background: rgba(201,168,76,0.04);
}
.harmonia-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 16px; cursor: pointer;
  border-bottom: 1px solid rgba(201,168,76,0.06);
  transition: background 0.15s;
}
.harmonia-item:hover { background: rgba(201,168,76,0.06); }
.harmonia-item.active { background: rgba(201,168,76,0.1); }
.harmonia-item.active .harmonia-item-title { color: var(--gold); }
.harmonia-item-num {
  font-family: var(--font-ui);
  font-size: 0.7rem; color: var(--text-muted);
  min-width: 22px; text-align: right;
}
.harmonia-item-title {
  font-family: var(--font-ui);
  font-size: 0.85rem; color: var(--text);
  flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.harmonia-item-dur {
  font-family: var(--font-ui);
  font-size: 0.7rem; color: var(--text-muted);
}
.harmonia-eq {
  display: flex; align-items: flex-end; gap: 2px; height: 14px;
}
.harmonia-eq span {
  width: 3px; background: var(--gold); border-radius: 1px;
  animation: harmoniaEq 0.8s ease-in-out infinite alternate;
}
.harmonia-eq span:nth-child(1) { height: 6px; animation-delay: 0s; }
.harmonia-eq span:nth-child(2) { height: 10px; animation-delay: 0.2s; }
.harmonia-eq span:nth-child(3) { height: 4px; animation-delay: 0.4s; }
.harmonia-eq span:nth-child(4) { height: 8px; animation-delay: 0.1s; }
@keyframes harmoniaEq {
  0% { height: 3px; }
  100% { height: 14px; }
}

/* ═══════════════════════════════════════════
   SPEED TEST
═══════════════════════════════════════════ */
.st-wrapper { max-width: 900px; margin: 0 auto; }

/* ── Gauge / Running state ── */
.st-gauge-area {
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  padding: 30px 0;
}
.st-gauge-display {
  position: relative; display: flex; flex-direction: column; align-items: center;
}
.st-gauge-number {
  font-family: 'JetBrains Mono', 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
  font-size: 5rem; color: var(--gold-bright);
  line-height: 1; text-shadow: 0 0 30px rgba(200,168,78,0.3);
  transition: color 0.15s;
  font-variant-numeric: tabular-nums;
  min-width: 320px; text-align: center;
  letter-spacing: -0.02em;
}
.st-gauge-unit {
  font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted);
  letter-spacing: .15em; text-transform: uppercase; margin-top: 4px;
}
.st-gauge-bar {
  width: 280px; height: 6px; background: rgba(255,255,255,0.08);
  border-radius: 3px; margin-top: 12px; overflow: hidden;
}
.st-gauge-bar-fill {
  height: 100%; width: 0%; border-radius: 3px;
  background: linear-gradient(90deg, #22c55e, #c8a84e, #ef4444);
  transition: width 0.15s linear;
}
.st-gauge-phase {
  font-family: var(--font-ui); font-size: .85rem; color: var(--text-muted);
  letter-spacing: .08em; margin-top: 8px;
}
.st-ping-display {
  font-family: 'JetBrains Mono', 'SF Mono', monospace; font-size: .85rem;
  color: var(--gold); margin-top: 6px; min-height: 1.2em;
  font-variant-numeric: tabular-nums;
}
.st-gauge-label {
  font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted);
  letter-spacing: .1em; text-transform: uppercase;
}
.st-start-btn {
  background: transparent; border: 2px solid var(--gold); color: var(--gold);
  font-family: var(--font-display); font-size: 1.1rem; padding: 14px 48px;
  border-radius: var(--radius); cursor: pointer; letter-spacing: .1em;
  transition: all var(--transition); text-transform: uppercase;
}
.st-start-btn:hover { background: var(--gold-glow); box-shadow: 0 0 20px var(--gold-glow); }
.st-start-btn:disabled { opacity: .4; cursor: default; }

/* ── Results cards ── */
.st-results {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin: 20px 0;
}
.st-result-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px; text-align: center;
}
.st-result-card .st-r-label {
  font-family: var(--font-ui); font-size: .65rem; color: var(--text-muted);
  letter-spacing: .12em; text-transform: uppercase; margin-bottom: 6px;
}
.st-result-card .st-r-value {
  font-family: var(--font-display); font-size: 1.5rem; color: var(--gold-bright);
}
.st-r-peak { font-size: .65rem; color: var(--gold-dim); margin-top: 4px; }
.st-r-peak.st-r-new { color: #ffd700; font-weight: 700; animation: st-pulse .6s ease; }
@keyframes st-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
.st-result-card .st-r-unit {
  font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted);
  letter-spacing: .08em;
}

/* ── Device info ── */
.st-device-info {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px; margin: 16px 0; padding: 16px;
  background: var(--night-card); border: 1px solid var(--border); border-radius: var(--radius);
}
.st-device-row {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-ui); font-size: .78rem;
}
.st-device-row .st-d-icon { color: var(--gold-dim); width: 16px; text-align: center; }
.st-device-row .st-d-label { color: var(--text-muted); }
.st-device-row .st-d-val { color: var(--text); margin-left: auto; font-weight: 500; }

/* ── Connection type picker (after test) ── */
.st-conn-picker { display: flex; gap: 4px; flex-wrap: wrap; }
.st-conn-opt {
  font-size: .65rem; padding: 3px 8px; border-radius: 10px; cursor: pointer;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  color: var(--text-muted); transition: all .2s; white-space: nowrap;
}
.st-conn-opt:hover { border-color: var(--gold-dim); color: var(--text); }
.st-conn-opt.active { background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold-bright); font-weight: 600; }

/* ── Connection type toggle ── */
.st-conn-tabs {
  display: flex; gap: 4px; justify-content: center; margin: 20px 0 10px;
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 4px; width: fit-content; margin-left: auto; margin-right: auto;
}
.st-conn-tab {
  font-family: var(--font-ui); font-size: .7rem; letter-spacing: .08em;
  text-transform: uppercase; padding: 8px 16px; border: none; background: none;
  color: var(--text-muted); cursor: pointer; border-radius: calc(var(--radius) - 2px);
  transition: all var(--transition);
}
.st-conn-tab.active { background: var(--gold-glow); color: var(--gold); }
.st-conn-tab:hover:not(.active) { color: var(--text); }

/* ── Leaderboard ── */
.st-leaderboards {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin: 20px 0;
}
.st-lb-panel {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
}
.st-lb-header {
  padding: 12px 16px; border-bottom: 1px solid var(--border);
  font-family: var(--font-ui); font-size: .7rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--gold-dim); text-align: center;
}
.st-lb-list { padding: 8px; max-height: 340px; overflow-y: auto; }
.st-lb-row {
  display: grid; grid-template-columns: 28px 1fr auto auto;
  align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: calc(var(--radius) - 2px);
  transition: background var(--transition);
  border-bottom: 1px solid rgba(255,255,255,.03);
}
.st-lb-row:last-child { border-bottom: none; }
.st-lb-row:hover { background: rgba(201,168,76,0.07); }
.st-lb-row:nth-child(1) { background: rgba(255,215,0,.04); }
.st-lb-rank {
  font-family: var(--font-display); font-size: .9rem; color: var(--gold-dim);
  min-width: 24px; text-align: center;
}
.st-lb-row:nth-child(1) .st-lb-rank { color: #ffd700; filter: drop-shadow(0 0 4px rgba(255,215,0,.4)); }
.st-lb-row:nth-child(2) .st-lb-rank { color: #c0c0c0; }
.st-lb-row:nth-child(3) .st-lb-rank { color: #cd7f32; }
.st-lb-name {
  font-family: var(--font-ui); font-size: .85rem; color: var(--text);
  font-weight: 600; letter-spacing: .02em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.st-lb-row:nth-child(1) .st-lb-name { color: var(--gold-bright); }
.st-lb-speed {
  font-family: var(--font-display); font-size: .9rem; color: var(--gold-bright);
  white-space: nowrap; text-align: right; min-width: 90px;
}
.st-lb-conn { font-size: .7rem; color: var(--text-dim); white-space: nowrap; background: rgba(255,255,255,.05); padding: 2px 8px; border-radius: 10px; }
.st-lb-speed small {
  font-family: var(--font-ui); font-size: .55rem; color: var(--text-muted);
  letter-spacing: .06em;
}
.st-lb-empty {
  padding: 24px; text-align: center;
  font-family: var(--font-ui); font-size: .78rem; color: var(--text-muted);
}

/* ── History table ── */
.st-history { margin-top: 20px; }
.st-history-title {
  font-family: var(--font-ui); font-size: .7rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--gold-dim); margin-bottom: 10px;
}
.st-history-table {
  width: 100%; border-collapse: collapse;
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
}
.st-history-table th, .st-history-table td {
  font-family: var(--font-ui); font-size: .72rem; padding: 8px 12px;
  text-align: center; border-bottom: 1px solid var(--border);
}
.st-history-table th {
  color: var(--text-muted); letter-spacing: .08em; text-transform: uppercase;
  font-weight: 500; font-size: .6rem;
}
.st-history-table td { color: var(--text); }
.st-history-table .st-h-speed { color: var(--gold-bright); font-weight: 600; }
.st-history-table th[onclick]:hover { color: var(--gold); cursor: pointer; }

/* ── Responsive ── */
@media (max-width: 800px) {
  .st-results { grid-template-columns: repeat(2, 1fr); }
  .st-leaderboards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px) {
  .st-results { grid-template-columns: 1fr 1fr; gap: 8px; }
  .st-leaderboards { grid-template-columns: 1fr; }
  .st-gauge-number { font-size: 3.5rem; min-width: 240px; }
  .st-gauge-bar { width: 220px; }
  .st-history-table { font-size: .65rem; }
}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media (max-width: 1100px) {
  .news-grid    { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1180px) {
  .news-featured { grid-template-columns: 1fr; }
  .news-featured-img-placeholder { min-height: 220px; }
  .war-grid { columns: 2; }
}
@media (max-width: 600px) {
  .nav { padding: 0 10px; background: rgba(4,6,15,0.92); -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px); }
  .nav-inner { gap: 6px; height: 56px; }
  .nav-actions { gap: 4px; }
  .nav-logo-text { font-size: 1rem; }
  .nav-logo-badge { display: none; }
  .lang-opt { font-size: 0.6rem; padding: 2px 4px; }
  .hamburger { padding: 6px; }
  .hamburger span { width: 20px; }
  .section { padding: 60px 20px; }
  .news-grid { grid-template-columns: 1fr; }
  .war-grid  { columns: 1; }
  .auth-panel { padding: 32px 24px; }
  .hero-content {
    padding-top: 80px;
    padding-bottom: 16px;
  }
  .hero-knight-wrap {
    width: 86vw;
    max-width: 400px;
    margin-bottom: 2px;
  }
  .hero-divider { margin: 10px auto 12px; }
  .hero-tagline { margin-bottom: 28px; }
  .stats-inner { flex-wrap: wrap; gap: 20px 0; }
  .stat-item   { min-width: 90px; padding: 0; flex: 0 0 33.33%; }
  .stat-sep    { display: none; }
  .stat-number { font-size: 1.8rem; }
}

/* ═══════════════════════════════════════════
   DISCORD VOICE BAR
═══════════════════════════════════════════ */
.discord-voice-bar {
  padding: 14px 24px;
  background: linear-gradient(135deg, rgba(88,101,242,.06) 0%, transparent 60%, rgba(88,101,242,.03) 100%);
  border-bottom: 1px solid rgba(88,101,242,.15);
  text-align: center;
  animation: dvFadeIn .5s ease;
}
@keyframes dvFadeIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
.dv-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap;
}
.dv-brand {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--font-ui); font-size: .65rem; letter-spacing: .15em;
  text-transform: uppercase; color: #7289da; font-weight: 600;
}
.dv-brand svg { width: 16px; height: 12px; fill: #7289da; }
.dv-channel {
  display: flex; align-items: center; gap: 8px;
  background: rgba(88,101,242,.06); border: 1px solid rgba(88,101,242,.12);
  border-radius: 20px; padding: 5px 14px 5px 10px;
}
.dv-channel-icon { color: #43b581; font-size: .85rem; }
.dv-channel-name {
  font-family: var(--font-ui); font-size: .7rem; font-weight: 600;
  color: rgba(88,101,242,.8); letter-spacing: .04em;
}
.dv-members { display: flex; align-items: center; gap: 6px; margin-left: 2px; }
.dv-member {
  display: flex; align-items: center; gap: 4px;
  font-family: var(--font-ui); font-size: .72rem; color: var(--text); font-weight: 500;
}
.dv-avatar {
  width: 20px; height: 20px; border-radius: 50%;
  border: 1.5px solid rgba(88,101,242,.3); object-fit: cover;
}
.dv-no-avatar {
  width: 20px; height: 20px; border-radius: 50%;
  background: rgba(88,101,242,.15); display: flex; align-items: center; justify-content: center;
  font-size: .5rem; color: #7289da; font-weight: 700;
}
@media(max-width:600px) {
  .dv-inner { flex-direction: column; gap: 10px; }
  .dv-channel { flex-wrap: wrap; justify-content: center; }
}

/* ═══════════════════════════════════════════
   STATS STRIP
═══════════════════════════════════════════ */
.stats-strip {
  position: relative;
  margin-top: 40px;
  padding: 36px 24px 32px;
  background: linear-gradient(135deg, rgba(201,168,76,0.04) 0%, transparent 60%, rgba(201,168,76,0.02) 100%);
  border-top: 1px solid rgba(201,168,76,0.10);
  border-bottom: 1px solid rgba(201,168,76,0.10);
  overflow: hidden;
}
.stats-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 140% at 50% -10%, rgba(201,168,76,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.stats-title {
  position: relative;
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold-dim);
  text-align: center;
  margin-bottom: 28px;
}
.stats-inner {
  position: relative;
  max-width: 860px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  padding: 0 40px;
  flex: 1;
}
.stat-number {
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  min-width: 2ch;
  text-align: center;
  transition: color 0.3s;
}
.stat-label {
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-dim);
  white-space: nowrap;
}
.stat-sep {
  width: 1px;
  height: 52px;
  background: linear-gradient(to bottom, transparent, rgba(201,168,76,0.18), transparent);
  flex-shrink: 0;
}
.stat-online-number::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--online);
  box-shadow: 0 0 6px var(--online-glow);
  margin-right: 6px;
  vertical-align: middle;
  position: relative;
  top: -1px;
}

/* ═══════════════════════════════════════════
   NEWS PAGINATION
═══════════════════════════════════════════ */
.news-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}

/* ═══════════════════════════════════════════
   FOOTER LEGAL
═══════════════════════════════════════════ */
.footer-legal {
  margin-top: 24px;
}
.footer-legal-link {
  font-family: var(--font-ui);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-dim);
  transition: color var(--transition);
}
.footer-legal-link:hover { color: var(--gold-dim); }

/* ═══════════════════════════════════════════
   RGPD MODAL
═══════════════════════════════════════════ */
.rgpd-panel {
  max-width: 640px;
  max-height: 82vh;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--gold-dim) transparent;
}
.rgpd-content h2 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--gold);
  margin-bottom: 4px;
}
.rgpd-date {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  color: var(--text-dim);
  letter-spacing: 0.1em;
  margin-bottom: 28px;
}
.rgpd-content h3 {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-dim);
  margin: 22px 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.rgpd-content p {
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 10px;
}
.rgpd-content strong { color: var(--text); }

/* ── Reactions ── */
.rx-bar {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 12px;
  margin-top: 12px;
  border-top: 1px solid var(--border);
}
.rx-btns {
  display: flex;
  align-items: center;
  gap: 6px;
}
.rx-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 13px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: rgba(255,255,255,0.03);
  font-family: var(--font-ui);
  font-size: 0.74rem;
  color: var(--text-muted);
  cursor: pointer;
  transition: border-color 0.18s, color 0.18s, background 0.18s;
  line-height: 1;
}
.rx-btn:not(:disabled):hover { border-color: var(--gold-dim); color: var(--text); }
.rx-btn:disabled { opacity: 0.35; cursor: default; }
.rx-btn.rx-on.rx-like    { border-color: var(--success); color: var(--success); background: rgba(126,168,126,0.1); }
.rx-btn.rx-on.rx-heart   { border-color: #e25555; color: #e25555; background: rgba(226,85,85,0.1); }
.rx-btn.rx-on.rx-wow     { border-color: #e2a832; color: #e2a832; background: rgba(226,168,50,0.1); }
.rx-btn.rx-on.rx-cry     { border-color: #5599cc; color: #5599cc; background: rgba(85,153,204,0.1); }
.rx-btn.rx-on.rx-dislike { border-color: var(--danger); color: var(--danger); background: rgba(196,106,90,0.1); }
.rx-btn.rx-on.rx-splash  { border-color: #4fc3f7; color: #4fc3f7; background: rgba(79,195,247,0.1); }
/* Inline names row */
.rx-names {
  display: none;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px 8px;
}
.rx-names.rx-has { display: flex; }
.rx-group {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
}
.rx-group-emoji {
  font-size: 0.72rem;
  flex-shrink: 0;
}
.rx-chip {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  letter-spacing: 0.04em;
  padding: 2px 9px;
  border-radius: 20px;
  white-space: nowrap;
}
.rx-chip-like    { color: rgba(74,222,128,0.85);  background: rgba(74,222,128,0.07);  border: 1px solid rgba(74,222,128,0.18); }
.rx-chip-dislike { color: rgba(248,113,113,0.85); background: rgba(248,113,113,0.07); border: 1px solid rgba(248,113,113,0.18); }
.rx-chip-more   { color: var(--text-dim); background: transparent; border: 1px solid var(--border); font-style: italic; }
.rx-sep-dot {
  color: var(--border);
  font-size: 0.6rem;
  flex-shrink: 0;
}
/* Wrapper for column-layout image sections (war, araya) */
.rx-img-wrap {
  break-inside: avoid;
  margin-bottom: 16px;
}
.rx-img-wrap .war-item,
.rx-img-wrap .araya-item {
  break-inside: unset;
  margin-bottom: 0;
  border-radius: var(--radius) var(--radius) 0 0;
}
/* Wrapper for grid-layout gallery */
.rx-gal-wrap { display: flex; flex-direction: column; }
.rx-gal-wrap .gallery-item { border-radius: var(--radius) var(--radius) 0 0; }
/* Reaction bar below image tiles — compact */
.rx-bar-img {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  padding: 8px 10px;
  margin-top: 0;
  gap: 5px;
}
.rx-bar-img .rx-btns {
  flex-wrap: wrap;
  gap: 4px;
  justify-content: center;
}
.rx-bar-img .rx-btn {
  font-size: 0.66rem;
  padding: 3px 8px;
  gap: 3px;
  border-radius: 14px;
}
.rx-bar-img .rx-chip { font-size: 0.64rem; padding: 1px 7px; }
/* Wrapper for song rows */
.rx-song-wrap { display: flex; flex-direction: column; }
/* Auth overlay caché tant que la session n'est pas vérifiée */
.has-token #auth-overlay { display: none; }

/* ── Comments ── */
.cm-wrap { margin-top: 24px; border-top: 1px solid var(--border); padding-top: 14px; }
.cm-toggle-btn {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.08em;
  color: var(--text-muted); background: none; border: none; cursor: pointer;
  padding: 2px 0; transition: color var(--transition);
}
.cm-toggle-btn:hover { color: var(--gold); }
.cm-toggle-btn .cm-ico { font-size: 0.85rem; }
.cm-count-badge {
  display: inline-block; background: var(--gold-subtle); border: 1px solid var(--gold-dim);
  border-radius: 10px; font-size: 0.62rem; color: var(--gold); padding: 1px 7px;
  font-family: var(--font-ui); line-height: 1.4;
}
.cm-count-badge:empty { display: none; }
.cm-count-badge.cm-count-zero { background: transparent; border-color: var(--border); color: var(--text-dim); opacity: 0.5; }
.cm-panel { display: none; margin-top: 10px; }
.cm-panel.open { display: block; animation: cmSlideIn 0.22s ease; }
@keyframes cmSlideIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cm-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.cm-empty {
  font-family: var(--font-ui); font-size: 0.72rem; color: var(--text-dim);
  text-align: center; padding: 12px 0; font-style: italic;
}
.cm-bubble {
  background: var(--night-lift); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 9px 12px; animation: bubbleIn 0.18s ease;
}
.cm-bubble.own { border-color: rgba(201,168,76,0.22); background: rgba(201,168,76,0.04); }
.cm-bubble-hdr {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 6px; margin-bottom: 4px;
}
.cm-author {
  font-family: var(--font-display); font-size: 0.67rem;
  letter-spacing: 0.1em; color: var(--gold); flex-shrink: 0;
}
.cm-time { font-family: var(--font-ui); font-size: 0.58rem; color: var(--text-dim); }
.cm-actions { display: flex; gap: 4px; margin-left: auto; }
.cm-act-btn {
  font-size: 0.7rem; color: var(--text-dim); background: none; border: none;
  cursor: pointer; padding: 1px 4px; border-radius: 3px;
  transition: color var(--transition), opacity var(--transition); opacity: 0.45;
  line-height: 1;
}
.cm-act-btn:hover { opacity: 1; }
.cm-act-btn.cm-edit-btn:hover { color: var(--gold); }
.cm-act-btn.cm-del-btn:hover  { color: var(--danger); }
.cm-trans {
  font-family: var(--font-body); font-size: 0.82rem; color: var(--text-dim);
  font-style: italic; margin-top: 4px; word-break: break-word;
  padding-left: 10px; border-left: 2px solid var(--border); line-height: 1.5;
}
.cm-text {
  font-family: var(--font-body); font-size: 0.88rem; color: var(--text);
  line-height: 1.55; word-break: break-word; white-space: pre-wrap;
}
.cm-edited { font-size: 0.62rem; color: var(--text-dim); font-style: italic; margin-top: 3px; }
.cm-edit-area {
  width: 100%; background: var(--night-alt); border: 1px solid var(--border);
  border-radius: var(--radius); color: var(--text); font-family: var(--font-body);
  font-size: 0.88rem; padding: 7px 10px; resize: none; outline: none;
  transition: border-color var(--transition); line-height: 1.5;
  margin-top: 6px; box-sizing: border-box;
}
.cm-edit-area:focus { border-color: var(--gold-dim); }
.cm-edit-actions { display: flex; gap: 6px; margin-top: 6px; justify-content: flex-end; }
.cm-save-btn {
  font-family: var(--font-ui); font-size: 0.65rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); border: 1px solid var(--gold-dim);
  background: transparent; border-radius: var(--radius); padding: 5px 14px;
  cursor: pointer; transition: all var(--transition);
}
.cm-save-btn:hover { background: var(--gold-subtle); }
.cm-cancel-btn {
  font-family: var(--font-ui); font-size: 0.65rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--text-muted); border: 1px solid var(--border);
  background: transparent; border-radius: var(--radius); padding: 5px 14px;
  cursor: pointer; transition: all var(--transition);
}
.cm-cancel-btn:hover { color: var(--text); border-color: rgba(255,255,255,0.2); }
.cm-form { display: flex; gap: 8px; align-items: flex-end; }
.cm-input {
  flex: 1; background: var(--night-alt); border: 1px solid var(--border);
  border-radius: var(--radius); color: var(--text); font-family: var(--font-body);
  font-size: 0.88rem; padding: 7px 11px; resize: none; line-height: 1.5;
  transition: border-color var(--transition); outline: none;
}
.cm-input:focus { border-color: var(--gold-dim); }
.cm-input::placeholder { color: var(--text-dim); font-style: italic; }
.cm-submit {
  font-family: var(--font-ui); font-size: 0.65rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gold); border: 1px solid var(--gold-dim);
  background: transparent; border-radius: var(--radius); padding: 8px 14px;
  cursor: pointer; transition: all var(--transition); white-space: nowrap; flex-shrink: 0;
}
.cm-submit:hover { background: var(--gold-subtle); }
.cm-submit:disabled { opacity: 0.4; cursor: default; }
.cm-login-hint {
  font-family: var(--font-ui); font-size: 0.7rem; color: var(--text-dim);
  text-align: center; padding: 8px 0; font-style: italic;
}

/* ── MAINTENANCE OVERLAY ── */
#maintenance-overlay {
  display:none; position:fixed; inset:0; z-index:99999;
  background:var(--night); color:var(--text);
  flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:32px; overflow:hidden;
}
#maintenance-overlay.active { display:flex; }
.maint-shield {
  width:120px; height:120px; margin-bottom:32px; position:relative;
  animation: maint-pulse 3s ease-in-out infinite;
}
.maint-shield svg { width:100%; height:100%; filter:drop-shadow(0 0 30px rgba(201,168,76,0.4)); }
@keyframes maint-pulse {
  0%,100% { transform:scale(1); opacity:1; }
  50% { transform:scale(1.06); opacity:0.85; }
}
.maint-stars { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.maint-stars span {
  position:absolute; width:2px; height:2px;
  background:var(--gold); border-radius:50%;
  animation: maint-twinkle 2s ease-in-out infinite;
}
@keyframes maint-twinkle { 0%,100%{opacity:0.15} 50%{opacity:1} }
.maint-title {
  font-family:var(--font-display); font-size:clamp(1.4rem,4vw,2.2rem); font-weight:700;
  background:linear-gradient(120deg,var(--gold) 0%,var(--gold-bright) 50%,var(--gold) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:20px; line-height:1.3;
}
.maint-msg {
  font-family:var(--font-body); font-size:clamp(1rem,2.5vw,1.25rem);
  color:var(--text-muted); max-width:540px; line-height:1.6; margin-bottom:32px;
}
.maint-badge {
  font-family:var(--font-ui); font-size:0.65rem; letter-spacing:0.25em;
  text-transform:uppercase; color:var(--gold-dim);
  border:1px solid var(--gold-dim); padding:8px 20px; border-radius:var(--radius);
}
.maint-cosmo {
  position:absolute; width:300px; height:300px; border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,76,0.08) 0%,transparent 70%);
  pointer-events:none; animation:maint-cosmo-spin 20s linear infinite;
}
@keyframes maint-cosmo-spin { from{transform:rotate(0)} to{transform:rotate(360deg)} }

/* FAQ */
.fq{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:10px;overflow:hidden;transition:border-color .3s,box-shadow .3s}
.fq:hover{border-color:var(--border-hover);box-shadow:0 4px 16px rgba(201,168,76,.05)}
.fq.open{border-color:var(--gold-dim);box-shadow:0 4px 20px rgba(201,168,76,.08)}
.fq-q{display:flex;align-items:center;gap:12px;padding:15px 18px;cursor:pointer;font-family:var(--font-display);font-size:.86rem;color:var(--text);transition:color .2s}
.fq.open .fq-q{color:var(--gold)}
.fq-i{font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--gold-subtle);flex-shrink:0}
.fq.open .fq-i{background:var(--gold-glow)}
.fq-arr{margin-left:auto;font-size:.55rem;color:var(--text-dim);width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--gold-subtle);transition:transform .3s}
.fq.open .fq-arr{transform:rotate(180deg);color:var(--gold);background:var(--gold-glow)}
.fq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease,opacity .25s;padding:0 18px 0 58px;opacity:0}
.fq.open .fq-a{max-height:400px;padding:0 18px 16px 58px;opacity:1}
.fq-a p{font-family:var(--font-body);font-size:.83rem;line-height:1.8;color:var(--text-muted);border-left:2px solid var(--gold-dim);padding-left:12px;margin:0}

/* Chat Tips Popup */
.chat-tips-popup{position:absolute;bottom:100%;left:0;right:0;background:var(--night-card);border:1px solid rgba(201,168,76,.2);border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:12;max-height:340px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -4px 20px rgba(0,0,0,.4)}
.chat-tips-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(201,168,76,.12);flex-shrink:0}
.chat-tips-title{font-family:var(--font-display);font-size:.85rem;color:var(--gold);letter-spacing:.06em}
.chat-tips-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:2px 6px;border-radius:4px}
.chat-tips-close:hover{color:var(--gold);background:rgba(201,168,76,.1)}
.chat-tips-body{overflow-y:auto;padding:10px 14px;-webkit-overflow-scrolling:touch}
.chat-tips-section{margin-bottom:10px}
.chat-tips-section:last-child{margin-bottom:0}
.chat-tips-label{font-size:.72rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;opacity:.8}
.chat-tips-row{font-size:.78rem;color:var(--text-muted);padding:2px 0;display:flex;align-items:center;gap:6px;line-height:1.5}
.chat-tips-row code{background:rgba(201,168,76,.08);color:var(--gold);padding:1px 5px;border-radius:3px;font-size:.75rem;font-family:monospace}
.chat-tips-row kbd{background:rgba(201,168,76,.1);color:var(--text);padding:1px 6px;border-radius:3px;font-size:.7rem;border:1px solid rgba(201,168,76,.2);font-family:var(--font-ui)}
.chat-tips-row strong{color:var(--text)}
.chat-tips-row em{color:var(--text)}

/* GIF Picker */
.gif-picker{position:absolute;bottom:100%;left:0;right:0;background:rgba(14,20,40,0.95);border:1px solid rgba(201,168,76,0.12);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:10px;z-index:10;height:260px;display:flex;flex-direction:column;overflow:hidden;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 -8px 24px rgba(0,0,0,0.4)}
.gif-search{width:100%;background:var(--night-alt);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-ui);font-size:.8rem;padding:8px 12px;margin-bottom:8px;flex-shrink:0}
.gif-search:focus{outline:none;border-color:var(--gold-dim)}
.gif-search::placeholder{color:var(--text-dim)}
.gif-results{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;overflow-y:scroll;min-height:0;flex:1 1 0}
.gif-results img{width:100%;height:55px;object-fit:cover;border-radius:4px;cursor:pointer;transition:opacity .15s}
.gif-results img:hover{opacity:.8}
.gif-results .gif-loading{grid-column:1/-1;text-align:center;color:var(--text-muted);font-size:.75rem;padding:20px}

/* DM Pickers */
.dm-input-wrap{flex-shrink:0}
.dm-picker-panel{background:rgba(10,12,18,0.95);border-top:1px solid rgba(201,168,76,.12);padding:10px;height:260px;display:flex;flex-direction:column;overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.dm-picker-panel .gif-results{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;overflow-y:auto;min-height:0;flex:1 1 0;-webkit-overflow-scrolling:touch}
.dm-picker-panel .gif-results img{width:100%;height:55px;object-fit:cover;border-radius:4px;cursor:pointer}
.dm-emoji-panel .emoji-results{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;overflow-y:auto;min-height:0;flex:1 1 0;-webkit-overflow-scrolling:touch}
.dm-emoji-panel .emoji-item{font-size:1.4rem;text-align:center;padding:4px;cursor:pointer;border-radius:4px}
.dm-emoji-panel .emoji-item:hover{background:rgba(201,168,76,.15)}
.dm-emoji-panel .emoji-cats{display:flex;gap:2px;padding:4px 0;border-bottom:1px solid rgba(201,168,76,.12);margin-bottom:6px;overflow-x:auto;flex-shrink:0}
@media(max-width:600px){.dm-picker-panel .gif-results{grid-template-columns:repeat(3,1fr)}.dm-emoji-panel .emoji-results{grid-template-columns:repeat(6,1fr)}}

/* Inline GIF in messages */
.msg-inline-gif{max-width:200px;max-height:180px;border-radius:8px;cursor:pointer;display:block;margin-top:4px;-webkit-transform:translateZ(0);transform:translateZ(0)}

/* Emoji Picker */
.emoji-picker{position:absolute;bottom:100%;left:0;right:0;background:rgba(14,20,40,0.95);border:1px solid rgba(201,168,76,0.12);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:10px;z-index:10;height:300px;display:flex;flex-direction:column;overflow:hidden;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 -8px 24px rgba(0,0,0,0.4)}
.emoji-search{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--night-bg);color:var(--text);font-size:.85rem;margin-bottom:6px;outline:none}
.emoji-search:focus{border-color:var(--gold)}
.emoji-cats{display:flex;gap:2px;padding:4px 0;border-bottom:1px solid var(--border);margin-bottom:6px;overflow-x:auto;flex-shrink:0}
.emoji-cat-btn{font-size:1.1rem;padding:3px 5px;cursor:pointer;border-radius:var(--radius);opacity:.5;transition:opacity .2s,background .2s}
.emoji-cat-btn:hover,.emoji-cat-btn.active{opacity:1;background:rgba(201,168,76,.15)}
.emoji-results{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;overflow-y:auto;min-height:0;flex:1 1 0;-webkit-overflow-scrolling:touch}
.emoji-item{font-size:1.4rem;text-align:center;padding:4px;cursor:pointer;border-radius:var(--radius);transition:background .15s}
.emoji-item:hover{background:rgba(201,168,76,.15)}
@media(max-width:600px){.emoji-results{grid-template-columns:repeat(6,1fr)}.emoji-item{font-size:1.3rem;padding:3px}}

/* ══════════════════════════════
   POLL / SONDAGGIO
══════════════════════════════ */
.msg-poll{background:rgba(201,168,76,.06);border:1.5px solid var(--gold);border-radius:var(--radius-lg);padding:14px 16px;margin-top:6px;max-width:360px}
.msg-poll-question{font-weight:700;font-size:.95rem;color:var(--gold);margin-bottom:12px;line-height:1.35}
.msg-poll-option{position:relative;border:1px solid rgba(201,168,76,.25);border-radius:var(--radius);padding:9px 12px;margin-bottom:6px;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:space-between;transition:border-color .2s,background .2s;background:rgba(0,0,0,.15);min-height:36px}
.msg-poll-option:hover{border-color:var(--gold);background:rgba(201,168,76,.08)}
.msg-poll-option.msg-poll-voted{border-color:var(--gold);background:rgba(201,168,76,.12)}
.msg-poll-option.msg-poll-voted .msg-poll-opt-text{font-weight:600}
.msg-poll-bar-fill{position:absolute;left:0;top:0;bottom:0;background:rgba(201,168,76,.18);border-radius:var(--radius);transition:width .4s ease;pointer-events:none}
.msg-poll-voted .msg-poll-bar-fill{background:rgba(201,168,76,.3)}
.msg-poll-opt-text{position:relative;z-index:1;font-size:.85rem;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:8px}
.msg-poll-count{position:relative;z-index:1;font-size:.75rem;color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.msg-poll-total{text-align:right;font-size:.75rem;color:var(--text-muted);margin-top:4px;font-style:italic}

/* Poll creator modal */
.poll-modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.poll-modal{background:var(--night-card,#1a1a2e);border:1.5px solid var(--gold);border-radius:var(--radius-lg);width:90%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.poll-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(201,168,76,.2);font-weight:700;font-size:1rem;color:var(--gold)}
.poll-modal-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius);transition:color .2s}
.poll-modal-close:hover{color:var(--text)}
.poll-modal-body{padding:16px 18px}
.poll-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.poll-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--night-bg,#0d0d1a);color:var(--text);font-size:.88rem;outline:none;margin-bottom:8px;box-sizing:border-box;transition:border-color .2s}
.poll-input:focus{border-color:var(--gold)}
.poll-add-option-btn{background:none;border:1px dashed rgba(201,168,76,.3);color:var(--gold);padding:7px 12px;border-radius:var(--radius);cursor:pointer;font-size:.82rem;width:100%;text-align:center;transition:background .2s,border-color .2s;margin-top:2px}
.poll-add-option-btn:hover{background:rgba(201,168,76,.08);border-color:var(--gold)}
.poll-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:12px 18px;border-top:1px solid rgba(201,168,76,.2)}
.poll-cancel-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:8px 18px;border-radius:var(--radius);cursor:pointer;font-size:.85rem;transition:color .2s,border-color .2s}
.poll-cancel-btn:hover{color:var(--text);border-color:var(--text-muted)}
.poll-create-btn{background:var(--gold);color:#000;border:none;padding:8px 22px;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:700;transition:opacity .2s}
.poll-create-btn:hover{opacity:.85}

/* ══════════════════════════════════════════════════
   CUSTOM STATUS SYSTEM
══════════════════════════════════════════════════ */

/* Status display (inline next to names) */
.user-status {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: .72rem;
  color: var(--text-muted);
  margin-left: 4px;
  vertical-align: middle;
  max-width: 180px;
  overflow: hidden;
  white-space: nowrap;
}
.user-status-text {
  opacity: .7;
  font-style: italic;
  text-overflow: ellipsis;
  overflow: hidden;
}
.online-banner-names .user-status {
  font-size: .65rem;
  max-width: 120px;
}

/* Status emoji in chat messages */
.msg-status-emoji {
  font-size: .7rem;
  margin-left: 3px;
  opacity: .8;
}

/* Status setter (in auth panel) */
.status-setter {
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(201,168,76,0.04);
  border: 1px solid rgba(201,168,76,0.12);
  border-radius: var(--radius);
}
.status-setter-current {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 4px 0;
  transition: opacity .2s;
}
.status-setter-current:hover { opacity: .8; }
.status-setter-label {
  font-size: .78rem;
  font-weight: 600;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-family: var(--font-ui);
}
.status-setter-preview .user-status {
  font-size: .78rem;
  max-width: 200px;
}

/* Status editor (expanded) */
.status-editor {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(201,168,76,0.1);
}
.status-emoji-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 10px;
}
.status-emoji-btn {
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.12);
  border-radius: 6px;
  cursor: pointer;
  transition: all .15s;
}
.status-emoji-btn:hover {
  background: rgba(201,168,76,0.15);
  border-color: var(--gold);
  transform: scale(1.12);
}
.status-emoji-btn.active {
  background: rgba(201,168,76,0.2);
  border-color: var(--gold);
  box-shadow: 0 0 8px rgba(201,168,76,0.3);
}
.status-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.status-selected-emoji {
  font-size: 1.2rem;
  min-width: 28px;
  text-align: center;
}
.status-input {
  flex: 1;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--night-bg, #0d0d1a);
  color: var(--text);
  font-size: .82rem;
  font-family: var(--font-ui);
  outline: none;
  transition: border-color .2s;
}
.status-input:focus { border-color: var(--gold); }
.status-input::placeholder { color: var(--text-muted); opacity: .5; }
.status-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.status-save-btn {
  background: var(--gold);
  color: #000;
  border: none;
  padding: 6px 18px;
  border-radius: var(--radius);
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s;
  font-family: var(--font-ui);
}
.status-save-btn:hover { opacity: .85; }
.status-clear-btn {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-muted);
  padding: 6px 14px;
  border-radius: var(--radius);
  font-size: .8rem;
  cursor: pointer;
  transition: color .2s, border-color .2s;
  font-family: var(--font-ui);
}
.status-clear-btn:hover { color: #e06060; border-color: #e06060; }

/* Status in member cards */
.member-card-status {
  margin-top: 2px;
  line-height: 1.2;
}
.member-card-status .user-status {
  font-size: .68rem;
  max-width: 130px;
  display: inline-flex;
}

/* Responsive */
@media (max-width: 600px) {
  .status-emoji-btn { width: 30px; height: 30px; font-size: 1rem; }
  .user-status { max-width: 120px; font-size: .65rem; }
  .online-banner-names .user-status { max-width: 80px; }
  .member-card-status .user-status { max-width: 100px; }
}

/* ══════════════════════════════════════════════════
   STREAKS & LEADERBOARD
══════════════════════════════════════════════════ */
.streak-display {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 0.72rem; font-weight: 700; color: var(--gold);
  background: var(--gold-subtle); border-radius: 10px; padding: 2px 8px;
  cursor: default; white-space: nowrap;
  animation: streak-glow 2s ease-in-out infinite alternate;
}
@keyframes streak-glow {
  from { box-shadow: 0 0 4px var(--gold-glow); }
  to   { box-shadow: 0 0 10px var(--gold-dim); }
}
.streak-lb-btn {
  font-size: 0.7rem !important;
  cursor: pointer;
}
.streak-overlay {
  position: fixed; inset: 0; z-index: 10100;
  background: rgba(0,0,0,0.65); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
}
.streak-modal {
  background: var(--night); border: 1px solid var(--border);
  border-radius: 14px; width: 340px; max-width: 92vw;
  max-height: 80vh; overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.streak-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--gold-subtle) 0%, var(--night) 100%);
}
.streak-modal-title {
  font-family: var(--font-display); font-size: 0.7rem;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold);
}
.streak-modal-body {
  padding: 8px 0; max-height: 50vh; overflow-y: auto;
}
.streak-lb-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px; transition: background 0.15s;
}
.streak-lb-row:hover { background: var(--gold-subtle); }
.streak-lb-row.streak-me {
  background: rgba(201,168,76,0.08);
  border-left: 3px solid var(--gold);
}
.streak-lb-rank {
  min-width: 24px; text-align: center; font-size: 0.85rem;
}
.streak-lb-name {
  flex: 1; font-size: 0.82rem; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.streak-lb-total {
  font-size: 0.72rem; color: var(--gold); font-weight: 600;
  white-space: nowrap;
}
.streak-my-stats {
  padding: 10px 16px; border-top: 1px solid var(--border);
  background: var(--gold-subtle);
}
.streak-my-row {
  display: flex; gap: 14px; flex-wrap: wrap;
  font-size: 0.75rem; color: var(--text);
}
.streak-my-row b { color: var(--gold); }

/* ═══ Feature: Chat Birthday Banner ═══ */
.chat-birthday-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  margin: 0 8px 12px;
  background: linear-gradient(135deg, rgba(201,168,76,0.15), rgba(255,215,0,0.08), rgba(201,168,76,0.15));
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 12px;
  text-align: center;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--gold);
  animation: chatBdayShine 3s ease-in-out infinite;
  position: relative;
  overflow: hidden;
}
.chat-birthday-banner::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,215,0,0.1), transparent);
  animation: chatBdayShimmer 4s ease-in-out infinite;
}
@keyframes chatBdayShine {
  0%, 100% { border-color: rgba(201,168,76,0.35); box-shadow: 0 0 0 transparent; }
  50% { border-color: rgba(255,215,0,0.6); box-shadow: 0 0 12px rgba(255,215,0,0.1); }
}
@keyframes chatBdayShimmer {
  0% { left: -100%; }
  100% { left: 200%; }
}
.chat-bday-confetti {
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--gold);
  border-radius: 50%;
  animation: confettiPulse 1.5s ease-in-out infinite;
}
.chat-bday-confetti:last-child { animation-delay: 0.7s; }
@keyframes confettiPulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.5); }
}

/* ═══ Feature: Pinned Messages Banner ═══ */
.pinned-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  margin: 0 8px 8px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  position: relative;
}
.pinned-banner:hover {
  background: rgba(201,168,76,0.14);
  border-color: rgba(201,168,76,0.4);
}
.pinned-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
}
.pinned-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pinned-author {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--gold);
}
.pinned-text {
  font-size: 0.78rem;
  color: #c8bfaf;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pinned-count {
  font-size: 0.68rem;
  color: #8a7e6d;
  margin-left: 6px;
}
.pinned-unpin {
  flex-shrink: 0;
  width: 22px; height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 0.7rem;
  color: #8a7e6d;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.pinned-unpin:hover {
  background: rgba(255,100,100,0.15);
  color: #ff6b6b;
}

/* ═══ Feature: DM Online Status + Seen Time ═══ */
@keyframes dmDotPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(46,204,113,0.4); }
  50% { box-shadow: 0 0 0 4px rgba(46,204,113,0); }
}
.dm-header-status {
  font-size: 0.68rem;
  color: #8a7e6d;
  margin-top: 1px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.dm-status-text {
  color: #2ecc71;
  font-weight: 600;
}
.dm-seen-time {
  font-size: 0.62rem;
  color: #6a9ec8;
  letter-spacing: 0.02em;
}

/* ══════════════════════════════
   VOICE PANEL
══════════════════════════════ */
.voice-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.7); z-index: 100002;
}
.voice-overlay.open { display: block; }
.voice-panel {
  position: fixed; top: 0; right: -400px;
  width: 380px; max-width: 100vw; height: 100dvh;
  background: #0d0f12; border-left: 1px solid rgba(201,168,76,0.15);
  z-index: 100003; display: flex; flex-direction: column;
  transition: right .3s cubic-bezier(.4,0,.2,1);
  box-shadow: -4px 0 24px rgba(0,0,0,0.5);
  overscroll-behavior: contain;
}
.voice-panel.open { right: 0; }
.voice-panel-header {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 18px; border-bottom: 1px solid rgba(201,168,76,0.15);
  min-height: 56px;
  background: linear-gradient(180deg, rgba(201,168,76,0.08) 0%, #0d0f12 100%);
}
.voice-panel-title {
  flex: 1; margin: 0; font-family: 'Cinzel', serif;
  font-size: 0.95rem; color: #C9A84C; letter-spacing: 0.06em;
}
.voice-panel-close {
  background: none; border: none; color: #8a7e6d;
  font-size: 1.2rem; cursor: pointer; padding: 4px 8px;
  transition: color .2s;
}
.voice-panel-close:hover { color: #C9A84C; }
.voice-back-btn {
  background: none; border: none; color: #C9A84C;
  font-size: 1.1rem; cursor: pointer; padding: 4px 8px;
  transition: opacity .2s;
}
.voice-back-btn:hover { opacity: 0.7; }
.voice-panel-body {
  flex: 1; overflow-y: auto; padding: 12px;
  -webkit-overflow-scrolling: touch;
}

/* Room cards */
.voice-rooms-list {
  display: flex; flex-direction: column; gap: 10px;
}
.voice-room-card {
  background: rgba(201,168,76,0.04);
  border: 1px solid rgba(201,168,76,0.12);
  border-radius: 10px; padding: 14px 16px;
  transition: border-color .2s, background .2s;
}
.voice-room-card:hover {
  border-color: rgba(201,168,76,0.3);
  background: rgba(201,168,76,0.07);
}
.voice-room-card.active {
  border-color: rgba(46,204,113,0.5);
  background: rgba(46,204,113,0.06);
}
.voice-room-info {
  display: flex; align-items: center; gap: 10px; margin-bottom: 8px;
}
.voice-room-icon { font-size: 1.2rem; }
.voice-room-name {
  flex: 1; font-family: 'Cinzel', serif; font-size: 0.88rem;
  color: #e8dcc8; letter-spacing: 0.04em;
}
.voice-room-count {
  font-size: 0.72rem; color: #8a7e6d;
}
.voice-room-avatars {
  display: flex; gap: 4px; margin-bottom: 10px; flex-wrap: wrap;
  min-height: 24px;
}
.voice-room-avatar {
  width: 26px; height: 26px; border-radius: 50%;
  object-fit: cover; border: 1px solid rgba(201,168,76,0.2);
}
.voice-room-avatar-default {
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(201,168,76,0.12); color: #C9A84C;
  font-size: 0.65rem; font-weight: 700;
}
.voice-room-join {
  display: block; width: 100%; padding: 8px 0; border: 1px solid rgba(201,168,76,0.3);
  background: rgba(201,168,76,0.08); color: #C9A84C;
  font-family: 'Cinzel', serif; font-size: 0.78rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  border-radius: 6px; text-align: center;
  transition: background .2s, border-color .2s;
}
.voice-room-card:hover .voice-room-join {
  background: rgba(201,168,76,0.18);
  border-color: rgba(201,168,76,0.5);
}

/* Users grid in room */
.voice-users-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 12px; padding: 8px 0;
}
.voice-user-card {
  display: flex; flex-direction: column; align-items: center;
  gap: 6px; padding: 14px 8px; border-radius: 10px;
  background: rgba(201,168,76,0.04);
  border: 2px solid transparent;
  transition: border-color .15s, box-shadow .15s;
  position: relative;
}
.voice-user-card.speaking {
  border-color: #2ecc71;
  box-shadow: 0 0 12px rgba(46,204,113,0.35), inset 0 0 8px rgba(46,204,113,0.08);
  animation: voice-glow 1s ease-in-out infinite alternate;
}
@keyframes voice-glow {
  from { box-shadow: 0 0 8px rgba(46,204,113,0.25); }
  to   { box-shadow: 0 0 16px rgba(46,204,113,0.45), inset 0 0 8px rgba(46,204,113,0.1); }
}
.voice-user-card.muted { opacity: 0.7; }
.voice-user-avatar {
  width: 48px; height: 48px; border-radius: 50%;
  object-fit: cover; border: 2px solid rgba(201,168,76,0.2);
}
.voice-user-avatar-default {
  display: flex; align-items: center; justify-content: center;
  background: rgba(201,168,76,0.12); color: #C9A84C;
  font-size: 1.1rem; font-weight: 700;
}
.voice-user-name {
  font-size: 0.72rem; color: #e8dcc8;
  text-align: center; word-break: break-word;
  font-family: 'Cinzel', serif; letter-spacing: 0.03em;
}
.voice-user-mute-icon {
  position: absolute; top: 6px; right: 6px;
  font-size: 0.7rem; opacity: 0.8;
}

/* Voice Transcription panel */
.vt-panel {
  margin-top: 14px; border-top: 1px solid rgba(201,168,76,.15);
  display: flex; flex-direction: column; flex: 1; min-height: 120px;
}
.vt-header {
  font-family: var(--font-ui); font-size: .72rem; font-weight: 700;
  color: var(--gold); letter-spacing: .06em; padding: 10px 12px 6px;
  display: flex; align-items: center; justify-content: space-between;
}
.vt-messages {
  flex: 1; min-height: 80px; max-height: 220px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 3px;
  padding: 6px 10px;
  scrollbar-width: thin; scrollbar-color: rgba(201,168,76,.2) transparent;
  background: rgba(0,0,0,.15); border-radius: 8px; margin: 0 8px;
}
.vt-messages::-webkit-scrollbar { width: 4px; }
.vt-messages::-webkit-scrollbar-thumb { background: rgba(201,168,76,.25); border-radius: 2px; }
.vt-messages:empty::before {
  content: '...'; display: block; text-align: center;
  color: var(--text-muted); font-style: italic; font-size: .75rem; padding: 20px;
}
.vt-msg {
  font-size: .78rem; line-height: 1.45; padding: 5px 10px;
  border-radius: 8px; background: rgba(201,168,76,.05);
  animation: vtFadeIn .3s ease;
}
@keyframes vtFadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
.vt-name {
  font-weight: 700; color: var(--gold); font-size: .7rem; margin-right: 6px;
}
.vt-text { color: var(--text); }
.vt-trans {
  display: block; font-style: italic; font-size: .68rem; color: var(--text-muted);
  margin-top: 2px; padding-left: 8px; border-left: 2px solid rgba(201,168,76,.15);
}
.vt-input-wrap {
  display: flex; gap: 6px; padding: 8px 10px;
  border-top: 1px solid rgba(201,168,76,.1);
}
.vt-input {
  flex: 1; padding: 8px 12px; border-radius: 8px;
  border: 1px solid rgba(201,168,76,.15); background: rgba(0,0,0,.2);
  color: var(--text); font-family: var(--font-ui); font-size: .8rem;
  outline: none; transition: border-color .2s;
}
.vt-input:focus { border-color: rgba(201,168,76,.4); }
.vt-input::placeholder { color: var(--text-muted); font-size: .75rem; }
.vt-send {
  width: 36px; height: 36px; border-radius: 8px; border: none;
  background: rgba(201,168,76,.15); color: var(--gold);
  font-size: .9rem; cursor: pointer; transition: background .2s;
  display: flex; align-items: center; justify-content: center;
}
.vt-send:hover { background: rgba(201,168,76,.25); }

/* Controls bar */
.voice-controls {
  display: flex; justify-content: center; gap: 16px;
  padding: 14px 18px; border-top: 1px solid rgba(201,168,76,0.15);
  background: rgba(0,0,0,0.3);
}
.voice-btn {
  width: 46px; height: 46px; border-radius: 50%;
  border: 1px solid rgba(201,168,76,0.25);
  background: rgba(201,168,76,0.08);
  color: #e8dcc8; font-size: 1.1rem;
  cursor: pointer; transition: all .2s;
  display: flex; align-items: center; justify-content: center;
}
.voice-btn:hover {
  background: rgba(201,168,76,0.18);
  border-color: rgba(201,168,76,0.4);
}
.voice-btn.active {
  background: rgba(231,76,60,0.18);
  border-color: rgba(231,76,60,0.5);
  color: #e74c3c;
}
.voice-btn.active-deafen {
  background: rgba(243,156,18,0.18);
  border-color: rgba(243,156,18,0.5);
  color: #f39c12;
}
.voice-btn.leave {
  background: rgba(231,76,60,0.12);
  border-color: rgba(231,76,60,0.35);
  color: #e74c3c;
}
.voice-btn.leave:hover {
  background: rgba(231,76,60,0.25);
  border-color: rgba(231,76,60,0.6);
}

/* Active indicator on chat header button */
#voice-toggle-btn.voice-active {
  position: relative;
}
#voice-toggle-btn.voice-active::after {
  content: ''; position: absolute; bottom: 2px; right: 2px;
  width: 7px; height: 7px; border-radius: 50%;
  background: #2ecc71; border: 1px solid #0d0f12;
  animation: voice-pulse 1.5s ease-in-out infinite;
}
@keyframes voice-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* Mobile responsive */
@media (max-width: 600px) {
  .voice-panel {
    width: 100vw !important; right: -100vw !important;
    border-left: none !important; box-shadow: none !important;
  }
  .voice-panel.open { right: 0 !important; }
  .voice-users-grid {
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 8px;
  }
  .voice-user-avatar { width: 40px; height: 40px; }
  .voice-user-name { font-size: 0.65rem; }
  .voice-btn { width: 42px; height: 42px; font-size: 1rem; }
}

/* ══════════════════════════════════════════
   HALL OF FAME
══════════════════════════════════════════ */
.hof-month-selector {
  display: flex; align-items: center; justify-content: center; gap: 16px;
  margin-bottom: 24px; font-family: var(--font-display);
}
.hof-month-btn {
  background: rgba(201,168,76,.15); border: 1px solid rgba(201,168,76,.3);
  color: var(--gold); border-radius: 6px; padding: 6px 12px; cursor: pointer;
  font-size: .85rem; transition: all .2s;
}
.hof-month-btn:hover { background: rgba(201,168,76,.3); }
.hof-month-label {
  font-size: 1rem; color: var(--gold); letter-spacing: .08em; font-weight: 600;
  text-transform: capitalize;
}

/* MVP Card */
.hof-mvp-card {
  background: linear-gradient(135deg, rgba(201,168,76,.18) 0%, rgba(201,168,76,.06) 100%);
  border: 1px solid rgba(201,168,76,.35); border-radius: 12px;
  padding: 20px 24px; margin-bottom: 28px; text-align: center;
  position: relative; overflow: hidden;
}
.hof-mvp-card::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(201,168,76,.12) 0%, transparent 70%);
  pointer-events: none;
}
.hof-mvp-crown { font-size: 2rem; margin-bottom: 4px; }
.hof-mvp-title {
  font-family: var(--font-display); font-size: .75rem; color: var(--gold);
  letter-spacing: .15em; text-transform: uppercase; margin-bottom: 12px;
}
.hof-mvp-body { display: flex; align-items: center; justify-content: center; gap: 14px; }
.hof-mvp-avatar {
  width: 56px; height: 56px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--gold); box-shadow: 0 0 16px rgba(201,168,76,.3);
}
.hof-mvp-name {
  font-family: var(--font-display); font-size: 1.1rem; color: var(--gold); font-weight: 700;
}
.hof-mvp-xp {
  font-family: var(--font-ui); font-size: .8rem; color: var(--text-muted); margin-top: 2px;
}

/* Grid */
.hof-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}

/* Card */
.hof-card {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 16px; transition: border-color .2s, box-shadow .2s;
}
.hof-card:hover {
  border-color: rgba(201,168,76,.25); box-shadow: 0 0 20px rgba(201,168,76,.08);
}
.hof-card-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.06);
}
.hof-card-icon { font-size: 1.3rem; }
.hof-card-title {
  font-family: var(--font-display); font-size: .8rem; color: var(--gold);
  letter-spacing: .06em;
}

/* Podium */
.hof-podium {
  display: flex; justify-content: center; gap: 12px; margin-bottom: 10px;
}
.hof-podium-entry {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  flex: 1; min-width: 0;
}
.hof-podium-entry.hof-rank-1 { order: 2; }
.hof-podium-entry.hof-rank-2 { order: 1; }
.hof-podium-entry.hof-rank-3 { order: 3; }
.hof-medal { font-size: 1.2rem; }
.hof-rank-1 .hof-medal { font-size: 1.5rem; }
.hof-avatar {
  width: 36px; height: 36px; border-radius: 50%; object-fit: cover;
  border: 2px solid rgba(255,255,255,.1);
}
.hof-rank-1 .hof-avatar {
  width: 44px; height: 44px; border-color: var(--gold);
  box-shadow: 0 0 12px rgba(201,168,76,.25);
}
.hof-rank-2 .hof-avatar { border-color: #c0c0c0; }
.hof-rank-3 .hof-avatar { border-color: #cd7f32; }
.hof-no-avatar {
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.06); font-size: 1rem;
}
.hof-name {
  font-family: var(--font-ui); font-size: .65rem; color: var(--text);
  text-align: center; white-space: nowrap; overflow: hidden;
  text-overflow: ellipsis; max-width: 80px;
}
.hof-rank-1 .hof-name { color: var(--gold); font-weight: 700; font-size: .7rem; }
.hof-value {
  font-family: var(--font-ui); font-size: .6rem; color: var(--text-muted);
}
.hof-rank-1 .hof-value { color: var(--gold); }

/* Runners (4th, 5th) */
.hof-runners {
  border-top: 1px solid rgba(255,255,255,.04); padding-top: 8px;
}
.hof-runner {
  display: flex; align-items: center; gap: 6px; padding: 3px 0;
  font-family: var(--font-ui); font-size: .65rem;
}
.hof-runner-rank { color: var(--text-muted); min-width: 20px; }
.hof-runner-avatar {
  width: 20px; height: 20px; border-radius: 50%; object-fit: cover;
}
.hof-runner-name { color: var(--text); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hof-runner-value { color: var(--text-muted); }

.hof-empty {
  text-align: center; padding: 20px; color: var(--text-muted);
  font-family: var(--font-ui); font-size: .75rem; font-style: italic;
}

/* See all link */
.hof-see-all {
  display: block; text-align: right; padding: 4px 0 8px;
  font-family: var(--font-ui); font-size: .68rem; font-weight: 600;
  color: var(--gold); text-decoration: none; letter-spacing: .04em;
  opacity: .7; transition: opacity .2s;
}
.hof-see-all:hover { opacity: 1; text-decoration: underline; }

/* Full list view */
.hof-back-link {
  display: inline-block; margin-bottom: 16px; padding: 6px 14px;
  font-family: var(--font-ui); font-size: .75rem; font-weight: 600;
  color: var(--gold); text-decoration: none; letter-spacing: .04em;
  background: rgba(201,168,76,.06); border: 1px solid rgba(201,168,76,.15);
  border-radius: 8px; transition: background .2s, border-color .2s;
}
.hof-back-link:hover { background: rgba(201,168,76,.12); border-color: rgba(201,168,76,.3); }
.hof-full-header {
  display: flex; align-items: center; gap: 14px; margin-bottom: 20px;
}
.hof-full-icon { font-size: 2rem; }
.hof-full-title {
  font-family: var(--font-display); font-size: 1.2rem; color: var(--gold);
  letter-spacing: .08em;
}
.hof-full-month {
  font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted);
  text-transform: capitalize;
}
.hof-full-list {
  display: flex; flex-direction: column; gap: 2px;
  max-width: 600px;
}
.hof-fl-row {
  display: flex; align-items: center; gap: 10px; padding: 8px 12px;
  border-radius: 8px; transition: background .15s;
  background: rgba(201,168,76,.02);
}
.hof-fl-row:hover { background: rgba(201,168,76,.06); }
.hof-fl-top1 { background: rgba(255,215,0,.06); border-left: 3px solid rgba(255,215,0,.4); }
.hof-fl-top2 { background: rgba(192,192,192,.04); border-left: 3px solid rgba(192,192,192,.3); }
.hof-fl-top3 { background: rgba(205,127,50,.04); border-left: 3px solid rgba(205,127,50,.3); }
.hof-fl-rank {
  min-width: 28px; font-family: var(--font-ui); font-size: .75rem;
  font-weight: 700; color: var(--text-muted); text-align: center;
}
.hof-fl-top1 .hof-fl-rank { font-size: 1rem; }
.hof-fl-avatar {
  width: 30px; height: 30px; border-radius: 50%; object-fit: cover;
  border: 1.5px solid rgba(201,168,76,.2); flex-shrink: 0;
}
.hof-fl-top1 .hof-fl-avatar { width: 36px; height: 36px; border-color: rgba(255,215,0,.4); }
.hof-fl-no-avatar {
  display: flex; align-items: center; justify-content: center;
  background: rgba(201,168,76,.08); font-size: .8rem;
}
.hof-fl-name {
  flex: 1; font-family: var(--font-ui); font-size: .8rem; font-weight: 600;
  color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.hof-fl-top1 .hof-fl-name { color: var(--gold); font-size: .85rem; }
.hof-fl-value {
  font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted);
  font-weight: 500; white-space: nowrap;
}
.hof-fl-top1 .hof-fl-value { color: var(--gold); font-weight: 700; }

/* Responsive */
@media (max-width: 900px) {
  .hof-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .hof-grid { grid-template-columns: 1fr; }
  .hof-mvp-card { padding: 14px 16px; }
  .hof-mvp-avatar { width: 44px; height: 44px; }
  .hof-mvp-name { font-size: .95rem; }
  .hof-card { padding: 12px; }
  .hof-podium { gap: 8px; }
  .hof-rank-1 .hof-avatar { width: 38px; height: 38px; }
  .hof-avatar { width: 30px; height: 30px; }
}

/* ═══════════════════════════════════════════
   WIKI SAINT SEIYA
═══════════════════════════════════════════ */
.wiki-controls {
  display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; align-items: center;
}
.wiki-search-wrap { flex: 1; min-width: 200px; }
.wiki-search {
  width: 100%; padding: 10px 16px; border-radius: var(--radius);
  background: var(--night-card); border: 1px solid var(--border);
  color: var(--text); font-family: var(--font-ui); font-size: .9rem;
  transition: border-color var(--transition);
}
.wiki-search:focus { border-color: var(--gold); outline: none; }
.wiki-filters { display: flex; flex-wrap: wrap; gap: 6px; }
.wiki-filter-btn {
  padding: 6px 14px; border-radius: 20px; border: 1px solid var(--border);
  background: transparent; color: var(--text); font-family: var(--font-ui);
  font-size: .8rem; cursor: pointer; transition: all var(--transition);
}
.wiki-filter-btn:hover { border-color: var(--gold); }
.wiki-filter-btn.active { background: var(--gold); color: #000; border-color: var(--gold); font-weight: 600; }
.wiki-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 16px;
}
.wiki-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; cursor: pointer;
  transition: all var(--transition); position: relative;
}
.wiki-card:hover { border-color: var(--gold); transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(201,168,76,0.15);
}
.wiki-card-img-wrap { position: relative; width: 100%; aspect-ratio: 3/4; overflow: hidden; background: var(--night-alt); }
.wiki-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.wiki-card:hover .wiki-card-img { transform: scale(1.05); }
.wiki-card-rank {
  position: absolute; top: 8px; right: 8px; padding: 3px 10px;
  border-radius: 12px; font-size: .7rem; font-weight: 700;
  color: #000; font-family: var(--font-ui); letter-spacing: .04em;
}
.wiki-card-info { padding: 10px 12px; }
.wiki-card-name { font-family: var(--font-display); font-size: .95rem; font-weight: 700; color: var(--text); }
.wiki-card-constellation { font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted); margin-top: 2px; }
.wiki-empty { grid-column: 1/-1; text-align: center; padding: 40px; color: var(--text-muted); font-family: var(--font-ui); }

/* Wiki Detail View */
.wiki-detail { max-width: 800px; margin: 0 auto; }
.wiki-back-btn {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px;
  border-radius: var(--radius); background: transparent; border: 1px solid var(--border);
  color: var(--gold); font-family: var(--font-ui); font-size: .85rem;
  cursor: pointer; transition: all var(--transition); margin-bottom: 20px;
}
.wiki-back-btn:hover { background: var(--gold-subtle); border-color: var(--gold); }
.wiki-detail-header {
  display: flex; gap: 24px; margin-bottom: 24px; align-items: flex-start;
}
.wiki-detail-img-wrap {
  width: 200px; min-width: 200px; aspect-ratio: 3/4; border-radius: var(--radius-lg);
  overflow: hidden; border: 2px solid var(--gold-dim); background: var(--night-alt);
}
.wiki-detail-img { width: 100%; height: 100%; object-fit: cover; }
.wiki-detail-meta { flex: 1; }
.wiki-detail-name {
  font-family: var(--font-display); font-size: 1.6rem; font-weight: 700;
  color: var(--gold); margin: 0 0 8px;
}
.wiki-detail-rank {
  display: inline-block; padding: 4px 14px; border-radius: 14px;
  font-size: .75rem; font-weight: 700; color: #000; margin-bottom: 12px;
  font-family: var(--font-ui);
}
.wiki-detail-row {
  font-family: var(--font-ui); font-size: .85rem; color: var(--text-muted);
  margin-bottom: 6px; line-height: 1.5;
}
.wiki-detail-row strong { color: var(--text); }
.wiki-detail-section { margin-bottom: 20px; }
.wiki-detail-section h4 {
  font-family: var(--font-display); font-size: 1rem; color: var(--gold);
  margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--border);
}
.wiki-attacks-list { display: flex; flex-wrap: wrap; gap: 8px; }
.wiki-attack-tag {
  padding: 5px 14px; border-radius: 20px; background: var(--gold-subtle);
  border: 1px solid var(--gold-dim); color: var(--gold-bright);
  font-family: var(--font-ui); font-size: .8rem; font-weight: 500;
}
.wiki-detail-desc {
  font-family: var(--font-body); font-size: 1rem; line-height: 1.7;
  color: var(--text-muted);
}

@media (max-width: 600px) {
  .wiki-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; }
  .wiki-detail-header { flex-direction: column; align-items: center; text-align: center; }
  .wiki-detail-img-wrap { width: 160px; min-width: 160px; }
  .wiki-detail-name { font-size: 1.3rem; }
  .wiki-attacks-list { justify-content: center; }
}

/* ═══════════════════════════════════════════
   GUIDE SSLOJ
═══════════════════════════════════════════ */
.guide-tabs {
  display: flex; gap: 4px; margin-bottom: 24px; overflow-x: auto;
  border-bottom: 2px solid var(--border); padding-bottom: 0;
}
.guide-tab {
  padding: 10px 20px; border: none; background: transparent;
  color: var(--text-muted); font-family: var(--font-ui); font-size: .85rem;
  cursor: pointer; transition: all var(--transition); position: relative;
  white-space: nowrap; border-bottom: 2px solid transparent; margin-bottom: -2px;
}
.guide-tab:hover { color: var(--text); }
.guide-tab.active { color: var(--gold); border-bottom-color: var(--gold); font-weight: 600; }

/* Tier List */
.guide-tier-row {
  display: flex; margin-bottom: 8px; border-radius: var(--radius);
  overflow: hidden; border: 1px solid var(--border);
}
.guide-tier-label {
  width: 50px; min-width: 50px; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 1.3rem; font-weight: 700;
  color: #000;
}
.guide-tier-content {
  flex: 1; padding: 12px 16px; background: var(--night-card);
}
.guide-tier-chars { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 4px; }
.guide-tier-char {
  padding: 4px 12px; border-radius: 14px; background: var(--night-lift);
  border: 1px solid var(--border); font-family: var(--font-ui); font-size: .8rem;
  color: var(--text);
}
.guide-tier-desc { font-family: var(--font-ui); font-size: .72rem; color: var(--text-dim); margin-top: 4px; }

/* Builds */
.guide-build-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 20px; margin-bottom: 16px;
  transition: border-color var(--transition);
}
.guide-build-card:hover { border-color: var(--gold-dim); }
.guide-build-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.guide-build-name { font-family: var(--font-display); font-size: 1.1rem; color: var(--gold); margin: 0; }
.guide-build-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.guide-build-tag {
  padding: 3px 10px; border-radius: 12px; background: var(--gold-subtle);
  font-family: var(--font-ui); font-size: .7rem; color: var(--gold-bright);
  border: 1px solid var(--gold-dim);
}
.guide-build-chars { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 14px; justify-content: center; }
.guide-build-char {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted);
}
.guide-build-char-img {
  width: 56px; height: 56px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--gold-dim); background: var(--night-alt);
}
.guide-build-desc { font-family: var(--font-body); font-size: .9rem; color: var(--text-muted); line-height: 1.6; margin: 0; }

/* Strategies (Accordion) */
.guide-strategy-card {
  margin-bottom: 8px; border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden;
}
.guide-strategy-header {
  width: 100%; display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border: none; background: var(--night-card);
  color: var(--text); font-family: var(--font-ui); font-size: .9rem;
  cursor: pointer; transition: background var(--transition); text-align: left;
}
.guide-strategy-header:hover { background: var(--night-lift); }
.guide-strategy-num {
  width: 28px; height: 28px; border-radius: 50%; background: var(--gold);
  color: #000; display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .8rem; flex-shrink: 0;
}
.guide-strategy-title { flex: 1; font-weight: 600; }
.guide-strategy-arrow {
  font-size: .7rem; transition: transform var(--transition); color: var(--text-muted);
}
.guide-strategy-card.open .guide-strategy-arrow { transform: rotate(180deg); }
.guide-strategy-body {
  max-height: 0; overflow: hidden; transition: max-height .4s ease, padding .3s ease;
  padding: 0 16px; background: var(--night-alt);
}
.guide-strategy-card.open .guide-strategy-body {
  max-height: 400px; padding: 16px;
}
.guide-strategy-body p {
  font-family: var(--font-body); font-size: .9rem; color: var(--text-muted);
  line-height: 1.7; margin: 0;
}

/* Resources */
.guide-resource-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 18px; margin-bottom: 12px;
}
.guide-resource-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.guide-resource-icon { font-size: 1.4rem; }
.guide-resource-name { font-family: var(--font-display); font-size: 1rem; color: var(--gold); margin: 0; }
.guide-resource-list {
  list-style: none; padding: 0; margin: 0;
}
.guide-resource-list li {
  padding: 6px 0 6px 20px; position: relative;
  font-family: var(--font-ui); font-size: .85rem; color: var(--text-muted);
  border-bottom: 1px solid var(--border);
}
.guide-resource-list li:last-child { border-bottom: none; }
.guide-resource-list li::before {
  content: ''; position: absolute; left: 0; top: 50%;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold); transform: translateY(-50%);
}

@media (max-width: 600px) {
  .guide-tabs { gap: 0; }
  .guide-tab { padding: 8px 12px; font-size: .78rem; }
  .guide-tier-label { width: 36px; min-width: 36px; font-size: 1rem; }
  .guide-build-chars { gap: 10px; }
  .guide-build-char-img { width: 44px; height: 44px; }
}

/* Cosmo canvas handles all ambient effects via JS */

/* ═══════════════════════════════════════════
   LIGHT MODE
═══════════════════════════════════════════ */
[data-mode="light"] {
  --night: #f5f0e8;
  --night-card: #ffffff;
  --night-alt: #f0ebe0;
  --night-lift: #faf7f0;
  --text: #1a1612;
  --text-dim: #6b6155;
  --text-muted: #8a7d6d;
  --gold: #9a7b30;
  --gold-bright: #7a6020;
  --gold-dim: rgba(154,123,48,.3);
  --gold-subtle: rgba(154,123,48,.06);
  --gold-glow: rgba(154,123,48,.12);
  --border: rgba(154,123,48,.15);
  --border-hover: rgba(154,123,48,.3);
  --blue-deep: #e8e0d0;
  --success: #5a8a5a;
  --danger: #b04a3a;
}
[data-mode="light"] .nav {
  background: rgba(245,240,232,.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
[data-mode="light"] .nav.scrolled {
  background: rgba(245,240,232,.98);
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
[data-mode="light"] .nav-logo-text {
  background: linear-gradient(180deg, #8a6a20 0%, #b08830 40%, #9a7b30 70%, #7a6020 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
[data-mode="light"] .nav-drop-menu {
  background: #ffffff;
  border: 1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
[data-mode="light"] .nav-drop-menu a:hover {
  background: rgba(154,123,48,.08);
}
[data-mode="light"] .hero-overlay {
  background: linear-gradient(180deg, rgba(245,240,232,.1) 0%, rgba(245,240,232,.85) 60%, #f5f0e8 100%);
}
[data-mode="light"] .section-badge {
  background: rgba(154,123,48,.08);
  color: #9a7b30;
  border: 1px solid rgba(154,123,48,.2);
}
[data-mode="light"] .section-title {
  color: #1a1612;
}
[data-mode="light"] .news-card,
[data-mode="light"] .thanatos-card,
[data-mode="light"] .member-card {
  background: #ffffff;
  border: 1px solid rgba(154,123,48,.1);
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
[data-mode="light"] .news-card:hover,
[data-mode="light"] .thanatos-card:hover,
[data-mode="light"] .member-card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.08);
  border-color: rgba(154,123,48,.25);
}
[data-mode="light"] .mobile-menu {
  background: rgba(245,240,232,.98);
}
[data-mode="light"] .auth-overlay-inner {
  background: #f5f0e8;
}
[data-mode="light"] .btn-primary {
  background: linear-gradient(135deg, #9a7b30, #b08830);
  color: #ffffff;
}
[data-mode="light"] .site-footer {
  background: #e8e0d0;
  border-top: 1px solid var(--border);
}
[data-mode="light"] .cookie-banner {
  background: #ffffff;
  border: 1px solid var(--border);
  box-shadow: 0 -4px 16px rgba(0,0,0,.08);
}
[data-mode="light"] input,
[data-mode="light"] textarea,
[data-mode="light"] select {
  background: #ffffff;
  border-color: rgba(154,123,48,.2);
  color: #1a1612;
}
[data-mode="light"] .chat-input-wrap {
  background: #ffffff;
  border-color: rgba(154,123,48,.2);
}
[data-mode="light"] .chat-msg {
  background: rgba(154,123,48,.04);
}
[data-mode="light"] .tab-bar,
[data-mode="light"] .mobile-tab-bar {
  background: rgb(245,240,232);
  border-top: 1px solid var(--border);
}
[data-mode="light"] .stat-card {
  background: #ffffff;
  border: 1px solid rgba(154,123,48,.1);
}
[data-mode="light"] .theme-picker {
  background: #ffffff;
  border: 1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
[data-mode="light"] .online-banner {
  background: rgba(154,123,48,.04);
  border-bottom: 1px solid var(--border);
}
[data-mode="light"] .guild-stats {
  background: rgba(154,123,48,.04);
}
[data-mode="light"] .dm-panel {
  background: #f5f0e8;
}
[data-mode="light"] .dm-thread-item {
  background: #ffffff;
  border-color: rgba(154,123,48,.1);
}
[data-mode="light"] .notif-bell-btn,
[data-mode="light"] .dm-nav-btn,
[data-mode="light"] .search-btn,
[data-mode="light"] .nav-icon-btn {
  color: #6b6155;
}
[data-mode="light"] .lang-opt {
  color: #8a7d6d;
}
[data-mode="light"] .lang-opt.active {
  color: #9a7b30;
}

/* Mode toggle button */
.mode-toggle-btn {
  font-size: 14px;
  padding: 4px 6px;
  cursor: pointer;
  transition: transform .3s ease;
}
.mode-toggle-btn:hover {
  transform: scale(1.15);
}

/* ═══════════════════════════════════════════
   FAN ART GALLERY
═══════════════════════════════════════════ */
.fanart-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
  padding: 0 4px;
}
.fanart-sort {
  display: flex;
  gap: 6px;
}
.fanart-sort-btn {
  background: var(--night-card);
  border: 1px solid var(--border);
  color: var(--text-muted);
  padding: 6px 14px;
  border-radius: 20px;
  font-family: var(--font-ui);
  font-size: .8rem;
  cursor: pointer;
  transition: all .25s ease;
}
.fanart-sort-btn:hover {
  border-color: var(--gold-dim);
  color: var(--text);
}
.fanart-sort-btn.active {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--night);
  font-weight: 600;
}
.fanart-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.fanart-tag-btn {
  background: var(--gold-subtle);
  border: 1px solid transparent;
  color: var(--text-dim);
  padding: 4px 10px;
  border-radius: 12px;
  font-family: var(--font-ui);
  font-size: .72rem;
  cursor: pointer;
  text-transform: capitalize;
  transition: all .25s ease;
}
.fanart-tag-btn:hover {
  border-color: var(--gold-dim);
  color: var(--text);
}
.fanart-tag-btn.active {
  background: var(--gold-dim);
  border-color: var(--gold);
  color: var(--text);
  font-weight: 600;
}

/* Masonry grid */
.fanart-masonry {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 900px) {
  .fanart-masonry { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .fanart-masonry { grid-template-columns: repeat(2, 1fr); }
  .fanart-toolbar { flex-direction: column; align-items: flex-start; }
}

.fanart-card {
  background: var(--night-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.fanart-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px var(--gold-glow);
  border-color: var(--border-hover);
}
.fanart-img-wrap {
  cursor: pointer;
  overflow: hidden;
  position: relative;
  aspect-ratio: 1;
}
.fanart-img-wrap img {
  width: 100%; height: 100%;
  display: block;
  transition: transform .4s ease;
  object-fit: cover;
  background: var(--night-alt);
}
.fanart-card:hover .fanart-img-wrap img {
  transform: scale(1.03);
}
.fanart-card-info {
  padding: 10px 12px 12px;
}
.fanart-card-title {
  font-family: var(--font-display);
  font-size: .82rem;
  color: var(--text);
  margin: 0 0 6px;
  line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fanart-card-artist {
  font-family: var(--font-ui);
  font-size: .68rem;
  color: var(--text-muted);
  display: block; margin-bottom: 8px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.fanart-react-row {
  display: flex; gap: 10px; margin-top: 4px;
}
.fanart-react-btn {
  display: flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
  padding: 6px 14px; border-radius: 22px; cursor: pointer;
  font-size: 1.1rem; transition: all .25s ease;
}
.fanart-react-btn span {
  font-family: var(--font-ui); font-size: .72rem; font-weight: 700;
  color: var(--text-muted); min-width: 8px;
}
.fanart-react-btn:hover { border-color: rgba(201,168,76,.35); background: rgba(201,168,76,.08); transform: scale(1.08); }
.fanart-react-btn.active { border-color: rgba(201,168,76,.5); background: rgba(201,168,76,.12); box-shadow: 0 0 8px rgba(201,168,76,.15); }
.fanart-react-btn.active span { color: var(--gold); font-weight: 800; }

/* Lightbox */
.fanart-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,.85);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: fadeIn .25s ease;
}
.fanart-lightbox-inner {
  max-width: 90vw;
  max-height: 90vh;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.fanart-lightbox-inner img {
  max-width: 100%;
  max-height: 75vh;
  border-radius: var(--radius-lg);
  box-shadow: 0 12px 40px rgba(0,0,0,.5);
  object-fit: contain;
}
.fanart-lightbox-close {
  position: absolute;
  top: -12px;
  right: -12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--gold);
  color: var(--night);
  border: none;
  font-size: 1.3rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  transition: transform .2s ease;
}
.fanart-lightbox-close:hover {
  transform: scale(1.1);
}
.fanart-lightbox-info {
  margin-top: 16px;
  text-align: center;
  color: #f5f2ea;
}
.fanart-lightbox-info h3 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  margin: 0 0 4px;
  color: var(--gold-bright, #e8c96d);
}
.fanart-lightbox-info p {
  font-family: var(--font-ui);
  font-size: .85rem;
  color: #cec6ac;
  margin: 0 0 8px;
}
.fanart-source-link {
  color: var(--gold, #c9a84c);
  font-family: var(--font-ui);
  font-size: .8rem;
  text-decoration: none;
  transition: color .2s;
}
.fanart-source-link:hover {
  color: var(--gold-bright, #e8c96d);
  text-decoration: underline;
}

/* ═══════════════════════════════════════════
   RSS NEWS / ACTUALITÉS
═══════════════════════════════════════════ */
.actu-filters {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 0 0 24px;
}
.actu-filter-btn {
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.18);
  color: var(--text-muted);
  padding: 7px 20px;
  border-radius: 20px;
  font-family: var(--font-ui);
  font-size: .8rem;
  cursor: pointer;
  transition: all .25s;
  letter-spacing: .04em;
}
.actu-filter-btn:hover {
  border-color: var(--gold-dim);
  color: var(--gold);
}
.actu-filter-btn.active {
  background: rgba(201,168,76,0.15);
  border-color: var(--gold);
  color: var(--gold);
  font-weight: 600;
}
.actu-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.actu-card {
  display: flex;
  gap: 0;
  background: var(--night-card, #0e1428);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .25s, border-color .25s, box-shadow .25s;
}
.actu-card:hover {
  transform: translateY(-3px);
  border-color: var(--gold);
  box-shadow: 0 8px 24px rgba(201,168,76,0.12);
}
.actu-card-thumb {
  flex: 0 0 120px;
  width: 120px;
  min-height: 120px;
  overflow: hidden;
  background: var(--night-lift, #141c32);
}
.actu-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.actu-card-body {
  flex: 1;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.actu-card-title {
  font-family: var(--font-ui);
  font-size: .88rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.actu-card:hover .actu-card-title {
  color: var(--gold);
}
.actu-card-desc {
  font-family: var(--font-ui);
  font-size: .78rem;
  color: var(--text-muted);
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.actu-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  flex-wrap: wrap;
}
.actu-source-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 600;
  color: #fff;
  letter-spacing: .03em;
  white-space: nowrap;
}
.actu-card-time {
  font-family: var(--font-ui);
  font-size: .72rem;
  color: var(--text-dim);
}
.actu-card-readmore {
  margin-left: auto;
  font-family: var(--font-ui);
  font-size: .75rem;
  color: var(--gold);
  font-weight: 500;
  white-space: nowrap;
}
.actu-loadmore-btn {
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.25);
  color: var(--gold);
  padding: 10px 32px;
  border-radius: 20px;
  font-family: var(--font-ui);
  font-size: .85rem;
  cursor: pointer;
  transition: all .25s;
  letter-spacing: .04em;
}
.actu-loadmore-btn:hover {
  background: rgba(201,168,76,0.18);
  border-color: var(--gold);
}

/* Mobile: 1 column, thumbnail on top */
@media (max-width: 768px) {
  .actu-grid {
    grid-template-columns: 1fr;
  }
  .actu-card {
    flex-direction: column;
  }
  .actu-card-thumb {
    flex: none;
    width: 100%;
    height: 160px;
  }
}

/* ═══════════════════════════════════════════
   TOURNAMENTS
═══════════════════════════════════════════ */
.tournament-card {
  background: var(--night-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 18px 20px; margin-bottom: 14px;
  transition: border-color .2s;
}
.tournament-card:hover { border-color: var(--border-hover); }
.tournament-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px;
}
.tournament-name {
  font-family: var(--font-display); font-size: 1rem; color: var(--gold);
  letter-spacing: .06em; margin: 0;
}
.tournament-status {
  font-family: var(--font-ui); font-size: .72rem; font-weight: 700;
  padding: 4px 12px; border-radius: 12px;
  background: rgba(201,168,76,.08); border: 1px solid rgba(201,168,76,.2); color: var(--gold);
}
.tournament-info {
  display: flex; gap: 16px; font-size: .78rem; color: var(--text-muted);
  margin-bottom: 10px;
}
.tournament-players {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px;
}
.tournament-player {
  font-size: .72rem; padding: 3px 10px; border-radius: 12px;
  background: rgba(201,168,76,.06); border: 1px solid rgba(201,168,76,.12);
  color: var(--text); font-family: var(--font-ui);
}
.tournament-player small { color: var(--text-muted); margin-left: 4px; }
.tournament-join {
  margin-top: 12px; padding: 8px 24px; background: rgba(201,168,76,.12);
  border: 1px solid rgba(201,168,76,.3); border-radius: 10px;
  color: var(--gold); font-weight: 700; font-size: .82rem; cursor: pointer;
  transition: all .2s;
}
.tournament-join:hover { background: rgba(201,168,76,.2); border-color: var(--gold); }

/* ═══════════════════════════════════════════
   RADIO STREAMING
═══════════════════════════════════════════ */
.radio-tabs {
  display: flex; gap: 8px; justify-content: center; margin-bottom: 24px; flex-wrap: wrap;
}
.radio-tab {
  padding: 8px 20px; border: 1px solid rgba(201,168,76,.2); border-radius: 22px;
  background: rgba(201,168,76,.04); color: var(--text-muted); font-family: var(--font-ui);
  font-size: .8rem; font-weight: 600; cursor: pointer; transition: all .2s;
}
.radio-tab:hover { border-color: rgba(201,168,76,.4); color: var(--text); }
.radio-tab.active { background: rgba(201,168,76,.15); border-color: var(--gold); color: var(--gold); }

.radio-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px; max-width: 1000px; margin: 0 auto;
}
.radio-card {
  display: flex; align-items: center; gap: 10px;
  background: rgba(201,168,76,.03); border: 1px solid rgba(201,168,76,.1);
  border-radius: 10px; padding: 12px 14px;
  cursor: pointer; transition: all .2s;
}
.radio-card:hover {
  border-color: rgba(201,168,76,.35); background: rgba(201,168,76,.07);
  transform: translateY(-1px);
}
.radio-card.playing {
  border-color: rgba(46,204,113,.5); background: rgba(46,204,113,.06);
  box-shadow: 0 0 12px rgba(46,204,113,.15);
}
.radio-card-flag { font-size: 1.2rem; flex-shrink: 0; }
.radio-card-name {
  flex: 1; font-family: var(--font-ui); font-size: .8rem; font-weight: 700;
  color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.radio-card.popular { border-color: rgba(201,168,76,.25); }
.radio-card.popular .radio-card-name { color: var(--gold); }
.radio-card-play {
  font-size: 1rem; flex-shrink: 0; opacity: .5; transition: opacity .2s;
}
.radio-card:hover .radio-card-play { opacity: 1; }
.radio-card.playing .radio-card-play { opacity: 1; color: #2ecc71; }

/* Player bar */
#radio-player-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  background: linear-gradient(135deg, rgba(46,204,113,.08), rgba(46,204,113,.03));
  border: 1px solid rgba(46,204,113,.2); border-radius: 12px;
  padding: 12px 18px; margin-bottom: 20px; flex-wrap: wrap;
}
.radio-bar-info { display: flex; align-items: center; gap: 10px; }
.radio-bar-flag { font-size: 1.1rem; }
.radio-bar-name { font-family: var(--font-ui); font-size: .88rem; font-weight: 700; color: var(--text); }
.radio-bar-live {
  font-size: .6rem; font-weight: 700; color: #2ecc71; letter-spacing: .08em;
  animation: radioLivePulse 2s ease-in-out infinite;
}
.radio-bar-now {
  font-family: var(--font-ui); font-size: .78rem; color: var(--text);
  font-style: italic; opacity: .85; max-width: 300px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
@keyframes radioLivePulse { 0%,100% { opacity: 1; } 50% { opacity: .4; } }
.radio-bar-controls { display: flex; align-items: center; gap: 12px; }
.radio-volume {
  width: 100px; height: 4px; -webkit-appearance: none; appearance: none;
  background: rgba(255,255,255,.15); border-radius: 2px; outline: none;
}
.radio-volume::-webkit-slider-thumb {
  -webkit-appearance: none; width: 14px; height: 14px; border-radius: 50%;
  background: var(--gold); cursor: pointer;
}
.radio-bar-stop {
  padding: 6px 16px; background: rgba(231,76,60,.08); border: 1px solid rgba(231,76,60,.25);
  border-radius: 8px; color: #e74c3c; font-family: var(--font-ui);
  font-size: .75rem; font-weight: 700; cursor: pointer; transition: all .2s;
}
.radio-bar-stop:hover { background: rgba(231,76,60,.15); border-color: rgba(231,76,60,.4); }

@media (max-width: 600px) {
  .radio-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .radio-card { padding: 10px; }
  .radio-card-name { font-size: .72rem; }
  .radio-volume { width: 70px; }
}

/* ═══════════════════════════════════════════
   TOURNAMENT BRACKET
═══════════════════════════════════════════ */
.bracket-wrap {
  overflow-x: auto; padding: 20px 0;
}
.bracket {
  display: flex !important; flex-direction: row !important; align-items: center; gap: 0; min-width: 700px;
  font-family: var(--font-ui); font-size: .75rem;
}
.bracket-round {
  display: flex !important; flex-direction: column !important; justify-content: space-around;
  position: relative; flex-shrink: 0;
}
.bracket-round-title {
  text-align: center; font-size: .65rem; font-weight: 700; color: var(--gold);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px;
}
.bracket-match {
  display: flex; flex-direction: column; margin: 12px 0; position: relative;
  min-width: 150px; max-width: 180px;
}
.bracket-slot {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 12px; background: var(--night-card); border: 1px solid var(--border);
  min-height: 30px; position: relative; transition: all .2s;
}
.bracket-slot:first-child { border-radius: var(--radius) var(--radius) 0 0; border-bottom: 1px solid rgba(201,168,76,0.08); }
.bracket-slot:last-child { border-radius: 0 0 var(--radius) var(--radius); }
.bracket-slot.winner { background: rgba(201,168,76,0.12); border-color: var(--gold-dim); }
.bracket-slot.winner .bracket-name { color: var(--gold); font-weight: 700; }
.bracket-slot.loser .bracket-name { color: var(--text-dim); text-decoration: line-through; opacity: 0.6; }
.bracket-seed { color: var(--text-dim); font-size: .6rem; min-width: 16px; }
.bracket-name { flex: 1; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bracket-score { color: var(--gold); font-weight: 700; font-size: .7rem; min-width: 16px; text-align: right; }
.bracket-empty { color: var(--text-dim); font-style: italic; opacity: 0.5; }

/* Connector lines */
.bracket-connector {
  width: 30px; display: flex; flex-direction: column; align-items: center;
  position: relative; align-self: stretch; flex-shrink: 0;
}
.bracket-connector::before {
  content: ''; position: absolute; top: 25%; bottom: 25%;
  left: 0; width: 15px; border: 1px solid var(--gold-dim);
  border-left: none; border-radius: 0 8px 8px 0;
}
.bracket-connector::after {
  content: ''; position: absolute; top: 50%;
  left: 15px; width: 15px; height: 1px;
  background: var(--gold-dim);
}

/* Special: final match */
.bracket-match.final { min-width: 160px; }
.bracket-match.final .bracket-slot { border-color: var(--gold-dim); }
.bracket-match.final .bracket-slot:first-child { border-top: 2px solid var(--gold); }

/* Petite finale */
.bracket-petite {
  margin-top: 20px; padding-top: 16px;
  border-top: 1px dashed var(--border);
}
.bracket-petite .bracket-round-title { color: #cd7f32; }
.bracket-petite .bracket-slot { border-color: rgba(205,127,50,0.3); }

/* ═══ PODIUM ═══ */
.podium-wrap {
  display: flex; justify-content: center; align-items: flex-end;
  gap: 4px; margin-top: 24px; padding: 20px 0 0;
}
.podium-place {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; transition: transform .3s;
}
.podium-place:hover { transform: translateY(-4px); }
.podium-avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--night-card); border: 2px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; margin-bottom: 6px; overflow: hidden;
}
.podium-avatar img { width: 100%; height: 100%; object-fit: cover; }
.podium-name {
  font-size: .72rem; font-weight: 600; color: var(--text);
  max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.podium-medal { font-size: 1.3rem; margin-bottom: 2px; }
.podium-bar {
  width: 80px; border-radius: var(--radius) var(--radius) 0 0;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 8px; margin-top: 4px;
}
.podium-place:nth-child(1) .podium-bar { /* 2nd place - left */
  height: 80px; background: linear-gradient(180deg, rgba(192,192,192,0.25), rgba(192,192,192,0.08));
  border: 1px solid rgba(192,192,192,0.3); border-bottom: none;
}
.podium-place:nth-child(2) .podium-bar { /* 1st place - center */
  height: 110px; background: linear-gradient(180deg, rgba(201,168,76,0.3), rgba(201,168,76,0.08));
  border: 1px solid rgba(201,168,76,0.4); border-bottom: none;
}
.podium-place:nth-child(3) .podium-bar { /* 3rd place - right */
  height: 60px; background: linear-gradient(180deg, rgba(205,127,50,0.25), rgba(205,127,50,0.08));
  border: 1px solid rgba(205,127,50,0.3); border-bottom: none;
}
.podium-place:nth-child(1) .podium-avatar { border-color: silver; }
.podium-place:nth-child(2) .podium-avatar { border-color: var(--gold); width: 56px; height: 56px; }
.podium-place:nth-child(3) .podium-avatar { border-color: #cd7f32; }
.podium-rank { font-size: .65rem; color: var(--text-dim); font-weight: 700; }

@media (max-width: 600px) {
  .bracket { min-width: 500px; font-size: .65rem; }
  .bracket-match { min-width: 100px; }
  .bracket-slot { padding: 4px 6px; }
  .podium-bar { width: 60px; }
}

