
/* ════════════════════════════════════════════════════════
   THEMES — dark (default) and light
   Switch via <html data-theme="light/dark">
   ════════════════════════════════════════════════════════ */

[data-theme="dark"] {
  --bg:     #06060E;
  --bg2:    #0D0D1A;
  --bg3:    #121226;
  --red:    #7265D5;
  --red2:   #9B8EF0;
  --gold:   #A594F9;
  --cyan:   #C4B5FD;
  --white:  #F0EEFF;
  --muted:  #7A788F;
  --border: rgba(255,255,255,0.07);
  --glass:  rgba(255,255,255,0.035);
  --card-shadow: 0 4px 24px rgba(0,0,0,.4);
  --nav-bg: rgba(6,6,14,0.85);
  --ticker-bg: #0D0D1A;
  --region-fill: rgba(15,15,40,0.95);
  --region-stroke: rgba(114,101,213,0.32);
  --trans-fill: rgba(114,101,213,0.09);
  --text-on-dark: rgba(255,255,255,0.85);
  --map-grid: rgba(255,255,255,0.5);
  --split-dr-bg: linear-gradient(155deg,#0D0A20 0%,#0A0818 100%);
  --split-ps-bg: linear-gradient(155deg,#060610 0%,#06100E 100%);
  --feat-bg:  linear-gradient(135deg,#0C0A1F,#0A0818);
  --scroll-bg: rgba(255,255,255,.04);
}

[data-theme="light"] {
  --bg:     #F5F4FF;
  --bg2:    #FFFFFF;
  --bg3:    #EDECFB;
  --red:    #5B4EC8;
  --red2:   #7265D5;
  --gold:   #8B7FE8;
  --cyan:   #7265D5;
  --white:  #1C1A35;
  --muted:  #6B69A0;
  --border: rgba(114,101,213,0.15);
  --glass:  rgba(114,101,213,0.06);
  --card-shadow: 0 4px 24px rgba(114,101,213,.1);
  --nav-bg: rgba(245,244,255,0.92);
  --ticker-bg: #EDECFB;
  --region-fill: rgba(237,236,251,0.95);
  --region-stroke: rgba(114,101,213,0.35);
  --trans-fill: rgba(114,101,213,0.12);
  --text-on-dark: rgba(28,26,53,0.85);
  --map-grid: rgba(114,101,213,0.4);
  --split-dr-bg: linear-gradient(155deg,#EAE8FF 0%,#F5F4FF 100%);
  --split-ps-bg: linear-gradient(155deg,#F5F4FF 0%,#EAF4FF 100%);
  --feat-bg:  linear-gradient(135deg,#EAE8FF,#F0EEFF);
  --scroll-bg: rgba(114,101,213,.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--white);font-family:'Nunito',sans-serif;overflow-x:hidden;cursor:none}

/* grain */
body::after{content:'';position:fixed;inset:0;z-index:9990;pointer-events:none;
  opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;mix-blend-mode:screen}

/* cursor */
#cur{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  width:10px;height:10px;border-radius:50%;background:var(--red);
  transform:translate(-50%,-50%);mix-blend-mode:exclusion;
  transition:width .35s cubic-bezier(.16,1,.3,1),height .35s cubic-bezier(.16,1,.3,1)}
#cur.big{width:52px;height:52px;background:rgba(114,101,213,.3)}

/* scroll bar */
#sp{position:fixed;left:0;top:0;bottom:0;width:2px;z-index:500;background:var(--scroll-bg)}
#sp i{position:absolute;top:0;left:0;width:100%;background:linear-gradient(to bottom,var(--red),var(--gold));height:0;transition:height .08s}
::-webkit-scrollbar{width:0}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 5vw;
  background:var(--nav-bg);backdrop-filter:blur(24px) saturate(1.4);
  border-bottom:1px solid var(--border)}

/* ── BETA badge in nav ── */
.beta-badge {
  font-family: 'Nunito', sans-serif;
  font-size: .52rem;
  font-weight: 800;
  letter-spacing: .1em;
  color: var(--red);
  background: rgba(114,101,213,.15);
  border: 1px solid rgba(114,101,213,.4);
  padding: .15rem .45rem;
  border-radius: 4px;
  vertical-align: middle;
  margin-left: .4rem;
  position: relative;
  top: -2px;
}
.nl{font-family:'Nunito',sans-serif;font-size:1.9rem;letter-spacing:.04em;text-decoration:none;color:var(--white);font-weight:900;text-transform:uppercase}
.nl em{color:var(--red);font-style:normal}
.nr{display:flex;gap:2.5rem;align-items:center}
.nr a{color:var(--muted);text-decoration:none;font-size:.85rem;font-weight:500;letter-spacing:.03em;transition:color .2s}
.nr a:hover{color:var(--white)}
.nb{background:var(--red)!important;color:#fff!important;padding:.5rem 1.4rem!important;
  border-radius:6px!important;font-weight:600!important;font-size:.82rem!important;
  transition:transform .2s,box-shadow .2s!important}
.nb:hover{transform:translateY(-1px)!important;box-shadow:0 8px 28px rgba(114,101,213,.5)!important}
.lang-sw{display:flex;gap:4px;align-items:center;margin-left:.5rem}
.lbtn{background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Nunito',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.08em;padding:.35rem .65rem;border-radius:6px;cursor:pointer;
  transition:all .2s;}
.lbtn:hover{border-color:rgba(114,101,213,.5);color:var(--white)}
.lbtn.active{background:var(--red);border-color:var(--red);color:#fff}

/* ═══════════════════════════ HERO ═══ */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;
  padding:5rem 5vw 3rem;gap:3rem;position:relative;overflow:hidden}

.hero-bg-glow{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 45% 55% at 15% 55%,rgba(114,101,213,.09) 0%,transparent 60%),
    radial-gradient(ellipse 35% 40% at 80% 30%,rgba(165,148,249,.05) 0%,transparent 55%)}

/* Left */
.hl{position:relative;z-index:2}
.h-badge{display:inline-flex;align-items:center;gap:8px;margin-bottom:1.8rem;
  font-size:.7rem;font-weight:700;color:var(--red2);text-transform:uppercase;letter-spacing:.12em;
  animation:fup .7s ease both}
.h-badge::before{content:'';width:24px;height:1px;background:var(--red);
  animation:widen .8s .2s ease both;transform-origin:left}
@keyframes widen{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.h-title{font-family:'Nunito',sans-serif;text-transform:uppercase;
  font-size:clamp(4.5rem,11vw,9.5rem);line-height:.9;letter-spacing:-.01em;
  margin-bottom:1.8rem;animation:fup .8s .08s ease both}
.h-title .ghost{color:rgba(255,255,255,.18);display:block}
.h-title .fire{color:var(--red);display:block;text-shadow:0 0 60px rgba(114,101,213,.35)}
.h-sub{color:var(--muted);font-size:1rem;line-height:1.7;max-width:400px;margin-bottom:2rem;
  animation:fup .8s .16s ease both}
.h-sub strong{color:var(--white);font-weight:500}
.h-btns{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem;animation:fup .8s .22s ease both}
.btn-p{display:inline-flex;align-items:center;gap:9px;background:var(--red);color:#fff;
  text-decoration:none;font-weight:600;font-size:.9rem;padding:.85rem 1.8rem;
  border-radius:7px;position:relative;overflow:hidden;
  transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s}
.btn-p::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 60%)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(114,101,213,.45)}
.btn-g{display:inline-flex;align-items:center;gap:9px;color:var(--white);text-decoration:none;
  font-weight:500;font-size:.9rem;padding:.85rem 1.8rem;border-radius:7px;
  border:1px solid var(--border);background:var(--glass);backdrop-filter:blur(8px);
  transition:border-color .25s,background .25s}
.btn-g:hover{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.07)}
.h-stats{display:flex;gap:2rem;animation:fup .8s .28s ease both}
.hs-n{font-family:'Nunito',sans-serif;font-weight:900;font-size:2.2rem;line-height:1;color:var(--white)}
.hs-n em{color:var(--red);font-style:normal}
.hs-l{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

@keyframes fup{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}

/* Right — Map */
.hr{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;
  animation:fup .9s .1s ease both}
.map-container{position:relative;width:100%;max-width:480px}
.map-container svg{width:100%;height:auto;display:block}

/* floating trip card on map */
.map-trip-card{
  position:absolute;
  bottom:8%;left:-5%;
  background:rgba(13,13,26,.92);
  border:1px solid rgba(114,101,213,.25);
  backdrop-filter:blur(16px);
  border-radius:16px;padding:14px 16px;
  min-width:200px;
  animation:floatCard 5s ease-in-out infinite;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
}
@keyframes floatCard{
  0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.mtc-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.mtc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.mtc-dot.a{background:var(--red);box-shadow:0 0 6px rgba(114,101,213,.8)}
.mtc-dot.b{background:var(--gold);box-shadow:0 0 6px rgba(165,148,249,.7)}
.mtc-line{width:1px;height:16px;background:var(--border);margin-left:3.5px}
.mtc-txt{font-size:.75rem;font-weight:500}
.mtc-sub{font-size:.65rem;color:var(--muted)}
.mtc-footer{display:flex;justify-content:space-between;align-items:center;
  margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.mtc-price{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.1rem;color:var(--gold)}
.mtc-seats{font-size:.7rem;color:var(--muted)}

/* badge on map - top right */
.map-badge{position:absolute;top:5%;right:0%;
  background:rgba(13,13,26,.88);border:1px solid rgba(196,181,253,.2);
  backdrop-filter:blur(12px);border-radius:12px;padding:10px 14px;
  animation:floatCard 6s 1s ease-in-out infinite;
  box-shadow:0 16px 40px rgba(0,0,0,.4)}
.mb-num{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.5rem;line-height:1;color:var(--cyan)}
.mb-lbl{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* ═══════════════════════════ TICKER ═══ */
.ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--ticker-bg);padding:.85rem 0;overflow:hidden;white-space:nowrap}
.ti{display:inline-flex;animation:tick 25s linear infinite}
.titem{display:inline-flex;align-items:center;gap:.6rem;padding:0 2rem;
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.tdot{width:4px;height:4px;border-radius:50%;background:var(--red);flex-shrink:0}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════ SECTION BASE ═══ */
section{padding:6rem 5vw}
.slabel{font-size:.68rem;font-weight:700;color:var(--red);text-transform:uppercase;
  letter-spacing:.14em;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}
.slabel::before{content:'';width:18px;height:1px;background:var(--red)}
.stitle{font-family:'Nunito',sans-serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:900;text-transform:uppercase;
  line-height:.95;letter-spacing:-.01em;margin-bottom:.8rem}
.ssub{color:var(--muted);font-size:.92rem;line-height:1.7;max-width:460px}

/* ═══════════════════════════ BENTO ═══ */
#bento{background:var(--bg2)}
.bh{max-width:560px;margin-bottom:3.5rem}
.bgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);border-radius:20px;overflow:hidden}
.bc{background:var(--bg2);padding:2rem;position:relative;overflow:hidden;transition:background .3s}
.bc:hover{background:var(--bg3)}
.bc::after{content:'';position:absolute;top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
  transform:scaleX(0);transform-origin:center;transition:transform .45s}
.bc:hover::after{transform:scaleX(1)}
.bc.w2{grid-column:span 2}.bc.w4{grid-column:span 4}
.bci{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  font-size:19px;margin-bottom:1.1rem;border:1px solid var(--border);background:var(--glass)}
.bc h3{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.25rem;letter-spacing:.02em;margin-bottom:.45rem}
.bc p{color:var(--muted);font-size:.83rem;line-height:1.6}
.bc-big{font-family:'Nunito',sans-serif;font-weight:900;text-transform:uppercase;font-size:clamp(3rem,7vw,6rem);
  line-height:.9;color:var(--red);margin:auto 0 .8rem;text-shadow:0 0 50px rgba(114,101,213,.25)}
.bc.feat{grid-column:span 2;grid-row:span 2;display:flex;flex-direction:column;
  background:var(--feat-bg)}

/* ═══════════════════════════ PHONE SHOWCASE ═══ */
#show{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.shl .stitle{margin-bottom:1.5rem}
.pills{display:flex;flex-direction:column;gap:.7rem;margin-top:2.5rem}
.pill{display:flex;align-items:center;gap:1rem;background:var(--bg2);
  border:1px solid var(--border);padding:.85rem 1.2rem;border-radius:12px;
  font-size:.88rem;transition:border-color .3s,transform .2s;cursor:default}
.pill:hover{border-color:rgba(114,101,213,.3);transform:translateX(6px)}
.pi{width:34px;height:34px;border-radius:9px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:15px;
  background:rgba(114,101,213,.1);border:1px solid rgba(114,101,213,.14)}
.pt strong{display:block;font-size:.84rem;font-weight:600}
.pt span{font-size:.73rem;color:var(--muted)}

.shr{display:flex;justify-content:center;align-items:center;position:relative}
.pw{animation:fp 7s ease-in-out infinite;position:relative}
@keyframes fp{
  0%,100%{transform:perspective(900px) rotateY(-5deg) rotateX(2deg)}
  50%{transform:perspective(900px) rotateY(4deg) rotateX(-1deg) translateY(-14px)}}

.phone{width:228px;background:var(--bg2);border-radius:34px;
  border:1.5px solid rgba(255,255,255,.1);
  box-shadow:0 55px 90px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.08);
  padding:15px 13px 13px;position:relative;overflow:hidden}
.phone::before{content:'';position:absolute;top:11px;left:50%;transform:translateX(-50%);
  width:60px;height:4px;border-radius:2px;background:rgba(255,255,255,.1)}
.phinner{padding-top:10px}
.ptop{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.plogo{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.05rem;letter-spacing:.04em}
.plogo em{color:var(--red);font-style:normal}
.pava{width:26px;height:26px;border-radius:50%;background:var(--red)}
.pmb{height:140px;border-radius:16px;background:#0E0E22;position:relative;overflow:hidden;margin-bottom:9px}
.pcard{background:var(--scroll-bg);border:1px solid var(--border);border-radius:13px;
  padding:9px;display:flex;align-items:center;gap:8px;margin-bottom:7px}
.pcic{width:30px;height:30px;border-radius:8px;flex-shrink:0;
  background:rgba(114,101,213,.14);display:flex;align-items:center;justify-content:center;font-size:13px}
.pct{font-size:.62rem;color:var(--muted)}.pcb{font-size:.72rem;font-weight:600}
.pcard2{background:rgba(165,148,249,.06);border:1px solid rgba(165,148,249,.1);
  border-radius:13px;padding:9px 11px;display:flex;justify-content:space-between;align-items:center}
.pc2l{font-size:.67rem;color:rgba(165,148,249,.75)}
.pc2r{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.2rem;color:var(--gold)}

.pr1,.pr2,.pr3{position:absolute;border-radius:50%;border:1px solid;animation:rp 4s ease-in-out infinite}
.pr1{width:300px;height:300px;top:50%;left:50%;transform:translate(-50%,-50%);border-color:rgba(114,101,213,.07)}
.pr2{width:460px;height:460px;top:50%;left:50%;transform:translate(-50%,-50%);border-color:rgba(114,101,213,.04);animation-delay:.8s}
.pr3{width:620px;height:620px;top:50%;left:50%;transform:translate(-50%,-50%);border-color:rgba(114,101,213,.02);animation-delay:1.6s}
@keyframes rp{0%,100%{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.4;transform:translate(-50%,-50%) scale(1.04)}}

/* ═══════════════════════════ ROUTES ═══ */
#routes{background:var(--bg2)}
.rg{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1px;background:var(--border);border:1px solid var(--border);border-radius:18px;overflow:hidden;margin-top:3rem}
.rc{background:var(--bg2);padding:1.8rem;transition:background .3s;position:relative;overflow:hidden}
.rc:hover{background:var(--bg3)}
.rc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--red),var(--gold));
  transform:scaleX(0);transform-origin:left;transition:transform .4s}
