/* RunOrJog landing — rich dark-neon theme with motion. */
:root {
  --bg: #06060e;
  --bg-2: #0b0b1a;
  --card: rgba(20, 20, 42, 0.6);
  --cyan: #00dcff;
  --green: #39ff14;
  --gold: #ffd700;
  --pink: #ff44aa;
  --purple: #aa44ff;
  --text: #ffffff;
  --text-70: rgba(255, 255, 255, 0.72);
  --text-45: rgba(255, 255, 255, 0.45);
  --border: rgba(255, 255, 255, 0.08);
  --maxw: 1140px;
  --radius: 18px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--cyan); text-decoration: none; }
.container { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; position: relative; }

/* ── Aurora animated background (fixed, behind everything) ── */
.aurora { position: fixed; inset: 0; z-index: -2; overflow: hidden; }
.aurora::before, .aurora::after {
  content: ""; position: absolute; width: 60vw; height: 60vw; border-radius: 50%;
  filter: blur(90px); opacity: 0.35; will-change: transform;
}
.aurora::before {
  background: radial-gradient(circle, var(--cyan), transparent 60%);
  top: -10vw; left: -10vw; animation: drift1 18s ease-in-out infinite alternate;
}
.aurora::after {
  background: radial-gradient(circle, var(--purple), transparent 60%);
  bottom: -15vw; right: -10vw; animation: drift2 22s ease-in-out infinite alternate;
}
@keyframes drift1 { to { transform: translate(20vw, 12vh) scale(1.2); } }
@keyframes drift2 { to { transform: translate(-16vw, -10vh) scale(1.15); } }

