/* ============================================================
   ScoreBattle · SPA · base tokens
   ============================================================ */
:root{
  --navy:#1B2E5E;
  --navy-deep:#14224A;
  --navy-700:#243A6E;
  --red:#C8202F;
  --red-deep:#A11824;
  --bone:#F5F2EC;
  --paper:#FFFFFF;
  --ink:#0E1530;
  --ink-2:#2A3252;
  --muted:#6B7390;
  --line:#E4E6EE;
  --field:#F3F4F8;
  --success:#1F8A5B;
  --warning:#C58A1B;
  --r-card:24px;
  --r-btn:14px;
  --r-fld:12px;
  --sans:'Inter',-apple-system,system-ui,'Segoe UI',Roboto,sans-serif;
  --display:'Bebas Neue','Inter',sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;overflow:hidden}
body{
  font-family:var(--sans);color:var(--ink);
  background:var(--bone);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit}

/* ── app shell ────────────────────────────────────────── */
.app{position:relative;width:100%;max-width:1280px;margin:0 auto;height:100vh;height:100dvh;overflow:hidden}
html[data-screen="splash"] .app,
html[data-screen="welcome"] .app{max-width:none}
.screen{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  background:var(--bone);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.screen[hidden]{display:none}
.screen.is-active{opacity:1;pointer-events:auto}

/* ─────────────────────────────────────────────────────────
   A1 · SPLASH
   ───────────────────────────────────────────────────────── */
.splash{background:var(--navy-deep);color:#fff;align-items:center;justify-content:center}
.splash__bg{
  position:absolute;inset:0;background-size:cover;background-position:center 30%;
}
.splash__veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(20,34,74,.45),rgba(20,34,74,.85) 70%,rgba(20,34,74,.95));
}
.splash__center{
  position:relative;z-index:2;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:22px;
  padding:24px;
}
.splash__logo{width:140px;height:auto;filter:drop-shadow(0 10px 30px rgba(0,0,0,.45))}
.splash__wordmark{
  font-family:var(--display);font-size:34px;letter-spacing:.08em;color:#fff;
  line-height:1;margin-top:-6px;
}
.splash__wordmark span{color:var(--red)}
.splash__spinner{
  width:34px;height:34px;border-radius:999px;
  border:2.5px solid rgba(255,255,255,.18);
  border-top-color:#fff;animation:spin 1s linear infinite;
}
.splash__caption{
  margin:0;font-size:13px;color:rgba(255,255,255,.75);letter-spacing:.04em;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─────────────────────────────────────────────────────────
   A2 · WELCOME — mobile-first
   ───────────────────────────────────────────────────────── */
.welcome{flex-direction:column;color:var(--ink);overflow:auto}

.welcome__hero{
  position:relative;height:52%;flex:0 0 auto;overflow:hidden;
  background:var(--navy);
}
.welcome__hero-img{
  position:absolute;inset:0;background-size:cover;background-position:center 25%;
  filter:saturate(1.05) contrast(1.02);
}
.welcome__hero-grad{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(20,34,74,.55) 0%,rgba(20,34,74,.10) 35%,rgba(245,242,236,0) 70%,var(--bone) 100%);
}
.welcome__hero-inner{
  position:relative;z-index:2;height:100%;
  padding:max(env(safe-area-inset-top),24px) 24px 24px;
  display:flex;flex-direction:column;justify-content:space-between;gap:14px;
  color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.45);
}
.welcome__brand{display:flex;align-items:center;gap:14px}
.welcome__brand img{width:48px;height:auto;display:block}
.welcome__brand-name{
  font-family:var(--display);font-size:22px;letter-spacing:.08em;color:#fff;line-height:1;
}
.welcome__brand-name span{color:var(--red)}
.welcome__brand-tag{
  font-size:11px;color:rgba(255,255,255,.7);letter-spacing:.18em;text-transform:uppercase;
}
.welcome__tag{
  margin:0;font-family:var(--display);font-size:34px;line-height:1;letter-spacing:.02em;
}

.welcome__sheet{
  margin-top:-28px;background:var(--bone);
  flex:1;display:flex;flex-direction:column;
  border-top-left-radius:28px;border-top-right-radius:28px;
  position:relative;z-index:3;
  padding:22px 24px max(env(safe-area-inset-bottom),26px);
}
.welcome__card{display:flex;flex-direction:column;max-width:440px;margin:0 auto;width:100%}
.welcome__eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);margin-bottom:6px;
}
.welcome__card h2{
  margin:0 0 6px;font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--ink);
}
.welcome__lead{margin:0 0 16px;color:var(--muted);font-size:14px;line-height:1.5}

.welcome__signup{
  text-align:center;margin:14px 0 12px;font-size:13px;color:var(--muted);
}
.welcome__signup a{color:var(--navy);font-weight:700;text-decoration:none}
.welcome__legal{
  text-align:center;font-size:11px;color:var(--muted);line-height:1.55;
  margin:auto 0 0;padding-top:14px;
}
.welcome__legal a{color:var(--ink-2);text-decoration:underline}

/* ── buttons ────────────────────────────────────────────── */
.btn{
  height:52px;padding:0 18px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border:0;cursor:pointer;background:none;color:inherit;
  border-radius:var(--r-btn);
  font:700 15px/1 var(--sans);letter-spacing:.005em;
  transition:transform .08s, background .15s, box-shadow .15s, border-color .15s;
}
.btn:active{transform:translateY(1px)}
.btn--block{width:100%}
.btn--primary{background:var(--red);color:#fff;
  box-shadow:0 8px 20px -10px rgba(200,32,47,.65)}
