:root{--bg: #09090b;--surface: #131316;--surface-2: #1a1a1f;--surface-3: #222228;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--gold: #c9a84c;--gold-bright: #e4c76b;--gold-muted: rgba(201, 168, 76, .15);--text: #fafafa;--text-secondary: #a1a1aa;--text-dim: #71717a;--course: #60a5fa;--course-bg: rgba(96, 165, 250, .12);--charge: #ef5555;--charge-bg: rgba(239, 85, 85, .12);--ready: #4ade80;--ready-bg: rgba(74, 222, 128, .12);--danger: #f87171;--radius: 16px;--radius-md: 12px;--radius-sm: 8px;--font: "DM Sans", system-ui, sans-serif;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--scrollbar-track: #141418;--scrollbar-thumb: #3a3a42;--scrollbar-thumb-hover: #4f4f58}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:4px}*::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px;border:2px solid var(--scrollbar-track)}*::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}*::-webkit-scrollbar-corner{background:var(--scrollbar-track)}*::-webkit-scrollbar-button{display:none;width:0;height:0}.queue-list,.panel-grid,.modal-sheet{scrollbar-color:var(--scrollbar-thumb) var(--surface-2)}.queue-list::-webkit-scrollbar-track,.panel-grid::-webkit-scrollbar-track,.modal-sheet::-webkit-scrollbar-track{background:var(--surface-2)}.queue-list::-webkit-scrollbar-thumb,.panel-grid::-webkit-scrollbar-thumb,.modal-sheet::-webkit-scrollbar-thumb{border-color:var(--surface-2)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(201,168,76,.08),transparent),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(201,168,76,.04),transparent);pointer-events:none;z-index:0}#root{min-height:100dvh;position:relative;z-index:1}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.app{min-height:100dvh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1.25rem;background:#09090bd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.brand{display:flex;flex-direction:column;gap:.1rem}.brand-mark{font-size:1.125rem;font-weight:700;letter-spacing:.06em;color:var(--gold-bright)}.brand-sub{font-size:.7rem;font-weight:500;color:var(--text-dim);letter-spacing:.04em;text-transform:uppercase}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.125rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;transition:transform .12s ease,opacity .12s ease,background .12s ease}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-gold{background:var(--gold);color:#09090b}.btn-gold:hover:not(:disabled){background:var(--gold-bright)}.btn-ghost{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.dashboard{flex:1;width:100%;max-width:960px;margin:0 auto;padding:1rem 1.25rem 2rem;display:flex;flex-direction:column;gap:1.25rem}.status-overview{display:grid;grid-template-columns:repeat(14,1fr);gap:4px;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md)}@media(max-width:520px){.status-overview{grid-template-columns:repeat(7,1fr);gap:6px}}.status-pill{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;transition:transform .1s ease}.status-pill-num{font-size:.65rem;font-weight:700}@media(min-width:521px){.status-pill-num{font-size:.7rem}}.status-available{background:var(--gold-muted);border-color:#c9a84c40;color:var(--gold-bright)}.status-out{background:var(--course-bg);border-color:#60a5fa4d;color:var(--course)}.status-charging{background:var(--charge-bg);border-color:#ef555559;color:var(--charge)}.hero{display:grid;grid-template-columns:1fr auto;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:var(--surface);border:1px solid rgba(201,168,76,.25);border-radius:var(--radius);box-shadow:var(--shadow),inset 0 1px #ffffff0a}@media(max-width:560px){.hero{grid-template-columns:1fr}}.hero-eyebrow{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);margin-bottom:.25rem}.hero-number{font-size:4rem;font-weight:700;line-height:1;color:var(--gold-bright);font-variant-numeric:tabular-nums}.hero-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;min-width:160px;min-height:72px;padding:1rem 1.5rem;background:var(--gold);color:#09090b;border-radius:var(--radius-md);font-weight:700;transition:background .12s ease,transform .12s ease}.hero-action:hover:not(:disabled){background:var(--gold-bright)}.hero-action:active:not(:disabled){transform:scale(.98)}.hero-action:disabled{opacity:.45;cursor:not-allowed}.hero-action-label{font-size:.95rem}.hero-action-hint{font-size:.75rem;font-weight:500;opacity:.7}.hero-empty{grid-column:1 / -1}.hero-empty p{font-size:1.125rem;font-weight:600;color:var(--text-secondary)}.hero-empty-hint{display:block;font-size:.8rem;color:var(--text-dim);margin-top:.25rem}.queue-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.section-head{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border)}.section-head h2{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.section-meta{font-size:.75rem;color:var(--text-dim);font-weight:500}.queue-list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.25rem;max-height:220px;overflow-y:auto}.queue-item{display:flex;align-items:center;gap:.35rem;padding:.5rem .75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:600}.queue-item--next{background:var(--gold-muted);border-color:#c9a84c66}.queue-rank{font-size:.65rem;font-weight:700;color:var(--text-dim);min-width:1rem;text-align:center}.queue-item--next .queue-rank{color:var(--gold)}.queue-id{font-size:1.125rem;font-variant-numeric:tabular-nums;min-width:1.25rem;text-align:center}.queue-item--next .queue-id{color:var(--gold-bright)}.queue-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);background:#c9a84c33;padding:.15rem .4rem;border-radius:4px}.queue-empty{padding:2rem 1.25rem;text-align:center}.queue-empty p{font-weight:600;color:var(--text-secondary)}.queue-empty span{display:block;font-size:.8rem;color:var(--text-dim);margin-top:.25rem}.panels{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:640px){.panels{grid-template-columns:1fr}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;min-height:180px}.panel--out{border-top:2px solid var(--course)}.panel--charging{border-top:2px solid var(--charge)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border)}.panel-header h2{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.panel--out .panel-header h2{color:var(--course)}.panel--charging .panel-header h2{color:var(--charge)}.panel-count{font-size:.75rem;font-weight:700;color:var(--text-dim);background:var(--surface-2);padding:.15rem .5rem;border-radius:999px}.panel-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;font-size:.875rem;color:var(--text-dim)}.panel-grid{list-style:none;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;flex:1;overflow-y:auto;max-height:320px}.panel-card{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.panel-card-num{font-size:1.25rem;font-weight:700;min-width:2rem;text-align:center;font-variant-numeric:tabular-nums}.panel--out .panel-card-num{color:var(--course)}.panel--charging .panel-card-num{color:var(--charge)}.panel-card-actions{flex:1;display:flex;gap:.5rem}.panel-btn{flex:1;padding:.625rem .5rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;transition:background .12s ease,transform .1s ease}.panel-btn:active:not(:disabled){transform:scale(.98)}.panel-btn:disabled{opacity:.45;cursor:not-allowed}.panel-btn--ready{background:var(--ready-bg);color:var(--ready);border:1px solid rgba(74,222,128,.25)}.panel-btn--ready:hover:not(:disabled){background:#4ade8033}.panel-btn--charge{background:var(--charge-bg);color:var(--charge);border:1px solid rgba(239,85,85,.3)}.panel-btn--charge:hover:not(:disabled){background:#ef555538}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0;animation:fadeIn .2s ease}@media(min-width:560px){.modal-backdrop{align-items:center;padding:1rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;max-height:92dvh;overflow-y:auto;animation:sheetUp .25s ease}@media(min-width:560px){.modal-sheet{border-radius:var(--radius)}}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(min-width:560px){@keyframes sheetUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}}.modal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.25rem 0}.modal-top h2{font-size:1.125rem;font-weight:700}.modal-top p{font-size:.8rem;color:var(--text-dim);margin-top:.25rem;line-height:1.4}.modal-close{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--surface-2);color:var(--text-secondary);font-size:1.25rem;line-height:1;flex-shrink:0}.modal-close:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.modal-lineup{margin:1rem 1.25rem;padding:.875rem 1rem;background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--radius-md);min-height:3.25rem}.lineup-placeholder{font-size:.85rem;color:var(--text-dim)}.lineup-track{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.lineup-chip{display:inline-flex;align-items:center;gap:.35rem;font-size:1.125rem;font-weight:700;padding:.25rem .6rem;background:var(--surface-3);border-radius:6px;color:var(--text-secondary)}.lineup-chip--first{background:var(--gold);color:#09090b}.lineup-arrow{font-size:.75rem;color:var(--text-dim);font-weight:400}.modal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;padding:0 1.25rem 1rem}@media(max-width:400px){.modal-grid{grid-template-columns:repeat(5,1fr)}}.pick-btn{aspect-ratio:1;position:relative;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);font-size:1.125rem;font-weight:700;color:var(--text);transition:all .1s ease}.pick-btn:hover:not(:disabled){border-color:var(--gold);background:var(--surface-3)}.pick-btn--on{background:var(--gold);color:#09090b;border-color:var(--gold)}.pick-btn--locked{opacity:.25;cursor:not-allowed}.pick-rank{position:absolute;top:2px;right:2px;font-size:.55rem;font-weight:700;background:#09090b;color:var(--gold-bright);width:1rem;height:1rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.pick-btn--on .pick-rank{background:#00000059;color:#fff}.modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;padding:1rem 1.25rem;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--surface)}.screen-message{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;color:var(--text-secondary)}.screen-message--error{color:var(--danger)}.spinner{width:2rem;height:2rem;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.busy-bar{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);z-index:200;animation:busyPulse .8s ease infinite}@keyframes busyPulse{0%,to{opacity:.4}50%{opacity:1}}.toast{position:fixed;bottom:max(1.25rem,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);max-width:calc(100% - 2rem);padding:.75rem 1.25rem;background:var(--surface-2);border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;z-index:200;box-shadow:var(--shadow);animation:fadeIn .2s ease}