/* ── Nav ── */
.nav {
  position: sticky; top: 0; z-index: 50;
  transition: background 0.3s, border-color 0.3s;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(6, 6, 14, 0.8);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { font-weight: 800; font-size: 21px; letter-spacing: 0.5px; }
.brand .accent { color: var(--cyan); }
.lang-switch { display: flex; gap: 4px; }
.lang-switch button {
  background: transparent; border: 1px solid rgba(255, 255, 255, 0.15);
  color: var(--text-70); font: inherit; font-size: 12px; font-weight: 700;
  text-transform: uppercase; padding: 6px 11px; border-radius: 9px; cursor: pointer;
  transition: all 0.15s;
}
.lang-switch button:hover { border-color: var(--cyan); color: var(--text); }
.lang-switch button.active { background: var(--cyan); color: #06060e; border-color: var(--cyan); }

/* ── Full-page 3D background (fixed, so the hex map animates on EVERY screen) ── */
#hero3d { position: fixed; inset: 0; width: 100%; height: 100%; z-index: -1; }
#hero3d canvas { display: block; width: 100% !important; height: 100% !important; }
/* Sections sit on a translucent dark veil so the moving 3D glows through subtly
   while text stays readable. The hero stays fully transparent for max effect. */
section, .pill-marquee, .final-cta, .footer { background: rgba(6, 6, 14, 0.8); position: relative; }

/* ── Hero ── */
.hero {
  position: relative; min-height: 100vh; display: flex; align-items: center;
  padding: 90px 0 120px; overflow: hidden; background: transparent;
}

/* ── Floating hero cards (the "fun" bits) ── */
.float-cards { position: absolute; inset: 0; pointer-events: none; z-index: 1; }
.float-card {
  position: absolute; display: inline-flex; align-items: center; gap: 10px;
  padding: 11px 15px; border-radius: 14px; font-weight: 700; font-size: 14px;
  background: rgba(14, 14, 30, 0.7); border: 1px solid var(--fc, var(--cyan));
  color: #fff; backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4), 0 0 24px -10px var(--fc, var(--cyan));
  white-space: nowrap; animation: cardfloat 7s ease-in-out infinite;
}
.float-card .ico { width: 18px; height: 18px; stroke: var(--fc, var(--cyan)); }
.float-card .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--fc); box-shadow: 0 0 8px var(--fc); }
.fc-a { top: 14%; left: 4%; --fc: var(--green); animation-delay: 0s; }
.fc-b { top: 26%; right: 6%; --fc: var(--gold); animation-delay: 1.2s; }
.fc-c { bottom: 24%; left: 7%; --fc: var(--pink); animation-delay: 2.1s; }
.fc-d { bottom: 30%; right: 5%; --fc: var(--cyan); animation-delay: 0.6s; }
@keyframes cardfloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-16px); } }
@media (max-width: 820px) { .float-cards { display: none; } }
.hero-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 40px; align-items: center; }
.hero h1 {
  font-size: clamp(36px, 6.2vw, 64px); font-weight: 900; line-height: 1.05; margin-bottom: 20px;
  background: linear-gradient(100deg, #fff 30%, var(--cyan) 55%, var(--green) 80%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  background-size: 200% auto; animation: shine 6s linear infinite;
}
@keyframes shine { to { background-position: 200% center; } }
.hero .sub { font-size: clamp(16px, 2.3vw, 20px); color: var(--text-70); max-width: 560px; margin-bottom: 32px; }
.cta-row { display: flex; gap: 14px; flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 15px 28px;
  border-radius: 32px; font-weight: 700; font-size: 16px; transition: transform 0.15s, box-shadow 0.25s, opacity 0.15s;
}
.btn-primary {
  background: linear-gradient(90deg, #006478, var(--cyan), #006478); color: #fff;
  box-shadow: 0 8px 30px rgba(0, 220, 255, 0.35);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(0, 220, 255, 0.5); }
.btn-ghost { border: 1px solid var(--border); color: var(--text); backdrop-filter: blur(6px); }
.btn-ghost:hover { transform: translateY(-2px); border-color: var(--cyan); }

/* ── Phone mockup ── */
.phone {
  position: relative; width: 280px; max-width: 80vw; margin: 0 auto; aspect-ratio: 9 / 19.5;
  border-radius: 38px; padding: 12px;
  background: linear-gradient(160deg, #1b1b33, #0a0a16);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6), 0 0 0 2px rgba(0, 220, 255, 0.12);
  animation: floaty 6s ease-in-out infinite;
}
@keyframes floaty { 0%, 100% { transform: translateY(0) rotate(-1.5deg); } 50% { transform: translateY(-14px) rotate(1.5deg); } }
.phone .screen {
  position: relative; width: 100%; height: 100%; border-radius: 28px; overflow: hidden;
  background: #0a0a16; display: flex; align-items: center; justify-content: center;
}
.phone .screen img, .phone .screen video { width: 100%; height: 100%; object-fit: cover; }
.phone .screen .ph-fallback { color: var(--text-45); font-size: 13px; text-align: center; padding: 20px; }
.phone .notch {
  position: absolute; top: 16px; left: 50%; transform: translateX(-50%);
  width: 90px; height: 22px; background: #0a0a16; border-radius: 0 0 14px 14px; z-index: 2;
}

/* Real screenshot sits on top of the faux map when present. */
.phone .screen .real-shot { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 4; }

/* Screenshots already include the iOS status bar / dynamic island, so hide
   the drawn frame notch to avoid a doubled pill. */
.phone:has(.real-shot) .notch,
.device:has(.screen img) .notch { display: none; }

/* ── Faux in-app map (a real-looking example of the game screen) ── */
.app-map { position: absolute; inset: 0; overflow: hidden;
  background: radial-gradient(120% 80% at 50% 28%, #0e1430, #070711); }
.app-map::before { /* faint streets */
  content: ""; position: absolute; inset: -10%;
  background-image:
    linear-gradient(72deg, transparent 48.5%, rgba(120, 150, 190, 0.10) 49.5%, transparent 50.5%),
    linear-gradient(-58deg, transparent 48.5%, rgba(120, 150, 190, 0.07) 49.5%, transparent 50.5%),
    linear-gradient(18deg, transparent 49%, rgba(120, 150, 190, 0.05) 50%, transparent 51%);
  background-size: 70px 70px, 100px 100px, 150px 150px;
}
.am-hex {
  position: absolute; width: 34px; height: 38px;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}
.am-hex.fc { box-shadow: 0 0 16px -2px var(--hc); background: color-mix(in srgb, var(--hc) 55%, transparent); border: 1px solid var(--hc); }
.am-hex.ol { background: rgba(255, 255, 255, 0.03); outline: 1px solid rgba(255, 255, 255, 0.08); }
.am-route { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; }
.am-route path { fill: none; stroke: var(--cyan); stroke-width: 3; stroke-linecap: round; filter: drop-shadow(0 0 4px var(--cyan)); }
.am-dot { position: absolute; width: 12px; height: 12px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 14px var(--cyan); z-index: 2; }
.am-top { position: absolute; top: 16px; left: 0; right: 0; display: flex; justify-content: center; gap: 6px; z-index: 3; }
.am-pill { font-size: 9px; font-weight: 800; padding: 4px 11px; border-radius: 20px; letter-spacing: .3px; }
.am-solo { background: rgba(57, 255, 20, 0.18); color: var(--green); }
.am-multi { background: rgba(255, 255, 255, 0.08); color: rgba(255, 255, 255, 0.55); }
.am-endo { position: absolute; bottom: 78px; left: 50%; transform: translateX(-50%); z-index: 3;
  font-size: 11px; font-weight: 800; color: var(--green); background: rgba(0, 0, 0, 0.55);
  padding: 5px 13px; border-radius: 14px; white-space: nowrap; }
.am-start { position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%); z-index: 3;
  width: 58px; height: 58px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 900; letter-spacing: 1px; color: var(--cyan);
  background: rgba(10, 10, 26, 0.85); border: 2px solid var(--cyan);
  box-shadow: 0 0 22px rgba(0, 220, 255, 0.5); animation: pulse 2.4s ease-in-out infinite; }

/* ── Sections ── */
section { padding: 70px 0; position: relative; }
.section-title { font-size: clamp(26px, 4.2vw, 38px); font-weight: 900; text-align: center; margin-bottom: 14px; }
.section-sub { text-align: center; color: var(--text-45); max-width: 560px; margin: 0 auto 44px; }

/* ── Stats band ── */
.stats { background: linear-gradient(180deg, rgba(6, 6, 14, 0.86), rgba(6, 6, 14, 0.78)); }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 24px; text-align: center; }
.stat .n { font-size: clamp(30px, 5vw, 48px); font-weight: 900; color: var(--cyan); line-height: 1; }
.stat .l { color: var(--text-70); font-size: 14px; margin-top: 8px; }

/* ── Feature grid ── */
.features { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 18px; }
.feature {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 26px; backdrop-filter: blur(8px);
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.feature:hover {
  transform: translateY(-6px); border-color: rgba(0, 220, 255, 0.4);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
}
.feature .ico { font-size: 30px; margin-bottom: 14px; display: inline-block; }
.feature:hover .ico { animation: pop 0.5s ease; }
@keyframes pop { 50% { transform: scale(1.3) rotate(-8deg); } }
.feature h3 { font-size: 19px; margin-bottom: 8px; }
.feature p { color: var(--text-70); font-size: 15px; }

/* ── Steps ── */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; }
.step { text-align: center; padding: 22px; }
.step .num {
  width: 52px; height: 52px; line-height: 52px; margin: 0 auto 14px; border-radius: 50%;
  background: rgba(0, 220, 255, 0.12); border: 1px solid rgba(0, 220, 255, 0.35);
  color: var(--cyan); font-weight: 900; font-size: 22px;
}

/* ── Gameplay video ── */
.video-frame {
  position: relative; max-width: 880px; margin: 0 auto; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--border); box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
  aspect-ratio: 16 / 9; background: #0a0a16;
}
.video-frame video, .video-frame iframe, .video-frame img { width: 100%; height: 100%; object-fit: cover; border: 0; display: block; }
.video-frame .vid-fallback {
  position: absolute; inset: 0; display: flex; flex-direction: column; gap: 14px;
  align-items: center; justify-content: center; color: var(--text-45);
  background:
    radial-gradient(600px 300px at 50% 30%, rgba(0, 220, 255, 0.1), transparent),
    repeating-linear-gradient(45deg, #0c0c1c, #0c0c1c 14px, #0e0e22 14px, #0e0e22 28px);
}
.play-badge {
  width: 76px; height: 76px; border-radius: 50%;
  background: rgba(0, 220, 255, 0.15); border: 2px solid var(--cyan);
  display: flex; align-items: center; justify-content: center;
  animation: pulse 2s ease-in-out infinite;
}
.play-badge::after { content: ""; border-left: 22px solid var(--cyan); border-top: 13px solid transparent; border-bottom: 13px solid transparent; margin-left: 6px; }
@keyframes pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(0, 220, 255, 0.4); } 50% { box-shadow: 0 0 0 18px rgba(0, 220, 255, 0); } }

/* ── Screenshot gallery ── */
.gallery { display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; }
.shot {
  width: 220px; max-width: 60vw; aspect-ratio: 9 / 19.5; border-radius: 26px; overflow: hidden;
  border: 1px solid var(--border); background: #0a0a16; will-change: transform;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5); transition: transform 0.3s, box-shadow 0.3s;
}
.shot:hover { transform: translateY(-10px) scale(1.03) !important; box-shadow: 0 30px 70px rgba(0, 220, 255, 0.25); }
.shot img { width: 100%; height: 100%; object-fit: cover; }
.shot .ph-fallback { color: var(--text-45); font-size: 12px; text-align: center; padding: 20px; height: 100%; display: flex; align-items: center; justify-content: center; }
.shot:nth-child(even) { margin-top: 28px; }

/* ── Keyword pill marquee (two rows, opposite directions) ── */
.pill-marquee { overflow: hidden; padding: 26px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: rgba(0, 0, 0, 0.22); display: grid; gap: 14px; }
.pill-row { display: flex; gap: 14px; width: max-content; }
.pill-row.left { animation: scroll-x 30s linear infinite; }
.pill-row.right { animation: scroll-x-rev 34s linear infinite; }
.pill-marquee:hover .pill-row { animation-play-state: paused; }
@keyframes scroll-x { to { transform: translateX(-50%); } }
@keyframes scroll-x-rev { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.pill {
  display: inline-flex; align-items: center; gap: 9px; white-space: nowrap;
  padding: 11px 20px; border-radius: 30px; font-weight: 700; font-size: 15px;
  background: rgba(255, 255, 255, 0.04); border: 1px solid var(--pc, var(--cyan));
  color: #fff; backdrop-filter: blur(6px);
}
.pill::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--pc, var(--cyan)); box-shadow: 0 0 10px var(--pc, var(--cyan)); }
.pc-cyan { --pc: var(--cyan); } .pc-green { --pc: var(--green); } .pc-gold { --pc: var(--gold); }
.pc-pink { --pc: var(--pink); } .pc-purple { --pc: var(--purple); }

