@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;600;700;800&family=Lora:ital,wght@0,600;1,400&display=swap');

:root{
  --bg:#ffffff;
  --card:#ffffff;
  --paper:#ffffff;
  --ink:#02503b;
  --ink-mid:#02503b;
  --ink-muted:#6b7787;
  --rule:rgba(2,80,59,.14);
  --rule-md:rgba(2,80,59,.26);
  --accent:#c95917;
  --accent-2:#d4e84a;
  --surface-strong:#02503b;
  --surface-strong-hover:#024733;
  --surface-soft:#0b2718;
  --surface-soft-2:#174a2c;
  --theme-band:#c95917;
  --theme-band-2:#d4e84a;
  --theme-muted:#6b7787;
  --win:#1a7a42;
  --loss:#c1442e;
  --golden:#c8920c;
  --slate:#3a5270;
  --court:#2e6b3e;
  --mono:"Courier New",Courier,monospace;
  --serif:"Lora",Georgia,"Times New Roman",serif;
  --sans:"Inter","Helvetica Neue",Helvetica,Arial,sans-serif;
  --display:"Bebas Neue",var(--sans);
  --gap:clamp(1rem,3vw,2rem);
  --page-width:1100px;
  --page-pad:1.75rem;
  --radius-sm:6px;
  --radius-md:14px;
  --shadow-sm:0 3px 14px rgba(22,28,36,.06);
  --shadow-md:0 4px 20px rgba(22,28,36,.07);
  --shadow-lg:0 10px 30px rgba(22,28,36,.08);
}

/* theme tokens only */
.summer-theme{
  --bg:#eef6ff;
  --ink:#091628;
  --ink-mid:#1a3a5c;
  --ink-muted:#4a6e8a;
  --rule:rgba(17,85,160,.11);
  --rule-md:rgba(17,85,160,.22);
  --accent:#e07518;
  --accent-2:#f5c518;
  --surface-strong:#1155a0;
  --surface-strong-hover:#4a6e92;
  --surface-soft:#5b82a6;
  --surface-soft-2:#2e78c4;
  --theme-band:#e07518;
  --theme-band-2:#2e78c4;
  --theme-muted:#4a6e8a;
  --win:#2d8a56;
}

.spring-theme{
  --bg:#f5eef5;
  --ink:#1a0a28;
  --ink-mid:#3b1a4a;
  --ink-muted:#7a6a8a;
  --rule:rgba(91,130,166,.12);
  --rule-md:rgba(91,130,166,.24);
  --accent:#d4679a;
  --accent-2:#c96aa5;
  --surface-strong:#5b82a6;
  --surface-strong-hover:#4a6e92;
  --surface-soft:#5b82a6;
  --surface-soft-2:#c96aa5;
  --theme-band:#d4679a;
  --theme-band-2:#5b82a6;
  --theme-muted:#7a6a8a;
  --win:#2d8a56;
}

.autumn-theme{
  --bg:#fbf6ef;
  --ink:#2a1a08;
  --ink-mid:#3b2208;
  --ink-muted:#7a6252;
  --rule:rgba(92,54,16,.13);
  --rule-md:rgba(92,54,16,.24);
  --accent:#b84520;
  --accent-2:#e8a020;
  --surface-strong:#3b2208;
  --surface-strong-hover:#4a2c0e;
  --surface-soft:#3b2208;
  --surface-soft-2:#d4751a;
  --theme-band:#b84520;
  --theme-band-2:#d4751a;
  --theme-muted:#8c7b6a;
}

*,*::before,*::after{box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.5;overflow-x:hidden;min-height:100dvh}
a{color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}

body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}

h1,h2,h3,h4{margin:0;font-family:var(--display);text-transform:uppercase;line-height:1.05;letter-spacing:.02em}
h1{font-size:clamp(2.8rem,8vw,6rem);font-weight:900}
h2{font-size:clamp(1.6rem,4vw,2.6rem);font-weight:900}
h3{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:700}
h4{font-size:.85rem;font-weight:700;letter-spacing:.08em}
p{margin:0;color:var(--ink-mid);font-size:clamp(.875rem,1.5vw,1rem);max-width:65ch}
em{font-style:italic;color:var(--accent)}

.page,
.masthead-inner,
.ticker-inner,
.breadcrumb-inner{
  width:min(var(--page-width),100% - 2*var(--page-pad));
  margin-inline:auto;
}

.page{padding:1.5rem 0 4rem}

/* masthead */
.masthead{background:var(--surface-strong);position:relative;overflow:hidden}
.masthead::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(-55deg,transparent,transparent 28px,rgba(255,255,255,.016) 28px,rgba(255,255,255,.016) 29px)}
.masthead-inner{padding:0 0 1.1rem;position:relative;z-index:1}
.masthead-body{display:grid;grid-template-columns:1fr auto;align-items:end;gap:2rem;padding:1.4rem 0 0}
.masthead h1{color:#fff}
.masthead h1 span{color:var(--accent);display:block}
.masthead-right{display:flex;flex-direction:column;align-items:flex-end;gap:.6rem;padding-bottom:.35rem}
.masthead-tagline{font-family:var(--serif);font-style:italic;font-size:1rem;color:rgba(255,255,255,.45);line-height:1.5;text-align:right}
.masthead-pills{display:flex;gap:.5rem;flex-wrap:wrap}
.masthead-pill{display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.62);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.26rem .8rem;border-radius:999px}
.masthead-pill.live{background:color-mix(in srgb,var(--accent-2) 14%, transparent);border-color:color-mix(in srgb,var(--accent-2) 32%, transparent);color:var(--accent-2)}
.masthead-rule{height:3px;background:var(--accent)}

/* top navigation / breadcrumb */
nav{border-bottom:1px solid var(--rule-md);background:var(--surface-strong);position:sticky;top:0;z-index:100}
nav>div{width:min(var(--page-width),100% - 2*var(--page-pad));margin-inline:auto;display:flex;align-items:center;gap:var(--gap);padding-block:.75rem}
nav strong{font-family:var(--display);font-size:1.15rem;letter-spacing:.04em;text-transform:uppercase;color:var(--paper);margin-right:auto;flex-shrink:0}
nav a{color:var(--paper);text-decoration:none;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;opacity:.65;transition:opacity .15s,color .15s;white-space:nowrap}
nav a:hover,nav a[aria-current]{opacity:1}
nav a[aria-current]{color:var(--accent)}
nav ul{display:flex;gap:clamp(.75rem,2vw,1.5rem);list-style:none;flex-wrap:wrap;padding:0;margin:0}
nav input[type=checkbox]{display:none}
nav label[for=nav-toggle]{display:none;cursor:pointer;width:1.5rem;height:1.1rem;flex-direction:column;justify-content:space-between;margin-left:auto}
nav label[for=nav-toggle] span{display:block;height:2px;background:var(--paper);transition:transform .2s,opacity .2s}

