/* ============================================================
   LUMY CHARGE — Website tokens  ("Gece Yolu" → web)
   Ported from lumycharge-ui-mock-v8.html (source of truth)
   ============================================================ */
:root{
  /* surfaces */
  --ink:#070A0F; --raise:#0E131B; --raise-2:#151C27; --raise-3:#1D2634;
  --line:rgba(148,170,200,.13); --hairline:rgba(255,255,255,.07);
  /* text */
  --text:#F0F4FA; --muted:#8C97AA; --faint:#566175;
  /* ion accent (hue can be tweaked) */
  --ion-h:214;
  --ion:oklch(0.84 0.12 var(--ion-h));
  --ion-2:oklch(0.68 0.13 var(--ion-h));
  --ion-glow:oklch(0.84 0.12 var(--ion-h) / .30);
  --ion-faint:oklch(0.84 0.12 var(--ion-h) / .12);
  /* status */
  --ok:#3DF08F; --busy:#FFB547; --down:#FF5C6C;
  /* map terrain */
  --road:#1A222E; --road-2:#141B25; --terrain:#0B1018; --park:#0E1620;
  /* glass + shadow */
  --glass:rgba(14,19,27,.72);
  --float:0 24px 60px rgba(0,0,0,.55);
  /* radii */
  --r-sm:12px; --r-md:18px; --r-lg:24px; --r-xl:32px;
  /* fonts */
  --display:'Space Grotesk', system-ui, sans-serif;
  --body:'Inter', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  /* layout */
  --maxw:1180px;
  --gutter:clamp(20px, 5vw, 64px);
  --spring:.45s cubic-bezier(.32,.72,.2,1);
}

/* ---- light theme (ported from mock) ---- */
[data-theme="light"]{
  --ink:#EEF2F8; --raise:#FFFFFF; --raise-2:#F2F6FB; --raise-3:#E7EDF5;
  --line:rgba(30,50,80,.12); --hairline:rgba(10,20,40,.06);
  --text:#0C1320; --muted:#5A6679; --faint:#98A4B8;
  --ion-h:222;
  --ion:oklch(0.62 0.12 var(--ion-h));
  --ion-2:oklch(0.54 0.12 var(--ion-h));
  --ion-glow:oklch(0.62 0.12 var(--ion-h) / .22);
  --ion-faint:oklch(0.62 0.12 var(--ion-h) / .10);
  --ok:#0FAF62; --busy:#D98A1B; --down:#E04557;
  --glass:rgba(255,255,255,.80);
  --float:0 24px 54px rgba(25,45,80,.16);
  --road:#D9E2EC; --road-2:#E4EBF3; --terrain:#E9EFF6; --park:#DFE9E2;
}
[data-theme="light"] body{ background:#DCE5EF }
[data-theme="light"] .nav.scrolled{ background:rgba(238,242,248,.8) }
[data-theme="light"] body::before{
  background:radial-gradient(820px 460px at 78% -6%, var(--ion-faint), transparent 60%);
}
[data-theme="light"] .btn-primary,[data-theme="light"] .nav-cta{ color:#F4FBFF }

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased; scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} }
body{
  font-family:var(--body);
  color:var(--text);
  background:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
}
::selection{background:var(--ion-glow); color:var(--text)}
a{color:inherit; text-decoration:none}
img,svg{display:block; max-width:100%}
button{font-family:inherit; cursor:pointer}

/* ambient page glow, like the app radial */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(820px 460px at 78% -6%, var(--ion-faint), transparent 60%),
    radial-gradient(700px 500px at 8% 8%, rgba(31,179,230,.06), transparent 55%);
}

/* ---------- shared layout ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter) }
.eyebrow{
  font-family:var(--mono); font-size:11px; font-weight:700;
  letter-spacing:.24em; color:var(--ion); text-transform:uppercase;
  display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{
  content:""; width:22px; height:1px; background:linear-gradient(90deg,var(--ion),transparent);
}
.eyebrow.center::before{display:none}
.mono{font-family:var(--mono); font-weight:700; font-variant-numeric:tabular-nums}
.ion{color:var(--ion)}
.section{ padding-block:clamp(72px,9vw,128px); position:relative }
.section-head{ max-width:640px }
.section-head h2{
  font-family:var(--display); font-weight:700;
  font-size:clamp(28px,4vw,46px); line-height:1.08; letter-spacing:-.02em;
  margin-top:18px; text-wrap:balance;
}
.section-head p{ color:var(--muted); font-size:clamp(15px,1.5vw,18px); margin-top:16px; max-width:54ch; text-wrap:pretty }

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(7,10,15,.74); backdrop-filter:blur(22px) saturate(1.4);
  border-bottom-color:var(--line);
}
.nav-in{ max-width:var(--maxw); margin-inline:auto; padding:16px var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:20px }
.logo{ display:flex; align-items:center; gap:11px; font-family:var(--display);
  font-weight:700; font-size:19px; letter-spacing:-.01em }
.logo .mk{ width:34px; height:34px; color:var(--ion); flex:none;
  filter:drop-shadow(0 4px 14px var(--ion-glow)) }
.logo b{font-weight:700}
.logo .c{color:var(--ion)}
.nav-links{ display:flex; align-items:center; gap:30px }
.nav-links a{ font-size:14px; color:var(--muted); font-weight:500; transition:color .18s }
.nav-links a:hover{ color:var(--text) }
.nav-cta{
  font-family:var(--display); font-weight:600; font-size:14px;
  padding:10px 18px; border-radius:999px; color:#04121A;
  background:linear-gradient(135deg,var(--ion),var(--ion-2));
  box-shadow:0 8px 22px var(--ion-glow); transition:transform .18s, box-shadow .18s;
}
.nav-cta:hover{ transform:translateY(-1px); box-shadow:0 12px 28px var(--ion-glow) }
.nav-links .only-wide{ display:inline }
@media (max-width:760px){
  .nav-links{ gap:14px }
  .nav-links .only-wide{ display:none }
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--display); font-weight:600; font-size:15px;
  padding:0 22px; height:54px; border-radius:16px; border:1px solid transparent;
  transition:transform .18s, box-shadow .18s, border-color .18s, background .18s;
  white-space:nowrap;
}
.btn-primary{ background:linear-gradient(135deg,var(--ion),var(--ion-2)); color:#04121A;
  box-shadow:0 14px 34px var(--ion-glow) }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 40px var(--ion-glow) }
.btn-ghost{ background:var(--raise); border-color:var(--line); color:var(--text) }
.btn-ghost:hover{ border-color:var(--ion); transform:translateY(-2px) }

/* ---------- waitlist form ---------- */
.waitlist{ display:flex; gap:10px; max-width:480px; width:100%; flex-wrap:wrap }
.waitlist .fieldwrap{ flex:1; min-width:220px; position:relative; display:flex; align-items:center }
.waitlist input{
  width:100%; height:54px; border-radius:16px; border:1px solid var(--line);
  background:var(--raise); color:var(--text); padding:0 18px; font-size:15px;
  font-family:var(--body); outline:none; transition:border-color .18s, box-shadow .18s;
}
.waitlist input::placeholder{ color:var(--faint) }
.waitlist input:focus{ border-color:var(--ion); box-shadow:0 0 0 3px var(--ion-glow) }
.waitlist .btn{ flex:none }
.waitlist[data-state="loading"] .btn{ opacity:.7; pointer-events:none }
.form-note{ font-size:12.5px; color:var(--faint); margin-top:12px; display:flex; align-items:center; gap:8px }
.form-note svg{ width:14px; height:14px; color:var(--ion); flex:none }
.form-msg{ font-size:13.5px; margin-top:12px; min-height:1.2em; font-weight:500 }
.form-msg.ok{ color:var(--ok) } .form-msg.err{ color:var(--down) }
.success-card{
  display:none; align-items:center; gap:14px; max-width:480px;
  background:linear-gradient(135deg,var(--ion-faint),transparent 70%);
  border:1px solid var(--ion); border-radius:18px; padding:16px 18px;
}
.success-card.show{ display:flex; animation:pop .4s var(--spring) }
@keyframes pop{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}
.success-card .tick{ width:42px; height:42px; border-radius:50%; flex:none;
  background:var(--ion-glow); color:var(--ion); display:grid; place-items:center }
.success-card b{ font-family:var(--display); font-size:15px; display:block }
.success-card span{ font-size:13px; color:var(--muted) }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:140px; padding-bottom:40px; overflow:hidden }
.hero-grid{
  max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter);
  display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:clamp(32px,5vw,72px); align-items:center;
}
.hero h1{
  font-family:var(--display); font-weight:700;
  font-size:clamp(40px,6.6vw,76px); line-height:.98; letter-spacing:-.03em;
  margin-top:22px; text-wrap:balance;
}
.hero h1 .br{ color:var(--ion) }
.hero-sub{ color:var(--muted); font-size:clamp(16px,1.7vw,20px); margin-top:22px;
  max-width:46ch; text-wrap:pretty }
