/* StumpMike — shared styles
   Palette: magenta #A51153 + teal #1CBCC6
   Type:    Bricolage Grotesque (display) + Geist (body) + JetBrains Mono (numerals)
   ───────────────────────────────────────────────────────────────────────── */

:root{
  --magenta:#A51153;
  --magenta-deep:#5E0930;
  --magenta-tint:#FCE9F0;
  --teal:#1CBCC6;
  --teal-deep:#0F7980;
  --teal-tint:#E1F7F8;
  --ink:#11091B;
  --ink-2:rgba(17,9,27,.62);
  --ink-3:rgba(17,9,27,.38);
  --line:rgba(17,9,27,.10);
  --paper:#FFFFFF;
  --cream:#FBF5F0;
  --night:#0B0610;
  --night-2:#1A1322;

  --display:"Bricolage Grotesque","Familjen Grotesk",ui-sans-serif,system-ui,sans-serif;
  --sans:"Geist",ui-sans-serif,system-ui,-apple-system,"Helvetica Neue",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --r-sm:10px;
  --r-md:18px;
  --r-lg:28px;
  --r-xl:40px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit}
::selection{background:var(--magenta);color:#fff}

/* ─────────────────────────── Layout ─────────────────────────── */
.wrap{max-width:1280px;margin:0 auto;padding:0 40px}
@media (max-width:720px){.wrap{padding:0 22px}}

section{padding:96px 0;position:relative}
@media (max-width:720px){section{padding:64px 0}}

/* ─────────────────────────── Type ─────────────────────────── */
.display{
  font-family:var(--display);
  font-weight:700;
  letter-spacing:-.025em;
  line-height:.92;
  font-variation-settings:"wdth" 100, "opsz" 96;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-2);
}
.eyebrow .dot{
  width:7px;height:7px;border-radius:50%;background:var(--magenta);
  box-shadow:0 0 0 4px rgba(165,17,83,.18);
}
.kicker{
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--magenta);
  display:flex;align-items:center;gap:12px;
}
.kicker::before{
  content:"";display:inline-block;width:26px;height:2px;background:var(--magenta);
}
.kicker.on-dark{color:var(--teal)}
.kicker.on-dark::before{background:var(--teal)}

h2.section-h{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(44px,6.4vw,96px);
  line-height:.94;letter-spacing:-.025em;
  margin:18px 0 0;max-width:18ch;
}
h2.section-h .magenta{color:var(--magenta)}
h2.section-h .teal{color:var(--teal)}

.section-lead{
  margin-top:22px;max-width:48ch;
  font-size:18px;line-height:1.55;color:var(--ink-2);
}

/* ─────────────────────────── Nav ─────────────────────────── */
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px;
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
}
.nav.scrolled{border-bottom-color:var(--line)}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:60px;width:auto;display:block}
.brand-mark{width:36px;height:36px;display:grid;place-items:center}
.brand-mark img{width:100%;height:100%;object-fit:contain}
.brand-name{
  font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:-.01em;
  font-variation-settings:"wdth" 100, "opsz" 24;
}
.brand-name .m{color:var(--magenta)}
.brand-name .t{color:var(--teal)}
.nav-links{display:flex;gap:32px;font-size:14.5px;color:var(--ink-2)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--magenta);color:#fff;
  padding:10px 18px;border-radius:999px;font-size:14px;font-weight:500;
  transition:transform .15s ease,background .2s;
}
.nav-cta:hover{transform:translateY(-1px);background:var(--magenta-deep)}
.nav-cta svg{width:13px;height:13px}
@media (max-width:780px){.nav-links{display:none}}

/* ─────────────────────────── Buttons ─────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 24px;border-radius:999px;
  font-size:15px;font-weight:500;
  border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .2s,border-color .2s;
}
.btn-primary{background:var(--magenta);color:#fff}
.btn-primary:hover{transform:translateY(-1px);background:var(--magenta-deep)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{transform:translateY(-1px);background:#000}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.2)}
.btn-ghost.on-dark:hover{border-color:#fff}
.btn svg{width:14px;height:14px}

/* App store / Play store badges */
.badge{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--ink);color:#fff;
  padding:13px 20px;border-radius:14px;font-size:13px;font-weight:500;
  transition:transform .15s ease;
}
.badge:hover{transform:translateY(-1px)}
.badge svg{width:24px;height:24px;flex-shrink:0}
.badge .b-top{display:block;font-size:9.5px;font-family:var(--mono);letter-spacing:.06em;opacity:.7;margin-bottom:1px;text-transform:uppercase}
.badge .b-name{font-size:17px;font-family:var(--display);font-weight:600;line-height:1;letter-spacing:-.01em}

/* ─────────────────────────── Stump motif divider ─────────────────────────── */
.stumps{
  display:inline-flex;gap:6px;align-items:flex-end;
}
.stumps span{
  display:block;width:5px;background:var(--magenta);border-radius:2px;
}
.stumps span:nth-child(1){height:32px}
.stumps span:nth-child(2){height:38px}
.stumps span:nth-child(3){height:32px}
.stumps.teal span{background:var(--teal)}
.stumps.lg span{width:7px}
.stumps.lg span:nth-child(1){height:54px}
.stumps.lg span:nth-child(2){height:64px}
.stumps.lg span:nth-child(3){height:54px}
.stumps.bails::after{
  content:"";display:block;position:absolute;
}

/* a red "ball" dot */
.ball{
  display:inline-block;width:12px;height:12px;border-radius:50%;
  background:var(--magenta);vertical-align:middle;
  box-shadow:inset -2px -2px 3px rgba(0,0,0,.25);
}
.ball.teal{background:var(--teal)}
.ball.lg{width:18px;height:18px}

/* ─────────────────────────── Hero ─────────────────────────── */
.hero{
  position:relative;
  padding:70px 0 40px;
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;
}
@media (max-width:1000px){.hero-grid{grid-template-columns:1fr;gap:50px}}