.breadcrumb{background:#fff;border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:120;backdrop-filter:saturate(160%) blur(6px)}
.breadcrumb-inner{padding:1rem 0;display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}
.breadcrumb a{color:var(--accent);text-decoration:none;font-family:var(--display);font-size:1.1rem;letter-spacing:.05em;text-transform:uppercase;font-weight:700;transition:color .15s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb a:visited{color:var(--accent)}
.breadcrumb-sep{color:var(--accent);margin:0 .15rem}

/* ticker */
.ticker-bar{background:var(--accent);padding:.55rem 0;overflow:hidden}
.ticker-inner{display:flex;align-items:center;gap:1.2rem}
.ticker-items{display:flex;gap:3rem;white-space:nowrap;animation:tick 28s linear infinite}
.ticker-item{font-family:var(--sans);font-size:.84rem;font-weight:700;color:#fff;white-space:nowrap;letter-spacing:.03em;text-transform:uppercase}
.ticker-item .hi{color:var(--accent-2)}
.ticker-sep{color:rgba(255,255,255,.3);font-weight:400}
.ticker-nav{width:100%;display:flex;align-items:center;justify-content:center;gap:0;white-space:normal;animation:none}
.ticker-nav .ticker-link{flex:1 1 0;text-align:center;font-family:var(--display);font-size:calc(.95rem + 2px);font-weight:800;color:#fff;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;padding:.1rem 0}
.ticker-nav .ticker-link:hover{color:var(--accent-2)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* section labels */
.slabel{display:flex;align-items:center;gap:.7rem;margin:2.5rem 0 .8rem}
.slabel-num,.slabel-txt{font-family:var(--display);line-height:1}
.slabel-num{font-size:1.5rem;color:var(--accent)}
.slabel-txt{font-size:1.5rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--theme-muted);white-space:nowrap}
.slabel::after{content:"";flex:1;height:1px;background:var(--rule)}

/* performance overview */
.stats-note{font-size:.92rem;color:var(--ink-muted);margin:0 0 1.5rem;font-style:italic;line-height:1.7;max-width:80ch}
.season-overview-wrap{display:grid;gap:1rem}
.player-overview-block{background:var(--card);border:1.5px solid var(--rule);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}
.player-overview-header{background:var(--surface-strong);color:#fff;padding:1.15rem 1.5rem;display:flex;align-items:center;gap:1rem}
.player-overview-name{font-family:var(--display);letter-spacing:.04em;text-transform:uppercase;font-size:1.9rem;color:#fff}
.player-overview-summary{display:flex;gap:.6rem;flex-wrap:wrap;margin-left:auto}
.overview-pill{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.86);background:rgba(255,255,255,.08)}
.season-accordions{border-top:none}
.season-accordion{border-top:1px solid var(--rule)}
.season-accordion:first-child{border-top:none}
.season-accordion-header{display:flex;align-items:center;gap:.9rem;padding:1rem 1.4rem;cursor:pointer;background:color-mix(in srgb,var(--surface-strong) 4%, white);width:100%;box-sizing:border-box}
.season-accordion.open .season-accordion-header{background:color-mix(in srgb,var(--accent) 8%, white)}
.season-accordion-title,.season-accordion-meta{font-family:var(--display);letter-spacing:.04em;text-transform:uppercase}
.season-accordion-title{font-size:.95rem;color:var(--surface-strong)}
.season-accordion-meta{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;padding:.28rem .7rem;border-radius:999px;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--rule);color:var(--surface-strong);background:#fff}
.season-accordion-chevron{font-size:1rem;color:var(--surface-strong);transition:transform .25s ease}
.season-accordion.open .season-accordion-chevron{transform:rotate(180deg)}
.season-accordion-body{max-height:0;overflow:hidden;transition:max-height .4s ease}
.season-accordion.open .season-accordion-body{max-height:5000px}
.season-overview-panel{display:none;padding:1.25rem}
.season-overview-panel.active{display:block}
.season-overview-panel.pad-lg{padding:1.4rem 1.8rem 1.8rem}
.overview-metrics-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.8rem;margin-bottom:1.2rem}
.overview-metric-card{background:color-mix(in srgb,var(--surface-strong) 4%, white);border:1px solid var(--rule);border-radius:12px;padding:.9rem 1rem;text-align:center}
.omc-value,.cat-rating-score,.cat-rating-grade{font-family:var(--display);line-height:1}
.omc-value{font-size:2rem;color:var(--surface-strong)}
.omc-value.good{color:var(--win)}
.omc-value.mid{color:var(--accent)}
.omc-value.low{color:var(--loss)}
.omc-label{display:block;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin-top:.25rem}
.scroll-hint{display:none;font-size:.72rem;color:var(--ink-muted);text-align:center;margin-bottom:.5rem;font-style:italic}
.overview-stat-table-wrap{overflow:auto}
.overview-stat-table{width:100%;border-collapse:collapse;min-width:540px;font-size:.83rem}
.overview-stat-table th{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);padding:.55rem .7rem;border-bottom:2px solid var(--rule);text-align:left}
.overview-stat-table th:not(:first-child),.overview-stat-table td:not(:first-child){text-align:right}
.overview-stat-table td{padding:.5rem .7rem;border-bottom:1px solid var(--rule)}
.ost-category-row td{padding-top:1rem;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}
.overall-ratings-section{padding:1.25rem;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);background:color-mix(in srgb,var(--surface-strong) 3%, white)}
.overall-ratings-label{font-family:var(--display);letter-spacing:.04em;text-transform:uppercase;font-size:1.1rem;color:var(--surface-strong);display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}
.overall-ratings-label::after{content:"";flex:1;height:1px;background:var(--rule)}
.category-ratings-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}
.cat-rating-card{background:var(--card);border:1.5px solid var(--rule);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}
.cat-rating-header{padding:.7rem .95rem;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff;display:flex;align-items:center}
.cat-rating-body{padding:.85rem .95rem;display:grid;gap:.6rem}
.cat-rating-score-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.cat-rating-score-block{display:flex;flex-direction:column}
.cat-rating-score{font-size:2rem;color:var(--surface-strong)}
.cat-rating-score.good{color:var(--win)}
.cat-rating-score.mid{color:var(--accent)}
.cat-rating-score.low{color:var(--loss)}
.cat-rating-grade-block{width:46px;height:46px;border-radius:10px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 10%, white)}
.cat-rating-grade-block.good{background:color-mix(in srgb,var(--win) 12%, white)}
.cat-rating-grade-block.mid{background:color-mix(in srgb,var(--accent) 12%, white)}
.cat-rating-grade-block.low{background:color-mix(in srgb,var(--loss) 12%, white)}
.cat-rating-grade{font-size:1.8rem;color:var(--accent)}
.cat-rating-grade.good{color:var(--win)}
.cat-rating-grade.mid{color:var(--accent)}
.cat-rating-grade.low{color:var(--loss)}
.cat-rating-sublabel{margin-top:.35rem;font-size:.7rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.07em}
.cat-rating-gauge{height:6px;border-radius:999px;background:color-mix(in srgb,var(--surface-strong) 8%, white);overflow:hidden}
.cat-rating-gauge-fill{height:100%;border-radius:999px;background:var(--accent);width:0}
.cat-rating-gauge-fill.good{background:var(--win)}
.cat-rating-gauge-fill.mid{background:var(--accent)}
.cat-rating-gauge-fill.low{background:var(--loss)}
.cat-rating-components{display:grid;gap:.35rem}
.cat-comp-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.78rem;color:var(--ink)}
.cat-comp-name{color:var(--ink-muted)}
.cat-comp-val{font-weight:700}
.cat-comp-val.good{color:var(--win)}
.cat-comp-val.low{color:var(--loss)}

