/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; background: #1e2438; }
body {
  font-family: 'DM Sans', sans-serif;
  background: transparent;
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
}
/* Old radial body atmosphere removed — replaced by animated mesh grid canvas (#mesh-bg) */
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
button { border: none; background: none; cursor: pointer; font-family: inherit; }
input, textarea, select { font-family: inherit; }
ul { list-style: none; }
::selection { background: rgba(59,130,246,.35); color: #fff; }

/* ════════════════════════════════
   Design System — Kuklev v2 (Bold Green)
════════════════════════════════ */
:root {
  --bg:           #1e2438;
  --bg2:          #232940;
  --bg3:          #2a3148;
  --bg-deep:      #131724;
  --surface:      rgba(255,255,255,.03);
  --surface2:     rgba(255,255,255,.06);

  --text:         #f5f5f5;
  --text-soft:    rgba(245,245,245,.82);
  --text-muted:   rgba(245,245,245,.55);
  --text-subtle:  rgba(245,245,245,.32);

  /* Purple Palette — Lavender / Purple / Violet */
  --o-50:  #eff6ff;
  --o-100: #dbeafe;
  --o-200: #bfdbfe;
  --o-300: #60a5fa;
  --o-400: #3b82f6;
  --o-500: #2563eb;
  --o-600: #1d4ed8;
  --y-300: #93c5fd;
  --y-400: #60a5fa;
  --y-500: #3b82f6;
  --a-300: #93c5fd;
  --r-400: #60a5fa;

  /* Greys — neutral edition */
  --g-100: #1a1a1f;
  --g-200: #232328;
  --g-300: #2e2e34;
  --g-400: #4a4a52;
  --g-500: #6e6e76;
  --g-600: #95959c;

  /* Acid block colors — solid Purple-on-Black blocks */
  --acid:        #bfdbfe;
  --acid-strong: #60a5fa;
  --ink:         #050608;

  /* Borders — neutral white-tint with purple subtle hint */
  --border:       rgba(255,255,255,.06);
  --border2:      rgba(255,255,255,.12);
  --border-glow:  rgba(147,197,253,.35);

  /* Gradients */
  --grad-1: linear-gradient(90deg, #bfdbfe 0%, #60a5fa 50%, #93c5fd 100%);
  --grad-2: linear-gradient(90deg, #93c5fd 0%, #3b82f6 50%, #2563eb 100%);
  --grad-btn: linear-gradient(90deg, #3b82f6 0%, #93c5fd 100%);
  --grad-btn-h: linear-gradient(90deg, #2563eb 0%, #60a5fa 100%);
  --grad-acid: linear-gradient(90deg, #dbeafe 0%, #93c5fd 100%);

  /* Display + Mono fonts */
  --font-display: 'Anton', 'Bricolage Grotesque', sans-serif;
  --font-headline: 'Bricolage Grotesque', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --mw:           1280px;
  --py:           120px;
  --py-sm:        80px;
  --r:            16px;
  --r-sm:         10px;
  --r-lg:         24px;
  --r-xl:         32px;
  --r-pill:       100px;
  --ease:         .25s cubic-bezier(.4,0,.2,1);
  --spring:       .55s cubic-bezier(.34,1.56,.64,1);

  /* Z-layers */
  --z-mesh:       -10;
  --z-progress:   1100;
  --z-nav:        1000;
  --z-mob-bar:    1050;
}

.container { max-width: var(--mw); margin: 0 auto; padding: 0 48px; }
section { padding: var(--py) 0; position: relative; }

/* Section atmosphere — warm radial accents on dark sections */
.section-atmosphere {
  position: relative;
  isolation: isolate;
}
.section-atmosphere::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 80% 0%, rgba(96,165,250,.08), transparent 60%),
    radial-gradient(50% 60% at 0% 100%, rgba(96,165,250,.06), transparent 60%);
  pointer-events: none;
  z-index: -1;
}

/* ════════════════════════════════
   Utility — Gradient Text
════════════════════════════════ */
.grad-text {
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.grad-text-2 {
  background: var(--grad-2);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.grad-text-anim {
  background-size: 200% 200%;
  animation: grad-shift 6s ease infinite;
}
@keyframes grad-shift {
  0%,100% { background-position: 0% 50%; }
  50%     { background-position: 100% 50%; }
}

/* ════════════════════════════════
   Buttons
════════════════════════════════ */
.btn-grad {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--grad-btn);
  background-size: 200% 100%;
  color: #0a0c12;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 14px; font-weight: 700;
  padding: 13px 24px; border-radius: var(--r-pill);
  transition: background-position .4s ease, transform var(--ease), box-shadow var(--ease);
  white-space: nowrap;
}
.btn-grad:hover {
  background-position: 100% 0;
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(59,130,246,.35);
}
.btn-grad svg { flex-shrink: 0; }
.btn-lg { font-size: 15px; padding: 16px 30px; }

.btn-glass {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(59,130,246,.08);
  border: 1px solid rgba(147,197,253,.25);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--o-100);
  font-size: 14px; font-weight: 600;
  padding: 13px 22px; border-radius: var(--r-pill);
  transition: all var(--ease);
  white-space: nowrap;
}
.btn-glass:hover {
  background: rgba(59,130,246,.15);
  border-color: rgba(147,197,253,.45);
  transform: translateY(-2px);
}

/* ════════════════════════════════
   Section Heads
════════════════════════════════ */
.sec-head { margin-bottom: 72px; max-width: 720px; }
.sec-lbl {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: var(--r-pill);
  background: rgba(96,165,250,.1);
  border: 1px solid rgba(147,197,253,.22);
  font-size: 11px; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--o-200);
  margin-bottom: 24px;
}
.sec-lbl::before {
  content: '✦'; color: var(--o-300);
}
.sec-title {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(40px, 5.5vw, 72px); font-weight: 700;
  line-height: 1.02; letter-spacing: -.02em;
  margin-bottom: 22px;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.sec-sub { font-size: 17px; color: var(--text-muted); line-height: 1.65; max-width: 580px; }

/* ════════════════════════════════
   Nav
════════════════════════════════ */
nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 0 48px;
  transition: background var(--ease), border-color var(--ease), box-shadow var(--ease);
}
nav.scrolled {
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(147,197,253,.08), 0 12px 40px rgba(0,0,0,.6);
}
.nav-inner {
  max-width: var(--mw); margin: 0 auto;
  display: flex; align-items: center; gap: 32px;
  height: 70px;
}
.nav-brand {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 16px;
  flex-shrink: 0;
}
.nav-logo {
  width: 32px; height: 32px;
  background: var(--grad-btn);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 1px rgba(147,197,253,.3), 0 8px 24px rgba(59,130,246,.3);
}
.nav-logo span {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 14px; color: #0a0c12;
  line-height: 1;
}
.nav-name { color: var(--text); }
.nav-links {
  display: flex; align-items: center; gap: 32px;
  margin-left: 16px;
}
.nav-links a {
  font-size: 13.5px; font-weight: 500;
  color: var(--text-muted);
  transition: color var(--ease);
  position: relative;
}
.nav-links a::after {
  content: '';
  position: absolute; left: 0; right: 100%; bottom: -6px;
  height: 1px; background: var(--grad-1);
  transition: right var(--ease);
}
.nav-links a:hover { color: var(--text); }
.nav-links a:hover::after { right: 0; }
.nav-right {
  display: flex; align-items: center; gap: 12px;
  margin-left: auto;
}
.lang-sw {
  display: flex; align-items: center; gap: 2px;
  padding: 3px;
  background: rgba(96,165,250,.06);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
}
.lang-btn {
  font-size: 10.5px; font-weight: 700; padding: 5px 11px;
  border-radius: var(--r-pill); color: var(--text-subtle);
  transition: all var(--ease); letter-spacing: .05em;
  cursor: pointer;
}
.lang-btn.active { background: var(--grad-btn); color: #0a0c12; }
.lang-btn:hover:not(.active) { color: var(--text-soft); }
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  padding: 8px; margin-left: 4px;
}
.hamburger span {
  display: block; width: 22px; height: 1.5px;
  background: var(--text); border-radius: 2px;
  transition: all .3s;
}

/* ════════════════════════════════
   Mobile Menu
════════════════════════════════ */
.mob-menu {
  position: fixed; inset: 0 0 0 30%; z-index: 2000;
  background: linear-gradient(180deg, #050608 0%, #000 100%);
  display: flex; flex-direction: column;
  padding: 0 0 40px;
  transform: translateX(100%);
  transition: transform .42s cubic-bezier(.4,0,.2,1);
  border-left: 1px solid var(--border2);
}
.mob-menu.open { transform: translateX(0); }
.mob-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 28px; border-bottom: 1px solid var(--border);
}
.mob-close {
  font-size: 18px; color: var(--text-muted);
  width: 36px; height: 36px; display: flex;
  align-items: center; justify-content: center;
  border-radius: 8px; transition: all var(--ease);
}
.mob-close:hover { background: var(--surface2); color: var(--text); }
.mob-links { display: flex; flex-direction: column; gap: 4px; padding: 24px 20px; flex: 1; }
.mob-links a {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 22px; font-weight: 700; color: var(--text-soft);
  padding: 12px 14px; border-radius: var(--r-sm);
  transition: all var(--ease); display: block;
}
.mob-links a:hover { color: var(--o-300); background: var(--surface); }
.mob-foot {
  padding: 0 28px;
  display: flex; flex-direction: column; gap: 16px;
}
.mob-overlay {
  position: fixed; inset: 0; z-index: 1999;
  background: rgba(0,0,0,.7); backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity .42s;
}
.mob-overlay.active { opacity: 1; pointer-events: auto; }

/* ════════════════════════════════
   HERO
════════════════════════════════ */
/* ════════════════════════════════
   HERO V2 — Edel · Massive Display · Cursor Glow · Distort
════════════════════════════════ */
.hero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  background: transparent;
  display: flex; flex-direction: column; justify-content: flex-end;
  isolation: isolate;
}
.hero-vignette {
  position: absolute; inset: 0; z-index: 1;
  background:
    radial-gradient(70% 55% at 50% 45%, transparent 20%, rgba(5,5,7,.45) 75%, rgba(5,5,7,.85) 100%),
    linear-gradient(180deg, rgba(5,5,7,.55) 0%, transparent 22%, transparent 70%, rgba(5,5,7,.85) 100%);
  pointer-events: none;
}
/* Cursor-tracking purple glow (only desktop, JS sets --x/--y) */
.hero-cursor-glow {
  position: absolute;
  top: 0; left: 0;
  width: 700px; height: 700px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(circle, rgba(96,165,250,.18) 0%, rgba(59,130,246,.08) 30%, transparent 65%);
  transform: translate3d(-50%, -50%, 0) translate3d(var(--x, 50vw), var(--y, 50vh), 0);
  mix-blend-mode: screen;
  opacity: 0;
  transition: opacity .6s ease;
  filter: blur(8px);
}
.hero:hover .hero-cursor-glow,
.hero.has-cursor .hero-cursor-glow { opacity: 1; }
@media (max-width: 1024px), (pointer: coarse) {
  .hero-cursor-glow { display: none; }
}

.hero .container {
  position: relative; z-index: 2;
  display: flex; flex-direction: column;
  justify-content: flex-end;
  min-height: 100svh;
  padding-top: 140px;
}
.hero-content {
  flex: 1;
  display: flex; flex-direction: column; justify-content: center;
  padding-bottom: 56px;
  text-align: center;
  align-items: center;
}

/* ── Meta: Mono tag + dot + location, replaces old badge ── */
.hero-meta {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 40px;
  font-size: 11.5px;
  letter-spacing: .08em;
  color: var(--text-soft);
}
.hero-meta-tag {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px;
  border: 1px solid var(--border2);
  border-radius: 999px;
  background: rgba(255,255,255,.025);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  text-transform: uppercase;
  font-weight: 600;
}
.hero-meta-loc {
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 500;
}
.hero-meta-sep {
  width: 24px; height: 1px;
  background: var(--border2);
}
.hero-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--acid-strong);
  box-shadow: 0 0 10px var(--acid-strong), 0 0 0 2px rgba(96,165,250,.18);
  animation: pulse-dot 2.5s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .55; transform: scale(.85); }
}
@media (max-width: 640px) {
  .hero-meta { gap: 10px; flex-wrap: wrap; justify-content: center; }
  .hero-meta-sep { display: none; }
}

