:root{
  --bg:#eef3ee; --ink:#122a1e; --muted:#516b5f; --faint:#89a294;
  --line:rgba(16,40,28,.13); --panel:#ffffff;
  --accent:#0b8f4e; --green:#0b8f4e; --teal:#16b37a; --gold:#c98a00; --red:#d64545; --orange:#e0842b; --blue:#2f7fd6;
  --f:"Inter",system-ui,sans-serif; --f-d:"Anton",Impact,sans-serif;
  --r:18px; --shadow:0 12px 30px -18px rgba(16,40,28,.42);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--f);color:var(--ink);background:var(--bg);-webkit-tap-highlight-color:transparent;overflow:hidden}
.field-bg{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(90% 52% at 50% -8%, rgba(11,143,78,.16), transparent 62%),
    radial-gradient(70% 45% at 50% 108%, rgba(11,143,78,.08), transparent 60%),
    /* hash marks: two faint dashed rows like midfield hashes */
    repeating-linear-gradient(90deg, transparent 0 26px, rgba(16,40,28,.05) 26px 28px) 0 34%/100% 2px no-repeat,
    repeating-linear-gradient(90deg, transparent 0 26px, rgba(16,40,28,.05) 26px 28px) 0 66%/100% 2px no-repeat,
    /* yard lines */
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(16,40,28,.05) 39px 40px),
    var(--bg);}

/* ===== field-branded home hero ===== */
.fieldbanner{position:relative;background:linear-gradient(180deg,#0c8046,#0a6636);border-radius:18px;padding:1.5rem 1rem 1.2rem;margin:.5rem 0 .2rem;overflow:hidden;box-shadow:0 18px 44px -22px rgba(10,102,54,.85)}
.fieldbanner::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0 44px,rgba(255,255,255,.20) 44px 47px);opacity:.6}
.fieldbanner::after{content:"";position:absolute;left:14px;right:14px;top:14px;bottom:34px;
  background:repeating-linear-gradient(90deg,transparent 0 20px,rgba(255,255,255,.28) 20px 22px) top/100% 3px no-repeat,
             repeating-linear-gradient(90deg,transparent 0 20px,rgba(255,255,255,.28) 20px 22px) bottom/100% 3px no-repeat}