/* performance benchmarks */
.ideal-panel,.match-accordion{background:var(--card);border:1.5px solid var(--rule);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}
.ideal-panel{margin-bottom:2rem}
.ideal-panel-header{background:var(--surface-strong);color:#fff;padding:1.15rem 1.5rem;display:flex;align-items:center;gap:1rem}
.ideal-panel-title{font-family:var(--display);letter-spacing:.04em;text-transform:uppercase;font-size:1.9rem;color:#fff}
.ideal-panel-subtitle{font-family:var(--serif);font-size:.9rem;color:rgba(255,255,255,.72);font-style:italic}
.ideal-categories{padding:1.25rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1rem}
.ideal-category{background:color-mix(in srgb,var(--accent-2) 12%, white);border:1px solid color-mix(in srgb,var(--accent-2) 30%, transparent);border-radius:12px;overflow:hidden}
.ideal-category-title{font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--surface-strong);padding:.7rem .9rem;background:color-mix(in srgb,var(--accent-2) 18%, white);border-bottom:1px solid color-mix(in srgb,var(--accent-2) 24%, transparent)}
.ideal-row,.stat-item{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem .9rem;border-bottom:1px solid var(--rule);font-size:.84rem}
.ideal-row:last-child,.stat-item:last-child{border-bottom:none}
.ideal-stat-val,.match-result-badge,.match-perf-label{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.ideal-stat-val{background:rgba(255,255,255,.75);color:var(--surface-strong);min-width:3.2rem}
.matches-list{display:grid;gap:1rem}
.season-tabs-bar{display:flex;gap:0;border-bottom:1px solid var(--rule);background:color-mix(in srgb,var(--surface-strong) 4%, white);overflow:auto}
.season-tab-btn,.player-tab{padding:.75rem 1rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--ink-muted);font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.season-tab-btn.active,.player-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:#fff}
.player-stats-panel.active{display:block}
.season-accordion-chevron,.match-chevron{font-size:1rem;color:var(--ink-muted);transition:transform .25s ease}
.match-accordion.open .match-chevron{transform:rotate(180deg)}
.match-body{max-height:0;overflow:hidden;transition:max-height .4s ease}
.match-accordion.open .match-body{max-height:12000px}
.match-accordion .match-header{background:color-mix(in srgb,var(--surface-strong) 6%, white);color:var(--ink)}
.match-accordion .match-title{color:var(--ink)}
.match-accordion .match-subtitle{color:var(--ink-muted)}
.match-accordion .match-score{color:var(--surface-strong)}
.match-accordion .match-chevron{color:var(--surface-strong)}
.player-stats-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin:1rem 0}
.player-stats-panel{display:none}
.stats-cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem 1.5rem}
.stat-group{margin-bottom:1rem}
.stat-group-title{font-size:.72rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--accent);margin-bottom:.45rem;padding-bottom:.25rem;border-bottom:1px solid var(--rule)}
.stat-item{border:1px solid var(--rule);border-radius:8px;margin-bottom:.3rem;background:#fff}
.stat-item.met{background:color-mix(in srgb,var(--win) 8%, white);border-color:color-mix(in srgb,var(--win) 25%, transparent)}
.stat-item.missed{background:color-mix(in srgb,var(--loss) 7%, white);border-color:color-mix(in srgb,var(--loss) 24%, transparent)}
.stat-item.neutral{background:color-mix(in srgb,var(--surface-strong) 4%, white)}
.stat-item-name{display:flex;align-items:center;gap:.5rem;color:var(--ink);font-weight:500}
.stat-item-right{display:flex;align-items:center;gap:.5rem}
.stat-item-actual{font-weight:800}
.stat-item.met .stat-item-actual{color:var(--win)}
.stat-item.missed .stat-item-actual{color:var(--loss)}
.stat-item-ideal{font-size:.72rem;color:var(--ink-muted)}
.match-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;cursor:pointer}
.match-result-badge.win{background:color-mix(in srgb,var(--win) 10%, white);color:var(--win)}
.match-result-badge.loss{background:color-mix(in srgb,var(--loss) 10%, white);color:var(--loss)}
.match-meta{flex:1;min-width:0}
.match-title{font-weight:800;font-size:1rem;color:var(--ink);line-height:1.3}
.match-subtitle{font-size:.82rem;color:var(--ink-muted);margin-top:.15rem}
.match-score{font-family:var(--display);font-size:1.3rem;color:var(--surface-strong)}
.opponent-note{font-size:.85rem;color:var(--ink-muted);font-style:italic;margin-bottom:1.2rem}
.ideals-tally{display:flex;flex-direction:column;align-items:center;gap:.2rem}
.ideals-tally-ring{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:800;border:2px solid}
.ideals-tally-ring.good{border-color:var(--win);color:var(--win);background:color-mix(in srgb,var(--win) 8%, white)}
.ideals-tally-ring.mid{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%, white)}
.ideals-tally-ring.low{border-color:var(--loss);color:var(--loss);background:color-mix(in srgb,var(--loss) 8%, white)}
.ideals-tally-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted)}
.match-body-inner{padding:0 1.2rem 1.3rem;border-top:1px solid var(--rule)}
.match-perf-label.excellent,.match-perf-label.good{background:color-mix(in srgb,var(--win) 10%, white);color:var(--win);border:1px solid color-mix(in srgb,var(--win) 25%, transparent)}
.match-perf-label.okay{background:color-mix(in srgb,var(--accent) 10%, white);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 25%, transparent)}
.match-perf-label.poor{background:color-mix(in srgb,var(--loss) 10%, white);color:var(--loss);border:1px solid color-mix(in srgb,var(--loss) 25%, transparent)}
.footer-text{font-size:.82rem;color:var(--ink-muted);font-style:italic;font-family:var(--serif)}

@media(max-width:760px){
  .scroll-hint{display:block}
  .stats-cols{grid-template-columns:1fr}
  .player-overview-summary{display:none}
  .match-score{display:none}
}

/* cards */
.season-panel,
.career-panel,
.match-card,
.member-card,
.fixture,
.player-card,
.goal-card,
.standings-wrap,
.ladder-wrap,
.drop-section,
.wl-bar-wrap,
.stat-card,
.pcard,
.ccard{
  background:var(--card);
  border:1.5px solid var(--rule);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);
}

