.course-setup{min-height:100dvh;display:flex;flex-direction:column;position:relative;z-index:1}.course-setup-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:#09090bd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-wrap:wrap}.course-setup-brand{display:flex;align-items:center;gap:.75rem}.course-setup-brand h1{font-size:1.125rem;font-weight:600}.course-setup-back{color:var(--text-secondary);text-decoration:none;font-size:.875rem}.course-setup-back:hover{color:var(--gold)}.course-setup-badge{font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:999px;background:var(--gold-muted);color:var(--gold)}.course-setup-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.course-setup-saving{font-size:.8125rem;color:var(--text-dim)}.course-setup-upload{cursor:pointer}.course-setup-empty{flex:1;display:grid;place-items:center;padding:2rem}.course-setup-empty-card{max-width:28rem;text-align:center;padding:2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.course-setup-empty-card h2{margin-bottom:.5rem}.course-setup-empty-card p{color:var(--text-secondary);margin-bottom:1.25rem}.course-setup-workspace{flex:1;display:grid;grid-template-columns:1fr min(22rem,100%);gap:0;min-height:0}.course-setup-main{padding:1rem 1.25rem 1.5rem;overflow:auto;min-width:0}.course-setup-hint{margin-bottom:.75rem;padding:.65rem .9rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem}.course-setup-legend{display:flex;flex-wrap:wrap;gap:1rem 1.25rem;list-style:none;margin-top:.75rem;font-size:.8125rem;color:var(--text-dim)}.course-setup-legend li{display:flex;align-items:center;gap:.4rem}.legend-swatch{width:1.25rem;height:3px;border-radius:2px}.legend-swatch--tee-green{background:#4ade80}.legend-swatch--green-tee{background:#fbbf24}.legend-dot{width:.65rem;height:.65rem;border-radius:50%}.legend-dot--tee{background:#4ade80;box-shadow:0 0 0 2px #4ade8059}.legend-dot--green{background:#f472b6;box-shadow:0 0 0 2px #f472b659}.course-setup-legend-nav{width:100%;color:var(--text-dim);font-size:.75rem}.course-setup-legend kbd{font:inherit;font-size:.6875rem;padding:.1rem .35rem;border-radius:4px;border:1px solid var(--border-strong);background:var(--surface-3);color:var(--text-secondary)}.course-canvas{position:relative;display:inline-block;max-width:100%;line-height:0}.course-canvas-viewport{position:relative;overflow:hidden;max-width:100%;width:100%;max-height:min(75vh,900px);min-height:280px;border-radius:var(--radius-md);border:1px solid var(--border-strong);box-shadow:var(--shadow);background:var(--surface-2);cursor:crosshair;touch-action:none}.course-canvas-viewport.is-navigating{cursor:grab}.course-canvas-viewport.is-panning{cursor:grabbing}.course-canvas-inner{transform-origin:0 0;position:relative;will-change:transform}.course-canvas-img{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none;pointer-events:none}.course-canvas-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.course-canvas-toolbar{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;font-size:.8125rem;color:var(--text-dim)}.course-canvas-zoom{font-variant-numeric:tabular-nums}.btn-sm{padding:.35rem .65rem;font-size:.8125rem}.course-canvas-lock{position:absolute;top:0;right:0;bottom:0;left:0;background:#09090b80;border-radius:var(--radius-md)}.course-path{stroke-width:4;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.course-path--tee-green{stroke:#4ade80}.course-path--green-tee{stroke:#fbbf24}.course-path--preview{stroke-dasharray:8 6;opacity:.85}.course-marker{vector-effect:non-scaling-stroke;stroke:#09090b;stroke-width:2}.course-marker--tee{fill:#4ade80}.course-marker--green{fill:#f472b6}.course-marker--waypoint{fill:#fafafa}.course-setup-sidebar{border-left:1px solid var(--border);background:var(--surface);padding:1rem;overflow:auto}.course-setup-sidebar h2{font-size:1rem;margin-bottom:.35rem}.course-setup-sidebar-note{font-size:.8125rem;color:var(--text-dim);margin-bottom:.75rem;line-height:1.45}.course-setup-hole-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.course-setup-hole{padding:.65rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2)}.course-setup-hole.active{border-color:var(--gold);box-shadow:0 0 0 1px #c9a84c40}.course-setup-hole-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.course-setup-par{display:flex;gap:.3rem;margin-bottom:.5rem}.course-setup-par-btn{flex:1;padding:.3rem .25rem;border-radius:6px;border:1px solid var(--border);background:var(--surface-3);color:var(--text-secondary);font:inherit;font-size:.6875rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.course-setup-par-btn:hover{border-color:var(--border-strong);color:var(--text)}.course-setup-par-btn.active{border-color:var(--gold);background:var(--gold-muted);color:var(--gold-bright)}.course-setup-hole-num{font-weight:600;font-size:.875rem}.course-setup-hole-status{font-size:.6875rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim)}.course-setup-hole-status--done{color:var(--ready)}.course-setup-hole-status--partial{color:var(--gold)}.course-setup-field{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.4rem;font-size:.75rem;color:var(--text-secondary)}.course-setup-field input{width:100%;padding:.4rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface-3);color:var(--text);font:inherit}.course-setup-field input:focus{outline:2px solid var(--gold-muted);border-color:var(--gold)}.course-setup-dev-only,.course-setup-error{padding:2rem;text-align:center;color:var(--text-secondary)}@media(max-width:900px){.course-setup-workspace{grid-template-columns:1fr}.course-setup-sidebar{border-left:none;border-top:1px solid var(--border);max-height:40vh}}.map-view{height:100dvh;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1}.map-view-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);background:#09090bd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-view-brand{display:flex;align-items:center;gap:.75rem}.map-view-brand h1{font-size:1.125rem;font-weight:600}.map-view-back{color:var(--text-secondary);text-decoration:none;font-size:.875rem}.map-view-back:hover{color:var(--gold)}.map-view-badge{font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:999px;background:var(--course-bg);color:var(--course)}.map-view-workspace{flex:1;display:grid;grid-template-columns:1fr min(20rem,100%);min-height:0;overflow:hidden}.map-view-main{padding:1rem 1.25rem;min-width:0;min-height:0;overflow:hidden;display:flex;flex-direction:column;align-items:stretch}.map-canvas{flex:1;min-height:0;display:flex;flex-direction:column;width:100%;max-width:100%}.map-canvas-viewport{position:relative;overflow:hidden;flex:1;min-height:0;width:100%;border-radius:var(--radius-md);border:1px solid var(--border-strong);box-shadow:var(--shadow);background:var(--surface-2);cursor:grab;touch-action:none}.map-view-sidebar{display:flex;flex-direction:column;min-height:0;overflow:hidden;border-left:1px solid var(--border);background:var(--surface);padding:1rem}.map-view-sidebar-head{flex-shrink:0;margin-bottom:.75rem}.map-view-sidebar h2{font-size:1rem;margin-bottom:.35rem}.map-view-sidebar-note{font-size:.8125rem;color:var(--text-dim);line-height:1.45}.map-buggy-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;flex:1;min-height:0;overflow:auto;margin:0;padding-right:.15rem}.map-buggy-list::-webkit-scrollbar-track{background:var(--surface)}.map-buggy-list::-webkit-scrollbar-thumb{border-color:var(--surface)}.map-buggy-card{display:block;width:100%;padding:.75rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:inherit;font:inherit;text-align:left;cursor:pointer;transition:border-color .15s ease,background .15s ease}.map-buggy-card:hover{border-color:var(--border-strong);background:var(--surface-3)}.map-buggy-card--selected{border-color:var(--gold);box-shadow:0 0 0 1px #c9a84c4d}.map-buggy-card--staging{border-color:#c9a84c59;background:var(--gold-muted)}.map-buggy-card--paired{border-color:#60a5fa59}.map-buggy-card-body{display:flex;align-items:center;gap:.85rem}.map-buggy-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.map-buggy-card-num{font-weight:600;font-size:.875rem}.map-buggy-card-sent{font-size:.6875rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);font-weight:600}.map-buggy-card-time{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.map-buggy-card-hole{flex-shrink:0;min-width:4.75rem;font-size:1.35rem;font-weight:700;line-height:1.1;color:var(--course);text-align:center;letter-spacing:-.02em}.map-buggy-card--staging .map-buggy-card-hole{font-size:1rem;color:var(--gold)}.map-buggy-card--paired .map-buggy-card-hole{color:var(--course)}.map-canvas-viewport.is-panning{cursor:grabbing}.map-canvas-inner{transform-origin:0 0;position:relative;will-change:transform}.map-canvas-img{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none;pointer-events:none}.map-canvas-markers-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none;shape-rendering:geometricPrecision;text-rendering:geometricPrecision}.map-canvas-toolbar{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;font-size:.8125rem;color:var(--text-dim);flex-wrap:wrap;flex-shrink:0}.map-canvas-zoom{font-variant-numeric:tabular-nums}.map-canvas-hint kbd{font:inherit;font-size:.6875rem;padding:.1rem .35rem;border-radius:4px;border:1px solid var(--border-strong);background:var(--surface-3);color:var(--text-secondary)}.map-buggy-halo{fill:#c9a84c40;stroke:none}.map-buggy--staging .map-buggy-halo{fill:#c9a84c26;animation:map-buggy-pulse 2s ease-in-out infinite}.map-buggy-dot{fill:var(--gold);stroke:#09090b}.map-buggy--staging .map-buggy-dot{fill:var(--surface-3);stroke:var(--gold)}.map-buggy--staging-cluster .map-buggy-halo{fill:#c9a84c38}.map-buggy-label{font-weight:700;fill:#09090b;pointer-events:none;-webkit-user-select:none;user-select:none}.map-buggy-label--paired{letter-spacing:-.02em}.map-buggy-label--staging-cluster{letter-spacing:-.03em;fill:var(--gold-bright)}.map-buggy--staging .map-buggy-label{fill:var(--gold-bright)}.map-buggy--selected .map-buggy-halo{fill:#c9a84c73}.map-buggy--selected .map-buggy-dot{stroke:var(--gold-bright)}@keyframes map-buggy-pulse{0%,to{opacity:.6}50%{opacity:1}}@media(max-width:900px){.map-view{height:auto;min-height:100dvh;overflow:auto}.map-view-workspace{grid-template-columns:1fr;overflow:visible}.map-view-main{min-height:min(52vh,420px);overflow:visible}.map-canvas-viewport{min-height:min(48vh,380px)}.map-view-sidebar{max-height:none;overflow:visible}.map-buggy-list{overflow:visible}.map-view-sidebar{border-left:none;border-top:1px solid var(--border)}}: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}
