/* ─────────────────────────────────────────────
 * LawOs — Landing Beta Privada Julio 2026
 * SF startup aesthetic: dark, premium, kinetic
 * ───────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
  /* Surfaces */
  --ebony:        #0A0A0C;
  --surface:      #141418;
  --raised:       #1C1C22;
  --hover:        #222228;
  --line:         #27272A;
  --line-strong:  #3F3F46;

  /* Text */
  --ink:          #FAFAFA;
  --ink-2:        #D4D4D8;
  --ink-3:        #A1A1AA;
  --ink-4:        #71717A;
  --ink-faint:    #52525B;

  /* Brand */
  --blue:         #0A84FF;
  --blue-bright:  #2D9DFF;
  --cyan:         #00D4FF;
  --blue-soft:    rgba(10, 132, 255, 0.14);
  --blue-glow:    rgba(10, 132, 255, 0.22);
  --cyan-glow:    rgba(0, 212, 255, 0.20);

  --pursue:       #34D399;
  --pursue-soft:  rgba(52, 211, 153, 0.12);
  --nurture:      #FBBF24;
  --crimson:      #E63A46;

  --r-xs: 4px; --r-sm: 6px; --r-md: 8px; --r-lg: 12px; --r-xl: 16px; --r-2xl: 24px; --r-pill: 999px;

  --t-micro: 10px;
  --t-cap:   11px;
  --t-xs:    12px;
  --t-sm:    13px;
  --t-base:  14px;
  --t-md:    16px;
  --t-lg:    18px;
  --t-xl:    22px;
  --t-2xl:   30px;
  --t-3xl:   44px;
  --t-display: 64px;

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}

* { box-sizing: border-box; }
::selection { background: var(--blue); color: #fff; }

html, body {
  margin: 0;
  background: var(--ebony);
  color: var(--ink);
  font-family: 'Inter', -apple-system, system-ui, sans-serif;
  font-size: var(--t-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'cv11', 'ss01', 'ss03';
  overflow-x: hidden;
}

html { scroll-behavior: smooth; }

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }

.mono { font-family: 'JetBrains Mono', ui-monospace, monospace; font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }

/* ── Layout ───────────────────────────────────── */
.wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
.wrap-tight { max-width: 1040px; margin: 0 auto; padding: 0 32px; }

section { position: relative; padding: 140px 0; }
section + section { border-top: 1px solid var(--line); }

/* ── Type ─────────────────────────────────────── */
.kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--t-cap); font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--cyan); margin-bottom: 24px;
}
.kicker::before {
  content: ''; width: 18px; height: 1px; background: var(--cyan); opacity: 0.6;
}

h1, h2, h3, h4 { font-family: 'Space Grotesk', 'Inter', sans-serif; font-weight: 700; letter-spacing: -0.03em; margin: 0; line-height: 1.05; color: var(--ink); }
h1 { font-size: clamp(48px, 7.6vw, 96px); letter-spacing: -0.04em; }
h2 { font-size: clamp(36px, 4.4vw, 60px); letter-spacing: -0.035em; line-height: 1.05; }
h3 { font-size: var(--t-xl); letter-spacing: -0.02em; }
h4 { font-size: var(--t-md); letter-spacing: -0.01em; }

p { color: var(--ink-3); max-width: 62ch; line-height: 1.65; }
p.lead { font-size: clamp(18px, 1.4vw, 22px); color: var(--ink-2); line-height: 1.55; max-width: 60ch; }
p strong { color: var(--ink); font-weight: 600; }

.gradient-text {
  background: linear-gradient(110deg, var(--blue) 0%, var(--cyan) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ── Nav ──────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: 14px 32px;
  display: flex; align-items: center; gap: 24px;
  transition: backdrop-filter .3s, background .3s, border-color .3s;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(10, 10, 12, 0.72);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border-bottom-color: var(--line);
}
.nav-inner { display: flex; align-items: center; gap: 24px; width: 100%; max-width: 1240px; margin: 0 auto; }
.nav-logo { display: flex; align-items: center; gap: 10px; }
.nav-logo img { height: 22px; width: auto; }
.nav-tag {
  font-size: 10px; font-weight: 600; color: var(--cyan);
  padding: 3px 8px; border: 1px solid rgba(0, 212, 255, 0.3);
  background: rgba(0, 212, 255, 0.06);
  border-radius: var(--r-pill); letter-spacing: 0.1em; text-transform: uppercase;
}
.nav-links { display: flex; gap: 4px; margin-left: auto; align-items: center; }
.nav-links a {
  padding: 7px 12px; font-size: var(--t-sm); font-weight: 500; color: var(--ink-3);
  border-radius: var(--r-sm); transition: color .15s, background .15s;
}
.nav-links a:hover { color: var(--ink); background: rgba(255,255,255,0.04); }
.nav-cta {
  padding: 8px 14px; font-size: var(--t-sm); font-weight: 600; color: var(--ink);
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md); transition: background .15s, border-color .15s;
}
.nav-cta:hover { background: rgba(255,255,255,0.1); border-color: var(--blue); }

/* ── Buttons ──────────────────────────────────── */
.btn {
  position: relative;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 20px; font-size: var(--t-base); font-weight: 600;
  border-radius: var(--r-md); border: 1px solid transparent;
  transition: transform .15s var(--ease-out), background .15s, border-color .15s, box-shadow .3s;
  white-space: nowrap; letter-spacing: -0.01em;
}
.btn:active { transform: translateY(1px); }
.btn-primary {
  background: linear-gradient(180deg, var(--blue-bright), var(--blue));
  color: #fff;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.08) inset, 0 8px 24px -8px var(--blue-glow), 0 1px 0 rgba(255,255,255,0.2) inset;
}
.btn-primary:hover {
  box-shadow: 0 0 0 1px rgba(255,255,255,0.12) inset, 0 12px 32px -8px var(--blue-glow), 0 1px 0 rgba(255,255,255,0.3) inset;
  transform: translateY(-1px);
}
.btn-secondary {
  background: rgba(255,255,255,0.04); color: var(--ink);
  border-color: var(--line-strong);
  backdrop-filter: blur(8px);
}
.btn-secondary:hover { background: rgba(255,255,255,0.08); border-color: var(--ink-4); }
.btn-lg { padding: 14px 24px; font-size: var(--t-md); }
.btn-arrow { transition: transform .2s var(--ease-out); }
.btn:hover .btn-arrow { transform: translateX(3px); }

/* ── Hero ─────────────────────────────────────── */
.hero {
  position: relative;
  padding: 220px 0 0;
  overflow: hidden;
  min-height: 100vh;
}
.hero-bg {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(900px 600px at 75% 20%, var(--blue-glow), transparent 60%),
    radial-gradient(700px 500px at 15% 70%, var(--cyan-glow), transparent 60%);
}
.hero-grid {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
}
.hero-spotlight {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(600px circle at var(--mx, 50%) var(--my, 30%), rgba(10,132,255,0.12), transparent 50%);
  transition: background 0.2s;
}
.hero-inner { position: relative; z-index: 1; text-align: center; }

.hero-badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 6px 6px 14px;
  border: 1px solid var(--line);
  background: rgba(20,20,24,0.6); backdrop-filter: blur(12px);
  border-radius: var(--r-pill);
  font-size: var(--t-xs); color: var(--ink-2);
  margin-bottom: 32px;
}
.hero-badge .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 12px var(--cyan);
  animation: pulse 2s var(--ease-in-out) infinite;
}
.hero-badge .pill {
  padding: 3px 10px; background: var(--blue-soft); color: var(--blue-bright);
  font-size: 10px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  border-radius: var(--r-pill);
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.4); }
}