/* ── Massive display headline ── */
.hero-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(72px, 14vw, 220px);
  line-height: .92;
  letter-spacing: -.012em;
  text-transform: uppercase;
  display: flex; flex-direction: column;
  margin-bottom: 36px;
  transition: text-shadow .6s ease;
}
.ht-line { display: block; padding: 0 .04em; transition: text-shadow .6s ease, filter .6s ease; white-space: nowrap; }
.ht-line.l1 {
  color: #ffffff;
  text-shadow: 0 4px 30px rgba(255,255,255,.05);
}
.ht-line.l2 {
  color: transparent;
  background: linear-gradient(180deg, #93c5fd 0%, #3b82f6 65%, #1d4ed8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 6px 24px rgba(59,130,246,.25));
}
/* Permanent state after scramble — adds glow + slight luminosity */
.ht-line.l1.is-scrambled {
  text-shadow:
    0 0 1px rgba(255,255,255,.6),
    0 0 24px rgba(255,255,255,.18),
    0 6px 50px rgba(147,197,253,.20);
}
.ht-line.l2.is-scrambled {
  filter: drop-shadow(0 0 1px rgba(96,165,250,.5))
          drop-shadow(0 8px 36px rgba(59,130,246,.55));
}
/* Punch flash on lock-in — subtle one-shot glow burst */
.ht-line.is-scrambled {
  animation: scramble-punch .55s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes scramble-punch {
  0%   { transform: scale(1.00); }
  35%  { transform: scale(1.018); }
  100% { transform: scale(1.00); }
}
@media (prefers-reduced-motion: reduce) {
  .ht-line.is-scrambled { animation: none; }
}

/* ── Sub ── */
.hero-sub {
  font-family: var(--font-body);
  font-size: clamp(15px, 1.25vw, 18px);
  line-height: 1.6;
  color: var(--text-soft);
  max-width: 600px;
  margin: 0 auto 40px;
  font-weight: 400;
}

/* ── Actions ── */
.hero-actions {
  display: flex; align-items: center; gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Stats: ticker-style, no boxes, mono labels ── */
.hero-stats-bar {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 36px 0 32px;
  border-top: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.012), rgba(0,0,0,.25));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.hs-item {
  display: flex; flex-direction: column;
  align-items: center;
  padding: 0 24px;
  position: relative;
  text-align: center;
  gap: 8px;
}
.hs-item:not(:last-child)::after {
  content: '';
  position: absolute; right: 0; top: 50%;
  transform: translateY(-50%);
  width: 1px; height: 70%;
  background: var(--border);
}
.hs-num {
  font-size: clamp(42px, 4vw, 64px);
  font-weight: 400;
  line-height: 1;
  color: #ffffff;
  letter-spacing: 0;
  text-transform: uppercase;
}
.hs-lbl {
  font-size: 10.5px; font-weight: 500;
  color: var(--text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* ════════════════════════════════
   MARQUEE V2 — thin mono strip, hard borders
════════════════════════════════ */
.mq-wrap {
  overflow: hidden;
  background: rgba(5,5,7,.45);
  border-top: 1px solid var(--border2);
  border-bottom: 1px solid var(--border2);
  padding: 12px 0;
  position: relative;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.mq-wrap::before, .mq-wrap::after {
  content: ''; position: absolute; top: 0; bottom: 0; width: 140px;
  z-index: 2; pointer-events: none;
}
.mq-wrap::before { left: 0; background: linear-gradient(90deg, rgba(5,5,7,.95), transparent); }
.mq-wrap::after  { right: 0; background: linear-gradient(-90deg, rgba(5,5,7,.95), transparent); }
.mq-track {
  display: flex;
  animation: mq-scroll 38s linear infinite;
  width: max-content;
}
@keyframes mq-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.mq-track:hover { animation-play-state: paused; }
.mq-item {
  display: flex; align-items: center; gap: 18px;
  padding: 0 22px;
  font-family: var(--font-mono);
  font-size: 12px; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  white-space: nowrap;
  color: var(--text-soft);
  -webkit-text-fill-color: var(--text-soft);
}
.mdot {
  color: var(--acid-strong);
  -webkit-text-fill-color: var(--acid-strong);
  font-size: 9px;
  filter: drop-shadow(0 0 4px rgba(96,165,250,.5));
}

/* ════════════════════════════════
   Section: Atmosphere wrapper for content sections
════════════════════════════════ */
section#leistungen, section#prozess, section#portfolio,
section#pakete, section#ueber-uns,
section#kontakt, footer {
  background: transparent;
  position: relative;
  isolation: isolate;
}
section#leistungen::before, section#portfolio::before,
section#kontakt::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 40% at 80% 10%, rgba(96,165,250,.07), transparent 60%),
    radial-gradient(50% 50% at 10% 90%, rgba(96,165,250,.05), transparent 60%);
  pointer-events: none;
  z-index: -1;
}

/* ════════════════════════════════
   LEISTUNGEN — Tab System (Session 3)
════════════════════════════════ */
.lt-shell {
  display: grid;
  grid-template-columns: minmax(360px, 0.95fr) 1.4fr;
  gap: 28px;
  align-items: stretch;
}

/* ── Tab list (left) ── */
.lt-tabs {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 0 14px 28px;
  border-left: none;
}
.lt-tab-rail {
  position: absolute;
  left: 0; top: 14px; bottom: 14px;
  width: 1px;
  background: var(--border);
  pointer-events: none;
}
.lt-tab-indicator {
  position: absolute;
  left: -1px;
  width: 3px;
  height: 0;
  background: var(--acid-strong);
  box-shadow: 0 0 16px rgba(96,165,250,.55), 0 0 32px rgba(96,165,250,.25);
  border-radius: 2px;
  transition: top .55s cubic-bezier(.34,1.56,.64,1), height .45s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
}
.lt-tab {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 22px;
  align-items: center;
  padding: 22px 24px 22px 4px;
  border: 1px solid transparent;
  border-radius: var(--r);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: color .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease), padding-left .4s cubic-bezier(.34,1.56,.64,1);
  overflow: hidden;
  isolation: isolate;
}
.lt-tab::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(96,165,250,.10) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .35s var(--ease);
  z-index: -1;
}
.lt-tab:hover {
  color: var(--text);
  padding-left: 12px;
}
.lt-tab:hover::before { opacity: 1; }
.lt-tab:hover .lt-tab-arrow { transform: translateX(4px); opacity: 1; }
.lt-tab.is-active {
  color: var(--text);
  background: rgba(96,165,250,.05);
  border-color: rgba(147,197,253,.18);
  padding-left: 16px;
}
.lt-tab.is-active::before { opacity: 1; }

.lt-tab-num {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: rgba(255,255,255,.10);
  -webkit-text-stroke: 1px rgba(147,197,253,.28);
  transition: color .4s var(--ease), -webkit-text-stroke-color .4s var(--ease);
  min-width: 70px;
}
.lt-tab.is-active .lt-tab-num {
  color: var(--acid-strong);
  -webkit-text-stroke: 1px transparent;
}
.lt-tab-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.lt-tab-name {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 1.05;
  color: inherit;
}
.lt-tab-hint {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.lt-tab.is-active .lt-tab-hint { color: rgba(147,197,253,.7); }
.lt-tab-arrow {
  font-family: var(--font-mono);
  font-size: 18px;
  color: var(--acid-strong);
  opacity: 0.35;
  transition: transform .35s var(--ease), opacity .35s var(--ease);
}
.lt-tab.is-active .lt-tab-arrow {
  opacity: 1;
  transform: translateX(2px);
}

/* ── Preview panel (right) ── */
.lt-preview {
  position: relative;
  background:
    linear-gradient(135deg, rgba(96,165,250,.04) 0%, rgba(255,255,255,.02) 100%),
    rgba(8,10,18,.45);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  padding: 44px 44px 36px;
  overflow: hidden;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  min-height: 560px;
}
.lt-preview::before {
  content: '';
  position: absolute;
  top: -40%; right: -20%;
  width: 80%; height: 100%;
  background: radial-gradient(closest-side, rgba(96,165,250,.18), transparent 70%);
  pointer-events: none;
  filter: blur(10px);
}
.lt-preview::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(147,197,253,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(147,197,253,.04) 1px, transparent 1px);
  background-size: 32px 32px;
  background-position: -1px -1px;
  pointer-events: none;
  mask-image: radial-gradient(closest-side at 100% 0%, #000 30%, transparent 70%);
}

.lt-panel {
  position: absolute;
  inset: 44px 44px 36px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
  transition: none;
}
.lt-panel.is-active {
  position: relative;
  inset: auto;
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

.lt-panel-head {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.lt-panel-tag {
  color: var(--acid-strong);
  background: rgba(96,165,250,.08);
  border: 1px solid rgba(147,197,253,.24);
  padding: 5px 10px;
  border-radius: 4px;
  font-weight: 600;
}
.lt-panel-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--acid-strong);
  box-shadow: 0 0 10px rgba(96,165,250,.7);
  animation: lt-pulse 2.4s ease-in-out infinite;
}
@keyframes lt-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}
.lt-panel-time { color: var(--text-muted); }

.lt-panel-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--text);
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.lt-panel-desc {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--text-soft);
  max-width: 56ch;
}

.lt-feats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 24px;
  margin-top: 4px;
}
.lt-feats li {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 14.5px;
  color: var(--text-soft);
  padding: 10px 0;
  border-top: 1px solid var(--border);
}
.lt-feat-tag {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--acid-strong);
  flex-shrink: 0;
}

.lt-panel-foot {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 24px;
  margin-top: auto;
  padding-top: 24px;
}
.lt-panel-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--acid-strong);
  border-radius: var(--r-pill);
  width: fit-content;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease);
  box-shadow: 0 6px 24px rgba(96,165,250,.2);
}
.lt-panel-cta:hover {
  transform: translateY(-2px);
  background: var(--y-300);
  box-shadow: 0 10px 32px rgba(96,165,250,.4);
}

/* ── Mock visuals ── */
.lt-mock {
  position: relative;
  width: 220px;
  height: 140px;
  border: 1px solid var(--border2);
  border-radius: 8px;
  background: rgba(5,6,8,.6);
  overflow: hidden;
  flex-shrink: 0;
}
.lt-mock-bar {
  display: flex; gap: 4px;
  padding: 8px 10px;
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid var(--border);
}
.lt-mock-bar i {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,.18);
}
.lt-mock-body { padding: 14px; display: flex; flex-direction: column; gap: 6px; }
.lt-mock-h {
  height: 8px; width: 70%;
  background: var(--grad-1);
  border-radius: 2px;
}
.lt-mock-l {
  height: 4px;
  background: rgba(255,255,255,.18);
  border-radius: 2px;
}
.lt-mock-l.dim { background: rgba(255,255,255,.07); }
.lt-mock-l.w-40 { width: 40%; }
.lt-mock-l.w-50 { width: 50%; }
.lt-mock-l.w-60 { width: 60%; }
.lt-mock-l.w-70 { width: 70%; }
.lt-mock-row { display: flex; gap: 6px; margin-top: 6px; }
.lt-mock-block {
  flex: 1; height: 36px;
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(96,165,250,.18), rgba(147,197,253,.06));
  border: 1px solid rgba(147,197,253,.18);
}
.lt-mock-block.sm { height: 24px; }

/* Mock 02 — Split before/after */
.lt-mock-split {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  height: 100%;
}
.lt-mock-side {
  padding: 14px;
  display: flex; flex-direction: column; gap: 5px;
}
.lt-mock-side .lt-mock-label {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.12em;
  color: var(--text-subtle);
  margin-bottom: 4px;
}
.lt-side-after .lt-mock-label { color: var(--acid-strong); }
.lt-mock-divider {
  background: linear-gradient(180deg, transparent, var(--border2) 30%, var(--border2) 70%, transparent);
}

/* Mock 03 — Conversion funnel */
.lt-mock-funnel {
  padding: 14px;
  display: flex; flex-direction: column; gap: 6px;
  height: 100%;
}
.lt-funnel-head {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 4px;
}
.lt-funnel-pulse {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--acid-strong);
  box-shadow: 0 0 8px var(--acid-strong);
  animation: lt-pulse 1.6s ease-in-out infinite;
}
.lt-funnel-eyebrow {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.14em;
  color: var(--acid-strong);
}
.lt-funnel-h {
  height: 10px; width: 80%;
  background: var(--grad-1);
  border-radius: 2px;
}
.lt-funnel-l {
  height: 4px; width: 60%;
  background: rgba(255,255,255,.2);
  border-radius: 2px;
}
.lt-funnel-cta {
  margin-top: 6px;
  padding: 8px 12px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: fit-content;
  min-width: 80px;
}
.lt-funnel-arrow { font-size: 12px; }
.lt-funnel-stats {
  margin-top: auto;
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}
.lt-funnel-stats span:first-child {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--acid-strong);
  letter-spacing: -0.02em;
}
.lt-funnel-stats span:last-child {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.12em;
  color: var(--text-subtle);
}

/* ── Mock 04 — Tool-Dashboard ── */
.lt-mock-4 {
  background:
    linear-gradient(180deg, rgba(96,165,250,.04) 0%, transparent 60%),
    rgba(8,11,20,.65);
  padding: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-md);
  border: 1px solid rgba(96,165,250,.12);
}
.lt-tool-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px 18px;
  background: rgba(15,20,32,.85);
  border: 1px solid rgba(96,165,250,.18);
  border-radius: var(--r-sm);
  box-shadow: 0 0 0 1px rgba(96,165,250,.05) inset, 0 12px 32px rgba(0,0,0,.4);
}
.lt-tool-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(96,165,250,.08);
}
.lt-tool-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  color: var(--acid-strong);
}
.lt-tool-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .16em;
  color: #6ee7b7;
}
.lt-tool-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #6ee7b7;
  box-shadow: 0 0 8px rgba(110,231,183,.7);
  animation: ltToolPulse 1.6s ease-in-out infinite;
}
@keyframes ltToolPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .55; transform: scale(.85); }
}

