*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#0d1614;color:#e9f1ed;font-family:'Space Grotesk',sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}
:root{
  --bg:#0d1614; --panel:#162321; --line:rgba(120,200,155,0.14); --ink:#e9f1ed;
  --dim:#7c958a; --accent:#3dd68c; --accent-dim:#2aa16a; --accent-soft:rgba(61,214,140,0.1);
  --ok:#3dd68c; --warn:#f0c674; --alert:#ff7a6b;
}
.mono{font-family:'IBM Plex Mono',ui-monospace,monospace}
.container{max-width:1080px;margin:0 auto;padding:0 24px}

nav{border-bottom:1px solid var(--line);background:rgba(13,22,20,0.92);backdrop-filter:blur(10px);position:sticky;top:0;z-index:10}
nav .container{display:flex;align-items:center;padding:16px 24px}
nav .brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--accent);letter-spacing:0.01em;font-size:16px;text-decoration:none}
nav .brand span{color:var(--ink)}
nav .brand .brand-mark{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:8px;background:#f5f0e6;padding:4px;flex-shrink:0;box-shadow:0 0 0 1px rgba(255,255,255,0.06)}
nav .brand .brand-mark img{width:100%;height:100%;object-fit:contain;display:block}
nav .brand .brand-text{display:inline-flex;align-items:center;color:var(--accent)}
nav .links{margin-left:auto;display:flex;gap:24px;align-items:center}
nav .links a{color:var(--dim);text-decoration:none;font-size:14px;transition:color .15s}
nav .links a:hover{color:var(--accent)}
nav .lang{display:flex;gap:0;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:0.08em;border:1px solid var(--line);border-radius:4px;overflow:hidden}
nav .lang a{color:var(--dim);padding:5px 9px;text-decoration:none;border-right:1px solid var(--line)}
nav .lang a:last-child{border-right:none}
nav .lang a.active{background:var(--accent);color:#0d1614;font-weight:700}

.hero{padding:100px 0 90px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(61,214,140,0.08) 0%,transparent 55%);pointer-events:none}
.hero .map-bg{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.18}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.hero-copy{position:relative;z-index:1}
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent);font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.08em;border-radius:20px;margin-bottom:22px;text-transform:uppercase}
.pill .live-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{font-size:48px;line-height:1.1;letter-spacing:-0.02em;margin:0 0 22px;font-weight:500}
.hero h1 strong{color:var(--accent);font-weight:700}
.hero .sub{color:var(--dim);font-size:19px;max-width:620px;margin:0 0 36px}
.cta{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;background:var(--accent);color:#0d1614;font-weight:700;font-size:15px;text-decoration:none;border-radius:6px;transition:filter .15s}
.cta:hover{filter:brightness(1.1)}
.cta.outline{background:transparent;color:var(--accent);border:1px solid var(--accent);margin-left:10px}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--panel)}
.stat{padding:32px 28px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{font-family:'IBM Plex Mono',monospace;font-size:34px;color:var(--accent);font-weight:500}
.stat .lbl{font-size:12px;color:var(--dim);letter-spacing:0.14em;text-transform:uppercase;margin-top:6px}

section.block{padding:90px 0;border-bottom:1px solid var(--line)}
section.block h2{font-size:32px;margin:0 0 14px;letter-spacing:-0.015em}
section.block h2 .num{font-family:'IBM Plex Mono',monospace;color:var(--accent);margin-right:14px;font-weight:500}
section.block .lede{color:var(--dim);font-size:17px;max-width:680px;margin:0 0 36px}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:28px}
.card h3{font-size:17px;margin:0 0 12px;color:var(--accent)}
.card p{color:var(--dim);font-size:14px;margin:0}
.card .icon{font-family:'IBM Plex Mono',monospace;color:var(--accent);font-size:12px;letter-spacing:0.1em;margin-bottom:14px;display:block}