/* homepage duel cards */
.match-duet{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1.3rem;animation:rise .45s .04s ease-out both}
.mduel{border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column;position:relative;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s,filter .2s;border:1px solid transparent;cursor:pointer}
.mduel:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(17,24,39,.18),0 0 0 1px rgba(255,255,255,.08);filter:saturate(1.08)}
.mduel:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 60%, white);outline-offset:3px}
.mduel.next{background:linear-gradient(145deg,var(--surface-strong) 0%,color-mix(in srgb,var(--surface-strong) 84%, white 16%) 55%,color-mix(in srgb,var(--surface-strong) 78%, white 22%) 100%);box-shadow:0 8px 32px color-mix(in srgb,var(--surface-strong) 38%, transparent)}
.mduel.last{background:linear-gradient(145deg,var(--surface-soft) 0%,color-mix(in srgb,var(--surface-soft) 70%, var(--surface-soft-2) 30%) 55%,var(--surface-soft-2) 100%);box-shadow:0 8px 32px color-mix(in srgb,var(--surface-soft) 38%, transparent)}
.mduel-head{padding:.85rem 1.15rem .65rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.06)}
.mduel-eye{font-size:.8rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}
.mduel.next .mduel-eye,.mduel.next .mduel-cta,.mduel.next .ldr-team.us .ldr-pos,.mduel.next .ladder-pill.us .ladder-pos{color:var(--accent-2)}
.mduel.last .mduel-eye,.mduel.last .mduel-cta,.mduel.last .rr-score,.mduel.last .mdt.us .mdt-name,.mduel.last .ladder-pill.us .ladder-pos{color:#4ade80;background-color:unset}
.mduel-rnd{font-family:var(--display);font-size:1rem;color:rgba(255,255,255,.3);letter-spacing:.06em}
.mduel-body{flex:1;padding:.95rem 1.15rem .75rem;display:flex;flex-direction:column;justify-content:center;gap:.75rem}
.mduel-matchup{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.6rem}
.mdt{display:flex;flex-direction:column;gap:.15rem}
.mdt.us{text-align:left}
.mdt.them{text-align:right}
.mdt-lbl{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.mdt-name{font-family:var(--display);font-size:clamp(1.7rem,2.6vw,2.35rem);line-height:.95;color:#fff;display:flex;align-items:baseline;gap:.45rem}
.mdt.them .mdt-name{justify-content:flex-end;text-align:right;width:100%}
.mdt.them .mdt-seed{order:-1}
.mdt-seed{font-size:1.1rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;opacity:.7}
.mduel.next .mdt.us .mdt-name{color:var(--accent)}
.mdt-sub{font-size:.85rem;font-weight:600;color:rgba(255,255,255,.4);margin-top:.2rem}
.mdc{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:0 .3rem}
.mdc-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.1)}
.mdc-vs{font-family:var(--display);font-size:1.25rem;color:rgba(255,255,255,.2);line-height:1}
.mdc-score{font-family:var(--display);font-size:2.6rem;line-height:1;color:#fff;letter-spacing:.02em;display:flex;align-items:baseline;gap:.3rem}
.mdc-score-win{color:#4ade80}
.mdc-score-loss{color:#f87171}
.mdc-score-sep{color:rgba(255,255,255,.45)}
.mduel-chips{display:flex;gap:.5rem;flex-wrap:wrap}
.mduel-chip{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.5);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:.2rem .6rem;white-space:nowrap}
.mduel-chip strong{color:rgba(255,255,255,.82)}
.mduel-standings{margin-top:.2rem;display:grid;grid-template-columns:1fr auto 1fr;gap:.7rem;align-items:center;padding:.7rem .9rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:10px}
.ladder-pill{display:flex;flex-direction:column;gap:.12rem}
.ladder-pill.us{text-align:left}
.ladder-pill.them{text-align:right}
.ladder-team{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.38)}
.ladder-pos{font-family:var(--display);font-size:2.2rem;line-height:1;color:#fff}
.ladder-pill.them .ladder-pos{color:rgba(255,255,255,.6)}
.ladder-record{font-size:.8rem;font-weight:600;color:rgba(255,255,255,.45)}
.ladder-divider{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.25);text-align:center}
.mduel-ladder{border-top:1px solid rgba(255,255,255,.06);padding:.75rem 1.4rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem}
.ldr-team{display:flex;flex-direction:column;gap:.08rem}
.ldr-team.us{text-align:left}
.ldr-team.them{text-align:right}
.ldr-label{font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28)}
.ldr-pos{font-family:var(--display);font-size:1.9rem;line-height:1}
.ldr-team.them .ldr-pos{color:rgba(255,255,255,.52)}
.ldr-record{font-size:.74rem;font-weight:600;color:rgba(255,255,255,.35)}
.ldr-divider{font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.16);text-align:center;padding:0 .3rem}
.mduel-section-title{padding:.3rem 1.15rem .15rem;font-size:.64rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.38)}
.mduel-rubbers{padding:0 1.15rem .25rem;display:flex;flex-direction:column;gap:.38rem}
.mduel-doubles{padding:0 1.15rem .7rem;display:flex;flex-direction:column;gap:.38rem}
.mduel-splits{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;padding:0 1.15rem .7rem}
.mduel-splits .mduel-section-title{padding:0 0 .2rem}
.mduel-splits .mduel-rubbers,.mduel-splits .mduel-doubles{padding:0}
.mduel-splits .rr{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:.5rem}
.mduel-splits .rr-score{margin-left:0;min-width:3.1rem;text-align:right;justify-self:end}
.rr{display:grid;grid-template-columns:clamp(7.5rem,18vw,10rem) 1fr auto;align-items:center;gap:.7rem}
.rr-player{font-size:.82rem;font-weight:700;color:rgba(255,255,255,.7)}
.rr-bar-wrap{height:6px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;display:flex}
.rr-bar{height:100%}
.rr-bar.win{background:#4ade80;border-radius:999px 0 0 999px}
.rr-bar.loss{background:#f87171;border-radius:0 999px 999px 0}
.rr-score{font-family:var(--display);font-size:1rem;letter-spacing:.04em}
.mduel-foot{padding:.7rem 1.15rem;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:flex-end}
.mduel-cta,.sp-foot-link,.ccard-cta,.mc-cta{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;display:flex;align-items:center;gap:.35rem;transition:gap .18s}
.mduel-cta:hover,.sp-foot-link:hover,.ccard:hover .ccard-cta,.member-card:hover .mc-cta{gap:.55rem}
.mduel-hover{position:absolute;right:1.2rem;top:1rem;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);font-size:.68rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:.28rem .7rem;border-radius:999px;opacity:0;transform:translateY(-6px);transition:opacity .2s,transform .2s}
.mduel:hover .mduel-hover{opacity:1;transform:translateY(0)}

/* season / career panels */
.season-panel,.career-panel{overflow:hidden;margin-bottom:1.3rem;animation:rise .45s .12s ease-out both}
.sp-head,.cp-head{background:var(--surface-strong);padding:1rem 1.6rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;color:#fff}
.sp-title,.cp-title{font-family:var(--display);font-size:2rem;color:#fff;letter-spacing:.03em;line-height:1}
.sp-title span,.cp-title span{color:var(--accent-2)}
.sp-badge,.cp-badge{display:flex;align-items:baseline;gap:.5rem}
.sp-pos,.cp-pos{font-family:var(--display);font-size:3.4rem;line-height:1;color:var(--accent-2)}
.sp-pos-label,.cp-pos-label{font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.32);line-height:1.4}
.sp-body,.cp-body{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--rule)}
.sp-stat,.cp-stat{padding:1.1rem 1rem;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;border-right:1px solid var(--rule);transition:background .15s}
.sp-stat:last-child,.cp-stat:last-child{border-right:none}
.sp-stat:hover,.cp-stat:hover{background:#fafaf8}
.sp-stat-num,.cp-stat-num{font-family:var(--display);font-size:2.6rem;line-height:1}
.sp-stat-num.w,.cp-stat-num.w{color:var(--win)}
.sp-stat-num.l,.cp-stat-num.l{color:var(--accent)}
.sp-stat-num.g,.cp-stat-num.g{color:var(--theme-band-2)}
.sp-stat-num.n,.cp-stat-num.n,.cp-stat-num.sl{color:var(--ink)}
.sp-stat-lbl,.cp-stat-lbl{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}
.sp-stat-sub,.cp-stat-sub{font-size:.72rem;color:var(--ink-muted);font-style:italic}
.sp-foot{border-top:1px solid var(--rule);padding:.85rem 1.6rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sp-foot-txt{font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--ink-muted)}
.sp-foot-link{color:var(--accent)}
.sp-rounds{display:flex;gap:.3rem;flex-wrap:wrap;justify-content:center;margin-bottom:.4rem}
.sp-rnd{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:6px;font-family:var(--display);font-size:.85rem;letter-spacing:.03em;color:#fff}
.sp-rnd.win{background:var(--win)}
.sp-rnd.loss{background:#b03020}
.sp-rnd.bye{background:rgba(22,28,36,.18);color:rgba(22,28,36,.45)}

/* drop sections */
.drop-section{margin:1rem 0 1.4rem;overflow:hidden}
.drop-summary{cursor:pointer;list-style:none;padding:1rem 1.6rem;background:var(--surface-strong);color:#fff;font-weight:800;letter-spacing:.02em;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .18s}
.drop-summary:hover{background:var(--surface-strong-hover)}
.drop-summary::-webkit-details-marker{display:none}
.drop-summary::after{content:"▾";font-size:1rem;transition:transform .18s ease}
.drop-section[open] .drop-summary::after{transform:rotate(180deg)}
.drop-body{padding:1rem 1.2rem .2rem}
.drop-body .match-cards{margin-bottom:0}

/* archive cards */
.prev-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.3rem;animation:rise .45s .24s ease-out both}
.pcard{overflow:hidden;text-decoration:none;color:var(--ink);display:flex;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-sm)}
.pcard:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(22,28,36,.11)}
.pcard-swatch{width:6px;flex-shrink:0;background:var(--accent)}
.pcard.summer .pcard-swatch{background:#e07518}
.pcard.spring .pcard-swatch{background:#5b82a6}
.pcard.autumn .pcard-swatch{background:#b84520}
.pcard-inner{padding:1.2rem 1.4rem;flex:1;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.pcard-left{display:flex;flex-direction:column;gap:.2rem}
.pcard-tag{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}
.pcard-title{font-family:var(--display);font-size:2rem;line-height:1}
.pcard.summer .pcard-title{color:#e07518}
.pcard.spring .pcard-title{color:#5b82a6}
.pcard.autumn .pcard-title{color:#b84520}
.pcard-div{font-size:.8rem;font-weight:600;color:var(--ink-muted)}
.pcard-right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}
.pcard-record{font-family:var(--display);font-size:1.9rem;line-height:1;color:var(--ink)}
.pcard-rlbl{font-size:.7rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-muted)}
.pcard-arrow{font-size:1rem;color:var(--rule-md);transition:transform .18s;margin-top:.15rem}
.pcard:hover .pcard-arrow{transform:translateX(4px)}

/* coaching */
.coaching-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.3rem;animation:rise .45s .30s ease-out both}
.coaching-grid.full{grid-template-columns:1fr}
.ccard{padding:1.2rem 1.25rem;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:.4rem;box-shadow:0 3px 12px rgba(22,28,36,.05);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.ccard:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(22,28,36,.1)}
.ccard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--slate)}
.ccard.plans::before{background:var(--court)}
.ccard-icon{font-size:1.4rem;line-height:1}
.ccard-title{font-family:var(--display);font-size:1.35rem;line-height:1;letter-spacing:.02em;color:var(--slate)}
.ccard.plans .ccard-title,.ccard.plans .ccard-cta{color:var(--court)}
.ccard-desc{font-size:.82rem;font-weight:500;color:var(--ink-muted);line-height:1.45;flex:1}
.ccard-cta{margin-top:.25rem;color:var(--slate)}

/* member cards */
.member-card{overflow:hidden;text-decoration:none;color:var(--ink);display:grid;grid-template-columns:1fr 1fr;min-height:175px;margin-bottom:1.3rem;transition:transform .2s,box-shadow .2s;animation:rise .45s .18s ease-out both}
.member-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(22,28,36,.12)}
.mc-left{border-right:1.5px solid var(--rule);padding:1.6rem 2rem;display:flex;flex-direction:column;justify-content:space-between;gap:.8rem;position:relative;overflow:hidden}
.mc-left::before{content:"";position:absolute;right:-30px;bottom:-30px;width:130px;height:130px;border-radius:50%;background:rgba(200,146,12,.06);pointer-events:none}
.mc-left-top{display:flex;flex-direction:column;gap:.3rem}
.mc-tag,.mc-cta{color:var(--golden)}
.mc-tag{font-size:.7rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase}
.mc-title{font-family:var(--display);font-size:3rem;line-height:.88;color:var(--golden)}
.mc-sub{font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--ink-muted);margin-top:.2rem}
.mc-right{padding:1.6rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;align-content:center}
.mc-stat{display:flex;flex-direction:column;gap:.1rem}
.mc-stat-num{font-family:var(--display);font-size:2.2rem;line-height:1;color:var(--ink)}
.mc-stat-lbl{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}

/* match cards */
.match-cards{display:grid;gap:1rem}
.match-card{overflow:hidden}
.match-header{background:var(--surface-strong);color:#fff;cursor:pointer;transition:background .18s;padding:1rem 1.35rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.match-header:hover{background:var(--surface-strong-hover)}
.match-card.card-win .match-header{background:var(--win)}
.match-card.card-win .match-header:hover{background:#26774a}
.match-card.card-loss .match-header{background:var(--loss)}
.match-card.card-loss .match-header:hover{background:#a8371f}
.match-card.card-bye .match-header{background:#4a5568}
.match-card.card-bye .match-header:hover{background:#3d4657}
.match-header-left,.match-header-right{display:flex;align-items:center;gap:1rem}
.match-header-left{flex:1;justify-content:space-between;min-width:0}
.match-header-right{flex-shrink:0}
.match-round{font-family:var(--display);font-size:2rem;color:#fff}
.match-meta{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.68)}
.match-header-result{font-family:var(--display);font-size:1.6rem;line-height:1;color:#fff}
.match-header-result.win{color:#6ee7a0}
.match-header-result.loss{color:#fca5a5}
.match-header-result-lbl{display:block;font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.match-toggle{font-size:1.2rem;line-height:1;transition:transform .18s ease}
.match-card-body{display:none}
.match-card.is-open .match-card-body{display:block}
.match-card.is-open .match-toggle{transform:rotate(180deg)}
.recent-badge{background:var(--accent-2);color:var(--surface-strong);font-weight:800;text-transform:uppercase}
.match-scoreline{padding:2rem 2.5rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);border-bottom:1.5px solid var(--rule)}
.team-block{display:flex;align-items:center;gap:1rem}
.team-block.us{justify-content:flex-start}
.team-block.them{justify-content:flex-end}
.team-info{display:flex;flex-direction:column;gap:.2rem}
.team-block.them .team-info{text-align:right}
.team-abbr{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}
.team-name{font-family:var(--display);font-size:2.6rem;line-height:1;color:var(--ink)}
.team-name.us{color:var(--accent)}
.team-games{font-size:.8rem;font-weight:600;color:var(--ink-muted)}
.team-score{font-family:var(--display);font-size:5rem;line-height:1;margin:.3rem 0}
.team-score.win{color:var(--win)}
.team-score.loss{color:var(--loss)}
.vs-divider{font-family:var(--display);font-size:1.2rem;letter-spacing:.1em;color:var(--rule-md)}
.rubbers{padding:0 2rem 1.5rem}
.rubbers-header,.rubber-row{display:grid;grid-template-columns:70px 1fr 140px 1fr;gap:.75rem}
.rubbers-header{padding:1rem 0 .75rem;border-bottom:2px solid var(--rule);font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--ink-muted)}
.rubbers-header span:last-child,.rubber-row>div:nth-child(4),.rubber-row>div:nth-child(4) div{text-align:right}
.rubber-row{padding:1.1rem 0;border-bottom:1px solid var(--rule);align-items:center}
.rubber-row:last-child{border-bottom:none}
.rubber-id{font-family:var(--display);font-size:1.6rem;color:var(--accent);line-height:1}
.rubber-player{font-weight:800;color:var(--ink)}
.rubber-player-sub{font-size:.78rem;color:var(--ink-muted)}
.rubber-score{font-family:var(--display);font-size:2.2rem;text-align:center;line-height:1}
.rubber-score.w{color:var(--win)}
.rubber-score.l{color:var(--loss)}

/* fixtures */
.schedule-list{display:grid;gap:1rem}
.fixture{display:grid;grid-template-columns:5rem 1fr auto;align-items:center;gap:1rem;padding:1rem 1.4rem;transition:transform .2s ease,box-shadow .2s ease;animation:slideUpFade .45s ease-out both;box-shadow:var(--shadow-sm)}
.fixture:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(22,28,36,.1)}
.fixture.home{border-top:4px solid var(--accent)}
.fixture.away{border-top:4px solid var(--theme-band-2)}
.fixture-date{display:flex;flex-direction:column;align-items:flex-start}
.date-weekday{color:var(--theme-band-2);font-size:.7rem;font-weight:700;text-transform:uppercase}
.date-day{font-family:var(--display);font-size:2.2rem;line-height:1;color:var(--ink)}
.date-month{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--ink-muted)}
.fixture-info{display:flex;flex-direction:column;gap:.25rem}
.fixture-matchup{font-family:var(--serif);font-size:1.1rem;font-weight:600;color:var(--ink)}
.fixture-matchup .us{color:var(--accent);font-style:italic}
.fixture-venue{font-size:.82rem;color:var(--ink-muted)}
.fixture-badge{display:inline-flex;align-items:center;width:max-content;padding:.22rem .55rem;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.badge-home{background:color-mix(in srgb,var(--accent) 12%, transparent);color:var(--accent)}
.badge-away{background:color-mix(in srgb,var(--theme-band-2) 12%, transparent);color:var(--theme-band-2)}
.fixture-right{display:flex;align-items:center;justify-content:flex-end}
.fixture-result-score{font-family:var(--display);font-size:1.6rem;color:var(--ink)}

/* standings */
.standings-wrap,.ladder-wrap{padding:.2rem .2rem .7rem;overflow:auto;box-shadow:var(--shadow-lg)}
.standings-table,.ladder-table{width:100%;border-collapse:collapse;min-width:960px}
.standings-table thead tr,.ladder-table thead tr{background:color-mix(in srgb,var(--surface-strong) 6%, white)}
.standings-table th,.ladder-table th{font-family:var(--display);font-size:1rem;color:var(--surface-strong);border-bottom:2px solid var(--accent-2);padding:.75rem .55rem;text-align:center;white-space:nowrap}
.standings-table td,.ladder-table td{padding:.7rem .55rem;border-bottom:1px solid var(--rule);text-align:center;font-size:.84rem;color:var(--ink);white-space:nowrap}
.standings-table td:nth-child(2),.ladder-table td:first-child{font-family:var(--serif);font-weight:700;text-align:left}
.standings-our-row td,.ladder-table tr.our-row td{background:color-mix(in srgb,var(--accent) 6%, white)}
.standings-our-row td:nth-child(2){color:var(--accent)}
.td-rank,.td-pts{font-family:var(--display)}
.td-pts{font-size:1.3rem;color:var(--accent)}
.standings-note{padding:.8rem .4rem 0;font-size:.76rem;color:var(--ink-muted)}

/* player cards */
.player-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}
.player-card{overflow:hidden;box-shadow:0 8px 24px rgba(22,28,36,.07);transition:transform .25s,box-shadow .25s}
.player-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(22,28,36,.11)}
.player-header{background:var(--surface-strong);color:#fff;padding:.8rem 1.1rem;display:grid;grid-template-columns:minmax(0,1fr) auto auto;grid-template-areas:"title title toggle" "wl ratings toggle";align-items:center;gap:.25rem .75rem;cursor:pointer}
.player-header-left{grid-area:title;display:flex;flex-direction:column;gap:.2rem;min-width:0}
.player-title{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;min-width:0}
.player-name{font-family:var(--display);font-size:2.1rem;color:#fff;line-height:1;min-width:0;order:1}
.player-rank{display:inline-flex;align-items:center;gap:.2rem;padding:.12rem .5rem;border-radius:999px;background:rgba(255,255,255,.14);font-size:.62rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85);order:2}
.player-meta{display:contents}
.player-meta-block{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.player-meta-block:first-child{grid-area:ratings;justify-self:end;align-items:flex-end;text-align:right}
.player-meta-block:last-child{grid-area:wl}
.player-meta-label{font-size:.55rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.player-meta-values{display:flex;flex-wrap:wrap;gap:.3rem}
.stat-chip{display:inline-flex;align-items:center;gap:.2rem;padding:.12rem .42rem;border-radius:999px;background:rgba(255,255,255,.08);font-size:.6rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.9);white-space:nowrap}
.stat-chip-label{color:rgba(255,255,255,.45)}
.stat-chip-value{font-family:var(--display);font-size:.86rem;color:var(--accent-2);line-height:1}
.stat-chip .w{color:#4ade80}
.stat-chip .l{color:#fca5a5}
.stat-chip-sep{color:rgba(255,255,255,.45)}
.player-toggle{grid-area:toggle;justify-self:end;font-size:1rem;line-height:1;transition:transform .18s ease}
.player-body{display:none;padding:.9rem 1.1rem 1rem;background:var(--card)}
.player-card.is-open .player-body{display:grid;gap:1rem}
.player-card.is-open .player-toggle{transform:rotate(180deg)}
.stat-category{display:flex;flex-direction:column;gap:.35rem}
.stat-cat-label{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--theme-muted)}
.stat-table{width:100%;border-collapse:collapse;margin-top:.35rem}
.stat-table th{font-size:.6rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);text-align:center;padding:.25rem .2rem;border-bottom:1px solid var(--rule)}
.stat-table th:first-child{text-align:left}
.stat-table td{font-size:.8rem;font-weight:700;text-align:center;padding:.35rem .2rem;border-bottom:1px solid var(--rule);color:var(--ink)}
.stat-table tbody tr:last-child td{border-bottom:none}
.stat-table td:first-child{font-size:.66rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-muted);text-align:left}
.stat-table .td-win,.stat-table .td-pct-win{color:var(--win)}
.stat-table .td-loss,.stat-table .td-pct-loss{color:var(--accent)}
.stat-table .td-pct-win,.stat-table .td-pct-loss,.stat-table .td-dns{font-size:.78rem}
.stat-table .td-dns{color:var(--ink-muted);font-style:italic}

/* goals */
.goals-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.goal-card{padding:1.2rem 1.25rem;position:relative;overflow:hidden}
.goal-card::before,.stat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-2),var(--accent))}
.goal-card-name,.stat-card-value{font-family:var(--display)}
.goal-card-name{font-size:1.45rem;color:var(--ink);margin-bottom:.55rem}
.goal-list{margin:0;padding:0;list-style:none;display:grid;gap:.55rem}
.goal-item{display:flex;align-items:flex-start;gap:.55rem;color:var(--ink-mid);font-size:.9rem}
.goal-check{flex-shrink:0;color:var(--accent)}
.goal-item.done{color:var(--ink)}

/* generic stat + goal cards */
.stat-card,.goal-card{box-shadow:0 6px 20px rgba(22,28,36,.07)}
.stat-card{padding:1.4rem 1.4rem 1.2rem;position:relative;overflow:hidden}
.stat-card-value{font-size:2.8rem;line-height:1;color:var(--ink)}
.goal-card-head{background:var(--surface-strong)}
.post-season-sep{display:flex;align-items:center;gap:1rem;margin:.25rem 0;color:var(--ink-muted)}
.post-season-sep::before,.post-season-sep::after{content:"";flex:1;height:1px;background:var(--rule-md)}
.post-season-sep-label{font-size:.68rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}

/* helper utilities kept small */
.red{color:var(--accent)}
.mono{font-family:var(--mono)}
.muted{color:var(--ink-muted)}
.ruled{border-top:1px solid var(--rule-md);margin-block:var(--gap)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,22rem),1fr));gap:var(--gap)}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,17rem),1fr));gap:var(--gap)}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,14rem),1fr));gap:var(--gap)}
article{background:var(--card);border:1px solid var(--rule-md);padding:clamp(1rem,2.5vw,1.5rem);display:flex;flex-direction:column;gap:.75rem;transition:border-color .2s;box-shadow:0 1px 4px var(--rule)}
article:hover{border-color:var(--ink-muted)}

