/* =============================================================
   LUCKYDROPS · v2 · Editorial / Sticker / Ticker
   Komplett eigene Interpretation — Tokens aus dem System,
   Layout & Sprache neu gedacht.
============================================================= */

:root {
  --ld-bg:           #060B1A;
  --ld-bg-2:         #0A1530;
  --ld-surface:      #0E1A38;
  --ld-surface-2:    #142850;
  --ld-border:       rgba(120,180,255,.10);
  --ld-border-2:     rgba(120,180,255,.18);

  --ld-primary:      #2E7BFF;
  --ld-primary-2:    #5BA9FF;
  --ld-primary-deep: #1746B5;
  --ld-primary-soft: #7CB8FF;
  --ld-secondary:    #7B5CFF;
  --ld-accent-live:  #FF3B6B;
  --ld-accent-gold:  #FFD86B;
  --ld-accent-success:#5DE0A6;
  --ld-accent-pink:  #FF6B8A;

  --ld-text:         #F2F6FF;
  --ld-text-muted:   #A8C0E5;
  --ld-text-dim:     #6B82A8;

  --grad-primary: linear-gradient(135deg, #2E7BFF 0%, #5BA9FF 100%);
  --grad-warm:    linear-gradient(135deg, #FFD86B 0%, #FF3B6B 100%);
  --grad-vip:     linear-gradient(135deg, #FFE38A 0%, #C99526 100%);
  --grad-cool:    linear-gradient(135deg, #5DE0A6 0%, #2E7BFF 100%);

  --ff-display:  'Space Grotesk', system-ui, sans-serif;
  --ff-body:     'Inter', system-ui, sans-serif;
  --ff-mono:     'JetBrains Mono', ui-monospace, monospace;

  --container:   1280px;
  --gutter:      clamp(20px, 4vw, 56px);
  --r-sm: 6px;
  --r-md: 12px;
  --r-lg: 22px;
  --r-xl: 32px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--ff-body);
  background: var(--ld-bg);
  color: var(--ld-text);
  line-height: 1.55;
  font-size: 16px;
  overflow-x: hidden;
  background-image:
    radial-gradient(1100px 600px at 85% -5%, rgba(46,123,255,.20), transparent 60%),
    radial-gradient(800px 500px at -10% 35%, rgba(123,92,255,.10), transparent 60%),
    radial-gradient(700px 500px at 50% 110%, rgba(255,216,107,.06), transparent 60%);
  background-attachment: fixed;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
ul { list-style: none; }

.wrap {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

.muted { color: var(--ld-text-muted); }
.dim   { color: var(--ld-text-dim); }
.mono  { font-family: var(--ff-mono); }

/* =============================================================
   Type system v2
============================================================= */
.kicker {
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ld-text-dim);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.kicker::before {
  content: '';
  width: 24px; height: 1px;
  background: currentColor;
  display: inline-block;
}

h1, h2, h3 {
  font-family: var(--ff-display);
  font-weight: 600;
  letter-spacing: -.025em;
  line-height: .98;
  color: var(--ld-text);
}
.huge {
  font-size: clamp(3.2rem, 11vw, 9rem);
  letter-spacing: -.045em;
  line-height: .85;
  font-weight: 700;
}
.big {
  font-size: clamp(2.4rem, 6vw, 4.6rem);
  letter-spacing: -.035em;
  line-height: .9;
  font-weight: 600;
}
.med {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1;
}

.grad   { background: var(--grad-primary); -webkit-background-clip: text; background-clip: text; color: transparent; }
.grad-w { background: var(--grad-warm);    -webkit-background-clip: text; background-clip: text; color: transparent; }
.grad-v { background: var(--grad-vip);     -webkit-background-clip: text; background-clip: text; color: transparent; }
.outline-text {
  -webkit-text-stroke: 1.5px var(--ld-text);
  color: transparent;
}

/* =============================================================
   BTN
============================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 22px;
  border-radius: 100px;
  font-weight: 600;
  font-size: .9rem;
  border: 1px solid transparent;
  transition: transform .15s, box-shadow .2s, background .2s, border-color .2s;
  white-space: nowrap;
}
.btn-lg { padding: 18px 30px; font-size: 1rem; }
.btn-pri {
  background: #fff;
  color: #060B1A;
  box-shadow: 0 10px 30px -10px rgba(255,255,255,.45);
}
.btn-pri:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -10px rgba(255,255,255,.6); }
.btn-blue {
  background: var(--grad-primary);
  color: #fff;
  box-shadow: 0 10px 30px -10px rgba(46,123,255,.6);
}
.btn-blue:hover { transform: translateY(-2px); }
.btn-ghost {
  background: rgba(255,255,255,.04);
  border-color: var(--ld-border-2);
  color: var(--ld-text);
}
.btn-ghost:hover { background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.3); }
.btn-arrow::after {
  content: '→';
  transition: transform .2s;
}
.btn-arrow:hover::after { transform: translateX(4px); }

/* =============================================================
   MARQUEE / TICKER (oben durchgängig)
============================================================= */
.ticker {
  position: relative;
  background: var(--grad-primary);
  color: #fff;
  font-family: var(--ff-mono);
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 10px 0;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.15);
}
.ticker-track {
  display: flex;
  gap: 36px;
  white-space: nowrap;
  animation: tickerScroll 38s linear infinite;
  width: max-content;
}
.ticker-track span { display: inline-flex; align-items: center; gap: 36px; }
.ticker-dot { width: 6px; height: 6px; border-radius: 50%; background: #FFD86B; box-shadow: 0 0 12px #FFD86B; }
@keyframes tickerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* =============================================================
   HEADER
============================================================= */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(18px);
  background: rgba(6,11,26,.72);
  border-bottom: 1px solid var(--ld-border);
}
.nav-row {
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 16px 0;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.1rem;
}
.brand-mark { width: 28px; height: 34px; }
.brand-mark svg { width: 100%; height: 100%; }

.nav-links {
  display: flex;
  gap: 4px;
  margin-left: auto;
  margin-right: auto;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--ld-border);
  border-radius: 100px;
  padding: 4px;
}
.nav-links a {
  padding: 8px 16px;
  font-size: .85rem;
  font-weight: 500;
  color: var(--ld-text-muted);
  border-radius: 100px;
  white-space: nowrap;
  transition: color .15s, background .15s;
}
.nav-links a:hover { color: var(--ld-text); }
.nav-links a.active {
  background: rgba(255,255,255,.06);
  color: var(--ld-text);
}

.nav-cta { display: flex; gap: 8px; }
.nav-cta .btn { padding: 10px 18px; font-size: .82rem; }

@media (max-width: 980px) {
  .nav-links { display: none; }
  .nav-cta .btn-ghost { display: none; }
}

/* =============================================================
   HERO — vertical ticker on left, asymm grid
============================================================= */
.hero {
  position: relative;
  padding: clamp(40px, 6vw, 80px) 0 clamp(60px, 9vw, 120px);
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: clamp(20px, 3vw, 44px);
  position: relative;
  align-items: stretch;
}

/* Vertical brand-ticker on the very left */
.v-ticker {
  position: relative;
  border-left: 1px solid var(--ld-border);
  border-right: 1px solid var(--ld-border);
  overflow: hidden;
  display: flex;
  justify-content: center;
  background: rgba(255,255,255,.015);
  min-height: 600px;
}
.v-ticker-track {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 60px;
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--ld-text-dim);
  writing-mode: vertical-rl;
  animation: vTicker 40s linear infinite;
  padding: 30px 0;
}
.v-ticker-track span { white-space: nowrap; }
.v-ticker-track em { color: var(--ld-primary-2); font-style: normal; }
@keyframes vTicker {
  from { transform: translateY(0); }
  to   { transform: translateY(-50%); }
}

.hero-main {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(20px, 3vw, 60px);
  align-items: center;
  position: relative;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 8px 16px 8px 12px;
  border-radius: 100px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--ld-border-2);
  font-size: .82rem;
  margin-bottom: 28px;
  backdrop-filter: blur(8px);
}
.status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--ld-text-dim);
  display: inline-block;
}
.status-pill[data-status="live"] {
  background: linear-gradient(135deg, rgba(255,59,107,.18), rgba(255,107,138,.10));
  border-color: rgba(255,59,107,.55);
  animation: livePulse 1.8s ease-out infinite;
}
.status-pill[data-status="live"] .status-dot {
  background: var(--ld-accent-live);
  box-shadow: 0 0 0 0 rgba(255,59,107,.7);
}
@keyframes livePulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(255,59,107,.55); }
  60%     { box-shadow: 0 0 0 14px rgba(255,59,107,0); }
}
.status-meta { color: var(--ld-text-muted); }
.status-meta strong { font-family: var(--ff-mono); color: var(--ld-text); margin-left: 6px; }
.status-sep { opacity: .35; }