.route-panel{background:#0a1210;border:1px solid var(--line);border-radius:8px;padding:0;overflow:hidden;font-family:'IBM Plex Mono',monospace}
.route-panel .hdr{padding:14px 20px;border-bottom:1px solid var(--line);display:flex;gap:10px;align-items:center;background:rgba(61,214,140,0.04)}
.route-panel .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.route-panel .hdr-title{color:var(--ink);font-size:13px;letter-spacing:0.04em}
.route-panel .body{padding:24px;font-size:13px;line-height:1.8}
.route-panel .row{display:grid;grid-template-columns:auto 1fr;gap:16px;margin-bottom:6px}
.route-panel .tag{color:var(--dim);text-transform:uppercase;font-size:11px;letter-spacing:0.1em}
.route-panel .ok{color:var(--ok)}
.route-panel .warn{color:var(--warn)}
.route-panel .alert{color:var(--alert)}
.route-panel .dim{color:var(--dim)}

.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:10px;max-width:720px}
.tier{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:32px;display:flex;flex-direction:column}
.tier.featured{border-color:var(--accent);box-shadow:0 10px 40px rgba(61,214,140,0.12)}
.tier h3{color:var(--accent);font-size:14px;letter-spacing:0.14em;text-transform:uppercase;margin:0 0 6px}
.tier .price{font-family:'IBM Plex Mono',monospace;font-size:38px;margin:6px 0 6px;font-weight:500}
.tier .price small{font-size:14px;color:var(--dim)}
.tier .tag{font-size:13px;color:var(--dim);margin:0 0 20px;min-height:38px}
.tier ul{list-style:none;padding:0;margin:0 0 22px;flex:1}
.tier li{padding:9px 0;font-size:14px;color:var(--ink);border-bottom:1px solid var(--line)}
.tier li:last-child{border-bottom:none}
.tier li::before{content:"\2713 ";color:var(--accent)}
.tier button,.tier a{display:block;width:100%;text-align:center;padding:13px;font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:700;border-radius:6px;text-decoration:none;cursor:pointer;transition:filter .15s;border:none;box-sizing:border-box}
.tier button{background:var(--accent);color:#0d1614}
.tier button:hover{filter:brightness(1.1)}
.tier .waitlist{margin-top:10px;background:transparent;color:var(--accent);border:1px solid var(--accent)}

.waitlist-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:680px;background:var(--panel);padding:28px;border:1px solid var(--line);border-radius:8px;margin-top:16px}
.waitlist-form label{display:flex;flex-direction:column;gap:6px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--dim);letter-spacing:0.04em;text-transform:uppercase}
.waitlist-form .full{grid-column:1/-1}
.waitlist-form input,.waitlist-form select,.waitlist-form textarea{background:#0a1210;border:1px solid var(--line);color:var(--ink);padding:13px 14px;min-height:44px;font-family:'Space Grotesk',sans-serif;font-size:14px;border-radius:5px}
.waitlist-form input:focus-visible,.waitlist-form select:focus-visible,.waitlist-form textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-color:var(--accent)}
.waitlist-form button{background:var(--accent);color:#0d1614;padding:14px;font-weight:700;font-size:14px;letter-spacing:0.04em;text-transform:uppercase;border:none;border-radius:5px;cursor:pointer}

footer{padding:40px 0;color:var(--dim);font-size:13px;border-top:1px solid var(--line)}
footer .cols{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
footer a{color:var(--dim);text-decoration:none}
footer a:hover{color:var(--accent)}

/* ── Live ticker: rule-change feed running across the hero ── */
.ticker{margin-top:28px;background:rgba(13,22,20,0.6);border:1px solid var(--line);border-radius:8px;padding:10px 16px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--dim);overflow:hidden;position:relative}
.ticker .label{color:var(--accent);text-transform:uppercase;letter-spacing:0.1em;margin-right:14px}
.ticker .feed{display:inline-block;animation:tick 28s linear infinite;white-space:nowrap}
.ticker .feed span{margin-right:34px}
.ticker .feed .alert{color:var(--alert)}
.ticker .feed .ok{color:var(--ok)}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── Hero side-card: live LEZ map preview ── */
.lez-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:22px;font-family:'IBM Plex Mono',monospace;font-size:12px;box-shadow:0 24px 60px rgba(0,0,0,0.45);position:relative;overflow:hidden}
.lez-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(61,214,140,0.08),transparent 55%);pointer-events:none}
.lez-card .head{color:var(--accent);text-transform:uppercase;letter-spacing:0.1em;font-size:10px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.lez-card .head .live{color:var(--ok)}
.lez-card svg{width:100%;height:auto;display:block}

/* ── Reveal-on-scroll ── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── Card hover lift + accent border ── */
.card{transition:border-color .15s,transform .15s}
.card:hover{border-color:var(--accent);transform:translateY(-2px)}

/* ── Disclaimer accent ── */
.disclaimer{color:var(--dim);font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:0.05em;margin-top:14px;opacity:.7}

@media (max-width:820px){
  .grid-3,.pricing,.waitlist-form{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .hero h1{font-size:34px}
  .hero-grid{grid-template-columns:1fr}
  .lez-card{order:2}
}

/* ── 2026 polish (added 2026-05-02) ─────────────────────────────────────── */

.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,#3dd68c,#7be0d2);z-index:99;transition:width .12s linear;box-shadow:0 0 12px rgba(61,214,140,0.5)}

.hero-mesh{position:absolute;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(540px circle at 22% 28%,rgba(61,214,140,0.10),transparent 60%),
  radial-gradient(420px circle at 78% 70%,rgba(255,122,107,0.06),transparent 65%),
  radial-gradient(380px circle at 50% 110%,rgba(61,214,140,0.05),transparent 60%);
  filter:blur(2px);animation:mesh-drift 22s ease-in-out infinite alternate}
@keyframes mesh-drift{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(20px,-12px,0) scale(1.05)}
}

@media (prefers-reduced-motion:reduce){
  .hero-mesh{animation:none}
}

/* ── 2026-05-03 · Why Fleetkeur comparison + 16-city scaffold ──────────── */

.compare{margin-top:30px;background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.compare table{width:100%;border-collapse:collapse;font-size:14px}
.compare th,.compare td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.compare thead th{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--dim);background:rgba(0,0,0,0.18);font-weight:500}
.compare tbody tr:last-child td{border-bottom:none}
.compare td.cap{color:var(--ink);font-weight:500}
.compare td.fk{color:var(--accent);text-align:center;font-family:'IBM Plex Mono',monospace;font-weight:600}
.compare td.gen{color:var(--dim);text-align:center;font-family:'IBM Plex Mono',monospace}
.compare td.fk.minus{color:var(--dim)}
.compare td.gen.plus{color:var(--accent);font-weight:600}
.compare .footnote{padding:14px 18px;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--dim);letter-spacing:0.04em;border-top:1px solid var(--line);background:rgba(0,0,0,0.12);opacity:.85}

