/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HOT BOARDS â€” styles.css
   Complete design system: tokens, layout, components
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ RESET â”€â”€ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* â”€â”€ DESIGN TOKENS â€” CANONICAL from design_handoff_hotboards/design-system/tokens.bundled.css â”€â”€
   This block is copied verbatim from the Claude Design handoff (Carbon & Brass).
   Canonical names (--ink-*, --heat-*, --grn-*, --acq-*, --status-*, --radius-*, --shadow-*)
   are the source of truth. Legacy names (--bg, --s1..s4, --t1..t4, --gold, --disp, --r-*)
   are kept ONLY as thin aliases pointing at the canonical vars so existing selectors resolve.
   â”€â”€ */
:root,[data-theme="dark"]{
  /* ---- Surfaces: near-black carbon ---- */
  --ink-950: #0B0C0E; --ink-900: #101216; --ink-850: #15181D; --ink-800: #181B21;
  --ink-750: #1F232A; --ink-700: #2A2E36; --ink-600: #3A3F49; --ink-500: #837E74;
  --ink-400: #9A958A; --ink-300: #BDB7AB; --ink-200: #D8D3C8; --ink-100: #F2EFE8; --ink-050: #FBFAF6;
  /* white-alpha borders */
  --alpha-1: rgba(255,255,255,0.07); --alpha-2: rgba(255,255,255,0.11); --alpha-3: rgba(255,255,255,0.16);
  /* paper surface (print spotter) */
  --paper:#FFFFFF; --paper-warm:#FBFAF6; --paper-line:#D9DEE6; --paper-rule:#AEB7C3; --paper-ink:#15140F; --paper-ink-soft:#534E45;
  /* Brass = brand accent */
  --heat-700:#7A5C30; --heat-600:#95743C; --heat-500:#B68A4E; --heat-400:#D8AE6E; --heat-300:#E6C892; --heat-200:#EFD9AE;
  --heat-glow:rgba(182,138,78,0.32); --heat-wash:rgba(182,138,78,0.13);
  --accent-grad:linear-gradient(180deg,#C79A56 0%,#A87C3E 100%);
  /* Gold ramp (draft codes) */
  --draft-600:#C7A24E; --draft-500:#E2C07A; --draft-wash:rgba(226,192,122,0.14); --gold-glow:rgba(182,138,78,0.30);
  /* Acquisition (steel blue) */
  --acq-600:#6E8CA8; --acq-500:#8AA6C2; --acq-wash:rgba(138,166,194,0.14);
  /* Green ramp (mint) */
  --grn-700:#2E8A5E; --grn-600:#3AA46E; --grn-500:#58C08C; --grn-400:#7FD3A8; --grn-300:#A6E2C4; --grn-wash:rgba(88,192,140,0.14);
  /* Status / injury */
  --status-out:#DE5B41; --status-doubt:#E0863F; --status-quest:#E2B85E; --status-active:#58C08C; --status-ps:#9A958A;
  --status-out-wash:rgba(222,91,65,0.14); --status-quest-wash:rgba(226,184,94,0.14); --status-active-wash:rgba(88,192,140,0.14);
  /* Highlight (board annotations) */
  --hl-yellow:#FCE56A; --hl-green:#A8E6A0; --hl-pink:#F7B0C8; --hl-blue:#A9D3F5;
  /* ---- SEMANTIC ALIASES ---- */
  --bg-app:var(--ink-950);
  --surface-panel:var(--ink-900); --surface-raised:var(--ink-850); --surface-card:var(--ink-800);
  --surface-input:var(--ink-750); --surface-hover:var(--ink-750); --surface-rookie:var(--grn-wash);
  --text-strong:var(--ink-050); --text-body:var(--ink-100); --text-secondary:var(--ink-300);
  --text-muted:var(--ink-400); --text-faint:var(--ink-500); --text-on-heat:#15110A;
  --border-hair:var(--alpha-1); --border-soft:var(--alpha-1); --border-strong:var(--alpha-3); --border-focus:var(--heat-500);
  --accent:var(--heat-500); --accent-hover:var(--heat-400); --accent-press:var(--heat-600);
  --accent-wash:var(--heat-wash); --accent-glow:var(--heat-glow);
  --info:var(--acq-500); --info-wash:var(--acq-wash); --positive:var(--grn-500); --positive-wash:var(--grn-wash); --live:var(--grn-500);
  --teal-700:var(--acq-600); --teal-600:var(--acq-600); --teal-500:var(--acq-500); --teal-400:#A2BBD2; --teal-300:#BFD2E2; --teal-wash:var(--acq-wash);
  --print-bg:var(--paper); --print-text:var(--paper-ink); --print-text-soft:var(--paper-ink-soft); --print-line:var(--paper-line); --print-rule:var(--paper-rule);
  /* ---- TYPE families/weights ---- */
  --font-display:"Saira Condensed","Oswald","Arial Narrow",system-ui,sans-serif;
  --font-sans:"Inter","Archivo",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-cond:"Saira Condensed","Oswald",system-ui,sans-serif;
  --font-field:"Barlow Condensed","Saira Condensed","Oswald",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-extra:800; --fw-black:900;
  /* FLUID TYPE SCALE */
  --fs-2xs:clamp(0.72rem,0.69rem + 0.14vw,0.82rem);
  --fs-xs:clamp(0.78rem,0.74rem + 0.20vw,0.92rem);
  --fs-sm:clamp(0.84rem,0.79rem + 0.26vw,1.00rem);
  --fs-base:clamp(0.92rem,0.85rem + 0.36vw,1.12rem);
  --fs-md:clamp(1.00rem,0.91rem + 0.45vw,1.24rem);
  --fs-lg:clamp(1.14rem,1.00rem + 0.66vw,1.50rem);
  --fs-xl:clamp(1.38rem,1.12rem + 1.20vw,2.10rem);
  --fs-2xl:clamp(1.80rem,1.35rem + 2.10vw,3.10rem);
  --fs-3xl:clamp(2.40rem,1.60rem + 3.60vw,4.60rem);
  --fs-display:clamp(3.40rem,2.00rem + 7.00vw,8.50rem);
  --lh-display:0.94; --lh-tight:1.05; --lh-snug:1.18; --lh-normal:1.42; --lh-relaxed:1.58;
  /* FIXED px scale (preview kits + print) */
  --text-2xs:11px; --text-xs:12px; --text-sm:13px; --text-base:14px; --text-md:15px; --text-lg:17px;
  --text-xl:20px; --text-2xl:24px; --text-3xl:30px; --text-4xl:38px; --text-5xl:50px; --text-6xl:66px; --text-7xl:88px;
  /* tracking */
  --track-tight:-0.02em; --track-snug:-0.01em; --track-normal:0; --track-wide:0.04em; --track-caps:0.07em; --track-mono:0.01em;
  /* semantic type roles */
  --type-wordmark-family:var(--font-display); --type-wordmark-weight:var(--fw-black); --type-wordmark-track:0.015em;
  --type-display-family:var(--font-display); --type-display-weight:var(--fw-bold); --type-display-lh:var(--lh-display); --type-display-track:var(--track-snug);
  --type-eyebrow-family:var(--font-cond); --type-eyebrow-weight:var(--fw-semibold); --type-eyebrow-size:var(--fs-xs); --type-eyebrow-track:var(--track-caps);
  --type-body-family:var(--font-sans); --type-body-weight:var(--fw-regular); --type-body-size:var(--fs-base); --type-body-lh:var(--lh-normal);
  --type-label-family:var(--font-sans); --type-label-weight:var(--fw-semibold); --type-label-track:0.01em;
  --type-data-family:var(--font-mono); --type-data-weight:var(--fw-medium); --type-data-track:var(--track-mono);
  --type-stat-family:var(--font-display); --type-stat-weight:var(--fw-bold); --type-stat-track:var(--track-tight);
  /* ---- SPACING ---- */
  --space-0:0; --space-px:1px; --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px;
  --space-6:24px; --space-7:32px; --space-8:40px; --space-9:48px; --space-10:64px; --space-11:80px; --space-12:96px;
  --sp-1:clamp(3px,0.2vw + 2px,6px); --sp-2:clamp(6px,0.4vw + 4px,10px);
  --sp-3:clamp(10px,0.6vw + 6px,16px); --sp-4:clamp(14px,0.9vw + 9px,24px);
  --sp-5:clamp(18px,1.3vw + 11px,34px); --sp-6:clamp(24px,2.0vw + 14px,52px);
  --sp-7:clamp(32px,3.0vw + 18px,76px); --sp-8:clamp(44px,4.4vw + 22px,112px);
  --density-tight:4px; --density-default:8px; --density-comfy:12px;
  --gutter-card:var(--space-4); --gutter-panel:var(--space-6); --gutter-page:var(--sp-6);
  --rail-sidebar:clamp(220px,18vw,320px); --rail-detail:clamp(320px,24vw,460px);
  --content-max:clamp(960px,92vw,2400px); --card-min:clamp(200px,16vw,280px);
  --topbar-h:clamp(52px,3.4vw,76px); --board-col-min:188px;
  --print-w:1632px; --print-h:1056px; --print-pad:36px;
  --z-base:0; --z-sticky:100; --z-dropdown:300; --z-overlay:800; --z-modal:900; --z-toast:1000;
  /* ---- EFFECTS ---- */
  --radius-xs:3px; --radius-sm:5px; --radius-md:7px; --radius-lg:10px; --radius-xl:14px; --radius-2xl:20px; --radius-pill:999px;
  --border-w:1px; --border-w-2:1.5px; --border-w-3:2px; --bar-accent:3px;
  /* Layered, soft elevation scale (premium depth instead of single harsh drop) */
  --shadow-none:none;
  --shadow-sm:0 1px 2px rgba(0,0,0,0.30);
  --shadow-md:0 1px 2px rgba(0,0,0,0.28),0 6px 18px -6px rgba(0,0,0,0.45);
  --shadow-lg:0 2px 6px rgba(0,0,0,0.30),0 18px 44px -12px rgba(0,0,0,0.58);
  --shadow-modal:0 4px 14px rgba(0,0,0,0.40),0 40px 90px -24px rgba(0,0,0,0.70);
  --shadow-pop:0 2px 8px rgba(0,0,0,0.34),0 12px 30px -10px rgba(0,0,0,0.52);
  /* Edge-light: a faint top highlight that gives raised surfaces dimension */
  --edge-top:inset 0 1px 0 rgba(255,255,255,0.07); --edge-inset:inset 0 0 0 1px rgba(255,255,255,0.04);
  --ring-focus:0 0 0 3px var(--heat-glow); --ring-inset:inset 0 0 0 1.5px var(--heat-500);
  --glow-heat:0 0 0 1px rgba(182,138,78,0.50),0 8px 26px rgba(182,138,78,0.22);
  --glow-gold:0 0 0 1px rgba(182,138,78,0.50),0 8px 24px rgba(182,138,78,0.22);
  --btn-shadow:0 2px 12px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.22);
  --shadow-paper:0 18px 50px rgba(0,0,0,0.40);
  --ease-out:cubic-bezier(0.22,1,0.36,1); --ease-in-out:cubic-bezier(0.65,0,0.35,1); --ease-snap:cubic-bezier(0.34,1.56,0.64,1);
  --dur-instant:80ms; --dur-fast:140ms; --dur-base:220ms; --dur-slow:340ms;
  /* ---- LEGACY ALIASES â†’ canonical (back-compat for existing selectors only) ---- */
  --bg:var(--ink-950); --s1:var(--ink-900); --s2:var(--ink-850); --s3:var(--ink-800); --s4:var(--ink-750);
  --b1:var(--alpha-1); --b2:var(--alpha-2); --b3:var(--alpha-3);
  --t1:var(--ink-100); --t2:var(--ink-300); --t3:var(--ink-400); --t4:var(--ink-500);
  --gold:var(--heat-500); --red:var(--status-out); --green:var(--grn-500); --blue:var(--acq-500);
  --orange:var(--status-doubt); --purple:#8B5CF6; --draft:var(--draft-500);
  --accent-ink:var(--text-on-heat); --accent-wash:var(--heat-wash); --focus-ring:var(--ring-focus);
  --disp:var(--font-display); --body:var(--font-sans); --mono:var(--font-mono);
  --r-sm:var(--radius-sm); --r-md:var(--radius-md); --r-lg:var(--radius-lg); --r-xl:var(--radius-xl); --r-pill:var(--radius-pill);
  --shadow:var(--shadow-sm);
}
/* LIGHT THEME â€” canonical [data-theme="light"] (aliases cascade automatically) */
[data-theme="light"]{
  --ink-950:#EFEDE7; --ink-900:#FFFFFF; --ink-850:#FFFFFF; --ink-800:#FFFFFF; --ink-750:#F3F1EB;
  --ink-700:#E4E1D9; --ink-600:#D0CCC2; --ink-500:#8A857B; --ink-400:#66615A; --ink-300:#494540;
  --ink-200:#2C2925; --ink-100:#18150F; --ink-050:#0C0A06;
  --alpha-1:rgba(20,18,12,0.08); --alpha-2:rgba(20,18,12,0.12); --alpha-3:rgba(20,18,12,0.16);
  --heat-500:#8A6A30; --heat-600:#745826; --heat-400:#A2823E; --draft-500:#9A7B2E; --acq-500:#466A92; --grn-500:#1F9A60; --status-out:#C8442B;
  --text-on-heat:#FFFFFF;
  --accent-grad:linear-gradient(180deg,#A2823E 0%,#876923 100%);
  --heat-wash:rgba(138,106,48,0.12); --grn-wash:rgba(31,154,96,0.12); --acq-wash:rgba(70,106,146,0.12); --draft-wash:rgba(154,123,46,0.14);
  --surface-hover:#EBE8E1; --surface-rookie:#EEF8F2;
  --teal-400:#466A92;
}

/* ── Global interaction polish (world-class refinement pass) ──
   Keyboard-only focus ring (accessibility), and reduced-motion respect.
   :focus-visible never fires on mouse click, so it won't disturb pointer UX. */
:focus-visible{outline:2px solid var(--heat-400);outline-offset:2px;border-radius:2px}
@media (prefers-reduced-motion: reduce){
  *,::before,::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
/* PRINT / PAPER SCOPE â€” canonical [data-surface="paper"] */
[data-surface="paper"]{
  --bg-app:var(--paper-warm); --surface-panel:var(--paper); --surface-raised:var(--paper);
  --surface-card:var(--paper); --surface-input:var(--paper); --surface-hover:#F1F0EC; --surface-rookie:#EEF8F1;
  --text-strong:var(--paper-ink); --text-body:var(--paper-ink); --text-secondary:var(--paper-ink-soft);
  --text-muted:#6B665C; --text-faint:#8A857B;
  --border-hair:var(--paper-line); --border-soft:var(--paper-line); --border-strong:var(--paper-rule);
}

/* â”€â”€ BASE â”€â”€ */
html{background:var(--bg);color:var(--t1);font-family:var(--body);font-size:13px;transition:background .25s,color .25s}
body{min-height:100vh;display:flex;flex-direction:column}
button,select,input,textarea{font-family:var(--body)}
button{cursor:pointer;border:none;background:none}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LANDING
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
#landing{display:flex;min-height:100vh;background:var(--bg-app)}
/* â”€â”€ Brand panel (left) â”€â”€ */
.land-brand-panel{
  flex:1;position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
  gap:clamp(28px,3vw,54px);padding:clamp(40px,5vw,96px);
  background:linear-gradient(155deg,var(--ink-900) 0%,var(--ink-950) 100%);
  border-right:1px solid var(--border-hair);
}
.land-glow{position:absolute;top:-100px;right:-100px;width:clamp(220px,22vw,360px);height:clamp(220px,22vw,360px);border-radius:50%;background:var(--heat-wash);filter:blur(50px);pointer-events:none}
.land-brand-head{position:relative;display:flex;flex-direction:column;gap:10px}
.land-wordmark{display:flex;align-items:center;gap:14px}
.land-mark{width:clamp(40px,3.2vw,54px);height:clamp(40px,3.2vw,54px);border-radius:13px;background:var(--accent-grad);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;color:var(--text-on-heat);font-size:clamp(18px,1.5vw,26px);letter-spacing:.02em;flex-shrink:0;box-shadow:0 10px 28px -10px var(--heat-glow)}
.land-wordmark-txt{font-family:var(--font-display);font-weight:900;font-size:clamp(1.7rem,1.2rem + 1.7vw,3rem);letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.lw-hot{color:var(--heat-500)}
.lw-boards{color:var(--text-strong)}
.land-eyebrow{font-family:var(--font-mono);font-size:clamp(.72rem,.66rem + .2vw,.86rem);letter-spacing:.18em;text-transform:uppercase;color:var(--teal-400);padding-left:3px}
.land-points{position:relative;display:flex;flex-direction:column;gap:clamp(15px,1.5vw,24px)}
.land-point{display:flex;gap:14px;align-items:flex-start}
.land-point-ico{width:clamp(34px,2.7vw,42px);height:clamp(34px,2.7vw,42px);flex-shrink:0;border-radius:11px;background:var(--heat-wash);border:1px solid rgba(182,138,78,.28);box-shadow:var(--edge-top);display:flex;align-items:center;justify-content:center;color:var(--heat-400)}
.land-point-ico svg{width:18px;height:18px}
.land-point-t{font-family:var(--font-display);font-weight:700;font-size:clamp(1.02rem,.9rem + .45vw,1.4rem);color:var(--text-strong)}
.land-point-d{font-size:clamp(.85rem,.8rem + .2vw,1.05rem);color:var(--text-muted);max-width:44ch;margin-top:3px;line-height:1.5}
/* â”€â”€ Sign-in column (right) â”€â”€ */
.land-auth-col{width:clamp(420px,32vw,560px);flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:clamp(28px,3vw,56px);background:var(--bg-app)}
.land-auth-inner{width:100%;max-width:392px;background:var(--surface-panel);border:1px solid var(--border-hair);border-radius:var(--radius-xl);box-shadow:var(--edge-top),var(--shadow-lg);padding:clamp(26px,2.2vw,38px)}
.land-badge{display:inline-block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--heat-400);background:var(--heat-wash);border:1px solid var(--border-hair);padding:4px 11px;border-radius:999px}
.land-auth-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,1.4rem + 1.2vw,2.6rem);color:var(--text-strong);margin:14px 0 4px;line-height:1}
.land-auth-sub{color:var(--text-muted);font-size:clamp(.9rem,.84rem + .2vw,1.05rem);margin-bottom:clamp(22px,2vw,30px)}
.lf{margin-bottom:clamp(13px,1.1vw,18px);text-align:left}
.lf label{font-family:var(--font-sans);font-size:clamp(.78rem,.72rem + .18vw,.92rem);font-weight:600;color:var(--text-secondary);display:block;margin-bottom:7px}
.lf input{width:100%;background:var(--surface-input);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-body);padding:clamp(11px,.9vw,15px) clamp(13px,1vw,16px);font-size:clamp(.95rem,.88rem + .2vw,1.1rem);outline:none;box-shadow:inset 0 1px 2px rgba(0,0,0,.22);transition:border-color .16s,box-shadow .16s,background .16s}
.lf input:hover{border-color:var(--border-focus)}
.lf input::placeholder{color:var(--text-faint)}
.lf input:focus{border-color:var(--accent);box-shadow:var(--ring-focus),inset 0 1px 2px rgba(0,0,0,.22)}
.login-btn{width:100%;background:var(--accent-grad);color:var(--text-on-heat);font-family:var(--font-display);font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:clamp(.95rem,.88rem + .25vw,1.12rem);padding:clamp(12px,1vw,15px);border-radius:var(--radius-md);margin-top:8px;box-shadow:var(--btn-shadow);transition:filter .16s,transform .12s var(--ease-out),box-shadow .16s}
.login-btn:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--btn-shadow)}
.login-btn:active{transform:translateY(0);filter:brightness(.98)}
.login-btn-alt{background:var(--surface-card);color:var(--text-body);border:1px solid var(--border-strong)}
.login-btn-alt:hover{background:var(--surface-hover);filter:none}
.land-or{display:flex;align-items:center;gap:12px;margin:clamp(15px,1.4vw,20px) 0}
.land-or::before,.land-or::after{content:"";flex:1;height:1px;background:var(--border-hair)}
.land-or span{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--text-faint);text-transform:uppercase}
#authMsg{margin-top:14px;font-size:clamp(.85rem,.8rem + .2vw,1rem);min-height:18px;text-align:center}
#apiCheck{margin-top:12px;font-size:clamp(.74rem,.7rem + .15vw,.86rem);color:var(--text-faint);text-align:center}
.land-foot{margin-top:clamp(20px,1.8vw,28px);padding-top:15px;border-top:1px solid var(--border-hair);font-size:.74rem;color:var(--text-faint);text-align:center;line-height:1.55}
@media(max-width:900px){
  #landing{flex-direction:column}
  .land-brand-panel{flex:0 0 auto;padding:clamp(32px,6vw,56px);border-right:none;border-bottom:1px solid var(--border-hair)}
  .land-auth-col{width:100%}
}