.hero h1 { max-width: 18ch; margin: 0 auto 28px; }
.hero h1 .line { display: block; }
.hero-sub {
  font-size: clamp(17px, 1.3vw, 20px);
  color: var(--ink-3); max-width: 56ch; margin: 0 auto 40px; line-height: 1.5;
}
.hero-ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 24px; }
.hero-microcopy {
  font-size: var(--t-sm); color: var(--ink-4);
  display: inline-flex; align-items: center; gap: 8px;
}
.hero-microcopy svg { color: var(--pursue); }

/* Reveal — content is always visible. (Animation removed because iframe animation
 * clocks freeze at 0% keyframe, leaving content invisible.)
 */
/* Reveal — VISIBLE by default (safe in any environment). Entrance motion is only
 * enabled once JS proves the animation clock runs, by adding html.anim-ready.
 * If rAF/transitions never fire (e.g. frozen preview), the class is never added
 * and content simply stays visible — no hidden-forever bug.
 */
.reveal { opacity: 1; transform: none; }
html.anim-ready .reveal {
  opacity: 0;
  transform: translate3d(0, 26px, 0);
  transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
  will-change: opacity, transform;
}
html.anim-ready .reveal.in { opacity: 1; transform: none; }
html.anim-ready .reveal[data-delay="100"] { transition-delay: .08s; }
html.anim-ready .reveal[data-delay="200"] { transition-delay: .16s; }
html.anim-ready .reveal[data-delay="300"] { transition-delay: .24s; }
html.anim-ready .reveal[data-delay="400"] { transition-delay: .32s; }
html.anim-ready .reveal[data-delay="500"] { transition-delay: .40s; }

/* ── Dashboard preview (animated mockup) ──────── */
.hero-preview {
  position: relative; z-index: 1;
  margin: 80px auto 0;
  max-width: 1100px;
  padding: 0 32px;
}
.preview-frame {
  position: relative;
  border-radius: var(--r-xl);
  background: linear-gradient(180deg, rgba(45,157,255,0.4), transparent 30%);
  padding: 1px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.04),
    0 60px 120px -20px rgba(10,132,255,0.35),
    0 30px 60px -30px rgba(0,212,255,0.25);
}
.preview-frame::before {
  content: ''; position: absolute; inset: -100px -50px 0; z-index: -1;
  background: radial-gradient(60% 50% at 50% 50%, var(--blue-glow), transparent 70%);
  filter: blur(40px);
  pointer-events: none;
}
.preview-inner {
  background: var(--ebony);
  border-radius: calc(var(--r-xl) - 1px);
  overflow: hidden;
}
.preview-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, var(--surface), transparent);
}
.preview-bar .dots { display: flex; gap: 6px; }
.preview-bar .dots span { width: 10px; height: 10px; border-radius: 50%; background: var(--line-strong); }
.preview-bar .addr {
  flex: 1; text-align: center; font-size: var(--t-xs); color: var(--ink-4);
  font-family: 'JetBrains Mono', monospace;
}
.preview-grid {
  display: grid;
  grid-template-columns: 200px 1fr;
  min-height: 480px;
}
.preview-side {
  background: var(--surface); border-right: 1px solid var(--line);
  padding: 16px 12px;
}
.side-brand { display: flex; align-items: center; gap: 8px; padding: 4px 8px 18px; }
.side-brand img { height: 16px; }
.side-section { font-size: 9px; color: var(--ink-faint); letter-spacing: 0.16em; text-transform: uppercase; padding: 12px 10px 4px; }
.side-item {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 10px; border-radius: var(--r-sm);
  font-size: var(--t-xs); color: var(--ink-3);
  margin-bottom: 1px;
}
.side-item svg { width: 14px; height: 14px; flex-shrink: 0; color: var(--ink-4); }
.side-item .ct { margin-left: auto; font-size: 9px; color: var(--ink-4); padding: 1px 6px; background: var(--ebony); border-radius: var(--r-pill); border: 1px solid var(--line); }
.side-item.active { background: var(--blue-soft); color: var(--blue-bright); }
.side-item.active svg { color: var(--blue-bright); }

.preview-main { padding: 20px 24px; background: var(--ebony); }
.preview-head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px;
}
.preview-head h4 { font-size: var(--t-md); letter-spacing: -0.02em; }
.preview-head .sub { font-size: 10px; color: var(--ink-4); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 2px; }

.kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 18px; }
.kpi-cell {
  padding: 12px 14px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.kpi-cell .lbl { font-size: 9px; color: var(--ink-4); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 4px; }
.kpi-cell .val { font-size: 22px; font-weight: 800; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.kpi-cell .dlt { font-size: 9px; color: var(--pursue); margin-top: 2px; }

.lead-table { width: 100%; border-collapse: collapse; font-size: var(--t-xs); }
.lead-table thead th {
  text-align: left; font-size: 9px; font-weight: 600;
  color: var(--ink-4); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 8px 10px; border-bottom: 1px solid var(--line);
}
.lead-table td {
  padding: 10px; border-bottom: 1px solid var(--line);
  color: var(--ink-2); font-size: var(--t-xs);
}
.lead-table .badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 9px; font-weight: 500; padding: 2px 6px; border-radius: var(--r-pill);
}
.lead-table .badge .d { width: 5px; height: 5px; border-radius: 50%; }
.badge.pursue { background: var(--pursue-soft); color: var(--pursue); }
.badge.pursue .d { background: var(--pursue); }
.badge.nurture { background: rgba(251,191,36,0.12); color: var(--nurture); }
.badge.nurture .d { background: var(--nurture); }
.badge.clarify { background: rgba(96,165,250,0.12); color: #60A5FA; }
.badge.clarify .d { background: #60A5FA; }

/* Lead rows always visible */
.lead-row { opacity: 1; }

.live-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px; border-radius: var(--r-pill);
  background: var(--pursue-soft); color: var(--pursue);
  font-size: 10px; font-weight: 600;
}
.live-pill .d { width: 6px; height: 6px; border-radius: 50%; background: var(--pursue); animation: pulse 1.8s infinite; }

/* ── Sections ─────────────────────────────────── */
.section-head { margin-bottom: 64px; max-width: 760px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head p { margin-top: 20px; }
.section-head.center p { margin-left: auto; margin-right: auto; }

/* Lead magnet */
.lead-magnet {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: center;
}
/* ── Ebook cover (faithful replica of the real ebook) ─────── */
.ebook-cover {
  position: relative;
  aspect-ratio: 3 / 4;
  background:
    radial-gradient(900px 600px at 80% -5%, var(--blue-glow), transparent 55%),
    radial-gradient(700px 600px at -10% 100%, var(--cyan-glow), transparent 55%),
    var(--surface);
  border-radius: var(--r-xl);
  border: 1px solid var(--line-strong);
  overflow: hidden;
  display: flex; flex-direction: column;
  transform: perspective(1400px) rotateY(-7deg) rotateX(3deg);
  transition: transform .6s var(--ease-out), box-shadow .6s var(--ease-out);
  box-shadow:
    0 50px 100px -30px rgba(0,0,0,0.7),
    0 30px 60px -30px var(--blue-glow),
    0 0 0 1px rgba(255,255,255,0.04) inset;
  will-change: transform;
}
.ebook-cover:hover { transform: perspective(1400px) rotateY(-2deg) rotateX(1deg); }
.ebook-cover::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; z-index: 3;
  background: linear-gradient(90deg, transparent, var(--blue), var(--cyan), transparent);
}
.ec-glow {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(420px circle at 78% 8%, rgba(0,212,255,0.10), transparent 60%);
}
.ec-grid {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 34px 34px;
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 60% 20%, #000, transparent 80%);
  mask-image: radial-gradient(ellipse 80% 70% at 60% 20%, #000, transparent 80%);
}
.ec-inner {
  position: relative; z-index: 1; flex: 1;
  padding: clamp(24px, 3vw, 40px);
  display: flex; flex-direction: column;
}
.ec-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.ec-logo { width: clamp(96px, 11vw, 128px); height: auto; }
.ec-yr {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-4); white-space: nowrap;
}
.ec-mid { margin-top: auto; }
.ec-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(11px, 1vw, 13px); letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--cyan); margin-bottom: 16px;
}
.ec-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700; font-size: clamp(28px, 3.6vw, 48px);
  line-height: 0.98; letter-spacing: -0.03em; color: var(--ink);
  margin: 0 0 16px; max-width: 13ch;
}
.grad-text {
  background: linear-gradient(118deg, var(--blue) 0%, var(--cyan) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ec-tagline {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(15px, 1.6vw, 20px); font-weight: 500;
  color: var(--ink); letter-spacing: -0.01em; margin-bottom: 14px;
}
.ec-sub {
  font-size: clamp(12px, 1.1vw, 14px); color: var(--ink-3);
  line-height: 1.55; max-width: 42ch; margin: 0;
}
.ec-meta { display: flex; gap: 0; margin: clamp(24px, 3vw, 40px) 0 0; }
.ec-meta > div { padding-right: clamp(14px, 1.6vw, 24px); margin-right: clamp(14px, 1.6vw, 24px); border-right: 1px solid var(--line); }
.ec-meta > div:last-child { border-right: 0; padding-right: 0; margin-right: 0; }
.ec-meta dt { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 5px; }
.ec-meta dd { margin: 0; font-size: clamp(11px, 1vw, 13px); color: var(--ink); font-weight: 600; }
.ec-disc {
  position: relative; z-index: 1;
  padding: 14px clamp(24px, 3vw, 40px);
  border-top: 1px solid var(--line);
  background: rgba(10,10,12,0.5);
  font-size: 10px; color: var(--ink-faint); line-height: 1.5;
}
.lm-bullet-list { margin-top: 32px; display: flex; flex-direction: column; gap: 14px; }
.lm-bullet {
  display: flex; gap: 14px; align-items: flex-start;
  font-size: var(--t-base); color: var(--ink-2); line-height: 1.5;
}
.lm-bullet .num {
  flex-shrink: 0; width: 26px; height: 26px;
  background: var(--blue-soft); color: var(--blue-bright);
  border-radius: var(--r-sm); border: 1px solid rgba(10,132,255,0.2);
  font-size: 11px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  font-variant-numeric: tabular-nums;
}

/* Problem section */
.problem-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 64px;
}
.problem-card {
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  transition: transform .3s var(--ease-out), border-color .3s, background .3s;
}
.problem-card:hover { transform: translateY(-4px); border-color: var(--line-strong); background: var(--raised); }
.problem-card .ico {
  width: 36px; height: 36px;
  background: rgba(230,58,70,0.08); color: var(--crimson);
  border-radius: var(--r-sm);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
  border: 1px solid rgba(230,58,70,0.18);
}
.problem-card h4 { margin-bottom: 8px; color: var(--ink); font-size: var(--t-md); }
.problem-card p { font-size: var(--t-sm); color: var(--ink-3); }

/* Change / contrast */
.change-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--line); border-radius: var(--r-xl);
  overflow: hidden;
  margin-top: 64px;
  background: var(--surface);
}
.change-col {
  padding: 40px 36px;
  position: relative;
}
.change-col + .change-col { border-left: 1px solid var(--line); }
.change-col.bad::before, .change-col.good::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
}
.change-col.bad::before { background: linear-gradient(90deg, var(--crimson), transparent); }
.change-col.good::before { background: linear-gradient(90deg, var(--blue), var(--cyan)); }
.change-col .label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill); display: inline-block; margin-bottom: 18px;
}
.change-col.bad .label { background: rgba(230,58,70,0.1); color: var(--crimson); }
.change-col.good .label { background: var(--blue-soft); color: var(--blue-bright); }
.change-col h3 { margin-bottom: 24px; font-size: 22px; }
.change-list { display: flex; flex-direction: column; gap: 12px; list-style: none; padding: 0; margin: 0; }
.change-list li { font-size: var(--t-sm); color: var(--ink-2); display: flex; gap: 10px; align-items: flex-start; }
.change-list li svg { flex-shrink: 0; margin-top: 3px; }
.change-col.bad svg { color: var(--crimson); }
.change-col.good svg { color: var(--pursue); }

/* Capabilities */
.cap-bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(220px, auto);
  gap: 16px; margin-top: 64px;
}
.cap {
  position: relative;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color .3s, transform .3s var(--ease-out);
}
.cap:hover { border-color: var(--line-strong); }
.cap.sp-3 { grid-column: span 3; }
.cap.sp-2 { grid-column: span 2; }
.cap.sp-4 { grid-column: span 4; }
.cap.tall { grid-row: span 2; }

.cap-num {
  position: absolute; top: 20px; right: 24px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--ink-faint); letter-spacing: 0.1em;
}
.cap h4 { font-size: 18px; margin-bottom: 10px; letter-spacing: -0.02em; }
.cap p { font-size: var(--t-sm); color: var(--ink-3); max-width: 38ch; }

.cap-viz { margin-top: 24px; position: relative; }

/* Lead pipeline viz */
.viz-pipeline { display: flex; gap: 6px; align-items: stretch; height: 100px; }
.viz-pipeline .stage {
  flex: 1; background: var(--ebony); border: 1px solid var(--line);
  border-radius: var(--r-sm); padding: 8px; display: flex; flex-direction: column; gap: 4px;
  font-size: 9px; color: var(--ink-4);
}
.viz-pipeline .stage .n { font-size: 16px; font-weight: 700; color: var(--ink); letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.viz-pipeline .stage.hot { border-color: var(--blue); background: linear-gradient(180deg, var(--blue-soft), transparent); }
.viz-pipeline .stage.hot .n { color: var(--blue-bright); }

/* Intake viz */
.viz-intake { display: flex; flex-direction: column; gap: 8px; }
.viz-intake .field {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; background: var(--ebony); border: 1px solid var(--line);
  border-radius: var(--r-sm); font-size: 10px;
}
.viz-intake .field .lbl { color: var(--ink-4); flex: 1; }
.viz-intake .field .val { color: var(--ink); font-weight: 500; }
.viz-intake .field.ok { border-color: rgba(52,211,153,0.3); }
.viz-intake .field.ok::after { content: '✓'; color: var(--pursue); font-weight: 700; }

/* Case context viz */
.viz-case { padding: 14px; background: var(--ebony); border: 1px solid var(--line); border-radius: var(--r-sm); }
.viz-case .ttl { font-size: var(--t-sm); color: var(--ink); font-weight: 600; margin-bottom: 8px; }
.viz-case .meta { font-size: 10px; color: var(--ink-4); margin-bottom: 12px; font-family: 'JetBrains Mono', monospace; }
.viz-case .timeline { display: flex; flex-direction: column; gap: 6px; }
.viz-case .tl-row { display: flex; gap: 8px; align-items: flex-start; font-size: 10px; color: var(--ink-3); }
.viz-case .tl-dot { width: 7px; height: 7px; border-radius: 50%; margin-top: 4px; flex-shrink: 0; background: var(--ink-faint); }
.viz-case .tl-dot.now { background: var(--blue); box-shadow: 0 0 0 3px var(--blue-soft); }
.viz-case .tl-dot.done { background: var(--pursue); }
.viz-case .tl-row strong { color: var(--ink); font-weight: 500; }

/* Doc viz */
.viz-docs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.viz-docs .doc {
  padding: 10px; background: var(--ebony); border: 1px solid var(--line); border-radius: var(--r-sm);
  display: flex; flex-direction: column; gap: 4px;
}
.viz-docs .doc .ico { width: 20px; height: 20px; border-radius: 3px; background: var(--blue-soft); color: var(--blue-bright); display: inline-flex; align-items: center; justify-content: center; }
.viz-docs .doc .nm { font-size: 10px; color: var(--ink-2); font-weight: 500; }
.viz-docs .doc .sz { font-size: 9px; color: var(--ink-4); font-family: 'JetBrains Mono', monospace; }

/* Report viz */
.viz-report { padding: 16px; background: var(--ebony); border: 1px solid var(--line); border-radius: var(--r-sm); }
.viz-report .header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 8px; border-bottom: 1px solid var(--line); margin-bottom: 10px; }
.viz-report .header .nm { font-size: 11px; font-weight: 600; }
.viz-report .header .dt { font-size: 9px; color: var(--ink-4); font-family: 'JetBrains Mono', monospace; }
.viz-report .lines { display: flex; flex-direction: column; gap: 6px; }
.viz-report .ln { height: 6px; background: var(--surface); border-radius: 2px; }
.viz-report .ln:nth-child(1) { width: 90%; }
.viz-report .ln:nth-child(2) { width: 75%; }
.viz-report .ln:nth-child(3) { width: 85%; background: linear-gradient(90deg, var(--blue), var(--cyan)); width: 65%; }
.viz-report .ln:nth-child(4) { width: 70%; }