/* ── Bento grid (varied-size cards) ── */
.bento-head { text-align: center; margin-bottom: 30px; }
.bento { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 150px; gap: 16px; }
.bento-card {
  border-radius: var(--radius); padding: 22px; border: 1px solid var(--border);
  background: var(--card); backdrop-filter: blur(8px); position: relative; overflow: hidden;
  transition: transform 0.25s, border-color 0.25s; --bc: var(--cyan);
}
.bento-card:hover { transform: translateY(-5px); border-color: var(--bc); }
.bento-card .ico { stroke: var(--bc); width: 30px; height: 30px; margin-bottom: 12px; }
.bento-card h4 { font-size: 18px; margin-bottom: 6px; }
.bento-card p { color: var(--text-70); font-size: 14px; }
.bento-card .big { font-size: clamp(28px, 5vw, 44px); font-weight: 900; color: var(--bc); line-height: 1; }
.bento-card.span2 { grid-column: span 2; }
.bento-card.row2 { grid-row: span 2; }
.bento-card .glow { position: absolute; right: -30px; bottom: -30px; width: 120px; height: 120px; border-radius: 50%; background: var(--bc); opacity: 0.14; filter: blur(30px); }
@media (max-width: 820px) { .bento { grid-template-columns: 1fr 1fr; grid-auto-rows: 140px; } .bento-card.span2 { grid-column: span 2; } .bento-card.row2 { grid-row: span 1; } }