/* ======================================================================
   MATCHUP DASHBOARD ("My Boards" home)
   ====================================================================== */
#dashboard{min-height:100vh;background:var(--bg-app);display:flex;flex:1}
.dash-rail{flex:0 0 var(--rail-sidebar,264px);width:var(--rail-sidebar,264px);background:var(--surface-panel);border-right:1px solid var(--border-hair);display:flex;flex-direction:column;padding:clamp(18px,1.4vw,24px) clamp(14px,1vw,18px);position:sticky;top:0;height:100vh}
.dash-brand{display:flex;align-items:center;gap:11px;padding:0 6px clamp(18px,1.6vw,26px)}
.dash-mark{width:36px;height:36px;border-radius:var(--radius-md);background:var(--accent-grad);color:var(--text-on-heat);font-family:var(--font-display);font-weight:700;font-size:.92rem;display:flex;align-items:center;justify-content:center;letter-spacing:.02em;flex-shrink:0;box-shadow:0 2px 10px var(--heat-glow,rgba(182,138,78,.32))}
.dash-wordmark{font-family:var(--font-display);font-size:1.02rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.dash-nav{display:flex;flex-direction:column;gap:3px}
.dash-nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}
.dash-nav-item:hover{background:var(--surface-hover);color:var(--text-body)}
.dash-nav-item.on{background:var(--heat-wash);color:var(--heat-400);box-shadow:inset 2px 0 0 var(--heat-500)}
.dash-nav-item svg{flex-shrink:0;opacity:.9}
.dash-rail-sp{flex:1}
.dash-user{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-md);background:var(--surface-raised);border:1px solid var(--border-hair)}
.dash-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-grad);color:var(--text-on-heat);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem;flex-shrink:0}
.dash-user-meta{flex:1;min-width:0}
.dash-user-name{font-size:.82rem;font-weight:600;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-user-sub{font-size:.7rem;color:var(--text-muted);margin-top:1px}
.dash-signout{width:30px;height:30px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}
.dash-signout:hover{background:var(--status-out-wash);color:var(--status-out)}

.dash-main{flex:1;min-width:0;overflow-y:auto;height:100vh}
.dash-inner{max-width:clamp(900px,86vw,1480px);margin:0 auto;padding:clamp(26px,3vw,52px) clamp(22px,3vw,48px)}
.dash-masthead{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:clamp(22px,2.4vw,36px)}
.dash-eyebrow{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--heat-400);margin-bottom:8px}
.dash-greeting{font-family:var(--font-display);font-size:clamp(1.7rem,2.6vw,2.5rem);font-weight:600;letter-spacing:.005em;color:var(--text-strong);line-height:1.05;margin:0}
.dash-masthead-r{display:flex;align-items:center;gap:14px;flex-shrink:0;padding-top:6px}
.dash-live{display:flex;align-items:center;gap:7px;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--grn-500);font-family:var(--font-mono)}
.dash-live-dot{width:7px;height:7px;border-radius:50%;background:var(--grn-500);box-shadow:0 0 0 3px var(--grn-wash)}
.dash-date{font-size:.82rem;color:var(--text-muted);white-space:nowrap}
.dash-theme-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border-hair);background:var(--surface-raised);color:var(--text-secondary);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s}
.dash-theme-btn:hover{background:var(--surface-hover)}

.dash-composer{position:relative;background:var(--surface-card);border:1px solid var(--border-hair);border-radius:var(--radius-lg);padding:clamp(20px,2vw,30px);overflow:hidden;margin-bottom:clamp(28px,3vw,42px)}
.dash-composer-bar{position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-grad)}
.dash-composer-title{font-family:var(--font-display);font-size:clamp(1.05rem,1.5vw,1.3rem);font-weight:600;color:var(--text-strong);margin:0 0 4px}
.dash-composer-sub{font-size:var(--fs-sm);color:var(--text-muted);margin:0 0 clamp(16px,1.6vw,22px)}
.dash-composer-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:clamp(12px,1.2vw,18px)}
.dash-field{flex:1;min-width:150px;display:flex;flex-direction:column;gap:7px}
.dash-field label{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.dash-select{appearance:none;-webkit-appearance:none;background:var(--surface-input) url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239A958A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 12px center;border:1px solid var(--border-hair);border-radius:var(--radius-sm);padding:11px 34px 11px 13px;font-size:var(--fs-sm);font-weight:500;color:var(--text-body);cursor:pointer;width:100%;transition:border-color .15s,box-shadow .15s}
.dash-select:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--ring-focus)}
.dash-build-btn{flex:0 0 auto;display:flex;align-items:center;gap:8px;background:var(--accent-grad);color:var(--text-on-heat);border:none;border-radius:var(--radius-md);padding:12px 22px;font-family:var(--font-display);font-size:var(--fs-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:filter .15s,transform .05s;box-shadow:0 2px 12px var(--heat-glow,rgba(182,138,78,.32))}
.dash-build-btn:hover{filter:brightness(1.07)}
.dash-build-btn:active{transform:translateY(1px)}
.dash-field-week{flex:0 0 150px;min-width:130px;max-width:160px}
.dash-field-matchup{flex:1 1 320px;min-width:280px;max-width:390px}
.dash-manual-row{display:flex;align-items:center;gap:9px}
.dash-manual-at{font-family:var(--font-mono);font-size:.72rem;color:var(--text-faint);font-weight:600;flex:0 0 auto}
.dash-composer-note{display:flex;align-items:center;gap:8px;margin-top:clamp(14px,1.4vw,20px);font-size:.76rem;color:var(--text-muted)}
.dash-composer-note svg{color:var(--grn-500);flex-shrink:0}

.dash-boards-head{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:clamp(14px,1.4vw,20px)}
.dash-boards-head h3{font-family:var(--font-display);font-size:clamp(1rem,1.3vw,1.2rem);font-weight:600;color:var(--text-strong);margin:0}
.dash-board-count{color:var(--text-faint);font-weight:500}
.dash-filter{display:flex;gap:4px;background:var(--surface-raised);border:1px solid var(--border-hair);border-radius:var(--radius-md);padding:3px}
.dash-filter button{border:none;background:transparent;color:var(--text-muted);font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,color .15s}
.dash-filter button:hover{color:var(--text-body)}
.dash-filter button.on{background:var(--surface-card);color:var(--text-strong);box-shadow:0 1px 3px rgba(0,0,0,.2)}

.dash-boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(260px,22vw,340px),1fr));gap:clamp(14px,1.4vw,20px)}
.dash-board-card{background:var(--surface-card);border:1px solid var(--border-hair);border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;transition:border-color .16s,transform .16s,box-shadow .16s}
.dash-board-card:hover{border-color:var(--heat-600);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
/* crown banner */
.dash-crown{position:relative;height:124px;display:flex;overflow:hidden}
.dash-crown-half{flex:1;display:block}
.dash-crown-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,13,.10) 0%,rgba(8,10,13,.05) 45%,rgba(8,10,13,.42) 100%);pointer-events:none}
.dash-crown-badge{position:absolute;top:12px;right:13px;z-index:3}
.dash-crown-go{position:absolute;top:13px;left:14px;z-index:3;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.92);text-shadow:0 1px 6px rgba(0,0,0,.5);opacity:0;transform:translateX(-6px);transition:opacity .16s,transform .16s;pointer-events:none}
.dash-board-card:hover .dash-crown-go{opacity:1;transform:translateX(0)}
.dash-crown-teams{position:absolute;inset:0;z-index:2;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;justify-items:center;padding:0 18px}
.dash-abbr{display:flex;flex-direction:column;align-items:center;gap:8px}
.dash-abbr-txt{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:.9;letter-spacing:.02em;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.55)}
.dash-abbr-rule{width:26px;height:3px;border-radius:2px;box-shadow:0 0 8px rgba(0,0,0,.35)}
.dash-at{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:rgba(10,12,15,.6);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(3px);font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;color:rgba(255,255,255,.9)}
/* status badge */
.dash-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:999px;backdrop-filter:blur(6px);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.dash-badge .dot{width:5px;height:5px;border-radius:50%}
.dash-badge.live{background:rgba(193,141,42,.92);color:#fff}
.dash-badge.live .dot{background:#fff}
.dash-badge.ready{background:var(--grn-wash);color:var(--grn-500)}
.dash-badge.ready .dot{background:var(--grn-500)}
.dash-badge.archived{background:rgba(0,0,0,.5);color:#fff}
/* body */
.dash-board-body{padding:15px 17px 16px}
.dash-board-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}
.dash-board-week{font-family:var(--font-mono);font-size:12.5px;font-weight:600;color:var(--text-secondary)}
.dash-board-edited{font-size:12.5px;color:var(--text-muted)}
.dash-board-note{margin-top:10px;font-size:.78rem;color:var(--text-muted);line-height:1.45}
.dash-board-divider{height:1px;background:var(--border-hair);margin:13px 0}
.dash-board-actions{display:flex;gap:8px}
.dash-act{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:34px;padding:0 14px;flex:1;cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.05em;text-transform:uppercase;border-radius:var(--radius-md);background:var(--surface-input);border:1px solid var(--border-strong);color:var(--text-secondary);transition:color .15s,border-color .15s,background .15s}
.dash-act:hover{color:var(--text-strong);border-color:var(--text-faint);background:var(--surface-hover)}
.dash-act.danger:hover{color:var(--status-out);border-color:var(--status-out);background:var(--status-out-wash)}
.dash-empty{grid-column:1/-1;text-align:center;padding:clamp(40px,5vw,72px) 20px;border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--surface-panel)}
.dash-empty-t{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-body);margin-bottom:6px}
.dash-empty>div:last-child{font-size:var(--fs-sm);color:var(--text-muted)}

