/* ═══════════════════════════════════════════════════════════════
   ZORTHORN — Design System
   Competitive Identity Platform for Mobile Gaming
   Valorant aesthetic: Red · Black · Silver · Gold
═══════════════════════════════════════════════════════════════ */

/* ── Design Tokens (single source of truth) ── */
:root {
  /* Backgrounds */
  --bg0:        #0f1117;
  --bg1:        #13151c;
  --bg2:        #1a1d27;
  --bg3:        #0c0d12;
  --bg4: #141420;
  --bg5: #1a1a26;
  --bg6: #202030;
  --bg-alt:     #161921;
  --steel:      #13151c;
  --steel-hi:   rgba(255,255,255,0.04);
  --steel-border: rgba(255,255,255,0.07);
  --steel-edge:   rgba(255,255,255,0.14);
  --rivet:        rgba(255,255,255,0.18);

  /* Brand red */
  --red:        #ff4655;
  --red-lt:     #ff6a76;
  --red-dk:     #7a0010;
  --red-dark:   #c02030;
  --red-bg:     rgba(184,24,32,0.10);
  --red-border: rgba(255,70,85,0.28);
  --red-glow:   rgba(255,70,85,0.40);

  /* Gold / brass */
  --brass:      #c89b3c;
  --brass-lt:   #e8b84c;
  --brass-dim:    #7a5c00;
  --brass-bg:     rgba(201,154,18,0.10);
  --brass-border: rgba(201,154,18,0.26);
  --brass-glow:   rgba(201,154,18,0.40);

  /* Amber */
  --amber:        #d48400;
  --amber-lt:     #f0a020;
  --amber-dk:     #8a5200;
  --amber-bg:     rgba(212,132,0,0.10);
  --amber-border: rgba(212,132,0,0.24);
  --amber-glow:   rgba(212,132,0,0.40);

  /* Text */
  --text:       #ece8e1;
  --text-2:     #9da6b3;
  --text-3:     #6e7a8a;
  --text-4:     #4e5a6a;

  /* Borders / lines */
  --line:       rgba(255,255,255,0.06);
  --line-md:    rgba(255,255,255,0.10);
  --line-hi: rgba(255,255,255,0.15);

  /* Neutral */
  --neutral:        #8a92b0;
  --neutral-lt:     #b0bcd4;
  --neutral-dk:     #484e60;
  --neutral-dim:    rgba(138,146,176,0.12);
  --neutral-bg:     rgba(136,144,168,0.07);
  --neutral-border: rgba(138,146,176,0.18);
  --neutral-glow:   rgba(138,146,176,0.22);

  /* Rarity tiers */
  --r-common:        #8890a8;
  --r-common-bg:     rgba(136,144,168,0.08);
  --r-common-border: rgba(136,144,168,0.18);
  --r-rare:        #4488ee;
  --r-rare-bg:     rgba(68,136,238,0.09);
  --r-rare-border: rgba(68,136,238,0.25);
  --r-rare-glow:   rgba(68,136,238,0.35);
  --r-epic:        #9955ee;
  --r-epic-bg:     rgba(153,85,238,0.09);
  --r-epic-border: rgba(153,85,238,0.26);
  --r-epic-glow:   rgba(153,85,238,0.38);
  --r-legendary:   #e8b420;
  --r-leg-bg:      rgba(232,180,32,0.09);
  --r-leg-border:  rgba(232,180,32,0.28);
  --r-leg-glow:    rgba(232,180,32,0.42);

  /* Game-specific accents */
  --streak:        #ff6b35;
  --streak-lt:     #ff8a5c;
  --streak-bg:     rgba(255,107,53,0.10);
  --streak-border: rgba(255,107,53,0.28);
  --streak-glow:   rgba(255,107,53,0.36);
  --speed:        #ffe01b;
  --speed-lt:     #fff07a;
  --speed-bg:     rgba(255,224,27,0.08);
  --speed-border: rgba(255,224,27,0.20);
  --nvg:        #00e676;
  --nvg-bg:     rgba(0,230,118,0.08);
  --nvg-border: rgba(0,230,118,0.20);
  --nvg-glow:   rgba(0,230,118,0.28);
  --intel:        #4488ee;
  --intel-bg:     rgba(68,136,238,0.09);
  --intel-border: rgba(68,136,238,0.22);
  --intel-glow:   rgba(68,136,238,0.28);

  /* XP */
  --xp:        var(--intel);
  --xp-bg:     var(--intel-bg);
  --xp-border: var(--intel-border);

  /* Misc accents */
  --discord-color: #7289da;

  /* Typography */
  --ff-display: 'Barlow Condensed', sans-serif;
  --ff-body: 'Inter', 'Barlow', sans-serif;

  /* Motion */
  --ease:    cubic-bezier(0.16, 1, 0.3, 1);
  --t:      0.18s;
  --t-med:  0.32s;

  /* Layout */
  --section-py: clamp(52px, 7vw, 88px);
  --wrap-max:   1200px;

}


/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg0);
  color: var(--text);
  font-family: var(--ff-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, select, input, textarea { font-family: inherit; font-size: inherit; border: none; outline: none; background: none; color: inherit; }
button { cursor: pointer; }

/* ── Subtle grain overlay ── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 160px 160px;
  opacity: 0.022;
  mix-blend-mode: overlay;
}

/* ── Layout ── */
.wrap { max-width: var(--wrap-max); margin: 0 auto; padding: 0 clamp(20px, 5vw, 48px); }

/* ══════════════════════════════════════
   SECTION KICKERS
══════════════════════════════════════ */
.section-kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--ff-display); font-size: 10px; font-weight: 800;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--red-lt);
  margin-bottom: 14px;
}
.section-kicker::before {
  content: '▶';
  font-size: 7px; color: var(--brass-lt); opacity: 0.9;
}
.section-kicker::after {
  content: '';
  display: block; width: 28px; height: 1px;
  background: linear-gradient(90deg, var(--red), transparent);
}

/* ── Section headings ── */
.section-h2 {
  font-family: var(--ff-display); font-size: clamp(36px, 5.5vw, 64px);
  font-weight: 900; line-height: 0.96; letter-spacing: 0.01em; color: var(--text);
  text-transform: uppercase;
}
.section-h2 span {
  background: linear-gradient(90deg, var(--red-lt), var(--brass-lt));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.section-h2 em { font-style: italic; }
.center-h2 { text-align: center; }
.section-desc { max-width: 520px; color: var(--text-2); font-size: 17px; line-height: 1.65; margin-top: 12px; }

/* ── Gradient text ── */
@keyframes brandGradient {
  0%  { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100%{ background-position: 0% 50%; }
}
.grad-text {
  background: linear-gradient(90deg, var(--amber), var(--brass), var(--red), var(--amber));
  background-size: 300% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: brandGradient 5s ease infinite;
}

/* ── Buttons ── */
.btn-red {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--red);
  color: #fff; font-family: var(--ff-display); font-size: 14px; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; padding: 14px 28px;
  border-radius: 2px;
  border: 1px solid var(--red-border);
  box-shadow: 0 4px 24px var(--red-glow), inset 0 1px 0 rgba(255,255,255,0.10);
  border-top: 3px solid var(--amber);
  transition: transform var(--t) var(--ease), box-shadow var(--t), filter var(--t), background var(--t);
  position: relative; overflow: hidden;
}
.btn-red::after {
  content: '';
  position: absolute; top: 0; left: -100%; right: 100%; bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  transition: left 0.4s ease, right 0.4s ease;
}
.btn-red:hover { background: var(--red-lt); transform: translateY(-2px); box-shadow: 0 8px 36px var(--red-glow); }
.btn-red:hover::after { left: 0; right: -100%; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--steel); color: var(--text-2);
  font-family: var(--ff-display); font-size: 14px; font-weight: 700;
  letter-spacing: 0.10em; text-transform: uppercase; padding: 14px 24px;
  border: 1px solid var(--steel-border); border-radius: 2px;
  transition: color var(--t), background var(--t), border-color var(--t), box-shadow var(--t);
}
.btn-ghost:hover { color: var(--text); background: var(--steel-hi); border-color: var(--neutral-border); box-shadow: 0 0 18px var(--neutral-glow); }

.btn-nav {
  display: inline-flex; align-items: center;
  background: var(--red); color: #fff; font-family: var(--ff-display); font-size: 12px;
  font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 9px 18px; border-radius: 2px; white-space: nowrap;
  border-top: 2px solid var(--amber);
  box-shadow: 0 2px 12px var(--red-glow);
  transition: background var(--t), box-shadow var(--t), transform var(--t);
}
.btn-nav:hover { background: var(--red-lt); box-shadow: 0 4px 20px var(--red-glow); transform: translateY(-1px); }

.btn-speed {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, var(--speed), #c9a800);
  color: #0a0800; font-family: var(--ff-display); font-size: 14px; font-weight: 800;
  letter-spacing: 0.10em; text-transform: uppercase; padding: 14px 28px; border-radius: 2px;
  border-top: 2px solid rgba(255,255,255,0.25);
  box-shadow: 0 4px 24px rgba(255,224,27,0.22);
  transition: transform var(--t) var(--ease), box-shadow var(--t), filter var(--t);
}
.btn-speed:hover { transform: translateY(-2px); box-shadow: 0 8px 36px rgba(255,224,27,0.38); filter: brightness(1.08); }
.full-btn { width: 100%; justify-content: center; }

/* ── Reveal animation ── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.55s var(--ease), transform 0.55s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ── Keyframes ── */
@keyframes dotPulse    { 0%,100%{opacity:1;box-shadow:0 0 5px var(--red)} 50%{opacity:0.4;box-shadow:0 0 16px var(--red)} }
@keyframes nvgPulse    { 0%,100%{opacity:1;box-shadow:0 0 5px var(--nvg)} 50%{opacity:0.5;box-shadow:0 0 12px var(--nvg)} }
@keyframes scrollBounce{ 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }
@keyframes stripScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes floatCard   { 0%,100%{transform:translateY(0) rotate(-1deg)} 50%{transform:translateY(-8px) rotate(0.5deg)} }
@keyframes ringPulse   { 0%,100%{opacity:1;box-shadow:0 0 0 rgba(204,26,26,0)} 50%{opacity:0.7;box-shadow:0 0 14px var(--red-glow)} }
@keyframes glowBorder  { 0%,100%{border-color:var(--amber-border);box-shadow:0 0 10px var(--amber-glow)} 50%{border-color:var(--red-border);box-shadow:0 0 18px var(--red-glow)} }

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  background: transparent; border-bottom: 1px solid transparent;
  transition: background var(--t-med), border-color var(--t-med);
}
.nav.scrolled {
  background: rgba(6,6,6,0.94);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid var(--neutral-border);
}
.nav.scrolled::after {
  content: '';
  position: absolute; bottom: -1px; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
  opacity: 0.5;
}
.nav-inner {
  max-width: var(--wrap-max); margin: 0 auto; padding: 0 clamp(20px,5vw,48px);
  height: 64px; display: flex; align-items: center; gap: 32px;
}
.nav-brand { display: flex; align-items: center; flex-shrink: 0; }
.nav-logo { height: 30px; width: auto; filter: invert(1) brightness(1.1); }
.nav-wordmark {
  font-family: var(--ff-display); font-size: 22px; font-weight: 900; letter-spacing: 0.14em;
  color: var(--text); text-transform: uppercase;
  text-shadow: 0 0 20px rgba(255,255,255,0.06);
}
.nav-links { display: flex; align-items: center; gap: 28px; margin-left: auto; }
.nav-links a {
  font-family: var(--ff-display); font-size: 12px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-3); transition: color var(--t);
  position: relative;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0; right: 0; height: 2px;
  background: var(--red); transform: scaleX(0); transition: transform var(--t) var(--ease);
}
.nav-links a:hover { color: var(--text-2); }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-links a.active { color: var(--red-lt); text-shadow: 0 0 10px var(--red-glow); }
.nav-links a.active::after { transform: scaleX(1); background: var(--red); }
.nav-burger { display: none; flex-direction: column; gap: 5px; padding: 8px; margin-left: auto; }
.nav-burger span { display: block; width: 22px; height: 2px; background: var(--text); transition: transform var(--t), opacity var(--t); }
.nav-mobile { display: none; flex-direction: column; background: rgba(6,6,6,0.97); border-top: 1px solid var(--neutral-border); padding: 16px clamp(20px,5vw,48px); gap: 4px; }
.nav-mobile.open { display: flex; }
.nav-mobile a { font-family: var(--ff-display); font-size: 14px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-3); padding: 10px 0; border-bottom: 1px solid var(--line); transition: color var(--t); }
.nav-mobile a:hover { color: var(--red-lt); }
.mobile-cta-link { color: var(--amber-lt) !important; border-bottom: none !important; margin-top: 8px; }

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; pointer-events: none; }

/* Glow effects */
.hero-glow-1 {
  position: absolute; top: -10%; right: 5%;
  width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(204,26,26,0.12) 0%, rgba(201,149,10,0.06) 35%, transparent 70%);
}
.hero-glow-2 {
  position: absolute; bottom: -15%; left: -8%;
  width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(68,136,238,0.05) 0%, rgba(204,26,26,0.03) 50%, transparent 75%);
}

/* Premium grid overlay */
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at 70% 35%, rgba(0,0,0,0.5) 15%, transparent 65%);
  -webkit-mask-image: radial-gradient(ellipse at 70% 35%, rgba(0,0,0,0.5) 15%, transparent 65%);
}

/* Bottom fade */
.hero-fade {
  position: absolute; bottom: 0; left: 0; right: 0; height: 28%;
  background: linear-gradient(to top, var(--bg0) 0%, transparent 100%);
  pointer-events: none;
}

/* Hero wrap */
.hero-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px);
  align-items: center; padding-top: 80px; padding-bottom: 60px; width: 100%; position: relative; z-index: 3;
}

/* Hero pill */
.hero-pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(204,26,26,0.08);
  border: 1px solid var(--red-border);
  border-left: 3px solid var(--red);
  border-radius: 1px;
  padding: 6px 14px; font-family: var(--ff-display); font-size: 11px; font-weight: 800;
  letter-spacing: 0.20em; text-transform: uppercase; color: var(--red-lt); margin-bottom: 24px;
}
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--red); box-shadow: 0 0 8px var(--red); animation: dotPulse 1.6s ease-in-out infinite; }

/* Hero heading */
.hero-h1 {
  font-family: var(--ff-display); font-size: clamp(58px, 8vw, 108px); font-weight: 900;
  line-height: 0.90; letter-spacing: 0.01em; color: var(--text); margin-bottom: 16px;
  text-transform: uppercase;
  text-shadow: 2px 2px 0 rgba(0,0,0,0.6), 0 0 40px rgba(0,0,0,0.4);
}
.hero-h1 em {
  font-style: italic;
  background: linear-gradient(90deg, var(--amber-lt), var(--brass-lt), var(--amber-lt));
  background-size: 300% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: brandGradient 4s ease infinite;
}

.hero-tagline {
  font-family: var(--ff-display); font-size: clamp(12px, 1.4vw, 15px);
  font-weight: 800; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 20px;
}
.hero-tagline em { color: var(--amber-lt); font-style: normal; }

.hero-desc { max-width: 480px; color: var(--text-2); font-size: 17px; line-height: 1.65; margin-bottom: 32px; }
.hero-cta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.hero-cta-note { font-size: 12px; color: var(--text-4); margin-top: 4px; display: flex; align-items: center; gap: 6px; margin-bottom: 32px; }
.hero-cta-note a { color: var(--amber-lt); text-decoration: underline; text-underline-offset: 2px; transition: color var(--t); }
.hero-cta-note a:hover { color: var(--brass-lt); }

/* Launch row */
.hero-launch-row { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.hli-item { display: flex; align-items: center; gap: 12px; }
.hli-icon {
  width: 36px; height: 36px; border-radius: 2px;
  background: var(--steel); border: 1px solid var(--neutral-border);
  display: flex; align-items: center; justify-content: center; color: var(--neutral); flex-shrink: 0;
}
.hli-title { font-family: var(--ff-display); font-size: 13px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text); }
.hli-sub { font-size: 11px; color: var(--text-3); margin-top: 2px; letter-spacing: 0.04em; }
.hli-div { width: 1px; height: 32px; background: var(--line-hi); }

/* ── Hero right — identity card ── */
.hero-right { position: relative; display: flex; justify-content: center; align-items: center; }
.identity-card-showcase { position: relative; width: 100%; max-width: 440px; }

.identity-card {
  background: rgba(10,10,12,0.92);
  border: 1px solid var(--steel-border);
  border-top: 3px solid var(--red);
  border-radius: 2px; padding: 24px; position: relative; z-index: 2;
  box-shadow: 0 24px 64px rgba(0,0,0,0.85), 4px 4px 0 rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.04);
}
.identity-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--red), var(--amber), var(--brass));
}
.identity-card::after {
  content: '';
  position: absolute; top: 10px; right: 10px;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--rivet); box-shadow: -14px 0 0 var(--rivet);
}
.ic-header { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.ic-avatar {
  position: relative; width: 48px; height: 48px; border-radius: 2px;
  background: linear-gradient(135deg, var(--red-dk), var(--brass-dim));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: 22px; font-weight: 900; color: #fff; flex-shrink: 0;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 0 100%);
}
.ic-avatar-ring { position: absolute; inset: -3px; border-radius: 3px; border: 2px solid var(--red); animation: ringPulse 2s ease-in-out infinite; }
.ic-name { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; }
.ic-verified { display: flex; align-items: center; gap: 4px; font-size: 10px; color: var(--text-3); margin-top: 3px; letter-spacing: 0.06em; text-transform: uppercase; }
.ic-verified svg { color: var(--nvg); }
.ic-rank-pip { margin-left: auto; font-size: 20px; }
.diamond-pip-sm { color: var(--intel); text-shadow: 0 0 12px var(--intel-glow); }
.ic-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border-radius: 1px; overflow: hidden; margin-bottom: 18px; }
.ic-stat { background: rgba(255,255,255,0.02); padding: 12px 6px; display: flex; flex-direction: column; align-items: center; gap: 4px; }
.ic-stat-val { font-family: var(--ff-display); font-size: 18px; font-weight: 900; color: var(--text); }
.ic-stat-label { font-size: 9px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; }
.ic-progress-wrap { margin-bottom: 16px; }
.ic-progress-label { display: flex; justify-content: space-between; font-size: 10px; color: var(--text-3); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.08em; }
.ic-progress-label span { color: var(--brass-lt); }
.ic-bar { height: 5px; background: var(--bg5); border-radius: 1px; overflow: hidden; }
.ic-bar-fill { height: 100%; background: linear-gradient(90deg, var(--red), var(--brass)); border-radius: 1px; box-shadow: 0 0 8px var(--red-glow); }
.ic-badges-row { display: flex; gap: 8px; margin-bottom: 16px; }
.ic-badge { width: 32px; height: 32px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.gold-badge-ic { background: var(--brass-bg); border: 1px solid var(--brass-border); }
.speed-badge-ic { background: var(--speed-bg); border: 1px solid var(--speed-border); }
.integrity-badge-ic { background: var(--nvg-bg); border: 1px solid var(--nvg-border); }
.founder-badge-ic { background: var(--amber-bg); border: 1px solid var(--amber-border); }
.more-badge { background: var(--steel); border: 1px solid var(--line-md); font-size: 11px; font-weight: 700; color: var(--text-3); }
.ic-recent-label { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: 8px; }
.ic-recent-match { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-2); padding: 5px 0; border-bottom: 1px solid var(--line); }
.ic-recent-match:last-child { border-bottom: none; }
.ic-game-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.bgmi-dot { background: var(--red); }
.speed-dot { background: var(--speed); }
.ic-match-name { flex: 1; }
.win-tag { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.10em; color: var(--nvg); background: var(--nvg-bg); padding: 2px 6px; border-radius: 1px; }
.ic-match-time { font-size: 11px; color: var(--text-4); }

/* Floating cards */
.fc-float {
  position: absolute; z-index: 3; border-radius: 2px; padding: 14px 16px;
  background: rgba(8,8,10,0.96);
  box-shadow: 0 12px 40px rgba(0,0,0,0.9), 2px 2px 0 rgba(0,0,0,0.5);
  animation: floatCard 5s ease-in-out infinite;
}
.fc-rank-card { border: 1px solid var(--brass-border); border-top: 2px solid var(--brass); top: -28px; left: -36px; animation-delay: -1s; box-shadow: 0 8px 32px rgba(0,0,0,0.8), 0 0 16px var(--brass-glow); }
.fc-label { font-size: 9px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--text-4); margin-bottom: 4px; }
.fc-rank-badge { font-family: var(--ff-display); font-size: 15px; font-weight: 800; margin-bottom: 2px; text-transform: uppercase; }
.diamond-rank { color: var(--intel); }
.fc-pts { font-size: 12px; color: var(--text-2); }
.fc-change { font-size: 11px; margin-top: 2px; }
.fc-change.up { color: var(--nvg); }
.fc-match-card { border: 1px solid var(--steel-border); border-top: 2px solid var(--red); bottom: -20px; right: -24px; min-width: 190px; animation-delay: -2.5s; }
.fc-match-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.fc-game-pill { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.10em; padding: 2px 8px; border-radius: 1px; text-transform: uppercase; }
.bgmi-pill { background: var(--red-bg); border: 1px solid var(--red-border); color: var(--red-lt); }
.fc-live-tag { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.14em; color: var(--red); animation: dotPulse 1.2s ease-in-out infinite; text-transform: uppercase; }
.fc-match-score { display: flex; align-items: center; gap: 10px; }
.fc-team { font-size: 11px; color: var(--text-2); }
.fc-team strong { color: var(--nvg); font-family: var(--ff-display); font-size: 11px; letter-spacing: 0.08em; }
.fc-team.opp-team strong { color: var(--red-lt); }
.fc-score-vs { font-family: var(--ff-display); font-size: 18px; font-weight: 900; color: var(--text); white-space: nowrap; }
.hero-orb { position: absolute; bottom: -80px; right: -80px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, rgba(204,26,26,0.06) 0%, transparent 70%); pointer-events: none; z-index: 1; }
.hero-scroll { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); color: var(--text-3); animation: scrollBounce 2s ease-in-out infinite; transition: color var(--t); }
.hero-scroll:hover { color: var(--red-lt); }

/* ══════════════════════════════════════
   BRAND STRIP
══════════════════════════════════════ */
.brand-strip {
  background: var(--bg1);
  border-top: 1px solid var(--neutral-border); border-bottom: 1px solid var(--neutral-border);
  overflow: hidden; padding: 12px 0; position: relative;
}
.brand-strip::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
  opacity: 0.45;
}
.strip-track { display: flex; gap: 32px; white-space: nowrap; animation: stripScroll 28s linear infinite; width: max-content; }
.strip-track span { font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-3); }
.strip-track b { color: var(--red); font-size: 8px; opacity: 0.7; }

/* ══════════════════════════════════════
   SECTION DIVIDER LINE
══════════════════════════════════════ */
.section-divider {
  width: 100%; overflow: hidden; line-height: 0;
  position: relative; z-index: 5;
  background: var(--bg0);
  padding: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--neutral-border), transparent);
  margin: 0;
}

/* ══════════════════════════════════════
   COMPETITIVE IDENTITY™
══════════════════════════════════════ */
.ci-section { padding: var(--section-py) 0; background: var(--bg0); position: relative; }
.ci-header { text-align: center; margin-bottom: 60px; }
.ci-header .section-kicker { justify-content: center; }
.ci-header .section-desc { margin: 12px auto 0; }
.ci-showcase { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 60px); align-items: start; }

.ci-profile-full {
  background: rgba(10,10,12,0.90);
  border: 1px solid var(--steel-border); border-top: 3px solid var(--red);
  border-radius: 2px; padding: 28px; position: relative; overflow: hidden;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.04);
}
.ci-profile-full::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--red), var(--amber), var(--brass)); }
.ci-profile-full::after { content: ''; position: absolute; top: 10px; right: 10px; width: 5px; height: 5px; border-radius: 50%; background: var(--rivet); box-shadow: -14px 0 0 var(--rivet), 0 14px 0 var(--rivet), -14px 14px 0 var(--rivet); }
.cpf-top { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 24px; }
.cpf-avatar { position: relative; width: 60px; height: 60px; border-radius: 2px; background: linear-gradient(135deg, var(--red-dk), var(--brass-dim)); display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 26px; font-weight: 900; color: #fff; flex-shrink: 0; clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 0 100%); }
.cpf-avatar-glow { position: absolute; inset: -3px; border-radius: 3px; border: 2px solid var(--red); animation: ringPulse 2.4s ease-in-out infinite; }
.cpf-name { font-family: var(--ff-display); font-size: 19px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.cpf-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.cpf-tag { display: inline-flex; align-items: center; gap: 4px; font-size: 9px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; padding: 3px 8px; border-radius: 1px; }
.verified-tag { background: var(--nvg-bg); color: var(--nvg); border: 1px solid var(--nvg-border); }
.founder-tag { background: var(--amber-bg); color: var(--amber-lt); border: 1px solid var(--amber-border); }
.integrity-tag { background: var(--intel-bg); color: var(--intel); border: 1px solid var(--intel-border); }
.cpf-rank { margin-left: auto; text-align: right; }
.cpf-rank-badge { font-family: var(--ff-display); font-size: 14px; font-weight: 900; color: var(--intel); text-transform: uppercase; letter-spacing: 0.06em; }
.cpf-rank-pts { font-size: 11px; color: var(--text-3); margin-top: 3px; }
.cpf-stats-row { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; background: var(--line); border-radius: 1px; overflow: hidden; margin-bottom: 20px; }
.cpf-stat { background: rgba(255,255,255,0.02); padding: 11px 6px; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.cpf-stat strong { font-family: var(--ff-display); font-size: 17px; font-weight: 900; color: var(--text); }
.cpf-stat span { font-size: 9px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; text-align: center; }
.cpf-progress-section { margin-bottom: 20px; }
.cpf-prog-label { display: flex; justify-content: space-between; font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.10em; margin-bottom: 8px; }
.cpf-prog-label span { color: var(--brass-lt); }
.cpf-prog-bar { height: 6px; background: var(--bg5); border-radius: 1px; overflow: hidden; }
.cpf-prog-fill { height: 100%; background: linear-gradient(90deg, var(--red), var(--brass)); box-shadow: 0 0 8px var(--red-glow); }
.cpf-badges-section { margin-bottom: 20px; }
.cpf-badges-label { font-size: 9px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--text-4); margin-bottom: 12px; }
.cpf-badges-row { display: flex; gap: 10px; flex-wrap: wrap; }
.cpf-badge { width: 64px; background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; padding: 10px 6px; display: flex; flex-direction: column; align-items: center; gap: 6px; transition: border-color var(--t), transform var(--t), box-shadow var(--t); }
.cpf-badge:hover { transform: translateY(-2px); }
.cb-name { font-size: 9px; text-align: center; color: var(--text-3); letter-spacing: 0.05em; line-height: 1.3; text-transform: uppercase; }
.gold-b { border-color: var(--brass-border); background: var(--brass-bg); }
.gold-b:hover { border-color: var(--brass); box-shadow: 0 4px 16px var(--brass-glow); }
.speed-b { border-color: var(--speed-border); background: var(--speed-bg); }
.speed-b:hover { border-color: var(--speed); }
.integrity-b { border-color: var(--nvg-border); background: var(--nvg-bg); }
.integrity-b:hover { border-color: var(--nvg); box-shadow: 0 4px 16px var(--nvg-glow); }
.founder-b { border-color: var(--amber-border); background: var(--amber-bg); }
.founder-b:hover { border-color: var(--amber); box-shadow: 0 4px 16px var(--amber-glow); }
.top100-b { border-color: var(--intel-border); background: var(--intel-bg); }
.top100-b:hover { border-color: var(--intel); box-shadow: 0 4px 16px var(--intel-glow); }
.season-b { border-color: var(--red-border); background: var(--red-bg); }
.season-b:hover { border-color: var(--red); box-shadow: 0 4px 16px var(--red-glow); }
.cpf-history-label { font-size: 9px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--text-4); margin-bottom: 10px; }
.cpf-match { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 12px; }
.cpf-match:last-child { border-bottom: none; }
.cpf-match-game { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.10em; padding: 2px 7px; border-radius: 1px; flex-shrink: 0; text-transform: uppercase; }
.bgmi-game { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.speed-game { background: var(--speed-bg); color: var(--speed); border: 1px solid var(--speed-border); }
.ff-game { background: rgba(255,140,0,0.09); color: #ffaa40; border: 1px solid rgba(255,140,0,0.20); }
.cpf-match-name { flex: 1; color: var(--text-2); }
.cpf-match-result { font-family: var(--ff-display); font-size: 10px; font-weight: 900; letter-spacing: 0.10em; text-transform: uppercase; }
.win-result { color: var(--nvg); }
.cpf-match-pts { font-family: var(--ff-display); font-size: 12px; font-weight: 700; }
.gold-pts { color: var(--brass-lt); }
.cpf-match-time { font-size: 11px; color: var(--text-4); flex-shrink: 0; }
.ci-pillars { display: flex; flex-direction: column; gap: 14px; }
.ci-pillar { background: var(--steel); border: 1px solid var(--steel-border); border-left: 3px solid transparent; border-radius: 1px; padding: 20px 20px 20px 18px; transition: border-color var(--t), transform var(--t), box-shadow var(--t); position: relative; }
.ci-pillar:hover { border-left-color: var(--red); border-color: var(--red-border); transform: translateX(5px); box-shadow: -4px 0 18px rgba(204,26,26,0.10); }
.ci-pillar-icon { width: 38px; height: 38px; border-radius: 2px; background: var(--red-bg); border: 1px solid var(--red-border); display: flex; align-items: center; justify-content: center; color: var(--red-lt); margin-bottom: 12px; }
.ci-pillar h3 { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 6px; }
.ci-pillar p { font-size: 13px; color: var(--text-2); line-height: 1.55; }

/* ══════════════════════════════════════
   HOW IT WORKS
══════════════════════════════════════ */
.hiw { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.hiw::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red-border), transparent); }
.hiw-header { text-align: center; margin-bottom: 56px; position: relative; z-index: 1; }
.hiw-header .section-kicker { justify-content: center; }
.hiw-sub { max-width: 480px; margin: 12px auto 0; color: var(--text-2); font-size: 17px; line-height: 1.6; text-align: center; }
.hiw-steps { display: flex; align-items: flex-start; justify-content: center; flex-wrap: wrap; position: relative; z-index: 1; }
.hiw-step { flex: 1; min-width: 150px; max-width: 200px; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px; padding: 26px 14px; background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; transition: border-color var(--t), transform var(--t), box-shadow var(--t); }
.hiw-step:hover { border-color: var(--neutral-border); transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.5), 0 0 16px var(--neutral-glow); }
.hiw-step-final { border-color: var(--amber-border); border-top: 2px solid var(--amber); background: linear-gradient(145deg, rgba(224,136,0,0.06), var(--steel)); animation: glowBorder 3s ease-in-out infinite; }
.hiw-step-final:hover { transform: translateY(-4px); }
.hiw-num { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.20em; color: var(--text-4); text-transform: uppercase; }
.hiw-num-final { color: var(--amber); }
.hiw-icon { width: 48px; height: 48px; border-radius: 2px; background: var(--steel); border: 1px solid var(--steel-border); display: flex; align-items: center; justify-content: center; color: var(--text-2); }
.hiw-icon-final { background: var(--amber-bg); border-color: var(--amber-border); color: var(--amber); box-shadow: 0 0 18px var(--amber-glow); }
.hiw-step h3 { font-family: var(--ff-display); font-size: 14px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; }
.hiw-step p { font-size: 12px; color: var(--text-3); line-height: 1.5; }
.hiw-arrow { display: flex; align-items: center; padding: 0 4px; color: var(--neutral-dk); align-self: center; flex-shrink: 0; }