.hero-form-wrap{ margin-top:34px }
.hero-stats{ display:flex; gap:28px; margin-top:38px; flex-wrap:wrap }
.hero-stats .st .v{ font-family:var(--mono); font-weight:800; font-size:24px; color:var(--text);
  display:flex; align-items:baseline; gap:3px }
.hero-stats .st .v small{ font-size:12px; color:var(--muted); font-weight:700 }
.hero-stats .st .l{ font-size:12px; color:var(--faint); margin-top:4px; letter-spacing:.02em }
.hero-stats .st + .st{ padding-left:28px; border-left:1px solid var(--line) }

/* ---- hero variant B (centered cinematic) ---- */
body[data-hero="b"] .hero-a{ display:none }
body[data-hero="a"] .hero-b{ display:none }
.hero-b{ padding-top:150px; padding-bottom:0; text-align:center }
.hero-b .hero-copy{ max-width:760px; margin-inline:auto; display:flex; flex-direction:column; align-items:center }
.hero-b h2{ font-size:clamp(44px,8.4vw,104px) }
.hero-b .hero-sub{ max-width:60ch }
.hero-b .waitlist{ margin-inline:auto }
.hero-b .form-note{ justify-content:center }
.hero-b .stage-b{ margin-top:clamp(40px,5vw,64px) }

/* ============================================================
   PHONE FRAME + LIVE MAP SCENE
   ============================================================ */
.phone-stage{ position:relative; display:flex; justify-content:center }
.phone-stage::after{ /* under-glow */
  content:""; position:absolute; left:50%; bottom:0; width:80%; height:60%;
  transform:translateX(-50%); background:radial-gradient(closest-side, var(--ion-faint), transparent 70%);
  filter:blur(20px); z-index:-1;
}
.phone{
  width:330px; height:680px; border-radius:46px; background:var(--ink);
  border:1px solid var(--line); box-shadow:var(--float), inset 0 1px 0 var(--hairline);
  position:relative; overflow:hidden;
}
.phone .notch{ position:absolute; top:12px; left:50%; transform:translateX(-50%);
  width:104px; height:28px; background:#000; border-radius:16px; z-index:20 }
.phone .sbar{ position:absolute; top:0; left:0; right:0; height:48px;
  display:flex; justify-content:space-between; align-items:center; padding:14px 26px 0;
  font-family:var(--mono); font-size:11.5px; font-weight:700; color:var(--text); z-index:15 }

/* map */
.map{ position:absolute; inset:0; background:var(--terrain); overflow:hidden }
.map .gridlines{ position:absolute; inset:-40%;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:48px 48px; opacity:.35; transform:rotate(-8deg) }
.map svg.roads{ position:absolute; inset:0; width:100%; height:100% }
.map .blocks rect{ fill:var(--park) }
.r1{ stroke:var(--road); stroke-width:30; fill:none; stroke-linecap:round }
.r2{ stroke:var(--road-2); stroke-width:13; fill:none; stroke-linecap:round }
.flow{ stroke:var(--ion); stroke-width:3; fill:none; stroke-linecap:round;
  stroke-dasharray:1 22; opacity:.78; filter:drop-shadow(0 0 6px var(--ion-glow));
  animation:flow 2.4s linear infinite }
@keyframes flow{ to{ stroke-dashoffset:-46 } }
.vignette{ position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg,var(--ink) 0%,transparent 15%,transparent 55%,var(--ink) 100%); opacity:.78 }

/* socket-ring pins */
.pin{ position:absolute; width:48px; height:48px; transform:translate(-50%,-50%);
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.5)); z-index:6 }
.pin .core{ fill:var(--raise); stroke:var(--hairline) }
.pin text.kw{ font-family:var(--mono); font-weight:800; font-size:13px; fill:var(--text) }
.pin text.unit{ font-family:var(--mono); font-weight:700; font-size:6px; fill:var(--muted); letter-spacing:.1em }
.pin.av .halo{ transform-origin:center; animation:halo 2.4s ease-out infinite }
@keyframes halo{ 0%{r:18; opacity:.5} 100%{r:31; opacity:0} }
.pin-sm{ position:absolute; width:18px; height:18px; transform:translate(-50%,-50%);
  border-radius:50%; background:var(--raise); border:3px solid var(--ok);
  box-shadow:0 4px 10px rgba(0,0,0,.45); z-index:5 }
.pin-sm.busy{ border-color:var(--busy) }
.cluster{ position:absolute; transform:translate(-50%,-50%); width:38px; height:38px;
  border-radius:50%; background:var(--glass); backdrop-filter:blur(10px);
  border:2px solid var(--ion); display:grid; place-items:center;
  font-family:var(--mono); font-weight:800; font-size:13px; color:var(--ion);
  box-shadow:0 0 18px var(--ion-glow); z-index:5 }
.me{ position:absolute; left:44%; top:62%; width:18px; height:18px; transform:translate(-50%,-50%); z-index:7 }
.me::before{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--ion);
  border:3px solid var(--ink); box-shadow:0 0 0 6px var(--ion-glow), 0 0 22px var(--ion-glow) }

/* phone glass overlays */
.p-search{ position:absolute; top:58px; left:16px; right:16px; z-index:14; display:flex; gap:8px }
.p-field{ flex:1; height:46px; backdrop-filter:blur(20px) saturate(1.4); background:var(--glass);
  border:1px solid var(--hairline); border-radius:14px; display:flex; align-items:center; gap:10px;
  padding:0 14px; color:var(--muted); font-size:12.5px; box-shadow:0 8px 26px rgba(0,0,0,.25) }
.p-field svg{ width:15px; height:15px; flex:none }
.p-chip{ width:46px; height:46px; border-radius:14px; backdrop-filter:blur(20px); background:var(--glass);
  border:1px solid var(--hairline); display:grid; place-items:center; color:var(--ion); font-family:var(--mono);
  font-weight:800; font-size:13px }
.p-chips{ position:absolute; top:116px; left:0; right:0; z-index:14; display:flex; gap:7px;
  padding:0 16px; overflow:hidden }
.p-pill{ flex:none; height:32px; padding:0 12px; border-radius:999px; backdrop-filter:blur(18px);
  background:var(--glass); border:1px solid var(--hairline); color:var(--text); font-size:11.5px;
  display:flex; align-items:center; gap:6px; white-space:nowrap }
.p-pill.sel{ background:var(--text); color:var(--ink); border-color:transparent; font-weight:600 }
.p-pill .dot{ width:6px; height:6px; border-radius:50%; background:var(--ok); box-shadow:0 0 8px var(--ok) }
.p-pill .n{ font-family:var(--mono); font-size:10px; color:var(--ion); font-weight:800 }
.p-pill.sel .n{ color:var(--ion-2) }

/* bottom live sheet inside phone */
.p-sheet{ position:absolute; left:0; right:0; bottom:0; z-index:13;
  background:linear-gradient(180deg,var(--raise) 0%,var(--ink) 100%);
  border-radius:26px 26px 0 0; border-top:1px solid var(--line); padding:12px 16px 18px;
  box-shadow:0 -18px 44px rgba(0,0,0,.4) }
.p-sheet .grip{ width:40px; height:4px; border-radius:99px; background:var(--faint); opacity:.5; margin:0 auto 10px }
.p-sheet-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:11px }
.p-sheet-head h4{ font-family:var(--display); font-size:14px; font-weight:600 }
.p-sheet-head h4 span{ color:var(--muted); font-weight:400; font-size:12px }
.live{ display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px;
  font-weight:700; color:var(--ok); letter-spacing:.06em }
.live i{ width:6px; height:6px; border-radius:50%; background:var(--ok); box-shadow:0 0 8px var(--ok);
  animation:blink 1.8s infinite }
@keyframes blink{ 50%{opacity:.25} }
.p-card{ background:linear-gradient(165deg,var(--raise-2),var(--raise)); border:1px solid var(--line);
  border-radius:16px; padding:12px; display:flex; gap:12px; align-items:center }
.p-card + .p-card{ margin-top:9px }
.p-ring{ flex:none; width:48px; height:48px; position:relative }
.p-ring .ckw{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--mono);
  font-weight:800; font-size:11px; color:var(--text); text-align:center; line-height:1 }
