*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{width:100%;height:100%;overflow:hidden;background:#0a0f14;color:#e8eef4;font-family:Inter,system-ui,-apple-system,sans-serif}.app{position:relative;width:100vw;height:100vh}.app__canvas{position:absolute;inset:0;z-index:0}.app__canvas canvas{display:block;width:100%!important;height:100%!important}.hud{position:absolute;inset:0;pointer-events:none;display:grid;grid-template-rows:auto 1fr auto;padding:1.5rem 2rem;z-index:10}.hud__brand{display:flex;flex-direction:column;gap:.1rem}.hud__title{font-size:1.1rem;font-weight:700;letter-spacing:.35em;color:#c8d4e0}.hud__subtitle{font-size:.65rem;letter-spacing:.5em;color:#6a8aa8}.hud__speed{position:absolute;bottom:5rem;left:2rem;display:flex;align-items:baseline;gap:.4rem}.hud__speed-value{font-size:4rem;font-weight:200;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hud__speed-unit{font-size:.85rem;letter-spacing:.15em;color:#6a8aa8}.hud__telemetry{position:absolute;top:1.5rem;right:2rem;display:flex;flex-direction:column;gap:.35rem;min-width:10rem;padding:.75rem 1rem;background:rgba(10,15,20,.55);border:1px solid rgba(200,212,224,.12);border-radius:4px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hud__row{display:flex;justify-content:space-between;gap:1rem;font-size:.72rem;letter-spacing:.08em}.hud__label{color:#6a8aa8}.hud__value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#e8eef4}.hud__handbrake{margin-top:.25rem;font-size:.65rem;letter-spacing:.2em;color:#e85d4a;text-align:right}.hud__controls{font-size:.62rem;letter-spacing:.06em;color:rgba(106,138,168,.7);text-align:center}.lap{position:absolute;top:4.2rem;left:2rem;gap:.3rem}.lap,.lap__current{display:flex;flex-direction:column}.lap__eyebrow{font-size:.55rem;letter-spacing:.3em;color:#6a8aa8}.lap__time{font-size:1.9rem;font-weight:300;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#e8eef4}.lap__rows{display:flex;flex-direction:column;gap:.15rem;margin-top:.2rem}.lap__row{display:flex;gap:.6rem;font-size:.7rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.lap__label{color:#6a8aa8;width:2.6rem;letter-spacing:.1em}.lap__value{color:#e8eef4}.lap__value--best{color:#7cffb2}@media (max-height:480px) and (orientation:landscape){.lap{top:3.4rem}.lap__time{font-size:1.5rem}}.exit-btn{position:absolute;top:1.25rem;left:50%;transform:translateX(-50%);z-index:25;padding:.5rem 1.15rem;font-size:.7rem;font-weight:600;letter-spacing:.2em;color:#e8eef4;background:rgba(10,15,20,.55);border:1px solid rgba(200,212,224,.16);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;pointer-events:auto;transition:background .15s ease,border-color .15s ease,transform .1s ease}.exit-btn:focus-visible,.exit-btn:hover{background:rgba(232,93,74,.22);border-color:rgba(232,93,74,.5);outline:none}.exit-btn:active{transform:translateX(-50%) scale(.97)}.sky-toast{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%) translateY(8px);z-index:20;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem 1rem;background:rgba(10,15,20,.55);border:1px solid rgba(200,212,224,.14);border-radius:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;transition:opacity .35s ease,transform .35s ease;pointer-events:none}.sky-toast--on{opacity:1;transform:translateX(-50%) translateY(0)}.sky-toast__eyebrow{font-size:.55rem;letter-spacing:.3em;color:#6a8aa8}.sky-toast__label{font-size:.95rem;font-weight:600;letter-spacing:.04em;color:#e8eef4}@media (max-height:480px) and (orientation:landscape){.sky-toast{bottom:.75rem;padding:.4rem .75rem}}.start{position:absolute;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:1.5rem;text-align:center;background:radial-gradient(120% 120% at 50% 25%,rgba(20,32,48,.35) 0,rgba(6,10,16,.82) 60%,rgba(4,7,11,.95) 100%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:start-fade .6s ease both}@keyframes start-fade{0%{opacity:0}to{opacity:1}}.start__inner{display:flex;flex-direction:column;align-items:center;gap:.5rem;max-width:32rem}.start__tag{font-size:clamp(.55rem,1.6vw,.7rem);letter-spacing:.45em;color:#e85d4a;padding-left:.45em}.start__title{font-size:clamp(2.3rem,11vw,5.5rem);font-weight:800;letter-spacing:.16em;line-height:.92;background:linear-gradient(180deg,#ffffff,#9fc4ff);-webkit-background-clip:text;background-clip:text;color:transparent;padding-left:.18em}.start__subtitle{font-size:clamp(.9rem,3.6vw,1.6rem);font-weight:300;letter-spacing:.7em;color:#6a8aa8;padding-left:.7em}.start__tagline{margin-top:.4rem;font-size:clamp(.72rem,2vw,.92rem);color:rgba(200,212,224,.7);max-width:26rem}.custom{display:flex;flex-wrap:wrap;justify-content:center;gap:1.4rem 2.4rem;margin-top:1.5rem}.custom__group{display:flex;flex-direction:column;align-items:center;gap:.5rem}.custom__label{font-size:.58rem;letter-spacing:.3em;color:#6a8aa8}.custom__swatches{display:flex;gap:.5rem}.swatch{width:1.6rem;height:1.6rem;border-radius:50%;border:2px solid rgba(255,255,255,.25);cursor:pointer;padding:0;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.swatch--active,.swatch:hover{transform:scale(1.12)}.swatch--active{border-color:#ffffff;box-shadow:0 0 0 3px rgba(255,255,255,.25)}.custom__toggle{display:flex;gap:.4rem}.pill{padding:.45rem 1.1rem;font-size:.72rem;letter-spacing:.08em;color:#c8d4e0;background:rgba(255,255,255,.06);border:1px solid rgba(200,212,224,.2);border-radius:999px;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.pill--active{background:linear-gradient(180deg,#ffffff,#b8d4e8);color:#06101a;border-color:#ffffff;font-weight:600}@media (max-height:480px) and (orientation:landscape){.custom{margin-top:.7rem;gap:.6rem 1.6rem}.swatch{width:1.3rem;height:1.3rem}}.start__cta{margin-top:1.4rem;padding:.85rem 3.2rem;font-size:clamp(.9rem,2.4vw,1.1rem);font-weight:700;letter-spacing:.3em;color:#06101a;background:linear-gradient(180deg,#ffffff,#b8d4e8);border:none;border-radius:999px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 0 0 0 rgba(184,212,232,.5)}.start__cta:focus-visible,.start__cta:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 12px 40px -8px rgba(184,212,232,.6);outline:none}.start__cta:active{transform:translateY(0) scale(.99)}.start__controls{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem 1.1rem;margin-top:1.6rem;font-size:clamp(.6rem,1.7vw,.74rem);letter-spacing:.05em;color:rgba(106,138,168,.85)}.start__controls b{color:#e8eef4;font-weight:600}@media (max-height:480px) and (orientation:landscape){.start__inner{gap:.25rem}.start__title{font-size:clamp(2.2rem,9vh,3.4rem)}.start__tagline{display:none}.start__cta{margin-top:.7rem;padding:.6rem 2.4rem}.start__controls{margin-top:.8rem}}.garage,.landing{inset:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(120% 120% at 50% 25%,rgba(20,32,48,.35) 0,rgba(6,10,16,.82) 60%,rgba(4,7,11,.95) 100%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:start-fade .6s ease both}.garage,.landing,.signature{position:absolute;text-align:center}.signature{bottom:3.4rem;left:0;right:0;font-size:clamp(.9rem,2.6vw,1.3rem);font-weight:600;letter-spacing:.28em;background:linear-gradient(90deg,#ffffff,#5b9bff,#ffffff,#5b9bff);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:signature-shimmer 6s linear infinite;pointer-events:none}@keyframes signature-shimmer{to{background-position:300% 0}}.site-footer{position:absolute;bottom:1rem;left:0;right:0;text-align:center;z-index:31;font-size:.72rem;letter-spacing:.12em;color:rgba(200,212,224,.6)}.site-footer a{color:#9fc4ff;text-decoration:none;pointer-events:auto;border-bottom:1px solid transparent;transition:color .15s ease,border-color .15s ease}.site-footer a:hover{color:#cfe0ff;border-bottom-color:#9fc4ff}.garage__panel{width:min(94vw,56rem);max-height:84vh;overflow-y:auto;display:flex;flex-direction:column;gap:1.2rem;padding:1.4rem 1.6rem 1.8rem;background:rgba(10,15,22,.72);border:1px solid rgba(200,212,224,.14);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.garage__header{display:flex;align-items:center;justify-content:space-between}.garage__title{font-size:1.1rem;font-weight:700;letter-spacing:.4em;color:#c8d4e0}.garage__back{background:none;border:none;color:#9fc4ff;cursor:pointer;font-size:.72rem;letter-spacing:.15em}.garage__body{gap:1.3rem}.garage__body,.garage__section{display:flex;flex-direction:column}.garage__section{gap:.6rem;align-items:flex-start}.dest-group{display:flex;flex-direction:column;gap:.4rem;width:100%}.dest-region{font-size:.6rem;letter-spacing:.25em;color:#6a8aa8}.dest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(8.5rem,1fr));grid-gap:.5rem;gap:.5rem;width:100%}.dest-card{padding:.6rem .7rem;font-size:.72rem;text-align:left;color:#c8d4e0;background:rgba(255,255,255,.05);border:1px solid rgba(200,212,224,.16);border-radius:8px;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.dest-card:hover{background:rgba(255,255,255,.1)}.dest-card--active{border-color:#9fc4ff;background:rgba(90,155,255,.18);color:#ffffff}.garage__drive{align-self:center;margin-top:.3rem}.dest-layout,.garage__section--center{align-items:center;width:100%}.dest-layout{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.globe-wrap{width:360px;height:360px;max-width:100%;flex:0 0 auto;cursor:-webkit-grab;cursor:grab}.globe-wrap:active{cursor:-webkit-grabbing;cursor:grabbing}.dest-list{flex:1 1 14rem;min-width:13rem;max-height:360px;overflow-y:auto;gap:.9rem;text-align:left;padding-right:.3rem}.dest-list,.dest-list__group{display:flex;flex-direction:column}.dest-list__group{gap:.3rem}.dest-item{padding:.5rem .7rem;font-size:.78rem;text-align:left;color:#c8d4e0;background:rgba(255,255,255,.05);border:1px solid rgba(200,212,224,.14);border-radius:8px;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.dest-item:hover{background:rgba(255,255,255,.1)}.dest-item--active{border-color:#9fc4ff;background:rgba(90,155,255,.2);color:#ffffff;font-weight:600}.globe-label{font-size:.7rem;font-weight:600;color:#ffffff;background:rgba(10,15,22,.85);border:1px solid rgba(159,196,255,.4);padding:2px 7px;border-radius:5px;white-space:nowrap;transform:translateY(-1.4rem)}.dest-selected{font-size:.95rem;font-weight:600;letter-spacing:.04em;color:#9fc4ff}@media (max-height:560px){.globe-wrap{height:220px}}.best-banner{position:absolute;top:22%;left:50%;transform:translateX(-50%);z-index:24;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.8rem 2.2rem;background:rgba(10,15,22,.55);border:1px solid rgba(124,255,178,.5);border-radius:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;animation:best-pop .4s ease both}@keyframes best-pop{0%{opacity:0;transform:translateX(-50%) translateY(10px) scale(.92)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.best-banner__title{font-size:1.1rem;font-weight:800;letter-spacing:.2em;color:#7cffb2}.best-banner__time{font-size:1.4rem;font-weight:300;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#ffffff}.minimap{position:absolute;bottom:1.5rem;right:1.5rem;z-index:20;width:150px;height:150px;padding:.5rem;background:rgba(10,15,20,.5);border:1px solid rgba(200,212,224,.14);border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.minimap__track{fill:none;stroke:rgba(159,196,255,.55);stroke-width:2.4;stroke-linejoin:round}.minimap__start{fill:#7cffb2}.minimap__car{fill:#ffffff;stroke:#e85d4a;stroke-width:1.4}@media (max-width:479px){.minimap{width:104px;height:104px;bottom:1rem;right:1rem}}.car-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(9rem,1fr));grid-gap:.5rem;gap:.5rem;width:100%}.car-card{display:flex;flex-direction:column;gap:.15rem;padding:.6rem .8rem;text-align:left;background:rgba(255,255,255,.05);border:1px solid rgba(200,212,224,.16);border-radius:8px;cursor:pointer;transition:background .12s ease,border-color .12s ease}.car-card:hover{background:rgba(255,255,255,.1)}.car-card--active{border-color:#9fc4ff;background:rgba(90,155,255,.18)}.car-card__name{font-size:.86rem;font-weight:700;letter-spacing:.04em;color:#ffffff}.car-card__tag{font-size:.62rem;letter-spacing:.05em;color:#8aa0b8}.dest-item{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.dest-item__rec{font-size:.66rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#7cffb2;opacity:.9}.landing__keys{position:absolute;bottom:5.6rem;left:0;right:0;text-align:center;font-size:clamp(.58rem,1.6vw,.72rem);letter-spacing:.05em;color:rgba(106,138,168,.8);pointer-events:none}@media (max-height:480px) and (orientation:landscape){.landing__keys{bottom:4.4rem}}.overlay{position:absolute;inset:0;z-index:40;justify-content:center;padding:1.5rem;background:rgba(6,10,16,.72);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:start-fade .3s ease both}.overlay,.overlay__panel{display:flex;align-items:center}.overlay__panel{flex-direction:column;gap:.9rem;width:min(92vw,26rem);padding:2rem 1.8rem;background:rgba(10,15,22,.85);border:1px solid rgba(200,212,224,.16);border-radius:14px;text-align:center}.overlay__title{font-size:1.6rem;font-weight:800;letter-spacing:.18em;color:#e8eef4}.overlay__title--win{color:#7cffb2;font-size:1.4rem}.overlay__stats{display:flex;flex-direction:column;gap:.4rem;width:100%}.overlay__stat{display:flex;justify-content:space-between;font-size:.82rem;letter-spacing:.05em;color:#8aa0b8;border-bottom:1px solid rgba(200,212,224,.08);padding-bottom:.3rem}.overlay__stat b{color:#e8eef4;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600}.overlay__best{color:#7cffb2!important}.overlay__link{background:none;border:none;color:#9fc4ff;cursor:pointer;font-size:.78rem;letter-spacing:.1em;pointer-events:auto}.overlay__link:hover{color:#cfe0ff}.countdown{position:absolute;inset:0;z-index:26;display:flex;align-items:center;justify-content:center;pointer-events:none}.countdown__num{font-size:clamp(5rem,22vw,12rem);font-weight:800;letter-spacing:.05em;color:#ffffff;text-shadow:0 0 40px rgba(95,155,255,.7);animation:count-pop .8s ease both}.countdown__num--go{color:#7cffb2;font-size:clamp(3.5rem,16vw,9rem);text-shadow:0 0 40px rgba(124,255,178,.8)}@keyframes count-pop{0%{opacity:0;transform:scale(1.6)}30%{opacity:1;transform:scale(1)}to{opacity:.85;transform:scale(1)}}.pos-badge{position:absolute;top:3.9rem;left:50%;transform:translateX(-50%);z-index:12;display:flex;align-items:baseline;gap:.3rem;padding:.3rem .9rem;background:rgba(10,15,20,.5);border:1px solid rgba(200,212,224,.14);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.pos-badge__p{font-size:1.3rem;font-weight:800;color:#ffd27a;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.pos-badge__total{font-size:.8rem;color:#8aa0b8}.touch{display:none}@media (hover:none) and (pointer:coarse){.touch{display:block}}.touch__drive,.touch__steer{position:absolute;bottom:1.4rem;z-index:22;display:flex;align-items:flex-end;gap:.8rem}.touch__steer{left:1.2rem}.touch__drive{right:1.2rem}.touch-btn{width:4.4rem;height:4.4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#e8eef4;background:rgba(10,15,20,.42);border:1px solid rgba(200,212,224,.3);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto;touch-action:none;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.touch-btn:active{background:rgba(159,196,255,.35);transform:scale(.95)}.touch-btn--throttle{width:5.4rem;height:5.4rem;border-color:rgba(124,255,178,.55);color:#7cffb2}.touch-btn--brake{border-color:rgba(232,93,74,.55);color:#e85d4a}.touch-btn--handbrake{width:3.4rem;height:3.4rem;font-size:1rem;letter-spacing:.05em}@media (hover:none) and (pointer:coarse){.hud__controls,.hud__telemetry{display:none}.hud__speed{left:50%;right:auto;transform:translateX(-50%);bottom:1.6rem}.hud__speed-value{font-size:2.6rem}.minimap{top:1rem;right:1rem;bottom:auto;width:108px;height:108px}}@media (max-width:479px){.hud{padding:1rem}.lap{top:3.4rem;left:1rem}.lap__time{font-size:1.4rem}.hud__speed-value{font-size:2.3rem}}.site-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem}.site-footer__link{background:none;border:none;color:#9fc4ff;cursor:pointer;font-size:inherit;letter-spacing:inherit;padding:0;pointer-events:auto}.site-footer__link:hover{color:#cfe0ff}.site-footer__sep{color:rgba(200,212,224,.35)}.consent{position:absolute;bottom:1.2rem;left:1.2rem;z-index:50;max-width:21rem;display:flex;flex-direction:column;gap:.7rem;padding:1rem 1.1rem;background:rgba(10,15,22,.88);border:1px solid rgba(200,212,224,.16);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto;animation:consent-in .45s ease both}@keyframes consent-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.consent__text{font-size:.74rem;line-height:1.5;color:#c8d4e0}.consent__link{background:none;border:none;color:#9fc4ff;cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.consent__accept{align-self:flex-start;padding:.4rem 1.2rem;font-size:.72rem;font-weight:600;letter-spacing:.1em;color:#06101a;background:linear-gradient(180deg,#ffffff,#b8d4e8);border:none;border-radius:999px;cursor:pointer}@media (max-width:479px){.consent{left:.8rem;right:.8rem;bottom:.8rem;max-width:none}}.legal{position:absolute;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:1.2rem;background:rgba(6,10,16,.74);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:start-fade .3s ease both}.legal__panel{width:min(94vw,40rem);max-height:85vh;display:flex;flex-direction:column;background:rgba(10,15,22,.96);border:1px solid rgba(200,212,224,.16);border-radius:14px;overflow:hidden}.legal__head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid rgba(200,212,224,.1)}.legal__title{font-size:1.1rem;font-weight:700;letter-spacing:.08em;color:#e8eef4}.legal__close{background:none;border:none;color:#8aa0b8;cursor:pointer;font-size:1.1rem;pointer-events:auto}.legal__close:hover{color:#e8eef4}.legal__updated{padding:.7rem 1.4rem 0;font-size:.66rem;letter-spacing:.04em;color:#6a8aa8}.legal__body{overflow-y:auto;padding:.7rem 1.4rem 1.5rem}.legal__intro{font-size:.84rem;line-height:1.55;color:#c8d4e0}.legal__intro,.legal__section{margin-bottom:.9rem}.legal__heading{font-size:.8rem;font-weight:600;color:#9fc4ff;margin-bottom:.3rem}.legal__p{font-size:.78rem;line-height:1.55;color:rgba(200,212,224,.85);margin-bottom:.4rem;word-break:break-word}.hud__nitro{position:absolute;bottom:3.2rem;left:2rem;display:flex;flex-direction:column;gap:.2rem;width:9rem}.hud__nitro-label{font-size:.5rem;letter-spacing:.3em;color:#6a8aa8}.hud__nitro-bar{height:.4rem;background:rgba(255,255,255,.12);border-radius:999px;overflow:hidden}.hud__nitro-fill{height:100%;background:linear-gradient(90deg,#5b9bff,#7cffb2);border-radius:999px;transition:width .15s linear}.touch-btn--boost{width:3.7rem;height:3.7rem;font-size:.7rem;font-weight:700;border-color:rgba(91,155,255,.6);color:#9fc4ff}@media (hover:none) and (pointer:coarse){.hud__nitro{left:50%;transform:translateX(-50%);bottom:4.6rem;width:8rem}}.records{display:flex;flex-direction:column;gap:.1rem}.records__row{display:flex;justify-content:space-between;gap:1rem;font-size:.82rem;padding:.4rem 0;border-bottom:1px solid rgba(200,212,224,.08);color:#c8d4e0}.records__time{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:#6a8aa8}.records__time--set{color:#7cffb2}.minimap__track{stroke-linecap:round}.minimap__finish{fill:#e85d4a;stroke:#ffffff;stroke-width:1}