  :root{
    /* ─── color tokens ─── */
    --bg:#f4ede0;
    --bg-card:#faf6ec;
    --ink:#1a1612;
    --ink-mute:#7a6f5e;
    --rule:#d8cdb8;
    --accent:#e8a93a;
    --danger:#c4422a;
    --ok:#2d7a4a;

    /* ─── type families ─── */
    /* Two voices from the Plex family + mono for data. The display face
       (Sans Condensed) carries headlines; body uses Plex Sans; numbers and
       UI rails stay on Plex Mono so data feels like data. */
    --font-display:'IBM Plex Sans Condensed', ui-sans-serif, system-ui, sans-serif;
    --font-body:'IBM Plex Sans', ui-sans-serif, system-ui, sans-serif;
    --font-mono:'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

    /* ─── tracking system ─── */
    /* One value per role. Caps labels get .12em everywhere; display tightens
       slightly; body and numerals are flat. No exceptions. */
    --track-label:    .12em;
    --track-display:  -.02em;
    --track-count:    -.045em;
    --track-body:      0;

    /* ─── type scale ─── */
    --fs-micro:  11px;
    --fs-small:  13px;
    --fs-body:   15px;
    --fs-meta:   18px;
    --fs-stat:   28px;
    --fs-ticket: clamp(28px, 4vw + 8px, 56px);
    --fs-display:clamp(40px, 6vw + 12px, 96px);
    --fs-hero:   clamp(56px, 9vw + 16px, 140px);
    --fs-count:  clamp(56px, 8vw + 4px, 160px);

    /* ─── spacing scale ─── */
    --s-1: 4px;  --s-2: 8px;  --s-3: 12px;  --s-4: 16px;
    --s-5: 20px; --s-6: 24px; --s-8: 32px;  --s-10: 40px;
    --s-12: 56px;

    /* ─── shell width ─── */
    --shell-w: min(100%, clamp(390px, 92vw, 1280px));
  }

  *,*::before,*::after{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--ink);color:var(--ink);
    font-family:var(--font-body);font-size:var(--fs-body);line-height:1.5;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
  body{display:flex;justify-content:center;min-height:100vh}
  button,input{font-family:inherit}
  a{color:inherit;text-decoration:none}

  /* ─── shell ─── */
  .shell{width:100%;max-width:var(--shell-w);min-height:100vh;background:var(--bg);
    position:relative;color:var(--ink)}
  .shell--accent{background:var(--accent)}

  /* ─── countbar (sticky editorial masthead) ─── */
  /* Four-layer hero stack: home/context/profile rail → REMAINING pretitle →
     the big number → bottom rail + progress. The number is the message,
     everything else is scaffolding around it. */
  .countbar{position:sticky;top:0;z-index:5;background:var(--ink);color:var(--bg);
    border-bottom:1px solid var(--ink);padding:14px 18px 14px;overflow:hidden;
    font-family:var(--font-mono)}
  .countbar__rail{font-size:var(--fs-micro);letter-spacing:var(--track-label);
    text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500}
  .countbar__rail--top{display:grid;grid-template-columns:1fr auto 1fr;
    align-items:center;gap:12px;margin-bottom:10px}
  .countbar__home{justify-self:start;color:rgba(255,255,255,.5);text-decoration:none;
    font-weight:700;letter-spacing:var(--track-label)}
  .countbar__home:hover{color:var(--accent)}
  .countbar__sub{justify-self:center;color:rgba(255,255,255,.55);font-weight:500;
    text-align:center;white-space:nowrap}
  .countbar__profile{justify-self:end;color:rgba(255,255,255,.7);text-decoration:none;
    font-weight:700;letter-spacing:var(--track-label);padding:6px 10px;
    border:1px solid rgba(255,255,255,.15)}
  .countbar__profile:hover{color:var(--accent);border-color:var(--accent)}
  .countbar__login{justify-self:end;color:var(--ink);background:var(--accent);
    text-decoration:none;font-weight:800;letter-spacing:var(--track-label);
    padding:7px 14px;border:1px solid var(--accent)}
  .countbar__login:hover{background:var(--bg);border-color:var(--bg)}
  .countbar__rail--bottom{display:flex;justify-content:space-between;
    color:rgba(255,255,255,.4);margin-top:10px;margin-bottom:0}
  .countbar__rail--bottom .right{color:rgba(255,255,255,.6)}
  .countbar__pretitle{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:.32em;text-transform:uppercase;color:var(--accent);
    font-weight:700;text-align:center;margin-bottom:6px;opacity:.85}
  .countbar__hero{position:relative;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:0;padding:2px 0}
  .countbar__num{font-family:var(--font-display);font-weight:800;font-size:var(--fs-count);
    line-height:.95;font-variant-numeric:tabular-nums;letter-spacing:var(--track-display);
    color:var(--bg);text-shadow:0 2px 0 rgba(0,0,0,.35)}
  .countbar__num.is-flicker{animation:flicker .6s ease-out}
  .countbar__delta{position:absolute;right:8px;top:-4px;font-size:16px;font-weight:800;
    color:var(--accent);pointer-events:none;animation:floatUp 1.4s ease-out forwards;
    font-family:var(--font-mono)}
  .countbar__progress{height:3px;margin-top:8px;background:rgba(255,255,255,.1);
    position:relative;overflow:hidden}
  .countbar__progress::after{content:"";position:absolute;left:0;top:0;bottom:0;
    width:var(--progress,2%);min-width:3px;background:var(--accent);
    box-shadow:0 0 12px rgba(232,169,58,.4)}

  /* Hide top rail's centered sub on very narrow viewports so it doesn't
     compete with the home brand + profile button for space. */
  @media (max-width:480px){
    .countbar__rail--top{grid-template-columns:auto auto;gap:8px}
    .countbar__sub{display:none}
    .countbar__home{font-size:10px}
    .countbar__profile{padding:5px 8px;font-size:10px}
    .countbar__login{padding:6px 10px;font-size:10px}
  }

  /* ─── editorial primitives ─── */
  .slash{font-family:var(--font-mono);font-weight:700;font-size:var(--fs-small);
    line-height:1;letter-spacing:var(--track-body);display:inline-flex;align-items:center;gap:6px}
  .slash--small{font-size:12px}
  .slash i{color:var(--danger);font-weight:800;font-style:normal}

  .pretitle{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);text-transform:uppercase;color:var(--ink-mute);font-weight:600}

  .pad{padding:24px 22px 0}
  .pad--tight{padding:0 22px}

  .topline{display:flex;justify-content:space-between;align-items:center}
  .cycle{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--ink-mute);text-transform:uppercase}

  .body{margin:0;font-size:var(--fs-small);line-height:1.55;color:var(--ink);
    letter-spacing:var(--track-body);text-wrap:pretty}

  /* ─── poster: WANTED stamp + hero block ─── */
  /* The stamp keeps its tilt — one of the two intentional rotations on the
     landing page. */
  .stamp{display:inline-block;background:var(--ink);color:var(--bg);
    padding:5px 12px;font-family:var(--font-display);font-size:13px;
    letter-spacing:var(--track-label);font-weight:800;text-transform:uppercase;
    transform:rotate(-2deg);box-shadow:3px 3px 0 rgba(0,0,0,.2)}
  .stamp--danger{background:var(--danger);padding:5px 14px}

  .poster-hero{text-align:center;padding:24px 22px 12px;position:relative}
  .poster-hero__title{font-family:var(--font-display);font-size:var(--fs-hero);
    font-weight:800;line-height:.92;letter-spacing:var(--track-display);
    margin:14px 0 0;text-wrap:balance;text-transform:uppercase}
  .poster-hero__title em{font-style:normal;background:var(--ink);color:var(--accent);
    padding:0 8px;white-space:nowrap}
  .poster-hero__sub{font-family:var(--font-body);font-size:var(--fs-body);
    font-weight:500;letter-spacing:var(--track-body);margin-top:14px;color:var(--ink)}

  .poster-paper{position:absolute;inset:0;top:110px;pointer-events:none;
    background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 50%)}

  /* ─── mascot squad area ─── */
  .squad{position:relative;width:100%;aspect-ratio:390/220;margin:8px 0;
    max-width:1040px;margin-inline:auto}
  .squad__slot{position:absolute}
  .sticker{position:absolute;padding:2px 6px;font-family:var(--font-mono);
    font-size:10px;font-weight:800;letter-spacing:var(--track-body);
    border:1.5px solid var(--ink);background:var(--bg-card)}
  .sticker--dark{background:var(--ink);color:var(--bg);border-color:var(--ink)}
  .sticker--danger{background:var(--danger);color:var(--bg);border-color:var(--ink);
    padding:2px 8px;font-size:11px}

  /* ─── torn ticket CTA (kept rotation — one of two on landing) ─── */
  .ticket{position:relative;background:var(--ink);color:var(--bg);
    padding:18px;box-shadow:5px 5px 0 rgba(0,0,0,.2);transform:rotate(-.5deg)}
  .ticket--light{background:var(--bg-card);color:var(--ink);border:2px solid var(--ink);
    box-shadow:5px 5px 0 var(--ink);transform:rotate(.4deg)}
  .ticket::before,.ticket::after{content:"";position:absolute;top:0;bottom:0;width:8px;
    background:radial-gradient(circle, var(--accent) 3px, transparent 3px) 0 0/8px 12px repeat-y}
  .ticket::before{left:-4px}
  .ticket::after{right:-4px}
  .ticket__rail{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--accent);text-transform:uppercase;font-weight:700}
  .ticket--light .ticket__rail{color:var(--ink-mute)}
  .ticket__title{font-family:var(--font-display);font-size:var(--fs-ticket);
    font-weight:800;line-height:1.02;letter-spacing:var(--track-display);
    margin:8px 0;text-transform:uppercase}
  .ticket__body{font-family:var(--font-body);font-size:var(--fs-small);
    color:rgba(255,255,255,.75);line-height:1.5;letter-spacing:var(--track-body)}
  .ticket--light .ticket__body{color:var(--ink-mute)}
  .ticket__cta{background:var(--accent);color:var(--ink);padding:13px;
    font-family:var(--font-display);font-weight:800;font-size:var(--fs-meta);
    letter-spacing:var(--track-label);text-transform:uppercase;text-align:center;
    border:2px solid var(--bg);margin-top:14px;cursor:pointer;width:100%;display:block}
  .ticket__cta--ink{background:var(--ink);color:var(--bg);border-color:var(--ink)}

  /* ─── rules box (straight, lighter chrome) ─── */
  .rules{margin:0 22px;padding:14px 16px;background:var(--bg-card);
    border:1px solid var(--rule)}
  .rules__title{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--ink-mute);
    text-transform:uppercase;font-weight:700}
  .rules ul{margin:6px 0 0;padding:0 0 0 16px;font-family:var(--font-body);
    font-size:var(--fs-small);line-height:1.6;letter-spacing:var(--track-body)}

  .colophon{text-align:center;font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);text-transform:uppercase;
    color:var(--ink);opacity:.5;padding:24px 0}

  /* ─── magic-link form ─── */
  .field{display:block;margin-bottom:12px}
  .field__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--ink-mute);
    text-transform:uppercase;margin-bottom:6px;font-weight:600}
  .field__input{width:100%;padding:12px 14px;font-family:var(--font-body);
    font-size:var(--fs-body);color:var(--ink);background:var(--bg-card);
    border:1.5px solid var(--ink);border-radius:4px;outline:none;font-weight:500;
    letter-spacing:var(--track-body)}
  .field__input::placeholder{color:var(--ink-mute);opacity:.7}
  .field__input:focus{border-color:var(--accent)}

  /* ─── polaroid (kept rotation — character) ─── */
  .polaroid-wrap{position:relative;display:flex;justify-content:center;margin:14px 0 6px}
  .polaroid{background:var(--bg);padding:10px 10px 26px;border:1px solid var(--ink);
    box-shadow:4px 6px 0 rgba(0,0,0,.18);transform:rotate(-3deg);position:relative}
  .polaroid__tape{position:absolute;top:-10px;left:50%;transform:translateX(-50%) rotate(3deg);
    width:56px;height:18px;background:rgba(26,22,18,.18);border:1px solid rgba(0,0,0,.08)}
  .polaroid__caption{position:absolute;bottom:6px;left:12px;right:12px;
    font-family:var(--font-body);font-size:12px;letter-spacing:var(--track-body);
    font-style:italic;color:var(--ink-mute);text-align:center}
  .scrawl{position:absolute;right:22px;top:28px;transform:rotate(12deg)}
  .scrawl__text{font-family:var(--font-display);font-size:13px;font-weight:800;
    color:var(--danger);line-height:1.2;text-transform:uppercase;letter-spacing:var(--track-label)}
  .scrawl__arrow{margin-top:4px;width:40px;border-top:2px solid var(--ink);
    transform:rotate(22deg);transform-origin:left}
  .vouch{position:absolute;left:8px;bottom:-4px;transform:rotate(-8deg);
    background:var(--ok);color:var(--bg);padding:5px 10px;font-family:var(--font-display);
    font-weight:800;font-size:12px;border:2px solid var(--ink);
    letter-spacing:var(--track-label);text-transform:uppercase}

  /* ─── dashboard ─── */
  /* No rotation, no hard shadow. The inverted ink panel is enough weight. */
  .today{background:var(--ink);color:var(--bg);padding:18px;position:relative}
  .today__tag{position:absolute;top:-10px;right:14px;background:var(--ink);
    color:var(--accent);padding:3px 10px;font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);text-transform:uppercase;font-weight:700;
    border:1px solid var(--accent)}
  .today__row{display:flex;align-items:center;gap:16px}
  .today__num{font-family:var(--font-mono);font-size:var(--fs-display);font-weight:800;
    line-height:1;letter-spacing:var(--track-count);color:var(--accent);
    font-variant-numeric:tabular-nums}
  .today__meta{flex:1}
  .today__meta b{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--accent);font-weight:700;text-transform:uppercase}
  .today__meta p{font-family:var(--font-body);font-size:var(--fs-small);
    color:rgba(255,255,255,.75);margin:6px 0 0;line-height:1.5;letter-spacing:var(--track-body)}
  .today__mascot{position:relative;flex-shrink:0}

  /* Action buttons keep their hard shadow — they earn it. */
  .quick{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
  .quick__btn{border:2px solid var(--bg);border-radius:0;padding:18px 12px;
    font-family:var(--font-display);font-weight:800;font-size:22px;
    letter-spacing:var(--track-display);cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:4px;
    transition:transform .08s,box-shadow .08s}
  .quick__btn--plus1{background:var(--accent);color:var(--ink)}
  .quick__btn--plus10{background:var(--danger);color:var(--bg)}
  .quick__btn:active{transform:translate(2px,2px)}
  .quick__btn b{font-family:var(--font-mono);font-size:36px;line-height:1;font-weight:800;
    font-variant-numeric:tabular-nums;letter-spacing:var(--track-count)}
  .quick__btn span{font-family:var(--font-mono);font-size:var(--fs-micro);
    opacity:.85;letter-spacing:var(--track-label);text-transform:uppercase}

  .custom{display:flex;align-items:center;justify-content:space-between;
    border:1.5px solid var(--accent);background:transparent;padding:10px 14px;
    margin-top:10px}
  .custom__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    color:var(--accent);letter-spacing:var(--track-label);text-transform:uppercase;font-weight:700}
  .custom__input{width:80px;border:none;background:transparent;text-align:right;
    font-family:var(--font-mono);font-size:var(--fs-meta);font-weight:800;
    color:var(--accent);outline:none;font-variant-numeric:tabular-nums}

  /* Stats: straight, light border, no hard shadow. */
  .stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
  .stat{padding:14px 16px;background:var(--bg-card);border:1px solid var(--rule)}
  .stat__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--ink-mute);font-weight:700;text-transform:uppercase}
  .stat__num{font-family:var(--font-mono);font-size:var(--fs-stat);font-weight:800;
    margin-top:6px;font-variant-numeric:tabular-nums;letter-spacing:var(--track-count)}

  /* Chain: stays green (success color makes sense for "from your network")
     but loses the rotation + hard shadow. */
  .chain{padding:14px 16px;background:var(--ok);color:var(--bg);
    border:1px solid var(--ink);display:flex;align-items:center;
    justify-content:space-between;gap:12px;margin-top:10px}
  .chain__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);text-transform:uppercase;opacity:.85;font-weight:700}
  .chain__sub{font-family:var(--font-body);font-size:var(--fs-small);opacity:.9;
    margin-top:3px;letter-spacing:var(--track-body)}
  .chain__num{font-family:var(--font-mono);font-size:var(--fs-stat);font-weight:800;
    font-variant-numeric:tabular-nums;letter-spacing:var(--track-count)}

  .personal{padding:14px 16px;background:var(--bg-card);border:1px solid var(--rule);
    margin-top:10px}
  .personal__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
  .personal__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--ink-mute);font-weight:700;text-transform:uppercase}
  .personal__pct{font-family:var(--font-mono);font-size:var(--fs-small);font-weight:800;
    font-variant-numeric:tabular-nums;letter-spacing:var(--track-count)}
  .personal__bar{height:10px;background:var(--bg);border:1px solid var(--rule);
    position:relative;overflow:hidden}
  .personal__bar::after{content:"";position:absolute;left:0;top:0;bottom:0;
    width:var(--progress,1%);min-width:4px;background:var(--accent)}
  .personal__caption{font-family:var(--font-body);font-size:var(--fs-small);
    color:var(--ink-mute);margin-top:8px;line-height:1.5;letter-spacing:var(--track-body)}

  /* Leaderboard: straight, light frame. Title now in display sans. */
  .lboard{background:var(--bg-card);border:1px solid var(--rule);
    padding:14px 16px 10px;position:relative;margin-top:18px}
  .lboard__tape{position:absolute;top:-10px;width:50px;height:16px;
    background:rgba(26,22,18,.15);border:1px solid rgba(0,0,0,.08)}
  .lboard__tape--l{left:16px;transform:rotate(-6deg)}
  .lboard__tape--r{right:30px;transform:rotate(8deg)}
  .lboard__title{font-family:var(--font-display);font-size:var(--fs-meta);
    font-weight:800;letter-spacing:var(--track-display);text-transform:uppercase;
    margin-bottom:10px;line-height:1}
  .lboard__row{display:grid;grid-template-columns:28px 1fr auto;gap:12px;align-items:center;
    padding:9px 0;border-bottom:1px solid var(--rule);font-size:var(--fs-small)}
  .lboard__row:last-child{border-bottom:none}
  .lboard__rank{font-family:var(--font-mono);color:var(--ink-mute);
    font-variant-numeric:tabular-nums;font-weight:700}
  .lboard__name{font-family:var(--font-body);font-weight:500;letter-spacing:var(--track-body)}
  .lboard__row--top .lboard__name{font-weight:700}
  .lboard__reps{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:700}

  /* The "you" row: ink on cream, not red. Quieter and more confident. */
  .lboard__you{margin-top:8px;display:grid;grid-template-columns:28px 1fr auto;gap:12px;
    align-items:center;padding:11px 12px;background:var(--ink);color:var(--bg);
    font-size:var(--fs-small)}
  .lboard__you b{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:800}
  .lboard__you strong{font-family:var(--font-body);font-weight:600}
  .lboard__youtag{font-family:var(--font-mono);font-size:var(--fs-micro);
    font-weight:500;letter-spacing:var(--track-label);opacity:.7;margin-left:8px;
    text-transform:uppercase}

  /* Referral: keep the inverted treatment, lose the danger-red shadow. */
  .referral{padding:14px 16px;background:var(--ink);color:var(--bg);
    border:1px solid var(--ink);margin-top:18px}
  .referral__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);color:var(--accent);font-weight:700;
    margin-bottom:8px;text-transform:uppercase}
  .referral__row{display:flex;align-items:center;justify-content:space-between;gap:10px;
    background:rgba(255,255,255,.06);border:1px solid var(--accent);
    padding:10px 12px;font-size:var(--fs-small)}
  .referral__url{font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;
    white-space:nowrap;color:var(--accent);letter-spacing:var(--track-body)}
  .referral__copy{border:1.5px solid var(--bg);background:var(--accent);color:var(--ink);
    font-family:var(--font-mono);font-size:var(--fs-micro);font-weight:800;
    letter-spacing:var(--track-label);padding:6px 12px;cursor:pointer;text-transform:uppercase}
  .referral__copy:active{background:var(--ok);color:var(--bg)}
  .referral__caption{font-family:var(--font-body);font-size:var(--fs-small);
    color:rgba(255,255,255,.65);margin-top:8px;line-height:1.5;letter-spacing:var(--track-body)}

  /* ─── dashboard topline ─── */
  .dashtop{display:flex;justify-content:space-between;align-items:center;padding:0 4px}

  /* ─── small cheering row (invite) ─── */
  .cheer{position:relative;height:120px;padding:0 22px;margin-top:18px}
  .cheer__sticker{position:absolute;left:70px;bottom:6px;
    background:var(--bg-card);border:1.5px solid var(--ink);padding:3px 10px;
    font-family:var(--font-mono);font-size:var(--fs-micro);font-weight:800;
    letter-spacing:var(--track-label);text-transform:uppercase}

  /* ─── mascot wrap ─── */
  .creature{display:inline-block;animation:creatureBreath 2.6s ease-in-out infinite;
    transform-origin:50% 20%}
  .creature--bob{animation:creatureBob 2.4s ease-in-out infinite}
  .creature__inner{display:block}
  .creature__inner.is-pulse{animation:creaturePullup .55s cubic-bezier(.2,.7,.3,1) both}
  .creature svg{display:block;overflow:visible}

  .quip{position:absolute;right:100%;top:6px;margin-right:8px;background:var(--bg-card);
    border:1.5px solid var(--ink);padding:6px 10px;border-radius:4px;white-space:nowrap;
    font-family:var(--font-body);font-size:12px;color:var(--ink);
    pointer-events:none;animation:bubbleIn 2.4s ease-out forwards;opacity:0;
    letter-spacing:var(--track-body)}

  .minus{position:absolute;font-family:var(--font-mono);font-weight:800;font-size:22px;
    color:var(--danger);letter-spacing:var(--track-count);pointer-events:none;
    animation:floatUp 1.4s ease-out forwards}

  /* ─── animations ─── */
  @keyframes flicker{0%,93%,100%{opacity:1}94%{opacity:.7}96%{opacity:1}97%{opacity:.85}}
  @keyframes creatureBreath{0%,100%{transform:translateY(0) scaleY(1)}50%{transform:translateY(1px) scaleY(.985)}}
  @keyframes creatureBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
  @keyframes creaturePullup{0%{transform:translateY(0)}38%{transform:translateY(-14px)}100%{transform:translateY(0)}}
  @keyframes floatUp{0%{opacity:0;transform:translateY(6px) scale(.6)}20%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(-34px) scale(1)}}
  @keyframes bubbleIn{0%{opacity:0;transform:translateY(4px) scale(.85)}30%{opacity:1;transform:translateY(0) scale(1)}80%{opacity:1}100%{opacity:0;transform:translateY(-2px)}}

  @media (prefers-reduced-motion: reduce){
    *,*::before,*::after{animation-duration:.001s !important;animation-iteration-count:1 !important;
      transition-duration:.001s !important}
  }

  /* ─── focus ring ─── */
  button:focus-visible,a:focus-visible,input:focus-visible,.referral__copy:focus-visible{
    outline:2px solid var(--accent);outline-offset:2px}

  /* ─── desktop framing ─── */
  @media (min-width:600px){
    body{padding:24px 0}
    .shell{box-shadow:0 24px 80px rgba(0,0,0,.35),0 0 0 1px rgba(0,0,0,.4)}
    .poster-hero,.rules,.ticket,.ticket--light{max-width:820px;margin-inline:auto}
    .rules{margin:0 auto}
  }
  @media (min-width:900px){
    .poster-hero{padding:36px 56px 18px}
    .dashtop,.today,.stats,.chain,.personal,.lboard,.referral{max-width:1040px;margin-inline:auto}
  }
  @media (min-width:1200px){
    .poster-hero,.rules,.ticket,.ticket--light{max-width:920px}
    .poster-hero{padding:48px 64px 24px}
    .squad{margin:18px auto}
    .dashtop,.today,.stats,.chain,.personal,.lboard,.referral{max-width:1100px}
    .today{padding:24px 28px}
    .lboard{padding:18px 22px 12px}
    .referral{padding:18px 22px}
    .personal{padding:16px 20px}
    .stat{padding:18px 22px}
    .chain{padding:18px 22px}
  }
  .cheer{max-width:520px;margin:18px auto 0}

  /* ─── visibility (only one screen mounted) ─── */
  [data-screen]{display:none}
  [data-screen].is-active{display:block}

  /* ─── topnav (logged-in pages) ─── */
  .topnav{display:flex;align-items:center;justify-content:space-between;
    gap:14px;flex-wrap:wrap;padding:14px 22px;background:var(--bg);
    border-bottom:1px solid var(--rule);font-family:var(--font-mono)}
  .topnav__brand{display:inline-flex;align-items:center;gap:8px;font-weight:800;
    font-size:var(--fs-small);letter-spacing:var(--track-label);color:var(--ink);
    text-decoration:none;text-transform:uppercase}
  .topnav__brand i{color:var(--danger);font-style:normal;font-weight:800;
    font-size:16px;line-height:1}
  .topnav__brand span{letter-spacing:var(--track-label)}
  .topnav__links{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
  .topnav__links a{font-size:var(--fs-micro);font-weight:700;letter-spacing:var(--track-label);
    text-transform:uppercase;color:var(--ink-mute);padding:8px 14px;
    border:1px solid transparent;text-decoration:none;line-height:1}
  .topnav__links a:hover{color:var(--ink);border-color:var(--rule)}
  .topnav__links a[aria-current="page"]{background:var(--ink);color:var(--accent);
    border-color:var(--ink)}
  @media (min-width:900px){
    .topnav{padding:16px 32px}
    .topnav__links a{padding:9px 16px}
  }

  /* ─── shellnav (footer nav, logged-in pages) ─── */
  .shellnav{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;
    padding:16px 22px 4px;font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);text-transform:uppercase;color:var(--ink-mute)}
  .shellnav a{color:var(--ink-mute);text-decoration:none;font-weight:700;
    padding:4px 2px;border-bottom:1px solid transparent}
  .shellnav a:hover{color:var(--ink);border-bottom-color:var(--rule)}
  .shellnav a[aria-current="page"]{color:var(--ink);border-bottom-color:var(--ink)}

  /* ─── subtree-branch (profile chain) ─── */
  .subtree-branch{display:block}
  .subtree-branch summary{display:grid;grid-template-columns:18px 1fr auto;gap:12px;
    align-items:center;padding:10px 2px;border-bottom:1px solid var(--rule);
    font-family:var(--font-body);font-size:var(--fs-small);cursor:pointer;list-style:none;
    letter-spacing:var(--track-body)}
  .subtree-branch summary::-webkit-details-marker{display:none}
  .subtree-branch summary::before{content:'▾';color:var(--ink-mute);font-size:11px;line-height:1}
  .subtree-branch:not([open]) > summary::before{content:'▸'}
  .subtree-branch__name{font-weight:500}
  .subtree-branch__reps{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:700}
  .subtree-branch__count{font-family:var(--font-mono);font-size:var(--fs-micro);
    color:var(--ink-mute);letter-spacing:var(--track-label);margin-left:8px;font-weight:500}
  .subtree-branch__children{padding-left:22px;border-left:1px solid var(--rule);margin-left:7px}
  .subtree-branch__leaf{display:grid;grid-template-columns:18px 1fr auto;gap:12px;
    align-items:center;padding:10px 2px;border-bottom:1px solid var(--rule);
    font-family:var(--font-body);font-size:var(--fs-small);letter-spacing:var(--track-body)}
  .subtree-branch__leaf::before{content:'·';color:var(--ink-mute);text-align:center}
  .subtree-branch__leaf .subtree-branch__name{grid-column:2}
  .subtree-branch__leaf .subtree-branch__reps{grid-column:3}
  .subtree-branch[open] > summary > .subtree-branch__name > .subtree-branch__count{display:none}

  /* ─── leaderboard filter (straight, light) ─── */
  .lb-filter{display:flex;gap:8px;margin:0 0 16px;flex-wrap:wrap}
  .lb-filter button{background:var(--bg-card);border:1px solid var(--rule);
    padding:6px 14px;font-family:var(--font-mono);font-size:var(--fs-micro);font-weight:700;
    letter-spacing:var(--track-label);text-transform:uppercase;cursor:pointer}
  .lb-filter button:hover{border-color:var(--ink)}
  .lb-filter button[aria-pressed="true"]{background:var(--ink);color:var(--bg);border-color:var(--ink)}

  .lboard--with-flags .lboard__row,
  .lboard--with-flags .lboard__row--top{grid-template-columns:28px 1fr auto 24px}

  .lb-flag{background:transparent;border:none;padding:0;cursor:pointer;
    width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px}
  .lb-flag:hover{background:rgba(0,0,0,.06)}
  .lb-flag svg{width:14px;height:14px;stroke:var(--ink-mute);fill:none;stroke-width:1.6}
  .lb-flag[aria-pressed="true"] svg{fill:var(--danger);stroke:var(--danger)}

  .lb-disputed{display:inline-block;background:var(--danger);color:var(--bg);
    padding:2px 6px;margin-right:6px;font-family:var(--font-mono);font-size:10px;
    font-weight:800;letter-spacing:var(--track-label);border:1px solid var(--ink);
    vertical-align:middle;text-transform:uppercase}

  .lb-empty{padding:30px 14px;text-align:center;color:var(--ink-mute);
    font-family:var(--font-body);font-size:var(--fs-body);letter-spacing:var(--track-body)}

  /* ─── edge marquees: scrolling diagonal "ONE MILLION" in the dark
     void columns either side of the centered shell. Decorative only. ─── */
  .edge-marquee{position:fixed;top:0;bottom:0;
    width:max(0px, calc((100vw - 1280px) / 2));
    overflow:hidden;pointer-events:none;z-index:0}
  .edge-marquee--left{left:0}
  .edge-marquee--right{right:0}
  .edge-marquee__inner{position:absolute;inset:-40% -120%;
    display:flex;flex-direction:column;gap:18px;white-space:nowrap;
    will-change:transform;transform-origin:center center}
  .edge-marquee__inner{animation:edgeMarquee 60s linear infinite}
  .edge-marquee__row{font-family:var(--font-display);font-weight:800;
    font-size:64px;letter-spacing:-.02em;text-transform:uppercase;
    color:var(--accent);opacity:.07;line-height:.95}

  @keyframes edgeMarquee{
    from{transform:rotate(-26deg) translateX(0)}
    to{transform:rotate(-26deg) translateX(-360px)}
  }

  @media (prefers-reduced-motion: reduce){
    .edge-marquee__inner{animation:none}
  }
  @media (max-width:1280px){
    .edge-marquee{display:none}
  }

  /* ─── home CTA (below rules, points to leaderboard) ─── */
  .home-cta{margin:28px 22px 8px;padding:18px 16px;text-align:center;
    border-top:1px solid var(--rule)}
  .home-cta__leaderboard{display:inline-block;font-family:var(--font-mono);
    font-size:var(--fs-small);font-weight:800;letter-spacing:var(--track-label);
    text-transform:uppercase;color:var(--ink);text-decoration:none;
    padding:11px 18px;border:2px solid var(--ink);background:var(--bg-card);
    box-shadow:3px 3px 0 var(--ink);transition:transform .08s,box-shadow .08s}
  .home-cta__leaderboard:hover{transform:translate(-1px,-1px);
    box-shadow:4px 4px 0 var(--ink)}
  .home-cta__leaderboard:active{transform:translate(1px,1px);
    box-shadow:2px 2px 0 var(--ink)}
  .home-cta__note{margin:14px auto 0;max-width:520px;font-family:var(--font-body);
    font-size:var(--fs-small);color:var(--ink-mute);letter-spacing:var(--track-body);
    line-height:1.5}

  /* ─── invite banner (home page, ?ref= present) ─── */
  .invite-banner{margin:16px 20px 0;background:var(--bg-card);border:1px solid var(--ink);
    padding:12px 14px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
  .invite-banner__label{font-family:var(--font-mono);font-size:var(--fs-micro);
    letter-spacing:var(--track-label);text-transform:uppercase;color:var(--ink-mute);font-weight:700}
  .invite-banner__msg{font-family:var(--font-body);font-size:var(--fs-small);color:var(--ink);
    flex:1;letter-spacing:var(--track-body);min-width:160px}
  .invite-banner__cta{font-family:var(--font-mono);font-size:var(--fs-micro);font-weight:800;
    letter-spacing:var(--track-label);text-transform:uppercase;color:var(--ink);
    background:var(--accent);padding:9px 14px;text-decoration:none;border:2px solid var(--ink);
    box-shadow:3px 3px 0 var(--ink);display:inline-flex;align-items:center;gap:4px;flex-shrink:0;
    transition:transform .08s,box-shadow .08s}
  .invite-banner__cta:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
  .invite-banner__cta:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}