.p-ring .ckw small{ font-size:6px; color:var(--muted); letter-spacing:.08em; display:block; margin-top:1px }
.p-cbody{ flex:1; min-width:0 }
.p-cbody h5{ font-size:12.5px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.p-cbody .op{ font-size:10.5px; color:var(--muted); margin-top:2px }
.p-cmeta{ display:flex; gap:6px; margin-top:8px; flex-wrap:wrap }
.p-tag{ font-family:var(--mono); font-size:9px; font-weight:700; padding:3px 7px; border-radius:7px; letter-spacing:.03em }
.p-tag.ok{ background:rgba(61,240,143,.12); color:var(--ok) }
.p-tag.price{ background:var(--ion-faint); color:var(--ion) }
.p-tag.up{ background:transparent; border:1px solid var(--line); color:var(--muted) }
.p-dist{ font-family:var(--mono); font-size:10px; color:var(--muted); font-weight:700; flex:none }
.p-cbody .top{ display:flex; justify-content:space-between; gap:8px; align-items:baseline }

/* ---- cinematic stage (variant B, no phone) ---- */
.stage-b{ position:relative; width:100%; height:clamp(320px,42vw,520px);
  border-radius:var(--r-xl); overflow:hidden; border:1px solid var(--line);
  background:var(--terrain); box-shadow:var(--float) }
.stage-b .map .gridlines{ background-size:64px 64px }
.stage-b .vignette{ background:
  radial-gradient(120% 80% at 50% 120%, transparent 40%, var(--ink) 100%),
  linear-gradient(180deg,var(--ink),transparent 22%); opacity:.9 }
.stage-b .pin text.kw{ font-size:12px }
.stage-b .floatcard{ position:absolute; z-index:12; backdrop-filter:blur(20px) saturate(1.4);
  background:var(--glass); border:1px solid var(--hairline); border-radius:16px;
  padding:11px 14px; box-shadow:var(--float); display:flex; align-items:center; gap:11px }
.stage-b .floatcard .ring{ width:40px; height:40px; position:relative; flex:none }
.stage-b .floatcard .ckw{ position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--mono); font-weight:800; font-size:10px; color:var(--text) }
.stage-b .floatcard b{ font-family:var(--display); font-size:12.5px; display:block }
.stage-b .floatcard span{ font-size:11px; color:var(--muted) }
.stage-b .fc-1{ left:6%; top:16%; animation:bob 5s ease-in-out infinite }
.stage-b .fc-2{ right:6%; bottom:16%; animation:bob 5s ease-in-out .8s infinite }
@keyframes bob{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)} }

/* ============================================================
   PROBLEM STRIP
   ============================================================ */
.problem{ position:relative }
.problem .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px); align-items:center }
.problem .before{ display:flex; flex-direction:column; gap:10px }
.op-row{ display:flex; align-items:center; gap:12px; padding:13px 16px; border-radius:14px;
  background:var(--raise); border:1px solid var(--line) }
.op-row .badge{ width:34px; height:34px; border-radius:9px; flex:none; display:grid; place-items:center;
  font-family:var(--display); font-weight:700; font-size:13px; color:var(--muted);
  background:var(--raise-3); border:1px solid var(--line) }
.op-row .nm{ font-size:13.5px; font-weight:500 }
.op-row .stt{ margin-left:auto; font-family:var(--mono); font-size:10.5px; font-weight:700; color:var(--faint) }
.op-row.unknown .stt{ color:var(--busy) }
.problem h2{ font-family:var(--display); font-weight:700; font-size:clamp(26px,3.6vw,42px);
  line-height:1.1; letter-spacing:-.02em; text-wrap:balance }
.problem .lead{ color:var(--muted); font-size:clamp(15px,1.6vw,18px); margin-top:18px }
.problem .arrow-line{ color:var(--ion); font-family:var(--mono); font-weight:700; font-size:13px;
  margin-top:22px; display:inline-flex; align-items:center; gap:10px; white-space:nowrap }

/* ============================================================
   FEATURES
   ============================================================ */
.features-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px }
.feature{ position:relative; background:linear-gradient(168deg,var(--raise-2),var(--raise));
  border:1px solid var(--line); border-radius:var(--r-lg); padding:30px;
  overflow:hidden; transition:border-color .25s, transform .25s }
.feature:hover{ border-color:var(--ion); transform:translateY(-3px) }
.feature .fnum{ font-family:var(--mono); font-size:11px; font-weight:700; color:var(--faint); letter-spacing:.1em }
.feature h3{ font-family:var(--display); font-weight:600; font-size:21px; margin-top:14px; letter-spacing:-.01em }
.feature p{ color:var(--muted); font-size:14.5px; margin-top:10px; max-width:42ch; text-wrap:pretty }
.feature .vis{ margin-top:22px; height:120px; display:flex; align-items:center; justify-content:center; position:relative }
.feat-badge{ display:inline-flex; align-items:center; gap:7px; font-family:var(--display); font-weight:600;
  font-size:11.5px; padding:6px 12px; border-radius:999px; background:var(--ion-faint);
  border:1px solid var(--ion); color:var(--text); margin-top:14px }
/* availability ring viz */
.ring-viz{ width:104px; height:104px; position:relative }
.ring-viz .ckw{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--mono);
  font-weight:800; font-size:20px; color:var(--text); flex-direction:column }
.ring-viz .ckw small{ font-size:9px; color:var(--muted); font-weight:700; letter-spacing:.08em }
/* price viz */
.price-viz{ text-align:center }
.price-viz .big{ font-family:var(--mono); font-weight:800; font-size:42px; color:var(--text); line-height:1 }
.price-viz .big small{ font-size:15px; color:var(--ion); font-weight:700 }
.price-viz .calc{ font-size:12px; color:var(--muted); margin-top:8px; font-family:var(--mono) }
/* uptime viz */
.spark{ display:flex; gap:5px; align-items:flex-end; height:64px }
.spark i{ width:9px; border-radius:4px; background:var(--ok); opacity:.85 }
.uptime-viz{ display:flex; align-items:center; gap:18px }
.uptime-viz .pct{ font-family:var(--mono); font-weight:800; font-size:38px; color:var(--ok) }
/* route timeline viz */
.route-viz{ width:100%; position:relative; padding-left:8px }
.route-viz .ln{ position:absolute; left:13px; top:6px; bottom:6px; width:3px; border-radius:3px;
  background:repeating-linear-gradient(180deg,var(--ion) 0 8px,transparent 8px 15px); opacity:.6 }
.route-viz .stp{ display:flex; align-items:center; gap:13px; padding:5px 0; position:relative }
.route-viz .stp i{ width:13px; height:13px; border-radius:50%; background:var(--ink); border:3px solid var(--ion);
  flex:none; box-shadow:0 0 10px var(--ion-glow) }
.route-viz .stp i.chg{ border-color:var(--ok); box-shadow:0 0 10px rgba(61,240,143,.5) }
.route-viz .stp .lbl{ font-size:12px; color:var(--muted) }
.route-viz .stp .lbl b{ color:var(--text); font-weight:600 }
.route-viz .stp .pc{ margin-left:auto; font-family:var(--mono); font-size:11px; font-weight:800; color:var(--ok) }

/* ============================================================
   VEHICLE TEASER
   ============================================================ */
.vehicle{ position:relative }
.vehicle .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center }
.vcard{ position:relative; border-radius:var(--r-xl);
  background:radial-gradient(420px 240px at 80% -15%, var(--ion-glow), transparent 70%),
    linear-gradient(168deg,var(--raise-2),var(--raise));
  border:1px solid var(--line); padding:30px; overflow:hidden }
.vcard .def{ position:absolute; top:18px; right:18px; font-family:var(--mono); font-size:9px;
  font-weight:800; letter-spacing:.12em; color:var(--ok); background:rgba(61,240,143,.12);
  padding:5px 9px; border-radius:8px }
.vcard h4{ font-family:var(--display); font-weight:700; font-size:22px }
.vcard .plate{ font-family:var(--mono); font-size:12px; color:var(--muted); margin-top:4px }
.vcard .carart{ color:var(--ion); margin:14px 0 6px; filter:drop-shadow(0 12px 26px var(--ion-glow)) }
.vcard .carart svg{ width:100%; height:120px }
.vspecs{ display:flex; gap:10px; margin-top:8px }
.vspecs .vs{ flex:1; background:var(--ink); border:1px solid var(--line); border-radius:14px;
  padding:13px 8px; text-align:center }
.vspecs .vs .v{ font-family:var(--mono); font-weight:800; font-size:18px }
.vspecs .vs .v small{ font-size:9px; color:var(--muted) }
.vspecs .vs .l{ font-family:var(--display); font-size:9px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); margin-top:4px; font-weight:600 }
.vconns{ display:flex; gap:7px; margin-top:14px }
.vconns .conn{ font-family:var(--mono); font-size:10px; font-weight:700; padding:6px 11px;
  border-radius:8px; background:var(--ion-faint); color:var(--ion) }

/* ============================================================
   DATA TRUST STRIP
   ============================================================ */
.trust{ border-block:1px solid var(--line); background:var(--raise);
  background-image:linear-gradient(180deg,rgba(91,227,255,.03),transparent) }
