:root{
  --bg:#050711; --panel:#0d1020; --panel2:#10162c; --text:#f5f8ff; --muted:#aab2d4;
  --cyan:#35e7ff; --violet:#8e62ff; --green:#72ffb8; --amber:#ffd166; --line:rgba(255,255,255,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;overflow-x:hidden}
.noise{position:fixed;inset:0;pointer-events:none;opacity:.07;z-index:99;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
.topbar{position:fixed;top:18px;left:50%;transform:translateX(-50%);width:min(1120px,calc(100% - 28px));height:66px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(6,7,17,.70);backdrop-filter:blur(18px);z-index:50;box-shadow:0 24px 80px rgba(0,0,0,.28)}
.logo{width:56px;height:56px;object-fit:contain}
nav{display:flex;gap:24px;color:#cbd3ef;font-size:13px}nav a{opacity:.85}
.top-cta,.primary{border:1px solid rgba(53,231,255,.45);background:linear-gradient(135deg,rgba(53,231,255,.18),rgba(142,98,255,.22));border-radius:999px;padding:12px 18px;font-weight:750;font-size:13px;box-shadow:0 0 34px rgba(53,231,255,.14)}
.hero{position:relative;min-height:100vh;display:grid;grid-template-columns:1.02fr .98fr;gap:42px;align-items:center;padding:120px max(24px,calc((100vw - 1120px)/2)) 70px;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(56px);opacity:.5}.orb-a{width:520px;height:520px;background:#32168c;right:-160px;top:-120px}.orb-b{width:460px;height:460px;background:#005b78;left:-180px;bottom:-140px}
.hero-copy{position:relative;z-index:2}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.22em;color:var(--cyan);font-weight:850}
.hero h1,.solution h2,.next h2,.intro-panel h2{font-size:clamp(42px,6vw,86px);letter-spacing:-.07em;line-height:.9;margin:18px 0}.lead{font-size:clamp(17px,2vw,22px);line-height:1.45;color:#d9def6;max-width:680px}
.hero-actions{display:flex;align-items:center;gap:18px;margin-top:30px}.hint{color:var(--muted);font-size:13px}
/* HERO PARKING MAP */
.hero-stage{position:relative;height:620px;border:1px solid rgba(255,255,255,.12);border-radius:38px;background:radial-gradient(circle at 50% 18%,rgba(53,231,255,.16),transparent 26%),linear-gradient(180deg,#10152a,#060913);overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04),0 40px 120px rgba(0,0,0,.4)}
.city-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(53,231,255,.10) 1px,transparent 1px),linear-gradient(90deg,rgba(53,231,255,.10) 1px,transparent 1px);background-size:32px 32px;opacity:.38}
.parking-gate{position:absolute;left:50%;top:40px;transform:translateX(-50%);width:260px;height:82px;border:1px solid rgba(53,231,255,.45);border-radius:24px;display:grid;place-items:center;background:rgba(4,8,18,.84);box-shadow:0 0 42px rgba(53,231,255,.18)}
.parking-gate:before{content:'ENTRADA INTELIGENTE';position:absolute;top:-26px;color:#cdefff;font-size:11px;letter-spacing:.18em;font-weight:850}.parking-gate span{position:absolute;width:190px;height:3px;background:var(--cyan);bottom:18px;box-shadow:0 0 20px var(--cyan)}.parking-gate b{font-size:12px;letter-spacing:.22em}
.scanner-ring{position:absolute;width:210px;height:210px;left:50%;top:210px;transform:translateX(-50%);border-radius:50%;border:1px dashed rgba(53,231,255,.55);animation:spin 9s linear infinite}.scanner-ring:after{content:'LECTURA DE PLACA';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:10px;font-weight:850;color:#cdefff;letter-spacing:.16em;text-align:center}
.mini-car{position:absolute;width:74px;height:116px;border-radius:22px;background:linear-gradient(180deg,#f8fbff,#7ab5ff);box-shadow:0 0 32px rgba(53,231,255,.24)}.mini-car i{position:absolute;inset:18px 14px;border-radius:14px;background:#0b1020}.car-one{left:70px;bottom:80px;transform:rotate(-12deg)}.car-two{right:92px;bottom:128px;transform:rotate(9deg);background:linear-gradient(180deg,#d2ffef,#35ffb6)}.car-three{left:270px;bottom:230px;transform:rotate(4deg);background:linear-gradient(180deg,#f2e7ff,#8e62ff)}
.ticket-panel{position:absolute;right:34px;top:34px;width:210px;padding:18px;border-radius:22px;background:rgba(6,7,17,.78);border:1px solid rgba(255,255,255,.13)}.ticket-panel small,.ticket-panel em{display:block;color:var(--muted);font-style:normal}.ticket-panel strong{display:block;margin:6px 0 8px;font-size:18px}@keyframes spin{to{transform:translateX(-50%) rotate(360deg)}}
.intro-panel{width:min(1120px,calc(100% - 48px));margin:0 auto;padding:80px 0 40px;display:grid;grid-template-columns:1fr 1fr;gap:60px;border-top:1px solid var(--line)}.intro-panel p:last-child{font-size:19px;line-height:1.5;color:#cdd3ea}.intro-panel h2{font-size:56px}
/* INTERACTIVE SECTION */
.scroll-world{position:relative;height:760vh}.world-sticky{position:sticky;top:0;height:100vh;overflow:hidden;background:radial-gradient(circle at 50% 10%,rgba(142,98,255,.16),transparent 34%),#070913}.world-sticky:before{content:'Recorrido de diagnóstico Parkcol';position:absolute;left:50%;top:154px;transform:translateX(-50%);z-index:5;font-size:clamp(24px,3vw,42px);font-weight:850;letter-spacing:-.055em;color:#fff;text-align:center;width:min(720px,calc(100% - 40px))}.world-sticky:after{content:'Cada checkpoint representa una parte real de la operación: entrada, cámaras, pagos, personal y salida.';position:absolute;left:50%;top:204px;transform:translateX(-50%);z-index:5;color:#aab2d4;text-align:center;width:min(620px,calc(100% - 44px));font-size:14px;line-height:1.4}
.hud{position:absolute;left:50%;top:104px;transform:translateX(-50%);width:min(1120px,calc(100% - 48px));display:flex;justify-content:space-between;color:#dfe5ff;font-size:13px;letter-spacing:.12em;text-transform:uppercase;z-index:5}.progress{position:absolute;top:134px;left:50%;transform:translateX(-50%);width:min(1120px,calc(100% - 48px));height:3px;background:rgba(255,255,255,.08);z-index:5}.progress span{display:block;width:0;height:100%;background:linear-gradient(90deg,var(--cyan),var(--violet));box-shadow:0 0 18px var(--cyan)}
.road-system{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);width:min(700px,calc(100% - 520px));height:560px;border:1px solid rgba(255,255,255,.12);border-radius:36px;background:radial-gradient(circle at 50% 20%,rgba(53,231,255,.12),transparent 35%),linear-gradient(180deg,rgba(17,23,45,.96),rgba(7,10,20,.96));box-shadow:0 40px 130px rgba(0,0,0,.42),inset 0 0 0 1px rgba(255,255,255,.04);overflow:hidden}.road-system:before{content:'MAPA OPERATIVO';position:absolute;left:26px;top:20px;color:#dfe8ff;font-size:12px;letter-spacing:.2em;font-weight:850}.road-system:after{content:'';position:absolute;inset:70px 38px 52px;border-radius:26px;border:1px solid rgba(53,231,255,.16);background-image:linear-gradient(rgba(53,231,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(53,231,255,.08) 1px,transparent 1px);background-size:26px 26px;opacity:.8}
.road{position:absolute;top:92px;bottom:78px;width:112px;border-radius:999px;background:linear-gradient(90deg,#10172d,#252d4b 45%,#252d4b 55%,#10172d);border:1px solid rgba(255,255,255,.12);z-index:2}.road:after{content:"";position:absolute;top:16px;bottom:16px;left:50%;width:3px;transform:translateX(-50%);background:repeating-linear-gradient(180deg,rgba(255,255,255,.62) 0 26px,transparent 26px 54px);animation:lane 1.15s linear infinite}.road-left{left:calc(50% - 128px)}.road-right{left:calc(50% + 18px)}@keyframes lane{to{background-position-y:54px}}
.entry-gate,.exit-gate{position:absolute;left:50%;transform:translateX(-50%);height:50px;width:330px;border:1px solid rgba(53,231,255,.38);border-radius:18px;background:rgba(6,9,19,.9);display:flex;align-items:center;justify-content:center;letter-spacing:.24em;color:#cdefff;font-weight:850;box-shadow:0 0 32px rgba(53,231,255,.10);z-index:4}.entry-gate{top:82px}.exit-gate{bottom:38px}.entry-gate:after{content:'cámara + placa';position:absolute;right:-100px;color:var(--cyan);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.exit-gate:after{content:'pago validado';position:absolute;right:-104px;color:var(--green);font-size:10px;letter-spacing:.12em;text-transform:uppercase}
.pay-kiosk{position:absolute;right:42px;top:51%;width:96px;height:120px;border:1px solid rgba(114,255,184,.45);border-radius:22px;background:rgba(7,22,22,.88);display:grid;place-items:center;z-index:4;box-shadow:0 0 42px rgba(114,255,184,.13)}.pay-kiosk:before{content:'KIOSKO / QR';position:absolute;top:-22px;color:#caffe1;font-size:10px;letter-spacing:.14em;font-weight:850}.pay-kiosk b{font-size:24px}.pay-kiosk small{color:var(--green);font-weight:850}
.camera{position:absolute;width:30px;height:30px;border-radius:50%;border:2px solid var(--cyan);box-shadow:0 0 26px rgba(53,231,255,.4);z-index:5}.camera:after{content:"";position:absolute;left:25px;top:13px;width:70px;height:2px;background:linear-gradient(90deg,rgba(53,231,255,.8),transparent);transform:rotate(14deg)}.cam-a{left:72px;top:145px}.cam-b{right:118px;top:155px}.cam-c{left:86px;bottom:116px}
.parking-slots{position:absolute;left:42px;top:250px;display:grid;grid-template-columns:repeat(2,82px);gap:13px;z-index:4}.parking-slots:before{content:'CUPOS';position:absolute;top:-24px;left:0;color:#aab2d4;font-size:10px;letter-spacing:.18em;font-weight:850}.parking-slots i{height:46px;border:1px solid rgba(255,255,255,.16);border-radius:10px;background:rgba(255,255,255,.04);position:relative}.parking-slots i:nth-child(2),.parking-slots i:nth-child(5),.parking-slots i:nth-child(7){background:linear-gradient(90deg,rgba(53,231,255,.18),rgba(142,98,255,.16));box-shadow:inset 0 0 0 1px rgba(53,231,255,.20)}.parking-slots i:nth-child(2):after,.parking-slots i:nth-child(5):after,.parking-slots i:nth-child(7):after{content:'';position:absolute;left:17px;right:17px;top:10px;bottom:10px;border-radius:9px;background:rgba(255,255,255,.55)}
.car-track{position:absolute;left:50%;top:120px;width:260px;height:360px;transform:translateX(-50%);z-index:6;pointer-events:none}.game-car{position:absolute;left:89px;top:0;width:82px;height:132px;border-radius:24px;background:linear-gradient(180deg,#fff,#35e7ff 64%,#286fff);box-shadow:0 0 44px rgba(53,231,255,.35),0 20px 60px rgba(0,0,0,.4);transition:transform .18s linear}.game-car span{position:absolute;left:15px;right:15px;top:24px;height:38px;border-radius:14px;background:#07101f}.game-car:before,.game-car:after{content:"";position:absolute;bottom:18px;width:10px;height:22px;border-radius:8px;background:#081020}.game-car:before{left:-4px}.game-car:after{right:-4px}
.question-card{position:absolute;right:max(24px,calc((100vw - 1120px)/2));top:55%;transform:translateY(-50%);width:min(430px,calc(100% - 48px));padding:28px;border-radius:30px;background:rgba(10,13,28,.82);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(18px);box-shadow:0 34px 120px rgba(0,0,0,.45),inset 0 0 0 1px rgba(255,255,255,.04);z-index:7}.card-kicker{margin:0 0 12px;color:var(--cyan);text-transform:uppercase;letter-spacing:.2em;font-weight:850;font-size:12px}.question-card h3{font-size:clamp(26px,3vw,40px);line-height:1;letter-spacing:-.055em;margin:0 0 16px}.question-card p:last-child{color:#bfc7e9;font-size:16px;line-height:1.45}.question-card:after{content:'Pregunta activa';position:absolute;right:22px;bottom:18px;color:rgba(255,255,255,.28);font-size:10px;text-transform:uppercase;letter-spacing:.16em}
.steps{position:absolute;inset:0;pointer-events:none}.step{height:50.6vh}
.solution{width:min(1120px,calc(100% - 48px));margin:0 auto;padding:120px 0}.solution h2{max-width:840px}.solution-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}.solution-card{min-height:260px;padding:24px;border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.12)}.solution-card span{color:var(--cyan);font-weight:850}.solution-card h3{font-size:25px;letter-spacing:-.04em}.solution-card p{color:#cbd2eb;line-height:1.5}.next{padding:60px 24px 120px}.next-card{width:min(1060px,100%);margin:0 auto;padding:56px;border-radius:40px;background:radial-gradient(circle at right top,rgba(53,231,255,.18),transparent 30%),linear-gradient(135deg,#121533,#080a16);border:1px solid rgba(255,255,255,.13);box-shadow:0 40px 140px rgba(0,0,0,.42)}.next-card h2{max-width:890px}.next-card p{font-size:19px;color:#d2d8f2;max-width:760px;line-height:1.5}.next-card .primary{display:inline-block;margin-top:22px}
@media(max-width:1180px){.road-system{width:calc(100% - 500px)}.entry-gate:after,.exit-gate:after{display:none}.question-card{width:390px}.parking-slots{left:28px;grid-template-columns:repeat(2,70px)}.pay-kiosk{right:26px}}
@media(max-width:980px){nav{display:none}.top-cta{display:none}.hero{grid-template-columns:1fr;padding-top:110px}.hero-stage{height:520px}.intro-panel{grid-template-columns:1fr}.scroll-world{height:auto}.world-sticky{position:relative;height:auto;min-height:780px;padding:96px 22px 34px;overflow:visible}.world-sticky:before{top:108px;font-size:32px}.world-sticky:after{top:152px}.hud{top:28px}.progress{top:58px}.road-system{position:relative;left:auto;top:auto;transform:none;width:100%;height:480px;margin:130px auto 24px;border-radius:28px}.question-card{position:relative;right:auto;top:auto;transform:none;width:100%;max-width:680px;margin:0 auto;padding:24px}.question-card h3{font-size:28px}.steps{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:14px;width:min(920px,calc(100% - 44px));margin:28px auto 0;pointer-events:auto}.step{height:auto;min-height:130px;padding:18px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.12)}.step:before{content:attr(data-kicker);display:block;color:var(--cyan);font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:850;margin-bottom:10px}.step:after{content:attr(data-question);display:block;color:#fff;font-size:16px;line-height:1.25;font-weight:750;letter-spacing:-.03em}.solution-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.topbar{height:58px;top:12px}.logo{width:48px;height:48px}.hero{padding:96px 18px 48px}.hero h1{font-size:44px}.lead{font-size:16px}.hero-actions{flex-direction:column;align-items:flex-start}.hero-stage{height:420px;border-radius:28px}.parking-gate{width:210px}.ticket-panel{right:18px;top:18px;width:174px}.mini-car{width:54px;height:86px;border-radius:17px}.scanner-ring{width:150px;height:150px;top:195px}.car-three{left:170px}.intro-panel{width:calc(100% - 36px);padding:54px 0 30px}.intro-panel h2{font-size:38px}.world-sticky{min-height:700px;padding-left:16px;padding-right:16px}.world-sticky:before{font-size:26px;top:96px}.world-sticky:after{top:136px;font-size:12px}.road-system{height:410px;margin-top:128px}.road{width:76px;top:88px;bottom:72px}.road-left{left:calc(50% - 86px)}.road-right{left:calc(50% + 10px)}.entry-gate,.exit-gate{width:235px;height:44px;font-size:11px}.pay-kiosk{width:70px;height:86px;right:14px;top:55%}.pay-kiosk b{font-size:18px}.parking-slots{left:16px;top:230px;grid-template-columns:repeat(2,48px);gap:9px}.parking-slots i{height:34px}.camera{display:none}.car-track{width:180px;height:290px;top:112px}.game-car{left:58px;width:62px;height:100px;border-radius:18px}.game-car span{left:12px;right:12px;top:18px;height:28px}.question-card{padding:20px;border-radius:24px}.question-card h3{font-size:24px}.question-card p:last-child{font-size:14px}.steps{grid-template-columns:1fr;width:calc(100% - 32px)}.step{min-height:104px}.solution{width:calc(100% - 36px);padding:76px 0}.solution h2,.next h2{font-size:38px}.solution-grid{grid-template-columns:1fr}.solution-card{min-height:auto}.next{padding:30px 18px 80px}.next-card{padding:28px;border-radius:30px}.next-card p{font-size:16px}}
@media(max-width:420px){.hero h1{font-size:38px}.hero-stage{height:360px}.city-grid{background-size:24px 24px}.ticket-panel{display:none}.parking-gate{top:30px;width:190px}.scanner-ring{top:160px}.mini-car{display:none}.road-system{height:370px}.parking-slots{display:none}.pay-kiosk{right:12px;width:62px}.entry-gate,.exit-gate{width:210px}.road-left{left:calc(50% - 72px)}.road-right{left:calc(50% + 0px)}.road{width:66px}.world-sticky{min-height:660px}}

/* --- Hero clarity override: make the first visual read as an actual parking entrance --- */
.hero-stage{
  isolation:isolate;
  height:620px;
  border-radius:38px;
  background:
    radial-gradient(circle at 52% 28%,rgba(53,231,255,.18),transparent 24%),
    radial-gradient(circle at 80% 72%,rgba(114,255,184,.12),transparent 24%),
    linear-gradient(180deg,#0e162b,#060913 70%);
}
.city-grid{opacity:.32;background-size:34px 34px;mask-image:linear-gradient(to bottom,black 0 72%,transparent)}
.stage-title{position:absolute;top:28px;left:50%;transform:translateX(-50%);z-index:6;padding:10px 18px;border:1px solid rgba(53,231,255,.22);border-radius:999px;background:rgba(5,10,22,.72);color:#d8f7ff;font-size:12px;font-weight:850;letter-spacing:.2em;text-transform:uppercase;white-space:nowrap;box-shadow:0 0 28px rgba(53,231,255,.12)}
.hero-road{position:absolute;left:50%;top:92px;bottom:-30px;width:220px;transform:translateX(-50%) perspective(560px) rotateX(54deg);transform-origin:top center;border-radius:34px 34px 0 0;background:linear-gradient(90deg,#0a0f1e,#1f2b4b 45%,#1f2b4b 55%,#0a0f1e);border:1px solid rgba(255,255,255,.14);box-shadow:0 0 60px rgba(53,231,255,.12),inset 0 0 0 1px rgba(53,231,255,.08);z-index:1;overflow:hidden}.hero-road:before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(180deg,rgba(255,255,255,.42) 0 34px,transparent 34px 76px);width:4px;left:50%;transform:translateX(-50%);animation:lane 1.25s linear infinite}.lane-mark{position:absolute;top:0;bottom:0;width:1px;background:rgba(53,231,255,.18)}.lane-a{left:26%}.lane-b{right:26%}
.parking-gate{top:104px;width:410px;height:76px;border-radius:22px;z-index:7;background:rgba(5,9,20,.92);border-color:rgba(53,231,255,.45);box-shadow:0 0 38px rgba(53,231,255,.20)}.parking-gate:before{content:'Punto de entrada';top:-28px;color:#93f2ff;font-size:10px;letter-spacing:.16em}.parking-gate span{width:300px;height:4px;bottom:19px;background:linear-gradient(90deg,var(--cyan),transparent);transform-origin:left center;transform:rotate(-8deg);box-shadow:0 0 20px var(--cyan)}.parking-gate b{position:absolute;top:18px;left:0;right:0;text-align:center;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#eafaff}
.scan-zone{position:absolute;left:50%;top:205px;width:250px;height:120px;transform:translateX(-50%);z-index:3;border:2px dashed rgba(53,231,255,.45);border-radius:34px;background:rgba(53,231,255,.035);box-shadow:0 0 42px rgba(53,231,255,.10)}.scan-zone:before{content:'';position:absolute;left:20px;right:20px;top:50%;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);box-shadow:0 0 18px var(--cyan);animation:scanline 2s ease-in-out infinite}.scan-zone small{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);color:#c9f8ff;font-size:10px;font-weight:850;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}@keyframes scanline{0%,100%{transform:translateY(-36px)}50%{transform:translateY(36px)}}
.hero-car{position:absolute;width:86px;height:138px;border-radius:25px;z-index:5;background:linear-gradient(180deg,#fff,#5db8ff 62%,#286fff);box-shadow:0 0 36px rgba(53,231,255,.32),0 22px 58px rgba(0,0,0,.38)}.hero-car i{position:absolute;left:16px;right:16px;top:23px;height:42px;border-radius:16px;background:#07101f}.hero-car b{position:absolute;left:12px;right:12px;bottom:17px;height:21px;border-radius:6px;background:#ecf7ff;color:#10172d;display:grid;place-items:center;font-size:9px;letter-spacing:.08em}.main-car{left:50%;top:258px;transform:translateX(-50%)}.waiting-car{left:calc(50% - 160px);top:408px;transform:rotate(-10deg);opacity:.86;background:linear-gradient(180deg,#f3fbff,#9fcaff 62%,#4e9dff)}
.booth{position:absolute;right:32px;bottom:92px;width:138px;height:142px;border-radius:24px;border:1px solid rgba(114,255,184,.42);background:linear-gradient(180deg,rgba(10,32,31,.94),rgba(5,14,22,.94));z-index:6;display:grid;place-items:center;text-align:center;box-shadow:0 0 38px rgba(114,255,184,.16)}.booth:before{content:'';position:absolute;top:24px;width:64px;height:64px;border-radius:16px;background:repeating-linear-gradient(0deg,#d9fff0 0 5px,#17271f 5px 10px);box-shadow:0 0 24px rgba(114,255,184,.20)}.booth small{position:absolute;top:94px;color:#caffe4;font-size:10px;letter-spacing:.12em;text-transform:uppercase}.booth strong{position:absolute;bottom:14px;color:var(--green);font-size:22px;letter-spacing:.08em}
.lpr-camera{position:absolute;left:34px;top:138px;z-index:8;width:126px;height:86px;border-radius:22px;border:1px solid rgba(53,231,255,.35);background:rgba(5,12,24,.88);display:flex;gap:10px;align-items:center;justify-content:center;box-shadow:0 0 34px rgba(53,231,255,.12)}.lpr-camera span{width:34px;height:34px;border-radius:50%;border:3px solid var(--cyan);box-shadow:0 0 20px rgba(53,231,255,.45)}.lpr-camera span:after{content:'';position:absolute;width:104px;height:2px;background:linear-gradient(90deg,rgba(53,231,255,.8),transparent);left:86px;top:43px;transform:rotate(18deg)}.lpr-camera b{font-size:10px;line-height:1.15;letter-spacing:.12em;text-transform:uppercase;color:#dffbff}.ticket-panel{right:28px;top:86px;width:210px;z-index:8;background:rgba(8,11,24,.88);border-color:rgba(255,255,255,.16)}.ticket-panel strong{font-size:17px}.ticket-panel em{font-size:13px;color:#c4cbed}
@media(max-width:980px){.stage-title{top:24px}.hero-road{width:200px}.parking-gate{width:350px}.parking-gate span{width:250px}.ticket-panel{top:88px;right:24px}.lpr-camera{left:24px}.booth{right:24px}}
@media(max-width:680px){.hero-stage{height:470px}.stage-title{font-size:10px;top:18px}.hero-road{top:72px;width:150px}.parking-gate{top:78px;width:260px;height:62px}.parking-gate:before{display:none}.parking-gate b{top:14px;font-size:10px}.parking-gate span{width:190px;bottom:15px}.scan-zone{top:165px;width:188px;height:96px}.main-car{top:225px;width:66px;height:106px;border-radius:19px}.waiting-car{left:50px;top:342px;width:58px;height:92px}.booth{right:18px;bottom:50px;width:96px;height:112px;border-radius:18px}.booth:before{top:17px;width:48px;height:48px}.booth small{top:72px;font-size:8px}.booth strong{font-size:18px}.lpr-camera{left:18px;top:95px;width:88px;height:66px;border-radius:17px}.lpr-camera span{width:26px;height:26px}.lpr-camera b{font-size:8px}.lpr-camera span:after{left:62px;top:34px;width:70px}.ticket-panel{right:16px;top:150px;width:150px;padding:12px;border-radius:18px}.ticket-panel strong{font-size:14px}.ticket-panel em{font-size:11px}}
@media(max-width:420px){.hero-stage{height:420px}.stage-title{width:calc(100% - 34px);text-align:center}.ticket-panel{display:block;top:142px;width:136px}.lpr-camera{top:88px}.booth{display:grid}.parking-gate{width:232px}.scan-zone{width:166px}.waiting-car{display:block}.hero-car b{font-size:7px}}
/* Keep status card from covering the gate label */
.hero-stage .ticket-panel{top:190px;right:26px;width:186px;padding:14px;border-radius:18px}
.hero-stage .ticket-panel small{font-size:11px}.hero-stage .ticket-panel strong{font-size:15px;line-height:1.1}.hero-stage .ticket-panel em{font-size:11px}
@media(max-width:680px){.hero-stage .ticket-panel{top:154px;right:14px;width:140px;padding:11px}.hero-stage .ticket-panel strong{font-size:13px}.hero-stage .ticket-panel em{font-size:10px}}
/* Mobile type safety */
@media(max-width:680px){.hero-copy{max-width:100%;overflow:hidden}.hero h1{font-size:38px;line-height:.96;letter-spacing:-.06em;max-width:352px}.lead{max-width:352px}.hero{overflow:hidden}}
@media(max-width:420px){.hero h1{font-size:35px;max-width:340px}.lead{max-width:340px;font-size:15px}}
@media(max-width:380px){.hero h1{font-size:32px;max-width:316px}.lead{max-width:316px}}
@media(max-width:680px){.hero-stage .ticket-panel{right:22px;width:124px}.hero-stage .ticket-panel small{font-size:9px}.hero-stage .ticket-panel strong{font-size:12px}.hero-stage .ticket-panel em{font-size:9px}}

/* --- Mobile scroll repair: same checkpoint experience as desktop, no stacked/overlapped cards --- */
@media(max-width:980px){
  .scroll-world{height:760vh;min-height:760vh;position:relative;}
  .world-sticky{position:sticky;top:0;height:100svh;min-height:100svh;padding:0;overflow:hidden;background:radial-gradient(circle at 50% 14%,rgba(142,98,255,.16),transparent 34%),#070913;}
  .world-sticky:before{top:92px;font-size:28px;line-height:1.02;width:calc(100% - 34px);z-index:8;}
  .world-sticky:after{top:128px;font-size:12px;line-height:1.32;width:calc(100% - 44px);z-index:8;}
  .hud{top:74px;width:calc(100% - 32px);font-size:10px;letter-spacing:.09em;z-index:12;}
  .progress{top:103px;width:calc(100% - 32px);height:4px;border-radius:999px;overflow:hidden;z-index:12;background:rgba(255,255,255,.12);}
  .road-system{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);width:calc(100% - 32px);height:310px;margin:0;border-radius:26px;z-index:2;}
  .road-system:before{top:14px;left:18px;font-size:10px;}
  .road-system:after{inset:54px 20px 38px;border-radius:20px;}
  .entry-gate{top:58px;width:250px;height:38px;font-size:10px;letter-spacing:.16em;}
  .exit-gate{bottom:26px;width:250px;height:38px;font-size:10px;letter-spacing:.16em;}
  .road{top:72px;bottom:58px;width:68px;}
  .road-left{left:calc(50% - 74px)}
  .road-right{left:calc(50% + 8px)}
  .car-track{top:86px;width:170px;height:220px;}
  .game-car{left:54px;width:62px;height:100px;border-radius:18px;}
  .game-car span{left:12px;right:12px;top:18px;height:28px;}
  .pay-kiosk{right:16px;top:48%;width:64px;height:82px;border-radius:16px;}
  .pay-kiosk:before{display:none;}
  .pay-kiosk b{font-size:16px}.pay-kiosk small{font-size:10px;}
  .parking-slots{left:16px;top:174px;grid-template-columns:repeat(2,42px);gap:8px;}
  .parking-slots:before{display:none;}
  .parking-slots i{height:30px;border-radius:8px;}
  .camera{display:none;}
  .question-card{position:absolute;left:16px;right:16px;bottom:22px;top:auto;transform:none;width:auto;max-width:none;min-height:226px;margin:0;padding:22px 20px 32px;border-radius:24px;z-index:10;background:rgba(10,13,28,.92);}
  .question-card h3{font-size:25px;line-height:1.08;letter-spacing:-.045em;margin:0 0 14px;}
  .question-card p:last-child{font-size:14.5px;line-height:1.42;padding-right:0;}
  .question-card:after{right:20px;bottom:14px;font-size:9px;}
  .steps{position:absolute;inset:0;display:block;width:auto;margin:0;pointer-events:none;}
  .step{height:50.6vh;min-height:0;padding:0;border:0;background:transparent;border-radius:0;}
  .step:before,.step:after{content:none!important;display:none!important;}
}
@media(max-width:680px){
  .world-sticky:before{top:88px;font-size:24px;}
  .world-sticky:after{top:120px;font-size:11.5px;}
  .hud{top:72px;}
  .progress{top:99px;}
  .road-system{top:41%;height:286px;width:calc(100% - 28px);}
  .question-card{left:14px;right:14px;bottom:18px;min-height:236px;padding:20px 18px 30px;}
  .question-card h3{font-size:23px;line-height:1.08;}
  .question-card p:last-child{font-size:14px;}
}
@media(max-width:420px){
  .scroll-world{height:800vh;min-height:800vh;}
  .world-sticky:before{top:84px;font-size:22px;}
  .world-sticky:after{top:112px;width:calc(100% - 36px);font-size:11px;}
  .hud{top:70px;width:calc(100% - 26px);}
  .progress{top:96px;width:calc(100% - 26px);}
  .road-system{top:39%;height:250px;width:calc(100% - 24px);}
  .road-system:before{font-size:9px;}
  .entry-gate,.exit-gate{width:214px;height:34px;font-size:9px;}
  .road{width:58px;top:66px;bottom:52px;}
  .road-left{left:calc(50% - 64px)}
  .road-right{left:calc(50% + 4px)}
  .car-track{top:82px;width:142px;height:180px;}
  .game-car{left:40px;width:54px;height:86px;}
  .pay-kiosk{width:56px;height:68px;right:10px;}
  .parking-slots{display:none;}
  .question-card{min-height:252px;bottom:16px;padding:19px 17px 30px;border-radius:22px;}
  .question-card h3{font-size:21px;line-height:1.12;}
  .question-card p:last-child{font-size:13.5px;line-height:1.38;}
}

/* Final mobile checkpoint pass: progress bar only at top, no header text overlap */
@media(max-width:980px){
  .scroll-world .world-sticky:before,
  .scroll-world .world-sticky:after{display:none!important;content:none!important;}
  .scroll-world .hud{top:76px!important;}
  .scroll-world .progress{top:104px!important;}
  .scroll-world .road-system{top:36%!important;height:292px!important;}
  .scroll-world .question-card{bottom:24px!important;min-height:244px!important;display:block!important;}
}
@media(max-width:680px){
  .scroll-world .hud{top:74px!important;}
  .scroll-world .progress{top:102px!important;}
  .scroll-world .road-system{top:35%!important;height:272px!important;}
  .scroll-world .question-card{bottom:22px!important;min-height:252px!important;}
}
@media(max-width:420px){
  .scroll-world .road-system{top:34%!important;height:240px!important;}
  .scroll-world .question-card{bottom:20px!important;min-height:270px!important;}
}

/* Reading pace: each question gets almost a full screen of scroll time */
.scroll-world{height:1500vh!important;min-height:1500vh!important;}
.step{height:100vh!important;}
@media(max-width:980px){
  .scroll-world{height:1650vh!important;min-height:1650vh!important;}
  .step{height:110vh!important;}
  .card-kicker{font-size:11px;line-height:1.15;}
}
@media(max-width:420px){
  .scroll-world{height:1800vh!important;min-height:1800vh!important;}
  .step{height:120vh!important;}
}

/* Mobile hero information layout: clear, stacked, no overlapping labels */
@media(max-width:680px){
  .hero{padding-top:104px!important;padding-bottom:44px!important;gap:26px!important;}
  .hero-actions{gap:12px!important;margin-top:22px!important;}
  .hint{display:block;font-size:13px;line-height:1.35;}
  .hero-stage{height:520px!important;border-radius:28px!important;overflow:hidden!important;}
  .hero-stage .stage-title{top:18px!important;width:calc(100% - 42px)!important;padding:9px 12px!important;font-size:10px!important;letter-spacing:.16em!important;}
  .hero-stage .hero-road{top:92px!important;bottom:-22px!important;width:168px!important;transform:translateX(-50%) perspective(560px) rotateX(50deg)!important;}
  .hero-stage .parking-gate{top:82px!important;width:292px!important;height:58px!important;border-radius:19px!important;}
  .hero-stage .parking-gate b{top:13px!important;font-size:9.5px!important;letter-spacing:.12em!important;white-space:nowrap!important;}
  .hero-stage .parking-gate span{width:216px!important;height:3px!important;bottom:14px!important;}
  .hero-stage .scan-zone{top:178px!important;width:178px!important;height:88px!important;border-radius:26px!important;opacity:.72!important;}
  .hero-stage .scan-zone small{display:none!important;}
  .hero-stage .lpr-camera{top:154px!important;left:18px!important;width:104px!important;height:74px!important;border-radius:18px!important;gap:7px!important;z-index:9!important;}
  .hero-stage .lpr-camera span{width:26px!important;height:26px!important;}
  .hero-stage .lpr-camera span:after{left:74px!important;top:37px!important;width:95px!important;opacity:.7!important;}
  .hero-stage .lpr-camera b{font-size:8px!important;line-height:1.15!important;letter-spacing:.08em!important;}
  .hero-stage .main-car{top:272px!important;left:50%!important;width:68px!important;height:110px!important;border-radius:20px!important;z-index:8!important;}
  .hero-stage .main-car i{top:19px!important;left:12px!important;right:12px!important;height:31px!important;}
  .hero-stage .main-car b{font-size:7px!important;bottom:13px!important;left:10px!important;right:10px!important;height:18px!important;}
  .hero-stage .waiting-car{top:402px!important;left:44px!important;width:54px!important;height:88px!important;opacity:.82!important;z-index:5!important;}
  .hero-stage .ticket-panel{top:236px!important;right:16px!important;width:126px!important;padding:11px!important;border-radius:17px!important;z-index:9!important;}
  .hero-stage .ticket-panel small{font-size:8px!important;margin-bottom:4px!important;}
  .hero-stage .ticket-panel strong{font-size:12px!important;line-height:1.08!important;margin:3px 0 4px!important;}
  .hero-stage .ticket-panel em{font-size:9px!important;line-height:1.2!important;}
  .hero-stage .booth{right:18px!important;bottom:28px!important;width:104px!important;height:112px!important;border-radius:18px!important;z-index:7!important;}
  .hero-stage .booth:before{top:16px!important;width:52px!important;height:46px!important;border-radius:12px!important;}
  .hero-stage .booth small{top:72px!important;font-size:8px!important;line-height:1.05!important;width:86px!important;}
  .hero-stage .booth strong{bottom:11px!important;font-size:18px!important;}
}
@media(max-width:420px){
  .hero-stage{height:500px!important;}
  .hero-stage .parking-gate{width:270px!important;}
  .hero-stage .lpr-camera{width:96px!important;left:16px!important;}
  .hero-stage .ticket-panel{right:14px!important;width:118px!important;}
  .hero-stage .booth{width:96px!important;right:14px!important;}
  .hero-stage .waiting-car{left:38px!important;}
}

/* Mobile intro/discovery information: readable section, not oversized or cut awkwardly */
@media(max-width:680px){
  .intro-panel{width:calc(100% - 32px)!important;margin:0 auto!important;padding:46px 0 34px!important;display:block!important;border-top:1px solid rgba(255,255,255,.10)!important;}
  .intro-panel .eyebrow{font-size:10px!important;letter-spacing:.22em!important;margin-bottom:12px!important;display:block!important;}
  .intro-panel h2{font-size:34px!important;line-height:1.02!important;letter-spacing:-.055em!important;margin:0 0 18px!important;max-width:340px!important;}
  .intro-panel p:last-child{font-size:15px!important;line-height:1.5!important;color:#d7dcf2!important;background:rgba(255,255,255,.055)!important;border:1px solid rgba(255,255,255,.11)!important;border-radius:22px!important;padding:18px!important;margin:0!important;}
}
@media(max-width:420px){
  .intro-panel h2{font-size:31px!important;max-width:310px!important;}
  .intro-panel p:last-child{font-size:14.5px!important;}
}

/* Desktop polish: keep the hero premium, readable and not oversized */
@media(min-width:981px){
  .hero{grid-template-columns:minmax(470px, .9fr) minmax(520px, 1.1fr)!important;gap:64px!important;padding-top:118px!important;align-items:center!important;}
  .hero h1{font-size:clamp(54px,5vw,72px)!important;line-height:.96!important;letter-spacing:-.062em!important;max-width:640px!important;margin:16px 0 18px!important;}
  .lead{max-width:610px!important;font-size:18px!important;line-height:1.5!important;}
  .hero-stage{height:560px!important;max-width:560px!important;width:100%!important;justify-self:end!important;border-radius:34px!important;}
  .hero-stage .parking-gate{width:360px!important;}
  .hero-stage .parking-gate span{width:260px!important;}
  .hero-stage .ticket-panel{top:225px!important;right:24px!important;width:170px!important;}
  .hero-stage .booth{right:24px!important;width:124px!important;height:132px!important;}
  .hero-stage .lpr-camera{left:28px!important;top:150px!important;}
  .hero-stage .main-car{top:288px!important;}
  .hero-stage .waiting-car{top:405px!important;left:84px!important;}
}

/* Desktop hero final balance: avoid orphan words and excessive line breaks */
@media(min-width:981px){
  .hero{grid-template-columns:minmax(560px,1.08fr) minmax(470px,.92fr)!important;gap:50px!important;}
  .hero h1{font-size:clamp(48px,4.35vw,60px)!important;line-height:.98!important;max-width:690px!important;}
  .lead{font-size:17px!important;max-width:590px!important;}
  .hero-stage{height:520px!important;max-width:520px!important;}
}

/* Desktop readability emergency fix: generous line-height so letters never overlap */
@media(min-width:981px){
  .hero h1{
    font-size:clamp(42px,3.9vw,56px)!important;
    line-height:1.16!important;
    letter-spacing:-.045em!important;
    max-width:720px!important;
    text-wrap:balance!important;
  }
  .solution h2,
  .next h2,
  .intro-panel h2{
    line-height:1.12!important;
    letter-spacing:-.045em!important;
  }
}

/* Responsive checkpoint layout: keep section heading, map and active question separated */
@media(min-width:981px){
  .scroll-world .world-sticky:before{
    top:34px!important;
    width:min(980px,calc(100% - 72px))!important;
    font-size:clamp(30px,3.2vw,46px)!important;
    line-height:1.14!important;
    letter-spacing:-.038em!important;
    z-index:9!important;
  }
  .scroll-world .world-sticky:after{
    top:94px!important;
    width:min(780px,calc(100% - 72px))!important;
    font-size:15px!important;
    line-height:1.55!important;
    z-index:9!important;
  }
  .scroll-world .hud{
    top:142px!important;
    width:min(1120px,calc(100% - 72px))!important;
    z-index:9!important;
  }
  .scroll-world .progress{
    top:172px!important;
    width:min(1120px,calc(100% - 72px))!important;
    z-index:9!important;
  }
  .scroll-world .road-system{
    top:62%!important;
    width:min(620px,calc(100% - 560px))!important;
    height:clamp(340px,calc(100vh - 230px),510px)!important;
    z-index:3!important;
  }
  .scroll-world .question-card{
    top:62%!important;
    width:min(400px,calc(100% - 48px))!important;
    padding:24px!important;
    z-index:8!important;
  }
  .scroll-world .question-card h3{
    font-size:clamp(25px,2.4vw,34px)!important;
    line-height:1.18!important;
    letter-spacing:-.038em!important;
  }
  .scroll-world .question-card p:last-child{
    font-size:15px!important;
    line-height:1.52!important;
  }
}
@media(min-width:981px) and (max-height:720px){
  .scroll-world .world-sticky:before{top:24px!important;font-size:clamp(27px,2.8vw,38px)!important;}
  .scroll-world .world-sticky:after{top:76px!important;font-size:13.5px!important;line-height:1.42!important;}
  .scroll-world .hud{top:118px!important;}
  .scroll-world .progress{top:146px!important;}
  .scroll-world .road-system{top:64%!important;height:clamp(310px,calc(100vh - 205px),450px)!important;}
  .scroll-world .question-card{top:64%!important;padding:22px!important;}
  .scroll-world .question-card h3{font-size:clamp(23px,2.1vw,30px)!important;line-height:1.16!important;}
}
@media(max-width:980px){
  .scroll-world .world-sticky:before,
  .scroll-world .world-sticky:after{display:none!important;content:none!important;}
}

/* Hard reset for checkpoint section: no decorative title overlap, no card-over-map text collision */
.scroll-world .world-sticky:before,
.scroll-world .world-sticky:after{
  display:none!important;
  content:none!important;
}
@media(min-width:981px){
  .scroll-world .hud{
    top:104px!important;
    width:min(1120px,calc(100% - 72px))!important;
    z-index:12!important;
  }
  .scroll-world .progress{
    top:136px!important;
    width:min(1120px,calc(100% - 72px))!important;
    z-index:12!important;
  }
  .scroll-world .road-system{
    left:max(36px,calc((100vw - 1120px)/2))!important;
    top:60%!important;
    transform:translateY(-50%)!important;
    width:min(600px,calc(100vw - 600px))!important;
    min-width:420px!important;
    height:clamp(330px,calc(100vh - 210px),500px)!important;
    z-index:3!important;
  }
  .scroll-world .question-card{
    right:max(36px,calc((100vw - 1120px)/2))!important;
    left:auto!important;
    top:60%!important;
    transform:translateY(-50%)!important;
    width:min(420px,calc(100vw - 660px))!important;
    min-width:350px!important;
    padding:26px!important;
    z-index:10!important;
  }
  .scroll-world .question-card h3{
    font-size:clamp(24px,2.15vw,32px)!important;
    line-height:1.22!important;
    letter-spacing:-.03em!important;
  }
  .scroll-world .question-card p:last-child{
    font-size:15px!important;
    line-height:1.55!important;
  }
}
@media(min-width:981px) and (max-width:1120px){
  .scroll-world .road-system{width:calc(100vw - 570px)!important;min-width:390px!important;}
  .scroll-world .question-card{width:380px!important;min-width:0!important;}
}
@media(max-width:980px) and (min-width:681px){
  .scroll-world .hud{top:102px!important;}
  .scroll-world .progress{top:132px!important;}
  .scroll-world .road-system{top:48%!important;height:292px!important;}
  .scroll-world .question-card{bottom:22px!important;min-height:238px!important;}
}