/* ══════════════════════════════════════
   RANKINGS
══════════════════════════════════════ */
.rankings { padding: var(--section-py) 0; background: var(--bg0); }
.rankings-header { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; margin-bottom: 40px; flex-wrap: wrap; }
.rankings-tabs { display: flex; gap: 4px; margin-bottom: 24px; background: var(--steel); padding: 4px; border-radius: 2px; width: fit-content; border: 1px solid var(--steel-border); }
.rtab { font-family: var(--ff-display); font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; padding: 8px 20px; border-radius: 2px; color: var(--text-3); transition: background var(--t), color var(--t); display: flex; align-items: center; gap: 6px; }
.rtab:hover { color: var(--text-2); }
.rtab.active { background: rgba(255,255,255,0.07); color: var(--text); }
.speed-rtab.active { color: var(--speed); }
.rankings-panel { display: none; }
.rankings-panel.active { display: block; }
.lb-table { background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; overflow: hidden; display: flex; flex-direction: column; }
.lb-thead { display: grid; grid-template-columns: 56px 1fr 120px 80px 80px 80px; padding: 10px 16px; font-size: 9px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); background: rgba(255,255,255,0.02); }
.lb-row { display: grid; grid-template-columns: 56px 1fr 120px 80px 80px 80px; padding: 12px 16px; border-top: 1px solid var(--line); align-items: center; transition: background var(--t); }
.lb-row:hover { background: rgba(204,26,26,0.04); }
.lb-featured { background: rgba(255,255,255,0.02); }
.lb-you-row { display: grid; grid-template-columns: 56px 1fr 120px 80px 80px 80px; padding: 12px 16px; background: rgba(204,26,26,0.07); border: 1px solid var(--red-border); border-radius: 2px; align-items: center; margin-top: 8px; box-shadow: 0 0 16px var(--red-glow); }
.lb-pos { font-family: var(--ff-display); font-size: 14px; font-weight: 900; color: var(--text-3); }
.gold-pos { color: var(--brass-lt); text-shadow: 0 0 10px var(--brass-glow); }
.silver-pos { color: #c8c4b8; }
.bronze-pos { color: #c07832; }
.you-pos { color: var(--red-lt); text-shadow: 0 0 10px var(--red-glow); }
.lb-player { display: flex; align-items: center; gap: 10px; font-family: var(--ff-display); font-size: 14px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; }
.lb-av { width: 28px; height: 28px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 12px; font-weight: 800; color: var(--text); border: 1px solid var(--line-md); flex-shrink: 0; }
.you-av { background: var(--red-bg); border-color: var(--red-border); color: var(--red-lt); }
.you-player { color: var(--red-lt); }
.lb-team { font-size: 12px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.04em; }
.lb-score { font-family: var(--ff-display); font-size: 14px; font-weight: 800; }
.you-score { color: var(--red-lt); }
.speed-score { color: var(--speed); }
.lb-wl { font-size: 12px; color: var(--text-3); }
.lb-change { font-size: 12px; font-weight: 800; }
.up { color: var(--nvg); }
.down { color: var(--red-lt); }
.neutral { color: var(--text-3); }
.lb-divisions { margin-top: 32px; padding-top: 28px; border-top: 1px solid var(--line); }
.div-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.div-item { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-2); font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.div-pip { width: 10px; height: 10px; border-radius: 2px; }
.bronze-d { background: #c07832; }
.silver-d { background: #c8c4b8; }
.gold-d { background: var(--brass); box-shadow: 0 0 6px var(--brass-glow); }
.plat-d { background: #88ccc0; }
.diamond-d { background: var(--intel); box-shadow: 0 0 6px var(--intel-glow); }
.champ-d { background: linear-gradient(135deg, var(--amber), var(--red)); box-shadow: 0 0 8px var(--amber-glow); }
.div-arrow { color: var(--text-4); font-size: 13px; }
.champion-div { font-weight: 700; }
.champion-div span { background: linear-gradient(90deg, var(--amber), var(--red)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.speed-lb-intro { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--speed); background: var(--speed-bg); border: 1px solid var(--speed-border); border-radius: 2px; padding: 10px 14px; margin-bottom: 16px; font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }

/* ══════════════════════════════════════
   SPEED ARENA™
══════════════════════════════════════ */
.speed-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.speed-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--speed), transparent); }
.speed-bg-el { position: absolute; top: -20%; left: -10%; width: 60vw; height: 60vw; max-width: 600px; max-height: 600px; background: radial-gradient(ellipse, rgba(255,224,27,0.04) 0%, transparent 70%); pointer-events: none; }
.speed-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: center; }
.speed-eyebrow { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--speed); margin-bottom: 20px; }
.speed-h2 { font-family: var(--ff-display); font-size: clamp(40px, 6vw, 72px); font-weight: 900; line-height: 0.95; letter-spacing: 0.01em; text-transform: uppercase; color: var(--text); margin-bottom: 24px; }
.speed-h2 em { font-style: italic; color: var(--speed); text-shadow: 0 0 28px rgba(255,224,27,0.3); }
.speed-desc { color: var(--text-2); font-size: 17px; line-height: 1.65; margin-bottom: 32px; }
.speed-features { display: flex; flex-direction: column; gap: 18px; margin-bottom: 36px; }
.sf-item { display: flex; align-items: flex-start; gap: 14px; }
.sf-item svg { flex-shrink: 0; color: var(--speed); margin-top: 2px; }
.sf-item > div { display: flex; flex-direction: column; gap: 2px; }
.sf-item strong { font-family: var(--ff-display); font-size: 14px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text); }
.sf-item span { font-size: 13px; color: var(--text-3); }
.speed-ui { background: rgba(8,8,10,0.90); border: 1px solid var(--speed-border); border-top: 3px solid var(--speed); border-radius: 2px; overflow: hidden; box-shadow: 0 24px 64px rgba(0,0,0,0.7); }
.sui-header { background: rgba(255,224,27,0.03); border-bottom: 1px solid var(--speed-border); padding: 12px 18px; display: flex; align-items: center; gap: 8px; font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--speed); }
.sui-live { margin-left: auto; font-size: 9px; letter-spacing: 0.14em; color: var(--red); animation: dotPulse 1.2s ease-in-out infinite; text-transform: uppercase; }
.sui-score-display { padding: 28px 18px 20px; text-align: center; border-bottom: 1px solid var(--line); }
.sui-score-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--text-4); margin-bottom: 8px; font-family: var(--ff-display); font-weight: 800; }
.sui-score-num { font-family: var(--ff-display); font-size: 44px; font-weight: 900; color: var(--speed); letter-spacing: -0.02em; line-height: 1; text-shadow: 0 0 40px rgba(255,224,27,0.5); margin-bottom: 8px; }
.sui-rank-indicator { display: inline-flex; align-items: center; gap: 5px; background: var(--speed-bg); border: 1px solid var(--speed-border); border-radius: 2px; padding: 4px 12px; font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.10em; color: var(--speed); text-transform: uppercase; }
.sui-leaderboard { padding: 14px 18px; border-bottom: 1px solid var(--line); }
.sui-lb-header { font-size: 9px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--text-4); margin-bottom: 10px; font-family: var(--ff-display); font-weight: 800; }
.sui-lb-row { display: flex; align-items: center; gap: 10px; padding: 7px 0; border-bottom: 1px solid var(--line); }
.sui-lb-row:last-child { border-bottom: none; }
.you-row-speed { background: rgba(255,224,27,0.04); margin: 0 -18px; padding: 7px 18px; }
.sui-r { font-family: var(--ff-display); font-size: 12px; font-weight: 900; width: 28px; color: var(--text-3); }
.gold-r { color: var(--brass-lt); }
.sui-n { flex: 1; font-size: 13px; color: var(--text-2); font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
.sui-s { font-family: var(--ff-display); font-size: 13px; font-weight: 800; }
.you-row-speed .sui-s { color: var(--speed); }
.sui-change { font-size: 11px; width: 16px; text-align: center; }
.up-s { color: var(--nvg); }
.down-s { color: var(--red); }
.sui-reward { padding: 12px 18px; display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--brass-lt); background: var(--brass-bg); border-top: 1px solid var(--brass-border); font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }

/* ══════════════════════════════════════
   COMPETITIONS / CHAMPIONSHIPS
══════════════════════════════════════ */
.competitions { padding: var(--section-py) 0; background: var(--bg0); }
.comp-header { text-align: center; margin-bottom: 48px; }
.comp-header .section-kicker { justify-content: center; }
.concept-label-inline { margin-bottom: 16px; }
.concept-label-bar { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-4); background: var(--steel); border: 1px solid var(--line); padding: 4px 12px; border-radius: 1px; }
.comp-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 20px; }
.comp-card { background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; padding: 26px; display: flex; flex-direction: column; gap: 18px; transition: border-color var(--t), transform var(--t), box-shadow var(--t); position: relative; }
.comp-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.6); }
.featured-comp { border-color: var(--red-border); border-top: 3px solid var(--red); background: linear-gradient(145deg, rgba(204,26,26,0.06), var(--steel)); }
.featured-comp:hover { border-color: var(--red); box-shadow: 0 16px 40px rgba(0,0,0,0.6), 0 0 24px var(--red-glow); }
.daily-card:hover { border-color: var(--neutral-border); }
.monthly-card:hover { border-color: var(--brass-border); }
.cc-featured-badge { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.20em; text-transform: uppercase; color: var(--red-lt); background: var(--red-bg); border: 1px solid var(--red-border); padding: 3px 10px; border-radius: 1px; position: absolute; top: -1px; right: 20px; }
.cc-header { display: flex; justify-content: space-between; align-items: center; }
.cc-format-tag { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; padding: 3px 9px; border-radius: 1px; }
.daily-tag { background: var(--neutral-bg); color: var(--neutral-lt); border: 1px solid var(--neutral-border); }
.weekly-tag { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.monthly-tag { background: var(--brass-bg); color: var(--brass-lt); border: 1px solid var(--brass-border); }
.cc-live-badge { display: flex; align-items: center; gap: 5px; font-size: 10px; color: var(--nvg); font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; }
.live-dot-sm { width: 6px; height: 6px; border-radius: 50%; background: var(--nvg); }
.cc-title { font-family: var(--ff-display); font-size: 18px; font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text); margin-bottom: 4px; }
.cc-game { font-size: 12px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; }
.cc-details { display: flex; flex-direction: column; gap: 8px; }
.cc-detail { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--text-3); }
.cc-detail strong { color: var(--text); font-weight: 700; }
.free-tag { color: var(--nvg); }
.red-prize { color: var(--red-lt); }
.cc-fill-label { display: flex; justify-content: space-between; font-size: 10px; color: var(--text-3); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.08em; }
.cc-fill-label span { color: var(--brass-lt); }
.cc-fill-bar { height: 4px; background: var(--bg5); border-radius: 1px; overflow: hidden; }
.cc-fill-prog { height: 100%; background: linear-gradient(90deg, var(--red), var(--brass)); }
.cc-countdown { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--amber-lt); font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.btn-comp { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--steel); color: var(--text-2); font-family: var(--ff-display); font-size: 12px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; padding: 11px 20px; border: 1px solid var(--steel-border); border-radius: 2px; transition: background var(--t), color var(--t), border-color var(--t); margin-top: auto; }
.btn-comp:hover { color: var(--text); background: var(--steel-hi); border-color: var(--neutral-border); }
.btn-comp-red { background: var(--red); color: #fff; border-color: var(--red-border); box-shadow: 0 4px 16px var(--red-glow); }
.btn-comp-red:hover { background: var(--red-lt); color: #fff; box-shadow: 0 6px 24px var(--red-glow); }
.btn-comp-outline { background: transparent; color: var(--brass-lt); border-color: var(--brass-border); }
.btn-comp-outline:hover { background: var(--brass-bg); color: var(--brass-lt); }
.comp-note { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-4); }

/* ══════════════════════════════════════
   GAMES
══════════════════════════════════════ */
.games-section { padding: var(--section-py) 0; background: var(--bg1); }
.games-header { text-align: center; margin-bottom: 40px; }
.games-header .section-kicker { justify-content: center; }
.games-season-label { margin-bottom: 20px; }
.gsl-tag { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.20em; text-transform: uppercase; padding: 4px 12px; border-radius: 1px; }
.active-gsl { color: var(--nvg); background: var(--nvg-bg); border: 1px solid var(--nvg-border); }
.upcoming-gsl { color: var(--text-3); background: var(--steel); border: 1px solid var(--steel-border); }
.games-grid { display: grid; gap: 16px; }
.s1-grid { grid-template-columns: 2fr 1fr; }
.p2-grid { grid-template-columns: repeat(3, 1fr); }
.game-card { background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; overflow: hidden; transition: border-color var(--t), transform var(--t), box-shadow var(--t); }
.game-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,0.6); }
.gc-featured { border-color: var(--red-border); }
.gc-featured:hover { border-color: var(--red); box-shadow: 0 12px 32px rgba(0,0,0,0.6), 0 0 20px var(--red-glow); }
.gc-speed-card:hover { border-color: var(--speed-border); box-shadow: 0 12px 32px rgba(0,0,0,0.6), 0 0 20px rgba(255,224,27,0.15); }
.gc-upcoming { opacity: 0.55; }
.gc-upcoming:hover { opacity: 0.75; }
.gc-bg { position: relative; height: 80px; overflow: hidden; display: flex; align-items: center; justify-content: flex-end; padding: 0 16px; }
.gc-bgmi { background: linear-gradient(135deg, rgba(204,26,26,0.2) 0%, rgba(10,10,12,0.95) 100%); }
.gc-split { background: linear-gradient(135deg, rgba(255,224,27,0.12) 0%, rgba(10,10,12,0.95) 100%); }
.gc-ff { background: linear-gradient(135deg, rgba(255,140,0,0.15) 0%, rgba(10,10,12,0.95) 100%); }
.gc-cod { background: linear-gradient(135deg, rgba(68,136,238,0.15) 0%, rgba(10,10,12,0.95) 100%); }
.gc-name-bg { font-family: var(--ff-display); font-size: 52px; font-weight: 900; color: rgba(255,255,255,0.04); letter-spacing: -0.02em; text-transform: uppercase; }
.speed-game-tag { position: absolute; top: 10px; left: 12px; display: flex; align-items: center; gap: 4px; font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--speed); background: rgba(255,224,27,0.08); border: 1px solid var(--speed-border); padding: 3px 8px; border-radius: 1px; }
.gc-body { padding: 16px; }
.gc-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
.gc-title { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text); }
.gc-sub { font-size: 11px; color: var(--text-3); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.06em; }
.gc-badge { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; padding: 3px 8px; border-radius: 1px; flex-shrink: 0; }
.gc-featured-badge { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.gc-speed-badge { background: var(--speed-bg); color: var(--speed); border: 1px solid var(--speed-border); }
.gc-upcoming-badge { background: var(--steel); color: var(--text-3); border: 1px solid var(--steel-border); }
.gc-tags-row { display: flex; gap: 6px; flex-wrap: wrap; }
.gc-tag { font-size: 10px; color: var(--text-3); background: rgba(255,255,255,0.03); border: 1px solid var(--line); padding: 2px 8px; border-radius: 1px; text-transform: uppercase; letter-spacing: 0.06em; }
.gc-more-card { display: flex; align-items: center; justify-content: center; min-height: 120px; border-style: dashed; }
.gc-more-body { display: flex; flex-direction: column; align-items: center; gap: 10px; color: var(--text-3); }
.gc-more-text { font-size: 12px; color: var(--text-3); text-align: center; line-height: 1.4; }
.phase2-note { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-4); margin-bottom: 14px; }

/* ══════════════════════════════════════
   INTEGRITY+
══════════════════════════════════════ */
.integrity { padding: var(--section-py) 0; background: var(--bg0); }
.int-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.int-desc { color: var(--text-2); font-size: 17px; line-height: 1.65; margin: 20px 0 28px; max-width: 460px; }
.int-manifesto { border-left: 3px solid var(--red); padding-left: 20px; margin-bottom: 28px; }
.int-manifesto p { font-size: 14px; color: var(--text-2); line-height: 1.65; font-style: italic; margin-bottom: 10px; }
.int-manifesto p:last-child { margin-bottom: 0; }
.int-badge-row { display: flex; flex-direction: column; gap: 12px; }
.int-badge { display: flex; align-items: flex-start; gap: 16px; background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; padding: 18px; }
.int-badge-icon { font-size: 24px; flex-shrink: 0; }
.int-badge-title { font-family: var(--ff-display); font-size: 14px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 4px; }
.int-badge-sub { font-size: 12px; color: var(--text-3); line-height: 1.5; }
.int-pillars { display: flex; flex-direction: column; gap: 16px; }
.int-pillar { display: flex; align-items: flex-start; gap: 16px; background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; padding: 20px; transition: border-color var(--t), transform var(--t); }
.int-pillar:hover { border-color: var(--neutral-border); transform: translateX(4px); }
.int-pillar-icon { width: 40px; height: 40px; border-radius: 2px; background: var(--steel-hi); border: 1px solid var(--steel-edge); display: flex; align-items: center; justify-content: center; color: var(--text-2); flex-shrink: 0; }
.int-pillar h3 { font-family: var(--ff-display); font-size: 15px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 6px; }
.int-pillar p { font-size: 13px; color: var(--text-2); line-height: 1.55; }

/* ══════════════════════════════════════
   ROADMAP
══════════════════════════════════════ */
.roadmap { padding: var(--section-py) 0; background: var(--bg1); }
.rm-intro { text-align: center; margin-bottom: 56px; }
.rm-intro .section-kicker { justify-content: center; }
.rm-sub { max-width: 480px; margin: 12px auto 24px; color: var(--text-2); font-size: 17px; line-height: 1.6; }
.rm-layer-legend { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
.layer-pill { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; padding: 4px 12px; border-radius: 1px; }
.launch-pill { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.vision-pill { background: var(--steel); color: var(--text-3); border: 1px solid var(--steel-border); }
.rm-timeline { display: flex; flex-direction: column; gap: 0; position: relative; }
.rm-timeline::before { content: ''; position: absolute; left: 36px; top: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, var(--red-border), var(--line), transparent); }
.rm-item { display: grid; grid-template-columns: 72px 1fr; gap: 32px; padding: 0 0 48px; position: relative; z-index: 1; }
.rm-item:last-child { padding-bottom: 0; }
.rm-marker { width: 44px; height: 44px; border-radius: 2px; background: var(--steel); border: 1px solid var(--steel-border); display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 11px; font-weight: 900; letter-spacing: 0.06em; color: var(--text-3); text-transform: uppercase; flex-shrink: 0; }
.active-marker { background: var(--red-bg); border-color: var(--red-border); color: var(--red-lt); box-shadow: 0 0 16px var(--red-glow); }
.vision-marker { background: var(--steel-hi); border-color: var(--steel-edge); color: var(--text-3); border-style: dashed; }
.rm-content { padding-top: 8px; }
.layer-tag { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; padding: 2px 8px; border-radius: 1px; display: inline-flex; margin-bottom: 10px; }
.launch-tag { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.vision-tag { background: var(--steel); color: var(--text-3); border: 1px solid var(--steel-border); }
.rm-active .rm-content h3 { color: var(--text); }
.rm-future .rm-content h3 { color: var(--text-2); }
.rm-content h3 { font-family: var(--ff-display); font-size: 20px; font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 10px; }
.rm-content p { font-size: 14px; color: var(--text-2); line-height: 1.65; margin-bottom: 14px; }
.rm-features { display: flex; gap: 8px; flex-wrap: wrap; }
.rm-features span { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; background: var(--steel); border: 1px solid var(--steel-border); padding: 4px 10px; border-radius: 1px; color: var(--text-3); }

/* ══════════════════════════════════════
   ABOUT / FOUNDER
══════════════════════════════════════ */
.founder { padding: var(--section-py) 0; background: var(--bg0); }
.founder-inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(48px, 7vw, 100px); align-items: center; }
.founder-quote { font-family: var(--ff-display); font-size: clamp(18px, 2.4vw, 26px); font-weight: 800; line-height: 1.3; letter-spacing: 0.02em; color: var(--text); text-transform: uppercase; border-left: 4px solid var(--red); padding-left: 24px; margin-bottom: 28px; }
.founder-paras { margin-bottom: 32px; display: flex; flex-direction: column; gap: 12px; }
.founder-para { font-size: 15px; color: var(--text-2); line-height: 1.65; }
.founder-sig { display: flex; align-items: center; gap: 16px; }
.founder-sig-avatar { width: 48px; height: 48px; border-radius: 2px; background: var(--red-bg); border: 2px solid var(--red-border); display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 20px; font-weight: 900; color: var(--red-lt); flex-shrink: 0; }
.founder-name { font-family: var(--ff-display); font-size: 15px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; }
.founder-title { font-size: 11px; color: var(--text-3); margin-top: 3px; letter-spacing: 0.06em; text-transform: uppercase; }

/* ══════════════════════════════════════
   APPLY
══════════════════════════════════════ */
.apply { padding: var(--section-py) 0; background: var(--bg1); }
.apply-tracks-header { text-align: center; margin-bottom: 48px; }
.apply-tracks-header .section-kicker { justify-content: center; }
.apply-sub { max-width: 520px; margin: 12px auto 28px; color: var(--text-2); font-size: 16px; line-height: 1.65; }
.track-switcher { display: inline-flex; gap: 4px; background: var(--steel); padding: 4px; border-radius: 2px; border: 1px solid var(--steel-border); }
.tsw { font-family: var(--ff-display); font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; padding: 8px 20px; border-radius: 2px; color: var(--text-3); transition: background var(--t), color var(--t); display: flex; align-items: center; gap: 6px; }
.tsw:hover { color: var(--text-2); }
.tsw.active { background: rgba(255,255,255,0.07); color: var(--text); }
.apply-panel { display: none; }
.apply-panel.active { display: block; }
.apply-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 64px); align-items: start; }
.ap-kicker { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.24em; text-transform: uppercase; color: var(--red-lt); margin-bottom: 14px; }
.org-kicker { color: var(--amber-lt); }
.ap-h3 { font-family: var(--ff-display); font-size: clamp(24px, 3.5vw, 36px); font-weight: 900; text-transform: uppercase; line-height: 1.0; margin-bottom: 16px; letter-spacing: 0.02em; }
.ap-h3 span { background: linear-gradient(90deg, var(--red-lt), var(--brass-lt)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.speed-span { background: linear-gradient(90deg, var(--speed), var(--amber-lt)) !important; -webkit-background-clip: text !important; -webkit-text-fill-color: transparent !important; background-clip: text !important; }
.ap-desc { font-size: 15px; color: var(--text-2); line-height: 1.65; margin-bottom: 28px; }
.ap-perks { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; }
.ap-perk { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--text-2); }
.ap-perk svg { flex-shrink: 0; color: var(--nvg); margin-top: 2px; }
.ap-slots-note { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-4); }
.ap-slots-note svg { flex-shrink: 0; color: var(--text-4); }
.apply-card { background: rgba(10,10,12,0.90); border: 1px solid var(--steel-border); border-top: 3px solid var(--red); border-radius: 2px; padding: 28px; box-shadow: 0 24px 64px rgba(0,0,0,0.7); }
.org-card { border-top-color: var(--amber); }
.acard-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 24px; }
.acard-title { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; }
.acard-sub { font-size: 11px; color: var(--text-3); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.08em; }
.acard-form { display: flex; flex-direction: column; gap: 16px; }
.fg { display: flex; flex-direction: column; gap: 6px; }
.fg label { font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.10em; font-weight: 700; }
.fg input, .fg select { background: var(--bg3); border: 1px solid var(--line-md); border-radius: 2px; padding: 11px 14px; color: var(--text); font-size: 14px; transition: border-color var(--t), box-shadow var(--t); }
.fg input::placeholder { color: var(--text-4); }
.fg input:focus, .fg select:focus { border-color: var(--red-border); box-shadow: 0 0 0 3px rgba(204,26,26,0.10); outline: none; }
.fg select { cursor: pointer; }
.fg select option { background: var(--bg3); }
.field-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-note { font-size: 11px; color: var(--text-4); text-align: center; margin-top: 4px; }
.apply-success { display: none; flex-direction: column; align-items: center; text-align: center; gap: 12px; padding: 32px 0; }
.apply-success.show { display: flex; }
.as-check { width: 48px; height: 48px; border-radius: 50%; background: var(--nvg-bg); border: 2px solid var(--nvg); display: flex; align-items: center; justify-content: center; color: var(--nvg); }
.apply-success strong { font-family: var(--ff-display); font-size: 20px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.06em; }
.apply-success p { font-size: 13px; color: var(--text-2); }

/* ══════════════════════════════════════
   CTA STRIP
══════════════════════════════════════ */
.cta-strip { display: flex; align-items: center; justify-content: space-between; gap: 32px; background: var(--steel); border: 1px solid var(--red-border); border-left: 4px solid var(--red); border-radius: 2px; padding: 24px 28px; flex-wrap: wrap; }
.cta-strip-text { font-size: 15px; color: var(--text-2); line-height: 1.5; }
.cta-strip-text strong { color: var(--text); }
.cta-strip-actions { display: flex; gap: 12px; flex-shrink: 0; flex-wrap: wrap; }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.footer { background: var(--bg0); border-top: 1px solid var(--neutral-border); padding: clamp(48px, 7vw, 80px) 0 40px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.footer-brand-col { display: flex; flex-direction: column; gap: 16px; }
.footer-logo { height: 28px; filter: invert(1) brightness(0.7); }
.footer-wm { font-family: var(--ff-display); font-size: 20px; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-2); }
.footer-desc { font-size: 13px; color: var(--text-3); line-height: 1.65; max-width: 260px; }
.footer-socials { display: flex; gap: 8px; }
.fsoc { width: 32px; height: 32px; border-radius: 2px; background: var(--steel); border: 1px solid var(--steel-border); display: flex; align-items: center; justify-content: center; color: var(--text-3); transition: color var(--t), border-color var(--t), background var(--t); }
.fsoc:hover { color: var(--text); border-color: var(--neutral-border); background: var(--steel-hi); }
.footer-col { display: flex; flex-direction: column; gap: 12px; }
.footer-col h5 { font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.20em; text-transform: uppercase; color: var(--text-3); margin-bottom: 4px; }
.footer-col a { font-size: 13px; color: var(--text-3); transition: color var(--t); }
.footer-col a:hover { color: var(--text); }
.footer-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-top: 24px; border-top: 1px solid var(--line); font-size: 11px; color: var(--text-4); flex-wrap: wrap; }
.footer-cat { font-family: var(--ff-display); font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--red); }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 900px) {
  .hero-wrap { grid-template-columns: 1fr; }
  .hero-right { display: none; }
  .ci-showcase { grid-template-columns: 1fr; }
  .speed-layout { grid-template-columns: 1fr; }
  .int-layout { grid-template-columns: 1fr; }
  .founder-inner { grid-template-columns: 1fr; }
  .apply-split { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .comp-cards { grid-template-columns: 1fr; }
  .s1-grid { grid-template-columns: 1fr; }
  .p2-grid { grid-template-columns: repeat(2, 1fr); }
  .hiw-steps { gap: 4px; }
  .hiw-arrow { display: none; }
  .lb-thead, .lb-row, .lb-you-row { grid-template-columns: 40px 1fr 60px 60px; }
  .lb-thead > div:nth-child(3),
  .lb-row > div:nth-child(3),
  .lb-you-row > div:nth-child(3) { display: none; }
  .lb-thead > div:nth-child(5),
  .lb-row > div:nth-child(5),
  .lb-you-row > div:nth-child(5) { display: none; }
}

@media (max-width: 600px) {
  .nav-links { display: none; }
  .nav-burger { display: flex; }
  .btn-nav { display: none; }
  .hero-h1 { font-size: clamp(52px, 14vw, 72px); }
  .footer-grid { grid-template-columns: 1fr; }
  .track-switcher { width: 100%; }
  .tsw { flex: 1; justify-content: center; }
  .field-row2 { grid-template-columns: 1fr; }
  .cpf-stats-row { grid-template-columns: repeat(3, 1fr); }
  .rm-item { grid-template-columns: 52px 1fr; gap: 16px; }
  .rm-timeline::before { left: 25px; }
  .cta-strip { flex-direction: column; align-items: flex-start; }
  .p2-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   XP / LEVEL DISPLAY — on identity card
══════════════════════════════════════ */
.ic-xp-row {
  margin-bottom: 14px;
}
.ic-xp-top {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 5px;
}
.ic-level-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--ff-display); font-size: 11px; font-weight: 900;
  letter-spacing: 0.10em; text-transform: uppercase;
  background: var(--intel-bg); border: 1px solid var(--intel-border);
  color: var(--intel); padding: 3px 8px; border-radius: 1px;
}
.ic-xp-label { font-size: 10px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.10em; }
.ic-xp-pts { font-family: var(--ff-display); font-size: 10px; font-weight: 800; color: var(--intel); }
.ic-xp-bar { height: 4px; background: var(--bg5); border-radius: 1px; overflow: hidden; }
.ic-xp-fill { height: 100%; background: linear-gradient(90deg, var(--intel), #88aaff); border-radius: 1px; box-shadow: 0 0 8px rgba(68,136,238,0.5); }

.ic-streak {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--ff-display); font-size: 11px; font-weight: 900;
  letter-spacing: 0.08em; text-transform: uppercase;
  background: var(--streak-bg); border: 1px solid var(--streak-border);
  color: var(--streak-lt); padding: 3px 9px; border-radius: 1px;
  box-shadow: 0 0 10px var(--streak-glow);
}

/* ══════════════════════════════════════
   LIVE STATS BAR
══════════════════════════════════════ */
.live-stats-bar {
  background: var(--bg1);
  border-bottom: 1px solid var(--neutral-border);
  padding: 0;
  position: relative; overflow: hidden;
}
.live-stats-bar::before {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--red-border), var(--brass-border), transparent);
}
.lsb-inner {
  max-width: var(--wrap-max); margin: 0 auto; padding: 0 clamp(20px,5vw,48px);
  display: grid; grid-template-columns: repeat(4, 1fr);
  divide-color: var(--line);
}
.lsb-stat {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 0; border-right: 1px solid var(--line);
  position: relative;
}
.lsb-stat:last-child { border-right: none; }
.lsb-stat + .lsb-stat { padding-left: clamp(16px, 3vw, 32px); }
.lsb-icon {
  width: 36px; height: 36px; border-radius: 2px;
  background: var(--steel); border: 1px solid var(--steel-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}
.lsb-num {
  font-family: var(--ff-display); font-size: 22px; font-weight: 900;
  letter-spacing: -0.02em; color: var(--text); line-height: 1;
}
.lsb-label { font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.12em; margin-top: 3px; }
.lsb-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--nvg); box-shadow: 0 0 6px var(--nvg); animation: nvgPulse 1.8s ease-in-out infinite; flex-shrink: 0; }
.lsb-countdown { font-family: var(--ff-display); font-size: 18px; font-weight: 900; color: var(--amber-lt); letter-spacing: 0.04em; }
.lsb-countdown-label { font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.12em; margin-top: 3px; }
@media (max-width: 900px) { .lsb-inner { grid-template-columns: repeat(2, 1fr); } .lsb-stat:nth-child(2) { border-right: none; } }
@media (max-width: 600px) { .lsb-inner { grid-template-columns: repeat(2, 1fr); } .lsb-stat { padding: 12px 0; } }

/* ══════════════════════════════════════
   XP SYSTEM & LEVELS — full section
══════════════════════════════════════ */
.xp-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.xp-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--intel-border), transparent); }
.xp-bg-glow { position: absolute; top: 10%; right: -5%; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(ellipse, rgba(68,136,238,0.05) 0%, transparent 70%); pointer-events: none; }
.xp-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.xp-desc { color: var(--text-2); font-size: 17px; line-height: 1.65; margin: 20px 0 32px; }
.xp-how { display: flex; flex-direction: column; gap: 16px; margin-bottom: 36px; }
.xp-how-item {
  display: flex; align-items: flex-start; gap: 14px;
  background: var(--steel); border: 1px solid var(--steel-border);
  border-left: 3px solid var(--intel-border); border-radius: 1px; padding: 16px;
  transition: border-color var(--t), transform var(--t);
}
.xp-how-item:hover { border-left-color: var(--intel); transform: translateX(4px); }
.xp-how-icon { width: 36px; height: 36px; border-radius: 2px; background: var(--intel-bg); border: 1px solid var(--intel-border); display: flex; align-items: center; justify-content: center; color: var(--intel); flex-shrink: 0; }
.xp-how-item strong { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; display: block; margin-bottom: 3px; }
.xp-how-item span { font-size: 12px; color: var(--text-3); }
.xp-multiplier { display: inline-flex; align-items: center; gap: 6px; background: var(--streak-bg); border: 1px solid var(--streak-border); color: var(--streak-lt); font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; padding: 4px 12px; border-radius: 1px; }