.trust .wrap{ display:flex; align-items:center; gap:clamp(24px,5vw,64px); flex-wrap:wrap }
.trust .ic{ width:64px; height:64px; border-radius:18px; flex:none; display:grid; place-items:center;
  color:var(--ion); background:var(--ion-faint); border:1px solid var(--ion) }
.trust .tx{ flex:1; min-width:280px }
.trust .tx h3{ font-family:var(--display); font-weight:600; font-size:clamp(19px,2.4vw,26px); letter-spacing:-.01em }
.trust .tx p{ color:var(--muted); font-size:15px; margin-top:8px; max-width:60ch }
.trust .src{ display:flex; gap:8px; margin-top:14px; flex-wrap:wrap }
.trust .src .s{ font-family:var(--mono); font-size:10.5px; font-weight:700; color:var(--muted);
  padding:6px 11px; border-radius:8px; background:var(--ink); border:1px solid var(--line) }
.trust .src .s b{ color:var(--ok) }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{ margin-top:48px; max-width:820px; border-top:1px solid var(--line) }
.faq{ border-bottom:1px solid var(--line) }
.faq summary{ list-style:none; cursor:pointer; padding:24px 4px; display:flex; align-items:center;
  gap:20px; font-family:var(--display); font-weight:600; font-size:clamp(16px,1.9vw,20px); color:var(--text) }
.faq summary::-webkit-details-marker{ display:none }
.faq summary .q{ flex:1 }
.faq summary .pm{ width:30px; height:30px; border-radius:9px; flex:none; display:grid; place-items:center;
  border:1px solid var(--line); color:var(--ion); position:relative; transition:transform var(--spring) }
.faq summary .pm::before,.faq summary .pm::after{ content:""; position:absolute; background:currentColor; border-radius:2px }
.faq summary .pm::before{ width:13px; height:2px } .faq summary .pm::after{ width:2px; height:13px; transition:transform .3s }
.faq[open] summary .pm::after{ transform:scaleY(0) }
.faq[open] summary .pm{ background:var(--ion-faint) }
.faq .a{ overflow:hidden; color:var(--muted); font-size:15.5px; line-height:1.7;
  padding:0 56px 4px 4px; max-width:70ch; text-wrap:pretty;
  display:grid; grid-template-rows:0fr; transition:grid-template-rows var(--spring) }
.faq[open] .a{ grid-template-rows:1fr; padding-bottom:24px }
.faq .a > div{ min-height:0 }
.faq .a a{ color:var(--ion) }

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{ position:relative; text-align:center; overflow:hidden }
.finalcta .panel{ position:relative; max-width:880px; margin-inline:auto;
  border-radius:var(--r-xl); border:1px solid var(--ion); padding:clamp(40px,6vw,72px) var(--gutter);
  background:radial-gradient(440px 300px at 50% -20%, var(--ion-glow), transparent 70%),
    linear-gradient(168deg,var(--raise-2),var(--raise)) }
.finalcta .mk{ width:60px; height:60px; color:var(--ion); margin:0 auto 22px;
  filter:drop-shadow(0 10px 30px var(--ion-glow)) }
.finalcta h2{ font-family:var(--display); font-weight:700; font-size:clamp(30px,4.6vw,52px);
  line-height:1.04; letter-spacing:-.02em; text-wrap:balance }
.finalcta p{ color:var(--muted); font-size:17px; margin-top:16px; max-width:48ch; margin-inline:auto }
.finalcta .waitlist{ margin:30px auto 0 }
.finalcta .form-note{ justify-content:center }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding-block:64px 40px }
.footer .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px }
.footer .brand-col .logo{ margin-bottom:16px }
.footer .brand-col p{ color:var(--muted); font-size:14px; max-width:34ch }
.footer .mailto{ display:inline-flex; align-items:center; gap:8px; margin-top:16px;
  font-family:var(--mono); font-size:13px; color:var(--ion); font-weight:700 }
.footer h5{ font-family:var(--display); font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--faint); font-weight:600; margin-bottom:16px }
.footer ul{ list-style:none; display:flex; flex-direction:column; gap:11px }
.footer ul a{ font-size:14px; color:var(--muted); transition:color .18s }
.footer ul a:hover{ color:var(--text) }
.footer ul a .soon{ font-family:var(--mono); font-size:8.5px; font-weight:800; letter-spacing:.08em;
  color:var(--faint); border:1px solid var(--line); border-radius:5px; padding:1px 5px; margin-left:7px; vertical-align:1px }
.footer .bottom{ display:flex; align-items:center; justify-content:space-between; gap:20px;
  margin-top:54px; padding-top:26px; border-top:1px solid var(--line); flex-wrap:wrap }
.footer .bottom .sig{ font-size:13px; color:var(--faint) }
.footer .bottom .sig b{ color:var(--muted); font-weight:600 }
.footer .socials{ display:flex; gap:10px }
.footer .brand-col .socials{ margin-top:18px; flex-wrap:wrap }
.footer .socials a{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center;
  border:1px solid var(--line); background:var(--raise); color:var(--muted); transition:.18s }
.footer .socials a:hover{ color:var(--ion); border-color:var(--ion) }
.footer .socials svg{ width:18px; height:18px }

/* ============================================================
   SCROLL REVEAL + signature route draw
   ============================================================ */
/* Reveal: content is ALWAYS visible by default (never gated behind an
   animation that could stall on idle/throttled tabs). Entrance motion is
   intentionally omitted; the signature motion is the route-line draw below. */
.reveal{ opacity:1; transform:none }
@media (prefers-reduced-motion:reduce){
  .flow,.pin.av .halo,.stage-b .fc-1,.stage-b .fc-2{ animation:none !important }
}

/* the signature draw-on-scroll route between sections */
.routeband{ position:relative; height:0 }
.routeband svg{ position:absolute; left:0; right:0; top:-60px; width:100%; height:200px; overflow:visible; pointer-events:none }
.routeband .draw{ stroke:var(--ion); stroke-width:2.5; fill:none; stroke-linecap:round;
  filter:drop-shadow(0 0 8px var(--ion-glow));
  stroke-dasharray:var(--len); stroke-dashoffset:var(--len); transition:stroke-dashoffset .1s linear }
.routeband .draw-bg{ stroke:var(--line); stroke-width:2.5; fill:none; stroke-linecap:round; stroke-dasharray:2 9 }
.routeband .node{ fill:var(--ink); stroke:var(--ion); stroke-width:2.5 }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:920px){
  .hero-grid{ grid-template-columns:1fr; text-align:center; gap:48px }
  .hero-form-wrap .waitlist,.hero-stats{ justify-content:center; margin-inline:auto }
  .hero h1{ font-size:clamp(40px,11vw,64px) }
  .hero .eyebrow{ justify-content:center }
  .problem .wrap,.vehicle .wrap{ grid-template-columns:1fr; gap:40px }
  .features-grid{ grid-template-columns:1fr }
  .footer .top{ grid-template-columns:1fr 1fr; gap:36px }
}
@media (max-width:560px){
  .footer .top{ grid-template-columns:1fr 1fr }
  .footer .brand-col{ grid-column:1 / -1 }
  .hero-stats .st + .st{ padding-left:18px }
  .feature{ padding:24px }
}

/* ============================================================
   SUPPORT PAGE
   ============================================================ */
.support-hero{ padding-top:150px; padding-bottom:20px }
.support-hero .wrap{ max-width:820px }
.support-hero h1{ font-family:var(--display); font-weight:700; font-size:clamp(34px,5.4vw,58px);
  line-height:1.02; letter-spacing:-.02em; margin-top:20px; text-wrap:balance }
.support-hero p{ color:var(--muted); font-size:clamp(16px,1.7vw,19px); margin-top:18px; max-width:56ch }
.support-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px }
.scard{ background:linear-gradient(168deg,var(--raise-2),var(--raise)); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:24px }
.scard .ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:var(--ion);
  background:var(--ion-faint); border:1px solid var(--ion); margin-bottom:16px }
.scard h3{ font-family:var(--display); font-weight:600; font-size:17px }
.scard p{ color:var(--muted); font-size:13.5px; margin-top:8px }
.scard a{ display:inline-flex; align-items:center; gap:7px; margin-top:14px; font-family:var(--mono);
  font-size:12.5px; font-weight:700; color:var(--ion) }
.contact-card{ max-width:820px; margin:0 auto; background:linear-gradient(168deg,var(--raise-2),var(--raise));
  border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(28px,4vw,44px) }
.contact-card .grid2{ display:grid; grid-template-columns:1fr 1fr; gap:14px }
.contact-card label{ font-family:var(--display); font-size:11px; font-weight:600; letter-spacing:.06em;
  color:var(--muted); text-transform:uppercase; display:block; margin-bottom:8px }