.lt-tool-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}
.lt-tool-cell {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(96,165,250,.03);
  border: 1px solid rgba(96,165,250,.08);
  transition: background var(--ease);
}
.lt-tool-cell.is-booked {
  background: rgba(96,165,250,.14);
  border-color: rgba(96,165,250,.45);
}
.lt-tool-cell.is-blocked {
  background: rgba(248,113,113,.08);
  border-color: rgba(248,113,113,.25);
}
.lt-tool-time {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .04em;
}
.lt-tool-cell.is-booked .lt-tool-time { color: var(--acid-strong); }
.lt-tool-cell.is-blocked .lt-tool-time { color: #f87171; }
.lt-tool-lbl {
  font-size: 10px;
  color: var(--text-subtle);
  letter-spacing: .02em;
}
.lt-tool-cell.is-booked .lt-tool-lbl { color: var(--text-muted); }

.lt-tool-foot {
  display: flex;
  gap: 16px;
  padding-top: 10px;
  border-top: 1px solid rgba(96,165,250,.08);
}
.lt-tool-stat {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .12em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.lt-tool-stat b {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 400;
  color: var(--acid-strong);
  letter-spacing: -0.02em;
  margin-right: 4px;
}

@media (prefers-reduced-motion: reduce) {
  .lt-tab-indicator { transition: none; }
  .lt-panel-dot, .lt-funnel-pulse, .lt-tool-dot { animation: none; }
}

/* ════════════════════════════════
   PROZESS — Pinned Scroll-Story (Session 3.2 v2)
════════════════════════════════ */
.ps-shell {
  position: relative;
}

/* ── Top Stepper ── */
.ps-stepper {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  margin-bottom: 48px;
  padding: 0 12px;
}
.ps-stepper-track {
  position: absolute;
  left: 12%;
  right: 12%;
  top: 26px;
  height: 1px;
  background: var(--border);
}
.ps-stepper-fill {
  position: absolute;
  left: 12%;
  top: 26px;
  height: 1px;
  width: 0;
  background: linear-gradient(90deg, var(--acid-strong) 0%, rgba(147,197,253,.4) 100%);
  box-shadow: 0 0 12px rgba(96,165,250,.6);
  transition: width .65s cubic-bezier(.4,0,.2,1);
}
.ps-stepper-dot {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: inherit;
  z-index: 1;
}
.ps-stepper-dot .ps-dot-num {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--text-soft);
  transition: color .4s var(--ease), background .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease);
}
.ps-stepper-dot .ps-dot-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-soft);
  transition: color .4s var(--ease);
}
.ps-stepper-dot:hover .ps-dot-num { border-color: rgba(147,197,253,.4); color: #ffffff; }
.ps-stepper-dot:hover .ps-dot-label { color: #ffffff; }
.ps-stepper-dot.is-active .ps-dot-num {
  background: var(--acid-strong);
  border-color: var(--acid-strong);
  box-shadow: 0 0 0 5px rgba(96,165,250,.12), 0 0 24px rgba(96,165,250,.45);
  transform: scale(1.06);
  color: var(--ink);
}
.ps-stepper-dot.is-active .ps-dot-label { color: var(--acid-strong); }

/* ── Stage ── */
.ps-stage {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
  min-height: 480px;
}

/* ── Big watermark number ── */
.ps-bignum-wrap {
  position: absolute;
  top: 50%;
  left: -40px;
  transform: translateY(-50%);
  pointer-events: none;
  user-select: none;
  z-index: 0;
  width: 100%;
  height: 100%;
}
.ps-bignum {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  font-family: var(--font-display);
  font-size: clamp(280px, 32vw, 480px);
  font-weight: 400;
  line-height: 0.78;
  letter-spacing: -0.05em;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(96,165,250,.18);
  opacity: 0;
  transition: opacity .6s var(--ease);
  white-space: nowrap;
}
.ps-bignum.is-active { opacity: 1; }

/* ── Content (left column) ── */
.ps-content {
  position: relative;
  z-index: 1;
  min-height: 420px;
}
.ps-steps {
  position: relative;
  min-height: 420px;
}
.ps-step {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
  transition: opacity .45s var(--ease), transform .45s var(--ease);
}
.ps-step.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.ps-step-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.ps-step-tag {
  color: var(--acid-strong);
  font-weight: 700;
}
.ps-step-name {
  font-family: var(--font-display);
  font-size: clamp(36px, 4.4vw, 64px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.ps-step-desc {
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-soft);
  max-width: 52ch;
}
.ps-step-feats {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 8px;
}
.ps-step-feats li {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--border);
  font-size: 14.5px;
  color: var(--text-soft);
}
.ps-step-feats li:last-child { border-bottom: 1px solid var(--border); }
.ps-feat-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--acid-strong);
  flex-shrink: 0;
  width: 16px;
}

/* ── Visuals (right column) ── */
.ps-visuals {
  position: relative;
  z-index: 1;
  width: 100%;
  aspect-ratio: 4 / 3;
  max-height: 460px;
}
.ps-visual {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(20px) scale(0.97);
  pointer-events: none;
  transition: opacity .45s var(--ease), transform .55s cubic-bezier(.34,1.56,.64,1);
}
.ps-visual.is-active {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.ps-vis-card {
  position: relative;
  width: 100%;
  height: 100%;
  background:
    linear-gradient(135deg, rgba(96,165,250,.06) 0%, rgba(255,255,255,.02) 100%),
    rgba(8,10,18,.5);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  padding: 28px;
  overflow: hidden;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  color: var(--acid-strong);
}
.ps-vis-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(147,197,253,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(147,197,253,.05) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
  mask-image: radial-gradient(closest-side at 100% 0%, #000 30%, transparent 75%);
}
.ps-vis-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.ps-vis-eyebrow { color: var(--acid-strong); font-weight: 700; }
.ps-vis-pulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--acid-strong);
  box-shadow: 0 0 12px var(--acid-strong);
  animation: ps-pulse 1.6s ease-in-out infinite;
}
.ps-vis-tag {
  padding: 3px 8px;
  background: rgba(96,165,250,.1);
  border: 1px solid rgba(147,197,253,.2);
  border-radius: 3px;
  color: var(--acid-strong);
}
@keyframes ps-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}

/* ── Shared visual footer ── */
.ps-vis-foot {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  font-size: 13px;
  color: var(--text-soft);
}
.ps-foot-arrow {
  font-family: var(--font-mono);
  color: var(--acid-strong);
  font-weight: 700;
}

/* ── Visual 01 — Strategy Board (2x2 grid of decisions) ── */
.ps-strat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  flex: 1;
}
.ps-strat-cell {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 8px;
  padding: 14px 14px 12px;
  border: 1px solid var(--border2);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(96,165,250,.04), transparent 70%),
    rgba(8,10,18,.4);
  overflow: hidden;
  transition: border-color var(--ease), background var(--ease);
}
.ps-strat-cell::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 24px; height: 1px;
  background: var(--acid-strong);
  box-shadow: 0 0 8px rgba(96,165,250,.6);
}
.ps-strat-key {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--acid-strong);
  font-weight: 700;
}
.ps-strat-val {
  font-family: var(--font-display);
  font-size: 16px;
  letter-spacing: -0.005em;
  line-height: 1.15;
  color: var(--text);
}

/* ── Visual 02 — Browser Mockup (Design Production) ── */
.ps-browser {
  flex: 1;
  display: flex;
  flex-direction: column;
  border-radius: 10px;
  border: 1px solid var(--border2);
  background: rgba(5,6,8,.7);
  overflow: hidden;
  min-height: 0;
}
.ps-browser-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  background: rgba(255,255,255,.04);
  border-bottom: 1px solid var(--border);
}
.ps-browser-dots { display: flex; gap: 5px; }
.ps-browser-dots i {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
}
.ps-browser-url {
  flex: 1;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: var(--text-subtle);
  background: rgba(255,255,255,.04);
  border-radius: 4px;
  padding: 3px 10px;
}
.ps-browser-canvas {
  flex: 1;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 0;
}
.ps-bw-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.ps-bw-logo {
  width: 22px; height: 8px;
  background: var(--grad-1);
  border-radius: 2px;
}
.ps-bw-links { display: flex; gap: 8px; align-items: center; }
.ps-bw-links span {
  width: 22px; height: 4px;
  background: rgba(255,255,255,.18);
  border-radius: 2px;
}
.ps-bw-cta {
  width: 36px !important;
  height: 14px !important;
  background: var(--acid-strong) !important;
  border-radius: 100px !important;
}
.ps-bw-hero {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
  padding: 12px 0 6px;
}
.ps-bw-h {
  height: 9px; width: 65%;
  background: var(--grad-1);
  border-radius: 2px;
}
.ps-bw-h:nth-child(2) { width: 78%; }
.ps-bw-sub {
  height: 4px; width: 50%;
  background: rgba(255,255,255,.22);
  border-radius: 2px;
  margin-top: 4px;
}
.ps-bw-btn {
  margin-top: 10px;
  width: 80px; height: 18px;
  background: var(--acid-strong);
  border-radius: 100px;
  box-shadow: 0 4px 12px rgba(96,165,250,.3);
}
.ps-bw-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-top: auto;
}
.ps-bw-grid > div {
  height: 32px;
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(96,165,250,.16), rgba(147,197,253,.04));
  border: 1px solid rgba(147,197,253,.16);
}

/* ── Visual 03 — Go-Live Checklist ── */
.ps-launch-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 8px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: 100px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  box-shadow: 0 0 0 4px rgba(96,165,250,.12), 0 4px 16px rgba(96,165,250,.4);
}
.ps-launch-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--ink);
  animation: ps-pulse 1.6s ease-in-out infinite;
}
.ps-launch-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
  padding: 6px 0;
}
.ps-launch-row {
  display: grid;
  grid-template-columns: 24px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(96,165,250,.04);
  transition: border-color var(--ease);
}
.ps-launch-check {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(96,165,250,.18);
  border: 1px solid rgba(147,197,253,.4);
  color: var(--acid-strong);
  font-weight: 800;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.ps-launch-label {
  font-size: 13.5px;
  color: var(--text);
}
.ps-launch-tag {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  font-weight: 700;
  color: var(--text-subtle);
  padding: 3px 8px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
  .ps-vis-pulse, .ps-status-dot { animation: none; }
  .ps-stepper-fill { transition: none; }
}

/* ════════════════════════════════
   PORTFOLIO — Horizontal Scroll Showcase (Session 3.3)
════════════════════════════════ */
.hs-shell {
  position: relative;
  width: 100%;
  margin-top: 32px;
}
.hs-track {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  padding: 0 6vw 24px;
  gap: 24px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 6vw;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}
.hs-track::-webkit-scrollbar { display: none; }

/* ── Slides ── */
.hs-slide {
  flex: 0 0 auto;
  width: min(78vw, 1100px);
  height: clamp(540px, 72vh, 700px);
  scroll-snap-align: start;
  scroll-snap-stop: always;
  display: grid;
  grid-template-columns: minmax(280px, 0.85fr) minmax(0, 1.15fr);
  gap: 32px;
  padding: 36px;
  border-radius: var(--r-xl);
  border: 1px solid var(--border2);
  background:
    linear-gradient(135deg, rgba(96,165,250,.05) 0%, rgba(255,255,255,.015) 100%),
    rgba(8,10,18,.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  overflow: hidden;
  position: relative;
}
.hs-slide::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 60px; height: 1px;
  background: var(--acid-strong);
  box-shadow: 0 0 12px var(--acid-strong);
}

.hs-info {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  padding: 12px 8px;
  min-width: 0;
}
.hs-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.hs-num {
  color: var(--acid-strong);
  font-weight: 700;
  padding: 5px 10px;
  background: rgba(96,165,250,.1);
  border: 1px solid rgba(147,197,253,.28);
  border-radius: 4px;
}
.hs-cat { color: var(--text-muted); }
.hs-name {
  font-family: var(--font-display);
  font-size: clamp(36px, 4.6vw, 64px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hs-desc {
  font-size: 15px;
  line-height: 1.65;
  color: var(--text-soft);
  max-width: 38ch;
}
.hs-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.hs-tags span {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-muted);
  padding: 6px 12px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
}
.hs-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--acid-strong);
  width: fit-content;
  transition: gap var(--ease);
}
.hs-link:hover { gap: 12px; }