/* Level ladder */
.level-ladder {
  display: flex; flex-direction: column; gap: 0;
  background: rgba(10,10,12,0.90);
  border: 1px solid var(--steel-border);
  border-top: 3px solid var(--intel);
  border-radius: 2px; overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.7);
}
.ll-header {
  background: rgba(68,136,238,0.05); border-bottom: 1px solid var(--intel-border);
  padding: 12px 20px; font-family: var(--ff-display); font-size: 10px; font-weight: 800;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--intel);
  display: flex; justify-content: space-between; align-items: center;
}
.ll-tier {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 20px; border-bottom: 1px solid var(--line);
  transition: background var(--t);
}
.ll-tier:hover { background: rgba(255,255,255,0.02); }
.ll-tier:last-child { border-bottom: none; }
.ll-tier.active-tier { background: rgba(68,136,238,0.06); border-bottom: 1px solid var(--intel-border); }
.ll-pip { width: 10px; height: 10px; border-radius: 2px; flex-shrink: 0; }
.ll-levels { font-family: var(--ff-display); font-size: 12px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-3); width: 80px; flex-shrink: 0; }
.active-tier .ll-levels { color: var(--intel); }
.ll-name { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; flex: 1; }
.ll-reward { font-size: 11px; color: var(--text-4); text-align: right; }
.ll-current-bar { padding: 14px 20px; background: rgba(68,136,238,0.05); border-top: 1px solid var(--intel-border); }
.ll-curr-top { display: flex; justify-content: space-between; font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.10em; margin-bottom: 8px; }
.ll-curr-top span:last-child { color: var(--intel); }
.ll-xp-bar { height: 6px; background: var(--bg5); border-radius: 1px; overflow: hidden; }
.ll-xp-fill { height: 100%; background: linear-gradient(90deg, var(--intel), #88aaff); box-shadow: 0 0 10px rgba(68,136,238,0.5); }
/* tier colors */
.pip-rookie   { background: var(--r-common); }
.pip-bronze   { background: #c07832; }
.pip-silver   { background: #c8c4b8; }
.pip-gold     { background: var(--brass); }
.pip-plat     { background: #88ccc0; }
.pip-diamond  { background: var(--intel); box-shadow: 0 0 5px var(--r-rare-glow); }
.pip-elite    { background: var(--r-epic); box-shadow: 0 0 5px var(--r-epic-glow); }
.pip-champ    { background: linear-gradient(135deg, var(--amber), var(--red)); }
.pip-legend   { background: var(--r-legendary); box-shadow: 0 0 7px var(--r-leg-glow); }
.pip-mythic   { background: linear-gradient(135deg, var(--red-lt), var(--r-legendary)); box-shadow: 0 0 10px var(--red-glow); }

@keyframes mythicShimmer { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }
.name-mythic {
  background: linear-gradient(90deg, var(--red-lt), var(--r-legendary), var(--r-epic), var(--red-lt));
  background-size: 300% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: mythicShimmer 3s ease infinite;
}
.name-legendary { color: var(--r-legendary); text-shadow: 0 0 12px var(--r-leg-glow); }
.name-epic { color: var(--r-epic); }
.name-diamond { color: var(--intel); }
.name-champ { background: linear-gradient(90deg, var(--amber), var(--red)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

@media (max-width: 900px) { .xp-layout { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   BADGE RARITY SYSTEM
══════════════════════════════════════ */
.rarity-section { padding: var(--section-py) 0; background: var(--bg0); }
.rarity-header { text-align: center; margin-bottom: 16px; }
.rarity-header .section-kicker { justify-content: center; }
.rarity-intro { max-width: 580px; margin: 0 auto 56px; text-align: center; color: var(--text-2); font-size: 17px; line-height: 1.65; }
.rarity-tiers { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--steel-border); border-radius: 2px; overflow: hidden; }
.rt-tier {
  display: grid; grid-template-columns: 200px 1fr auto;
  gap: 0; align-items: stretch;
  border-bottom: 1px solid var(--line);
}
.rt-tier:last-child { border-bottom: none; }
.rt-label {
  display: flex; align-items: center; gap: 12px;
  padding: 20px 24px; border-right: 1px solid var(--line);
  background: rgba(255,255,255,0.01);
}
.rt-pip { width: 12px; height: 12px; border-radius: 2px; flex-shrink: 0; }
.rt-name { font-family: var(--ff-display); font-size: 14px; font-weight: 900; letter-spacing: 0.10em; text-transform: uppercase; }
.rt-badges { display: flex; align-items: center; gap: 12px; padding: 16px 24px; flex-wrap: wrap; }
.rt-badge {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  width: 76px; padding: 12px 8px; border-radius: 2px;
  border: 1px solid var(--steel-border); background: var(--steel);
  transition: transform var(--t), box-shadow var(--t);
  cursor: default;
}
.rt-badge:hover { transform: translateY(-3px); }
.rt-badge-icon { font-size: 22px; line-height: 1; }
.rt-badge-name { font-size: 9px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; text-align: center; line-height: 1.3; }
.rt-count { padding: 16px 24px; display: flex; align-items: center; font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; color: var(--text-4); white-space: nowrap; }
/* Tier-specific badge styles */
.rt-common .rt-name { color: var(--r-common); }
.rt-common .rt-badge { border-color: var(--r-common-border); }
.rt-common .rt-badge:hover { border-color: var(--r-common); box-shadow: 0 4px 16px rgba(136,144,168,0.2); }

.rt-rare .rt-label { background: rgba(68,136,238,0.03); }
.rt-rare .rt-name { color: var(--r-rare); }
.rt-rare .rt-badge { border-color: var(--r-rare-border); background: var(--r-rare-bg); }
.rt-rare .rt-badge:hover { border-color: var(--r-rare); box-shadow: 0 4px 16px var(--r-rare-glow); }

.rt-epic .rt-label { background: rgba(153,85,238,0.04); }
.rt-epic .rt-name { color: var(--r-epic); }
.rt-epic .rt-badge { border-color: var(--r-epic-border); background: var(--r-epic-bg); }
.rt-epic .rt-badge:hover { border-color: var(--r-epic); box-shadow: 0 4px 16px var(--r-epic-glow); }

.rt-legendary .rt-label { background: rgba(232,180,32,0.04); }
.rt-legendary .rt-name { color: var(--r-legendary); }
.rt-legendary .rt-badge { border-color: var(--r-leg-border); background: var(--r-leg-bg); }
.rt-legendary .rt-badge:hover { border-color: var(--r-legendary); box-shadow: 0 4px 20px var(--r-leg-glow); }

.rt-mythic .rt-label { background: rgba(204,26,26,0.04); }
.rt-mythic .rt-name {
  background: linear-gradient(90deg, var(--red-lt), var(--r-legendary));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: mythicShimmer 3s ease infinite; background-size: 300% auto;
}
.rt-mythic .rt-badge { border-color: var(--red-border); background: var(--red-bg); animation: glowBorder 3s ease-in-out infinite; }
.rt-mythic .rt-badge:hover { box-shadow: 0 4px 20px var(--red-glow); }
.rt-mythic .rt-count { color: var(--red-lt); }

.rarity-note { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 20px; font-size: 12px; color: var(--text-4); }
@media (max-width: 900px) { .rt-tier { grid-template-columns: 140px 1fr; } .rt-count { display: none; } }
@media (max-width: 600px) { .rt-tier { grid-template-columns: 1fr; } .rt-label { border-right: none; border-bottom: 1px solid var(--line); } }

/* ══════════════════════════════════════
   DAILY QUESTS & WEEKLY MISSIONS
══════════════════════════════════════ */
.quests-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.quests-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--brass-border), transparent); }
.quests-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 60px); align-items: start; }
.quests-board-label { font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-4); margin-bottom: 16px; display: flex; align-items: center; justify-content: space-between; }
.qbl-reset { color: var(--amber-lt); font-size: 10px; }
.quest-card {
  background: rgba(10,10,12,0.90); border: 1px solid var(--steel-border);
  border-radius: 2px; padding: 16px 20px; margin-bottom: 10px;
  display: flex; align-items: flex-start; gap: 14px;
  transition: border-color var(--t), transform var(--t);
  position: relative;
}
.quest-card:hover { border-color: var(--brass-border); transform: translateX(4px); }
.quest-card.quest-done { border-color: var(--nvg-border); background: rgba(0,230,118,0.03); }
.quest-card.quest-done::after { content: '✓'; position: absolute; top: 12px; right: 14px; font-family: var(--ff-display); font-size: 13px; font-weight: 900; color: var(--nvg); }
.quest-icon { width: 38px; height: 38px; border-radius: 2px; background: var(--brass-bg); border: 1px solid var(--brass-border); display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.quest-done .quest-icon { background: var(--nvg-bg); border-color: var(--nvg-border); }
.quest-body { flex: 1; }
.quest-name { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.05em; text-transform: uppercase; color: var(--text); margin-bottom: 4px; }
.quest-done .quest-name { color: var(--text-3); text-decoration: line-through; text-decoration-color: var(--nvg); }
.quest-desc { font-size: 11px; color: var(--text-3); margin-bottom: 10px; }
.quest-progress { display: flex; align-items: center; gap: 10px; }
.quest-bar { flex: 1; height: 3px; background: var(--bg5); border-radius: 1px; overflow: hidden; }
.quest-fill { height: 100%; background: linear-gradient(90deg, var(--brass), var(--amber-lt)); }
.quest-done .quest-fill { background: var(--nvg); width: 100% !important; }
.quest-progress-text { font-family: var(--ff-display); font-size: 10px; font-weight: 800; color: var(--text-4); white-space: nowrap; }
.quest-xp { display: inline-flex; align-items: center; gap: 4px; font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--intel); background: var(--intel-bg); border: 1px solid var(--intel-border); padding: 2px 8px; border-radius: 1px; flex-shrink: 0; }

/* Weekly mission track */
.weekly-track {
  background: rgba(10,10,12,0.90); border: 1px solid var(--steel-border);
  border-top: 3px solid var(--brass); border-radius: 2px; overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.7);
}
.wt-header {
  background: var(--brass-bg); border-bottom: 1px solid var(--brass-border);
  padding: 12px 20px; display: flex; justify-content: space-between; align-items: center;
  font-family: var(--ff-display); font-size: 11px; font-weight: 800;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--brass-lt);
}
.wt-timer { font-size: 10px; color: var(--amber-lt); }
.wt-steps { display: flex; align-items: center; padding: 20px; gap: 0; }
.wt-step {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  flex: 1; position: relative;
}
.wt-step-pip {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--steel); border: 2px solid var(--steel-border);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: 10px; font-weight: 900;
  color: var(--text-4); z-index: 1; transition: all var(--t);
}
.wt-step.done .wt-step-pip { background: var(--nvg-bg); border-color: var(--nvg); color: var(--nvg); }
.wt-step.active-step .wt-step-pip { background: var(--brass-bg); border-color: var(--brass); color: var(--brass-lt); box-shadow: 0 0 12px var(--brass-glow); animation: glowBorder 2s ease-in-out infinite; }
.wt-step.reward .wt-step-pip { background: var(--amber-bg); border-color: var(--amber); color: var(--amber-lt); }
.wt-step-connector { position: absolute; top: 13px; left: 50%; right: -50%; height: 2px; background: var(--line); z-index: 0; }
.wt-step.done .wt-step-connector { background: var(--nvg); opacity: 0.4; }
.wt-step:last-child .wt-step-connector { display: none; }
.wt-step-label { font-size: 9px; color: var(--text-4); text-align: center; text-transform: uppercase; letter-spacing: 0.06em; line-height: 1.3; }
.wt-step.done .wt-step-label { color: var(--nvg); }
.wt-step.active-step .wt-step-label { color: var(--brass-lt); }
.wt-reward-reveal {
  margin: 0 20px 20px; padding: 14px; background: var(--brass-bg);
  border: 1px solid var(--brass-border); border-radius: 2px;
  display: flex; align-items: center; gap: 12px;
}
.wtr-icon { font-size: 22px; }
.wtr-text strong { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; color: var(--brass-lt); display: block; margin-bottom: 3px; }
.wtr-text span { font-size: 11px; color: var(--text-3); }
@media (max-width: 900px) { .quests-layout { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   SEASONAL REWARDS
══════════════════════════════════════ */
.seasonal-section { padding: var(--section-py) 0; background: var(--bg0); }
.seasonal-header { text-align: center; margin-bottom: 52px; }
.seasonal-header .section-kicker { justify-content: center; }
.season-track-wrap {
  background: rgba(10,10,12,0.90); border: 1px solid var(--steel-border);
  border-top: 3px solid var(--red); border-radius: 2px; padding: 32px 28px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.7); margin-bottom: 32px;
  position: relative; overflow: hidden;
}
.season-track-wrap::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--red), var(--amber), var(--r-epic), var(--r-legendary), var(--red));
  background-size: 300% auto; animation: brandGradient 4s ease infinite;
}
.season-track-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 28px; flex-wrap: wrap; gap: 12px;
}
.sth-title { font-family: var(--ff-display); font-size: 18px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; }
.sth-meta { display: flex; align-items: center; gap: 12px; }
.sth-progress { font-size: 12px; color: var(--text-3); }
.sth-progress strong { color: var(--text); }
.season-progress-bar { height: 8px; background: var(--bg5); border-radius: 2px; overflow: hidden; margin-bottom: 32px; position: relative; }
.spb-fill { height: 100%; background: linear-gradient(90deg, var(--red), var(--amber), var(--r-legendary)); background-size: 200% auto; animation: brandGradient 3s ease infinite; border-radius: 2px; box-shadow: 0 0 12px var(--red-glow); }
.season-rewards-track { display: flex; gap: 0; overflow-x: auto; padding-bottom: 8px; scrollbar-width: none; }
.season-rewards-track::-webkit-scrollbar { display: none; }
.sr-node { flex: 1; min-width: 100px; display: flex; flex-direction: column; align-items: center; gap: 10px; position: relative; }
.sr-connector { position: absolute; top: 28px; left: 50%; right: -50%; height: 2px; background: var(--line); z-index: 0; }
.sr-node.unlocked .sr-connector { background: linear-gradient(90deg, var(--red), var(--amber)); opacity: 0.5; }
.sr-node:last-child .sr-connector { display: none; }
.sr-gem {
  width: 56px; height: 56px; border-radius: 2px;
  background: var(--steel); border: 2px solid var(--steel-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; z-index: 1; transition: all var(--t);
  clip-path: polygon(15% 0%, 85% 0%, 100% 15%, 100% 85%, 85% 100%, 15% 100%, 0% 85%, 0% 15%);
}
.sr-node.unlocked .sr-gem { border-color: var(--amber-border); background: var(--brass-bg); box-shadow: 0 0 16px var(--brass-glow); }
.sr-node.active-node .sr-gem { border-color: var(--red); background: var(--red-bg); box-shadow: 0 0 20px var(--red-glow); animation: glowBorder 2s ease-in-out infinite; }
.sr-node.locked .sr-gem { opacity: 0.35; filter: grayscale(0.7); }
.sr-level { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; color: var(--text-4); }
.sr-node.unlocked .sr-level { color: var(--text-3); }
.sr-node.active-node .sr-level { color: var(--red-lt); }
.sr-reward-name { font-size: 9px; color: var(--text-4); text-align: center; line-height: 1.3; text-transform: uppercase; letter-spacing: 0.06em; }
.sr-node.unlocked .sr-reward-name { color: var(--brass-lt); }
.season-fomo { display: flex; align-items: center; justify-content: center; gap: 12px; padding: 16px 20px; background: var(--red-bg); border: 1px solid var(--red-border); border-radius: 2px; margin-top: 16px; font-size: 13px; color: var(--text-2); flex-wrap: wrap; text-align: center; }
.season-fomo strong { color: var(--red-lt); font-family: var(--ff-display); font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; }
@media (max-width: 600px) { .sr-gem { width: 44px; height: 44px; font-size: 18px; } .sr-node { min-width: 76px; } }

/* ══════════════════════════════════════
   GAMER CARD
══════════════════════════════════════ */
.gamercard-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.gamercard-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red-border), transparent); }
.gc-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: center; }
.gc-desc { color: var(--text-2); font-size: 17px; line-height: 1.65; margin: 20px 0 28px; }
.gc-bullets { display: flex; flex-direction: column; gap: 14px; margin-bottom: 36px; }
.gc-bullet { display: flex; align-items: flex-start; gap: 12px; font-size: 14px; color: var(--text-2); }
.gc-bullet svg { flex-shrink: 0; color: var(--red-lt); margin-top: 2px; }
.gc-bullet strong { color: var(--text); font-family: var(--ff-display); font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; display: block; margin-bottom: 2px; }

/* The card itself */
.gamer-card-preview {
  position: relative;
  background: rgba(8,8,10,0.96);
  border: 1px solid var(--steel-border);
  border-radius: 4px; overflow: hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,0.9), 0 0 30px var(--red-glow);
  max-width: 380px; margin: 0 auto;
  transform: perspective(800px) rotateY(-6deg) rotateX(2deg);
  transition: transform 0.6s var(--ease);
}
.gamer-card-preview:hover {
  transform: perspective(800px) rotateY(0deg) rotateX(0deg) translateY(-6px);
  box-shadow: 0 50px 100px rgba(0,0,0,0.9), 0 0 40px var(--red-glow);
}
.gcp-shine {
  position: absolute; inset: 0; pointer-events: none; z-index: 10;
  background: linear-gradient(135deg, rgba(255,255,255,0.04) 0%, transparent 40%, rgba(255,255,255,0.02) 100%);
}
.gcp-top-bar {
  height: 5px;
  background: linear-gradient(90deg, var(--red), var(--amber), var(--r-epic), var(--r-legendary));
  background-size: 300% auto; animation: brandGradient 4s ease infinite;
}
.gcp-header { padding: 20px 20px 16px; border-bottom: 1px solid var(--line); }
.gcp-brand { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.gcp-logo { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.18em; color: var(--text-3); text-transform: uppercase; }
.gcp-season { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--red-lt); background: var(--red-bg); border: 1px solid var(--red-border); padding: 3px 8px; border-radius: 1px; }
.gcp-player { display: flex; align-items: center; gap: 16px; }
.gcp-avatar {
  width: 56px; height: 56px; border-radius: 2px;
  background: linear-gradient(135deg, var(--red-dk), var(--r-epic));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: 24px; font-weight: 900; color: #fff;
  flex-shrink: 0; position: relative;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 0 100%);
}
.gcp-avatar-ring { position: absolute; inset: -3px; border: 2px solid var(--r-epic); border-radius: 3px; animation: ringPulse 2.4s ease-in-out infinite; }
.gcp-name { font-family: var(--ff-display); font-size: 18px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 6px; }
.gcp-badges-row { display: flex; gap: 5px; }
.gcp-badge-pill { font-family: var(--ff-display); font-size: 8px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 7px; border-radius: 1px; }
.gcp-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); }
.gcp-stat { background: rgba(255,255,255,0.02); padding: 12px 8px; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.gcp-stat-val { font-family: var(--ff-display); font-size: 18px; font-weight: 900; color: var(--text); }
.gcp-stat-lbl { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.07em; }
.gcp-bottom { padding: 16px 20px; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--line); }
.gcp-rank-display { display: flex; align-items: center; gap: 10px; }
.gcp-rank-gem { font-size: 20px; }
.gcp-rank-name { font-family: var(--ff-display); font-size: 14px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; }
.gcp-rank-pts { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.gcp-level-big { text-align: right; }
.gcp-level-num { font-family: var(--ff-display); font-size: 32px; font-weight: 900; line-height: 1; color: var(--intel); letter-spacing: -0.02em; }
.gcp-level-lbl { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.14em; }
.gcp-badges-showcase { padding: 12px 20px; border-top: 1px solid var(--line); display: flex; align-items: center; gap: 8px; }
.gcp-badge-icon { font-size: 18px; }
.gcp-badge-more { font-family: var(--ff-display); font-size: 11px; font-weight: 800; color: var(--text-4); margin-left: 4px; }
.gcp-streak-bar { padding: 10px 20px; background: var(--streak-bg); border-top: 1px solid var(--streak-border); display: flex; align-items: center; justify-content: space-between; }
.gcp-streak-txt { font-family: var(--ff-display); font-size: 12px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; color: var(--streak-lt); }
.gcp-streak-xp { font-size: 10px; color: var(--streak); }
.gc-locked-badge {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 10px;
  background: rgba(6,6,6,0.82); backdrop-filter: blur(4px); z-index: 5;
  pointer-events: none;
}
.gc-lock-icon { font-size: 32px; }
.gc-lock-text { font-family: var(--ff-display); font-size: 12px; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); text-align: center; padding: 0 32px; }
@media (max-width: 900px) { .gc-layout { grid-template-columns: 1fr; } .gamer-card-preview { transform: none; } .gamer-card-preview:hover { transform: translateY(-4px); } }

/* ══════════════════════════════════════
   WIN STREAK / FOMO additions to hero
══════════════════════════════════════ */
.hero-streak-row { display: flex; align-items: center; gap: 10px; margin-bottom: 28px; flex-wrap: wrap; }
.streak-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-display); font-size: 12px; font-weight: 900;
  letter-spacing: 0.10em; text-transform: uppercase;
  background: var(--streak-bg); border: 1px solid var(--streak-border);
  color: var(--streak-lt); padding: 6px 14px; border-radius: 2px;
  box-shadow: 0 0 14px var(--streak-glow);
}
.hero-fomo { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-3); }
.hero-fomo strong { color: var(--amber-lt); font-family: var(--ff-display); font-weight: 900; }

/* Hero XP bar */
.hero-xp-wrap { margin-bottom: 32px; }
.hero-xp-label { display: flex; justify-content: space-between; font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); margin-bottom: 6px; }
.hero-xp-label .level-now { color: var(--intel); }
.hero-xp-label .level-next { color: var(--text-4); }
.hero-xp-bar-outer { height: 6px; background: var(--bg4); border-radius: 1px; overflow: hidden; border: 1px solid var(--line); }
.hero-xp-bar-fill { height: 100%; background: linear-gradient(90deg, var(--intel), #88aaff, var(--r-epic)); background-size: 200% auto; animation: brandGradient 3s ease infinite; box-shadow: 0 0 10px rgba(68,136,238,0.5); width: 62%; }

/* Apply section FOMO enhancements */
.fomo-counter {
  display: flex; align-items: center; gap: 10px; padding: 12px 16px;
  background: var(--red-bg); border: 1px solid var(--red-border); border-radius: 2px;
  margin-bottom: 20px;
}
.fomo-num { font-family: var(--ff-display); font-size: 22px; font-weight: 900; color: var(--red-lt); line-height: 1; }
.fomo-label { font-size: 12px; color: var(--text-2); line-height: 1.4; }
.fomo-label strong { color: var(--text); display: block; font-family: var(--ff-display); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
.fomo-joined-today { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-4); margin-top: 8px; }
.fomo-joined-today .nvg-num { color: var(--nvg); font-family: var(--ff-display); font-weight: 900; }

/* Unlock button — hero CTA variant */
.btn-unlock {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, var(--red), var(--red-lt));
  color: #fff; font-family: var(--ff-display); font-size: 15px; font-weight: 900;
  letter-spacing: 0.12em; text-transform: uppercase; padding: 16px 32px;
  border-radius: 2px;
  border-top: 3px solid var(--amber);
  box-shadow: 0 6px 32px var(--red-glow), inset 0 1px 0 rgba(255,255,255,0.12);
  transition: transform var(--t) var(--ease), box-shadow var(--t), filter var(--t);
  position: relative; overflow: hidden;
}
.btn-unlock::after {
  content: '';
  position: absolute; top: 0; left: -100%; right: 100%; bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.10), transparent);
  transition: left 0.4s ease, right 0.4s ease;
}
.btn-unlock:hover { transform: translateY(-3px); box-shadow: 0 12px 48px var(--red-glow); filter: brightness(1.06); }
.btn-unlock:hover::after { left: 0; right: -100%; }

/* ══════════════════════════════════════
   HOW IT WORKS
══════════════════════════════════════ */
.hiw { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.hiw::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red-border), transparent); }
.hiw-header { text-align: center; margin-bottom: 56px; position: relative; z-index: 1; }
.hiw-header .section-kicker { justify-content: center; }
.hiw-sub { max-width: 480px; margin: 12px auto 0; color: var(--text-2); font-size: 17px; line-height: 1.6; text-align: center; }
.hiw-steps { display: flex; align-items: stretch; justify-content: center; flex-wrap: wrap; gap: 0; position: relative; z-index: 1; }
.hiw-step {
  flex: 1; min-width: 200px; max-width: 240px;
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px;
  padding: 32px 20px; background: var(--steel); border: 1px solid var(--steel-border);
  border-right: none; border-radius: 0;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
  position: relative;
}
.hiw-step:first-child { border-radius: 2px 0 0 2px; }
.hiw-step:last-child { border-right: 1px solid var(--steel-border); border-radius: 0 2px 2px 0; }
.hiw-step:hover { z-index: 2; border-color: var(--neutral-border); box-shadow: 0 12px 32px rgba(0,0,0,0.5); }
.hiw-step-final { border-color: var(--amber-border) !important; border-top: 2px solid var(--amber); background: linear-gradient(145deg, rgba(224,136,0,0.06), var(--steel)); }
.hiw-step-final:hover { box-shadow: 0 12px 32px rgba(0,0,0,0.5), 0 0 20px var(--amber-glow); }
.hiw-num { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.20em; color: var(--text-4); text-transform: uppercase; }
.hiw-num-final { color: var(--amber); }
.hiw-icon {
  width: 52px; height: 52px; border-radius: 2px;
  background: var(--steel-hi); border: 1px solid var(--steel-edge);
  display: flex; align-items: center; justify-content: center; color: var(--text-2);
  transition: background var(--t), border-color var(--t), box-shadow var(--t);
}
.hiw-step:hover .hiw-icon { background: var(--red-bg); border-color: var(--red-border); color: var(--red-lt); box-shadow: 0 0 20px var(--red-glow); }
.hiw-step-final .hiw-icon { background: var(--amber-bg); border-color: var(--amber-border); color: var(--amber); box-shadow: 0 0 18px var(--amber-glow); }
.hiw-step h3 { font-family: var(--ff-display); font-size: 15px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text); }
.hiw-step p { font-size: 12px; color: var(--text-3); line-height: 1.6; }
.hiw-connector { display: flex; align-items: center; padding: 0; color: var(--neutral-dk); align-self: center; flex-shrink: 0; }
@media (max-width: 900px) {
  .hiw-steps { flex-direction: column; }
  .hiw-step { max-width: 100%; border-right: 1px solid var(--steel-border); border-bottom: none; border-radius: 0; }
  .hiw-step:first-child { border-radius: 2px 2px 0 0; }
  .hiw-step:last-child { border-bottom: 1px solid var(--steel-border); border-radius: 0 0 2px 2px; }
  .hiw-connector { display: none; }
}