.hero h1{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(64px,10.8vw,168px);
  line-height:.88;letter-spacing:-.035em;
  margin:24px 0 0;
  font-variation-settings:"wdth" 95, "opsz" 96;
}
.hero h1 .magenta{color:var(--magenta)}
.hero h1 .teal{color:var(--teal)}
.hero h1 .with-ball{position:relative;display:inline-block}
.hero-sub{
  margin-top:30px;max-width:46ch;
  font-size:clamp(17px,1.4vw,20px);line-height:1.55;color:var(--ink-2);
}
.hero-sub strong{color:var(--ink);font-weight:500}
.hero-ctas{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:36px;
}
.hero-meta{
  margin-top:24px;
  display:flex;gap:24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta .dot{width:5px;height:5px;border-radius:50%;background:var(--magenta)}

/* QR join chip (hero) */
.qr-join{
  position:relative;
  display:inline-flex;align-items:center;
  margin-left:6px;padding-left:18px;
  border-left:1px solid var(--line);
  cursor:help;
}
.qr-box{
  width:62px;height:62px;border-radius:14px;
  background:#fff;border:1px solid var(--line);
  padding:7px;
  box-shadow:0 8px 20px -10px rgba(17,9,27,.22);
  transition:transform .18s ease, box-shadow .18s ease;
}
.qr-join:hover .qr-box,.qr-join:focus .qr-box{
  transform:translateY(-2px);
  box-shadow:0 14px 30px -10px rgba(165,17,83,.3);
}
.qr-svg{display:block;width:100%;height:100%}
.qr-tip{
  position:absolute;left:50%;bottom:calc(100% + 12px);transform:translateX(-50%) translateY(4px);
  width:210px;
  background:var(--ink);color:#fff;
  font-family:var(--sans);font-size:12.5px;line-height:1.4;font-weight:400;
  padding:11px 13px;border-radius:12px;
  text-align:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  box-shadow:0 12px 28px -10px rgba(17,9,27,.4);
  z-index:20;
}
.qr-tip::after{
  content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--ink);
}
.qr-join:hover .qr-tip,.qr-join:focus .qr-tip{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);
}
@media (max-width:560px){.qr-join{display:none}}

/* ─────────────────────────── Phone mockup ─────────────────────────── */
.phone{
  border-radius:42px;
  background:#0e0712;
  padding:9px;
  box-shadow:
    0 28px 70px -14px rgba(165,17,83,.32),
    0 12px 28px -8px rgba(17,9,27,.22),
    0 0 0 1px rgba(17,9,27,.04);
  position:relative;
}
.phone .screen{
  border-radius:34px;
  background:#fff;
  width:100%;height:100%;
  overflow:hidden;position:relative;
  display:flex;flex-direction:column;
}
.phone .screen .app-shot{
  width:100%;height:100%;
  object-fit:cover;object-position:top center;
  display:block;
}
.phone .notch{
  position:absolute;left:50%;top:18px;transform:translateX(-50%);
  width:96px;height:26px;border-radius:14px;background:#0e0712;z-index:5;
}
.phone .status{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 26px 8px;font-family:var(--mono);font-size:11px;color:var(--ink);font-weight:500;
}
.phone .status .right{display:flex;gap:5px;align-items:center}
.phone .status .right .bars{display:inline-flex;gap:1.5px;align-items:flex-end}
.phone .status .right .bars span{width:2.5px;background:var(--ink);border-radius:1px}
.phone .status .right .bars span:nth-child(1){height:4px}
.phone .status .right .bars span:nth-child(2){height:6px}
.phone .status .right .bars span:nth-child(3){height:8px}
.phone .status .right .bars span:nth-child(4){height:10px}

/* hero phone size + tilt + floats */
.hero-phone-wrap{
  position:relative;display:flex;justify-content:center;align-items:center;
  min-height:680px;
}
.hero-phone{
  width:340px;height:680px;
  transform:rotate(-3deg);
}
@media (max-width:600px){.hero-phone{width:290px;height:580px}.hero-phone-wrap{min-height:580px}}

/* floating chips around hero phone */
.float{
  position:absolute;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px 18px;
  font-size:13.5px;
  box-shadow:0 14px 30px -10px rgba(17,9,27,.15);
  display:flex;align-items:center;gap:12px;
}
.float .av{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--magenta));
  color:#fff;display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:14px;flex-shrink:0;
}
.float .txt{display:flex;flex-direction:column;gap:2px;white-space:nowrap}
.float .txt strong{font-size:13px;font-weight:600}
.float .txt small{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.04em}
.float .lang{
  font-family:var(--mono);font-size:10px;color:var(--magenta);letter-spacing:.04em;
  padding:3px 7px;border-radius:6px;background:var(--magenta-tint);
}
.float-1{top:0;left:-110px;transform:rotate(-4deg)}
.float-2{top:50%;right:-90px;transform:translateY(-50%) rotate(3deg)}
.float-3{bottom:10px;left:-90px;transform:rotate(-2deg)}
@media (max-width:1200px){
  .float-1{left:-50px}.float-2{right:-40px}.float-3{left:-40px}
}
@media (max-width:1000px){
  .float-1{left:0}.float-2{right:0}.float-3{left:10px}
}
@media (max-width:600px){.float{display:none}}

/* waveform */
.wave{
  display:inline-flex;align-items:center;gap:2.5px;height:22px;
}
.wave span{
  display:block;width:2.5px;background:var(--teal);border-radius:1px;
}
.wave.magenta span{background:var(--magenta)}

/* ─────────────────────────── In-app screens (mocks) ─────────────────────────── */
.feed{
  flex:1;display:flex;flex-direction:column;gap:14px;
  padding:6px 16px 14px;overflow:hidden;
}
.feed-h{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:6px 4px 4px;
}
.feed-h h3{
  margin:0;font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:-.02em;
  font-variation-settings:"wdth" 100, "opsz" 24;
}
.feed-h .live{
  font-family:var(--mono);font-size:9.5px;color:var(--magenta);letter-spacing:.08em;
  display:inline-flex;align-items:center;gap:5px;
}
.feed-h .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--magenta);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.post{
  display:flex;gap:10px;
  padding:12px 0;border-bottom:1px solid var(--line);
}
.post:last-child{border-bottom:0}
.post .av{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal),var(--magenta));
  color:#fff;display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:13px;
}
.post .body{flex:1;min-width:0}
.post .meta{
  display:flex;gap:8px;align-items:baseline;
  font-size:12px;color:var(--ink-3);
}
.post .meta b{color:var(--ink);font-weight:600;font-size:12.5px}
.post .meta .lang{
  font-family:var(--mono);font-size:9px;letter-spacing:.04em;
  background:var(--teal-tint);color:var(--teal-deep);padding:1px 5px;border-radius:4px;
}
.post .content{font-size:13.5px;line-height:1.45;margin-top:4px;color:var(--ink)}

