/* ════════════════════════════════════════════════════════════════════
   WIN FOR SURE — design system + cinematic layer
   "Motion as restraint": at any instant ~90% of the frame is still,
   one thing moves, glows, or resolves. Stillness is the brand.
   ════════════════════════════════════════════════════════════════════ */

:root{
  /* ── color ── */
  --bg:#080b18; --panel:#111831; --panel-2:#18203f; --line:#27305a; --line-soft:#161d36;
  --ink:#eef1f8; --muted:#8b93ab; --faint:#5b6486;
  --win:#4ed08f; --win-dim:rgba(78,208,143,.13);
  --loss:#f0716a; --loss-dim:rgba(240,113,106,.12);
  --push:#9aa3b2; --push-dim:rgba(154,163,178,.10);
  --accent:#e2b600; --accent-dim:rgba(226,182,0,.14);
  --shadow:0 1px 0 rgba(255,255,255,.03), 0 18px 40px -18px rgba(0,0,0,.6);
  --maxw:1140px;
  /* ── motion grammar ── */
  --ease:cubic-bezier(.16,1,.3,1);          /* expo-out — entrances */
  /* ── bloom — spend it only on "the tenth", the equity line, primary CTAs ── */
  --bloom-accent:0 0 0 1px rgba(226,182,0,.4), 0 0 28px -2px rgba(226,182,0,.55), 0 0 70px -10px rgba(226,182,0,.4);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:"Hanken Grotesk",sans-serif;
  line-height:1.55;-webkit-font-smoothing:antialiased;position:relative;min-height:100vh;overflow-x:hidden;
}

/* ── graph-paper grid + single soft light source (top-right) ── */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.4;
  background-image:
    radial-gradient(circle at 16% -8%, rgba(226,182,0,.07), transparent 45%),
    radial-gradient(circle at 94% 2%, rgba(39,52,139,.20), transparent 42%),
    linear-gradient(rgba(255,255,255,.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.012) 1px, transparent 1px);
  background-size:auto,auto,48px 48px,48px 48px;
}

.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:760px}
a{color:inherit}
main{position:relative;z-index:1}

/* ════════════════════════════════════════════════════════════════════
   FILM STOCK — global atmosphere overlays (the "film")
   ════════════════════════════════════════════════════════════════════ */

/* film grain: fixed noise, mix-blend overlay, gently breathing.
   Swap the SVG for assets/grain.png later via --grain-img if you prefer. */
.grain{
  position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.045;
  mix-blend-mode:overlay;
  background-image:var(--grain-img, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"));
  background-size:160px 160px;
  animation:grainBreathe 4s ease-in-out infinite;
}
@keyframes grainBreathe{0%,100%{opacity:.04}50%{opacity:.055}}

/* soft edge vignette */
.vignette{
  position:fixed;inset:0;z-index:55;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 42%, transparent 55%, rgba(0,0,0,.34) 100%);
}

/* ════════════════════════════════════════════════════════════════════
   REVEAL — trigger-once: rise 24px + fade, expo-out
   ════════════════════════════════════════════════════════════════════ */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* staggered groups — children rise 80–120ms apart */
.js .stagger>*{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.js .stagger.in>*{opacity:1;transform:none}
.js .stagger.in>*:nth-child(1){transition-delay:.04s}
.js .stagger.in>*:nth-child(2){transition-delay:.13s}
.js .stagger.in>*:nth-child(3){transition-delay:.22s}
.js .stagger.in>*:nth-child(4){transition-delay:.31s}
.js .stagger.in>*:nth-child(5){transition-delay:.40s}
.js .stagger.in>*:nth-child(6){transition-delay:.49s}

/* ════════════════════════════════════════════════════════════════════
   SHARED ATOMS
   ════════════════════════════════════════════════════════════════════ */
.mark{
  width:34px;height:34px;border:1.5px solid var(--accent);border-radius:8px;display:grid;place-items:center;
  font-family:"JetBrains Mono",monospace;font-weight:700;color:var(--accent);font-size:15px;letter-spacing:-1px;
  box-shadow:inset 0 0 18px rgba(226,182,0,.12);flex:none;
}
.eyebrow{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.eyebrow .n{color:var(--faint);margin-right:10px}
.btn{
  appearance:none;border:0;cursor:pointer;text-decoration:none;display:inline-block;white-space:nowrap;
  background:var(--accent);color:#06121c;font-family:"JetBrains Mono",monospace;font-weight:700;font-size:14px;
  letter-spacing:.01em;padding:14px 22px;border-radius:10px;transition:transform .16s var(--ease), box-shadow .16s var(--ease);
  box-shadow:0 8px 24px -10px rgba(226,182,0,.7);
}
.btn:hover{box-shadow:0 12px 30px -10px rgba(226,182,0,.9)}   /* lift handled by Motion; shadow is the no-Motion fallback */
.btn-ghost{
  appearance:none;cursor:pointer;text-decoration:none;display:inline-block;white-space:nowrap;
  background:transparent;color:var(--ink);border:1px solid var(--line);font-family:"JetBrains Mono",monospace;
  font-weight:500;font-size:14px;padding:13px 20px;border-radius:10px;transition:.16s;
}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.mono{font-family:"JetBrains Mono",monospace;font-variant-numeric:tabular-nums}
.pos{color:var(--win)} .neg{color:var(--loss)} .neu{color:var(--ink)}

/* ════════════════════════════════════════════════════════════════════
   NAV
   ════════════════════════════════════════════════════════════════════ */
.nav{position:sticky;top:0;z-index:50;background:rgba(8,11,24,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.nav-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:13px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nm{font-family:"Fraunces",serif;font-style:italic;font-weight:500;font-size:20px;line-height:1;color:var(--accent)}   /* logo wordmark — gold italic serif; reused in the modal + pricing card */
.nm .tld,.nm .dot{color:var(--muted);font-weight:500}   /* recessive .com — dot matches the tld */
.navlinks{display:flex;gap:26px;align-items:center}
.navlinks a{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);text-decoration:none;letter-spacing:.02em;transition:.15s}
.navlinks a:hover{color:var(--ink)}
.navlinks a.on{color:var(--accent)}
.navdiv{width:1px;height:15px;background:var(--line);margin:0 4px}
.navdest{color:var(--ink)}
.navdest .ext{color:var(--accent);font-size:11px;margin-left:1px}
.navlinks a.navdest:hover{color:var(--accent)}
.nav-cta{font-size:12.5px;padding:10px 16px;position:relative}
/* count badge — red notification pill on the button's top-right corner */
.nav-badge{
  position:absolute;top:-7px;right:-6px;z-index:2;
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;padding:0;
  border-radius:50%;background:var(--loss);color:#fff;
  font-size:11px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;
  border:2px solid var(--bg);box-shadow:0 2px 6px rgba(0,0,0,.35);
}
.nav-right{display:flex;align-items:center;gap:12px}
/* account dropdown on the member "Today's Picks" button */
/* language switcher (placeholder — EN / 中文) */
/* single-button language toggle (promobar) — bigger flag + text */
.lang-seg{display:inline-flex;align-items:center;gap:3px;flex:none;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:999px;padding:2px;line-height:1}
.lang-seg .ls-opt{appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;border-radius:999px;padding:4px 10px;color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:13.5px;font-weight:600;letter-spacing:.02em;line-height:1;transition:background .18s,color .18s}
.lang-seg .ls-opt .flag{font-size:21px;line-height:1}
.lang-seg .ls-opt:not(.is-on):hover{color:var(--ink)}
.lang-seg .ls-opt.is-on{background:var(--accent);color:#17130a}
.lang-seg .ls-opt.is-on .flag{filter:saturate(1.05)}
/* mobile: flags only — hide the EN/中文/PT/ES labels (the .flag keeps its own font-size) */
@media(max-width:680px){.lang-seg .ls-opt{font-size:0;gap:0;padding:5px 9px}}
.navnum,.menu-extra{display:none}   /* section numbers + the 2 extra items show only in the mobile menu */
.menu-foot{display:contents}        /* desktop: destinations flow into the nav; the row layout is mobile-only */

/* Insights → "all articles" dropdown (hover/focus on desktop; inline sublist on mobile) */
.navdrop{position:relative;display:inline-flex;align-items:center}
.navdrop>.navdest{display:inline-flex;align-items:center;gap:5px}
.navdrop .navdest .ext{font-size:10px;transition:transform .18s var(--ease),color .18s}
.navdrop:hover .navdest .ext,.navdrop:focus-within .navdest .ext{transform:rotate(180deg);color:var(--accent)}
.navdrop::after{content:"";position:absolute;top:100%;right:0;width:320px;max-width:70vw;height:14px}   /* hover bridge across the gap */
.navdrop-menu{
  position:absolute;top:calc(100% + 12px);right:0;min-width:380px;display:none;flex-direction:column;gap:1px;z-index:60;
  background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:14px;
  padding:8px;box-shadow:0 32px 64px -26px rgba(0,0,0,.92);animation:menuDrop .2s var(--ease);
}
.navdrop:hover .navdrop-menu,.navdrop:focus-within .navdrop-menu{display:flex}
.navdrop-menu .dd-head{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);padding:7px 12px 8px}
.navdrop-menu .dd-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 12px;border-radius:10px;text-decoration:none;transition:background .14s}
.navdrop-menu .dd-row .dd-title{font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:.01em;color:var(--ink);white-space:nowrap}
.navdrop-menu .dd-row .dd-meta{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);flex:none}
.navdrop-menu .dd-row .dd-meta.start{color:var(--accent)}
.navdrop-menu a.dd-row:hover,.navdrop-menu a.dd-row:focus-visible{background:rgba(255,255,255,.05)}
.navdrop-menu a.dd-row:hover .dd-title{color:var(--accent)}
.navdrop-menu .dd-all{display:block;margin-top:5px;padding:11px 12px 6px;border-top:1px solid var(--line-soft);font-family:"JetBrains Mono",monospace;font-size:11.5px;letter-spacing:.04em;color:var(--accent);text-decoration:none}
.navdrop-menu .dd-all:hover{color:var(--ink)}

/* hamburger */
.navtoggle{display:none;appearance:none;cursor:pointer;background:transparent;border:1px solid var(--line);
  border-radius:9px;width:40px;height:36px;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.navtoggle span{display:block;width:17px;height:2px;background:var(--ink);border-radius:2px;transition:.22s}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@keyframes menuDrop{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.navlinks{animation:none}}

/* ════════════════════════════════════════════════════════════════════
   ROUTER
   ════════════════════════════════════════════════════════════════════ */
.page{display:none}
.page.active{display:block}

/* ════════════════════════════════════════════════════════════════════
   HERO — "The Tenth"
   ════════════════════════════════════════════════════════════════════ */
.hero{position:relative;padding:96px 0 64px;overflow:hidden;min-height:clamp(560px,86vh,820px);display:flex;align-items:center}
/* the cinematic field sits behind everything in the hero */
.hero-stage{position:absolute;inset:0;z-index:0;pointer-events:none}
/* legibility wash — heavier on the left, where the headline lives */
.hero-stage::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(8,11,24,.82) 0%, rgba(8,11,24,.5) 38%, rgba(8,11,24,.1) 70%, transparent 100%);
}
/* one slow horizontal light-sweep on first load (market opening bell) */
.hero-sweep{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;
  background:linear-gradient(90deg, transparent 0%, rgba(226,182,0,.07) 48%, rgba(233,237,243,.05) 50%, rgba(226,182,0,.07) 52%, transparent 100%);
  transform:translateX(-60%);
}
.hero-sweep.play{animation:sweep 1.4s var(--ease) .15s 1 forwards}
@keyframes sweep{0%{opacity:0;transform:translateX(-60%)}20%{opacity:1}100%{opacity:0;transform:translateX(60%)}}