/* Headline as poster */
.poster {
  position: relative;
  margin-bottom: 36px;
}
.poster .line-1 {
  display: block;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(3.2rem, 10vw, 8rem);
  line-height: .85;
  letter-spacing: -.05em;
}
.poster .line-2 {
  display: block;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(3.2rem, 10vw, 8rem);
  line-height: .85;
  letter-spacing: -.05em;
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  position: relative;
}
.poster-mark {
  position: absolute;
  top: -22px;
  right: -4px;
  font-family: var(--ff-mono);
  font-size: .7rem;
  letter-spacing: .2em;
  color: var(--ld-text-dim);
  transform: rotate(8deg);
}

.hero-lede {
  font-size: clamp(1rem, 1.3vw, 1.12rem);
  color: var(--ld-text-muted);
  margin-bottom: 36px;
  max-width: 480px;
  line-height: 1.55;
}
.hero-lede strong { color: var(--ld-text); }

.hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 56px;
}

/* Three stat columns w/ vertical separators (no border-line above) */
.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--ld-border);
  padding-top: 24px;
  max-width: 540px;
}
.hero-stats > div {
  padding: 0 18px;
  border-right: 1px solid var(--ld-border);
}
.hero-stats > div:first-child { padding-left: 0; }
.hero-stats > div:last-child  { border-right: 0; }
.hero-stats strong {
  display: block;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.7rem;
  letter-spacing: -.02em;
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-stats span { font-size: .78rem; color: var(--ld-text-muted); }

/* HERO mascot — sticker style, kippt aus dem Raster */
.hero-mascot {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  filter: drop-shadow(0 30px 60px rgba(46,123,255,.4));
}
.hero-mascot::before {
  content: '';
  position: absolute;
  width: 88%; height: 88%;
  background: radial-gradient(circle, rgba(46,123,255,.4), transparent 65%);
  filter: blur(60px);
  z-index: -1;
}
.hero-mascot svg { max-width: 420px; width: 100%; }

/* Mascot v2 — PNG-based with silhouette glow + bob + tilt */
.mascot-stage {
  position: relative;
  width: 100%;
  max-width: 340px;
  aspect-ratio: 470 / 455;
  margin: 0 auto;
}
.mascot-img,
.mascot-glow {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
}
.mascot-glow {
  /* tint the white silhouette to brand-blue and bloom it out as a halo */
  filter:
    brightness(0)
    invert(48%)
    sepia(95%)
    saturate(2400%)
    hue-rotate(195deg)
    blur(28px);
  opacity: .55;
  transform-origin: 50% 60%;
  animation: mascotGlow 4.2s ease-in-out infinite;
  z-index: 0;
}
.mascot-img {
  z-index: 1;
  transform-origin: 50% 100%;
  animation: mascotBob 4.8s ease-in-out infinite;
  filter: drop-shadow(0 28px 40px rgba(46,123,255,.35));
  transition: transform .35s ease, filter .35s ease;
}
.hero-mascot:hover .mascot-img {
  animation-play-state: paused;
  transform: translateY(-18px) rotate(-2deg) scale(1.02);
  filter: drop-shadow(0 40px 60px rgba(46,123,255,.5));
}

@keyframes mascotBob {
  0%, 100% { transform: translateY(0)     rotate(-1.6deg); }
  50%      { transform: translateY(-16px) rotate(1.6deg); }
}
@keyframes mascotGlow {
  0%, 100% { transform: scale(1)    translateY(0);   opacity: .42; }
  50%      { transform: scale(1.08) translateY(-8px); opacity: .62; }
}

/* WCAG 2.3.3 — kill all motion for users who opted out at OS level.
   Universal nuke: any element, any pseudo, animation + transition
   reduced to ~0ms. Keeps reveal/stagger elements visible (opacity 1)
   instead of stuck at their initial offscreen position. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal, .stagger > * {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* Sticker badge floating beside mascot */
.sticker {
  position: absolute;
  background: var(--ld-accent-gold);
  color: #060B1A;
  font-family: var(--ff-mono);
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 14px 18px;
  border-radius: 100px;
  border: 2px solid #060B1A;
  box-shadow: 0 8px 24px rgba(255,216,107,.35);
  animation: stickerSpin 12s linear infinite;
  z-index: 2;
}
.sticker.s-1 { top: 6%; right: -2%; transform: rotate(8deg); }
.sticker.s-2 { bottom: 14%; left: -4%; transform: rotate(-10deg); background: var(--ld-accent-live); color: #060B1A; }
@keyframes stickerSpin {
  0%   { transform: rotate(8deg); }
  50%  { transform: rotate(-4deg); }
  100% { transform: rotate(8deg); }
}

@media (max-width: 1000px) {
  .hero-grid { grid-template-columns: 1fr; }
  .v-ticker { display: none; }
  .hero-main { grid-template-columns: 1fr; }
  .hero-mascot { order: -1; max-width: 240px; margin: 0 auto; }
  .hero-mascot svg, .mascot-stage { max-width: 240px; }
  .sticker.s-1 { right: 2%; }
}

/* =============================================================
   SECTION basics
============================================================= */
.sec {
  padding: clamp(60px, 9vw, 130px) 0;
  position: relative;
}
.sec-head {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px;
  align-items: end;
  margin-bottom: 56px;
}
.sec-head .lead p {
  color: var(--ld-text-muted);
  font-size: 1.05rem;
  max-width: 540px;
}
.sec-head .left .kicker { margin-bottom: 16px; }
@media (max-width: 800px) {
  .sec-head { grid-template-columns: 1fr; gap: 20px; }
}

/* Reveal */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }
.stagger > * { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.stagger.in-view > * { opacity: 1; transform: translateY(0); }
.stagger.in-view > *:nth-child(1) { transition-delay: .04s; }
.stagger.in-view > *:nth-child(2) { transition-delay: .12s; }
.stagger.in-view > *:nth-child(3) { transition-delay: .20s; }
.stagger.in-view > *:nth-child(4) { transition-delay: .28s; }
.stagger.in-view > *:nth-child(5) { transition-delay: .36s; }
.stagger.in-view > *:nth-child(6) { transition-delay: .44s; }

/* =============================================================
   LIVE-STRIP — full-bleed band
============================================================= */
.live-band {
  border-top: 1px solid var(--ld-border);
  border-bottom: 1px solid var(--ld-border);
  padding: clamp(40px, 6vw, 80px) 0;
  background:
    radial-gradient(800px 300px at 80% 50%, rgba(46,123,255,.18), transparent 70%),
    radial-gradient(600px 240px at 10% 50%, rgba(123,92,255,.12), transparent 70%);
  position: relative;
}
.live-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(28px, 5vw, 80px);
  align-items: center;
}
.next-stream-mark {
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--ld-text-dim);
  margin-bottom: 14px;
  display: inline-flex;
  gap: 12px;
  align-items: center;
}
.next-stream-mark::before {
  content: '';
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--ld-text-dim);
}
.next-stream-when {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  line-height: .95;
  letter-spacing: -.03em;
  margin-bottom: 14px;
}
.next-stream-when em { font-style: normal; background: var(--grad-primary); -webkit-background-clip: text; background-clip: text; color: transparent; }
.next-stream-wink { color: var(--ld-text-muted); margin-bottom: 28px; max-width: 480px; }
.next-stream-cta { display: flex; gap: 12px; flex-wrap: wrap; }