.voice-row{
  display:flex;align-items:center;gap:10px;margin-top:8px;
  padding:8px 10px;background:var(--magenta-tint);border-radius:14px;
}
.voice-row .play{
  width:28px;height:28px;border-radius:50%;background:var(--magenta);
  color:#fff;display:grid;place-items:center;font-size:11px;flex-shrink:0;
}
.voice-row .dur{font-family:var(--mono);font-size:10.5px;color:var(--magenta);margin-left:auto}

.post .actions{
  display:flex;gap:16px;margin-top:6px;
  font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.02em;
}
.post .actions span{display:inline-flex;align-items:center;gap:4px}

/* ─────────────────────────── Live ticker ─────────────────────────── */
.ticker{
  background:var(--ink);color:#fff;
  padding:14px 0;
  overflow:hidden;position:relative;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.ticker-inner{
  display:flex;gap:48px;white-space:nowrap;
  animation:slide 40s linear infinite;
  width:max-content;
  font-family:var(--mono);font-size:13px;letter-spacing:.04em;
}
.ticker-inner > span{display:inline-flex;gap:48px;align-items:center}
.ticker-inner b{color:var(--teal);font-weight:500}
.ticker-inner i{font-style:normal;color:var(--magenta)}
.ticker-inner .sep{color:rgba(255,255,255,.25)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─────────────────────────── Four pillars ─────────────────────────── */
.pillars{
  margin-top:44px;
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.pillar{
  position:relative;overflow:hidden;
  background:var(--cream);
  border-radius:var(--r-lg);
  padding:34px 32px 36px;
  display:flex;flex-direction:column;gap:18px;
  min-height:380px;
}
.pillar.span-7{grid-column:span 7}
.pillar.span-5{grid-column:span 5}
.pillar.span-6{grid-column:span 6}
@media (max-width:980px){.pillar.span-7,.pillar.span-5,.pillar.span-6{grid-column:1/-1}}

.pillar .num{
  font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;
}
.pillar h3{
  font-family:var(--display);font-weight:700;
  font-size:44px;line-height:.95;letter-spacing:-.025em;margin:0;
  font-variation-settings:"wdth" 95, "opsz" 44;
}
.pillar h3 .magenta{color:var(--magenta)}
.pillar h3 .teal{color:var(--teal)}
.pillar p{margin:0;color:var(--ink-2);font-size:15.5px;line-height:1.55;max-width:36ch}
.pillar .demo{
  margin-top:auto;
  position:relative;
}

/* Quick Singles demo: stack of small posts */
.demo-feed{
  background:#fff;border-radius:var(--r-md);
  padding:14px;
  display:flex;flex-direction:column;gap:12px;
  box-shadow:0 8px 24px -10px rgba(17,9,27,.1);
  border:1px solid var(--line);
  position:relative;
}
.stat-pill{
  position:absolute;top:-11px;right:14px;z-index:2;
  font-family:var(--mono);font-size:10px;letter-spacing:.04em;
  text-transform:uppercase;
  background:var(--ink);color:#fff;
  padding:5px 11px;border-radius:999px;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 6px 16px -6px rgba(17,9,27,.35);
}
.stat-pill::before{
  content:"";width:5px;height:5px;border-radius:50%;background:var(--teal);
}

/* Huddle demo: dark chat bubbles */
.demo-chat{
  background:var(--ink);color:#fff;border-radius:var(--r-md);
  padding:16px 14px;
  display:flex;flex-direction:column;gap:8px;
  font-size:12.5px;
  position:relative;
  overflow:hidden;
}
.demo-chat .msg{
  display:flex;gap:8px;align-items:flex-start;
}
.demo-chat .msg .av{
  width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--magenta));
  display:grid;place-items:center;color:#fff;font-size:10px;font-weight:600;
  flex-shrink:0;
}
.demo-chat .msg .bub{
  background:rgba(255,255,255,.08);border-radius:12px;padding:7px 10px;
  border-bottom-left-radius:4px;max-width:80%;
}
.demo-chat .msg .bub b{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--teal);margin-bottom:2px}
.demo-chat .msg.mine{justify-content:flex-end}
.demo-chat .msg.mine .bub{background:var(--magenta);border-bottom-left-radius:12px;border-bottom-right-radius:4px}
.demo-chat .msg.mine .bub b{color:rgba(255,255,255,.7)}
.demo-chat .scoreband{
  position:absolute;top:0;left:0;right:0;
  background:rgba(255,255,255,.06);
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;
  padding:6px 14px;display:flex;justify-content:space-between;align-items:center;
}
.demo-chat .scoreband b{color:var(--teal);font-weight:500}
.demo-chat .pad-top{padding-top:24px}

/* Long Innings demo: article cards */
.demo-news{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.demo-news .card{
  background:#fff;border-radius:14px;border:1px solid var(--line);
  padding:14px;display:flex;flex-direction:column;gap:8px;
}
.demo-news .card .tag{font-family:var(--mono);font-size:9.5px;color:var(--teal-deep);letter-spacing:.06em;text-transform:uppercase}
.demo-news .card h4{margin:0;font-family:var(--display);font-weight:600;font-size:15px;line-height:1.15;letter-spacing:-.01em}
.demo-news .card .img{
  height:148px;border-radius:8px;overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(17,9,27,.06) 0 6px, transparent 6px 12px),
    linear-gradient(135deg, var(--teal-tint), var(--magenta-tint));
}
.demo-news .card .img img{width:100%;height:100%;object-fit:cover;display:block}
.demo-news .card .meta{font-family:var(--mono);font-size:9.5px;color:var(--ink-3);letter-spacing:.04em}

/* Games demo: pixel grid */
.demo-games{
  background:#fff;border-radius:var(--r-md);
  padding:16px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  border:1px solid var(--line);
}
.demo-games .tile{
  aspect-ratio:1;border-radius:12px;overflow:hidden;
  position:relative;
  background:var(--ink);
}
.demo-games .tile img{
  width:100%;height:100%;object-fit:cover;display:block;
}