.rc:hover::after{transform:scaleX(1)}
.rc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.rc-r{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.4rem;letter-spacing:.02em;line-height:1.05}
.rc-p{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.4rem;color:var(--gold);white-space:nowrap}
.rc-meta{display:flex;gap:.5rem;flex-wrap:wrap}
.rm{font-size:.69rem;color:var(--muted);border:1px solid var(--border);border-radius:100px;padding:.2rem .65rem;background:var(--glass)}

/* ═══════════════════════════ SPLIT ═══ */
#split{display:grid;grid-template-columns:1fr 1fr;padding:0}
.sp{padding:6rem 5vw;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}
.sp.dr{background:var(--split-dr-bg)}
.sp.ps{background:var(--split-ps-bg)}
.sp::before{content:'';position:absolute;inset:0;pointer-events:none}
.sp.dr::before{background:radial-gradient(ellipse 70% 50% at 110% 0%,rgba(114,101,213,.07),transparent)}
.sp.ps::before{background:radial-gradient(ellipse 70% 50% at -10% 0%,rgba(165,148,249,.05),transparent)}
.sdiv{width:1px;background:var(--border)}
.stag{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  padding:.3rem .9rem;border-radius:100px;display:inline-block;margin-bottom:2rem}
.dr .stag{background:rgba(114,101,213,.1);color:var(--red);border:1px solid rgba(114,101,213,.22)}
.ps .stag{background:rgba(165,148,249,.07);color:var(--gold);border:1px solid rgba(165,148,249,.18)}
.sp h3{font-family:'Nunito',sans-serif;font-weight:900;font-size:clamp(2.2rem,4.5vw,3.8rem);letter-spacing:-.01em;line-height:.95;margin-bottom:1.2rem}
.sp p{color:var(--muted);font-size:.9rem;line-height:1.7;max-width:380px;margin-bottom:2rem}
.cl{display:flex;flex-direction:column;gap:.65rem}
.ci{display:flex;align-items:center;gap:.75rem;font-size:.84rem;color:rgba(255,255,255,.75)}
.ck{width:18px;height:18px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px}
.dr .ck{background:rgba(114,101,213,.14);color:var(--red)}
.ps .ck{background:rgba(165,148,249,.09);color:var(--gold)}
.sp-bg{position:absolute;right:-1rem;bottom:-2rem;font-family:'Nunito',sans-serif;
  font-size:clamp(7rem,18vw,16rem);line-height:1;opacity:.04;color:var(--white);
  pointer-events:none;user-select:none;letter-spacing:-.04em}