/* ══════════════════════════════════════
   SOCIAL PROOF
══════════════════════════════════════ */
.social-proof { padding: var(--section-py) 0; background: var(--bg0); position: relative; overflow: hidden; }
.social-proof::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--neutral-border), transparent); }
.sp-header { text-align: center; margin-bottom: 48px; }
.sp-header .section-kicker { justify-content: center; }
.sp-stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--steel-border); border-radius: 2px; overflow: hidden; margin-bottom: 60px; }
.sp-stat { background: var(--steel); padding: 28px 20px; text-align: center; }
.sp-stat-num { font-family: var(--ff-display); font-size: clamp(28px, 4vw, 42px); font-weight: 900; line-height: 1; margin-bottom: 6px; }
.sp-stat-num.red-num { color: var(--red-lt); text-shadow: 0 0 20px var(--red-glow); }
.sp-stat-num.gold-num { color: var(--brass-lt); text-shadow: 0 0 16px var(--brass-glow); }
.sp-stat-num.green-num { color: var(--nvg); text-shadow: 0 0 16px var(--nvg-glow); }
.sp-stat-num.blue-num { color: var(--intel); text-shadow: 0 0 16px var(--intel-glow); }
.sp-stat-label { font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.12em; }
.sp-quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.sp-quote {
  background: var(--steel); border: 1px solid var(--steel-border);
  border-radius: 2px; padding: 28px;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
  position: relative;
}
.sp-quote:hover { border-color: var(--neutral-border); transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.5); }
.sp-quote-mark { font-family: Georgia, serif; font-size: 48px; line-height: 0.7; color: var(--red); opacity: 0.4; margin-bottom: 12px; display: block; }
.sp-quote-text { font-size: 14px; color: var(--text-2); line-height: 1.7; margin-bottom: 20px; font-style: italic; }
.sp-quote-author { display: flex; align-items: center; gap: 12px; }
.sp-av { width: 36px; height: 36px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 14px; font-weight: 900; flex-shrink: 0; }
.sp-av-1 { background: var(--red-bg); border: 1px solid var(--red-border); color: var(--red-lt); }
.sp-av-2 { background: var(--intel-bg); border: 1px solid var(--intel-border); color: var(--intel); }
.sp-av-3 { background: var(--brass-bg); border: 1px solid var(--brass-border); color: var(--brass-lt); }
.sp-author-name { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; }
.sp-author-meta { font-size: 10px; color: var(--text-4); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.08em; }
.sp-author-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 9px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 7px; border-radius: 1px; margin-top: 4px; }
.badge-beta { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.badge-rank { background: var(--intel-bg); color: var(--intel); border: 1px solid var(--intel-border); }
.badge-speed { background: var(--speed-bg); color: var(--speed); border: 1px solid var(--speed-border); }
@media (max-width: 900px) { .sp-stats-row { grid-template-columns: repeat(2, 1fr); } .sp-quotes { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   ZE COIN ECONOMY
══════════════════════════════════════ */
.ze-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.ze-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--amber-border), transparent); }
.ze-bg-glow { position: absolute; top: -10%; left: -5%; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(ellipse, rgba(232,180,32,0.04) 0%, transparent 70%); pointer-events: none; }
.ze-header { text-align: center; margin-bottom: 60px; }
.ze-header .section-kicker { justify-content: center; color: var(--brass-lt); }
.ze-header .section-kicker::before { color: var(--amber-lt); }
.ze-layout { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; margin-bottom: 52px; }
/* Earn card */
.ze-card {
  background: rgba(10,10,12,0.90); border: 1px solid var(--steel-border);
  border-radius: 2px; overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6);
}
.ze-card-head {
  padding: 16px 20px; border-bottom: 1px solid var(--line);
  font-family: var(--ff-display); font-size: 10px; font-weight: 800;
  letter-spacing: 0.18em; text-transform: uppercase;
  display: flex; align-items: center; justify-content: space-between;
}
.ze-card-head-earn { background: rgba(232,180,32,0.04); border-bottom-color: var(--brass-border); color: var(--brass-lt); }
.ze-card-head-wallet { background: rgba(68,136,238,0.04); border-bottom-color: var(--intel-border); color: var(--intel); }
.ze-card-head-spend { background: rgba(153,85,238,0.04); border-bottom-color: var(--r-epic-border); color: var(--r-epic); }
.ze-earn-list { padding: 16px 20px; display: flex; flex-direction: column; gap: 0; }
.ze-earn-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--line);
}
.ze-earn-item:last-child { border-bottom: none; }
.ze-earn-icon { width: 30px; height: 30px; border-radius: 2px; background: var(--brass-bg); border: 1px solid var(--brass-border); display: flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }
.ze-earn-name { flex: 1; font-size: 12px; color: var(--text-2); }
.ze-earn-amt { font-family: var(--ff-display); font-size: 12px; font-weight: 900; color: var(--brass-lt); white-space: nowrap; }
/* Wallet card */
.ze-wallet-body { padding: 20px; }
.ze-wallet-balance { text-align: center; padding: 20px 0 16px; border-bottom: 1px solid var(--line); margin-bottom: 16px; }
.ze-coin-symbol { font-family: var(--ff-display); font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brass-lt); margin-bottom: 4px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.ze-coin-icon { width: 18px; height: 18px; border-radius: 50%; background: linear-gradient(135deg, var(--brass), var(--amber)); display: inline-flex; align-items: center; justify-content: center; font-size: 10px; flex-shrink: 0; }
.ze-balance-num { font-family: var(--ff-display); font-size: 40px; font-weight: 900; color: var(--brass-lt); letter-spacing: -0.02em; line-height: 1; text-shadow: 0 0 30px var(--brass-glow); }
.ze-balance-label { font-size: 10px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.12em; margin-top: 4px; }
.ze-wallet-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line); border-radius: 1px; overflow: hidden; margin-bottom: 16px; }
.ze-meta-item { background: rgba(255,255,255,0.02); padding: 10px 12px; }
.ze-meta-label { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.10em; margin-bottom: 3px; }
.ze-meta-val { font-family: var(--ff-display); font-size: 14px; font-weight: 900; }
.ze-meta-val.earned { color: var(--nvg); }
.ze-meta-val.spent { color: var(--text-3); }
.ze-tx-list { display: flex; flex-direction: column; gap: 0; }
.ze-tx { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 11px; }
.ze-tx:last-child { border-bottom: none; }
.ze-tx-dir { width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 9px; flex-shrink: 0; }
.ze-tx-dir.in { background: var(--nvg-bg); color: var(--nvg); }
.ze-tx-dir.out { background: var(--r-epic-bg); color: var(--r-epic); }
.ze-tx-name { flex: 1; color: var(--text-2); }
.ze-tx-amt { font-family: var(--ff-display); font-size: 11px; font-weight: 900; }
.ze-tx-amt.in-amt { color: var(--nvg); }
.ze-tx-amt.out-amt { color: var(--r-epic); }
.ze-tx-time { font-size: 9px; color: var(--text-4); white-space: nowrap; }
/* Spend card */
.ze-spend-grid { padding: 16px 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ze-spend-item {
  background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px;
  padding: 12px 10px; display: flex; flex-direction: column; align-items: center; gap: 6px;
  text-align: center; transition: border-color var(--t), transform var(--t);
  cursor: default;
}
.ze-spend-item:hover { border-color: var(--r-epic-border); transform: translateY(-2px); }
.ze-spend-icon { font-size: 20px; }
.ze-spend-name { font-size: 9px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; line-height: 1.3; }
.ze-spend-cost { font-family: var(--ff-display); font-size: 11px; font-weight: 900; color: var(--brass-lt); display: flex; align-items: center; gap: 3px; }
/* Bottom row */
.ze-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: center; padding: 32px 28px; background: rgba(232,180,32,0.04); border: 1px solid var(--brass-border); border-radius: 2px; }
.ze-bottom-text h3 { font-family: var(--ff-display); font-size: clamp(20px, 3vw, 28px); font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 10px; }
.ze-bottom-text h3 span { color: var(--brass-lt); }
.ze-bottom-text p { font-size: 14px; color: var(--text-2); line-height: 1.65; }
.ze-founding-bonus { background: rgba(204,26,26,0.06); border: 1px solid var(--red-border); border-radius: 2px; padding: 20px; display: flex; flex-direction: column; gap: 10px; }
.ze-founding-icon { font-size: 28px; }
.ze-founding-title { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; color: var(--amber-lt); }
.ze-founding-desc { font-size: 12px; color: var(--text-2); line-height: 1.5; }
.ze-founding-amt { font-family: var(--ff-display); font-size: 24px; font-weight: 900; color: var(--brass-lt); text-shadow: 0 0 20px var(--brass-glow); }
@media (max-width: 900px) { .ze-layout { grid-template-columns: 1fr; } .ze-bottom { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   IDENTITY STORE
══════════════════════════════════════ */
.store-section { padding: var(--section-py) 0; background: var(--bg0); position: relative; overflow: hidden; }
.store-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--r-epic-border), transparent); }
.store-bg-glow { position: absolute; top: 20%; right: -5%; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(ellipse, rgba(153,85,238,0.04) 0%, transparent 70%); pointer-events: none; }
.store-header { text-align: center; margin-bottom: 52px; }
.store-header .section-kicker { justify-content: center; color: var(--r-epic); }
.store-header .section-kicker::before { color: var(--r-epic); }
.store-cats { display: flex; gap: 8px; justify-content: center; margin-bottom: 40px; flex-wrap: wrap; }
.store-cat-pill {
  font-family: var(--ff-display); font-size: 11px; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 7px 18px; border-radius: 2px;
  background: var(--steel); border: 1px solid var(--steel-border); color: var(--text-3);
}
.store-cat-pill.active { background: var(--r-epic-bg); border-color: var(--r-epic-border); color: var(--r-epic); }
.store-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 40px; }
.store-item {
  background: var(--steel); border: 1px solid var(--steel-border);
  border-radius: 2px; overflow: hidden;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
  cursor: default; position: relative;
}
.store-item:hover { border-color: var(--r-epic-border); transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.6), 0 0 20px var(--r-epic-glow); }
.store-item-preview {
  height: 120px; display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.si-frame { width: 64px; height: 64px; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 22px; font-weight: 900; color: #fff; clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 0 100%); }
.si-frame-epic { background: linear-gradient(135deg, var(--r-epic), rgba(153,85,238,0.3)); border: 2px solid var(--r-epic); box-shadow: 0 0 20px var(--r-epic-glow); }
.si-frame-legendary { background: linear-gradient(135deg, var(--r-legendary), rgba(232,180,32,0.3)); border: 2px solid var(--r-legendary); box-shadow: 0 0 20px var(--r-leg-glow); }
.si-frame-mythic { background: linear-gradient(135deg, var(--red-lt), var(--r-legendary)); border: 2px solid var(--red); animation: glowBorder 2s ease-in-out infinite; }
.si-frame-rare { background: linear-gradient(135deg, var(--r-rare), rgba(68,136,238,0.3)); border: 2px solid var(--r-rare); box-shadow: 0 0 16px var(--r-rare-glow); }
.si-preview-bg-1 { background: linear-gradient(135deg, rgba(153,85,238,0.15) 0%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-2 { background: linear-gradient(135deg, rgba(232,180,32,0.12) 0%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-3 { background: linear-gradient(135deg, rgba(204,26,26,0.15) 0%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-4 { background: linear-gradient(135deg, rgba(68,136,238,0.12) 0%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-5 { background: linear-gradient(135deg, rgba(255,107,53,0.12) 0%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-6 { background: linear-gradient(135deg, rgba(0,230,118,0.08) 0%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-7 { background: radial-gradient(ellipse at 50% 40%, rgba(232,180,32,0.18) 0%, rgba(153,85,238,0.10) 50%, rgba(10,10,12,0.98) 100%); }
.si-preview-bg-8 { background: linear-gradient(135deg, rgba(255,224,27,0.12) 0%, rgba(10,10,12,0.98) 100%); }
.si-theme-preview { width: 90%; height: 80%; border-radius: 2px; border: 1px solid; display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; }
.si-rarity-tag { position: absolute; top: 8px; right: 8px; font-family: var(--ff-display); font-size: 8px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; padding: 2px 6px; border-radius: 1px; }
.si-rarity-epic { background: var(--r-epic-bg); color: var(--r-epic); border: 1px solid var(--r-epic-border); }
.si-rarity-legendary { background: var(--r-leg-bg); color: var(--r-legendary); border: 1px solid var(--r-leg-border); }
.si-rarity-mythic { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.si-rarity-rare { background: var(--r-rare-bg); color: var(--r-rare); border: 1px solid var(--r-rare-border); }
.si-rarity-limited { background: var(--streak-bg); color: var(--streak-lt); border: 1px solid var(--streak-border); }
.store-item-body { padding: 14px 16px; }
.store-item-name { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 2px; }
.store-item-type { font-size: 10px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.10em; margin-bottom: 10px; }
.store-item-footer { display: flex; align-items: center; justify-content: space-between; }
.store-item-cost { display: flex; align-items: center; gap: 5px; font-family: var(--ff-display); font-size: 14px; font-weight: 900; color: var(--brass-lt); }
.store-item-btn { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; padding: 5px 12px; border-radius: 1px; background: var(--r-epic-bg); border: 1px solid var(--r-epic-border); color: var(--r-epic); transition: background var(--t), color var(--t); }
.store-item:hover .store-item-btn { background: var(--r-epic); color: #fff; }
.store-cta-bar { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 24px 28px; background: var(--steel); border: 1px solid var(--r-epic-border); border-radius: 2px; flex-wrap: wrap; }
.store-cta-text strong { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; display: block; margin-bottom: 4px; }
.store-cta-text p { font-size: 13px; color: var(--text-3); }
@media (max-width: 900px) { .store-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .store-grid { grid-template-columns: 1fr 1fr; } }

/* ══════════════════════════════════════
   COMMUNITIES SECTION
══════════════════════════════════════ */
.communities-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.communities-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--nvg-border), transparent); }
.communities-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: center; }
.comm-kicker { color: var(--nvg) !important; }
.comm-kicker::before { color: var(--nvg) !important; }
.comm-desc { color: var(--text-2); font-size: 17px; line-height: 1.65; margin: 20px 0 32px; }
.comm-features { display: flex; flex-direction: column; gap: 14px; margin-bottom: 36px; }
.comm-feature { display: flex; align-items: flex-start; gap: 14px; background: var(--steel); border: 1px solid var(--steel-border); border-left: 3px solid var(--nvg-border); border-radius: 1px; padding: 16px; transition: border-color var(--t), transform var(--t); }
.comm-feature:hover { border-left-color: var(--nvg); transform: translateX(4px); }
.comm-feat-icon { width: 36px; height: 36px; border-radius: 2px; background: var(--nvg-bg); border: 1px solid var(--nvg-border); display: flex; align-items: center; justify-content: center; color: var(--nvg); flex-shrink: 0; }
.comm-feature strong { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; display: block; margin-bottom: 3px; }
.comm-feature span { font-size: 12px; color: var(--text-3); }
.comm-card-visual {
  background: rgba(10,10,12,0.92); border: 1px solid var(--steel-border);
  border-top: 3px solid var(--nvg); border-radius: 2px; padding: 24px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.7);
}
.comm-card-header { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--line); }
.comm-org-logo { width: 48px; height: 48px; border-radius: 2px; background: var(--nvg-bg); border: 1px solid var(--nvg-border); display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 18px; font-weight: 900; color: var(--nvg); flex-shrink: 0; }
.comm-org-name { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 4px; }
.comm-org-tag { font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; }
.comm-verified { display: flex; align-items: center; gap: 4px; font-size: 9px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; background: var(--nvg-bg); color: var(--nvg); border: 1px solid var(--nvg-border); padding: 3px 8px; border-radius: 1px; margin-top: 6px; width: fit-content; }
.comm-stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border-radius: 1px; overflow: hidden; margin-bottom: 20px; }
.comm-stat { background: rgba(255,255,255,0.02); padding: 14px 8px; display: flex; flex-direction: column; align-items: center; gap: 4px; }
.comm-stat strong { font-family: var(--ff-display); font-size: 20px; font-weight: 900; color: var(--text); }
.comm-stat span { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.08em; text-align: center; }
.comm-events-label { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: 10px; }
.comm-event-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 12px; }
.comm-event-row:last-child { border-bottom: none; }
.comm-event-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.comm-event-dot.active { background: var(--nvg); box-shadow: 0 0 6px var(--nvg); animation: nvgPulse 1.8s ease-in-out infinite; }
.comm-event-dot.upcoming { background: var(--amber); }
.comm-event-name { flex: 1; color: var(--text-2); }
.comm-event-badge { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 6px; border-radius: 1px; }
.comm-event-live { background: var(--nvg-bg); color: var(--nvg); border: 1px solid var(--nvg-border); }
.comm-event-soon { background: var(--amber-bg); color: var(--amber-lt); border: 1px solid var(--amber-border); }
@media (max-width: 900px) { .communities-layout { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   ORGANIZATIONS SECTION
══════════════════════════════════════ */
.orgs-section { padding: var(--section-py) 0; background: var(--bg0); position: relative; overflow: hidden; }
.orgs-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--amber-border), transparent); }
.orgs-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: center; }
.orgs-features { display: flex; flex-direction: column; gap: 14px; margin: 28px 0; }
.org-feature { display: flex; align-items: flex-start; gap: 14px; }
.org-feat-icon { width: 40px; height: 40px; border-radius: 2px; background: var(--amber-bg); border: 1px solid var(--amber-border); display: flex; align-items: center; justify-content: center; color: var(--amber-lt); flex-shrink: 0; }
.org-feature strong { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; display: block; margin-bottom: 3px; color: var(--text); }
.org-feature span { font-size: 12px; color: var(--text-3); }
.org-card-preview { background: rgba(10,10,12,0.92); border: 1px solid var(--steel-border); border-top: 3px solid var(--amber); border-radius: 2px; padding: 24px; box-shadow: 0 24px 64px rgba(0,0,0,0.7); }
.org-card-top { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.org-logo-big { width: 60px; height: 60px; border-radius: 2px; background: linear-gradient(135deg, var(--amber-dk), var(--red-dk)); border: 1px solid var(--amber-border); display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 22px; font-weight: 900; color: var(--amber-lt); flex-shrink: 0; }
.org-name-big { font-family: var(--ff-display); font-size: 18px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 4px; }
.org-handle { font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; }
.org-tags { display: flex; gap: 6px; margin-top: 6px; flex-wrap: wrap; }
.org-tag { font-size: 9px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 7px; border-radius: 1px; }
.org-tag-gold { background: var(--brass-bg); color: var(--brass-lt); border: 1px solid var(--brass-border); }
.org-tag-red { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.org-roster-label { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: 10px; }
.org-roster { display: flex; flex-direction: column; gap: 0; }
.org-roster-row { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--line); }
.org-roster-row:last-child { border-bottom: none; }
.org-av-sm { width: 26px; height: 26px; border-radius: 1px; display: flex; align-items: center; justify-content: center; font-family: var(--ff-display); font-size: 11px; font-weight: 900; flex-shrink: 0; }
.org-av-r { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.org-av-b { background: var(--intel-bg); color: var(--intel); border: 1px solid var(--intel-border); }
.org-av-g { background: var(--nvg-bg); color: var(--nvg); border: 1px solid var(--nvg-border); }
.org-player-name { flex: 1; font-family: var(--ff-display); font-size: 12px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; }
.org-player-rank { font-size: 11px; color: var(--text-3); }
.org-player-xp { font-family: var(--ff-display); font-size: 10px; font-weight: 800; color: var(--intel); }
@media (max-width: 900px) { .orgs-layout { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   PUBLISHERS SECTION
══════════════════════════════════════ */
.publishers-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; overflow: hidden; }
.publishers-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--speed-border), transparent); }
.pub-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: center; }
.pub-kicker { color: var(--speed) !important; }
.pub-kicker::before { color: var(--speed) !important; }
.pub-desc { color: var(--text-2); font-size: 17px; line-height: 1.65; margin: 20px 0 32px; }
.pub-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 36px; }
.pub-pillar { background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; padding: 18px; transition: border-color var(--t), transform var(--t); }
.pub-pillar:hover { border-color: var(--speed-border); transform: translateY(-3px); }
.pub-pillar-icon { font-size: 22px; margin-bottom: 10px; }
.pub-pillar h4 { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 4px; }
.pub-pillar p { font-size: 11px; color: var(--text-3); line-height: 1.5; }
.pub-card { background: rgba(10,10,12,0.92); border: 1px solid var(--speed-border); border-top: 3px solid var(--speed); border-radius: 2px; padding: 24px; box-shadow: 0 24px 64px rgba(0,0,0,0.7); }
.pub-card-label { font-family: var(--ff-display); font-size: 10px; font-weight: 800; letter-spacing: 0.20em; text-transform: uppercase; color: var(--speed); margin-bottom: 20px; display: flex; align-items: center; gap: 8px; }
.pub-metrics { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border-radius: 1px; overflow: hidden; margin-bottom: 20px; }
.pub-metric { background: rgba(255,255,255,0.02); padding: 16px 12px; }
.pub-metric-num { font-family: var(--ff-display); font-size: 22px; font-weight: 900; color: var(--speed); line-height: 1; margin-bottom: 4px; }
.pub-metric-label { font-size: 10px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.10em; }
.pub-features-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.pub-feat { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--text-2); }
.pub-feat svg { flex-shrink: 0; color: var(--speed); }
@media (max-width: 900px) { .pub-layout { grid-template-columns: 1fr; } .pub-pillars { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   TRUST SECTION
══════════════════════════════════════ */
.trust-section { padding: var(--section-py) 0; background: var(--bg0); position: relative; overflow: hidden; }
.trust-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--nvg-border), transparent); }
.trust-header { text-align: center; margin-bottom: 52px; }
.trust-header .section-kicker { justify-content: center; color: var(--nvg); }
.trust-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin-bottom: 40px; }
.trust-pillar { background: var(--steel); border: 1px solid var(--steel-border); border-radius: 2px; padding: 24px 20px; text-align: center; transition: border-color var(--t), transform var(--t), box-shadow var(--t); }
.trust-pillar:hover { border-color: var(--nvg-border); transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.5), 0 0 16px var(--nvg-glow); }
.trust-icon { width: 48px; height: 48px; border-radius: 50%; background: var(--nvg-bg); border: 1px solid var(--nvg-border); display: flex; align-items: center; justify-content: center; color: var(--nvg); margin: 0 auto 14px; }
.trust-title { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 6px; }
.trust-desc { font-size: 11px; color: var(--text-3); line-height: 1.6; }
.trust-integrity-strip { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 24px 28px; background: var(--steel); border: 1px solid var(--nvg-border); border-left: 4px solid var(--nvg); border-radius: 2px; flex-wrap: wrap; }
.tis-left strong { font-family: var(--ff-display); font-size: 16px; font-weight: 900; letter-spacing: 0.06em; text-transform: uppercase; color: var(--nvg); display: block; margin-bottom: 4px; }
.tis-left p { font-size: 13px; color: var(--text-2); }
.tis-badge { display: flex; align-items: center; gap: 10px; }
.tis-badge-icon { font-size: 28px; }
.tis-badge-text strong { font-family: var(--ff-display); font-size: 13px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; color: var(--intel); display: block; }
.tis-badge-text span { font-size: 11px; color: var(--text-3); }
@media (max-width: 1100px) { .trust-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .trust-grid { grid-template-columns: 1fr 1fr; } }

/* ══════════════════════════════════════
   FAQ SECTION
══════════════════════════════════════ */
.faq-section { padding: var(--section-py) 0; background: var(--bg1); position: relative; }
.faq-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--neutral-border), transparent); }
.faq-layout { display: grid; grid-template-columns: 1fr 2fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.faq-sidebar p { font-size: 15px; color: var(--text-2); line-height: 1.65; margin-top: 14px; }
.faq-list { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--steel-border); border-radius: 2px; overflow: hidden; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item:last-child { border-bottom: none; }
.faq-q { width: 100%; background: none; text-align: left; padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; cursor: pointer; font-family: var(--ff-display); font-size: 15px; font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text); transition: background var(--t), color var(--t); }
.faq-q:hover { background: rgba(255,255,255,0.02); color: var(--red-lt); }
.faq-q-arrow { width: 20px; height: 20px; border-radius: 50%; background: var(--steel); border: 1px solid var(--steel-border); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: transform var(--t), background var(--t); }
.faq-item.open .faq-q { color: var(--red-lt); }
.faq-item.open .faq-q-arrow { transform: rotate(45deg); background: var(--red-bg); border-color: var(--red-border); color: var(--red-lt); }
.faq-a { display: none; padding: 0 24px 20px; font-size: 14px; color: var(--text-2); line-height: 1.7; }
.faq-item.open .faq-a { display: block; }
@media (max-width: 900px) { .faq-layout { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════
   IMPROVED ROADMAP (4-phase)
══════════════════════════════════════ */
.rm-phase-tag { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; padding: 2px 8px; border-radius: 1px; display: inline-flex; margin-bottom: 10px; }
.rm-phase-1 { background: var(--red-bg); color: var(--red-lt); border: 1px solid var(--red-border); }
.rm-phase-2 { background: var(--amber-bg); color: var(--amber-lt); border: 1px solid var(--amber-border); }
.rm-phase-3 { background: var(--r-epic-bg); color: var(--r-epic); border: 1px solid var(--r-epic-border); }
.rm-phase-4 { background: var(--steel-hi); color: var(--text-3); border: 1px solid var(--steel-edge); border-style: dashed; }

/* ══════════════════════════════════════
   DISCORD / COMMUNITY CTA CHIP
══════════════════════════════════════ */
.discord-chip {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(88,101,242,0.10); border: 1px solid rgba(88,101,242,0.25);
  border-radius: 2px; padding: 6px 14px;
  font-family: var(--ff-display); font-size: 11px; font-weight: 800;
  letter-spacing: 0.10em; text-transform: uppercase; color: #8b9cf7;
  transition: background var(--t), border-color var(--t);
  white-space: nowrap;
}
.discord-chip:hover { background: rgba(88,101,242,0.18); border-color: rgba(88,101,242,0.40); }
.discord-chip svg { flex-shrink: 0; }

/* ══════════════════════════════════════
   IMPROVED HERO SOCIAL PROOF ROW
══════════════════════════════════════ */
.hero-sp-row {
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
  padding-top: 20px; border-top: 1px solid var(--line);
  margin-top: 8px;
}
.hero-sp-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-3); }
.hero-sp-item strong { color: var(--text-2); font-family: var(--ff-display); font-weight: 900; font-size: 13px; }
.hero-sp-div { width: 1px; height: 14px; background: var(--line-hi); }

/* ══════════════════════════════════════
   CONCEPT / PREVIEW LABEL (single, clean)
══════════════════════════════════════ */
.preview-label-wrap { margin-bottom: 14px; }
.preview-label { font-family: var(--ff-display); font-size: 9px; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-4); background: var(--steel); border: 1px solid var(--line); padding: 3px 10px; border-radius: 1px; display: inline-flex; align-items: center; gap: 6px; }
.preview-label::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--red); box-shadow: 0 0 6px var(--red); animation: dotPulse 1.6s ease-in-out infinite; }

/* ══════════════════════════════════════
   ADDITIONAL MOBILE FIXES
══════════════════════════════════════ */
@media (max-width: 900px) {
  .ze-layout { grid-template-columns: 1fr; }
  .store-grid { grid-template-columns: repeat(2, 1fr); }
  .trust-grid { grid-template-columns: repeat(3, 1fr); }
  .sp-stats-row { grid-template-columns: repeat(2, 1fr); }
  .sp-quotes { grid-template-columns: 1fr; }
  .pub-layout { grid-template-columns: 1fr; }
  .orgs-layout { grid-template-columns: 1fr; }
  .communities-layout { grid-template-columns: 1fr; }
  .faq-layout { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .store-grid { grid-template-columns: 1fr 1fr; }
  .pub-pillars { grid-template-columns: 1fr; }
}


/* ── Richer grain texture ── */
body::before {
  opacity: 0.032;
  mix-blend-mode: soft-light;
}

/* ── Deep background with ambient glow ── */
body {
  background: var(--bg0);
  background-image:
    radial-gradient(ellipse 120% 60% at 50% 0%, rgba(184,24,32,0.04) 0%, transparent 60%),
    radial-gradient(ellipse 80% 40% at 80% 100%, rgba(201,154,18,0.025) 0%, transparent 55%);
}

/* ── Section separators — premium hairline gradient ── */
section + section {
  border-top: 1px solid transparent;
  background-clip: padding-box;
}

/* ── Section kicker — refined, no triangle ── */
.section-kicker {
  color: var(--amber-lt);
  letter-spacing: 0.28em;
}
.section-kicker::before {
  content: '';
  display: block;
  width: 20px; height: 2px;
  background: linear-gradient(90deg, var(--red), var(--amber));
  border-radius: 1px;
}
.section-kicker::after {
  width: 20px; height: 2px;
  background: linear-gradient(90deg, var(--amber), transparent);
  border-radius: 1px;
}

/* ── Section heading gradient — richer gold ── */
.section-h2 span {
  background: linear-gradient(100deg, var(--amber-lt), var(--brass-lt) 40%, var(--red-lt));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ── Premium NAV ── */
.nav.scrolled {
  background: rgba(7,7,11,0.92);
  backdrop-filter: blur(28px) saturate(160%) brightness(0.96);
  -webkit-backdrop-filter: blur(28px) saturate(160%) brightness(0.96);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  box-shadow: 0 1px 0 rgba(255,255,255,0.04), 0 8px 32px rgba(0,0,0,0.6);
}
.nav.scrolled::after {
  background: linear-gradient(90deg, transparent, var(--amber-lt), var(--red), transparent);
  opacity: 0.3;
}
.nav-wordmark {
  letter-spacing: 0.18em;
  color: var(--text);
  text-shadow: 0 0 32px rgba(240,160,32,0.10);
}
.nav-links a { color: var(--text-3); letter-spacing: 0.16em; }

/* ── Hero — deeper glow, richer backdrop ── */
.hero-glow-1 {
  background: radial-gradient(ellipse, rgba(184,24,32,0.16) 0%, rgba(201,154,18,0.08) 40%, transparent 70%);
  width: 600px; height: 600px;
}
.hero-glow-2 {
  background: radial-gradient(ellipse, rgba(68,136,238,0.06) 0%, rgba(184,24,32,0.04) 50%, transparent 75%);
}
.hero-grid {
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 52px 52px;
}
.hero-h1 {
  text-shadow: 0 0 80px rgba(0,0,0,0.8), 0 2px 0 rgba(0,0,0,0.9);
  letter-spacing: 0.008em;
}

/* ── Primary CTA — premium multi-layer ── */
.btn-red {
  background: linear-gradient(170deg, var(--red-lt) 0%, var(--red) 60%, #8a0c14 100%);
  border: 1px solid rgba(232,32,48,0.4);
  border-top: none;
  outline: 1px solid rgba(255,255,255,0.07);
  outline-offset: -2px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.18) inset,
    0 -1px 0 rgba(0,0,0,0.5) inset,
    0 6px 28px rgba(184,24,32,0.5),
    0 1px 0 rgba(0,0,0,0.6);
  letter-spacing: 0.14em;
}
.btn-red:hover {
  background: linear-gradient(170deg, #ff4050 0%, var(--red-lt) 55%, var(--red) 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.20) inset,
    0 -1px 0 rgba(0,0,0,0.5) inset,
    0 10px 44px rgba(184,24,32,0.65),
    0 0 0 1px rgba(232,32,48,0.3);
  transform: translateY(-2px);
}

/* ── Ghost button — premium glass ── */
.btn-ghost {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(8px);
  color: var(--text-3);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.07), 0 2px 8px rgba(0,0,0,0.4);
}
.btn-ghost:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.18);
  color: var(--text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.10), 0 4px 16px rgba(0,0,0,0.5);
}

/* ── Unlock CTA — boldest primary ── */
.btn-unlock {
  background: linear-gradient(170deg, #e82030 0%, #b81820 55%, #7a0010 100%);
  border: 1px solid rgba(232,32,48,0.35);
  border-top: none;
  outline: 1px solid rgba(255,255,255,0.08);
  outline-offset: -2px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.20) inset,
    0 -1px 0 rgba(0,0,0,0.6) inset,
    0 8px 40px rgba(184,24,32,0.6),
    0 2px 0 rgba(0,0,0,0.7);
  letter-spacing: 0.14em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.btn-unlock:hover {
  background: linear-gradient(170deg, #ff3545 0%, #e82030 55%, #b81820 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 -1px 0 rgba(0,0,0,0.6) inset,
    0 14px 56px rgba(184,24,32,0.75),
    0 0 0 1px rgba(232,32,48,0.35);
  transform: translateY(-3px);
  filter: none;
}

/* ── Speed CTA — premium gold ── */
.btn-speed {
  background: linear-gradient(160deg, #f8d840 0%, #d4a010 55%, #9a7000 100%);
  border: 1px solid rgba(201,154,18,0.35);
  border-top: none;
  outline: 1px solid rgba(255,255,255,0.12);
  outline-offset: -2px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.30) inset,
    0 -1px 0 rgba(0,0,0,0.5) inset,
    0 6px 28px rgba(201,154,18,0.45);
  color: #0a0800;
  text-shadow: 0 1px 0 rgba(255,255,255,0.2);
}
.btn-speed:hover {
  background: linear-gradient(160deg, #ffe050 0%, #f0b820 55%, #c08800 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.35) inset,
    0 -1px 0 rgba(0,0,0,0.5) inset,
    0 10px 44px rgba(201,154,18,0.60);
  transform: translateY(-2px);
  filter: none;
}

/* ── Identity card — deeper, more sculpted ── */
.identity-card {
  background: linear-gradient(160deg, rgba(14,14,22,0.97) 0%, rgba(8,8,14,0.99) 100%);
  border: 1px solid rgba(255,255,255,0.10);
  border-top: none;
  box-shadow:
    0 32px 80px rgba(0,0,0,0.95),
    4px 4px 0 rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.09),
    0 0 0 1px rgba(255,255,255,0.04);
}
.identity-card::before {
  background: linear-gradient(90deg, var(--red), var(--amber-lt), var(--brass-lt));
  height: 2px;
}

/* ── Panel cards — glass morphism upgrade ── */
.sp-quote,
.hiw-step,
.ze-card,
.store-item,
.comp-card,
.trust-pillar,
.pub-pillar,
.comm-card-visual,
.org-card-preview,
.apply-card,
.pub-card,
.gamer-card-preview {
  background: linear-gradient(160deg, rgba(255,255,255,0.048) 0%, rgba(255,255,255,0.020) 100%);
  border-color: rgba(255,255,255,0.090);
  box-shadow: 0 1px 0 rgba(255,255,255,0.07) inset, 0 8px 32px rgba(0,0,0,0.5);
}
.sp-quote:hover,
.store-item:hover,
.comp-card:hover,
.trust-pillar:hover {
  border-color: rgba(255,255,255,0.15);
  box-shadow: 0 1px 0 rgba(255,255,255,0.09) inset, 0 16px 48px rgba(0,0,0,0.65), 0 0 0 1px rgba(201,154,18,0.12);
}

/* ── Floating hero cards — deeper glass ── */
.fc-float {
  background: linear-gradient(160deg, rgba(14,14,22,0.98) 0%, rgba(8,8,14,0.99) 100%);
  box-shadow: 0 16px 56px rgba(0,0,0,0.95), 2px 2px 0 rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.08);
}

/* ── Stats rows — premium glass cells ── */
.sp-stat,
.ic-stat,
.lb-row {
  background: rgba(255,255,255,0.026);
}
.sp-stat-num.gold-num { color: var(--brass-lt); text-shadow: 0 0 24px var(--brass-glow), 0 0 8px rgba(201,154,18,0.2); }
.sp-stat-num.red-num  { text-shadow: 0 0 24px var(--red-glow), 0 0 8px rgba(184,24,32,0.2); }

/* ── Leaderboard rows ── */
.lb-table {
  background: rgba(255,255,255,0.022);
  border-color: rgba(255,255,255,0.090);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
.lb-featured { background: rgba(255,255,255,0.038) !important; }
.lb-you-row {
  background: linear-gradient(90deg, rgba(184,24,32,0.08) 0%, rgba(255,255,255,0.018) 100%);
}

/* ── Section backgrounds — richer depth ── */
.hero,
.games-section,
.orgs-section,
.trust-section { background: var(--bg0); }

.hiw,
.speed-section,
.gamercard-section,
.publishers-section,
.apply,
.seasonal-section { background: var(--bg1); }

.social-proof,
.rankings,
.competitions,
.communities-section,
.faq-section { background: var(--bg0); }

.ze-section,
.store-section { background: var(--bg1); }
.roadmap { background: var(--bg0); }
.founder { background: var(--bg1); }

/* ── Section top-edge accent lines — refined ── */
.hiw::before,
.speed-section::before,
.social-proof::before {
  background: linear-gradient(90deg, transparent 0%, rgba(201,154,18,0.25) 40%, rgba(184,24,32,0.2) 60%, transparent 100%);
}
.gamercard-section::before,
.ze-section::before,
.store-section::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,154,18,0.2), transparent);
}

/* ── Roadmap markers — more jewel-like ── */
.rm-marker {
  background: linear-gradient(160deg, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0.02) 100%);
  border-color: rgba(255,255,255,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 4px 16px rgba(0,0,0,0.5);
}
.active-marker {
  background: linear-gradient(160deg, rgba(184,24,32,0.28) 0%, rgba(184,24,32,0.14) 100%);
  border-color: var(--red-border);
  box-shadow: 0 0 24px rgba(184,24,32,0.4), inset 0 1px 0 rgba(255,255,255,0.12);
}

/* ── ZE wallet balance number — gold ── */
.ze-balance-num {
  color: var(--brass-lt);
  text-shadow: 0 0 32px rgba(201,154,18,0.5), 0 0 16px rgba(201,154,18,0.25);
}

/* ── Identity store rarity glows — richer ── */
.si-rarity-tag.-mythic,
.si-rarity-tag-mythic { box-shadow: 0 0 12px var(--brass-glow); }
.si-frame-mythic { box-shadow: 0 0 28px rgba(201,154,18,0.5) !important; }
.si-frame-legendary { box-shadow: 0 0 20px rgba(201,154,18,0.35) !important; }
.si-frame-epic { box-shadow: 0 0 16px rgba(153,85,238,0.4) !important; }

/* ── Trust integrity strip — richer ── */
.trust-integrity-strip {
  background: linear-gradient(100deg, rgba(14,14,22,0.85) 0%, rgba(8,8,14,0.90) 100%);
  border-color: rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 8px 32px rgba(0,0,0,0.5);
}

/* ── FAQ items — glass look ── */
.faq-item {
  background: linear-gradient(160deg, rgba(255,255,255,0.034) 0%, rgba(255,255,255,0.016) 100%);
  border-color: rgba(255,255,255,0.082);
}
.faq-item.open { border-color: rgba(201,154,18,0.26); box-shadow: 0 0 0 1px rgba(201,154,18,0.10) inset; }
.faq-q { color: var(--text-2); }
.faq-item.open .faq-q { color: var(--text); }

/* ── Gamer card preview — deeper depth ── */
.gamer-card-preview {
  background: linear-gradient(160deg, #0e0e18 0%, #08080f 100%);
  border-color: rgba(255,255,255,0.12);
  box-shadow:
    0 32px 80px rgba(0,0,0,0.9),
    inset 0 1px 0 rgba(255,255,255,0.10),
    0 0 0 1px rgba(255,255,255,0.04);
}
.gcp-top-bar {
  background: linear-gradient(90deg, var(--red), var(--amber-lt), var(--brass-lt));
  height: 2px;
}

/* ── Season track — premium ── */
.season-track-wrap {
  background: linear-gradient(160deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.018) 100%);
  border-color: rgba(255,255,255,0.09);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.07), 0 8px 40px rgba(0,0,0,0.5);
}

/* ── Hero pill — richer gold ── */
.hero-pill {
  background: rgba(201,154,18,0.09);
  border-color: rgba(201,154,18,0.30);
  border-left-color: var(--amber-lt);
  color: var(--amber-lt);
}

/* ── Live stats bar — subtle gradient ── */
.live-stats-bar {
  background: linear-gradient(90deg, rgba(9,9,14,0.98), rgba(11,11,18,0.98));
  border-color: rgba(255,255,255,0.065);
  box-shadow: 0 1px 0 rgba(255,255,255,0.04) inset;
}