.week-list { display: grid; gap: 0; }
.week-row {
  display: grid;
  grid-template-columns: 64px 80px 1fr auto;
  align-items: center;
  padding: 22px 4px;
  border-bottom: 1px solid var(--ld-border);
  gap: 16px;
  position: relative;
  transition: background .2s;
}
.week-row:first-child { border-top: 1px solid var(--ld-border); }
.week-row:hover { background: rgba(255,255,255,.02); }
.week-row .day {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: -.02em;
  color: var(--ld-text-muted);
}
.week-row .time {
  font-family: var(--ff-mono);
  font-size: .9rem;
  color: var(--ld-text-muted);
}
.week-row .what { font-weight: 500; font-size: 1rem; }
.week-row .marker { width: 8px; height: 8px; border-radius: 50%; background: var(--ld-text-dim); }
.week-row.active { background: linear-gradient(90deg, rgba(46,123,255,.10), transparent 70%); }
.week-row.active .day  { background: var(--grad-primary); -webkit-background-clip: text; background-clip: text; color: transparent; }
.week-row.active .marker { background: var(--ld-primary-2); box-shadow: 0 0 14px var(--ld-primary-2); }

@media (max-width: 800px) {
  .live-grid { grid-template-columns: 1fr; }
  .week-row { grid-template-columns: 48px 60px 1fr 12px; padding: 18px 0; }
  .week-row .day { font-size: 1.3rem; }
}

