:root{
 --bg:#0d1117;--card:#161b22;--card2:#1c232d;--line:#2a313c;--ink:#e6edf3;--mut:#8b949e;
 --yellow:#ffd60a;--green:#3fb950;--amber:#d29922;--red:#f85149;--blue:#58a6ff;--purple:#bc8cff;--teal:#39c5cf;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
 font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}
button{font:inherit;cursor:pointer;border:1px solid var(--line);background:var(--card2);color:var(--ink);
 border-radius:8px;padding:7px 13px}
button:hover{border-color:var(--mut)}
button.primary{background:var(--yellow);color:#1a1a1a;border-color:var(--yellow);font-weight:700}
button.primary:hover{filter:brightness(1.05)}
button.ghost{background:transparent}
button:disabled{opacity:.45;cursor:not-allowed}
input{font:inherit;background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:8px 11px}
input:focus{outline:none;border-color:var(--yellow)}
.wrap{max-width:1160px;margin:0 auto;padding:0 18px}

/* top nav */
nav{position:sticky;top:0;z-index:20;background:rgba(13,17,23,.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;gap:6px;height:56px}
.brand{font-weight:800;font-size:16px;margin-right:14px;white-space:nowrap}
.brand b{color:var(--yellow)}
.tabs{display:flex;gap:2px;flex:1;flex-wrap:wrap}
.tabs a{color:var(--mut);padding:7px 12px;border-radius:8px;font-weight:600;font-size:13px}
.tabs a.active{color:var(--ink);background:var(--card)}
.tabs a:hover{text-decoration:none;color:var(--ink)}
.who{color:var(--mut);font-size:13px;white-space:nowrap;display:flex;gap:8px;align-items:center}

main{padding:22px 0 70px}
h1.page{font-size:20px;margin:0 0 4px}
.lead{color:var(--mut);margin:0 0 18px;font-size:13px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.span{grid-column:1/-1}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:15px 17px}
.card h2{margin:0 0 12px;font-size:12px;text-transform:uppercase;letter-spacing:.7px;color:var(--mut)}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.spread{justify-content:space-between}
.mut{color:var(--mut)}.b{font-weight:700}.yel{color:var(--yellow)}
.right{text-align:right}.center{text-align:center}

table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--mut);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;padding:4px 8px;border-bottom:1px solid var(--line)}
td{padding:6px 8px;border-bottom:1px solid var(--card2)}
tr:last-child td{border-bottom:none}
tbody tr.click{cursor:pointer}tbody tr.click:hover td{background:var(--card2)}

.bar{height:9px;border-radius:5px;background:var(--yellow)}
.barrow{display:flex;align-items:center;gap:10px;margin:7px 0}
.barrow .nm{width:150px;font-size:13px}.barrow .pct{width:46px;text-align:right;color:var(--yellow);font-weight:700}
.track{flex:1;background:var(--card2);border-radius:5px;overflow:hidden}