/* footer */
footer{border-top:1px solid var(--rule-md);padding-block:clamp(1.5rem,3vw,2.5rem);font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}
footer>div{width:min(var(--page-width),100% - 2*var(--page-pad));margin-inline:auto;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center}
footer a{color:var(--ink-muted);text-decoration:none}
footer a:hover{color:var(--ink)}
.site-footer{padding:1.2rem 0 0;border-top:2px solid var(--rule-md);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.footer-brand{font-family:var(--display);font-size:1.2rem;letter-spacing:.05em;color:var(--ink-mid)}
.footer-txt{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:var(--ink-muted)}

/* session plans */
.plan-intro{margin:0 0 1.5rem;color:var(--ink-mid);font-family:var(--serif);font-style:italic;max-width:70ch}
.plan-section{margin-bottom:2.5rem}
.plan-split{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--gap)}
.plan-pane{background:var(--card);border:1.5px solid var(--rule);border-radius:var(--radius-md);padding:1.2rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}
.plan-pane-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;border-bottom:1px solid var(--rule);padding-bottom:.6rem}
.plan-pane-sub{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}
.plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.9rem}
.plan-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem}
.plan-card{background:color-mix(in srgb,var(--bg) 88%, white 12%);border:1.5px solid var(--rule);border-radius:var(--radius-md);padding:.85rem;display:flex;flex-direction:column;gap:.45rem;min-height:120px;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s,border-color .2s}
.plan-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:color-mix(in srgb,var(--accent) 30%, var(--rule))}
.plan-card:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 55%, white);outline-offset:3px}
.plan-card-title{font-family:var(--display);font-size:1rem;letter-spacing:.04em;text-transform:uppercase}
.plan-card-sub{font-size:.8rem;color:var(--ink-muted);flex:1}
.plan-card-meta{font-size:.8rem;color:var(--ink-muted);line-height:1.5}
.plan-card-cta{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}