/* ── Pricing tiers ── */
.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: stretch; }
.tier {
  border-radius: var(--radius); padding: 28px 24px; border: 1px solid var(--border);
  background: var(--card); backdrop-filter: blur(8px); display: flex; flex-direction: column;
  transition: transform 0.25s, border-color 0.25s; --tc: var(--cyan);
}
.tier:hover { transform: translateY(-6px); border-color: var(--tc); }
.tier.featured { border-color: var(--gold); box-shadow: 0 20px 60px -20px var(--gold); }
.tier .badge { align-self: flex-start; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: #06060e; background: var(--tc); padding: 4px 10px; border-radius: 20px; margin-bottom: 14px; }
.tier h3 { font-size: 20px; margin-bottom: 8px; color: var(--tc); }
.tier .price { font-size: clamp(26px, 4vw, 34px); font-weight: 900; margin-bottom: 4px; }
.tier .per { color: var(--text-45); font-size: 13px; margin-bottom: 18px; }
.tier ul { list-style: none; display: grid; gap: 9px; margin-bottom: 22px; }
.tier li { position: relative; padding-left: 24px; color: var(--text-70); font-size: 14px; }
.tier li::before { content: ""; position: absolute; left: 0; top: 6px; width: 12px; height: 7px; border-left: 2px solid var(--tc); border-bottom: 2px solid var(--tc); transform: rotate(-45deg); }
.tier .tier-cta { margin-top: auto; text-align: center; padding: 12px; border-radius: 26px; font-weight: 700; border: 1px solid var(--tc); color: var(--tc); }
.tier.featured .tier-cta { background: var(--gold); color: #06060e; border-color: var(--gold); }
@media (max-width: 820px) { .tiers { grid-template-columns: 1fr; } }

/* ── Interactive calculator ── */
.calc {
  max-width: 760px; margin: 0 auto; background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 30px; backdrop-filter: blur(8px);
}
.calc-row { margin-bottom: 22px; }
.calc-row .row-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
.calc-row label { color: var(--text-70); font-size: 14px; font-weight: 600; }
.calc-row .val { color: var(--cyan); font-weight: 800; font-size: 18px; }
.calc input[type="range"] {
  -webkit-appearance: none; appearance: none; width: 100%; height: 6px; border-radius: 5px;
  background: linear-gradient(90deg, var(--cyan), rgba(255,255,255,0.08)); outline: none;
}
.calc input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%;
  background: var(--cyan); cursor: pointer; box-shadow: 0 0 12px var(--cyan); border: 2px solid #06060e;
}
.calc input[type="range"]::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%; background: var(--cyan); cursor: pointer;
  box-shadow: 0 0 12px var(--cyan); border: 2px solid #06060e;
}
.calc-results { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin-top: 26px; }
.calc-card { border-radius: 14px; padding: 18px; text-align: center; border: 1px solid var(--rc, var(--cyan)); background: color-mix(in srgb, var(--rc, var(--cyan)) 10%, transparent); }
.calc-card .cn { font-size: clamp(22px, 4vw, 30px); font-weight: 900; color: var(--rc, var(--cyan)); line-height: 1; }
.calc-card .cl { font-size: 12px; color: var(--text-70); margin-top: 8px; }
.calc-note { text-align: center; color: var(--text-45); font-size: 12px; margin-top: 18px; }