/* ── Mockup container ── */
.hs-mock {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
}
.hs-browser {
  width: 100%;
  height: 100%;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  border-radius: 12px;
  border: 1px solid var(--border2);
  background: rgba(5,6,8,.85);
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.4), 0 0 0 1px rgba(96,165,250,.06) inset;
}
/* Windows-style title bar — URL pill left, ─ □ ✕ controls right */
.hs-browser-bar {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0;
  height: 36px;
  background: linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.025) 100%);
  border-bottom: 1px solid var(--border);
}
.hs-bw-url {
  order: 1;
  flex: 1 1 auto;
  margin: 0 12px 0 14px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 6px;
  padding: 5px 12px;
  max-width: 360px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.hs-bw-url::before {
  content: '';
  width: 10px; height: 10px;
  flex-shrink: 0;
  background: currentColor;
  opacity: .55;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 14' fill='none' stroke='white' stroke-width='1.4'><rect x='2.5' y='6' width='7' height='6' rx='1'/><path d='M4 6V4a2 2 0 0 1 4 0v2'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 14' fill='none' stroke='white' stroke-width='1.4'><rect x='2.5' y='6' width='7' height='6' rx='1'/><path d='M4 6V4a2 2 0 0 1 4 0v2'/></svg>") center/contain no-repeat;
}
.hs-bw-dots {
  order: 2;
  display: flex;
  height: 100%;
  margin-left: auto;
  gap: 0;
}
.hs-bw-dots i {
  width: 44px;
  height: 100%;
  background: transparent;
  border-radius: 0;
  position: relative;
  color: rgba(255,255,255,.6);
  transition: background .15s ease, color .15s ease;
}
.hs-bw-dots i::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
/* Minimize — horizontal line */
.hs-bw-dots i:nth-child(1)::before {
  width: 10px; height: 1px;
  background: currentColor;
}
/* Maximize — hollow square */
.hs-bw-dots i:nth-child(2)::before {
  width: 9px; height: 9px;
  border: 1px solid currentColor;
}
/* Close — X (two diagonals via ::before + ::after) */
.hs-bw-dots i:nth-child(3)::before,
.hs-bw-dots i:nth-child(3)::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 11px; height: 1px;
  background: currentColor;
}
.hs-bw-dots i:nth-child(3)::before { transform: translate(-50%, -50%) rotate(45deg); }
.hs-bw-dots i:nth-child(3)::after  { transform: translate(-50%, -50%) rotate(-45deg); }
/* Hover */
.hs-bw-dots i:hover { background: rgba(255,255,255,.08); color: rgba(255,255,255,.92); }
.hs-bw-dots i:nth-child(3):hover { background: #c42b1c; color: #fff; }
.hs-browser-body {
  flex: 1;
  padding: 32px;
  overflow: hidden;
  position: relative;
}

/* Slide 01 — Law */
.hs-mock-law {
  display: flex;
  flex-direction: column;
  gap: 22px;
  background:
    radial-gradient(closest-side at 80% 0%, rgba(96,165,250,.06), transparent 70%),
    rgba(5,6,8,.7);
}
.hs-law-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.hs-law-logo {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.04em;
  color: var(--text);
}
.hs-law-links { display: flex; gap: 14px; }
.hs-law-links span {
  width: 38px; height: 4px;
  background: rgba(255,255,255,.18);
  border-radius: 2px;
}
.hs-law-hero { display: flex; flex-direction: column; gap: 10px; padding: 16px 0; }
.hs-law-h {
  font-family: var(--font-display);
  font-size: clamp(22px, 3vw, 38px);
  letter-spacing: -0.01em;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hs-law-sub { font-size: 13px; color: var(--text-muted); }
.hs-law-cta {
  align-self: flex-start;
  margin-top: 8px;
  padding: 10px 18px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
}
.hs-law-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: auto; }
.hs-law-card {
  display: flex; flex-direction: column; gap: 4px;
  padding: 14px 16px;
  background: rgba(96,165,250,.05);
  border: 1px solid rgba(147,197,253,.16);
  border-radius: 8px;
}
.hs-law-card span {
  font-family: var(--font-mono);
  font-size: 9.5px; letter-spacing: 0.16em;
  color: var(--acid-strong);
  font-weight: 700;
}
.hs-law-card b {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 400;
  letter-spacing: 0.005em;
  color: var(--text);
}

/* Slide 02 — Fitness */
.hs-mock-fit {
  display: flex; flex-direction: column; gap: 22px;
  background:
    radial-gradient(closest-side at 100% 100%, rgba(96,165,250,.10), transparent 60%),
    linear-gradient(180deg, #0a0c12 0%, #050608 100%);
}
.hs-fit-hero { display: flex; flex-direction: column; gap: 12px; }
.hs-fit-pill {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.18em;
  color: var(--acid-strong);
  padding: 5px 10px;
  background: rgba(96,165,250,.1);
  border: 1px solid rgba(147,197,253,.28);
  border-radius: 4px;
}
.hs-fit-h {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.6vw, 48px);
  line-height: 0.95;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--text);
}
.hs-fit-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.hs-fit-stat {
  padding: 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hs-fit-stat b {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 400;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hs-fit-stat span {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  color: var(--text-subtle);
}
.hs-fit-cta {
  align-self: flex-start;
  margin-top: auto;
  padding: 12px 22px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* Slide 03 — Event (Screenshot der echten Site) */
.hs-mock-event {
  padding: 0;
  background: #f5efe2;
  position: relative;
  overflow: hidden;
}
.hs-live-shot {
  position: absolute; inset: 0;
  display: block;
  cursor: pointer;
  overflow: hidden;
}
.hs-live-shot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .6s cubic-bezier(.2,.7,.2,1);
}
.hs-live-shot:hover img,
.hs-live-shot:focus-visible img { transform: scale(1.02); }
.hs-ev-pill {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.18em;
  color: var(--acid-strong);
  padding: 5px 12px;
  background: rgba(96,165,250,.1);
  border: 1px solid rgba(147,197,253,.3);
  border-radius: var(--r-pill);
  text-transform: uppercase;
}
.hs-ev-h {
  font-family: var(--font-display);
  font-size: clamp(40px, 5.5vw, 80px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hs-ev-line {
  width: 56px; height: 3px;
  background: var(--acid-strong);
  border-radius: 2px;
  box-shadow: 0 0 12px var(--acid-strong);
}
.hs-ev-sub {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  text-transform: uppercase;
}
.hs-ev-cta {
  margin-top: 12px;
  padding: 14px 24px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Slide 04 — Tech */
.hs-mock-tech {
  display: flex; flex-direction: column; gap: 16px;
  background:
    linear-gradient(135deg, #0a0d18 0%, #050608 100%);
}
.hs-tech-eyebrow {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: 0.18em;
  color: var(--acid-strong);
  font-weight: 700;
}
.hs-tech-h {
  font-family: var(--font-display);
  font-size: clamp(32px, 4.5vw, 60px);
  line-height: 0.92;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--text);
}
.hs-tech-h em {
  font-style: normal;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hs-tech-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 8px; }
.hs-tech-card {
  padding: 14px 16px;
  background: rgba(96,165,250,.05);
  border: 1px solid rgba(147,197,253,.2);
  border-radius: 8px;
  display: flex; flex-direction: column; gap: 4px;
}
.hs-tech-card b {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.005em;
  color: var(--text);
}
.hs-tech-card span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--text-subtle);
}
.hs-tech-cta {
  align-self: flex-start;
  margin-top: auto;
  padding: 12px 22px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

/* Slide 05 — Salon Booking Tool */
.hs-slide-tool {
  background:
    radial-gradient(closest-side at 80% 30%, rgba(212,163,115,.10), transparent 60%),
    rgba(8,10,18,.7);
}
.hs-tool-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  padding: 11px 20px;
  background: linear-gradient(135deg, #d4a373 0%, #8b1e3f 130%);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), gap .2s var(--ease);
  box-shadow: 0 8px 24px rgba(139,30,63,.32);
  width: fit-content;
}
.hs-tool-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(139,30,63,.4);
  gap: 12px;
}

/* Slide salon mockup body */
.hs-mock-salon {
  background: #faf7f2;
  color: #1a1414;
  font-family: 'Manrope', sans-serif;
  padding: 22px 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 100%;
  overflow: hidden;
}
.hs-salon-hdr {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 14px;
  border-bottom: 1px solid #ebe4dc;
}
.hs-salon-logo {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 17px;
  font-weight: 500;
  color: #1a1414;
  letter-spacing: .02em;
}
.hs-salon-tag {
  font-size: 9.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #6b5f5a;
  font-weight: 600;
}
.hs-salon-stepper {
  display: flex;
  align-items: center;
  gap: 18px;
  position: relative;
  padding: 4px 8px 0;
}
.hs-salon-stepper::before {
  content: '';
  position: absolute;
  top: 13px; left: 22px; right: 22px;
  height: 1px;
  background: #ebe4dc;
}
.hs-step {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #d8cec3;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700;
  color: #a89e98;
  position: relative; z-index: 1;
  flex: 1 0 22px;
  max-width: 22px;
}
.hs-step.is-active {
  background: #8b1e3f;
  border-color: #8b1e3f;
  color: #fff;
}
.hs-salon-h {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: #1a1414;
}
.hs-salon-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  flex: 1;
  min-height: 0;
}
.hs-salon-card {
  background: #fff;
  border: 1.5px solid #ebe4dc;
  border-radius: 10px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: space-between;
  min-height: 0;
}
.hs-salon-card.is-selected {
  border-color: #8b1e3f;
  box-shadow: 0 0 0 1.5px #8b1e3f inset;
}
.hs-salon-card-name {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 13.5px;
  font-weight: 500;
  color: #1a1414;
}
.hs-salon-card-foot {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  font-size: 10px;
  color: #6b5f5a;
  border-top: 1px dashed #ebe4dc;
  padding-top: 6px;
}
.hs-salon-card-foot b {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 13px;
  color: #8b1e3f;
  font-weight: 500;
}

/* Slide 05 — CTA outro (now slide 06) */
.hs-slide-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(closest-side at 50% 50%, rgba(96,165,250,.18), transparent 70%),
    rgba(8,10,18,.7);
  border-color: rgba(147,197,253,.4);
}
.hs-cta-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  text-align: center;
  max-width: 540px;
}
.hs-cta-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--acid-strong);
  font-weight: 700;
}
.hs-cta-h {
  font-family: var(--font-display);
  font-size: clamp(40px, 5.5vw, 80px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--text);
}
.hs-cta-sub {
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-soft);
}
.hs-cta-btn {
  margin-top: 8px;
  padding: 18px 32px;
  background: var(--acid-strong);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 8px 32px rgba(96,165,250,.35);
  transition: transform var(--ease), box-shadow var(--ease);
}
.hs-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(96,165,250,.5);
}

/* ── Progress bar ── */
.hs-progress {
  margin: 16px 6vw 0;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  pointer-events: none;
}
.hs-progress-num {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.hs-progress-num span { color: var(--acid-strong); }
.hs-progress-bar {
  position: relative;
  height: 1px;
  background: var(--border);
}
.hs-progress-fill {
  position: absolute;
  left: 0; top: -1px; height: 3px;
  width: 0%;
  background: var(--acid-strong);
  box-shadow: 0 0 12px var(--acid-strong);
  transition: width 0.15s linear;
}
.hs-progress-hint {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  color: var(--text-subtle);
  text-transform: uppercase;
}

/* Subtle hint that horizontal scroll is possible */
@keyframes hs-hint-arrow {
  0%, 100% { transform: translateX(0); opacity: 0.4; }
  50% { transform: translateX(4px); opacity: 1; }
}
.hs-progress-hint::before {
  content: '↔ ';
  display: inline-block;
  margin-right: 4px;
  animation: hs-hint-arrow 1.8s ease-in-out infinite;
}

/* ── Mobile: keep horizontal swipe, just smaller slides ── */
@media (max-width: 900px) {
  .hs-track {
    padding: 0 16px 16px;
    scroll-padding-left: 16px;
    gap: 16px;
  }
  .hs-slide {
    width: min(86vw, 540px);
    height: auto;
    min-height: 580px;
    grid-template-columns: 1fr;
    padding: 24px;
    gap: 20px;
  }
  .hs-mock { min-height: 280px; }
  .hs-progress { margin: 12px 16px 0; gap: 12px; }
  .hs-progress-hint { display: none; }
}

/* ════════════════════════════════
   PAKETE — Bold Pricing (Session 4)
════════════════════════════════ */
.pkg-grid {
  display: flex;
  align-items: stretch;
  gap: 20px;
  max-width: 880px;
  margin: 0 auto;
}
.pkg-card {
  flex: 1 1 0;
  min-width: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: 40px 32px 32px;
  background: rgba(8,10,18,.6);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
  transition: transform var(--ease), border-color var(--ease);
  isolation: isolate;
}
.pkg-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(147,197,253,.5) 50%, transparent);
  opacity: 0.4;
}
.pkg-card:hover {
  border-color: rgba(147,197,253,.3);
  transform: translateY(-6px);
}
.pkg-card:hover::before { opacity: 1; }

/* Massive watermark number */
.pkg-bgnum {
  position: absolute;
  top: 12px; right: -10px;
  font-family: var(--font-display);
  font-size: 200px;
  font-weight: 400;
  line-height: 0.8;
  letter-spacing: -0.04em;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(96,165,250,.10);
  pointer-events: none;
  user-select: none;
  z-index: -1;
}

/* ── Featured (Growth) — Solid Blue-on-Black ── */
.pkg-featured {
  background:
    linear-gradient(180deg, rgba(96,165,250,.10) 0%, rgba(8,10,18,.95) 70%),
    rgba(8,10,18,.95);
  border-color: rgba(96,165,250,.5);
  box-shadow:
    0 0 0 1px rgba(96,165,250,.2),
    0 30px 80px rgba(59,130,246,.18);
  transform: scale(1.025);
}
.pkg-featured::before {
  background: var(--acid-strong);
  opacity: 1;
  height: 2px;
  box-shadow: 0 0 16px var(--acid-strong);
}
.pkg-featured:hover {
  transform: translateY(-6px) scale(1.025);
}
.pkg-featured .pkg-bgnum {
  -webkit-text-stroke-color: rgba(96,165,250,.22);
}

.pkg-badge {
  position: absolute;
  top: 14px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--acid-strong);
  padding: 6px 14px;
  border-radius: var(--r-pill);
  white-space: nowrap;
  box-shadow: 0 8px 24px rgba(96,165,250,.45);
  z-index: 2;
}
.pkg-featured { padding-top: 56px; }

/* ── Head ── */
.pkg-head {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pkg-tier {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--acid-strong);
}
.pkg-tagline {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.005em;
  color: var(--text);
}

