*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--f1-red: #e10600;--f1-dark: #15151e;--f1-gray: #38383f;--bg-body: #09090b;--bg-card: #111113;--bg-hover: rgba(39, 39, 42, .5);--bg-input: #1c1c1f;--border: #27272a;--border-subtle: rgba(39, 39, 42, .3);--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-faint: #52525b;--green: #22c55e;--red: #ef4444;--yellow: #eab308;--blue: #3b82f6;--purple: #a855f7;--amber: #f59e0b;--cyan: #06b6d4}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-body);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%}.app-layout{display:flex;height:100vh}.sidebar{display:none;flex-direction:column;width:14rem;background:var(--bg-card);border-right:1px solid var(--border);padding:1rem;gap:.25rem;flex-shrink:0}.main-content{flex:1;overflow:auto;padding:1rem 1rem 5rem}@media(min-width:768px){.sidebar{display:flex}.main-content{padding-bottom:1rem}.mobile-nav{display:none!important}}.sidebar-title{font-size:1.125rem;font-weight:700;color:var(--f1-red);margin-bottom:.5rem;text-align:center}.connection-indicator{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}.status-dot{width:.5rem;height:.5rem;border-radius:50%}.status-dot--connected{background:var(--green)}.status-dot--disconnected{background:var(--red)}.nav-item{display:block;padding:.5rem .75rem;border-radius:.375rem;font-size:.875rem;color:var(--text-secondary);text-decoration:none;transition:background .15s,color .15s}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item--active{color:var(--text-primary);background:var(--bg-input);font-weight:500}.mobile-nav{display:flex;justify-content:space-around;position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);padding:.5rem 0;z-index:50}.mobile-nav-item{font-size:.75rem;padding:.25rem .5rem;color:var(--text-secondary);text-decoration:none}.mobile-nav-item--active{color:var(--f1-red)}.card{background:var(--bg-card);border-radius:.5rem;border:1px solid var(--border);overflow:hidden}.card-padded{background:var(--bg-card);border-radius:.5rem;border:1px solid var(--border);padding:1rem}.page-title{font-size:1.25rem;font-weight:700;margin-bottom:1rem}.section-title{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:60vh;gap:.75rem}.coming-soon-car{font-size:4rem}.coming-soon-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.coming-soon-text{font-size:.875rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.login-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:2rem;width:100%;max-width:24rem}.login-title{font-size:1.5rem;font-weight:700;color:var(--f1-red);margin-bottom:.25rem}.login-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:1rem}input[type=text],input[type=password],textarea{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;color:var(--text-primary);font-family:inherit}textarea{resize:vertical;font-family:SF Mono,Fira Code,Cascadia Code,monospace}input:focus,textarea:focus{outline:none;border-color:var(--text-muted)}label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.btn{display:inline-block;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:background .15s;color:#fff}.btn--primary{background:var(--f1-red)}.btn--primary:hover{background:#b91c1c}.btn--secondary{background:#3f3f46}.btn--secondary:hover{background:#52525b}.btn:disabled{background:#3f3f46;color:var(--text-muted);cursor:not-allowed}.btn--full{width:100%}.alert{border-radius:.5rem;padding:.75rem;font-size:.875rem}.alert--error{background:#7f1d1d4d;border:1px solid #991b1b;color:#fca5a5}.alert--success{background:#14532d4d;border:1px solid #166534;color:#86efac}.leaderboard-container{max-width:64rem;margin:0 auto}.leaderboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.leaderboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-width:36rem}.standings-header{padding:.75rem;border-bottom:1px solid var(--border)}.standings-header--compact{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.25rem .5rem}.standings-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.live-badge{display:flex;align-items:center;gap:.25rem;font-size:10px;font-weight:600;color:var(--red);margin-left:.5rem;flex-shrink:0}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.standings-subtitle{font-size:10px;color:var(--text-faint);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.standings-row{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.25rem .5rem;border-bottom:1px solid var(--border-subtle)}.standings-row:last-child{border-bottom:none}.standings-row:hover{background:#27272a33}.standings-row-left{display:flex;align-items:center;gap:.375rem;min-width:0}.standings-rank{font-size:11px;color:var(--text-faint);font-variant-numeric:tabular-nums;width:1rem;flex-shrink:0}.standings-name{font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--text-secondary)}.standings-points{font-size:.75rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary);flex-shrink:0}.standings-empty{padding:1rem .75rem;text-align:center;color:var(--text-faint);font-size:.75rem}.lb-row-btn{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);cursor:pointer;text-align:left;transition:background .15s}.lb-row-btn:hover{background:var(--bg-hover)}.lb-rank{color:var(--text-muted);font-size:.875rem;font-family:monospace;width:2rem}.lb-name-wrap{flex:1;min-width:0}.lb-name-row{display:flex;align-items:center;gap:.5rem}.lb-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-points{text-align:right}.lb-points-value{font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums}.lb-points-unit{color:var(--text-muted);font-size:.75rem;margin-left:.25rem}.lb-arrow{color:var(--text-muted);transition:transform .2s}.lb-arrow--open{transform:rotate(180deg)}.lb-expanded{padding:0 1rem .75rem;border-top:1px solid var(--border)}.lb-section-title{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem;margin-bottom:.25rem}.lb-breakdown-row{display:flex;align-items:center;justify-content:space-between;padding:.25rem .5rem}.lb-driver-info{display:flex;align-items:center;gap:.5rem}.lb-driver-name{font-size:.875rem;color:var(--text-secondary)}.lb-color-dot{width:.5rem;height:.5rem;border-radius:50%}.lb-boost-badge{font-size:10px;background:#eab30833;color:var(--yellow);padding:0 .25rem;border-radius:.25rem;font-weight:700}.lb-breakdown-points{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-family:monospace}.chip-badge{display:inline-block;border-radius:9999px;color:#fff;font-size:10px;padding:.125rem .375rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.chip--3x_boost{background:#9333ea}.chip--no_negative{background:#2563eb}.chip--autopilot{background:#d97706}.chip--wildcard{background:#16a34a}.chip--limitless{background:#dc2626}.chip--final_fix{background:#0891b2}.chip--default{background:#52525b}.chip--used{background:#3f3f46;color:#71717a;text-decoration:line-through}.pts-positive{color:#4ade80}.pts-negative{color:#f87171}.pts-neutral{color:var(--text-secondary)}.pts-blue{color:var(--blue)}.pts-purple{color:var(--purple)}.pts-yellow{color:var(--yellow)}.pts-muted{color:var(--text-muted)}.track-page{height:100%;display:flex;flex-direction:column}.track-canvas-wrap{flex:1;background:var(--bg-card);border-radius:.5rem;border:1px solid var(--border);overflow:hidden;min-height:300px}.telemetry-page{height:100%;display:flex;flex-direction:column}.driver-selector{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem}.driver-btn{padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-family:monospace;border:none;cursor:pointer;transition:background .15s;background:var(--bg-input);color:var(--text-secondary)}.driver-btn:hover{background:#3f3f46}.driver-btn--selected{background:var(--blue);color:#fff}.driver-btn--selected:hover{background:#2563eb}.telemetry-charts{flex:1;overflow:auto;display:flex;flex-direction:column;gap:1rem}.telemetry-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.telemetry-driver-num{font-size:.875rem;font-family:monospace;font-weight:700}.telemetry-stats{display:flex;gap:1rem;font-size:.75rem;font-family:monospace;color:var(--text-secondary)}.mini-chart-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2px}.mini-chart-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.mini-chart-value{font-size:.75rem;font-family:monospace}.mini-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.5rem}.mini-chart-canvas{width:100%;height:3rem;background:var(--bg-body);border-radius:.25rem;display:block}.rc-page{max-width:42rem;margin:0 auto;height:100%;display:flex;flex-direction:column}.rc-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.rc-message{border-left:2px solid var(--text-faint);padding-left:.75rem;padding-top:.375rem;padding-bottom:.375rem}.rc-border-yellow{border-left-color:var(--yellow)}.rc-border-green{border-left-color:var(--green)}.rc-border-amber{border-left-color:var(--amber)}.rc-meta{display:flex;align-items:baseline;gap:.5rem}.rc-timestamp{font-size:.75rem;color:var(--text-faint);font-family:monospace}.rc-flag{font-size:.75rem;font-weight:700;text-transform:uppercase}.rc-flag--green{color:#4ade80}.rc-flag--yellow{color:#facc15}.rc-flag--double-yellow{color:#eab308}.rc-flag--red{color:#f87171}.rc-flag--chequered{color:#fff}.rc-text{font-size:.875rem;color:var(--text-secondary)}.session-page{max-width:42rem;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stat-grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(min-width:640px){.stat-grid-4{grid-template-columns:repeat(4,1fr)}}.stat-label{font-size:.75rem;color:var(--text-muted)}.stat-value{font-size:1.125rem;font-weight:500}.progress-bar{height:6px;background:var(--bg-input);border-radius:9999px;overflow:hidden;grid-column:1 / -1}.progress-fill{height:100%;background:var(--f1-red);border-radius:9999px;transition:width .3s}.track-status-bar{border-radius:.5rem;padding:.75rem 1rem;text-align:center;font-weight:700;font-size:1.125rem}.track-status--green{background:#16a34a;color:#dcfce7}.track-status--yellow{background:#eab308;color:#fef9c3}.track-status--sc{background:#d97706;color:#fef3c7}.track-status--red{background:#dc2626;color:#fee2e2}.track-status--vsc{background:#f59e0b;color:#fef3c7}.track-status--other{background:#3f3f46;color:var(--text-secondary)}.league-page{max-width:48rem;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.league-table{width:100%;border-collapse:collapse}.league-table thead{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border)}.league-table th{padding:.5rem 1rem;text-align:center;font-weight:400}.league-table th:last-child{text-align:center}.league-table td{padding:.5rem 1rem}.league-table tbody tr{border-bottom:1px solid var(--border-subtle)}.league-table tbody tr:hover{background:#27272a4d}.league-rank{color:var(--text-muted);font-size:.875rem;width:3rem;text-align:center}.league-name-cell{display:flex;align-items:center}.league-team-name-primary{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:.375rem;font-weight:500}.league-team-name-logo{height:1em;width:auto}.league-name-divider{width:.75rem;flex-shrink:0}.league-player-name-secondary{flex:1;text-align:left;color:var(--text-faint);font-size:.75rem;font-weight:400}.league-points-unit{font-size:.625rem;font-weight:400;color:var(--text-faint)}.league-points{text-align:center;font-weight:700;font-variant-numeric:tabular-nums}.time-machine-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 0}.time-machine-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex-shrink:0}.time-machine-rounds{display:flex;gap:.25rem;flex-wrap:wrap}.time-machine-btn{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;border:none;cursor:pointer;background:var(--bg-input);color:var(--text-secondary);transition:background .15s}.time-machine-btn:hover{background:var(--bg-hover)}.time-machine-btn--active{background:var(--f1-red);color:#fff}.league-row--clickable{cursor:pointer}.league-row--clickable:hover{background:var(--bg-hover)}.league-expand-arrow{display:inline-block;color:var(--text-faint);margin-left:.5rem;font-size:.75rem;transition:transform .2s}.league-roster{padding:1.5rem 1rem;background:var(--bg-body);border-top:1px solid var(--border)}.league-roster-section{margin-bottom:1.5rem}.league-roster-section:last-child{margin-bottom:0}.league-roster-label{font-size:.625rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.league-roster-row{display:flex;align-items:center;justify-content:space-between;padding:.2rem 0;font-size:.8125rem}.league-roster-drivers-grid{display:flex;gap:0}.league-roster-driver-card{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;min-width:0}.league-roster-headshot{width:96px;height:96px;border-radius:50%;object-fit:cover;background:var(--bg-input);margin-bottom:.375rem}.league-roster-headshot-fallback{width:96px;height:96px;border-radius:50%;background:var(--bg-input);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;color:var(--text-faint);margin-bottom:.375rem}.league-roster-driver-name{font-size:.75rem;color:var(--text-secondary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.league-roster-driver-team{font-size:.625rem;color:var(--text-faint)}.league-roster-constructors-grid{display:flex;gap:1rem;justify-content:center}.league-roster-constructor-card{display:flex;flex-direction:column;align-items:center;text-align:center}.league-roster-constructor-logo{height:48px;width:auto;object-fit:contain;margin-bottom:.375rem}.league-roster-constructor-fallback{height:48px;display:flex;align-items:center;font-size:.75rem;color:var(--text-faint);margin-bottom:.375rem}.league-roster-name{color:var(--text-secondary)}.league-roster-team{color:var(--text-faint);font-size:.75rem;margin-left:.5rem}.league-roster-badges{display:flex;gap:.25rem}.league-roster-chips-row{display:flex;justify-content:space-between;align-items:flex-start;padding-top:.5rem;border-top:1px solid var(--border-subtle)}.league-roster-chips{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center}.league-roster-chips--right{justify-content:flex-end}.season-chart-container{display:flex;gap:.75rem;background:var(--bg-card);border-radius:.5rem;border:1px solid var(--border);padding:1rem}.season-chart-legend{display:flex;flex-direction:column;gap:.375rem;flex-shrink:0;padding-top:.5rem}.season-chart-legend-item{display:flex;align-items:center;gap:.375rem;cursor:pointer;padding:.2rem .5rem;border-radius:.25rem;transition:background .15s}.season-chart-legend-item:hover,.season-chart-legend-item--active{background:var(--bg-hover)}.season-chart-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.season-chart-legend-abbr{font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--text-secondary)}.season-chart-graph{flex:1;min-width:0}.breakdown-chart-container{background:var(--bg-card);border-radius:.5rem;border:1px solid var(--border);padding:1rem}.breakdown-chart-selector{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem;justify-content:center}.breakdown-chart-selector-btn{padding:.25rem .625rem;border-radius:.25rem;font-size:.75rem;font-weight:700;letter-spacing:.05em;border:none;cursor:pointer;background:var(--bg-input);color:var(--text-secondary);transition:background .15s}.breakdown-chart-selector-btn:hover{background:var(--bg-hover)}.breakdown-chart-selector-btn--active{background:var(--f1-red);color:#fff}.breakdown-mode-selector{display:flex;gap:.375rem;justify-content:center;margin-bottom:1rem}.breakdown-mode-btn{padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:500;border:1px solid var(--border);cursor:pointer;background:var(--bg-input);color:var(--text-secondary);transition:background .15s}.breakdown-mode-btn:hover{background:var(--bg-hover)}.breakdown-mode-btn--active{background:var(--border);color:var(--text-primary);border-color:var(--text-muted)}.breakdown-chart-legend{display:flex;justify-content:center;gap:1.5rem;margin-bottom:.75rem;font-size:.75rem;color:var(--text-secondary)}.breakdown-legend-group{display:flex;align-items:center;gap:.375rem}.breakdown-legend-dot{width:8px;height:8px;border-radius:50%}.breakdown-chart-content{position:relative}.breakdown-chart-penalties{text-align:center;font-size:.75rem;color:#f87171;margin-top:.5rem}.breakdown-comparison{display:flex;flex-direction:column;gap:0}.breakdown-comparison .breakdown-chart-container{border-radius:0;border-bottom:none}.breakdown-comparison .breakdown-chart-container:first-child{border-radius:.5rem .5rem 0 0}.breakdown-comparison .breakdown-chart-container:last-child{border-radius:0 0 .5rem .5rem;border-bottom:1px solid var(--border)}.breakdown-compare-toggle{display:block;width:100%;padding:.625rem 1rem;background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;text-align:center;transition:color .15s}.breakdown-compare-toggle:hover{color:var(--text-secondary)}.breakdown-comparison-divider{height:1px;background:var(--border);margin:0 1rem}.admin-page{max-width:42rem;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.admin-form-group{display:flex;flex-direction:column;gap:.75rem}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-faint{color:var(--text-faint)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-mono{font-family:monospace}.font-bold{font-weight:700}.tabular-nums{font-variant-numeric:tabular-nums}.whitespace-pre-wrap{white-space:pre-wrap}.mt-2{margin-top:.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.centered{display:flex;align-items:center;justify-content:center}.full-height{height:100%}