.cities{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
@media (max-width:880px){.cities{grid-template-columns:repeat(2,1fr)}}
.city-card{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:16px;font-family:'IBM Plex Mono',monospace;font-size:12px;transition:border-color .15s,transform .15s}
.city-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.city-card .name{font-size:14px;color:var(--accent);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:8px}
.city-card .row{display:flex;justify-content:space-between;padding:4px 0;color:var(--dim);font-size:11px;letter-spacing:0.04em}
.city-card .row b{color:var(--ink);font-weight:500}
.city-card.live{border-color:rgba(61,214,140,0.45)}
.city-card.live::before{content:"● LIVE";display:block;font-size:9px;color:var(--accent);letter-spacing:0.12em;margin-bottom:6px}
.city-card.scheduled::before{content:"○ Q3 2026";display:block;font-size:9px;color:var(--dim);letter-spacing:0.12em;margin-bottom:6px}
.city-card.tbd .row b{color:var(--dim);font-style:italic}


/* ── 2026-05-06 · Pass-6 full-bleed shader hero (photos demoted to inset) ── */
body { background-color: var(--scroll-bg, #0d1614); transition: background-color 200ms linear; }
.hero { position: relative; isolation: isolate; }
.hero .hero-canvas {
  position: absolute; inset: 0; width: 100%; height: 100%;
  z-index: 0; pointer-events: none; display: block;
}
.hero .hero-veil {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 60% at 50% 40%, rgba(13,22,20,0) 0%, rgba(13,22,20,0.35) 60%, rgba(13,22,20,0.85) 100%),
    linear-gradient(180deg, rgba(13,22,20,0.10) 0%, rgba(13,22,20,0.55) 100%);
}
.hero .hero-mesh, .hero .map-bg, .hero .container { position: relative; z-index: 2; }
.split-char { display: inline-block; will-change: transform, opacity; }

.side-image {
  margin: 0 0 24px; padding: 0; max-width: 320px; float: right;
  border: 1px solid var(--line); background: rgba(0,0,0,0.2);
}
.side-image img { display: block; width: 100%; height: auto; filter: saturate(0.9); }
.side-image figcaption {
  padding: 8px 12px; font-family: 'IBM Plex Mono', monospace; font-size: 10px;
  letter-spacing: 0.12em; color: var(--dim); border-top: 1px solid var(--line);
}

.dashboard-shot {
  margin: 24px 0 28px; padding: 0; max-width: 720px;
  border: 1px solid var(--line); background: rgba(0,0,0,0.2);
}
.dashboard-shot img { display: block; width: 100%; height: auto; filter: saturate(0.95) contrast(1.02); }
.dashboard-shot figcaption {
  padding: 10px 14px; font-family: 'IBM Plex Mono', monospace; font-size: 10.5px;
  letter-spacing: 0.12em; color: var(--dim); border-top: 1px solid var(--line);
}

.cities-spot {
  margin: 0 0 16px; max-width: 200px; opacity: 0.92;
}
.cities-spot img { display: block; width: 100%; height: auto; }

@media (max-width: 880px) {
  .side-image { float: none; max-width: 100%; margin: 0 0 20px; }
  .dashboard-shot { max-width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
  .shader-grain { display: none; }
  body { transition: none; }
}