.lesson-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:2rem;background:rgba(3,12,8,.7);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:200}
.lesson-modal:target{opacity:1;pointer-events:auto}
.lesson-card{background:var(--paper);border-radius:var(--radius-md);border:1.5px solid var(--rule);width:min(960px,100%);max-height:90vh;overflow:auto;padding:2rem;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:slideUpFade .25s ease}
.lesson-head{display:flex;justify-content:space-between;gap:1.5rem;align-items:flex-start}
.lesson-sub{margin-top:.4rem;color:var(--ink-muted);font-size:.95rem}
.lesson-close{text-decoration:none;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:.45rem .8rem;border:1px solid var(--rule-md);border-radius:999px;color:var(--ink);background:color-mix(in srgb,var(--bg) 92%, white 8%);white-space:nowrap}
.lesson-close:hover{border-color:var(--accent);color:var(--accent)}
.lesson-meta{display:flex;flex-wrap:wrap;gap:.7rem;margin:1rem 0 1.4rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}
.lesson-meta span{padding:.25rem .6rem;border:1px solid var(--rule);border-radius:999px;background:color-mix(in srgb,var(--bg) 92%, white 8%)}
.lesson-body h3{margin-bottom:.4rem}
.lesson-list{list-style:disc;padding-left:1.2rem;margin:0 0 1.2rem;color:var(--ink-mid)}
.lesson-list li{margin-bottom:.4rem}