/* ─────────────────────────── Voice / Audio first section ─────────────────────────── */
.voice-stage{position:relative}
.voice-deco{
  position:absolute;z-index:0;pointer-events:none;
  top:-118px;left:-116px;width:402px;height:auto;display:block;
  filter:drop-shadow(0 14px 30px rgba(17,9,27,.28));
}
@media (max-width:980px){.voice-deco{display:none}}
.voice-hero{
  background:var(--magenta);color:#fff;
  border-radius:var(--r-xl);
  padding:80px 60px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:stretch;
  position:relative;z-index:1;overflow:hidden;
}
@media (max-width:980px){.voice-hero{grid-template-columns:1fr;padding:60px 32px}}
.voice-hero h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(40px,6vw,84px);line-height:.95;letter-spacing:-.03em;
  margin:0;max-width:14ch;
}
.voice-hero h2 em{font-style:normal;color:var(--teal)}
.voice-hero p{
  margin-top:20px;font-size:17px;max-width:42ch;line-height:1.55;
  color:rgba(255,255,255,.85);
}
.voice-hero .stat{
  margin-top:34px;display:flex;gap:36px;flex-wrap:wrap;
}
.voice-hero .stat .n{
  font-family:var(--display);font-weight:700;font-size:48px;letter-spacing:-.02em;line-height:1;
  color:var(--teal);
}
.voice-hero .stat small{
  display:block;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.7);
  letter-spacing:.04em;text-transform:uppercase;margin-top:8px;max-width:14ch;
}

/* Big waveform visual */
.voice-visual{
  display:flex;flex-direction:column;height:100%;
}
.big-wave{
  display:flex;align-items:stretch;gap:5px;
  flex:1;min-height:200px;
}
.big-wave span{
  flex:1;height:100%;background:var(--teal);border-radius:3px;
  transform-origin:center;
  animation:wavebob 1.4s ease-in-out infinite;
}
@keyframes wavebob{
  0%,100%{transform:scaleY(.3)}
  50%{transform:scaleY(1)}
}

/* ─────────────────────────── Match-night Huddle section (dark) ─────────────────────────── */
.huddle-night{
  background:var(--night);color:#fff;
}
.huddle-night h2{color:#fff}
.huddle-night .section-lead{color:rgba(255,255,255,.7)}
.huddle-night .matchup{
  margin-top:50px;
  background:var(--night-2);border-radius:var(--r-lg);
  padding:30px;
  display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch;
  border:1px solid rgba(255,255,255,.06);
}
@media (max-width:880px){.huddle-night .matchup{grid-template-columns:1fr}}
.matchup .score{
  display:flex;flex-direction:column;justify-content:space-between;gap:20px;
}
.matchup .teams{
  display:flex;flex-direction:column;gap:14px;
  font-family:var(--display);
}
.matchup .team{
  display:flex;justify-content:space-between;align-items:baseline;gap:20px;
  padding:18px 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.matchup .team:last-child{border-bottom:0}
.matchup .team .name{
  font-weight:700;font-size:32px;letter-spacing:-.02em;
  display:flex;align-items:center;gap:14px;
}
.matchup .team .flag{
  width:34px;height:24px;border-radius:4px;
  background:var(--teal);
  display:grid;place-items:center;color:#fff;font-family:var(--mono);font-size:10px;font-weight:600;
}
.matchup .team .flag.m{background:var(--magenta)}
.matchup .team .runs{
  font-family:var(--mono);font-weight:500;font-size:30px;color:var(--teal);
}
.matchup .team .runs small{font-size:14px;color:rgba(255,255,255,.5);margin-left:6px}
.matchup .live-strip{
  font-family:var(--mono);font-size:11.5px;color:rgba(255,255,255,.7);letter-spacing:.04em;
  display:flex;align-items:center;gap:10px;
}
.matchup .live-strip .dot{
  width:7px;height:7px;border-radius:50%;background:var(--magenta);
  animation:pulse 1.4s infinite;
}
.matchup .live-strip b{color:#fff;font-weight:500}

.huddle-chat{
  background:#0F0716;border:1px solid rgba(255,255,255,.06);
  border-radius:var(--r-md);padding:20px;
  display:flex;flex-direction:column;gap:10px;
  font-size:13.5px;
  min-height:340px;
  position:relative;
}
.huddle-chat .h{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:rgba(255,255,255,.5);
  text-transform:uppercase;margin-bottom:6px;
  display:flex;justify-content:space-between;align-items:center;
}
.huddle-chat .h .count{color:var(--teal)}
.h-msg{display:flex;gap:10px;align-items:flex-start}
.h-msg .av{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal),var(--magenta));
  display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:600;font-size:11px;
}
.h-msg .bub{
  background:rgba(255,255,255,.06);border-radius:14px;padding:8px 12px;
  border-bottom-left-radius:4px;max-width:84%;
  display:flex;flex-direction:column;gap:3px;
}
.h-msg .bub .who{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;color:var(--teal)}
.h-msg .bub .who span{color:rgba(255,255,255,.4);margin-left:6px}
.h-msg.voice .bub{display:flex;flex-direction:row;align-items:center;gap:10px;padding:10px 12px}
.h-msg.voice .play{
  width:24px;height:24px;border-radius:50%;background:var(--magenta);color:#fff;
  display:grid;place-items:center;font-size:10px;flex-shrink:0;
}
.h-msg.voice .dur{font-family:var(--mono);font-size:10px;color:var(--teal);margin-left:auto}
.h-msg.reaction .bub{
  background:transparent;border:1px dashed rgba(255,255,255,.15);
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.6);
  display:inline-flex;flex-direction:row;align-items:center;gap:8px;padding:6px 10px;
}

