/* ── Teams tab styles ── */
#pg-sat{display:none;}
#pg-sat.on{display:flex;flex-direction:column;height:100dvh;overflow:hidden;}

/* ── Match Days list view ── */
#satListView{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;}
.sat-list-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;
  background:var(--surf);border-bottom:1px solid var(--bdr);flex-shrink:0;}
.sat-list-title{font-size:17px;font-weight:800;color:var(--cream);}
.sat-list-actions{display:flex;align-items:center;gap:8px;}
.sat-day-list{flex:1;overflow-y:auto;padding:10px 12px 100px;}
/* Swipe-to-delete wrapper */
.sdi-swipe-wrap{position:relative;margin-bottom:8px;border-radius:14px;overflow:hidden;}
.sdi-del-bg{position:absolute;right:0;top:0;bottom:0;width:88px;
  background:#dc2626;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  color:#fff;border-radius:0 14px 14px 0;pointer-events:none;}
.sdi-del-bg [data-lucide]{width:20px;height:20px;}
.sdi-del-bg span{font-size:11px;font-weight:700;font-family:-apple-system,sans-serif;}

/* Day list items */
.sat-day-item{display:flex;flex-direction:column;gap:8px;
  padding:13px 14px;background:var(--surf);border-radius:14px;margin-bottom:0;
  border:1px solid var(--bdr);cursor:pointer;position:relative;z-index:1;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .12s;}
.sat-day-item:active{background:var(--bg);}
.sdi-top-row{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.sdi-actions{display:flex;align-items:center;gap:7px;flex-shrink:0;}
.sdi-date{font-size:15px;font-weight:700;color:var(--cream);}
.sdi-arrow{color:var(--muted);display:flex;align-items:center;}
.sdi-arrow [data-lucide]{width:16px;height:16px;}
/* Meta row (players count etc) */
.sdi-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.sdi-meta-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--muted);}
.sdi-meta-item [data-lucide]{width:12px;height:12px;}
.sdi-meta-item strong{color:var(--cream);font-weight:700;}
/* Team rows */
.sdi-team-row{display:flex;align-items:center;gap:5px;font-size:12px;overflow:hidden;}
.sdi-team-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.sdi-team-label{font-weight:700;color:var(--cream);font-size:12px;min-width:46px;flex-shrink:0;}
.sdi-team-opp{color:var(--muted);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;}
.sdi-team-extra{display:flex;align-items:center;gap:3px;color:var(--muted);font-size:11px;flex-shrink:0;white-space:nowrap;}
.sdi-team-extra [data-lucide]{width:10px;height:10px;flex-shrink:0;}
.sdi-section-hd{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;
  letter-spacing:1.2px;padding:16px 4px 8px;}
.sdi-empty{padding:40px 20px;text-align:center;color:var(--muted);font-size:13px;line-height:1.6;}
/* Status pills for day list */
.sdl-pill{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
  padding:3px 8px;border-radius:8px;flex-shrink:0;
  background:var(--bg);color:var(--muted);border:1px solid var(--bdr);}