.btn--primary:hover{background:var(--red-deep)}
.btn--google{background:#fff;color:#1F1F1F;border:1.5px solid var(--line)}
.btn--google:hover{border-color:#c5cbdc}
.btn--ghost{background:transparent;color:var(--ink-2);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:#c5cbdc;background:rgba(14,21,48,.03)}

/* ── divider ────────────────────────────────────────────── */
.divider{
  display:flex;align-items:center;gap:12px;
  color:var(--muted);font-size:11px;font-weight:700;
  margin:14px 0;letter-spacing:.18em;text-transform:uppercase;
}
.divider::before,.divider::after{
  content:'';flex:1;height:1px;background:var(--line);
}

/* ─────────────────────────────────────────────────────────
   Google Identity Services button slot
   The official iframe button replaces the slot's contents at runtime; the
   placeholder is what users see while GIS loads (or if it fails to load).
   ───────────────────────────────────────────────────────── */
.g-slot{
  position:relative;width:100%;min-height:44px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-btn);overflow:hidden;
}
.g-slot[data-state="ready"]{background:none;min-height:0;overflow:visible}
.g-slot[data-state="ready"] .g-slot__skeleton,
.g-slot[data-state="ready"] .g-slot__hint{display:none}
/* iframes injected by Google. The iframe is now hidden under our custom
   .gg-btn (see overlay rules below) — these defaults just keep the iframe
   sized normally inside its (invisible) slot. */
.g-slot > iframe{margin:0 auto !important;display:block}

/* placeholder shown while GIS loads */
.g-slot__skeleton{
  position:absolute;inset:0;
  background:#fff;border:1.5px solid var(--line);border-radius:var(--r-btn);
}
.g-slot--dark .g-slot__skeleton{
  background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.10);
}
.g-slot__skeleton::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(0,0,0,.04) 50%,
    transparent 100%);
  animation:g-slot-shimmer 1.4s linear infinite;
}
.g-slot--dark .g-slot__skeleton::after{
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.08) 50%,
    transparent 100%);
}
.g-slot__hint{
  position:relative;z-index:1;
  font-size:12.5px;font-weight:600;letter-spacing:.02em;
  color:var(--muted);
}
.g-slot--dark .g-slot__hint{color:rgba(255,255,255,.55)}
/* terminal error states — replace shimmer with a flat warning tone */
.g-slot[data-state="missing-config"] .g-slot__skeleton::after,
.g-slot[data-state="script-failed"]  .g-slot__skeleton::after{animation:none;background:none}
.g-slot[data-state="missing-config"] .g-slot__hint,
.g-slot[data-state="script-failed"]  .g-slot__hint{color:var(--red-deep)}
.g-slot--dark[data-state="missing-config"] .g-slot__hint,
.g-slot--dark[data-state="script-failed"]  .g-slot__hint{color:#FF8089}

@keyframes g-slot-shimmer{
  0%   {transform:translateX(-60%)}
  100% {transform:translateX(60%)}
}

/* ── terms gate: locks Google + email register until consent ────────────
   We wrap the slot so the guard can sit as an absolutely-positioned sibling
   — putting it as a child would not survive Google's iframe re-render which
   wipes .g-slot's children every time renderButton() is called. */
.g-slot-wrap{position:relative}
.g-slot__guard{
  position:absolute;inset:0;z-index:2;
  background:transparent;border:0;padding:0;margin:0;
  border-radius:var(--r-btn);
  pointer-events:none;          /* transparent to clicks by default */
  cursor:not-allowed;
}
.form-card[data-terms-accepted="false"] .g-slot__guard{pointer-events:auto}
.form-card[data-terms-accepted="false"] .g-slot{opacity:.55;filter:saturate(.6)}

/* ─────────────────────────────────────────────────────────
   TikTok login button — sits below the Google slot. Plain DOM
   (no iframe), so we can style it directly.
   ───────────────────────────────────────────────────────── */
.tk-btn{
  margin-top:10px;
  /* Match Google's "size: large" iframe — 40px tall — so all three auth
     buttons (Google + TikTok + email-primary) read as a uniform stack.
     .btn--primary is also pinned to 40px in welcome/form-card contexts
     (see overrides further down) for the same reason. */
  width:100%;height:40px;box-sizing:border-box;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:0 16px;
  font:600 14px/1 'Inter',system-ui,sans-serif;letter-spacing:.01em;
  color:#161823;background:#fff;text-decoration:none;
  border:1.5px solid var(--line);border-radius:var(--r-btn);
  cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .04s ease;
}
.tk-btn:hover{background:#F7F8FA;border-color:#cfd4dc}
.tk-btn:active{transform:translateY(1px)}
.tk-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.tk-btn__logo{flex:0 0 auto;display:block}
/* Match Google's `filled_black` theme exactly: pure black bg, no border,
   white text. Keeps the two social buttons reading as a pair on the dark
   form-card screens (login / register). */
.tk-btn--dark{
  color:#fff;background:#000;border-color:#000;
}
.tk-btn--dark:hover{background:#1A1A1A;border-color:#1A1A1A}
/* On the register screen the same terms gate that locks Google also locks
   TikTok. Keep pointer-events on so register.js's nudge handler still fires
   and bumps the checkbox instead of silently swallowing the click. */
.form-card[data-terms-accepted="false"] .tk-btn{
  opacity:.55;filter:saturate(.6);cursor:not-allowed;
}

/* ─────────────────────────────────────────────────────────
   Custom Google button — visually identical to .tk-btn. The native GSI
   iframe is hidden in an invisible overlay on top of this button so the
   real Google sign-in popup still fires from a trusted user gesture, but
   the user sees our own pixel-perfect button.
   ───────────────────────────────────────────────────────── */
.gg-btn-wrap{position:relative;margin-top:10px}
.gg-btn{
  /* Same dimensions + typography as .tk-btn — the two MUST stay in sync. */
  width:100%;height:40px;box-sizing:border-box;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:0 16px;
  font:600 14px/1 'Inter',system-ui,sans-serif;letter-spacing:.01em;
  color:#161823;background:#fff;text-decoration:none;
  border:1.5px solid var(--line);border-radius:var(--r-btn);
  cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .04s ease;
}
.gg-btn:hover{background:#F7F8FA;border-color:#cfd4dc}
.gg-btn:active{transform:translateY(1px)}
.gg-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.gg-btn__logo{flex:0 0 auto;display:block}
.gg-btn--dark{
  color:#fff;background:#000;border-color:#000;
}
.gg-btn--dark:hover{background:#1A1A1A;border-color:#1A1A1A}

/* The real GSI iframe — sized to the wrap, fully transparent, on top so it
   intercepts the click. Pointer-events stay default so the iframe receives
   the click as a trusted user gesture (needed for the Google popup to open). */
.gg-btn__overlay{
  position:absolute;inset:0;
  opacity:0;
  z-index:2;
  /* The skeleton/hint inside .g-slot is meaningless when invisible — also
     suppresses any visual leak before GSI replaces them. */
  pointer-events:auto;
}
.gg-btn__overlay .g-slot__skeleton,
.gg-btn__overlay .g-slot__hint{display:none}

/* Terms gate on register: disable ONLY the overlay so clicks fall through to
   the visible .gg-btn underneath — register.js attaches a handler there that
   nudges the terms checkbox instead of silently dropping the click. */
.form-card[data-terms-accepted="false"] .gg-btn__overlay{
  pointer-events:none;
}
.form-card[data-terms-accepted="false"] .gg-btn{
  opacity:.55;filter:saturate(.6);cursor:not-allowed;
}

/* Pin the email-primary CTA in the auth stack to the same 40px height as the
   Google iframe + TikTok button so the three rows line up. Outside the auth
   screens the default 52px .btn height still applies. */
.welcome__card .btn--primary,
.form-card    .btn--primary{
  height:40px;
  font-size:14px;
  padding:0 16px;
  letter-spacing:.01em;
}

/* ── nudge animation when the user clicks a gated control ───────────── */
.check--nudge{animation:check-nudge .42s ease-out}
.check--nudge .check__box{
  border-color:var(--red);
  box-shadow:0 0 0 4px rgba(200,32,47,.18);
}
@keyframes check-nudge{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-5px)}
  40%,80%{transform:translateX(5px)}
}

/* ─────────────────────────────────────────────────────────
   Desktop split layout — kicks in at ≥ 900px
   ───────────────────────────────────────────────────────── */
@media (min-width:900px){
  .welcome{flex-direction:row;overflow:hidden}

  .welcome__hero{
    height:100%;flex:1.05 1 0;
  }
  .welcome__hero-grad{
    background:
      linear-gradient(180deg,rgba(20,34,74,.32) 0%,rgba(20,34,74,.15) 50%,rgba(20,34,74,.78) 100%),
      linear-gradient(90deg,rgba(20,34,74,.15) 0%,rgba(20,34,74,.55) 100%);
  }
  .welcome__hero-inner{padding:56px;justify-content:space-between;gap:32px}
  .welcome__brand img{width:56px}
  .welcome__brand-name{font-size:28px}
  .welcome__tag{font-size:68px;line-height:.95}

  .welcome__sheet{
    margin-top:0;flex:1 1 0;
    border-radius:0;
    padding:56px;
    display:flex;align-items:center;justify-content:center;
    background:var(--bone);
  }
  .welcome__card{max-width:420px}
  .welcome__card h2{font-size:32px}
  .welcome__lead{font-size:15px;margin-bottom:22px}

  .splash__logo{width:170px}
  .splash__wordmark{font-size:44px}
}

/* very small screens */
@media (max-height:640px) and (max-width:480px){
  .welcome__hero{height:44%}
  .welcome__tag{font-size:28px}
}

/* ─────────────────────────────────────────────────────────
   A3 · REGISTER — form screen
   ───────────────────────────────────────────────────────── */
.form-screen{
  background:var(--navy-deep);color:var(--ink);
  flex-direction:column;overflow:auto;
  -webkit-overflow-scrolling:touch;
}
.form-screen__bg{
  position:fixed;inset:0;z-index:0;
  background-size:cover;background-position:center 30%;
  opacity:.32;filter:saturate(1.05);
}
.form-screen__veil{
  position:fixed;inset:0;z-index:0;
  background:
    radial-gradient(900px 600px at 50% -10%,rgba(200,32,47,.18),transparent 60%),
    linear-gradient(180deg,rgba(20,34,74,.85),rgba(10,18,38,.95));
}
.form-screen__inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;
  min-height:100%;width:100%;
}

.topbar{
  position:sticky;top:0;z-index:5;
  display:grid;grid-template-columns:42px 1fr 42px;align-items:center;
  padding:calc(env(safe-area-inset-top) + 14px) 18px 12px;
  background:linear-gradient(180deg,rgba(10,18,38,.92),rgba(10,18,38,.65) 70%,transparent);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
}
.topbar__back{
  width:38px;height:38px;border-radius:999px;
  background:rgba(255,255,255,.10);color:#fff;
  border:0;display:grid;place-items:center;cursor:pointer;
  transition:background .15s;
}
.topbar__back:hover{background:rgba(255,255,255,.18)}
.topbar__title{
  text-align:center;font-size:14px;font-weight:700;color:#fff;
  letter-spacing:.01em;
}
.topbar__spacer{width:38px}

.form-card{
  width:100%;max-width:440px;margin:8px auto auto;
  padding:14px 24px 28px;
  display:flex;flex-direction:column;
}
.form-card[hidden]{display:none}
.form-card__eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);margin-bottom:6px;
}
.form-card h2{
  margin:0 0 6px;color:#fff;
  font-size:26px;font-weight:800;letter-spacing:-.02em;line-height:1.15;
}
.form-card__lead{
  margin:0 0 18px;color:rgba(231,233,242,.7);font-size:14px;line-height:1.5;
}

.form{display:flex;flex-direction:column;gap:0}