/* ─────────────────────────── Global section ─────────────────────────── */
.global{
  background:var(--cream);
}
.globe-grid{
  margin-top:60px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
@media (max-width:880px){.globe-grid{grid-template-columns:1fr}}

.lang-card-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
.lang-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:18px;display:flex;flex-direction:column;gap:10px;
  transition:transform .2s;
}
.lang-card:nth-child(even){transform:translateY(20px)}
.lang-card .who{display:flex;align-items:center;gap:10px}
.lang-card .av{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal),var(--magenta));
  color:#fff;display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:14px;
}
.lang-card .name{font-weight:600;font-size:14px}
.lang-card .city{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}
.lang-card .said{font-size:14px;line-height:1.45;color:var(--ink)}
.lang-card .said em{font-style:italic;color:var(--magenta)}
.lang-card .lang-tag{
  align-self:flex-start;
  font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--teal-deep);
  background:var(--teal-tint);padding:3px 8px;border-radius:6px;
}

/* stat strip */
.stat-strip{
  margin-top:80px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  padding:50px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
@media (max-width:780px){.stat-strip{grid-template-columns:1fr 1fr}}
.stat-strip .item{
  display:flex;flex-direction:column;gap:6px;
}
.stat-strip .n{
  font-family:var(--display);font-weight:700;font-size:56px;letter-spacing:-.025em;line-height:1;
  color:var(--magenta);
}
.stat-strip .n .teal{color:var(--teal)}
.stat-strip small{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase;max-width:18ch}

/* investor insight */
.ii-stage{position:relative;margin-top:80px}
.ii-deco{position:absolute;z-index:0;pointer-events:none}
.ii-deco-ball{top:-118px;right:-72px;width:248px;height:248px;display:block;opacity:.9}
.ii-deco-wicket{bottom:-118px;left:-104px;width:390px;height:auto;display:block;opacity:.85;filter:drop-shadow(0 8px 20px rgba(17,9,27,.22));transform:scaleX(-1)}
.investor-insight{
  position:relative;z-index:1;
  background:var(--ink);color:#fff;
  border-radius:var(--r-lg,22px);
  padding:48px 44px;
  display:grid;grid-template-columns:1fr;gap:40px;
}
.ii-head{max-width:none}
.ii-thesis{
  margin:18px 0 0;
  font-family:var(--display);font-weight:600;
  font-size:clamp(23px,2.3vw,30px);line-height:1.25;letter-spacing:-.015em;
  color:#fff;text-wrap:pretty;
}
.ii-thesis .ii-closer{display:block}
.ii-thesis em{font-style:italic;color:rgba(255,255,255,.92)}
.ii-thesis .teal{color:var(--teal)}
.ii-thesis .magenta{color:#F06A9E}
.ii-metrics{
  display:grid;grid-template-columns:repeat(4,1fr);gap:26px;
  border-top:1px solid rgba(255,255,255,.14);padding-top:36px;
}
.ii-m{display:flex;flex-direction:column;gap:9px}
.ii-n{
  font-family:var(--display);font-weight:700;font-size:48px;letter-spacing:-.025em;line-height:1;
  color:#fff;
}
.ii-n.teal{color:var(--teal)}
.ii-n .sup{font-size:.5em;vertical-align:super;font-weight:600;opacity:.8}
.ii-l{font-size:13.5px;line-height:1.35;color:rgba(255,255,255,.7);max-width:16ch}
.ii-tag{
  margin-top:2px;align-self:flex-start;white-space:nowrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--teal);
  padding:4px 9px;border-radius:999px;border:1px solid rgba(28,188,198,.35);
}
@media (max-width:900px){
  .investor-insight{padding:38px 30px;gap:32px}
  .ii-metrics{grid-template-columns:1fr 1fr;gap:24px}
  .ii-deco{display:none}
}
@media (max-width:520px){
  .ii-metrics{grid-template-columns:1fr}
}

/* ─────────────────────────── Final CTA ─────────────────────────── */
.cta-stage{position:relative}
.cta-deco{position:absolute;z-index:0;pointer-events:none}
.cta-deco-ball{top:-118px;left:-72px;width:248px;height:248px;display:block;opacity:.9;transform:scaleX(-1)}
.cta-deco-wicket{bottom:-118px;right:-104px;width:390px;height:auto;display:block;opacity:.85;filter:drop-shadow(0 8px 20px rgba(0,0,0,.28))}
.cta{
  position:relative;z-index:1;
  background:var(--ink);color:#fff;border-radius:var(--r-xl);
  padding:90px 60px;
  display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center;
  overflow:hidden;
}
@media (max-width:880px){.cta{grid-template-columns:1fr;padding:60px 32px}.cta-deco{display:none}}
.cta h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(46px,6.4vw,96px);line-height:.94;letter-spacing:-.03em;
  margin:0;max-width:14ch;color:#fff;
}
.cta h2 .m{color:var(--magenta)}
.cta h2 .t{color:var(--teal)}
.cta .actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta .badges{display:flex;gap:12px;flex-wrap:wrap;width:100%}
.cta .meta{
  font-family:var(--mono);font-size:11.5px;color:rgba(255,255,255,.55);
  letter-spacing:.04em;margin-top:14px;width:100%;text-align:center;
}
.cta .bg-stumps{
  display:none;
  position:absolute;right:60px;top:60px;
  align-items:flex-end;opacity:.12;
  pointer-events:none;
}
.cta .bg-stumps span{
  display:block;width:18px;background:var(--teal);border-radius:5px;
}
.cta .bg-stumps span:nth-child(1){height:120px}
.cta .bg-stumps span:nth-child(2){height:160px}
.cta .bg-stumps span:nth-child(3){height:120px}
.cta .bg-ball{
  display:none;
  position:absolute;right:130px;top:30px;
  width:40px;height:40px;border-radius:50%;background:var(--magenta);
  box-shadow:inset -6px -6px 10px rgba(0,0,0,.3);
  opacity:.5;
}

/* ─────────────────────────── Footer ─────────────────────────── */
footer{
  padding:96px 0 40px;
  border-top:1px solid var(--line);
}
.foot-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
}
@media (max-width:780px){.foot-top{grid-template-columns:1fr 1fr;gap:30px}}
.foot-col h5{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-3);margin:0 0 14px;font-weight:500;
}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.foot-col a{color:var(--ink-2);font-size:14.5px}
.foot-col a:hover{color:var(--magenta)}
.foot-lead p{
  font-family:var(--display);
  font-size:24px;line-height:1.15;letter-spacing:-.015em;
  margin:14px 0 0;max-width:24ch;color:var(--ink);font-weight:500;
}
.foot-bottom{
  margin-top:60px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;
  border-top:1px solid var(--line);padding-top:24px;
}
.foot-bottom .legal{display:flex;gap:20px}