/* ── Form fields — premium glass ── */
.acard-form input,
.acard-form select,
.acard-form textarea {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
  color: var(--text);
  box-shadow: inset 0 1px 4px rgba(0,0,0,0.4), inset 0 0 0 1px rgba(0,0,0,0.3);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.acard-form input:focus,
.acard-form select:focus {
  border-color: rgba(201,154,18,0.40);
  background: rgba(255,255,255,0.055);
  box-shadow: inset 0 1px 4px rgba(0,0,0,0.4), 0 0 0 3px rgba(201,154,18,0.12);
  outline: none;
}

/* ── Apply card — premium glass ── */
.apply-card {
  background: linear-gradient(160deg, rgba(255,255,255,0.048) 0%, rgba(255,255,255,0.020) 100%);
  border-color: rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 16px 56px rgba(0,0,0,0.6);
}

/* ── FOMO counter ── */
.fomo-counter {
  background: linear-gradient(100deg, rgba(184,24,32,0.10) 0%, rgba(184,24,32,0.04) 100%);
  border-color: rgba(184,24,32,0.28);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 4px 16px rgba(184,24,32,0.15);
}

/* ── CTA strip — premium ── */
.cta-strip {
  background: linear-gradient(100deg, rgba(184,24,32,0.12) 0%, rgba(255,255,255,0.030) 50%, rgba(201,154,18,0.08) 100%);
  border-color: rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 0 60px rgba(184,24,32,0.10);
}

/* ── Footer — rich dark ── */
.footer {
  background: linear-gradient(180deg, var(--bg0) 0%, #050508 100%);
  border-top-color: rgba(255,255,255,0.07);
  box-shadow: 0 -1px 0 rgba(255,255,255,0.04);
}
.footer-bar { border-top-color: rgba(255,255,255,0.06); }

/* ── Preview labels — refined ── */
.preview-label {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.10);
  color: var(--text-3);
  backdrop-filter: blur(8px);
}

/* ── Mythic shimmer keyframe — richer colors ── */
@keyframes mythicShimmer {
  0%   { background-position: 0%   50%; }
  25%  { background-position: 50%  0%;  }
  50%  { background-position: 100% 50%; }
  75%  { background-position: 50%  100%;}
  100% { background-position: 0%   50%; }
}

/* ── Scrollbar — premium dark ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg0); }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.10); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(201,154,18,0.35); }

/* ── Selection highlight ── */
::selection {
  background: rgba(184,24,32,0.35);
  color: var(--text);
}

/* ── Focus ring — gold ── */
:focus-visible {
  outline: 2px solid rgba(201,154,18,0.6);
  outline-offset: 3px;
}

/* ── Premium body font — Inter for body copy ── */

body {
  font-size: 15px;
  letter-spacing: -0.01em;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Hero tagline — gold accent ── */
.hero-tagline {
  color: var(--text-4);
  letter-spacing: 0.28em;
}
.hero-tagline em { color: var(--brass-lt); font-style: normal; }

/* ── Hero desc — slightly lighter ── */
.hero-desc { color: var(--text-2); font-size: 16px; line-height: 1.75; }

/* ── Nav link underline — gold ── */
.nav-links a::after { background: var(--amber-lt); }
.nav-links a.active { color: var(--amber-lt); text-shadow: 0 0 14px rgba(201,154,18,0.35); }
.nav-links a.active::after { background: var(--amber-lt); transform: scaleX(1); }

/* ── Rankings tab active — gold ── */
.rtab.active { color: var(--amber-lt); }
.rtab.speed-rtab.active { color: var(--speed-lt); }

/* ── Competitive identity heading gradient — override ── */
.identity-card::before { opacity: 1; }

/* ── ZE Coin earn item — refined ── */
.ze-earn-item { border-bottom-color: rgba(255,255,255,0.05); }
.ze-earn-item:last-child { border-bottom: none; }

/* ── Store item rarity ring on hover ── */
.store-item:hover .store-item-preview { transform: scale(1.03); }
.store-item-preview { transition: transform 0.3s cubic-bezier(0.16,1,0.3,1); }

/* ── Org/Comm card headers — premium ── */
.comm-card-visual,
.org-card-preview {
  background: linear-gradient(160deg, rgba(255,255,255,0.042) 0%, rgba(255,255,255,0.018) 100%);
}

/* ── Speed UI — more dramatic ── */
.speed-ui {
  box-shadow: 0 32px 80px rgba(0,0,0,0.85), 0 0 0 1px rgba(255,224,27,0.10);
}
.sui-score-num {
  text-shadow: 0 0 40px rgba(255,224,27,0.3), 0 0 20px rgba(255,224,27,0.15);
}

/* ── Gamer card shine — animated ── */
.gcp-shine {
  background: linear-gradient(105deg, transparent 35%, rgba(255,255,255,0.06) 50%, transparent 65%);
  animation: cardShine 4s ease-in-out infinite;
}
@keyframes cardShine {
  0%,100% { opacity: 0; transform: translateX(-100%) skewX(-10deg); }
  50% { opacity: 1; transform: translateX(200%) skewX(-10deg); }
}

/* ── Trust icons — gold ring ── */
.trust-icon {
  background: linear-gradient(160deg, rgba(201,154,18,0.12) 0%, rgba(201,154,18,0.04) 100%);
  border-color: rgba(201,154,18,0.22);
  box-shadow: 0 0 20px rgba(201,154,18,0.10), inset 0 1px 0 rgba(255,255,255,0.08);
  color: var(--amber-lt);
}

/* ── Roadmap feature tags — more visible ── */
.rm-features span {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.09);
  color: var(--text-3);
}
.rm-item.rm-active .rm-features span {
  background: rgba(184,24,32,0.10);
  border-color: rgba(184,24,32,0.22);
  color: var(--text-2);
}

/* ── Founder quote border — richer ── */
.founder-quote {
  border-left-color: var(--amber-lt);
  color: var(--text);
}

/* ── Pill / badge adjustments ── */
.hero-pill { letter-spacing: 0.22em; }

/* ── Section spacing — more breathing room ── */


/* ── Live stats bar divider dots ── */
.lsb-div { background: rgba(255,255,255,0.12); }

/* ── Competition featured card ── */
.featured-comp {
  background: linear-gradient(160deg, rgba(184,24,32,0.10) 0%, rgba(255,255,255,0.028) 60%, rgba(201,154,18,0.06) 100%);
  border-color: rgba(184,24,32,0.35);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.09), 0 16px 56px rgba(184,24,32,0.20);
}

/* ── Score / stat numbers — richer weight ── */
.sp-stat-num, .fomo-num, .pub-metric-num {
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}

/* ═══════════════════════════════════════════════════════════════
   CONTRAST & COLOR CONSISTENCY FIXES
═══════════════════════════════════════════════════════════════ */

/* ── Nav links — use text-2 as base so they're readable ── */
.nav-links a { color: var(--text-3); }
.nav-links a:hover { color: var(--text-2); }
.nav-mobile a { color: var(--text-3); }

/* ── Hero tagline — bump to text-3 (now readable) ── */
.hero-tagline { color: var(--text-3); }
.hero-cta-note { color: var(--text-3); }

/* ── Hero card labels — dim but visible ── */
.ic-stat-label,
.ic-progress-label,
.ic-recent-label,
.ic-xp-label { color: var(--text-4); }

/* ── Floating card labels ── */
.fc-label { color: var(--text-4); }

/* ── How It Works step number + body text ── */
.hiw-num { color: var(--text-4); }
.hiw-step p { color: var(--text-2); }

/* ── Brand strip ── */
.strip-track span { color: var(--text-3); }

/* ── Leaderboard table header — needs to be readable ── */
.lb-thead { color: var(--text-3); }
.lb-team { color: var(--text-3); }
.lb-wl { color: var(--text-3); }
.lb-pos { color: var(--text-3); }

/* ── Speed UI labels ── */
.sui-score-label { color: var(--text-3); }
.sui-lb-header { color: var(--text-3); }
.sui-r { color: var(--text-3); }

/* ── Competition cards ── */
.cc-game { color: var(--text-3); }
.cc-detail { color: var(--text-3); }
.cc-fill-label { color: var(--text-3); }
.comp-note { color: var(--text-3); }
.phase2-note { color: var(--text-3); }

/* ── Games section ── */
.gc-sub { color: var(--text-3); }
.gc-tag { color: var(--text-3); }
.gc-upcoming-badge { color: var(--text-3); }
.gc-more-body { color: var(--text-3); }
.upcoming-gsl { color: var(--text-3); }

/* ── Profile card labels ── */
.cpf-rank-pts { color: var(--text-3); }
.cpf-stat span { color: var(--text-3); }
.cpf-prog-label { color: var(--text-3); }
.cpf-badges-label { color: var(--text-4); }
.cpf-history-label { color: var(--text-4); }
.cpf-match-time { color: var(--text-4); }
.cb-name { color: var(--text-3); }

/* ── Speed Arena feature bullets ── */
.sf-item span { color: var(--text-2); }

/* ── Season reward track labels ── */
.sr-level { color: var(--text-3); }
.sr-reward-name { color: var(--text-3); }

/* ── Form fields ── */
.form-note { color: var(--text-3); }
.fg label { color: var(--text-3); }
.fg input::placeholder,
.fg select::placeholder { color: var(--text-4); }

/* ── Apply section ── */
.ap-slots-note { color: var(--text-3); }
.ap-slots-note svg { color: var(--text-4); }
.ap-perk { color: var(--text-2); }
.ap-desc { color: var(--text-2); }

/* ── Footer bar ── */
.footer-bar { color: var(--text-3); }

/* ── Preview label — text-3, not text-4 ── */
.preview-label { color: var(--text-3) !important; }

/* ── Rarity note ── */
.rarity-note { color: var(--text-3); }

/* ── Quest board label ── */
.quests-board-label { color: var(--text-3); }
.quest-progress-text { color: var(--text-3); }

/* ── Walkthrough step labels ── */
.wt-step-label { color: var(--text-3); }

/* ── Level list ── */
.ll-reward { color: var(--text-3); }

/* ── Rank count label ── */
.rt-count { color: var(--text-3); }

/* ── Concept label bar ── */
.concept-label-bar { color: var(--text-3); }

/* ── Division arrows ── */
.div-arrow { color: var(--text-3); }

/* ── Discord nav link — use CSS var instead of hardcoded ── */

.nav-mobile [href*="discord.gg"] { color: var(--discord-color) !important; }

/* ── Hardcoded bronze rank color — keep as accent, no change needed ── */

/* ── ZE Coins wallet section micro-labels — bump from text-4 ── */
.ze-wallet-meta span,
.ze-section small,
[style*="--text-4"][style*="9px"] { color: var(--text-3); }

/* ── Tiny 9px labels in HTML (ZE header labels) ── 
   These use inline style="color:var(--text-4);font-size:9px"
   Override via parent context ── */
.ze-card-head-earn span,
.ze-card-head-wallet span,
.ze-card-head-spend span { color: var(--text-3); }

/* ── Match time / XP labels (identity card) ── */
.ic-match-time { color: var(--text-4); }

/* ── Hero launch row sub-text ── */
.hli-sub { color: var(--text-3); }

/* ── Hero scroll indicator ── */
.hero-scroll { color: var(--text-3); }

/* ── Social proof quote author info ── */
.sq-role { color: var(--text-3); }
.sq-badge-row { opacity: 0.85; }

/* ── Section description paragraphs — ensure text-2 minimum ── */
.section-desc,
.hero-desc,
.gc-desc,
.speed-desc,
.comm-desc,
.pub-desc,
.founder-para { color: var(--text-2); }

/* ── Roadmap ── */
.rm-sub { color: var(--text-2); }
.rm-content p { color: var(--text-2); }

/* ── Section card micro-labels — bump to text-3 for readability ── */
.ze-balance-label,
.ze-meta-label { color: var(--text-3); }

.ze-tx-time { color: var(--text-4); }   /* timestamps — dim is fine */

.store-item-type { color: var(--text-3); }

.comm-stat span,
.comm-events-label { color: var(--text-3); }

.org-roster-label { color: var(--text-3); }

.pub-metric-label { color: var(--text-3); }

/* ── Wallet section ── */
.ze-wallet-meta,
.ze-wallet-balance { color: var(--text-3); }

/* ── Footer bar — slightly brighter ── */
.footer-bar { color: var(--text-3); }

/* ── Concept label bar inside cards ── */
.concept-label-bar { color: var(--text-3); }

/* ── Level list reward text ── */
.ll-header { color: var(--text-2); }

/* ── Hero-cta note — readable helper text ── */
.hero-cta-note { color: var(--text-3); }

/* ── Speed Arena rank num for #2 ── */
.sui-lb-row .sui-r:not(.gold-r) { color: var(--text-3); }

/* ═══════════════════════════════════════════════════════════════
   FREE IMAGE INTEGRATION
═══════════════════════════════════════════════════════════════ */

/* ── Hero background photo ── */
.hero-bg-photo {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 30%;
  opacity: 0.09;
  filter: grayscale(0.5) saturate(0.5) blur(0px);
  mix-blend-mode: luminosity;
  pointer-events: none;
  z-index: 0;
}

/* Strengthen the gradient overlays so text stays crisp */
.hero-glow-1 { z-index: 1; }
.hero-glow-2 { z-index: 1; }
.hero-grid   { z-index: 2; }
.hero-fade   { z-index: 3; }
.hero-wrap   { z-index: 4; }
.hero-scroll { z-index: 4; }

/* ── Social proof photo avatars ── */
.sp-av-photo {
  width: 44px; height: 44px;
  border-radius: 2px;
  overflow: hidden;
  border: 2px solid var(--steel-edge);
  flex-shrink: 0;
  box-shadow: 0 0 0 1px var(--line-md);
  background: var(--steel);
}
.sp-av-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: saturate(0.7) brightness(0.9);
}
.sp-av-photo img:hover {
  filter: saturate(1) brightness(1);
  transition: filter 0.3s;
}

/* ── Game card background photos ── */
.gc-bg {
  position: relative;
  overflow: hidden;
}
.gc-bg-photo {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.22;
  filter: grayscale(0.3) saturate(0.6);
  mix-blend-mode: luminosity;
  transition: opacity 0.4s ease, filter 0.4s ease;
  pointer-events: none;
  z-index: 0;
}
.game-card:hover .gc-bg-photo {
  opacity: 0.35;
  filter: grayscale(0) saturate(0.8);
}
/* Keep the text labels above the photo */
.gc-bg > *:not(.gc-bg-photo) { position: relative; z-index: 1; }

/* ── Championships background photo ── */
.competitions {
  position: relative;
  overflow: hidden;
}
.comp-bg-photo {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 40%;
  opacity: 0.05;
  filter: grayscale(0.4) saturate(0.5);
  mix-blend-mode: luminosity;
  pointer-events: none;
  z-index: 0;
}
.competitions .wrap { position: relative; z-index: 1; }

/* ── Founder section background photo ── */
.founder {
  position: relative;
  overflow: hidden;
}
.founder-bg-photo {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.04;
  filter: grayscale(0.6) saturate(0.4);
  mix-blend-mode: luminosity;
  pointer-events: none;
  z-index: 0;
}
/* Subtle vignette to keep text readable */
.founder::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 80% at 50% 50%, transparent 30%, var(--bg1) 90%);
  pointer-events: none;
  z-index: 0;
}
.founder .wrap { position: relative; z-index: 1; }

/* ── Communities section background photo ── */
.communities-section {
  position: relative;
  overflow: hidden;
}
.section-bg-photo {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.04;
  filter: grayscale(0.5) saturate(0.4);
  mix-blend-mode: luminosity;
  pointer-events: none;
  z-index: 0;
}
.communities-section .wrap { position: relative; z-index: 1; }

/* ── Speed Arena hero photo (right panel ambient) ── */
.speed-section { overflow: hidden; }


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  VALORANT OVERHAUL — Full visual redesign                       ║
   ║  Riot Games / Valorant aesthetic: sharp geometry, vivid red,    ║
   ║  opaque dark panels, angular cuts, high-energy typography       ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── 1. Color system reset — Valorant palette ── */


/* ── 2. Body — cool-tinted dark base ── */
body {
  background: var(--bg0);
  background-image:
    radial-gradient(ellipse 100% 50% at 50% 0%,   rgba(255,70,85,0.05) 0%, transparent 55%),
    radial-gradient(ellipse 60%  40% at 90% 100%,  rgba(200,155,60,0.04) 0%, transparent 50%);
}

/* ── 3. Section alternation — break visual monotony ── */
section { background: var(--bg0); }
#competitive-identity, #store,     #communities,
#championships,        #roadmap,   #apply          { background: var(--bg-alt); }
#how-it-works,         #rankings,  #organizations,
#trust,                #faq                        { background: var(--bg1); }

/* ── 4. Angular diagonal cuts between sections ── */
.hero {
  clip-path: polygon(0 0, 100% 0, 100% 92%, 0 100%);
  padding-bottom: calc(var(--section-py) + 72px);
}
.cta-strip {
  clip-path: polygon(0 5%, 100% 0, 100% 100%, 0 100%);
  padding-top: calc(var(--section-py) + 60px);
  margin-top: -40px;
}
#championships {
  clip-path: polygon(0 3%, 100% 0, 100% 97%, 0 100%);
  padding-top: calc(var(--section-py) + 40px);
  padding-bottom: calc(var(--section-py) + 40px);
}

/* ── 5. Cards — strip glassmorphism, use opaque Valorant panels ── */
.sp-quote,
.hiw-step,
.ze-card,
.store-item,
.comp-card,
.trust-pillar,
.pub-pillar,
.comm-card-visual,
.org-card-preview,
.apply-card,
.pub-card,
.gamer-card-preview,
.ci-pillar,
.int-pillar,
.rm-item {
  background: var(--bg2) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 1px !important;
  box-shadow: none !important;
}

/* Card hover — red glow border instead of glass shimmer */
.sp-quote:hover,
.store-item:hover,
.comp-card:hover,
.trust-pillar:hover,
.ci-pillar:hover,
.rm-item:hover,
.hiw-step:hover {
  border-color: rgba(255,70,85,0.40) !important;
  box-shadow: 0 0 0 1px rgba(255,70,85,0.15) inset, 0 8px 28px rgba(0,0,0,0.5) !important;
  transform: translateY(-3px) !important;
}

/* Left accent stripe on key cards */
.ci-pillar  { border-left: 2px solid var(--red-border) !important; }
.hiw-step   { border-top:  2px solid var(--red-border) !important; }
.rm-item    { border-left: 2px solid rgba(200,155,60,0.30) !important; }
.comp-card  { border-top:  2px solid var(--red-border) !important; }
.trust-pillar { border-top: 2px solid rgba(200,155,60,0.30) !important; }

/* ── 6. Buttons — sharp, uppercase, Valorant energy ── */
.btn-red {
  background: var(--red) !important;
  background-image: none !important;
  border-radius: 2px !important;
  box-shadow: none !important;
  text-transform: uppercase !important;
  letter-spacing: 0.10em !important;
  font-weight: 800 !important;
  transition: background var(--t), transform var(--t), box-shadow var(--t), filter var(--t) !important;
}
.btn-red:hover {
  background: var(--red-lt) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 32px rgba(255,70,85,0.50) !important;
  filter: none !important;
}
.btn-red::after { display: none !important; } /* remove shimmer sweep */

.btn-ghost {
  border-radius: 2px !important;
  border-color: rgba(255,255,255,0.16) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.10em !important;
  font-weight: 700 !important;
}
.btn-ghost:hover {
  border-color: var(--red) !important;
  color: var(--text) !important;
  background: rgba(255,70,85,0.08) !important;
  box-shadow: none !important;
}

.btn-unlock, .btn-speed, .btn-comp {
  border-radius: 2px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}
.btn-comp:hover {
  background: var(--red) !important;
  color: var(--text) !important;
  border-color: var(--red) !important;
}

/* ── 7. Section headings — bolder, tighter Valorant scale ── */
.section-h2 {
  font-size: clamp(2.2rem, 5vw, 3.4rem) !important;
  letter-spacing: -0.01em !important;
  line-height: 1.05 !important;
}
.section-h2 span { color: var(--red) !important; }

/* Hero heading — massive, cinematic */
.hero-h1 {
  font-size: clamp(3rem, 8vw, 5.8rem) !important;
  line-height: 1.0 !important;
  letter-spacing: -0.02em !important;
}
.hero-tagline em { color: var(--red) !important; }

/* ── 8. Nav — sharper, red active indicator ── */
.nav-links a.active { color: var(--red) !important; }
.nav-links a.active::after { background: var(--red) !important; }
.nav.scrolled {
  background: rgba(15,17,23,0.97) !important;
  border-bottom-color: rgba(255,70,85,0.15) !important;
  box-shadow: 0 1px 0 rgba(255,70,85,0.08), 0 8px 32px rgba(0,0,0,0.6) !important;
}

/* ── 9. Brand strip / dividers — red accent line ── */
.brand-strip {
  background: var(--bg3) !important;
  border-top: 1px solid rgba(255,70,85,0.15) !important;
  border-bottom: 1px solid rgba(255,70,85,0.15) !important;
}

/* ── 10. Rankings — Valorant leaderboard energy ── */
.rtab.active {
  background: var(--red) !important;
  color: var(--text) !important;
  box-shadow: 0 4px 16px rgba(255,70,85,0.40) !important;
}
.lb-row:hover { background: rgba(255,70,85,0.05) !important; }
.gold-pos   { color: #f0c060 !important; }
.silver-pos { color: #b8c8d8 !important; }
.bronze-pos { color: #e08844 !important; }

/* ── 11. Rarity badges — keep but sharper ── */
.badge-legendary { color: #f0c060 !important; border-color: rgba(240,192,96,0.30) !important; }
.badge-epic      { color: #c060ff !important; border-color: rgba(192,96,255,0.28) !important; }
.badge-rare      { color: #4499ff !important; border-color: rgba(68,153,255,0.28) !important; }

/* ── 12. Scroll reveal — snappier speed ── */
.reveal {
  opacity: 0 !important;
  transform: translateY(20px) !important;
  transition: opacity 0.35s ease, transform 0.35s ease !important;
}
.reveal.in {
  opacity: 1 !important;
  transform: none !important;
}

/* ── 13. Season / speed ring — red accent ── */
.sui-ring { border-color: rgba(255,70,85,0.15) !important; }
.sui-ring-fill { stroke: var(--red) !important; }

/* ── 14. Live stats bar — stronger separation ── */
.live-stats-bar {
  background: linear-gradient(90deg, rgba(15,17,23,0.96) 0%, rgba(26,29,39,0.96) 100%) !important;
  border-top: 1px solid rgba(255,70,85,0.12) !important;
  border-bottom: 1px solid rgba(255,70,85,0.12) !important;
}

/* ── 15. Footer — dark anchored base ── */
.site-footer {
  background: var(--bg3) !important;
  border-top: 1px solid rgba(255,70,85,0.12) !important;
}
.footer-brand-name { color: var(--text) !important; }

/* ── 16. Apply track switcher ── */
.tsw.active {
  background: var(--red) !important;
  color: var(--text) !important;
}

/* ── 17. FAQ ── */
.faq-item { border-color: rgba(255,255,255,0.07) !important; border-radius: 1px !important; }
.faq-item.open {
  border-color: rgba(255,70,85,0.30) !important;
  box-shadow: none !important;
}
.faq-item.open .faq-q { color: var(--red) !important; }

/* ── 18. XP bar fill — red → gold gradient ── */
.ic-bar-fill {
  background: linear-gradient(90deg, var(--red) 0%, var(--brass-lt) 100%) !important;
}
.cpf-prog-fill { background: var(--red) !important; }

/* ── 19. Game cards — high-contrast hover ── */
.game-card { border-radius: 1px !important; background: var(--bg1) !important; border: 1px solid rgba(255,255,255,0.07) !important; }
.game-card:hover { border-color: var(--red) !important; box-shadow: 0 0 0 1px rgba(255,70,85,0.12) inset, 0 12px 40px rgba(0,0,0,0.6) !important; }

/* ── 20. Section decorative badge labels ── */
.section-badge, .preview-label, .section-eyebrow, .lsb-label, .store-badge,
.cc-badge, .ri-label, .stat-label, .sp-stat-label {
  color: var(--red) !important;
  border-color: rgba(255,70,85,0.22) !important;
  background: rgba(255,70,85,0.08) !important;
}

/* ── 21. Scrollbar — dark themed ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg0); }
::-webkit-scrollbar-thumb { background: rgba(255,70,85,0.35); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,70,85,0.60); }


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  MOBILE OPTIMISATION — Full pass                                ║
   ║  Breakpoints: 900px (tablet) · 600px (phone) · 420px (small)   ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── Tablet (≤ 900px) ─────────────────────────────────────── */
@media (max-width: 900px) {
  :root { --section-py: 60px; }

  /* Soften diagonal cuts — less aggressive on tablet */
  .hero        { clip-path: polygon(0 0, 100% 0, 100% 95%, 0 100%); padding-bottom: calc(60px + 48px); }
  .cta-strip   { clip-path: polygon(0 4%, 100% 0, 100% 100%, 0 100%); padding-top: calc(72px + 40px); margin-top: -28px; }
  #championships { clip-path: polygon(0 2%, 100% 0, 100% 98%, 0 100%); }

  /* Section headings */
  .section-h2 { font-size: clamp(1.9rem, 4.5vw, 2.6rem) !important; }

  /* Games grid — 2 col */
  .games-grid  { grid-template-columns: repeat(2, 1fr) !important; }

  /* Rankings leaderboard — hide 2 right cols */
  .lb-thead, .lb-row, .lb-you-row {
    grid-template-columns: 44px 1fr 80px 70px !important;
  }
  .lb-thead > div:nth-child(5),
  .lb-row   > div:nth-child(5),
  .lb-you-row > div:nth-child(5),
  .lb-thead > div:nth-child(6),
  .lb-row   > div:nth-child(6),
  .lb-you-row > div:nth-child(6) { display: none; }

  /* Speed layout — stack */
  .speed-layout { gap: 32px; }

  /* Org / pub grids */
  .org-grid, .pub-grid { grid-template-columns: 1fr 1fr !important; }

  /* Apply split */
  .apply-content { gap: 32px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }

  /* Nav CTA */
  .btn-nav { display: none; }
}

/* ── Phone (≤ 600px) ──────────────────────────────────────── */
@media (max-width: 600px) {
  :root {
    --section-py: 44px;
    --wrap-px:    18px;
  }

  /* ---- clip-paths: flatten on small screens ---- */
  .hero        { clip-path: polygon(0 0, 100% 0, 100% 97%, 0 100%); padding-bottom: calc(44px + 28px); }
  .cta-strip   { clip-path: polygon(0 3%, 100% 0, 100% 100%, 0 100%); padding-top: calc(56px + 28px); margin-top: -16px; }
  #championships { clip-path: none; padding-top: 56px; padding-bottom: 56px; }

  /* ---- Typography ---- */
  .hero-h1     { font-size: clamp(2.4rem, 11vw, 3.6rem) !important; line-height: 1.02 !important; }
  .section-h2  { font-size: clamp(1.7rem, 6.5vw, 2.2rem) !important; }
  .hero-desc, .section-desc { font-size: 14px; }

  /* ---- Hero ---- */
  .hero-cta    { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-cta .btn-red, .hero-cta .btn-ghost { width: 100%; justify-content: center; text-align: center; }
  .hero-badges { flex-wrap: wrap; gap: 6px; }

  /* ---- Brand strip — pause marquee, prevent overflow ---- */
  .brand-strip-inner { animation-play-state: paused; }

  /* ---- Live stats bar — 2 col ---- */
  .lsb-inner   { grid-template-columns: 1fr 1fr !important; }
  .lsb-stat:nth-child(3), .lsb-stat:nth-child(4) { border-top: 1px solid var(--line); }

  /* ---- How It Works — single column ---- */
  .hiw-steps   { flex-direction: column; align-items: stretch; }
  .hiw-step    { max-width: 100%; min-width: unset; }
  .hiw-arrow   { display: none; }

  /* ---- Social proof ---- */
  .sp-stats-row { grid-template-columns: 1fr 1fr !important; }
  .sp-quotes    { grid-template-columns: 1fr !important; }

  /* ---- XP & Levels ---- */
  .xp-layout   { grid-template-columns: 1fr !important; }
  .cpf-badges  { grid-template-columns: repeat(4, 1fr) !important; }
  .cpf-stats-row{ grid-template-columns: repeat(2, 1fr) !important; }

  /* ---- Badge rarity ---- */
  .rt-tier     { grid-template-columns: 1fr !important; }
  .rt-label    { border-right: none !important; border-bottom: 1px solid var(--line); }
  .rt-count    { display: none; }

  /* ---- Rankings leaderboard — 3 col ---- */
  .lb-thead, .lb-row, .lb-you-row {
    grid-template-columns: 36px 1fr 70px !important;
  }
  .lb-thead > div:nth-child(4),
  .lb-row   > div:nth-child(4),
  .lb-you-row > div:nth-child(4),
  .lb-thead > div:nth-child(5),
  .lb-row   > div:nth-child(5),
  .lb-you-row > div:nth-child(5),
  .lb-thead > div:nth-child(6),
  .lb-row   > div:nth-child(6),
  .lb-you-row > div:nth-child(6) { display: none; }

  /* ---- Store — 1 col ---- */
  .store-grid  { grid-template-columns: 1fr !important; }

  /* ---- Games — 2 col ---- */
  .games-grid  { grid-template-columns: repeat(2, 1fr) !important; }

  /* ---- Championships ---- */
  .comp-cards  { grid-template-columns: 1fr !important; }
  .s1-grid     { grid-template-columns: 1fr !important; }

  /* ---- Orgs / Pub ---- */
  .org-grid, .pub-grid { grid-template-columns: 1fr !important; }

  /* ---- Trust grid — 2 col ---- */
  .trust-grid  { grid-template-columns: repeat(2, 1fr) !important; }

  /* ---- Communities ---- */
  .communities-layout { grid-template-columns: 1fr !important; }

  /* ---- Seasonal rewards ---- */
  .sr-track    { overflow-x: auto; padding-bottom: 12px; -webkit-overflow-scrolling: touch; }
  .sr-nodes    { min-width: 440px; }

  /* ---- Gamer card ---- */
  .gc-layout   { grid-template-columns: 1fr !important; }
  .gamer-card-preview { max-width: 100%; }

  /* ---- Roadmap ---- */
  .rm-item     { grid-template-columns: 44px 1fr; gap: 14px; }
  .rm-timeline::before { left: 22px; }

  /* ---- Apply ---- */
  .track-switcher { width: 100%; }
  .tsw         { flex: 1; justify-content: center; }
  .field-row2  { grid-template-columns: 1fr; }
  .apply-split { grid-template-columns: 1fr !important; }

  /* ---- FAQ ---- */
  .faq-layout  { grid-template-columns: 1fr !important; }

  /* ---- CTA strip ---- */
  .cta-strip   { flex-direction: column !important; align-items: stretch !important; gap: 14px !important; }
  .cta-strip .btn-red { width: 100%; justify-content: center; }

  /* ---- Footer ---- */
  .footer-grid { grid-template-columns: 1fr !important; gap: 28px; }
  .footer-brand { margin-bottom: 24px; }

  /* ---- Section eyebrow badges ---- */
  .section-badge { font-size: 10px; }

  /* ---- Touch targets — WCAG 2.5.5 ---- */
  .rtab, .tsw, .faq-q { min-height: 44px; }
  .btn-red, .btn-ghost, .btn-unlock, .btn-comp, .btn-speed { min-height: 46px; }
  .nav-mobile a { min-height: 44px; display: flex; align-items: center; }

  /* ---- Form inputs — prevent iOS auto-zoom ---- */
  .fg input, .fg select, .fg textarea { font-size: 16px !important; }

  /* ---- ZE Coins layout ---- */
  .ze-layout   { grid-template-columns: 1fr !important; }
  .ze-bottom   { grid-template-columns: 1fr 1fr !important; }
}

/* ── Small phone (≤ 420px) ────────────────────────────────── */
@media (max-width: 420px) {
  :root {
    --section-py: 36px;
    --wrap-px:    14px;
  }

  .hero-h1    { font-size: clamp(2.1rem, 12vw, 2.8rem) !important; }
  .section-h2 { font-size: clamp(1.5rem, 7vw, 2rem) !important; }

  /* Games — 1 col */
  .games-grid { grid-template-columns: 1fr !important; }

  /* Badge grid — 3 col */
  .cpf-badges { grid-template-columns: repeat(3, 1fr) !important; }

  /* Trust — 2 col */
  .trust-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Ze bottom — 1 col */
  .ze-bottom  { grid-template-columns: 1fr !important; }

  /* Leaderboard — player + score only */
  .lb-thead, .lb-row, .lb-you-row {
    grid-template-columns: 32px 1fr 64px !important;
  }

  /* Nav logo text — hide on tiny screens */
  .nav-logo-tagline { display: none; }

  /* Store — 1 col */
  .store-grid { grid-template-columns: 1fr !important; }
}

/* ── Horizontal overflow guard (all sizes) ── */
html, body { overflow-x: hidden; max-width: 100vw; }
.wrap { overflow: visible; }
section { overflow: hidden; }


/* ── Hero h1 <em> — "Permanently Yours." — Valorant red, always visible ── */
.hero-h1 em {
  background: linear-gradient(90deg, var(--red-lt) 0%, var(--red) 50%, var(--red-lt) 100%) !important;
  background-size: 200% auto !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  font-style: normal !important;
  animation: brandGradient 3s ease infinite !important;
}

/* ── Hero h1 em — solid vivid red, kills text-shadow inheritance ── */
.hero-h1 em {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: #ff4655 !important;
  color: #ff4655 !important;
  text-shadow: 0 0 48px rgba(255,70,85,0.55), 0 2px 0 rgba(0,0,0,0.3) !important;
  font-style: normal !important;
  animation: none !important;
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  PRE-CONTACT CTA + CONTACT SECTION                              ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── Pre-contact CTA ── */
.pre-contact-cta {
  background: linear-gradient(135deg, #0f1117 0%, #16101a 50%, #0f1117 100%);
  border-top: 1px solid rgba(255,70,85,0.12);
  border-bottom: 1px solid rgba(255,70,85,0.12);
  padding: var(--section-py) 0;
  position: relative;
  overflow: hidden;
}
.pre-contact-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 50%, rgba(255,70,85,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 50% 80% at 80% 50%, rgba(200,155,60,0.04) 0%, transparent 55%);
  pointer-events: none;
}
.pcc-inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 48px;
}
.pcc-text { flex: 1; }
.pcc-heading {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--text);
  text-transform: uppercase;
  margin: 10px 0 12px;
}
.pcc-heading em {
  -webkit-text-fill-color: var(--red);
  color: var(--red);
  font-style: normal;
}
.pcc-sub {
  font-size: 15px;
  color: var(--text-2);
  max-width: 480px;
  line-height: 1.6;
}
.pcc-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex-shrink: 0;
}

/* ── Contact section ── */
.contact-section {
  background: var(--bg1);
  padding: var(--section-py) 0;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* Trust banner */
.contact-trust {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: rgba(255,70,85,0.05);
  border: 1px solid rgba(255,70,85,0.14);
  border-left: 3px solid var(--red);
  border-radius: 2px;
  padding: 14px 18px;
  margin-bottom: 28px;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.ct-icon {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--red);
  opacity: 0.85;
}
.contact-trust p {
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.65;
  margin: 0;
}
.contact-trust strong { color: var(--text); }

/* Heading block */
.contact-header { text-align: center; margin-bottom: 48px; }
.contact-desc { max-width: 520px; margin: 12px auto 0; }

/* 4-card grid */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 900px;
  margin: 0 auto 32px;
}

/* Contact card */
.contact-card {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  background: var(--bg2);
  border: 1px solid rgba(255,255,255,0.07);
  border-top: 2px solid rgba(255,70,85,0.30);
  border-radius: 2px;
  padding: 22px 20px;
  text-decoration: none;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t), background var(--t);
  position: relative;
}
.contact-card:hover {
  border-color: var(--red);
  border-top-color: var(--red);
  background: rgba(255,70,85,0.05);
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,70,85,0.12) inset;
}
.contact-card:hover .cc-arrow { color: var(--red); transform: translateX(4px); }
.contact-card:hover .cc-email { color: var(--red); }

/* Icon wrap */
.cc-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: rgba(255,70,85,0.08);
  border: 1px solid rgba(255,70,85,0.16);
  color: var(--red);
}
.cc-icon-support   { background: rgba(68,153,255,0.08); border-color: rgba(68,153,255,0.20); color: #4499ff; }
.cc-icon-partners  { background: rgba(200,155,60,0.08); border-color: rgba(200,155,60,0.20); color: var(--brass-lt); }
.cc-icon-publishers{ background: rgba(192,96,255,0.08); border-color: rgba(192,96,255,0.20); color: #c060ff; }

/* Card body */
.cc-body { flex: 1; min-width: 0; }
.cc-type {
  display: block;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 4px;
}
.cc-email {
  display: block;
  font-family: var(--ff-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
  margin-bottom: 6px;
  transition: color var(--t);
  word-break: break-all;
}
.cc-desc {
  font-size: 12px;
  color: var(--text-3);
  line-height: 1.55;
  margin: 0;
}

/* Arrow */
.cc-arrow {
  flex-shrink: 0;
  color: var(--text-4);
  transition: color var(--t), transform var(--t);
  margin-top: 2px;
}

/* Response note */
.contact-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-size: 12px;
  color: var(--text-3);
  text-align: center;
  flex-wrap: wrap;
  max-width: 560px;
  margin: 0 auto;
}
.contact-note svg { flex-shrink: 0; color: var(--text-4); }
.contact-note strong { color: var(--text-2); }
.contact-discord-link {
  color: var(--red);
  text-decoration: none;
  font-weight: 600;
  transition: color var(--t);
}
.contact-discord-link:hover { color: var(--red-lt); }

/* ── Footer contact column ── */
.footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr 1.4fr !important; }

.fc-contact-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.fc-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-4);
}
.fc-email {
  font-size: 12px !important;
  color: var(--text-3) !important;
  word-break: break-all;
  transition: color var(--t) !important;
}
.fc-email:hover { color: var(--red) !important; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .pcc-inner { flex-direction: column; align-items: flex-start; gap: 28px; }
  .pcc-actions { flex-direction: row; }
  .contact-grid { grid-template-columns: 1fr; max-width: 560px; }
  .footer-grid { grid-template-columns: 1fr 1fr 1fr !important; }
  .footer-contact-col { grid-column: 1 / -1; }
  .fc-email { word-break: normal; }
}

@media (max-width: 600px) {
  .pcc-actions { flex-direction: column; width: 100%; }
  .pcc-actions .btn-red,
  .pcc-actions .btn-ghost { width: 100%; justify-content: center; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; }
  .footer-contact-col { grid-column: 1 / -1; }
  .footer-contact-col .fc-contact-item { flex-direction: row; align-items: baseline; gap: 8px; }
  .fc-label { min-width: 80px; }
}

@media (max-width: 420px) {
  .footer-grid { grid-template-columns: 1fr !important; }
  .footer-contact-col .fc-contact-item { flex-direction: column; gap: 2px; }
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  CONVERSION & TRUST AUDIT — Final pass                         ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── ISSUE 1: Hero value prop strip ── */
.hero-value-props {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin: 14px 0 0;
}
.hvp-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-2);
}
.hvp-item svg { color: var(--red); flex-shrink: 0; }