/* ── Price block ── */
.pkg-price-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 0 24px;
  border-bottom: 1px solid var(--border);
}
.pkg-from {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.pkg-price {
  font-family: var(--font-display);
  font-size: clamp(48px, 5vw, 64px);
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: -0.025em;
  color: var(--text);
  display: flex;
  align-items: baseline;
  gap: 2px;
  font-variant-numeric: tabular-nums;
}
.pkg-featured .pkg-price {
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.pkg-currency {
  font-size: 0.55em;
  color: var(--acid-strong);
  -webkit-text-fill-color: var(--acid-strong);
  font-weight: 400;
}
.pkg-pricenote {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  color: var(--text-subtle);
  text-transform: uppercase;
  margin-top: 4px;
}

.pkg-desc {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-soft);
}

/* ── Features ── */
.pkg-feats {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pkg-feats li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
  color: var(--text-soft);
  line-height: 1.45;
}
.pkg-feats li:last-child { border-bottom: none; }
.pf-check {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(147,197,253,.3);
  color: var(--acid-strong);
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}
.pkg-featured .pf-check {
  background: var(--acid-strong);
  border-color: var(--acid-strong);
  color: var(--ink);
}

/* ── CTA ── */
.pkg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 22px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  margin-top: auto;
  transition: all var(--ease);
}
.pkg-btn svg { transition: transform var(--ease); }
.pkg-btn:hover svg { transform: translateX(4px); }

.pkg-btn-ghost {
  background: transparent;
  border: 1.5px solid var(--border2);
  color: var(--text);
}
.pkg-btn-ghost:hover {
  border-color: var(--acid-strong);
  background: rgba(96,165,250,.08);
  color: var(--acid-strong);
}
.pkg-btn-solid {
  background: var(--acid-strong);
  color: var(--ink);
  box-shadow: 0 8px 28px rgba(96,165,250,.4);
}
.pkg-btn-solid:hover {
  transform: translateY(-2px);
  background: var(--y-300);
  box-shadow: 0 14px 36px rgba(96,165,250,.55);
}

/* ── Trust footer ── */
.pkg-trust {
  margin-top: 96px;
  padding: 24px 32px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: rgba(8,10,18,.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: relative;
  z-index: 1;
}
.pkg-trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  color: var(--text-soft);
}
.pkg-trust-icon {
  width: 18px; height: 18px;
  flex-shrink: 0;
  border-radius: 50%;
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(147,197,253,.3);
  color: var(--acid-strong);
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 1100px) {
  .pkg-grid { flex-direction: column; max-width: 540px; margin: 0 auto; gap: 16px; }
  .pkg-featured { transform: none; }
  .pkg-featured:hover { transform: translateY(-4px); }
  .pkg-trust { grid-template-columns: 1fr 1fr; margin-top: 64px; }
}
@media (max-width: 600px) {
  .pkg-trust { grid-template-columns: 1fr; padding: 20px 22px; margin-top: 48px; }
  .pkg-bgnum { font-size: 160px; }
}


/* ════════════════════════════════
   ÜBER MICH (Session 4)
════════════════════════════════ */
.ab-wrap {
  display: grid;
  grid-template-columns: minmax(320px, 0.85fr) 1.3fr;
  gap: 80px;
  align-items: start;
}
.ab-left {
  position: sticky; top: 110px;
}

/* ── Portrait ── */
.ab-portrait {
  display: flex; flex-direction: column; gap: 20px;
  max-width: 380px;
}
.ab-portrait-frame {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--bg-deep);
  border: 1px solid var(--border2);
  isolation: isolate;
  box-shadow:
    0 30px 80px rgba(0,0,0,.55),
    inset 0 0 0 1px rgba(255,255,255,.02);
}
.ab-portrait-frame::before {
  content: '';
  position: absolute; inset: -1px;
  border-radius: var(--r-xl);
  padding: 1px;
  background: linear-gradient(160deg, rgba(147,197,253,.45), transparent 35%, transparent 65%, rgba(96,165,250,.2));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  z-index: 3;
}
.ab-portrait-frame::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(5,5,7,.5) 100%);
  pointer-events: none;
  z-index: 2;
}
.ab-portrait-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 22%;
  display: block;
  filter: contrast(1.04) saturate(.92);
  transition: transform .8s cubic-bezier(.4,0,.2,1), filter .4s ease;
}
.ab-portrait:hover .ab-portrait-img {
  transform: scale(1.03);
  filter: contrast(1.06) saturate(1);
}
.ab-portrait-tag {
  position: absolute;
  top: 18px; left: 18px;
  z-index: 3;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--acid-strong);
  padding: 6px 12px;
  background: rgba(8,10,18,.7);
  border: 1px solid rgba(147,197,253,.3);
  border-radius: 4px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.ab-portrait-cap {
  display: flex; flex-direction: column;
  padding: 0 4px;
}
.ab-portrait-name {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 400;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1.05;
}
.ab-portrait-role {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 6px;
}
.ab-portrait-loc {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--acid-strong);
}
.ab-loc-pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--acid-strong);
  box-shadow: 0 0 10px var(--acid-strong);
  animation: ab-pulse 1.6s ease-in-out infinite;
}
@keyframes ab-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}

/* ── Right: Story + cards ── */
.ab-right { display: flex; flex-direction: column; gap: 28px; }
.ab-title {
  font-family: var(--font-display);
  font-size: clamp(48px, 6.5vw, 92px);
  font-weight: 400;
  line-height: 0.92;
  letter-spacing: -0.015em;
  text-transform: uppercase;
}
.ab-title-line {
  display: block;
  color: var(--text);
}
.ab-title-line.ab-title-accent {
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.ab-story { display: flex; flex-direction: column; gap: 16px; }
.ab-intro,
.ab-intro-2 {
  font-size: 17px;
  line-height: 1.7;
  color: var(--text-soft);
}
.ab-intro-2 { color: var(--text-muted); font-size: 15.5px; }

/* ── Cards (numbered, clean) ── */
.ab-cards {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ab-card {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 24px;
  padding: 22px 0;
  border-top: 1px solid var(--border);
  transition: padding-left var(--ease);
}
.ab-card:last-child { border-bottom: 1px solid var(--border); }
.ab-card:hover { padding-left: 8px; }
.ab-card-num {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--acid-strong);
}
.ab-card-body { display: flex; flex-direction: column; gap: 6px; }
.ab-card h4 {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--text);
}
.ab-card p {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-muted);
}

/* ── Stats Strip ── */
.ab-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 8px;
  padding: 24px 0;
  border-top: 1px solid var(--border2);
  border-bottom: 1px solid var(--border2);
  background:
    linear-gradient(135deg, rgba(96,165,250,.04) 0%, transparent 70%);
}
.ab-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 0 16px;
  position: relative;
  text-align: center;
}
.ab-stat:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 12%;
  height: 76%;
  width: 1px;
  background: var(--border);
}
.ab-stat-num {
  font-family: var(--font-display);
  font-size: clamp(32px, 3.6vw, 44px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: -0.015em;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-variant-numeric: tabular-nums;
}
.ab-stat-lbl {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
}

/* ── CTA ── */
.ab-cta {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  padding: 16px 28px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--acid-strong);
  border-radius: var(--r-pill);
  box-shadow: 0 8px 28px rgba(96,165,250,.35);
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
}
.ab-cta:hover {
  transform: translateY(-2px);
  background: var(--y-300);
  box-shadow: 0 14px 36px rgba(96,165,250,.5);
}
.ab-cta svg { transition: transform var(--ease); }
.ab-cta:hover svg { transform: translateX(4px); }

@media (max-width: 1100px) {
  .ab-wrap { grid-template-columns: 1fr; gap: 48px; }
  .ab-left { position: static; }
  .ab-portrait { max-width: 320px; margin: 0 auto; }
}
@media (max-width: 700px) {
  .ab-stats { grid-template-columns: 1fr; gap: 18px; padding: 22px 0; }
  .ab-stat:not(:last-child)::after { display: none; }
  .ab-card { grid-template-columns: 44px 1fr; gap: 16px; }
  .ab-card-num { font-size: 24px; }
  .ab-card h4 { font-size: 17px; }
  .ab-cta { width: 100%; justify-content: center; }
}

@media (prefers-reduced-motion: reduce) {
  .ab-loc-pulse { animation: none; }
}

/* ════════════════════════════════
   KONTAKT
════════════════════════════════ */
.ct-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
}
.ct-left {
  display: flex; flex-direction: column; gap: 32px;
  position: sticky; top: 110px;
}
.ct-title {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(44px, 5.5vw, 72px); font-weight: 700;
  line-height: .95; letter-spacing: -.02em;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.ct-sub { font-size: 16px; color: var(--text-muted); line-height: 1.65; max-width: 420px; }
.ct-items { display: flex; flex-direction: column; gap: 20px; }
.ct-item { display: flex; align-items: flex-start; gap: 16px; }
.ct-ic {
  width: 44px; height: 44px; flex-shrink: 0;
  background: rgba(96,165,250,.08);
  border: 1px solid rgba(147,197,253,.25);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--o-300);
}
.ct-lbl { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--o-300); margin-bottom: 4px; }
.ct-val { font-size: 15px; font-weight: 600; color: var(--text); }
a.ct-val { transition: color var(--ease); }
a.ct-val:hover { color: var(--o-300); }
.ct-form-card {
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  padding: 40px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  position: relative;
  overflow: hidden;
}
.ct-form-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px; background: var(--grad-1); opacity: .5;
}
.f-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.f-grp { display: flex; flex-direction: column; gap: 8px; }
#form-inner { display: flex; flex-direction: column; gap: 20px; }
.f-lbl {
  font-size: 11.5px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text-muted);
}
.f-inp {
  background: rgba(255,255,255,.02); color: var(--text);
  border: 1.5px solid var(--border); border-radius: var(--r-sm);
  padding: 13px 16px; font-size: 14.5px; font-weight: 400;
  transition: border-color var(--ease), background var(--ease), box-shadow var(--ease);
  outline: none; width: 100%;
}
.f-inp::placeholder { color: var(--text-subtle); }
.f-inp:focus {
  border-color: var(--o-400);
  background: rgba(96,165,250,.04);
  box-shadow: 0 0 0 4px rgba(96,165,250,.1);
}

/* ── Error states ── */
.f-err {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: #f87171;
  letter-spacing: .01em;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .25s ease, opacity .2s ease, margin-top .2s ease;
  margin-top: 0;
}
.f-grp.has-error .f-err,
.f-err-consent.is-visible {
  max-height: 28px;
  opacity: 1;
  margin-top: 2px;
}
.f-grp.has-error .f-inp {
  border-color: rgba(248,113,113,.55);
  background: rgba(248,113,113,.04);
}
.f-grp.has-error .f-inp:focus {
  box-shadow: 0 0 0 4px rgba(248,113,113,.12);
}
.f-consent.has-error .f-consent-box {
  border-color: rgba(248,113,113,.7);
  box-shadow: 0 0 0 3px rgba(248,113,113,.12);
}
.f-err-consent {
  display: block;
  font-size: 12px;
  color: #f87171;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .25s ease, opacity .2s ease, margin-top .2s ease;
  margin-top: 0;
}
.f-sel { appearance: none; cursor: pointer; }
.f-ta { resize: vertical; min-height: 130px; }
.f-btn {
  width: 100%;
  background: var(--grad-btn);
  background-size: 200% 100%;
  color: #0a0c12;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 15px; font-weight: 800;
  padding: 17px; border-radius: var(--r-pill);
  cursor: pointer;
  transition: background-position .4s ease, transform var(--ease), box-shadow var(--ease);
}
.f-btn:hover {
  background-position: 100% 0;
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(59,130,246,.4);
}
.f-ok {
  display: none;
  flex-direction: column; align-items: center; gap: 16px;
  text-align: center; padding: 50px 0;
}
.f-ok-ic {
  width: 68px; height: 68px;
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(147,197,253,.3);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.f-ok h3 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 24px; font-weight: 700;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.f-ok p { font-size: 15px; color: var(--text-muted); }

/* ════════════════════════════════
   AUDIT-TEASER (Mini-Demo)
════════════════════════════════ */
.ad-section {
  padding: var(--py) 0;
  position: relative;
  overflow: hidden;
}
.ad-section::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 800px; height: 800px;
  background: radial-gradient(circle, rgba(96,165,250,.06) 0%, transparent 60%);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: -1;
}

.ad-grid {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 80px;
  align-items: center;
}

/* ── Left ── */
.ad-left { display: flex; flex-direction: column; gap: 24px; }
.ad-title {
  font-family: 'Anton', sans-serif;
  font-size: clamp(40px, 5.5vw, 72px);
  font-weight: 400;
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--text);
  margin: 0;
  text-transform: uppercase;
}
.ad-sub {
  font-size: 17px;
  line-height: 1.55;
  color: var(--text-muted);
  max-width: 500px;
  margin: 0;
}
.ad-checks {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ad-checks li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  color: var(--text);
  font-weight: 500;
}
.ad-check-ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(96,165,250,.3);
  border-radius: 50%;
  color: var(--acid-strong);
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}
.ad-cta {
  margin-top: 10px;
  align-self: flex-start;
}

/* ── Right (Card) ── */
.ad-right { display: flex; justify-content: center; }
.ad-card {
  width: 100%;
  max-width: 520px;
  background: linear-gradient(180deg, rgba(15,20,32,.96), rgba(8,11,18,.98));
  border: 1px solid rgba(96,165,250,.18);
  border-radius: var(--r-lg);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  position: relative;
  isolation: isolate;
  box-shadow:
    0 30px 80px rgba(0,0,0,.5),
    0 0 0 1px rgba(96,165,250,.06) inset;
  overflow: hidden;
}
.ad-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(96,165,250,.7) 50%, transparent);
}

