/* ═══════════════════════════════════════════
   TOKENS
═══════════════════════════════════════════ */
:root{
  --y:#F7C325;--yd:#D9A91E;--y10:rgba(247,195,37,.10);--y25:rgba(247,195,37,.25);
  --bg:#090909;--s1:#101010;--s2:#161616;--s3:#1C1C1C;--s4:#242424;--s5:#2C2C2C;
  --b1:rgba(255,255,255,.06);--b2:rgba(255,255,255,.10);--b3:rgba(255,255,255,.18);
  --txt:#EDE8D5;--dim:#666;--faint:#2A2A2A;
  --red:#E8453C;--red10:rgba(232,69,60,.10);--red25:rgba(232,69,60,.25);
  --fs:'Syne',sans-serif;--fm:'Space Mono',monospace;
  --nav-h:56px;
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);
}

/* ═══════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;-webkit-text-size-adjust:100%}
body{
  height:100%;height:100dvh;
  background:var(--bg);
  color:var(--txt);
  font-family:var(--fs);
  overscroll-behavior:none;
  overflow:hidden;
}
#app-scroll{
  position:fixed;inset:0;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
button,input,select,textarea{font-family:var(--fs)}

/* ═══════════════════════════════════════════
   APP CONTAINER
═══════════════════════════════════════════ */
#app{
  max-width:520px;
  margin:0 auto;
  min-height:100%;
}
/* Pages that use .pg get padding via .pg rule */
/* ═══════════════════════════════════════════
   NAV
═══════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
  padding-top:var(--safe-t);
  background:rgba(9,9,9,.96);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--b1);
  max-width:520px;margin:0 auto;
}
.nav-left{display:flex;align-items:center;gap:9px;cursor:pointer;min-width:0}
.nav-logo-img{
  width:34px;height:34px;border-radius:8px;
  object-fit:cover;flex-shrink:0;
}
.nav-title{
  font-size:15px;font-weight:800;color:var(--y);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.nav-right{display:flex;gap:4px;flex-shrink:0}

/* ═══════════════════════════════════════════
   AUTH PAGE — background image
═══════════════════════════════════════════ */
.auth-bg{
  min-height:100vh;
  background:
    linear-gradient(to bottom, rgba(9,9,9,.72) 0%, rgba(9,9,9,.88) 50%, rgba(9,9,9,.97) 100%),
    url('bg.png') center top / cover no-repeat;
  display:flex;flex-direction:column;
}
.auth-wrap{
  padding:calc(var(--safe-t) + 48px) 20px 40px;
  max-width:420px;
  margin:0 auto;
  width:100%;
  flex:1;
  display:flex;flex-direction:column;
}
.auth-logo{
  display:flex;align-items:center;gap:12px;
  margin-bottom:6px;
}
.auth-logo-img{
  width:56px;height:56px;border-radius:14px;
  object-fit:cover;flex-shrink:0;
}
.auth-title{font-size:24px;font-weight:800;color:var(--y)}
.auth-sub{font-size:13px;color:var(--dim);margin-bottom:28px;line-height:1.5}
.team-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.team-row{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(22,22,22,.9);
  border:1.5px solid var(--b2);
  border-radius:14px;
  padding:16px 14px;
  cursor:pointer;
  transition:all .15s;
  /* big touch target */
  min-height:58px;
}
.team-row:hover{border-color:var(--b3);background:var(--s3)}
.team-row:active{transform:scale(.98)}
.team-row-name{font-size:15px;font-weight:600}
.divider{height:1px;background:var(--b1);margin:14px 0}

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  border:none;border-radius:12px;
  font-family:var(--fs);font-weight:700;
  cursor:pointer;transition:all .15s;white-space:nowrap;
  /* minimum touch target 44px */
  min-height:44px;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--y);color:#000;padding:13px 18px;font-size:15px}
.btn-primary:hover{background:var(--yd)}
.btn-secondary{background:var(--s3);color:var(--txt);padding:13px 18px;font-size:15px;border:1.5px solid var(--b2)}
.btn-secondary:hover{background:var(--s4)}
.btn-danger{background:transparent;color:var(--red);padding:13px 18px;font-size:14px;border:1.5px solid var(--red25)}
.btn-danger:hover{background:var(--red10)}
.btn-ghost{background:transparent;color:var(--dim);padding:8px;border-radius:10px;border:1.5px solid var(--b2);min-height:40px}
.btn-ghost:hover{background:var(--s3);color:var(--txt)}
.btn-full{width:100%;margin-top:8px}
.btn-icon{width:40px;height:40px;border-radius:10px;background:var(--s3);border:1.5px solid var(--b1);color:var(--dim);flex-shrink:0}
.btn-icon:hover{background:var(--s4);color:var(--txt)}
.btn-icon:active{transform:scale(.94)}