/* Comms viz */
.viz-comms { display: flex; flex-direction: column; gap: 6px; }
.viz-comms .msg {
  display: flex; gap: 8px; padding: 8px 10px;
  background: var(--ebony); border: 1px solid var(--line); border-radius: var(--r-sm);
  font-size: 10px;
}
.viz-comms .msg .av { width: 18px; height: 18px; border-radius: 50%; background: linear-gradient(135deg, var(--blue), var(--cyan)); color: #001a2a; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-size: 9px; flex-shrink: 0; }
.viz-comms .msg .bd { color: var(--ink-2); }
.viz-comms .msg .nm { color: var(--ink); font-weight: 600; font-size: 10px; }
.viz-comms .msg .ts { color: var(--ink-faint); font-size: 9px; margin-left: auto; font-family: 'JetBrains Mono', monospace; }

/* Intel viz */
.viz-intel { display: flex; flex-direction: column; gap: 6px; }
.viz-intel .alert {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 10px; border-radius: var(--r-sm);
  background: var(--ebony); border: 1px solid var(--line);
  font-size: 10px;
}
.viz-intel .alert.warn { border-left: 2px solid var(--nurture); }
.viz-intel .alert.crit { border-left: 2px solid var(--crimson); }
.viz-intel .alert.ok { border-left: 2px solid var(--pursue); }
.viz-intel .alert .ttl { color: var(--ink); font-weight: 600; margin-bottom: 2px; }
.viz-intel .alert .ds { color: var(--ink-4); font-size: 9px; }

/* Aspirational */
.asp {
  text-align: center; padding: 180px 0;
  background:
    radial-gradient(800px 500px at 50% 50%, var(--blue-glow), transparent 70%),
    var(--ebony);
}
.asp h2 { max-width: 22ch; margin: 0 auto 56px; font-size: clamp(36px, 5vw, 64px); }
.asp-list {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0; max-width: 720px; margin: 56px auto;
  text-align: left;
  border: 1px solid var(--line); border-radius: var(--r-xl);
  overflow: hidden;
  background: rgba(20,20,24,0.5); backdrop-filter: blur(8px);
}
.asp-list .row {
  padding: 18px 24px;
  border-bottom: 1px solid var(--line);
  display: flex; gap: 14px; align-items: center;
  font-size: var(--t-base); color: var(--ink-2);
}
.asp-list .row:nth-child(odd) { border-right: 1px solid var(--line); }
.asp-list .row:nth-last-child(-n+2) { border-bottom: 0; }
.asp-list .row svg { color: var(--cyan); flex-shrink: 0; }
.asp-conclusion { font-size: var(--t-lg); color: var(--ink); margin: 0; font-weight: 600; }
.asp-conclusion + .asp-conclusion { color: var(--ink-3); font-weight: 400; margin-top: 8px; }

/* Beta offer */
.offer {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: stretch;
}
.offer-left { display: flex; flex-direction: column; justify-content: center; }
.offer-card {
  padding: 40px;
  background:
    linear-gradient(160deg, rgba(10,132,255,0.06), transparent 60%),
    var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  position: relative;
  overflow: hidden;
}
.offer-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--blue), var(--cyan), transparent);
}
.offer-card h3 { margin-bottom: 28px; letter-spacing: -0.02em; }
.offer-card .list { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; gap: 14px; }
.offer-card .list li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: var(--t-base); color: var(--ink-2);
  padding-bottom: 14px; border-bottom: 1px dashed var(--line);
}
.offer-card .list li:last-child { border-bottom: 0; padding-bottom: 0; }
.offer-card .list svg { flex-shrink: 0; margin-top: 2px; color: var(--cyan); }
.offer-microcopy { font-size: var(--t-xs); color: var(--ink-4); margin-top: 16px; line-height: 1.5; max-width: 60ch; }

/* For whom */
.audience-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 12px; margin-top: 64px;
}
.aud {
  padding: 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  transition: transform .3s var(--ease-out), border-color .3s, background .3s;
}
.aud:hover { transform: translateY(-3px); border-color: var(--blue); background: var(--raised); }
.aud .ico { color: var(--cyan); margin-bottom: 16px; }
.aud h4 { font-size: var(--t-md); margin-bottom: 8px; }
.aud p { font-size: var(--t-sm); color: var(--ink-3); margin: 0; }

.audience-no {
  margin-top: 40px;
  padding: 28px 32px;
  background: linear-gradient(135deg, rgba(10,132,255,0.06), transparent);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  display: flex; gap: 24px; align-items: center;
}
.audience-no .x { font-size: 48px; font-weight: 200; color: var(--crimson); line-height: 1; }
.audience-no h4 { font-size: var(--t-md); margin: 0; color: var(--ink-3); font-weight: 500; }
.audience-no h4 + h4 { color: var(--ink); margin-top: 4px; font-weight: 700; }

/* Differentiator */
.diff {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.diff-quote {
  font-size: clamp(28px, 3.2vw, 44px); font-weight: 700;
  letter-spacing: -0.03em; line-height: 1.15;
  color: var(--ink);
}
.diff-quote .strike { color: var(--ink-faint); text-decoration: line-through; text-decoration-thickness: 2px; }
.diff-quote .gradient-text { font-weight: 800; }

.diff-stack {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 4px;
  display: flex; flex-direction: column; gap: 4px;
}
.diff-layer {
  padding: 18px 22px;
  background: var(--ebony);
  border-radius: var(--r-md);
  display: flex; align-items: center; gap: 16px;
  font-size: var(--t-sm);
  border: 1px solid transparent;
}
.diff-layer .ord { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--ink-4); }
.diff-layer .nm { font-weight: 700; color: var(--ink); font-size: var(--t-md); letter-spacing: -0.01em; }
.diff-layer .ds { color: var(--ink-3); font-size: var(--t-xs); margin-left: auto; }
.diff-layer.first { background: linear-gradient(135deg, var(--blue-soft), transparent); border-color: rgba(10,132,255,0.3); }
.diff-layer.first .nm { color: var(--blue-bright); }
.diff-layer.last { background: linear-gradient(135deg, rgba(0,212,255,0.08), transparent); border-color: rgba(0,212,255,0.2); }
.diff-layer.last .nm { color: var(--cyan); }

/* Form */
.form-wrap {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 80px;
  align-items: start;
}
.form-meta h2 { margin-bottom: 20px; }
.form-meta p { color: var(--ink-3); max-width: 42ch; }
.form-meta .perks {
  margin-top: 32px; padding: 24px; border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--surface);
  display: flex; flex-direction: column; gap: 14px;
}
.form-meta .perks .row { display: flex; gap: 12px; font-size: var(--t-sm); color: var(--ink-2); }
.form-meta .perks svg { color: var(--cyan); flex-shrink: 0; margin-top: 2px; }