/* ── FAQ ── */
.faq { max-width: 760px; margin: 0 auto; }
.faq-search {
  width: 100%; padding: 14px 18px; border-radius: 14px; margin-bottom: 22px;
  background: var(--card); border: 1px solid var(--border); color: var(--text); font: inherit; font-size: 15px;
}
.faq-search:focus { outline: none; border-color: var(--cyan); }
.faq-item { border: 1px solid var(--border); border-radius: 14px; margin-bottom: 12px; overflow: hidden; background: rgba(255,255,255,0.02); }
.faq-q {
  width: 100%; text-align: left; background: none; border: 0; color: var(--text); font: inherit;
  font-size: 16px; font-weight: 700; padding: 18px 20px; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
}
.faq-q::after { content: "+"; color: var(--cyan); font-size: 22px; font-weight: 400; transition: transform 0.25s; }
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; color: var(--text-70); font-size: 15px; }
.faq-a > div { padding: 0 20px 18px; }
.faq-item.open .faq-a { max-height: 320px; }

/* ── Final CTA ── */
.final-cta { text-align: center; padding: 90px 0; }
.final-cta h2 { font-size: clamp(28px, 5vw, 44px); font-weight: 900; margin-bottom: 18px; }

/* ── Footer ── */
.footer { border-top: 1px solid var(--border); padding: 50px 0 34px; color: var(--text-45); font-size: 14px; }
.footer-cols { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 30px; margin-bottom: 36px; }
.footer-brand .brand { font-size: 22px; font-weight: 800; }
.footer-brand p { color: var(--text-45); font-size: 13px; margin-top: 10px; max-width: 260px; }
.footer-col h4 { font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: var(--text-45); margin-bottom: 14px; }
.footer-col a { display: block; color: var(--text-70); margin: 0 0 9px; font-size: 14px; }
.footer-col a:hover { color: var(--cyan); text-decoration: none; }
.footer-bottom { border-top: 1px solid var(--border); padding-top: 22px; text-align: center; }
@media (max-width: 720px) { .footer-cols { grid-template-columns: 1fr 1fr; } }

