/* ============================================================
   BRUUM — bruum.co
   Precision Noir: near-black, neon ice-blue, electric accents
   ============================================================ */

:root{
  --bg:#07070c;
  --bg2:#0a0a0f;
  --panel:#0f1118;
  --panel2:#12141d;
  --line:rgba(165,205,255,.13);
  --text:#eaf2ff;
  --muted:#93a0b8;
  --neon:#bfe3ff;
  --blue:#3b82f6;
  --blue2:#60a5fa;
  --green:#34d399;
  --red:#f87171;
  --glow:rgba(110,170,255,.22);
  --radius:18px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,"Helvetica Neue",Arial,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:var(--blue2)}
img{max-width:100%;display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}

/* ---------- header ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(7,7,12,.78);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;letter-spacing:.02em}
.brand a{color:inherit;text-decoration:none;display:flex;align-items:center;gap:10px}
.brand img{width:34px;height:34px;border-radius:9px;filter:drop-shadow(0 0 8px var(--glow))}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--neon);box-shadow:0 0 12px var(--neon);display:inline-block}
nav.site{display:flex;align-items:center;gap:22px}
nav.site a{color:var(--muted);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s;margin:0}
nav.site a:hover{color:var(--text);text-decoration:none}
.lang-switch{
  border:1px solid var(--line);border-radius:999px;padding:4px 12px;
  font-size:.8rem;font-weight:700;color:var(--neon)!important;letter-spacing:.06em;
}
.lang-switch:hover{background:rgba(165,205,255,.08)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,var(--blue) 0%,#2563eb 100%);
  color:#fff;text-decoration:none;font-weight:700;font-size:1rem;
  padding:14px 28px;border-radius:14px;border:none;cursor:pointer;
  box-shadow:0 8px 28px rgba(59,130,246,.35);
  transition:transform .15s,box-shadow .15s;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(59,130,246,.5);text-decoration:none}
.btn.ghost{
  background:transparent;border:1px solid var(--line);color:var(--text);box-shadow:none;
}
.btn.ghost:hover{background:rgba(165,205,255,.07);box-shadow:none}

/* store badges */
.stores{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.store-badge{
  display:flex;align-items:center;gap:12px;text-decoration:none;
  background:#000;border:1px solid rgba(255,255,255,.22);border-radius:14px;
  padding:10px 20px;min-width:190px;transition:transform .15s,border-color .15s;
}
.store-badge:hover{transform:translateY(-2px);border-color:var(--neon);text-decoration:none}
.store-badge svg{width:28px;height:28px;flex-shrink:0}
.store-badge .txt{line-height:1.2;text-align:left}
.store-badge .txt small{display:block;font-size:.68rem;color:#bbb;letter-spacing:.04em;text-transform:uppercase}
.store-badge .txt strong{display:block;font-size:1.05rem;color:#fff;font-weight:700}
.store-note{font-size:.85rem;color:var(--muted)}

/* ---------- hero ---------- */
.hero{
  position:relative;
  padding:84px 0 60px;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:-40% -20% auto;height:140%;
  background:
    radial-gradient(560px 420px at 18% 20%,rgba(59,130,246,.20),transparent 65%),
    radial-gradient(640px 480px at 85% 10%,rgba(191,227,255,.10),transparent 60%),
    radial-gradient(500px 500px at 65% 90%,rgba(59,130,246,.10),transparent 65%);
  pointer-events:none;
  animation:heroGlow 9s ease-in-out infinite alternate;
}
@keyframes heroGlow{from{opacity:.7;transform:translateY(0)}to{opacity:1;transform:translateY(18px)}}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.eyebrow{
  display:inline-block;font-size:.78rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;
  color:var(--neon);border:1px solid var(--line);border-radius:999px;padding:7px 16px;
  background:rgba(165,205,255,.06);box-shadow:0 0 24px rgba(120,180,255,.12) inset;
  margin-bottom:22px;
}
.hero h1{
  font-size:clamp(2.4rem,5.2vw,4rem);
  line-height:1.06;font-weight:900;letter-spacing:-.02em;
  margin-bottom:22px;
}
.hero h1 .shine{
  background:linear-gradient(100deg,var(--neon) 10%,var(--blue2) 50%,var(--neon) 90%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shine 5s linear infinite;
}
@keyframes shine{to{background-position:200% center}}
.hero .lead{font-size:1.2rem;color:var(--muted);max-width:34em;margin-bottom:30px}
.hero .lead strong{color:var(--text)}
.hero .cta{display:flex;flex-direction:column;gap:14px;align-items:flex-start}

/* ---------- phone mockup ---------- */
.phone-col{display:flex;justify-content:center}
.phone{
  width:300px;border-radius:42px;padding:12px;
  background:linear-gradient(160deg,#1a1d28,#0b0d14);
  border:1px solid rgba(165,205,255,.18);
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 60px rgba(80,140,255,.12);
  animation:floaty 6s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:rotate(2.5deg) translateY(0)}50%{transform:rotate(2.5deg) translateY(-12px)}}
.screen{
  border-radius:32px;background:var(--bg2);overflow:hidden;
  border:1px solid rgba(165,205,255,.08);
  padding:18px 16px 20px;
  font-size:.8rem;
}
.screen .statusbar{display:flex;justify-content:space-between;color:var(--muted);font-size:.65rem;margin-bottom:14px}
.screen .car-name{font-weight:800;font-size:.95rem;margin-bottom:2px}
.screen .car-sub{color:var(--green);font-size:.68rem;display:flex;align-items:center;gap:6px;margin-bottom:14px}
.screen .car-sub::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.gauges{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.gauge{
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:10px 12px;
}
.gauge .g-label{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.gauge .g-value{font-size:1.3rem;font-weight:800;color:var(--neon);font-variant-numeric:tabular-nums}
.gauge .g-unit{font-size:.65rem;color:var(--muted);font-weight:600}
.chat-bubble{
  background:linear-gradient(135deg,rgba(59,130,246,.16),rgba(59,130,246,.05));
  border:1px solid rgba(96,165,250,.35);border-radius:14px;padding:11px 13px;
  font-size:.74rem;line-height:1.45;color:var(--text);
}
.chat-bubble .who{display:flex;align-items:center;gap:6px;font-weight:800;color:var(--blue2);font-size:.66rem;margin-bottom:5px;text-transform:uppercase;letter-spacing:.08em}
.chat-bubble .who::before{content:"✦"}

/* ---------- marquee ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:rgba(165,205,255,.03);
  overflow:hidden;white-space:nowrap;padding:14px 0;
}
.marquee .track{display:inline-block;animation:scroll 28s linear infinite}
.marquee span{
  font-size:.85rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin:0 28px;
}
.marquee span b{color:var(--neon)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
section{padding:88px 0}
section.tight{padding:56px 0}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:900;letter-spacing:-.02em;line-height:1.12;margin-bottom:14px}
.sub{color:var(--muted);font-size:1.12rem;max-width:42em;margin-bottom:44px}
.center{text-align:center}
.center .sub{margin-left:auto;margin-right:auto}

/* benefit cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{
  background:linear-gradient(170deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px;
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-5px);border-color:rgba(165,205,255,.32);box-shadow:0 18px 48px rgba(0,0,0,.45),0 0 40px rgba(80,140,255,.08)}
.card .ic{font-size:1.9rem;margin-bottom:14px;filter:drop-shadow(0 0 12px var(--glow));background:none;border:none;width:auto;height:auto;display:block}
.card h3{font-size:1.15rem;font-weight:800;margin-bottom:8px}
.card p{color:var(--muted);font-size:.95rem}
.card p b{color:var(--text)}

/* manifesto / revolution */
.manifesto{
  position:relative;text-align:center;
  background:radial-gradient(700px 360px at 50% 0%,rgba(59,130,246,.14),transparent 70%);
}
.manifesto h2{font-size:clamp(2.2rem,5vw,3.6rem)}
.manifesto p{color:var(--muted);font-size:1.15rem;max-width:38em;margin:0 auto 8px}
.manifesto p strong{color:var(--text)}

/* versus */
.versus{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:44px;text-align:left}
.vs-col{
  border-radius:var(--radius);padding:30px 28px;border:1px solid var(--line);
  background:var(--panel);
}
.vs-col.win{
  border-color:rgba(96,165,250,.45);
  background:linear-gradient(170deg,rgba(59,130,246,.10),var(--panel));
  box-shadow:0 0 50px rgba(59,130,246,.10);
}
.vs-col h3{font-size:1.1rem;font-weight:800;margin-bottom:18px;color:var(--muted)}
.vs-col.win h3{color:var(--neon)}
.vs-col ul{list-style:none}
.vs-col li{padding:9px 0;border-bottom:1px solid rgba(165,205,255,.07);color:var(--muted);font-size:.97rem;display:flex;gap:10px;align-items:baseline}
.vs-col li:last-child{border-bottom:none}
.vs-col li::before{content:"✕";color:var(--red);font-weight:800;flex-shrink:0}
.vs-col.win li::before{content:"✓";color:var(--green)}
.vs-col.win li{color:var(--text)}
.vs-price{margin-top:18px;font-weight:900;font-size:1.3rem;color:var(--neon)}
.vs-price small{display:block;font-weight:500;font-size:.8rem;color:var(--muted)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:step}
.step{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;position:relative;counter-increment:step;
}
.step::before{
  content:counter(step,decimal-leading-zero);
  font-size:2.6rem;font-weight:900;color:transparent;
  -webkit-text-stroke:1.5px rgba(165,205,255,.4);
  display:block;margin-bottom:10px;line-height:1;
  background:none;width:auto;height:auto;
}
.step h3{font-size:1.12rem;font-weight:800;margin-bottom:8px}
.step p{color:var(--muted);font-size:.95rem}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat{padding:28px 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
.stat .num{
  font-size:clamp(2rem,4vw,3rem);font-weight:900;color:var(--neon);
  font-variant-numeric:tabular-nums;line-height:1.1;
  text-shadow:0 0 30px rgba(120,180,255,.35);
}
.stat .lbl{color:var(--muted);font-size:.88rem;margin-top:6px}

/* investors */
.invest{
  background:linear-gradient(170deg,rgba(59,130,246,.08),transparent 55%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.invest .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.invest ul{list-style:none;margin:20px 0 28px}
.invest li{padding:10px 0;display:flex;gap:12px;color:var(--muted);font-size:1.02rem}
.invest li::before{content:"⚡";flex-shrink:0}
.invest li b{color:var(--text)}
.invest-card{
  background:var(--panel);border:1px solid rgba(96,165,250,.35);border-radius:var(--radius);
  padding:36px 32px;text-align:center;box-shadow:0 0 60px rgba(59,130,246,.10);
}
.invest-card .big{font-size:1.5rem;font-weight:900;margin-bottom:10px}
.invest-card p{color:var(--muted);margin-bottom:22px}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
.faq details{
  border:1px solid var(--line);border-radius:14px;background:var(--panel);
  margin-bottom:12px;overflow:hidden;
}
.faq summary{
  cursor:pointer;padding:18px 22px;font-weight:700;font-size:1.02rem;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--neon);font-weight:400;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 22px 18px;color:var(--muted);font-size:.97rem}

/* final CTA */
.final-cta{
  text-align:center;position:relative;overflow:hidden;
  background:radial-gradient(640px 380px at 50% 110%,rgba(59,130,246,.20),transparent 70%);
}
.final-cta .stores{justify-content:center;margin-top:30px}

/* callout (shared with legal) */
.callout{
  background:rgba(59,130,246,.08);border:1px solid rgba(96,165,250,.3);
  border-radius:14px;padding:18px 22px;color:var(--text);margin:20px 0;
}

/* ---------- legal pages ---------- */
main.legal,.legal{max-width:820px;margin:0 auto;padding:56px 24px 80px}
.legal h1{font-size:2.1rem;font-weight:900;letter-spacing:-.01em;margin-bottom:8px}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:28px}
.legal h2{font-size:1.3rem;margin:36px 0 12px}
.legal h3{font-size:1.05rem;margin:24px 0 8px;font-weight:700}
.legal p{color:#c6d2e6;margin-bottom:12px}
.legal ul{margin:0 0 14px 22px;color:#c6d2e6}
.legal li{margin-bottom:6px}
.legal table{width:100%;border-collapse:collapse;margin:14px 0 18px;font-size:.92rem}
.legal th,.legal td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top;color:#c6d2e6}
.legal th{background:var(--panel);color:var(--text)}
.legal code{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:.85em}

/* form */
.form{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-top:24px}
.form label{display:block;font-weight:700;font-size:.92rem;margin:18px 0 6px}
.form input,.form textarea{
  width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:12px;
  color:var(--text);padding:12px 14px;font-size:.97rem;font-family:inherit;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--blue2)}
.form textarea{min-height:140px;resize:vertical}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);padding:34px 0;background:var(--bg2)}
footer.site .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.9rem}
footer.site nav{display:flex;gap:20px;flex-wrap:wrap}
footer.site a{color:var(--muted);text-decoration:none;margin:0}
footer.site a:hover{color:var(--text)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .phone,.hero::before,.marquee .track,.hero h1 .shine{animation:none}
}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .phone-col{order:-1}
  .phone{width:260px}
  .grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .versus{grid-template-columns:1fr}
  .invest .wrap{grid-template-columns:1fr}
  nav.site a:not(.lang-switch){display:none}
}
@media(max-width:560px){
  .grid{grid-template-columns:1fr}
  section{padding:64px 0}
  .hero{padding:56px 0 40px}
}