/* ═══════════════════════════ SOCIAL PROOF ═══ */
#social{background:var(--bg2)}
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);border-radius:20px;overflow:hidden;margin-top:3rem}
.tc{background:var(--bg2);padding:2rem;transition:background .3s}
.tc:hover{background:var(--bg3)}
.tc-top{display:flex;align-items:center;gap:.75rem;margin-bottom:1.2rem}
.ta{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Nunito',sans-serif;font-size:1rem;font-weight:700;flex-shrink:0}
.tc-name{font-weight:600;font-size:.9rem}
.tc-meta{font-size:.72rem;color:var(--muted)}
.tc-stars{color:var(--gold);font-size:.8rem;margin-bottom:.75rem;letter-spacing:2px}
.tc-text{color:var(--muted);font-size:.85rem;line-height:1.6}

/* ═══════════════════════════ CTA ═══ */
#cta{text-align:center;padding:9rem 5vw;position:relative;overflow:hidden}
#cta::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 55% 55% at 50% 50%,rgba(114,101,213,.08) 0%,transparent 65%)}
.ct-label{font-size:.68rem;font-weight:700;color:var(--red);text-transform:uppercase;
  letter-spacing:.14em;margin-bottom:1rem;display:block;position:relative;z-index:1}
.ct-title{font-family:'Nunito',sans-serif;font-size:clamp(4rem,12vw,11rem);font-weight:900;text-transform:uppercase;
  line-height:.9;letter-spacing:-.02em;margin-bottom:1.2rem;position:relative;z-index:1}
.ct-title .ct-ghost{display:block;color:rgba(255,255,255,.15)}
.ct-sub{color:var(--muted);font-size:.95rem;max-width:400px;margin:0 auto 3rem;line-height:1.7;position:relative;z-index:1}
.stores{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.sb{display:flex;align-items:center;gap:14px;background:var(--bg2);
  border:1px solid var(--border);padding:1rem 1.8rem;border-radius:14px;
  text-decoration:none;color:var(--white);
  transition:border-color .3s,transform .25s cubic-bezier(.16,1,.3,1),box-shadow .3s}
.sb:hover{border-color:rgba(255,255,255,.18);transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.45)}
.sbi{font-size:2.1rem;line-height:1}
.sbt small{display:block;color:var(--muted);font-size:.63rem;text-transform:uppercase;letter-spacing:.1em}
.sbt strong{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.15rem;letter-spacing:.04em}

/* footer */
footer{border-top:1px solid var(--border);background:var(--bg2);
  padding:2.5rem 5vw;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.fl{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.4rem;letter-spacing:.04em}
.fl em{color:var(--red);font-style:normal}
.fc{color:var(--muted);font-size:.78rem}
.fls{display:flex;gap:2rem}
.fls a{color:var(--muted);font-size:.78rem;text-decoration:none;transition:color .2s}
.fls a:hover{color:var(--white)}

/* reveals */
.rev{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.rev.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}

/* responsive */
  #show{grid-template-columns:1fr}.shr{display:none}
  #split{grid-template-columns:1fr}.sdiv{display:none}
  .tg{grid-template-columns:1fr}
  .bgrid{grid-template-columns:repeat(2,1fr)}
  .bc.feat{grid-column:span 2}
  .nr{display:none}
}
.bc.feat,.bc.w2{grid-column:span 1}
  .h-stats{flex-wrap:wrap;gap:1.5rem}
  footer{flex-direction:column;text-align:center}.fls{justify-content:center}
}




