
:root{
  --bg:#fff; --ink:#16181c; --muted:#8a8f98; --line:#e6e8eb; --line2:#f0f2f4;
  --accent:#19a974; --hot:#e8112d; --bar:#0b0b0c; --gold:#e9b949;
  --g1:#e9b949; --g2:#b9c0c7; --g3:#cd8a52; --link:#1f7ae0;
}
*{box-sizing:border-box}
body{margin:0;font:15px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}
.bar{background:var(--bar);color:#fff;display:flex;align-items:center;gap:16px;padding:12px 26px}
.bar .logo{font-weight:800;font-size:17px;color:var(--gold)}.bar .logo a{color:var(--gold)}
.bar .logo sup.alpha{font-size:9px;letter-spacing:.12em;text-transform:uppercase;margin-left:4px;opacity:.85;color:var(--gold)}
.bar .bmeta{color:#7e848c;font-size:12.5px;letter-spacing:.02em}
.bar .right{margin-left:auto;color:#9aa0a8;font-size:12.5px;font-weight:700;letter-spacing:.04em}
.bar .right a{color:#cfd3d8}
.wrap{max-width:1320px;margin:0 auto;padding:20px 30px 64px}
.crumb{font-size:12.5px;color:var(--muted);margin:2px 0 0}
.evhead{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:18px;margin-bottom:4px}
.evhead .when{font-size:13.5px;line-height:1.5}.evhead .when .t{color:var(--muted)}
.evhead .title{text-align:center;font-size:29px;font-weight:800;letter-spacing:-.015em;margin:0}
.evhead .cond{text-align:right;font-size:13px;color:var(--muted);line-height:1.5}.evhead .cond b{color:var(--ink);font-weight:700}
.tabs{display:flex;justify-content:center;margin:16px 0 26px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:999px;background:#fff;padding:3px}
.seg button{border:0;background:transparent;padding:6px 20px;font:700 13px/1 inherit;color:var(--muted);cursor:pointer;border-radius:999px;transition:.12s}
.seg button.on{background:var(--bar);color:#fff}
.panel{display:none}.panel.on{display:block}
hr.rule{border:0;border-top:1px solid var(--line);margin:0 0 18px}
table.res{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
table.res th,table.res td{padding:8px 10px;text-align:center;border-bottom:1px solid var(--line2)}
table.res th{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:700;border-bottom:1px solid var(--line);padding-bottom:9px}
table.res td.rk{font-weight:800;width:42px}table.res td.no{color:var(--muted);width:46px}
table.res td.nm{text-align:left;font-weight:600}table.res td.nm small{display:block;color:var(--muted);font-weight:400;font-size:12px;margin-top:1px}
table.res td.sum{font-weight:800}table.res td.win{color:var(--accent)}table.res tr.elim td{color:var(--muted)}table.res tr:hover td{background:#f7f9fa}
.medal{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dotcol{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px;vertical-align:middle}
svg{width:100%;height:auto;display:block;overflow:visible}
.colhead{font-size:13px;font-weight:700;fill:var(--ink)}.axisnum{font-size:11px;fill:var(--muted)}
.flow{fill:none;stroke-linejoin:round;stroke-linecap:round;cursor:pointer;transition:opacity .12s}.node{cursor:pointer}
.endlabel{font-size:12.5px;font-weight:600;cursor:pointer;dominant-baseline:middle}
.endrank{font-size:12px;font-weight:800;dominant-baseline:middle}.gridline{stroke:var(--line);stroke-width:1}
.flowhint{color:var(--muted);font-size:13px;margin:-6px 0 14px}.empty{color:var(--muted);padding:30px 0}
.venue{display:grid;grid-template-columns:170px 1fr;gap:10px 22px;max-width:680px;font-size:14.5px}
.venue dt{color:var(--muted)}.venue dd{margin:0}.venue code{background:#f2f4f5;padding:1px 6px;border-radius:4px;font-size:12.5px}
.datasec h3{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:8px;margin:24px 0 10px}
table.grid{width:100%;border-collapse:collapse;font-size:13.5px;font-variant-numeric:tabular-nums}
table.grid th,table.grid td{padding:5px 8px;border-bottom:1px solid var(--line2);text-align:center}
table.grid th{color:var(--muted);font-weight:700;font-size:11px;text-transform:uppercase}
table.grid td.l,table.grid th.l{text-align:left}table.grid td.dance{font-weight:700;background:#f7f9fa;text-align:left}
#tip{position:fixed;pointer-events:none;z-index:30;background:#111;color:#fff;border-radius:8px;padding:10px 13px;font-size:12px;max-width:560px;box-shadow:0 8px 30px rgba(0,0,0,.28);opacity:0;transition:opacity .1s}
#tip table{white-space:nowrap}#tip th,#tip td{padding:2px 7px}
#tip .tname{font-weight:700;font-size:13px;margin-bottom:2px}#tip .tclub{color:#aeb4bb;margin-bottom:7px}
#tip table{border-collapse:collapse;width:100%}#tip th,#tip td{padding:2px 6px;text-align:center;font-variant-numeric:tabular-nums}
#tip th{color:#8a8f98;font-weight:600;border-bottom:1px solid #333}#tip td.d{text-align:left;color:#cdd2d8}#tip td.rk{color:var(--accent);font-weight:700}
.foot{margin-top:30px;color:var(--muted);font-size:11.5px}.foot code{background:#f2f4f5;padding:1px 5px;border-radius:4px}
.hero{margin:14px 0 26px;padding:18px 20px;background:#0b0b0c;color:#fff;border-radius:12px}
.hero .eyebrow{color:#9aa0a8;font-size:12px;letter-spacing:.05em;text-transform:uppercase}
.hero h2{margin:4px 0 2px;font-size:24px}.hero h2 .accent{color:var(--gold)}.hero a{color:#fff}
.grp{margin:26px 0 6px;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:8px}
table.idx{width:100%;border-collapse:collapse}
table.idx th,table.idx td{padding:9px 10px;border-bottom:1px solid var(--line2);text-align:left;font-size:14px}
table.idx th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
table.idx td.c,table.idx th.c{text-align:center;font-variant-numeric:tabular-nums}
table.idx td.win{font-weight:600}table.idx tr:hover td{background:#f7f9fa}
table.idx .pn{color:var(--muted);width:36px;text-align:right;font-variant-numeric:tabular-nums}
.tcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin:22px 0}
.tcard{display:block;border:1px solid var(--line);border-radius:14px;padding:18px 20px;color:var(--ink)}
.tcard:hover{text-decoration:none;border-color:var(--ink);box-shadow:0 6px 24px rgba(0,0,0,.07)}
.tcard h3{margin:0 0 2px;font-size:20px}
.tcard .d{color:var(--muted);font-size:13px}
.tcard .stat{margin-top:12px;font-size:13px;color:var(--muted)}
.tcard .stat b{color:var(--ink);font-size:18px;font-weight:800;display:block}
.tcard .statrow{display:flex;gap:22px;margin-top:10px}
.tcard .hero2{margin-top:12px;font-size:13px;color:var(--muted)}
.tcard .hero2 b{color:var(--accent)}
.navlinks{margin-left:auto;display:flex;gap:18px}
.navlinks a{color:#cfd3d8;font-size:12.5px;font-weight:700;letter-spacing:.04em}
.navlinks a:first-child{color:var(--gold)}
.langsw{display:inline-flex;margin-left:14px}
.langsel{appearance:none;-webkit-appearance:none;background:#1c1f24;color:var(--gold);border:1px solid #2c3037;
  border-radius:6px;font:800 11px/1 inherit;letter-spacing:.04em;padding:4px 20px 4px 8px;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%23e9b949' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 6px center}
.toggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:3px;margin:12px 0 4px;background:#fff}
.toggle a{padding:5px 16px;border-radius:999px;font-size:13px;font-weight:700;color:var(--muted)}
.toggle a.on{background:var(--bar);color:#fff}
.toggle a:hover{text-decoration:none}
.pairsline{margin:8px 0 2px;font-size:13.5px;color:var(--muted)}.pairsline a{font-weight:600}
.sitefoot{display:flex;flex-wrap:wrap;gap:8px 22px;margin:36px 0 0;padding:16px 0 4px;border-top:1px solid var(--line);font-size:12.5px;font-weight:700;letter-spacing:.03em}
.sitefoot a{color:var(--muted)}.sitefoot a:hover{color:var(--ink)}
/* people index */
.search{width:100%;max-width:360px;padding:9px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px;margin:14px 0 6px}
table.people td.app,table.people th.app{text-align:center;font-variant-numeric:tabular-nums}
.tdots{display:inline-flex;gap:3px}.tdot{width:8px;height:8px;border-radius:50%;display:inline-block}
.pillbest{font-weight:800}
.formc{text-align:center;padding:2px 10px;white-space:nowrap}
.cmprow{display:flex;flex-wrap:wrap;gap:0 56px;align-items:flex-start}
.cmprow>div{min-width:0}
/* three analytic blocks stacked under one shared season filter (radar · h2h · judges) */
.a3stack>div{margin-top:10px}
.a3empty{color:var(--muted);font-size:13px;margin-top:6px}
tr.morebtn td{text-align:center;color:var(--accent);font-weight:700;font-size:12.5px;cursor:pointer;padding:8px 10px}
tr.morebtn td:hover{background:#f3faf6}
.strbar{display:flex;align-items:center;gap:8px;margin:8px 0 2px;font-size:11px;color:var(--muted)}
.strbar span{white-space:nowrap}
.strbar i{flex:1;height:6px;background:#eef0f2;border-radius:4px;overflow:hidden}
.strbar i b{display:block;height:100%;background:var(--accent)}
/* person page */
/* milestones: personal firsts & bests */
.mstones{display:flex;flex-wrap:wrap;gap:10px 14px;margin-top:6px}
.mstone{display:flex;gap:9px;align-items:flex-start;border:1px solid var(--line);border-radius:10px;padding:9px 13px;background:#fff;min-width:220px}
.mstone .mic{font-size:18px;line-height:1.2}
.mstone .mt{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.mstone .md{font-size:13.5px;margin-top:1px}
.psum{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:14px 0 8px}
.psum div{padding:12px 16px;border-right:1px solid var(--line)}
.psum div:last-child{border-right:0}
.psum .k{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.psum .v{font-size:22px;font-weight:800;margin-top:2px}
.pgrp{margin:22px 0 6px;font-weight:800;font-size:16px}
.pgrp small{color:var(--muted);font-weight:500;font-size:13px;margin-left:8px}
.meth4{color:var(--muted);font-size:12.5px;line-height:1.5;max-width:640px;margin:-2px 0 8px}
.methbox{margin:10px 0;max-width:680px;background:var(--card,#faf9f6);border:1px solid var(--line);border-radius:8px;padding:0 12px}
.methbox summary{cursor:pointer;font-weight:700;font-size:13px;padding:9px 0;color:var(--ink)}
.methbox p{color:var(--muted);font-size:13px;line-height:1.55;margin:0 0 8px}
/* columns that carry an explanatory tooltip (title=) — dotted underline + help cursor */
.hint{cursor:help;text-decoration:underline dotted var(--line);text-underline-offset:3px;text-decoration-thickness:1px}
#hintpop{position:absolute;z-index:95;background:#16181b;color:#fff;font-size:12.5px;font-weight:500;line-height:1.5;
  padding:10px 13px;border-radius:9px;max-width:300px;box-shadow:0 12px 32px rgba(0,0,0,.28);white-space:normal;
  text-transform:none;letter-spacing:0;text-align:left}
th.hint:hover,.hint:hover{text-decoration-color:var(--muted)}
table.pev{width:100%;border-collapse:collapse}
table.pev td,table.pev th{padding:8px 10px;border-bottom:1px solid var(--line2);text-align:left;font-size:14px}
table.pev th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
table.pev td.c{text-align:center;font-variant-numeric:tabular-nums}
table.pev td.res{font-weight:800}
table.pev tr:hover td{background:#f7f9fa}
.discdot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}
.pts{font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums}
table.idx td.pts,table.pev td.pts{text-align:center}
/* filters: label above each control; custom chevron with symmetric padding */
.filters{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:end;margin:16px 0 8px}
.filt{display:flex;flex-direction:column;gap:5px}
.filt>span{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}
.yrsel{padding:8px 34px 8px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:#fff;
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%238a8f98' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center}
/* judge column header: given name over surname (surnames can collide) */
th .jgiv,th .jsur{display:block;line-height:1.06}
th .jgiv{font-weight:500;font-size:10px;color:var(--muted)}
th .jsur{font-weight:700}
.srch{position:relative;display:inline-flex;align-items:center}
.srch .search{margin:0;padding-right:30px}
.srch .clr{position:absolute;right:6px;border:0;background:transparent;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:2px 6px;display:none}
.srch .clr:hover{color:var(--ink)}
.srch.has .clr{display:block}
/* searchable category combobox */
.combo{position:relative;display:inline-block}
.combo-list{position:absolute;top:100%;left:0;z-index:20;background:#fff;border:1px solid var(--line);
  border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,.14);max-height:300px;overflow:auto;
  min-width:240px;margin-top:3px;display:none}
.combo-list.open{display:block}
/* W1-B entity-matching tool */
.matchbar{margin:6px 0 4px;font-size:14px;color:var(--ink)}
.mrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:7px 10px;border:1px solid var(--line);border-radius:8px;margin:4px 0;max-width:720px}
.mrow .mn{font-weight:600}
.mrow .meq{color:var(--muted)}
.mrow .mev{color:var(--muted);font-size:12px}
.mrow .macts{margin-left:auto;display:flex;gap:6px}
.mbtn{border:1px solid var(--line);background:#fff;border-radius:6px;padding:5px 12px;font:600 12.5px inherit;cursor:pointer;color:var(--ink)}
.mbtn.same.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.mbtn.diff.on{background:var(--hot);color:#fff;border-color:var(--hot)}
.mbtn.export{background:var(--ink);color:#fff;border-color:var(--ink)}
.manualadd{display:flex;gap:8px;align-items:center;flex-wrap:wrap;max-width:720px}
.manualadd .search{max-width:240px;margin:0}
.combo-list .ci{padding:7px 12px;font-size:13.5px;cursor:pointer;white-space:nowrap;
  display:flex;justify-content:space-between;align-items:center;gap:16px}
.combo-list .ci .cn{color:var(--muted);font-size:12px}
.combo-list .ci.all{color:var(--muted);border-bottom:1px solid var(--line2)}
.combo-list .ci:hover{background:#f3f5f7}
.tagp{font-size:10px;font-weight:800;letter-spacing:.03em;color:#fff;background:var(--accent);border-radius:4px;padding:1px 5px;vertical-align:middle}
.tagt{font-size:10px;font-weight:700;color:var(--muted);border:1px solid var(--line);border-radius:4px;padding:0 5px;margin-left:6px}
.rankbox{display:flex;flex-wrap:wrap;gap:18px;align-items:center;background:#f4faf7;border:1px solid #cfeede;border-radius:12px;padding:14px 18px;margin:12px 0}
.rankbox .big{font-size:26px;font-weight:800;color:var(--accent)}
.rankbox .k{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
/* compact, right-aligned numeric tables + hover on every table */
table.res th,table.res td,table.grid th,table.grid td,table.pev th,table.pev td,table.idx th,table.idx td{white-space:nowrap}
table.res th,table.res td{text-align:right;padding:7px 13px}
table.res td.nm,table.res th.l{text-align:left;white-space:normal}
table.idx{width:auto;min-width:540px}
table.idx th,table.idx td{padding:7px 15px}
table.idx td.c,table.idx th.c,table.idx td.app,table.idx th.app,table.idx td.pts,table.idx th.pts{text-align:right}
table.pev td.c,table.pev th.c{text-align:right}
table.grid td:not(.l):not(.dance),table.grid th:not(.l){text-align:right}
table.idx tr:hover td,table.res tr:hover td,table.pev tr:hover td,table.grid tr:hover td{background:#f6f8f9}
/* ===== design system: compact data tables ===== */
/* every data table shrinks to its content (never full width) so numbers sit close
   together and read at a glance; one shared, tight cell metric across all tables. */
table.res,table.idx,table.pev,table.grid{width:auto;max-width:100%}
table.idx{min-width:0}
table.res th,table.res td,table.idx th,table.idx td,table.pev th,table.pev td,table.grid th,table.grid td{padding:6px 12px;vertical-align:top}
/* group-header row inside a merged table — lets several "tables" with the same
   columns share one column layout so similar columns line up across groups. */
tr.ghead td{background:#f3f5f7;font-weight:800;font-size:12.5px;padding:16px 12px 7px;
  border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
tr.ghead:first-child td{padding-top:8px}
tr.ghead td .gn{font-size:11px;font-weight:600;color:var(--muted);margin-left:8px;letter-spacing:.02em}
table.pev td.l a,table.idx td a{color:var(--link)}
/* judge bias map + two-column tendency tables */
.heat{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px;margin:10px 0 6px}
.hcell{border:1px solid var(--line);border-radius:8px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12.5px;min-height:40px}
.hcell span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hcell b{font-variant-numeric:tabular-nums;font-weight:800}
.twocol{display:grid;grid-template-columns:auto auto;gap:80px;align-items:start;justify-content:start}
@media(max-width:720px){.twocol{grid-template-columns:1fr}}
table.pev td.l small{display:block;font-size:11.5px}
/* head-to-head + form on dancer page */
.rivtag{font-size:11px;color:var(--muted)}
.formpill{display:inline-block;font-size:12px;font-weight:800;border-radius:6px;padding:2px 9px;vertical-align:middle}
.spark{display:block}
/* season points-race: collapsed to a ≤40px bar by default, expandable */
details.racewrap{margin:12px 0 10px;border:1px solid var(--line);border-radius:10px;overflow:hidden}
details.racewrap>summary{list-style:none;cursor:pointer;height:40px;display:flex;align-items:center;gap:12px;padding:0 14px;font-size:13px;overflow:hidden;white-space:nowrap}
details.racewrap>summary::-webkit-details-marker{display:none}
details.racewrap>summary .rl{font-weight:800;flex:none}
details.racewrap>summary .rlead{color:var(--muted);overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
details.racewrap>summary .rx{flex:none;color:var(--link);font-weight:700;transition:transform .15s}
details.racewrap[open]>summary{border-bottom:1px solid var(--line)}
details.racewrap[open]>summary .rx{transform:rotate(180deg)}
details.racewrap .racehint{color:var(--muted);font-size:13px;margin:10px 14px 6px}
details.racewrap svg{margin:0 14px 12px;max-width:calc(100% - 28px)}
/* ===== mobile: compact, nothing scrolls sideways except the table that must ===== */
.catmob{display:none}            /* desktop: categories live in their own column */
@media(max-width:720px){
  body{overflow-x:hidden}
  .wrap{padding:16px 12px 44px}
  .bar{flex-wrap:wrap;gap:6px 14px;padding:10px 14px}
  .langsw{margin-left:auto}            /* top-right of the first row (nav wraps below) */
  .navlinks{flex:0 0 100%;margin-left:0;gap:18px;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:2px}
  .navlinks a{white-space:nowrap}
  .evhead{grid-template-columns:1fr;gap:6px}
  .evhead .title{font-size:22px;text-align:left;overflow-wrap:anywhere}
  .evhead .when,.evhead .cond{text-align:left}
  .tabs{justify-content:flex-start;margin:14px 0 20px}.seg{max-width:100%;overflow-x:auto}
  .psum{grid-template-columns:repeat(2,1fr)}
  .twocol{grid-template-columns:1fr;gap:18px}
  th,td{padding:5px 8px!important;font-size:12.5px}
  /* dancers + clubs indexes FIT the screen (no sideways scroll): numeric columns
     shrink to content, the name/club column takes the rest and wraps at spaces */
  table.tdancers,table.tclubs{display:table;width:100%}
  table.tdancers td.app,table.tdancers th.app,table.tclubs td.c,table.tclubs th.c{width:1px;white-space:nowrap}
  table.tdancers td:nth-child(2),table.tclubs td:nth-child(2){white-space:normal;overflow-wrap:break-word;word-break:normal}
  .formc{display:none}                        /* form sparkline: drop on mobile to fit */
  .catcol{display:none}                       /* clubs: hide the categories column … */
  .catmob{display:block;font-size:11px;color:var(--muted);margin-top:3px;white-space:normal;font-weight:400}/* … show it under the club name */
  /* wide tables (event results/data, merged dancer/judge tables) scroll within themselves */
  table.idx,table.res,table.pev,table.grid{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
  table.tdancers,table.tclubs{display:table}  /* re-assert: these fit, don't scroll */
  table.res td.nm,table.res td.l,table.res th.l,table.pev td.l,table.grid td.l{white-space:normal;overflow-wrap:break-word;word-break:normal}
  /* venue list compresses to fit */
  .venue{grid-template-columns:92px 1fr;gap:6px 12px;font-size:13px;max-width:100%}
  .venue dd{word-break:break-word}.venue code{word-break:break-all}
}