/* ═══════════════════════════════════════════
   INPUTS
═══════════════════════════════════════════ */
.input,.select,.textarea{
  width:100%;background:var(--s2);
  border:1.5px solid var(--b2);border-radius:12px;
  padding:13px 14px;color:var(--txt);
  font-size:16px;/* 16px prevents iOS zoom */
  font-weight:500;outline:none;
  transition:border-color .15s;-webkit-appearance:none;
  min-height:48px;
}
.input:focus,.select:focus,.textarea:focus{border-color:var(--y)}
.input::placeholder,.textarea::placeholder{color:var(--dim);font-weight:400}
.select{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  padding-right:40px;
}
.textarea{resize:none;min-height:80px;line-height:1.5;font-size:14px}
.field{margin-bottom:12px}
.field-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:7px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ═══════════════════════════════════════════
   SECTION CARD
═══════════════════════════════════════════ */
.section{background:var(--s1);border:1.5px solid var(--b1);border-radius:16px;overflow:hidden;margin-bottom:12px}
.section-h{padding:13px 16px;border-bottom:1px solid var(--b1);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--dim)}
.section-b{padding:14px 16px}

/* ═══════════════════════════════════════════
   PAGE WRAPPER
═══════════════════════════════════════════ */
.pg{
  padding-top:calc(var(--nav-h) + 12px);
  padding-left:16px;padding-right:16px;
  padding-bottom:calc(72px + var(--safe-b));
}

/* ═══════════════════════════════════════════
   HERO
═══════════════════════════════════════════ */
.hero{margin-bottom:20px}
.hero-sup{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-bottom:4px}
.hero-h{font-size:28px;font-weight:800;line-height:1.15;letter-spacing:-.5px}
.hero-h span{color:var(--y)}

/* ═══════════════════════════════════════════
   MATCH CARDS
═══════════════════════════════════════════ */
.match-list{display:flex;flex-direction:column;gap:9px}
.match-card{
  background:var(--s2);border:1.5px solid var(--b1);border-radius:14px;overflow:hidden;
  cursor:pointer;transition:border-color .15s;
  /* touch feedback */
  -webkit-tap-highlight-color:rgba(247,195,37,.08);
}
.match-card:hover{border-color:var(--b3)}
.match-card:active{background:var(--s3)}
.match-card-top{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--b1)}
.match-card-name{font-size:14px;font-weight:700}
.match-card-date{font-size:10px;color:var(--dim);margin-top:1px}
.match-card-scores{display:flex;align-items:center;justify-content:space-between;padding:14px}
.mcs-team{display:flex;flex-direction:column;align-items:center;gap:3px}
.mcs-name{font-size:11px;color:var(--dim);font-weight:600}
.mcs-score{font-family:var(--fm);font-size:32px;font-weight:700;line-height:1}
.mcs-score.leader{color:var(--y)}
.mcs-sep{font-size:11px;color:var(--faint);font-weight:700}