.sdl-pill--planning{background:rgba(59,130,246,.1);color:#1d4ed8;border-color:rgba(59,130,246,.25);}
.sdl-pill--live{background:rgba(22,163,74,.12);color:var(--green);border-color:rgba(22,163,74,.3);}
.sdl-pill--finished{background:#f1f5f9;color:#334155;border-color:#cbd5e1;}
.sdl-pill--past{background:var(--bg);color:var(--muted);border-color:var(--bdr);}

/* ── Match Day detail view ── */
#satDetailView{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;}

/* ── Planning / Score mode tab bar ── */
.sat-detail-mode-tabs{display:flex;background:var(--surf);border-bottom:2px solid var(--bdr);flex-shrink:0;}
.sdmt-btn{flex:1;padding:11px 16px;border:none;background:transparent;
  font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;
  border-bottom:3px solid transparent;margin-bottom:-2px;
  font-family:-apple-system,sans-serif;transition:color .15s,border-color .15s;}
.sdmt-btn.sdmt-on{color:var(--green);border-bottom-color:var(--green);}

/* ── Planning pane ── */
#satPlanningPane{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;}

/* ── Score pane ── */
#satScorePane{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;}

/* ── List row score button ── */
.sdi-score-btn{flex-shrink:0;padding:7px 10px;border:1px solid var(--bdr);
  border-radius:10px;background:var(--surf);color:var(--muted);
  cursor:pointer;display:flex;align-items:center;gap:5px;
  font-size:12px;font-weight:700;font-family:-apple-system,sans-serif;
  transition:background .12s;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.sdi-score-btn:hover{background:var(--bg);}
.sdi-score-btn [data-lucide]{width:13px;height:13px;}
.sdi-team-score{font-size:11px;font-weight:700;color:var(--green);background:rgba(22,163,74,.09);border-radius:5px;padding:1px 6px;white-space:nowrap;}
.sdi-team-score--opp{color:var(--muted);background:var(--bg);}
.sdi-team-score-sep{font-size:10px;color:var(--muted);margin:0 1px;}
.sat-detail-hd{display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--surf);border-bottom:1px solid var(--bdr);flex-shrink:0;}
.sat-back-btn{display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:10px;border:1px solid var(--bdr);
  background:var(--bg);color:var(--cream);cursor:pointer;flex-shrink:0;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.sat-back-btn:active{background:var(--bdr);}
.sat-back-btn [data-lucide]{width:18px;height:18px;}
.sat-detail-date{font-size:16px;font-weight:800;color:var(--cream);flex:1;}

/* ── Match Day top bar ── */
.match-day-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;
  background:var(--surf);border-bottom:1px solid var(--bdr);flex-shrink:0;gap:8px;flex-wrap:wrap;}
.match-day-bar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.team-count-pills{display:flex;gap:6px;}
.tc-pill{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:16px;font-size:12px;font-weight:700;}
.tc-g{background:var(--dim);color:var(--green);border:1px solid rgba(22,163,74,.25);}
.tc-w{background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;}
.tc-pill span{font-size:15px;font-weight:800;}
/* Sport pill in Teams bar */
.sport-day-pill{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:14px;
  background:var(--surf2);border:1px solid var(--bdr);font-size:12px;font-weight:700;
  cursor:pointer;color:var(--cream);white-space:nowrap;transition:border-color .15s;}
.sport-day-pill:hover{border-color:var(--green);}

/* ── Match info shared ── */
.mis-sep{font-size:12px;color:var(--bdr);font-weight:400;}

/* Edit form */
.mis-form{padding:12px 14px 14px;border-top:1px solid var(--bdr);background:var(--surf2);}
.mis-teams-row{display:flex;gap:12px;margin-bottom:10px;}
.mis-team-section{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;}
.mis-team-label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:800;color:var(--cream);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;}
.mis-team-g .mis-team-label{color:var(--green);}
.mis-team-w .mis-team-label{color:#64748b;}
.mis-form-row{display:flex;flex-wrap:wrap;gap:8px;}
.mis-field{display:flex;flex-direction:column;gap:4px;min-width:80px;flex:1;}
.mis-field--wide{flex:2;min-width:120px;}
.mis-label{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;}
.mis-label [data-lucide]{width:10px;height:10px;}
.mis-input{
  background:var(--surf);border:1px solid var(--bdr);border-radius:8px;
  padding:7px 10px;font-size:13px;color:var(--cream);font-family:inherit;
  outline:none;transition:border-color .15s;width:100%;
}
.mis-input:focus{border-color:var(--bright);}
.mis-form-actions{display:flex;gap:6px;align-items:center;}
.mis-clear-btn{margin-left:auto;color:var(--muted);}
/* Location Google Maps link */
.mis-loc-link{color:var(--bright);text-decoration:none;border-bottom:1px solid rgba(22,163,74,.3);}
.mis-loc-link:hover{border-bottom-color:var(--bright);}
/* Per-team strip chips */
.mis-team-chip{display:inline-flex;align-items:center;font-size:12px;font-weight:600;color:var(--cream);}
.mis-chip-g{color:var(--green);}
.mis-chip-w{color:#64748b;}
.mis-team-chip+.mis-team-chip::before{content:'·';margin:0 7px;color:var(--bdr);}
@media(max-width:480px){.mis-teams-row{flex-direction:column;}}

/* ── Match Day teams area ── */
.match-teams{display:flex;flex:1;overflow:hidden;}
/* padding-bottom must clear: nav (~62px) + gap(12px) + bar(~46px) + gap(8px) = ~128px. 160px gives breathing room */
.match-teams .team-col{flex:1;overflow-y:auto;padding-bottom:160px;}

/* ── Match Day bottom bar ── */
.match-bottom-bar{
  position:fixed;bottom:calc(90px + env(safe-area-inset-bottom));
  left:12px;right:12px;z-index:55;
  background:rgba(255,255,255,0.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--bdr);border-radius:12px;
  box-shadow:0 2px 10px rgba(0,0,0,.08);
  display:flex;align-items:center;justify-content:space-between;padding:6px 10px;gap:8px;}
.mbb-stats{display:flex;align-items:center;gap:5px;flex:1;flex-wrap:nowrap;min-width:0;}
.mbb-stat{font-size:12px;font-weight:700;color:var(--cream);display:flex;align-items:center;gap:4px;}
.mbb-stat-num{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:13px;font-weight:800;}
.mbb-stat-lbl{font-size:11px;font-weight:600;color:var(--muted);}
.mbb-mins{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap;}
.mbb-dot{color:var(--bdr);font-size:12px;}
.mbb-actions{display:flex;gap:5px;align-items:center;flex-shrink:0;}

/* ── Availability modal ── */
.avail-modal{height:88vh;max-height:88vh;display:flex;flex-direction:column;padding:0;overflow:hidden;}
.avail-modal-hd{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;border-bottom:1px solid var(--bdr);flex-shrink:0;}
.avail-modal-hd h3{margin:0;}
.avail-modal-actions{display:flex;align-items:center;gap:7px;
  padding:8px 12px;border-bottom:1px solid var(--bdr);flex-shrink:0;}
.avail-modal-actions .avail-search{flex:1;margin-bottom:0;}
.avail-filter-row{display:flex;gap:5px;padding:6px 12px;border-bottom:1px solid var(--bdr);flex-shrink:0;flex-wrap:wrap;}
#availList{flex:1;overflow-y:auto;padding:6px 12px;min-height:0;}
.avail-modal-sum{padding:10px 14px;border-top:1px solid var(--bdr);
  flex-shrink:0;background:var(--surf2);border-radius:0 0 20px 20px;}

/* ── Richer availability rows ── */
.avail-info{flex:1;min-width:0;}
.avail-name{font-size:13px;font-weight:700;color:var(--cream);display:block;}
.avail-meta{display:flex;align-items:center;gap:6px;margin-top:2px;flex-wrap:wrap;}
.avail-skill{font-size:11px;color:#f59e0b;letter-spacing:1px;}

/* ── Inline G/W toggle for Both players ── */
.both-inline{display:flex;gap:3px;flex-shrink:0;background:var(--surf2);border:1px solid var(--bdr);border-radius:10px;padding:2px;}
.bi-btn{padding:4px 11px;border:none;cursor:pointer;font-size:11px;font-weight:800;
  letter-spacing:.5px;border-radius:7px;background:transparent;color:var(--muted);transition:all .15s;}
.bi-btn.on-g{background:var(--green);color:#fff;box-shadow:0 1px 4px rgba(21,128,61,.3);}
.bi-btn.on-w{background:#475569;color:#fff;box-shadow:0 1px 4px rgba(71,85,105,.3);}
.sec-ttl{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:10px;letter-spacing:2px;color:var(--green);text-transform:uppercase;margin-bottom:3px;font-weight:800;}
select,input[type=number],input[type=text],input[type=date]{
  background:var(--surf2);border:1px solid var(--bdr);border-radius:10px;color:var(--cream);
  padding:8px 10px;font-family:-apple-system,'Roboto',sans-serif;font-size:13px;width:100%;}
select:focus,input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(21,128,61,.1);}
label.cfg-lbl{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-weight:700;}
.cfg-row{display:flex;flex-direction:column;gap:6px;}
.win-seg{display:flex;gap:5px;}
.win-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:9px 4px;border:1px solid var(--bdr);border-radius:12px;
  background:var(--surf2);cursor:pointer;gap:3px;transition:all .18s;}
.win-btn.on{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 2px 8px rgba(21,128,61,.25);}
.win-num{font-size:20px;font-weight:800;line-height:1;font-family:-apple-system,sans-serif;}
.win-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;opacity:.75;}

.btn{padding:8px 14px;border:none;border-radius:12px;cursor:pointer;font-family:-apple-system,'Roboto Condensed',sans-serif;
  font-size:13px;font-weight:800;letter-spacing:.3px;transition:all .18s;white-space:nowrap;touch-action:manipulation;}
.btn-green{background:var(--green);color:#fff;} .btn-green:active{background:var(--bright);}
.btn-white{background:#fff;color:var(--cream);border:1px solid var(--bdr);box-shadow:0 1px 3px rgba(0,0,0,.06);} .btn-white:active{background:var(--surf2);}
.btn-ghost{background:var(--surf2);color:var(--muted);border:1px solid var(--bdr);} .btn-ghost:active{color:var(--cream);}
.btn-red{background:var(--red);color:#fff;}
.btn-sm{padding:5px 10px;font-size:11px;}
.btn-xs{padding:4px 8px;font-size:10px;}
.btn-full{width:100%;text-align:center;padding:13px;}
.btn-row{display:flex;gap:5px;flex-wrap:wrap;}
.divider{height:1px;background:var(--bdr);flex-shrink:0;}

.des{display:inline-block;font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:10px;font-weight:800;
  padding:2px 7px;border-radius:6px;flex-shrink:0;}
.des-G{background:var(--tg-bdg-bg);color:var(--tg-bdg-tx);border:1px solid var(--tg-bdr);}
.des-W{background:var(--tw-bdg-bg);color:var(--tw-bdg-tx);border:1px solid var(--tw-bdr);}
.des-Both{background:var(--tb-bdg-bg);color:var(--tb-bdg-tx);border:1px solid var(--tb-bdr);}

.avail-search{background:var(--surf2);border:1px solid var(--bdr);border-radius:10px;color:var(--cream);
  padding:7px 10px;font-size:12px;width:100%;margin-bottom:4px;}
.avail-search::placeholder{color:var(--muted);}
.avail-search:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(21,128,61,.1);}
.avail-grp-hd{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:10px;letter-spacing:1.5px;color:var(--muted);
  text-transform:uppercase;padding:4px 4px 2px;border-bottom:1px solid var(--bdr);margin-top:3px;font-weight:700;}
.avail-list{display:flex;flex-direction:column;gap:2px;max-height:250px;overflow-y:auto;}
.avail-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;
  cursor:pointer;border:1px solid transparent;border-left:3px solid transparent;margin-bottom:4px;}
/* Always-on left border hint by team designation */
.avail-item.des-G{border-left-color:rgba(22,163,74,.35);}
.avail-item.des-W{border-left-color:rgba(148,163,184,.5);}
.avail-item.des-Both{border-left-color:rgba(59,130,246,.45);}
/* Ticked state: stronger border + background */
.avail-item.tk-G{background:rgba(22,163,74,.08);border-color:rgba(22,163,74,.22);border-left-color:var(--green);}
.avail-item.tk-W{background:rgba(148,163,184,.08);border-color:rgba(148,163,184,.22);border-left-color:#94a3b8;}
.avail-item.tk-Both{background:rgba(59,130,246,.06);border-color:rgba(59,130,246,.18);border-left-color:var(--tb-bdr);}
.avail-item input[type=checkbox]{accent-color:var(--green);width:16px;height:16px;flex-shrink:0;}
.avail-pos{font-size:10px;font-family:-apple-system,'Roboto Condensed',sans-serif;background:var(--surf2);color:var(--muted);padding:1px 5px;border-radius:5px;flex-shrink:0;border:1px solid var(--bdr);}
/* ── Flex Players (Both quick-assign) ── */
.both-row{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-radius:10px;
  background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.15);margin-bottom:3px;}
.both-name{font-size:12px;font-weight:700;color:var(--cream);flex:1;}
.both-tog{display:flex;gap:3px;background:var(--surf2);border:1px solid var(--bdr);border-radius:10px;padding:2px;}
.both-btn{padding:4px 12px;border:none;cursor:pointer;font-size:11px;font-weight:800;
  letter-spacing:.5px;border-radius:8px;background:transparent;color:var(--muted);transition:all .15s;}
.both-btn.on-g{background:var(--green);color:#fff;box-shadow:0 1px 4px rgba(21,128,61,.3);}
.both-btn.on-w{background:#475569;color:#fff;box-shadow:0 1px 4px rgba(71,85,105,.3);}
.sum-box{background:var(--surf2);border:1px solid var(--bdr);border-radius:12px;padding:10px;}
.sum-row{display:flex;justify-content:space-between;align-items:baseline;padding:2px 0;}
.sum-label{font-size:11px;color:var(--muted);}
.sum-val{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--green);}
.sum-note{font-size:10px;color:var(--muted);margin-top:4px;line-height:1.5;text-align:center;}

.team-col{border-right:1px solid var(--bdr);overflow-y:auto;padding:10px 8px;display:flex;flex-direction:column;gap:8px;background:var(--bg);}
.team-col:last-child{border-right:none;}
.col-G{border-top:4px solid var(--green);}
.col-W{border-top:4px solid #94a3b8;}
.team-hd{display:flex;flex-direction:column;gap:0;}
.team-hd-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
/* Per-team match info row */
.team-info-row{
  display:flex;align-items:center;gap:6px;
  padding:6px 10px;cursor:pointer;
  font-size:12px;color:var(--muted);
  border:1.5px dashed var(--bdr);border-radius:8px;
  margin:6px 8px 2px;background:var(--surf2);
  transition:all .15s;min-height:30px;
}
.team-info-row:hover{border-color:var(--green);color:var(--cream);background:#f0fdf4;}
.team-info-row.tmi-row--filled{color:var(--cream);border-style:solid;background:var(--surf);border-color:var(--bdr);}
.team-info-row.tmi-row--missing{border-color:rgba(220,38,38,.4);background:rgba(220,38,38,.04);animation:tmi-pulse 1s ease-out;}
@keyframes tmi-pulse{0%{box-shadow:0 0 0 0 rgba(220,38,38,.3);}100%{box-shadow:0 0 0 6px rgba(220,38,38,0);}}
.tmi-text{flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:1.3;}
.tmi-pencil{flex-shrink:0;width:12px;height:12px;opacity:.5;}
.team-info-row:hover .tmi-pencil{opacity:.9;}
/* Inline edit form */
.tmi-form{
  padding:8px 10px 10px;border-top:1px solid var(--bdr);
  background:var(--surf2);display:flex;flex-direction:column;gap:5px;
}
.tmi-form .mis-input{font-size:12px;padding:6px 8px;}
.tmi-form-actions{display:flex;gap:5px;padding-top:2px;}
.tmi-clear{margin-left:auto;font-size:11px;}
.team-badge{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;}
.tbdg-G{background:var(--green);color:#fff;}
.tbdg-W{background:#475569;color:#fff;}
.team-nm{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--cream);}

.fp{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.fp.good{background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.3);color:var(--green);}
.fp.warn{background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.3);color:#ca8a04;}
.fp-dot{width:7px;height:7px;border-radius:50%;background:currentColor;}
/* Legacy - kept for safety */
.rot-done-state{display:flex;align-items:center;gap:7px;padding:10px 12px;border-radius:12px;background:rgba(22,163,74,.07);border:1px solid rgba(22,163,74,.2);font-size:12px;font-weight:700;color:var(--green);}
.rot-done-state [data-lucide]{width:15px;height:15px;flex-shrink:0;}

/* ── Rotation success card ── */
.rot-success{
  background:linear-gradient(160deg,#f0fdf4 0%,#dcfce7 100%);
  border:1px solid rgba(22,163,74,.22);border-radius:14px;
  padding:14px 14px 12px;display:flex;flex-direction:column;gap:12px;
  box-shadow:0 2px 8px rgba(22,163,74,.08);
}
.rot-success-hd{display:flex;align-items:flex-start;gap:10px;}
.rot-success-icon{width:20px;height:20px;color:var(--green);flex-shrink:0;margin-top:2px;}
.rot-success-title{font-size:13px;font-weight:800;color:var(--green);}
.rot-success-sub{font-size:11px;color:var(--bright);margin-top:2px;opacity:.85;}
.rot-success-stats{
  display:flex;align-items:stretch;
  background:rgba(255,255,255,.65);border:1px solid rgba(22,163,74,.15);
  border-radius:10px;padding:10px 0;
}
.rot-stat-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;}
.rot-stat-val{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--green);line-height:1;}
.rot-stat-lbl{font-size:9px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.rot-stat-div{width:1px;background:rgba(22,163,74,.18);align-self:stretch;flex-shrink:0;}
.rot-success-cta{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:9px 14px;border:none;border-radius:10px;
  background:var(--green);color:#fff;font-size:12px;font-weight:700;
  cursor:pointer;font-family:-apple-system,sans-serif;
  transition:background .15s;
}
.rot-success-cta:hover{background:var(--bright);}
.rot-success-cta [data-lucide]{width:13px;height:13px;}

.squad-builder{background:var(--surf);border:1px solid var(--bdr);border-radius:12px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04);}
.sb-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;
  border-bottom:1px solid var(--bdr);font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:11px;background:var(--surf2);}
.sb-count{color:var(--green);font-size:14px;font-weight:700;}
.sb-hint{font-size:10px;color:var(--muted);margin-top:1px;}
.sb-pool{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:8px;min-height:40px;}
.sb-pool.drag-over{background:rgba(22,163,74,.06);outline:2px dashed rgba(22,163,74,.35);outline-offset:-3px;}
.sb-player{display:flex;align-items:center;gap:5px;padding:7px 8px;border-radius:9px;
  font-size:12px;font-weight:700;cursor:grab;border:1px solid transparent;user-select:none;min-width:0;}
.sp-grip{font-size:13px;color:var(--muted);opacity:.35;flex-shrink:0;cursor:grab;user-select:none;line-height:1;}
.sp-name{flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;}
.sb-player:active{cursor:grabbing;opacity:.7;}
.sp-pos{font-size:10px;opacity:.65;font-family:-apple-system,'Roboto Condensed',sans-serif;flex-shrink:0;}
/* Fat-finger move button — min 36×36 tap target */
.sp-move{min-width:34px;min-height:34px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;margin-left:auto;flex-shrink:0;background:transparent;border:none;
  border-radius:8px;font-size:14px;font-weight:800;color:var(--muted);padding:0;transition:all .15s;}
.sp-move:hover,.sp-move:active{background:rgba(0,0,0,.08);color:var(--cream);}
.sb-player.team-G{background:rgba(22,163,74,.12);border-color:rgba(22,163,74,.35);color:var(--green);}
.sb-player.team-W{background:rgba(71,85,105,.1);border-color:rgba(148,163,184,.4);color:#334155;}
.col-G .sb-player.team-Both{background:rgba(22,163,74,.1);border-color:rgba(22,163,74,.3);color:var(--green);}
.col-W .sb-player.team-Both{background:rgba(71,85,105,.1);border-color:rgba(148,163,184,.3);color:#334155;}
.sb-empty{font-size:12px;color:var(--muted);padding:4px 0;grid-column:1/-1;}

.timeline{display:flex;border-radius:10px;overflow:hidden;border:1px solid var(--bdr);box-shadow:0 1px 3px rgba(0,0,0,.04);}
.tl-seg{flex:1;padding:5px 3px;text-align:center;background:var(--surf);border-right:1px solid var(--bdr);}
.tl-seg:last-child{border-right:none;}
.tl-label{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:12px;color:var(--green);}
.tl-time{font-size:10px;color:var(--muted);}
.tl-ht{background:rgba(22,163,74,.06);}

.rot-wrap{border:1px solid var(--bdr);border-radius:14px;overflow:hidden;overflow-x:auto;box-shadow:0 2px 6px rgba(0,0,0,.04);}
.rot-table{width:100%;border-collapse:collapse;min-width:300px;}
.rot-table thead th{background:var(--surf2);padding:6px 4px;font-family:-apple-system,'Roboto Condensed',sans-serif;
  font-size:11px;color:var(--green);border-bottom:1px solid var(--bdr);text-align:center;white-space:nowrap;font-weight:800;}
.rot-table thead th.lth{text-align:left;padding-left:10px;}
.rot-table tbody tr{border-bottom:1px solid var(--bdr);}
.rot-table tbody tr:last-child{border-bottom:none;}
.rot-table tbody tr:hover{background:rgba(22,163,74,.03);}
.rot-table td{padding:5px 4px;text-align:center;vertical-align:middle;}
.rot-table td.ntd{text-align:left;padding-left:10px;}
.p-nm{font-weight:700;font-size:12px;color:var(--cream);} .p-ps{font-size:10px;color:var(--muted);}
.chip{display:inline-flex;align-items:center;justify-content:center;gap:2px;min-width:44px;
  padding:3px 4px;border-radius:6px;font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:11px;}
.chip.on{background:var(--on-bg);border:1px solid var(--on-bdr);color:var(--green);}
.chip.off{background:var(--off-bg);border:1px solid var(--bdr);color:var(--off-col);}
.mins-td{font-family:-apple-system,'Roboto Condensed',sans-serif;font-size:15px;font-weight:700;}
.mins-td.eq{color:var(--green);} .mins-td.hi{color:#ca8a04;} .mins-td.lo{color:var(--red);}
.ht-col{border-left:2px solid rgba(22,163,74,.25)!important;border-right:2px solid rgba(22,163,74,.25)!important;background:rgba(22,163,74,.03);}
.empty-state{padding:12px 8px;text-align:center;color:var(--muted);font-size:12px;line-height:1.5;}

.save-banner{
  background:var(--surf);border:1px solid var(--bdr);border-radius:12px;
  padding:10px 12px;display:flex;align-items:center;justify-content:space-between;
  gap:8px;flex-wrap:wrap;margin-top:8px;
  box-shadow:0 1px 4px rgba(0,0,0,.05);
}
.save-banner-inner{display:flex;align-items:center;gap:9px;flex:1;min-width:0;}
.save-banner-icon{width:16px;height:16px;color:var(--muted);flex-shrink:0;}
.save-banner-title{font-size:12px;font-weight:700;color:var(--cream);}
.save-banner-sub{font-size:11px;color:var(--muted);margin-top:1px;}
/* legacy class kept */
.save-banner-txt{font-size:12px;color:var(--green);}

/* ── Availability status badges (L1570) ── */
.avail-status{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:8px;font-size:11px;font-weight:700;
  flex-shrink:0;margin-left:auto;
}
.avail-status--in{background:rgba(22,163,74,.12);color:var(--green);border:1px solid rgba(22,163,74,.3);}
.avail-status--injured{background:rgba(220,38,38,.1);color:var(--red);border:1px solid rgba(220,38,38,.25);}
.avail-status--away{background:rgba(245,158,11,.1);color:#ca8a04;border:1px solid rgba(245,158,11,.25);}
.avail-status--out{background:var(--surf2);color:var(--muted);border:1px solid var(--bdr);}

/* Bigger, more readable availability rows (L1581) */
.avail-item{padding:10px 12px;gap:12px;}
.avail-name{font-size:14px;}
.avail-item input[type=checkbox]{width:20px;height:20px;}

/* ── Validation modal (opposition empty) (L1586) ── */
.opp-validation-modal{max-width:340px;padding:0;}
.ovm-hd{
  background:linear-gradient(135deg,#fef3c7,#fde68a);
  border-radius:16px 16px 0 0;padding:20px 18px 14px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.ovm-icon{font-size:36px;line-height:1;}
.ovm-title{font-size:16px;font-weight:800;color:#92400e;}
.ovm-body{padding:16px 18px 8px;}
.ovm-msg{font-size:14px;color:var(--cream);line-height:1.6;margin-bottom:8px;}
.ovm-teams{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.ovm-team-row{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  background:var(--surf2);border:1px solid var(--bdr);border-radius:10px;
}
.ovm-team-label{font-size:12px;font-weight:700;min-width:60px;}
.ovm-team-label--g{color:var(--green);}
.ovm-team-label--w{color:#64748b;}
.ovm-team-opp{font-size:12px;color:var(--muted);font-style:italic;}
.ovm-team-missing{font-size:12px;color:#dc2626;font-weight:700;}
.ovm-input{flex:1;border:1.5px solid var(--bdr);border-radius:8px;padding:6px 10px;font-size:13px;
  font-family:-apple-system,sans-serif;background:var(--surf);color:var(--cream);outline:none;}
.ovm-input:focus{border-color:var(--green);}
.ovm-footer{display:flex;gap:8px;padding:12px 18px;border-top:1px solid var(--bdr);}

/* ── Spacing audit fixes (L1609–1628) ── */
.tmi-form{padding:12px 14px 14px;gap:8px;}
.tmi-form .mis-input{padding:9px 12px;}
.train-modal-body{padding:16px 18px;gap:16px;}
.avail-modal-actions{padding:10px 14px;}
.avail-filter-row{padding:8px 14px;gap:6px;}
#availList{padding:8px 14px;}
.match-day-bar{padding:8px 12px;gap:8px;}
.mbb-actions .btn-green{padding:10px 18px;font-size:14px;min-height:44px;}
.mbb-actions .btn-ghost{padding:10px 12px;font-size:12px;min-height:44px;}
.mbb-actions .btn-green:disabled{opacity:.6;cursor:not-allowed;}
@keyframes spin{to{transform:rotate(360deg);}}
.spin{display:inline-block;animation:spin .7s linear infinite;}
/* Tmi clear as danger link */
.tmi-clear{color:var(--red)!important;background:transparent!important;border-color:transparent!important;font-size:11px;padding:4px 8px;margin-left:auto;}
.tmi-clear:hover{background:rgba(220,38,38,.07)!important;}

/* ── Pitch wrapper padding for sticky header ── */
.pitch-wrapper{padding-top:8px;}

/* ════════════════════════════════════════
   MATCH DAY REDESIGN — Teams Tab
   ════════════════════════════════════════ */

/* Override layout: md-body scrolls, topbar is fixed height */
#pg-sat.on{overflow:hidden;}
.md-topbar{
  display:flex;align-items:center;gap:6px;
  padding:8px 12px;background:var(--surf);
  border-bottom:1px solid var(--bdr);flex-shrink:0;
}
.md-arrow{
  width:36px;height:36px;border:1px solid var(--bdr);border-radius:8px;
  background:var(--surf);cursor:pointer;display:flex;align-items:center;
  justify-content:center;color:var(--cream);flex-shrink:0;
  transition:border-color .15s,color .15s;
}
.md-arrow:hover{border-color:var(--bright);color:var(--bright);}
.md-arrow [data-lucide]{width:16px;height:16px;}
.md-date-btn{
  flex:1;display:flex;align-items:center;gap:6px;padding:6px 10px;
  border:1px solid var(--bdr);border-radius:8px;background:var(--surf);
  cursor:pointer;font-size:13px;font-weight:700;color:var(--cream);
  transition:border-color .15s;
}
.md-date-btn:hover{border-color:var(--bright);}
.md-status-pill{
  padding:4px 10px;border-radius:12px;font-size:10px;font-weight:800;
  letter-spacing:.8px;text-transform:uppercase;background:var(--dim);
  color:var(--green);border:1px solid rgba(22,163,74,.2);white-space:nowrap;flex-shrink:0;
}
.md-status-pill--live{background:#fef2f2;color:#dc2626;border-color:rgba(220,38,38,.2);}
.md-status-pill--ht{background:#fff8e6;color:#d97706;border-color:rgba(217,119,6,.25);}
.md-status-pill--finished{background:#f1f5f9;color:var(--muted);border-color:var(--bdr);}
.md-status-pill--past{background:#f1f5f9;color:var(--muted);border-color:var(--bdr);}

/* ── Kick Off button ── */
.kick-off-area{display:flex;justify-content:center;padding:4px 0 8px;}
.kick-off-btn{display:flex;align-items:center;gap:8px;padding:13px 32px;
  background:var(--green);color:#fff;border:none;border-radius:14px;
  font-size:15px;font-weight:800;cursor:pointer;letter-spacing:.2px;
  box-shadow:0 4px 18px rgba(21,128,61,.35);touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;transition:filter .12s;}
.kick-off-btn:active{filter:brightness(.92);}
.kick-off-btn [data-lucide]{width:18px;height:18px;}

/* ── Sync badge ── */
.sync-badge{font-size:10px;font-weight:700;letter-spacing:.3px;padding:3px 8px;
  border-radius:8px;white-space:nowrap;flex-shrink:0;}
.sync-badge--synced{background:rgba(22,163,74,.08);color:var(--green);}
.sync-badge--saving{background:rgba(245,158,11,.1);color:#d97706;}
.sync-badge--offline{background:rgba(220,38,38,.1);color:#dc2626;}

/* ── Match phase step indicator ── */
.match-phase-steps{display:flex;align-items:center;padding:6px 10px;background:var(--surf);
  border-bottom:1px solid var(--bdr);flex-shrink:0;overflow-x:auto;gap:2px;-webkit-overflow-scrolling:touch;}
.match-phase-steps::-webkit-scrollbar{display:none;}
.mps-step{padding:5px 9px;border-radius:8px;font-size:10px;font-weight:800;letter-spacing:.5px;
  text-transform:uppercase;border:none;background:none;color:var(--muted);cursor:pointer;
  white-space:nowrap;transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent;
  touch-action:manipulation;}
.mps-step:active{background:var(--surf2);}
.mps-step--active{background:var(--dim);color:var(--green);}
.mps-step--done{color:var(--muted);opacity:.45;}
.mps-arrow{color:var(--bdr);font-size:13px;flex-shrink:0;line-height:1;padding:0 1px;}

/* Scrollable body */
.md-body{flex:1;overflow-y:auto;padding:12px 12px 180px;display:flex;flex-direction:column;gap:12px;}

/* Team Cards grid */
.md-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.md-card{
  background:var(--surf);border:1px solid var(--bdr);border-radius:14px;
  overflow:hidden;display:flex;flex-direction:column;
}
.md-card--g{border-top:3px solid var(--green);}
.md-card--w{border-top:3px solid #94a3b8;}
.md-card-head{
  display:flex;align-items:center;gap:6px;padding:10px 12px 8px;
}
.md-card-count{font-size:13px;font-weight:700;color:var(--muted);}
.md-card-head .tc-pill{font-size:11px;font-weight:700;padding:2px 8px;}

/* Match info row & form within card */
.md-tmi-row{
  display:flex;align-items:center;gap:6px;padding:7px 12px;
  cursor:pointer;border-top:1px solid var(--bdr);min-height:36px;
  transition:background .15s;
}
.md-tmi-row:hover{background:var(--surf2);}
.md-tmi-row .tmi-text{flex:1;font-size:12px;color:var(--muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;}
.md-tmi-row.tmi-row--filled .tmi-text{color:var(--cream);}
.md-tmi-row .tmi-pencil{width:12px;height:12px;opacity:.7;flex-shrink:0;}
.md-tmi-form{padding:10px 12px;border-top:1px solid var(--bdr);background:var(--surf2);display:flex;flex-direction:column;gap:6px;}
.tmi-inline-row{display:flex;gap:6px;}
.tmi-inline-row .mis-input:first-child{width:110px;flex-shrink:0;}
.md-tmi-form .tmi-form-actions{display:flex;gap:5px;padding-top:2px;}

/* Squad section inside card */
.md-squad-section{padding:8px 12px 4px;border-top:1px solid var(--bdr);position:relative;}
.md-squad-section::after{content:'';position:absolute;bottom:0;left:0;right:0;height:36px;background:linear-gradient(transparent,var(--surf));pointer-events:none;border-radius:0 0 4px 4px;}
.md-squad-lbl{
  display:flex;align-items:center;justify-content:space-between;
  font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:5px;
}
.md-squad-section .sb-pool{
  grid-template-columns:1fr;padding:0;min-height:30px;
  max-height:200px;overflow-y:auto;
}
.md-empty-state{font-size:12px;padding:6px 12px;color:var(--muted);text-align:left;}

/* Open Pitch button at bottom of card */
.md-pitch-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:11px 12px;border:none;border-top:1px solid var(--bdr);
  cursor:pointer;font-size:13px;font-weight:700;background:var(--surf2);
  width:100%;color:var(--muted);margin-top:auto;transition:all .15s;
  font-family:-apple-system,'Roboto Condensed',sans-serif;letter-spacing:.3px;
}
.md-pitch-btn:hover{background:var(--bdr);}
.md-pitch-btn--g:hover,.md-pitch-btn--g:active{color:var(--green);background:rgba(22,163,74,.07);}
.md-pitch-btn--w:hover,.md-pitch-btn--w:active{color:#475569;background:rgba(71,85,105,.07);}
.md-pitch-btn [data-lucide]{width:14px;height:14px;}

/* Inline availability section */
.md-avail{background:var(--surf);border:1px solid var(--bdr);border-radius:14px;overflow:hidden;}
.md-avail-hd{
  display:flex;align-items:center;gap:8px;padding:10px 14px;
  border-bottom:1px solid var(--bdr);flex-wrap:wrap;
}
.md-avail-title{font-size:13px;font-weight:800;color:var(--cream);flex:1;}
.md-avail-actions{display:flex;gap:5px;}
.btn-xs{padding:4px 8px;font-size:11px;border-radius:8px;}
.md-avail-filters{padding:8px 14px;border-bottom:1px solid var(--bdr);display:flex;flex-direction:column;gap:6px;}
.md-avail-filters .avail-search{margin-bottom:0;width:100%;}
.md-avail-filters .avail-filter-row{padding:0;border:none;}

/* Availability sheet list and summary */
#availSheet #availList{flex:1;overflow-y:auto;min-height:0;}
#availSheet .avail-modal-sum{border-radius:0;}

/* ── Bottom bar overflow menu ── */
.mbb-generate-btn{flex:1;padding:12px 20px;font-size:15px;min-height:48px;}
.mbb-overflow-trigger{flex-shrink:0;}
.mbb-overflow-menu{
  display:none;position:absolute;bottom:calc(100% + 8px);left:0;right:0;
  background:var(--surf);border:1px solid var(--bdr);border-radius:12px;
  box-shadow:0 4px 20px rgba(0,0,0,.12);overflow:hidden;
}
.mbb-overflow-menu.open{display:block;}
.mbb-menu-item{
  display:flex;align-items:center;gap:10px;width:100%;padding:13px 16px;
  border:none;background:transparent;font-size:14px;font-weight:600;
  color:var(--cream);cursor:pointer;text-align:left;font-family:-apple-system,sans-serif;
  border-bottom:1px solid var(--bdr);transition:background .12s;
}
.mbb-menu-item:last-child{border-bottom:none;}
.mbb-menu-item:hover{background:var(--surf2);}
.mbb-menu-item [data-lucide]{width:16px;height:16px;flex-shrink:0;color:var(--muted);}

/* ── Card header stat ── */
.md-card-stat{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap;margin-left:auto;}
.md-card-stat.stat-ready{color:var(--green);}
.md-card-stat.stat-warn{color:#ca8a04;}

/* ── Stepwise empty state guide ── */
.md-empty-guide{padding:10px 12px;display:flex;flex-direction:column;gap:3px;}
.meg-count{font-size:13px;font-weight:700;color:var(--cream);}
.meg-hint{font-size:11px;color:var(--muted);line-height:1.4;}
.md-empty-guide.state-ready .meg-count{color:var(--green);}
.md-empty-guide.state-warn .meg-count{color:#ca8a04;}

/* ── Flex player badge in squad pool ── */
.sp-flex-badge{
  font-size:8px;font-weight:800;letter-spacing:.5px;
  background:rgba(59,130,246,.12);color:#3b82f6;
  border:1px solid rgba(59,130,246,.25);border-radius:4px;
  padding:1px 4px;flex-shrink:0;
}

/* ══════════════════════════════════════
   PITCH-SIDE UX IMPROVEMENTS
   ══════════════════════════════════════ */

/* 1. Stack team cards on all phones */
@media(max-width:640px){.md-cards{grid-template-columns:1fr;}}

/* 2. Fat-finger availability rows — minimum 52px tap target */
.avail-item{padding:12px 14px;min-height:52px;}
.avail-item input[type=checkbox]{width:22px;height:22px;}

/* 3. Bigger G/W inline toggle buttons */
.bi-btn{padding:7px 14px;}

/* 4. Scoreboard-style summary stats in availability sheet */
#availSheet .avail-modal-sum{
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:10px 0;gap:0;flex-shrink:0;
}
#availSheet .sum-row{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:10px 6px;border-right:1px solid var(--bdr);gap:3px;
}
#availSheet .sum-row:last-of-type{border-right:none;}
#availSheet .sum-val{font-size:22px;font-weight:800;color:var(--green);font-family:-apple-system,'Roboto Condensed',sans-serif;}
#availSheet .sum-label{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;text-align:center;}
#availSheet .sum-note{grid-column:1/-1;text-align:center;padding:6px 14px 10px;font-size:11px;color:var(--muted);}

/* 6. Generate button closer to nav — reclaim screen space */
.match-bottom-bar{bottom:calc(66px + env(safe-area-inset-bottom));}

/* 7. All In button prominence */
.md-allin-btn{display:inline-flex;align-items:center;gap:5px;}

/* ── 8. Collapsible availability section ── */
.md-avail-toggle{
  width:32px;height:32px;border:1px solid var(--bdr);border-radius:8px;
  background:var(--surf2);cursor:pointer;display:flex;align-items:center;
  justify-content:center;color:var(--muted);flex-shrink:0;
  transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent;
}
.md-avail-toggle:hover{border-color:var(--bright);}
.md-avail-toggle [data-lucide]{width:14px;height:14px;transition:transform .22s ease;}
.md-avail--collapsed .md-avail-toggle [data-lucide]{transform:rotate(-90deg);}
/* Collapse: hide body content; keep header visible */
.md-avail--collapsed .md-avail-filters,
.md-avail--collapsed #availList,
.md-avail--collapsed .avail-modal-sum{display:none;}
/* Hide All In / Clear when collapsed — user must expand to edit */
.md-avail--collapsed .md-avail-actions{display:none;}

/* ── Availability bottom sheet ── */
.avail-sheet-backdrop{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;
}
.avail-sheet{
  position:fixed;bottom:0;left:0;right:0;z-index:301;
  background:var(--surf);border-radius:20px 20px 0 0;
  display:flex;flex-direction:column;max-height:88dvh;
  transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);
  padding-bottom:env(safe-area-inset-bottom,0);
  pointer-events:none; /* prevent intercepting touches when off-screen */
}
.avail-sheet.open{transform:translateY(0);pointer-events:auto;}
.avail-sheet-drag{
  width:40px;height:4px;background:var(--bdr);border-radius:2px;
  margin:10px auto 4px;flex-shrink:0;
}
.avail-sheet-hd{
  display:flex;align-items:center;gap:8px;padding:6px 14px 10px;
  border-bottom:1px solid var(--bdr);flex-shrink:0;
}
.avail-sheet-hd .md-avail-title{font-size:14px;font-weight:800;color:var(--cream);flex:1;}
.avail-sheet-close{
  width:28px;height:28px;border:1px solid var(--bdr);border-radius:8px;
  background:var(--surf2);cursor:pointer;display:flex;align-items:center;
  justify-content:center;color:var(--muted);flex-shrink:0;padding:0;
  transition:background .12s;
}
.avail-sheet-close:active{background:var(--bdr);}
.avail-sheet-close [data-lucide]{width:14px;height:14px;}
.avail-sheet .md-avail-filters{padding:8px 14px;border-bottom:1px solid var(--bdr);flex-shrink:0;}
.avail-sheet .md-avail-filters .avail-search{margin-bottom:0;}

/* ── New Match Sheet body ── */
.nm-sheet-body{
  padding:16px;display:flex;flex-direction:column;gap:12px;
}
.nm-date-label{
  font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;
}
.nm-date-input{
  width:100%;padding:12px 14px;border:1.5px solid var(--bdr);border-radius:12px;
  background:var(--surf);color:var(--cream);font-size:15px;font-weight:600;
  cursor:pointer;text-align:center;box-sizing:border-box;
}
.nm-date-input:focus{outline:none;border-color:var(--green);}
.nm-confirm-btn{
  width:100%;padding:14px;border-radius:12px;font-size:15px;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.nm-confirm-btn:disabled{opacity:.4;pointer-events:none;}

/* ── Edit availability button in card head ── */
.md-avail-edit-btn{
  margin-left:auto;display:inline-flex;align-items:center;gap:4px;
  padding:5px 10px;border:1px solid var(--bdr);border-radius:8px;
  background:var(--surf2);color:var(--muted);font-size:11px;font-weight:700;
  cursor:pointer;font-family:-apple-system,sans-serif;
  transition:background .12s,border-color .12s;
  -webkit-tap-highlight-color:transparent;
}
.md-avail-edit-btn:active{background:var(--bdr);}

/* ── Card action row (Pitch + Score) ── */
.md-card-actions{display:flex;border-top:1px solid var(--bdr);margin-top:auto;}
.md-card-actions .md-pitch-btn{
  flex:1;border-top:none;border-right:1px solid var(--bdr);border-radius:0 0 0 11px;
}
.md-score-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
  padding:11px 12px;border:none;cursor:pointer;font-size:13px;font-weight:700;
  background:var(--surf2);color:var(--muted);margin-top:auto;transition:all .15s;
  font-family:-apple-system,'Roboto Condensed',sans-serif;letter-spacing:.3px;
  border-radius:0 0 11px 0;
}
.md-score-btn [data-lucide]{width:14px;height:14px;}
.md-score-btn--g:hover,.md-score-btn--g:active{color:var(--green);background:rgba(22,163,74,.07);}
.md-score-btn--w:hover,.md-score-btn--w:active{color:#475569;background:rgba(71,85,105,.07);}

/* ── Score pane back row ── */
.sc2-back-row{
  display:flex;align-items:center;padding:8px 12px;
  background:var(--surf);border-bottom:1px solid var(--bdr);flex-shrink:0;gap:10px;
}
.sc2-back-btn{
  display:inline-flex;align-items:center;gap:4px;padding:7px 12px;
  border:1px solid var(--bdr);border-radius:10px;background:var(--surf2);
  color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;
  font-family:-apple-system,sans-serif;transition:background .12s;
  -webkit-tap-highlight-color:transparent;
}
.sc2-back-btn:active{background:var(--bdr);}
.sc2-back-btn [data-lucide]{width:14px;height:14px;}
.sc2-team-label{
  display:flex;align-items:center;gap:7px;
  font-size:14px;font-weight:700;color:var(--cream);
}
.sc2-team-label .team-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