.form-card {
  padding: 36px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  position: relative;
}
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field.full { grid-column: span 2; }
.field label { font-size: var(--t-xs); color: var(--ink-3); font-weight: 500; letter-spacing: 0; }
.field input, .field select, .field textarea {
  padding: 11px 14px; font-size: var(--t-sm);
  background: var(--ebony); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--r-md);
  transition: border-color .15s, box-shadow .15s;
  font-family: inherit;
}
.field input::placeholder { color: var(--ink-faint); }
.field input:focus, .field select:focus, .field textarea:focus { outline: 0; border-color: var(--blue); box-shadow: 0 0 0 3px var(--blue-soft); }

.form-card button[type=submit] { width: 100%; margin-top: 24px; justify-content: center; }
.form-card .legal { margin-top: 16px; font-size: 11px; color: var(--ink-4); line-height: 1.55; }

/* CTA closing */
.cta-final {
  text-align: center; padding: 180px 0;
  position: relative; overflow: hidden;
  background: var(--ebony);
}
.cta-final::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(900px 500px at 50% 100%, var(--blue-glow), transparent 70%),
    radial-gradient(700px 400px at 30% 0%, var(--cyan-glow), transparent 60%);
}
.cta-final-inner { position: relative; z-index: 1; }
.cta-final h2 { max-width: 22ch; margin: 0 auto 24px; font-size: clamp(40px, 5.5vw, 72px); }
.cta-final p { margin: 0 auto 40px; max-width: 50ch; font-size: var(--t-md); color: var(--ink-2); }
.cta-final-ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.cta-final-list { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; margin-top: 56px; font-size: var(--t-xs); color: var(--ink-4); }
.cta-final-list span { display: inline-flex; align-items: center; gap: 6px; }
.cta-final-list span::before { content: ''; width: 4px; height: 4px; background: var(--ink-faint); border-radius: 50%; }

/* Footer */
.footer {
  padding: 56px 0 32px;
  border-top: 1px solid var(--line);
  background: var(--ebony);
}
.footer-row { display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.footer-brand { display: flex; align-items: center; gap: 12px; }
.footer-brand img { height: 18px; }
.footer-meta { font-size: var(--t-xs); color: var(--ink-4); }
.footer-links { display: flex; gap: 20px; font-size: var(--t-xs); color: var(--ink-3); }
.footer-links a:hover { color: var(--ink); }

/* Marquee of capabilities (used as a stream banner) */
.marquee {
  position: relative;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 24px 0; overflow: hidden;
  background: var(--surface);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.marquee-track {
  display: flex; gap: 64px; width: max-content;
  animation: marquee 38s linear infinite;
}
.marquee-track .it {
  display: flex; align-items: center; gap: 10px;
  font-size: var(--t-sm); color: var(--ink-3);
  letter-spacing: -0.01em; white-space: nowrap;
}
.marquee-track .it svg { color: var(--cyan); }
.marquee-track .sep { color: var(--line-strong); }
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ── Form section — inline offer card ─────────── */
.form-card {
  position: relative;
  padding: 32px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,0.5),
    0 0 0 1px rgba(255,255,255,0.02);
}
.form-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; z-index: 2;
  background: linear-gradient(90deg, transparent, var(--blue), var(--cyan), transparent);
}
.form-card::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 50% 0%, var(--blue-glow), transparent 60%);
  pointer-events: none; opacity: 0.5;
}
.form-card > * { position: relative; z-index: 1; }
.form-card-head { margin-bottom: 22px; }
.form-card-head .row { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.form-card-head h3 { font-size: var(--t-xl); letter-spacing: -0.02em; margin: 0; }
.form-card-head .sub { font-size: var(--t-xs); color: var(--ink-3); margin-top: 4px; max-width: 36ch; }
.form-card-head .live-pill { flex-shrink: 0; white-space: nowrap; }
.form-card .legal { margin: 16px 0 0; }

.offer-inline-list { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 12px; }
.offer-inline-list li { display: flex; gap: 10px; align-items: center; font-size: var(--t-sm); color: var(--ink-2); }
.offer-inline-list svg { color: var(--cyan); flex-shrink: 0; }

/* ── Form popup (custom LawOs form → HighLevel) ─ */
.form-popup {
  position: fixed; inset: 0; z-index: 200;
  display: none;
  align-items: center; justify-content: center;
  padding: 24px;
}
.form-popup.open { display: flex; }
.form-popup-backdrop {
  position: absolute; inset: 0;
  background: rgba(6, 6, 8, 0.78);
  backdrop-filter: blur(16px) saturate(130%);
  -webkit-backdrop-filter: blur(16px) saturate(130%);
}
.form-popup-shell {
  position: relative;
  width: 100%;
  max-width: 940px;
  height: min(800px, calc(100vh - 40px));
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  overflow: hidden;
  display: grid;
  grid-template-columns: 340px 1fr;
  box-shadow:
    0 40px 80px -20px rgba(0, 0, 0, 0.6),
    0 0 0 1px rgba(255,255,255,0.04),
    0 0 60px -10px var(--blue-glow);
}
.form-popup-shell::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--blue), var(--cyan), transparent);
  z-index: 4;
}

/* Left rail — LawOs branded */
.fp-rail {
  position: relative;
  padding: 32px 28px;
  display: flex; flex-direction: column; justify-content: space-between;
  gap: 28px;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(10,132,255,0.16), transparent 55%),
    radial-gradient(100% 70% at 100% 100%, rgba(0,212,255,0.12), transparent 60%),
    linear-gradient(180deg, var(--raised), var(--surface));
  border-right: 1px solid var(--line);
  overflow: hidden;
}
.fp-rail-grid {
  position: absolute; inset: 0; pointer-events: none; opacity: 0.5;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 90% 70% at 30% 20%, #000, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 90% 70% at 30% 20%, #000, transparent 75%);
}
.fp-rail-top { position: relative; z-index: 1; }
.fp-rail-brand { display: flex; align-items: center; gap: 10px; margin-bottom: 28px; flex-wrap: wrap; }
.fp-rail-brand img { height: 20px; width: auto; }
.fp-rail-brand .nav-tag { white-space: nowrap; }
.fp-rail-title { font-size: 26px; line-height: 1.1; letter-spacing: -0.03em; margin: 0 0 12px; }
.fp-rail-sub { font-size: var(--t-sm); color: var(--ink-3); margin: 0 0 22px; line-height: 1.55; }