.contact-card input,.contact-card textarea{ width:100%; border-radius:14px; border:1px solid var(--line);
  background:var(--ink); color:var(--text); padding:14px 16px; font-size:15px; font-family:var(--body); outline:none;
  transition:border-color .18s, box-shadow .18s }
.contact-card input{ height:52px }
.contact-card textarea{ min-height:130px; resize:vertical }
.contact-card input:focus,.contact-card textarea:focus{ border-color:var(--ion); box-shadow:0 0 0 3px var(--ion-glow) }
.contact-card .field{ margin-bottom:16px }
@media (max-width:760px){
  .support-cards{ grid-template-columns:1fr }
  .contact-card .grid2{ grid-template-columns:1fr }
}

/* ============================================================
   NAV CONTROLS — language + theme toggles
   ============================================================ */
.nav-tools{ display:flex; align-items:center; gap:8px }
.icbtn{ width:38px; height:38px; border-radius:11px; display:grid; place-items:center;
  border:1px solid var(--line); background:var(--raise); color:var(--muted);
  transition:color .18s, border-color .18s, transform .18s }
.icbtn:hover{ color:var(--ion); border-color:var(--ion); transform:translateY(-1px) }
.icbtn svg{ width:18px; height:18px }
.icbtn .sun{ display:none } .icbtn .moon{ display:block }
[data-theme="light"] .icbtn .sun{ display:block } [data-theme="light"] .icbtn .moon{ display:none }
.lang-toggle{ height:38px; padding:0 4px; border-radius:11px; border:1px solid var(--line);
  background:var(--raise); display:flex; align-items:center; gap:2px }
.lang-toggle button{ height:30px; min-width:34px; padding:0 9px; border:none; border-radius:8px;
  background:transparent; color:var(--muted); font-family:var(--display); font-weight:600;
  font-size:12px; letter-spacing:.04em; transition:.15s }
.lang-toggle button.on{ background:var(--ion-faint); color:var(--ion) }

/* ============================================================
   APP STORE DOWNLOAD BUTTONS
   ============================================================ */
.store-btns{ display:flex; gap:12px; flex-wrap:wrap }
.hero-b .store-btns,.plans-cta .store-btns{ justify-content:center }
.store-btn{ display:inline-flex; align-items:center; gap:12px; height:56px; padding:0 20px 0 18px;
  border-radius:15px; background:#0A0D12; border:1px solid rgba(255,255,255,.14); color:#fff;
  transition:transform .18s, box-shadow .18s, border-color .18s }
.store-btn:hover{ transform:translateY(-2px); border-color:var(--ion); box-shadow:0 14px 30px rgba(0,0,0,.4) }
.store-btn svg{ width:26px; height:26px; flex:none }
.store-btn .lbl{ display:flex; flex-direction:column; line-height:1.1; text-align:left }
.store-btn .lbl small{ font-size:10px; font-weight:500; color:rgba(255,255,255,.7); letter-spacing:.02em }
.store-btn .lbl b{ font-family:var(--display); font-size:16px; font-weight:600; margin-top:1px }
.store-note{ font-size:12.5px; color:var(--faint); margin-top:14px; display:flex; align-items:center; gap:8px }
.hero-b .store-note,.plans-cta .store-note{ justify-content:center }
.store-note .dot{ width:6px; height:6px; border-radius:50%; background:var(--busy); box-shadow:0 0 8px var(--busy); flex:none }

/* ============================================================
   PLANS
   ============================================================ */
.plans-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:54px; align-items:stretch }
.plan-card{ position:relative; display:flex; flex-direction:column;
  background:linear-gradient(168deg,var(--raise-2),var(--raise)); border:1px solid var(--line);
  border-radius:var(--r-xl); padding:32px }
.plan-card.pro{ border-color:var(--ion);
  background:radial-gradient(420px 280px at 80% -20%, var(--ion-glow), transparent 70%),
    linear-gradient(168deg,var(--raise-2),var(--raise)) }
.plan-card .ptag{ position:absolute; top:24px; right:24px; font-family:var(--mono); font-size:9px;
  font-weight:800; letter-spacing:.12em; padding:5px 10px; border-radius:8px }
.plan-card .ptag.free{ color:var(--muted); background:var(--raise-3); border:1px solid var(--line) }
.plan-card .ptag.soon{ color:var(--ion); background:var(--ion-faint); border:1px solid var(--ion) }
.plan-card .pname{ font-family:var(--display); font-weight:700; font-size:24px; letter-spacing:-.01em }
.plan-card .pdesc{ color:var(--muted); font-size:14px; margin-top:8px; max-width:36ch }
.plan-card .pprice{ margin-top:22px; display:flex; align-items:baseline; gap:8px }
.plan-card .pprice .amt{ font-family:var(--mono); font-weight:800; font-size:40px; color:var(--text); line-height:1 }
.plan-card .pprice .per{ font-size:13px; color:var(--muted) }
.plan-card ul{ list-style:none; margin-top:24px; display:flex; flex-direction:column; gap:13px; flex:1 }
.plan-card li{ display:flex; align-items:flex-start; gap:11px; font-size:14.5px; color:var(--text) }
.plan-card li.off{ color:var(--faint) }
.plan-card li .ck{ width:20px; height:20px; border-radius:50%; flex:none; display:grid; place-items:center;
  background:var(--ion-faint); color:var(--ion); margin-top:1px }
.plan-card li.off .ck{ background:var(--raise-3); color:var(--faint) }
.plan-card li .ck svg{ width:12px; height:12px }
.plan-card .pfoot{ margin-top:26px; font-family:var(--mono); font-size:11.5px; color:var(--muted); font-weight:700 }
.plans-cta{ text-align:center; margin-top:48px }
.plans-cta h3{ font-family:var(--display); font-weight:700; font-size:clamp(22px,3vw,32px); letter-spacing:-.01em }
.plans-cta p{ color:var(--muted); font-size:15px; margin-top:10px }
.plans-cta .store-btns{ margin-top:24px }

/* anonymized operator rows */
.op-row .badge{ background:var(--raise-3); color:var(--faint) }
.op-row .badge svg{ width:18px; height:18px }

@media (max-width:920px){
  .plans-grid{ grid-template-columns:1fr }
}
@media (max-width:760px){
  .nav-links a.only-wide{ display:none }
  .store-btn{ flex:1; min-width:0; justify-content:center }
}
@media (max-width:560px){
  .nav-links{ gap:8px }
  .nav-tools{ gap:6px }
  .store-btns{ width:100% }
}

/* ============================================================
   v2 REVISIONS
   ============================================================ */
/* "Yakında" badge on store buttons */
.store-btn{ position:relative; overflow:visible }
.store-soon{ position:absolute; top:-9px; right:-7px; font-family:var(--mono); font-size:8.5px;
  font-weight:800; letter-spacing:.1em; padding:3px 7px; border-radius:7px;
  background:var(--busy); color:#241500; box-shadow:0 4px 12px rgba(0,0,0,.4) }

/* "Yakında" badge above the nav İndir button */
.nav-cta-wrap{ position:relative; display:inline-flex }
.cta-soon{ position:absolute; top:-10px; right:-6px; z-index:2; font-family:var(--mono);
  font-size:8px; font-weight:800; letter-spacing:.1em; padding:2px 6px; border-radius:6px;
  background:var(--busy); color:#241500; box-shadow:0 4px 12px rgba(0,0,0,.4); pointer-events:none }

/* back-to-top button (appears after scroll) */
.to-top{ position:fixed; right:24px; bottom:24px; z-index:60; width:48px; height:48px;
  display:grid; place-items:center; border:1px solid var(--line); border-radius:50%;
  background:var(--raise-2); color:var(--ion); cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.4);
  opacity:0; transform:translateY(14px) scale(.9); pointer-events:none;
  transition:opacity .26s ease, transform .26s ease, border-color .18s, background .18s }
.to-top svg{ width:22px; height:22px }
.to-top:hover{ border-color:var(--ion); background:var(--raise-3); transform:translateY(-2px) scale(1) }
.to-top.show{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto }
@media (max-width:560px){ .to-top{ right:16px; bottom:16px; width:44px; height:44px } }
@media (prefers-reduced-motion: reduce){ .to-top{ transition:opacity .2s } }

/* hero value props (replaces fabricated stats) */
.hero-points{ list-style:none; display:flex; flex-direction:column; gap:13px; margin-top:36px }
.hero-points li{ display:flex; align-items:center; gap:12px; font-size:15px; color:var(--text); font-weight:500 }
.hero-points .ck{ width:24px; height:24px; border-radius:8px; flex:none; display:grid; place-items:center;
  background:var(--ion-faint); color:var(--ion); border:1px solid var(--ion) }
.hero-points .ck svg{ width:13px; height:13px }
.hero-points b{ color:var(--ion); font-weight:600 }
@media (max-width:920px){ .hero-points{ align-items:center; max-width:340px; margin-inline:auto } }

/* phone "updated" indicator (was live) */
.upd{ display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px;
  font-weight:700; color:var(--muted); letter-spacing:.04em }
.upd svg{ width:11px; height:11px; color:var(--ion) }

/* ---- problem: app-chaos visual ---- */
.chaos{ position:relative; height:340px; display:flex; align-items:center; justify-content:center }
.chaos .tile{ position:absolute; width:150px; border-radius:20px; padding:15px;
  background:linear-gradient(168deg,var(--raise-2),var(--raise)); border:1px solid var(--line);
  box-shadow:var(--float) }
.chaos .tile .ic{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center;
  background:var(--raise-3); color:var(--faint); margin-bottom:10px }
.chaos .tile .ic svg{ width:18px; height:18px }
.chaos .tile .nm{ font-family:var(--display); font-size:12.5px; font-weight:600; color:var(--muted) }
.chaos .tile .stt{ font-family:var(--mono); font-size:9.5px; font-weight:700; letter-spacing:.04em;
  color:var(--busy); margin-top:7px; display:flex; align-items:center; gap:5px }
.chaos .tile .stt::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--busy) }
.chaos .t1{ transform:rotate(-11deg) translate(-96px,-58px); z-index:1 }
.chaos .t2{ transform:rotate(7deg) translate(78px,-72px); z-index:2 }
.chaos .t3{ transform:rotate(-5deg) translate(-110px,72px); z-index:3 }
.chaos .t4{ transform:rotate(13deg) translate(96px,64px); z-index:2 }
.chaos .t5{ transform:rotate(-2deg) translate(6px,4px); z-index:5 }
.chaos .qmark{ position:absolute; z-index:9; font-family:var(--display); font-weight:700;
  color:var(--down); opacity:.85 }
