/* =========================================================
   1M1S EXPRESS — Landing page
   Design system + bespoke motion-ready styles
   ========================================================= */

:root{
  --bg:#0a0410;
  --bg-soft:#0f0718;
  --surface:#150a1d;
  --surface-2:#1f0f2a;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.16);
  --text:#f1f5f9;
  --muted:#a896b4;
  --muted-dim:#6b5876;

  /* 1M1S Express brand — royal purple #62007F + gold #FBB040 (from app theme) */
  --purple:#62007f;
  --purple-bright:#9d1bc4;
  --gold:#fbb040;
  --gold-light:#ffce6a;
  --mint:#9d1bc4;   /* primary accent (bright purple) */
  --sky:#fbb040;    /* secondary accent (gold) */
  --violet:#ffce6a; /* tertiary accent (gold light) */
  --rose:#fbb040;
  --accent:var(--mint);
  --grad: linear-gradient(120deg,#62007f 0%,#9d1bc4 45%,#fbb040 115%);
  --grad-soft: linear-gradient(120deg, rgba(157,27,196,.18), rgba(251,176,64,.12));

  --radius:22px;
  --radius-lg:30px;
  --ease: cubic-bezier(.16,1,.3,1);
  --container:1180px;
  --font-display:"Sora", sans-serif;
  --font-body:"Space Grotesk", sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
@media (max-width:900px){ body{cursor:auto} }

img,svg{display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(157,27,196,.3);color:#fff}

/* ---------- Custom cursor ---------- */
.cursor{position:fixed;left:0;top:0;z-index:9999;pointer-events:none;mix-blend-mode:difference}
.cursor__dot{position:fixed;width:7px;height:7px;border-radius:50%;background:#fff;transform:translate(-50%,-50%)}
.cursor__ring{position:fixed;width:38px;height:38px;border:1.5px solid #fff;border-radius:50%;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),opacity .25s}
.cursor.is-hover .cursor__ring{width:64px;height:64px;background:rgba(255,255,255,.08)}
@media (max-width:900px){ .cursor{display:none} }

/* ---------- Loader ---------- */
.loader{position:fixed;inset:0;z-index:9000;background:var(--bg);display:grid;place-items:center}
.loader__inner{text-align:center}
.loader__lottie{width:108px;height:128px;margin:0 auto 14px;filter:drop-shadow(0 8px 30px rgba(157,27,196,.5))}
.loader__mark span{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,7vw,4rem);letter-spacing:.04em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.loader__bar{width:220px;max-width:60vw;height:3px;background:rgba(255,255,255,.1);border-radius:99px;margin:18px auto 0;overflow:hidden}
.loader__bar i{display:block;height:100%;width:0;background:var(--grad);border-radius:99px}
.loader__tag{margin-top:14px;color:var(--muted);font-size:.85rem;letter-spacing:.28em;text-transform:uppercase}

/* ---------- Brand logo (real app wordmark, rendered via mask so it
   stays crisp + legible on dark, filled with the purple→gold gradient) ---------- */
.brand-logo{display:inline-block;background:var(--grad);
  -webkit-mask:url(assets/logo.svg) center/contain no-repeat;
  mask:url(assets/logo.svg) center/contain no-repeat;
  aspect-ratio:136/73}
.nav__brand-logo{height:40px;width:75px}
.footer__logo{height:52px;width:97px}
.loader__logo{height:104px;width:194px;margin:0 auto;
  filter:drop-shadow(0 10px 34px rgba(157,27,196,.55))}

/* ---------- Ambient aurora ---------- */
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;background:radial-gradient(120% 80% at 50% -10%,#1c0b2a 0%,#0a0410 60%)}
.aurora__blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;will-change:transform}
.aurora__blob--1{width:46vw;height:46vw;background:radial-gradient(circle,#4a0a5e,transparent 70%);top:-10%;left:-8%}
.aurora__blob--2{width:40vw;height:40vw;background:radial-gradient(circle,#5e3c0a,transparent 70%);top:30%;right:-12%}
.aurora__blob--3{width:38vw;height:38vw;background:radial-gradient(circle,#3a0a4e,transparent 70%);bottom:-15%;left:25%}
.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(120% 90% at 50% 0%,#000 30%,transparent 80%);opacity:.5}
.noise{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-display);font-weight:600;font-size:.98rem;padding:.95em 1.6em;border-radius:99px;cursor:none;border:1px solid transparent;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s}
@media(max-width:900px){.btn{cursor:pointer}}
.btn svg{flex:none}
.btn--primary{background:var(--grad);color:#ffffff;box-shadow:0 10px 40px -12px rgba(157,27,196,.7)}
.btn--primary:hover{box-shadow:0 18px 55px -10px rgba(157,27,196,.85)}
.btn--ghost{background:rgba(255,255,255,.04);color:var(--text);border-color:var(--line-strong);backdrop-filter:blur(8px)}
.btn--ghost:hover{background:rgba(255,255,255,.09)}
.btn--pill{background:rgba(255,255,255,.05);border-color:var(--line-strong);color:var(--text);padding:.7em 1.25em;font-size:.9rem}
.btn--pill:hover{background:var(--grad);color:#ffffff;border-color:transparent}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.1rem clamp(1rem,4vw,2.6rem);transition:background .4s,backdrop-filter .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
.nav.is-scrolled{background:rgba(10,4,16,.72);backdrop-filter:blur(16px) saturate(150%);border-bottom-color:var(--line);padding-top:.8rem;padding-bottom:.8rem}
.nav__brand{display:flex;align-items:center;gap:.5rem}
.nav__icon{width:34px;height:34px;border-radius:9px;box-shadow:0 6px 18px -6px rgba(157,27,196,.7)}
.nav__brand .nav__logo{align-self:baseline}
.nav__logo{font-family:var(--font-display);font-weight:800;font-size:1.35rem;letter-spacing:.02em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav__logo-sub{font-family:var(--font-display);font-weight:600;font-size:.7rem;letter-spacing:.34em;color:var(--muted)}
.nav__links{display:flex;gap:2rem}
.nav__links a{font-size:.95rem;color:var(--muted);position:relative;padding:.2em 0;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--grad);border-radius:2px;transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--text)}
.nav__links a:hover::after{width:100%}
.nav__cta{cursor:none}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.nav.menu-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.menu-open .nav__burger span:nth-child(2){transform:translateY(-0px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:90;background:rgba(10,4,16,.97);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;opacity:0;pointer-events:none;transition:opacity .4s}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--font-display);font-size:1.6rem;color:var(--text)}

@media(max-width:840px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
}

/* ---------- Layout helpers ---------- */
.section{max-width:var(--container);margin:0 auto;padding:clamp(5rem,11vw,9rem) clamp(1.1rem,4vw,2rem)}
.section__head{margin-bottom:clamp(2.5rem,5vw,4rem)}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-display);font-size:.78rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);padding:.5em 1em;border:1px solid var(--line);border-radius:99px;background:rgba(255,255,255,.02)}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 0 rgba(157,27,196,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(157,27,196,.55)}70%{box-shadow:0 0 0 10px rgba(157,27,196,0)}100%{box-shadow:0 0 0 0 rgba(157,27,196,0)}}
.section__title{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.02em;font-size:clamp(2rem,5.5vw,3.6rem);margin-top:1rem}
.section__lead{color:var(--muted);font-size:clamp(1rem,1.4vw,1.18rem);max-width:46ch;margin-top:1.3rem}

/* ---------- Hero ---------- */
.hero{max-width:1280px;margin:0 auto;min-height:100svh;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(2rem,5vw,4rem);padding:8.5rem clamp(1.1rem,4vw,2.6rem) 4rem}
.hero__copy{position:relative;z-index:2}
.hero__title{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;line-height:.98;font-size:clamp(2.9rem,8vw,5.8rem);margin:1.4rem 0}
.hero__title .line{display:block;overflow:hidden}
.hero__title em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__lead{color:var(--muted);font-size:clamp(1.02rem,1.5vw,1.22rem);max-width:48ch}
.hero__lead strong{color:var(--text);font-weight:600}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin:2rem 0 1.6rem}
.hero__rating{display:flex;align-items:center;gap:.7rem;color:var(--muted);font-size:.92rem}
.hero__rating .stars{color:var(--mint);letter-spacing:.12em}
.hero__rating strong{color:var(--text)}

/* phone */
.hero__device{position:relative;display:grid;place-items:center;perspective:1400px}
.phone{position:relative;width:clamp(260px,30vw,330px);aspect-ratio:9/19.2;border-radius:46px;background:linear-gradient(160deg,#1f0f2a,#0f0718);border:1.5px solid rgba(255,255,255,.12);padding:13px;box-shadow:0 40px 90px -30px rgba(0,0,0,.8),inset 0 0 0 2px rgba(0,0,0,.5);transform-style:preserve-3d;will-change:transform}
.phone__glow{position:absolute;inset:-30% -20%;background:radial-gradient(circle at 50% 30%,rgba(157,27,196,.25),transparent 60%);filter:blur(20px);z-index:-1}
.phone__notch{position:absolute;top:13px;left:50%;transform:translateX(-50%);width:38%;height:24px;background:#0a0410;border-radius:0 0 16px 16px;z-index:3}
.phone__screen{position:relative;width:100%;height:100%;border-radius:34px;overflow:hidden;background:#070b14;display:flex;flex-direction:column}

.mini-map{position:relative;flex:1;background:#0a101d}
.mini-map__svg{width:100%;height:100%}
.mini-map__roads path{stroke:rgba(255,255,255,.06);stroke-width:2;fill:none}
.mini-map__route{stroke-dasharray:520;stroke-dashoffset:520;filter:drop-shadow(0 0 6px rgba(157,27,196,.5))}
.mini-map__pin--start{fill:#fff;stroke:var(--mint);stroke-width:3}
.car__halo{fill:rgba(157,27,196,.25)}
.car__core{fill:var(--mint);stroke:#fff;stroke-width:2}
.dest__pin{fill:none;stroke:var(--sky);stroke-width:2.5}
.dest__dot{fill:var(--sky)}

.ride-card{background:rgba(12,17,28,.92);backdrop-filter:blur(8px);border-top:1px solid var(--line);padding:14px 14px 16px;display:flex;flex-direction:column;gap:11px}
.ride-card__bar{width:36px;height:4px;border-radius:99px;background:rgba(255,255,255,.18);margin:0 auto}
.ride-card__row{display:flex;align-items:center;justify-content:space-between}
.ride-card__driver{display:flex;align-items:center;gap:10px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--grad);color:#ffffff;font-family:var(--font-display);font-weight:700;font-size:.8rem;display:grid;place-items:center}
.ride-card__driver strong{display:block;font-size:.85rem}
.ride-card__driver span{font-size:.7rem;color:var(--muted)}
.ride-card__eta{text-align:right}
.ride-card__eta b{font-family:var(--font-display);font-size:1.3rem;color:var(--mint)}
.ride-card__eta small{display:block;font-size:.62rem;color:var(--muted);letter-spacing:.05em}
.ride-card__progress{height:5px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}
.ride-card__progress i{display:block;height:100%;width:38%;border-radius:99px;background:var(--grad);animation:fill 3.5s var(--ease) infinite alternate}
@keyframes fill{from{width:22%}to{width:82%}}
.ride-card__btn{margin-top:2px;border:0;border-radius:12px;padding:11px;font-family:var(--font-display);font-weight:600;font-size:.85rem;background:rgba(255,255,255,.06);color:var(--text);cursor:none}

.chip{position:absolute;display:flex;align-items:center;gap:.5em;font-family:var(--font-display);font-size:.8rem;font-weight:500;padding:.65em 1em;border-radius:14px;background:rgba(14,19,32,.85);border:1px solid var(--line-strong);backdrop-filter:blur(10px);box-shadow:0 16px 40px -16px rgba(0,0,0,.7);white-space:nowrap}
.chip svg{color:var(--mint)}
.chip--a{top:14%;left:-6%}
.chip--b{bottom:16%;right:-8%}
.chip--b svg{color:var(--sky)}

/* ---------- Hero screenshots (real App Store screens) ---------- */
.shots{position:relative;width:clamp(264px,30vw,340px);aspect-ratio:300/676;transform-style:preserve-3d;will-change:transform}
.shots__glow{position:absolute;inset:-22% -16%;background:radial-gradient(circle at 50% 32%,rgba(157,27,196,.4),transparent 62%);filter:blur(26px);z-index:-1}
.shot{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;border-radius:13%/6.2%;
  filter:drop-shadow(0 40px 70px rgba(0,0,0,.65));opacity:0;transform:scale(.97);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
.shot.is-active{opacity:1;transform:scale(1)}
.shots__dots{position:absolute;left:50%;bottom:-34px;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.shots__dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.22);transition:all .4s var(--ease);cursor:pointer}
.shots__dots i.is-active{width:22px;border-radius:99px;background:var(--grad)}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.4rem 0;background:rgba(255,255,255,.015);margin-top:-1rem}
.marquee__track{display:flex;align-items:center;gap:2.4rem;width:max-content;will-change:transform}
.marquee__track span{font-family:var(--font-display);font-weight:600;font-size:clamp(1.1rem,2.4vw,1.7rem);color:var(--muted-dim)}
.marquee__track i{color:var(--mint);font-style:normal;font-size:.9rem}

/* ---------- Stats ---------- */
.stats{max-width:var(--container);margin:0 auto;padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2rem);display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{padding:1.6rem 1.4rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(255,255,255,.01))}
.stat b{font-family:var(--font-display);font-weight:800;font-size:clamp(1.9rem,3.5vw,2.7rem);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block}
.stat p{color:var(--muted);font-size:.9rem;margin-top:.5rem}
@media(max-width:820px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- Bento features ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(220px,auto);gap:1.2rem}
.bento__card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem;background:linear-gradient(165deg,rgba(255,255,255,.045),rgba(255,255,255,.012));transition:transform .5s var(--ease),border-color .4s,box-shadow .5s var(--ease);transform-style:preserve-3d}
.bento__card::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:opacity .5s}
.bento__card:hover{border-color:var(--line-strong);box-shadow:0 30px 70px -34px rgba(157,27,196,.4)}
.bento__card:hover::before{opacity:1}
.bento__card--lg{grid-row:span 2}
.bento__card--wide{grid-column:span 2}
.tile__icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:rgba(157,27,196,.12);border:1px solid rgba(157,27,196,.25);color:var(--mint);margin-bottom:1.2rem;position:relative;z-index:1}
.tile h3{font-family:var(--font-display);font-weight:600;font-size:1.35rem;position:relative;z-index:1}
.tile p{color:var(--muted);margin-top:.6rem;position:relative;z-index:1;max-width:44ch}

.tile__art{position:absolute;right:-30px;bottom:-30px;width:180px;height:180px;display:grid;place-items:center}
.ripple{position:absolute;border:1.5px solid rgba(157,27,196,.4);border-radius:50%;width:40px;height:40px;animation:ripple 3s ease-out infinite}
.ripple:nth-child(2){animation-delay:1s}
.ripple:nth-child(3){animation-delay:2s}
@keyframes ripple{0%{transform:scale(.4);opacity:.9}100%{transform:scale(3.4);opacity:0}}
.tile__pin{width:14px;height:14px;background:var(--mint);border-radius:50%;box-shadow:0 0 16px var(--mint)}
.tile__dots{display:flex;gap:8px;margin-top:1.4rem;position:relative;z-index:1}
.tile__dots i{width:34px;height:6px;border-radius:99px;background:rgba(255,255,255,.1)}
.tile__dots i:nth-child(-n+3){background:var(--grad)}

@media(max-width:860px){
  .bento{grid-template-columns:1fr 1fr}
  .bento__card--lg{grid-row:auto}
  .bento__card--wide{grid-column:span 2}
}
@media(max-width:560px){
  .bento{grid-template-columns:1fr}
  .bento__card--wide{grid-column:auto}
}

/* ---------- About / official description ---------- */
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.about__intro .section__lead{max-width:48ch}
.why{margin-top:2.2rem;padding:1.8rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(155deg,rgba(157,27,196,.07),rgba(255,206,106,.05));position:relative;overflow:hidden}
.why::before{content:"";position:absolute;inset:auto -20% -60% auto;width:60%;height:120%;background:radial-gradient(circle,rgba(157,27,196,.18),transparent 70%);filter:blur(30px)}
.why h3{font-family:var(--font-display);font-weight:700;font-size:1.3rem;position:relative;z-index:1}
.why p{color:var(--muted);margin-top:.6rem;position:relative;z-index:1}
.why .btn{margin-top:1.4rem;position:relative;z-index:1}

.about__list{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.about__item{display:flex;gap:1.1rem;align-items:flex-start;padding:1.3rem 1.4rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(165deg,rgba(255,255,255,.045),rgba(255,255,255,.012));transition:transform .45s var(--ease),border-color .35s,box-shadow .45s var(--ease)}
.about__item:hover{transform:translateX(6px);border-color:var(--line-strong);box-shadow:0 24px 60px -34px rgba(157,27,196,.45)}
.about__emoji{flex:none;width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;background:rgba(157,27,196,.1);border:1px solid rgba(157,27,196,.22)}
.about__item h4{font-family:var(--font-display);font-weight:600;font-size:1.12rem}
.about__item p{color:var(--muted);font-size:.95rem;margin-top:.35rem}
@media(max-width:820px){.about__grid{grid-template-columns:1fr}}

/* ---------- How it works ---------- */
.steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.steps__line{display:none;position:absolute;top:34px;left:6%;right:6%;height:2px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.steps__line i{display:block;height:100%;width:0;background:var(--grad)}
.step{position:relative;padding-top:.5rem}
.step__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:linear-gradient(165deg,rgba(157,27,196,.14),rgba(251,176,64,.06));aspect-ratio:4/3.4;margin-bottom:1.4rem;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.step:hover .step__media{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:0 30px 70px -34px rgba(157,27,196,.55)}
.step__media picture{display:block;width:100%;height:100%}
.step__media img{width:100%;height:100%;object-fit:contain;object-position:center bottom;padding:1rem 1rem 0}
.step__num{position:absolute;top:14px;left:14px;font-family:var(--font-display);font-weight:800;font-size:1.05rem;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(10,4,16,.7);backdrop-filter:blur(6px);border:1px solid var(--line-strong);color:var(--gold);z-index:2}
.step h3{font-family:var(--font-display);font-weight:600;font-size:1.28rem;line-height:1.2}
.step p{color:var(--muted);margin-top:.5rem;max-width:36ch}
@media(max-width:1024px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps{grid-template-columns:1fr}.steps__line{display:none}}

/* ---------- Live tracking ---------- */
.track{display:grid;grid-template-columns:1fr 1.1fr;align-items:center;gap:clamp(2rem,5vw,4rem)}
.track .section__title{margin-top:1rem}
.ticks{list-style:none;margin-top:1.8rem;display:flex;flex-direction:column;gap:.9rem}
.ticks li{display:flex;align-items:center;gap:.8rem;font-size:1.02rem}
.ticks li span{flex:none;width:24px;height:24px;border-radius:50%;background:rgba(157,27,196,.14);border:1px solid rgba(157,27,196,.4);position:relative}
.ticks li span::after{content:"";position:absolute;left:8px;top:5px;width:6px;height:10px;border:solid var(--mint);border-width:0 2px 2px 0;transform:rotate(45deg)}

.map-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-strong);aspect-ratio:5/4;background:#070d18;box-shadow:0 40px 100px -40px rgba(0,0,0,.8)}
.big-map{width:100%;height:100%}
.big-map__roads path{stroke:rgba(255,255,255,.05);stroke-width:2;fill:none}
.big-map__route{stroke-dasharray:760;stroke-dashoffset:760;filter:drop-shadow(0 0 10px rgba(157,27,196,.45))}
.big-map__start{fill:#fff;stroke:var(--mint);stroke-width:4}
.dest__pin--big{stroke-width:3}
.map-card__hud{position:absolute;left:18px;right:18px;bottom:18px}
.map-card__hud-row{display:flex;align-items:center;justify-content:space-between;background:rgba(8,13,24,.82);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:16px;padding:.8rem 1.1rem}
.map-card__live{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);font-weight:700;font-size:.75rem;letter-spacing:.18em;color:var(--mint)}
.map-card__live i{width:8px;height:8px;border-radius:50%;background:var(--mint);animation:blink 1.2s infinite}
@keyframes blink{50%{opacity:.25}}
.map-card__eta-big{font-size:.92rem;color:var(--muted)}
.map-card__eta-big b{font-family:var(--font-display);color:var(--text);font-size:1.1rem}
@media(max-width:820px){.track{grid-template-columns:1fr}}

/* ---------- Drive ---------- */
.drive__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center;padding:clamp(2.4rem,4vw,3.6rem);border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(150deg,rgba(157,27,196,.06),rgba(255,206,106,.05));position:relative;overflow:hidden}
.drive__inner .btn{margin-top:1.8rem}
.drive__metrics{display:flex;flex-direction:column;gap:1rem}
.metric{padding:1.2rem 1.3rem;border:1px solid var(--line);border-radius:18px;background:rgba(10,4,16,.5)}
.metric b{font-family:var(--font-display);font-size:1.2rem;display:block;color:var(--text)}
.metric span{color:var(--muted);font-size:.9rem}
@media(max-width:760px){.drive__inner{grid-template-columns:1fr}}

/* ---------- CTA ---------- */
.cta__card{position:relative;max-width:920px;margin:0 auto;text-align:center;padding:clamp(3rem,7vw,5.5rem) clamp(1.5rem,5vw,4rem);border:1px solid var(--line-strong);border-radius:var(--radius-lg);background:linear-gradient(160deg,rgba(14,19,32,.9),rgba(8,11,20,.9));overflow:hidden}
.cta__glow{position:absolute;inset:auto 0 -40% 0;height:70%;background:radial-gradient(60% 100% at 50% 100%,rgba(157,27,196,.4),transparent 70%);filter:blur(40px);z-index:0}
.cta__title{position:relative;z-index:1;font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;line-height:1.02;font-size:clamp(2.1rem,6vw,4rem)}
.cta__lead{position:relative;z-index:1;color:var(--muted);max-width:46ch;margin:1.2rem auto 0;font-size:1.08rem}
.store-buttons{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2.2rem}
.store-btn{display:inline-flex;align-items:center;gap:.8rem;padding:.85rem 1.5rem;border-radius:16px;background:#0c1120;border:1px solid var(--line-strong);transition:transform .35s var(--ease),border-color .3s,background .3s;cursor:none}
.store-btn:hover{transform:translateY(-3px);border-color:var(--mint);background:#10162a}
.store-btn span{display:flex;flex-direction:column;line-height:1.1;text-align:left}
.store-btn small{font-size:.68rem;color:var(--muted);letter-spacing:.04em}
.store-btn strong{font-family:var(--font-display);font-size:1.1rem}
@media(max-width:900px){.store-btn{cursor:pointer}}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);background:rgba(10,4,16,.6);margin-top:4rem}
.footer__top{max-width:var(--container);margin:0 auto;padding:clamp(3rem,6vw,4.5rem) clamp(1.1rem,4vw,2rem) 2.5rem;display:grid;grid-template-columns:1fr 1.4fr;gap:2.5rem}
.footer__brand-row{display:flex;align-items:center;gap:.55rem}
.footer__brand-row img{width:40px;height:40px;border-radius:11px;box-shadow:0 8px 22px -8px rgba(157,27,196,.7)}
.footer__brand-row .nav__logo{align-self:baseline}
.footer__brand p{color:var(--muted);margin-top:.8rem}
.footer__credit .heart{color:var(--rose,#f43f5e);font-style:normal;animation:beat 1.4s ease-in-out infinite;display:inline-block}
.footer__credit strong{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}
@keyframes beat{0%,100%{transform:scale(1)}15%{transform:scale(1.28)}30%{transform:scale(1)}45%{transform:scale(1.18)}}
.footer__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.footer__cols h4{font-family:var(--font-display);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-dim);margin-bottom:1rem}
.footer__cols a{display:block;color:var(--muted);font-size:.95rem;padding:.28rem 0;transition:color .3s}
.footer__cols a:hover{color:var(--mint)}
.footer__bottom{max-width:var(--container);margin:0 auto;padding:1.5rem clamp(1.1rem,4vw,2rem);border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--muted-dim);font-size:.85rem}
@media(max-width:680px){.footer__top{grid-template-columns:1fr}.footer__cols{grid-template-columns:1fr 1fr}}

/* ---------- Reveal animation base ----------
   Initial hidden state is gated behind `.js` so that if JS/GSAP fails to load,
   all content stays visible (no blank/overlapping hero). */
.hero__title .line{display:block;overflow:hidden;padding-bottom:.08em}
.hero__title .line > span{display:block}
.js [data-reveal]{opacity:0;transform:translateY(34px)}
.js .hero__title .line > span{transform:translateY(110%)}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .js [data-reveal],.js .hero__title .line > span{opacity:1!important;transform:none!important}
}