/* Mini product preview in rail */
.fp-mini {
  background: rgba(10,10,12,0.6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 12px;
  margin-bottom: 22px;
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 32px -16px rgba(0,0,0,0.6);
}
.fp-mini-head { display: flex; align-items: center; gap: 7px; margin-bottom: 10px; white-space: nowrap; }
.fp-mini-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--pursue); box-shadow: 0 0 8px var(--pursue); flex-shrink: 0; }
.fp-mini-ttl { font-size: 11px; font-weight: 600; color: var(--ink-2); letter-spacing: -0.01em; white-space: nowrap; }
.fp-mini-live { margin-left: auto; font-size: 8.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--pursue); font-weight: 600; white-space: nowrap; }
.fp-mini-row {
  display: flex; align-items: center; gap: 9px;
  padding: 7px 0; border-top: 1px solid var(--line);
}
.fp-mini-av {
  width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700; color: #001018;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
}
.fp-mini-info { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.fp-mini-info strong { font-size: 11px; color: var(--ink); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fp-mini-info span { font-size: 9px; color: var(--ink-4); }
.fp-mini-badge {
  font-size: 8.5px; font-weight: 600; padding: 2px 7px; border-radius: var(--r-pill); white-space: nowrap;
}
.fp-mini-badge.pursue { background: var(--pursue-soft); color: var(--pursue); }
.fp-mini-badge.clarify { background: rgba(96,165,250,0.14); color: #60A5FA; }
.fp-mini-spark { display: flex; align-items: flex-end; gap: 3px; height: 26px; margin-top: 9px; padding-top: 9px; border-top: 1px solid var(--line); }
.fp-mini-spark i { flex: 1; background: linear-gradient(180deg, var(--cyan), var(--blue)); border-radius: 2px 2px 0 0; opacity: 0.85; }
.fp-mini-spark i:last-child { opacity: 1; box-shadow: 0 -6px 16px var(--blue-glow); }
.fp-rail-perks { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.fp-rail-perks li { display: flex; gap: 10px; align-items: flex-start; font-size: var(--t-sm); color: var(--ink-2); line-height: 1.4; }
.fp-rail-perks svg { color: var(--cyan); flex-shrink: 0; margin-top: 1px; }
.fp-rail-bottom { position: relative; z-index: 1; }
.fp-cupos-row { display: flex; justify-content: space-between; align-items: baseline; font-size: var(--t-xs); color: var(--ink-3); margin-bottom: 8px; }
.fp-cupos-row .mono { color: var(--cyan); font-weight: 600; }
.fp-cupos-bar { height: 5px; border-radius: var(--r-pill); background: var(--ebony); border: 1px solid var(--line); overflow: hidden; }
.fp-cupos-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--blue), var(--cyan)); border-radius: inherit; }
.fp-rail-legal { font-size: 10.5px; color: var(--ink-4); margin: 18px 0 0; line-height: 1.5; }

/* Right column */
.fp-main { display: flex; flex-direction: column; min-width: 0; min-height: 0; overflow: hidden; }

.form-popup-header {
  padding: 26px 64px 18px 28px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(10,132,255,0.06), transparent);
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
  flex-shrink: 0;
  position: relative; z-index: 2;
}
.form-popup-header h3 { margin: 0; color: var(--ink); font-size: var(--t-xl); letter-spacing: -0.02em; }
.form-popup-header .sub { font-size: var(--t-xs); color: var(--ink-3); margin-top: 4px; }
.form-popup-header .sub strong { color: var(--ink); }
.form-popup-header .live-pill { flex-shrink: 0; white-space: nowrap; }
.fp-step {
  flex-shrink: 0; white-space: nowrap;
  font-size: 10px; color: var(--ink-4);
  padding: 4px 10px; border: 1px solid var(--line);
  border-radius: var(--r-pill); background: rgba(255,255,255,0.02);
  align-self: center;
}
.form-popup-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  background: var(--ebony);
  padding: 0;
  position: relative;
  color-scheme: dark;
}
.form-popup-body iframe {
  width: 100%;
  min-height: 760px;
  /* Crop HighLevel's white page margin at the top so it sits flush under our header.
     overflow-y:auto on the parent means this clipped top area simply isn't scrollable. */
  margin-top: -20px;
  border: 0;
  display: block;
  background: var(--ebony);
  /* color-scheme intentionally omitted: HighLevel form ships its own
     light theme; forcing dark on the iframe made input text dark-on-dark
     (invisible while typing). Parent .form-popup-body keeps color-scheme:
     dark so our scrollbar stays themed. */
}
/* Skeleton while the HighLevel form loads */
.hl-skel {
  position: absolute; inset: 0; z-index: 1;
  padding: 28px; display: flex; flex-direction: column; gap: 18px;
  pointer-events: none;
}
.hl-skel .sk-row, .hl-skel .sk-btn {
  border-radius: var(--r-md);
  background: linear-gradient(90deg, var(--surface) 0%, var(--raised) 50%, var(--surface) 100%);
  background-size: 300% 100%;
  animation: hlShimmer 1.4s infinite linear;
}
.hl-skel .sk-row { height: 46px; }
.hl-skel .sk-btn { height: 50px; margin-top: 8px; }
@keyframes hlShimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -100% 0; }
}
.form-popup-close {
  position: absolute; top: 16px; right: 16px; z-index: 5;
  width: 34px; height: 34px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(20,20,24,0.85);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  color: var(--ink-2);
  transition: background .15s, color .15s, border-color .15s;
  cursor: pointer;
}
.form-popup-close:hover { background: var(--raised); color: var(--ink); border-color: var(--ink-4); }

body.popup-open { overflow: hidden; }

/* Custom form fields */
.lf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.lf-field { display: flex; flex-direction: column; gap: 7px; }
.lf-field.lf-full { grid-column: span 2; }
.lf-label { font-size: var(--t-xs); color: var(--ink-2); font-weight: 500; letter-spacing: -0.01em; }
.lf-label i { color: var(--blue-bright); font-style: normal; }
.lawos-form input,
.lawos-form select,
.lawos-form textarea {
  width: 100%;
  padding: 11px 14px;
  font-size: var(--t-sm);
  font-family: inherit;
  background: var(--surface);
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  transition: border-color .15s, box-shadow .15s, background .15s;
  -webkit-appearance: none; appearance: none;
}
.lawos-form textarea { resize: vertical; min-height: 56px; line-height: 1.5; }
.lawos-form input::placeholder,
.lawos-form textarea::placeholder { color: var(--ink-faint); }
.lawos-form select {
  cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23A1A1AA' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}
.lawos-form select option { background: var(--surface); color: var(--ink); }
.lawos-form input:focus,
.lawos-form select:focus,
.lawos-form textarea:focus {
  outline: 0;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px var(--blue-soft);
  background: var(--ebony);
}
.lawos-form .invalid { border-color: var(--crimson) !important; box-shadow: 0 0 0 3px rgba(230,58,70,0.12) !important; }

/* Segmented radio */
.lf-segmented { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.lf-segmented label {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  padding: 11px 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  font-size: var(--t-sm); color: var(--ink-3);
  cursor: pointer; transition: all .15s;
  text-align: center;
}
.lf-segmented input { position: absolute; opacity: 0; pointer-events: none; }
.lf-segmented label:hover { border-color: var(--line-strong); color: var(--ink-2); }
.lf-segmented input:checked + span { color: var(--blue-bright); font-weight: 600; }
.lf-segmented label:has(input:checked) { border-color: var(--blue); background: var(--blue-soft); }

.lf-submit { width: 100%; justify-content: center; margin-top: 22px; }
.lf-legal { font-size: 11px; color: var(--ink-4); text-align: center; margin: 14px 0 0; }
.lf-error {
  margin: 14px 0 0; padding: 10px 14px;
  font-size: var(--t-xs); color: #FCA5A5;
  background: rgba(230,58,70,0.08); border: 1px solid rgba(230,58,70,0.25);
  border-radius: var(--r-md); text-align: center;
}

/* Success state */
.lf-success {
  text-align: center;
  padding: 40px 16px 20px;
  display: flex; flex-direction: column; align-items: center;
}
.lf-success-ring {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--blue-soft); color: var(--cyan);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 24px;
  box-shadow: 0 0 0 6px rgba(10,132,255,0.06), 0 0 30px -4px var(--blue-glow);
}
.lf-success h3 { font-size: var(--t-xl); margin-bottom: 12px; }
.lf-success p { color: var(--ink-3); max-width: 40ch; margin: 0 auto 24px; font-size: var(--t-sm); }

@media (max-width: 900px) {
  .form-popup-shell { grid-template-columns: 1fr; max-width: 560px; }
  .fp-rail { display: none; }
}
@media (max-width: 640px) {
  .form-popup { padding: 0; }
  .form-popup-shell { max-width: 100%; height: 100%; max-height: 100%; border-radius: 0; border: 0; }
  .fp-main { max-height: 100%; }
  .form-popup-header { padding: 20px 60px 16px 20px; }
  .form-popup-header h3 { font-size: 18px; }
  .form-popup-body { padding: 0; min-height: 480px; }
}
@media (max-width: 1000px) {
  .lead-magnet, .offer, .form-wrap, .diff { grid-template-columns: 1fr; gap: 48px; }
  .problem-grid, .audience-grid { grid-template-columns: 1fr 1fr; }
  .cap-bento { grid-template-columns: 1fr 1fr; }
  .cap.sp-3, .cap.sp-2, .cap.sp-4 { grid-column: span 2; }
  .change-grid { grid-template-columns: 1fr; }
  .change-col + .change-col { border-left: 0; border-top: 1px solid var(--line); }
  section { padding: 96px 0; }
  .hero { padding-top: 160px; }
  .hero-preview { display: none; }
  .nav-links a:not(.nav-cta) { display: none; }
  .form-grid { grid-template-columns: 1fr; }
  .field.full { grid-column: span 1; }
  .asp-list { grid-template-columns: 1fr; }
  .asp-list .row:nth-child(odd) { border-right: 0; }
  .asp-list .row:nth-last-child(-n+2) { border-bottom: 1px solid var(--line); }
  .asp-list .row:last-child { border-bottom: 0; }
}
@media (max-width: 640px) {
  .problem-grid, .audience-grid, .cap-bento { grid-template-columns: 1fr; }
  .cap.sp-3, .cap.sp-2, .cap.sp-4 { grid-column: span 1; }
  .wrap, .wrap-tight { padding: 0 20px; }
  section { padding: 80px 0; }

  /* Mobile hero typography — clamp() floor (48px) overflows <400px viewports
     because words like "herramientas" exceed the available 18ch at that size.
     36px fits 2-3 words per line in Space Grotesk 700 cleanly. */
  .hero h1 { font-size: 36px; letter-spacing: -0.03em; line-height: 1.08; max-width: 100%; }
  .hero-sub { font-size: 15px; }
  .hero { padding-top: 120px; }

  /* iOS Safari rendering bug: a parent with -webkit-background-clip: text +
     color: transparent fails to extend the gradient clip to inline-block
     descendants. Our .gradient-text <em> contains .word spans (injected by
     landing.js, display: inline-block), so the third H1 line renders as
     transparent on iOS = invisible text between span 2 ("Necesita") and the
     sub-headline. Forcing the em itself to inline-block makes it a single
     rendering unit; the clip applies cleanly and the words inherit color. */
  .hero h1 .gradient-text { display: inline-block; }
}

/* ════════════════════════════════════════════════
   WOW LAYER — SF-tier kinetic effects (JS-driven)
   ════════════════════════════════════════════════ */

/* ── Trust / security ────────────────────────── */
.trust-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin-top: 64px;
}
.trust-card {
  padding: 28px 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  transition: border-color .3s, transform .3s var(--ease-out);
}
.trust-card:hover { border-color: var(--line-strong); transform: translateY(-3px); }
.trust-ico {
  width: 42px; height: 42px; border-radius: 12px;
  display: grid; place-items: center; margin-bottom: 18px;
  color: var(--cyan);
  background: rgba(0,212,255,0.07);
  border: 1px solid rgba(0,212,255,0.2);
}
.trust-ico svg { width: 20px; height: 20px; }
.trust-card h4 { font-size: var(--t-md); margin-bottom: 8px; }
.trust-card p { font-size: var(--t-sm); color: var(--ink-3); margin: 0; line-height: 1.55; }

