:root{color-scheme:dark;--bg: #0f172a;--panel: #1e293b;--panel-2: #334155;--text: #e2e8f0;--muted: #94a3b8;--accent: #22d3ee;--accent-2: #06b6d4;--good: #22c55e;--warn: #f59e0b;--bad: #ef4444;--radius: 12px}*{box-sizing:border-box}html,body,#root{height:100%;overflow:hidden;overscroll-behavior:none}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent}button,input,select{font:inherit;color:inherit}.app{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}.appbar{padding:max(env(safe-area-inset-top),12px) 16px 12px;background:var(--panel);border-bottom:1px solid #0b1220}.appbar h1{margin:0;font-size:18px;letter-spacing:.3px}.content{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;min-height:0}.content>*{flex:0 0 auto}.content>.panel:last-child{flex:1 0 auto;margin-bottom:0}.panel{background:var(--panel);border-radius:var(--radius);padding:16px;margin-bottom:16px}.panel h2{margin:0 0 12px;font-size:16px}.panel hr{border:none;border-top:1px solid var(--panel-2);margin:16px 0}.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.row:last-child{margin-bottom:0}input[type=text],input[type=password],input[type=file],input[type=datetime-local],select{flex:1 1 180px;min-width:0;padding:12px 14px;border-radius:10px;border:1px solid var(--panel-2);background:#0b1220;color:var(--text);font-size:16px}select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:38px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%2394a3b8' d='M6 8L0 0h12z'/></svg>");background-repeat:no-repeat;background-position:right 14px center;background-size:10px 7px}.unit-input{flex:0 0 80px}.field-label{flex:0 0 auto;color:var(--muted);font-size:12px;letter-spacing:.6px;text-transform:uppercase;font-weight:600}.muted-soft{text-transform:none;letter-spacing:0;font-weight:500;opacity:.7}.form{display:flex;flex-direction:column;gap:14px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 480px){.form-grid{grid-template-columns:1fr}}.field{display:flex;flex-direction:column;gap:6px;min-width:0}.field>select,.field>input[type=text],.field>input[type=password],.field>input[type=datetime-local]{flex:1 1 auto;width:100%}.field-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.field-row>input{flex:1 1 200px}.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:4px}button{padding:12px 16px;border-radius:10px;border:1px solid transparent;background:var(--panel-2);color:var(--text);font-weight:600;cursor:pointer;font-size:15px;touch-action:manipulation;min-height:44px}.section-h3{margin:0 0 8px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.segmented{display:flex;gap:4px;background:var(--panel);padding:4px;border-radius:12px;margin-bottom:14px;position:sticky;top:0;z-index:10}.segment{flex:1 1 0;padding:8px 6px;background:transparent;border:none;border-radius:9px;color:var(--muted);font-size:13px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:2px;min-height:0}.segment .seg-icon{font-size:16px;line-height:1}.segment .seg-label{font-size:11px}.segment.on{background:var(--panel-2);color:var(--text)}.empty-state{text-align:center;padding:24px 8px;color:var(--muted)}.empty-state p{margin:0 0 14px}.empty-state .row{justify-content:center}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#062a30}button.secondary{background:var(--panel-2)}button.danger{background:transparent;color:var(--bad);border-color:var(--bad)}button.link{background:transparent;color:var(--accent);padding:6px 8px;font-weight:600;font-size:14px}.list{list-style:none;margin:0;padding:0}.list li{display:flex;align-items:center;gap:10px;padding:12px;background:#0b1220;border-radius:10px;margin-bottom:8px;flex-wrap:wrap}.list li .title{flex:1 1 auto;font-weight:600;min-width:0;word-break:break-word}.list li .empty,.empty{color:var(--muted)}.manage-list .manage-card{display:flex;flex-direction:column;align-items:stretch;gap:10px}.manage-card .manage-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}.manage-card .manage-head .title{flex:1 1 auto;font-size:17px;min-width:0}.manage-card .manage-head input[type=text]{flex:1 1 140px}.manage-card .manage-actions{display:flex;flex-wrap:wrap;gap:6px;width:100%}.manage-card .manage-actions>button{flex:0 0 auto;padding:10px 12px;font-size:14px}.manage-card .manage-actions .link{padding:8px 6px}.manage-card .badge{flex:0 0 auto}.badge{font-size:12px;padding:4px 8px;background:var(--panel-2);border-radius:999px;color:var(--muted)}.muted{color:var(--muted);font-size:14px}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.chip{padding:10px 14px;border-radius:999px;background:#0b1220;border:2px solid var(--panel-2);color:var(--text)}.chip.on{background:var(--accent);color:#062a30;border-color:var(--accent)}.big-start,.big-stop{width:100%;padding:22px;font-size:22px;border-radius:16px;background:var(--good);color:#062a08;border:none}.big-stop{background:var(--bad);color:#2a0606}.runlist.solo li .big-stop{min-height:35vh;padding:24px;font-size:clamp(36px,9vw,56px);letter-spacing:3px;border-radius:20px}.run-hero{background:#0b1220;border-radius:16px;padding:20px 16px;margin-bottom:14px;text-align:center}.run-hero-label{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.run-hero-time{font-variant-numeric:tabular-nums;font-weight:800;font-size:clamp(56px,18vw,96px);line-height:1.05;color:var(--accent);letter-spacing:-1px}.run-hero-when{margin-top:10px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;color:var(--muted);font-size:14px}.run-hero-when input[type=datetime-local]{flex:1 1 200px}.runlist{list-style:none;padding:0;margin:0}.runlist li{background:#0b1220;border-radius:12px;padding:14px;margin-bottom:10px;display:grid;grid-template-columns:1fr auto;grid-template-areas:"who elapsed" "action action";gap:8px 12px;align-items:center}.runlist li .who{grid-area:who;font-weight:700;font-size:18px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.runlist li .who-name{flex:0 1 auto}.runlist li .elapsed{grid-area:elapsed;font-variant-numeric:tabular-nums;font-size:28px;font-weight:700;color:var(--accent)}.runlist li .big-stop,.runlist li .manual{grid-area:action}.runlist li.done{opacity:.95}.runlist li.done .elapsed{color:var(--good)}.place{display:inline-flex;align-items:center;justify-content:center;min-width:32px;padding:2px 6px;border-radius:999px;background:var(--panel-2);color:var(--text);font-size:12px;font-weight:800;letter-spacing:.5px}.runlist li.done:nth-child(1) .place{background:#fbbf24;color:#3a1d00}.row-pr{font-size:12px;font-weight:600;color:var(--muted);background:#0b1220;padding:2px 8px;border-radius:999px}.row-pr.pr-beat{background:var(--good);color:#062a08}.elapsed.pr-beat{color:var(--good)}.elapsed.on-pace{color:#facc15}.chip-pr{display:block;margin-top:2px;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.3px}.chip.on .chip-pr{color:#062a30;opacity:.8}.backup-banner{padding:10px 12px;border-radius:10px;margin-bottom:12px;font-size:14px;font-weight:600}.backup-banner.banner-ok{background:#0b2a14;color:#86efac;border:1px solid #14532d}.backup-banner.banner-warn{background:#2a1f06;color:#fcd34d;border:1px solid #78350f}.backup-banner.banner-bad{background:#2a0b0b;color:#fca5a5;border:1px solid #7f1d1d}.photo-icon{display:inline-block;border-radius:50%;object-fit:cover;vertical-align:middle;background:#0b1220}.session-card{background:var(--panel);border-radius:14px;padding:14px;margin-bottom:18px;border:1px solid var(--panel-2)}.session-card:last-child{margin-bottom:0}.session-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--panel-2)}.session-title{margin:0;font-size:15px;font-weight:700;color:var(--text);letter-spacing:.2px}.session-card .list{margin-top:4px}.session-notes{width:100%;background:#0b1220;border:1px solid var(--panel-2);border-radius:10px;padding:10px 12px;color:var(--text);font-family:inherit;font-size:14px;resize:vertical;margin-bottom:8px}.result-photo{display:block;margin-top:8px}.result-photo img,video.result-photo{max-width:240px;max-height:240px;border-radius:8px;display:block;background:#000}.celebration-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:50}.celebration-toast{position:absolute;top:12vh;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#062a30;padding:14px 22px;border-radius:16px;display:flex;align-items:center;gap:12px;font-weight:800;box-shadow:0 20px 50px #00000080;animation:toast-pop 2.6s ease-out forwards;white-space:nowrap}.celebration-toast-emoji{font-size:38px;line-height:1}.celebration-toast-title{font-size:18px;letter-spacing:1.5px}.celebration-toast-name{font-size:14px;opacity:.85}@keyframes toast-pop{0%{transform:translate(-50%) translateY(-20px) scale(.7);opacity:0}10%{transform:translate(-50%) translateY(0) scale(1.05);opacity:1}20%{transform:translate(-50%) translateY(0) scale(1)}85%{transform:translate(-50%) translateY(0) scale(1);opacity:1}to{transform:translate(-50%) translateY(-30px) scale(.95);opacity:0}}.confetti{position:absolute;top:18vh;width:10px;height:14px;border-radius:2px;animation-name:confetti-fall;animation-timing-function:cubic-bezier(.2,.6,.4,1);animation-fill-mode:forwards}@keyframes confetti-fall{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(var(--drift, 0vw),90vh) rotate(var(--rot, 360deg));opacity:0}}.tab{position:relative}.tab-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--bad)}.manual{width:100%;padding:10px 12px;border-radius:10px;background:#050a14;border:1px solid var(--panel-2);color:var(--text);font-size:15px}.cmp-wrap{overflow-x:auto}.cmp-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.cmp-table th,.cmp-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--panel-2);white-space:nowrap}.cmp-table th{font-weight:600;color:var(--muted);font-size:12px;letter-spacing:.5px;text-transform:uppercase;background:#0b1220;position:sticky;top:0}.cmp-table td.num{text-align:right;font-variant-numeric:tabular-nums}.cmp-table td.muted{color:var(--muted)}.cmp-table .delta-good{color:var(--good);font-weight:700}.cmp-table .delta-bad{color:var(--bad);font-weight:700}.cmp-table .delta-flat{color:var(--muted)}.hist-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.hist-main .title{font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:2px}.hist-main .muted{line-height:1.35}.list li.swipe-row{display:block;position:relative;overflow:hidden;padding:0;background:transparent;margin-bottom:10px;border-radius:10px;touch-action:pan-y;flex-wrap:nowrap}.swipe-action{position:absolute;top:0;bottom:0;width:88px;display:flex;align-items:center;justify-content:center;border:none;color:#fff;font-weight:700;font-size:14px;letter-spacing:.5px;z-index:0;border-radius:0;min-height:0;padding:0}.swipe-action.swipe-left{left:0;background:var(--accent);color:#062a30}.swipe-action.swipe-right{right:0;background:var(--bad)}.swipe-content{position:relative;z-index:1;display:flex;align-items:center;gap:12px;padding:14px;background:#0b1220;border-radius:10px;flex-wrap:wrap;will-change:transform;width:100%;min-height:100%}.list li.is-best,.swipe-row.is-best .swipe-content{background:linear-gradient(180deg,#0b1220,#0b2230);border-left:3px solid var(--accent);padding-left:11px}.list li.edit-row{display:flex;flex-direction:column;align-items:stretch;gap:4px;padding:14px;background:#0b1220;border-radius:10px;margin-bottom:10px}.list li.edit-row.is-best{border-left:3px solid var(--accent);padding-left:11px}.avatar{display:inline-flex;align-items:center;justify-content:center;font-size:22px;line-height:1;width:1.4em;text-align:center}.runlist .who .avatar{font-size:24px}.bests-name .avatar{font-size:20px;margin-right:4px}.list li .avatar{flex:0 0 auto}.avatar-picker{position:relative;display:flex;align-items:center;gap:4px;flex:0 0 auto}.avatar-display{background:#0b1220;border:1px solid var(--panel-2);border-radius:10px;padding:6px 10px;font-size:22px;cursor:pointer}.avatar-grid{position:absolute;top:calc(100% + 6px);left:0;z-index:20;background:var(--panel);border:1px solid var(--panel-2);border-radius:12px;padding:8px;display:grid;grid-template-columns:repeat(8,1fr);gap:4px;max-width:min(360px,92vw);box-shadow:0 12px 32px #0006}.avatar-option{background:transparent;border:2px solid transparent;border-radius:8px;padding:6px;font-size:22px;cursor:pointer}.avatar-option:hover{background:#0b1220}.avatar-option.on{border-color:var(--accent);background:#0b2230}.pr-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:1px;padding:2px 6px;border-radius:4px;background:var(--accent);color:#062a30}.bests-card{margin-bottom:16px}.bests-name{margin:0 0 8px;font-size:16px;color:var(--text)}.bests-list .bests-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.bests-cat{flex:1;min-width:0}.bests-val{text-align:right}.small{font-size:12px}.hist-when{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.location-field{margin-top:14px;margin-bottom:14px;padding:12px;background:#0b1220;border-radius:10px}.loc-link{color:var(--accent);text-decoration:none;font-weight:600;font-size:12px;background:#0b1220;padding:2px 8px;border-radius:999px}.loc-link:hover{text-decoration:underline}.hist-value{font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent);font-size:18px}.tabbar{display:flex;flex-shrink:0;background:var(--bg);border-top:1px solid #0b1220;padding:6px 6px 0;gap:4px;overflow-x:auto}.tab{flex:1 0 auto;padding:8px;background:transparent;border:none;color:var(--muted);font-size:11px;font-weight:600;border-radius:8px;white-space:nowrap;display:flex;flex-direction:column;align-items:center;gap:2px}.tab .tab-icon{font-size:18px;line-height:1}.tab .tab-label{font-size:11px}.tab.active{background:var(--panel-2);color:var(--text)}.tab.tab-blocked{opacity:.35;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;animation:fade-in .15s ease-out}.modal-card{background:var(--panel);border-radius:14px;padding:20px;max-width:420px;width:100%;box-shadow:0 24px 64px #00000080}.modal-title{margin:0 0 12px;font-size:17px;color:var(--text);word-break:break-word}.modal-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;margin-top:16px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.toast{position:fixed;right:16px;bottom:calc(96px + env(safe-area-inset-bottom));max-width:calc(100% - 32px);background:var(--panel-2);color:var(--text);padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 12px 32px #00000073;z-index:100;animation:toast-in .18s ease-out;pointer-events:none}@keyframes toast-in{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}