.hero .wrap{width:100%}
.hero-grid{position:relative;z-index:2;display:flex;flex-direction:column;gap:40px}
.hero h1{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(34px,4.4vw,47px);line-height:1.07;letter-spacing:-.7px}
.hero h1 .line{display:block}
.hero h1 em{font-style:italic;color:var(--accent)}

/* hero copy plays in on its own cinematic timeline (set by app.js).
   Scoped to .js so the content is visible if scripts never run. */
.js .hero-copy .line,
.js .hero-copy .lede,
.js .hero-copy .cta-row,
.js .hero-copy .trust-strip{opacity:0}
.hero-copy.play .l1{opacity:1;animation:letterIn 1s var(--ease) .1s both}
.hero-copy.play .l2{opacity:1;animation:letterIn 1.1s var(--ease) .8s both}
.hero-copy.play .lede{opacity:1;animation:riseIn .9s var(--ease) 1.25s both}
.hero-copy.play .cta-row{opacity:1;animation:riseIn .9s var(--ease) 1.45s both}
.hero-copy.play .trust-strip{opacity:1;animation:riseIn .9s var(--ease) 1.6s both}
@keyframes letterIn{from{opacity:0;letter-spacing:.12em;transform:translateY(10px)}to{opacity:1;letter-spacing:-.8px;transform:none}}
@keyframes riseIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.lede{margin-top:20px;color:var(--muted);font-size:clamp(15.5px,1.7vw,18px);max-width:540px}
.cta-row{margin-top:30px;display:flex;gap:13px;flex-wrap:wrap}
.trust-strip{margin-top:30px;display:flex;flex-wrap:wrap;gap:9px;font-family:"JetBrains Mono",monospace;font-size:11px}
.trust-strip span{border:1px solid var(--line);border-radius:6px;padding:6px 10px;color:var(--muted);background:rgba(255,255,255,.015)}
.trust-strip span b{color:var(--ink);font-weight:500}

/* "record at a glance" glass card */
.glance{background:linear-gradient(180deg,rgba(20,26,35,.86),rgba(27,33,44,.86));backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.glance::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 0,rgba(226,182,0,.10),transparent 60%);pointer-events:none}
.glance .gh{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.glance .gh .t{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.glance .gh .live{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--win);display:flex;align-items:center;gap:6px}
.glance .gh .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--win);box-shadow:0 0 0 0 rgba(78,208,143,.5);animation:pulse 2s infinite}
.glance .gh .soon{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.04em;color:var(--accent);display:flex;align-items:center;gap:6px;padding:4px 11px;margin-top:0;border-radius:20px}
.glance .gh .soon::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(78,208,143,.45)}70%{box-shadow:0 0 0 7px rgba(78,208,143,0)}100%{box-shadow:0 0 0 0 rgba(78,208,143,0)}}
.gnums{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:16px 0 6px;container-type:inline-size}   /* all four stats on one row; cqi sizes the figures to the card width */
.gnum{min-width:0}
.gnum .l{font-family:"JetBrains Mono",monospace;font-size:clamp(8px,2.5cqi,10px);letter-spacing:.03em;text-transform:uppercase;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gnum .v{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:clamp(13px,5.3cqi,21px);letter-spacing:-.5px;margin-top:4px;font-variant-numeric:tabular-nums;white-space:nowrap}
.spark{display:block;width:100%;height:46px;overflow:visible}
.spark-wrap{position:relative;margin:6px 0 4px}
.sp-zero,.sp-end{position:absolute;font-family:"JetBrains Mono",monospace;font-size:9px;line-height:1;pointer-events:none;white-space:nowrap;font-variant-numeric:tabular-nums}
.sp-zero{left:0;color:var(--faint);transform:translateY(-50%);background:rgba(18,23,32,.72);padding:0 3px 0 0}
.sp-end{right:1px;font-weight:700;transform:translateY(-120%)}
.sp-x{display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--faint);letter-spacing:.03em;margin-top:2px}
/* hero glance spark: no draw-in animation — the line renders fully on first paint (per user) */
/* hero record slider — Pre-World Cup ⟷ World Cup 2026 */
.glance-vp{overflow:hidden}
.glance-track{display:flex;align-items:stretch;transition:transform .5s cubic-bezier(.16,1,.3,1);will-change:transform}
.glance-slide{flex:0 0 100%;min-width:0;display:flex;flex-direction:column}
.glance-dots{display:flex;gap:7px;justify-content:center;margin:14px 0 4px}
.gdot{width:7px;height:7px;padding:0;border:0;border-radius:50%;background:var(--line);cursor:pointer;transition:background .2s,width .2s}
.gdot:hover{background:var(--muted)}
.gdot.on{background:var(--accent);width:20px;border-radius:4px}
.glance .glink{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.glance .glink:hover{text-decoration:underline}
.glance .gnote{font-family:"JetBrains Mono",monospace;font-size:9.5px;color:var(--faint);margin-top:10px;letter-spacing:.02em}

/* full desktop — headline spans the full width across the top; the lede column
   sits on the left with the "record at a glance" card (its original shape) on
   the right. hero-copy's children are promoted into the hero grid so the
   headline can break out to full width while the lede stays beside the card. */
@media(min-width:901px){
  .hero-copy{display:contents}
  .hero-grid{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(330px,400px);
    grid-template-areas:
      "head  glance"
      "lede  glance"
      "cta   glance"
      "trust glance";
    column-gap:56px;row-gap:0;
    align-content:center;align-items:start;
  }
  .hero-grid h1{grid-area:head}
  .hero-grid .lede{grid-area:lede}
  .hero-grid .cta-row{grid-area:cta}
  .hero-grid .trust-strip{grid-area:trust}
  /* glance column fills the section height; the slider + chart grow to fill, the dots sit below the card */
  .hero-grid .glance-col{grid-area:glance;align-self:stretch;display:flex;flex-direction:column}
  .hero-grid .glance-col .glance{flex:1;display:flex;flex-direction:column;min-height:0}
  .hero-grid .glance-vp{flex:1;display:flex;flex-direction:column;min-height:0}
  .hero-grid .glance-track{flex:1;min-height:0}
  .hero-grid .glance .spark-wrap{flex:1;min-height:70px;margin-top:18px;margin-bottom:8px;display:flex;flex-direction:column}
  .hero-grid .glance .spark-wrap .spark{flex:1;min-height:0}
}

/* ════════════════════════════════════════════════════════════════════
   GENERIC SECTION
   ════════════════════════════════════════════════════════════════════ */
.sec{padding:64px 0;border-top:1px solid var(--line-soft);scroll-margin-top:70px;position:relative}
.sec h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(26px,3.6vw,38px);line-height:1.1;letter-spacing:-.5px;max-width:760px}
.sec h2 em{font-style:italic;color:var(--accent)}
.sec .body{margin-top:18px;color:var(--muted);font-size:16.5px;max-width:680px}
.sec .body.tight{max-width:620px}
.pull{margin:30px 0 0;border-left:2px solid var(--accent);padding:6px 0 6px 22px;font-family:"Fraunces",serif;font-style:italic;font-weight:400;font-size:clamp(19px,2.4vw,25px);line-height:1.3;color:var(--ink);max-width:640px}
.ghostlink{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--accent);text-decoration:none}
.ghostlink:hover{text-decoration:underline}

/* faint ghosted "fantasy screenshots" behind the problem section — dissolve on entry */
.ghosts{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ghosts i{
  position:absolute;display:block;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.012);
  opacity:.5;filter:blur(1px);transition:opacity 1.1s var(--ease), transform 1.1s var(--ease)
}
.ghosts i:nth-child(1){width:200px;height:130px;top:8%;right:6%;transform:rotate(6deg)}
.ghosts i:nth-child(2){width:160px;height:110px;top:46%;right:22%;transform:rotate(-5deg)}
.ghosts i:nth-child(3){width:180px;height:120px;top:24%;right:38%;transform:rotate(3deg)}
/* dissolve once the statement (the .reveal that precedes them) lands */
.reveal.in ~ .ghosts i{opacity:0;transform:scale(.96) rotate(0)}

/* ════════════════════════════════════════════════════════════════════
   PROOF — KPIs, equity curve, ledger
   ════════════════════════════════════════════════════════════════════ */
.method{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11px}
.method span{border:1px solid var(--line);border-radius:6px;padding:5px 9px;color:var(--muted);background:rgba(255,255,255,.015);letter-spacing:.02em}
.method span b{color:var(--ink);font-weight:500}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:34px 0 26px}
.kpi{background:linear-gradient(180deg,var(--panel),var(--panel) 60%,var(--panel-2));border:1px solid var(--line);border-radius:13px;padding:18px 18px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .lab{font-size:11px;color:var(--muted);letter-spacing:.13em;text-transform:uppercase;font-family:"JetBrains Mono",monospace}
.kpi .val{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:clamp(24px,3.6vw,33px);letter-spacing:-1px;margin-top:9px;font-variant-numeric:tabular-nums;line-height:1}
.kpi .meta{font-size:11.5px;color:var(--faint);margin-top:8px;font-family:"JetBrains Mono",monospace}
/* `.primary` (not `.hero`) to avoid colliding with the hero-section's `.hero` rule */
.kpi.primary{border-color:rgba(226,182,0,.4)}
.kpi.primary::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 0,rgba(226,182,0,.10),transparent 60%);pointer-events:none}