/* ── ISSUE 4: HIW 5-step (flex wraps naturally) ── */
.hiw-steps { flex-wrap: wrap; }
.hiw-step { min-width: 140px; }

/* ── ISSUE 5: Integrity+ Without/With compare ── */
.integrity-compare {
  display: flex;
  align-items: stretch;
  gap: 0;
  max-width: 820px;
  margin: 48px auto 56px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
}
.ic-side {
  flex: 1;
  padding: 28px 28px 28px;
}
.ic-without { background: rgba(255,70,85,0.04); border-right: 1px solid rgba(255,255,255,0.06); }
.ic-with    { background: rgba(50,210,120,0.04); }
.ic-side-header {
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.ic-without .ic-side-header { color: rgba(255,70,85,0.80); }
.ic-with    .ic-side-header { color: #32d278; }
.ic-list { list-style: none; display: flex; flex-direction: column; gap: 10px; margin: 0; padding: 0; }
.ic-list li {
  font-size: 13px;
  color: var(--text-2);
  padding-left: 20px;
  position: relative;
  line-height: 1.45;
}
.ic-list-bad  li::before { content: '✕'; position: absolute; left: 0; color: rgba(255,70,85,0.70); font-size: 11px; }
.ic-list-good li::before { content: '✓'; position: absolute; left: 0; color: #32d278; font-size: 11px; }
.ic-divider {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 12px;
  background: var(--bg2);
  gap: 8px;
}
.ic-divider-line { width: 1px; flex: 1; background: rgba(255,255,255,0.08); }
.ic-divider-badge {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 900;
  color: var(--text-3);
  letter-spacing: 0.10em;
  padding: 6px 0;
}

/* ── ISSUE 7: Roadmap date tags ── */
.rm-date-tag {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass-lt);
  background: rgba(200,155,60,0.10);
  border: 1px solid rgba(200,155,60,0.20);
  border-radius: 2px;
  padding: 3px 8px;
  margin: 4px 0 8px;
}

/* ── ISSUE 10: Founding Player Benefits ── */
.founding-benefits {
  background: var(--bg0);
  padding: var(--section-py) 0;
  border-top: 1px solid rgba(255,70,85,0.10);
}
.fb-header { text-align: center; margin-bottom: 48px; }
.fb-sub { max-width: 540px; margin: 12px auto 0; }
.fb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
.fb-card {
  background: var(--bg2);
  border: 1px solid rgba(255,255,255,0.07);
  border-top: 2px solid rgba(255,255,255,0.10);
  border-radius: 2px;
  padding: 24px 20px;
  position: relative;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
}
.fb-card:hover {
  border-color: rgba(255,70,85,0.35);
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}
.fb-card-mythic {
  border-top-color: rgba(255,70,85,0.60) !important;
  background: linear-gradient(160deg, rgba(255,70,85,0.06) 0%, var(--bg2) 60%) !important;
}
.fb-icon { font-size: 28px; margin-bottom: 12px; }
.fb-title {
  font-family: var(--ff-display);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 8px;
}
.fb-desc { font-size: 13px; color: var(--text-2); line-height: 1.6; margin-bottom: 16px; }
.fb-rarity {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--red);
  border: 1px solid rgba(255,70,85,0.25);
  background: rgba(255,70,85,0.08);
  display: inline-block;
  padding: 3px 8px;
  border-radius: 2px;
}
.fb-card-mythic .fb-rarity { color: #e8b84c; border-color: rgba(232,184,76,0.35); background: rgba(232,184,76,0.08); }
.fb-cta { text-align: center; }
.fb-urgency {
  margin-top: 14px;
  font-size: 13px;
  color: var(--text-3);
}
.fb-urgency strong { color: var(--red); }

/* ── ISSUE 12: Investor Vision ── */
.investor-vision {
  background: var(--bg-alt);
  padding: var(--section-py) 0;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.iv-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: center;
}
.iv-desc { font-size: 15px; color: var(--text-2); line-height: 1.7; margin-bottom: 14px; }
.iv-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--red);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,70,85,0.30);
  padding-bottom: 2px;
  transition: color var(--t), border-color var(--t);
}
.iv-cta:hover { color: var(--red-lt); border-color: var(--red); }
.iv-compare {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 16px;
}
.iv-model { flex: 1; padding: 22px 20px; }
.iv-model-old { background: rgba(255,255,255,0.02); border-right: 1px solid rgba(255,255,255,0.06); }
.iv-model-new { background: rgba(255,70,85,0.05); }
.iv-model-label {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 6px;
}
.iv-model-tag {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  display: inline-block;
  margin-bottom: 14px;
}
.iv-tag-old { color: var(--text-3); border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.04); }
.iv-tag-new { color: var(--red); border: 1px solid rgba(255,70,85,0.25); background: rgba(255,70,85,0.08); }
.iv-model-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.iv-model-list li { font-size: 12px; color: var(--text-2); line-height: 1.4; }
.iv-vs {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 900;
  color: var(--red);
  background: var(--bg2);
}
.iv-footnote { font-size: 12px; color: var(--text-3); line-height: 1.6; font-style: italic; }

/* ── ISSUE 13+14: Pre-contact CTA with reasons + partner box ── */
.pcc-right-col { display: flex; flex-direction: column; gap: 16px; flex-shrink: 0; min-width: 240px; }
.pcc-reasons { margin-top: 18px; display: flex; flex-direction: column; gap: 8px; }
.pcc-reason-title {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 4px;
}
.pcc-reason {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-2);
}
.pcc-reason svg { color: var(--red); flex-shrink: 0; }
.pcc-partner-box {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 2px;
  padding: 16px 18px;
}
.pcc-partner-heading {
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 4px;
}
.pcc-partner-desc { font-size: 12px; color: var(--text-3); margin-bottom: 10px; }
.pcc-partner-link {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--red);
  text-decoration: none;
  transition: color var(--t);
}
.pcc-partner-link:hover { color: var(--red-lt); }

/* ── ISSUE 8: Contact response times ── */
.contact-response-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  max-width: 700px;
  margin: 32px auto 24px;
}
.crt-card {
  background: var(--bg2);
  border: 1px solid rgba(255,255,255,0.07);
  border-top: 2px solid rgba(255,70,85,0.28);
  border-radius: 2px;
  padding: 18px 16px;
  text-align: center;
}
.crt-icon { font-size: 20px; margin-bottom: 8px; }
.crt-label {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 4px;
}
.crt-time {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 8px;
}
.crt-link {
  font-size: 11px;
  color: var(--text-3);
  text-decoration: none;
  word-break: break-all;
  transition: color var(--t);
}
.crt-link:hover { color: var(--red); }
.contact-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--text-3);
  margin-top: 8px;
}
.contact-location, .contact-discord-note {
  display: flex;
  align-items: center;
  gap: 7px;
}
.contact-location strong { color: var(--text-2); }

/* ── ISSUE 9: Footer trust links + SEO links ── */
.footer-trust-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 20px;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding: 18px 0;
  margin-bottom: 12px;
}
.footer-trust-links a {
  font-size: 12px;
  color: var(--text-4);
  text-decoration: none;
  transition: color var(--t);
}
.footer-trust-links a:hover { color: var(--text-2); }
.footer-seo-links {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
  margin-bottom: 16px;
}
.footer-seo-links a {
  font-size: 11px;
  color: var(--text-4);
  text-decoration: none;
  transition: color var(--t);
  opacity: 0.7;
}
.footer-seo-links a:hover { opacity: 1; color: var(--text-3); }

/* ── ISSUE 15: Accessibility — focus states ── */
:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 3px;
  border-radius: 2px;
}
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 3px;
}
/* Skip to content link */
.skip-to-content {
  position: absolute;
  top: -60px;
  left: 16px;
  background: var(--red);
  color: #fff;
  padding: 10px 18px;
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  z-index: 10000;
  transition: top 0.15s;
}
.skip-to-content:focus { top: 16px; }

/* ── Responsive: new sections ── */
@media (max-width: 900px) {
  .fb-grid { grid-template-columns: repeat(2, 1fr); }
  .iv-inner { grid-template-columns: 1fr; gap: 36px; }
  .integrity-compare { flex-direction: column; }
  .ic-without { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.06); }
  .ic-divider { flex-direction: row; padding: 12px 20px; }
  .ic-divider-line { width: auto; height: 1px; flex: 1; }
  .contact-response-grid { grid-template-columns: 1fr; max-width: 360px; }
  .pcc-inner { flex-direction: column; gap: 32px; }
  .pcc-right-col { width: 100%; }
  .pcc-actions { flex-direction: row; }
}
@media (max-width: 600px) {
  .fb-grid { grid-template-columns: 1fr; }
  .iv-compare { flex-direction: column; }
  .iv-vs { padding: 10px; writing-mode: horizontal-tb; transform: rotate(90deg); }
  .pcc-actions { flex-direction: column; }
  .pcc-actions .btn-red, .pcc-actions .btn-ghost { width: 100%; justify-content: center; }
  .hero-value-props { gap: 12px; }
  .footer-trust-links { gap: 8px 14px; }
  .contact-meta { flex-direction: column; gap: 10px; align-items: flex-start; }
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  LOGO AREA FIX + SCROLL-TO-TOP BUTTON                          ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── Nav logomark (black PNG → inverted white on dark bg) ── */
.nav-logomark {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  object-fit: contain;
  filter: invert(1) brightness(1.2);
  transition: filter var(--t), transform var(--t);
}
.nav-brand:hover .nav-logomark {
  /* On hover: tint red — invert → sepia → saturate → hue-rotate to red */
  filter: invert(1) brightness(1.0) sepia(1) saturate(8) hue-rotate(315deg);
  transform: scale(1.07);
}
.nav-wordmark {
  margin-left: 10px;
  font-family: var(--ff-display);
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 0.18em;
  color: var(--text);
  text-transform: uppercase;
  line-height: 1;
}

/* ── Footer brand mark ── */
.footer-brand-mark {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.footer-logomark {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  object-fit: contain;
  filter: invert(1) brightness(1.1);
}
.footer-wm {
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1;
}
.footer-tagline-sub {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-4);
  margin: 0 0 14px;
}

/* ── Scroll-to-top button ── */
.scroll-top-btn {
  position: fixed;
  bottom: 28px;
  right: 28px;
  width: 46px;
  height: 46px;
  background: var(--red);
  border: none;
  border-radius: 2px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 9000;
  box-shadow: 0 4px 20px rgba(255,70,85,0.45);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity 0.22s ease, transform 0.22s ease,
              background 0.15s, box-shadow 0.15s;
}
.scroll-top-btn.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.scroll-top-btn:hover {
  background: var(--red-lt);
  box-shadow: 0 6px 28px rgba(255,70,85,0.65);
  transform: translateY(-2px);
}
.scroll-top-btn:active { transform: translateY(0); }
.scroll-top-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

@media (max-width: 600px) {
  .scroll-top-btn { bottom: 20px; right: 16px; width: 42px; height: 42px; }
  .nav-wordmark { font-size: 17px; letter-spacing: 0.14em; }
  .footer-wm { font-size: 18px; }
}

/* ══════════════════════════════════════
   LAUNCH COUNTDOWN STRIP
══════════════════════════════════════ */
.launch-countdown {
  background: linear-gradient(135deg, #0a0c10 0%, #130810 50%, #0a0c10 100%);
  border-top: 2px solid rgba(255,70,85,0.35);
  border-bottom: 2px solid rgba(255,70,85,0.15);
  padding: 36px 0;
  position: relative;
  overflow: hidden;
}
.launch-countdown::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 200% at 50% 50%, rgba(255,70,85,0.10) 0%, transparent 70%);
  pointer-events: none;
}
.lc-inner {
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
  justify-content: space-between;
}
.lc-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: var(--text-3);
  text-transform: uppercase;
  white-space: nowrap;
}
.lc-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 8px var(--red);
  animation: lcPulse 1.4s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes lcPulse {
  0%,100% { opacity: 1; box-shadow: 0 0 8px var(--red); }
  50%      { opacity: 0.5; box-shadow: 0 0 3px var(--red); }
}
.lc-date {
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--brass-lt);
  white-space: nowrap;
}
.lc-units {
  display: flex;
  align-items: center;
  gap: 4px;
}
.lc-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 80px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,70,85,0.12);
  border-radius: 4px;
  padding: 12px 8px 10px;
}
.lc-num {
  font-family: var(--ff-display);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 900;
  line-height: 1;
  color: var(--text);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 40px rgba(255,70,85,0.25);
}
.lc-sub {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--text-4);
  margin-top: 6px;
  text-transform: uppercase;
}
.lc-sep {
  font-family: var(--ff-display);
  font-size: 36px;
  font-weight: 900;
  color: var(--red);
  line-height: 1;
  padding-bottom: 20px;
  opacity: 0.5;
}
.lc-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--red);
  color: #fff;
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 10px 20px;
  border-radius: 2px;
  white-space: nowrap;
  transition: background var(--t), transform var(--t);
  flex-shrink: 0;
}
.lc-cta:hover { background: var(--red-lt); transform: translateY(-1px); }
.lc-cta svg { flex-shrink: 0; }

@media (max-width: 900px) {
  .lc-inner { gap: 16px; justify-content: center; }
  .lc-date  { display: none; }
}
@media (max-width: 600px) {
  .launch-countdown { padding: 14px 0; }
  .lc-inner  { gap: 12px; flex-direction: column; align-items: center; }
  .lc-label  { font-size: 10px; }
  .lc-unit   { min-width: 44px; }
  .lc-num    { font-size: 38px; }
  .lc-unit   { min-width: 64px; padding: 10px 6px 8px; }
  .lc-cta    { font-size: 11px; padding: 9px 18px; }
}

/* ══════════════════════════════════════
   AUDIT FIXES — new components
══════════════════════════════════════ */

/* Hero launch tag */
.hero-launch-tag {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--brass-lt);
  background: rgba(232,184,76,0.10);
  border: 1px solid rgba(232,184,76,0.22);
  padding: 4px 10px;
  border-radius: 2px;
}

/* Social proof disclaimer + stat note */
.sp-stat-note {
  font-size: 11px;
  color: var(--text-4);
  margin-top: 4px;
  font-family: var(--ff-body);
  font-weight: 400;
  letter-spacing: 0;
}
.sp-disclaimer {
  margin-top: 32px;
  padding: 14px 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  font-size: 12px;
  color: var(--text-4);
  line-height: 1.6;
  text-align: center;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

/* ZE Coins disclaimer */
.ze-disclaimer {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 32px;
  padding: 16px 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line-md);
  border-left: 3px solid var(--brass-lt);
  border-radius: 2px;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.ze-disclaimer svg { flex-shrink: 0; color: var(--brass-lt); margin-top: 2px; }
.ze-disclaimer p { font-size: 12px; color: var(--text-3); line-height: 1.65; margin: 0; }
.ze-disclaimer strong { color: var(--text-2); }

/* Apply founding rewards list */
.ap-founding-rewards {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ap-reward-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 2px;
}
.ap-reward-icon {
  font-size: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}
.ap-reward-item div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ap-reward-item strong {
  font-size: 13px;
  color: var(--text);
  font-weight: 600;
}
.ap-reward-item span {
  font-size: 12px;
  color: var(--text-3);
}

/* Tournament flow */
.tourn-flow {
  margin-top: 56px;
  border-top: 1px solid var(--line-md);
  padding-top: 48px;
}
.tf-heading {
  text-align: center;
  margin-bottom: 40px;
}
.tf-h3 {
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 900;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1.1;
  margin-top: 8px;
}
.tf-h3 span { color: var(--red); }
.tf-steps {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
}
.tf-step {
  flex: 1;
  min-width: 140px;
  max-width: 180px;
  background: var(--bg2);
  border: 1px solid var(--line-md);
  border-top: 2px solid var(--red);
  padding: 20px 16px;
  border-radius: 2px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: border-color var(--t), transform var(--t);
}
.tf-step:hover { border-top-color: var(--red-lt); transform: translateY(-3px); }
.tf-num {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: var(--red);
}
.tf-icon { font-size: 24px; }
.tf-label {
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text);
}
.tf-desc {
  font-size: 11px;
  color: var(--text-3);
  line-height: 1.5;
}
.tf-arrow {
  font-size: 20px;
  color: var(--red);
  opacity: 0.5;
  align-self: center;
  flex-shrink: 0;
  padding-top: 0;
}
@media (max-width: 700px) {
  .tf-steps  { flex-direction: column; align-items: stretch; }
  .tf-step   { max-width: 100%; flex-direction: row; text-align: left; align-items: flex-start; }
  .tf-arrow  { display: none; }
  .tf-icon   { font-size: 20px; flex-shrink: 0; }
}

/* Comparison table */
.compare-section { padding: var(--section-py) 0; background: var(--bg1); }
.compare-header { text-align: center; margin-bottom: 40px; }
.compare-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  min-width: 560px;
}
.compare-table thead tr {
  border-bottom: 2px solid var(--line-md);
}
.compare-table th {
  padding: 14px 16px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-3);
  text-align: center;
}
.compare-table th span {
  display: block;
  font-weight: 400;
  letter-spacing: 0.04em;
  font-size: 10px;
  color: var(--text-4);
  margin-top: 2px;
  text-transform: none;
}
.ct-feature { text-align: left !important; color: var(--text-2) !important; min-width: 180px; }
.ct-zorthorn {
  background: rgba(255,70,85,0.06);
  color: var(--red-lt) !important;
  border-left: 1px solid rgba(255,70,85,0.15);
  border-right: 1px solid rgba(255,70,85,0.15);
}
.compare-table tbody tr {
  border-bottom: 1px solid var(--line);
  transition: background var(--t);
}
.compare-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.compare-table td {
  padding: 13px 16px;
  text-align: center;
  vertical-align: middle;
}
.compare-table td.ct-feature {
  text-align: left;
  color: var(--text-2);
  font-size: 13px;
}
.ct-yes  { color: #00e676; font-weight: 700; font-size: 16px; }
.ct-no   { color: var(--text-4); font-size: 16px; }
.ct-partial { color: var(--amber-lt); font-size: 12px; font-weight: 600; }
td.ct-zorthorn.ct-yes { color: var(--red-lt); }

/* Footer built-by */
.footer-built-by {
  margin-top: 16px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 2px;
}
.fbb-label {
  font-size: 10px;
  font-family: var(--ff-display);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-4);
  white-space: nowrap;
  padding-top: 2px;
  flex-shrink: 0;
}
.fbb-company {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.fbb-company strong {
  font-size: 13px;
  color: var(--text);
  font-weight: 600;
}
.fbb-company span {
  font-size: 11px;
  color: var(--text-4);
}
.fbb-company a { color: var(--brass-lt); text-decoration: none; }
.fbb-company a:hover { color: var(--text); }

/* ═══════════════════════════════════════════════════════
   USER JOURNEY SECTION
═══════════════════════════════════════════════════════ */
.user-journey {
  padding: var(--section-py) 0 calc(var(--section-py) + 16px);
  background: var(--bg0);
  position: relative;
  overflow: hidden;
}
.user-journey::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,70,85,0.3), transparent);
}
.uj-header { text-align: center; margin-bottom: 56px; }

.uj-steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
  position: relative;
}
.uj-step {
  flex: 1;
  min-width: 140px;
  max-width: 180px;
  background: var(--bg2);
  border: 1px solid var(--line-md);
  border-top: 2px solid transparent;
  border-radius: 2px;
  padding: 24px 16px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  transition: transform var(--t-med), border-color var(--t-med), box-shadow var(--t-med);
  position: relative;
}
.uj-step:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 48px rgba(0,0,0,0.5);
}
.uj-step-final { border-top-color: var(--r-epic) !important; }
.uj-icon-wrap {
  width: 52px; height: 52px;
  border-radius: 50%;
  border: 1px solid;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform var(--t);
}
.uj-step:hover .uj-icon-wrap { transform: scale(1.1); }
.uj-step-num {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: var(--text-4);
  position: absolute;
  top: 10px; right: 12px;
}
.uj-step-title {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1.2;
}
.uj-step-desc {
  font-size: 11.5px;
  color: var(--text-3);
  line-height: 1.55;
}
.uj-step-tag {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  margin-top: auto;
}
.uj-tag-red    { background: rgba(255,70,85,0.10); color: var(--red-lt); }
.uj-tag-blue   { background: rgba(68,136,238,0.10); color: var(--intel); }
.uj-tag-green  { background: rgba(0,230,118,0.10); color: var(--nvg); }
.uj-tag-amber  { background: rgba(240,160,32,0.10); color: var(--amber-lt); }
.uj-tag-gold   { background: rgba(232,184,76,0.10); color: var(--brass-lt); }
.uj-tag-epic   { background: rgba(153,85,238,0.10); color: var(--r-epic); }

.uj-connector {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  flex-shrink: 0;
  align-self: center;
  margin-top: -24px;
}
.uj-cta-row {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 48px;
}

@media (max-width: 900px) {
  .uj-steps { gap: 8px; }
  .uj-step  { min-width: 120px; max-width: 150px; padding: 18px 12px 16px; }
  .uj-step-title { font-size: 12px; }
  .uj-connector { padding: 0 2px; }
}
@media (max-width: 640px) {
  .uj-steps { flex-direction: column; align-items: stretch; }
  .uj-step  { max-width: 100%; flex-direction: row; text-align: left;
               padding: 16px 14px; gap: 12px; }
  .uj-icon-wrap { flex-shrink: 0; width: 44px; height: 44px; }
  .uj-step-num  { position: static; order: -1; }
  .uj-connector { display: none; }
  .uj-step-final { border-top-color: var(--r-epic) !important; }
}

/* ═══════════════════════════════════════════════════════
   APP PREVIEW — PHONE MOCKUPS
═══════════════════════════════════════════════════════ */
.app-preview-section {
  padding: var(--section-py) 0;
  background: var(--bg-alt);
  position: relative;
  overflow: hidden;
}
.app-preview-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,70,85,0.2), transparent);
}
.ap-header { text-align: center; margin-bottom: 52px; }

/* Scroll container */
.ap-scroll-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,70,85,0.3) transparent;
  padding: 20px 0 40px;
}
.ap-scroll-wrap::-webkit-scrollbar { height: 4px; }
.ap-scroll-wrap::-webkit-scrollbar-track { background: transparent; }
.ap-scroll-wrap::-webkit-scrollbar-thumb { background: rgba(255,70,85,0.3); border-radius: 2px; }

.ap-phones {
  display: flex;
  gap: 28px;
  padding: 0 clamp(20px, 5vw, 80px);
  width: max-content;
}

/* Phone frame */
.phone-frame {
  width: 214px;
  background: linear-gradient(160deg, #1c1c28 0%, #0e0e18 100%);
  border-radius: 36px;
  border: 2px solid rgba(255,255,255,0.10);
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.9),
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 60px 120px rgba(0,0,0,0.85),
    0 0 40px rgba(255,70,85,0.04);
  position: relative;
  flex-shrink: 0;
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease);
}
.phone-frame:hover {
  transform: translateY(-10px) scale(1.02);
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.9),
    inset 0 1px 0 rgba(255,255,255,0.10),
    0 80px 140px rgba(0,0,0,0.9),
    0 0 60px rgba(255,70,85,0.10);
}
/* Side buttons */
.phone-frame::after {
  content: '';
  position: absolute;
  right: -3px; top: 90px;
  width: 3px; height: 44px;
  background: rgba(255,255,255,0.10);
  border-radius: 0 2px 2px 0;
  box-shadow: 0 60px 0 rgba(255,255,255,0.10);
}
.phone-island {
  position: absolute;
  top: 13px; left: 50%;
  transform: translateX(-50%);
  width: 76px; height: 20px;
  background: #000;
  border-radius: 20px;
  z-index: 10;
}
.phone-screen {
  margin: 6px;
  border-radius: 31px;
  background: #08090f;
  overflow: hidden;
  min-height: 430px;
  display: flex;
  flex-direction: column;
  padding: 42px 0 0;
  position: relative;
}
.phone-label {
  text-align: center;
  padding: 16px 8px 20px;
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-4);
}

/* Status bar */
.ps-statusbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 16px;
  font-size: 9px;
  font-weight: 600;
  color: var(--text-3);
  margin-bottom: 4px;
  flex-shrink: 0;
}
.ps-icons { display: flex; gap: 4px; font-size: 8px; }

/* Screen label bar */
.ps-label-bar {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: var(--red);
  text-align: center;
  padding: 6px 0 10px;
  border-bottom: 1px solid rgba(255,70,85,0.12);
  margin-bottom: 10px;
  flex-shrink: 0;
}

/* ── Screen 1: Profile ── */
.ps-avatar-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 4px 0 10px;
}
.ps-avatar {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red) 0%, #7a0010 100%);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-size: 18px; font-weight: 900;
  color: #fff;
  border: 2px solid rgba(255,70,85,0.4);
  box-shadow: 0 0 20px rgba(255,70,85,0.3);
}
.ps-level-ring {
  background: var(--red);
  color: #fff;
  font-family: var(--ff-display);
  font-size: 8px; font-weight: 800;
  letter-spacing: 0.10em;
  padding: 2px 7px;
  border-radius: 20px;
}
.ps-ign {
  text-align: center;
  font-family: var(--ff-display);
  font-size: 14px; font-weight: 800;
  color: var(--text);
  letter-spacing: 0.04em;
  padding: 0 12px;
}
.ps-rank-row {
  display: flex; gap: 6px;
  align-items: center; justify-content: center;
  padding: 4px 12px 10px;
}
.ps-rank-badge {
  font-family: var(--ff-display);
  font-size: 10px; font-weight: 700;
  padding: 3px 8px; border-radius: 20px;
}
.ps-rank-diamond { background: rgba(68,136,238,0.15); color: #6aabff; }
.ps-game-tag {
  font-size: 9px; color: var(--text-4);
  background: rgba(255,255,255,0.06);
  padding: 3px 7px; border-radius: 20px;
}
.ps-xp-section { padding: 0 14px 8px; flex-shrink: 0; }
.ps-xp-header {
  display: flex; justify-content: space-between;
  font-size: 9px; color: var(--text-4); margin-bottom: 4px;
}
.ps-xp-outer {
  height: 4px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px; overflow: hidden;
}
.ps-xp-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--red), var(--brass-lt));
  border-radius: 2px;
}
.ps-badges-row {
  display: flex; gap: 6px;
  justify-content: center;
  padding: 6px 12px 10px;
}
.ps-badge-sm {
  width: 28px; height: 28px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  border: 1px solid var(--line-md);
}
.ps-b-mythic   { background: rgba(153,85,238,0.15); border-color: rgba(153,85,238,0.3); }
.ps-b-epic     { background: rgba(68,136,238,0.12); border-color: rgba(68,136,238,0.25); }
.ps-b-legendary{ background: rgba(232,180,32,0.12); border-color: rgba(232,180,32,0.25); }
.ps-b-rare     { background: rgba(68,136,238,0.08); border-color: rgba(68,136,238,0.18); }
.ps-stats-row {
  display: flex; align-items: center;
  margin: 6px 14px 0;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 8px;
}
.ps-stat { flex: 1; text-align: center; }
.ps-stat-div { width: 1px; background: var(--line-md); align-self: stretch; }
.ps-stat-n { font-family: var(--ff-display); font-size: 13px; font-weight: 800; color: var(--text); }
.ps-stat-l { font-size: 8px; color: var(--text-4); margin-top: 2px; letter-spacing: 0.08em; text-transform: uppercase; }

