:root{--bg-primary: #0A0F0D;--bg-secondary: #11171A;--bg-card: #11171A;--bg-card-hover: #161D20;--bg-input: #0A0F0D;--surface-2: #161D20;--surface-3: #1B2326;--border: rgba(242, 234, 211, .08);--border-light: rgba(242, 234, 211, .16);--line: rgba(242, 234, 211, .08);--line-strong: rgba(242, 234, 211, .16);--text-primary: #F2EAD3;--text-secondary: #B6BFB9;--text-muted: #7A8580;--ivory: #F2EAD3;--cloth: #0E5A3E;--cloth-bright: #1FAA64;--cloth-soft: rgba(31, 170, 100, .12);--accent: #1FAA64;--accent-hover: #0E5A3E;--accent-muted: rgba(31, 170, 100, .12);--brass: #C49A4E;--brass-soft: rgba(196, 154, 78, .14);--mahogany: #3D2A1E;--ivory-soft: rgba(242, 234, 211, .08);--danger: #D14A3D;--danger-muted: rgba(209, 74, 61, .14);--warning: #E2A23E;--warning-muted: rgba(226, 162, 62, .14);--info: #1FAA64;--info-muted: rgba(31, 170, 100, .12);--foul: #D14A3D;--radius-sm: 4px;--radius-md: 12px;--radius-lg: 20px;--radius-pill: 9999px;--shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 1px 2px rgba(0,0,0,.4);--shadow-2: 0 8px 32px rgba(0,0,0,.5);--downlight: radial-gradient(80% 60% at 50% 0%, rgba(31,170,100,.18), transparent 60%);--transition: .18s cubic-bezier(.2, .8, .2, 1);--ease-out: cubic-bezier(.2, .8, .2, 1);--ease-in: cubic-bezier(.6, 0, .8, .4);--font-display: "Fraunces", ui-serif, Georgia, serif;--font-body: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Geist Mono", ui-monospace, "JetBrains Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font-body);background:var(--bg-primary);background-image:radial-gradient(circle at 25% 10%,rgba(31,170,100,.04),transparent 50%),radial-gradient(circle at 75% 90%,rgba(196,154,78,.03),transparent 50%);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;color:var(--ivory);line-height:1.1}h1{font-size:28px;font-variation-settings:"opsz" 36}h2{font-size:22px;font-variation-settings:"opsz" 36;font-weight:500}h3{font-size:16px;font-variation-settings:"opsz" 24;font-weight:500}.stat-value,code,.num,.data-table td.num{font-feature-settings:"tnum" 1}.stat-value{font-family:var(--font-display);font-variation-settings:"opsz" 72;letter-spacing:-.03em}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;min-width:0;display:flex;flex-direction:column}.page-content{flex:1;padding:28px 32px;overflow-y:auto}.page-header{margin-bottom:28px}.page-header h1{font-size:1.7rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:.95rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:28px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;margin-bottom:28px}.table-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:22px;transition:border-color var(--transition)}.card:hover{border-color:var(--border-light)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-header h3{font-size:1rem;font-weight:600;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;border:none;transition:all var(--transition)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-icon{padding:8px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary)}.btn-icon:hover{border-color:var(--border-light);color:var(--text-primary)}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;transition:border-color var(--transition)}.form-input:focus{outline:none;border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}.toggle{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;cursor:pointer;transition:background var(--transition);border:none}.toggle.active{background:var(--accent)}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform var(--transition)}.toggle.active:after{transform:translate(20px)}.search-bar{position:relative;margin-bottom:20px}.search-bar input{width:100%;padding:10px 14px 10px 40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem}.search-bar input:focus{outline:none;border-color:var(--accent)}.search-bar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1rem}.activity-feed{display:flex;flex-direction:column;gap:2px}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:7px;flex-shrink:0}.activity-dot.match_started{background:var(--accent)}.activity-dot.match_ended{background:var(--info)}.activity-dot.table_activated{background:var(--warning)}.activity-dot.player_joined{background:var(--accent)}.activity-dot.device_alert{background:var(--danger)}.activity-message{flex:1;font-size:.9rem;color:var(--text-primary)}.activity-time{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:10px 14px;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.data-table td{padding:12px 14px;font-size:.9rem;border-bottom:1px solid var(--border)}.data-table tr:hover td{background:var(--bg-card-hover)}.heatmap-grid{display:grid;gap:3px}.heatmap-cell{border-radius:3px;aspect-ratio:1;min-width:20px}.section{margin-bottom:28px}.section-title{font-size:1.05rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.leaderboard-row{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px}.leaderboard-rank{font-size:1.1rem;font-weight:700;color:var(--text-muted);width:28px;text-align:center}.leaderboard-rank.top-3{color:var(--accent)}.leaderboard-name{flex:1;font-weight:500}.leaderboard-stat{font-weight:600;color:var(--accent)}@media(max-width:1024px){.page-content{padding:20px}.chart-grid{grid-template-columns:1fr}}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.table-grid{grid-template-columns:1fr}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary)}.login-card{width:100%;max-width:400px;padding:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:6px}.login-card .subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:.95rem}.login-error{padding:10px 14px;background:var(--danger-muted);border:1px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger);font-size:.9rem;margin-bottom:16px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.telemetry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}.telemetry-item{padding:16px;background:var(--bg-secondary);border-radius:var(--radius-sm);text-align:center}.telemetry-value{font-size:1.5rem;font-weight:700;color:var(--accent)}.telemetry-label{font-size:.8rem;color:var(--text-muted);margin-top:4px}.timer-controls{display:flex;align-items:center;gap:12px;margin-top:12px}.settings-section{margin-bottom:32px}.settings-section h2{font-size:1.15rem;font-weight:600;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.settings-row label{font-size:.95rem;color:var(--text-primary)}.settings-row .description{font-size:.82rem;color:var(--text-muted);margin-top:2px}@media(max-width:1024px){.detail-grid{grid-template-columns:1fr}}.page{padding:24px;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.page-header h1{margin:0}.toolbar{margin-bottom:12px}.input{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary)}.btn{padding:8px 14px;border:0;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:var(--transition)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-sm{padding:4px 8px;font-size:12px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px}.stat-label{color:var(--text-muted);text-transform:uppercase;font-size:12px}.stat-value{font-size:32px;font-weight:600;margin:8px 0}.stat-link{color:var(--accent);text-decoration:none;font-size:13px}.stat-sub{font-size:12px;margin-top:2px}.highlights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:12px}.highlight-tile{display:flex;flex-direction:column;gap:8px;padding:12px}.highlight-tile-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.highlight-tile-time{font-size:12px}.highlight-tile-video{aspect-ratio:16 / 9;background:var(--bg-secondary);border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center}.highlight-tile-video video{width:100%;height:100%;object-fit:contain}.highlight-tile-meta{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:13px}.highlight-tile-player{font-weight:600}.highlight-tile-actions{display:flex;gap:8px}.highlight-tile-actions .btn{flex:1}.badge-shot{background:#95a5a626;color:#95a5a6}.badge-break{background:var(--brass-soft);color:var(--brass)}.badge-frame_end{background:var(--cloth-soft);color:var(--cloth-bright)}.badge-foul{background:var(--danger-muted);color:var(--foul)}.credential-modal{min-width:480px}.credential-display{background:var(--bg-secondary);padding:12px;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;word-break:break-all;white-space:pre-wrap;border:1px solid var(--accent);color:var(--text-primary);margin:12px 0}.data-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden}.data-table th,.data-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.data-table th{background:var(--bg-secondary);font-size:12px;text-transform:uppercase;color:var(--text-muted)}.data-table tr:last-child td{border-bottom:0}.data-table a{color:var(--text-primary);text-decoration:none}.data-table a:hover{color:var(--accent)}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;text-transform:uppercase}.badge-guest,.badge-draft{background:var(--info-muted);color:var(--info)}.badge-member,.badge-active,.badge-open,.badge-yes{background:var(--accent-muted);color:var(--accent)}.badge-vip,.badge-complete{background:#9b59b626;color:#b794d8}.badge-cancelled,.badge-no{background:var(--danger-muted);color:var(--danger)}.badge-maybe,.badge-closed{background:var(--warning-muted);color:var(--warning)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-card);padding:24px;border-radius:var(--radius-lg);min-width:400px;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}.modal h2{margin-top:0}.modal label{display:block;margin:12px 0;color:var(--text-secondary);font-size:13px}.modal label input,.modal label textarea,.modal label select{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);margin-top:4px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.list{list-style:none;padding:0;margin:12px 0}.list li{padding:8px 0;border-bottom:1px solid var(--border)}.list li:last-child{border-bottom:0}.list a{color:var(--text-primary);text-decoration:none}.list a:hover{color:var(--accent)}.muted{color:var(--text-muted)}.error{background:var(--danger-muted);color:var(--danger);padding:8px 12px;border-radius:var(--radius-sm);margin:8px 0}.hint{color:var(--text-muted);font-size:13px}.back-link{color:var(--text-muted);text-decoration:none;font-size:14px}.back-link:hover{color:var(--text-primary)}.card{background:var(--bg-card);padding:20px;border-radius:var(--radius-md);margin-bottom:16px}.card.highlight{border:1px solid var(--accent)}.kv{display:grid;grid-template-columns:140px 1fr;gap:8px 16px}.kv dt{color:var(--text-muted)}.token{display:block;background:var(--bg-input);padding:8px 12px;border-radius:var(--radius-sm);word-break:break-all;font-family:monospace;font-size:12px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{background:var(--bg-card);padding:32px;border-radius:var(--radius-lg);min-width:360px;box-shadow:var(--shadow)}.login-card label{display:block;margin:12px 0;color:var(--text-secondary)}.login-card input{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);margin-top:4px}.login-card button{width:100%;margin-top:16px}.bracket{display:flex;gap:24px;overflow-x:auto;padding:16px 0}.bracket-round{min-width:220px}.bracket-round h3{color:var(--text-muted);font-size:13px;text-transform:uppercase;margin-bottom:12px}.match-card{background:var(--bg-input);border-radius:var(--radius-sm);padding:8px;margin-bottom:12px;border:1px solid var(--border)}.match-card.match-complete{opacity:.7}.slot{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.slot.winner{color:var(--accent);font-weight:600}.score-input{width:100%;margin-top:4px;padding:4px 8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px}.score{color:var(--text-muted);font-size:12px;margin-top:4px;text-align:center}.seed{color:var(--text-muted);font-size:11px}.sidebar{width:220px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:100vh;padding:18px 12px;box-sizing:border-box}.sidebar-brand{font-size:18px;font-weight:700;padding:6px 12px 18px;letter-spacing:-.02em}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px}.nav-item{display:block;padding:9px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:14px;transition:var(--transition)}.nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.nav-item.nav-item-active{background:var(--accent-muted);color:var(--accent);font-weight:600}.sidebar-footer{padding-top:14px;margin-top:14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.user-info{padding:0 6px}.user-name{font-size:14px;font-weight:500;color:var(--text-primary)}.user-role{font-size:12px;color:var(--text-muted);text-transform:capitalize}.sidebar-footer .btn{width:100%;text-align:center}