.equity{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:20px 20px 8px;margin-bottom:26px;box-shadow:var(--shadow)}
.equity .ehead{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;flex-wrap:wrap;gap:8px}
.equity .ehead h3{font-family:"Fraunces",serif;font-weight:500;font-size:16px;letter-spacing:-.2px}
.equity .ehead .note{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint)}
.equity svg{display:block;width:100%;height:170px;overflow:visible}
.eq-plot{position:relative}
.eq-zero,.eq-end{position:absolute;font-family:"JetBrains Mono",monospace;font-size:10.5px;line-height:1;pointer-events:none;white-space:nowrap;font-variant-numeric:tabular-nums}
.eq-zero{left:0;color:var(--faint);transform:translateY(-50%);background:var(--panel);padding:0 4px 0 1px}
.eq-end{right:2px;font-weight:700;transform:translateY(-125%)}
.eq-xaxis{display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:10.5px;color:var(--faint);letter-spacing:.04em;margin-top:6px}
.eq-xaxis span:empty{display:none}

/* proof-section narrative bridge + recent-form block + section sub-heads */
.proof-bridge{margin:24px 0 2px;padding:13px 0 13px 16px;border-left:2px solid var(--accent);max-width:760px;color:var(--ink);font-size:15px;line-height:1.62}
.proof-bridge b{color:var(--accent);font-weight:600}
.sub-head{display:flex;justify-content:space-between;align-items:baseline;gap:6px 16px;flex-wrap:wrap;margin:34px 0 16px}
.sub-head h3{font-family:"Fraunces",serif;font-weight:500;font-size:18px;letter-spacing:-.2px}
.sub-head .note,.form-head .note{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint);letter-spacing:.02em}
/* record tabs — World Cup ⟷ Pre-World Cup, feeding the same KPI box + equity chart + ledger */
.rec-tabs{display:flex;align-items:center;flex-wrap:wrap;gap:0 18px;margin:34px 0 18px;border-bottom:1px solid var(--line-soft)}
.rec-tab{appearance:none;background:transparent;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);font-family:"Fraunces",serif;font-style:italic;font-weight:500;font-size:18px;letter-spacing:-.2px;padding:8px 2px 10px;cursor:pointer;transition:color .15s,border-color .15s}
.rec-tab:hover{color:var(--ink)}
.rec-tab.on{color:var(--accent);border-bottom-color:var(--accent)}
.rec-tabs .note{margin-left:auto;align-self:center;color:var(--faint);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.02em}
@media (max-width:560px){ .rec-tab{font-size:16px} .rec-tabs .note{flex-basis:100%;margin:6px 0 0} }
.form-record{margin:34px 0 6px;border:1px solid var(--line);border-radius:13px;background:linear-gradient(180deg,var(--panel),var(--panel-2));box-shadow:var(--shadow);overflow:hidden}
.form-head{display:flex;justify-content:space-between;align-items:baseline;gap:6px 16px;flex-wrap:wrap;padding:18px 20px 0}
.form-head h3{font-family:"Fraunces",serif;font-weight:500;font-size:18px;letter-spacing:-.2px}
.form-kpis{display:flex;flex-wrap:wrap;gap:14px 30px;padding:8px 20px 17px}
.form-kpis .fk{display:flex;flex-direction:column;gap:5px}
.form-kpis .fk-val{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:21px;letter-spacing:-.5px;font-variant-numeric:tabular-nums;line-height:1}
.form-kpis .fk-val.pos{color:var(--win)} .form-kpis .fk-val.neg{color:var(--loss)} .form-kpis .fk-val.neu{color:var(--ink)}
.form-kpis .fk-lab{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.form-weeks{border-top:1px solid var(--line-soft);padding:4px 0 12px}
/* upcoming (pending) picks — always shown, above the collapsible settled list */
.form-upcoming{border-top:1px solid var(--line-soft);padding:0 20px;background:rgba(226,182,0,.035)}
.form-upcoming:empty{display:none}
.form-up-lab{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);padding:13px 0 2px}
.form-upcoming .form-row{border-top:1px solid var(--line-soft)}
.form-up-lab + .form-row{border-top:0}
.fr-cd{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:10.5px;font-weight:600;letter-spacing:.04em;padding:4px 10px;border-radius:20px;white-space:nowrap;color:var(--accent);background:var(--accent-dim);box-shadow:inset 0 0 0 1px rgba(226,182,0,.35)}
.fr-cd.live{color:var(--accent);background:var(--accent-dim);box-shadow:inset 0 0 0 1px rgba(226,182,0,.4)}
.fr-cd.ended{color:var(--muted);background:rgba(255,255,255,.04);box-shadow:inset 0 0 0 1px var(--line)}
.form-row{display:flex;flex-direction:column;gap:7px;padding:12px 0;border-top:1px solid var(--line-soft)}
.form-weeks > .form-row:first-child{border-top:0}
/* zebra-striped ledger: the horizontal inset lives on the row so the shading bleeds edge-to-edge */
.form-weeks > .form-row{padding-left:20px;padding-right:20px}
.form-weeks > .form-row:nth-child(odd){background:var(--panel-2)}
.form-row .fr-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.form-row .fr-date{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;flex:none}
.form-row .fr-mid{min-width:0;display:flex;flex-direction:column;gap:3px}
.form-row .fr-match{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;flex-wrap:wrap}
.fr-score{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600;color:var(--ink);background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:6px;padding:1px 7px;letter-spacing:.04em;white-space:nowrap;vertical-align:middle}
.pk-titlerow .fr-score{margin-left:2px}
/* live match: green score chip + the LIVE pill pulse together while in play */
.fr-score.fr-score-live{color:var(--accent);background:var(--accent-dim);border-color:rgba(226,182,0,.4)}
.fr-cd.live,.fr-score.fr-score-live{animation:livePulse 1.6s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1;filter:drop-shadow(0 0 0 rgba(226,182,0,0))}50%{opacity:.66;filter:drop-shadow(0 0 5px rgba(226,182,0,.55))}}
/* in-play pick card: the running score sits beside the LIVE pill, matched to its height */
.pick-card .pk-titlerow .pk-live-wrap{display:flex;align-items:stretch;gap:8px}
.pick-card .pk-titlerow .pk-live-wrap .fr-score{display:inline-flex;align-items:center;border-radius:8px}
.form-row .fr-league{font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.form-row .fr-pick{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--muted)}
.form-row .fr-pick-lab{color:var(--accent);font-weight:700}
.form-row .fr-pick.fr-soon{font-size:13.5px;color:#ff8c42;font-weight:700;letter-spacing:.01em}   /* locked/"Coming soon" status — bigger, orange */
.form-row .fr-pick.fr-soon .fr-lock{width:13px;height:13px;vertical-align:-2px}
.form-row .fr-res{flex:none;display:flex;flex-direction:row;align-items:center;gap:8px;text-align:right}
.form-row .fr-pl,.pk-scorecard .fr-pl{font-family:"JetBrains Mono",monospace;font-size:13.5px;font-weight:700;font-variant-numeric:tabular-nums;text-align:right;flex:none;line-height:1.1}
.form-weeks.is-collapsed > .form-row:nth-child(n+4){display:none}   /* show 3 by default; #formMore toggles */
.form-more{display:block;width:100%;padding:13px 20px;background:rgba(255,255,255,.015);border:0;border-top:1px solid var(--line-soft);color:var(--accent);font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.06em;cursor:pointer;transition:background .15s}
.form-more:hover{background:rgba(226,182,0,.06)}
/* recommended-bookmaker advert (HKJC) — sponsored-style strip, no outbound link */
.bet-advert{display:flex;align-items:center;justify-content:center;gap:9px 12px;flex-wrap:wrap;margin:26px 0;padding:12px 18px;border:1px solid rgba(226,182,0,.35);border-radius:11px;background:rgba(226,182,0,.06);text-align:center}
.bet-advert .ad-tag{font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(226,182,0,.4);border-radius:5px;padding:2px 7px;flex:none}
.bet-advert .ad-txt{font-size:13.5px;color:var(--muted)}
.bet-advert .ad-txt b{color:var(--accent);font-weight:600}
@media(max-width:520px){
  .form-kpis{gap:12px 22px}
  .form-row .fr-pick{white-space:normal}
}

.controls{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.segs{display:inline-flex;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:3px}
.segs button{appearance:none;border:0;background:transparent;color:var(--muted);cursor:pointer;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.02em;padding:7px 13px;border-radius:7px;transition:.15s}
.segs button:hover{color:var(--ink)}
.segs button.on{background:var(--accent-dim);color:var(--accent);box-shadow:inset 0 0 0 1px rgba(226,182,0,.3)}
.leaguefilter{display:flex;align-items:center;gap:8px}
.leaguefilter label{font-size:11px;color:var(--faint);font-family:"JetBrains Mono",monospace;letter-spacing:.06em;text-transform:uppercase}
select{
  appearance:none;background:var(--panel) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238a94a4' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 11px center;
  border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:8px 30px 8px 12px;font-family:"JetBrains Mono",monospace;font-size:12px;cursor:pointer;
}
select:focus{outline:none;border-color:var(--accent)}

.guarantee{display:none;align-items:center;gap:14px;flex-wrap:wrap;background:var(--win-dim);border:1px solid rgba(78,208,143,.3);border-radius:11px;padding:13px 16px;margin-bottom:14px;font-size:13.5px}
.guarantee.show{display:flex}
.guarantee .g-val{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:18px}
.guarantee .g-txt{color:#cdeede}
.guarantee .g-txt b{color:#fff;font-weight:600}

.ledger{background:var(--panel);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow);overflow:hidden}
.tablescroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:560px}
thead th{text-align:left;font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:500;padding:14px 16px;background:var(--panel-2);border-bottom:1px solid var(--line);position:sticky;top:0;white-space:nowrap}
th.num,td.num{text-align:right}
tbody td{padding:14px 16px;border-bottom:1px solid var(--line-soft);font-size:13.5px;vertical-align:middle;white-space:nowrap}
tbody tr:last-child td{border-bottom:0}
tbody tr{transition:background .12s}
tbody tr:hover{background:rgba(255,255,255,.022)}
tbody tr.pending{background:rgba(226,182,0,.035)}
tbody tr.pending:hover{background:rgba(226,182,0,.06)}
.match{font-weight:500;color:var(--ink)}
.league{font-size:11px;color:var(--muted);font-family:"JetBrains Mono",monospace;letter-spacing:.02em}
.match .league{display:block;font-weight:400;margin-top:3px}   /* league as a sub-label under the match name */
.pick{color:var(--muted)}
.pick.locked{color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.pick.passed{color:var(--push);font-style:italic}
.lockicon{width:11px;height:11px;flex:none;opacity:.9}
.posted{display:block;font-size:11px;color:var(--faint);font-family:"JetBrains Mono",monospace;margin-top:3px}   /* posted time as a sub-label under the pick */
.posted .tick{color:var(--win);margin-right:4px}
.pl-pos{color:var(--win);font-weight:600} .pl-neg{color:var(--loss);font-weight:600} .pl-zero{color:var(--push)}
.bal{color:var(--muted);font-weight:500}
.emptyrow td{text-align:center;color:var(--faint);padding:34px 16px;font-family:"JetBrains Mono",monospace;font-size:13px}

/* pills (shared) */
.pill{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:10.5px;font-weight:600;letter-spacing:.06em;padding:4px 9px;border-radius:20px;text-transform:uppercase;white-space:nowrap}
/* "1st half" chip on half-time picks */
.pk-ht-tag{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(226,182,0,.4);border-radius:5px;padding:1px 5px;vertical-align:middle;white-space:nowrap}
.fr-pick .pk-ht-tag{margin-left:6px}
.pk-scorecard .pk-sc-pickwrap .pk-ht-tag{margin-top:3px}
.pill.won{color:var(--win);background:var(--win-dim);box-shadow:inset 0 0 0 1px rgba(78,208,143,.3)}
.pill.lost{color:var(--loss);background:var(--loss-dim);box-shadow:inset 0 0 0 1px rgba(240,113,106,.3)}
.pill.push{color:var(--push);background:var(--push-dim);box-shadow:inset 0 0 0 1px rgba(154,163,178,.3)}
.pill.locked{color:var(--accent);background:var(--accent-dim);box-shadow:inset 0 0 0 1px rgba(226,182,0,.35)}

.record-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:18px}
.recordcta{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--accent);text-decoration:none}
.recordcta:hover{text-decoration:underline}
/* folded record teaser */
.ledger.record-collapsed .controls{display:none}
.ledger.record-collapsed .guarantee{display:none}
.ledger.record-collapsed #tablescroll{max-height:312px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;-webkit-mask-image:linear-gradient(#000 70%,transparent);mask-image:linear-gradient(#000 70%,transparent)}

/* ════════════════════════════════════════════════════════════════════
   STEPS / CARDS
   ════════════════════════════════════════════════════════════════════ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:34px}
.step{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:22px;box-shadow:var(--shadow)}
.step .sn{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:13px;color:var(--accent);border:1px solid rgba(226,182,0,.4);width:30px;height:30px;border-radius:8px;display:grid;place-items:center}

.step h3{font-family:"Fraunces",serif;font-weight:500;font-size:18px;margin:16px 0 7px;letter-spacing:-.2px}
.step p{color:var(--muted);font-size:14px}

/* .steps.trio — stays 3-up on EVERY viewport, all content visible (no flip) */
.steps.trio .step{display:flex;flex-direction:column;transition:border-color .18s,transform .18s}
.steps.trio .step:hover{border-color:rgba(226,182,0,.45);transform:translateY(-2px)}

@media(max-width:640px){
  .steps.trio{gap:9px}
  .steps.trio .step{padding:14px;border-radius:11px}
  .steps.trio .step .sn{width:26px;height:26px;font-size:12px}

  .steps.trio .step h3{font-size:14px;margin:11px 0 6px;letter-spacing:-.3px}
  .steps.trio .step p{font-size:11.5px;line-height:1.45}
}
@media(max-width:400px){
  .steps.trio .step h3{font-size:12.5px;margin:9px 0 5px}
  .steps.trio .step p{font-size:10.5px;line-height:1.4}
}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:30px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:22px;box-shadow:var(--shadow)}
.card .sn{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:13px;color:var(--accent);border:1px solid rgba(226,182,0,.4);width:30px;height:30px;border-radius:8px;display:grid;place-items:center}
.card h3{font-family:"Fraunces",serif;font-weight:500;font-size:18px;margin:14px 0 7px;letter-spacing:-.2px}
.card p{color:var(--muted);font-size:14px}

