:root{color-scheme:light;--bg: #fafafa;--bg-elevated: #ffffff;--bg-muted: #f4f4f5;--bg-subtle: #fafafa;--fg: #18181b;--fg-muted: #71717a;--fg-subtle: #a1a1aa;--border: rgba(24, 24, 27, .08);--border-strong: rgba(24, 24, 27, .12);--accent: #18181b;--accent-hover: #27272a;--focus: rgba(59, 130, 246, .45);--danger-bg: #fef2f2;--danger-border: rgba(239, 68, 68, .25);--danger-fg: #b91c1c;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .08);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--tabular: ui-monospace, "SF Mono", Menlo, Monaco, Consolas, monospace}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font);font-feature-settings:"cv02","cv03","cv04","cv11";background:var(--bg);display:flex;align-items:stretch;justify-content:center;color:var(--fg);-webkit-font-smoothing:antialiased}#root{flex:1;display:flex;justify-content:center;padding:var(--space-6) var(--space-5)}.app-shell{width:100%;max-width:1160px;margin-inline:auto;display:flex;flex-direction:column;gap:var(--space-6)}.app-masthead{padding-bottom:var(--space-5);border-bottom:1px solid var(--border)}.app-masthead-inner{display:flex;flex-direction:column;gap:var(--space-3);max-width:52ch}.app-eyebrow{margin:0;font-size:.6875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-subtle)}.app-title-row{display:flex;align-items:flex-start;gap:var(--space-3)}.app-title-block{min-width:0}.app-title{margin:0;font-size:clamp(1.5rem,2.5vw,1.75rem);font-weight:600;letter-spacing:-.035em;line-height:1.15;color:var(--fg)}.ball-glyph{width:22px;height:22px;border-radius:999px;background:radial-gradient(circle at 32% 28%,#fafafa,#e4e4e7);border:1.5px solid var(--border-strong);box-shadow:var(--shadow-sm);position:relative;flex-shrink:0}.ball-glyph:before,.ball-glyph:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:999px;border:1px solid rgba(24,24,27,.2);border-top-color:transparent;border-left-color:transparent}.ball-glyph:after{transform:rotate(120deg)}.app-subtitle{margin:var(--space-2) 0 0;font-size:.9375rem;line-height:1.5;color:var(--fg-muted);max-width:42ch}.workspace{display:grid;grid-template-columns:minmax(0,340px) minmax(0,1fr);align-items:stretch;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm);overflow:hidden;min-height:min(70vh,720px)}.workspace-panel{display:flex;flex-direction:column;min-height:0;padding:var(--space-6)}.workspace-panel--config{background:var(--bg-muted);border-right:1px solid var(--border)}.workspace-panel--output{background:var(--bg-elevated);flex:1 1 auto;min-height:0;overflow:hidden}@media(max-width:980px){#root{padding:var(--space-4) var(--space-3)}.workspace{grid-template-columns:minmax(0,1fr);min-height:unset}.workspace-panel--config{border-right:none;border-bottom:1px solid var(--border)}.schedule-status{align-items:flex-start;text-align:left;max-width:none}.meta-chips{justify-content:flex-start}}.config-form{display:flex;flex-direction:column;flex:1;min-height:0}.section-head{margin-bottom:var(--space-5)}.section-eyebrow{margin:0 0 var(--space-1);font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-subtle)}.section-title{margin:0 0 var(--space-2);font-size:1.125rem;font-weight:600;letter-spacing:-.025em;line-height:1.25;color:var(--fg)}.section-lede{margin:0;font-size:.8125rem;line-height:1.5;color:var(--fg-muted);max-width:40ch}.section-head--schedule{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-5);flex-wrap:wrap;margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}.section-head-main{flex:1;min-width:min(100%,240px)}.schedule-status{flex-shrink:0;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2);max-width:280px}.schedule-status-line{margin:0;font-size:.8125rem;color:var(--fg-muted);line-height:1.4}.schedule-status-strong{font-weight:600;color:var(--fg)}.schedule-status-sep{margin:0 .35em;color:var(--fg-subtle)}.schedule-status-placeholder{margin:0;font-size:.8125rem;color:var(--fg-subtle);font-style:normal}.meta-chips{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:var(--space-2)}.meta-chip{display:inline-block;padding:3px 10px;border-radius:6px;font-size:.6875rem;font-weight:500;letter-spacing:.02em;color:var(--fg-muted);background:var(--bg-muted);border:1px solid var(--border)}.form-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:var(--space-4);margin-bottom:var(--space-3)}@media(max-width:640px){.option-grid,.option-grid-duration{grid-template-columns:repeat(3,minmax(0,1fr))}}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:.8125rem;font-weight:500;letter-spacing:0;text-transform:none;color:var(--fg-muted)}.form-hint{font-size:.8125rem;line-height:1.45;color:var(--fg-muted)}.option-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-2)}.option-grid-duration{grid-template-columns:repeat(4,minmax(0,1fr))}.option-tile{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--bg-elevated);color:var(--fg);border-radius:var(--radius-md);height:52px;font-size:1.125rem;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease,transform .08s ease}.option-tile:hover{border-color:var(--border-strong);background:var(--bg-muted)}.option-tile:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.option-tile:active{transform:translateY(1px)}.option-tile.is-active{background:var(--accent);color:#fafafa;border-color:var(--accent);box-shadow:var(--shadow-sm)}.players-field{margin-top:var(--space-1)}.players-editor{border-radius:var(--radius-md);background:var(--bg-muted);display:flex;flex-direction:column;gap:var(--space-2)}.players-editor-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--space-2)}.players-chip-list{display:flex;flex-wrap:wrap;gap:var(--space-2);max-height:160px;overflow-y:auto;border-radius:var(--radius-sm);padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border)}.players-empty{color:var(--fg-subtle);font-size:.8125rem}.player-chip{display:inline-flex;align-items:center;gap:6px;border-radius:999px;border:1px solid var(--border);background:var(--bg-muted);color:var(--fg);padding:5px 10px;font-size:.8125rem;font-weight:500}.player-chip-remove{border:0;background:transparent;color:var(--fg-muted);cursor:pointer;border-radius:999px;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:.875rem;line-height:1}.player-chip-remove:hover{background:#18181b14;color:var(--fg)}.form-actions{margin-top:var(--space-4);display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;border-radius:var(--radius-sm);height:40px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;font-size:.875rem;font-weight:500;letter-spacing:-.01em;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .08s ease}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.btn:active:not(:disabled){transform:translateY(1px)}.btn-default{background:var(--accent);border-color:var(--accent);color:#fafafa;box-shadow:var(--shadow-sm)}.btn-default:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-outline{background:var(--bg-elevated);border-color:var(--border-strong);color:var(--fg)}.btn-outline:hover:not(:disabled){background:var(--bg-muted);border-color:#18181b33}.btn-ghost{background:transparent;border-color:transparent;color:var(--fg-muted)}.btn-ghost:hover:not(:disabled){background:var(--bg-muted);color:var(--fg)}.players-count{font-size:.8125rem;color:var(--fg-muted)}.error-banner{margin-top:var(--space-3);border-radius:var(--radius-md);padding:10px 12px;background:var(--danger-bg);border:1px solid var(--danger-border);font-size:.8125rem;color:var(--danger-fg);display:flex;align-items:center;gap:var(--space-2)}.error-dot{width:6px;height:6px;border-radius:999px;background:#ef4444;flex-shrink:0}.loading-text{margin-top:var(--space-3);font-size:.8125rem;color:var(--fg-muted);display:inline-flex;align-items:center;gap:var(--space-2)}.loading-orb{width:10px;height:10px;border-radius:999px;border:2px solid var(--border-strong);border-top-color:var(--fg);animation:spin .85s linear infinite}.schedule-content{flex:1;min-height:0;display:flex;flex-direction:column;gap:var(--space-3);overflow:auto}.schedule-board{min-width:840px;display:flex;flex-direction:column;gap:var(--space-3)}.schedule-grid-header,.schedule-grid-row{display:grid;grid-template-columns:minmax(88px,104px) repeat(var(--court-count, 2),minmax(200px,1fr)) minmax(120px,180px);gap:var(--space-3);align-items:stretch}.schedule-board{--court-count: 2}.schedule-time-label,.court-header-card{text-transform:none;letter-spacing:.02em;font-size:.6875rem;font-weight:600;color:var(--fg-subtle);display:flex;align-items:center;padding-left:2px;min-width:0;font-family:var(--font);font-style:normal}.schedule-grid-header .schedule-time-label,.schedule-grid-header .court-header-card{min-height:44px;align-items:flex-end;padding-bottom:var(--space-1)}.time-pill{border-radius:var(--radius-md);background:var(--bg-muted);border:1px solid var(--border);box-shadow:none;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--space-2);min-height:132px;min-width:0;text-align:center;padding:var(--space-3) var(--space-2)}.time-pill-main{font-size:1rem;font-weight:600;color:var(--fg);letter-spacing:-.02em;line-height:1.25;max-width:100%;font-family:var(--tabular)}.time-range{display:inline-flex;flex-wrap:wrap;align-items:baseline;justify-content:center;gap:.2em;column-gap:.25em}.time-range time{font-variant-numeric:tabular-nums}.time-range-sep{color:var(--fg-subtle);font-weight:500;flex-shrink:0}.session-start-input{max-width:200px}.time-pill-sub{text-transform:none;font-size:.6875rem;letter-spacing:.06em;font-weight:600;color:var(--fg-subtle)}.court-slot-card{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm);min-height:132px;padding:var(--space-3);display:flex;flex-direction:column;justify-content:center;gap:var(--space-2)}.team-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-2)}.player-pill{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-muted);min-height:38px;display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-2);font-size:.9375rem;font-weight:600;letter-spacing:-.02em;color:var(--fg);cursor:pointer;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease}.schedule-board .player-pill.is-highlighted,.schedule-board .bench-chip.is-highlighted{outline:2px solid #3b82f6;outline-offset:0;background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.schedule-board .bench-chip.is-highlighted{border:1px solid #bfdbfe}.versus-pill{text-transform:uppercase;letter-spacing:.14em;font-size:.6875rem;color:var(--fg-subtle);font-weight:600;text-align:center}.court-slot-card.is-empty{justify-content:center;align-items:center;text-align:center;gap:var(--space-2);background:var(--bg-subtle)}.empty-label{text-transform:none;letter-spacing:.02em;font-size:.8125rem;color:var(--fg-subtle);font-weight:500}.bench-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2)}.bench-chip{border-radius:999px;background:var(--bg-muted);color:var(--fg-muted);font-size:.75rem;font-weight:500;padding:5px 9px;cursor:pointer;border:1px solid var(--border);transition:background .12s ease,border-color .12s ease}.bench-column-cell{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm);min-height:132px;min-width:0;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.bench-chips-column{justify-content:center;max-width:100%}.bench-empty{color:var(--fg-subtle);font-size:1rem;font-weight:500;font-family:var(--tabular)}.schedule-empty{border-radius:var(--radius-md);border:1px dashed var(--border-strong);padding:var(--space-5) var(--space-4);font-size:.875rem;line-height:1.5;color:var(--fg-muted);text-align:center;background:var(--bg-subtle)}.export-bar{margin-top:auto;padding-top:var(--space-4);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.export-bar-label{font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-subtle)}.export-bar-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}@media(max-width:1100px){.schedule-grid-header,.schedule-grid-row{grid-template-columns:minmax(80px,96px) repeat(var(--court-count, 2),minmax(180px,1fr)) minmax(100px,140px);gap:10px}.time-pill-main{font-size:.9375rem}.player-pill{font-size:.875rem}}.input-control{display:flex;width:100%;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-elevated);padding:0 12px;font-size:.875rem;font-weight:400;color:var(--fg);font-family:inherit;box-shadow:var(--shadow-sm);transition:border-color .15s ease,box-shadow .15s ease}.input-control::placeholder{color:var(--fg-subtle)}.input-control:hover:not(:disabled){border-color:#18181b2e}.input-control:focus-visible{outline:none;border-color:#18181b59;box-shadow:var(--shadow-sm),0 0 0 3px var(--focus)}.input-control:disabled{opacity:.5;cursor:not-allowed}@keyframes spin{to{transform:rotate(360deg)}}