/* ── Screen 2: Leaderboard ── */
.ps-lb-tabs {
  display: flex; gap: 2px;
  padding: 0 10px 10px;
}
.ps-lb-tab {
  flex: 1; font-family: var(--ff-display); font-size: 9px; font-weight: 700;
  letter-spacing: 0.10em; text-transform: uppercase;
  padding: 6px 4px; border-radius: 4px; border: none; cursor: pointer;
  background: rgba(255,255,255,0.04); color: var(--text-4);
  transition: all 0.15s;
}
.ps-lb-active { background: rgba(255,70,85,0.15) !important; color: var(--red-lt) !important; }
.ps-lb-rows { flex: 1; padding: 0 10px; display: flex; flex-direction: column; gap: 3px; }
.ps-lb-row {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.03);
  font-size: 10px;
}
.ps-lb-gold   { background: rgba(232,180,32,0.10); }
.ps-lb-silver { background: rgba(180,180,200,0.08); }
.ps-lb-bronze { background: rgba(180,100,40,0.10); }
.ps-lb-you    { background: rgba(255,70,85,0.10); border: 1px solid rgba(255,70,85,0.18); }
.ps-pos { font-size: 13px; flex-shrink: 0; }
.ps-pos-num { font-family: var(--ff-display); font-size: 10px; font-weight: 800; color: var(--text-3); width: 18px; text-align: center; }
.ps-name { flex: 1; color: var(--text-2); font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ps-pts  { font-family: var(--ff-display); font-size: 9px; font-weight: 700; color: var(--brass-lt); white-space: nowrap; }
.ps-you-tag { background: var(--red); color: #fff; font-size: 7px; font-weight: 800; padding: 1px 4px; border-radius: 2px; margin-left: 4px; vertical-align: middle; }
.ps-lb-footer { text-align: center; padding: 8px 10px; font-size: 8px; color: var(--text-4); border-top: 1px solid var(--line); margin-top: 8px; }

/* ── Screen 3: Tournament ── */
.ps-tourn-card {
  margin: 0 10px 10px;
  background: linear-gradient(135deg, rgba(255,70,85,0.08) 0%, rgba(255,255,255,0.03) 100%);
  border: 1px solid rgba(255,70,85,0.18);
  border-radius: 8px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 8px;
}
.ps-tourn-badge {
  font-family: var(--ff-display); font-size: 8px; font-weight: 800;
  letter-spacing: 0.14em; color: var(--brass-lt);
}
.ps-tourn-name {
  font-family: var(--ff-display); font-size: 13px; font-weight: 900;
  color: var(--text); letter-spacing: 0.02em;
}
.ps-tourn-game { font-size: 9px; color: var(--text-3); }
.ps-tourn-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.ps-tg-item { text-align: center; }
.ps-tg-val  { font-family: var(--ff-display); font-size: 11px; font-weight: 800; }
.ps-tg-label{ font-size: 8px; color: var(--text-4); margin-top: 2px; }
.ps-tg-green{ color: var(--nvg); }
.ps-tg-gold { color: var(--brass-lt); }
.ps-tg-red  { color: var(--red-lt); }
.ps-tourn-fill { display: flex; flex-direction: column; gap: 4px; }
.ps-tf-bar  { height: 3px; background: rgba(255,255,255,0.08); border-radius: 2px; overflow: hidden; }
.ps-tf-fill { height: 100%; background: var(--red); border-radius: 2px; }
.ps-tourn-fill > span { font-size: 8px; color: var(--text-4); }
.ps-join-btn {
  background: var(--red); color: #fff; border: none; cursor: pointer;
  font-family: var(--ff-display); font-size: 10px; font-weight: 800;
  letter-spacing: 0.10em; text-transform: uppercase;
  padding: 8px; border-radius: 4px; width: 100%;
}
.ps-tourn-mini { padding: 0 10px; display: flex; flex-direction: column; gap: 4px; }
.ps-tm-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 7px 8px;
  background: rgba(255,255,255,0.03);
  border-radius: 4px;
  font-size: 9px; color: var(--text-3);
}

/* ── Screen 4: ZE Wallet ── */
.ps-wallet-hero {
  text-align: center;
  padding: 8px 12px 14px;
  background: linear-gradient(160deg, rgba(232,184,76,0.08) 0%, transparent 70%);
  border-bottom: 1px solid var(--line);
  margin-bottom: 10px;
}
.ps-wallet-label { font-size: 8px; color: var(--brass-lt); font-family: var(--ff-display); letter-spacing: 0.12em; margin-bottom: 4px; }
.ps-wallet-bal   { font-family: var(--ff-display); font-size: 28px; font-weight: 900; color: var(--text); line-height: 1; }
.ps-wallet-sub   { font-size: 8px; color: var(--text-4); margin-top: 3px; }
.ps-wallet-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; padding: 0 10px 10px; }
.ps-wg-item { background: rgba(255,255,255,0.04); border-radius: 6px; padding: 8px; text-align: center; }
.ps-wg-val  { font-family: var(--ff-display); font-size: 13px; font-weight: 800; }
.ps-wg-l    { font-size: 8px; color: var(--text-4); margin-top: 2px; }
.ps-tx-list { padding: 0 10px; display: flex; flex-direction: column; gap: 4px; }
.ps-tx {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 8px; border-radius: 5px;
  background: rgba(255,255,255,0.03);
}
.ps-tx-icon {
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 800; flex-shrink: 0;
}
.ps-tx-earn  { background: rgba(0,230,118,0.15); color: var(--nvg); }
.ps-tx-spend { background: rgba(255,70,85,0.15); color: var(--red-lt); }
.ps-tx-info  { flex: 1; }
.ps-tx-info > div:first-child { font-size: 9px; color: var(--text-2); }
.ps-tx-time  { font-size: 8px; color: var(--text-4); }
.ps-tx-amt   { font-family: var(--ff-display); font-size: 10px; font-weight: 800; }
.ps-wallet-note { text-align: center; padding: 8px; font-size: 8px; color: var(--text-4); border-top: 1px solid var(--line); margin-top: 8px; }

/* ── Screen 5: Badge Collection ── */
.ps-badge-sections { display: flex; flex-direction: column; gap: 5px; padding: 0 10px; flex: 1; }
.ps-br-row {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 8px; border-radius: 5px;
  border: 1px solid transparent;
}
.ps-br-mythic   { background: rgba(153,85,238,0.10); border-color: rgba(153,85,238,0.18); }
.ps-br-legendary{ background: rgba(232,180,32,0.08); border-color: rgba(232,180,32,0.15); }
.ps-br-epic     { background: rgba(68,136,238,0.08); border-color: rgba(68,136,238,0.15); }
.ps-br-rare     { background: rgba(68,136,238,0.05); border-color: rgba(68,136,238,0.10); }
.ps-br-common   { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.07); }
.ps-br-label { font-family: var(--ff-display); font-size: 7px; font-weight: 800; letter-spacing: 0.12em; min-width: 52px; color: var(--text-3); }
.ps-br-badges { display: flex; gap: 4px; flex: 1; }
.ps-badge-icon {
  width: 22px; height: 22px; border-radius: 4px;
  background: rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: center; font-size: 11px;
}
.ps-badge-icon.locked { opacity: 0.25; filter: grayscale(1); }
.ps-bi-mythic    { background: rgba(153,85,238,0.2); }
.ps-bi-legendary { background: rgba(232,180,32,0.15); }
.ps-bi-epic      { background: rgba(68,136,238,0.15); }
.ps-bi-rare      { background: rgba(68,136,238,0.08); }
.ps-br-count { font-size: 8px; color: var(--text-4); white-space: nowrap; }
.ps-badge-total { text-align: center; padding: 8px; font-size: 8px; color: var(--text-4); border-top: 1px solid var(--line); margin-top: auto; }

/* ── Screen 6: Daily Quests ── */
.ps-quest-streak {
  display: flex; align-items: center; gap: 8px;
  margin: 0 10px 10px;
  padding: 8px 10px;
  background: linear-gradient(90deg, rgba(255,107,53,0.12) 0%, rgba(255,224,27,0.06) 100%);
  border: 1px solid rgba(255,107,53,0.18);
  border-radius: 6px;
}
.ps-qs-fire { font-size: 18px; }
.ps-qs-num  { font-family: var(--ff-display); font-size: 16px; font-weight: 900; color: var(--streak-lt); line-height: 1; }
.ps-qs-label{ font-size: 8px; color: var(--text-3); }
.ps-qs-bonus{ margin-left: auto; font-size: 8px; color: var(--speed-lt); font-weight: 600; text-align: right; }
.ps-quests  { padding: 0 10px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.ps-quest {
  background: rgba(255,255,255,0.04); border: 1px solid var(--line);
  border-radius: 6px; padding: 8px;
  display: flex; align-items: center; gap: 7px;
}
.ps-q-done { background: rgba(0,230,118,0.06); border-color: rgba(0,230,118,0.15); }
.ps-q-active{ background: rgba(255,70,85,0.06); border-color: rgba(255,70,85,0.15); }
.ps-q-check {
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(0,230,118,0.2); color: var(--nvg);
  font-size: 10px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ps-q-partial { background: rgba(255,70,85,0.2) !important; color: var(--red-lt) !important; font-size: 8px !important; }
.ps-q-lock   { background: rgba(255,255,255,0.06) !important; color: var(--text-4) !important; font-size: 8px !important; }
.ps-q-info   { flex: 1; min-width: 0; }
.ps-q-title  { font-size: 9px; color: var(--text-2); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ps-q-prog-bar { height: 3px; background: rgba(255,255,255,0.08); border-radius: 2px; overflow: hidden; }
.ps-qp-fill  { height: 100%; background: var(--red); border-radius: 2px; }
.ps-q-done .ps-qp-fill { background: var(--nvg); }
.ps-q-rewards{ display: flex; flex-direction: column; gap: 3px; flex-shrink: 0; }
.ps-qr       { font-family: var(--ff-display); font-size: 8px; font-weight: 700; color: var(--brass-lt); text-align: right; }
.ps-quest-footer{ text-align: center; padding: 8px 10px; font-size: 8px; color: var(--text-4); border-top: 1px solid var(--line); margin-top: 8px; }

/* Scroll hint */
.ap-scroll-hint {
  text-align: center;
  font-size: 11px;
  color: var(--text-4);
  margin-top: 4px;
  font-family: var(--ff-display);
  letter-spacing: 0.12em;
}
@media (min-width: 1400px) { .ap-scroll-hint { display: none; } }

/* ═══════════════════════════════════════════════════════
   WHY ZORTHORN — MANIFESTO BLOCK
═══════════════════════════════════════════════════════ */
.why-zorthorn-manifesto {
  background: linear-gradient(135deg, rgba(255,70,85,0.05) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid rgba(255,70,85,0.15);
  border-left: 3px solid var(--red);
  border-radius: 2px;
  padding: 28px 28px 24px;
  margin-bottom: 28px;
}
.wzm-line {
  font-size: 15px;
  color: var(--text-3);
  line-height: 1.7;
  margin-bottom: 6px;
}
.wzm-line strong { color: var(--text-2); }
.wzm-divider {
  width: 48px; height: 2px;
  background: var(--red);
  margin: 20px 0;
}
.wzm-brand {
  font-family: var(--ff-display);
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 900;
  text-transform: uppercase;
  color: var(--text);
  letter-spacing: 0.06em;
  margin-bottom: 20px;
}
.wzm-pillars { display: flex; flex-direction: column; gap: 10px; }
.wzm-pillar {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; color: var(--text-2);
}
.wzm-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--red);
  flex-shrink: 0;
  box-shadow: 0 0 8px var(--red);
}
.wzm-pillar strong { color: var(--text); }

/* ═══════════════════════════════════════════════════════
   BUILT IN INDIA SECTION
═══════════════════════════════════════════════════════ */
.built-india {
  padding: var(--section-py) 0;
  background: var(--bg1);
  position: relative;
}
.built-india::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,184,76,0.3), transparent);
}
.bi-header { text-align: center; margin-bottom: 48px; }
.bi-grid {
  display: grid;
  grid-template-columns: 1.3fr repeat(3, 1fr);
  gap: 16px;
  align-items: start;
}
.bi-card {
  background: var(--bg2);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform var(--t-med), border-color var(--t-med);
}
.bi-card:hover { transform: translateY(-3px); border-color: rgba(232,184,76,0.25); }
.bi-card-main {
  border-top: 2px solid var(--brass-lt);
  background: linear-gradient(160deg, rgba(232,184,76,0.05) 0%, var(--bg2) 60%);
}
.bi-flag { font-size: 28px; }
.bi-company-name {
  font-family: var(--ff-display);
  font-size: 16px; font-weight: 900;
  letter-spacing: 0.04em;
  color: var(--text);
  text-transform: uppercase;
}
.bi-company-sub { font-size: 11px; color: var(--text-4); }
.bi-brand-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 2px;
  margin-top: 4px;
}
.bi-brand-icon {
  width: 32px; height: 32px;
  border-radius: 6px;
  background: var(--red);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: 14px; font-weight: 900; color: #fff;
  flex-shrink: 0;
}
.bi-brand-name { font-size: 13px; font-weight: 600; color: var(--text); }
.bi-brand-desc { font-size: 11px; color: var(--text-4); }
.bi-contact-row {
  display: flex; align-items: center; gap: 7px;
  font-size: 12px; color: var(--text-3); margin-top: 4px;
}
.bi-contact-row a { color: var(--brass-lt); }
.bi-contact-row a:hover { color: var(--text); }
.bi-cert-icon { font-size: 24px; }
.bi-cert-title {
  font-family: var(--ff-display);
  font-size: 14px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--text);
}
.bi-cert-body { font-size: 12px; color: var(--text-3); line-height: 1.6; }
.bi-cert-tag {
  font-family: var(--ff-display);
  font-size: 9px; font-weight: 700; letter-spacing: 0.12em;
  color: var(--brass-lt);
  background: rgba(232,184,76,0.10);
  padding: 3px 8px; border-radius: 2px;
  align-self: flex-start; margin-top: auto;
}
.bi-links {
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-top: 40px;
  justify-content: center;
}
.bi-link {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  font-family: var(--ff-display);
  font-size: 11px; font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--text-3);
  transition: all var(--t);
  text-decoration: none;
}
.bi-link:hover { background: rgba(255,255,255,0.07); color: var(--text); border-color: var(--line-hi); }
.bi-link-discord { color: #7289da; border-color: rgba(114,137,218,0.2); }
.bi-link-discord:hover { background: rgba(114,137,218,0.10); border-color: rgba(114,137,218,0.35); color: #7289da; }

@media (max-width: 1000px) {
  .bi-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .bi-grid { grid-template-columns: 1fr; }
  .bi-links { flex-direction: column; align-items: stretch; }
  .bi-link  { justify-content: center; }
}

/* ═══════════════════════════════════════════════════════
   SCROLL-TO-TOP BUTTON
═══════════════════════════════════════════════════════ */
.scroll-top-btn {
  position: fixed;
  bottom: 28px; right: 28px;
  width: 42px; height: 42px;
  background: var(--red);
  color: #fff;
  border: none; cursor: pointer;
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.25s, visibility 0.25s, transform 0.25s, background 0.2s;
  z-index: 900;
  box-shadow: 0 4px 20px rgba(255,70,85,0.35);
}
.scroll-top-btn.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.scroll-top-btn:hover   { background: var(--red-lt); }

/* ═══════════════════════════════════════════════════════
   NAV & FOOTER LOGO
═══════════════════════════════════════════════════════ */
.footer-logomark {
  width: 160px;
  height: 160px;
  object-fit: contain;
  filter: invert(1) brightness(1.2);
}

/* ═══════════════════════════════════════════════════════
   SOCIAL PROOF — STAT NOTES & DISCLAIMER
═══════════════════════════════════════════════════════ */
.sp-stat-note {
  font-size: 10px;
  color: var(--text-4);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 3px;
}
.sp-disclaimer {
  font-size: 12px;
  color: var(--text-4);
  line-height: 1.6;
  max-width: 640px;
  margin: 16px auto 0;
  text-align: center;
  padding: 12px 16px;
  border: 1px solid var(--line);
  border-radius: 2px;
  background: rgba(255,255,255,0.02);
}

/* ═══════════════════════════════════════════════════════
   ROADMAP DATE TAG
═══════════════════════════════════════════════════════ */
.rm-date-tag {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass-lt);
  background: rgba(232,184,76,0.10);
  border: 1px solid rgba(232,184,76,0.18);
  padding: 3px 8px;
  border-radius: 2px;
  margin-bottom: 8px;
}

/* ═══════════════════════════════════════════════════════
   APPLY SECTION — FOUNDING REWARDS
═══════════════════════════════════════════════════════ */
.ap-founding-rewards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 18px 0 4px;
}
.ap-reward-item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  font-size: 12px; color: var(--text-2);
}
.ap-reward-icon { font-size: 16px; flex-shrink: 0; }

/* ═══════════════════════════════════════════════════════
   HOW IT WORKS — CONNECTOR
═══════════════════════════════════════════════════════ */
.hiw-connector {
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--red);
  opacity: 0.5;
  padding: 0 2px;
  align-self: center;
}
@media (max-width: 640px) { .hiw-connector { display: none; } }

/* ═══════════════════════════════════════════════════════
   SECTION BADGE (used in pre-contact-cta & contact)
═══════════════════════════════════════════════════════ */
.section-badge {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass-lt);
  background: rgba(232,184,76,0.10);
  border: 1px solid rgba(232,184,76,0.20);
  padding: 4px 10px;
  border-radius: 2px;
  margin-bottom: 14px;
}

/* ═══════════════════════════════════════════════════════
   FOUNDING BENEFITS SECTION
═══════════════════════════════════════════════════════ */
.founding-benefits {
  padding: var(--section-py) 0;
  background: var(--bg-alt);
  position: relative;
}
.founding-benefits::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,184,76,0.3), transparent);
}
.fb-header { text-align: center; margin-bottom: 48px; }
.fb-sub { max-width: 560px; margin: 14px auto 0; text-align: center; }
.fb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.fb-card {
  background: var(--bg2);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  padding: 28px 22px 22px;
  display: flex; flex-direction: column; gap: 10px;
  transition: transform var(--t-med), border-color var(--t-med), box-shadow var(--t-med);
}
.fb-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.4);
  border-color: rgba(232,184,76,0.2);
}
.fb-card-mythic {
  border-top: 2px solid var(--brass-lt);
  background: linear-gradient(160deg, rgba(232,184,76,0.06) 0%, var(--bg2) 50%);
}
.fb-icon { font-size: 28px; }
.fb-title {
  font-family: var(--ff-display);
  font-size: 15px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--text);
}
.fb-desc { font-size: 13px; color: var(--text-3); line-height: 1.65; flex: 1; }
.fb-rarity {
  font-family: var(--ff-display);
  font-size: 9px; font-weight: 800; letter-spacing: 0.16em;
  color: var(--brass-lt);
  background: rgba(232,184,76,0.10);
  padding: 3px 8px; border-radius: 2px;
  align-self: flex-start; margin-top: auto;
}
.fb-cta { text-align: center; margin-top: 44px; }
.fb-urgency {
  font-size: 12px; color: var(--text-4);
  margin-top: 12px;
}

@media (max-width: 900px) { .fb-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .fb-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════
   INVESTOR VISION SECTION
═══════════════════════════════════════════════════════ */
.investor-vision {
  padding: var(--section-py) 0;
  background: var(--bg0);
}
.iv-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.iv-desc {
  font-size: 15px; color: var(--text-3); line-height: 1.75;
  margin-bottom: 14px;
}
.iv-cta {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--red-lt);
  font-family: var(--ff-display);
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-decoration: none; margin-top: 8px;
  transition: color var(--t);
}
.iv-cta:hover { color: var(--text); }
.iv-compare {
  display: flex; gap: 16px; align-items: stretch;
  margin-bottom: 20px;
}
.iv-model {
  flex: 1;
  background: var(--bg2);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  padding: 20px;
  display: flex; flex-direction: column; gap: 8px;
}
.iv-model-old { border-top: 2px solid rgba(255,255,255,0.12); }
.iv-model-new { border-top: 2px solid var(--red); background: linear-gradient(160deg, rgba(255,70,85,0.05) 0%, var(--bg2) 60%); }
.iv-model-label {
  font-family: var(--ff-display);
  font-size: 12px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.10em; color: var(--text);
}
.iv-model-tag {
  font-family: var(--ff-display);
  font-size: 9px; font-weight: 700; letter-spacing: 0.12em;
  padding: 2px 7px; border-radius: 2px;
  align-self: flex-start;
}
.iv-tag-old { background: rgba(255,255,255,0.06); color: var(--text-4); }
.iv-tag-new { background: rgba(255,70,85,0.12); color: var(--red-lt); }
.iv-model-list {
  list-style: none; padding: 0; margin: 6px 0 0;
  display: flex; flex-direction: column; gap: 6px;
  font-size: 12px; color: var(--text-3); line-height: 1.5;
}
.iv-model-list li::before { content: '→ '; color: var(--text-4); }
.iv-vs {
  display: flex; align-items: center;
  font-family: var(--ff-display); font-size: 20px;
  color: var(--red); font-weight: 900;
  padding: 0 4px; flex-shrink: 0;
}
.iv-footnote {
  font-size: 12px; color: var(--text-4);
  border-top: 1px solid var(--line);
  padding-top: 14px; line-height: 1.6;
}

@media (max-width: 800px) {
  .iv-inner { grid-template-columns: 1fr; gap: 36px; }
  .iv-compare { flex-direction: column; }
  .iv-vs { transform: rotate(90deg); align-self: center; }
}

/* ═══════════════════════════════════════════════════════
   COMPARISON SECTION
═══════════════════════════════════════════════════════ */
.compare-section {
  padding: var(--section-py) 0;
  background: var(--bg-alt);
}
.compare-header { text-align: center; margin-bottom: 44px; }
.compare-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.compare-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.compare-table th, .compare-table td {
  padding: 12px 14px;
  border: 1px solid var(--line);
  text-align: center;
  vertical-align: middle;
}
.compare-table thead th {
  font-family: var(--ff-display);
  font-size: 11px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.10em; color: var(--text-3);
  background: var(--bg2);
}
.compare-table tbody tr:nth-child(even) td { background: rgba(255,255,255,0.02); }
.compare-table tbody tr:hover td { background: rgba(255,255,255,0.04); }
.ct-feature { text-align: left !important; color: var(--text-2); font-weight: 500; }
.ct-platform { color: var(--text-4); }
.ct-zorthorn { color: var(--brass-lt) !important; background: rgba(232,184,76,0.05) !important; font-weight: 700 !important; }
.ct-yes     { color: var(--nvg); font-weight: 700; font-size: 15px; }
.ct-no      { color: rgba(255,70,85,0.6); font-size: 15px; }
.ct-partial { color: var(--amber-lt); font-size: 13px; }

/* ═══════════════════════════════════════════════════════
   PRE-CONTACT CTA SECTION
═══════════════════════════════════════════════════════ */
.pre-contact-cta {
  padding: var(--section-py) 0;
  background: linear-gradient(135deg, #0a0c12 0%, #100812 50%, #0a0c12 100%);
  position: relative; overflow: hidden;
}
.pre-contact-cta::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 120% at 60% 50%, rgba(255,70,85,0.07) 0%, transparent 65%);
  pointer-events: none;
}
.pcc-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
  position: relative;
}
.pcc-heading {
  font-family: var(--ff-display);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 900; text-transform: uppercase;
  letter-spacing: 0.02em; color: var(--text);
  line-height: 1.1; margin: 0 0 14px;
}
.pcc-heading em { color: var(--red-lt); font-style: normal; }
.pcc-sub { font-size: 15px; color: var(--text-3); line-height: 1.7; margin-bottom: 22px; }
.pcc-reasons { display: flex; flex-direction: column; gap: 8px; }
.pcc-reason-title {
  font-family: var(--ff-display);
  font-size: 10px; font-weight: 800; letter-spacing: 0.14em;
  color: var(--text-4); text-transform: uppercase; margin-bottom: 4px;
}
.pcc-reason {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-2);
}
.pcc-reason svg { color: var(--nvg); flex-shrink: 0; }
.pcc-right-col { display: flex; flex-direction: column; gap: 20px; }
.pcc-actions { display: flex; flex-direction: column; gap: 10px; }
.pcc-contact-btn { justify-content: center; }
.pcc-partner-box {
  background: var(--bg2);
  border: 1px solid var(--line-md);
  border-radius: 2px;
  padding: 20px;
  display: flex; flex-direction: column; gap: 6px;
}
.pcc-partner-heading {
  font-family: var(--ff-display);
  font-size: 13px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--text);
}
.pcc-partner-desc { font-size: 12px; color: var(--text-4); }
.pcc-partner-link {
  font-size: 13px; color: var(--brass-lt); font-weight: 600;
  margin-top: 4px;
}
.pcc-partner-link:hover { color: var(--text); }

@media (max-width: 800px) {
  .pcc-inner { grid-template-columns: 1fr; gap: 36px; }
}

/* ═══════════════════════════════════════════════════════
   FOOTER — BRAND, CONTACT COL, TRUST & SEO LINKS
═══════════════════════════════════════════════════════ */
.footer-brand-mark { margin-bottom: 8px; }
.footer-tagline-sub {
  font-family: var(--ff-display);
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-4);
  margin-bottom: 10px;
}
.footer-contact-col { }
.fc-contact-item {
  display: flex; flex-direction: column; gap: 2px;
  margin-bottom: 12px;
}
.fc-label {
  font-family: var(--ff-display);
  font-size: 9px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-4);
}
.fc-email { font-size: 12px; color: var(--brass-lt); }
.fc-email:hover { color: var(--text); }

.footer-trust-links {
  display: flex; flex-wrap: wrap; gap: 6px 18px;
  padding: 16px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 12px;
}
.footer-trust-links a {
  font-size: 11px; color: var(--text-4);
}
.footer-trust-links a:hover { color: var(--text-2); }

.footer-seo-links {
  display: flex; flex-wrap: wrap; gap: 4px 14px;
  margin-bottom: 16px;
}
.footer-seo-links a {
  font-size: 10px; color: var(--text-4); opacity: 0.6;
}
.footer-seo-links a:hover { opacity: 1; }

/* ── Footer social feed placeholder ── */
.footer-social-feed {
  margin-top: 20px;
  padding: 14px;
  background: rgba(255,255,255,0.02);
  border: 1px dashed rgba(255,255,255,0.10);
  border-radius: 4px;
}
.fsf-label {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--ff-display);
  font-size: 9px; font-weight: 800; letter-spacing: 0.16em;
  color: var(--text-4); text-transform: uppercase;
  margin-bottom: 10px;
}
.fsf-cs-tag {
  background: rgba(232,184,76,0.12);
  color: var(--brass-lt);
  border: 1px solid rgba(232,184,76,0.20);
  font-size: 8px; padding: 1px 6px; border-radius: 2px;
  letter-spacing: 0.12em;
}
.fsf-placeholder {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 6px;
  margin-bottom: 10px;
}
.fsf-post {
  aspect-ratio: 1;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 3px;
  position: relative; overflow: hidden;
}
.fsf-post::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.04) 50%, transparent 70%);
  animation: shimmer 2s infinite;
}
@keyframes shimmer {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.fsf-follow {
  display: block;
  font-size: 11px; color: var(--text-4);
  transition: color var(--t);
}
.fsf-follow:hover { color: var(--brass-lt); }

/* ═══════════════════════════════════════════════════════
   APPLY — MAILBOX CTA (replaces form)
═══════════════════════════════════════════════════════ */
.acard-mailbox {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 4px 0 0;
}
.acard-what {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.acard-what-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.5;
}
.acard-what-item span {
  font-size: 16px;
  flex-shrink: 0;
  width: 22px;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   RANKING DIMENSIONS
═══════════════════════════════════════════════════════════════ */
.rank-dims-section {
  padding: 96px 0;
  background: var(--bg1);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.rdims-header { text-align: center; margin-bottom: 52px; }
.rdims-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2px;
  margin-bottom: 32px;
}
.rdim-card {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 24px 18px;
  text-align: center;
  transition: border-color var(--t) var(--ease), background var(--t) var(--ease);
}
.rdim-card:hover {
  border-color: var(--line-md);
  background: var(--bg3);
}
.rdim-highlight {
  border-color: var(--red-border);
  background: linear-gradient(135deg, var(--bg2) 0%, rgba(255,70,85,0.06) 100%);
}
.rdim-icon { font-size: 26px; margin-bottom: 10px; }
.rdim-name {
  font-family: var(--ff-display);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 8px;
}
.rdim-desc { font-size: 12px; color: var(--text-3); line-height: 1.5; }
.rdims-note {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-3);
  justify-content: center;
}
.rdims-note svg { color: var(--red); flex-shrink: 0; }
@media (max-width: 900px) {
  .rdims-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .rdims-grid { grid-template-columns: 1fr; gap: 1px; }
}

/* ═══════════════════════════════════════════════════════════════
   GAMES SUPPORTED
═══════════════════════════════════════════════════════════════ */
.games-section {
  padding: 96px 0;
  background: var(--bg0);
  border-bottom: 1px solid var(--line);
}
.games-header { text-align: center; margin-bottom: 52px; }
.games-launch-wrap { margin-bottom: 48px; }
.games-launch-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--nvg);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.games-launch-label::before {
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  background: var(--nvg);
}
.games-launch-card {
  background: linear-gradient(135deg, var(--bg2) 0%, rgba(0,230,118,0.05) 100%);
  border: 1px solid var(--nvg-border);
  border-radius: 2px;
  padding: 32px;
  position: relative;
  overflow: hidden;
}
.games-launch-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 60%, rgba(0,230,118,0.04) 100%);
  pointer-events: none;
}
.glc-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--nvg);
  background: var(--nvg-bg);
  border: 1px solid var(--nvg-border);
  padding: 4px 12px;
  border-radius: 1px;
  margin-bottom: 20px;
}
.glc-body {
  display: flex;
  gap: 28px;
  align-items: flex-start;
}
.glc-icon-wrap {
  width: 64px;
  height: 64px;
  background: var(--nvg-bg);
  border: 1px solid var(--nvg-border);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  flex-shrink: 0;
}
.glc-name {
  font-family: var(--ff-display);
  font-size: 32px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1;
  margin-bottom: 4px;
}
.glc-tagline {
  font-size: 12px;
  color: var(--nvg);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.glc-desc { font-size: 14px; color: var(--text-2); line-height: 1.65; margin-bottom: 16px; }
.glc-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.glc-tag {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-2);
  background: var(--steel-hi);
  border: 1px solid var(--steel-border);
  padding: 3px 10px;
  border-radius: 1px;
}
.glc-status-bar {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--nvg-border);
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--nvg);
}
.games-future-wrap { margin-bottom: 32px; }
.games-future-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.games-future-label::before {
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  background: var(--text-4);
}
.games-future-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}
.gfg-item {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 20px 16px;
  text-align: center;
  transition: border-color var(--t) var(--ease);
}
.gfg-item:hover { border-color: var(--line-md); }
.gfg-open { border-color: var(--red-border); background: var(--red-bg); }
.gfg-icon { font-size: 24px; margin-bottom: 8px; }
.gfg-open .gfg-icon {
  font-size: 28px;
  font-family: var(--ff-display);
  font-weight: 900;
  color: var(--red);
}
.gfg-name {
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--text);
  margin-bottom: 3px;
}
.gfg-sub { font-size: 11px; color: var(--text-4); margin-bottom: 10px; }
.gfg-status {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 1px;
  border: 1px solid;
  text-decoration: none;
}
.gfs-soon { color: var(--amber-lt); border-color: var(--amber-border); background: var(--amber-bg); }
.gfs-planned { color: var(--text-3); border-color: var(--line); background: var(--steel-hi); }
.gfs-open { color: var(--red-lt); border-color: var(--red-border); background: var(--red-bg); cursor: pointer; }
.games-arch-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--text-3);
  line-height: 1.65;
  padding: 16px 20px;
  background: var(--steel-hi);
  border: 1px solid var(--line);
  border-radius: 2px;
}
.games-arch-note svg { color: var(--brass-lt); flex-shrink: 0; margin-top: 2px; }
.arch-link { color: var(--intel); text-decoration: none; }
.arch-link:hover { text-decoration: underline; }
@media (max-width: 900px) {
  .glc-body { flex-direction: column; }
  .games-future-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .games-future-grid { grid-template-columns: 1fr; }
  .games-launch-card { padding: 20px; }
}