/* locked upcoming tip card — faint glow, pulsing lock, hover shimmer (never reveals) */
.locked-card{position:relative;margin-top:18px;background:rgba(226,182,0,.04);border:1px solid rgba(226,182,0,.28);border-radius:13px;padding:18px 20px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;overflow:hidden}
.locked-card .lk{display:flex;align-items:center;gap:11px}
.locked-card .lk .lockicon{width:16px;height:16px;color:var(--accent);animation:lockPulse 2.6s ease-in-out infinite}
@keyframes lockPulse{0%,100%{opacity:.6;filter:drop-shadow(0 0 0 rgba(226,182,0,0))}50%{opacity:1;filter:drop-shadow(0 0 6px rgba(226,182,0,.7))}}
.locked-card .meta{flex:1;min-width:200px}
.locked-card .lg{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);letter-spacing:.04em}
.locked-card .lm{font-weight:500;font-size:15.5px;margin-top:3px}
.locked-card::before{
  content:"";position:absolute;top:0;bottom:0;width:40%;left:-50%;pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(226,182,0,.10), transparent);transform:skewX(-18deg)
}
.locked-card:hover::before{animation:shimmer 1.1s var(--ease) 1 forwards}
@keyframes shimmer{from{left:-50%}to{left:120%}}

/* ════════════════════════════════════════════════════════════════════
   PRICING + GUARANTEE
   ════════════════════════════════════════════════════════════════════ */
.price-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:34px;align-items:start}
.price-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid rgba(226,182,0,.4);border-radius:16px;padding:26px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.price-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 88% 0,rgba(226,182,0,.10),transparent 55%);pointer-events:none}
.price-card .pname{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.price-card .amt{font-family:"Fraunces",serif;font-weight:500;font-size:48px;letter-spacing:-1px;margin:12px 0 2px;line-height:1}
.price-card .amt span{font-family:"JetBrains Mono",monospace;font-size:15px;color:var(--muted);font-weight:400;letter-spacing:0}
.feat{list-style:none;margin:20px 0 24px;display:flex;flex-direction:column;gap:11px}
.feat li{position:relative;padding-left:26px;font-size:14.5px;color:var(--ink)}
.feat li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--win);font-weight:700}   /* U+2713 check via CSS escape (encoding-proof; a literal glyph here mis-decoded to mojibake when the CSS was read as latin-1) */
.price-card .btn{width:100%;text-align:center;position:relative;z-index:1}
/* the CTA is the conversion target — it keeps a soft persistent glow */
.price-card .btn{box-shadow:0 8px 24px -10px rgba(226,182,0,.7), 0 0 0 0 rgba(226,182,0,.5);animation:ctaGlow 3.4s ease-in-out infinite}
@keyframes ctaGlow{0%,100%{box-shadow:0 8px 24px -10px rgba(226,182,0,.6), 0 0 22px -6px rgba(226,182,0,.3)}50%{box-shadow:0 8px 26px -8px rgba(226,182,0,.8), 0 0 34px -4px rgba(226,182,0,.5)}}
.price-card .cancel{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint);text-align:center;margin-top:13px}

.guarantee-card{position:relative;overflow:hidden;background:var(--win-dim);border:1px solid rgba(78,208,143,.32);border-radius:16px;padding:26px}
.guarantee-card .gt{font-family:"Fraunces",serif;font-weight:500;font-size:20px;letter-spacing:-.2px;color:#d7f3e6}
.guarantee-card p{color:#bfe8d4;font-size:14.5px;margin-top:12px}
.guarantee-card p b{color:#fff;font-weight:600}
/* a single slow sweep of green light on entry — a "seal" */
.guarantee-card::before{
  content:"";position:absolute;top:0;bottom:0;left:-60%;width:55%;pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(78,208,143,.18), transparent);transform:skewX(-16deg);opacity:0
}
.in .guarantee-card::before{animation:sealSweep 1.6s var(--ease) .2s 1 forwards}
@keyframes sealSweep{0%{left:-60%;opacity:0}15%{opacity:1}100%{left:130%;opacity:0}}
.soon{margin-top:18px;border:1px dashed var(--line);border-radius:12px;padding:16px 18px;font-size:13.5px;color:var(--muted)}
.soon b{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:6px;color:var(--accent)}

/* ════════════════════════════════════════════════════════════════════
   ANONYMITY — the "absent identity" mark
   ════════════════════════════════════════════════════════════════════ */
.anon-grid{display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:start;margin-bottom:8px}
.identity-void{width:120px;height:120px;flex:none}
.identity-void rect{
  fill:none;stroke:var(--accent);stroke-width:1.5;
  stroke-dasharray:var(--len,520);stroke-dashoffset:var(--len,520);
  filter:drop-shadow(0 0 10px rgba(226,182,0,.45))
}
.in .identity-void rect{transition:stroke-dashoffset 1.6s var(--ease) .15s;stroke-dashoffset:0}
.identity-void .q{fill:var(--accent);opacity:0;transition:opacity .6s var(--ease) 1.5s}
.in .identity-void .q{opacity:.5}
/* the framed-but-unresolved figure — draws in after the frame, stays an outline (never fills) */
.identity-void .figure>*{
  fill:none;stroke:var(--accent);stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round;
  opacity:.5;stroke-dasharray:1;stroke-dashoffset:1;
  filter:drop-shadow(0 0 6px rgba(226,182,0,.28))
}
.in .identity-void .figure>*{transition:stroke-dashoffset 1.4s var(--ease) .55s;stroke-dashoffset:0}

/* ════════════════════════════════════════════════════════════════════
   FAQ
   ════════════════════════════════════════════════════════════════════ */
.faqgroup{margin-top:30px}
.faq-cat{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:26px 0 10px}
.faq-cat:first-child{margin-top:0}
details.faq{border:1px solid var(--line);border-radius:11px;background:var(--panel);margin-bottom:9px;overflow:hidden;transition:border-color .15s}
details.faq[open]{border-color:rgba(226,182,0,.4)}
details.faq summary{list-style:none;cursor:pointer;padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:500;font-size:15.5px}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary .ic{font-family:"JetBrains Mono",monospace;color:var(--accent);font-size:18px;flex:none;transition:transform .2s;line-height:1}
details.faq[open] summary .ic{transform:rotate(45deg)}
details.faq .ans{padding:0 18px 18px;color:var(--muted);font-size:14.5px;max-width:680px}
/* smooth expand */
details.faq .ans{overflow:hidden}
details.faq[open] .ans{animation:faqOpen .4s var(--ease)}
@keyframes faqOpen{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ════════════════════════════════════════════════════════════════════
   PROSE (articles & legal)
   ════════════════════════════════════════════════════════════════════ */
.prose{max-width:720px}
.prose p{color:#c4ccd8;font-size:16.5px;margin:0 0 18px;line-height:1.7}
.prose h2{font-family:"Fraunces",serif;font-weight:500;font-size:26px;letter-spacing:-.3px;margin:40px 0 14px;color:var(--ink)}
.prose h3{font-family:"Fraunces",serif;font-weight:500;font-size:20px;margin:28px 0 10px;color:var(--ink)}
.prose ul,.prose ol{margin:0 0 18px;padding-left:22px;color:#c4ccd8;font-size:16.5px;line-height:1.7}
.prose li{margin-bottom:9px}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.prose blockquote{border-left:2px solid var(--accent);margin:24px 0;padding:4px 0 4px 20px;font-family:"Fraunces",serif;font-style:italic;font-size:20px;color:var(--ink);line-height:1.4}
.prose .lead{font-size:19px;color:var(--ink);line-height:1.6}
.legal-meta{font-family:"JetBrains Mono",monospace;font-size:11.5px;color:var(--faint);margin-bottom:30px;letter-spacing:.03em}

/* page hero (interior) */
.phero{padding:64px 0 26px;border-bottom:1px solid var(--line-soft)}
.phero h1{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(30px,4.6vw,50px);line-height:1.05;letter-spacing:-.6px;max-width:860px}
.phero h1 em{font-style:italic;color:var(--accent)}
.phero .lede{margin-top:18px;color:var(--muted);font-size:clamp(15.5px,1.7vw,18px);max-width:620px}
.crumbs{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint);margin-bottom:20px;letter-spacing:.04em}
.back-link{display:inline-block;margin:-6px 0 18px;font-family:"JetBrains Mono",monospace;font-size:12.5px;letter-spacing:.03em;color:var(--accent);text-decoration:none}
.back-link:hover{text-decoration:underline;text-underline-offset:3px}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--accent)}

/* callout box */
.callout{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:20px 22px;margin:26px 0;box-shadow:var(--shadow)}
.callout.accent{background:var(--accent-dim);border-color:rgba(226,182,0,.32)}
.callout.win{background:var(--win-dim);border-color:rgba(78,208,143,.3)}
.callout .ct{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);margin-bottom:9px}
.callout p{margin:0;font-size:14.5px;color:#cdd5e0}
.callout p b{color:#fff}

/* article cards (insights hub) */
.posts{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:8px}
.post{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:var(--shadow);text-decoration:none;transition:border-color .16s var(--ease), transform .16s var(--ease);min-height:200px}
.post:hover{border-color:rgba(226,182,0,.45)}   /* lift handled by Motion; border is the no-Motion fallback */
.post .tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.post h3{font-family:"Fraunces",serif;font-weight:500;font-size:21px;line-height:1.2;letter-spacing:-.3px;color:var(--ink)}
.post p{color:var(--muted);font-size:14px;margin-top:10px;flex:1}
.post .meta{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint);margin-top:16px}
.post.featured{grid-column:1 / -1;border-color:rgba(226,182,0,.35)}
.post.featured h3{font-size:27px}
.list-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px 20px;flex-wrap:wrap;margin-bottom:18px}
.list-head .eyebrow{margin-bottom:0}
.list-count{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.post.upcoming{opacity:.55;pointer-events:none}      /* not yet published — inert, visually dimmed */
.post.upcoming .tag{color:var(--faint)}
.post.upcoming .meta{color:var(--accent)}

/* responsible-gambling resource cards */
.rg-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:8px 0}
.rg-card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:22px;box-shadow:var(--shadow)}
.rg-card .region{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.rg-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:19px;letter-spacing:-.2px}
.rg-card .num{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:22px;color:var(--accent);margin:10px 0 4px;letter-spacing:-.5px}
.rg-card p{color:var(--muted);font-size:13.5px;margin-top:8px}
.rg-card a{color:var(--accent);text-decoration:none;font-family:"JetBrains Mono",monospace;font-size:12.5px}