/* ── Reveal animation ── */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.7s ease, transform 0.7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal.scale { transform: translateY(28px) scale(0.94); }
.reveal.scale.in { transform: none; }

/* ── SVG icons ── */
.svg-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.ico {
  width: 26px; height: 26px; stroke: var(--cyan); fill: none;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
  transition: transform 0.3s, filter 0.3s;
}
.icon-badge {
  width: 56px; height: 56px; border-radius: 15px; display: inline-flex;
  align-items: center; justify-content: center; margin-bottom: 16px;
  background: rgba(0, 220, 255, 0.1); border: 1px solid rgba(0, 220, 255, 0.3);
}
.feature:hover .ico { transform: scale(1.15) rotate(-6deg); filter: drop-shadow(0 0 8px var(--cyan)); }

/* ENDO atom: keep the symbol's own neon-green colours instead of the .ico stroke. */
.ico-endo { stroke: none !important; fill: none; }
/* Subtle 3D-spin: rotate around Y so the orbital ellipses read as a tumbling atom. */
@keyframes spin3d-rotate { 0% { transform: rotateY(0); } 100% { transform: rotateY(360deg); } }
.spin3d { transform-style: preserve-3d; animation: spin3d-rotate 7s linear infinite; }
.feature:hover .ico-endo, .feature:hover .spin3d { transform: rotateY(0) scale(1.1); filter: drop-shadow(0 0 14px #39ff14); }

/* ── Contextual chips floating around each showcase device ── */
.media { position: relative; }
.device-chip {
  position: absolute; display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 11px; border-radius: 13px; font-weight: 700; font-size: 12px;
  background: rgba(10, 10, 24, 0.85); border: 1px solid var(--accent, var(--cyan));
  color: #fff; backdrop-filter: blur(8px); white-space: nowrap; z-index: 2;
  box-shadow: 0 10px 24px -10px var(--accent, var(--cyan));
  animation: cardfloat 6.5s ease-in-out infinite;
}
.device-chip .ico { width: 14px; height: 14px; stroke: var(--accent, var(--cyan)); }
.device-chip .ico-endo { width: 18px; height: 18px; }
.device-chip.a { top: 12%; left: -5%; animation-delay: 0s; }
.device-chip.b { bottom: 18%; right: -4%; animation-delay: 1.4s; }
.showcase-row.reverse .device-chip.a { left: auto; right: -5%; }
.showcase-row.reverse .device-chip.b { right: auto; left: -4%; }
@media (max-width: 820px) { .device-chip.a { left: 2%; top: 5%; } .device-chip.b { right: 2%; bottom: 5%; left: auto; } .showcase-row.reverse .device-chip.a { right: auto; left: 2%; } .showcase-row.reverse .device-chip.b { left: auto; right: 2%; } }

/* ── Scroll progress bar ── */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 0;
  background: linear-gradient(90deg, var(--cyan), var(--green), var(--gold));
  z-index: 100; box-shadow: 0 0 12px var(--cyan); transition: width 0.1s linear;
}

/* ── Section tints for variety ── */
.tint-cyan { background: radial-gradient(700px 360px at 15% 0%, rgba(0, 220, 255, 0.07), transparent); }
.tint-purple { background: radial-gradient(700px 360px at 85% 0%, rgba(170, 68, 255, 0.08), transparent); }
.tint-green { background: radial-gradient(700px 360px at 50% 100%, rgba(57, 255, 20, 0.06), transparent); }

/* quick-feature badge colour variety */
.features .feature:nth-child(1) .icon-badge { background: rgba(0,220,255,.1); border-color: rgba(0,220,255,.35); }
.features .feature:nth-child(1) .ico { stroke: var(--cyan); }
.features .feature:nth-child(2) .icon-badge { background: rgba(255,68,170,.1); border-color: rgba(255,68,170,.35); }
.features .feature:nth-child(2) .ico { stroke: var(--pink); }
.features .feature:nth-child(3) .icon-badge { background: rgba(255,215,0,.1); border-color: rgba(255,215,0,.35); }
.features .feature:nth-child(3) .ico { stroke: var(--gold); }

/* ── Detailed showcase rows ── */
.showcase-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center;
  margin-bottom: 90px; --accent: var(--cyan);
}
.showcase-row.a2 { --accent: var(--green); }
.showcase-row.a3 { --accent: var(--gold); }
.showcase-row.a4 { --accent: var(--pink); }
.showcase-row.a5 { --accent: var(--purple); }
.showcase-row:last-child { margin-bottom: 0; }
.showcase-row.reverse .copy { order: 2; }
.showcase-row.reverse .media { order: 1; }
.showcase .eyebrow {
  display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--accent); margin-bottom: 14px;
}
.showcase .eyebrow .ico { width: 18px; height: 18px; stroke: var(--accent); }
.showcase h3 { font-size: clamp(22px, 3.4vw, 30px); font-weight: 800; margin-bottom: 14px; line-height: 1.2; }
.showcase .lead { color: var(--text-70); font-size: 16px; margin-bottom: 18px; }
.showcase ul.checks { list-style: none; display: grid; gap: 10px; }
.showcase ul.checks li { position: relative; padding-left: 28px; color: var(--text-70); font-size: 15px; }
.showcase ul.checks li::before {
  content: ""; position: absolute; left: 0; top: 7px; width: 14px; height: 8px;
  border-left: 2px solid var(--accent); border-bottom: 2px solid var(--accent);
  transform: rotate(-45deg);
}
.media { display: flex; justify-content: center; }

