*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #111113;--surface: #1a1a1f;--border: #2a2a30;--text: #e8e8ec;--text-muted: #9898a0;--accent: #e10600;--accent-hover: #ff1a14;--success: #00c853;--blue: #1e41ff;--teal: #00d2be;--font: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--radius: 8px;--gap: 1rem}html{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}body{min-height:100dvh}h1{font-size:1.75rem;font-weight:700;margin-bottom:.75rem}h2{font-size:1.35rem;font-weight:600;margin-bottom:.5rem}h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}p{margin-bottom:.5rem}header{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;background:var(--surface);border-bottom:2px solid var(--accent)}header a{text-decoration:none;color:var(--text);font-size:1.15rem;font-weight:700;letter-spacing:.02em}header a:hover{color:var(--accent)}main{max-width:900px;margin:0 auto;padding:1.5rem 1.25rem 2rem}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:var(--gap)}form{display:flex;flex-direction:column;gap:.85rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem;color:var(--text-muted)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem 2rem .5rem .75rem;font-size:.95rem;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239898a0' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}select:focus{outline:none;border-color:var(--accent)}.rating-group{width:fit-content}.rating-buttons{display:flex;gap:.35rem;margin-top:.4rem}.rating-btn{width:2.4rem;height:2.4rem;padding:0;font-size:.95rem;font-weight:600;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-muted);cursor:pointer;transition:background .12s,border-color .12s,color .12s}.rating-btn:hover{border-color:var(--accent);color:var(--text)}.rating-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.rating-btn.disabled{opacity:.3;cursor:default;pointer-events:none}.rating-labels{display:flex;justify-content:space-between;margin-top:.25rem;font-size:.8rem;color:var(--text-muted)}button{font-family:var(--font);font-size:.9rem;padding:.55rem 1.25rem;border-radius:var(--radius);cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}button[type=submit]{background:var(--accent);color:#fff;border:none;font-weight:700;text-transform:uppercase;letter-spacing:.04em;align-self:flex-start;min-width:200px}button[type=submit]:hover:not(:disabled){background:var(--accent-hover)}button[type=submit]:disabled{opacity:.5;cursor:not-allowed}button[type=button]{background:transparent;color:var(--text-muted);border:1px solid var(--border)}button[type=button]:hover:not(:disabled){border-color:var(--text-muted);color:var(--text)}button[type=button]:disabled{background:var(--border);color:var(--text);font-weight:600;cursor:default}ul,ol{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}li{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem}li a{font-weight:600}.filter-bar{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:var(--gap)}.filter-bar label{flex-direction:column}.filter-bar button+button{margin-left:.35rem}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:var(--gap)}.vote-confirmation{background:var(--surface);border:1px solid var(--success);border-radius:var(--radius);padding:1.25rem;margin-top:.5rem}.vote-confirmation h3{color:var(--success)}.error-text{color:var(--accent);font-size:.9rem;font-weight:600}.recharts-default-tooltip{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;color:var(--text)!important}.recharts-cartesian-axis-tick-value{fill:var(--text-muted)!important;font-size:.8rem}header select{font-size:.85rem;padding:.35rem 2rem .35rem .5rem}.session-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--gap);margin-top:.5rem}.session-card{position:relative;display:block;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);text-decoration:none;color:var(--text);transition:border-color .15s,transform .15s}.session-card:hover{border-color:var(--accent);transform:translateY(-2px);text-decoration:none}.session-card-img{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover}.session-card-placeholder{background:linear-gradient(135deg,var(--border),var(--surface))}.session-card-closed{opacity:.65}.session-card-closed:hover{opacity:1}.session-card-upcoming{border-style:dashed}.session-card-overlay{display:flex;flex-direction:column;gap:.15rem;padding:.75rem}.session-card-badges{display:flex;align-items:center;gap:.35rem}.session-card-badge{display:inline-block;width:fit-content;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .4rem;border-radius:4px;background:var(--accent);color:#fff}.session-card-badge.badge-sprint{background:var(--teal)}.session-card-status{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.session-card-status.status-open{color:var(--success)}.session-card-status.status-closed{color:var(--text-muted)}.session-card-status.status-upcoming{color:var(--blue)}.session-card-status.status-cancelled{color:var(--accent)}.session-card-cancelled{opacity:.5}.session-card-cancelled:hover{opacity:.7}.session-card-name{font-weight:700;font-size:1rem}.session-card-rating{font-size:.95rem;font-weight:600;color:var(--teal)}.session-card-meta{font-size:.8rem;color:var(--text-muted)}.session-hero{margin:-1.5rem -1.25rem 1rem;overflow:hidden}.session-hero img{display:block;width:100%;max-height:320px;object-fit:cover;border-radius:0 0 var(--radius) var(--radius)}.session-info-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.track-image{width:100px;height:auto;flex-shrink:0;border-radius:var(--radius);border:1px solid var(--border)}.driver-picker{position:relative;display:flex;flex-direction:column;gap:.3rem}.driver-picker-label{font-size:.9rem;color:var(--text-muted);font-weight:600}.driver-picker-trigger{display:flex;align-items:center;width:100%;text-align:left;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.4rem .75rem;color:var(--text);cursor:pointer;min-height:2.75rem}.driver-picker-trigger:hover{border-color:var(--text-muted)}.driver-picker-trigger.has-value{border-color:var(--border)}.driver-picker-trigger.readonly{cursor:default;pointer-events:none;opacity:.85}.driver-picker-placeholder{color:var(--text-muted);font-size:.9rem}.driver-picker-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:.25rem;box-shadow:0 8px 24px #0006}.driver-picker-search{width:100%;padding:.5rem .75rem;font-size:.9rem;background:var(--bg);color:var(--text);border:none;border-bottom:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;outline:none;font-family:var(--font)}.driver-picker-search:focus{border-bottom-color:var(--accent)}.driver-picker-list{max-height:240px;overflow-y:auto}.driver-picker-empty{padding:.75rem;color:var(--text-muted);font-size:.85rem;text-align:center}.driver-row{display:flex;align-items:center;gap:.5rem}.driver-row-option{width:100%;text-align:left;padding:.5rem .75rem;background:transparent;border:none;border-radius:0;color:var(--text);cursor:pointer;transition:background .1s}.driver-row-option:hover{background:var(--bg)}.driver-row-option.active{background:var(--accent);color:#fff}.driver-row-text{display:flex;flex-direction:column;min-width:0}.driver-row-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.driver-row-team{font-size:.75rem;color:var(--text-muted)}.driver-row-option.active .driver-row-team{color:#ffffffb3}.driver-headshot{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--border)}.driver-headshot-sm{width:24px;height:24px}.driver-headshot-placeholder{display:inline-block;background:linear-gradient(135deg,var(--border),var(--surface))}@media (max-width: 640px){header{padding:.6rem .75rem}header a{font-size:1rem}main{padding:1rem .75rem 1.5rem}h1{font-size:1.4rem}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar button+button{margin-left:0}form,section,.chart-card{padding:1rem}.rating-buttons{flex-wrap:wrap}.rating-btn{width:2.2rem;height:2.2rem;font-size:.85rem}.session-card-grid{grid-template-columns:1fr}.session-hero{margin:-1rem -.75rem .75rem}.session-hero img{max-height:200px}.session-info-row{flex-direction:column;align-items:flex-start}.track-image{width:80px}}