.fieldbanner .pylon{position:absolute;top:8px;width:7px;height:20px;border-radius:3px;background:linear-gradient(#ffe14d,#f5b60c);box-shadow:0 0 8px rgba(245,182,12,.7);z-index:2}
.fieldbanner .pylon.l{left:9px}.fieldbanner .pylon.r{right:9px}
.home-title{position:relative;z-index:1;color:#fff;text-shadow:0 3px 0 rgba(0,0,0,.18),0 6px 16px rgba(0,0,0,.25)}
.home-title .dash{color:#ffd21e;-webkit-text-fill-color:#ffd21e}
.endzone{position:relative;z-index:1;margin-top:.4rem;font-weight:800;letter-spacing:.42em;font-size:.66rem;color:rgba(255,255,255,.82);text-transform:uppercase;text-indent:.42em}

/* ===== jumbotron scoreboard on results ===== */
.scoreboard{background:linear-gradient(180deg,#0e2a1e,#08160f);border-radius:16px;padding:1rem .8rem .9rem;margin:.5rem auto 1rem;max-width:360px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.06),inset 0 0 30px rgba(0,0,0,.5),0 16px 40px -22px rgba(0,0,0,.7)}
body.flash::after{content:"";position:fixed;inset:0;z-index:90;pointer-events:none;background:var(--gold);animation:flashA .65s ease forwards}
@keyframes flashA{0%{opacity:.45}100%{opacity:0}}

.bignum{font-family:var(--f-d);font-weight:400;letter-spacing:.01em}
.dash{color:var(--accent)}

.screen{position:fixed;inset:0;z-index:1;display:none;flex-direction:column;
  padding:max(env(safe-area-inset-top),16px) 15px max(env(safe-area-inset-bottom),16px);overflow:hidden}
.screen.is-on{display:flex;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
#home,#result{overflow-y:auto}

.btn{border:0;border-radius:999px;padding:.8em 1.4em;font-family:var(--f);font-weight:800;font-size:1rem;background:var(--accent);color:#fff;cursor:pointer;transition:transform .1s,filter .15s;box-shadow:0 8px 20px -12px var(--accent)}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.5}
.btn-lg{padding:.95em 2.1em;font-size:1.15rem;margin-top:1.3rem}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line);font-weight:700;box-shadow:none}
.icon-btn{background:#fff;border:1px solid var(--line);color:var(--ink);width:40px;height:40px;border-radius:12px;font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;flex:none}
.eyebrow{font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-size:.74rem;margin:0}

/* ---------- HOME ---------- */
.home-head{text-align:center;max-width:560px;margin:0 auto;padding:clamp(1rem,5vw,2.2rem) 6px 0}
.home-title{font-size:clamp(4.6rem,29vw,9rem);line-height:.82;margin:.4rem 0 .2rem;color:var(--ink)}
.tag{color:var(--muted);font-size:clamp(.98rem,3.7vw,1.12rem);margin:.6rem auto 0;max-width:34ch;line-height:1.5}
.tag b{color:var(--ink)}
.mode-switch{display:inline-flex;gap:4px;margin:1.3rem auto .5rem;padding:4px;background:#fff;border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow)}
.mode-opt{background:none;border:0;color:var(--muted);font-family:var(--f);font-weight:700;font-size:.9rem;padding:.55em 1.1em;border-radius:999px;cursor:pointer;transition:.15s;white-space:nowrap}
.mode-opt.is-on{background:var(--accent);color:#fff}
.mode-hint{color:var(--faint);font-size:.82rem;margin:.15rem auto 0;min-height:1em}
.home-best{color:var(--green);font-weight:800;font-size:.98rem;margin:.9rem 0 0;min-height:1em}
.home-stats{color:var(--muted);font-size:.84rem;margin:.25rem 0 0;min-height:1em}
.home-board{max-width:520px;margin:1.6rem auto .5rem;width:100%}
.board-head{display:flex;justify-content:space-between;align-items:center;font-weight:700;color:var(--muted);font-size:.9rem;margin-bottom:.5rem;padding:0 2px}
.foot-link{color:var(--accent);text-decoration:none;font-weight:700;font-size:.84rem}
.home-foot{text-align:center;color:var(--faint);font-size:.8rem;padding:1.6rem 0 .6rem}

/* ---------- DRAFT ---------- */
.hud{display:flex;align-items:center;gap:10px}
.hud-mid{flex:1;text-align:center;min-width:0}
.hud-title{font-family:var(--f-d);font-size:1.3rem;line-height:1;letter-spacing:.02em}
.hud-sub{font-size:.76rem;color:var(--muted);margin-top:2px}
.hud-mode{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:.3em .7em;flex:none}

.spinwrap{margin-top:14px}
.spincard{position:relative;border:1px solid var(--line);border-radius:20px;background:#fff;padding:1.5rem 1.2rem 1.55rem;text-align:center;overflow:hidden;box-shadow:0 16px 36px -24px var(--tc,rgba(16,40,28,.5))}
.spincard::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--tc,#999)}
.spin-team{display:flex;align-items:center;justify-content:center;gap:.45em;font-family:var(--f-d);font-size:clamp(1.9rem,8vw,2.6rem);line-height:1;color:var(--ink)}
.spin-dot{width:.46em;height:.46em;border-radius:50%;background:var(--tc,#888);flex:none}
.spin-era{margin-top:.45rem;font-weight:800;color:var(--accent);font-size:1.05rem;letter-spacing:.22em}
.spincard.rolling .spin-team{filter:blur(.5px);opacity:.85}
.spincard.rolling .spin-era{opacity:.5}
.respins{display:flex;gap:8px;justify-content:center;margin-top:12px}
.respin{background:#fff;border:1px solid var(--line);color:var(--ink);font-weight:700;font-size:.86rem;border-radius:999px;padding:.5em 1em;cursor:pointer;transition:.12s;box-shadow:var(--shadow)}
.respin:active{transform:scale(.96)}
.respin:disabled{opacity:.42;box-shadow:none}
.respin-n{display:inline-grid;place-items:center;min-width:1.5em;height:1.5em;margin-left:.3em;background:var(--accent);color:#fff;border-radius:999px;font-size:.76rem;font-weight:800}
.respin:disabled .respin-n{background:var(--faint)}

.pick-label{text-align:center;font-weight:700;color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin:1rem 0 .5rem}
.pick-label.flash{color:var(--accent)}
.options{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;min-height:60px;padding:2px}
.opt{display:flex;align-items:center;gap:12px;text-align:left;border:1px solid var(--line);border-left:4px solid var(--tc,#999);border-radius:13px;background:#fff;padding:.7em .85em;color:inherit;cursor:pointer;box-shadow:var(--shadow);animation:optin .28s ease both;animation-delay:calc(var(--i,0)*.035s)}
.opt:active{transform:scale(.99)}
.opt.locked{background:#dde3de;border-color:transparent;border-left-color:#a7b3aa;box-shadow:none;cursor:default}
.opt.locked .opt-pos,.opt.locked .opt-sub{color:#8f9d93}
.opt.locked .opt-name{color:#94a29a;text-decoration:line-through;text-decoration-color:#aab6ac;text-decoration-thickness:2px}
.opt.locked .opt-rat{color:#a7b3aa}
.opt.locked .opt-lock{font-weight:800;color:#7f8d84}
@keyframes optin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.opt-pos{font-family:var(--f-d);font-size:.95rem;color:var(--muted);width:2.1em;text-align:center;flex:none}
.opt-main{flex:1;min-width:0}
.opt-name{display:block;font-weight:700;font-size:1.05rem;line-height:1.15}
.opt-sub{display:block;color:var(--muted);font-size:.8rem}
.opt-rat{font-family:var(--f-d);font-size:1.55rem;color:var(--accent);flex:none}
.opt-rat.blind{color:var(--faint)}

.tracker{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:.8rem}
.chip{border:1px solid var(--line);border-radius:10px;padding:.4em .2em;text-align:center;background:#fff;min-height:50px;display:flex;flex-direction:column;justify-content:center;gap:1px;overflow:hidden}
.chip.filled{border-color:var(--tc);border-bottom:3px solid var(--tc)}
.chip-pos{font-family:var(--f-d);font-size:.76rem;color:var(--muted);line-height:1}
.chip-name{font-size:.64rem;font-weight:700;line-height:1.05;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.chip-dec{font-size:.6rem;color:var(--faint)}
.chip-empty{color:var(--faint);font-size:.8rem}
.chip-meta{display:flex;gap:4px;justify-content:center;align-items:baseline;line-height:1}
.chip-rat{font-family:var(--f-d);color:var(--accent);font-size:.74rem}

/* ---------- RESULT ---------- */
.result-card{position:relative;width:100%;max-width:500px;margin:auto;text-align:center;padding:1rem 0}
.perfect-stamp{position:absolute;top:8px;left:50%;transform:translate(-50%,-6px) rotate(-8deg) scale(.7);opacity:0;pointer-events:none;
  font-family:var(--f-d);color:var(--gold);border:4px solid var(--gold);border-radius:12px;padding:.1em .5em;line-height:.9;font-size:1.5rem;letter-spacing:.04em;z-index:3;transition:transform .4s cubic-bezier(.2,1.4,.4,1),opacity .3s}
.perfect-stamp span{display:block;font-size:.72rem;letter-spacing:.28em}
.perfect-stamp.show{opacity:.9;transform:translate(-50%,-6px) rotate(-8deg) scale(1)}
.record{font-size:clamp(4.4rem,24vw,7rem);line-height:.85;margin:.1rem 0;color:#fff}
.record .dash{color:#12c46b}
.record.pending{opacity:.28}
.record.perfect{color:#ffd21e;text-shadow:0 4px 26px rgba(255,210,30,.5)}
.season{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin:.5rem auto 0;max-width:320px}
.pip{width:14px;height:14px;border-radius:4px;background:rgba(255,255,255,.14);transition:background .12s,transform .12s}
.pip.w{background:#12c46b;transform:scale(1.05)}
.pip.l{background:#ff5a5f}
.res-line{font-weight:700;font-size:1.05rem;margin:.2rem 0 .2rem;color:var(--ink)}
.pctl{font-weight:800;color:var(--green);font-size:.9rem;margin:.1rem 0 1.1rem;min-height:1em}
.cats{display:flex;flex-direction:column;gap:11px;margin:0 auto 1.4rem;max-width:440px;text-align:left}
.cat-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.86rem;margin-bottom:4px}
.cat-name{font-weight:600}
.cat-weak{margin-left:.5em;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--red);border:1px solid var(--red);border-radius:999px;padding:.05em .5em}
.cat-grade{font-weight:800}
.cat-bar{height:9px;border-radius:6px;background:rgba(16,40,28,.09);overflow:hidden}
.cat-bar span{display:block;height:100%;border-radius:6px;transition:width .7s cubic-bezier(.2,.8,.2,1)}
.g-elite{color:var(--green)} .cat-bar span.g-elite{background:var(--green)}
.g-great{color:var(--teal)} .cat-bar span.g-great{background:var(--teal)}
.g-solid{color:var(--gold)} .cat-bar span.g-solid{background:var(--gold)}
.g-shaky{color:var(--orange)} .cat-bar span.g-shaky{background:var(--orange)}
.g-weak{color:var(--red)} .cat-bar span.g-weak{background:var(--red)}
.res-roster{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 auto 1.3rem;max-width:460px}
.rc{position:relative;border:1px solid var(--line);border-left:4px solid var(--tc,#999);border-radius:11px;padding:.5em .6em;text-align:left;background:#fff;box-shadow:var(--shadow)}
.rc-pos{font-family:var(--f-d);font-size:.72rem;color:var(--muted)}
.rc-name{display:block;font-weight:700;font-size:.9rem;line-height:1.15;margin-top:1px}
.rc-sub{display:block;color:var(--muted);font-size:.74rem}
.rc-rat{position:absolute;top:.45em;right:.55em;font-family:var(--f-d);font-size:1.05rem;color:var(--accent)}
.save-form{display:flex;gap:8px;margin:0 auto 1.1rem;max-width:420px}
input[type=text]{flex:1;min-width:0;font-family:var(--f);font-size:1.02rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:.7em .9em;outline:none;transition:border-color .15s}
input[type=text]:focus{border-color:var(--accent)}
.result-actions{display:flex;flex-direction:column;gap:9px;max-width:420px;margin:0 auto}
.save-status{margin:0 auto 1.1rem;max-width:420px;font-weight:700;color:var(--green);font-size:.95rem}
.save-status b{color:var(--ink)}
.save-status a{color:var(--muted);font-weight:600;text-decoration:underline}

/* ---------- leaderboard ---------- */
.lb-tabs{display:flex;gap:5px;justify-content:center;margin:0 0 .6rem}
.lb-tab{background:#fff;border:1px solid var(--line);color:var(--muted);font-family:var(--f);font-weight:700;font-size:.78rem;padding:.4em .9em;border-radius:999px;cursor:pointer;transition:.12s}
.lb-tab.is-on{background:var(--ink);color:#fff;border-color:transparent}
.board,.mini-lb{text-align:left;border:1px solid var(--line);border-radius:15px;overflow:hidden;background:#fff;margin-bottom:1.1rem;box-shadow:var(--shadow)}
.lb-entry{border-top:1px solid var(--line)}
.lb-entry:first-child{border-top:0}
.lb-entry.perfect .board-rec{color:var(--gold)}
.board-row{display:flex;align-items:center;gap:10px;padding:.6em .85em;font-size:.94rem;cursor:pointer}
.board-row:active{background:rgba(11,143,78,.06)}
.lb-caret{color:var(--faint);font-weight:800;transition:transform .15s;margin-left:2px}
.lb-entry.open .lb-caret{transform:rotate(90deg)}
.lb-roster{display:none;flex-direction:column;gap:5px;padding:.1em .7em .7em 2.5em;background:rgba(0,0,0,.02)}
.lb-entry.open .lb-roster{display:flex}
.lbp{display:flex;align-items:center;gap:8px;font-size:.84rem;border-left:3px solid var(--tc,#999);padding-left:8px}
.lbp b{width:2.2em;color:var(--muted);font-weight:800;font-family:var(--f-d)}
.lbp-n{flex:1;font-weight:600}
.lbp-d{color:var(--faint);font-size:.76rem;white-space:nowrap}
.lbp-r{font-family:var(--f-d);color:var(--accent);font-size:.9rem;width:1.8em;text-align:right}
.board-rank{width:1.6em;text-align:center;font-family:var(--f-d);color:var(--muted)}
.board-name{flex:1;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.board-rec{font-family:var(--f-d);color:var(--accent);font-size:1.05rem}
.board-mar{color:var(--faint);font-size:.82rem;width:3.2em;text-align:right;font-variant-numeric:tabular-nums}
.board-load,.board-empty{padding:1.1rem;text-align:center;color:var(--muted);font-size:.9rem}

.confetti{position:fixed;inset:0;z-index:100;pointer-events:none}

@media (min-width:560px){ .options{gap:9px} }
@media (prefers-reduced-motion:reduce){ *{animation-duration:.01ms!important} .cat-bar span,.pip{transition:none} }