.risk-lo{color:var(--green)}.risk-md{color:var(--amber)}.risk-hi{color:var(--red);font-weight:700}
.badge{display:inline-block;min-width:60px;text-align:center;padding:2px 7px;border-radius:6px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.t-flat{background:#0d3b66;color:#9ecbff}.t-hilly{background:#0c3b3e;color:#7fe0e6}
.t-mountain,.t-summit{background:#4a1d1d;color:#ff9b94}.t-itt,.t-ttt{background:#33245c;color:#cdb4ff}.t-punch{background:#4a1f3d;color:#ff9ed8}
.cap{color:var(--yellow);font-weight:700}

/* budget bar */
.budget{height:12px;border-radius:7px;background:var(--card2);overflow:hidden;margin:6px 0}
.budget>div{height:100%;background:var(--green)}
.budget.over>div{background:var(--red)}
.pill{display:inline-block;padding:1px 8px;border-radius:20px;font-size:11px;font-weight:700;background:var(--card2);border:1px solid var(--line)}
.err{color:var(--red);font-size:12.5px}
.ok{color:var(--green);font-size:12.5px}

/* roster grid */
.roster{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.slot{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--card2);border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:13px}
.slot .x{color:var(--mut);cursor:pointer;font-weight:700}.slot .x:hover{color:var(--red)}
.slot.empty{color:var(--mut);justify-content:center;border-style:dashed}

/* search dropdown */
.search{position:relative}
.results{position:absolute;z-index:30;left:0;right:0;top:42px;background:var(--card);border:1px solid var(--line);border-radius:8px;max-height:280px;overflow:auto;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.results div{padding:7px 11px;cursor:pointer;display:flex;justify-content:space-between;gap:8px}
.results div:hover{background:var(--card2)}
.results .dis{opacity:.4;cursor:not-allowed}

/* auth */
.authwrap{max-width:360px;margin:60px auto;text-align:center}
.authwrap .card{text-align:left}
.authwrap input{width:100%;margin:6px 0}
.tabbtns{display:flex;gap:6px;margin-bottom:12px}
.tabbtns button{flex:1}
.kpi{display:flex;gap:22px;flex-wrap:wrap}
.kpi div{font-size:12px;color:var(--mut)}.kpi b{display:block;font-size:20px;color:var(--ink)}
.kpi .y b{color:var(--yellow)}
.distbar{height:26px;position:relative;background:var(--card2);border-radius:8px;margin-top:6px}
.dfill{position:absolute;top:0;bottom:0;background:#3a3410;border-radius:8px}
.dmean{position:absolute;top:-3px;bottom:-3px;width:3px;background:var(--yellow);border-radius:2px}
.note{color:var(--mut);font-size:11.5px;line-height:1.6;margin-top:12px}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--line);
 border-radius:8px;padding:10px 16px;z-index:50;box-shadow:0 8px 24px rgba(0,0,0,.5);font-size:13px}
.hidden{display:none}

/* clickable rider name */
.pl{color:var(--blue);cursor:pointer;font-weight:600}.pl:hover{text-decoration:underline}
.barrow.click{cursor:pointer;border-radius:6px;padding:4px 6px;margin:3px -6px}
.barrow.click:hover{background:var(--card2)}

/* modal (rider stats / win-prob calc) */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:flex-start;justify-content:center;z-index:100;padding:40px 16px;overflow:auto}
.modal{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 22px;max-width:520px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.modal h2{font-size:18px}.modal h3{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--mut);margin:16px 0 8px}
.modal .x{cursor:pointer;color:var(--mut);font-weight:700;font-size:18px}.modal .x:hover{color:var(--red)}
.calc{display:flex;flex-wrap:wrap;align-items:center;gap:10px;background:var(--card2);border-radius:8px;padding:10px 12px;font-size:13px}
.calc b{color:var(--ink)}.calc .y{color:var(--yellow)}
.factors{margin:6px 0 0;padding-left:18px;font-size:13px;color:var(--ink)}.factors li{margin:3px 0}

/* dashboard extras */
.adjrow{padding:6px 0;border-bottom:1px solid var(--card2);font-size:13px}.adjrow:last-child{border:none}
.teamcard{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px}
.teamcard.mine{border-color:var(--yellow);box-shadow:inset 0 0 0 1px var(--yellow)}
.roster-line{font-size:12.5px;margin-top:6px;line-height:1.9}
.warn{background:#3a2d0a;border:1px solid #5a4a14;color:#ffe08a;border-radius:8px;padding:8px 11px;font-size:12px;margin:6px 0}
.mineRow td{background:rgba(255,214,10,.06)}
.newsrow{padding:8px 0;border-bottom:1px solid var(--card2)}.newsrow:last-child{border:none}
.slot.gone{border-color:var(--red)}
.yel{color:var(--yellow)}
.alertbar{background:#3a1414;border:1px solid var(--red);color:#ffd9d5;border-radius:10px;padding:10px 14px;margin:14px 0;font-size:13px;display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.alertbar b{color:#fff}.alertbar .amut{color:#e0a9a3}
.alertbar button{margin-left:4px}

@media(max-width:760px){.grid{grid-template-columns:1fr}.roster{grid-template-columns:1fr}.barrow .nm{width:110px}}