@media(max-width:820px){
  #dashboard{flex-direction:column}
  .dash-rail{flex:0 0 auto;width:100%;height:auto;position:static;flex-direction:row;align-items:center;gap:14px;padding:10px 16px;border-right:none;border-bottom:1px solid var(--border-hair)}
  .dash-brand{padding:0;flex-shrink:0}
  .dash-nav{flex-direction:row}
  .dash-rail-sp{flex:1}
  .dash-user{padding:6px 8px}
  .dash-user-meta{display:none}
  .dash-main{height:auto;overflow:visible}
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HEADER
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
/* ======================================================================
   ACCOUNT & BILLING
   ====================================================================== */
#billing{min-height:100vh;background:var(--bg-app);display:flex;flex:1}
.bill-wrap{max-width:880px;margin:0 auto;width:100%;padding:clamp(28px,3vw,44px) clamp(22px,3vw,40px) 64px}
.bill-head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.bill-title{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,2.4vw,28px);margin:0;color:var(--text-strong);letter-spacing:.01em}
.bill-sub{margin:0 0 24px;color:var(--text-muted);font-size:.9rem}
.bill-card{background:var(--surface-card);border:1px solid var(--border-hair);border-radius:var(--radius-lg);padding:clamp(16px,1.6vw,22px);margin-bottom:18px}
.bill-card-flush{padding:0}
.bill-card-plan{position:relative;overflow:hidden;border-color:var(--border-strong)}
.bill-card-plan::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-grad)}
.bill-plan-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.bill-plan-name-row{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.bill-plan-name{font-family:var(--font-display);font-weight:700;font-size:1.32rem;color:var(--text-strong)}
.bill-plan-desc{font-size:.84rem;color:var(--text-muted);max-width:430px;line-height:1.5}
.bill-plan-price{text-align:right;flex-shrink:0}
.bill-price-amt{font-family:var(--font-display);font-weight:800;font-size:2.5rem;color:var(--text-strong);line-height:1}
.bill-price-per{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);margin-top:2px}
.bill-plan-actions{display:flex;gap:10px;margin-top:18px}
.bill-btn{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:8px 16px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.bill-btn-secondary{background:var(--surface-raised);border:1px solid var(--border-strong);color:var(--text-body)}
.bill-btn-secondary:hover{background:var(--surface-hover);color:var(--text-strong)}
.bill-btn-ghost{background:transparent;border:1px solid transparent;color:var(--text-muted)}
.bill-btn-ghost:hover{color:var(--status-out)}
.bill-badge{display:inline-flex;align-items:center;gap:5px;font-size:.64rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:999px;flex-shrink:0}
.bill-badge-active{background:var(--grn-wash);color:var(--grn-500)}
.bill-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--grn-500)}
.bill-badge-sm{padding:2px 7px;font-size:.6rem}
.bill-grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.bill-card-eyebrow{font-family:var(--font-sans);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:12px}
.bill-card-eyebrow-pad{padding:16px 16px 0}
.bill-pay-row{display:flex;align-items:center;gap:12px;padding:0 0 14px}
.bill-card-icon{width:46px;height:30px;border-radius:5px;background:var(--surface-input);border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}
.bill-pay-meta{flex:1;min-width:0}
.bill-pay-card{font-family:var(--font-mono);font-weight:600;font-size:.9rem;color:var(--text-strong)}
.bill-pay-exp{font-size:.76rem;color:var(--text-muted);margin-top:1px}
.bill-icon-btn{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border-hair);background:var(--surface-raised);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}
.bill-icon-btn:hover{background:var(--surface-hover);color:var(--text-strong)}
.bill-autopay{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border-hair);font-size:.84rem;color:var(--text-secondary)}
.bill-switch{width:38px;height:21px;border-radius:999px;border:none;background:var(--surface-input);box-shadow:inset 0 0 0 1px var(--border-strong);cursor:pointer;position:relative;transition:background .18s;padding:0}
.bill-switch-knob{position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:var(--text-muted);transition:left .18s,background .18s}
.bill-switch.on{background:var(--accent-grad);box-shadow:none}
.bill-switch.on .bill-switch-knob{left:19px;background:#fff}
.bill-stat{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border-hair);font-size:.84rem;color:var(--text-muted)}
.bill-stat-last{border-bottom:none}
.bill-stat b{font-family:var(--font-mono);font-weight:600;font-size:.92rem;color:var(--text-strong)}
.bill-inv-list{display:flex;flex-direction:column}
.bill-inv-row{display:flex;align-items:center;gap:14px;padding:11px 16px;border-bottom:1px solid var(--border-hair)}
.bill-inv-row:last-child{border-bottom:none}
.bill-inv-date{font-family:var(--font-mono);font-size:.8rem;color:var(--text-body);width:104px;flex-shrink:0}
.bill-inv-label{flex:1;font-size:.82rem;color:var(--text-muted)}
.bill-inv-amt{font-family:var(--font-mono);font-weight:600;font-size:.8rem;color:var(--text-strong)}
.bill-secure{margin-top:14px;font-size:.74rem;color:var(--text-faint);display:flex;align-items:center;gap:7px}
@media(max-width:820px){
  #billing{flex-direction:column}
  .bill-grid2{grid-template-columns:1fr}
}

.hdr{background:var(--s1);border-bottom:1px solid var(--b2);min-height:var(--topbar-h);display:flex;align-items:center;padding:0 var(--sp-4);gap:var(--sp-3);position:sticky;top:0;z-index:90;flex-shrink:0}
.hdr-back,.hdr-help{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 13px;background:var(--surface-raised);border:1px solid var(--border-hair);color:var(--text-secondary);font-family:var(--disp);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:8px;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}
.hdr-back:hover,.hdr-help:hover{background:var(--surface-hover);color:var(--text-strong);border-color:var(--border-strong)}
.hdr-help svg{color:var(--accent);flex-shrink:0}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-size:var(--fs-lg);font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.logo-mark{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border-strong);border-radius:9px;color:var(--accent);flex-shrink:0}
.logo-mark svg{width:18px;height:18px}
.logo .lw-hot{color:var(--accent)}
.logo .lw-boards{color:var(--t1)}
.hdiv{width:1px;height:20px;background:var(--b2);flex-shrink:0}
.hdr-div{width:1px;height:24px;background:var(--border-hair);flex-shrink:0}
/* header right cluster: re-scrape icon, synced, LIVE | Print CTA, theme, avatar */
.re-btn-icon{margin-left:0;width:30px;height:30px;justify-content:center;padding:0;gap:0;border-radius:var(--radius-md);background:var(--surface-card);border:1px solid var(--border-strong);color:var(--text-muted)}
.re-btn-icon:hover{border-color:var(--text-faint);color:var(--text-strong)}
.print-cta{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:8px;background:var(--heat-500);color:var(--text-on-heat);border:none;cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;transition:background .12s}
.print-cta:hover{background:var(--accent-hover)}
.print-cta:active{background:var(--accent-press)}
.print-cta.on{box-shadow:inset 0 0 0 2px var(--accent-press)}
.print-cta svg{flex-shrink:0}
.hdr-acct{position:relative;flex-shrink:0}
.hdr-av-btn{width:30px;height:30px;border-radius:50%;background:var(--ink-700);border:1px solid var(--border-strong);color:var(--text-body);font-family:var(--font-display);font-weight:800;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .12s}
.hdr-av-btn:hover{border-color:var(--text-faint)}
.hdr-av-menu{position:absolute;top:38px;right:0;min-width:140px;background:var(--surface-card);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-pop);padding:5px;z-index:120}
.hdr-av-item{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:13px;font-weight:600;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s,color .12s}
.hdr-av-item:hover{background:var(--surface-hover);color:var(--text-strong)}
.cdot{width:9px;height:9px;border-radius:50%;flex-shrink:0;transition:background .3s}
select.tsel{background:var(--s2);border:1px solid var(--b2);color:var(--t1);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-sm);font-size:var(--fs-xs);font-weight:600;min-width:clamp(150px,12vw,230px);outline:none;transition:border-color .15s,box-shadow .15s}
select.tsel:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}
.vs-lbl{font-family:var(--disp);font-size:var(--fs-xs);font-weight:600;color:var(--t4);letter-spacing:.16em}
.btn-load{background:var(--accent-grad);color:var(--text-on-heat);font-family:var(--disp);font-size:var(--fs-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-md);white-space:nowrap;transition:filter .2s,transform .12s}
.btn-load:hover{filter:brightness(1.06)}.btn-load:active{transform:translateY(1px)}.btn-load:disabled{opacity:.45;cursor:wait}
.season-toggle{display:inline-flex;align-items:center;gap:var(--sp-2);margin-left:var(--sp-1)}
.season-lbl{font-family:var(--mono);font-size:var(--fs-2xs);font-weight:600;letter-spacing:.1em;color:var(--t4)}
.season-toggle .seg{font-family:var(--mono);font-size:var(--fs-2xs);font-weight:600;letter-spacing:.03em;color:var(--t3);background:var(--s2);border:1px solid var(--b2);padding:var(--sp-1) var(--sp-2);cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.season-toggle .seg:first-of-type{border-radius:var(--r-sm) 0 0 var(--r-sm)}
.season-toggle .seg:last-of-type{border-radius:0 var(--r-sm) var(--r-sm) 0;border-left:0}
.season-toggle .seg:hover{color:var(--t1)}
.season-toggle .seg.on{background:var(--heat-500);border-color:var(--heat-500);color:var(--accent-ink)}
.hdr-r{display:flex;align-items:center;gap:var(--sp-2);margin-left:auto}
.hbtn{background:var(--surface-input);border:1px solid var(--border-strong);color:var(--text-secondary);font-family:var(--font-display);font-size:13px;font-weight:600;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);letter-spacing:.05em;text-transform:uppercase;transition:all .15s;white-space:nowrap}
.hbtn:hover{color:var(--t1);border-color:var(--b3)}
.hbtn.on{border-color:var(--accent);color:var(--accent);background:var(--accent-wash)}
.theme-btn{width:clamp(30px,2.4vw,38px);height:clamp(28px,2.2vw,34px);background:var(--s2);border:1px solid var(--b2);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:var(--fs-sm);color:var(--t2);transition:all .2s}
.theme-btn:hover{border-color:var(--accent);color:var(--t1)}
.apipill{display:flex;align-items:center;gap:5px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--t3)}
.apidot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.apidot.live{background:var(--green);box-shadow:0 0 6px rgba(40,184,112,.5);animation:pulse-g 2.5s infinite}
.apidot.err{background:var(--red)}
.apidot.busy{background:var(--gold);animation:pulse-g 1s infinite}
@keyframes pulse-g{0%,100%{opacity:1}50%{opacity:.5}}
/* Merged data-status chip: LIVE dot + last-updated + click-to-rescrape (replaces the separate re-btn + apipill) */
.data-chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 10px;border-radius:var(--radius-md);background:var(--surface-card);border:1px solid var(--border-strong);color:var(--text-muted);font-family:var(--font-mono,monospace);font-size:11px;cursor:pointer;white-space:nowrap;transition:border-color .12s,color .12s}
.data-chip:hover{border-color:var(--text-faint);color:var(--text-strong)}
.data-chip .data-lbl{font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--green)}
.data-chip .data-upd{color:var(--text-muted);font-variant-numeric:tabular-nums}
.data-chip .data-re{flex-shrink:0;opacity:.55;transition:opacity .12s}
.data-chip:hover .data-re{opacity:1}
.data-chip.syncing .data-re{animation:hb-spin .8s linear infinite}
@keyframes hb-spin{to{transform:rotate(360deg)}}
/* Season toggle is temporary (testing) — keep it quiet until it's removed at launch */
.season-toggle--temp{opacity:.5;transform:scale(.88);transform-origin:right center;transition:opacity .15s}
.season-toggle--temp:hover{opacity:1}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SOURCE BAR
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
/* Active-team source links — mono link style in the toolbar SOURCE cluster. */
.dc-src-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--acq-500);text-decoration:none;height:30px;padding:0 6px;border-radius:var(--radius-sm);transition:color .12s;white-space:nowrap}
.dc-src-link svg{width:12px;height:12px;flex-shrink:0;opacity:.9}
.dc-src-link:hover{color:var(--acq-600)}
@media print{.dc-cluster,.mh,.dc-tb-div{display:none!important}}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   NAV TABS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
/* Inline in the app header — no longer a standalone full-width bar. */
.navtabs{display:flex;align-self:stretch;align-items:stretch;gap:24px;flex-shrink:0;margin-left:6px;overflow-x:auto}
.ntab{display:flex;align-items:center;font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.05em;color:var(--text-muted);padding:0 2px;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .15s,border-color .15s;text-transform:uppercase;white-space:nowrap}
.ntab:hover{color:var(--t2)}
.ntab.on{color:var(--t1);border-bottom-color:var(--accent)}
.ntab-sep{width:1px;height:16px;background:var(--b2);align-self:center;margin:0 var(--sp-2);flex-shrink:0}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TOOLBAR
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.toolbar{background:var(--s1);border-bottom:1px solid var(--b1);padding:5px 16px;display:flex;align-items:center;gap:4px;flex-wrap:wrap;flex-shrink:0}
.tblbl{font-size:9px;font-weight:700;color:var(--t4);letter-spacing:.1em;text-transform:uppercase;margin-right:2px;white-space:nowrap}
.tog{font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:3px;border:1px solid var(--b2);background:transparent;color:var(--t3);transition:all .15s;white-space:nowrap}
.tog.on{background:var(--s3);color:var(--gold);border-color:rgba(240,192,64,.3)}
.tbsep{width:1px;height:13px;background:var(--b2);margin:0 4px;flex-shrink:0}
.re-btn{margin-left:auto;display:flex;align-items:center;gap:5px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:9px;font-weight:700;padding:3px 10px;border-radius:3px;letter-spacing:.5px;text-transform:uppercase;transition:all .15s;white-space:nowrap}
.re-btn:hover{border-color:var(--orange);color:var(--orange)}
.re-btn.spin svg{animation:spinr .7s linear infinite}
@keyframes spinr{to{transform:rotate(360deg)}}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MAIN AREA & VIEWS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.main-area{flex:1;overflow:hidden;display:flex;flex-direction:column}
.view{display:none;flex:1;overflow-y:auto;flex-direction:column}
.view.on{display:flex}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BOARD VIEW
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.board-pad{padding:14px 16px}
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.tpanel{background:var(--s1);border:1px solid var(--b2);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.tphdr{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--b2)}
.tbar{width:4px;border-radius:2px;height:40px;flex-shrink:0}
.tabbr{font-family:var(--disp);font-size:28px;font-weight:900;line-height:1}
.tname{font-size:11px;color:var(--t2);margin-top:2px}
.tpcount{font-size:9px;color:var(--t4);font-weight:600;margin-left:auto;margin-right:8px}
.tpilive{font-size:9px;padding:2px 7px;border-radius:10px;background:rgba(40,184,112,.12);color:var(--green);font-weight:700;white-space:nowrap}
.tside{font-family:var(--disp);font-size:9px;font-weight:800;letter-spacing:1.5px;padding:3px 8px;border-radius:3px;margin-left:6px}
.sechdr{font-family:var(--disp);font-size:9px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--t4);padding:5px 13px 3px;border-top:1px solid var(--b1);display:flex;align-items:center;gap:8px}
.sechdr::after{content:'';flex:1;height:1px;background:var(--b1)}