/* ════════════════════════════════════════════════════════════════════
   FINAL CTA — echo of the hero void, one card ignites
   ════════════════════════════════════════════════════════════════════ */
.final{position:relative;overflow:hidden;padding:96px 0 84px;text-align:center;border-top:1px solid var(--line-soft);margin-top:48px}
.final h2{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(28px,4vw,44px);letter-spacing:-.6px;line-height:1.08;max-width:760px;margin:0 auto}
.final p{color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:13.5px;margin:18px auto 0;letter-spacing:.02em}
.final .btn{margin-top:28px;font-size:15px;padding:16px 28px}
.final.in .btn{animation:ctaPulseOnce 1.4s var(--ease) .6s 1}
@keyframes ctaPulseOnce{0%{box-shadow:0 8px 24px -10px rgba(226,182,0,.7)}40%{box-shadow:0 8px 24px -10px rgba(226,182,0,.7), var(--bloom-accent)}100%{box-shadow:0 8px 24px -10px rgba(226,182,0,.7)}}
.final .wrap{position:relative;z-index:1}

/* ════════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════════ */
footer{background:#000;border-top:1px solid var(--line-soft);padding:52px 0 40px;margin-top:48px}
.foot-top{display:grid;grid-template-columns:1.35fr 1fr;gap:40px;align-items:start}
.foot-brand .brand{margin-bottom:15px}
.foot-tag{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:20px}
.foot-rg-title{font-family:"Fraunces",serif;font-weight:500;font-size:21px;letter-spacing:-.3px;color:var(--ink);margin-bottom:12px}
.foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.foot-col{display:flex;flex-direction:column;gap:12px}
.foot-h{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:2px}
.foot-col a{font-size:14px;color:var(--muted);text-decoration:none;width:fit-content;transition:color .15s}
.foot-col a:hover{color:var(--ink)}
.foot-disc{color:var(--faint);font-size:11.5px;max-width:640px;line-height:1.6;margin-top:40px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:24px;padding-top:22px;border-top:1px solid var(--line-soft)}
.foot-legal{display:flex;gap:22px;flex-wrap:wrap}
.foot-legal a{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);text-decoration:none}
.foot-legal a:hover{color:var(--ink)}
.copy{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint)}
@media(max-width:700px){
  .foot-top{grid-template-columns:1fr;gap:32px}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:12px}
}

/* ════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════ */
@media(max-width:900px){
  .hero-grid{gap:32px}
  .price-wrap{grid-template-columns:1fr}
  .steps:not(.trio){grid-template-columns:1fr}   /* ordinary steps stack on mobile; .steps.trio stays 3-up */
  .anon-grid{grid-template-columns:1fr;gap:20px}
  .grid3,.grid2,.posts,.rg-cards{grid-template-columns:1fr}
  .post.featured{grid-column:auto}
  .kpis{grid-template-columns:repeat(2,1fr)}   /* 4 KPI tiles get too cramped below ~900px */
  /* mobile menu — full-width sheet with app-style rows */
  .navtoggle{display:flex}
  .nav-inner .brand{margin-right:auto}   /* hamburger (first) + brand pack left; CTA stays right */
  .navlinks{
    position:absolute;top:calc(100% + 1px);left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:1px;
    background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-top:0;
    padding:12px 14px 16px;box-shadow:0 32px 64px -26px rgba(0,0,0,.92);animation:menuDrop .22s var(--ease);
  }
  .navlinks.open{display:flex}
  .navlinks a{
    display:flex;align-items:center;justify-content:flex-start;gap:12px;
    padding:13px 14px;border-radius:11px;text-align:left;
    font-family:"JetBrains Mono",monospace;font-size:14px;letter-spacing:.01em;color:var(--ink);
    transition:background .14s,color .14s;
  }
  .navlinks a:hover,.navlinks a:focus-visible{background:rgba(255,255,255,.05)}
  .navlinks a.on{color:var(--accent);background:rgba(226,182,0,.09)}
  .navlinks a .ext{margin-left:auto;color:var(--accent);font-size:13px}
  .navnum{display:inline-block;min-width:22px;color:var(--faint);font-size:12px;font-variant-numeric:tabular-nums}
  .navlinks a.on .navnum{color:var(--accent)}
  .navdiv{display:block;width:auto;height:1px;background:var(--line-soft);margin:9px 12px}
  /* footer row of the mobile menu: Insights · How we pick · …language (last column) */
  .menu-foot{display:flex;align-items:center;flex-wrap:wrap;gap:6px 16px;padding:12px 14px 2px}
  .menu-foot .navdest{display:inline-flex;align-items:center;gap:6px;padding:6px 0;font-size:13.5px;background:transparent;border-radius:0;flex:none}
  .menu-foot .navdest:hover,.menu-foot .navdest:focus-visible{background:transparent;color:var(--accent)}
  .menu-foot .navdest .ext{margin-left:0}
  /* burger menu: Insights is just a link to the listing page — the article sub-list is desktop-hover only */
  .menu-foot{flex-direction:column;align-items:stretch;gap:2px}
  .menu-foot .navdrop{display:block;width:100%}
  .menu-foot .navdrop .navdest{display:flex;width:100%;padding:13px 14px;font-size:14px;border-radius:11px}
  .menu-foot .navdrop .navdest .ext{display:none}
  .navdrop::after{display:none}
  .navdrop-menu,
  .navdrop:hover .navdrop-menu,
  .navdrop:focus-within .navdrop-menu{display:none}        /* no inline article listing in the burger menu */
}
@media(max-width:680px){
  .wrap{padding:0 16px}
  .hero{padding:72px 0 48px;min-height:auto}
}

/* ════════════════════════════════════════════════════════════════════
   REDUCED MOTION — show final states, no choreography
   ════════════════════════════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .grain{animation:none}
  .hero-sweep{display:none}
  .hero-copy .line,.hero-copy .lede,.hero-copy .cta-row,.hero-copy .trust-strip{opacity:1!important;animation:none!important;letter-spacing:-.8px}
  .js .reveal,.js .stagger>*{opacity:1!important;transform:none!important;transition:none!important}
  .locked-card .lk .lockicon{animation:none}
  .price-card .btn{animation:none}
  .in .guarantee-card::before,.locked-card:hover::before{animation:none}
  .in .identity-void rect{transition:none;stroke-dashoffset:0}
  .in .identity-void .q{transition:none;opacity:.5}
  .in .identity-void .figure>*{transition:none;stroke-dashoffset:0}
  .final.in .btn{animation:none}
  details.faq[open] .ans{animation:none}
  .glance .gh .live::before{animation:none}
  .fr-cd.live,.fr-score.fr-score-live{animation:none}
}

/* ════════════════════════════════════════════════════════════════════
   DESIGN ENHANCEMENTS — loader · route transitions · depth · focus
   (Motion owns transforms on interactive elements; CSS keeps
    non-transform feedback as the no-Motion fallback.)
   ════════════════════════════════════════════════════════════════════ */

/* cinematic loader — the "one lit cell among dim" motif, JS-dismissed */
#loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:grid;place-items:center;opacity:1;transition:opacity .55s var(--ease)}
#loader.out{opacity:0}
#loader.done{display:none}
#loader .lcells{display:flex;gap:9px}
#loader i{display:block;width:15px;height:22px;border-radius:5px;background:var(--panel-2);border:1px solid var(--line);opacity:0;transform:translateY(8px);animation:loaderRise .45s var(--ease) forwards}
#loader i:nth-child(1){animation-delay:.02s}
#loader i:nth-child(2){animation-delay:.06s}
#loader i:nth-child(3){animation-delay:.10s}
#loader i:nth-child(4){animation-delay:.14s}
#loader i:nth-child(6){animation-delay:.22s}
#loader i:nth-child(7){animation-delay:.26s}
#loader i:nth-child(8){animation-delay:.30s}
#loader i:nth-child(9){animation-delay:.34s}
#loader i.lit{background:linear-gradient(150deg,var(--accent),#b88e00);border-color:transparent;animation:litCell .95s var(--ease) .12s forwards}
@keyframes loaderRise{from{opacity:0;transform:translateY(8px)}to{opacity:.5;transform:none}}
@keyframes litCell{0%{opacity:0;transform:translateY(8px);box-shadow:none}45%{opacity:.55;transform:none;box-shadow:none}100%{opacity:1;box-shadow:var(--bloom-accent)}}