/* device used inside showcase (no infinite float — reveal + parallax instead) */
.device {
  position: relative; width: 260px; max-width: 72vw; aspect-ratio: 9 / 19.5;
  border-radius: 36px; padding: 11px; will-change: transform;
  background: linear-gradient(160deg, #1b1b33, #0a0a16);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.55), 0 0 60px -18px var(--accent, var(--cyan));
  transition: transform 0.35s cubic-bezier(.2,.7,.2,1), box-shadow 0.35s;
  transform-style: preserve-3d;
}
.media:hover .device {
  transform: perspective(1000px) rotateY(-7deg) rotateX(3deg) translateY(-4px);
  box-shadow: 0 36px 90px rgba(0, 0, 0, 0.6), 0 0 80px -10px var(--accent, var(--cyan));
}
.showcase-row.reverse .media:hover .device { transform: perspective(1000px) rotateY(7deg) rotateX(3deg) translateY(-4px); }
.device .screen { position: relative; width: 100%; height: 100%; border-radius: 26px; overflow: hidden; background: #0a0a16; display: flex; align-items: center; justify-content: center; }
.device .screen img, .device .screen video { width: 100%; height: 100%; object-fit: cover; }
.device .notch { position: absolute; top: 14px; left: 50%; transform: translateX(-50%); width: 84px; height: 20px; background: #0a0a16; border-radius: 0 0 13px 13px; z-index: 2; }
.device .ph-fallback { color: var(--text-45); font-size: 12px; text-align: center; padding: 18px; }

@media (max-width: 820px) {
  .showcase-row { grid-template-columns: 1fr; gap: 26px; text-align: center; margin-bottom: 64px; }
  .showcase-row.reverse .copy { order: 2; }
  .showcase-row.reverse .media { order: 1; }
  .showcase .eyebrow { justify-content: center; }
  .showcase ul.checks { display: inline-grid; text-align: left; }
}

/* ── i18n visibility ── */
[data-lang] { display: none; }
[data-lang].lang-active { display: block; }
span[data-lang].lang-active, a[data-lang].lang-active { display: inline; }

/* ── Responsive ── */
@media (max-width: 820px) {
  .hero-grid { grid-template-columns: 1fr; text-align: center; }
  .hero .sub { margin-left: auto; margin-right: auto; }
  .cta-row { justify-content: center; }
  .phone { margin-top: 30px; }
  .shot:nth-child(even) { margin-top: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .aurora::before, .aurora::after, .hero h1, .phone, .play-badge, .pill-row, .float-card { animation: none !important; }
}