/* â”€â”€ ROSTER TABLE â”€â”€ */
.tblwrap{overflow-x:auto}
table.rt{width:100%;border-collapse:collapse;font-size:12px}
table.rt thead th{font-family:var(--disp);font-size:8px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--t4);padding:4px 7px;text-align:left;border-bottom:1px solid var(--b1);white-space:nowrap;cursor:pointer;user-select:none}
table.rt thead th:hover{color:var(--t2)}
table.rt thead th.sort-on{color:var(--gold)}
table.rt tbody tr{cursor:pointer;border-bottom:1px solid var(--b1);transition:background .1s}
table.rt tbody tr:last-child{border-bottom:none}
table.rt tbody tr:hover{background:var(--s2)}
table.rt tbody td{padding:5px 7px;white-space:nowrap;color:var(--t2);vertical-align:middle}
.tdnum{font-family:var(--disp);font-size:16px;font-weight:900}
.tdname{font-weight:600;color:var(--t1)!important;font-size:12px}
.tdphon{font-size:9px;color:var(--t4);font-style:italic;display:block;line-height:1.2;font-weight:400}
.posp{display:inline-block;padding:1px 5px;border-radius:2px;background:var(--s3);color:var(--t2);font-size:8.5px;font-weight:800;font-family:var(--disp)}
.ndot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--gold);margin-left:4px;vertical-align:middle}
.ovdot{color:var(--gold);font-size:8px;margin-left:3px;vertical-align:middle}
.prevt{font-size:10px;color:var(--t3);font-style:italic;max-width:120px;overflow:hidden;text-overflow:ellipsis}