/* smooth SPA route transitions */
.js .page.active{animation:pageEnter .55s var(--ease)}
@keyframes pageEnter{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* keyboard focus — accessible + on-brand */
a:focus-visible,button:focus-visible,summary:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:8px}
:focus:not(:focus-visible){outline:none}

/* a little more depth: a hairline top highlight on raised surfaces */
.kpi,.step,.card,.price-card,.rg-card,.post,.glance,.locked-card,.equity,.ledger{box-shadow:inset 0 1px 0 rgba(255,255,255,.04),var(--shadow)}
.post{cursor:pointer}
.btn,.post,.price-card{will-change:transform}

/* closing CTA — a soft pool of light behind the last line */
.final::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(58% 75% at 50% 42%,rgba(226,182,0,.05),transparent 72%)}

@media(prefers-reduced-motion:reduce){
  #loader{display:none}
  .js .page.active{animation:none}
  #loader i,#loader i.lit{animation:none}
}

/* ── limited-time offer bar ── */
.promobar{position:relative;z-index:40;overflow:hidden;background:linear-gradient(90deg,var(--accent-dim),rgba(39,52,139,.16));border-bottom:1px solid rgba(226,182,0,.22)}
.promobar::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(100deg,transparent 35%,rgba(226,182,0,.13) 50%,transparent 65%);transform:translateX(-100%);animation:pbSweep 6.5s ease-in-out infinite}
@keyframes pbSweep{0%{transform:translateX(-100%)}55%,100%{transform:translateX(100%)}}
@media(prefers-reduced-motion:reduce){.promobar::after{display:none}}
.promobar-row{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:7px 24px;display:flex;align-items:center;gap:16px}
.promobar-inner{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:11px;text-decoration:none;font-family:"JetBrains Mono",monospace;font-size:12.5px;color:var(--muted);flex-wrap:nowrap;text-align:right;min-width:0;overflow:hidden}
.promobar .pb-text{white-space:nowrap}
.promobar .pb-dot{width:7px;height:7px;border-radius:50%;background:var(--win);box-shadow:0 0 0 0 rgba(78,208,143,.5);animation:pulse 2s infinite;flex:none}
.promobar .pb-text b{color:var(--ink);font-weight:600}
.promobar .pb-free{color:var(--loss);font-weight:700;letter-spacing:.02em}
@media(max-width:680px){.promobar-row{padding:7px 14px;gap:10px}.promobar-inner{font-size:11px;gap:8px}}

/* ── pricing: free-offer treatment ── */
.price-badge{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#06121c;background:linear-gradient(150deg,var(--accent),#b88e00);padding:5px 11px;border-radius:20px;margin-bottom:14px;position:relative;z-index:1}
.amt-offer{font-family:"Fraunces",serif;font-weight:500;font-size:46px;letter-spacing:-1px;line-height:1;margin:2px 0 6px}
.amt-offer span{display:block;font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);font-weight:400;letter-spacing:.02em;margin-top:9px;text-transform:none}
.amt-then{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--faint)}
.amt-then b{color:var(--ink);font-weight:600}

/* ticker: activates only when text can't fit (narrow phones) */
@keyframes pbTick{
  from{transform:translateX(100%)}
  to  {transform:translateX(-110%)}
}
@media(max-width:520px){
  .promobar-inner{flex:1;justify-content:flex-start}
  .promobar .pb-text{display:inline-block;animation:pbTick 12s linear infinite}
}
@media(prefers-reduced-motion:reduce){.promobar .pb-dot{animation:none}.promobar .pb-text{animation:none !important}}

/* ════════════════════════════════════════════════════════════════════
   FREE SIGN-UP + MEMBERS AREA
   ════════════════════════════════════════════════════════════════════ */
[hidden]{display:none !important}

/* members "Picks" page */
.member-gate .gate-inner{text-align:center}
.gate-lock{width:42px;height:42px;color:var(--accent);margin:0 auto 18px;display:block;filter:drop-shadow(0 0 14px rgba(226,182,0,.4))}
.member-gate h2{margin-left:auto;margin-right:auto}
.member-gate .body{margin-left:auto;margin-right:auto}
.member-gate .btn{margin-top:26px}
.picks-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:30px}
@media(min-width:1024px){.picks-grid{grid-template-columns:repeat(2,1fr)}}   /* 2 columns on desktop only */
.pick-card{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid rgba(226,182,0,.32);border-radius:14px;padding:22px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),var(--shadow);container-type:inline-size}
.pick-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 0,rgba(226,182,0,.10),transparent 55%);pointer-events:none}
.pick-card .pk-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap}
.pick-card .pk-stage{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.pick-card .pk-time{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint)}
.pick-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:19px;letter-spacing:-.2px;margin:8px 0 14px}
.pick-card .pk-label{display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:"JetBrains Mono",monospace;font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 7px}
/* admin-only: a pick scheduled to reveal later — sits on the "Our pick / Our call" row, right-aligned */
.pick-card .pk-sched{display:inline-flex;align-items:center;gap:6px;flex:none;font-family:"JetBrains Mono",monospace;font-weight:500;font-size:11px;letter-spacing:.02em;text-transform:none;color:var(--accent);background:rgba(226,182,0,.1);border:1px solid rgba(226,182,0,.32);border-radius:8px;padding:4px 9px;margin:0}
.pick-card .pk-sel{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--accent-dim);border:1px solid rgba(226,182,0,.3);border-radius:10px;padding:11px 14px}
.pick-card .pk-pick{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:15px;color:var(--accent)}
.pick-card .pk-meta{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);margin-left:auto}
.pick-card .pk-titlerow{display:flex;justify-content:space-between;align-items:flex-start;gap:8px 14px;margin:8px 0 14px}
.pick-card .pk-titlerow h3{margin:0;line-height:1.16}
.pick-card .pk-titlerow h3 .pk-team{display:block}              /* always stack: Home / vs / Away */
.pick-card .pk-titlerow h3 .pk-vs{display:block;margin:2px 0}   /* small "vs" on the middle line */
.pick-card .pk-side{color:inherit}
.flagi{height:.82em;width:auto;border-radius:2px;vertical-align:-.04em;margin-right:.42em;box-shadow:0 0 0 1px rgba(255,255,255,.1);background:rgba(255,255,255,.05)}
.flagi.flagi-logo{height:1.05em;border-radius:0;box-shadow:none;background:none}   /* team crest: a touch larger, no flag chrome */
.pk-team{white-space:nowrap}
.match .flagi{margin-right:.34em}
.pick-card .pk-vs{color:var(--faint);font-weight:400;font-size:.72em;font-family:"JetBrains Mono",monospace}