/* =============================================================
   LEADERBOARD — ranked list, hero-1 separately
============================================================= */
.lb-feature {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(28px, 4vw, 64px);
  align-items: center;
  margin-bottom: 36px;
  padding: clamp(28px, 4vw, 56px);
  border: 1px solid rgba(255,216,107,.25);
  border-radius: var(--r-xl);
  background:
    radial-gradient(500px 280px at 0% 50%, rgba(255,216,107,.12), transparent 60%),
    rgba(255,255,255,.015);
  position: relative;
  overflow: hidden;
}
.lb-feature::before {
  content: '01';
  position: absolute;
  top: -50px; right: -14px;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 18rem;
  line-height: .85;
  letter-spacing: -.05em;
  background: var(--grad-vip);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  opacity: .14;
  pointer-events: none;
}
.lb-feature-meta { position: relative; z-index: 1; }
.lb-feature .badge-crown {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: var(--grad-vip);
  color: #2a1604;
  border-radius: 100px;
  margin-bottom: 18px;
  font-weight: 700;
}
.lb-feature h3 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 5vw, 4rem);
  letter-spacing: -.03em;
  line-height: .95;
  margin-bottom: 10px;
}
.lb-feature .role {
  font-family: var(--ff-mono);
  font-size: .85rem;
  color: var(--ld-accent-gold);
  margin-bottom: 24px;
  letter-spacing: .04em;
}
.lb-feature .points {
  font-family: var(--ff-mono);
  font-size: 1rem;
  color: var(--ld-text-muted);
}
.lb-feature .points strong {
  font-size: 2rem;
  color: var(--ld-text);
  margin-right: 8px;
}
.lb-avatar-xl {
  width: 220px; height: 220px;
  border-radius: 50%;
  margin: 0 auto;
  background: var(--grad-vip);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 7rem;
  color: #2a1604;
  position: relative;
  box-shadow: 0 30px 80px -20px rgba(255,216,107,.45);
  z-index: 1;
}
.lb-avatar-xl::before {
  content: '👑';
  position: absolute;
  top: -34px; left: 50%;
  transform: translateX(-50%) rotate(-8deg);
  font-size: 3rem;
  filter: drop-shadow(0 6px 18px rgba(255,216,107,.6));
  animation: crownSway 5s ease-in-out infinite;
}
@keyframes crownSway {
  0%,100% { transform: translateX(-50%) rotate(-8deg); }
  50%     { transform: translateX(-50%) rotate(8deg); }
}

.lb-list {
  display: grid;
  gap: 0;
  margin-bottom: 36px;
}
.lb-row {
  display: grid;
  grid-template-columns: 60px 64px 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 20px 8px;
  border-bottom: 1px solid var(--ld-border);
  transition: background .2s, padding .2s;
}
.lb-row:hover { background: rgba(255,255,255,.025); padding-left: 18px; }
.lb-row .num {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 2.2rem;
  letter-spacing: -.03em;
  color: var(--ld-text-dim);
  -webkit-text-stroke: 1px var(--ld-text-dim);
  color: transparent;
}
.lb-row .av {
  width: 48px; height: 48px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.2rem;
  color: #fff;
}
.lb-row .meta h3 { font-family: var(--ff-display); font-size: 1.15rem; margin-bottom: 2px; font-weight: 600; }
.lb-row .meta span { font-family: var(--ff-mono); font-size: .78rem; color: var(--ld-text-muted); }
.lb-row .pts strong {
  font-family: var(--ff-mono);
  font-size: 1.2rem;
  color: var(--ld-primary-2);
}
.lb-row .pts span { display: block; font-size: .72rem; color: var(--ld-text-dim); text-align: right; }

.lb-actions { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 40px; }

.rules {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
  gap: 12px;
}
.rule {
  padding: 18px 20px;
  border: 1px dashed var(--ld-border-2);
  border-radius: var(--r-md);
  display: flex;
  gap: 14px;
  align-items: baseline;
  background: rgba(255,255,255,.015);
}
.rule strong {
  font-family: var(--ff-mono);
  font-size: 1.1rem;
  color: var(--ld-accent-success);
  white-space: nowrap;
}
.rule span { font-size: .88rem; color: var(--ld-text-muted); }

@media (max-width: 800px) {
  .lb-feature { grid-template-columns: 1fr; text-align: center; }
  .lb-avatar-xl { width: 160px; height: 160px; font-size: 5rem; }
  .lb-row { grid-template-columns: 36px 48px 1fr auto; gap: 12px; }
  .lb-row .num { font-size: 1.6rem; }
}

/* =============================================================
   A–Z — full-bleed letter wall
============================================================= */
.az-wrap { position: relative; }
.az-progress-row {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: clamp(20px, 3vw, 48px);
  align-items: end;
  padding: 22px 0 14px;
  border-bottom: 1px solid var(--ld-border);
  margin-bottom: 36px;
}
.az-progress-row > div span { display: block; font-family: var(--ff-mono); font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ld-text-dim); margin-bottom: 6px; }
.az-progress-row > div strong { font-family: var(--ff-display); font-weight: 700; font-size: 1.6rem; letter-spacing: -.02em; }
.az-progress-row > div em { font-style: normal; }

.az-bar {
  grid-column: 1 / -1;
  height: 10px;
  background: rgba(255,255,255,.04);
  border-radius: 100px;
  overflow: hidden;
  position: relative;
  margin-top: 14px;
}
.az-bar-fill {
  height: 100%;
  background: var(--grad-primary);
  border-radius: 100px;
  transition: width 1.4s cubic-bezier(.2,.8,.2,1);
  box-shadow: 0 0 18px rgba(46,123,255,.5);
  position: relative;
}
.az-bar-fill::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  animation: shine 2.4s linear infinite;
}
@keyframes shine {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.az-grid {
  display: grid;
  grid-template-columns: repeat(13, 1fr);
  gap: 6px;
  margin-bottom: 36px;
}
.az-cell {
  aspect-ratio: 1;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.02);
  border: 1px solid var(--ld-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ff-display);
  font-size: clamp(1.2rem, 2.4vw, 2rem);
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--ld-text-muted);
  position: relative;
  transition: transform .15s, border-color .15s, color .15s, box-shadow .15s;
  overflow: hidden;
  /* button reset (cells are <button> for click + keyboard support) */
  cursor: pointer;
  padding: 0;
  -webkit-appearance: none;
  appearance: none;
  font-family: var(--ff-display);
}
.az-cell:hover { transform: translateY(-2px); border-color: var(--ld-primary); color: var(--ld-text); }
.az-cell[aria-pressed="true"]:not(.active) {
  border-color: var(--ld-primary);
  box-shadow: 0 0 0 2px rgba(46,123,255,.35);
  color: var(--ld-text);
}
.az-cell .count {
  position: absolute;
  bottom: 4px; right: 6px;
  font-family: var(--ff-mono);
  font-size: .6rem;
  font-weight: 500;
  color: var(--ld-text-dim);
  letter-spacing: 0;
}
.az-cell.done {
  background: linear-gradient(135deg, rgba(93,224,166,.14), rgba(93,224,166,.04));
  border-color: rgba(93,224,166,.35);
  color: var(--ld-accent-success);
}
.az-cell.done .count { color: var(--ld-accent-success); }
.az-cell.active {
  background: var(--grad-primary);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 0 0 0 rgba(46,123,255,.6);
  animation: cellPulse 2s ease-in-out infinite;
}
@keyframes cellPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(46,123,255,.6), 0 8px 24px rgba(46,123,255,.4); }
  50%     { box-shadow: 0 0 0 10px rgba(46,123,255,0), 0 8px 24px rgba(46,123,255,.4); }
}