/* â”€â”€ BADGES â”€â”€ */
.badge{display:inline-block;padding:1px 4px;border-radius:2px;font-size:7px;font-weight:800;letter-spacing:.04em;font-family:var(--disp);margin-left:3px;vertical-align:middle;text-transform:uppercase;line-height:1.5}
.b-r1{background:rgba(240,192,64,.15);color:#f0c040;border:1px solid rgba(240,192,64,.25)}
.b-pb{background:rgba(74,158,255,.12);color:#4a9eff;border:1px solid rgba(74,158,255,.2)}
.b-ap{background:rgba(139,92,246,.12);color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}
.b-rk{background:rgba(40,184,112,.1);color:#28b870;border:1px solid rgba(40,184,112,.2)}
.b-cap{background:rgba(232,52,26,.1);color:#e8341a;border:1px solid rgba(232,52,26,.2)}
.b-inj{background:rgba(240,120,48,.12);color:#f07830;border:1px solid rgba(240,120,48,.25)}
.b-dc{background:rgba(74,158,255,.08);color:#4a9eff;border:1px solid rgba(74,158,255,.15)}
.b-dr{background:rgba(240,192,64,.1);color:#f0c040;border:1px solid rgba(240,192,64,.2)}

/* â”€â”€ STATUS PILLS â”€â”€ */
.sts{display:inline-block;padding:1px 6px;border-radius:2px;font-size:8px;font-weight:800;letter-spacing:.04em;font-family:var(--disp);white-space:nowrap}
.s-act{background:rgba(40,184,112,.1);color:#28b870}
.s-q{background:rgba(240,120,48,.15);color:#f07830}
.s-d{background:rgba(232,52,26,.2);color:#e85040}
.s-out{background:rgba(232,52,26,.15);color:#e87060}
.s-ir{background:rgba(74,158,255,.12);color:#4a9eff}
.s-ps{background:rgba(139,92,246,.12);color:#8b5cf6}
.s-dnp{background:rgba(100,100,120,.1);color:var(--t3)}
.s-pup{background:rgba(74,158,255,.08);color:#7ab0d8}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   DEPTH CHART VIEW
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.depth-pad{padding:14px 16px}
.depth-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.depth-panel{background:var(--s1);border:1px solid var(--b2);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.depth-phdr{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--surface-raised);border-bottom:1px solid var(--border-strong);box-shadow:inset 0 2px 0 var(--heat-500)}
.depth-sect{padding:12px 14px;border-bottom:1px solid var(--b1)}
.depth-sect:last-child{border-bottom:none}
.depth-sect-ttl{display:flex;align-items:center;height:28px;padding:0 12px;margin:-2px -2px 10px;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--heat-wash),transparent);border-left:3px solid var(--heat-500);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-strong)}
.depth-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:5px;min-height:24px}
.depth-pos{font-family:var(--disp);font-size:11px;font-weight:800;color:var(--t3);min-width:34px;padding-top:2px;flex-shrink:0}
.depth-slots{display:flex;flex-wrap:wrap;gap:4px;flex:1}
.dslot{display:flex;align-items:center;gap:5px;background:var(--s2);border:1px solid var(--b1);border-radius:4px;padding:3px 8px;cursor:pointer;transition:background .12s}
.dslot:hover{background:var(--s3);border-color:var(--b2)}
.dslot-rank{font-size:8px;font-weight:800;color:var(--t4);font-family:var(--disp);min-width:14px}
.dslot-name{font-size:11px;font-weight:600;color:var(--t1)}
.dslot-inj{font-size:8px;color:var(--orange);margin-left:2px}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   INJURY VIEW
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.inj-pad{padding:14px 16px}
.inj-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.inj-panel{background:var(--s1);border:1px solid var(--b2);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.inj-phdr{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--surface-raised);border-bottom:1px solid var(--border-strong);box-shadow:inset 0 2px 0 var(--status-out)}
.inj-src{font-size:9px;font-weight:700;letter-spacing:.04em;padding:5px 14px;border-bottom:1px solid var(--border-strong)}
.inj-src-official{background:rgba(40,184,112,.10);color:var(--green)}
.inj-src-fallback{background:rgba(232,168,56,.12);color:var(--orange)}
table.injt{width:100%;border-collapse:collapse;font-size:11px}
table.injt thead th{font-family:var(--disp);font-size:8px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:7px 10px;background:var(--surface-input);border-bottom:1px solid var(--border-strong);text-align:left;white-space:nowrap}
table.injt tbody tr{border-bottom:1px solid var(--b1);cursor:pointer;transition:background .1s}
table.injt tbody tr:last-child{border-bottom:none}
table.injt tbody tr:hover{background:var(--s2)}
table.injt tbody td{padding:6px 10px;vertical-align:middle;color:var(--t2)}
.pchip{display:inline-block;font-size:8px;font-weight:800;padding:1px 5px;border-radius:2px;font-family:var(--disp)}
.pc-lp{background:rgba(240,120,48,.12);color:#f07830}
.pc-fp{background:rgba(40,184,112,.1);color:#28b870}
.pc-dnp{background:rgba(100,100,120,.1);color:var(--t3)}
.pc-none{color:var(--t4);font-size:9px}
.no-data{padding:24px;text-align:center;color:var(--t4);font-size:12px;font-style:italic}
.inj-refresh-bar{display:flex;align-items:center;gap:10px;padding:7px 14px;background:rgba(240,120,48,.05);border-bottom:1px solid rgba(240,120,48,.1);font-size:10px;color:var(--orange)}
.inj-ts{font-size:9px;color:var(--t3);margin-left:auto}
.inj-rescrape{font-size:9px;font-weight:700;padding:2px 8px;border-radius:3px;border:1px solid rgba(240,120,48,.3);background:rgba(240,120,48,.07);color:var(--orange);cursor:pointer;transition:all .15s;white-space:nowrap}
.inj-rescrape:hover{background:rgba(240,120,48,.15)}
.inj-rescrape.spin{animation:spinr .7s linear infinite}
.inj-pfr{font-size:9px;font-weight:700;padding:2px 8px;border-radius:3px;border:1px solid var(--border-strong);background:var(--surface-input);color:var(--text-muted);text-decoration:none;white-space:nowrap;transition:all .15s}
.inj-pfr:hover{color:var(--text-strong);border-color:var(--text-muted)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   COACHES VIEW
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.coach-pad{padding:14px 16px}
.coach-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:1440px;margin:0 auto}
/* Coaches tab — broadcast "lower-thirds" name-plate strips (Carbon & Brass) */
.coach-panel{background:var(--surface-card);border:1px solid var(--border-strong);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-pop,0 8px 24px rgba(0,0,0,.5))}
.coach-phdr{display:flex;align-items:center;gap:14px;padding:16px 18px;background:linear-gradient(180deg,color-mix(in srgb,var(--team,#888) 14%,transparent),transparent);border-bottom:1px solid var(--border-hair)}
.coach-bar{width:6px;height:44px;border-radius:3px;background:var(--team,#888);flex:0 0 auto;box-shadow:0 0 18px color-mix(in srgb,var(--team,#888) 40%,transparent)}
.coach-htxt{min-width:0}
.coach-abbr{font-family:var(--font-display);font-weight:700;font-size:34px;line-height:.9;letter-spacing:.01em}
.coach-hname{font-size:12.5px;color:var(--text-secondary);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.coach-hsub{color:var(--text-faint)}
.coach-rescrape-btn{margin-left:auto;display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 11px;border-radius:var(--radius-md);background:var(--surface-card);border:1px solid var(--border-strong);color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;cursor:pointer;flex:0 0 auto;transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}
.coach-rescrape-btn:hover{color:var(--text-strong);border-color:var(--text-faint)}
.coach-staff{list-style:none;margin:0;padding:14px;display:flex;flex-direction:column;gap:9px}
.lt{display:flex;align-items:stretch;min-height:58px;background:var(--surface-raised);border:1px solid var(--border-hair);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--edge-top);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}
.lt:hover{background:var(--surface-hover);border-color:color-mix(in srgb,var(--team,#888) 45%,var(--border-strong))}
.lt-chip{width:52px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,color-mix(in srgb,var(--team,#888) 20%,var(--surface-panel)),var(--surface-panel));font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:.06em;color:color-mix(in srgb,var(--team,#888) 52%,#ffffff)}
.lt-chip::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--team,#888);box-shadow:0 0 12px color-mix(in srgb,var(--team,#888) 55%,transparent)}
.lt-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:8px 16px}
.lt-main{display:flex;align-items:center;gap:10px}
.lt-name{flex:1;min-width:0;font-family:var(--font-display);font-weight:700;font-size:20px;line-height:1.02;letter-spacing:.01em;text-transform:uppercase;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lt-sub{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-faint);min-width:0}
.lt-role{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lt-dot{opacity:.45;flex:0 0 auto}
.lt-edit{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:26px;height:26px;opacity:0;color:var(--text-faint);transition:opacity var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}
.lt-edit svg{width:14px;height:14px}
.lt:hover .lt-edit{opacity:1}
.lt-edit:hover{color:var(--heat-300)}
.lt-stat{font-family:var(--font-mono);font-size:10.5px;color:var(--text-secondary);white-space:nowrap;flex:0 0 auto}
.lt-verify{display:flex;align-items:center;gap:5px;padding:0 15px;flex:0 0 auto;font-family:var(--font-mono);font-size:11px;color:var(--text-faint);text-decoration:none;white-space:nowrap;transition:color var(--dur-fast)}
.lt-verify svg{width:13px;height:13px;color:var(--positive)}
.lt-verify:hover{color:var(--grn-400)}
.lt-unver{color:var(--text-faint);opacity:.55;cursor:default}
.coach-add-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;border:none;border-top:1px dashed var(--border-strong);background:transparent;cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);transition:color var(--dur-fast)}
.coach-add-btn:hover{color:var(--heat-300)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   EMPTY / LOADING STATES
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.empty-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:380px;gap:12px;border:1px solid var(--b1);border-radius:10px;background:var(--s1);margin:14px 16px}
.empty-rz{font-family:var(--disp);font-size:var(--fs-3xl);font-weight:900;color:var(--accent);opacity:.1;letter-spacing:4px}
.empty-t{font-family:var(--disp);font-size:18px;font-weight:700;color:var(--t3)}
.empty-s{font-size:12px;color:var(--t4);text-align:center;max-width:320px;line-height:1.65}
.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:380px;gap:14px;border:1px solid var(--b1);border-radius:10px;background:var(--s1);margin:14px 16px}
.spinner{width:30px;height:30px;border:3px solid var(--s3);border-top-color:var(--accent);border-radius:50%;animation:spinr .7s linear infinite}
.loading-t{font-family:var(--disp);font-size:14px;font-weight:700;color:var(--t3);letter-spacing:1px;text-transform:uppercase}
.loading-s{font-size:11px;color:var(--t4);text-align:center;max-width:340px;line-height:1.65}
.step-list{display:flex;flex-direction:column;gap:5px;margin-top:6px;min-width:280px;text-align:left}
.step{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--t4)}
.step.done{color:var(--green)}.step.active{color:var(--gold)}
.step-ic{font-size:11px;width:16px;text-align:center;flex-shrink:0}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PLAYER MODAL
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.mbg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:300;align-items:flex-start;justify-content:center;padding:28px 16px;overflow-y:auto}
.mbg.open{display:flex}
.modal{background:var(--s1);border:1px solid var(--b2);border-radius:12px;width:100%;max-width:640px;animation:msu .15s ease;box-shadow:0 16px 48px rgba(0,0,0,.4)}
@keyframes msu{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
.mtop{display:flex;align-items:flex-start;gap:12px;padding:15px 17px;border-bottom:1px solid var(--b1)}
.mnum{font-family:var(--disp);font-size:46px;font-weight:900;line-height:1;min-width:70px;text-align:center}
.minfo{flex:1;min-width:0}
.mname{font-family:var(--disp);font-size:21px;font-weight:800;margin-bottom:3px}
.mmeta{font-size:11px;color:var(--t2)}
.mprev{font-size:10px;color:var(--t3);font-style:italic;margin-top:2px}
.minjury{font-size:10px;color:var(--orange);margin-top:3px;font-weight:600}
.mdepth{font-size:10px;color:var(--blue);margin-top:2px;font-weight:600}
.mbadges{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px}
.msrc{font-size:9px;color:var(--green);margin-top:3px;font-style:italic;opacity:.7}
.mclose{background:var(--s2);border:1px solid var(--b2);color:var(--t2);width:30px;height:30px;border-radius:5px;font-size:17px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mclose:hover{color:var(--t1)}
.mtabs{display:flex;border-bottom:1px solid var(--b1);padding:0 17px;overflow-x:auto}
.mtab{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text-muted);padding:9px 12px;border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px;transition:all .15s;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.mtab.on{color:var(--accent);border-bottom-color:var(--accent)}
.mpanel{display:none;padding:15px 17px}.mpanel.on{display:block}

/* â”€â”€ BIO GRID â”€â”€ */
.biogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--b1);border-radius:7px;overflow:hidden;margin-bottom:12px}
.bstat{background:var(--s1);padding:9px 11px}
.bstl{font-size:9px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.07em}
.bstv{font-family:var(--disp);font-size:15px;font-weight:800;color:var(--t1);margin-top:2px}

/* â”€â”€ EDIT SECTIONS â”€â”€ */
.esec{background:var(--s2);border-radius:7px;padding:12px;margin-bottom:10px}
.esecttl{font-size:9px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:9px;display:flex;align-items:center;gap:6px}
.src-chip{font-size:7px;font-weight:800;padding:1px 5px;border-radius:2px;background:rgba(40,184,112,.1);color:var(--green);border:1px solid rgba(40,184,112,.18);font-family:var(--disp);letter-spacing:.04em}
.eg3{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.eg2{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-top:7px}
.ef{display:flex;flex-direction:column;gap:3px}
.ef label{font-size:9px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.06em}
input.ei,select.ei{background:var(--s2);border:1px solid var(--b2);border-radius:4px;color:var(--t1);padding:5px 7px;font-size:12px;width:100%;outline:none;transition:border-color .2s}
input.ei:focus,select.ei:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}
.pnote{font-size:10px;color:var(--t4);font-style:italic;margin-top:4px}
.team-src-row{display:flex;align-items:center;gap:8px;background:rgba(40,184,112,.06);border:1px solid rgba(40,184,112,.12);border-radius:6px;padding:7px 10px;margin-bottom:10px;font-size:10px;color:var(--green)}
.team-src-row a{color:var(--blue);font-size:9px;text-decoration:none;margin-left:auto}
.team-src-row a:hover{text-decoration:underline}

/* â”€â”€ STATS TAB â”€â”€ */
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:12px}
.scard{background:var(--s2);border-radius:6px;padding:9px 10px}
.scardl{font-size:9px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.06em}
.scardv{font-family:var(--disp);font-size:20px;font-weight:900;color:var(--t1);margin-top:2px}
.segrid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.ngscard{background:rgba(74,158,255,.06);border:1px solid rgba(74,158,255,.12);border-radius:6px;padding:9px 10px}
.ngscardl{font-size:9px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.06em;opacity:.8}
.ngscardv{font-family:var(--disp);font-size:18px;font-weight:900;color:var(--t1);margin-top:2px}
.ngscardh{font-size:9px;color:var(--t3);margin-top:2px;line-height:1.3}

/* â”€â”€ GAME LOG â”€â”€ */
.glhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.glttl{font-size:11px;font-weight:600;color:var(--t2)}
.addbtn{font-size:10px;font-weight:700;padding:4px 9px;border-radius:4px;border:1px solid var(--b2);background:var(--s2);color:var(--t2)}
table.glt{width:100%;border-collapse:collapse;font-size:11px}
table.glt th{font-size:8px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.06em;padding:4px 5px;border-bottom:1px solid var(--b1);text-align:left}
table.glt td{padding:5px;border-bottom:1px solid var(--b1);color:var(--t2)}
table.glt tr:last-child td{border-bottom:none}
.gform{background:var(--s2);border-radius:7px;padding:11px;margin-top:10px;display:none}
.gform.open{display:block}
.gfg{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:9px}

/* â”€â”€ NOTES â”€â”€ */
.noteblk{margin-bottom:10px}
.notelbl{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.note-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.note-cc{font-size:8px;color:var(--t4);font-style:italic}
.note-as{font-size:8px;color:var(--green);font-weight:600;opacity:0;transition:opacity .3s}
.note-as.show{opacity:1}
textarea.nta{width:100%;background:var(--s2);border:1px solid var(--b2);border-radius:5px;color:var(--t1);padding:7px 9px;font-size:12px;resize:none;line-height:1.5;outline:none}
textarea.nta:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}
textarea.nta::placeholder{color:var(--t4)}

/* â”€â”€ MODAL ACTIONS â”€â”€ */
.macts{display:flex;gap:7px;padding:0 17px 14px}
.savebtn{flex:1;background:var(--accent-grad);color:var(--text-on-heat);font-family:var(--disp);font-size:var(--fs-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:9px;border-radius:var(--radius-md)}
.savebtn:hover{opacity:.85}
.clearbtn{background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:12px;font-weight:600;padding:9px 13px;border-radius:5px}
.clearbtn:hover{color:var(--accent);border-color:var(--accent)}
.savedok{font-size:11px;color:var(--green);text-align:center;padding-bottom:10px;display:none}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   COACH MODAL
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.cmbg{display:none;position:fixed;inset:0;background:radial-gradient(120% 90% at 50% 0%,rgba(182,138,78,.05),transparent),rgba(4,9,16,.74);z-index:400;align-items:flex-start;justify-content:center;padding:26px 16px;overflow-y:auto}
.cmbg.open{display:flex}

/* Coach detail modal (Carbon & Brass) — mirrors the player modal chrome */
.cm2{width:860px;max-width:100%;background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);overflow:hidden;animation:msu .15s ease}

/* toolbar */
.cm2-bar{position:relative;display:flex;align-items:center;gap:10px;padding:7px 12px 7px 16px;border-bottom:1px solid var(--border-hair);background:var(--surface-raised)}
.cm2-bar-accent{position:absolute;left:0;top:0;right:0;height:2px;background:var(--accent-grad)}
.cm2-save{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-sans);font-size:11.5px;font-weight:600;color:var(--text-muted);white-space:nowrap}
.cm2-save-dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint)}
.cm2-save.saved{color:var(--grn-400)}
.cm2-save.saved .cm2-save-dot{background:var(--grn-400)}
.cm2-sp{flex:1}
.cm2-srcs{display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap}
.cm2-lbl{font-family:var(--font-sans);font-weight:600;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--text-faint);white-space:nowrap}
.cm2-srclink-src{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-sans);font-weight:600;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);white-space:nowrap;text-decoration:none}
.cm2-srclink-src .cm2-src-dot{background:var(--grn-400)}
.cm2-srclink-src:hover{color:var(--text-secondary)}
.cm2-div{width:1px;height:18px;background:var(--border-strong);margin:0 4px;flex:0 0 auto}
.cm2-prev{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 11px;border-radius:999px;border:1px solid var(--heat-600);background:var(--heat-wash);color:var(--heat-300);font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.cm2-prev:hover{color:var(--heat-200)}
.cm2-x{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);font-size:21px;line-height:1;cursor:pointer;border-radius:7px}
.cm2-x:hover{color:var(--text-strong);background:var(--surface-input)}

/* top grid */
.cm2-top{position:relative;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:linear-gradient(135deg,var(--ink-850),var(--ink-900));border-bottom:1px solid var(--border-hair)}
.cm2-id{display:flex;flex-direction:column;gap:12px;padding:18px 22px}
.cm2-id-head{display:flex;align-items:center;gap:15px}
.cm2-crest{width:56px;height:56px;flex:0 0 auto;border-radius:11px;background:linear-gradient(135deg,var(--team),color-mix(in srgb,var(--team) 80%,#000));display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.16);border-bottom:3px solid var(--team2);box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
.cm2-crest-txt{font-family:var(--font-display);font-weight:700;font-size:20px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5);text-align:center;outline:none;min-width:20px}
.cm2-id-txt{flex:1;min-width:0}
.cm2-title{font-family:var(--font-sans);font-weight:700;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--heat-400);outline:none;display:inline-block}
.cm2-name{font-family:var(--font-display);font-size:27px;line-height:1.02;color:var(--text-strong);letter-spacing:.005em;margin-top:3px}
.cm2-name span{outline:none}
.cm2-team{font-size:13px;color:var(--text-secondary);margin-top:4px}
.cm2-block .cm2-lbl{display:block}
.cm2-phon{display:flex;gap:8px}
.cm2-mono-in{flex:1;min-width:0;box-sizing:border-box;background:var(--surface-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:6px 10px;font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-secondary);outline:none}
.cm2-mono-in:focus{box-shadow:var(--ring-focus);border-color:var(--border-focus)}
.cm2-mono-in::placeholder{color:var(--text-faint);font-style:italic}
.cm2-prn-spacer{width:22px;flex:0 0 auto}

/* editable field rows (bio, tenure) */
.cm2-frow-head{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.cm2-srcdot{width:4px;height:4px;border-radius:50%;background:var(--grn-400);flex:0 0 auto}
.cm2-frow-body{display:flex;align-items:center;gap:8px}
.cm2-in{flex:1;min-width:0;box-sizing:border-box;margin:0;background:var(--surface-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:7px 11px;font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--text-strong);line-height:1.4;outline:none}
.cm2-in:focus{box-shadow:var(--ring-focus);border-color:var(--border-focus)}
.cm2-in::placeholder{color:var(--text-faint);font-style:italic;font-weight:500}
.cm2-in-mono{font-family:var(--font-mono);font-size:12px}
.cm2-in-grn{color:var(--grn-400)}

/* print toggle */
.cm2-prn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;flex:0 0 auto;padding:0;border-radius:6px;border:none;background:transparent;color:var(--text-faint);opacity:.5;cursor:pointer}
.cm2-prn.on{color:var(--heat-400);opacity:1}

/* right column — flags + talking points */
.cm2-desk{display:flex;flex-direction:column;gap:12px;padding:16px 22px;border-left:1px solid var(--border-hair)}
.cm2-flags{display:flex;align-items:center;gap:9px}
.cm2-pc{display:inline-flex;align-items:center;gap:7px;height:26px;padding:0 11px;border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--surface-input);color:var(--text-muted);font-family:var(--font-sans);font-weight:700;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.cm2-pc.on{border-color:rgba(216,174,110,.5);background:var(--heat-wash);color:var(--heat-300)}
.cm2-pc .cm2-pc-ic-off{display:none}
.cm2-pc .cm2-pc-ic-on{display:inline}
.cm2-pc:not(.on) .cm2-pc-ic-on{display:none}
.cm2-pc:not(.on) .cm2-pc-ic-off{display:inline}
.cm2-verified{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 11px;border-radius:var(--radius-md);background:var(--grn-wash);border:1px solid rgba(88,192,140,.45);color:var(--grn-400);font-family:var(--font-sans);font-weight:700;font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.cm2-verified.hide{display:none}
.cm2-tp{flex:1;display:flex;flex-direction:column}
.cm2-sec-row{display:flex;align-items:center;margin-bottom:8px}
.cm2-seclbl{font-family:var(--font-sans);font-weight:700;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}
.cm2-srclink{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-sans);font-weight:600;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);white-space:nowrap}
.cm2-src-dot{width:5px;height:5px;border-radius:50%;flex:0 0 auto}
.cm2-srclink-manual .cm2-src-dot{background:var(--heat-400)}
.cm2-note{width:100%;box-sizing:border-box;min-height:64px;resize:vertical;background:var(--surface-input);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-body);font-family:var(--font-sans);font-size:13px;line-height:1.55;padding:9px 11px;outline:none}
.cm2-note:focus{box-shadow:var(--ring-focus);border-color:var(--border-focus)}
.cm2-note::placeholder{color:var(--text-faint);font-style:italic}
.cm2-note-tp{flex:1;min-height:150px}

/* full-width note sections */
.cm2-nsec{padding:15px 24px;border-top:1px solid var(--border-hair)}
.cm2-nsec-head{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.cm2-nsec-bar{width:3px;height:13px;border-radius:2px;flex:0 0 auto}
.cm2-nsec-ic{flex:0 0 auto}
.cm2-nsec-hint{font-family:var(--font-mono);font-size:10.5px;color:var(--text-faint);white-space:nowrap}

/* footer */
.cm2-foot{display:flex;align-items:center;gap:10px;padding:12px 24px;border-top:1px solid var(--border-hair);background:var(--surface-raised)}
.cm2-btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--radius-md);border:none;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.cm2-btn-ghost{background:transparent;color:var(--text-muted)}
.cm2-btn-ghost:hover{background:var(--surface-input)}
.cm2-btn-danger{color:var(--status-out)}
.cm2-btn-secondary{background:var(--surface-input);border:1px solid var(--border-strong);color:var(--text-secondary)}
.cm2-btn-secondary:hover{color:var(--text-strong)}
.cm2-btn-primary{background:var(--accent-grad);color:var(--accent-ink)}
.cm2-btn-primary:hover{opacity:.9}
@media(max-width:760px){.cm2-top{grid-template-columns:1fr}.cm2-desk{border-left:none;border-top:1px solid var(--border-hair)}}

/* edited-field indicator + per-field reset (matches player-modal pm-modified) */
.cm2-fw{position:relative;display:inline-flex;align-items:stretch}
.cm2-frow-body .cm2-fw,.cm2-phon .cm2-fw{flex:1;min-width:0}
.cm2-fw-block{display:flex;flex-direction:column;width:100%}
.cm2-fw-grow{flex:1;min-height:0}
.cm2-fw>.cm2-in,.cm2-fw>.cm2-mono-in,.cm2-fw>.cm2-note{flex:1;min-width:0}
.cm2-fw.cm2-edited>.cm2-in,.cm2-fw.cm2-edited>.cm2-mono-in,.cm2-fw.cm2-edited>.cm2-note{background:var(--heat-wash);box-shadow:inset 0 0 0 1px var(--heat-600)}
.cm2-fw.cm2-edited>.cm2-crest-txt,.cm2-fw.cm2-edited>.cm2-title,.cm2-fw.cm2-edited>.cm2-name span,.cm2-fw.cm2-edited>span[contenteditable]{background:var(--heat-wash);box-shadow:inset 0 0 0 1px var(--heat-600);border-radius:4px}
.cm2-reset{position:absolute;top:-8px;right:-8px;width:18px;height:18px;display:none;align-items:center;justify-content:center;padding:0;border:1px solid var(--heat-600);border-radius:50%;background:var(--ink-900);color:var(--heat-400);font-size:12px;line-height:1;cursor:pointer;z-index:6;box-shadow:0 1px 4px rgba(0,0,0,.45)}
.cm2-reset:hover{background:var(--heat-600);color:#fff}
.cm2-fw.cm2-edited>.cm2-reset{display:flex}

/* ── simple coach modal: single column, five fields ── */
.cm2.cm2-simple{width:520px}
.cm2-shd{display:flex;align-items:center;gap:15px;padding:18px 22px 16px;border-bottom:1px solid var(--border-hair);background:linear-gradient(135deg,var(--ink-850),var(--ink-900))}
.cm2-sbody{display:flex;flex-direction:column;gap:16px;padding:18px 22px 20px}
.cm2-two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cm2-sbody .cm2-lbl{color:var(--heat-400)}
.cm2-sbody .cm2-lbl.cm2-lbl-grn{color:var(--grn-400)}
.cm2-note-bio{min-height:58px}
.cm2-note-week{min-height:104px;border-color:rgba(88,192,140,.3);background:var(--grn-wash)}
.cm2-tag{font-family:var(--font-mono);font-size:8.5px;letter-spacing:.13em;text-transform:uppercase;border-radius:5px;padding:2px 7px;line-height:1.5;white-space:nowrap}
.cm2-tag-saved{color:var(--heat-300);background:var(--heat-wash);border:1px solid var(--heat-600)}
.cm2-tag-week{color:var(--grn-400);background:var(--grn-wash);border:1px solid rgba(88,192,140,.4)}
.cm2-pgdiv{display:flex;align-items:center;gap:10px}
.cm2-pgline{flex:1;height:1px;background:var(--border-hair)}
.cm2-pgcap{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint)}
.cm2-tpclear{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;padding:0;font-family:var(--font-sans);font-size:11px;color:var(--text-faint);cursor:pointer}
.cm2-tpclear:hover{color:var(--text-secondary)}

/* print preview overlay (paper spotter card) */
.cm-print-ovl{position:fixed;inset:0;z-index:1000;background:rgba(4,9,16,.8);display:flex;flex-direction:column;align-items:center;padding:26px 18px 44px;overflow:auto}
.cm-print-bar{width:520px;max-width:100%;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.cm-print-bar-lbl{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-sans);font-size:12px;font-weight:600;color:var(--text-secondary)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SCROLLBAR
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s4);border-radius:3px}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Header Action Buttons
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.hdr-action-btn{font-family:var(--disp);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);cursor:pointer;transition:all .2s;white-space:nowrap;margin-left:6px}
.add-player-btn{background:var(--s3);color:var(--t2)}
.add-player-btn:hover{background:var(--s4);color:var(--t1);border-color:var(--b3)}
.stats-btn{background:var(--s3);color:var(--t2)}
.stats-btn:hover{background:var(--s4);color:var(--t1);border-color:var(--b3)}
.stats-btn.stats-loading{background:var(--s2);color:var(--gold);border-color:rgba(240,192,64,.3);cursor:wait;pointer-events:none}
.stats-btn.stats-loading .stats-spin{display:inline-block;animation:statsSpin 1s linear infinite}
@keyframes statsSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.stats-btn.stats-done{background:rgba(40,184,112,.15);color:var(--green);border-color:rgba(40,184,112,.3)}
.stats-btn.stats-error{background:rgba(232,52,26,.15);color:var(--red);border-color:rgba(232,52,26,.3)}
@media print{.hdr-action-btn{display:none!important}}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Offensive Stats Layout
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.sgrid:has(.off-stat-row){display:block;grid-template-columns:none}
.segrid:has(.off-stat-row){display:block;grid-template-columns:none}
.off-stat-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;background:var(--s2);border-radius:7px;padding:10px 12px;width:100%}
.off-stat-row-lbl{font-family:var(--disp);font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);min-width:78px;flex-shrink:0;border-right:1px solid var(--b2);padding-right:12px;align-self:stretch;display:flex;align-items:center}
.off-stat-row-cells{display:flex;gap:14px;flex:1;flex-wrap:nowrap;overflow-x:auto;min-width:0}
.off-stat-cell{flex:0 0 auto;min-width:44px;text-align:left}
.off-stat-lbl{font-size:8.5px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;white-space:nowrap}
.off-stat-val{font-family:var(--disp);font-size:17px;font-weight:900;color:var(--t1);line-height:1;white-space:nowrap}
.off-stat-edit-cells{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;flex:1;min-width:0}
.off-stat-edit-cells .ef{min-width:0}
.off-stat-edit-cells .ef label{font-size:8.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.off-stat-edit-cells .ef input.ei{font-size:11px;padding:4px 6px}
@media(max-width:700px){.off-stat-edit-cells{grid-template-columns:repeat(3,1fr)}}

/* â”€â”€ Career stats â”€â”€ */
.career-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.career-label{font-family:var(--disp);font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--gold);text-transform:uppercase}
.career-gp{font-family:var(--disp);font-size:11px;font-weight:600;color:var(--t3);letter-spacing:.5px}
.verify-link{font-family:var(--disp);font-size:9px;font-weight:600;letter-spacing:.5px;color:var(--blue);text-decoration:none;text-transform:uppercase;margin-left:6px;opacity:.7;transition:opacity .15s}
.verify-link:hover{opacity:1;text-decoration:underline}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PRINT BOARD SELECTION
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.sel-tally{font-family:var(--disp);font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.3px;padding:2px 8px;border-radius:4px;background:var(--s2);border:1px solid var(--b2);white-space:nowrap}
.sel-tally .sel-full{color:var(--green);font-weight:800}
.sel-th{width:28px;text-align:center;cursor:default;color:var(--gold);font-size:10px}
.sel-td{width:28px;text-align:center;cursor:pointer!important;padding:4px 2px!important}
.sel-star{font-size:14px;color:var(--t4);transition:color .15s,transform .15s;display:inline-block;line-height:1}
.sel-star:hover{color:var(--gold);transform:scale(1.2)}
.sel-star.sel-on{color:var(--gold);text-shadow:0 0 4px rgba(240,192,64,.4)}
.sel-row{background:rgba(240,192,64,.04)!important}
.sel-row:hover{background:rgba(240,192,64,.08)!important}
@media print{.sel-tally,.sel-th,.sel-td{display:none!important}}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PRINT SYSTEM v9
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.pp-page{background:#fff;border:1px solid var(--b2);border-radius:9px;padding:10px 14px;margin-bottom:14px;color:#111;width:1632px;height:1056px;overflow:hidden;box-sizing:border-box;display:flex;flex-direction:column}
.pp-auto{height:auto;min-height:400px}
.pp-hdr{display:flex;align-items:center;justify-content:space-between;padding:4px 6px;margin-bottom:6px;border-bottom:3px solid #222;flex-shrink:0}
.pp-hdr-l{display:flex;align-items:baseline;gap:6px}
.pp-hdr-b{font-family:var(--disp);font-size:18px;font-weight:900;letter-spacing:3px;color:#e8341a}
.pp-hdr-s{color:#ccc;font-size:12px}
.pp-hdr-t{font-family:var(--disp);font-size:14px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#333}
.pp-hdr-r{display:flex;align-items:baseline;gap:12px}
.pp-hdr-m{font-family:var(--disp);font-size:13px;font-weight:700;color:#222}
.pp-hdr-d{font-size:10px;color:#999;font-weight:600}
.pp-teambar{display:flex;align-items:center;gap:6px;padding:3px 6px;margin-bottom:6px;border-left:4px solid #888;background:#f4f4f4;border-radius:2px;flex-shrink:0}
.pp-teambar-a{font-family:var(--disp);font-size:16px;font-weight:900}
.pp-teambar-n{font-family:var(--disp);font-size:10px;font-weight:600;color:#666}
.pp-2col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pp-divider{font-family:var(--disp);font-size:9px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#aaa;padding:8px 0 3px;margin-top:6px;border-top:1px solid #ddd;text-align:center}
.pp-body{display:flex;gap:6px;flex:1;min-height:0;overflow:hidden;align-items:stretch}
.pp-col{min-width:0;display:flex;flex-direction:column}
.pp-col-hdr{font-family:var(--disp);font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;text-align:center;padding:3px 4px 2px;margin-bottom:3px;border-bottom:2px solid #ccc;flex-shrink:0}
.pp-col-stack{display:flex;flex-direction:column;gap:4px;flex:1;min-height:0;overflow:hidden}
.pp-col-stack.pp-drop-target{background:rgba(240,192,64,.08);border-radius:3px}
.pp-ol-section{flex-shrink:0;border-top:2px solid #ccc;padding-top:4px;margin-top:auto}
.pp-zone-label{font-family:var(--disp);font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;text-align:center;padding:3px 4px 2px;margin-bottom:3px;border-bottom:2px solid #ccc}
.pp-ol-row{display:flex;gap:5px;margin-bottom:4px}
.pp-ol-row .pp-card{flex:1;min-width:0;min-height:50px}
.pp-ol-row.pp-drop-target{background:rgba(240,192,64,.08);border-radius:3px}
.pp-res-label{font-family:var(--disp);font-size:7px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#aaa;padding:2px 4px}
.pp-sidebar{width:180px;flex-shrink:0;border:1px dashed #d0d0d0;border-radius:3px;padding:6px;align-self:stretch}
.pp-sb-hdr{font-family:var(--disp);font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;border-bottom:2px solid #bbb;padding-bottom:3px;margin-bottom:6px}
.pp-sb-section{margin-bottom:8px}
.pp-sb-label{font-family:var(--disp);font-size:9px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#999;border-bottom:1px solid #ddd;padding-bottom:2px;margin-bottom:4px}
.pp-sb-lines{min-height:90px;background:repeating-linear-gradient(transparent,transparent 16px,#e0e0e0 16px,#e0e0e0 17px)}
.pp-card{background:#fff;border:1px solid #c0c0c0;border-radius:4px;padding:6px 8px;font-size:10px;line-height:1.4;color:#222;overflow:hidden;position:relative;cursor:grab;user-select:none;flex:none;min-height:80px}
.pp-tier-starter{border-width:2px;border-color:#666}
.pp-tier-deep{border-color:#ddd}
.pp-tier-btns{display:flex;gap:1px;flex-shrink:0;opacity:0;transition:opacity .15s}
.pp-card:hover .pp-tier-btns{opacity:1}
.pp-tbtn{font-size:7px;font-weight:800;font-family:var(--disp);padding:2px 4px;border-radius:2px;background:#eee;color:#999;border:none;cursor:pointer;line-height:1}
.pp-tbtn:hover{background:#ddd;color:#333}
.pp-tbtn-on{background:#333;color:#fff}
.pp-tier-starter .pp-num{font-size:36px;min-width:44px;height:40px}
.pp-tier-starter .pp-name{font-size:15px}
.pp-tier-starter .pp-name b{font-size:17px}
.pp-tier-deep .pp-num{font-size:22px;min-width:28px;height:26px}
.pp-tier-deep .pp-name{font-size:11px}
.pp-tier-deep .pp-name b{font-size:12px}
.pp-card.pp-dragging{opacity:.3;border-color:#e8341a}
.pp-card.pp-hover{border-color:#f0c040;border-style:dashed}
.pp-card:hover{border-color:#999}
.pp-r1{display:flex;align-items:center;gap:6px;margin-bottom:2px}
.pp-num{font-family:var(--disp);font-size:30px;font-weight:900;color:#fff;min-width:38px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:4px;line-height:1;flex-shrink:0}
.pp-num-sm{font-size:16px;min-width:24px;height:22px}
.pp-id{flex:1;min-width:0}
.pp-name{font-family:var(--disp);font-size:14px;font-weight:400;color:#333;word-wrap:break-word;overflow-wrap:break-word}
.pp-name b{font-weight:900;color:#000;letter-spacing:.5px;font-size:16px}
.pp-pos{font-family:var(--disp);font-size:10px;font-weight:800;color:#888;letter-spacing:.5px;flex-shrink:0}
.pp-phon{font-size:9px;color:#999;font-style:italic}
.pp-bio{font-size:9px;color:#666;line-height:1.3;margin-top:1px}
.pp-badges{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}
.pp-bg{display:inline-block;padding:1px 4px;border-radius:2px;font-size:7.5px;font-weight:800;letter-spacing:.3px;font-family:var(--disp);text-transform:uppercase;line-height:1.5}
.pp-bg.b-r1{background:#fff3d0;color:#9a7000}.pp-bg.b-dr{background:#fff8e0;color:#a08020}.pp-bg.b-rk{background:#e0f5ea;color:#1a7a42}.pp-bg.b-pb{background:#e0edff;color:#2060b0}.pp-bg.b-ap{background:#ece0ff;color:#6030b0}.pp-bg.b-cap{background:#ffe0dd;color:#b02010}.pp-bg.b-dc{background:#e0edff;color:#2060b0}
.pp-inj{font-size:9px;color:#c33;font-weight:700;line-height:1.3;margin-top:2px}
.pp-stat{font-family:var(--disp);font-size:10px;font-weight:700;color:#222;background:#f0f0f0;border-radius:2px;padding:2px 6px;margin-top:3px;letter-spacing:.3px}
.pp-car{min-height:0}
.pp-cline{font-family:var(--disp);font-size:9px;font-weight:600;color:#555;background:#f8f8f8;border-radius:2px;padding:2px 6px;margin-top:2px}
.pp-notes{margin-top:3px;padding-top:3px;border-top:1px solid #ddd}
.pp-nl{font-size:9px;color:#444;line-height:1.5;margin-bottom:1px}
.pp-prev{font-size:8px;color:#999;font-style:italic;margin-top:2px}
.pp-feature .pp-num{font-size:36px;min-width:44px;height:40px}
.pp-feature .pp-name{font-size:15px}
.pp-feature .pp-name b{font-size:17px}
.print-pad{padding:14px 16px}
.pvhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.pvtitle{font-family:var(--disp);font-size:16px;font-weight:800}
.pvacts{display:flex;gap:6px}
.backbtn{background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:11px;font-weight:600;padding:6px 12px;border-radius:5px}
.printbtn{background:var(--accent-grad);color:var(--text-on-heat);font-family:var(--disp);font-size:var(--fs-sm);font-weight:600;padding:6px 14px;border-radius:var(--radius-md);letter-spacing:.05em;text-transform:uppercase}

@media print{
  @page{size:17in 11in;margin:.25in}
  body{background:#fff!important;color:#000!important}
  .hdr,.navtabs,.toolbar,.view:not(#printView),.mbg,.src-bar,.cmbg{display:none!important}
  #printView{display:flex!important;flex-direction:column;padding:0}
  .pvhdr{display:none!important}
  .print-pad{padding:0!important}
  .pp-page,.pp-auto{border:none!important;border-radius:0!important;margin:0!important;padding:6px 8px!important;break-after:page;box-shadow:none!important;width:auto!important;height:auto!important}
  .pp-card{break-inside:avoid;cursor:default}
  .pp-tier-btns{display:none!important}
  .pp-stat,.pp-cline,.pp-teambar,.pp-num,.pp-bg,.pp-col-hdr,.pp-zone-label,.pp-sb-lines{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .pp-sidebar{border-style:solid;border-color:#ccc}
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   DEPTH CHART BOARD â€” Column Layout (v10)
/* ══════════════════════════════════════════════════════════════════
   DEPTH CHART BOARD — v21.1 (minimal v7 + zoom/density/drawer)
   ══════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════════
   ROSTER BOARD v26 — unified toolbar + section bands + columns
   ══════════════════════════════════════════════════════════════════ */
/* ── UNIFIED TOOLBAR ── */
.dc-toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:7px clamp(12px,1.4vw,18px) 8px;background:var(--surface-raised);border-bottom:1px solid var(--border-hair);position:sticky;top:0;z-index:50}
.dc-tb-div{width:1px;height:40px;background:var(--border-hair);flex-shrink:0;align-self:flex-end;margin-bottom:1px}
.dc-tb-sp{flex:1;min-width:8px}

/* captioned control clusters (SOURCE / BOARD / VIEW) */
.dc-cluster{display:flex;flex-direction:column}
.dc-guide{max-width:430px}
.dc-guide-txt{font-family:var(--font-sans);font-size:11px;font-weight:500;line-height:1.35;color:var(--text-muted)}
.dc-guide-txt b{font-weight:700;color:var(--text-secondary)}
.dc-guide-q{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1px solid var(--border-strong);background:transparent;color:var(--text-muted);font-family:var(--font-display);font-size:10px;font-weight:700;line-height:1;cursor:pointer;vertical-align:middle;margin-left:2px}
.dc-guide-q:hover{color:var(--text-strong);border-color:var(--text-faint)}
.clab{font-family:var(--font-display);font-weight:600;font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--text-faint);margin:0 0 5px 2px}
.dc-cluster-row{display:flex;align-items:center;gap:8px}

/* board-editing pills (Reset / Add Player) — quiet outline, never brass */
.dc-pill{height:30px;padding:0 12px;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;cursor:pointer;transition:background .12s,border-color .12s,color .12s}
.dc-pill:hover{background:var(--surface-card);color:var(--text-strong);border-color:var(--text-faint)}
.dc-pill svg{flex-shrink:0}

/* matchup hero */
.mh{display:flex;align-items:center;gap:10px}
.mh-team{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;border-radius:var(--radius-md);background:transparent;border:1px solid transparent;opacity:.5;cursor:pointer;transition:opacity .15s,background .15s,border-color .15s}
.mh-team.on{background:var(--surface-card);opacity:1}
.mh-team:hover{opacity:1}
.mh-chip{width:34px;height:34px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.22);font-family:var(--font-display);font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.mh-stack{display:flex;flex-direction:column;line-height:1}
.mh-abbr{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--text-strong)}
.mh-role{font-family:var(--font-sans);font-weight:600;font-size:9.5px;letter-spacing:.11em;text-transform:uppercase;color:var(--text-faint);margin-top:3px}
.mh-at{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--text-faint)}
.dc-tb-lbl{font-family:var(--font-sans);font-weight:600;font-size:.78rem;color:var(--text-secondary);white-space:nowrap}
.dc-tb-hint{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.7rem;color:var(--text-faint);white-space:nowrap}
.dc-tb-hint svg{opacity:.8}

/* segmented control */
.dc-seg{display:inline-flex;background:var(--surface-raised);border:1px solid var(--border-hair);border-radius:var(--radius-md);padding:3px;gap:2px}
.dc-seg-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--text-muted);font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:6px 13px;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}
.dc-seg-btn:hover{color:var(--text-body)}
.dc-seg-btn.on{background:var(--accent-grad);color:var(--text-on-heat);box-shadow:0 1px 6px var(--heat-glow,rgba(182,138,78,.32))}
.dc-seg-btn em{font-style:normal;font-weight:500;font-size:.68rem;color:var(--text-faint);letter-spacing:.02em}
.dc-seg-btn.on em{color:var(--text-on-heat);opacity:.72}
.dc-seg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dc-seg-sm .dc-seg-btn{padding:6px 11px;font-size:.74rem}

/* actives-only switch */
.dc-switch-wrap{display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.dc-switch{position:relative;width:36px;height:20px;border-radius:999px;border:1px solid var(--border-hair);background:var(--surface-input);cursor:pointer;padding:0;flex-shrink:0;transition:background .18s,border-color .18s}
.dc-switch.on{background:var(--accent-grad);border-color:var(--heat-500)}
.dc-switch-knob{position:absolute;top:50%;left:2px;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:var(--text-strong);transition:left .18s}
.dc-switch.on .dc-switch-knob{left:18px;background:var(--text-on-heat)}

/* search */
.dc-search{display:inline-flex;align-items:center;gap:7px;background:var(--surface-input);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:0 11px;height:32px;width:clamp(120px,13vw,180px);color:var(--text-muted);transition:border-color .15s,box-shadow .15s}
.dc-search:focus-within{border-color:var(--border-focus);box-shadow:var(--ring-focus)}
.dc-search svg{flex-shrink:0}
.dc-search input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--text-body);font-family:var(--font-sans);font-size:.8rem}
.dc-search input::placeholder{color:var(--text-faint)}

/* zoom control (segmented − % +) */
.dc-zoom{display:inline-flex;align-items:center;height:32px;background:var(--surface-input);border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:hidden}
.dc-zoom-btn{width:28px;height:100%;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:background .12s,color .12s}
.dc-zoom-btn:hover{background:var(--surface-hover);color:var(--text-strong)}
.dc-zoom-val{min-width:46px;height:100%;padding:0 4px;background:none;border:none;border-left:1px solid var(--border-strong);border-right:1px solid var(--border-strong);font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-body);cursor:pointer;transition:background .12s,color .12s}
.dc-zoom-val:hover{background:var(--surface-hover);color:var(--text-strong)}

/* ── CANVAS ── */
.dc-canvas{padding:clamp(12px,1.4vw,18px);overflow-x:auto;--dc-col-w:clamp(184px,15vw,232px);--dc-col-gap:12px}

/* ── SECTION BANDS ── */
.dc-band{display:flex;align-items:center;gap:12px;height:36px;padding:0 14px;margin:0 0 12px;border-radius:var(--radius-sm)}
.dc-band-off{background:linear-gradient(90deg,var(--heat-wash),transparent);border-left:3px solid var(--heat-500)}
.dc-band-def{background:linear-gradient(90deg,var(--acq-wash),transparent);border-left:3px solid var(--acq-500)}
.dc-band-name{font-family:var(--font-display);font-weight:600;font-size:clamp(15px,1.3vw,18px);letter-spacing:.06em;text-transform:uppercase;color:var(--text-strong)}
.dc-band-count{font-family:var(--font-sans);font-weight:600;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}
.dc-band-count b{font-family:var(--font-display);font-weight:700;font-size:15px;margin-right:4px}
.dc-band-off .dc-band-count b{color:var(--heat-400)}
.dc-band-def .dc-band-count b{color:var(--acq-500)}
.dc-band-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.dc-band-actions .dc-pill{height:26px;padding:0 10px;font-size:11px;gap:5px}
.dc-band .dc-seg{margin-left:auto;flex-wrap:nowrap}
@media print{.dc-band-actions{display:none!important}}
/* Extra-column status filter living on the right of the section band.
   Compact, single row, consistent chip sizing. */
.dc-band .dc-extra-filter .dc-seg-btn{padding:5px 10px;font-size:.72rem;min-width:40px;justify-content:center}
.dc-band-gap{height:22px}

/* ── COLUMNS ── */
.dc-cols{display:flex;gap:var(--dc-col-gap);align-items:flex-start;margin-bottom:16px;width:max-content;min-width:100%}
.dc-col{width:var(--dc-col-w);flex:0 0 auto;display:flex;flex-direction:column;gap:5px;border-radius:var(--radius-md);transition:background .12s}
.dc-col.dc-dragover{background:var(--heat-wash)}
.dc-col-dashed{border:1px dashed var(--border-strong);background:rgba(0,0,0,.12);padding:8px;min-height:128px;align-self:stretch}
.dc-col-dashed.dc-dragover{border-color:var(--heat-500)}
.dc-col-hdr{display:flex;align-items:center;justify-content:space-between;padding:0 2px 5px;border-bottom:1px solid var(--border-strong)}
.dc-col-dashed .dc-col-hdr{border-bottom-style:dashed}
.dc-col-lbl{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}
.dc-col-dashed .dc-col-lbl{color:var(--text-muted);font-size:12px}
.dc-col-sub{font-family:var(--font-sans);font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin-left:6px}
.dc-col-ct{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);font-variant-numeric:tabular-nums}
.dc-col-empty{text-align:center;font-family:var(--font-mono);font-size:11px;color:var(--text-faint);padding:16px 0}
.dc-col-hint{text-align:center;font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.02em;color:var(--text-secondary);padding:5px 0 6px}
@media print{.dc-col-hint{display:none!important}}

/* Roster (Extra) column collapse — chevron toggle + collapsed thin rail */
.dc-col-collapse{margin-left:6px;flex:0 0 auto;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-strong);border-radius:5px;background:none;color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s}
.dc-col-collapse:hover{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--border-focus)}
.dc-col-collapse svg{display:block;transition:transform .15s}
.dc-col-dashed.dc-col-collapsed{width:38px;min-width:38px;padding:8px 2px 12px;align-items:center;cursor:pointer;background:var(--heat-wash);border:1px solid var(--heat-500);box-shadow:inset 0 0 0 1px rgba(182,138,78,.18),0 0 14px -4px var(--heat-glow,rgba(182,138,78,.32));transition:background .14s,border-color .14s,box-shadow .14s}
.dc-col-dashed.dc-col-collapsed:hover{background:var(--accent-wash,rgba(182,138,78,.16));border-color:var(--heat-400)}
.dc-col-dashed.dc-col-collapsed .dc-card,
.dc-col-dashed.dc-col-collapsed .dc-col-hint,
.dc-col-dashed.dc-col-collapsed .dc-col-sub,
.dc-col-dashed.dc-col-collapsed .dc-extra-filter,
.dc-col-dashed.dc-col-collapsed .dc-col-empty{display:none}
.dc-col-dashed.dc-col-collapsed .dc-col-hdr{flex-direction:column;align-items:center;gap:10px;border-bottom:none;padding:2px 0 0}
.dc-col-dashed.dc-col-collapsed .dc-col-collapse{order:-1}
.dc-col-dashed.dc-col-collapsed .dc-col-collapse svg{transform:scaleX(-1)}
.dc-col-dashed.dc-col-collapsed .dc-col-lbl{writing-mode:vertical-rl;transform:rotate(180deg);letter-spacing:.16em;margin:0;color:var(--heat-400);font-weight:700}
.dc-col-dashed.dc-col-collapsed .dc-col-ct{writing-mode:vertical-rl;color:var(--heat-300)}
.dc-col-dashed.dc-col-collapsed .dc-col-collapse{color:var(--heat-400);border-color:rgba(182,138,78,.5)}
@media print{.dc-col-dashed.dc-col-collapsed{width:auto;min-width:0}}

/* Roster column status filter (moved onto the column so it's clearly its control) */
.dc-col-dashed .dc-extra-filter{display:flex;width:100%;margin:6px 0 8px}
.dc-col-dashed .dc-extra-filter .dc-seg-btn{flex:1;min-width:0;justify-content:center;padding:6px 2px;font-size:.68rem;letter-spacing:.02em}

/* Editable jersey number + name on the modal hero card (click to edit -> OV) */
#cardOv .cardov-id-edit{cursor:text;border-radius:3px;transition:box-shadow .12s}
#cardOv .cardov-id-edit:hover{box-shadow:inset 0 0 0 1px rgba(182,138,78,.55)}
#cardOv .cardov-id-edit:focus{outline:none;box-shadow:inset 0 0 0 1.5px var(--heat-500,#B68A4E)}
/* Remove (delete) button in the card overlay top bar — only shown for manual players */
#cardOv .cardov-del{color:var(--status-out,#DE5B41)!important;border-color:rgba(222,91,65,.4)!important}
#cardOv .cardov-del:hover{background:rgba(222,91,65,.12)!important;border-color:var(--status-out,#DE5B41)!important}

/* Clerk sign-in mount (landing right column) */
.clerk-mount{width:100%;min-height:360px;display:flex;justify-content:center}

/* "More sports coming soon" teasers (sign-in brand panel + dashboard masthead) */
.land-soon{margin-top:clamp(18px,2vw,26px);padding-top:clamp(14px,1.6vw,20px);border-top:1px solid var(--border-hair);font-family:var(--font-mono);font-size:clamp(.68rem,.63rem + .15vw,.8rem);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);line-height:1.6}
.land-soon b{color:var(--heat-400);font-weight:600}
.dash-soon{margin-top:7px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.05em;color:var(--text-faint)}
.dash-soon b{color:var(--heat-400);font-weight:600}

/* Add Player — clean manual-entry modal */
.hb-addp-ov{position:fixed;inset:0;z-index:100000;background:rgba(7,8,10,.62);display:flex;align-items:center;justify-content:center;padding:24px}
.hb-addp-modal{width:430px;max-width:100%;background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:16px;box-shadow:var(--shadow-modal);overflow:hidden}
.hb-addp-hd{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border-strong)}
.hb-addp-mark{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:#fff;font-size:13px;letter-spacing:.02em;flex:0 0 auto}
.hb-addp-ttl{font-family:var(--font-display);font-size:19px;font-weight:700;letter-spacing:.02em;color:var(--text-strong);text-transform:uppercase;line-height:1}
.hb-addp-team{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);margin-top:2px}
.hb-addp-x{margin-left:auto;color:var(--text-muted);font-size:17px;background:none;border:none;cursor:pointer;line-height:1}
.hb-addp-x:hover{color:var(--text-secondary)}
.hb-addp-body{padding:18px}
.hb-addp-row{display:flex;gap:12px;margin-bottom:14px}
.hb-addp-sec{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin:2px 0 12px;padding-top:12px;border-top:1px solid var(--border-strong);display:flex;align-items:center;gap:8px}
.hb-addp-sec span{font-weight:500;letter-spacing:.04em;text-transform:none;color:var(--text-faint);font-size:11px}
.hb-addp-f{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.hb-addp-f.hb-addp-j{flex:0 0 92px}
.hb-addp-lbl{font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}
.hb-addp-in,.hb-addp-sel{background:var(--surface-input);border:1px solid var(--ink-600);border-radius:8px;color:var(--text-body);font-family:var(--font-sans);font-size:14px;padding:10px 12px;outline:none;width:100%;transition:border-color .15s,box-shadow .15s}
.hb-addp-in::placeholder{color:var(--text-faint)}
.hb-addp-in:focus,.hb-addp-sel:focus{border-color:var(--heat-500);box-shadow:var(--ring-focus)}
.hb-addp-sel{appearance:none;-webkit-appearance:none;padding-right:30px;cursor:pointer}
.hb-addp-err{color:var(--status-out);font-family:var(--font-sans);font-size:12px;min-height:14px;margin-top:2px}
.hb-addp-ft{display:flex;justify-content:flex-end;gap:10px;padding:4px 18px 18px}
.hb-addp-btn{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:9px;padding:10px 18px;cursor:pointer;transition:filter .15s,transform .12s,background .15s}
.hb-addp-cancel{color:var(--text-secondary);background:none;border:1px solid var(--border-strong)}
.hb-addp-cancel:hover{background:var(--surface-hover)}
.hb-addp-add{color:var(--text-on-heat);background:var(--accent-grad);border:none}
.hb-addp-add:hover{filter:brightness(1.06);transform:translateY(-1px)}

/* KR/PR returner reference slots — live at the bottom of the ST column. */
.dc-ret{display:flex;flex-direction:column;gap:calc(4px * var(--zf));margin-top:calc(6px * var(--zf));padding-top:calc(6px * var(--zf));border-top:1px dashed var(--border-strong)}
.dc-ret-hdr{font-family:var(--disp);font-size:calc(7px * var(--zf));font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}
.dc-ret-slot{display:flex;flex-direction:column;align-items:stretch;gap:calc(3px * var(--zf));min-height:calc(22px * var(--zf));padding:calc(3px * var(--zf)) calc(5px * var(--zf));border:1px dashed var(--border-strong);border-radius:var(--radius-sm);background:rgba(0,0,0,.1);transition:background .12s,border-color .12s}
.dc-ret-slot.dc-ret-over{border-color:var(--heat-500);background:var(--heat-wash)}
.dc-ret-slot.dc-ret-full{border-style:solid}
.dc-ret-lbl{font-family:var(--disp);font-size:calc(8px * var(--zf));font-weight:700;letter-spacing:.06em;color:var(--text-secondary);flex-shrink:0}
.dc-ret-chips{display:flex;flex-direction:column;gap:calc(4px * var(--zf));flex:1;min-width:0}
.dc-ret-hint{font-family:var(--font-mono);font-size:calc(7px * var(--zf));color:var(--text-faint);font-style:italic}
.dc-ret-chip{display:flex;align-items:center;gap:calc(4px * var(--zf));padding:calc(2px * var(--zf)) calc(4px * var(--zf));background:var(--surface-raised);border:1px solid var(--border-hair);border-radius:4px;cursor:pointer;width:100%}
.dc-ret-chip:hover{border-color:var(--border-strong)}
.dc-ret-num{font-family:var(--font-mono);font-size:calc(7px * var(--zf));color:var(--text-faint)}
.dc-ret-nm{font-family:var(--disp);font-size:calc(8px * var(--zf));font-weight:600;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}
.dc-ret-pos{font-family:var(--disp);font-size:calc(6px * var(--zf));font-weight:700;color:var(--t2);letter-spacing:.04em}
.dc-ret-x{border:none;background:none;color:var(--text-faint);font-size:calc(11px * var(--zf));line-height:1;cursor:pointer;padding:0 0 0 calc(1px * var(--zf))}
.dc-ret-x:hover{color:var(--status-out)}
.dc-ret-tag{display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;height:calc(10px * var(--zf));font-family:var(--disp);font-size:calc(4.5px * var(--zf));font-weight:700;letter-spacing:.04em;line-height:1;color:#fff;background:var(--accent);border:1px solid transparent;border-radius:3px;padding:0 calc(3px * var(--zf));flex-shrink:0}

/* ── OFFENSE MAIN BLOCK (skill row stacked over OL strip) ── */
/* Holding columns (Not on Board / Extra) sit to the RIGHT of this block and
   run the full height, so they extend down alongside the OL strip instead of
   pushing it below them. */
.dc-off-main{display:flex;flex-direction:column;gap:var(--dc-col-gap);flex:0 0 auto}
.dc-skill-row{display:flex;gap:var(--dc-col-gap);align-items:flex-start}

/* ── OL STRIP (2-deep) ── */
.dc-ol-strip{margin-bottom:0}
.dc-ol-strip-hdr{display:flex;align-items:baseline;gap:8px;padding:0 4px 6px;border-bottom:2px solid var(--heat-600);margin-bottom:10px}
.dc-ol-strip-name{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--heat-400)}
.dc-ol-strip-sub{font-family:var(--font-mono);font-size:10.5px;color:var(--text-muted);letter-spacing:.04em}
.dc-ol-row{display:grid;grid-template-columns:repeat(5,var(--dc-col-w));gap:var(--dc-col-gap);width:max-content;min-width:100%}
.dc-ol-slot{display:flex;flex-direction:column;min-width:0;border-radius:var(--radius-md);transition:background .12s}
.dc-ol-slot.dc-dragover{background:var(--heat-wash)}
.dc-ol-pos{padding:0 2px 5px;text-align:center;font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border-hair);margin-bottom:6px}
.dc-ol-body{padding:0;display:flex;flex-direction:column;gap:5px;flex:1;min-height:60px}


/* ═══════════════════════════════════════════════════════════════════
   CARD - single-line layout (zoom-aware via --zf)
   ═══════════════════════════════════════════════════════════════════ */
:root{--zf:1}

.dc-card{
  display:flex;
  align-items:center;
  gap:calc(7px * var(--zf));
  padding:calc(1.5px * var(--zf)) calc(5px * var(--zf)) calc(1.5px * var(--zf)) calc(3px * var(--zf));
  background:var(--s2);
  border:1px solid var(--b2);
  border-left:3px solid var(--b2);
  border-radius:var(--radius-md);
  cursor:grab;
  user-select:none;
  transition:border-color .08s,background .08s;
  position:relative;
  min-height:calc(22px * var(--zf));
}
.dc-card:hover{border-color:var(--b3);background:var(--s3)}
.dc-card:active{cursor:grabbing}
.dc-dragging{opacity:.3}
.dc-card.dc-rookie{background:rgba(40,184,112,.08);border-color:rgba(40,184,112,.25);border-left-color:#28b870}
.dc-card.dc-rookie:hover{background:rgba(40,184,112,.14)}
/* One-click bench/restore toggle — a flex child on the right of each card (scales
   with the board zoom factor; cursor:pointer so it reads as a button, not a drag). */
.dc-bench-btn{
  flex:0 0 auto; margin-left:auto;
  width:calc(15px * var(--zf)); height:calc(15px * var(--zf)); padding:0;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:calc(10px * var(--zf)); line-height:1;
  border:1px solid var(--b3); border-radius:3px;
  background:rgba(255,255,255,.05); color:var(--t3);
  cursor:pointer; transition:background .1s,color .1s,border-color .1s;
}
.dc-bench-btn:hover{background:rgba(255,255,255,.16);color:var(--t1);border-color:var(--b2)}
/* Restore button on Roster cards: green-tinted (those cards are off-board). */
.dc-bench-restore{background:rgba(46,120,72,.22);color:#9fe7b4;border-color:rgba(46,120,72,.5)}
.dc-bench-restore:hover{background:rgba(46,120,72,.42);color:#fff}

/* Jersey number — inline at the start of the name row */
.dc-num{
  font-family:var(--disp);
  font-size:calc(7px * var(--zf));
  font-weight:500;
  line-height:1;
  color:var(--t1);
  font-variant-numeric:tabular-nums;
  letter-spacing:-.01em;
  text-align:right;
  flex-shrink:0;
  min-width:calc(13px * var(--zf));
}
/* Position — inline at the start of the bio row */
.dc-pos{
  font-family:var(--disp);
  font-size:calc(5px * var(--zf));
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--t2);
  line-height:1;
  flex-shrink:0;
  min-width:calc(13px * var(--zf));
  text-align:right;
}
.dc-bio-row{
  display:flex;
  align-items:baseline;
  gap:calc(6px * var(--zf));
  min-width:0;
}

/* RIGHT BLOCK: name row + bio line stacked */
.dc-info{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:calc(1px * var(--zf));
  overflow:hidden;
}
.dc-name-row{
  display:flex;
  align-items:center;
  gap:calc(6px * var(--zf));
  min-width:0;
}
.dc-name-wrap{
  flex:1;
  min-width:0;
  overflow:hidden;
}
.dc-name{
  font-family:var(--disp);
  font-weight:500;
  color:var(--t1);
  font-size:calc(7px * var(--zf));
  letter-spacing:-.005em;
  text-transform:uppercase;
  line-height:1.05;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* BIO LINE: D1-09 (gold) · TR DET '21 (blue) */
.dc-bio{
  font-family:var(--mono);
  font-size:calc(5px * var(--zf));
  font-weight:500;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  letter-spacing:.01em;
  font-variant-numeric:tabular-nums;
  flex:0 1 auto;
  min-width:0;
}
.dc-draft{color:var(--draft-500)}
.dc-acq{color:var(--acq-500)}
.dc-bio-sep{color:var(--t3);margin:0 calc(6px * var(--zf));font-weight:500}

/* Badge sits at the right end of its text row (name row or bio row), so it
   stays vertically aligned with that line of text. */
.dc-bdg-slot{
  margin-left:auto;
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  padding-left:calc(5px * var(--zf));
}
/* Second-line group: rookie + KR/PR badges laid out horizontally. */
.dc-bdg-slot-group{
  gap:calc(3px * var(--zf));
}
.dc-bdg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box;
  height:calc(10px * var(--zf));
  font-family:var(--disp);
  font-size:calc(4.5px * var(--zf));
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:0 calc(2.5px * var(--zf));
  border:1px solid transparent;
  border-radius:2px;
  white-space:nowrap;
  text-align:center;
  line-height:1;
  color:#fff;
  min-width:calc(9px * var(--zf));
}
/* 3-bucket scheme: red = ALL injury/reserve, grey = practice squad,
   green = active (active cards carry no badge; absence = active).
   Badge TEXT (O/D/Q/IR/PUP/NFI/RES) still distinguishes designation. */
.dc-bdg-q,.dc-bdg-d,.dc-bdg-o,
.dc-bdg-ir,.dc-bdg-pup,.dc-bdg-nfi,.dc-bdg-res{background:var(--status-out);color:#fff}
.dc-bdg-ps{background:var(--status-ps);color:#fff}
/* Rookie badge: bare green border, no fill (mockup parity) */
.dc-bdg-rk{background:transparent;color:var(--grn-400);border:1px solid rgba(88,192,140,.5)}

/* Injury status label under the bio line (mockup parity) */
.dc-status-label{
  font-family:var(--body);
  font-size:calc(11px * var(--zf));
  font-weight:600;
  line-height:1.25;
  color:var(--status-out);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  margin-top:calc(2px * var(--zf));
}

/* Status border tints (overrides team color via !important) */
.dc-sts-out,.dc-sts-doubt,.dc-sts-quest,
.dc-sts-ir,.dc-sts-pup,.dc-sts-nfi,.dc-sts-res{border-left-color:var(--status-out)!important}
.dc-sts-ps{border-left-color:var(--status-ps)!important}

/* Density: min/medium/full no longer change card layout (cards are uniform single-line) */

/* Other column inside section (split drawer behavior) */
.dc-other-col{
  flex:0 0 calc(160px * var(--zf));
  min-width:0;
  background:var(--s2);
  border:1px dashed var(--b2);
  border-radius:5px;
  display:none;
  flex-direction:column;
  margin-left:5px;
}
body[data-other-open="1"] .dc-other-col{display:flex}
.dc-other-col.dc-dragover{border-color:var(--gold);background:rgba(240,192,64,.06)}
.dc-other-col > .dc-col-hdr{
  background:var(--s3);
  border-bottom:1px solid var(--b2);
  border-radius:5px 5px 0 0;
}
.dc-other-col > .dc-card{margin:3px}
.dc-other-col > .dc-col-empty{padding:14px 8px;font-style:italic;color:var(--t4);font-size:10px;text-align:center}

.ndot{position:absolute;top:4px;right:4px;display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold)}
.ovdot{position:absolute;top:4px;right:13px;color:var(--gold);font-size:9px}

.dc-drop-indicator{height:3px;background:var(--gold);border-radius:2px;margin:2px 4px;pointer-events:none;animation:dropPulse .8s ease-in-out infinite alternate}
@keyframes dropPulse{from{opacity:.6}to{opacity:1}}

.dc-empty{text-align:center;color:var(--text-muted);font-family:var(--font-mono);font-size:12px;padding:40px 16px}
.tgrid:has(.dc-toolbar){display:block}
/* Single-panel data-center board: don't trap it in the old two-team 1fr/1fr grid
   (which leaves an empty second column on ultrawide). Fill, then cap+center the
   whole unit (tabs + header + columns) so everything stays aligned on ultrawide. */
.tgrid:has(.dc-board){display:block;max-width:2800px;margin-inline:auto}

@media print{
  .dc-toolbar{display:none!important}
}

/* ── Board auto-save: print-bar state pill + status toasts ── */
.hb-save-state{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-left:6px;white-space:nowrap}
.hb-save-state.on{color:var(--grn-500)}
.hb-save-now-btn,.hb-save-folder-btn{white-space:nowrap}
#hbToastHost{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:min(380px,calc(100vw - 36px))}
.hb-toast{display:flex;align-items:center;gap:10px;background:var(--surface-card,#1c1a17);color:var(--text-body,#e8e3da);border:1px solid var(--border-strong,#3a352e);border-left-width:3px;border-radius:var(--radius-md,10px);padding:11px 12px 11px 14px;font-family:var(--font-sans);font-size:.82rem;line-height:1.35;box-shadow:0 10px 30px rgba(0,0,0,.4);transition:opacity .2s}
.hb-toast-ok{border-left-color:var(--grn-500,#1f9a60)}
.hb-toast-warn{border-left-color:var(--status-out,#c8442b)}
.hb-toast-prompt{border-left-color:var(--heat-500,#b68a4e)}
.hb-toast-btn{flex:0 0 auto;border:none;background:var(--accent,#b68a4e);color:var(--text-on-heat,#1a140a);font-family:var(--font-display);font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:.8rem;padding:6px 11px;border-radius:var(--radius-md);cursor:pointer}
.hb-toast-btn:hover{filter:brightness(1.08)}
.hb-toast-btn+.hb-toast-btn{background:transparent;color:var(--text-muted);font-weight:600}
.hb-toast-x{flex:0 0 auto;border:none;background:transparent;color:var(--text-faint,#888);font-size:18px;line-height:1;cursor:pointer;padding:0 2px;margin-left:2px}
.hb-toast-x:hover{color:var(--text-strong)}
@media print{#hbToastHost{display:none!important}}
