*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0e1a;--surface: #111827;--border: #1e293b;--text: #e2e8f0;--muted: #64748b;--green: #22c55e;--red: #ef4444;--blue: #3b82f6;--yellow: #facc15;--radius: 10px}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:14px}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border)}.header-left{display:flex;align-items:center;gap:12px}.logo{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#1d4ed8,#22c55e);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:#fff}.brand{font-size:18px;font-weight:800;letter-spacing:.05em;color:#fff}.brand-ai{color:var(--yellow)}.brand-sub{font-size:11px;color:var(--yellow);letter-spacing:.04em}.header-stats{display:flex;gap:10px}.stat-chip{padding:6px 14px;border-radius:8px;background:#1e293b;border:1px solid var(--border);text-align:center;min-width:90px}.stat-chip.stat-accent{border-color:var(--blue);background:#1e3a5f}.stat-value{font-size:18px;font-weight:700;color:#fff;line-height:1.2}.stat-label{font-size:10px;color:var(--muted);margin-top:2px;white-space:nowrap}.main{display:grid;grid-template-rows:auto auto auto;gap:0;max-width:1280px;margin:0 auto;padding:16px}.video-section{width:100%}.video-wrap{position:relative;background:#000;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9;width:100%}.main-video{width:100%;height:100%;object-fit:contain;display:block}.video-label{position:absolute;bottom:10px;left:12px;background:#0009;color:#aaa;font-size:11px;font-weight:600;letter-spacing:.08em;padding:3px 8px;border-radius:4px}.court-map-section{margin-top:16px}.court-map{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px}.court-map-title{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.court-map-empty{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center;color:var(--muted);font-size:13px}.court-grid{display:grid;grid-template-columns:repeat(var(--cols, 2),1fr);gap:12px}.court-card{border-radius:var(--radius);padding:14px;border:2px solid;transition:all .3s ease}.court-free{background:#0d2218;border-color:#166534}.court-occupied{background:#1a1a3a;border-color:#1d4ed8}.court-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.court-name{font-size:13px;font-weight:700;color:#fff}.court-badge{font-size:10px;font-weight:700;letter-spacing:.06em;padding:3px 8px;border-radius:20px}.badge-free{background:#14532d;color:var(--green)}.badge-occ{background:#1e3a8a;color:#93c5fd}.court-icon{display:flex;justify-content:center;margin:8px 0}.court-svg{width:100%;max-width:160px;height:auto}.court-persons{text-align:center;margin-top:6px;font-size:12px}.persons-count{color:#93c5fd;display:flex;align-items:center;justify-content:center;gap:5px;font-weight:600}.persons-none{color:var(--muted)}.person-icon{color:currentColor}.metrics-panel{margin-top:16px}.tabs{display:flex;gap:4px;margin-bottom:12px}.tab{padding:7px 16px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;font-size:13px;transition:all .2s}.tab:hover{color:var(--text);border-color:#334155}.tab.active{background:#1e3a5f;color:#93c5fd;border-color:var(--blue)}.tab-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.section-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.week-section+.week-section{margin-top:20px}.timelines-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.timeline-wrap{background:#1e293b;border-radius:8px;padding:10px 12px}.timeline-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.timeline-label{font-size:12px;font-weight:600;color:var(--text)}.timeline-hours-today{font-size:11px;color:var(--muted)}.timeline-bar{position:relative;height:14px;background:#0f172a;border-radius:4px;overflow:hidden}.timeline-block{position:absolute;top:0;height:100%;background:var(--blue);opacity:.85;border-radius:2px}.timeline-hours-row{display:flex;justify-content:space-between;margin-top:4px;font-size:9px;color:var(--muted)}.heatmap-wrap{overflow-x:auto}.heatmap-grid{display:grid;grid-template-columns:44px repeat(16,1fr);gap:3px}.heatmap-cell{height:22px;border-radius:3px;min-width:18px;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--muted)}.heatmap-label{font-size:10px;color:var(--muted);display:flex;align-items:center;padding-right:4px}@media(max-width:900px){.header{flex-direction:column;gap:10px;align-items:flex-start}.header-stats{flex-wrap:wrap}.timelines-grid{grid-template-columns:1fr}.court-grid{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:600px){.court-grid{grid-template-columns:1fr!important}.main{padding:10px}}
