*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --navy:#1F2C44;--navy-2:#2A3A58;
  --accent:#4A77B4;--accent-dark:#3B6296;--accent-soft:#E9F0F9;--accent-text:#2C4A74;
  --amber-soft:#FBF2DE;--amber:#B07818;--amber-dark:#6B4A0D;--amber-mid:#E9A23B;
  --speed-soft:#E2EFF5;--speed:#205A75;
  --bg:#F3F5F9;--card:#fff;--text:#1A2433;--muted:#5C6B80;--faint:#93A1B5;--border:#E4E9F1;
  --radius:16px;
  --shadow:0 1px 2px rgba(20,30,55,.05),0 4px 14px rgba(20,30,55,.05);
  --display:'Manrope','Inter',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
[hidden]{display:none!important}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;min-height:100dvh}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
.hdr{position:sticky;top:0;z-index:30;background:var(--navy);color:#fff;display:flex;align-items:center;gap:11px;padding:13px 16px;padding-top:calc(13px + env(safe-area-inset-top,0px))}
.hdr-logo{width:38px;height:38px;border-radius:12px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:17px;flex-shrink:0}
.hdr-titles{flex:1;min-width:0}
.hdr-title{font-family:var(--display);font-weight:800;font-size:17px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-sub{font-size:11.5px;color:rgba(255,255,255,.6);font-weight:500}
.year-sel{height:38px;border-radius:11px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);color:#fff;font-family:var(--display);font-size:14px;font-weight:700;padding:0 10px;appearance:none}
.year-sel option{color:var(--text)}
.hdr-gear{width:38px;height:38px;border-radius:11px;border:none;background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;transition:background .15s}
.hdr-gear:hover{background:rgba(255,255,255,.2)}
main{max-width:600px;margin:0 auto;padding:18px 14px calc(88px + env(safe-area-inset-bottom,0px))}
.fab-wrap{position:fixed;bottom:0;right:0;z-index:40;display:flex;align-items:center;gap:10px;padding:0 18px;padding-bottom:calc(18px + env(safe-area-inset-bottom,0px))}
.fab-label{background:var(--navy);color:rgba(255,255,255,.85);font-family:var(--display);font-size:13px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;padding:9px 16px;border-radius:99px;box-shadow:0 4px 16px rgba(18,26,42,.25)}
.fab-btn{width:58px;height:58px;border-radius:50%;border:none;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(74,119,180,.45);transition:transform .15s,background .15s}
.fab-btn:active{transform:scale(.92)}
.fab-btn:hover{background:var(--accent-dark)}
#nav-backdrop{position:fixed;inset:0;z-index:50}
#nav-sheet{position:fixed;bottom:88px;right:16px;z-index:51;background:#fff;border:1px solid var(--border);border-radius:16px;padding:7px;width:215px;box-shadow:0 12px 40px rgba(18,26,42,.22);transform:scale(.92) translateY(10px);transform-origin:bottom right;opacity:0;pointer-events:none;transition:transform .2s cubic-bezier(.32,1,.5,1),opacity .18s ease}
#nav-sheet.open{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}
#nav-sheet a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:10px;font-size:14px;font-weight:600;color:var(--muted);transition:all .12s}
#nav-sheet a:hover{background:var(--bg)}
#nav-sheet a.active{background:var(--accent-soft);color:var(--accent-text)}
#nav-sheet .nav-div{height:1px;background:var(--border);margin:5px 8px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px;margin-bottom:12px}
.card.soft-speed{background:var(--speed-soft);border-color:transparent;box-shadow:none}
h2.section{font-family:var(--display);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--faint);margin:20px 4px 8px}
.chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3.5px 10px;border-radius:99px;background:var(--bg);color:var(--muted)}
.chip.amber{background:var(--amber-soft);color:var(--amber-dark)}
.chip.speed{background:var(--speed-soft);color:var(--speed)}
.chip.blue{background:var(--accent-soft);color:var(--accent-text)}
.tabs{display:flex;gap:7px;overflow-x:auto;padding:2px 0 12px;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tabs button{flex-shrink:0;border:1px solid var(--border);background:#fff;color:var(--muted);font-size:13px;font-weight:600;padding:7px 15px;border-radius:99px;transition:all .15s}
.tabs button.active{background:var(--accent-soft);border-color:transparent;color:var(--accent-text);font-weight:700}
.seg{display:flex;background:#E7EBF2;border-radius:12px;padding:3px;margin-bottom:12px}
.seg button{flex:1;border:none;background:transparent;font-size:13px;font-weight:700;padding:8px 0;border-radius:9px;color:var(--muted);transition:all .15s}
.seg button.active{background:#fff;color:var(--text);box-shadow:0 1px 3px rgba(20,30,55,.12)}
.row{display:flex;align-items:center;gap:10px;padding:10px 0;border-top:1px solid var(--border)}
.row:first-of-type{border-top:none}
.rank{width:22px;font-family:var(--display);font-size:13px;font-weight:800;color:var(--faint);text-align:center;flex-shrink:0}
.rank.r1{color:var(--amber-mid)}
.row-main{flex:1;min-width:0}
.row-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-mark{font-family:var(--display);font-size:15px;font-weight:800;font-variant-numeric:tabular-nums;text-align:right}
.row-mark small{display:block;font-size:11px;font-weight:600;color:var(--faint)}
.search{width:100%;border:1px solid var(--border);border-radius:13px;padding:11px 15px;font-size:15px;font-family:inherit;background:#fff;box-shadow:var(--shadow);margin-bottom:12px}
.search:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:transparent}
.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin:12px 0}
.metric{background:var(--bg);border-radius:13px;padding:11px 13px;min-width:0}
.metric .lab{font-size:11px;font-weight:600;color:var(--muted)}
.metric .val{font-family:var(--display);font-size:21px;font-weight:800;font-variant-numeric:tabular-nums;margin-top:2px}
.metric .val small{font-size:12px;font-weight:600;color:var(--muted)}
.metric a,.metric .sub{display:block;font-size:12.5px;font-weight:600;color:var(--text);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-meta{display:flex;gap:16px;margin-top:9px}
.feed-meta div{font-size:12px;color:var(--muted)}
.feed-meta b{display:block;font-family:var(--display);font-size:17px;font-weight:800;color:var(--text)}
.prlist{margin-top:11px;display:flex;flex-direction:column;gap:7px}
.pritem{display:flex;align-items:center;gap:8px;font-size:13px}
.pritem .ev{color:var(--muted);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pritem .mk{font-family:var(--display);font-weight:800;font-variant-numeric:tabular-nums}
.more-btn{margin-top:11px;width:100%;border:1px solid var(--border);background:#fff;border-radius:11px;padding:8px;font-size:12.5px;font-weight:600;color:var(--muted);transition:all .15s}
.more-btn:hover{border-color:var(--accent);color:var(--accent-text)}
.gate{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px}
.gate-card{background:#fff;border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:34px 28px;width:100%;max-width:370px;text-align:center}
.gate-logo{width:62px;height:62px;border-radius:18px;background:var(--accent-soft);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}
.gate h1{font-family:var(--display);font-size:21px;font-weight:800;letter-spacing:-.01em;margin-bottom:2px}
.gate p.sub{font-size:13px;color:var(--muted);margin-bottom:20px}
.gate label{display:block;text-align:left;font-size:12px;font-weight:600;color:var(--muted);margin:13px 0 5px}
.gate input{width:100%;border:1px solid var(--border);border-radius:11px;padding:11px 13px;font-size:15px;font-family:inherit}
.gate input:focus{outline:2px solid var(--accent);outline-offset:-1px}
.gate .go{width:100%;margin-top:20px;border:none;background:var(--accent);color:#fff;font-family:var(--display);font-size:15px;font-weight:800;padding:13px;border-radius:12px;transition:background .15s}
.gate .go:hover{background:var(--accent-dark)}
.gate .err{color:#C0392B;font-size:13px;font-weight:600;margin-top:10px;min-height:18px}
.gate .hint{font-size:11.5px;color:var(--faint);margin-top:14px}
.spark{display:block;width:100%;height:54px;margin:6px 0 2px}
.back{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:700;color:var(--muted);margin-bottom:10px;background:none;border:none}
.coach-note{background:var(--accent-soft);color:var(--accent-text);border-radius:13px;padding:11px 14px;font-size:12.5px;margin-bottom:12px}
.season-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-top:1px solid var(--border)}
.season-row:first-of-type{border-top:none}
.season-row .yr{font-family:var(--display);font-size:16px;font-weight:800;width:52px}
.season-row .sid{flex:1;font-size:12px;color:var(--muted);font-family:ui-monospace,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.season-row .del{border:none;background:#FBEAE8;color:#9C3428;font-size:12px;font-weight:700;padding:5px 10px;border-radius:8px}
.add-form{display:grid;grid-template-columns:90px 1fr auto;gap:8px;margin-top:12px}
.add-form input{border:1px solid var(--border);border-radius:10px;padding:9px 11px;font-size:14px;font-family:inherit;min-width:0}
.add-form button{border:none;background:var(--accent);color:#fff;font-weight:700;font-size:13px;padding:0 16px;border-radius:10px}
.empty{text-align:center;color:var(--faint);font-size:13px;padding:34px 0}
.group-head{display:flex;align-items:baseline;gap:8px;margin:20px 4px 8px}
.group-head h2{font-family:var(--display);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--faint)}
.group-head span{font-size:12px;color:var(--faint)}
.xtra-wrap{display:none}
.card.open .xtra-wrap{display:block}
.ev-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2px}
.ev-head h3{font-family:var(--display);font-size:15px;font-weight:800;letter-spacing:-.01em}
.ev-head .best{font-size:13px;font-weight:700;color:var(--amber)}
/* athlete pop-out */
#ath-overlay{position:fixed;inset:0;z-index:90}
.ov-backdrop{position:absolute;inset:0;background:rgba(18,26,42,.5);animation:fade .2s}
.ov-panel{position:absolute;left:0;right:0;bottom:0;max-height:90dvh;background:var(--card);border-radius:22px 22px 0 0;display:flex;flex-direction:column;animation:rise .26s cubic-bezier(.32,1,.45,1);box-shadow:0 -8px 40px rgba(18,26,42,.25)}
.ov-grab{width:40px;height:4px;border-radius:2px;background:var(--border);margin:10px auto 0;flex-shrink:0}
.ov-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:10px 20px 12px;flex-shrink:0}
.ov-head h1{font-family:var(--display);font-size:21px;font-weight:800;letter-spacing:-.015em;line-height:1.15}
.ov-head .sub{font-size:13px;color:var(--muted);margin-top:2px}
.ov-close{width:34px;height:34px;border-radius:50%;border:none;background:var(--bg);color:var(--muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.ov-close:hover{background:var(--border);color:var(--text)}
.ov-body{overflow-y:auto;padding:0 20px 26px;overscroll-behavior:contain}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.pr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin:8px 0 4px}
.pr-cell{background:var(--bg);border-radius:11px;padding:8px 11px;min-width:0}
.pr-cell .ev{font-size:11px;font-weight:600;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-cell .mk{font-family:var(--display);font-size:16px;font-weight:800;font-variant-numeric:tabular-nums;margin-top:1px}
.ev-tabs{padding-top:6px}
.chart-wrap{margin:4px 0 2px}
.chart-wrap svg{display:block;width:100%;height:96px}
.chart-dot{cursor:pointer}
.ev-detail{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg);border-radius:11px;padding:9px 13px;margin:8px 0 4px;font-size:13px}
.ev-detail .who{color:var(--muted);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev-detail .mk{font-family:var(--display);font-weight:800;font-variant-numeric:tabular-nums;flex-shrink:0}
@keyframes rise{from{transform:translateY(60px);opacity:.4}to{transform:translateY(0);opacity:1}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@media (min-width:700px){
  main{padding-top:24px}
  .tabbar a{padding:12px 0 10px}
  .ov-panel{left:50%;top:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:580px;max-height:86vh;border-radius:22px;animation:pop .22s cubic-bezier(.32,1,.45,1)}
  .ov-grab{display:none}
  .ov-head{padding-top:20px}
}
@keyframes pop{from{transform:translate(-50%,-48%) scale(.97);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}
@media (min-width:760px){
  main.wide{max-width:1100px}
  .board-grid{column-count:2;column-gap:12px}
  .board-grid>.card{break-inside:avoid;display:inline-block;width:100%;margin-bottom:12px}
}
@media (min-width:1150px){
  .board-grid{column-count:3}
}