.az-current {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: center;
  padding: 28px 0;
  border-top: 1px solid var(--ld-border);
}
.az-current-letter {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(4rem, 8vw, 7rem);
  line-height: 1;
  letter-spacing: -.05em;
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  padding: 0 24px;
  border-right: 1px solid var(--ld-border);
}
.az-current-meta .label {
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ld-text-dim);
  margin-bottom: 14px;
  display: block;
}
.az-champs { display: flex; gap: 8px; flex-wrap: wrap; }
.champ {
  padding: 8px 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--ld-border);
  border-radius: 100px;
  font-size: .85rem;
  font-family: var(--ff-mono);
}
.champ.done { border-color: rgba(93,224,166,.3); color: var(--ld-accent-success); }
.champ.active {
  background: var(--grad-primary);
  border-color: transparent;
  color: #fff;
}

@media (max-width: 700px) {
  .az-grid { grid-template-columns: repeat(7, 1fr); }
  .az-current { grid-template-columns: 1fr; gap: 12px; }
  .az-current-letter { padding: 0; border-right: 0; border-bottom: 1px solid var(--ld-border); padding-bottom: 12px; }
}

/* =============================================================
   CLIPS — masonry-feel asymmetric
============================================================= */
.clip-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 18px;
}
.clip {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--ld-border);
  transition: transform .25s ease, border-color .25s;
  min-height: 200px;
}
.clip:hover { transform: translateY(-6px); border-color: var(--ld-border-2); }
.clip-1 { grid-row: 1 / span 2; min-height: 460px; }
.clip-thumb {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.clip-thumb::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0,8,30,.85) 100%);
}
.clip-play {
  width: 64px; height: 64px;
  background: rgba(255,255,255,.16);
  backdrop-filter: blur(12px);
  border: 1.5px solid rgba(255,255,255,.35);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; color: #fff;
  z-index: 2;
  transition: transform .2s, background .2s;
}
.clip:hover .clip-play { transform: scale(1.12); background: rgba(255,255,255,.28); }
.clip-info {
  position: absolute;
  inset: auto 0 0 0;
  padding: 22px 22px 20px;
  z-index: 2;
}
.clip-info h3 {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}
.clip-1 .clip-info h3 { font-size: 1.5rem; }
.clip-info .meta {
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ld-text-muted);
}
.clip-dur {
  position: absolute;
  top: 14px; right: 14px;
  background: rgba(0,0,0,.7);
  font-family: var(--ff-mono);
  font-size: .72rem;
  padding: 5px 10px;
  border-radius: 100px;
  z-index: 2;
}

@media (max-width: 800px) {
  .clip-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .clip-1 { grid-row: auto; grid-column: 1 / -1; min-height: 240px; }
  .clip { min-height: 180px; }
}

/* =============================================================
   GIVEAWAY — billboard with wheel right
============================================================= */
.give-section {
  background: linear-gradient(180deg, transparent, rgba(255,216,107,.04) 50%, transparent);
}
.give {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(28px, 5vw, 70px);
  align-items: center;
  padding: clamp(32px, 5vw, 64px);
  border: 1px solid rgba(255,216,107,.22);
  border-radius: var(--r-xl);
  background:
    radial-gradient(700px 380px at 80% 100%, rgba(255,216,107,.16), transparent 60%),
    radial-gradient(500px 300px at 0% 0%, rgba(255,59,107,.10), transparent 60%),
    rgba(255,255,255,.015);
  position: relative;
  overflow: hidden;
}
.give-prize {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(2.2rem, 5vw, 4rem);
  letter-spacing: -.04em;
  line-height: .95;
  margin: 18px 0 18px;
}
.give-prize em { font-style: normal; background: var(--grad-warm); -webkit-background-clip: text; background-clip: text; color: transparent; }
.give-body { color: var(--ld-text-muted); margin-bottom: 28px; max-width: 480px; }

.countdown {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  max-width: 460px;
  margin-bottom: 28px;
}
.countdown > div {
  background: rgba(0,8,30,.55);
  border: 1px solid rgba(255,216,107,.28);
  border-radius: var(--r-md);
  padding: 18px 12px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.countdown > div::after {
  content: '';
  position: absolute;
  top: 50%; left: 0; right: 0;
  height: 1px;
  background: rgba(255,216,107,.15);
}
.countdown strong {
  display: block;
  font-family: var(--ff-mono);
  font-weight: 700;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  color: var(--ld-text);
  line-height: 1;
}
.countdown span {
  display: block;
  font-family: var(--ff-mono);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ld-accent-gold);
  margin-top: 8px;
}
.give-cta { display: flex; gap: 12px; flex-wrap: wrap; }