.chaos .q1{ font-size:26px; top:16%; right:30% } .chaos .q2{ font-size:18px; bottom:22%; left:24% }
.chaos .q3{ font-size:34px; top:42%; right:14% }
@media (max-width:920px){ .chaos{ height:300px } .problem .before{ order:2 } }

/* ---- AI routing section ---- */
.ai{ position:relative; border-block:1px solid var(--line);
  background:radial-gradient(700px 380px at 82% 10%, var(--ion-faint), transparent 65%), var(--raise) }
.ai .wrap{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(32px,5vw,72px); align-items:center }
.ai .badge-ai{ display:inline-flex; align-items:center; gap:8px; font-family:var(--display); font-weight:600;
  font-size:12px; padding:7px 14px; border-radius:999px; background:var(--ion-faint); border:1px solid var(--ion);
  color:var(--text); letter-spacing:.02em; white-space:nowrap }
.ai h2{ font-family:var(--display); font-weight:700; font-size:clamp(28px,4vw,46px); line-height:1.06;
  letter-spacing:-.02em; margin-top:18px; text-wrap:balance }
.ai .lead{ color:var(--muted); font-size:clamp(15px,1.6vw,18px); margin-top:16px; max-width:46ch; text-wrap:pretty }
.ai-points{ list-style:none; margin-top:24px; display:flex; flex-direction:column; gap:14px }
.ai-points li{ display:flex; gap:14px; align-items:flex-start }
.ai-points .ic{ width:38px; height:38px; border-radius:11px; flex:none; display:grid; place-items:center;
  color:var(--ion); background:var(--ion-faint); border:1px solid var(--ion) }
.ai-points .ic svg{ width:19px; height:19px }
.ai-points b{ font-family:var(--display); font-size:15px; font-weight:600; display:block }
.ai-points span{ font-size:13.5px; color:var(--muted); display:block; margin-top:2px; text-wrap:pretty }
/* big route visual */
.ai-route{ position:relative; border-radius:var(--r-xl); border:1px solid var(--line);
  background:linear-gradient(168deg,var(--raise-2),var(--raise)); padding:26px 26px 30px;
  box-shadow:var(--float) }
.ai-route .rhead{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px }
.ai-route .rhead b{ font-family:var(--display); font-size:15px; font-weight:600 }
.ai-route .eta{ font-family:var(--mono); font-size:11px; font-weight:800; color:var(--ion) }
.ai-route .summary{ display:flex; gap:8px; margin:14px 0 20px }
.ai-route .sm{ flex:1; text-align:center; background:var(--ink); border:1px solid var(--line); border-radius:13px; padding:11px 6px }
.ai-route .sm .v{ font-family:var(--mono); font-weight:800; font-size:16px }
.ai-route .sm .l{ font-family:var(--display); font-size:8.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-top:3px; font-weight:600 }
.ai-route .stops{ position:relative; padding-left:6px }
.ai-route .stops .ln{ position:absolute; left:13px; top:8px; bottom:8px; width:3px; border-radius:3px;
  background:repeating-linear-gradient(180deg,var(--ion) 0 9px,transparent 9px 17px); opacity:.6 }
.ai-route .stp{ display:flex; align-items:center; gap:14px; padding:9px 0; position:relative }
.ai-route .stp i{ width:15px; height:15px; border-radius:50%; background:var(--ink); border:4px solid var(--ion);
  flex:none; box-shadow:0 0 10px var(--ion-glow) }
.ai-route .stp i.chg{ border-color:var(--ok); box-shadow:0 0 10px rgba(61,240,143,.5) }
.ai-route .stp .tx{ flex:1; min-width:0 }
.ai-route .stp .tx b{ font-size:13.5px; font-weight:600 }
.ai-route .stp .tx span{ font-size:11.5px; color:var(--muted); display:block; margin-top:1px }
.ai-route .stp .pc{ font-family:var(--mono); font-size:12px; font-weight:800; color:var(--ok); flex:none }
@media (max-width:920px){ .ai .wrap{ grid-template-columns:1fr; gap:40px } }

/* ---- vehicle bullets ---- */
.veh-points{ list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:13px }
.veh-points li{ display:flex; gap:12px; align-items:flex-start; font-size:14.5px; color:var(--text) }
.veh-points .ic{ width:30px; height:30px; border-radius:9px; flex:none; display:grid; place-items:center;
  color:var(--ion); background:var(--ion-faint); border:1px solid var(--ion) }
.veh-points .ic svg{ width:16px; height:16px }
.veh-points b{ font-weight:600 }
.veh-points span{ color:var(--muted) }
/* vehicle switcher chips inside card */
.vswitch{ display:flex; gap:7px; margin-top:14px; flex-wrap:wrap }
.vswitch .vc{ display:flex; align-items:center; gap:7px; padding:7px 11px; border-radius:11px;
  border:1px solid var(--line); background:var(--ink); font-size:11.5px; font-weight:500; color:var(--muted) }
.vswitch .vc.on{ border-color:var(--ion); background:var(--ion-faint); color:var(--text) }
.vswitch .vc svg{ width:18px; height:12px; color:currentColor }
.vswitch .vadd{ color:var(--ion); font-weight:600; white-space:nowrap }

/* ============================================================
   ABOUT + LEGAL PAGES
   ============================================================ */
.page-hero{ padding-top:150px; padding-bottom:24px }
.page-hero .wrap{ max-width:860px }
.page-hero .back{ display:flex; width:max-content; white-space:nowrap; align-items:center; gap:7px; font-family:var(--mono);
  font-size:12.5px; font-weight:700; color:var(--muted); margin-bottom:22px; transition:color .18s }
.page-hero .back:hover{ color:var(--ion) }
.page-hero h1{ font-family:var(--display); font-weight:700; font-size:clamp(34px,5.4vw,58px);
  line-height:1.02; letter-spacing:-.02em; margin-top:14px; text-wrap:balance }
.page-hero .lede{ color:var(--muted); font-size:clamp(16px,1.7vw,19px); margin-top:18px; max-width:60ch; text-wrap:pretty }
.page-hero .updated{ font-family:var(--mono); font-size:12px; color:var(--faint); margin-top:18px }

/* about specifics */
.about-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:8px }
.value{ background:linear-gradient(168deg,var(--raise-2),var(--raise)); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:26px }
.value .ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:var(--ion);
  background:var(--ion-faint); border:1px solid var(--ion); margin-bottom:16px }
.value h3{ font-family:var(--display); font-weight:600; font-size:18px }
.value p{ color:var(--muted); font-size:14px; margin-top:9px; text-wrap:pretty }
.about-quote{ margin-top:8px; border-radius:var(--r-xl); border:1px solid var(--ion);
  background:radial-gradient(420px 280px at 80% -20%, var(--ion-glow), transparent 70%), linear-gradient(168deg,var(--raise-2),var(--raise));
  padding:clamp(32px,5vw,56px) }
