:root{--canvas:#010102;--surface-1:#0f1011;--surface-2:#141516;--surface-3:#18191a;--hairline:#23252a;--hairline-2:#34343a;--ink:#f7f8f8;--ink-muted:#d0d6e0;--ink-subtle:#8a8f98;--ink-3:#62666d;--accent:#5e6ad2;--accent-hover:#828fff;--accent-bg:#5e6ad221;--success:#27a644;--win:#f5b73d;--win-bg:#f5b73d21;--font:"Inter", -apple-system, system-ui, "Segoe UI", Roboto, sans-serif;--ease:cubic-bezier(.22, 1, .36, 1);--top-h:56px;--tab-h:46px;--sum-h:calc(var(--top-h) + var(--tab-h));--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0}body{background:var(--canvas);color:var(--ink);font-family:var(--font);letter-spacing:-.011em;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}button{font-family:inherit}.app{max-width:620px;min-height:100dvh;padding-bottom:max(28px, env(safe-area-inset-bottom));margin:0 auto}.topbar{z-index:100;height:var(--top-h);padding:0 16px;padding-top:env(safe-area-inset-top);background:color-mix(in srgb, var(--canvas) 80%, transparent);-webkit-backdrop-filter:blur(14px)saturate(1.4);border-bottom:1px solid var(--hairline);justify-content:center;align-items:center;display:flex;position:sticky;top:0}.topbar h1{letter-spacing:-.02em;color:var(--ink);margin:0;font-size:clamp(1.05rem,4.6vw,1.25rem);font-weight:600}.topbar h1:after{content:"";background:var(--accent);vertical-align:.12em;border-radius:50%;width:7px;height:7px;margin-left:8px;display:inline-block}.admin{gap:7px;display:inline-flex;position:absolute;right:14px}.topbar-actions{align-items:center;gap:8px;display:inline-flex;position:absolute;right:14px}.view-link{background:var(--accent-bg);border:1px solid var(--accent);min-height:36px;color:var(--accent-hover);white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:0 12px;font-size:.8rem;font-weight:600;text-decoration:none;display:inline-flex}.view-link:hover{background:var(--accent);color:#fff}.view-link.live{color:#ff6166;background:#e5484d24;border-color:#e5484d}.view-link.live:hover{color:#fff;background:#e5484d}.refresh{background:var(--surface-1);border:1px solid var(--hairline);min-height:40px;color:var(--ink-muted);cursor:pointer;transition:border-color .14s var(--ease), color .14s var(--ease);border-radius:8px;align-items:center;gap:5px;padding:0 12px;font-size:.8rem;font-weight:500;display:inline-flex}.refresh:hover{border-color:var(--hairline-2);color:var(--ink)}.tabs{top:var(--top-h);z-index:99;height:var(--tab-h);background:color-mix(in srgb, var(--canvas) 86%, transparent);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--hairline);display:flex;position:sticky}.tabs button{color:var(--ink-subtle);font-family:var(--font);letter-spacing:-.01em;cursor:pointer;transition:color .14s var(--ease);background:0 0;border:0;flex:1;font-size:.82rem;font-weight:500;position:relative}.tabs button:hover{color:var(--ink-muted)}.tabs button.on{color:var(--ink)}.tabs button.on:after{content:"";background:var(--accent);border-radius:2px;height:2px;position:absolute;bottom:-1px;left:30%;right:30%}.cat-filter{flex-direction:column;gap:8px;padding:13px 13px 8px;display:flex}.cat-row{align-items:center;gap:9px;display:flex}.cat-rowlabel{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);text-align:right;flex:0 0 64px;font-size:.62rem;font-weight:700}.cat-grid{flex:1;gap:6px;display:grid}.cat-chip{background:var(--surface-1);border:1px solid var(--hairline);width:100%;min-height:34px;color:var(--ink-subtle);font-family:var(--font);letter-spacing:.01em;cursor:pointer;transition:background .14s var(--ease), border-color .14s var(--ease), color .14s var(--ease);border-radius:999px;padding:0 8px;font-size:.76rem;font-weight:600}.cat-chip:hover{border-color:var(--hairline-2);color:var(--ink-muted)}.cat-chip.on{background:var(--accent-bg);border-color:color-mix(in srgb, var(--accent) 60%, var(--hairline));color:var(--accent-hover)}.day-group{padding-bottom:6px}.day-group h2{top:var(--sum-h);z-index:90;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-subtle);background:color-mix(in srgb, var(--canvas) 88%, transparent);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--hairline);margin:0;padding:11px 18px 8px;font-size:.72rem;font-weight:600;position:sticky}.card{background:var(--surface-1);border:1px solid var(--hairline);transition:border-color .14s var(--ease);border-radius:12px;margin:10px 12px;padding:17px 16px 18px;box-shadow:inset 0 1px #ffffff09;container-type:inline-size}.card.status-finished{opacity:.5}.card.fav{border-color:color-mix(in srgb, var(--accent) 55%, var(--hairline));box-shadow:inset 0 1px 0 #ffffff0a, 0 0 0 1px var(--accent-bg)}.card.timeoff{background:var(--canvas);box-shadow:none;border-style:dashed;justify-content:center;align-items:center;gap:10px;display:flex}.off-label{color:var(--ink-subtle);font-size:.86rem;font-weight:500}.card.timeoff .time{color:var(--ink-3)}.card-head{flex-wrap:wrap;justify-content:center;align-items:center;gap:7px 9px;margin-bottom:17px;display:flex}.time{letter-spacing:-.02em;color:var(--ink);font-variant-numeric:tabular-nums;font-size:clamp(.95rem,4.2vw,1.1rem);font-weight:600}.court{letter-spacing:.02em;color:var(--ink-muted);background:var(--surface-3);border:1px solid var(--hairline);border-radius:999px;padding:2px 8px;font-size:.66rem;font-weight:600}.cat{color:var(--ink-3);font-size:.7rem;font-weight:500}.status-chip{background:var(--surface-2);letter-spacing:.03em;text-transform:uppercase;color:var(--ink-subtle);border-radius:999px;align-items:center;gap:5px;padding:2px 9px 2px 7px;font-size:.62rem;font-weight:600;display:inline-flex}.status-chip:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px}.status-chip.live{color:var(--success);animation:pulse 1.8s var(--ease) infinite}.status-chip.pending{color:var(--win)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.teams{text-align:center;letter-spacing:-.015em;color:var(--ink);grid-template-columns:1fr auto 1fr;place-items:center;column-gap:.3em;font-size:clamp(.82rem,3.6vw,1.06rem);font-weight:500;line-height:1.3;display:grid}.teams>*{min-width:0}.team{overflow-wrap:anywhere;font:inherit;letter-spacing:inherit;color:inherit;cursor:pointer;transition:color .14s var(--ease), background .14s var(--ease);background:0 0;border:0;border-radius:6px;justify-content:center;align-items:baseline;gap:3px;margin:-5px -3px;padding:5px 3px;display:inline-flex}button.team:hover{background:var(--surface-2)}.team.slot,.team.tbd{color:var(--ink-subtle)}.team.followed{color:var(--accent-hover)}.team.winner{color:var(--win);font-weight:700}.team .trophy{font-size:.85em}.vs{color:var(--ink-3);font-size:.62em;font-weight:500}.slot-group{flex-direction:column;align-items:center;gap:5px;display:inline-flex}.slot-label{letter-spacing:.09em;text-transform:uppercase;color:var(--ink-subtle);margin:0 0 1px;font-size:.55em;font-weight:600}.feeder-teams{flex-direction:column;align-items:center;gap:5px;display:inline-flex}.result{text-align:center;letter-spacing:-.01em;color:var(--ink);font-variant-numeric:tabular-nums;margin-top:9px;font-size:1.05rem;font-weight:600}.search{padding:16px 14px}.search input{background:var(--surface-1);border:1px solid var(--hairline);width:100%;min-height:46px;color:var(--ink);font-family:var(--font);transition:border-color .14s var(--ease);border-radius:8px;padding:0 14px;font-size:.92rem}.search input::placeholder{color:var(--ink-3)}.search input:focus{border-color:var(--hairline-2);box-shadow:0 0 0 2px var(--accent-bg);outline:none}.search ul{flex-direction:column;gap:7px;margin:12px 0 0;padding:0;list-style:none;display:flex}.star{background:var(--surface-1);border:1px solid var(--hairline);width:100%;min-height:50px;color:var(--ink);font-family:var(--font);text-align:left;cursor:pointer;transition:border-color .14s var(--ease), background .14s var(--ease), color .14s var(--ease);border-radius:8px;align-items:center;gap:10px;padding:0 15px;font-size:.96rem;font-weight:500;display:flex}.star:hover{border-color:var(--hairline-2)}.star.on{color:var(--accent-hover);border-color:color-mix(in srgb, var(--accent) 55%, var(--hairline));background:var(--accent-bg)}.empty,.error{text-align:center;color:var(--ink-subtle);margin:26px 22px;font-size:.92rem;line-height:1.5}.error{color:#e5484d}.meta{padding:16px;padding-bottom:max(16px, env(safe-area-inset-bottom));text-align:center;color:var(--ink-3);border-top:1px solid var(--hairline);margin-top:18px;font-size:.72rem}.confirm{background:var(--surface-2);border:1px solid var(--hairline-2);width:min(340px,100vw - 40px);color:var(--ink);border-radius:14px;margin:auto;padding:22px 22px 18px;box-shadow:0 24px 60px -20px #000c}.confirm::backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#010102a8}.confirm-q{text-align:center;color:var(--ink-muted);margin:0 0 18px;font-size:1.02rem;line-height:1.4}.confirm-q strong{color:var(--ink);font-weight:600}.confirm-actions{gap:10px;display:flex}.confirm-actions button{min-height:44px;font-family:var(--font);cursor:pointer;transition:background .14s var(--ease), border-color .14s var(--ease);border-radius:8px;flex:1;font-size:.92rem;font-weight:600}.btn-ghost{background:var(--surface-1);border:1px solid var(--hairline);color:var(--ink-muted)}.btn-ghost:hover{border-color:var(--hairline-2);color:var(--ink)}.btn-primary{background:var(--accent);border:1px solid var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.tl-page{flex-direction:column;max-width:none;height:100dvh;padding:0;display:flex}.tl-head{justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.tl-head-left{align-items:center;gap:12px;display:inline-flex}.tl-head h1{letter-spacing:-.02em;font-size:1.05rem;font-weight:600}.tl-now-btn{background:var(--accent-bg);border:1px solid var(--accent);color:var(--accent-hover);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:5px 14px;font-size:.78rem;font-weight:600;display:inline-flex}.tl-now-btn.live{color:#ff6166;background:#e5484d24;border-color:#e5484d}.tl-live-dot{width:8px;height:8px;animation:pulse 1.6s var(--ease) infinite;background:#ff5a5f;border-radius:50%;box-shadow:0 0 6px #ff5a5fcc}.tl-loading{color:var(--ink-subtle);padding:28px 16px}.tl-body{flex:1 1 0;min-height:0;display:flex;position:relative;overflow:hidden}.tl-gutter{z-index:6;background:var(--canvas);border-right:1px solid var(--hairline);flex:0 0 40px;overflow:hidden}.tl-gutter-inner{will-change:transform}.tl-lane-label{color:var(--ink-subtle);border-top:1px solid var(--hairline);align-items:center;padding-left:8px;font-size:.78rem;font-weight:600;display:flex}.tl-scroller{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;cursor:grab;-webkit-user-select:none;user-select:none;flex:1;position:relative;overflow:auto}.tl-scroller:active{cursor:grabbing}.tl-scroller{scrollbar-width:thin;scrollbar-color:var(--accent-hover) transparent}.tl-scroller::-webkit-scrollbar{width:6px;height:6px}.tl-scroller::-webkit-scrollbar-track{background:0 0}.tl-scroller::-webkit-scrollbar-thumb{background:var(--accent-hover);border-radius:999px;box-shadow:0 0 6px #828fffb3}.tl-scroller::-webkit-scrollbar-thumb:hover{background:var(--accent)}.tl-track,.tl-canvas{position:relative}.tl-scroller *{-webkit-user-drag:none}.tl-playhead{background:var(--ink);opacity:.85;z-index:7;pointer-events:none;width:2px;margin-left:-1px;position:absolute;top:0;bottom:0;left:calc(20px + 50%)}.tl-playhead:before{content:"";border-left:6px solid #0000;border-right:6px solid #0000;border-top:7px solid var(--ink);position:absolute;top:-1px;left:-5px}.tl-tick{background:var(--hairline);z-index:1;width:1px;position:absolute;top:0}.tl-tick-label{color:var(--ink-3);white-space:nowrap;font-size:.72rem;position:absolute;top:11px;left:5px}.tl-day-label{letter-spacing:.04em;color:var(--accent-hover);font-size:.68rem;font-weight:700;position:absolute;top:-1px;left:5px}.tl-gap{z-index:2;border-left:1px dashed var(--hairline-2);border-right:1px dashed var(--hairline-2);background:repeating-linear-gradient(-45deg,#0000 0 6px,#8a8f981a 6px 12px);justify-content:center;align-items:center;display:flex;position:absolute}.tl-gap-label{color:var(--ink-subtle);background:var(--canvas);white-space:nowrap;border-radius:5px;padding:2px 5px;font-size:.6rem;transform:rotate(-90deg)}.tl-band{z-index:3;border-left:1px solid var(--accent);border-right:1px solid var(--accent);background:#5e6ad21a;justify-content:center;align-items:flex-start;display:flex;position:absolute}.tl-band-label{color:var(--accent-hover);white-space:nowrap;writing-mode:vertical-rl;margin-top:6px;font-size:.62rem}.tl-block{z-index:4;box-sizing:border-box;background:var(--surface-2);border:1px solid var(--hairline);cursor:default;border-radius:8px;flex-direction:column;justify-content:center;gap:1px;padding:5px 7px;display:flex;position:absolute;overflow:hidden}.tl-team{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:500;line-height:1.18;overflow:hidden}.tl-mid{font-size:.7rem;line-height:1.1}.tl-mid i{color:var(--ink-3);font-style:normal}.tl-cat{letter-spacing:.03em;color:var(--ink-3);pointer-events:none;font-size:.56rem;font-weight:600;position:absolute;top:4px;right:7px}.tl-score{color:var(--success);font-weight:700}.tl-win{color:var(--win);font-weight:700}.tl-win:before{content:"🏆 ";font-size:.85em}.tl-block.status-live{border-color:var(--success);background:#27a6441a}.tl-block.status-pending{border-color:color-mix(in srgb, var(--win) 55%, var(--hairline))}.tl-block.status-finished{opacity:.5}.tl-block.fav{border-color:color-mix(in srgb, var(--accent) 60%, var(--hairline));background:var(--accent-bg);box-shadow:0 0 0 1px var(--accent-bg)}.tl-now{background:var(--accent-hover);z-index:5;pointer-events:none;width:2px;position:absolute;top:0}.tl-now-dot{background:var(--accent-hover);border-radius:50%;width:10px;height:10px;position:absolute;top:0;left:-4px}.tl-summary{border-top:1px solid var(--hairline);background:var(--surface-1);flex:0 0 31dvh;padding:12px 16px 16px;overflow-y:auto}.tl-summary-head{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.tl-rel{letter-spacing:-.02em;color:var(--ink);font-size:1.12rem;font-weight:700}.tl-rel.is-now{color:#ff6166}.tl-clock{color:var(--ink-subtle);font-size:.84rem;font-weight:600}.tl-summary-empty{color:var(--ink-subtle);font-size:.9rem}.tl-band-cheer{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;display:flex}.tl-band-cheer .tl-cheer-match{color:var(--accent-hover);letter-spacing:.02em;font-size:.82rem;font-weight:600}.tl-cheer-score{align-items:center;gap:12px;margin:2px 0;display:inline-flex}.tl-cheer-score b{color:#4aa3ff;font-size:2.4rem;font-weight:800;line-height:1}.tl-cheer-score .tl-cheer-sep{color:var(--ink-subtle);font-size:1.1rem;font-weight:600}.tl-cheer-score .tl-cheer-team{letter-spacing:.05em;color:var(--ink);font-size:.8rem;font-weight:700}.tl-band-cheer strong{letter-spacing:-.01em;color:#4aa3ff;font-size:1.5rem;font-weight:800}.tl-band-cheer span:last-child{color:var(--ink);font-size:.95rem;font-weight:600}.tl-summary-list{flex-direction:column;gap:7px;display:flex}.tl-summary-row{background:var(--surface-2);border:1px solid var(--hairline);border-radius:9px;grid-template-columns:30px 1fr auto;align-items:center;gap:10px;padding:9px 11px;display:grid}.tl-summary-row.status-live{border-color:var(--success)}.tl-summary-row.status-pending{border-color:color-mix(in srgb, var(--win) 55%, var(--hairline))}.tl-sr-pending{color:var(--win);font-weight:700}.tl-summary-row.status-finished{opacity:.62}.tl-summary-row.fav{border-color:color-mix(in srgb, var(--accent) 60%, var(--hairline));background:var(--accent-bg)}.tl-sr-court{color:var(--ink-subtle);font-size:.78rem;font-weight:700}.tl-sr-teams{color:var(--ink);font-size:.92rem;line-height:1.25}.tl-sr-teams i{color:var(--ink-3);font-style:normal}.tl-sr-meta{color:var(--ink-subtle);white-space:nowrap;font-size:.8rem;font-weight:600}