.ad-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.ad-card-meta { display: flex; flex-direction: column; gap: 4px; }
.ad-card-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .2em;
  color: var(--text-subtle);
}
.ad-card-url {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.ad-card-tag {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .22em;
  padding: 5px 10px;
  background: rgba(251,191,36,.1);
  border: 1px solid rgba(251,191,36,.3);
  color: #fbbf24;
  border-radius: var(--r-pill);
}

/* ── Gauge ── */
.ad-gauge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  padding: 8px 0;
}
.ad-gauge svg { display: block; }
.ad-gauge-num {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -65%);
  font-family: 'Anton', sans-serif;
  font-size: 44px;
  font-weight: 400;
  color: var(--text);
  letter-spacing: -0.02em;
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.ad-gauge-max {
  font-size: 16px;
  color: var(--text-subtle);
  font-family: var(--font-mono);
  font-weight: 500;
}
.ad-gauge-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  color: var(--text-subtle);
  margin-top: 4px;
}

/* ── Bars ── */
.ad-bars {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ad-bars li { display: flex; flex-direction: column; gap: 6px; }
.ad-bar-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
}
.ad-bar-name { color: var(--text-muted); font-weight: 500; }
.ad-bar-val {
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--text);
}
.ad-bar-track {
  height: 5px;
  background: rgba(255,255,255,.04);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.ad-bar-fill {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--c, #60a5fa);
  border-radius: var(--r-pill);
  transition: width 1.4s cubic-bezier(.22,1,.36,1);
}

/* ── Findings ── */
.ad-findings {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 6px;
}
.ad-find-h {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  color: var(--text-subtle);
}
.ad-findings ul {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ad-find {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--text-muted);
  padding: 9px 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  transition: border-color var(--ease), background var(--ease);
}
.ad-find-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ad-find.err .ad-find-dot { background: #f87171; box-shadow: 0 0 10px rgba(248,113,113,.5); }
.ad-find.warn .ad-find-dot { background: #fbbf24; box-shadow: 0 0 10px rgba(251,191,36,.4); }
.ad-find.err { border-color: rgba(248,113,113,.18); }
.ad-find.warn { border-color: rgba(251,191,36,.15); }

@media (max-width: 1100px) {
  .ad-grid { grid-template-columns: 1fr; gap: 48px; }
  .ad-left { text-align: left; }
  .ad-card { max-width: 560px; margin: 0 auto; }
}
@media (max-width: 600px) {
  .ad-card { padding: 22px 18px; gap: 18px; }
  .ad-find { font-size: 12.5px; padding: 8px 10px; }
  .ad-gauge-num { font-size: 36px; }
  .ad-cta { width: 100%; justify-content: center; }
  .ad-section::before { width: 480px; height: 480px; }
}

/* ════════════════════════════════
   FOOTER
════════════════════════════════ */
footer {
  padding: 80px 0 32px;
  border-top: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, transparent 0%, rgba(8,12,20,.4) 100%);
}
footer::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(96,165,250,.4) 50%, transparent);
}
.ft-inner { display: flex; flex-direction: column; gap: 0; position: relative; }

/* ── 4-Column Grid ── */
.ft-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1.2fr 1fr;
  gap: 56px;
  padding-bottom: 64px;
  border-bottom: 1px solid var(--border);
}
.ft-col { display: flex; flex-direction: column; gap: 16px; }
.ft-col-brand { gap: 18px; }

.ft-brand-row {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--acid-strong);
}
.ft-name {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: .005em;
  color: var(--text);
  text-transform: uppercase;
  display: inline-flex;
  align-items: baseline;
}

.ft-tagline {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--text);
  max-width: 320px;
  margin: 0;
}

.ft-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--acid-strong);
  padding: 10px 0;
  border-bottom: 1px solid rgba(96,165,250,.3);
  width: fit-content;
  transition: color var(--ease), border-color var(--ease), gap var(--ease);
}
.ft-cta:hover {
  color: var(--text);
  border-color: var(--acid-strong);
  gap: 12px;
}

/* ── Column Heads + Lists ── */
.ft-h {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin: 0 0 4px;
}
.ft-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
  padding: 0; margin: 0;
}
.ft-list a, .ft-meta-item {
  font-size: 14px;
  color: var(--text-muted);
  transition: color var(--ease);
  position: relative;
  display: inline-block;
}
.ft-list a:hover { color: var(--text); }
.ft-list a::after {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 0; height: 1px;
  background: var(--acid-strong);
  transition: width var(--ease);
}
.ft-list a:hover::after { width: 100%; }

/* ── Massive Wordmark ── */
.ft-wordmark {
  font-family: 'Anton', sans-serif;
  font-size: clamp(110px, 18vw, 240px);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 0.85;
  color: transparent;
  -webkit-text-stroke: 1px rgba(96,165,250,.18);
  text-align: center;
  padding: 48px 0 12px;
  user-select: none;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(96,165,250,.06) 0%, transparent 80%);
  -webkit-background-clip: text;
  background-clip: text;
}

/* ── Bottom Bar ── */
.ft-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  gap: 24px;
}
.ft-copy {
  font-size: 12px;
  color: var(--text-subtle);
  letter-spacing: .02em;
}
.ft-version {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

/* ════════════════════════════════
   RESPONSIVE
════════════════════════════════ */
@media (max-width: 1100px) {
  .lt-shell { grid-template-columns: 1fr; gap: 32px; }
  .lt-tabs { padding: 8px 0 8px 24px; }
  .lt-tab { padding: 18px 18px 18px 4px; gap: 18px; }
  .lt-tab-num { font-size: 44px; min-width: 56px; }
  .lt-tab-name { font-size: 18px; }
  .lt-preview { padding: 32px 28px 28px; min-height: auto; }
  .lt-feats { grid-template-columns: 1fr; gap: 0; }
  .lt-panel-foot { grid-template-columns: 1fr; gap: 24px; }
  .lt-mock { width: 100%; max-width: 360px; }
  .ps-stepper { margin-bottom: 32px; }
  .ps-stepper-dot .ps-dot-num { width: 40px; height: 40px; font-size: 11px; }
  .ps-stepper-dot .ps-dot-label { font-size: 10px; }
  .ps-stepper-track, .ps-stepper-fill { top: 20px; }
  .ps-stage {
    grid-template-columns: 1fr;
    gap: 32px;
    min-height: auto;
  }
  .ps-content { min-height: auto; }
  .ps-steps { display: flex; flex-direction: column; gap: 56px; position: static; }
  .ps-step {
    position: static;
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }
  .ps-visuals { display: none; }
  .ps-bignum-wrap { display: none; }
  /* Portfolio horizontal-scroll: smaller cards on tablet, swipe stays */
  .hs-slide { grid-template-columns: 1fr; min-height: 600px; height: auto; }
  .hs-mock { min-height: 280px; }
  .ct-grid, .ab-wrap { grid-template-columns: 1fr; gap: 56px; }
  .ct-left, .ab-left { position: static; }
}

@media (max-width: 768px) {
  :root { --py: 80px; --py-sm: 60px; }
  .container { padding: 0 24px; }
  nav { padding: 0 24px; }
  .nav-links, .nav-right .btn-grad { display: none; }
  .hamburger { display: flex; }
  .hero-title { font-size: clamp(64px, 16vw, 130px); }
  .hero-stats-bar { grid-template-columns: 1fr 1fr; padding: 24px 0; gap: 20px 0; }
  .hs-item:nth-child(2)::after { display: none; }
  .hs-item { padding: 12px 16px; }
  .hs-item:nth-child(2)::after { display: none; }
  .hs-num { font-size: 28px; }
  .hs-slide { padding: 20px 18px; min-height: 540px; }
  .f-row { grid-template-columns: 1fr; }
  .sec-title { font-size: clamp(32px, 8vw, 48px); }
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 36px; padding-bottom: 48px; }
  .ft-col-brand { grid-column: 1 / -1; }
  .ft-bottom { flex-direction: column; align-items: flex-start; gap: 16px; }
  .ft-wordmark { padding: 36px 0 8px; -webkit-text-stroke-width: 0.8px; }
  .ct-form-card { padding: 28px 22px; }
  .mob-menu { inset: 0 0 0 20%; }
}

@media (max-width: 480px) {
  .hero-title { font-size: clamp(56px, 18vw, 96px); }
  .hero-actions { flex-direction: column; align-items: stretch; width: 100%; max-width: 320px; }
  .btn-grad, .btn-glass { justify-content: center; }
  .ab-title { font-size: clamp(40px, 11vw, 60px); }
  .mob-menu { inset: 0; border-left: none; }
}

/* ════════════════════════════════
   AUDIT TOOL
════════════════════════════════ */
.audit-section {
  position: relative;
  isolation: isolate;
  background: transparent;
}
.audit-section::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 40% at 50% 20%, rgba(96,165,250,.10), transparent 60%),
    radial-gradient(40% 50% at 90% 90%, rgba(147,197,253,.06), transparent 60%);
  pointer-events: none;
  z-index: -1;
}

.au-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 56px;
}
.au-head .sec-lbl {
  display: inline-flex; align-items: center; gap: 8px;
  margin-bottom: 24px;
  padding: 7px 16px;
  background: rgba(96,165,250,.08);
  border: 1px solid rgba(96,165,250,.22);
  border-radius: var(--r-pill);
}
.sec-lbl-icon {
  color: #60a5fa;
  filter: drop-shadow(0 0 6px rgba(96,165,250,.55));
}
.au-head .sec-title {
  margin-bottom: 22px;
}
.au-head .sec-title .grad-2-text {
  background: linear-gradient(90deg, #93c5fd, #3b82f6, #2563eb);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.au-head .sec-sub {
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.65;
  color: var(--text-soft);
  font-weight: 400;
}

/* ── State machine ── */
.au-stage { display: none; }
.audit-section[data-state="form"]    .au-stage-form    { display: grid; }
.audit-section[data-state="confirm"] .au-stage-confirm { display: flex; }
.audit-section[data-state="loading"] .au-stage-loading { display: flex; }
.audit-section[data-state="results"] .au-stage-results { display: block; }

/* ── Form state ── */
.au-stage-form {
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: start;
  max-width: 1100px;
  margin: 0 auto;
}
.au-form {
  display: flex; flex-direction: column;
  gap: 20px;
  padding: 36px 36px 32px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  position: relative;
  overflow: hidden;
}
.au-form::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, #60a5fa, transparent);
  opacity: .6;
}
.au-field {
  display: flex; flex-direction: column;
  gap: 8px;
}
.au-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px; font-weight: 700;
  letter-spacing: .04em;
  color: var(--text);
}
.au-label-icon {
  font-size: 14px;
  filter: grayscale(.2);
}
.au-input {
  width: 100%;
  padding: 14px 18px;
  background: rgba(0,0,0,.3);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: inherit; font-size: 14.5px; font-weight: 500;
  color: var(--text);
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}
.au-input::placeholder { color: rgba(245,245,245,.32); }
.au-input:focus {
  outline: none;
  border-color: rgba(96,165,250,.6);
  background: rgba(0,0,0,.45);
  box-shadow: 0 0 0 3px rgba(96,165,250,.12), 0 0 20px rgba(59,130,246,.18);
}
.au-input:invalid:not(:placeholder-shown) {
  border-color: rgba(96,165,250,.5);
}

.au-check {
  display: flex; align-items: flex-start; gap: 12px;
  cursor: pointer;
  font-size: 13px; line-height: 1.55;
  color: var(--text-soft);
  user-select: none;
}
.au-check input { position: absolute; opacity: 0; pointer-events: none; }
.au-check-box {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border-radius: 5px;
  border: 1.5px solid rgba(96,165,250,.45);
  background: rgba(0,0,0,.3);
  margin-top: 2px;
  transition: all var(--ease);
  position: relative;
}
.au-check input:checked ~ .au-check-box {
  background: #60a5fa;
  border-color: #60a5fa;
  box-shadow: 0 0 12px rgba(96,165,250,.4);
}
.au-check input:checked ~ .au-check-box::after {
  content: '';
  position: absolute;
  left: 5px; top: 1px;
  width: 5px; height: 10px;
  border: solid #0a0c12;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.au-check input:focus-visible ~ .au-check-box {
  outline: 2px solid rgba(96,165,250,.6);
  outline-offset: 2px;
}
.au-link {
  color: #60a5fa;
  text-decoration: underline;
  text-decoration-color: rgba(96,165,250,.4);
  text-underline-offset: 3px;
}
.au-link:hover { text-decoration-color: #60a5fa; }

.au-submit {
  margin-top: 6px;
  justify-content: center;
  font-size: 15px;
}

.au-trust {
  display: flex; align-items: center; justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  color: var(--text-muted);
}
.au-trust-item { display: inline-flex; align-items: center; gap: 6px; }
.au-trust-icon { font-size: 13px; }
.au-trust-sep {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: rgba(96,165,250,.4);
}

/* Categories preview (right side) */
.au-categories {
  padding: 32px;
  background: rgba(255,255,255,.015);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  backdrop-filter: blur(8px);
}
.au-cat-label {
  font-size: 11.5px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 18px;
}
.au-cat-pills {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 24px;
}
.au-cat-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  font-size: 12.5px; font-weight: 600;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  color: var(--text-soft);
  transition: border-color var(--ease), background var(--ease), transform var(--ease);
}
.au-cat-pill:hover {
  border-color: rgba(96,165,250,.4);
  background: rgba(96,165,250,.06);
  transform: translateY(-2px);
}
.au-cat-pill-icon { font-size: 14px; }
.au-demo-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600;
  color: #60a5fa;
  background: transparent;
  padding: 8px 0;
  transition: gap var(--ease);
}
.au-demo-link:hover { gap: 10px; }