.about-quote p{ font-family:var(--display); font-weight:600; font-size:clamp(20px,2.6vw,30px);
  line-height:1.3; letter-spacing:-.01em; text-wrap:balance }
.about-quote .by{ font-family:var(--mono); font-size:12.5px; color:var(--muted); margin-top:18px; font-weight:700 }
@media (max-width:820px){ .about-grid{ grid-template-columns:1fr } }

/* legal prose */
.legal{ padding-block:8px 40px }
.legal .wrap{ max-width:820px }
.legal .toc{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:36px; padding-bottom:28px; border-bottom:1px solid var(--line) }
.legal .toc a{ font-family:var(--mono); font-size:11.5px; font-weight:700; color:var(--muted);
  padding:7px 12px; border-radius:9px; border:1px solid var(--line); background:var(--raise); transition:.18s }
.legal .toc a:hover{ color:var(--ion); border-color:var(--ion) }
.legal section{ margin-bottom:38px; scroll-margin-top:96px }
.legal h2{ font-family:var(--display); font-weight:700; font-size:clamp(20px,2.6vw,28px);
  letter-spacing:-.01em; display:flex; gap:14px; align-items:baseline }
.legal h2 .n{ font-family:var(--mono); font-size:14px; font-weight:800; color:var(--ion); flex:none }
.legal h3{ font-family:var(--display); font-weight:600; font-size:16px; margin-top:22px; color:var(--text) }
.legal p,.legal li{ color:var(--muted); font-size:15px; line-height:1.75; margin-top:12px; text-wrap:pretty }
.legal ul{ margin-top:12px; padding-left:22px; display:flex; flex-direction:column; gap:6px }
.legal li{ margin-top:0 }
.legal .lorem-note{ display:flex; align-items:center; gap:10px; margin-bottom:30px; padding:13px 16px;
  border-radius:14px; border:1px dashed var(--busy); background:rgba(255,181,71,.07); color:var(--busy);
  font-family:var(--mono); font-size:12px; font-weight:700 }
.legal .lorem-note svg{ width:16px; height:16px; flex:none }

/* ---- bilingual legal content (switched by <html lang>) ---- */
html[lang="en"] .lng-tr{ display:none !important }
html[lang="tr"] .lng-en{ display:none !important }

/* ---- legal prose extras ---- */
.legal a:not(.back){ color:var(--ion); font-weight:500; text-decoration:underline; text-underline-offset:2px;
  text-decoration-color:rgba(91,227,250,.35); transition:text-decoration-color .18s }
.legal a:not(.back):hover{ text-decoration-color:var(--ion) }
.legal strong, .legal b{ color:var(--text); font-weight:600 }
.legal h4{ font-family:var(--display); font-weight:600; font-size:14.5px; margin-top:18px; color:var(--text) }
.legal ul.dash{ list-style:none; padding-left:0 }
.legal ul.dash li{ position:relative; padding-left:18px }
.legal ul.dash li::before{ content:"–"; position:absolute; left:0; color:var(--ion); font-weight:700 }

/* entity / address card */
.legal .entity{ margin-top:14px; padding:16px 18px; border-radius:14px; border:1px solid var(--line);
  background:var(--raise); font-size:14.5px; line-height:1.7; color:var(--text) }
.legal .entity .lbl{ font-family:var(--mono); font-size:10.5px; font-weight:700; letter-spacing:.08em;
  color:var(--faint); text-transform:uppercase; display:block; margin-bottom:6px }
.legal .entity a{ text-decoration:none }

/* consent / callout blockquote */
.legal blockquote{ margin:14px 0 0; padding:14px 18px; border-left:3px solid var(--ion);
  border-radius:0 12px 12px 0; background:var(--ion-faint); color:var(--text);
  font-size:14.5px; line-height:1.7 }
.legal blockquote.consent{ display:flex; flex-direction:column; gap:10px }
.legal blockquote.consent .opt{ display:flex; align-items:center; gap:9px; font-family:var(--mono);
  font-size:12px; font-weight:700; color:var(--ion) }
.legal blockquote.consent .box{ width:15px; height:15px; border-radius:4px; border:1.5px solid var(--ion); flex:none }

/* tables */
.legal .tbl-wrap{ margin-top:16px; overflow-x:auto; border:1px solid var(--line); border-radius:14px }
.legal table{ width:100%; border-collapse:collapse; font-size:13.5px; min-width:440px }
.legal thead th{ text-align:left; font-family:var(--mono); font-size:10.5px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; color:var(--faint); background:var(--raise-2);
  padding:11px 14px; border-bottom:1px solid var(--line) }
.legal tbody td{ padding:11px 14px; color:var(--muted); line-height:1.6; vertical-align:top;
  border-bottom:1px solid var(--line) }
.legal tbody tr:last-child td{ border-bottom:0 }
.legal tbody td:first-child{ color:var(--text); font-weight:500 }

/* subprocessor cards */
.legal .subproc{ margin-top:16px; padding:18px 20px; border-radius:16px; border:1px solid var(--line);
  background:linear-gradient(168deg,var(--raise-2),var(--raise)) }
.legal .subproc h3{ margin-top:0 }
.legal .subproc .meta{ display:grid; grid-template-columns:auto 1fr; gap:6px 16px; margin-top:12px; font-size:13.5px }
.legal .subproc .meta dt{ font-family:var(--mono); font-size:10.5px; font-weight:700; letter-spacing:.05em;
  text-transform:uppercase; color:var(--faint); padding-top:3px }
.legal .subproc .meta dd{ margin:0; color:var(--muted); line-height:1.6 }
.legal .subproc .meta dd a{ word-break:break-word }
.legal .pill{ display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px;
  font-weight:700; letter-spacing:.04em; padding:3px 9px; border-radius:999px; vertical-align:middle }
.legal .pill.on{ background:rgba(61,240,143,.12); color:var(--ok) }
.legal .pill.partial{ background:rgba(255,181,71,.12); color:var(--busy) }
@media (max-width:560px){
  .legal .subproc .meta{ grid-template-columns:1fr; gap:2px 0 }
  .legal .subproc .meta dt{ padding-top:10px }
}

/* ============================================================
   SUPPORT (Lumynax-style) — big email card + note box
   ============================================================ */
.contact-intro{ color:var(--muted); font-size:clamp(16px,1.7vw,19px); line-height:1.7; max-width:60ch; margin:8px 0 36px }
.contact-intro a{ color:var(--ion); font-weight:600 }
.mailcard{ position:relative; border-radius:var(--r-xl); overflow:hidden; padding:clamp(28px,4vw,40px);
  border:1px solid var(--line);
  background:radial-gradient(540px 300px at 12% -30%, var(--ion-glow), transparent 65%), linear-gradient(168deg,var(--raise-2),var(--raise)) }
.mailcard .pill{ display:inline-flex; white-space:nowrap; font-family:var(--mono); font-size:10px; font-weight:800; letter-spacing:.16em;
  color:var(--ion); background:var(--ion-faint); border:1px solid var(--ion); padding:6px 11px; border-radius:8px }
.mailcard .addr{ display:block; font-family:var(--display); font-weight:700; letter-spacing:-.01em;
  font-size:clamp(26px,4.4vw,44px); margin:18px 0 14px; color:var(--text); width:max-content; max-width:100% }
.mailcard .addr:hover{ color:var(--ion) }
.mailcard p{ color:var(--muted); font-size:15px; max-width:52ch }
.notebox{ margin-top:18px; border-radius:var(--r-lg); border:1px solid var(--line);
  background:linear-gradient(168deg,var(--raise-2),var(--raise)); padding:22px 26px }
.notebox h3{ font-family:var(--display); font-weight:600; font-size:16px; color:var(--ion); margin-bottom:8px }
.notebox p{ color:var(--muted); font-size:14.5px; line-height:1.7; max-width:70ch; text-wrap:pretty }
.notebox p a{ color:var(--ion); font-weight:600 }

/* ============================================================
   HELP CENTER (Lumynax-style) — grouped accordions
   ============================================================ */
.hc-wrap{ max-width:860px }
.hc-sub{ color:var(--muted); font-size:clamp(15px,1.6vw,18px); margin-top:16px }
.hc-sub a{ color:var(--ion); font-weight:600 }
.hc-group{ margin-top:46px }
.hc-group > h2{ font-family:var(--display); font-weight:700; font-size:clamp(20px,2.8vw,28px);
  letter-spacing:-.01em; margin-bottom:16px }
.hc-acc{ display:flex; flex-direction:column; gap:10px }
.hc-item{ border:1px solid var(--line); border-radius:var(--r-md); background:linear-gradient(168deg,var(--raise-2),var(--raise));
  overflow:hidden; transition:border-color .18s }