.beta-band {
  margin-top: 24px;
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center;
  padding: 40px;
  background:
    radial-gradient(700px 300px at 0% 0%, var(--blue-soft), transparent 60%),
    var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  position: relative; overflow: hidden;
}
.beta-band::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--blue), var(--cyan), transparent);
}
.beta-tag {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: var(--t-xs); font-weight: 600; color: var(--cyan);
  padding: 6px 13px; border: 1px solid rgba(0,212,255,0.3);
  background: rgba(0,212,255,0.06); border-radius: var(--r-pill);
  margin-bottom: 18px;
}
.beta-tag .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 8px var(--cyan); }
.beta-band h3 { font-size: var(--t-xl); margin-bottom: 12px; letter-spacing: -0.02em; }
.beta-band p { font-size: var(--t-sm); color: var(--ink-3); margin: 0; line-height: 1.6; }
.beta-band-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.beta-band-list li { display: flex; align-items: center; gap: 12px; font-size: var(--t-sm); color: var(--ink-2); }
.beta-band-list svg { width: 17px; height: 17px; color: var(--pursue); flex-shrink: 0; }

/* ── FAQ accordion ───────────────────────────── */
.faq { margin-top: 56px; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color .25s, background .25s;
}
.faq-item:hover { border-color: var(--line-strong); }
.faq-item[open] { border-color: rgba(10,132,255,0.3); background: linear-gradient(180deg, var(--blue-soft), transparent 40%), var(--surface); }
.faq-item summary {
  list-style: none; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  padding: 22px 26px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: var(--t-md); font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-ico {
  position: relative; flex-shrink: 0;
  width: 20px; height: 20px;
}
.faq-ico::before, .faq-ico::after {
  content: ''; position: absolute; background: var(--blue-bright);
  border-radius: 2px; transition: transform .3s var(--ease-out), opacity .3s;
}
.faq-ico::before { top: 9px; left: 2px; right: 2px; height: 2px; }
.faq-ico::after { left: 9px; top: 2px; bottom: 2px; width: 2px; }
.faq-item[open] .faq-ico::after { transform: rotate(90deg); opacity: 0; }
.faq-body { padding: 0 26px 24px; }
.faq-body p { font-size: var(--t-sm); color: var(--ink-3); margin: 0; line-height: 1.65; max-width: 64ch; }

@media (max-width: 900px) {
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .beta-band { grid-template-columns: 1fr; gap: 28px; padding: 32px; }
}
@media (max-width: 560px) {
  .trust-grid { grid-template-columns: 1fr; }
  .faq-item summary { padding: 18px 20px; font-size: var(--t-base); }
  .faq-body { padding: 0 20px 20px; }
}

/* ── Sticky CTA bar ──────────────────────────── */
.sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 90;
  padding: 12px 20px;
  transform: translateY(120%);
  pointer-events: none;
}
.sticky-cta.show { pointer-events: auto; }
.sticky-cta-inner {
  position: relative;
  max-width: 1100px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 12px 14px 12px 20px;
  background: rgba(20,20,24,0.82);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  box-shadow: 0 20px 50px -16px rgba(0,0,0,0.7), 0 0 40px -12px var(--blue-glow);
}
.sticky-cta-left { display: flex; align-items: center; gap: 14px; min-width: 0; }
.sticky-cta-left > img { height: 20px; width: auto; flex-shrink: 0; }
.sticky-cta-copy { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.sticky-cta-copy strong { font-size: var(--t-sm); color: var(--ink); font-weight: 600; letter-spacing: -0.01em; white-space: nowrap; }
.sticky-cta-cupos { display: inline-flex; align-items: center; gap: 7px; font-size: var(--t-xs); color: var(--ink-3); white-space: nowrap; }
.sticky-cta-cupos .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--pursue); box-shadow: 0 0 8px var(--pursue); flex-shrink: 0; }
.sticky-cta .btn { flex-shrink: 0; }

@media (max-width: 640px) {
  .sticky-cta { padding: 10px 12px; }
  .sticky-cta-inner { padding: 10px 12px 10px 16px; border-radius: var(--r-lg); }
  .sticky-cta-left > img { display: none; }
  .sticky-cta-copy strong { font-size: var(--t-xs); }
  .sticky-cta-cupos { font-size: 11px; }
  .sticky-cta .btn { padding: 11px 16px; font-size: var(--t-sm); }
}

