:root{color-scheme:dark;--bg:#090b0d;--track:#171b1f;--panel:#11161b;--panel-strong:#1d242a;--text:#f7f8f4;--muted:#a7b0b7;--line:#303941;--line-bright:#59636b;--accent:#ffd34d;--accent-strong:#ffb000;--red:#ec3f35;--green:#4ec45f;--danger:#ff6b6b;--safe-top:env(safe-area-inset-top,0px);--safe-right:env(safe-area-inset-right,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px)}*{box-sizing:border-box}body,html{width:100%;min-height:100%;margin:0;background:linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px) 0 0 /72px 72px,radial-gradient(circle at 50% -20%,rgba(255,211,77,.14),transparent 34%),var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif;overscroll-behavior:none;touch-action:manipulation}body{min-height:100dvh;overflow:hidden}button,input,select{font:inherit}button{min-height:44px;border:0;border-radius:8px;background:var(--panel-strong);color:#171717;font-weight:700;cursor:pointer;padding:0 18px}button:disabled{cursor:not-allowed;opacity:.5}a{color:inherit}.app-shell{min-height:100dvh;padding:max(16px,var(--safe-top)) max(16px,var(--safe-right)) max(16px,var(--safe-bottom)) max(16px,var(--safe-left));overflow:auto;-webkit-overflow-scrolling:touch}.race-home,.race-layout{width:min(100%,980px);margin:0 auto}.race-home{display:grid;grid-gap:18px;gap:18px;min-height:calc(100dvh - max(32px, var(--safe-top)) - max(32px, var(--safe-bottom)));align-content:center}.race-home-copy,.race-page-head{position:relative;padding-top:28px}.race-home-copy:before,.race-page-head:before{content:"";position:absolute;top:0;left:0;width:min(180px,58vw);height:12px;background:repeating-linear-gradient(90deg,#f7f8f4 0 18px,#101316 18px 36px),#f7f8f4;border-radius:2px}.race-home h1,.race-page-head h1{margin:0;font-size:clamp(42px,13vw,96px);line-height:.9;letter-spacing:0;text-transform:uppercase}.race-home h2,.race-layout h2{margin:0;font-size:clamp(26px,7vw,42px);line-height:1;letter-spacing:0}.race-layout{display:grid;grid-gap:16px;gap:16px}.race-page-head{display:grid;grid-gap:8px;gap:8px}.eyebrow,.panel-kicker{margin:0;color:var(--accent);font-size:12px;font-weight:900;letter-spacing:.12em}.stack{display:flex;flex-direction:column;gap:16px;width:100%}.race-panel,.surface{position:relative;border:1px solid var(--line);border-radius:8px;background:linear-gradient(135deg,rgba(255,211,77,.08),transparent 28%),linear-gradient(180deg,rgba(255,255,255,.035),transparent),var(--panel);padding:16px;overflow:hidden}.race-panel:after{content:"";position:absolute;right:-24px;bottom:-26px;width:150px;height:90px;background:url(/racing/sprites/smoke.png) 50%/contain no-repeat;opacity:.08;pointer-events:none}.race-panel-home{min-height:260px;justify-content:end}.action-panel{min-height:210px;justify-content:space-between}.hall-grid{display:grid;grid-gap:14px;gap:14px}.lobby-panel{gap:18px}.lobby-topline,.race-actions,.room-list-item,.tuning-panel{display:flex;gap:12px;align-items:center;justify-content:space-between}.tuning-panel{align-items:flex-start;border-top:1px solid var(--line);padding-top:14px}.tuning-panel-column{display:grid}.driver-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.driver-card{min-height:112px;display:grid;align-content:space-between;grid-gap:6px;gap:6px;border:1px solid var(--line);border-left:6px solid var(--line-bright);border-radius:8px;background:rgba(7,9,11,.52);padding:12px}.driver-yellow{border-left-color:#f4c430}.driver-green{border-left-color:#52c46b}.driver-purple{border-left-color:#9b6ef3}.driver-red{border-left-color:#ef5350}.driver-card strong{font-size:20px;line-height:1.05}.driver-card span:not(.driver-role){color:var(--muted);font-size:13px}.driver-role,.status-pill{width:-moz-fit-content;width:fit-content;border:1px solid rgba(255,211,77,.42);border-radius:999px;color:var(--accent);background:rgba(255,211,77,.1);padding:5px 9px;font-size:12px;font-weight:900}.room-list-item{min-height:64px;border-top:1px solid var(--line);padding-top:12px}.room-list-item strong{min-width:86px;font-size:22px;letter-spacing:.08em}.room-list-item span{color:var(--muted)}.empty-grid{min-height:150px;display:grid;align-content:center;grid-gap:10px;gap:10px}.row{display:flex;gap:12px;align-items:center}.row-wrap{flex-wrap:wrap}.field{display:grid;grid-gap:6px;gap:6px}.field span{color:var(--muted);font-size:13px}.input{min-height:44px;width:100%;border:1px solid var(--line);border-radius:8px;background:#080b0e;color:var(--text);padding:10px 12px}.room-code-input{font-size:22px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.muted{color:var(--muted);margin:0}.error,.error-banner{color:var(--danger)}.error-banner{border:1px solid rgba(255,107,107,.42);border-radius:8px;background:rgba(255,107,107,.08);padding:12px;margin:0}.loading-copy{color:var(--muted);text-align:center}.primary-action,.secondary-action{min-width:126px}.primary-action{background:var(--accent);color:#111;box-shadow:0 8px 0 rgba(0,0,0,.28)}.secondary-action{border:1px solid var(--line-bright);background:#f3f5ee;color:#111}.step-button{min-width:48px;padding:0;background:#f3f5ee;color:#111}.lap-readout{min-width:72px;text-align:center;font-size:22px}.color-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.color-swatch{min-height:58px;border:2px solid rgba(255,255,255,.14);border-radius:8px;color:rgba(0,0,0,.72);padding:8px;text-align:left;box-shadow:inset 0 -16px rgba(0,0,0,.12)}.color-swatch[aria-pressed=true]{border-color:var(--text)}.color-swatch span{display:block;font-size:12px;font-weight:900}.start-hint{border-top:1px solid var(--line);padding-top:12px}.racing-runtime{position:fixed;inset:0;width:100vw;height:100dvh;overflow:hidden;background:#000;touch-action:none}.racing-runtime canvas{display:block;width:100%;height:100%;touch-action:none}@media (min-width:720px){.race-home{grid-template-columns:minmax(0,1fr) minmax(360px,.72fr);align-items:center}.hall-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.color-grid,.driver-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.race-panel,.surface{padding:20px}}@media (max-width:520px){.lobby-topline,.race-actions,.room-list-item,.tuning-panel{align-items:stretch;flex-direction:column}.primary-action,.secondary-action{width:100%}}