/* ─────────────────────────── Sub-pages (privacy, support) ─────────────────────────── */
.page-h{
  padding:80px 0 30px;
}
.page-h h1{
  font-family:var(--display);font-weight:700;
  font-size:clamp(48px,7vw,104px);line-height:.94;letter-spacing:-.03em;
  margin:18px 0 0;
}
.page-h h1 .m{color:var(--magenta)}
.page-h h1 .t{color:var(--teal)}
.page-h .lead{
  margin-top:24px;max-width:54ch;font-size:18px;color:var(--ink-2);line-height:1.55;
}

.content-prose{
  max-width:780px;margin:0 auto;padding:50px 0 80px;
}
.content-prose h2{
  font-family:var(--display);font-weight:700;
  font-size:32px;letter-spacing:-.02em;margin:48px 0 14px;
}
.content-prose h3{
  font-family:var(--display);font-weight:600;
  font-size:20px;letter-spacing:-.01em;margin:30px 0 10px;
}
.content-prose p{margin:0 0 14px;color:var(--ink-2);font-size:16px;line-height:1.65}
.content-prose ul{margin:0 0 14px;padding-left:22px;color:var(--ink-2);font-size:16px;line-height:1.65}
.content-prose li{margin:0 0 6px}
.content-prose strong{color:var(--ink)}
.content-prose a{color:var(--magenta);text-decoration:underline;text-underline-offset:3px}
.content-prose .updated{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);
}

.contact-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px;
}
@media (max-width:780px){.contact-grid{grid-template-columns:1fr}}
.contact-card{
  background:var(--cream);border-radius:var(--r-md);padding:30px;
  display:flex;flex-direction:column;gap:10px;
}
.contact-card h3{
  margin:0;font-family:var(--display);font-weight:700;font-size:26px;letter-spacing:-.015em;
}
.contact-card h3 .m{color:var(--magenta)}
.contact-card p{margin:0;color:var(--ink-2);font-size:15px;line-height:1.5}
.contact-card a.cta-link{
  margin-top:auto;color:var(--magenta);font-weight:500;font-size:15px;
  display:inline-flex;align-items:center;gap:6px;
}
.contact-card a.cta-link:hover{color:var(--magenta-deep)}
.contact-card .icon{
  width:44px;height:44px;border-radius:12px;background:#fff;
  display:grid;place-items:center;font-family:var(--display);font-weight:700;color:var(--magenta);font-size:20px;
  margin-bottom:6px;
}