/* ── fields (dark-on-bone variants live on card; here we sit on navy) ── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field-row .field{margin-bottom:14px}
@media (max-width:380px){
  .field-row{grid-template-columns:1fr}
}
.field__label{
  font-size:11px;font-weight:700;letter-spacing:.08em;
  color:rgba(255,255,255,.78);text-transform:uppercase;
}
.field__wrap{position:relative}
.field input{
  width:100%;box-sizing:border-box;
  height:50px;padding:0 16px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.10);
  border-radius:var(--r-fld);
  font:500 15px/1 var(--sans);color:#fff;outline:none;
  transition:border-color .15s, background .15s;
}
.field input::placeholder{color:rgba(255,255,255,.35)}
.field input:focus{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.4);
}
.field__eye{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:none;border:0;padding:8px;cursor:pointer;color:rgba(255,255,255,.7);
}
.field__eye:hover{color:#fff}
.field--error input{border-color:var(--red);background:rgba(200,32,47,.10)}
.field--ok input{border-color:rgba(31,138,91,.65);background:rgba(31,138,91,.10)}
.field__err{
  color:#FF8089;font-size:12px;font-weight:600;
  display:flex;gap:6px;align-items:center;
}
.field__err[hidden]{display:none}
.field__err::before{
  content:'!';width:14px;height:14px;border-radius:999px;
  background:var(--red);color:#fff;font-size:10px;font-weight:800;
  display:grid;place-items:center;
}
.field__help{font-size:12px;color:rgba(231,233,242,.55)}

/* ── password strength meter ──────────────────────────── */
.strength{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:8px}
.strength i{height:4px;border-radius:99px;background:rgba(255,255,255,.10)}
.strength--s1 i:nth-child(-n+1){background:var(--red)}
.strength--s2 i:nth-child(-n+2){background:var(--warning)}
.strength--s3 i:nth-child(-n+3){background:#6BA56F}
.strength--s4 i:nth-child(-n+4){background:var(--success)}
.strength__label{
  margin-top:6px;font-size:11px;color:rgba(231,233,242,.55);
  display:flex;justify-content:space-between;
}
.strength__label b{color:#fff;font-weight:700}

/* ── consent checkboxes ───────────────────────────────── */
.check{
  display:flex;gap:12px;align-items:flex-start;
  padding:10px 0;font-size:13px;line-height:1.5;
  color:rgba(231,233,242,.85);cursor:pointer;
}
.check--quiet{color:rgba(231,233,242,.65);font-size:12.5px}
.check input{display:none}
.check__box{
  width:22px;height:22px;border-radius:6px;
  border:1.5px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.06);flex-shrink:0;margin-top:1px;
  display:grid;place-items:center;transition:background .15s, border-color .15s;
}
.check__box svg{opacity:0}
.check input:checked + .check__box{background:var(--red);border-color:var(--red)}
.check input:checked + .check__box svg{opacity:1}
.check[data-field="terms"].is-error .check__box{border-color:var(--red);background:rgba(200,32,47,.12)}
.check a{color:#fff;font-weight:700;text-decoration:underline;text-decoration-color:rgba(255,255,255,.4)}
.check a:hover{text-decoration-color:#fff}

/* ── banner (top-level submit error) ──────────────────── */
.form-banner{
  margin:6px 0 12px;padding:11px 14px;border-radius:10px;
  font-size:13px;line-height:1.45;
}
.form-banner--err{background:rgba(200,32,47,.14);color:#FFB4BA;border:1px solid rgba(200,32,47,.35)}
.form-banner--ok{background:rgba(31,138,91,.18);color:#A8E6C8;border:1px solid rgba(31,138,91,.45)}

/* ── submit ───────────────────────────────────────────── */
#register-submit, #login-submit{margin-top:8px}
#register-submit[disabled], #login-submit[disabled]{opacity:.6;cursor:not-allowed}
#register-submit.is-loading, #login-submit.is-loading{position:relative;color:transparent}
#register-submit.is-loading::after, #login-submit.is-loading::after{
  content:'';position:absolute;width:18px;height:18px;border-radius:999px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  animation:spin .8s linear infinite;
}

/* ── login extras: remember toggle + forgot link ──────── */
.row-between{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin:2px 0 14px;
}
.toggle{display:inline-flex;align-items:center;gap:10px;font-size:13px;color:rgba(231,233,242,.85);cursor:pointer;user-select:none}
.toggle input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.toggle__dot{
  width:36px;height:20px;border-radius:99px;
  background:rgba(255,255,255,.16);
  position:relative;transition:background .15s;flex-shrink:0;
}
.toggle__dot::after{
  content:'';position:absolute;top:2px;left:2px;
  width:16px;height:16px;border-radius:999px;background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.35);transition:left .15s;
}
.toggle input:checked + .toggle__dot{background:var(--red)}
.toggle input:checked + .toggle__dot::after{left:18px}
.toggle input:focus-visible + .toggle__dot{
  box-shadow:0 0 0 3px rgba(200,32,47,.30);
}
.link{
  color:#fff;font-weight:600;text-decoration:none;font-size:13px;
  opacity:.85;
}
.link:hover{opacity:1;text-decoration:underline}

/* ─────────────────────────────────────────────────────────
   League select + home (post-auth screens)
   ───────────────────────────────────────────────────────── */

/* topbar variant: title centred, action on the right */
.topbar--end{grid-template-columns:38px 1fr 42px}

/* light-ghost button on dark form-screen */
.btn--ghost-light{
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.20);
}
.btn--ghost-light:hover{border-color:rgba(255,255,255,.40);background:rgba(255,255,255,.05)}

/* state machine — only one of {loading,error,empty,ready} is visible */
.leagues-state,.leagues-list{display:none}
#screen-league-select[data-state="loading"] .leagues-state--loading,
#screen-league-select[data-state="error"]   .leagues-state--error,
#screen-league-select[data-state="empty"]   .leagues-state--empty,
#screen-league-select[data-state="ready"]   .leagues-list{display:block}

.leagues-state{
  text-align:center;padding:24px 0;color:rgba(231,233,242,.7);
}
.leagues-state .splash__spinner{margin:0 auto 14px}
.leagues-state p{margin:0 0 14px;font-size:14px;line-height:1.5}
.leagues-state--error p,.leagues-state--empty p{margin-bottom:18px}

/* league list */
.leagues-list{display:grid;gap:10px;margin-top:6px}
.league-card{
  display:grid;grid-template-columns:48px 1fr 22px;align-items:center;gap:14px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.10);
  border-radius:14px;
  padding:12px 14px;
  cursor:pointer;text-align:left;
  color:#fff;font:inherit;
  transition:background .15s, border-color .15s, transform .08s;
}
.league-card:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22)}
.league-card:active{transform:translateY(1px)}
.league-card__logo{
  width:48px;height:48px;border-radius:10px;background:#fff;
  display:grid;place-items:center;flex-shrink:0;
  color:var(--navy);font-weight:800;font-size:14px;letter-spacing:.04em;
  overflow:hidden;
}
.league-card__logo img{width:100%;height:100%;object-fit:contain;padding:6px;display:block}
.league-card__meta{min-width:0}
.league-card__name{
  font-size:15px;font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.league-card__sub{
  font-size:12px;color:rgba(255,255,255,.55);margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.league-card__chev{color:rgba(255,255,255,.4);justify-self:end}

/* topbar action button variant (accent / create button) */
.topbar__back--accent{
  background:var(--red);color:#fff;
}
.topbar__back--accent:hover{background:var(--red-deep)}

/* ═════════════════════════════════════════════════════════
   v2 LEAGUES — light-theme list (mobile-first)
   ═════════════════════════════════════════════════════════ */
.mv2-screen{background:var(--bone)}
.mv2{
  background:var(--bone);color:var(--ink);
  display:flex;flex-direction:column;
  /* fill the .screen parent (which is position:absolute; inset:0) */
  position:absolute;inset:0;
  overflow:hidden;
}

/* ── top app bar ─────────────────────────────────── */
.mv2__top{
  padding:max(env(safe-area-inset-top),18px) 18px 12px;
  background:#fff;border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;
  position:relative;z-index:5;flex-shrink:0;
}
.mv2__row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.mv2__title-block{flex:1;min-width:0}
.mv2__title{
  margin:0;font:800 22px/1.1 var(--sans);color:var(--ink);letter-spacing:-.02em;
}
.mv2__title-row{display:flex;align-items:baseline;gap:8px}
.mv2__count{font-size:11px;color:var(--muted);font-weight:600}

.mv2__icbtn{
  width:36px;height:36px;border-radius:99px;background:var(--field);
  border:0;display:grid;place-items:center;cursor:pointer;color:var(--ink);
  flex-shrink:0;
}
.mv2__icbtn--solid{background:var(--ink);color:#fff}
.mv2__icbtn--solid:active{background:#000}
.mv2__icbtn--ghost{background:transparent;color:var(--ink-2)}
.mv2__icbtn--ghost:hover{background:var(--field)}

/* search */
.mv2__search{
  height:40px;background:var(--field);border:0;border-radius:10px;
  display:flex;align-items:center;gap:8px;padding:0 12px;
}
.mv2__search input{
  flex:1;border:0;outline:0;background:transparent;
  font:500 14px/1 var(--sans);color:var(--ink);min-width:0;
}
.mv2__search input::placeholder{color:#9CA3B5}
.mv2__search svg{color:var(--muted);flex-shrink:0}

/* segment tabs */
.mv2__seg{
  display:flex;gap:0;padding:0 18px;background:#fff;
  border-bottom:1px solid var(--line);
  overflow-x:auto;scrollbar-width:none;flex-shrink:0;
}
.mv2__seg::-webkit-scrollbar{display:none}
.mv2__seg button{
  background:transparent;border:0;cursor:pointer;flex-shrink:0;
  padding:10px 12px 12px;color:var(--muted);font:700 12.5px/1 var(--sans);
  border-bottom:2px solid transparent;margin-bottom:-1px;
  display:inline-flex;align-items:center;gap:5px;
}
.mv2__seg button.is-active{color:var(--ink);border-bottom-color:var(--ink)}
.mv2__seg .n{
  font-size:10px;background:var(--field);padding:1px 6px;border-radius:99px;
  color:var(--muted);font-weight:700;font-variant-numeric:tabular-nums;
}
.mv2__seg button.is-active .n{background:var(--ink);color:#fff}

/* ── list body ──────────────────────────────────── */
.mv2__body{
  flex:1 1 0;min-height:0;overflow:auto;
  padding:0 0 84px;background:var(--bone);
  -webkit-overflow-scrolling:touch;
}
.mv2__list{list-style:none;margin:0;padding:0;background:#fff;display:none}
#screen-leagues-list[data-state="ready"] .mv2__list{display:block}

/* state machine */
.mv2__state{display:none;text-align:center;padding:24px 18px;color:var(--muted);font-size:14px}
.mv2__state p{margin:0 0 14px}
#screen-leagues-list[data-state="loading"] .mv2__state--loading{display:block}
#screen-leagues-list[data-state="error"]   .mv2__state--error{display:block}
#screen-leagues-list[data-state="empty"][data-view="all"]  .mv2__state--empty{display:block}
#screen-leagues-list[data-state="empty"][data-view="mine"] .mv2__state--empty-mine{display:block}

.mv2__btn{
  height:44px;padding:0 22px;border-radius:10px;
  background:#fff;border:1px solid var(--line);color:var(--ink);
  font:700 13px/1 var(--sans);cursor:pointer;
}
.mv2__btn--solid{background:var(--ink);color:#fff;border-color:var(--ink)}
.mv2__btn--solid:active{background:#000}
.mv2__btn--block{width:100%}

/* empty state card */
.mv2__empty-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:32px 22px;margin:18px 18px 0;
  display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;
}
.mv2__empty-glyph{
  width:64px;height:64px;border-radius:99px;background:var(--field);
  display:grid;place-items:center;color:var(--ink-2);margin-bottom:4px;
}
.mv2__empty-card h3{margin:0;font:800 16px/1.2 var(--sans);color:var(--ink);letter-spacing:-.01em}
.mv2__empty-card p{margin:0 0 8px;font-size:13px;color:var(--muted);line-height:1.5}
.mv2__empty-card .mv2__btn{margin-top:4px}

.mv2__filter-empty{
  display:none;text-align:center;padding:24px 18px;color:var(--muted);font-size:13px;
}
.mv2__filter-empty.is-empty{display:block}

/* ── row item ──────────────────────────────────── */
.mrow2{
  display:grid;grid-template-columns:36px 1fr auto;gap:12px;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--line);
  position:relative;
}
.mrow2:active{background:#FAFAF7}
.mrow2:last-child{border-bottom:0}

.mrow2__av{
  width:36px;height:36px;border-radius:9px;
  display:grid;place-items:center;flex-shrink:0;
  font-family:var(--display);font-size:14px;letter-spacing:.04em;color:#fff;
  background:var(--ink);
}
.mrow2__av--red  {background:var(--red)}
.mrow2__av--navy {background:var(--navy)}
.mrow2__av--gold {background:#9b6f10}
.mrow2__av--green{background:#1F8A5B}
.mrow2__av--mute {background:#6B7390}

.mrow2__body{min-width:0;display:flex;flex-direction:column;gap:3px}
.mrow2__name{
  display:flex;align-items:center;gap:5px;
  font:700 14px/1.2 var(--sans);color:var(--ink);letter-spacing:-.01em;
  min-width:0;
}
.mrow2__name-text{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;
}
.mrow2__name .lk{width:10px;height:10px;color:var(--muted);flex-shrink:0}
.mrow2__meta{
  color:var(--muted);font-size:11.5px;line-height:1.3;
  display:flex;align-items:center;gap:0;flex-wrap:wrap;
}
.mrow2__meta > * + *::before{
  content:'·';display:inline-block;margin:0 5px;color:#C8CBD8;
}
.mrow2__meta .t{font-weight:700;color:var(--ink-2)}
.mrow2__meta .t--sponsor{color:#9b6f10}
.mrow2__meta .t--h2h{color:var(--red-deep)}
.mrow2__meta .t--gw{color:var(--ink-2);font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;gap:3px}
.mrow2__meta .t--gw .ico-gw{width:12px;height:12px;color:var(--muted);flex-shrink:0}
.mrow2__meta .you{color:var(--red-deep);font-weight:700}
.mrow2__msg{
  color:var(--ink-2);font-size:12px;line-height:1.35;font-style:italic;
  margin-top:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* bottom strip: members + status */
.mrow2__btm{
  display:flex;align-items:center;gap:8px;margin-top:4px;font-size:11px;
}
.mrow2__btm .mnum{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums}
.mrow2__btm .mnum span{color:var(--muted);font-weight:500}
.mrow2__btm .mbar{
  width:48px;height:3px;background:var(--line);border-radius:99px;overflow:hidden;flex-shrink:0;
}
.mrow2__btm .mbar i{display:block;height:100%;background:var(--ink);border-radius:99px}
.mrow2__btm .mbar.full i{background:var(--red)}
.mrow2__btm .mstat{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;
  color:var(--muted);
}
.mrow2__btm .mstat::before{
  content:'';width:6px;height:6px;border-radius:99px;background:currentColor;
}
.mrow2__btm .mstat--live{color:var(--success)}
.mrow2__btm .mstat--live::before{
  animation:mlp 1.6s infinite;box-shadow:0 0 0 0 rgba(31,138,91,.5);
}
@keyframes mlp{
  0%{box-shadow:0 0 0 0 rgba(31,138,91,.5)}
  70%{box-shadow:0 0 0 4px rgba(31,138,91,0)}
  100%{box-shadow:0 0 0 0 rgba(31,138,91,0)}
}
.mrow2__btm .mstat--full{color:var(--red-deep)}

/* action button */
.mrow2__act{
  height:32px;padding:0 14px;border-radius:8px;
  font:700 12px/1 var(--sans);border:1px solid transparent;cursor:pointer;
  display:inline-flex;align-items:center;gap:4px;flex-shrink:0;
}
.mrow2__act svg{width:11px;height:11px}
.mrow2__act--join  {background:var(--ink);color:#fff;border-color:var(--ink)}
.mrow2__act--join:active{background:#000}
.mrow2__act--lock  {background:#fff;color:var(--ink);border-color:var(--line)}
.mrow2__act--full  {background:var(--field);color:var(--muted);border-color:var(--line);cursor:not-allowed}
.mrow2__act--open  {background:#fff;color:var(--ink);border-color:var(--line)}
.mrow2__act--manage{background:rgba(200,32,47,.10);color:var(--red-deep);border-color:transparent}

.mrow2__ico{
  width:32px;height:32px;border-radius:8px;border:1px solid var(--line);
  background:#fff;color:var(--muted);display:grid;place-items:center;cursor:pointer;flex-shrink:0;
}
.mrow2__ico:hover{color:var(--red-deep);border-color:var(--red)}
.mrow2__ico svg{width:13px;height:13px}

/* ── bottom tab bar ─────────────────────────────── */
.mv2__tabs{
  position:absolute;bottom:0;left:0;right:0;
  height:calc(62px + env(safe-area-inset-bottom));
  background:#fff;border-top:1px solid var(--line);
  display:grid;grid-auto-flow:column;grid-auto-columns:1fr;
  padding-bottom:env(safe-area-inset-bottom);
  z-index:6;
}
.mv2__tabs a{
  text-decoration:none;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  font-size:10px;font-weight:600;letter-spacing:.04em;
  position:relative;cursor:pointer;
}
.mv2__tabs a.is-active{color:var(--ink)}
.mv2__tabs a.is-active::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:24px;height:2px;background:var(--ink);border-radius:0 0 2px 2px;
}
.mv2__tabs a[data-disabled="1"]{opacity:.4;pointer-events:none}
.mv2__tabs svg{width:18px;height:18px;display:block}
.mv2__tabs .tbadge{
  position:absolute;top:8px;right:50%;margin-right:-22px;
  background:var(--ink);color:#fff;font-size:9px;font-weight:800;
  padding:0 5px;border-radius:99px;line-height:14px;min-width:14px;text-align:center;
}
.mv2__tabs a.is-active .tbadge{background:var(--red)}

/* Global "Lig değiştir" button — body-level, pinned to top-right.
   Hidden by default; JS reveals it once an active league exists. */
#sb-change-league{
  display:none;
  position:fixed;top:12px;right:18px;z-index:9999;
  align-items:center;gap:6px;
  height:38px;padding:0 16px 0 12px;
  border:0;border-radius:99px;cursor:pointer;
  background:var(--ink);color:#fff;
  font:700 13px/1 var(--sans);letter-spacing:-.01em;
  box-shadow:0 4px 14px rgba(14,21,48,.35);
}
#sb-change-league:hover{background:#000}
#sb-change-league svg{flex-shrink:0}

/* Corner button replaces these — hide the header's back-chevron and title. */
.mv2__top .mv2__icbtn[data-action="back-to-active"],
.mv2__top .mv2__title-block{display:none}
.mv2__top .mv2__row{justify-content:flex-end}

/* ── desktop: convert bottom tabs into a top nav bar ───── */
@media (min-width:760px){
  .mv2__tabs{
    position:relative;order:-1;
    height:56px;left:auto;right:auto;bottom:auto;
    padding-bottom:0;
    border-top:0;border-bottom:1px solid var(--line);
    grid-auto-flow:column;grid-auto-columns:auto;
    justify-content:flex-start;column-gap:6px;
    padding-left:18px;padding-right:18px;
  }
  .mv2__tabs a{
    flex-direction:row;gap:8px;
    padding:0 14px;font-size:13px;font-weight:700;letter-spacing:-.01em;
    border-radius:8px;
  }
  .mv2__tabs a:hover{background:var(--field);color:var(--ink)}
  .mv2__tabs a.is-active::before{
    top:auto;bottom:0;width:60%;height:2px;border-radius:2px 2px 0 0;
  }
  .mv2__tabs svg{width:16px;height:16px}
  .mv2__tabs .tbadge{
    position:static;margin:0;line-height:16px;min-width:16px;font-size:10px;padding:0 6px;
  }
  .mv2__body{padding-bottom:0}

  /* Wide screens: surface the create button with the i18n label. */
  .mv2__top .mv2__icbtn[data-action="open-create"]{
    width:auto;padding:0 14px;border-radius:10px;gap:6px;
  }
  .mv2__top .mv2__icbtn[data-action="open-create"] svg{display:none}
  .mv2__top .mv2__icbtn[data-action="open-create"] .mv2__icbtn-label{
    font:700 13px/1 var(--sans);letter-spacing:-.01em;color:#fff;
  }
}
.mv2__icbtn-label{display:none}
@media (min-width:760px){
  .mv2__top .mv2__icbtn[data-action="open-create"] .mv2__icbtn-label{display:inline}
}

/* ═════════════════════════════════════════════════════════
   Bottom-sheet modal (create league + join private)
   ═════════════════════════════════════════════════════════ */
.ms-backdrop{
  /* Viewport-level overlay so the modal works from any parent — both for
     the in-leagues-list create-modal and the body-level join-private. */
  position:fixed;inset:0;
  background:rgba(14,21,48,.45);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  display:flex;align-items:flex-end;justify-content:center;z-index:150;
}
.ms-backdrop[hidden]{display:none}
.ms{
  width:100%;max-width:520px;background:#fff;
  border-radius:18px 18px 0 0;
  padding:8px 16px max(env(safe-area-inset-bottom),24px);
  max-height:92%;
  display:flex;flex-direction:column;
  animation:msSlide .25s cubic-bezier(.2,.7,.2,1);
}
@keyframes msSlide{from{transform:translateY(100%)}to{transform:none}}
.ms__grab{
  width:36px;height:4px;border-radius:99px;background:var(--line);
  margin:6px auto 14px;flex-shrink:0;
}
.ms__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
  margin-bottom:14px;flex-shrink:0;
}
.ms__head h2{margin:0;font:800 18px/1.1 var(--sans);color:var(--ink);letter-spacing:-.01em}
.ms__head p{margin:4px 0 0;font-size:12px;color:var(--muted)}
.ms__close{
  width:32px;height:32px;border-radius:99px;background:var(--field);border:0;
  color:var(--ink);display:grid;place-items:center;cursor:pointer;flex-shrink:0;
}
.ms__body{
  flex:1;overflow:auto;display:flex;flex-direction:column;gap:14px;
  padding-right:2px;-webkit-overflow-scrolling:touch;
}
.ms__group{display:flex;flex-direction:column}
.ms__group .lbl{
  display:block;font:700 10.5px/1 var(--sans);letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-2);margin-bottom:7px;
}
.ms__input{
  width:100%;height:40px;padding:0 12px;
  background:#fff;border:1px solid var(--line);border-radius:9px;
  font:500 14px/1 var(--sans);color:var(--ink);outline:0;
  box-sizing:border-box;
}
.ms__input:focus{border-color:var(--ink)}
.ms__textarea{
  width:100%;min-height:54px;padding:10px 12px;resize:vertical;
  background:#fff;border:1px solid var(--line);border-radius:9px;
  font:500 13.5px/1.5 var(--sans);color:var(--ink);outline:0;
  font-family:var(--sans);box-sizing:border-box;
}
.ms__textarea:focus{border-color:var(--ink)}
.ms__hint{margin-top:5px;font-size:11px;color:var(--muted)}
.ms__hint.ok{color:var(--success);font-weight:600}
.ms__hint[data-err]:not([hidden]){color:var(--red-deep);font-weight:600}
.ms__group.is-error .ms__input,
.ms__group.is-error .ms__textarea{border-color:var(--red)}

/* type radios */
.ms__type{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.ms__type label{
  cursor:pointer;border:1px solid var(--line);border-radius:9px;
  padding:10px 12px;background:#fff;
  display:flex;flex-direction:column;gap:2px;position:relative;
  transition:border-color .15s, background .15s;
}
.ms__type input{position:absolute;opacity:0;pointer-events:none}
.ms__type label.is-on{border-color:var(--ink);background:var(--field)}
.ms__type b{font:700 13px/1.1 var(--sans);color:var(--ink)}
.ms__type span{font-size:11px;color:var(--muted);line-height:1.35}

/* slider header + value */
.ms__sh{
  display:flex;align-items:baseline;justify-content:space-between;gap:8px;
  margin-bottom:8px;
}
.ms__sh .lbl{margin-bottom:0}
.ms__sv{
  font:600 12px/1 var(--sans);color:var(--muted);font-variant-numeric:tabular-nums;
  display:inline-flex;align-items:baseline;gap:3px;
}
.ms__sv b{
  font-family:var(--display);font-size:20px;color:var(--ink);font-weight:400;
  letter-spacing:.04em;line-height:1;
}
.ms__sv .lt{color:#C8CBD8;padding:0 1px;font-size:12px}
.ms__sv .tick{color:var(--success);font-weight:800;margin-left:3px}
.ms__sv .warn{
  color:var(--red-deep);font-weight:700;margin-left:3px;
  font-size:10px;letter-spacing:.04em;text-transform:uppercase;
}

.ms__range{
  -webkit-appearance:none;appearance:none;width:100%;height:24px;
  background:transparent;cursor:pointer;outline:0;margin:0;
}
.ms__range::-webkit-slider-runnable-track{
  height:4px;border-radius:99px;
  background:linear-gradient(to right,
    var(--ink) 0%, var(--ink) var(--p,0%),
    var(--line) var(--p,0%), var(--line) 100%);
}
.ms__range::-moz-range-track{
  height:4px;border-radius:99px;border:0;
  background:linear-gradient(to right,
    var(--ink) 0%, var(--ink) var(--p,0%),
    var(--line) var(--p,0%), var(--line) 100%);
}
.ms__range::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:20px;height:20px;border-radius:99px;
  background:#fff;border:2px solid var(--ink);margin-top:-8px;
  box-shadow:0 1px 4px rgba(0,0,0,.18);
}
.ms__range::-moz-range-thumb{
  width:20px;height:20px;border-radius:99px;
  background:#fff;border:2px solid var(--ink);
  box-shadow:0 1px 4px rgba(0,0,0,.18);
}
.ms__bounds{
  display:flex;justify-content:space-between;margin-top:4px;
  font-size:10px;color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums;
}
.ms__group.is-locked .ms__range{opacity:.45;cursor:not-allowed}
.ms__group.is-locked .ms__bounds{opacity:.45}

/* week tile grid */
.ms__weeks{
  display:grid;grid-template-columns:repeat(auto-fill, 36px);gap:6px;
  justify-content:space-between;
}
.mtile{
  width:36px;height:36px;
  background:#fff;border:1px solid var(--line);border-radius:8px;
  font:600 14px/1 var(--sans);color:var(--muted);cursor:pointer;
  display:grid;place-items:center;padding:0;
  font-variant-numeric:tabular-nums;user-select:none;
  transition:background .12s,color .12s,border-color .12s;
}
.mtile.in-range{
  background:rgba(14,21,48,.18);color:var(--ink);
  border-color:rgba(14,21,48,.25);font-weight:700;
}
.mtile.is-start,.mtile.is-end{
  background:var(--ink);color:#fff;border-color:var(--ink);font-weight:800;
}
.mtile.is-preview{
  background:rgba(14,21,48,.10);border-color:rgba(14,21,48,.20);color:var(--ink-2);
}
.mtile.is-disabled{
  background:#FAFAF7;color:#C8CBD8;border-color:var(--line);
  cursor:not-allowed;text-decoration:line-through;opacity:.7;
}

/* privacy row */
.ms__priv{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px;background:var(--field);border-radius:10px;
}
.ms__priv-txt b{display:block;font:700 13px/1.2 var(--sans);color:var(--ink);margin-bottom:1px}
.ms__priv-txt span{font-size:11px;color:var(--muted);line-height:1.3}
.ms__toggle{
  width:40px;height:22px;background:var(--line);border-radius:99px;
  position:relative;cursor:pointer;flex-shrink:0;border:0;transition:background .18s;
  padding:0;
}
.ms__toggle::after{
  content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:99px;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.18);transition:transform .18s;
}
.ms__toggle.is-on{background:var(--ink)}
.ms__toggle.is-on::after{transform:translateX(18px)}

/* footer */
.ms__foot{
  display:flex;gap:8px;padding-top:14px;margin-top:8px;
  border-top:1px solid var(--line);flex-shrink:0;
}
.ms__foot button{
  flex:1;height:46px;border-radius:10px;border:1px solid transparent;
  font:800 13.5px/1 var(--sans);cursor:pointer;
}
.ms__foot .ghost{background:#fff;color:var(--ink-2);border-color:var(--line);flex:0 0 100px}
.ms__foot .pri{background:var(--ink);color:#fff;border-color:var(--ink)}
.ms__foot .pri[disabled]{opacity:.55;cursor:not-allowed}
.ms__foot .pri.is-loading{position:relative;color:transparent}
.ms__foot .pri.is-loading::after{
  content:'';position:absolute;left:50%;top:50%;
  width:16px;height:16px;border-radius:999px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  transform:translate(-50%,-50%);
  animation:spin .8s linear infinite;
}

.ms--compact{padding-bottom:max(env(safe-area-inset-bottom),20px)}

/* ── form-banner colour tweak for light-theme modals ─── */
.ms .form-banner--err{
  background:rgba(200,32,47,.08);color:var(--red-deep);
  border:1px solid rgba(200,32,47,.25);
}

/* desktop polish — wider card, fixed sidebar room */
@media (min-width:900px){
  .ms-backdrop{align-items:center}
  .ms{
    max-width:540px;border-radius:14px;
    padding:12px 22px 22px;max-height:84vh;
  }
  .ms__weeks{grid-template-columns:repeat(auto-fill, 36px);gap:8px}
  .mtile{width:36px;height:36px;font-size:14px;border-radius:8px}
}

/* ─────────────────────────────────────────────────────────
   B1 · LEAGUES LIST
   ───────────────────────────────────────────────────────── */
.ll-inner{padding-bottom:40px}
.ll-body{
  width:100%;max-width:520px;margin:0 auto;
  padding:8px 24px 24px;display:flex;flex-direction:column;
}
.ll-head h2{
  margin:8px 0 4px;color:#fff;font-size:22px;font-weight:800;letter-spacing:-.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* filter chips (horizontal scroll on small screens) */
.ll-chips{
  display:flex;gap:8px;overflow-x:auto;
  margin:14px -24px 16px;padding:2px 24px 6px;
  scrollbar-width:none;
}
.ll-chips::-webkit-scrollbar{display:none}
.chip{
  display:inline-flex;align-items:center;gap:6px;flex-shrink:0;
  height:32px;padding:0 14px;border-radius:99px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.85);
  font:600 12.5px/1 var(--sans);letter-spacing:.02em;
  cursor:pointer;transition:background .15s, border-color .15s, color .15s;
}
.chip:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18)}
.chip.is-active{background:#fff;color:var(--navy);border-color:#fff}

/* card list */
.ll-list,.ll-empty-filter{display:none}
#screen-leagues-list[data-state="ready"] .ll-list{display:grid;gap:12px}
.ll-empty-filter{
  text-align:center;padding:18px 0;color:rgba(231,233,242,.55);font-size:13px;
}
#screen-leagues-list[data-state="ready"] .ll-empty-filter.is-empty{display:block}

.ll-card{
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.10);
  border-radius:16px;
  padding:14px;color:#fff;
  display:flex;flex-direction:column;gap:12px;
  transition:background .15s, border-color .15s;
}
.ll-card:hover{background:rgba(255,255,255,.085)}
.ll-card--joined{border-color:rgba(31,138,91,.5)}

.ll-card__head{display:grid;grid-template-columns:48px 1fr auto;gap:12px;align-items:start}
.ll-card__avatar{
  width:48px;height:48px;border-radius:12px;
  display:grid;place-items:center;flex-shrink:0;
  background:var(--navy-700);color:#fff;
  font-weight:800;font-size:14px;letter-spacing:.04em;
  overflow:hidden;
}
.ll-card__avatar--red  {background:var(--red)}
.ll-card__avatar--ink  {background:var(--ink-2)}
.ll-card__avatar--gold {background:#C58A1B;color:#1f1408}
.ll-card__avatar--green{background:#1F8A5B}
.ll-card__avatar--bone {background:var(--bone);color:var(--navy)}
.ll-card__avatar img{width:100%;height:100%;object-fit:contain;padding:6px;display:block}

.ll-card__title{min-width:0}
.ll-card__name{
  font-size:15px;font-weight:800;line-height:1.2;color:#fff;
  display:flex;align-items:center;gap:6px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ll-card__name .lock-ic{width:13px;height:13px;color:rgba(255,255,255,.55);flex-shrink:0}
.ll-card__meta{
  font-size:12px;color:rgba(255,255,255,.55);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.ll-card__badges{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end;max-width:140px}
.badge{
  display:inline-flex;align-items:center;
  font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 7px;border-radius:99px;
  background:rgba(255,255,255,.10);color:rgba(255,255,255,.85);
}
.badge--classic{background:rgba(36,58,110,.55);color:#cdd5f0}
.badge--h2h    {background:rgba(200,32,47,.18);color:#FFB4BA}
.badge--sponsor{background:rgba(197,138,27,.20);color:#F0C97A}
.badge--live   {background:rgba(31,138,91,.22);color:#7BE0B0}
.badge--ns     {background:rgba(255,255,255,.10);color:rgba(255,255,255,.75)}
.badge--full   {background:rgba(200,32,47,.22);color:#FFB4BA}
.badge--joined {background:rgba(31,138,91,.22);color:#7BE0B0}

/* progress bar */
.ll-card__bar{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.ll-card__bar .bar{
  height:6px;background:rgba(255,255,255,.10);border-radius:99px;overflow:hidden;
}
.ll-card__bar .bar > i{
  display:block;height:100%;background:linear-gradient(90deg,#7BE0B0,#1F8A5B);
  border-radius:99px;
}
.ll-card__bar .bar--warm > i{background:linear-gradient(90deg,#F0C97A,#C58A1B)}
.ll-card__bar .bar--full > i{background:linear-gradient(90deg,#FFB4BA,var(--red))}
.ll-card__bar .num{font-size:12px;color:rgba(255,255,255,.75);font-weight:700;white-space:nowrap}
.ll-card__bar .num small{color:rgba(255,255,255,.45);font-weight:600;margin-left:2px}

/* meta row */
.ll-card__row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  background:rgba(0,0,0,.18);
  border-radius:10px;padding:8px 10px;
}
.ll-card__row div{display:flex;flex-direction:column;gap:2px;min-width:0}
.ll-card__row .k{
  font-size:10px;color:rgba(255,255,255,.45);font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
}
.ll-card__row .v{font-size:12.5px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* cta row */
.ll-card__cta{display:flex;gap:8px}
.ll-card__cta .btn{flex:1;height:42px;font-size:13px}
.btn--joined{
  background:rgba(31,138,91,.16);color:#7BE0B0;
  border:1.5px solid rgba(31,138,91,.36);cursor:default;
}
.btn--joined:hover{background:rgba(31,138,91,.22)}
.btn--disabled, .btn[disabled]{opacity:.55;cursor:not-allowed}
.btn--full{
  background:rgba(200,32,47,.10);color:#FFB4BA;
  border:1.5px solid rgba(200,32,47,.30);cursor:not-allowed;
}

/* ─────────────────────────────────────────────────────────
   Join private modal (bottom sheet on mobile, centred on desktop)
   ───────────────────────────────────────────────────────── */
.lp-modal{
  position:fixed;inset:0;z-index:60;
  display:flex;align-items:flex-end;justify-content:center;
}
.lp-modal[hidden]{display:none}
.lp-modal__veil{position:absolute;inset:0;background:rgba(5,10,24,.62);animation:lp-fade .2s ease}
.lp-modal__sheet{
  position:relative;width:100%;max-width:520px;
  background:#0F1530;
  border-top-left-radius:24px;border-top-right-radius:24px;
  padding:18px 22px max(env(safe-area-inset-bottom),22px);
  display:flex;flex-direction:column;gap:14px;
  color:#fff;animation:lp-slide .26s cubic-bezier(.22,1,.36,1);
  border-top:1px solid rgba(255,255,255,.08);
}
@keyframes lp-fade{from{opacity:0}to{opacity:1}}
@keyframes lp-slide{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
.lp-modal__grip{
  width:42px;height:4px;border-radius:99px;background:rgba(255,255,255,.22);
  margin:0 auto;
}
.lp-modal__head{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:center}
.lp-modal__title h3{
  margin:0;font-size:17px;font-weight:800;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.lp-modal__meta{font-size:12px;color:rgba(255,255,255,.55);margin-top:2px}
.lp-modal__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  background:rgba(0,0,0,.22);border-radius:10px;padding:10px 8px;
}
.lp-modal__stats div{display:flex;flex-direction:column;gap:2px;align-items:center;text-align:center}
.lp-modal__stats div b{font-size:14px;font-weight:800;color:#fff}
.lp-modal__stats div small{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em}
.lp-modal__cta{display:flex;gap:8px;margin-top:4px}
.lp-modal__cta .btn{flex:1;height:46px}
.lp-modal__cta .btn--primary{flex:1.4}

@media (min-width:600px){
  .lp-modal{align-items:center}
  .lp-modal__sheet{border-radius:20px;padding:24px;max-width:440px}
  .lp-modal__grip{display:none}
}

/* ─────────────────────────────────────────────────────────
   B2 · CREATE LEAGUE form
   ───────────────────────────────────────────────────────── */
.cl-section{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:20px;margin-top:20px;
}
.cl-section:first-of-type{border-top:0;margin-top:6px;padding-top:6px}
.cl-section__title{
  display:flex;align-items:center;gap:10px;margin:0 0 14px;
  font-size:14px;font-weight:800;letter-spacing:.02em;color:#fff;
  text-transform:uppercase;
}
.cl-section__num{
  width:24px;height:24px;border-radius:999px;
  background:var(--red);color:#fff;
  display:grid;place-items:center;
  font-size:12px;font-weight:800;letter-spacing:0;
}

/* avatar picker */
.cl-avatar{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.cl-avatar > .field__label{
  font-size:11px;font-weight:700;letter-spacing:.08em;
  color:rgba(255,255,255,.78);text-transform:uppercase;
}
.cl-avatar__row{display:flex;gap:10px;flex-wrap:wrap}
.cl-av{
  width:38px;height:38px;border-radius:10px;border:2px solid transparent;
  background:var(--navy-700);cursor:pointer;padding:0;
  transition:transform .08s, border-color .15s, box-shadow .15s;
}
.cl-av--red  {background:var(--red)}
.cl-av--ink  {background:var(--ink-2)}
.cl-av--gold {background:#C58A1B}
.cl-av--green{background:#1F8A5B}
.cl-av--bone {background:var(--bone)}
.cl-av:hover{transform:translateY(-1px)}
.cl-av.is-active{
  border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.22);
}

/* radio cards for type */
.cl-radios{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.cl-radio{
  position:relative;cursor:pointer;display:flex;flex-direction:column;gap:6px;
  padding:14px;border:1.5px solid rgba(255,255,255,.10);border-radius:14px;
  background:rgba(255,255,255,.04);transition:border-color .15s, background .15s;
}
.cl-radio:hover{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.07)}
.cl-radio.is-active{border-color:var(--red);background:rgba(200,32,47,.08)}
.cl-radio input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.cl-radio__glyph{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;background:rgba(255,255,255,.08);color:#fff;
}
.cl-radio__glyph--red{background:rgba(200,32,47,.18);color:#FFB4BA}
.cl-radio b{font-size:14px;font-weight:800;color:#fff}
.cl-radio span{font-size:11.5px;color:rgba(255,255,255,.55);line-height:1.45}

/* range slider */
.cl-slider-block{margin-bottom:18px}
.cl-slider-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cl-slider-row{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}
.cl-range{
  -webkit-appearance:none;appearance:none;
  width:100%;height:6px;border-radius:99px;
  background:rgba(255,255,255,.12);outline:none;
}
.cl-range::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:22px;height:22px;border-radius:999px;
  background:var(--red);border:3px solid #fff;
  cursor:pointer;box-shadow:0 4px 12px rgba(200,32,47,.40);
}
.cl-range::-moz-range-thumb{
  width:22px;height:22px;border-radius:999px;
  background:var(--red);border:3px solid #fff;
  cursor:pointer;box-shadow:0 4px 12px rgba(200,32,47,.40);
}
.cl-slider-val{
  display:flex;align-items:baseline;gap:6px;
  font-family:var(--display);font-size:24px;letter-spacing:.04em;color:#fff;
  min-width:80px;justify-content:flex-end;
}
.cl-slider-val small{
  font-family:var(--sans);font-size:10px;font-weight:700;
  color:rgba(255,255,255,.5);letter-spacing:.06em;text-transform:uppercase;
}

/* weeks summary card */
.cl-weeks{
  display:flex;align-items:center;gap:10px;
  margin-top:10px;padding:10px 12px;border-radius:10px;
  font-size:13px;color:#fff;
  background:rgba(31,138,91,.10);border:1px solid rgba(31,138,91,.30);
}
.cl-weeks svg{color:var(--success);flex-shrink:0}
.cl-weeks.is-bad{background:rgba(200,32,47,.10);border-color:rgba(200,32,47,.32)}
.cl-weeks.is-bad svg{color:var(--red)}

/* week range two-column row helper */
.row-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* privacy toggle row */
.cl-priv-row{
  display:flex;align-items:center;gap:14px;
  padding:10px 0;margin-bottom:6px;
}
.cl-priv-row__txt{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.cl-priv-row__txt b{font-size:14px;font-weight:700;color:#fff}
.cl-priv-row__txt span{font-size:12px;color:rgba(255,255,255,.55)}

#create-league-submit{margin-top:18px}
#create-league-submit[disabled]{opacity:.6;cursor:not-allowed}
#create-league-submit.is-loading{position:relative;color:transparent}
#create-league-submit.is-loading::after{
  content:'';position:absolute;width:18px;height:18px;border-radius:999px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  animation:spin .8s linear infinite;
}

/* shared chip lock svg */
.chip svg{margin-right:0}

/* home — selected league header */
.home-league{
  display:grid;grid-template-columns:56px 1fr;gap:14px;align-items:center;
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:12px 14px;margin-bottom:18px;
}
.home-league__logo{
  width:56px;height:56px;border-radius:12px;background:#fff;
  display:grid;place-items:center;
  color:var(--navy);font-weight:800;font-size:15px;letter-spacing:.04em;
  overflow:hidden;
}
.home-league__logo img{width:100%;height:100%;object-fit:contain;padding:6px;display:block}
.home-league__meta{min-width:0}
.home-league__name{
  font-size:16px;font-weight:800;color:#fff;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.home-league__sub{
  font-size:12px;color:rgba(255,255,255,.55);margin-top:3px;
}

/* ── card footer ──────────────────────────────────────── */
.form-card__bottom{
  text-align:center;margin:16px 0 0;padding:14px 0 4px;
  font-size:13px;color:rgba(231,233,242,.85);
}
.form-card__bottom a{
  color:#fff;font-weight:800;font-size:14px;
  text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px;
  margin-left:6px;padding:2px 4px;border-radius:4px;
}
.form-card__bottom a:hover{background:rgba(255,255,255,.10)}

/* ── desktop polish ───────────────────────────────────── */
@media (min-width:900px){
  .form-screen__inner{justify-content:center}
  .topbar{
    position:absolute;background:transparent;backdrop-filter:none;
    -webkit-backdrop-filter:none;padding-top:20px;
  }
  .topbar__title{display:none}
  .form-card{
    margin:auto;
    background:rgba(15,22,46,.78);
    border:1px solid rgba(255,255,255,.06);
    border-radius:20px;
    padding:36px 36px 32px;
    backdrop-filter:saturate(140%) blur(10px);
    -webkit-backdrop-filter:saturate(140%) blur(10px);
    box-shadow:0 40px 80px -30px rgba(0,0,0,.6);
  }
  .form-card h2{font-size:30px}
}

/* ─────────────────────────────────────────────────────────
   App-wide alert/confirm dialog (scripts/ui-modal.js)
   ───────────────────────────────────────────────────────── */
.uim{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:18px}
.uim[hidden]{display:none}
.uim__veil{position:absolute;inset:0;background:rgba(5,10,24,.62);animation:uim-fade .18s ease}
.uim__sheet{
  position:relative;width:100%;max-width:380px;
  background:#0F1530;color:#fff;border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  padding:22px 22px 18px;
  display:flex;flex-direction:column;gap:10px;
  box-shadow:0 30px 70px -20px rgba(0,0,0,.6);
  animation:uim-pop .22s cubic-bezier(.22,1,.36,1);
}
.uim__title{margin:0;font-size:17px;font-weight:800;letter-spacing:-.01em}
.uim__title[hidden]{display:none}
.uim__msg{margin:0;font-size:14px;line-height:1.5;color:rgba(255,255,255,.78)}
.uim__cta{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}
.uim__btn{height:42px;padding:0 16px;border-radius:12px;font-size:14px;font-weight:700;border:1.5px solid transparent}
.uim__btn--cancel{
  background:transparent;color:rgba(255,255,255,.78);
  border-color:rgba(255,255,255,.18);
}
.uim__btn--cancel:hover{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.05)}
.uim__btn--cancel[hidden]{display:none}
.uim__btn--primary{background:#fff;color:var(--ink);border-color:#fff}
.uim__btn--primary:hover{background:rgba(255,255,255,.92)}
.uim__btn--danger{background:var(--red);color:#fff;border-color:var(--red);
  box-shadow:0 8px 20px -10px rgba(200,32,47,.6)}
.uim__btn--danger:hover{background:var(--red-deep);border-color:var(--red-deep)}

@keyframes uim-fade{from{opacity:0}to{opacity:1}}
@keyframes uim-pop{from{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}

@media (max-width:599px){
  .uim{align-items:flex-end;padding:0}
  .uim__sheet{
    max-width:none;border-radius:22px 22px 0 0;
    padding:18px 20px max(env(safe-area-inset-bottom),18px);
  }
}

/* ═════════════════════════════════════════════════════════
   PROFILE screen
   ═════════════════════════════════════════════════════════ */
.pr-screen{background:var(--bone)}
.pr{
  flex:1;display:flex;flex-direction:column;
  padding-bottom:calc(62px + env(safe-area-inset-bottom));
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.pr__top{
  position:sticky;top:0;z-index:5;
  background:#fff;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:10px;
  height:54px;padding:0 12px;
}
.pr__top-back{
  width:36px;height:36px;border-radius:8px;
  display:grid;place-items:center;
  border:0;background:transparent;color:var(--ink);cursor:pointer;
}
.pr__top-back:hover{background:var(--field)}
.pr__top-back svg{width:18px;height:18px}
.pr__top-title{
  flex:1;margin:0;font:800 16px/1 var(--sans);color:var(--ink);
  letter-spacing:-.01em;text-align:center;
}
.pr__top-spacer{width:36px}

.pr__body{
  width:100%;max-width:560px;margin:0 auto;
  padding:16px 16px 24px;display:flex;flex-direction:column;gap:18px;
}

/* identity card */
.pr__id{
  display:flex;align-items:center;gap:14px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;
}
.pr__id-av{
  width:56px;height:56px;border-radius:99px;flex-shrink:0;
  display:grid;place-items:center;
  background:var(--navy);color:#fff;
  font:800 20px/1 var(--sans);letter-spacing:.02em;
}
.pr__id-meta{flex:1;min-width:0}
.pr__id-name{
  font:800 16px/1.2 var(--sans);color:var(--ink);
  letter-spacing:-.01em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pr__id-email{
  font:500 12.5px/1.3 var(--sans);color:var(--ink-2);margin-top:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pr__id-user{
  font:600 11.5px/1 var(--sans);color:var(--muted);margin-top:4px;
  letter-spacing:.02em;
}

/* sections */
.pr__sec{display:flex;flex-direction:column;gap:8px}
.pr__sec-title{
  margin:0 4px 4px;
  font:700 11px/1 var(--sans);letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);
}
.pr__sec--danger .pr__sec-title{color:var(--red-deep)}

/* generic row (link or expandable) */
.pr__row{
  display:flex;align-items:center;gap:12px;
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:0;text-align:left;width:100%;
  font:600 14px/1.2 var(--sans);color:var(--ink);
  text-decoration:none;cursor:pointer;
}
.pr__row--link{
  padding:14px 14px;
}
.pr__row--link:hover{background:var(--field)}
.pr__row-head{
  display:flex;align-items:center;gap:12px;
  width:100%;padding:14px;
  background:transparent;border:0;cursor:pointer;
  font:600 14px/1.2 var(--sans);color:var(--ink);text-align:left;
}
.pr__row-head:hover{background:var(--field)}
.pr__row-ico{
  width:34px;height:34px;border-radius:8px;flex-shrink:0;
  display:grid;place-items:center;
  background:var(--field);color:var(--ink-2);
}
.pr__row--danger .pr__row-ico{
  background:rgba(200,32,47,.10);color:var(--red-deep);
}
.pr__row-lbl{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.pr__row-lbl small{
  font:500 12px/1.3 var(--sans);color:var(--muted);letter-spacing:0;
}
.pr__row-chev{color:var(--muted);display:grid;place-items:center;flex-shrink:0;transition:transform .2s}
.pr__row--exp.is-open .pr__row-chev{transform:rotate(90deg);color:var(--ink)}
.pr__row--exp.is-open{border-color:var(--ink)}

.pr__row--danger{
  background:#fff;border-color:rgba(200,32,47,.25);color:var(--red-deep);
}
.pr__row--danger:hover{background:rgba(200,32,47,.06)}

/* expandable panel */
.pr__row-panel{
  border-top:1px solid var(--line);
  padding:14px;
  display:flex;flex-direction:column;gap:12px;
}
.pr__row--exp{display:flex;flex-direction:column;align-items:stretch;gap:0;padding:0}
.pr__row--exp > .pr__row-head{width:100%}

/* form bits inside panels */
.pr__form{display:flex;flex-direction:column;gap:12px}
.pr__field{display:flex;flex-direction:column;gap:6px}
.pr__field-lbl{
  font:700 10.5px/1 var(--sans);letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-2);
}
.pr__field input[type="password"],
.pr__field input[type="text"]{
  width:100%;height:40px;padding:0 12px;
  background:#fff;border:1px solid var(--line);border-radius:9px;
  font:500 14px/1 var(--sans);color:var(--ink);outline:0;
  box-sizing:border-box;
}
.pr__field input:focus{border-color:var(--ink)}
.pr__field-hint{font:500 11px/1.3 var(--sans);color:var(--muted)}

/* color picker rows */
.pr__color-preview{
  align-self:center;
  width:72px;height:72px;border-radius:99px;
  border:3px solid var(--navy);
  background:#fff;color:var(--ink);
  display:grid;place-items:center;
  font:800 24px/1 var(--sans);letter-spacing:.02em;
  margin-bottom:4px;
}
.pr__color-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.pr__color-row .pr__field-lbl{flex:1;margin:0}
.pr__color-input{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--field);border:1px solid var(--line);border-radius:9px;
  padding:4px 8px 4px 4px;
}
.pr__color-input input[type="color"]{
  width:32px;height:32px;border:0;padding:0;background:transparent;
  cursor:pointer;border-radius:6px;
}
.pr__color-input input[type="color"]::-webkit-color-swatch-wrapper{padding:0}
.pr__color-input input[type="color"]::-webkit-color-swatch{
  border:1px solid var(--line);border-radius:6px;
}
.pr__color-input input[type="text"]{
  width:88px;height:30px;padding:0 8px;
  border:0;background:transparent;
  font:600 12px/1 'JetBrains Mono','Menlo',ui-monospace,monospace;
  color:var(--ink);outline:0;text-transform:uppercase;
  font-variant-numeric:tabular-nums;
}

/* buttons */
.pr__btn{
  height:42px;padding:0 18px;
  border-radius:10px;border:1px solid transparent;cursor:pointer;
  font:800 13.5px/1 var(--sans);letter-spacing:.01em;
}
.pr__btn--primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.pr__btn--primary:hover{background:#000}
.pr__btn--primary[disabled]{opacity:.55;cursor:not-allowed}
.pr__btn--ghost{background:#fff;color:var(--ink-2);border-color:var(--line)}
.pr__btn--ghost:hover{background:var(--field);color:var(--ink)}
.pr__btn-row{display:flex;gap:8px;justify-content:flex-end}

/* banners (success) — light-theme override for the profile panel */
.pr .form-banner--ok{
  background:rgba(31,138,91,.10);color:var(--success);
  border:1px solid rgba(31,138,91,.25);
  padding:10px 12px;border-radius:9px;font:600 13px/1.4 var(--sans);
}
.pr .form-banner--err{
  background:rgba(200,32,47,.08);color:var(--red-deep);
  border:1px solid rgba(200,32,47,.25);
  padding:10px 12px;border-radius:9px;font:600 13px/1.4 var(--sans);
}

/* desktop polish */
@media (min-width:760px){
  .pr{padding-bottom:0}
  .pr__top{
    border-radius:0;
  }
  .pr__body{padding:24px 24px 40px;gap:22px}
  .pr__id{padding:18px 20px}
  .pr__id-av{width:64px;height:64px;font-size:22px}
}

/* ─────────────────────────────────────────────────────────
   A2.5 · HOW TO PLAY
   Static onboarding screen — sits inside .form-screen shell.
   ───────────────────────────────────────────────────────── */
.howto .form-screen__inner{overflow-y:auto}
.welcome__sep{margin:0 6px;color:var(--muted);opacity:.55}

.howto__card{max-width:520px}
.howto__card h2{margin:0 0 6px;font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}

.howto__steps{
  list-style:none;margin:18px 0 22px;padding:0;
  display:flex;flex-direction:column;gap:12px;
}
.howto__step{
  display:flex;gap:14px;align-items:flex-start;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:14px 16px;
  box-shadow:0 1px 0 rgba(14,21,48,.02);
}
.howto__step-num{
  flex:0 0 auto;
  width:32px;height:32px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:18px;letter-spacing:.02em;line-height:1;
}
.howto__step-body{flex:1;min-width:0}
.howto__step-body h3{
  margin:0 0 4px;font-size:15px;font-weight:700;color:var(--ink);
  letter-spacing:-.01em;
}
.howto__step-body p{
  margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2);
}
.howto__step-body b{color:var(--ink);font-weight:700}
.howto__step-body i{font-style:italic;color:var(--navy)}

/* phones */
@media (max-width:480px){
  .howto__card h2{font-size:21px}
  .howto__step{padding:12px 14px;gap:12px}
  .howto__step-num{width:28px;height:28px;font-size:16px}
  .howto__step-body h3{font-size:14px}
  .howto__step-body p{font-size:13px}
}

/* ─────────────────────────────────────────────────────────
   TERMS & CONDITIONS
   Long-form legal screen — uses the form-screen shell. The
   content card is wider and renders the document as light
   article-style text on white, so it's readable across long
   sections without losing the app's navy/red brand frame.
   ───────────────────────────────────────────────────────── */
.terms .form-screen__inner{
  padding-bottom:calc(env(safe-area-inset-bottom) + 24px);
}

.terms__card{
  display:block;                    /* override form-card flex; long article stacks naturally */
  max-width:760px;
  background:var(--paper);
  border-radius:var(--r-card);
  padding:22px 26px 26px;
  margin:8px auto 16px;
  box-shadow:0 12px 40px rgba(0,0,0,.18);
}
.terms__card h2{color:var(--ink);font-size:26px;letter-spacing:-.02em}
.terms__card .form-card__lead{color:var(--ink-2)}

.terms__notice{
  display:block;
  background:linear-gradient(180deg,#FFF,#FAF8F2);
  border:1px solid var(--line);
  border-left:4px solid var(--red);
  border-radius:14px;
  padding:14px 16px;
  margin:6px 0 22px;
  color:var(--ink-2);
  font-size:13.5px;line-height:1.55;
}
.terms__notice strong{display:block;color:var(--ink);font-weight:800;margin-bottom:4px;letter-spacing:-.01em}

.terms__toc{
  background:#F8F7F1;
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px 16px 6px;
  margin-bottom:24px;
}
.terms__toc-title{
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;
}
.terms__toc ol{
  list-style:none;margin:0;padding:0;counter-reset:tc;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px 14px;
}
.terms__toc li{counter-increment:tc}
.terms__toc a{
  display:flex;gap:8px;text-decoration:none;color:var(--ink-2);
  font-size:13px;line-height:1.4;padding:6px 6px;border-radius:8px;
  transition:background .15s,color .15s;
}
.terms__toc a::before{
  content:counter(tc,decimal-leading-zero);
  color:var(--muted);font-variant-numeric:tabular-nums;font-weight:700;flex:none;
}
.terms__toc a:hover{background:#EEEAE0;color:var(--navy)}

.terms__doc{display:block;color:var(--ink-2);font-size:14.5px;line-height:1.65}
.terms__doc section{margin:0 0 28px;scroll-margin-top:80px}
.terms__doc h3{
  display:flex;align-items:baseline;gap:10px;
  margin:0 0 10px;padding-bottom:8px;
  border-bottom:1px solid var(--line);
  font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.01em;
}
.terms__doc h4{
  margin:18px 0 6px;font-size:14px;font-weight:700;color:var(--ink);letter-spacing:-.005em;
}
.terms__num{
  flex:none;background:#EEF0F7;color:var(--navy);
  font-size:11px;font-variant-numeric:tabular-nums;font-weight:800;
  letter-spacing:.04em;padding:2px 8px;border-radius:8px;
}
.terms__doc p{margin:0 0 10px}
.terms__doc ul{margin:0 0 12px;padding-left:20px}
.terms__doc li{margin:5px 0}
.terms__doc strong{color:var(--ink);font-weight:700}
.terms__a{color:var(--navy);text-decoration:underline;text-underline-offset:2px}
.terms__a:hover{color:var(--red)}

.terms__table-wrap{margin:8px 0 14px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.terms__table{
  width:100%;border-collapse:collapse;font-size:13.5px;background:var(--paper);
}
.terms__table thead th{
  background:var(--navy);color:#fff;text-align:left;
  padding:10px 14px;font-weight:700;font-size:12.5px;letter-spacing:.02em;
}
.terms__table thead th:first-child{width:38%}
.terms__table td{
  border-top:1px solid var(--line);padding:10px 14px;vertical-align:top;color:var(--ink-2);
}
.terms__table tbody tr:nth-child(even) td{background:#F8F7F1}
.terms__table strong{color:var(--ink)}

.terms__rights{
  border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:8px 0 14px;
}
.terms__rights-row{
  display:grid;grid-template-columns:180px 1fr;
  border-top:1px solid var(--line);
}
.terms__rights-row:first-child{border-top:0}
.terms__rights-k{
  background:#F4F4EC;padding:10px 14px;
  font-weight:700;font-size:13px;color:var(--navy);
}
.terms__rights-v{padding:10px 14px;font-size:13.5px}

@media (max-width:560px){
  .terms__card{padding:18px 18px 20px;border-radius:18px}
  .terms__toc ol{grid-template-columns:1fr}
  .terms__doc{font-size:14px}
  .terms__doc h3{font-size:15.5px}
  .terms__rights-row{grid-template-columns:1fr}
  .terms__rights-k{border-bottom:1px solid var(--line)}
  .terms__table thead{display:none}
  .terms__table,.terms__table tbody,.terms__table tr,.terms__table td{display:block;width:100%}
  .terms__table tr{border-top:1px solid var(--line)}
  .terms__table tr:first-child{border-top:0}
  .terms__table td{border-top:0;padding:8px 14px}
  .terms__table td:first-child{padding-top:12px;background:#F8F7F1}
  .terms__table td:last-child{padding-bottom:12px}
  .terms__table tbody tr:nth-child(even) td{background:transparent}
  .terms__table tbody tr:nth-child(even) td:first-child{background:#F8F7F1}
}

/* Desktop: counteract the .form-screen__inner{justify-content:center} +
   .form-card{margin:auto} pattern designed for short forms. For long-form
   legal documents, content must flow from the top — otherwise tall content
   gets vertically centered and the top scrolls off-screen. Also re-establish
   the sticky topbar (which desktop hides for short forms) so the back button
   stays reachable while scrolling, and keep the white card look. */
@media (min-width:900px){
  .terms .form-screen__inner{justify-content:flex-start}
  .terms .topbar{
    position:sticky;background:linear-gradient(180deg,rgba(10,18,38,.92),rgba(10,18,38,.65) 70%,transparent);
    backdrop-filter:saturate(140%) blur(8px);-webkit-backdrop-filter:saturate(140%) blur(8px);
    padding-top:calc(env(safe-area-inset-top) + 14px);
  }
  .terms .topbar__title{display:block}
  .terms__card{
    margin:8px auto 24px;
    background:var(--paper);
    border:0;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    padding:28px 32px 28px;
  }
  .terms__card h2{font-size:28px;color:var(--ink)}
}

/* ─────────────────────────────────────────────────────────
   COOKIE CONSENT BANNER
   Overlays every screen on first visit. Persists choice in localStorage;
   re-openable via openCookieSettings() from a footer/profile link.
   ───────────────────────────────────────────────────────── */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:9999;
  padding:14px;
  opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .35s ease, transform .35s ease;
}
.cookie-banner[hidden]{display:none}
.cookie-banner.is-open{opacity:1;transform:none;pointer-events:auto}

.cookie-banner__inner{
  max-width:980px;margin:0 auto;
  background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:var(--r-card);
  box-shadow:0 18px 40px rgba(14,21,48,.18);
  padding:16px 18px;
  display:flex;align-items:center;gap:18px;
}

.cookie-banner__body{flex:1;min-width:0}
.cookie-banner__body b{display:block;font-size:14px;font-weight:700;margin:0 0 4px;color:var(--ink)}
.cookie-banner__body p{margin:0;font-size:13px;line-height:1.55;color:var(--ink-2)}
.cookie-banner__links{margin-top:6px !important;font-size:12px}
.cookie-banner__links a{color:var(--navy);font-weight:600;text-decoration:underline}

.cookie-banner__actions{
  flex:0 0 auto;display:flex;gap:8px;align-items:center;
}
.cookie-banner__actions .btn{padding:10px 16px;font-size:13.5px;min-height:auto;height:auto}

/* phones — stack vertically */
@media (max-width:640px){
  .cookie-banner{padding:10px}
  .cookie-banner__inner{
    flex-direction:column;align-items:stretch;gap:12px;
    padding:14px 16px;
  }
  .cookie-banner__actions{flex-direction:column-reverse}
  .cookie-banner__actions .btn{width:100%}
}

/* ───────────── language picker ───────────── */
.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}

/* Custom dropdown so we control both the trigger AND the open panel.
   Native <select> reverts to OS chrome when opened, which breaks brand. */
.lang-picker{position:relative;display:inline-block;text-align:left}

.lang-picker__btn{
  appearance:none;border:1.5px solid var(--line);
  background:var(--paper);border-radius:var(--r-btn);
  padding:9px 12px 9px 14px;
  display:inline-flex;align-items:center;gap:10px;
  font:700 12.5px/1 var(--sans);letter-spacing:.02em;color:var(--ink-2);
  cursor:pointer;
  transition:border-color .15s, color .15s, box-shadow .15s, background-color .15s;
}
.lang-picker__btn:hover{border-color:#c5cbdc;color:var(--ink)}
.lang-picker.is-open .lang-picker__btn,
.lang-picker__btn:focus-visible{
  outline:none;border-color:var(--navy);color:var(--ink);
  box-shadow:0 0 0 3px rgba(27,46,94,.12);
}
.lang-picker__chev{
  width:10px;height:6px;color:var(--muted);flex-shrink:0;
  transition:transform .2s ease;
}
.lang-picker.is-open .lang-picker__chev{transform:rotate(180deg);color:var(--ink)}

.lang-picker__menu{
  position:absolute;top:calc(100% + 6px);right:0;
  min-width:180px;
  margin:0;padding:6px;list-style:none;
  background:var(--paper);
  border:1.5px solid var(--line);border-radius:var(--r-fld);
  box-shadow:0 12px 32px rgba(14,21,48,.12);
  z-index:50;
  opacity:0;transform:translateY(-4px);pointer-events:none;
  transition:opacity .15s ease, transform .15s ease;
}
.lang-picker.is-open .lang-picker__menu{
  opacity:1;transform:translateY(0);pointer-events:auto;
}
.lang-picker--up .lang-picker__menu{
  top:auto;bottom:calc(100% + 6px);
  transform:translateY(4px);
}
.lang-picker--up.is-open .lang-picker__menu{transform:translateY(0)}

.lang-picker__opt{
  appearance:none;border:0;background:transparent;
  width:100%;text-align:left;
  padding:9px 12px;border-radius:8px;
  font:600 13px/1 var(--sans);color:var(--ink-2);
  cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  transition:background-color .12s, color .12s;
}
.lang-picker__opt:hover{background:var(--field);color:var(--ink)}
.lang-picker__opt.is-selected{color:var(--navy)}
.lang-picker__opt.is-selected::after{
  content:'';width:8px;height:8px;border-radius:999px;
  background:var(--navy);flex-shrink:0;
}

/* Welcome screen: the picker floats above the form card, right-aligned to
   the same 440-wide column the card occupies. */
.lang-picker-bar{
  display:flex;justify-content:flex-end;
  width:100%;max-width:440px;margin:-6px auto 10px;
}

/* Profile screen: a non-clickable row that hosts the picker on the right.
   Same shell as .pr__row--link, minus the chevron and hover affordance. */
.pr__row--inline{
  padding:10px 14px;cursor:default;gap:12px;
}
.pr__row--inline:hover{background:#fff}
.pr__row--inline .pr__row-lbl{
  font:600 14px/1.2 var(--sans);color:var(--ink);
}
.pr__row--inline .lang-picker{flex-shrink:0}