/* ── Confirm state (Double-Opt-In pending) ── */
.au-stage-confirm {
  justify-content: center;
}
.au-confirm-card {
  max-width: 520px; width: 100%;
  padding: 56px 40px 40px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  backdrop-filter: blur(14px);
  text-align: center;
}
.au-confirm-icon {
  width: 80px; height: 80px;
  margin: 0 auto 24px;
  display: flex; align-items: center; justify-content: center;
  font-size: 36px;
  background: linear-gradient(135deg, rgba(96,165,250,.18), rgba(147,197,253,.12));
  border: 1.5px solid rgba(96,165,250,.4);
  border-radius: 50%;
  box-shadow: 0 0 40px rgba(59,130,246,.2);
  animation: au-pulse 2.4s ease-in-out infinite;
}
@keyframes au-pulse {
  0%, 100% { box-shadow: 0 0 40px rgba(59,130,246,.2); }
  50%      { box-shadow: 0 0 60px rgba(59,130,246,.4); }
}
.au-confirm-title {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 28px; font-weight: 700;
  letter-spacing: -.01em;
  color: var(--text);
  margin-bottom: 16px;
}
.au-confirm-text {
  font-size: 15px; line-height: 1.65;
  color: var(--text-soft);
  margin-bottom: 24px;
}
.au-confirm-text strong {
  color: #60a5fa;
  font-weight: 700;
}
.au-confirm-hint {
  display: flex; align-items: flex-start; gap: 10px;
  text-align: left;
  padding: 14px 18px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-size: 13px; color: var(--text-muted);
  margin-bottom: 28px;
}
.au-confirm-hint-icon { color: #60a5fa; font-weight: 700; flex-shrink: 0; }
.au-confirm-back {
  font-size: 13px; padding: 10px 18px;
}

/* ── Loading state ── */
.au-stage-loading {
  justify-content: center;
}
.au-loader-card {
  max-width: 560px; width: 100%;
  padding: 48px 40px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  backdrop-filter: blur(14px);
  display: flex; flex-direction: column; align-items: center;
  gap: 32px;
}
.au-loader-ring {
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.au-loader-pct {
  position: absolute;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 26px; font-weight: 700;
  background: linear-gradient(90deg, #bfdbfe, #60a5fa, #93c5fd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.au-loader-progress {
  transition: stroke-dashoffset .6s cubic-bezier(.4,0,.2,1);
}
.au-loader-stages {
  width: 100%;
  display: flex; flex-direction: column; gap: 10px;
}
.au-loader-stage {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 16px;
  font-size: 13.5px; font-weight: 500;
  color: var(--text-muted);
  background: rgba(255,255,255,.015);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  transition: all var(--ease);
}
.au-loader-stage.is-active {
  background: rgba(96,165,250,.06);
  border-color: rgba(96,165,250,.3);
  color: var(--text);
}
.au-loader-stage.is-done {
  color: var(--text-soft);
}
.au-loader-stage.is-done .au-stage-num {
  background: #60a5fa;
  color: #0a0c12;
}
.au-loader-stage.is-done .au-stage-num::after {
  content: '✓';
  font-weight: 700;
}
.au-loader-stage.is-done .au-stage-num::before { display: none; }
.au-stage-num {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(96,165,250,.15);
  border: 1px solid rgba(96,165,250,.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  color: #60a5fa;
}
.au-loader-stage.is-active .au-stage-num {
  background: #60a5fa;
  color: #0a0c12;
  box-shadow: 0 0 12px rgba(96,165,250,.5);
  animation: au-stage-pulse 1.4s ease-in-out infinite;
}
@keyframes au-stage-pulse {
  0%, 100% { box-shadow: 0 0 12px rgba(96,165,250,.5); }
  50%      { box-shadow: 0 0 20px rgba(96,165,250,.8); }
}

/* ── Results state ── */
.au-results-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
  padding: 32px 36px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  backdrop-filter: blur(14px);
  margin-bottom: 28px;
}
.au-results-lbl {
  font-size: 11.5px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 8px;
}
.au-results-url {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(22px, 2.4vw, 30px); font-weight: 700;
  background: linear-gradient(90deg, #bfdbfe, #60a5fa, #93c5fd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  word-break: break-all;
}
.au-overall {
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.au-overall-text {
  position: absolute;
  text-align: center;
}
.au-overall-num {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 42px; font-weight: 800; line-height: 1;
  background: linear-gradient(90deg, #bfdbfe, #60a5fa, #93c5fd);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.au-overall-lbl {
  font-size: 10.5px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 4px;
}

.au-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
  margin-bottom: 32px;
}
.au-cat-card {
  padding: 20px 22px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  backdrop-filter: blur(8px);
  transition: border-color var(--ease), transform var(--ease);
}
.au-cat-card:hover {
  border-color: var(--border2);
  transform: translateY(-3px);
}
.au-cat-card[data-grade="a"] { border-left: 3px solid #60a5fa; }
.au-cat-card[data-grade="b"] { border-left: 3px solid #93c5fd; }
.au-cat-card[data-grade="c"] { border-left: 3px solid #93c5fd; }
.au-cat-card[data-grade="d"] { border-left: 3px solid #93c5fd; }
.au-cat-card[data-grade="e"] { border-left: 3px solid #60a5fa; }

.au-cat-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  margin-bottom: 14px;
}
.au-cat-icon {
  font-size: 24px;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--border);
  border-radius: 12px;
}
.au-cat-meta { min-width: 0; }
.au-cat-name {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 15px; font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}
.au-cat-bar {
  height: 4px;
  background: rgba(96,165,250,.1);
  border-radius: 4px;
  overflow: hidden;
}
.au-cat-bar span {
  display: block; height: 100%;
  width: var(--w, 0%);
  background: linear-gradient(90deg, #60a5fa, #93c5fd);
  border-radius: 4px;
  transition: width 1.2s cubic-bezier(.4,0,.2,1);
}
.au-cat-card[data-grade="c"] .au-cat-bar span { background: linear-gradient(90deg, #93c5fd, #fcd34d); }
.au-cat-card[data-grade="d"] .au-cat-bar span { background: linear-gradient(90deg, #93c5fd, #93c5fd); }
.au-cat-card[data-grade="e"] .au-cat-bar span { background: linear-gradient(90deg, #60a5fa, #93c5fd); }
.au-cat-score {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 28px; font-weight: 800;
  line-height: 1;
  color: var(--text);
}

.au-cat-method {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .08em;
  color: var(--text-subtle);
  text-transform: uppercase;
  margin-top: 4px;
  line-height: 1.4;
}
.au-cat-meta-detail {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-top: 2px;
  padding: 2px 7px;
  background: rgba(96,165,250,.06);
  border: 1px solid rgba(96,165,250,.14);
  border-radius: 6px;
  display: inline-block;
  width: fit-content;
}

.au-cat-findings {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 12.5px;
}
.au-finding {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 13px;
  background: rgba(255,255,255,.018);
  border-radius: var(--r-sm);
  color: var(--text-soft);
  line-height: 1.5;
}
.au-finding-dot {
  flex-shrink: 0;
  width: 6px; height: 6px;
  border-radius: 50%;
  margin-top: 7px;
}
.au-finding-info  .au-finding-dot  { background: #60a5fa; box-shadow: 0 0 6px rgba(96,165,250,.5); }
.au-finding-warn  .au-finding-dot  { background: #fbbf24; box-shadow: 0 0 6px rgba(251,191,36,.55); }
.au-finding-error .au-finding-dot  { background: #f87171; box-shadow: 0 0 6px rgba(248,113,113,.6); }
.au-finding-good  .au-finding-dot  { background: #34d399; box-shadow: 0 0 6px rgba(52,211,153,.5); }
.au-finding-good {
  background: rgba(52,211,153,.05);
  border: 1px solid rgba(52,211,153,.16);
}

.au-finding-body {
  flex: 1;
  display: flex; flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.au-finding-headline {
  display: flex; align-items: baseline; gap: 8px;
  flex-wrap: wrap;
}
.au-finding-label {
  font-weight: 600;
  font-size: 13px;
  color: var(--text);
}
.au-finding-detail {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
  padding: 2px 7px;
  border-radius: 6px;
  background: rgba(96,165,250,.10);
  border: 1px solid rgba(96,165,250,.22);
  color: #93c5fd;
  white-space: nowrap;
}
.au-finding-error .au-finding-detail {
  background: rgba(248,113,113,.10);
  border-color: rgba(248,113,113,.28);
  color: #fca5a5;
}
.au-finding-warn .au-finding-detail {
  background: rgba(251,191,36,.10);
  border-color: rgba(251,191,36,.28);
  color: #fcd34d;
}
.au-finding-advice {
  font-size: 11.5px;
  line-height: 1.55;
  color: rgba(245,245,245,.62);
  padding-top: 2px;
  display: flex; gap: 6px;
  align-items: flex-start;
}
.au-advice-arrow {
  color: var(--acid-strong);
  font-weight: 700;
  flex-shrink: 0;
  font-family: var(--font-mono);
}

/* ════════════════════════════════
   AUDIT — Conversion Sprint Upsell
════════════════════════════════ */
.au-upsell {
  position: relative;
  margin: 64px 0 32px;
  padding: 56px 56px 48px;
  border-radius: var(--r-xl);
  border: 1px solid rgba(147,197,253,.22);
  background:
    linear-gradient(135deg, rgba(96,165,250,.06) 0%, rgba(255,255,255,.015) 60%),
    rgba(8,10,18,.65);
  overflow: hidden;
  isolation: isolate;
}
.au-upsell-glow {
  position: absolute;
  top: -30%; right: -10%;
  width: 60%; height: 80%;
  background: radial-gradient(closest-side, rgba(96,165,250,.18), transparent 70%);
  filter: blur(20px);
  pointer-events: none;
  z-index: -1;
}
.au-upsell::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--acid-strong) 50%, transparent);
  opacity: 0.5;
}

.au-upsell-head { margin-bottom: 36px; }
.au-upsell-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--acid-strong);
  background: rgba(96,165,250,.1);
  border: 1px solid rgba(147,197,253,.3);
  border-radius: 4px;
  margin-bottom: 18px;
}
.au-upsell-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 14px;
  max-width: 18ch;
}
.au-upsell-title em {
  font-style: normal;
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.au-upsell-sub {
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--text-soft);
  max-width: 60ch;
}

/* ── ROI Calculator ── */
.au-roi {
  margin-bottom: 36px;
  padding: 28px 32px;
  border-radius: var(--r);
  background: rgba(5,6,8,.55);
  border: 1px solid var(--border);
}
.au-roi-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 22px;
}
.au-roi-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--acid-strong);
}
.au-roi-pulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--acid-strong);
  box-shadow: 0 0 12px var(--acid-strong);
  animation: au-pulse 1.6s ease-in-out infinite;
}
.au-roi-inputs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 28px;
}
.au-roi-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.au-roi-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.au-roi-input {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -0.005em;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border2);
  border-radius: 8px;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  transition: border-color var(--ease), background var(--ease);
}
.au-roi-input:focus {
  outline: none;
  border-color: var(--acid-strong);
  background: rgba(96,165,250,.06);
}
.au-roi-input::-webkit-outer-spin-button,
.au-roi-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.au-roi-input[type=number] { -moz-appearance: textfield; }
.au-roi-prefix, .au-roi-suffix {
  position: relative;
  display: flex;
  align-items: center;
}
.au-roi-prefix .au-roi-input { padding-left: 36px; }
.au-roi-suffix .au-roi-input { padding-right: 36px; }
.au-roi-unit {
  position: absolute;
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--acid-strong);
  pointer-events: none;
}
.au-roi-prefix .au-roi-unit { left: 14px; }
.au-roi-suffix .au-roi-unit { right: 14px; }

.au-roi-result {
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  gap: 16px;
  padding: 24px 0 16px;
  border-top: 1px solid var(--border);
}
.au-roi-stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 10px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--border);
  transition: background var(--ease), border-color var(--ease);
}
.au-roi-stat.is-highlight {
  background: rgba(96,165,250,.08);
  border-color: rgba(147,197,253,.35);
  box-shadow: inset 0 0 32px rgba(96,165,250,.05);
}
.au-roi-num {
  font-family: var(--font-display);
  font-size: clamp(32px, 3.6vw, 44px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: -0.015em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.au-roi-stat.is-highlight .au-roi-num {
  background: var(--grad-1);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.au-roi-lbl {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.au-roi-note {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  text-align: center;
  margin-top: 6px;
}

/* ── Bullets ── */
.au-upsell-bullets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 32px;
}
.au-upsell-bullet {
  display: flex;
  gap: 16px;
  padding: 20px 22px;
  border-radius: 10px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--border);
}
.au-bullet-num {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--acid-strong);
  flex-shrink: 0;
}
.au-bullet-body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.au-bullet-body strong {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--text);
}
.au-bullet-body span {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-muted);
}

/* ── Sprint CTA ── */
.au-upsell-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 32px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--acid-strong);
  border-radius: var(--r-pill);
  box-shadow: 0 8px 32px rgba(96,165,250,.35);
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
}
.au-upsell-cta:hover {
  transform: translateY(-2px);
  background: var(--y-300);
  box-shadow: 0 14px 40px rgba(96,165,250,.5);
}
.au-upsell-cta svg {
  transition: transform var(--ease);
}
.au-upsell-cta:hover svg { transform: translateX(4px); }

@media (max-width: 900px) {
  .au-upsell { padding: 36px 24px 32px; margin: 40px 0 24px; }
  .au-upsell-title { font-size: clamp(24px, 6vw, 36px); }
  .au-roi { padding: 22px 18px; }
  .au-roi-inputs { grid-template-columns: 1fr; gap: 12px; }
  .au-roi-result { grid-template-columns: 1fr; gap: 10px; }
  .au-upsell-bullets { grid-template-columns: 1fr; }
  .au-upsell-cta { width: 100%; justify-content: center; }
}

@media (prefers-reduced-motion: reduce) {
  .au-roi-pulse { animation: none; }
}

.au-results-cta {
  display: flex; align-items: center; justify-content: center;
  gap: 14px; flex-wrap: wrap;
  padding: 32px;
  background: rgba(96,165,250,.04);
  border: 1px solid rgba(96,165,250,.18);
  border-radius: var(--r-xl);
}
.au-restart-link {
  background: transparent;
  font-size: 13px; font-weight: 600;
  color: var(--text-muted);
  padding: 10px 18px;
  transition: color var(--ease);
}
.au-restart-link:hover { color: #60a5fa; }

/* Audit nav-link accent */
.nav-link-accent {
  position: relative;
  color: #60a5fa !important;
}
.nav-link-accent::after {
  content: '';
  position: absolute; left: 50%; bottom: -3px;
  transform: translateX(-50%);
  width: 4px; height: 4px;
  border-radius: 50%;
  background: #60a5fa;
  box-shadow: 0 0 8px #60a5fa;
  animation: au-pulse 2s ease-in-out infinite;
}

/* ── Responsive ── */
@media (max-width: 960px) {
  .au-stage-form { grid-template-columns: 1fr; gap: 24px; }
  .au-results-head { grid-template-columns: 1fr; text-align: center; }
  .au-overall { margin: 0 auto; }
}
@media (max-width: 640px) {
  .au-form { padding: 28px 22px 24px; }
  .au-categories { padding: 24px 20px; }
  .au-confirm-card { padding: 40px 24px 28px; }
  .au-loader-card { padding: 32px 24px; }
  .au-results-head { padding: 24px; }
  .au-cat-grid { grid-template-columns: 1fr; }
  .au-results-cta { padding: 24px 20px; }
  .au-trust { gap: 10px; font-size: 11.5px; }
}

/* ════════════════════════════════════════════════════════════════
   ▓▓ FOUNDATION V2 — Kuklev. Bold Refresh                     ▓▓
   ▓▓ Animated Mesh BG · Pill Nav · Progress · Mobile Bar      ▓▓
════════════════════════════════════════════════════════════════ */

/* ── Animated Mesh Grid Background (global, fixed) ────────── */
#mesh-bg {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-mesh);
  pointer-events: none;
  display: block;
  filter: contrast(1.08) brightness(.92) saturate(1.05);
  background: var(--bg);
}
/* Vignette overlay — deeper edges, "edel" feel */
.bg-vignette {
  position: fixed;
  inset: 0;
  z-index: calc(var(--z-mesh) + 1);
  pointer-events: none;
  background:
    radial-gradient(ellipse 95% 75% at 50% 35%, transparent 0%, transparent 65%, rgba(5,8,16,.42) 100%);
}

/* ── Scroll-Progress Bar (top, lime, 2px) ─────────────────── */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  width: 0%;
  background: linear-gradient(90deg, #bfdbfe, #93c5fd 50%, #dbeafe);
  box-shadow: 0 0 12px rgba(147,197,253,.55), 0 0 4px rgba(147,197,253,.8);
  z-index: var(--z-progress);
  pointer-events: none;
  transition: width .12s linear;
}

/* ── Floating Pill Nav — override default nav ─────────────── */
nav#main-nav {
  padding: 14px 24px 0;
  background: transparent !important;
  border-bottom: none !important;
  box-shadow: none !important;
}
nav#main-nav .nav-inner {
  max-width: 1180px;
  height: 58px;
  padding: 0 8px 0 18px;
  border-radius: 999px;
  background: rgba(10,18,15,.55);
  border: 1px solid var(--border);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 12px 40px rgba(0,0,0,.35);
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
  position: relative;
  overflow: hidden;
}
nav#main-nav.scrolled .nav-inner {
  background: rgba(10,18,15,.78);
  border-color: var(--border2);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 16px 50px rgba(0,0,0,.55),
    0 0 0 1px rgba(147,197,253,.05);
}