/* ── broadcast-style live scorecard (member posted-pick card) ── */
.pick-card.pk-scorecard{padding:0;border-color:var(--line)}
.pick-card.pk-scorecard::after{content:none}
.pk-scorecard .pk-pitch{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,14,26,.62) 0%, rgba(7,14,26,.12) 22%, transparent 42%, transparent 74%, rgba(7,14,26,.34) 100%),
    radial-gradient(60% 85% at 50% -28%, rgba(210,230,255,.22), transparent 55%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 1px, transparent 1px 55px),
    repeating-linear-gradient(90deg, rgba(0,0,0,.06) 0 55px, rgba(255,255,255,.028) 55px 110px),
    linear-gradient(180deg, #1c6e40 0%, #155a33 52%, #114829 100%)}
.pk-scorecard .pk-pitch::before{content:"";position:absolute;left:50%;top:15%;bottom:17%;width:1px;background:rgba(255,255,255,.07);transform:translateX(-50%)}   /* faint halfway line */
.pk-scorecard>:not(.pk-pitch){position:relative;z-index:1}
.pk-scorecard.is-settled .pk-pitch{filter:saturate(.5) brightness(.82)}
.pk-scorecard .pk-sc-top{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:13px 16px 0}
.pk-scorecard .pk-sc-top .pk-stage{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.pk-clock{font-family:"JetBrains Mono",monospace;font-size:11.5px;font-weight:700;letter-spacing:.04em;padding:4px 10px;border-radius:20px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;flex:none}
.pk-clock-live{color:#fff;background:rgba(240,113,106,.92);box-shadow:0 0 14px rgba(240,113,106,.45)}
.pk-clock-live .pk-clock-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:scPulse 1.1s ease-in-out infinite}
.pk-clock-ht{color:var(--accent);background:var(--accent-dim);box-shadow:inset 0 0 0 1px rgba(226,182,0,.35)}
.pk-clock-ft{color:var(--muted);background:rgba(255,255,255,.07)}
.pk-clock-soon{color:var(--accent);background:rgba(226,182,0,.1);box-shadow:inset 0 0 0 1px rgba(226,182,0,.28);font-weight:600}
.pk-scorecard .pk-sc-top .pk-cd{display:inline-flex;align-items:center;font-family:"JetBrains Mono",monospace;font-size:11.5px;font-weight:600;color:var(--accent);background:rgba(226,182,0,.1);box-shadow:inset 0 0 0 1px rgba(226,182,0,.28);padding:4px 10px;border-radius:20px;white-space:nowrap;margin:0}
@keyframes scPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)}}
.pk-scorecard .pk-sc-body{position:relative;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;padding:18px 14px 20px}
.pk-scorecard .pk-sc-body>*{position:relative;z-index:1}
.pk-scorecard .pk-sc-body::after{content:"";position:absolute;left:50%;top:47%;width:104px;height:104px;border:1px solid rgba(255,255,255,.11);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:0}   /* subtle centre circle behind the score */
.pk-scorecard .pk-sc-team{display:flex;flex-direction:column;align-items:center;gap:9px;min-width:0}
.pk-scorecard .pk-sc-logo{width:54px;height:54px;object-fit:contain;filter:drop-shadow(0 3px 7px rgba(0,0,0,.55))}
.pk-scorecard .pk-sc-flag{display:flex;align-items:center;justify-content:center}
.pk-scorecard .pk-sc-flag .flagi{height:30px;width:auto;border-radius:3px;margin:0;box-shadow:0 0 0 1px rgba(255,255,255,.12)}
.pk-scorecard .pk-sc-blank{width:54px;height:54px;display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-weight:700;font-size:15px;color:var(--muted);background:rgba(255,255,255,.06);border-radius:10px}
.pk-scorecard .pk-sc-name{font-family:"Fraunces",serif;font-weight:600;font-size:16px;text-align:center;line-height:1.12;color:var(--ink);max-width:130px}
.pk-scorecard .pk-sc-team.is-backed .pk-sc-name{color:var(--accent)}
.pk-scorecard .pk-sc-mid{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0 6px}
.pk-scorecard .pk-sc-goals{font-family:"JetBrains Mono",monospace;font-weight:800;font-size:33px;line-height:1;color:var(--ink);display:flex;align-items:center;gap:9px}
.pk-scorecard .pk-sc-goals i{font-style:normal;color:rgba(255,255,255,.6);font-weight:400;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.pk-scorecard .pk-sc-goals b{text-shadow:0 1px 3px rgba(0,0,0,.6)}   /* keep the score crisp over the green pitch */
.pk-scorecard .pk-sc-vs{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:18px;letter-spacing:.1em;color:rgba(255,255,255,.72);text-shadow:0 1px 3px rgba(0,0,0,.55)}
.pk-scorecard .pk-sc-when{display:flex;flex-direction:column;align-items:center;gap:1px;line-height:1.2;font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.04em;color:rgba(255,255,255,.82);white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.55)}
.pk-scorecard .pk-sc-when .pk-when-time{font-size:11.5px;font-weight:600;color:#fff;letter-spacing:.05em}
.pk-scorecard .pk-sc-pick{display:grid;grid-template-columns:1fr auto 1fr;align-items:end;gap:8px;padding:11px 16px 13px;border-top:1px solid rgba(255,255,255,.07);background:rgba(0,0,0,.28)}
.pk-scorecard .pk-sc-side{align-self:end;padding-bottom:1px}
.pk-scorecard .pk-sc-pickwrap{display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;min-width:0}
.pk-scorecard .pk-sc-picklabel{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.pk-scorecard .pk-sc-pick .pk-pick{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:15px;color:var(--accent);line-height:1.15}
.pk-scorecard .pk-sc-side{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);min-width:0}
.pk-scorecard .pk-sc-side-l{text-align:left}
.pk-scorecard .pk-sc-side-r{display:flex;flex-direction:column-reverse;align-items:flex-end;gap:3px}   /* pill stacked above the P/L */
.pk-scorecard .pk-sc-pick .pk-meta{color:var(--muted)}
.pk-scorecard .pk-sc-side-l .pk-meta,.pk-scorecard .pk-odds-admin{display:block}   /* stake on top, admin odds beneath */
.pk-scorecard .pk-odds-admin{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--accent);opacity:.72;margin-top:2px;letter-spacing:.02em}
/* ── fixture-detail meta: HT/penalties sub-line · league badge+flag · round chip · venue/referee facts ── */
.pk-scorecard .pk-sc-sub{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.03em;color:rgba(255,255,255,.78);text-shadow:0 1px 2px rgba(0,0,0,.6);margin-top:-2px}
.pk-scorecard .pk-stage .pk-lg-badges{display:inline-flex;align-items:center;gap:4px;vertical-align:-3px;margin-right:6px}
.pk-scorecard .pk-stage .pk-lg-logo,.pk-scorecard .pk-stage .pk-lg-flag{height:14px;width:auto;object-fit:contain}
.pk-scorecard .pk-stage .pk-lg-logo{filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
.pk-scorecard .pk-stage .pk-lg-flag{border-radius:2px;box-shadow:0 0 0 1px rgba(255,255,255,.16)}
/* live projected result — provisional while the match is in play (outlined + gentle pulse, vs the solid settled pill) */
.pk-scorecard .pill.pill-live{background:transparent;border:1px solid currentColor;display:inline-flex;align-items:center;gap:5px;animation:pkLivePulse 2.2s ease-in-out infinite}
.pk-scorecard .pill.pill-live.won{color:var(--win)}
.pk-scorecard .pill.pill-live.lost{color:var(--loss)}
.pk-scorecard .pill.pill-live.push{color:var(--muted)}
.pk-scorecard .pill.pill-live .pk-clock-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:none;flex:none}
@keyframes pkLivePulse{0%,100%{opacity:1}50%{opacity:.6}}
/* goal flash — when the poll detects the score went up */
.pick-card.pk-goal{animation:pkGoalCard 1.8s ease-out}
.pick-card.pk-goal .pk-sc-goals{animation:pkGoalScore 1.8s ease-out}
/* ── live-card expand → full-screen "watch live" ─────────────────────────── */
.pk-sc-topr{display:inline-flex;align-items:center;gap:8px;flex:none}
.pk-expand{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:rgba(0,0,0,.32);color:var(--ink);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s}
.pk-expand:hover{background:rgba(0,0,0,.55);border-color:rgba(255,255,255,.34)}
.pk-expand:active{transform:scale(.94)}
body.pk-focus-open{overflow:hidden}
.pk-focus{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(5,9,15,.93);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);opacity:0;visibility:hidden;transition:opacity .2s ease}
.pk-focus.on{opacity:1;visibility:visible}
.pk-focus-close{position:absolute;top:14px;right:16px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-size:26px;line-height:1;border:1px solid rgba(255,255,255,.2);border-radius:11px;background:rgba(0,0,0,.45);color:var(--ink);cursor:pointer;z-index:2;-webkit-tap-highlight-color:transparent}
.pk-focus-close:hover{background:rgba(0,0,0,.7)}
.pk-focus-grid{display:flex;flex-direction:column;gap:14px;width:100%;max-width:760px;max-height:100%;align-items:stretch;justify-content:center;overflow:auto}
.pk-focus .pk-scorecard{margin:0;cursor:default;box-shadow:0 14px 50px rgba(0,0,0,.5)}
.pk-focus .pk-expand{display:none}
.pk-focus .pk-sc-top{padding-top:18px}
.pk-focus .pk-sc-name{font-size:21px;max-width:none}
.pk-focus .pk-sc-logo{width:74px;height:74px}
.pk-focus .pk-sc-goals{font-size:60px;gap:14px}
.pk-focus .pk-sc-pick{padding:16px}
.pk-focus .pk-pick{font-size:21px}
.pk-focus-grid:not(.multi) .pk-sc-goals{font-size:88px}
.pk-focus-grid:not(.multi) .pk-sc-logo{width:88px;height:88px}
.pk-focus-grid:not(.multi) .pk-sc-name{font-size:24px}
@media(min-width:700px){.pk-focus-grid.multi{flex-direction:row;max-width:1100px}.pk-focus-grid.multi .pk-scorecard{flex:1}}
@keyframes pkGoalCard{0%{box-shadow:0 0 0 0 rgba(125,224,128,0)}12%{box-shadow:0 0 32px 5px rgba(125,224,128,.5)}100%{box-shadow:0 0 0 0 rgba(125,224,128,0)}}
@keyframes pkGoalScore{0%{transform:scale(1)}14%{transform:scale(1.26);color:var(--win)}42%{transform:scale(1)}100%{transform:scale(1)}}
.pk-goal-chip{position:absolute;top:46px;left:50%;z-index:3;font-family:"JetBrains Mono",monospace;font-weight:800;font-size:14px;letter-spacing:.06em;color:#06121c;background:var(--win);padding:5px 13px;border-radius:999px;box-shadow:0 6px 22px rgba(125,224,128,.45);animation:pkGoalChip 1.9s ease-out forwards;pointer-events:none}
@keyframes pkGoalChip{0%{opacity:0;transform:translate(-50%,8px) scale(.6)}14%{opacity:1;transform:translate(-50%,0) scale(1.08)}30%{transform:translate(-50%,0) scale(1)}80%{opacity:1}100%{opacity:0;transform:translate(-50%,-10px) scale(.95)}}
@media(prefers-reduced-motion:reduce){.pick-card.pk-goal,.pick-card.pk-goal .pk-sc-goals,.pk-goal-chip,.pk-scorecard .pill.pill-live{animation:none}}
.pk-scorecard .pk-sc-pick .pk-result{flex:none}
/* pass / awaiting-pick share the same bar, in a muted voice (no gold) */
.pk-scorecard .pk-sc-pick .pk-pick-pass,.pk-scorecard .pk-sc-pick .pk-pick-tbd{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:13px;letter-spacing:.01em;color:var(--muted);display:inline-flex;align-items:center;gap:7px}
.pk-scorecard .pk-sc-pick .pk-pick-tbd .pk-lock{flex:none;opacity:.85}
.pick-card.pk-scorecard.is-pass,.pick-card.pk-scorecard.is-tbd{border-color:var(--line)}
.pick-card.pk-scorecard.is-pass::after,.pick-card.pk-scorecard.is-tbd::after{display:none}
/* bracket-TBD: teams unknown → a single centred line instead of two crests */
.pk-scorecard .pk-sc-body-solo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;min-height:96px;padding:18px 16px;text-align:center}
.pk-scorecard .pk-sc-solomatch{font-family:"Fraunces",serif;font-weight:600;font-size:19px;color:var(--ink);line-height:1.2}
.pk-scorecard .pk-pass-note,.pk-scorecard .pk-tbd-note,.pk-scorecard .pk-note{margin:0;padding:11px 16px 13px;background:rgba(0,0,0,.26);border-top:1px solid rgba(255,255,255,.06)}
.pk-scorecard .pk-edit{position:absolute;top:10px;right:10px}
.pick-card .pk-cd{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.02em;color:var(--accent);background:rgba(226,182,0,.07);border:1px solid rgba(226,182,0,.22);border-radius:8px;padding:6px 10px}
.pick-card .pk-cd::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor;opacity:.85}
.pick-card .pk-cd.is-live{color:var(--accent);background:var(--accent-dim);border-color:rgba(226,182,0,.32);font-weight:700;letter-spacing:.08em}
.pick-card .pk-cd.is-live::before{animation:cdpulse 1.2s ease-in-out infinite}
.pick-card .pk-cd.is-ended{color:var(--muted);background:rgba(255,255,255,.04);border-color:var(--line)}
@keyframes cdpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.6)}}
@media(prefers-reduced-motion:reduce){.pick-card .pk-cd.is-live::before{animation:none}}
/* TBD fixture (teams unknown — knockout rounds): muted, no gold glow */
.pick-card.pick-tbd{border-color:var(--line)}
.pick-card.pick-tbd::after{display:none}
.pick-card .pk-tbd-note{margin-top:4px;font-family:"JetBrains Mono",monospace;font-size:12.5px;line-height:1.5;color:var(--faint)}
/* a fixture we passed on — muted, no gold, "no bet" tag */
.pick-card.pick-pass{border-color:var(--line)}
.pick-card.pick-pass::after{display:none}
.pick-card.pick-pass h3{color:var(--muted)}
.pick-card .pk-pass-note,.pick-card .pk-note{color:var(--faint);font-size:13.5px;line-height:1.55;margin-top:13px}
.pick-card .pk-label.pk-label-pass{color:var(--muted)}
.pick-card .pk-sel.pk-sel-pass{background:rgba(255,255,255,.04);border-color:var(--line)}
.pick-card .pk-sel.pk-sel-pass .pk-pick{color:var(--muted)}
.pick-card .pk-sel.pk-sel-tbd{background:rgba(255,255,255,.025);border:1px dashed var(--line)}
.pick-card .pk-sel.pk-sel-tbd .pk-pick{color:var(--muted);display:inline-flex;align-items:center;gap:7px;font-weight:600}
.pick-card .pk-sel.pk-sel-tbd .pk-lock{flex:none;opacity:.85}
.pk-result{display:inline-block;margin-top:14px;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;letter-spacing:.04em;padding:5px 10px;border-radius:7px}
.pk-result.won{color:var(--win);background:var(--win-dim)}
.pk-result.lost{color:var(--loss);background:var(--loss-dim)}
.pk-result.push{color:var(--push);background:var(--push-dim)}
.pk-empty{color:var(--muted);font-size:15px;line-height:1.6;padding:18px 0}
/* live-picks tabs */
.pk-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:26px 0 16px}
.pk-add{margin-left:auto;display:inline-flex;align-items:center;gap:6px;appearance:none;cursor:pointer;font-family:"JetBrains Mono",monospace;font-size:12.5px;font-weight:700;letter-spacing:.02em;color:#06121c;background:var(--win);border:0;border-radius:10px;padding:9px 14px;white-space:nowrap}
.pk-add:hover{filter:brightness(1.07)}
#memberPicks.is-admin .pick-card{cursor:pointer}
.pk-tabs + .picks-grid{margin-top:0}
.pk-tab{appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--line);color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:12.5px;letter-spacing:.02em;padding:9px 14px;border-radius:10px;transition:border-color .15s,color .15s,background .15s}
.pk-tab:hover{border-color:rgba(226,182,0,.5);color:var(--ink)}
.pk-tab.on{background:var(--accent);color:#06121c;border-color:var(--accent);font-weight:700}
.pk-tabn{display:inline-flex;align-items:center;justify-content:center;min-width:19px;height:19px;padding:0 5px;border-radius:10px;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;background:rgba(255,255,255,.08);color:inherit}
.pk-tab.on .pk-tabn{background:rgba(6,18,28,.2)}
.pk-empty-tab{padding:28px 2px}

/* modal */
.modal{position:fixed;inset:0;z-index:200;display:none;place-items:center;padding:24px;background:rgba(6,9,13,.72);backdrop-filter:blur(6px)}
.modal.open{display:grid;animation:modalIn .25s var(--ease)}
@keyframes modalIn{from{opacity:0}to{opacity:1}}
.modal-card{position:relative;width:100%;max-width:460px;max-height:92vh;overflow:auto;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8);animation:modalCard .35s var(--ease)}
@keyframes modalCard{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:14px;right:16px;appearance:none;border:0;background:transparent;color:var(--muted);font-size:26px;line-height:1;cursor:pointer;width:32px;height:32px;border-radius:8px}
.modal-x:hover{color:var(--ink);background:rgba(255,255,255,.05)}
/* auth modal — brand header + centered step headers */
.modal-brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line-soft)}
.modal-brand .mark{width:30px;height:30px;font-size:13px;border-radius:7px}
.signup-body,.signup-success{text-align:center}
.signup-body form{text-align:left}
.modal-card h2{font-family:"Fraunces",serif;font-weight:500;font-size:25px;letter-spacing:-.3px;margin:12px 0 8px}
.signup-sub{color:var(--muted);font-size:14.5px;line-height:1.55;margin-bottom:22px}
#emailForm,#nameForm,#otpForm{display:flex;flex-direction:column;gap:13px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.field input{appearance:none;background:var(--bg);border:1px solid var(--line);border-radius:9px;color:var(--ink);font-family:"Hanken Grotesk",sans-serif;font-size:15px;padding:11px 13px;transition:border-color .15s,box-shadow .15s}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(226,182,0,.12)}
.form-error{color:var(--loss);font-size:12.5px;margin:0}
#emailForm .btn,#nameForm .btn,#otpForm .btn{margin-top:6px;width:100%;text-align:center}
#otpForm .signup-fine{margin-top:2px;text-align:center}
.otp-boxes{display:flex;gap:10px}
.otp-box{flex:1;width:100%;min-width:0;text-align:center;appearance:none;background:var(--bg);border:1px solid var(--line);border-radius:10px;color:var(--ink);font-family:"JetBrains Mono",monospace;font-size:26px;font-weight:700;padding:14px 0;transition:border-color .15s,box-shadow .15s}
.otp-box:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(226,182,0,.14)}
.otp-box:not(:placeholder-shown),.otp-box[value]:not([value=""]){border-color:var(--accent)}
.signup-fine{font-size:11.5px;color:var(--faint);line-height:1.5;margin:0}
.signup-fine a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}
.signup-fine a.is-disabled{color:var(--faint);text-decoration:none;pointer-events:none;opacity:.6;cursor:default}
/* resend link — clearer than the surrounding fine print: gold when ready, legible grey while counting down */
#otpResend{color:var(--accent);font-weight:600}
#otpResend.is-disabled{color:rgba(255,255,255,.62);opacity:1;font-weight:500}
/* age + responsible-gambling screen */
.age-check{display:flex;align-items:flex-start;gap:9px;font-size:13px;line-height:1.45;color:var(--ink);margin:2px 0 13px;cursor:pointer;text-align:left}
.age-check input{margin-top:2px;width:16px;height:16px;flex:none;accent-color:var(--accent);cursor:pointer}
.age-warn{font-size:11.5px;line-height:1.55;color:var(--faint);background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;padding:12px 13px;margin-bottom:14px;text-align:left}
.age-warn p{margin:0 0 8px}
.age-warn p:last-child{margin-bottom:0}
.age-warn strong{color:var(--muted);font-weight:700}
.age-warn a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.signup-success{text-align:center;padding:8px 0}
.success-check{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;margin:0 auto 8px;font-size:30px;color:#06121c;background:linear-gradient(150deg,var(--accent),#b88e00);box-shadow:var(--bloom-accent)}
.signup-success .btn{margin-top:10px}

@media(max-width:680px){
  .picks-grid{grid-template-columns:1fr}
  .modal{padding:14px}
  .modal-card{padding:24px}
}
@media(prefers-reduced-motion:reduce){.modal.open,.modal-card{animation:none}}

/* ── Admin inline edit on member pick cards (✎) ─────────────────────── */
.pk-edit{display:inline-flex;align-items:center;justify-content:center;margin-top:14px;height:34px;padding:0 15px;border-radius:9px;border:1px solid rgba(226,182,0,.4);background:rgba(226,182,0,.08);color:var(--accent);cursor:pointer;font-family:"JetBrains Mono",monospace;font-size:14px;line-height:1;transition:background .15s,border-color .15s,transform .08s}
.pk-edit:hover{background:var(--accent);color:#06121c}
.pk-edit:active{transform:translateY(1px)}
/* pick box + edit button on one row (main card) */
.pk-selrow{display:flex;align-items:stretch;gap:10px}
.pk-selrow > .pk-sel{flex:1;min-width:0}
.pk-selrow > .pk-edit{margin-top:0;height:auto;padding:0 17px;font-size:15px}
/* edit modal (reuses .modal / .modal-card / .field / .btn) */
.pe-card{max-width:560px;text-align:left}
.pe-title{font-family:"Fraunces",serif;font-weight:500;font-size:23px;margin:0 0 4px}
.pe-fixture{display:flex;flex-direction:column;gap:2px;margin:0 0 18px}
.pe-fixture #peMatch{font-family:"Hanken Grotesk",sans-serif;font-weight:600;color:var(--ink);font-size:16px}
.pe-when{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--faint)}
.pe-form .field{margin:0 0 12px}
.pe-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}
.pe-grid .field{margin:0}
.pe-form input,.pe-form select,.pe-form textarea{width:100%}
.pe-form textarea{resize:vertical;min-height:46px}
.pe-int{font-size:9px;color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:0 4px;vertical-align:middle;text-transform:uppercase;letter-spacing:.04em;margin-left:5px}
/* admin grading: final-score inputs → auto-computed result */
.pe-score-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.pe-score-row input{width:64px!important;text-align:center;flex:none}
.pe-score-sep{color:var(--muted);font-weight:600;font-size:16px}
.pe-score-out{font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:700;letter-spacing:.02em;margin-left:6px}
.pe-score-out.pos{color:var(--win)} .pe-score-out.neg{color:var(--loss)} .pe-score-out.neu{color:var(--muted)}
.pe-result-lab{display:block;margin-top:12px}
.pe-ou-suffix{color:var(--muted);font-size:14px}
.pe-compose-row{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.pe-compose-row select,.pe-compose-row input{width:auto;min-width:0}
.pe-compose-row #peAhTeam{flex:2 1 0}
.pe-compose-row #peAhLine,.pe-compose-row #peOuSide,.pe-compose-row #peOuLine{flex:1 1 0}
.pe-compose-row .pe-ou-suffix{flex:none}
/* add-pick: searchable next-24h fixtures list (replaces the old WC team dropdowns + datetime) */
.pe-fixsearch{width:100%;margin-bottom:8px}
.pe-fixselect{width:100%;font-family:"JetBrains Mono",monospace;font-size:12px;line-height:1.55;padding:4px}
.pe-fixselect option{padding:3px 6px;border-radius:5px}
.pe-fixstatus{font-family:"JetBrains Mono",monospace;font-size:10.5px;color:var(--faint);margin:6px 0 0}
.pe-passhint{font-family:"Hanken Grotesk",sans-serif;font-size:13px;color:var(--muted);background:rgba(255,255,255,.03);border:1px dashed var(--line);border-radius:10px;padding:11px 13px;margin:0 0 14px;line-height:1.45}
/* publish-timing chips — pick "now" or schedule the reveal before kickoff */
.pe-actions{display:flex;gap:10px;margin-top:6px}
.pe-ghost{background:transparent;border:1px solid var(--line);color:var(--muted)}
.pe-ghost:hover{color:var(--ink);border-color:var(--muted)}
.pe-reset{margin-right:auto;background:transparent;border:1px solid var(--line);color:var(--muted)}
.pe-reset:hover{color:var(--loss);border-color:var(--loss)}
.pe-delete{margin-right:auto;background:rgba(240,113,106,.12);border:1px solid rgba(240,113,106,.5);color:var(--loss);font-weight:600}
.pe-delete:hover{background:rgba(240,113,106,.22);border-color:var(--loss)}
@media(max-width:560px){.pe-grid{grid-template-columns:1fr}}