/* ═══════════════════════════════════════════════════════════════
   HALL OF CHAMPIONS
═══════════════════════════════════════════════════════════════ */
.hoc-section {
  padding: 96px 0;
  background: var(--bg3);
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.hoc-bg-glow {
  position: absolute;
  top: -120px;
  left: 50%;
  transform: translateX(-50%);
  width: 700px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(232,180,32,0.10) 0%, transparent 70%);
  pointer-events: none;
}
.hoc-header { text-align: center; margin-bottom: 52px; }
/* Zorthorn Kings */
.hok-block {
  text-align: center;
  margin-bottom: 64px;
  padding: 40px 32px;
  background: linear-gradient(135deg, var(--bg2) 0%, rgba(232,180,32,0.06) 100%);
  border: 1px solid var(--r-leg-border);
  position: relative;
  overflow: hidden;
}
.hok-block::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--r-legendary), transparent);
}
.hok-crown-wrap { position: relative; display: inline-block; margin-bottom: 12px; }
.hok-crown-glow {
  position: absolute;
  inset: -20px;
  background: radial-gradient(ellipse, rgba(232,180,32,0.3) 0%, transparent 70%);
  pointer-events: none;
}
.hok-crown { font-size: 52px; position: relative; }
.hok-title {
  font-family: var(--ff-display);
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--r-legendary);
  margin-bottom: 10px;
}
.hok-sub {
  max-width: 560px;
  margin: 0 auto 32px;
  font-size: 15px;
  color: var(--text-2);
  line-height: 1.65;
}
.hok-slots {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.hok-slot {
  background: var(--bg3);
  border: 1px solid var(--line);
  padding: 20px 28px;
  min-width: 160px;
  text-align: center;
}
.hok-current { border-color: var(--r-leg-border); background: var(--r-leg-bg); }
.hok-locked { opacity: 0.5; }
.hok-slot-season {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-4);
  margin-bottom: 10px;
}
.hok-slot-throne { font-size: 32px; margin-bottom: 8px; }
.locked-throne { filter: grayscale(1); opacity: 0.4; }
.hok-slot-name {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 4px;
}
.hok-slot-date { font-size: 11px; color: var(--text-3); margin-bottom: 8px; }
.hok-slot-tag {
  font-family: var(--ff-display);
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--nvg);
  background: var(--nvg-bg);
  border: 1px solid var(--nvg-border);
  padding: 3px 8px;
  display: inline-block;
}
/* Category cards */
.hoc-cats-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-4);
  text-align: center;
  margin-bottom: 24px;
}
.hoc-cats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 52px;
}
.hoc-cat {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 24px 20px;
  transition: border-color var(--t) var(--ease);
}
.hoc-cat:hover { border-color: var(--line-md); }
.hoc-cat-icon { font-size: 28px; margin-bottom: 12px; }
.hoc-cat-title {
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 8px;
}
.hoc-cat-desc { font-size: 13px; color: var(--text-2); line-height: 1.6; margin-bottom: 14px; }
.hoc-cat-badge {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 10px;
  border: 1px solid;
  border-radius: 1px;
}
/* Records */
.hoc-records {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 32px;
  margin-bottom: 48px;
}
.hoc-rec-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-4);
  margin-bottom: 20px;
}
.hoc-rec-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-bottom: 20px;
}
.hoc-rec-item {
  background: var(--bg3);
  border: 1px solid var(--line);
  padding: 18px 14px;
  text-align: center;
}
.hoc-rec-icon { font-size: 22px; margin-bottom: 8px; }
.hoc-rec-name {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-2);
  margin-bottom: 6px;
}
.hoc-rec-val {
  font-family: var(--ff-display);
  font-size: 20px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 4px;
}
.hoc-rec-val span { font-size: 10px; color: var(--text-4); letter-spacing: 0.1em; }
.hoc-rec-note { font-size: 10px; color: var(--text-4); }
.hoc-rec-note-bottom { font-size: 13px; color: var(--text-3); line-height: 1.6; }
/* CTA */
.hoc-cta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 32px;
  background: var(--red-bg);
  border: 1px solid var(--red-border);
}
.hoc-cta-row h3 {
  font-family: var(--ff-display);
  font-size: 26px;
  font-weight: 900;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.1;
}
.hoc-cta-row h3 span { color: var(--red-lt); }
.hoc-cta-row p { font-size: 13px; color: var(--text-2); max-width: 420px; line-height: 1.6; }
@media (max-width: 900px) {
  .hoc-cats { grid-template-columns: repeat(2, 1fr); }
  .hoc-rec-grid { grid-template-columns: repeat(2, 1fr); }
  .hoc-cta-row { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 600px) {
  .hoc-cats { grid-template-columns: 1fr; }
  .hok-slots { flex-direction: column; align-items: center; }
  .hoc-rec-grid { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   ACHIEVEMENT SYSTEM
═══════════════════════════════════════════════════════════════ */
.achievements-section {
  padding: 96px 0;
  background: var(--bg1);
  border-bottom: 1px solid var(--line);
}
.ach-header { text-align: center; margin-bottom: 52px; }
.ach-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-bottom: 32px;
}
.ach-card {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 24px 18px;
  text-align: center;
  transition: border-color var(--t) var(--ease), transform var(--t) var(--ease);
}
.ach-card:hover { transform: translateY(-2px); }
.ach-icon { font-size: 32px; margin-bottom: 12px; }
.ach-name {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 6px;
  line-height: 1.2;
}
.ach-cond { font-size: 11px; color: var(--text-3); line-height: 1.5; margin-bottom: 14px; }
.ach-rarity {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 10px;
  border: 1px solid;
  border-radius: 1px;
}
.ach-common { border-color: var(--r-common-border); }
.ach-rare { border-color: var(--r-rare-border); }
.ach-epic { border-color: var(--r-epic-border); }
.ach-legendary { border-color: var(--r-leg-border); }
.ach-mythic {
  border-color: var(--red-border);
  background: linear-gradient(135deg, var(--bg2) 0%, rgba(255,70,85,0.06) 100%);
  position: relative;
  overflow: hidden;
}
.ach-mythic::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
}
.ach-r-common { color: var(--r-common); border-color: var(--r-common-border); }
.ach-r-rare { color: var(--r-rare); border-color: var(--r-rare-border); }
.ach-r-epic { color: var(--r-epic); border-color: var(--r-epic-border); }
.ach-r-legendary { color: var(--r-legendary); border-color: var(--r-leg-border); }
.ach-r-mythic { color: var(--red-lt); border-color: var(--red-border); }
.ach-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--text-3);
  line-height: 1.65;
  padding: 16px 20px;
  background: var(--steel-hi);
  border: 1px solid var(--line);
}
.ach-note svg { color: var(--intel); flex-shrink: 0; margin-top: 1px; }
@media (max-width: 1000px) {
  .ach-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .ach-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .ach-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   SEASONAL MODEL
═══════════════════════════════════════════════════════════════ */
.season-model-section {
  padding: 96px 0;
  background: var(--bg0);
  border-bottom: 1px solid var(--line);
}
.sm-header { text-align: center; margin-bottom: 52px; }
.sm-seasons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-bottom: 64px;
}
.sm-season {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 28px 20px;
  position: relative;
  transition: border-color var(--t) var(--ease);
}
.sm-season:hover { border-color: var(--line-md); }
.sm-active {
  border-color: var(--red-border);
  background: linear-gradient(135deg, var(--bg2) 0%, rgba(255,70,85,0.05) 100%);
}
.sm-active-pill {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--nvg);
  background: var(--nvg-bg);
  border: 1px solid var(--nvg-border);
  padding: 3px 10px;
  display: inline-block;
  margin-bottom: 14px;
}
.sm-spring { border-top: 2px solid #f9a8d4; }
.sm-summer { border-top: 2px solid var(--red); }
.sm-autumn { border-top: 2px solid var(--amber-lt); }
.sm-winter { border-top: 2px solid var(--intel); }
.sm-season-icon { font-size: 32px; margin-bottom: 10px; }
.sm-season-name {
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 4px;
}
.sm-season-dates {
  font-size: 11px;
  color: var(--text-4);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
}
.sm-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sm-features li {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.4;
  padding-left: 14px;
  position: relative;
}
.sm-features li::before {
  content: '✦';
  position: absolute;
  left: 0;
  color: var(--text-4);
  font-size: 8px;
  top: 2px;
}
/* Each-season grid */
.sm-each-season { }
.sm-es-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-4);
  text-align: center;
  margin-bottom: 24px;
}
.sm-es-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}
.sm-es-item {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 22px 18px;
}
.sm-es-icon { font-size: 24px; margin-bottom: 10px; }
.sm-es-name {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 7px;
}
.sm-es-desc { font-size: 12px; color: var(--text-3); line-height: 1.6; }
@media (max-width: 900px) {
  .sm-seasons { grid-template-columns: repeat(2, 1fr); }
  .sm-es-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .sm-seasons { grid-template-columns: 1fr; }
  .sm-es-grid { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════════════════════════
   PREMIUM UPGRADE — AAA Esports Platform v2.0
   Road to Zorthorn Kings · Live Matches · Player Progression
   Download App · Enhanced Hero · Premium Glassmorphism
═══════════════════════════════════════════════════════════════ */

/* ── Enhanced Hero Neon Pulse ── */
@keyframes neonPulse {
  0%,100% { box-shadow: 0 0 20px rgba(255,70,85,0.4), 0 0 60px rgba(255,70,85,0.15); }
  50%      { box-shadow: 0 0 40px rgba(255,70,85,0.7), 0 0 100px rgba(255,70,85,0.25); }
}
@keyframes floatY {
  0%,100% { transform: translateY(0px); }
  50%      { transform: translateY(-12px); }
}
@keyframes scanline {
  0% { transform: translateY(-100%); }
  100% { transform: translateY(100vh); }
}
@keyframes particleDrift {
  0%   { transform: translate(0,0) scale(1); opacity: 0.8; }
  50%  { transform: translate(30px,-40px) scale(1.2); opacity: 0.4; }
  100% { transform: translate(-20px, 60px) scale(0.8); opacity: 0; }
}
@keyframes glitchShift {
  0%,90%,100% { clip-path: none; transform: none; }
  91% { clip-path: polygon(0 5%, 100% 5%, 100% 20%, 0 20%); transform: translateX(-3px); }
  92% { clip-path: polygon(0 40%, 100% 40%, 100% 55%, 0 55%); transform: translateX(3px); }
  93% { clip-path: none; transform: none; }
}
@keyframes countUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: none; }
}
@keyframes borderTrail {
  0% { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}
@keyframes rankGlow {
  0%,100% { filter: drop-shadow(0 0 8px currentColor); }
  50%      { filter: drop-shadow(0 0 20px currentColor) brightness(1.3); }
}
@keyframes liveFlash {
  0%,100% { opacity: 1; }
  50%      { opacity: 0.3; }
}
@keyframes roadmapPulse {
  0%,100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(255,70,85,0.4); }
  50%      { transform: scale(1.08); box-shadow: 0 0 0 12px rgba(255,70,85,0); }
}
@keyframes shimmerCard {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes typewriter {
  from { width: 0; }
  to   { width: 100%; }
}
@keyframes blink-caret {
  from,to { border-right-color: transparent; }
  50%     { border-right-color: var(--red); }
}

/* ── Hero Enhancement — animated stats ── */
.hero-stats-bar {
  display: flex;
  gap: 0;
  margin-top: 28px;
  border: 1px solid rgba(255,70,85,0.15);
  border-radius: 3px;
  overflow: hidden;
  background: rgba(255,70,85,0.04);
}
.hero-stat-item {
  flex: 1;
  padding: 14px 16px;
  border-right: 1px solid rgba(255,70,85,0.1);
  position: relative;
}
.hero-stat-item:last-child { border-right: none; }
.hero-stat-num {
  font-family: var(--ff-display);
  font-size: 26px;
  font-weight: 900;
  line-height: 1;
  color: var(--red-lt);
  letter-spacing: -0.01em;
}
.hero-stat-num.gold { color: var(--brass-lt); }
.hero-stat-num.green { color: var(--nvg); }
.hero-stat-num.blue { color: var(--intel); }
.hero-stat-label {
  font-size: 9px;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-top: 3px;
}

/* ── Floating particle effects for hero ── */
.hero-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.hero-particle {
  position: absolute;
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--red-lt);
  animation: particleDrift var(--dur, 4s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  opacity: 0.6;
}
.hp-gold { background: var(--brass-lt); }
.hp-blue { background: var(--intel); }
.hp-green { background: var(--nvg); }

/* ── Road to Zorthorn Kings ── */
.road-section {
  padding: var(--section-py) 0;
  background: var(--bg3);
  position: relative;
  overflow: hidden;
}
.road-section::before {
  content: '';
  position: absolute;
  top: -100px; left: 50%;
  transform: translateX(-50%);
  width: 800px; height: 800px;
  background: radial-gradient(ellipse, rgba(255,70,85,0.06) 0%, transparent 65%);
  pointer-events: none;
}
.road-header { text-align: center; margin-bottom: 60px; }
.road-crown {
  font-size: 48px;
  display: block;
  margin-bottom: 16px;
  filter: drop-shadow(0 0 24px rgba(201,155,60,0.6));
  animation: floatY 3s ease-in-out infinite;
}
.road-pathway {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  max-width: 680px;
  margin: 0 auto;
  position: relative;
}
.road-pathway::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0; bottom: 0;
  width: 2px;
  transform: translateX(-50%);
  background: linear-gradient(180deg,
    var(--red) 0%,
    var(--r-epic) 25%,
    var(--intel) 50%,
    var(--brass-lt) 75%,
    #ffd700 100%
  );
  opacity: 0.4;
}
.road-node {
  display: flex;
  align-items: center;
  gap: 20px;
  width: 100%;
  position: relative;
  padding: 4px 0;
}
.road-node:nth-child(even) { flex-direction: row-reverse; }
.road-node-content {
  flex: 1;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 4px;
  padding: 18px 22px;
  transition: transform 0.3s var(--ease), border-color 0.3s, box-shadow 0.3s;
  cursor: default;
}
.road-node-content:hover {
  transform: scale(1.02) translateY(-2px);
  border-color: var(--node-color, var(--red-border));
  box-shadow: 0 8px 32px var(--node-glow, rgba(255,70,85,0.15));
}
.road-node-pip {
  width: 48px; height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
  border: 2px solid var(--node-color, var(--red));
  background: var(--node-bg, rgba(255,70,85,0.1));
  box-shadow: 0 0 20px var(--node-glow, rgba(255,70,85,0.3));
  position: relative;
  z-index: 2;
  transition: box-shadow 0.3s, transform 0.3s;
}
.road-node:hover .road-node-pip {
  transform: scale(1.15);
  box-shadow: 0 0 40px var(--node-glow, rgba(255,70,85,0.5));
}
.road-node-connector {
  position: absolute;
  left: 50%;
  top: 100%;
  width: 2px;
  height: 28px;
  background: linear-gradient(180deg, var(--node-color, var(--red)), transparent);
  transform: translateX(-50%);
  opacity: 0.5;
}
.road-title {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 4px;
}
.road-sub {
  font-size: 12px;
  color: var(--text-3);
  line-height: 1.5;
}
.road-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 9px;
  font-family: var(--ff-display);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  margin-top: 6px;
  background: var(--node-bg, rgba(255,70,85,0.1));
  border: 1px solid var(--node-color, var(--red-border));
  color: var(--node-color, var(--red-lt));
}
.road-final-node {
  text-align: center;
  padding: 32px;
  background: linear-gradient(135deg, rgba(201,155,60,0.08), rgba(255,215,0,0.04), rgba(255,70,85,0.06));
  border: 1px solid rgba(201,155,60,0.3);
  border-radius: 6px;
  box-shadow: 0 0 60px rgba(201,155,60,0.12), inset 0 1px 0 rgba(255,255,255,0.05);
  animation: neonPulse 3s ease-in-out infinite;
  animation-name: glowBorder;
  width: 100%;
  margin-top: 16px;
}
.road-final-crown { font-size: 52px; margin-bottom: 12px; display: block; filter: drop-shadow(0 0 30px rgba(255,215,0,0.8)); animation: floatY 2.5s ease-in-out infinite; }
.road-final-title {
  font-family: var(--ff-display);
  font-size: clamp(24px, 4vw, 40px);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #ffd700, var(--brass-lt), var(--amber-lt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.road-final-sub { font-size: 14px; color: var(--text-2); margin-top: 8px; }

/* ── Live Matches Section ── */
.live-section {
  padding: var(--section-py) 0;
  background: var(--bg1);
  position: relative;
  overflow: hidden;
}
.live-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
}
.live-header { margin-bottom: 40px; }
.live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,70,85,0.08);
  border: 1px solid rgba(255,70,85,0.2);
  border-radius: 2px;
  padding: 6px 14px;
  font-size: 11px;
  font-family: var(--ff-display);
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red-lt);
  margin-bottom: 20px;
}
.live-dot-animated {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--red);
  animation: liveFlash 1s ease-in-out infinite;
}
.live-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 24px;
}
.live-match-card {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 20px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.3s, transform 0.3s, box-shadow 0.3s;
}
.live-match-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--card-top, var(--red));
  opacity: 0.8;
}
.live-match-card:hover {
  transform: translateY(-4px);
  border-color: rgba(255,70,85,0.25);
  box-shadow: 0 16px 48px rgba(0,0,0,0.4), 0 0 20px rgba(255,70,85,0.08);
}
.lmc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.lmc-game-tag {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
}
.lmc-live-badge {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  color: var(--red-lt);
  font-family: var(--ff-display);
  font-weight: 700;
  letter-spacing: 0.1em;
}
.lmc-live-badge span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--red);
  animation: liveFlash 1s infinite;
}
.lmc-title {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text);
  margin-bottom: 12px;
}
.lmc-teams {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.lmc-team { text-align: center; }
.lmc-team-name {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text);
}
.lmc-team-sub { font-size: 10px; color: var(--text-4); margin-top: 2px; }
.lmc-vs {
  font-family: var(--ff-display);
  font-size: 20px;
  font-weight: 900;
  color: var(--text-3);
  letter-spacing: 0.08em;
}
.lmc-score {
  font-family: var(--ff-display);
  font-size: 28px;
  font-weight: 900;
  color: var(--brass-lt);
  text-align: center;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
}
.lmc-meta {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--text-4);
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.lmc-viewers { color: var(--intel); }
.lmc-watch-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 10px;
  background: rgba(255,70,85,0.08);
  border: 1px solid rgba(255,70,85,0.2);
  border-radius: 2px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red-lt);
  margin-top: 14px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}
.lmc-watch-btn:hover {
  background: rgba(255,70,85,0.15);
  border-color: var(--red);
  transform: translateY(-1px);
}
.live-upcoming {
  border: 1px solid var(--line);
  border-radius: 3px;
  overflow: hidden;
}
.live-upcoming-header {
  background: rgba(255,255,255,0.03);
  padding: 12px 20px;
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-4);
  border-bottom: 1px solid var(--line);
}
.live-upcoming-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--line);
  transition: background 0.2s;
}
.live-upcoming-row:last-child { border-bottom: none; }
.live-upcoming-row:hover { background: rgba(255,255,255,0.02); }
.lur-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.lur-dot.live { background: var(--red); animation: liveFlash 1s infinite; }
.lur-dot.soon { background: var(--amber-lt); }
.lur-dot.upcoming { background: var(--text-4); }
.lur-name { flex: 1; font-size: 13px; color: var(--text-2); }
.lur-game { font-size: 10px; color: var(--text-4); }
.lur-prize { font-family: var(--ff-display); font-size: 12px; font-weight: 800; color: var(--brass-lt); }
.lur-time { font-size: 11px; color: var(--text-3); }
.lur-status {
  font-size: 9px;
  font-family: var(--ff-display);
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 2px;
}
.lur-status.live-s { background: rgba(255,70,85,0.1); border: 1px solid rgba(255,70,85,0.2); color: var(--red-lt); }
.lur-status.soon-s { background: rgba(240,160,32,0.1); border: 1px solid rgba(240,160,32,0.2); color: var(--amber-lt); }

/* ── Player Progression Ranks ── */
.ranks-section {
  padding: var(--section-py) 0;
  background: var(--bg0);
  position: relative;
  overflow: hidden;
}
.ranks-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 100%, rgba(153,85,238,0.05) 0%, transparent 60%);
  pointer-events: none;
}
.ranks-header { text-align: center; margin-bottom: 52px; }
.ranks-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 2px;
  margin-bottom: 48px;
}
.rank-card-premium {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 20px 14px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s var(--ease), border-color 0.3s, box-shadow 0.3s;
  cursor: default;
}
.rank-card-premium::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--rank-color, var(--text-4));
  opacity: 0.6;
}
.rank-card-premium:hover {
  transform: translateY(-6px) scale(1.02);
  border-color: var(--rank-color, var(--text-4));
  box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 0 24px var(--rank-glow, rgba(255,255,255,0.1));
}
.rank-icon-lg {
  font-size: 36px;
  margin-bottom: 10px;
  display: block;
  filter: drop-shadow(0 0 8px var(--rank-color, transparent));
  transition: filter 0.3s, transform 0.3s;
}
.rank-card-premium:hover .rank-icon-lg {
  filter: drop-shadow(0 0 20px var(--rank-color, transparent));
  transform: scale(1.1) rotate(-5deg);
  animation: rankGlow 1.5s ease-in-out infinite;
}
.rank-name-lg {
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--rank-color, var(--text));
  margin-bottom: 4px;
}
.rank-range {
  font-size: 9px;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.rank-unlock-label {
  font-size: 9px;
  color: var(--text-3);
  margin-top: 8px;
  line-height: 1.4;
}
.rank-card-premium.active-rank {
  border-color: var(--rank-color, var(--red));
  box-shadow: 0 0 30px var(--rank-glow, rgba(255,70,85,0.2));
}
.rank-current-pill {
  position: absolute;
  top: 8px; left: 50%; transform: translateX(-50%);
  background: var(--rank-color, var(--red));
  color: #0a0a0a;
  font-size: 7px;
  font-family: var(--ff-display);
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 2px;
  white-space: nowrap;
}

/* Second row of ranks */
.ranks-grid-2 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2px;
  margin-bottom: 16px;
}
.ranks-legend {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 11px;
  color: var(--text-3);
  margin-top: 24px;
}
.ranks-legend svg { flex-shrink: 0; }

/* ── Download App Section ── */
.download-section {
  padding: var(--section-py) 0;
  background: var(--bg3);
  position: relative;
  overflow: hidden;
}
.download-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(255,70,85,0.07) 0%, transparent 50%),
              radial-gradient(ellipse at 70% 50%, rgba(68,136,238,0.05) 0%, transparent 50%);
  pointer-events: none;
}
.download-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.download-left {}
.download-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
}
.dl-kicker { margin-bottom: 6px; }
.download-h2 {
  font-family: var(--ff-display);
  font-size: clamp(40px, 6vw, 72px);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 0.9;
  color: var(--text);
  margin-bottom: 20px;
}
.download-h2 span {
  background: linear-gradient(90deg, var(--red-lt), var(--brass-lt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.dl-desc { font-size: 17px; color: var(--text-2); line-height: 1.65; max-width: 440px; margin-bottom: 28px; }
.dl-features {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 28px;
}
.dl-feat {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--text-2);
}
.dl-feat svg { color: var(--nvg); flex-shrink: 0; }
.dl-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.dl-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  transition: transform 0.2s var(--ease), border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.dl-btn:hover {
  transform: translateY(-3px);
  border-color: rgba(255,70,85,0.4);
  box-shadow: 0 12px 32px rgba(0,0,0,0.3);
  background: rgba(255,255,255,0.07);
}
.dl-btn-icon { font-size: 28px; }
.dl-btn-text { display: flex; flex-direction: column; }
.dl-btn-sub { font-size: 9px; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.1em; }
.dl-btn-name { font-family: var(--ff-display); font-size: 17px; font-weight: 800; color: var(--text); letter-spacing: 0.04em; }
.dl-soon-badge {
  font-size: 9px;
  font-family: var(--ff-display);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--amber-lt);
  background: rgba(240,160,32,0.1);
  border: 1px solid rgba(240,160,32,0.2);
  padding: 2px 8px;
  border-radius: 2px;
  align-self: flex-start;
  margin-top: 12px;
}
/* App mockup */
.dl-app-mockup {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 24px;
  padding: 24px;
  max-width: 320px;
  margin: 0 auto;
  position: relative;
  box-shadow: 0 32px 80px rgba(0,0,0,0.5), 0 0 60px rgba(255,70,85,0.06);
}
.dl-app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.dl-app-brand {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
}
.dl-app-version {
  font-size: 10px;
  color: var(--text-4);
  background: rgba(255,255,255,0.06);
  padding: 2px 8px;
  border-radius: 10px;
}
.dl-feature-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.dl-feat-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 6px;
}
.dl-feat-row-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  background: rgba(255,70,85,0.08);
  flex-shrink: 0;
}
.dl-feat-row-text strong { font-size: 13px; color: var(--text); display: block; }
.dl-feat-row-text span { font-size: 11px; color: var(--text-4); }

/* ── Enhanced Championship Cards ── */
.champ-ecosystem {
  padding: var(--section-py) 0;
  background: var(--bg0);
}
.champ-eco-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-bottom: 3px;
}
.champ-eco-row2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}
.ce-card {
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 28px 22px;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s var(--ease), border-color 0.3s, box-shadow 0.3s;
}
.ce-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--ce-color, var(--red));
  opacity: 0.8;
}
.ce-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: radial-gradient(ellipse at 50% -20%, var(--ce-glow, rgba(255,70,85,0.06)) 0%, transparent 60%);
  pointer-events: none;
}
.ce-card:hover {
  transform: translateY(-6px);
  border-color: var(--ce-color, var(--red-border));
  box-shadow: 0 24px 60px rgba(0,0,0,0.4), 0 0 30px var(--ce-glow, rgba(255,70,85,0.12));
}
.ce-tier-badge {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ce-color, var(--red-lt));
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}
.ce-icon { font-size: 32px; margin-bottom: 10px; position: relative; z-index: 1; }
.ce-title {
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text);
  margin-bottom: 8px;
  position: relative;
  z-index: 1;
}
.ce-desc { font-size: 12px; color: var(--text-3); line-height: 1.6; margin-bottom: 16px; position: relative; z-index: 1; }
.ce-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
  z-index: 1;
}
.ce-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
}
.ce-detail-label { color: var(--text-4); }
.ce-detail-val { color: var(--text-2); font-family: var(--ff-display); font-weight: 700; }
.ce-prize { color: var(--brass-lt); }
.ce-badge-reward {
  margin-top: 14px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 2px;
  font-size: 11px;
  color: var(--text-3);
  position: relative;
  z-index: 1;
}
.ce-join-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
  padding: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 2px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  z-index: 1;
  text-decoration: none;
}
.ce-join-btn:hover {
  background: var(--ce-bg, rgba(255,70,85,0.08));
  border-color: var(--ce-color, var(--red-border));
  color: var(--ce-color, var(--red-lt));
}

/* ── Top Players & Teams ── */
.top-players-section {
  padding: var(--section-py) 0;
  background: var(--bg1);
}
.top-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}
.top-panel-label {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-4);
  padding: 10px 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--line);
  border-bottom: none;
}
.player-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-top: none;
  transition: background 0.2s, transform 0.2s;
}
.player-row:hover {
  background: rgba(255,255,255,0.04);
  transform: translateX(4px);
}
.pr-pos {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 900;
  width: 28px;
  text-align: center;
  flex-shrink: 0;
}
.pr-pos.gold { color: #ffd700; }
.pr-pos.silver { color: #c0c0c0; }
.pr-pos.bronze { color: #cd7f32; }
.pr-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 900;
  flex-shrink: 0;
  background: rgba(255,70,85,0.1);
  border: 1px solid rgba(255,70,85,0.2);
  color: var(--text);
}
.pr-info { flex: 1; min-width: 0; }
.pr-name { font-size: 14px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pr-sub { font-size: 10px; color: var(--text-4); margin-top: 1px; }
.pr-rank-badge {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 2px;
  flex-shrink: 0;
}
.pr-score {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 900;
  color: var(--brass-lt);
  flex-shrink: 0;
}
.pr-change {
  font-size: 10px;
  font-family: var(--ff-display);
  font-weight: 800;
  width: 30px;
  text-align: right;
  flex-shrink: 0;
}
.pr-change.up { color: var(--nvg); }
.pr-change.down { color: var(--red); }

/* ── Glassmorphism Enhanced Cards ── */
.glass-card {
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 4px;
}
.glass-card-premium {
  background: linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 8px 32px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.06);
}

/* ── Premium button upgrade ── */
.btn-unlock {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--red) 0%, #c62035 100%);
  color: #fff;
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 16px 32px;
  border-radius: 3px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,100,120,0.3);
  border-top: 2px solid rgba(255,150,160,0.4);
  box-shadow:
    0 4px 24px rgba(255,70,85,0.35),
    0 1px 0 rgba(255,255,255,0.1) inset,
    0 -1px 0 rgba(0,0,0,0.2) inset;
  transition: transform 0.2s var(--ease), box-shadow 0.2s, filter 0.2s;
}
.btn-unlock::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.1) 0%, transparent 60%);
  opacity: 0.5;
}
.btn-unlock::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  transform: skewX(-20deg);
  transition: left 0.5s ease;
}
.btn-unlock:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(255,70,85,0.5), 0 1px 0 rgba(255,255,255,0.1) inset;
  filter: brightness(1.1);
}
.btn-unlock:hover::after { left: 200%; }
.btn-unlock svg { position: relative; z-index: 1; }

/* ── Animated Counter Stats ── */
.stats-counter {
  font-family: var(--ff-display);
  font-variant-numeric: tabular-nums;
}
.stat-number-animated {
  display: inline-block;
  animation: countUp 0.6s var(--ease) both;
}

/* ── Premium section transitions ── */
section { position: relative; }

/* ── Nav Premium Upgrade ── */
.nav-links a {
  position: relative;
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-2);
  transition: color var(--t);
  padding: 4px 0;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 100%;
  height: 1px;
  background: var(--red);
  transition: right 0.25s var(--ease);
}
.nav-links a:hover { color: var(--text); }
.nav-links a:hover::after,
.nav-links a.active::after { right: 0; }
.nav-links a.active { color: var(--red-lt); }

/* ── Animated background grid lines ── */
.hero-grid {
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 1;
  animation: none;
}

/* ── Live section overlay effects ── */
.live-section::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(255,255,255,0.005) 2px,
    rgba(255,255,255,0.005) 4px
  );
  pointer-events: none;
  opacity: 0.5;
}

/* ── Responsive adjustments ── */
@media (max-width: 1100px) {
  .ranks-grid { grid-template-columns: repeat(4, 1fr); }
  .ranks-grid-2 { grid-template-columns: repeat(4, 1fr); }
  .live-grid { grid-template-columns: repeat(2, 1fr); }
  .champ-eco-grid { grid-template-columns: repeat(2, 1fr); }
  .champ-eco-row2 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .download-grid { grid-template-columns: 1fr; gap: 40px; }
  .top-split { grid-template-columns: 1fr; }
  .hero-stats-bar { display: none; }
}
@media (max-width: 600px) {
  .ranks-grid { grid-template-columns: repeat(3, 1fr); }
  .ranks-grid-2 { grid-template-columns: repeat(3, 1fr); }
  .live-grid { grid-template-columns: 1fr; }
  .champ-eco-grid { grid-template-columns: 1fr; }
  .champ-eco-row2 { grid-template-columns: 1fr; }
}

/* ── Scroll-triggered section reveals (stagger) ── */
.stagger-reveal > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
}
.stagger-reveal > *.in {
  opacity: 1;
  transform: none;
}

/* ── Premium hover glow on comp-cards ── */
.comp-card {
  transition: transform 0.3s var(--ease), border-color 0.3s, box-shadow 0.3s !important;
}
.comp-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 24px 60px rgba(0,0,0,0.4), 0 0 40px rgba(255,70,85,0.1) !important;
}
.featured-comp:hover {
  box-shadow: 0 24px 60px rgba(0,0,0,0.5), 0 0 60px rgba(255,70,85,0.2) !important;
}

/* ── Enhanced XP bar animation ── */
@keyframes xpFill {
  from { width: 0; }
}
.hero-xp-bar-fill,
.ic-xp-fill,
.cpf-prog-fill,
.quest-fill,
.cc-fill-prog,
.ps-xp-fill {
  animation: xpFill 1.2s var(--ease) both;
  animation-delay: 0.4s;
}

/* ── Holographic card shimmer ── */
.identity-card:hover,
.gamer-card-preview:hover {
  background: linear-gradient(135deg,
    rgba(255,255,255,0.06) 0%,
    rgba(255,255,255,0.03) 50%,
    rgba(255,255,255,0.06) 100%
  );
}

/* ── Mobile nav premium ── */
.nav-mobile {
  background: rgba(13,14,20,0.98);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
}

