*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at 18% 8%,rgba(20,184,166,.14),transparent 28%),radial-gradient(circle at 82% 12%,rgba(244,63,94,.14),transparent 30%),#080d16;color:#eef4ff;font-family:Segoe UI,Yu Gothic UI,sans-serif}button,input,select{font:inherit}button{border:1px solid #2a3447;background:#111827;color:#dbe7ff;border-radius:6px;padding:8px 12px;cursor:pointer}button.primary{border-color:#14b8a6b8;background:linear-gradient(135deg,#14b8a6,#0f766e);color:#f8fffe;display:inline-flex;align-items:center;gap:6px;box-shadow:0 10px 24px #14b8a633}button.ghost{display:inline-flex;align-items:center;gap:6px;background:#161f31;color:#cbd5e1}button.compact{height:28px;padding:4px 8px;font-size:12px;white-space:nowrap}input,select{border:1px solid #2a3447;border-radius:6px;padding:9px 10px;min-width:0;background:#0c1220;color:#eef4ff}.login-page{min-height:100vh;display:grid;place-items:center}.login-panel{width:min(420px,calc(100vw - 32px));background:#111827;border:1px solid #263247;border-radius:8px;padding:28px;display:grid;gap:18px}.login-helper{margin:0;color:#9aa8bc;font-size:13px;line-height:1.5}.login-error{margin:0;color:#ff98a8;font-size:13px}.login-panel label{display:grid;gap:7px}.eyebrow{margin:0 0 4px;color:#8390a8;font-size:13px}h1,h2{margin:0;letter-spacing:0}h1{color:#f8fafc;font-size:26px;font-weight:900}h2{font-size:18px}.app-shell{height:100vh;height:100dvh;min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:4px;padding:6px 8px 8px;overflow:hidden;background:linear-gradient(180deg,#111827f5,#080d16f5),#080d16}.topbar,.player-slot,.timeline-panel,.metrics-panel,.admin-panel{background:#111827eb;border:1px solid #273247;border-radius:8px;box-shadow:0 18px 45px #00000047}.topbar{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;border-bottom-color:#1c2638}.title-block{display:flex;align-items:center;gap:12px}.session-badge{display:grid;gap:2px;padding:6px 10px;border:1px solid rgba(49,240,215,.18);border-radius:8px;background:#090f199e}.session-badge strong{color:#eef4ff;font-size:13px;font-weight:800}.session-badge span{color:#8fa0b8;font-size:11px}.topbar nav{display:flex;gap:8px}.topbar .eyebrow{display:inline-flex;align-items:center;width:fit-content;border:1px solid rgba(20,184,166,.55);border-radius:5px;margin:0;padding:3px 8px;color:#31f0d7;background:#14b8a61a;font-weight:800}.selection-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.player-slot{position:relative;min-height:78px;padding:8px 16px 8px 20px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:14px;overflow:hidden;background:radial-gradient(circle at 92% 18%,rgba(20,184,166,.08),transparent 32%),#111827}.player-slot.red{background:radial-gradient(circle at 92% 18%,rgba(251,77,109,.1),transparent 32%),#111827}.player-slot:before{content:"";position:absolute;inset:0 auto 0 0;width:4px}.player-slot.cyan:before{background:#14b8a6;box-shadow:0 0 20px #14b8a6e6}.player-slot.red:before{background:#fb4d6d;box-shadow:0 0 20px #fb4d6de6}.player-slot>div,.player-slot button{position:relative;z-index:1}.slot-summary{display:flex;align-items:center;gap:18px;min-width:0}.slot-info{min-width:0;flex:1}.player-slot strong{color:#f8fafc;font-size:20px;font-weight:900}.slot-heading{display:flex;align-items:center;gap:10px;min-width:0}.slot-chip{margin:0;padding:3px 8px;border:1px solid #31405b;border-radius:999px;color:#97a6bc;font-size:11px;font-weight:800;white-space:nowrap}.player-slot .primary{background:#0f172ae0;border-color:#273247;color:#cbd5e1;box-shadow:none}.player-slot.cyan .primary:hover{border-color:#14b8a6}.player-slot.red .primary:hover{border-color:#fb4d6d}.slot-meta{margin:0;color:#8290aa;font-size:13px}.slot-meta-row{display:flex;flex-wrap:wrap;gap:4px 12px;margin-top:4px}.slot-stats{flex:0 0 auto;display:flex;align-items:baseline;gap:8px;margin-left:12px}.slot-record{margin:0;font-size:clamp(23px,2vw,32px);font-weight:900;letter-spacing:0;line-height:1;white-space:nowrap}.slot-distance{margin:0;color:#9aa8bc;font-size:12px;font-weight:800}.player-slot.cyan .slot-record{color:#14e0c7;text-shadow:0 0 24px rgba(20,224,199,.35)}.player-slot.red .slot-record{color:#ff5472;text-shadow:0 0 24px rgba(255,84,114,.35)}.analysis-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:8px;height:100%;min-height:0;overflow:hidden;align-items:stretch}.analysis-grid-wide{grid-template-columns:minmax(0,1fr) 36px}.analysis-grid-wide .track-panel{padding:0}.analysis-grid-wide .track-visual{min-height:100%}.analysis-grid-wide .track-svg{transform:scale(1.14);transform-origin:center}.track-panel{position:relative;min-height:0;height:100%;background:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),#060b12;background-size:64px 64px;border-radius:8px;padding:8px;overflow:hidden}.track-visual{position:relative;min-height:100%;height:100%;overflow:hidden;display:grid}.track-svg{width:100%;height:100%;min-height:0;display:block}.speed-svg{width:100%}.track-bg{display:none}.svg-line{fill:none;stroke-linecap:round;stroke-linejoin:round}.svg-line.cyan{stroke:#12dac7;stroke-width:3;opacity:.94;filter:drop-shadow(0 0 5px rgba(18,218,199,.55))}.svg-line.red{stroke:#ff496a;stroke-width:1.8;opacity:.94;filter:drop-shadow(0 0 5px rgba(255,73,106,.55))}.track-guide{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.6;opacity:.82;vector-effect:non-scaling-stroke}.track-guide.inner-course{stroke:#e2e8f0d1;stroke-dasharray:12 8}.track-guide.outer-course{stroke:#94a3b8ad;stroke-dasharray:12 8}.track-guide.lane-divider{stroke:#38bdf86b;stroke-dasharray:6 8}.position-marker{stroke:#fff;stroke-width:2.4;filter:drop-shadow(0 2px 5px rgba(0,0,0,.45))}.position-marker.cyan{fill:#54d6d5}.position-marker.red{fill:#e64646}.empty-svg-text{fill:#9fb0bf;font-size:20px}.metrics-panel{min-height:0;height:100%;overflow:auto;padding:12px 12px 10px;display:flex;flex-direction:column}.metrics-panel.collapsed{overflow:hidden;padding:6px 4px;align-items:stretch;justify-content:stretch}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.metrics-panel h2{color:#eef4ff;font-size:18px;margin-bottom:0}.metrics-toggle-tab{flex:1;width:100%;height:100%;border-radius:8px;justify-content:center;background:linear-gradient(180deg,#14b8a629,#0f172af5),#111827;color:#e6f8ff;font-size:13px;font-weight:800;letter-spacing:.08em;writing-mode:vertical-rl;text-orientation:mixed;padding:12px 6px}.athlete-data-list{display:grid;gap:8px;margin-top:12px}.athlete-data-list div{border:1px solid #273247;border-radius:6px;background:#131b2a;padding:12px 14px}.athlete-data-list span,.athlete-data-list small{display:block;color:#8390a8;font-size:12px}.athlete-data-list strong{display:block;margin:2px 0;font-size:14px}table{width:100%;border-collapse:collapse;margin-top:12px;font-size:14px;color:#e5edf9}.splits-table{table-layout:fixed;margin-top:8px}.splits-table th:first-child,.splits-table td:first-child{width:31%;padding-left:4px}.splits-table th:not(:first-child),.splits-table td:not(:first-child){width:34.5%;text-align:right}.splits-table th{font-size:11px;line-height:1.2;word-break:break-word}.splits-table td{font-variant-numeric:tabular-nums;white-space:nowrap}th,td{border-bottom:1px solid #273247;padding:9px 8px;text-align:left}th{color:#8390a8;font-size:12px}.result-row td{background:#171f31;font-weight:700}.result-row td:nth-child(2),.metrics-panel tbody td:nth-child(2){color:#31f0d7}.result-row td:nth-child(3),.metrics-panel tbody td:nth-child(3){color:#ff6b85}.timeline-panel{padding:8px 10px;display:flex;justify-content:space-between;gap:16px;align-items:center}.timeline{display:grid;grid-template-columns:auto minmax(240px,1fr) auto;gap:12px;align-items:center;flex:1}.speed-buttons{display:flex;gap:6px}.speed-buttons button.active{border-color:#14b8a6;background:#123d3b;color:#31f0d7}.playback-toggle{min-width:110px;justify-content:center}.speed-svg{flex:1;min-height:0;margin-top:4px;background:transparent}.speed-overlay{position:absolute;left:50%;top:50%;z-index:2;width:min(1040px,82%);height:clamp(404px,54%,572px);transform:translate(-50%,-50%);border:1px solid #273247;border-radius:10px;background:linear-gradient(180deg,#111827d1,#0c1220e0),#111827db;box-shadow:0 28px 80px #0000006b,inset 0 1px #ffffff0a;padding:10px 12px 12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column}.analysis-grid:not(.analysis-grid-wide) .speed-overlay{height:clamp(500px,62%,620px);max-height:620px}.analysis-grid-wide .speed-overlay{width:min(1120px,80%);height:clamp(428px,58%,620px)}@media(min-width:1800px){.analysis-grid:not(.analysis-grid-wide) .speed-overlay{width:min(940px,74%)}}@media(max-width:1280px)and (min-width:901px){.analysis-grid:not(.analysis-grid-wide) .speed-overlay{width:min(820px,72%);height:clamp(440px,58%,560px);max-height:560px}.analysis-grid-wide .speed-overlay{width:min(900px,74%);height:clamp(416px,56%,580px)}.analysis-grid:not(.analysis-grid-wide) .track-svg{transform:scaleY(1.12);transform-origin:center}}.speed-overlay-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:2px}.speed-overlay h2{color:#eef4ff;font-size:15px}.metric-toggle{display:inline-flex;gap:4px}.chart-controls{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.time-readout{min-width:100px;color:#8390a8;font-size:13px;font-weight:700;text-align:right}.metric-toggle button{padding:4px 8px;border-radius:5px;font-size:12px}.metric-toggle button.active{border-color:#14b8a6;background:#14b8a6;color:#fff}.range-controls{display:flex;justify-content:stretch;align-items:center;margin-top:6px;padding:0;border:0;border-radius:0;background:transparent}.chart-frame-width{width:calc(100% - 16px);margin-left:10px;margin-right:6px}.axis-control{display:grid;align-items:center;gap:8px;color:#8390a8;font-size:12px;font-weight:700}.time-axis-control{grid-template-columns:minmax(0,1fr);gap:8px}.speed-axis-control{grid-template-columns:128px 84px 84px auto;justify-content:start;width:100%;padding:7px 10px;border:1px solid rgba(148,163,184,.16);border-radius:6px;background:#060b125c;box-shadow:inset 0 1px #ffffff08}.axis-heading{color:#d7e3f4;white-space:nowrap}.axis-unit{color:#97a6bc;font-size:12px;font-weight:700;white-space:nowrap;padding-left:6px}.axis-control label{display:grid;align-items:center;gap:6px;min-width:0}.speed-axis-control label{grid-template-columns:28px 46px}.time-window-header{display:grid;grid-template-columns:112px auto auto;align-items:center;gap:14px}.axis-control label span{white-space:nowrap}.range-controls input[type=range]{width:100%;height:18px;padding:0;accent-color:#5f930b}.time-window-controls{margin-top:6px;padding:10px 12px 12px;border:1px solid rgba(148,163,184,.16);border-radius:6px;background:#060b125c}.time-window-slider{position:relative;height:30px;min-width:0;width:100%}.time-window-slider:before,.time-window-fill{content:"";position:absolute;left:0;right:0;top:11px;height:8px;border-radius:999px}.time-window-slider:before{background:#e5e7eb;box-shadow:inset 0 0 0 2px #0f172a52}.time-window-fill{left:var(--range-start);right:auto;width:var(--range-width);z-index:1;background:linear-gradient(90deg,#5f930b,#85b91c);box-shadow:0 0 10px #84cc1652;cursor:grab;touch-action:none}.time-window-fill:active{cursor:grabbing}.time-window-slider input[type=range]{position:absolute;top:0;right:0;bottom:0;left:0;height:30px;margin:0;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;pointer-events:none}.time-window-start{z-index:2}.time-window-end{z-index:3}.time-axis-control{grid-template-columns:minmax(0,1fr);gap:10px}.time-window-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.time-window-meta{display:flex;align-items:center;gap:8px;color:#9aa8bc;white-space:nowrap;flex-wrap:wrap}.time-window-meta span{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border:1px solid rgba(148,163,184,.12);border-radius:999px;background:#0f172a80}.time-window-slider input[type=range]::-webkit-slider-runnable-track{height:8px;background:transparent}.time-window-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;margin-top:-5px;border-radius:50%;border:2px solid #d9f99d;background:#5f930b;box-shadow:0 2px 8px #00000073;cursor:ew-resize;pointer-events:auto}.time-window-slider input[type=range]::-moz-range-track{height:8px;background:transparent}.time-window-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;border:2px solid #d9f99d;background:#5f930b;box-shadow:0 2px 8px #00000073;cursor:ew-resize;pointer-events:auto}.range-controls input[type=number]{width:46px;height:26px;padding:4px 6px;font-size:12px}.range-controls input::placeholder{color:#536179}.grid-lines line{stroke:#94a3b821;stroke-width:1}.speed-value-lines line{stroke:#94a3b852;stroke-width:1.3}.speed-value-lines text{fill:#8390a8;font-size:13px;font-weight:700}.lap-marker{stroke-dasharray:5 5;opacity:.62}.lap-marker.cyan{stroke:#1cbfc0;stroke-width:1.8}.lap-marker.red{stroke:#dc2f2f;stroke-width:1.1}.current-time-line{stroke:#f8fafc;stroke-width:2;opacity:.8}.chart-timeline{display:grid;grid-template-columns:auto minmax(160px,1fr) auto;gap:8px;align-items:center;color:#8390a8;font-size:12px;font-weight:700}.empty-chart-text{fill:#8390a8;font-size:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000ad;display:grid;place-items:center;padding:24px}.search-modal{position:relative;z-index:1001;width:min(980px,100%);max-height:min(760px,calc(100vh - 48px));overflow:auto;background:#111827;border:1px solid #273247;border-radius:8px;padding:18px;color:#e5edf9;box-shadow:0 30px 90px #0000008c}.search-modal table{background:transparent}.search-modal header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.search-form,.inline-form{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.search-field{display:grid;gap:6px}.search-field span,.search-note,.search-result-meta{color:#9aa8bc;font-size:12px}.search-submit{align-self:end;justify-content:center;min-height:42px}.search-note{margin:10px 0 0}.search-result-meta{display:flex;justify-content:space-between;gap:12px;margin-top:10px}.search-results-table{table-layout:fixed}.search-suggestion-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}.search-suggestion-panel{padding:10px 12px;border:1px solid #273247;border-radius:8px;background:#0c1220b8}.search-suggestion-panel h3{margin:0 0 8px;color:#dbe7ff;font-size:13px}.search-chip-list{display:flex;flex-wrap:wrap;gap:6px}.search-chip{max-width:100%}.search-empty-hint{color:#7f8ba1;font-size:12px}.search-results-table th,.search-results-table td{vertical-align:middle}.search-results-table td{overflow-wrap:anywhere}.table-sort{padding:0;border:0;background:transparent;color:inherit;font-size:inherit}.table-sort.active{color:#dbe7ff}.pagination-bar{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:12px}.error-text{color:#b42318;margin:12px 0 0}.status-text{margin:0;color:#4d5b6b}.row-actions{display:flex;gap:6px}.admin-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:12px}.admin-nav{background:#fff;border:1px solid #d9dee7;border-radius:8px;padding:10px;display:grid;align-content:start;gap:6px}.admin-nav button{display:flex;align-items:center;gap:8px;justify-content:flex-start}.admin-nav button.active{border-color:#1f6feb;color:#1f6feb;background:#eef5ff}.admin-panel{min-height:560px;padding:18px}@media(max-width:900px){.app-shell{height:auto;gap:2px;padding:4px 6px 6px;overflow:visible}.topbar{align-items:flex-start;gap:8px;padding:4px 10px}.topbar h1{font-size:22px}.title-block{gap:8px;align-items:flex-start;flex-wrap:wrap}.topbar nav{gap:6px;flex-wrap:wrap;justify-content:flex-end}.topbar nav button{padding:6px 10px;font-size:13px}.topbar .eyebrow{padding:2px 6px;font-size:11px}.selection-grid,.analysis-grid,.admin-layout{grid-template-columns:1fr}.analysis-grid{height:auto;gap:4px}.analysis-grid-wide{grid-template-columns:1fr}.selection-grid{gap:6px}.player-slot{min-height:70px;padding:6px 12px 6px 16px;column-gap:10px}.slot-summary{gap:10px}.player-slot strong{font-size:16px}.slot-meta-row{gap:2px 8px;margin-top:2px}.slot-meta{font-size:12px}.slot-stats{margin-left:8px}.slot-record{font-size:clamp(18px,6vw,24px)}.track-panel{display:flex;flex-direction:column;gap:2px;min-height:0;padding:0 0 4px;background-size:48px 48px}.track-visual,.track-panel.track-only .track-visual{width:100%;height:auto;min-height:0;aspect-ratio:1000 / 520}.splits-table{table-layout:auto}.speed-overlay{position:relative;left:auto;top:auto;bottom:auto;transform:none;width:100%;min-height:250px;max-height:none;height:auto;margin:0;padding:8px 8px 10px}.speed-overlay-header{gap:8px;margin-bottom:0}.chart-controls{gap:4px;justify-content:flex-start}.playback-toggle{min-width:92px}.time-readout{min-width:auto;font-size:12px}.range-controls{margin-top:4px}.chart-frame-width{width:100%;margin-left:0;margin-right:0}.speed-axis-control{grid-template-columns:104px 72px 72px auto;padding:6px 8px}.chart-timeline{margin-top:4px}.time-window-controls{margin-top:4px;padding:8px 10px 10px}.metrics-panel.collapsed{display:none}.metrics-panel{padding:10px 10px 8px}.timeline-panel{align-items:stretch;flex-direction:column}.search-form,.inline-form,.search-suggestion-grid{grid-template-columns:1fr}}