.hc-item[open]{ border-color:var(--ion) }
.hc-item summary{ list-style:none; cursor:pointer; padding:18px 20px; display:flex; align-items:center;
  gap:16px; font-family:var(--display); font-weight:600; font-size:15.5px; color:var(--text) }
.hc-item summary::-webkit-details-marker{ display:none }
.hc-item summary .q{ flex:1 }
.hc-item summary .pm{ width:26px; height:26px; border-radius:8px; flex:none; display:grid; place-items:center;
  border:1px solid var(--line); color:var(--ion); position:relative }
.hc-item summary .pm::before,.hc-item summary .pm::after{ content:""; position:absolute; background:currentColor; border-radius:2px }
.hc-item summary .pm::before{ width:11px; height:2px } .hc-item summary .pm::after{ width:2px; height:11px; transition:transform .3s }
.hc-item[open] summary .pm{ background:var(--ion-faint) }
.hc-item[open] summary .pm::after{ transform:scaleY(0) }
.hc-item .a{ overflow:hidden; display:grid; grid-template-rows:0fr; transition:grid-template-rows var(--spring) }
.hc-item[open] .a{ grid-template-rows:1fr }
.hc-item .a > div{ min-height:0 }
.hc-item .a p{ color:var(--muted); font-size:14.5px; line-height:1.7; padding:0 52px 18px 20px; margin:0; text-wrap:pretty }

/* ============================================================
   ABOUT (Lumynax-style) — why / how / join
   ============================================================ */
.about-prose{ max-width:820px }
.about-prose h2{ font-family:var(--display); font-weight:700; font-size:clamp(22px,3vw,32px);
  letter-spacing:-.01em; margin-top:44px }
.about-prose p{ color:var(--muted); font-size:clamp(15px,1.6vw,17px); line-height:1.8; margin-top:16px; max-width:64ch; text-wrap:pretty }
.how-cards{ display:flex; flex-direction:column; gap:12px; margin-top:24px }
.how-card{ border:1px solid var(--line); border-radius:var(--r-lg); padding:22px 26px;
  background:linear-gradient(168deg,var(--raise-2),var(--raise)) }
.how-card b{ font-family:var(--display); font-weight:600; font-size:16px; display:block }
.how-card span{ color:var(--muted); font-size:14.5px; display:block; margin-top:7px; text-wrap:pretty }
.joinbar{ display:block; margin-top:32px; border-radius:var(--r-lg); padding:22px 26px;
  border:1px solid var(--ion); color:var(--ion); font-family:var(--display); font-weight:600; font-size:16px;
  background:radial-gradient(420px 200px at 12% 50%, var(--ion-glow), transparent 70%), var(--raise);
  transition:transform .18s }
.joinbar:hover{ transform:translateY(-2px) }
.joinbar b{ color:var(--text); font-weight:700 }


/* ============================================================
   WIDGET SECTION
   ============================================================ */
.widget-sec{ background:var(--raise) }
.widget-sec .wrap{
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:clamp(32px,5vw,72px); align-items:center
}
.widget-sec .badge-ai{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--display); font-weight:600; font-size:12px;
  padding:7px 14px; border-radius:999px;
  background:var(--ion-faint); border:1px solid var(--ion);
  color:var(--text); letter-spacing:.02em
}
.widget-sec h2{
  font-family:var(--display); font-weight:700;
  font-size:clamp(28px,4vw,46px); line-height:1.08;
  letter-spacing:-.02em; margin-top:18px; text-wrap:balance
}
.widget-sec .lead{
  color:var(--muted); font-size:clamp(15px,1.5vw,17px);
  margin-top:16px; max-width:46ch; text-wrap:pretty
}

/* showcase wrapper */
.widget-showcase{ display:flex; flex-direction:column; gap:10px; align-items:flex-start }
.ws-os-label{
  font-family:var(--mono); font-size:10px; font-weight:700;
  letter-spacing:.2em; color:var(--faint); text-transform:uppercase
}

/* widget grid */
.widget-grid{
  display:grid; grid-template-columns:1fr 2fr; gap:12px;
  width:100%; max-width:480px
}

/* base card */
.wcard{
  background:var(--raise-2); border:1px solid var(--line);
  border-radius:20px; padding:14px 15px;
  display:flex; flex-direction:column; gap:0;
  min-height:160px;
  box-shadow:0 2px 18px rgba(0,0,0,.25)
}
.wcard-sm{ /* natural height */ }
.wcard-md{ grid-column:2; grid-row:1; /* fills right col */ }
.wcard-route{ grid-column:1; grid-row:2 }

/* widget header */
.wc-head{
  display:flex; align-items:center; gap:5px; margin-bottom:10px
}
.wc-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--ok); flex:none
}
.wc-app{
  font-family:var(--mono); font-size:9px; letter-spacing:.14em;
  color:var(--muted); line-height:1
}

/* donut body */
.wc-body{ display:flex; align-items:center; gap:10px; flex:1 }
.wc-donut{
  position:relative; width:72px; height:72px; flex:none
}
.wc-donut svg{ width:72px; height:72px; display:block }
.wc-track{ fill:none; stroke:var(--raise-3); stroke-width:7 }
.wc-fill{ fill:none; stroke:var(--ok); stroke-width:7; stroke-linecap:round }
.wc-donut-inner{
  position:absolute; inset:0; display:flex;
  flex-direction:column; align-items:center; justify-content:center; gap:1px
}
.wc-cnt{
  font-family:var(--display); font-size:20px;
  font-weight:700; line-height:1; color:var(--text)
}
.wc-avail{
  font-family:var(--mono); font-size:7px; font-weight:700;
  letter-spacing:.08em; color:var(--ok)
}
.wc-side{ display:flex; flex-direction:column; gap:4px }
.wc-pw{ font-size:12px; color:var(--muted) }
.wc-pw b{ color:var(--ion); font-weight:700 }

/* bottom labels */
.wc-name{
  font-family:var(--display); font-size:13px;
  font-weight:700; margin-top:auto; padding-top:8px;
  color:var(--text)
}
.wc-ts{
  font-size:9px; color:var(--faint); margin-top:3px;
  font-family:var(--mono)
}

/* list widget */
.wc-list{
  list-style:none; display:flex; flex-direction:column;
  gap:7px; flex:1
}
.wc-list li{
  display:flex; align-items:center; gap:6px; font-size:12px
}
.wc-sname{
  flex:1; font-weight:500; font-size:12px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis
}
.wc-dist{ color:var(--muted); font-size:11px; white-space:nowrap }
.wc-slots{
  font-family:var(--mono); font-size:11px;
  font-weight:700; white-space:nowrap
}
.wc-slots.ok{ color:var(--ok) }
.wc-slots.busy{ color:var(--down) }
.wc-kw{ color:var(--ion); font-size:11px; font-weight:600; white-space:nowrap }

/* route widget */
.wc-route-bar{ margin:6px 0 4px }
.wc-route-track{
  height:3px; border-radius:2px;
  background:var(--raise-3); overflow:hidden
}
.wc-route-fill{
  height:100%; border-radius:2px; background:var(--ion)
}
.wc-km{
  display:flex; align-items:baseline; gap:5px; margin:6px 0 2px
}
.wc-km-num{
  font-family:var(--display); font-size:30px;
  font-weight:700; line-height:1; color:var(--text)
}
.wc-km-label{
  font-family:var(--mono); font-size:9px;
  letter-spacing:.1em; color:var(--muted)
}
.wc-next-label{ font-size:10px; color:var(--muted) }
.wc-next-stop{
  display:flex; align-items:center; gap:4px;
  font-size:12px; font-weight:600; margin-top:2px; color:var(--text)
}
.wc-stop-dist{ color:var(--ion); font-size:12px }
.wc-cost{
  font-family:var(--mono); font-size:10px;
  color:var(--faint); margin-top:auto; padding-top:6px
}

/* responsive */
@media(max-width:860px){
  .widget-sec .wrap{
    grid-template-columns:1fr; gap:clamp(32px,6vw,56px)
  }
  .widget-showcase{ align-items:center; width:100% }
  .widget-grid{ max-width:440px; margin-inline:auto }
}
@media(max-width:480px){
  .widget-grid{ grid-template-columns:1fr 1fr; max-width:100% }
  .wcard{ min-height:140px; padding:12px 12px }
  .wc-donut{ width:60px; height:60px }
  .wc-donut svg{ width:60px; height:60px }
  .wc-cnt{ font-size:16px }
  .wc-km-num{ font-size:24px }
}

.faq-more{ display:inline-flex; align-items:center; gap:7px; margin-top:24px; font-family:var(--mono); font-size:13px; font-weight:700; color:var(--ion); border:1px solid var(--line); padding:10px 16px; border-radius:12px; transition:border-color .18s, transform .18s }
.faq-more:hover{ border-color:var(--ion); transform:translateY(-1px) }