.wheel-wrap { display: flex; justify-content: center; }
.wheel {
  width: clamp(220px, 32vw, 340px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: conic-gradient(
    #FF3B6B 0deg 45deg,
    #FFD86B 45deg 90deg,
    #5DE0A6 90deg 135deg,
    #2E7BFF 135deg 180deg,
    #7B5CFF 180deg 225deg,
    #FF3B6B 225deg 270deg,
    #FFD86B 270deg 315deg,
    #5DE0A6 315deg 360deg
  );
  border: 6px solid rgba(255,255,255,.08);
  box-shadow: 0 0 80px rgba(255,216,107,.3), inset 0 0 40px rgba(0,0,0,.5);
  animation: wheelSpin 18s linear infinite;
  position: relative;
}
.wheel::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: 50%;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.18);
}
.wheel-center {
  position: absolute;
  inset: 36%;
  background: var(--ld-bg);
  border: 4px solid rgba(255,255,255,.1);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem;
  animation: wheelSpin 18s linear infinite reverse;
}
.wheel-pointer {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 14px solid transparent;
  border-right: 14px solid transparent;
  border-top: 22px solid var(--ld-accent-gold);
  filter: drop-shadow(0 4px 8px rgba(255,216,107,.5));
  z-index: 3;
}
@keyframes wheelSpin { to { transform: rotate(360deg); } }

@media (max-width: 800px) {
  .give { grid-template-columns: 1fr; }
}

/* =============================================================
   VALUES — 3 cards w mascot moods
============================================================= */
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.value {
  position: relative;
  padding: 36px 32px 32px;
  border: 1px solid var(--ld-border);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.015);
  transition: transform .25s, border-color .25s;
  overflow: hidden;
}
.value::before {
  content: '';
  position: absolute;
  top: -40%; right: -40%;
  width: 80%; height: 80%;
  background: radial-gradient(circle, var(--glow), transparent 65%);
  filter: blur(30px);
  opacity: .25;
  pointer-events: none;
  transition: opacity .3s;
}
.value:hover { transform: translateY(-4px) rotate(-.4deg); border-color: rgba(255,255,255,.18); }
.value:hover::before { opacity: .45; }
.value-mascot {
  width: 100px; height: 110px;
  margin-bottom: 22px;
  filter: drop-shadow(0 10px 24px var(--glow));
  transition: transform .3s;
}
.value:hover .value-mascot { transform: rotate(-3deg) scale(1.06); }
.value h3 {
  font-family: var(--ff-display);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 12px;
}
.value p { color: var(--ld-text-muted); font-size: .96rem; }
.value .num {
  position: absolute;
  top: 20px; right: 24px;
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .15em;
  color: var(--ld-text-dim);
}
@media (max-width: 800px) {
  .values-grid { grid-template-columns: 1fr; }
}

/* =============================================================
   SPRINKLE
============================================================= */
.sprinkle-section {
  background:
    radial-gradient(700px 400px at 80% 50%, rgba(255,143,163,.08), transparent 60%),
    radial-gradient(500px 300px at 10% 50%, rgba(255,216,107,.05), transparent 60%);
  border-top: 1px solid var(--ld-border);
  border-bottom: 1px solid var(--ld-border);
}
.sprinkle-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(40px, 6vw, 90px);
  align-items: center;
}
.sprinkle-text { max-width: 540px; }
.sprinkle-text h2 { margin-bottom: 22px; }
.sprinkle-text p { color: var(--ld-text-muted); margin-bottom: 28px; font-size: 1.05rem; }
.feature-list {
  display: grid;
  gap: 10px;
  margin-bottom: 32px;
  border-top: 1px solid var(--ld-border);
}
.feature-list li {
  padding: 14px 4px 14px 36px;
  position: relative;
  border-bottom: 1px solid var(--ld-border);
  font-size: .98rem;
}
.feature-list li::before {
  content: '✦';
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ld-accent-gold);
  font-size: 1rem;
}

.sprinkle-bot-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
.bot {
  width: clamp(200px, 28vw, 280px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, #FFFCEB 0%, #FFD86B 40%, #FF8FA3 78%, #E04877 100%);
  position: relative;
  box-shadow:
    0 40px 100px -10px rgba(255,143,163,.4),
    inset -20px -30px 80px rgba(0,0,0,.18);
  animation: botBob 4.5s ease-in-out infinite;
}
@keyframes botBob {
  0%,100% { transform: translateY(0) rotate(-1deg); }
  50%     { transform: translateY(-12px) rotate(1deg); }
}
.bot::after {
  content: '';
  position: absolute;
  top: 18%; left: 22%;
  width: 30%; height: 14%;
  background: rgba(255,255,255,.55);
  border-radius: 50%;
  transform: rotate(-25deg);
  filter: blur(2px);
}
.bot-face {
  position: absolute;
  top: 44%; left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  gap: 24%;
  width: 50%;
  justify-content: space-between;
}
.bot-eye {
  width: 16%; aspect-ratio: .7;
  background: #2A1B0A;
  border-radius: 50%;
  animation: blink 4s infinite;
}
@keyframes blink {
  0%, 92%, 100% { transform: scaleY(1); }
  95%           { transform: scaleY(.05); }
}
.bot-mouth {
  position: absolute;
  bottom: 30%; left: 50%;
  transform: translateX(-50%);
  width: 14%; aspect-ratio: 2;
  border-bottom: 4px solid #2A1B0A;
  border-radius: 0 0 30px 30px;
}
.bot-bubble {
  margin-top: 28px;
  padding: 16px 22px;
  background: var(--ld-surface);
  border: 1px solid var(--ld-border);
  border-radius: var(--r-md);
  font-size: .95rem;
  position: relative;
  max-width: 320px;
  text-align: center;
}
.bot-bubble::before {
  content: '';
  position: absolute;
  top: -8px; left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 14px; height: 14px;
  background: var(--ld-surface);
  border-left: 1px solid var(--ld-border);
  border-top: 1px solid var(--ld-border);
}

@media (max-width: 800px) {
  .sprinkle-grid { grid-template-columns: 1fr; }
}

/* =============================================================
   SUB-GOAL
============================================================= */
.subgoal {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 64px);
  align-items: center;
  padding: clamp(32px, 5vw, 64px);
  border-radius: var(--r-xl);
  border: 1px solid var(--ld-border-2);
  background:
    radial-gradient(600px 380px at 90% 50%, rgba(46,123,255,.22), transparent 60%),
    rgba(255,255,255,.015);
  position: relative;
  overflow: hidden;
}
.subgoal h2 { margin: 18px 0; }
.subgoal-meter .row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 14px;
  font-family: var(--ff-mono);
}
.subgoal-meter .row strong { font-size: 1.6rem; color: var(--ld-text); }
.subgoal-meter .pct {
  color: var(--ld-primary-2);
  font-weight: 700;
  font-size: 1.6rem;
}
.meter-track {
  height: 18px;
  background: rgba(255,255,255,.04);
  border-radius: 100px;
  overflow: hidden;
  margin-bottom: 28px;
  position: relative;
}
.meter-fill {
  height: 100%;
  background: var(--grad-primary);
  border-radius: 100px;
  transition: width 1.6s cubic-bezier(.2,.8,.2,1);
  box-shadow: 0 0 22px rgba(46,123,255,.6);
  position: relative;
}
.meter-fill::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  animation: shine 2.4s linear infinite;
}
.subgoal-cta { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 800px) {
  .subgoal { grid-template-columns: 1fr; }
}