/* Live section indicator — animated underline pill behind active link */
nav#main-nav .nav-links {
  position: relative;
  margin-left: 8px;
  gap: 0;
  padding: 4px;
  border-radius: 999px;
}
nav#main-nav .nav-links a {
  position: relative;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .005em;
  color: var(--text-muted);
  border-radius: 999px;
  transition: color .25s ease;
  z-index: 2;
}
nav#main-nav .nav-links a::after { display: none; }
nav#main-nav .nav-links a:hover { color: var(--text); }
nav#main-nav .nav-links a.is-active {
  color: var(--ink);
}
.nav-pill-indicator {
  position: absolute;
  top: 4px;
  left: 0;
  height: calc(100% - 8px);
  width: 0;
  background: var(--acid-strong);
  border-radius: 999px;
  transition: transform .45s cubic-bezier(.4,0,.2,1), width .45s cubic-bezier(.4,0,.2,1), opacity .25s ease;
  z-index: 1;
  opacity: 0;
  pointer-events: none;
  box-shadow: 0 0 0 1px rgba(147,197,253,.35), 0 0 24px rgba(147,197,253,.25);
}
.nav-pill-indicator.is-visible { opacity: 1; }

nav#main-nav .nav-brand {
  gap: 9px;
  padding-right: 4px;
  align-items: center;
}
.brand-mark {
  flex-shrink: 0;
  color: var(--text);
  transition: color var(--ease), transform var(--ease);
}
nav#main-nav .nav-brand:hover .brand-mark {
  color: var(--acid-strong);
}
nav#main-nav .nav-name {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .005em;
  text-transform: uppercase;
  color: var(--text);
  display: inline-flex;
  align-items: baseline;
}
.nav-mark-dot {
  color: var(--acid-strong);
  display: inline-block;
  margin-left: 1px;
  text-shadow: 0 0 14px rgba(96,165,250,.6);
  font-weight: 700;
}
.nav-logo { display: none !important; }

nav#main-nav .lang-sw {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  padding: 2px;
}
nav#main-nav .lang-btn {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 4px 9px;
  font-weight: 600;
  letter-spacing: .05em;
}
nav#main-nav .lang-btn.active {
  background: var(--acid-strong);
  color: var(--ink);
  box-shadow: 0 0 0 1px rgba(147,197,253,.4);
}
nav#main-nav .nav-right .btn-grad {
  padding: 9px 18px;
  font-size: 12.5px;
  letter-spacing: .005em;
}
@media (max-width: 1024px) {
  nav#main-nav .nav-links { display: none; }
  .nav-pill-indicator { display: none; }
}
@media (max-width: 640px) {
  nav#main-nav { padding: 10px 12px 0; }
  nav#main-nav .nav-inner { height: 52px; padding-left: 14px; }
  nav#main-nav .nav-right .btn-grad { display: none; }
}

/* Audit nav-link override colors (for new pill nav) */
.nav-link-accent { color: var(--acid) !important; }
.nav-link-accent::after {
  background: var(--acid-strong);
  box-shadow: 0 0 8px var(--acid-strong);
}
nav#main-nav .nav-links a.nav-link-accent.is-active { color: var(--ink) !important; }

/* ── Sticky Mobile Bottom-Bar ─────────────────────────────── */
.mob-bottom-bar {
  display: none;
}
@media (max-width: 1024px) {
  .mob-bottom-bar {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: var(--z-mob-bar);
    padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
    background: rgba(5,8,7,.78);
    backdrop-filter: blur(20px) saturate(160%);
    -webkit-backdrop-filter: blur(20px) saturate(160%);
    border-top: 1px solid var(--border);
    gap: 10px;
    transform: translateY(110%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    pointer-events: none;
  }
  .mob-bottom-bar.is-visible {
    transform: translateY(0);
    pointer-events: auto;
  }
  .mob-bottom-bar a {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 13px 16px;
    border-radius: 999px;
    font-family: var(--font-body);
    font-size: 13.5px;
    font-weight: 600;
    letter-spacing: .005em;
    transition: transform var(--ease), background var(--ease);
  }
  .mob-bottom-bar .mb-audit {
    background: rgba(255,255,255,.03);
    border: 1px solid var(--border2);
    color: var(--o-200);
  }
  .mob-bottom-bar .mb-audit:active { transform: scale(.97); }
  .mob-bottom-bar .mb-cta {
    background: var(--acid-strong);
    color: var(--ink);
    border: 1px solid var(--acid);
    box-shadow: 0 4px 16px rgba(147,197,253,.25);
  }
  .mob-bottom-bar .mb-cta:active { transform: scale(.97); }
  .mob-bottom-bar .mb-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--acid-strong);
    box-shadow: 0 0 8px var(--acid-strong);
    animation: au-pulse 2s ease-in-out infinite;
    flex-shrink: 0;
  }
}

/* ── Hero canvas hidden (replaced by global mesh-bg) ──────── */
#hero-canvas {
  display: none !important;
}
.hero-vignette {
  background:
    radial-gradient(ellipse 70% 50% at 50% 50%, transparent 30%, rgba(5,8,7,.4) 75%, var(--bg) 100%);
}

/* ── Display + Mono utilities ─────────────────────────────── */
.font-display {
  font-family: var(--font-display);
  letter-spacing: .005em;
  font-weight: 400;
}
.font-mono {
  font-family: var(--font-mono);
  font-feature-settings: 'ss01', 'ss02';
}
.kbd-tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  padding: 4px 9px;
  border-radius: 6px;
  border: 1px solid var(--border2);
  background: rgba(255,255,255,.02);
  color: var(--text-soft);
  text-transform: uppercase;
}

/* ── Audit form error message ─────────────────────────────── */
.au-error {
  margin-top: 14px;
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(252,165,165,.08);
  border: 1px solid rgba(252,165,165,.32);
  color: #fca5a5;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.45;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transform: translateY(-4px);
  transition: opacity .25s ease, max-height .35s ease, transform .25s ease, margin-top .25s ease;
}
.au-error.is-visible {
  opacity: 1;
  max-height: 120px;
  transform: translateY(0);
  margin-top: 14px;
}
.au-submit:disabled { opacity: .65; cursor: wait; }

/* Restore body scroll padding so anchor scrolls don't hide under floating nav */
html { scroll-padding-top: 96px; }
@media (max-width: 1024px) { html { scroll-padding-top: 80px; } }

/* ── Contact form privacy consent ─────────────────────────── */
.f-consent {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  cursor: pointer;
  user-select: none;
  margin: -4px 0 18px;
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--text-muted);
}
.f-consent input { position: absolute; opacity: 0; pointer-events: none; }
.f-consent-box {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border: 1.5px solid var(--border2);
  border-radius: 5px;
  background: rgba(255,255,255,.025);
  position: relative;
  transition: all var(--ease);
  margin-top: 1px;
}
.f-consent-box::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23050507' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 11px;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0;
  transition: opacity var(--ease);
}
.f-consent input:checked + .f-consent-box {
  background: var(--acid-strong);
  border-color: var(--acid-strong);
  box-shadow: 0 0 0 3px rgba(96,165,250,.18);
}
.f-consent input:checked + .f-consent-box::after { opacity: 1; }
.f-consent input:focus-visible + .f-consent-box {
  box-shadow: 0 0 0 3px rgba(96,165,250,.35);
}
.f-consent-text a {
  color: var(--acid-strong);
  border-bottom: 1px solid rgba(96,165,250,.4);
  transition: color var(--ease), border-color var(--ease);
}
.f-consent-text a:hover {
  color: var(--acid);
  border-color: var(--acid);
}

/* ── Cookie / Consent Banner ──────────────────────────────── */
.consent-banner {
  position: fixed;
  bottom: 16px; left: 16px; right: 16px;
  max-width: 520px;
  margin: 0 auto;
  z-index: 1200;
  padding: 18px 22px 16px;
  background: rgba(10,10,15,.92);
  border: 1px solid var(--border2);
  border-radius: 18px;
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: 0 16px 50px rgba(0,0,0,.55);
  transform: translateY(160%);
  transition: transform .45s cubic-bezier(.4,0,.2,1);
}
.consent-banner.is-visible { transform: translateY(0); }
.consent-banner h3 {
  font-family: var(--font-headline);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 6px;
  letter-spacing: -.005em;
}
.consent-banner p {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-muted);
  margin: 0 0 14px;
}
.consent-banner p a {
  color: var(--acid-strong);
  border-bottom: 1px solid rgba(96,165,250,.4);
}
.consent-banner-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.consent-btn {
  flex: 1;
  min-width: 110px;
  padding: 10px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--ease);
}
.consent-btn-accept {
  background: var(--acid-strong);
  color: var(--ink);
  border: 1px solid var(--acid-strong);
}
.consent-btn-accept:hover { background: var(--acid); border-color: var(--acid); }
.consent-btn-decline {
  background: rgba(255,255,255,.04);
  color: var(--text-soft);
  border: 1px solid var(--border2);
}
.consent-btn-decline:hover {
  background: rgba(255,255,255,.08);
  color: var(--text);
}
@media (max-width: 480px) {
  .consent-banner { left: 8px; right: 8px; bottom: 8px; padding: 16px 18px 14px; }
  .consent-banner-actions { flex-direction: column; }
  .consent-btn { flex: none; width: 100%; }
}