.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:20px;font-size:10px;font-weight:700}
.chip-green{background:rgba(62,207,114,.12);color:#3ECF72}
.chip-blue{background:rgba(59,130,246,.12);color:#60A5FA}
.chip-yellow{background:var(--y10);color:var(--y)}
.chip-red{background:var(--red10);color:var(--red)}

.empty-state{display:flex;flex-direction:column;align-items:center;padding:56px 20px;color:var(--dim)}
.empty-state-text{font-size:13px;font-weight:500;margin-top:12px;text-align:center;line-height:1.5}

/* ═══════════════════════════════════════════
   TABS
═══════════════════════════════════════════ */
.tabs{display:flex;background:var(--s2);border-radius:13px;padding:4px;gap:3px;margin-bottom:16px}
.tab{
  flex:1;padding:10px 4px;border-radius:10px;border:none;
  background:transparent;color:var(--dim);
  font-size:12px;font-weight:700;transition:all .15s;
  display:flex;align-items:center;justify-content:center;gap:5px;
  min-height:40px;
}
.tab.on{background:var(--y);color:#000}

/* ═══════════════════════════════════════════
   PAGE HEADER
═══════════════════════════════════════════ */
.back-btn{
  display:flex;align-items:center;gap:7px;
  background:transparent;border:none;color:var(--dim);
  font-size:14px;font-weight:600;cursor:pointer;padding:0;
  transition:color .15s;margin-bottom:18px;
  min-height:44px;
}
.back-btn:hover{color:var(--txt)}

/* ═══════════════════════════════════════════
   BO PICKER
═══════════════════════════════════════════ */
.bo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.bo-opt{
  background:var(--s3);border:2px solid var(--b2);border-radius:13px;
  padding:14px 6px;text-align:center;cursor:pointer;transition:all .16s;
  min-height:68px;display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.bo-opt.on{border-color:var(--y);background:var(--y10)}
.bo-opt:active{transform:scale(.95)}
.bo-n{font-size:18px;font-weight:800;color:var(--y);line-height:1}
.bo-s{font-size:9px;color:var(--dim);margin-top:4px;font-weight:600}
.bo-desc{font-size:12px;color:var(--dim);line-height:1.5;margin-top:10px}
.bo-desc b{color:var(--txt)}

/* ═══════════════════════════════════════════
   STEPPER
═══════════════════════════════════════════ */
.stepper{display:flex;background:var(--s2);border:1.5px solid var(--b2);border-radius:13px;overflow:hidden;align-items:stretch}
.st-btn{
  width:60px;border:none;background:transparent;color:var(--txt);font-size:24px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .13s;padding:0;min-height:56px;
}
.st-btn:hover{background:var(--s3)}
.st-btn:active{background:var(--s4)}
.st-mid{flex:1;text-align:center;border-left:1px solid var(--b1);border-right:1px solid var(--b1);padding:10px 4px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.st-v{font-size:28px;font-weight:800;color:var(--y);line-height:1}
.st-h{font-size:10px;color:var(--dim);margin-top:3px}

/* ═══════════════════════════════════════════
   MATCH RIBBON (in-game header)
═══════════════════════════════════════════ */
.ribbon{background:var(--s1);border:1.5px solid var(--b1);border-radius:16px;padding:14px;margin-bottom:12px}
.rib-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:10px}
.rib-name{font-size:15px;font-weight:800;letter-spacing:-.3px}
.rib-fmt{font-size:11px;color:var(--dim);margin-top:2px}
.series{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}
.sr-t{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-t.t1{color:var(--y)}
.sr-t.t2{color:var(--red);text-align:right}
.sr-c{text-align:center}
.sr-score{font-family:var(--fm);font-size:40px;font-weight:700;line-height:1;letter-spacing:-1px}
.sr-lbl{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:var(--dim);margin-top:3px}
.pips{display:flex;gap:5px;justify-content:center;margin-top:9px}
.pip{height:5px;border-radius:3px;flex:1;max-width:36px;background:var(--s4);transition:background .28s}
.pip.t1{background:var(--y)}.pip.t2{background:var(--red)}.pip.nx{outline:1.5px solid var(--dim);outline-offset:2px}

/* ═══════════════════════════════════════════
   SET CARD
═══════════════════════════════════════════ */
.set-card{background:var(--s1);border:1.5px solid var(--b1);border-radius:16px;margin-bottom:10px;overflow:hidden;transition:border-color .2s}
.set-card.active{border-color:var(--y25)}
.set-card.d1{border-color:rgba(247,195,37,.18)}.set-card.d2{border-color:rgba(232,69,60,.14)}
.set-hd{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--b1)}
.set-badge{
  width:30px;height:30px;border-radius:9px;background:var(--s3);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:var(--dim);flex-shrink:0;
}
.set-card.active .set-badge{background:var(--y);color:#000}
.set-hd-info{flex:1;min-width:0}
.set-hd-name{font-size:14px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.set-hd-desc{font-size:11px;color:var(--dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.set-hd-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.set-sc{font-family:var(--fm);font-size:15px;font-weight:700}
.set-sc.cur{color:var(--dim)}.set-sc.w1{color:var(--y)}.set-sc.w2{color:var(--red)}

/* ═══════════════════════════════════════════
   MANCHE ROW (done)
═══════════════════════════════════════════ */
.m-row{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-bottom:1px solid var(--b1);
}
.m-row:last-of-type{border-bottom:none}
.m-idx{width:20px;text-align:center;font-size:11px;color:var(--dim);font-weight:700;flex-shrink:0}
.m-info{flex:1;min-width:0}
.m-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.m-desc{font-size:11px;color:var(--dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.m-sc{display:flex;align-items:center;gap:6px;flex-shrink:0}
.m-num{font-family:var(--fm);font-size:16px;font-weight:700;min-width:22px;text-align:center}
.m-num.w{color:var(--y)}.m-num.l{color:var(--red)}
.m-dash{font-size:12px;color:var(--faint)}
.m-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.m-dot.t1{background:var(--y)}.m-dot.t2{background:var(--red)}
.m-actions{display:flex;gap:2px;flex-shrink:0}
.m-btn{
  width:36px;height:36px;border-radius:9px;border:none;
  background:transparent;color:var(--dim);
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;cursor:pointer;
}
.m-btn:hover{background:var(--s3);color:var(--txt)}
.m-btn:active{transform:scale(.9)}
.m-btn.del:hover{background:var(--red10);color:var(--red)}

/* ═══════════════════════════════════════════
   MANCHE INPUT ZONE
═══════════════════════════════════════════ */
.m-input{padding:14px;background:rgba(247,195,37,.02);border-top:1px solid var(--b1)}
.mi-title{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--y);margin-bottom:13px}
.mi-fields{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.mi-field{
  display:flex;align-items:center;gap:9px;
  background:var(--s2);border:1.5px solid var(--b1);border-radius:11px;
  padding:11px 13px;transition:border-color .14s;
}
.mi-field:focus-within{border-color:var(--b3)}
.mi-field-ico{flex-shrink:0;opacity:.4;display:flex;align-items:center}
.mi-field input{
  flex:1;background:transparent;border:none;color:var(--txt);
  font-size:15px;font-weight:500;outline:none;
}
.mi-field input::placeholder{color:var(--dim);font-weight:400}

/* ═══════════════════════════════════════════
   SCORE ENTRY — BIG BUTTONS
═══════════════════════════════════════════ */
.se{display:grid;grid-template-columns:1fr 28px 1fr;gap:10px;align-items:center;margin-bottom:14px}
.se-side{display:flex;flex-direction:column;gap:8px}
.se-tname{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.se-tname.t1{color:var(--y)}.se-tname.t2{color:var(--red)}
.se-num{
  font-family:var(--fm);font-size:64px;font-weight:700;line-height:1;
  text-align:center;padding:10px 4px;border-radius:13px;
  background:var(--s2);transition:all .12s;user-select:none;
}
.se-num.hi{color:var(--y);background:var(--y10)}.se-num.lo{color:var(--red);background:var(--red10)}.se-num.ne{color:var(--txt)}
.se-btns{display:grid;grid-template-columns:1fr 1.7fr;gap:6px}
.se-m{
  height:52px;border-radius:11px;border:1.5px solid var(--b2);
  background:var(--s3);color:var(--dim);font-size:24px;
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;cursor:pointer;
}
.se-m:hover{background:var(--s4);color:var(--txt)}
.se-m:active{transform:scale(.92)}
.se-p{
  height:52px;border-radius:11px;border:none;font-size:30px;font-weight:800;
  display:flex;align-items:center;justify-content:center;transition:all .12s;cursor:pointer;
}
.se-p.t1{background:var(--y);color:#000}.se-p.t2{background:var(--red);color:#fff}
.se-p:active{transform:scale(.92)}
.se-dash{font-size:20px;color:var(--faint);text-align:center;font-weight:700}

/* ═══════════════════════════════════════════
   VALIDATE BUTTON
═══════════════════════════════════════════ */
.vld-pre{
  display:flex;align-items:center;gap:10px;
  padding:12px 13px;background:var(--s2);border-radius:11px;margin-bottom:9px;
}
.vp-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.vp-dot.t1{background:var(--y)}.vp-dot.t2{background:var(--red)}
.vp-txt{font-size:14px;font-weight:600;flex:1}
.vp-sc{font-family:var(--fm);font-size:12px;color:var(--dim)}
.btn-vld{
  width:100%;padding:16px;border-radius:13px;border:none;
  font-size:16px;font-weight:800;letter-spacing:-.1px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .15s;cursor:pointer;min-height:54px;
}
.btn-vld.rdy{background:var(--y);color:#000}
.btn-vld.rdy:hover{background:var(--yd)}
.btn-vld.rdy:active{transform:scale(.98)}
.btn-vld.dis{background:var(--s2);color:var(--dim);border:1.5px dashed var(--b2);cursor:default}

/* ═══════════════════════════════════════════
   BANNERS
═══════════════════════════════════════════ */
.banner{border-radius:16px;padding:18px;text-align:center;margin-bottom:12px;animation:up .28s ease}
@keyframes up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.banner.setwon{background:var(--s2);border:1.5px solid var(--y25)}
.banner.gamewon{background:var(--s2);border:1.5px solid var(--b2)}
.bn-ico{margin-bottom:8px;display:flex;justify-content:center;color:var(--y)}
.bn-title{font-size:22px;font-weight:800;letter-spacing:-.4px;color:var(--y);margin-bottom:4px}
.bn-title.big{font-size:28px}
.bn-sub{font-size:13px;color:var(--dim);margin-bottom:16px;line-height:1.5}
.bn-recap{display:flex;justify-content:center;gap:24px;margin-bottom:18px}
.bn-r{text-align:center}
.bn-r-l{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);margin-bottom:3px}
.bn-r-v{font-family:var(--fm);font-size:34px;font-weight:700}
.bn-r-v.w{color:var(--y)}.bn-r-v.l{color:var(--red)}
.bn-acts{display:flex;gap:9px}
.btn-next{
  width:100%;padding:16px;border-radius:12px;border:none;
  background:var(--y);color:#000;font-size:15px;font-weight:800;
  cursor:pointer;transition:all .15s;min-height:52px;
}
.btn-next:hover{background:var(--yd)}
.btn-next:active{transform:scale(.98)}

/* ═══════════════════════════════════════════
   MODAL BOTTOM SHEET
═══════════════════════════════════════════ */
.m-ov{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,.78);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .22s;
}
.m-ov.open{opacity:1;pointer-events:all}
.m-sheet{
  width:100%;max-width:520px;background:var(--s2);
  border-radius:24px 24px 0 0;border-top:1.5px solid var(--b2);
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  max-height:92vh;overflow-y:auto;
  padding-bottom:var(--safe-b);
}
.m-ov.open .m-sheet{transform:translateY(0)}
.m-handle{width:36px;height:4px;background:var(--b3);border-radius:2px;margin:14px auto 18px}
.m-title{font-size:18px;font-weight:800;padding:0 18px 15px;border-bottom:1px solid var(--b1)}
.m-body{padding:14px 16px 20px}
.m-acts{display:flex;flex-direction:column;gap:8px;margin-bottom:9px}
.m-act{
  display:flex;align-items:center;gap:13px;
  padding:15px 16px;border-radius:12px;border:none;
  background:var(--s3);color:var(--txt);
  font-size:14px;font-weight:600;transition:all .14s;cursor:pointer;text-align:left;width:100%;
  min-height:52px;
}
.m-act:hover{background:var(--s4)}
.m-act:active{transform:scale(.98)}
.m-act.danger{color:var(--red)}
.m-act.danger:hover{background:var(--red10)}
.m-act-ico{width:24px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.m-cancel{
  width:100%;padding:14px;border-radius:12px;border:1.5px solid var(--b2);
  background:transparent;color:var(--dim);font-size:14px;font-weight:700;
  cursor:pointer;transition:all .14s;min-height:52px;
}
.m-cancel:hover{background:var(--s3);color:var(--txt)}

/* ═══════════════════════════════════════════
   EDIT MODAL SCORE ROW
═══════════════════════════════════════════ */
.edit-sc-row{display:grid;grid-template-columns:1fr 20px 1fr;gap:10px;align-items:center;margin-bottom:13px}
.esc-lbl{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-bottom:7px;text-align:center}
.esc-ctrl{display:flex;gap:6px;align-items:center;justify-content:center}
.esc-btn{
  height:44px;flex:1;border-radius:10px;border:1.5px solid var(--b2);
  background:var(--s3);color:var(--dim);font-size:20px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s;
}
.esc-btn:hover{background:var(--s4);color:var(--txt)}
.esc-val{font-family:var(--fm);font-size:30px;font-weight:700;text-align:center;min-width:48px;color:var(--txt)}
.esc-dash{text-align:center;font-size:14px;color:var(--faint);font-weight:700}
.edit-acts{display:flex;gap:9px;margin-top:14px}
.btn-save{flex:1;padding:14px;border-radius:11px;border:none;background:var(--y);color:#000;font-size:15px;font-weight:800;cursor:pointer;transition:all .14s;min-height:50px}
.btn-save:hover{background:var(--yd)}
.btn-cx{padding:14px 18px;border-radius:11px;border:1.5px solid var(--b2);background:transparent;color:var(--dim);font-size:14px;font-weight:700;cursor:pointer;transition:all .14s;min-height:50px}
.btn-cx:hover{background:var(--s3);color:var(--txt)}

/* ═══════════════════════════════════════════
   STATS
═══════════════════════════════════════════ */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:10px}
.stat-tile{background:var(--s1);border:1.5px solid var(--b1);border-radius:14px;padding:14px}
.stat-tile-l{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);margin-bottom:9px}
.stat-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.stat-name{font-size:12px;font-weight:500}
.stat-val{font-family:var(--fm);font-size:24px;font-weight:700}
.stat-val.y{color:var(--y)}.stat-val.r{color:var(--red)}
.stat-div{height:1px;background:var(--b1);margin:7px 0}
.h2h{height:5px;border-radius:3px;overflow:hidden;display:flex;margin-top:9px;margin-bottom:4px}
.h2h-t1{background:var(--y);transition:width .5s}.h2h-t2{background:var(--red);transition:width .5s}
.h2h-l{display:flex;justify-content:space-between;font-size:9px;color:var(--dim)}

/* ═══════════════════════════════════════════
   HISTORY
═══════════════════════════════════════════ */
.hi-sets{border-top:1px solid var(--b1)}
.hi-sr{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;padding:8px 14px;border-bottom:1px solid var(--b1);font-size:10px}
.hi-sr:last-child{border-bottom:none}
.hi-sn{color:var(--dim);font-weight:700;white-space:nowrap;font-size:10px}
.hi-chips{display:flex;gap:3px;flex-wrap:wrap}
.hi-ch{padding:2px 7px;border-radius:20px;font-size:9px;font-family:var(--fm)}
.hi-ch.w{background:var(--y10);color:var(--y)}.hi-ch.l{background:var(--red10);color:var(--red)}
.hi-res{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;white-space:nowrap}
.hi-res.w{background:var(--y10);color:var(--y)}.hi-res.l{background:var(--red10);color:var(--red)}

/* ═══════════════════════════════════════════
   TOAST
═══════════════════════════════════════════ */
.toast{
  position:fixed;bottom:calc(80px + var(--safe-b) + 10px);
  left:50%;transform:translateX(-50%);
  background:var(--s4);color:var(--txt);
  padding:12px 20px;border-radius:12px;
  font-size:14px;font-weight:600;z-index:500;
  animation:up .2s ease;border:1px solid var(--b2);
  white-space:nowrap;max-width:calc(100vw - 32px);
  text-align:center;
}

/* ═══════════════════════════════════════════
   LOADING
═══════════════════════════════════════════ */
.loading{display:flex;align-items:center;justify-content:center;padding:56px;color:var(--dim);font-size:14px}

/* ═══════════════════════════════════════════
   HOME — NO SCROLL FULL SCREEN LAYOUT
═══════════════════════════════════════════ */
.home-layout{
  display:flex;flex-direction:column;
  height:100dvh;
  max-height:100dvh;
  padding:0;overflow:hidden;
}
/* When home is shown, prevent #app-scroll from scrolling */
#app-scroll:has(.home-layout){overflow:hidden}

/* VS header */
.home-vs{
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:8px;
  padding:16px 16px 12px;
  flex-shrink:0;
}
.home-vs-team{
  font-size:16px;font-weight:800;letter-spacing:-.3px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.home-vs-team.t1{color:var(--y);text-align:left}
.home-vs-team.t2{color:var(--red);text-align:right}
.home-vs-sep{
  font-family:var(--fm);font-size:13px;font-weight:700;
  color:var(--dim);text-align:center;flex-shrink:0;
}

/* Tabs area — takes remaining space */
.home-tabs{
  flex:1;min-height:0;
  display:flex;flex-direction:column;
  padding:0 16px;
  overflow:hidden;
}
.home-tabs .tabs{flex-shrink:0}

/* Tab content — scrollable within its zone */
.home-tab-content{
  flex:1;min-height:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:8px;
}

/* Bottom CTA — fixed at bottom */
.home-bottom{
  padding:12px 16px;
  padding-bottom:calc(12px + var(--safe-b));
  flex-shrink:0;
  border-top:1px solid var(--b1);
  background:var(--bg);
}

ar(--s4);color:var(--txt);padding:10px 18px;border-radius:10px;font-size:13px;font-weight:600;z-index:500;animation:up .2s ease;border:1px solid var(--b2)}

/* LOADING */
.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--dim);font-size:13px}