/* =============================================================
   CREW — 6 role cards
============================================================= */
.crew-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
.role {
  border: 1px solid var(--ld-border);
  border-radius: var(--r-lg);
  padding: 28px 26px;
  background: rgba(255,255,255,.015);
  position: relative;
  transition: transform .2s, border-color .2s;
}
.role:hover { transform: translateY(-4px); border-color: rgba(123,92,255,.4); }
.role-num {
  position: absolute;
  top: 20px; right: 24px;
  font-family: var(--ff-mono);
  font-size: .68rem;
  letter-spacing: .15em;
  color: var(--ld-text-dim);
}
.role-icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--ld-border);
  border-radius: var(--r-md);
  font-size: 1.6rem;
  margin-bottom: 22px;
}
.role h3 { font-family: var(--ff-display); font-size: 1.2rem; font-weight: 600; margin-bottom: 10px; }
.role p { color: var(--ld-text-muted); font-size: .92rem; margin-bottom: 22px; }
.role-status {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 100px;
  font-size: .7rem;
  font-family: var(--ff-mono);
  text-transform: uppercase;
  letter-spacing: .12em;
  background: rgba(93,224,166,.1);
  color: var(--ld-accent-success);
  border: 1px solid rgba(93,224,166,.3);
}
.crew-cta { text-align: center; }

@media (max-width: 800px) {
  .crew-grid { grid-template-columns: 1fr; }
}

/* =============================================================
   FOOTER
============================================================= */
footer {
  border-top: 1px solid var(--ld-border);
  padding: 80px 0 30px;
  background: linear-gradient(180deg, transparent, rgba(123,92,255,.04));
  position: relative;
}
.foot-huge {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(4rem, 14vw, 12rem);
  line-height: .85;
  letter-spacing: -.06em;
  margin-bottom: 60px;
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.foot-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
}
.foot-tag {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 1.1rem;
  margin: 12px 0 4px;
}
.foot-col h4 {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  font-family: var(--ff-mono);
  color: var(--ld-text-dim);
  margin-bottom: 18px;
}
.foot-col ul { display: grid; gap: 12px; }
.foot-col a { font-size: .92rem; color: var(--ld-text-muted); transition: color .15s; }
.foot-col a:hover { color: var(--ld-text); }

.foot-base {
  display: flex;
  justify-content: space-between;
  padding-top: 28px;
  border-top: 1px solid var(--ld-border);
  flex-wrap: wrap;
  gap: 12px;
  font-size: .8rem;
  color: var(--ld-text-dim);
}

@media (max-width: 800px) {
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 500px) {
  .foot-grid { grid-template-columns: 1fr; }
}