/* animations */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUpFade{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}

/* responsive */
@media (min-width:821px){
  .player-name{font-size:2.35rem}
  .player-meta-label{font-size:.65rem}
  .stat-chip{font-size:.7rem}
  .stat-chip-value{font-size:.98rem}
  .career-range{font-size:.68rem}
  .stat-cat-label{font-size:.8rem}
  .stat-table th{font-size:.7rem}
  .stat-table td{font-size:.88rem}
  .stat-table td:first-child{font-size:.7rem}
}

@media (max-width:820px){
  .sp-body,.cp-body{grid-template-columns:repeat(3,1fr)}
  .sp-stat:nth-child(3),.cp-stat:nth-child(3){border-right:none}
  .sp-stat:nth-child(n+4),.cp-stat:nth-child(n+4){border-top:1px solid var(--rule)}
  .sp-stat:last-child,.cp-stat:last-child{border-right:none}
  .season-panel .sp-body{grid-template-columns:1fr 1fr}
  .season-panel .sp-stat{min-height:6.5rem}
  .season-panel .sp-stat:nth-child(3),
  .season-panel .sp-stat:last-child{grid-column:1 / -1}
  .season-panel .sp-stat{border-right:1px solid var(--rule)!important;border-top:0!important}
  .season-panel .sp-stat:nth-child(2n){border-right:none!important}
  .season-panel .sp-stat:nth-child(n+3){border-top:1px solid var(--rule)!important}
  .member-card{grid-template-columns:1fr}
  .mc-left{border-right:none;border-bottom:1.5px solid var(--rule)}
  .prev-row{grid-template-columns:1fr}
  .mduel-splits{grid-template-columns:1fr}
}