/* ── STATUS SECTION ── */
#status{background:var(--bg);padding:6rem 5vw}
.status-grid{
  display:grid;grid-template-columns:1fr 2fr;gap:4rem;align-items:start;margin-top:3.5rem;
}

/* Big progress circle */
.prog-circle-wrap{display:flex;flex-direction:column;align-items:center;gap:1.5rem}
.prog-circle{position:relative;width:180px;height:180px}
.prog-circle svg{transform:rotate(-90deg)}
.prog-circle .track{fill:none;stroke:rgba(114,101,213,.12);stroke-width:10}
.prog-circle .fill{
  fill:none;stroke-width:10;stroke-linecap:round;
  stroke:url(#pg-grad);
  stroke-dasharray:502;
  stroke-dashoffset:502;
  transition:stroke-dashoffset 1.8s cubic-bezier(.16,1,.3,1);
}
.prog-circle .fill.animated{stroke-dashoffset:calc(502 - 502 * 0.72)}
.prog-num{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'Nunito',sans-serif;font-size:2.6rem;font-weight:900;
  color:var(--white);line-height:1;text-align:center;
}
.prog-num small{display:block;font-size:.7rem;font-weight:500;color:var(--muted);margin-top:.1rem}
.prog-label{font-size:.78rem;color:var(--muted);text-align:center;
  text-transform:uppercase;letter-spacing:.1em;font-weight:600}

/* Feature bars */
.feat-bars{display:flex;flex-direction:column;gap:1.4rem}
.fbar{display:flex;flex-direction:column;gap:.5rem}
.fbar-top{display:flex;justify-content:space-between;align-items:center}
.fbar-name{font-size:.88rem;font-weight:600;display:flex;align-items:center;gap:.6rem}
.fbar-icon{
  width:28px;height:28px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:13px;
  background:rgba(114,101,213,.1);border:1px solid rgba(114,101,213,.15);flex-shrink:0;
}
.fbar-pct{font-family:'Nunito',sans-serif;font-size:.85rem;font-weight:800;color:var(--red)}
.fbar-track{
  height:6px;background:rgba(255,255,255,.06);border-radius:100px;overflow:hidden;
}
.fbar-fill{
  height:100%;border-radius:100px;width:0;
  background:linear-gradient(90deg,var(--red),#9B8EF0);
  transition:width 1.4s cubic-bezier(.16,1,.3,1);
}
.fbar-fill.done{background:linear-gradient(90deg,#22C55E,#4ADE80)}

/* Roadmap */
.roadmap{display:flex;gap:0;margin-top:3.5rem;position:relative}
.roadmap::before{
  content:'';position:absolute;top:20px;left:20px;right:20px;height:2px;
  background:linear-gradient(90deg,var(--red) 0%,rgba(114,101,213,.3) 100%);
  z-index:0;
}
.rm-step{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem;
  position:relative;z-index:1;
}
.rm-dot{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:15px;
  border:2px solid var(--border);background:var(--bg2);
  position:relative;overflow:visible;
  transition:border-color .3s,background .3s;
}
.rm-step.done .rm-dot{
  background:linear-gradient(135deg,var(--red),#9B8EF0);
  border-color:transparent;
}
.rm-step.current .rm-dot{
  background:var(--bg2);border-color:var(--red);
  box-shadow:0 0 16px rgba(114,101,213,.4);
}
.rm-step.current .rm-dot::after{
  content:'';position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:56px;height:56px;border-radius:50%;
  border:1.5px solid rgba(114,101,213,.4);
  animation:rp 2.5s ease-in-out infinite;
  pointer-events:none;
}
.rm-text{text-align:center}
.rm-title{font-size:.78rem;font-weight:700;margin-bottom:.2rem}
.rm-sub{font-size:.68rem;color:var(--muted)}
.rm-step.done .rm-title{color:var(--white)}
.rm-step.current .rm-title{color:var(--red)}
.rm-step:not(.done):not(.current) .rm-title{color:var(--muted)}

  .prog-circle-wrap{flex-direction:row;align-items:center}
  .roadmap{flex-direction:column;gap:1.5rem}
  .roadmap::before{display:none}
}

/* ══════════════════════════════════════════════════
   i18n LAYOUT LOCK — prevents resize on lang switch
   ══════════════════════════════════════════════════ */

/* NAV — never wrap */
.nr a { white-space:nowrap }
.lang-sw { flex-shrink:0 }

/* HERO TITLE — fixed line heights so 3 lines always hold space */
.h-title {
  min-height: 2.85em;          /* holds 3 lines at any language */
}
/* HERO SUBTITLE — longest text is Romanian ~120 chars */
.h-sub {
  min-height: 5.6em;
}
/* HERO BUTTONS — centered, fixed min-width */
.btn-p, .btn-g {
  min-width: 196px;
  justify-content: center;
}
/* HERO STAT LABELS */
.hs-l {
  min-height: 1.4em;
  white-space: nowrap;
}
/* MAP BADGE LABEL */
.mb-lbl { white-space: nowrap }
/* MAP CARD texts */
.mtc-txt { min-width: 140px }
.mtc-sub { min-height: 1.2em }

/* BENTO SECTION HEADER */
.bh .stitle { min-height: 2em }
.bh .ssub   { min-height: 3.4em }

/* BENTO CARDS — fixed icon+title+body block heights */
.bc { min-height: 200px }
.bc h3 {
  min-height: 2.6em;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}
.bc p {
  min-height: 3.8em;
}
/* Featured card gets more height */
.bc.feat { min-height: 340px }

/* SHOWCASE */
.shl .stitle  { min-height: 2em }
.shl .ssub    { min-height: 3.4em }
/* Pills — fixed height, text wraps inside */
.pill         { min-height: 68px; align-items:flex-start }
.pill .pt strong { min-height: 1.4em; display:block }
.pill .pt span   { min-height: 2.4em; display:block }

/* ROUTES SECTION HEADER */
.routes-head .stitle { min-height: 1.2em; white-space:nowrap }
.routes-head .ssub   { min-height: 1.5em }
/* Route cards — fixed height */
.rc         { min-height: 100px }
.rc-r       { min-height: 2.8em }

/* SPLIT SECTION — driver/passenger */
.stag       { min-height: 1.4em; display:inline-flex; align-items:center }
.sp h3      { min-height: 2.6em }
.sp p       { min-height: 6.4em }
.ci         { min-height: 1.8em; align-items:flex-start }

/* TESTIMONIALS */
.tc-meta    { min-height: 1.2em; white-space:nowrap }
.tc-text    { min-height: 5.2em }

/* CTA */
.ct-label   { min-height: 1.2em; display:block }
.ct-title   { min-height: 1.85em }   /* 2 lines */
.ct-sub     { min-height: 4.2em }
.sbt small  { min-height: 1em; display:block; white-space:nowrap }
.sbt strong { white-space:nowrap }

/* FOOTER */
.fc         { white-space:nowrap }
.fls a      { white-space:nowrap }


            .md-region{fill:var(--region-fill);stroke:var(--region-stroke);stroke-width:1.2;transition:fill 0.3s;cursor:default}
            .md-region:hover{fill:rgba(114,101,213,0.14)}
            .md-trans{fill:rgba(114,101,213,0.1);stroke:rgba(114,101,213,0.28);stroke-width:1.2;cursor:default}
            .md-trans:hover{fill:rgba(114,101,213,0.2)}
          
/* ════════════════════════════════════════════════════════
   RESPONSIVE — mobile-first, tested breakpoints
   ════════════════════════════════════════════════════════ */

/* ── 960px — tablet landscape ─────────────────────────── */
@media (max-width: 960px) {

  /* NAV */
  .nr { display: none }
  nav { padding: 1rem 4vw }

  /* HERO — single column, map hidden */
  #hero {
    grid-template-columns: 1fr;
    padding: 6rem 6vw 3rem;
    min-height: auto;
  }

  /* BENTO */
  .bgrid {
    grid-template-columns: repeat(2, 1fr);
  }
  .bc.feat { grid-column: span 2 }

  /* SHOWCASE */
  #show { grid-template-columns: 1fr }
  .shr  { display: none }

  /* SPLIT */
  #split { grid-template-columns: 1fr }
  .sdiv  { display: none }

  /* TESTIMONIALS */
  .tg { grid-template-columns: 1fr }

  /* STATUS */
  .status-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .prog-circle-wrap {
    flex-direction: row;
    align-items: center;
    gap: 2rem;
  }

  /* ROADMAP */
  .roadmap {
    flex-direction: column;
    gap: 1.2rem;
  }
  .roadmap::before { display: none }
  .rm-step {
    flex-direction: row;
    align-items: center;
    gap: 1rem;
  }
  .rm-text { text-align: left }
}

/* ── 600px — mobile ───────────────────────────────────── */
@media (max-width: 600px) {

  /* GLOBAL */
  :root { --section-pad: 4rem 5vw }
  section { padding: 4rem 5vw }
  body { cursor: auto }
  #cur { display: none }

  /* DEV BANNER */
  .dbanner-inner { flex-wrap: wrap; gap: .4rem }
  .dbanner-text  { font-size: .72rem }
  .dbanner-link  { font-size: .7rem }

  /* NAV */
  nav { padding: .9rem 5vw }
  .nl { font-size: 1.5rem }
  .lang-sw { gap: 3px }
  .lbtn { padding: .28rem .52rem; font-size: .68rem }

  /* HERO */
  #hero {
    padding: 5.5rem 5vw 3rem;
    gap: 2rem;
  }
  .h-badge {
    font-size: .65rem;
    margin-bottom: 1.2rem;
  }
  .h-title {
    font-size: clamp(3.2rem, 14vw, 5rem);
    margin-bottom: 1.2rem;
    min-height: auto;
  }
  .h-sub {
    font-size: .92rem;
    margin-bottom: 1.5rem;
    min-height: auto;
  }
  .h-btns {
    flex-direction: column;
    align-items: stretch;
    gap: .6rem;
  }
  .btn-p, .btn-g {
    min-width: unset;
    width: 100%;
    justify-content: center;
    padding: .9rem 1rem;
  }
  .h-stats {
    gap: 1.5rem;
    flex-wrap: wrap;
  }
  .hs-n  { font-size: 1.8rem }
  .hs-l  { font-size: .65rem }

  /* MAP — show below hero text on mobile */
  .hr {
    display: block;
    width: 100%;
    margin-top: 2rem;
  }
  .map-container {
    width: 85%;
    margin: 0 auto;
    position: relative;
  }
  /* Hide floating cards on mobile — they overlap */
  .map-badge     { display: none }
  .map-trip-card { display: none }

  /* SECTION LABELS & TITLES */
  .stitle {
    font-size: clamp(1.8rem, 8vw, 2.6rem);
  }
  .ssub { font-size: .88rem; min-height: auto }

  /* BENTO */
  .bgrid {
    grid-template-columns: 1fr;
    border-radius: 14px;
  }
  .bc        { padding: 1.4rem; min-height: auto }
  .bc.feat   { grid-column: span 1; min-height: auto }
  .bc.w2     { grid-column: span 1 }
  .bc-big    { font-size: 3.5rem }
  .bc h3     { font-size: 1.1rem; min-height: auto }
  .bc p      { font-size: .82rem; min-height: auto }

  /* SHOWCASE PILLS */
  .pills { gap: .5rem; margin-top: 1.5rem }
  .pill  { padding: .7rem 1rem; min-height: auto }
  .pt strong { font-size: .82rem; min-height: auto }
  .pt span   { font-size: .72rem; min-height: auto }

  /* ROUTES */
  .routes-head {
    flex-direction: column;
    align-items: flex-start;
    gap: .5rem;
    margin-bottom: 1.5rem;
  }
  .rg { grid-template-columns: 1fr; border-radius: 14px }
  .rc { padding: 1.2rem; min-height: auto }
  .rc-r  { font-size: 1.15rem; min-height: auto }
  .rc-p  { font-size: 1.15rem }

  /* SPLIT */
  .sp    { padding: 3.5rem 5vw }
  .sp h3 { font-size: 2.2rem; min-height: auto }
  .sp p  { font-size: .88rem; min-height: auto }
  .sp-bg { font-size: 8rem }
  .stag  { font-size: .65rem }

  /* TESTIMONIALS */
  .tg { border-radius: 14px }
  .tc { padding: 1.4rem }
  .tc-text { font-size: .82rem; min-height: auto }

  /* STATUS SECTION */
  .prog-circle-wrap {
    flex-direction: column;
    align-items: center;
  }
  .prog-circle { width: 140px; height: 140px }
  .prog-circle svg { width: 140px; height: 140px }
  .prog-num    { font-size: 2rem }
  .feat-bars   { gap: 1rem }
  .fbar-name   { font-size: .82rem }

  /* ROADMAP */
  .rm-dot   { width: 34px; height: 34px; font-size: 13px }
  .rm-title { font-size: .75rem }
  .rm-sub   { font-size: .65rem }

  /* CTA */
  .ct-title { font-size: clamp(3rem, 14vw, 5.5rem) }
  .ct-sub   { font-size: .88rem; min-height: auto }
  .stores   { flex-direction: column; align-items: center }
  .sb { width: 260px; justify-content: flex-start }

  /* FOOTER */
  footer {
    flex-direction: column;
    text-align: center;
    padding: 2rem 5vw;
    gap: .75rem;
  }
  .fls { justify-content: center; gap: 1.2rem }
  .fls a, .fc { font-size: .75rem }

  /* TICKER */
  .titem { font-size: .7rem; padding: 0 1.2rem }
}

/* ── 380px — small phones ─────────────────────────────── */
@media (max-width: 380px) {
  .h-title   { font-size: 3rem }
  .ct-title  { font-size: 3rem }
  .stitle    { font-size: 1.7rem }
  .sb        { width: 100% }
  .lang-sw   { gap: 2px }
  .lbtn      { padding: .25rem .45rem; font-size: .64rem }
}

/* ════════════════════════════════════════════════════════
   LIGHT THEME — specific overrides
   ════════════════════════════════════════════════════════ */

[data-theme="light"] body {
  background: var(--bg);
  color: var(--white);
}

/* Nav */
[data-theme="light"] nav {
  border-bottom-color: rgba(114,101,213,0.15);
}

/* Hero background glow */
[data-theme="light"] .hero-bg-glow {
  background:
    radial-gradient(ellipse 45% 55% at 15% 55%, rgba(114,101,213,.08) 0%, transparent 60%),
    radial-gradient(ellipse 35% 40% at 80% 30%, rgba(165,148,249,.06) 0%, transparent 55%);
}

/* Scroll progress */
[data-theme="light"] #sp { background: rgba(114,101,213,.08) }

/* Ticker */
[data-theme="light"] .ticker {
  border-color: rgba(114,101,213,0.15);
}
[data-theme="light"] .titem { color: var(--muted) }

/* Bento */
[data-theme="light"] .bgrid {
  background: rgba(114,101,213,0.12);
  border-color: rgba(114,101,213,0.12);
}
[data-theme="light"] .bc::after {
  background: linear-gradient(90deg,transparent,var(--red),transparent);
}

/* Cards */
[data-theme="light"] .rg,
[data-theme="light"] .tg {
  background: rgba(114,101,213,0.1);
  border-color: rgba(114,101,213,0.12);
}
[data-theme="light"] .rc::after {
  background: linear-gradient(90deg,var(--red),var(--gold));
}

/* Split section tags */
[data-theme="light"] .dr .stag {
  background: rgba(114,101,213,.12);
  color: var(--red);
  border-color: rgba(114,101,213,.3);
}
[data-theme="light"] .ps .stag {
  background: rgba(114,101,213,.08);
  color: var(--gold);
  border-color: rgba(114,101,213,.2);
}
[data-theme="light"] .dr .ck { background: rgba(114,101,213,.12); color: var(--red) }
[data-theme="light"] .ps .ck { background: rgba(114,101,213,.08); color: var(--gold) }
[data-theme="light"] .sp-bg  { color: rgba(28,26,53,0.06) }
[data-theme="light"] .sdiv   { background: rgba(114,101,213,.15) }

/* Roadmap */
[data-theme="light"] .roadmap::before {
  background: linear-gradient(90deg,var(--red) 0%,rgba(114,101,213,.2) 100%);
}
[data-theme="light"] .rm-dot {
  background: var(--bg2);
  border-color: rgba(114,101,213,.2);
}

/* Progress bars */
[data-theme="light"] .fbar-track { background: rgba(114,101,213,.1) }
[data-theme="light"] .prog-circle .track { stroke: rgba(114,101,213,.12) }

/* Store buttons */
[data-theme="light"] .sb {
  background: var(--bg2);
  border-color: rgba(114,101,213,.15);
  box-shadow: 0 2px 12px rgba(114,101,213,.08);
}
[data-theme="light"] .sb:hover {
  border-color: var(--red);
  box-shadow: 0 8px 28px rgba(114,101,213,.18);
}

/* Map SVG text */
[data-theme="light"] .map-trip-card,
[data-theme="light"] .map-badge {
  background: rgba(245,244,255,0.92);
  border-color: rgba(114,101,213,.25);
  color: var(--white);
}
[data-theme="light"] .mtc-txt  { color: #1C1A35 }
[data-theme="light"] .mtc-sub  { color: var(--muted) }
[data-theme="light"] .mb-num   { color: var(--red) }
[data-theme="light"] .mb-lbl   { color: var(--muted) }
[data-theme="light"] .mtc-footer { border-color: rgba(114,101,213,.12) }

/* Grain — subtler in light */
[data-theme="light"] body::after { opacity: .015 }

/* CTA section */
[data-theme="light"] #cta::before {
  background: radial-gradient(ellipse 55% 55% at 50% 50%, rgba(114,101,213,.06) 0%, transparent 65%);
}

/* Footer */
[data-theme="light"] footer {
  border-color: rgba(114,101,213,.12);
  background: var(--bg3);
}

/* Theme toggle button */
.theme-btn {
  background: var(--glass);
  border: 1px solid var(--border);
  color: var(--muted);
  width: 34px; height: 34px;
  border-radius: 8px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; line-height: 1;
  transition: background .2s, border-color .2s, transform .2s;
  flex-shrink: 0;
}
.theme-btn:hover {
  background: rgba(114,101,213,.15);
  border-color: rgba(114,101,213,.4);
  transform: rotate(15deg);
}

/* BETA badge light */
[data-theme="light"] .beta-badge {
  background: rgba(114,101,213,.1);
  border-color: rgba(114,101,213,.35);
}

/* Pill hover */
[data-theme="light"] .pill:hover {
  border-color: rgba(114,101,213,.35);
}

/* Cursor */
[data-theme="light"] #cur { background: var(--red); mix-blend-mode: multiply }

/* Hero ghost text */
[data-theme="light"] .h-title .ghost { color: rgba(28,26,53,.15) }
[data-theme="light"] .ct-title .ct-ghost { color: rgba(28,26,53,.15) }