/* clip click-overlay — covers entire card, opens twitch in new tab */
.clip-link {
  position: absolute;
  inset: 0;
  z-index: 5;
  text-decoration: none;
  border-radius: inherit;
}
/* values section: pull-quote under the three value cards */
.values-quote {
  margin: 56px auto 0;
  max-width: 880px;
  padding: 36px 40px;
  border-radius: var(--r-lg, 18px);
  background: linear-gradient(135deg, rgba(46,123,255,.08), rgba(123,92,255,.08));
  border: 1px solid var(--ld-border-1, rgba(255,255,255,.08));
  text-align: center;
}
.values-quote p {
  font-family: var(--ff-display, "Space Grotesk", sans-serif);
  font-size: clamp(1.15rem, 2.2vw, 1.6rem);
  line-height: 1.4;
  font-weight: 500;
  color: var(--ld-text, #F4F7FF);
  margin: 0 0 18px;
  font-style: italic;
}
.values-quote cite {
  font-family: var(--ff-mono, "JetBrains Mono", monospace);
  font-size: .82rem;
  font-style: normal;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ld-text-muted, #9FB0D6);
}
@media (max-width: 600px) {
  .values-quote { padding: 28px 22px; margin-top: 40px; }
}

/* WCAG 2.4.7 — global focus-visible for keyboard users.
   Browser-default outline is invisible against the dark theme; this
   adds an explicit gold ring with offset on every interactive element. */
:where(a, button, [role="button"], input, select, textarea, summary,
       .btn, .role, .clip, .clip-link, .az-cell, .lb-row, .nav-links a,
       .crew .role, .b, .pers, .clip-info):focus-visible {
  outline: 3px solid var(--ld-accent-gold, #FFD86B);
  outline-offset: 3px;
  border-radius: 8px;
}
.clip-link:focus-visible { /* preserve original tighter ring inside the card */
  outline-offset: -3px;
  outline-color: var(--ld-accent-gold, #FFD86B);
}

/* =============================================================
   PAGE TEMPLATE — long-form pages (impressum, datenschutz,
   nutzungsbedingungen, kontakt, ki-tools, …). Rendered via
   templates/page.html with wp:post-title + wp:post-content.
============================================================= */
.ld-page {
  padding: clamp(60px, 9vw, 120px) 0 clamp(80px, 11vw, 140px);
  background:
    radial-gradient(900px 400px at 80% 0%, rgba(46,123,255,.10), transparent 70%),
    radial-gradient(700px 320px at 5% 30%, rgba(123,92,255,.08), transparent 70%);
}
.ld-page__inner {
  max-width: 880px;          /* readable measure for long text */
  padding-inline: clamp(20px, 5vw, 48px);
}
.ld-page__title {
  font-family: var(--ff-display);
  font-weight: 700;
  letter-spacing: -.025em;
  line-height: 1.05;
  font-size: clamp(2.2rem, 5.5vw, 3.6rem);
  margin: 0 0 clamp(28px, 4vw, 56px);
}
.ld-page__title.grad-text {
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.ld-page__body {
  color: var(--ld-text);
  font-family: var(--ff-body);
  font-size: 1.06rem;
  line-height: 1.7;
}
.ld-page__body p {
  margin: 0 0 1.1em;
  max-width: 70ch;
}
.ld-page__body h2 {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: clamp(1.4rem, 2.6vw, 1.85rem);
  letter-spacing: -.015em;
  line-height: 1.2;
  margin: 2.4em 0 .7em;
  padding-top: .4em;
  border-top: 1px solid var(--ld-border-1, rgba(255,255,255,.08));
  color: var(--ld-text);
}
.ld-page__body h2:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
.ld-page__body h3 {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: clamp(1.15rem, 2vw, 1.35rem);
  margin: 1.8em 0 .5em;
  color: var(--ld-text);
}
.ld-page__body strong {
  color: var(--ld-text);
  font-weight: 600;
}
.ld-page__body a {
  color: var(--ld-accent-blue, #5BA9FF);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.ld-page__body a:hover { color: var(--ld-accent-gold, #FFD86B); }
.ld-page__body em {
  display: block;
  padding: 14px 18px;
  margin: 0 0 1.6em;
  background: rgba(255, 216, 107, .08);
  border-left: 3px solid var(--ld-accent-gold);
  border-radius: 0 8px 8px 0;
  font-style: italic;
  font-size: .96rem;
  color: var(--ld-text-muted);
}
.ld-page__body ul,
.ld-page__body ol {
  margin: 0 0 1.4em;
  padding-left: 1.4em;
}
.ld-page__body li {
  margin-bottom: .35em;
}
.ld-page__body ul li::marker { color: var(--ld-accent-blue); }
.ld-page__body ol li::marker { color: var(--ld-accent-gold); font-weight: 600; }
.ld-page__body hr {
  border: none;
  border-top: 1px solid var(--ld-border-1, rgba(255,255,255,.08));
  margin: 2.4em 0;
}
.ld-page__body code {
  font-family: var(--ff-mono);
  font-size: .92em;
  padding: .14em .42em;
  background: rgba(255,255,255,.06);
  border-radius: 4px;
  border: 1px solid var(--ld-border-1, rgba(255,255,255,.08));
}
.ld-page__body table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.4em 0;
  font-size: .94rem;
}
.ld-page__body th,
.ld-page__body td {
  padding: 10px 14px;
  border: 1px solid var(--ld-border-1, rgba(255,255,255,.08));
  text-align: left;
}
.ld-page__body th {
  background: rgba(255,255,255,.04);
  font-weight: 600;
}
@media (max-width: 600px) {
  .ld-page__body { font-size: 1rem; line-height: 1.65; }
  .ld-page__body h2 { margin-top: 2em; }
}

/* =============================================================
   MOBILE — true-smartphone breakpoint at 480px. Catches the
   Galaxy/iPhone Mini sizes that the main 800px breakpoint is
   too generous for. Tightens padding, fixes overflowing rows,
   right-sizes touch targets.
============================================================= */
@media (max-width: 480px) {
  /* container side-padding */
  .wrap { padding-inline: 16px; }

  /* hero: smaller mascot, mascot overlapping stickers reduced */
  .hero { padding-top: 80px; }
  .hero .poster { font-size: clamp(2.6rem, 14vw, 4rem); }
  .mascot-img, .mascot-glow, .hero-mascot svg, .mascot-stage { max-width: 200px; }
  .sticker { font-size: .62rem; padding: 10px 14px; }
  .hero-stats { gap: 18px; flex-wrap: wrap; }

  /* nav: collapse to icon-only CTA + brand */
  .nav-row { gap: 12px; flex-wrap: wrap; }
  .nav-cta .btn { padding: 8px 14px; font-size: .76rem; }

  /* leaderboard rows: stack the points block under the meta */
  .lb-row {
    grid-template-columns: 36px 36px 1fr;
    grid-template-rows: auto auto;
    gap: 6px 10px;
    padding: 12px 14px;
  }
  .lb-row .pts {
    grid-column: 2 / 4;
    text-align: left;
  }
  .lb-row .meta h3 { font-size: 1rem; }

  /* a-z grid: bigger tap targets, fewer per row */
  .az-grid { grid-template-columns: repeat(4, 1fr); }
  .az-cell { min-height: 48px; }

  /* clip cards: single column, smaller */
  .clip-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
  .clip-1 { grid-row: auto; min-height: 280px; }
  .clip { min-height: 220px; }

  /* sections: less generous padding */
  .sec { padding: 60px 0; }
  .sec-head .big { font-size: clamp(2rem, 8vw, 2.6rem); }

  /* values cards stack tight */
  .values-grid { gap: 22px; }
  .value { padding: 26px 22px; }

  /* role / persona cards stack */
  .crew-grid { grid-template-columns: 1fr; gap: 18px; }
  .role { padding: 22px 20px; }

  /* sprinkle / giveaway cards */
  .give-card { padding: 28px 22px; }
  .give-prize { font-size: clamp(2.2rem, 9vw, 3rem); }

  /* footer columns stack */
  .foot-grid { gap: 28px; }

  /* CTA buttons full-width on smallest screens */
  .lb-actions, .give-actions, .hero-cta {
    flex-direction: column;
    align-items: stretch;
  }
  .lb-actions .btn,
  .give-actions .btn,
  .hero-cta .btn { width: 100%; justify-content: center; }

  /* page template: more compact */
  .ld-page { padding: 70px 0 80px; }
  .ld-page__inner { padding-inline: 18px; }

  /* tickers: thinner, faster */
  .v-ticker, .live-band .ticker { font-size: .85rem; }
}