/* ─────────────────────────── askMike pillar (full-width) ─────────────────────────── */
.pillar.askmike{
  grid-column:1/-1;
  background:linear-gradient(135deg, var(--ink) 0%, #1A0F2A 100%);
  color:#fff;
  display:grid;grid-template-columns:1.1fr .9fr;gap:40px;
  padding:42px 44px;
  min-height:360px;
  position:relative;overflow:hidden;
}
@media (max-width:880px){.pillar.askmike{grid-template-columns:1fr;padding:36px 30px}}
.pillar.askmike .num{color:rgba(255,255,255,.5)}
.pillar.askmike h3{color:#fff;font-size:52px}
.pillar.askmike h3 .teal{color:var(--teal)}
.pillar.askmike p{color:rgba(255,255,255,.72);max-width:38ch}
.pillar.askmike .new-badge{
  position:absolute;top:30px;right:30px;
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  background:var(--magenta);color:#fff;padding:6px 12px;border-radius:999px;
}
.askmike-prompts{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;
}
.askmike-prompts .chip{
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  padding:7px 12px;border-radius:999px;color:rgba(255,255,255,.85);
}
.askmike-prompts .chip::before{content:"→ ";color:var(--teal)}

.askmike-chat{
  background:#0B0610;border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-md);padding:18px;
  display:flex;flex-direction:column;
  font-size:13.5px;
  min-height:380px;max-height:440px;
  position:relative;
}
.askmike-chat .who-head{
  display:flex;align-items:center;gap:10px;
  padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06);
  margin-bottom:4px;flex-shrink:0;
}
.askmike-chat .who-head .mark{
  position:relative;
  width:32px;height:32px;border-radius:50%;
  background:var(--teal);color:var(--ink);
  display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:14px;
}
.askmike-chat .who-head .mark .live-dot{
  position:absolute;right:-1px;bottom:-1px;
  width:10px;height:10px;border-radius:50%;
  background:#22dd7a;border:2px solid #0B0610;
  box-shadow:0 0 0 0 rgba(34,221,122,.6);
  animation:liveGlow 1.8s infinite;
}
@keyframes liveGlow{
  0%{box-shadow:0 0 0 0 rgba(34,221,122,.55)}
  70%{box-shadow:0 0 0 7px rgba(34,221,122,0)}
  100%{box-shadow:0 0 0 0 rgba(34,221,122,0)}
}
.askmike-chat .who-head .name{font-family:var(--display);font-weight:600;font-size:15px;color:#fff;letter-spacing:-.01em}
.askmike-chat .who-head .name small{display:block;font-family:var(--mono);font-weight:400;font-size:10px;letter-spacing:.04em;color:var(--teal);margin-top:2px}

.insight-toggle{
  margin-left:auto;flex-shrink:0;cursor:pointer;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);
  padding:6px 10px;border-radius:999px;
  transition:all .2s ease;
}
.insight-toggle::before{content:"+ ";color:var(--teal)}
.insight-toggle:hover{border-color:var(--teal);color:#fff}
.insight-toggle[aria-pressed="true"]{background:rgba(28,188,198,.14);border-color:var(--teal);color:#fff}
.insight-toggle[aria-pressed="true"]::before{content:"− "}

.insight-panel{
  margin:10px 0 4px;
  background:linear-gradient(120deg, rgba(165,17,83,.18), rgba(28,188,198,.14));
  border:1px solid rgba(28,188,198,.28);
  border-radius:12px;padding:12px 14px;
  font-size:12px;line-height:1.5;color:rgba(255,255,255,.85);
  flex-shrink:0;
  animation:insightIn .3s ease;
}
.insight-panel b{color:#fff;font-weight:600}
@keyframes insightIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

.chat-scroll{
  flex:1;overflow-y:auto;
  display:flex;flex-direction:column;gap:10px;
  padding:10px 2px 4px;
  scroll-behavior:smooth;
}
.chat-scroll::-webkit-scrollbar{width:5px}
.chat-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:99px}

.askmike-chat .you{
  align-self:flex-end;
  background:var(--magenta);color:#fff;padding:9px 13px;border-radius:14px;
  border-bottom-right-radius:4px;max-width:82%;font-size:13px;line-height:1.45;
  animation:msgIn .35s cubic-bezier(.22,1,.36,1);
}
.askmike-chat .mike{
  align-self:flex-start;position:relative;
  color:#fff;padding:11px 14px;border-radius:14px;
  border-bottom-left-radius:4px;max-width:90%;font-size:13px;line-height:1.5;
  border:1px solid transparent;
  background-image:linear-gradient(rgba(255,255,255,.06),rgba(255,255,255,.06)),linear-gradient(125deg,var(--teal),var(--magenta));
  background-origin:border-box;background-clip:padding-box,border-box;
  animation:msgIn .4s cubic-bezier(.22,1,.36,1);
}
@keyframes msgIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.askmike-chat .mike .roast{display:block;color:rgba(255,255,255,.92)}
.askmike-chat .mike .src{
  display:block;margin-top:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;
  color:rgba(255,255,255,.45);
}
.askmike-chat .mike .stat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;
  font-family:var(--mono);font-size:11px;
}
.askmike-chat .mike .stat-grid div{
  background:rgba(0,0,0,.28);padding:7px 10px;border-radius:8px;
  display:flex;justify-content:space-between;gap:8px;
}
.askmike-chat .mike .stat-grid div b{color:var(--teal);font-weight:500}
.askmike-chat .mike .lead-name{
  display:inline-block;font-family:var(--display);font-weight:700;font-size:15px;
  color:var(--teal);letter-spacing:-.01em;
}

.askmike-chat .typing{
  align-self:flex-start;
  background:rgba(255,255,255,.06);border-radius:14px;border-bottom-left-radius:4px;
  padding:11px 14px;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10.5px;color:var(--teal);letter-spacing:.04em;
}
.askmike-chat .typing .dots{display:inline-flex;gap:3px}
.askmike-chat .typing .dots span{
  width:5px;height:5px;border-radius:50%;background:var(--teal);
  animation:typeBob 1.1s infinite;
}
.askmike-chat .typing .dots span:nth-child(2){animation-delay:.18s}
.askmike-chat .typing .dots span:nth-child(3){animation-delay:.36s}
@keyframes typeBob{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}

.hot-prompts{
  display:flex;flex-direction:column;gap:8px;
  padding-top:14px;margin-top:10px;border-top:1px solid rgba(255,255,255,.06);
  flex-shrink:0;
}
.hot-prompt{
  text-align:left;cursor:pointer;
  font-family:var(--sans);font-size:12.5px;font-weight:500;
  color:#fff;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);border-radius:999px;
  padding:9px 14px;
  display:flex;align-items:center;gap:8px;
  transition:all .18s ease;
}
.hot-prompt::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);flex-shrink:0}
.hot-prompt:hover:not(:disabled){background:rgba(28,188,198,.14);border-color:var(--teal);transform:translateY(-1px)}
.hot-prompt:disabled{opacity:.4;cursor:not-allowed}
.hot-prompt.used{opacity:.32;cursor:default}
.hot-prompt.used::before{background:rgba(255,255,255,.3)}

/* ─────────────────────────── Leaderboard section ─────────────────────────── */
.leaderboard-sec{background:var(--cream)}
.leaderboard-grid{
  margin-top:44px;
  display:grid;grid-template-columns:.95fr 1.05fr;gap:60px;align-items:stretch;
}
@media (max-width:880px){.leaderboard-grid{grid-template-columns:1fr;gap:40px}}

.lb-card{
  background:#fff;border-radius:var(--r-lg);
  padding:30px;
  box-shadow:0 14px 40px -16px rgba(17,9,27,.12);
  border:1px solid var(--line);
}
.lb-tabs{
  display:flex;gap:6px;background:var(--cream);
  padding:4px;border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;
  margin-bottom:20px;
}
.lb-tabs span{
  padding:8px 14px;border-radius:999px;color:var(--ink-2);
}
.lb-tabs span.on{background:var(--magenta);color:#fff}

.lb-list{display:flex;flex-direction:column;gap:8px}
.lb-row{
  display:grid;grid-template-columns:32px 1fr auto auto;gap:14px;align-items:center;
  padding:12px 16px;border-radius:14px;
  background:var(--cream);
}
.lb-row .rank{
  font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;
  color:var(--ink-3);
}
.lb-row .av{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal),var(--magenta));
  color:#fff;display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:13px;
}
.lb-row .who{display:flex;align-items:center;gap:10px;min-width:0}
.lb-row .who .name{font-weight:600;font-size:14px}
.lb-row .who .city{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}
.lb-row .streak{
  font-family:var(--mono);font-size:11px;color:var(--magenta);letter-spacing:.04em;
}
.lb-row .pts{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink);min-width:60px;text-align:right}