/* ── Flow stepper (cómo funciona) ────────────── */
.flow {
  position: relative;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px;
  margin-top: 72px;
}
.flow-line, .flow-progress {
  position: absolute; top: 32px; left: 8%; right: 8%; height: 2px;
  border-radius: 2px;
}
.flow-line { background: var(--line-strong); }
.flow-progress {
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  box-shadow: 0 0 16px var(--blue-glow);
  width: 0; right: auto;
}
.flow-step { position: relative; text-align: center; padding: 0 6px; }
.flow-node {
  position: relative; z-index: 2;
  width: 64px; height: 64px; margin: 0 auto 18px;
  border-radius: 18px;
  display: grid; place-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  color: var(--ink-3);
  transition: all .4s var(--ease-out);
}
.flow-node svg { width: 26px; height: 26px; }
.flow-step.lit .flow-node {
  background: linear-gradient(160deg, var(--blue), var(--blue-bright));
  border-color: transparent; color: #fff;
  box-shadow: 0 0 0 6px var(--blue-soft), 0 12px 32px -8px var(--blue-glow);
  transform: translateY(-3px);
}
.flow-no { font-size: 11px; color: var(--blue-bright); letter-spacing: 0.14em; margin-bottom: 8px; font-weight: 600; }
.flow-step h4 { font-size: var(--t-md); margin-bottom: 8px; }
.flow-step p { font-size: var(--t-sm); color: var(--ink-3); max-width: 22ch; margin: 0 auto; line-height: 1.5; }

.flow-foot {
  margin-top: 64px;
  display: flex; align-items: center; gap: 24px;
  padding: 28px 32px;
  background: linear-gradient(125deg, var(--blue-soft), transparent 70%);
  border: 1px solid rgba(10,132,255,0.3);
  border-radius: var(--r-xl);
}
.flow-foot-pill {
  display: inline-flex; align-items: center; gap: 9px; flex-shrink: 0;
  font-size: var(--t-xs); font-weight: 600; color: var(--cyan);
  padding: 7px 14px; border: 1px solid rgba(0,212,255,0.3);
  background: rgba(0,212,255,0.06); border-radius: var(--r-pill);
  letter-spacing: 0.04em;
}
.flow-foot-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 8px var(--cyan); }
.flow-foot p { font-size: var(--t-base); color: var(--ink-2); margin: 0; max-width: none; }

@media (max-width: 900px) {
  .flow { grid-template-columns: 1fr 1fr; gap: 32px 20px; }
  .flow-line, .flow-progress { display: none; }
  .flow-foot { flex-direction: column; align-items: flex-start; gap: 14px; }
}
@media (max-width: 560px) {
  .flow { grid-template-columns: 1fr; gap: 28px; text-align: left; }
  .flow-node { margin-left: 0; margin-right: 0; }
  .flow-step { padding: 0; }
  .flow-step p { margin-left: 0; max-width: none; }
}

/* ── Hero headline word-by-word reveal ───────── */
.hero-h1 .word { display: inline-block; white-space: pre; }
html.anim-ready .hero-h1 .word {
  opacity: 0;
  transform: translateY(0.5em) rotate(2deg);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
}
html.anim-ready .hero-h1.words-in .word { opacity: 1; transform: none; }

/* ── Live lead row (pipeline advancing) ──────── */
#live-lead { transition: background .4s var(--ease-out); }
#live-lead.flash { background: var(--blue-soft); }
#live-badge { transition: background .4s, color .4s; }
#live-stage, #live-action { transition: opacity .3s; }

/* ── Live signals ticker ─────────────────────── */
.marquee-signals { position: relative; }
.marquee-edge-label {
  position: absolute; left: 0; top: 0; bottom: 0; z-index: 3;
  display: flex; align-items: center; gap: 8px;
  padding: 0 18px 0 32px;
  font-size: var(--t-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cyan);
  background: linear-gradient(90deg, var(--ebony) 70%, transparent);
}
.marquee-edge-label .lv {
  width: 7px; height: 7px; border-radius: 50%; background: var(--cyan);
  box-shadow: 0 0 10px var(--cyan); flex-shrink: 0;
}
.marquee-signals .sig {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: var(--t-sm); color: var(--ink-2); white-space: nowrap; font-weight: 500;
}
.marquee-signals .sig b {
  font-family: 'JetBrains Mono', monospace; font-weight: 500;
  font-size: var(--t-xs); color: var(--ink-4);
  padding: 2px 8px; border: 1px solid var(--line); border-radius: var(--r-pill);
  margin-left: 2px;
}
.marquee-signals .sd { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.marquee-signals .sd.pursue  { background: var(--pursue);  box-shadow: 0 0 8px var(--pursue); }
.marquee-signals .sd.nurture { background: var(--nurture); box-shadow: 0 0 8px var(--nurture); }
.marquee-signals .sd.clarify { background: #60A5FA; box-shadow: 0 0 8px #60A5FA; }
.marquee-signals .sd.cyan    { background: var(--cyan);    box-shadow: 0 0 8px var(--cyan); }
.marquee-signals .sd.crimson { background: var(--crimson); box-shadow: 0 0 8px var(--crimson); }

/* Scramble text */
.scramble { color: var(--cyan); font-weight: 600; letter-spacing: 0; }

/* Confetti canvas */
#confetti-canvas {
  position: fixed; inset: 0; z-index: 300; pointer-events: none;
  width: 100vw; height: 100vh;
}

/* Scroll progress bar */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 2px; width: 0;
  z-index: 120;
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  box-shadow: 0 0 12px var(--cyan-glow);
  pointer-events: none;
}

/* Premium grain */
.grain {
  position: fixed; inset: 0; z-index: 110; pointer-events: none;
  opacity: 0.04; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Hero 3D tilt + parallax */
.hero-preview { perspective: 1600px; will-change: transform; }
.preview-frame { transform-style: preserve-3d; transition: transform .12s ease-out; }

/* Floating product cards */
.float-card {
  position: absolute; z-index: 6;
  display: flex; align-items: center; gap: 11px;
  padding: 12px 15px;
  background: rgba(20,20,26,0.72);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  box-shadow: 0 20px 50px -16px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04) inset;
  will-change: transform;
  pointer-events: none;
}
.float-card .fc-title { font-size: 12px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; white-space: nowrap; }
.float-card .fc-title strong { color: var(--cyan); }
.float-card .fc-sub { font-size: 10px; color: var(--ink-4); white-space: nowrap; margin-top: 1px; }
.float-card .fc-sub strong { color: var(--ink-2); }
.float-card .fc-icon {
  width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--blue), var(--cyan)); color: #001018;
}
.float-card .fc-avatar {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #fff;
  background: linear-gradient(135deg, #6366F1, #A78BFA);
}
.float-card .fc-spark { display: flex; align-items: flex-end; gap: 2px; height: 26px; width: 30px; flex-shrink: 0; }
.float-card .fc-spark i { flex: 1; background: linear-gradient(180deg, var(--cyan), var(--blue)); border-radius: 2px 2px 0 0; opacity: 0.9; }

.fc-lead { top: 6%; left: -4%; }
.fc-msg  { top: 40%; right: -6%; }
.fc-stat { bottom: 8%; left: 2%; }

.pulse-ring { position: relative; }
.pulse-ring::after {
  content: ''; position: absolute; inset: -4px; border-radius: inherit;
  border: 1.5px solid var(--cyan); opacity: 0;
}

/* Card cursor-spotlight (renders fine in preview — static gradient via vars) */
.cap, .problem-card, .aud { isolation: isolate; }
.cap::after, .problem-card::after, .aud::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(360px circle at var(--mx, 50%) var(--my, 0%), rgba(10,132,255,0.14), transparent 45%);
  opacity: 0; transition: opacity .35s; pointer-events: none; z-index: -1;
}
.cap:hover::after, .problem-card:hover::after, .aud:hover::after { opacity: 1; }

/* Magnetic buttons */
.btn-primary { will-change: transform; }

/* Hero headline shimmer sweep on the gradient word (JS adds .swept) */
.hero h1 .gradient-text {
  background-size: 200% auto;
}

@media (max-width: 1000px) {
  .float-card { display: none; }
  .grain { opacity: 0.03; }
}
@media (prefers-reduced-motion: reduce) {
  .preview-frame { transform: none !important; }
  .float-card { transform: none !important; }
}