@media (max-width:700px){
  .match-duet{grid-template-columns:1fr}
}

@media (max-width:720px){
  .player-header{grid-template-columns:minmax(0,1fr) auto auto;grid-template-areas:"title ratings toggle" "wl wl toggle";align-items:center;row-gap:.35rem}
  .player-meta-block:first-child{justify-self:start;align-items:center;text-align:left;flex-direction:row;gap:.4rem}
  .player-meta-block:first-child .player-meta-label{display:none}
  .player-meta-block:first-child .player-meta-values{gap:.35rem}
  .player-toggle{justify-self:end}
}

@media (max-width:640px){
  nav label[for=nav-toggle]{display:flex}
  nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface-strong);border-top:1px solid var(--rule-md);flex-direction:column;padding:1rem var(--gap);gap:.75rem}
  .player-grid,.goals-grid,.coaching-grid{grid-template-columns:1fr}
  .player-header{padding:.6rem 1rem}
  .player-name{font-size:1.85rem}
  .player-meta-label{font-size:.62rem}
  .stat-chip{font-size:.68rem;padding:.16rem .5rem}
  .stat-chip-value{font-size:.98rem}
  .player-body{padding:.8rem 1rem 1rem}
  .stat-table th{font-size:.7rem}
  .stat-table td{font-size:.9rem}
  .stat-table td:first-child{font-size:.72rem}
  .fixture{grid-template-columns:4rem 1fr}
  .fixture-right{display:none}
  .rubbers-header{display:none}
  .rubber-row{grid-template-columns:48px 1fr 80px 1fr;font-size:.78rem}
  .rubber-id{font-size:1.2rem}
  .rubber-score{font-size:1.6rem}
  .match-scoreline{gap:.75rem;padding:1.2rem 1rem}
  .team-score{font-size:3rem}
  .plan-pane-head{flex-direction:column;align-items:flex-start}
  .lesson-card{padding:1.4rem}
  .lesson-head{flex-direction:column}
}

@media (max-width:580px){
  .masthead-body{grid-template-columns:1fr;gap:1rem}
  .masthead-right{align-items:flex-start}
}

@media (max-width:560px){
  .page{padding:1.1rem 0 3rem}
  .sp-head,.cp-head{padding:.7rem 1rem}
  .sp-title,.cp-title{font-size:1.4rem}
  .sp-pos,.cp-pos{font-size:2.2rem}
  .sp-body,.cp-body{grid-template-columns:1fr 1fr}
  .sp-stat,.cp-stat{border-right:1px solid var(--rule)!important;border-top:0!important}
  .sp-stat:nth-child(2n),.cp-stat:nth-child(2n){border-right:none!important}
  .sp-stat:nth-child(n+3),.cp-stat:nth-child(n+3){border-top:1px solid var(--rule)!important}
  .match-header{padding:.6rem .85rem;gap:.35rem;align-items:center}
  .match-header-left{flex-direction:column;align-items:flex-start;justify-content:center;gap:.2rem;text-align:left}
  .match-header-right{flex-direction:column;align-items:center;gap:.25rem;text-align:center}
  .match-round{font-size:1.25rem;line-height:1.1}
  .match-meta{font-size:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .match-header-result{font-size:1.15rem}
  .match-header-result-lbl{font-size:.6rem}
  .sp-foot{padding:.6rem 1rem;flex-wrap:wrap;gap:.4rem}
  .ticker-item:nth-child(n+4){display:none}
  .mdc-score{font-size:2.3rem}
  .mdt-name{font-size:1.7rem}
  .mduel-standings{grid-template-columns:1fr;gap:.4rem}
  .mduel-ladder{grid-template-columns:1fr 1fr}
  .ladder-divider{display:none}
  .ladder-pill.us{text-align:left}
  .ladder-pill.them{text-align:right}
  .ladder-team,
  .ladder-record{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ladder-team{font-size:clamp(.55rem,2.2vw,.68rem)}
  .ladder-record{font-size:clamp(.7rem,2.6vw,.8rem)}
  .mc-right{grid-template-columns:1fr 1fr}
}

@media (max-width:480px){
  .breadcrumb-inner{flex-wrap:nowrap;gap:.35rem;white-space:nowrap;overflow:hidden}
  .breadcrumb a{font-size:.9rem;letter-spacing:.03em;white-space:nowrap}
  .breadcrumb-sep{margin:0 .1rem}
  .match-scoreline{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.5rem 1rem;padding:.9rem 1rem}
  .team-block.us,
  .team-block.them{flex-direction:column;align-items:center;justify-content:center;text-align:center}
  .team-block.them .team-info{order:1}
  .team-block.them .team-score{order:2}
  .team-block.them .team-info{text-align:center}
  .vs-divider{display:none}
  .team-score{font-size:1.6rem}
  .team-name{font-size:1.6rem}
  .team-games{font-size:.72rem}
  .rubber-row{grid-template-columns:36px 1fr 70px 1fr;font-size:.72rem}
  .rubber-id{font-size:1.1rem}
  .rubber-score{font-size:1.5rem}
  .sp-rounds{gap:.25rem}
  .sp-rnd{font-size:.62rem;padding:.2rem .35rem}
  .player-name{font-size:1.75rem}
}

@media (max-width:600px){
  .standings-wrap{overflow:visible}
  .standings-table{min-width:0}
  .standings-table th:nth-child(3),.standings-table td:nth-child(3),
  .standings-table th:nth-child(6),.standings-table td:nth-child(6),
  .standings-table th:nth-child(7),.standings-table td:nth-child(7),
  .standings-table th:nth-child(8),.standings-table td:nth-child(8),
  .standings-table th:nth-child(9),.standings-table td:nth-child(9),
  .standings-table th:nth-child(10),.standings-table td:nth-child(10),
  .standings-table th:nth-child(11),.standings-table td:nth-child(11),
  .standings-table th:nth-child(12),.standings-table td:nth-child(12),
  .standings-table th:nth-child(13),.standings-table td:nth-child(13),
  .standings-table th:nth-child(14),.standings-table td:nth-child(14),
  .standings-table th:nth-child(15),.standings-table td:nth-child(15),
  .standings-table th:nth-child(17),.standings-table td:nth-child(17){display:none}
  .standings-wrap.season-history{overflow:auto;-webkit-overflow-scrolling:touch}
  .standings-wrap.season-history .standings-table{min-width:640px}
  .standings-wrap.season-history .standings-table th,
  .standings-wrap.season-history .standings-table td{display:table-cell}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