.lb-row.you{
  background:var(--ink);color:#fff;
  border:1px solid var(--magenta);
}
.lb-row.you .rank{color:var(--teal)}
.lb-row.you .who .name{color:#fff}
.lb-row.you .who .city{color:rgba(255,255,255,.5)}
.lb-row.you .pts{color:var(--teal)}
.lb-row.you .streak{color:var(--teal)}

.lb-row.top1 .rank{color:var(--magenta)}

.badges-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px;
}
@media (max-width:600px){.badges-strip{grid-template-columns:1fr 1fr}}
.fan-badge{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:18px 16px;display:flex;flex-direction:column;gap:6px;
  text-align:center;align-items:center;
}
.fan-badge .icon{
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:20px;
  background:var(--magenta-tint);color:var(--magenta);
  margin-bottom:6px;
}
.fan-badge .icon.t{background:var(--teal-tint);color:var(--teal-deep)}
.fan-badge .icon.i{background:#11091B;color:#fff}
.fan-badge .label{font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:-.005em}
.fan-badge .desc{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}

/* ─────────────────────────── Personalisation section ─────────────────────────── */
.perso-grid{
  margin-top:60px;
  display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start;
}
@media (max-width:880px){.perso-grid{grid-template-columns:1fr}}

.perso-card{
  background:var(--cream);
  border-radius:var(--r-lg);
  padding:36px;
  position:relative;
}
.perso-step{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;
  color:var(--magenta);text-transform:uppercase;margin-bottom:14px;
}
.perso-card h4{
  font-family:var(--display);font-weight:700;
  font-size:24px;letter-spacing:-.015em;margin:0 0 18px;
}
.perso-chips{display:flex;flex-wrap:wrap;gap:8px}
.perso-chip{
  font-family:var(--sans);font-size:13px;font-weight:500;
  padding:8px 14px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  display:inline-flex;align-items:center;gap:6px;
  cursor:default;transition:all .2s;
}
.perso-chip.on{background:var(--magenta);color:#fff;border-color:var(--magenta)}
.perso-chip.on::before{content:"✓ ";font-size:11px}
.perso-chip.teal-on{background:var(--teal);color:#fff;border-color:var(--teal)}
.perso-chip.teal-on::before{content:"✓ ";font-size:11px}

.perso-bullets{
  margin-top:30px;display:flex;flex-direction:column;gap:18px;
}
.perso-bullet{
  display:flex;gap:18px;align-items:flex-start;
  padding-bottom:18px;border-bottom:1px solid var(--line);
}
.perso-bullet:last-child{border:0;padding-bottom:0}
.perso-bullet .num{
  font-family:var(--mono);font-size:11px;color:var(--magenta);letter-spacing:.06em;
  flex-shrink:0;width:40px;padding-top:4px;
}
.perso-bullet h5{
  margin:0 0 4px;font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.01em;
}
.perso-bullet p{margin:0;color:var(--ink-2);font-size:14.5px;line-height:1.55}

/* ─────────────────────────── Match Moments · reaction surge ─────────────────────────── */
.soundboard{
  --sb-mag:#A51153;
  --sb-teal:#1cbcc6;
  --sb-navy:#0f111a;
  background:#fafafa;
  border-top:1px solid var(--line);
}
.sb-grid{
  display:grid;grid-template-columns:.82fr 1.18fr;gap:64px;align-items:center;
}
@media (max-width:920px){.sb-grid{grid-template-columns:1fr;gap:40px}}

/* left panel */
.sb-label{
  display:inline-flex;align-items:center;
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--sb-mag);font-weight:500;
}
.sb-title{
  font-family:var(--display);font-weight:800;
  font-size:clamp(48px,5.6vw,82px);line-height:.9;letter-spacing:-.035em;
  margin:18px 0 0;color:var(--sb-navy);
  font-variation-settings:"wdth" 95,"opsz" 72;
}
.sb-persp{display:flex;flex-direction:column;gap:14px;margin-top:34px}
.sb-persp-card{
  border-radius:18px;padding:20px 22px;
  border:1px solid var(--line);background:#fff;
  position:relative;overflow:hidden;
}
.sb-persp-card.investor{
  background:var(--sb-navy);border-color:var(--sb-navy);
}
.sb-persp-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--sb-mag);
}
.sb-persp-card.investor::before{background:var(--sb-teal)}
.sb-persp-head{
  display:flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--sb-mag);margin-bottom:8px;font-weight:500;
}
.sb-persp-card.investor .sb-persp-head{color:var(--sb-teal)}
.sb-persp-head .sb-dot{width:7px;height:7px;border-radius:50%;background:var(--sb-mag)}
.sb-persp-head .sb-dot.teal{background:var(--sb-teal)}
.sb-persp-card p{margin:0;font-size:15px;line-height:1.55;color:var(--ink-2)}
.sb-persp-card.investor p{color:rgba(255,255,255,.82)}
.sb-persp-card.investor p b{color:#fff;font-weight:600}
.sb-persp-card p b{color:var(--sb-mag);font-weight:600}

/* board grid */
.sb-board{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
@media (max-width:540px){.sb-board{grid-template-columns:1fr}}

.sb-card{
  --acc:var(--sb-mag);
  position:relative;overflow:hidden;
  text-align:left;
  background:#fff;border:1px solid var(--line);border-radius:22px;
  padding:22px 22px 20px;
  min-height:208px;
  display:flex;flex-direction:column;
  color:var(--ink);
  transition:transform .18s cubic-bezier(.4,0,.2,1), background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.sb-card[data-accent="teal"]{--acc:var(--sb-teal)}
.sb-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -18px rgba(15,17,26,.28);border-color:rgba(15,17,26,.18)}

.sb-card-top{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.sb-tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-3);
}
/* peak reaction badge */
.sb-peak{
  flex-shrink:0;
  font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.02em;
  color:#fff;background:var(--acc);
  padding:5px 11px;border-radius:999px;
  display:inline-flex;align-items:baseline;gap:3px;
}
.sb-peak small{font-size:9.5px;opacity:.72;letter-spacing:.04em}

.sb-card-mid{flex:1;display:flex;align-items:flex-end;margin-top:18px}
.sb-card h3{
  margin:0;font-family:var(--display);font-weight:700;
  font-size:25px;line-height:1.02;letter-spacing:-.02em;
  font-variation-settings:"wdth" 100,"opsz" 26;
}

/* reaction-surge bars */
.sb-viz{
  display:flex;align-items:flex-end;gap:2px;height:40px;margin-top:18px;
}
.sb-viz span{
  flex:1;background:var(--acc);border-radius:2px;height:6%;
  opacity:.85;
  transition:height .5s cubic-bezier(.22,1,.36,1);
}

.sb-meta{
  display:flex;justify-content:space-between;align-items:center;margin-top:14px;
  padding-top:13px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-3);
}
.sb-state{text-transform:uppercase;letter-spacing:.08em;color:var(--acc);font-weight:500}

@media (prefers-reduced-motion:reduce){
  .sb-viz span{transition:none}
}

/* ─────────────────────────── Reveal animations ─────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
