/* ============================================================
   ANAVSAN V2 — Design System
   Primary: #6f51ce (brand purple)
   Supports: Dark theme (default) + Light theme (data-theme="light")
   Cross-browser: Chrome, Firefox, Safari, Edge
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap');

/* ========================
   RESET
   ======================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background-color: var(--bg-0);
  color: var(--text-1);
  line-height: 1.6;
  overflow-x: hidden;
  transition: background-color 0.3s ease, color 0.3s ease;
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button { cursor: pointer; font-family: inherit; }
input, button, textarea, select { font: inherit; }

/* ========================
   DARK THEME (default)
   ======================== */
:root,
[data-theme="dark"] {
  --bg-0: #07090F;
  --bg-1: #0B0F1A;
  --bg-2: #0F1525;
  --bg-card: rgba(255,255,255,0.04);
  --bg-card-hover: rgba(255,255,255,0.072);
  --bg-glass: rgba(15,21,37,0.88);

  --brand: #6f51ce;
  --brand-light: #9B77F0;
  --brand-dark: #5842B5;
  --brand-xlight: #C4B5FD;
  --brand-glow: rgba(111,81,206,0.18);
  --brand-glow2: rgba(155,119,240,0.14);

  --green: #10B981;
  --green-light: #34D399;
  --amber: #F59E0B;
  --red: #EF4444;

  --text-0: #FFFFFF;
  --text-1: #F1F5F9;
  --text-2: #94A3B8;
  --text-3: #64748B;
  --text-4: #475569;

  --border-0: rgba(255,255,255,0.10);
  --border-1: rgba(255,255,255,0.06);
  --border-brand: rgba(111,81,206,0.35);
  --border-brand-sub: rgba(111,81,206,0.18);

  --grad-brand: linear-gradient(135deg, #6f51ce 0%, #9B77F0 100%);
  --grad-text: linear-gradient(135deg, #9B77F0 0%, #C4B5FD 100%);
  --grad-card: linear-gradient(135deg, rgba(111,81,206,0.10) 0%, rgba(155,119,240,0.06) 100%);
  --grad-glow1: radial-gradient(circle, rgba(111,81,206,0.20) 0%, transparent 70%);
  --grad-glow2: radial-gradient(circle, rgba(155,119,240,0.16) 0%, transparent 70%);

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.6);
  --shadow-card-hover: 0 8px 32px rgba(0,0,0,0.6), 0 0 0 1px rgba(111,81,206,0.18);
  --shadow-glow: 0 0 48px rgba(111,81,206,0.14);

  --logo-src: url('../logo/Anavsan (White).svg');
  --logo-nav-filter: none;
}

/* ========================
   LIGHT THEME
   ======================== */
[data-theme="light"] {
  --bg-0: #FAF9FF;
  --bg-1: #FFFFFF;
  --bg-2: #F0EDF9;
  --bg-card: rgba(111,81,206,0.04);
  --bg-card-hover: rgba(111,81,206,0.07);
  --bg-glass: rgba(250,249,255,0.92);

  --brand: #6f51ce;
  --brand-light: #7A5CD8;
  --brand-dark: #5842B5;
  --brand-xlight: #8B6FE5;
  --brand-glow: rgba(111,81,206,0.12);
  --brand-glow2: rgba(111,81,206,0.08);

  --text-0: #0F0C1A;
  --text-1: #1A1530;
  --text-2: #4A4560;
  --text-3: #6B6785;
  --text-4: #9490A8;

  --border-0: rgba(111,81,206,0.14);
  --border-1: rgba(111,81,206,0.08);
  --border-brand: rgba(111,81,206,0.30);
  --border-brand-sub: rgba(111,81,206,0.15);

  --grad-brand: linear-gradient(135deg, #6f51ce 0%, #8B6FE5 100%);
  --grad-text: linear-gradient(135deg, #6f51ce 0%, #8B6FE5 100%);
  --grad-card: linear-gradient(135deg, rgba(111,81,206,0.06) 0%, rgba(139,111,229,0.03) 100%);
  --grad-glow1: radial-gradient(circle, rgba(111,81,206,0.10) 0%, transparent 70%);
  --grad-glow2: radial-gradient(circle, rgba(111,81,206,0.07) 0%, transparent 70%);

  --shadow-sm: 0 1px 3px rgba(111,81,206,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(111,81,206,0.10), 0 2px 6px rgba(0,0,0,0.04);
  --shadow-lg: 0 8px 32px rgba(111,81,206,0.14), 0 2px 8px rgba(0,0,0,0.06);
  --shadow-card-hover: 0 8px 24px rgba(111,81,206,0.14), 0 0 0 1px rgba(111,81,206,0.18);
  --shadow-glow: 0 0 40px rgba(111,81,206,0.10);

  --logo-nav-filter: none;
}

/* ========================
   SPACING / RADIUS TOKENS
   ======================== */
:root {
  --s-section: 112px;
  --s-section-sm: 72px;
  --container: 1200px;
  --r-xs: 4px;  --r-sm: 8px;  --r-md: 12px;
  --r-lg: 16px; --r-xl: 20px; --r-2xl: 28px;
  --r-full: 9999px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --ease-out: cubic-bezier(0,0,0.2,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
  --t-fast: 0.15s cubic-bezier(0.4,0,0.2,1);
  --t-base: 0.25s cubic-bezier(0.4,0,0.2,1);
  --t-slow: 0.45s cubic-bezier(0,0,0.2,1);
}

/* ========================
   TYPOGRAPHY
   ======================== */
h1,h2,h3,h4,h5,h6 {
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: 700; line-height: 1.15; letter-spacing: -0.025em; color: var(--text-0);
}
h1 { font-size: clamp(2.25rem,5.5vw,4.25rem); letter-spacing:-0.035em; font-weight:800; }
h2 { font-size: clamp(1.875rem,4vw,3rem); letter-spacing:-0.03em; }
h3 { font-size: clamp(1.125rem,2vw,1.375rem); letter-spacing:-0.02em; }
h4 { font-size: 1.0625rem; letter-spacing:-0.01em; }
h5 { font-size: 0.9375rem; }
p  { line-height: 1.72; color: var(--text-2); }

/* ========================
   LAYOUT
   ======================== */
.container { max-width: var(--container); margin: 0 auto; padding: 0 28px; }
section { padding: var(--s-section) 0; }
.section-header { margin-bottom: 56px; }
.section-header.center { text-align:center; max-width:720px; margin-left:auto; margin-right:auto; }
.section-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.75rem; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--brand-light); margin-bottom: 14px;
}
.section-eyebrow-line { width:20px; height:2px; background:var(--grad-brand); border-radius:2px; }
.section-title { margin-bottom: 18px; }
.section-desc { font-size:1.0625rem; color:var(--text-2); max-width:560px; line-height:1.75; }
.section-header.center .section-desc { margin: 0 auto; }

/* ========================
   GRADIENT TEXT
   ======================== */
.gradient-text {
  background: var(--grad-text);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.gradient-text-purple { /* alias */
  background: var(--grad-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* ========================
   BADGE
   ======================== */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 14px;
  background: rgba(111,81,206,0.10); border: 1px solid rgba(111,81,206,0.28);
  border-radius: var(--r-full); font-size: 0.8rem; font-weight: 600;
  color: var(--brand-light); letter-spacing: 0.03em;
}
.badge-dot { width:6px; height:6px; background:var(--brand-light); border-radius:50%; animation:pulse-dot 2s ease-in-out infinite; }
.badge-green { background:rgba(16,185,129,0.1); border-color:rgba(16,185,129,0.28); color:#34D399; }

/* ========================
   BUTTONS
   ======================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 24px; border-radius: var(--r-md);
  font-family: 'Plus Jakarta Sans', sans-serif; font-size: 0.9375rem; font-weight: 600;
  cursor: pointer; border: none; -webkit-appearance: none; appearance: none;
  text-align: center; white-space: nowrap; text-decoration: none; position: relative; overflow: hidden;
  transition: transform var(--t-base), box-shadow var(--t-base), background var(--t-base), border-color var(--t-base);
}
.btn::after { content:''; position:absolute; inset:0; background:rgba(255,255,255,0); transition:background var(--t-fast); }
.btn:hover::after { background:rgba(255,255,255,0.06); }
.btn-primary {
  background: var(--grad-brand); color: #fff;
  box-shadow: 0 2px 12px rgba(111,81,206,0.32), 0 1px 3px rgba(0,0,0,0.2);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 6px 24px rgba(111,81,206,0.42), 0 2px 8px rgba(0,0,0,0.3); }
.btn-primary:active { transform:translateY(0); }
.btn-ghost { background:var(--bg-card); color:var(--text-1); border:1px solid var(--border-0); }
.btn-ghost:hover { background:var(--bg-card-hover); border-color:var(--border-brand-sub); transform:translateY(-2px); }
.btn-ghost:active { transform:translateY(0); }
.btn-lg { padding:14px 32px; font-size:1rem; border-radius:var(--r-lg); }
.btn-sm { padding:7px 16px; font-size:0.8375rem; border-radius:var(--r-sm); gap:6px; }
.btn svg { width:16px; height:16px; flex-shrink:0; transition:transform var(--t-base); }
.btn:hover svg.arrow { transform:translateX(3px); }

/* ========================
   THEME TOGGLE
   ======================== */
.theme-toggle {
  width: 38px; height: 38px; border-radius: var(--r-md);
  background: var(--bg-card); border: 1px solid var(--border-0);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
  flex-shrink: 0; color: var(--text-2);
}
.theme-toggle:hover { background:var(--bg-card-hover); border-color:var(--border-brand-sub); color:var(--text-1); transform:scale(1.05); }
.theme-toggle svg { width:16px; height:16px; }
.theme-toggle .icon-sun { display:none; }
.theme-toggle .icon-moon { display:block; }
[data-theme="light"] .theme-toggle .icon-sun { display:block; }
[data-theme="light"] .theme-toggle .icon-moon { display:none; }

/* ========================
   NAVIGATION
   ======================== */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:200; height:64px;
  display: flex; align-items: center; padding: 0 28px;
  transition:
    background var(--t-slow),
    border-color var(--t-slow),
    -webkit-backdrop-filter var(--t-slow),
    backdrop-filter var(--t-slow),
    -webkit-transform 0.35s cubic-bezier(0.4,0,0.2,1),
    transform 0.35s cubic-bezier(0.4,0,0.2,1);
  border-bottom: 1px solid transparent;
  will-change: transform;
}
.nav.scrolled {
  background: var(--bg-glass);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  border-bottom-color: var(--border-1);
  box-shadow: var(--shadow-sm);
}
.nav-inner { max-width:1440px; margin:0 auto; width:100%; display:flex; align-items:center; gap:28px; }
.nav-logo {
  display: flex; align-items: center; gap: 10px; flex-shrink: 0;
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800;
  font-size: 1.125rem; letter-spacing: -0.04em; color: var(--text-0);
}
.nav-logo-img { height: 26px; width: auto; display: block; transition: opacity 0.3s; }
.nav-links { display:flex; align-items:center; gap:2px; list-style:none; flex:1; }
.nav-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  cursor: pointer; padding: 4px; background: none; border: none; margin-left: auto;
}
.nav-hamburger span {
  display:block; width:22px; height:2px; background:var(--text-1); border-radius:2px;
  transition: transform var(--t-base), opacity var(--t-base);
  -webkit-transform-origin: center; transform-origin: center;
}

/* ========================
   NAV — SMART SCROLL
   ======================== */
/* Hide nav on scroll-down (JS adds this class) */
.nav.nav-hidden {
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
}
/* Progress bar under nav */
.nav-progress {
  position: absolute; bottom: 0; left: 0; height: 2px; width: 0%;
  background: var(--grad-brand); transition: width 0.1s linear;
  border-radius: 0 2px 2px 0; pointer-events: none;
}

/* ========================
   NAV — DROPDOWN SYSTEM
   ======================== */
.nav-item {
  position: relative;
  list-style: none;
}

/* Trigger button/link */
.nav-item > a,
.nav-trigger {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 7px 13px; font-size: 0.875rem; font-weight: 500; color: var(--text-2);
  border-radius: var(--r-sm); border: none; background: none;
  cursor: pointer; white-space: nowrap; font-family: inherit;
  transition: color var(--t-fast), background var(--t-fast);
  -webkit-appearance: none; appearance: none;
  text-decoration: none;
}
.nav-item > a:hover,
.nav-trigger:hover,
.nav-item.open > .nav-trigger {
  color: var(--text-1); background: var(--bg-card);
}
.nav-item > a.active,
.nav-item.open > .nav-trigger { color: var(--brand-light); }

/* Caret icon */
.nav-caret {
  width: 14px; height: 14px; flex-shrink: 0; color: var(--text-3);
  transition: transform 0.2s var(--ease), color 0.15s;
}
.nav-item.open .nav-caret { transform: rotate(180deg); color: var(--brand-light); }

/* ========================
   DROPDOWN PANEL BASE
   ======================== */
.nav-dropdown {
  position: absolute; top: calc(100% + 10px); left: 0;
  background: var(--nav-drop-bg, #0d1120);
  border: 1px solid var(--nav-drop-border, rgba(139,92,246,0.22));
  border-radius: var(--r-xl);
  box-shadow: 0 16px 56px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,255,255,0.04);
  min-width: 240px; padding: 8px;
  opacity: 0; pointer-events: none; visibility: hidden;
  -webkit-transform: translateY(-8px) scale(0.98);
  transform: translateY(-8px) scale(0.98);
  -webkit-transform-origin: top left;
  transform-origin: top left;
  transition:
    opacity 0.2s var(--ease),
    transform 0.2s var(--ease),
    -webkit-transform 0.2s var(--ease),
    visibility 0s 0.2s;
  z-index: 300;
}
[data-theme="light"] .nav-dropdown {
  --nav-drop-bg: #ffffff;
  --nav-drop-border: rgba(111,81,206,0.18);
  box-shadow: 0 12px 48px rgba(111,81,206,0.12), 0 2px 8px rgba(0,0,0,0.08), 0 0 0 1px rgba(111,81,206,0.10);
}
.nav-item.open > .nav-dropdown {
  opacity: 1; pointer-events: all; visibility: visible;
  -webkit-transform: translateY(0) scale(1);
  transform: translateY(0) scale(1);
  transition-delay: 0s;
}

/* Simple dropdown item */
.dropdown-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: var(--r-md);
  color: var(--text-1); text-decoration: none; font-size: 0.875rem; font-weight: 500;
  transition: background var(--t-fast), color var(--t-fast);
  cursor: pointer; white-space: nowrap;
}
.dropdown-item:hover { background: rgba(139,92,246,0.10); color: var(--text-0); }
.dropdown-item.active { color: var(--brand-light); }
.dropdown-item-icon {
  width: 34px; height: 34px; border-radius: var(--r-sm); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 0.9rem;
  background: rgba(139,92,246,0.12); border: 1px solid rgba(139,92,246,0.22);
  color: var(--brand-light);
  transition: background var(--t-fast), border-color var(--t-fast);
}
.dropdown-item:hover .dropdown-item-icon { background: rgba(139,92,246,0.22); border-color: rgba(139,92,246,0.38); }
.dropdown-item-text { display: flex; flex-direction: column; }
.dropdown-item-label { font-size: 0.875rem; font-weight: 600; color: var(--text-0); line-height: 1.2; }
.dropdown-item-desc { font-size: 0.75rem; color: var(--text-2); margin-top: 2px; line-height: 1.3; white-space: normal; }
.dropdown-item:hover .dropdown-item-label { color: var(--brand-xlight); }

/* Dropdown divider */
.dropdown-divider { height: 1px; background: rgba(139,92,246,0.14); margin: 6px 4px; }

/* ========================
   MEGA DROPDOWN (Products)
   ======================== */
.nav-dropdown-mega {
  left: 0;
  -webkit-transform: translateY(-8px) scale(0.98);
  transform: translateY(-8px) scale(0.98);
  -webkit-transform-origin: top left;
  transform-origin: top left;
  width: 620px;
  max-width: min(620px, calc(100vw - 32px));
  padding: 16px;
}
.nav-item.open > .nav-dropdown-mega {
  -webkit-transform: translateY(0) scale(1);
  transform: translateY(0) scale(1);
}
.mega-header {
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--brand-light); padding: 4px 8px 10px; margin-bottom: 4px;
  border-bottom: 1px solid rgba(139,92,246,0.18);
}
.mega-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-bottom: 2px;
}
.mega-footer {
  margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(139,92,246,0.14);
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.mega-footer-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.8rem; font-weight: 600; color: var(--brand-light);
  padding: 6px 10px; border-radius: var(--r-sm);
  transition: background var(--t-fast), color var(--t-fast);
}
.mega-footer-link:hover { background: rgba(139,92,246,0.12); color: var(--brand-xlight); }
.mega-footer-link svg { width: 12px; height: 12px; }

/* ========================
   RIGHT-ALIGNED DROPDOWN
   ======================== */
.nav-dropdown-right { left: auto; right: 0; -webkit-transform-origin: top right; transform-origin: top right; }
.nav-item.open > .nav-dropdown-right { -webkit-transform: translateY(0) scale(1); transform: translateY(0) scale(1); }

/* Mobile menu */
.mobile-menu {
  position: fixed; top:64px; left:0; right:0; z-index:199;
  background: #0d1120;
  border-bottom: 1px solid rgba(139,92,246,0.18);
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  padding: 16px 28px 28px;
  -webkit-transform: translateY(-8px); transform: translateY(-8px);
  opacity: 0; pointer-events: none;
  transition: transform 0.3s var(--ease), opacity 0.3s var(--ease);
}
[data-theme="light"] .mobile-menu {
  background: #ffffff;
  border-bottom-color: rgba(111,81,206,0.14);
  box-shadow: 0 12px 40px rgba(111,81,206,0.10);
}
.mobile-menu.open { -webkit-transform:translateY(0); transform:translateY(0); opacity:1; pointer-events:all; }
.mobile-menu-links { list-style:none; display:flex; flex-direction:column; gap:2px; margin-bottom:20px; }
.mobile-menu-links a {
  display:block; padding:11px 14px; color:var(--text-2); font-size:0.9375rem; font-weight:500;
  border-radius:var(--r-sm); transition:color var(--t-fast), background var(--t-fast);
}
.mobile-menu-links a:hover { color:var(--text-1); background:var(--bg-card); }
.mobile-menu-links a.active { color:var(--brand-light); }

/* Mobile accordion groups */
.mobile-group-trigger {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 14px; color: var(--text-3); font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em; cursor: default;
  border-radius: var(--r-sm); margin-top: 6px;
}
.mobile-group-items { display: flex; flex-direction: column; gap: 1px; }
.mobile-group-items a {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 14px 9px 20px; color: var(--text-2); font-size: 0.9rem; font-weight: 500;
  border-radius: var(--r-sm); transition: color var(--t-fast), background var(--t-fast);
}
.mobile-group-items a:hover { color: var(--text-1); background: var(--bg-card); }
.mobile-group-items .mgi-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--brand); flex-shrink: 0; opacity: 0.5; }
.mobile-group-items a:hover .mgi-dot { opacity: 1; }

.mobile-menu-actions { display:flex; flex-direction:column; gap:10px; }
.mobile-menu-actions .btn { width:100%; }

/* ========================
   HERO
   ======================== */
.hero {
  position: relative; min-height:100vh; display:flex;
  flex-direction:column; align-items:center; justify-content:center;
  padding: 128px 28px 80px; overflow: hidden;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; z-index:0; }
.hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(111,81,206,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(111,81,206,0.05) 1px, transparent 1px);
  background-size: 72px 72px;
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 40%, black 20%, transparent 80%);
  mask-image: radial-gradient(ellipse 90% 80% at 50% 40%, black 20%, transparent 80%);
}
[data-theme="light"] .hero-grid {
  background-image:
    linear-gradient(rgba(111,81,206,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(111,81,206,0.07) 1px, transparent 1px);
}
.orb { position:absolute; border-radius:50%; pointer-events:none; }
.orb-1 { width:700px; height:700px; background:var(--grad-glow1); filter:blur(80px); top:-200px; left:-150px; animation:orb-drift-1 10s ease-in-out infinite; }
.orb-2 { width:600px; height:600px; background:var(--grad-glow2); filter:blur(80px); top:-100px; right:-100px; animation:orb-drift-2 13s ease-in-out infinite; }
.orb-3 { width:500px; height:500px; background:radial-gradient(circle, rgba(111,81,206,0.10) 0%, transparent 70%); filter:blur(60px); bottom:0; left:35%; animation:orb-drift-3 16s ease-in-out infinite; }
.hero-noise { position:absolute; inset:0; opacity:0.025; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); background-size:200px; }
.hero-content { max-width:var(--container); width:100%; text-align:center; position:relative; z-index:1; }
.hero-badge { margin-bottom:28px; animation:fade-in-up 0.6s var(--ease-out) both; }
.hero-headline { font-size:clamp(2.5rem,6vw,4.5rem); font-weight:800; letter-spacing:-0.04em; line-height:1.1; margin-bottom:24px; animation:fade-in-up 0.6s var(--ease-out) 0.1s both; }
.hero-headline-line { display:block; }
.hero-headline-line--accent { margin-top:0.12em; }
.hero-sub { font-size:clamp(1.0625rem,2vw,1.25rem); color:var(--text-2); max-width:600px; margin:0 auto 44px; line-height:1.72; animation:fade-in-up 0.6s var(--ease-out) 0.2s both; }
.hero-actions { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:72px; animation:fade-in-up 0.6s var(--ease-out) 0.3s both; }
.hero-divider { width:1px; height:44px; background:var(--border-0); }
.hero-stats { display:flex; align-items:center; justify-content:center; gap:56px; flex-wrap:wrap; animation:fade-in-up 0.6s var(--ease-out) 0.4s both; }
.hero-stat { text-align:center; }
.hero-stat-value { font-family:'Plus Jakarta Sans',sans-serif; font-size:2.25rem; font-weight:800; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; line-height:1; margin-bottom:6px; letter-spacing:-0.03em; }
.hero-stat-label { font-size:0.8125rem; color:var(--text-3); font-weight:500; letter-spacing:0.02em; }

/* Dashboard mockup */
.hero-preview { margin-top:80px; position:relative; max-width:960px; margin-left:auto; margin-right:auto; animation:fade-in-up 0.8s var(--ease-out) 0.5s both; }
.hero-preview-glow { position:absolute; inset:-40px; background:radial-gradient(ellipse at 50% 0%, rgba(111,81,206,0.15), transparent 60%); pointer-events:none; }
.dashboard-mockup { background:var(--bg-1); border:1px solid var(--border-0); border-radius:var(--r-2xl); padding:20px; box-shadow:0 40px 80px rgba(0,0,0,0.3), 0 0 0 1px var(--border-1); overflow:hidden; }
.dashboard-topbar { display:flex; align-items:center; gap:8px; margin-bottom:16px; padding-bottom:16px; border-bottom:1px solid var(--border-1); }
.dash-dot { width:10px; height:10px; border-radius:50%; }
.dash-dot-red { background:#FF5F57; } .dash-dot-yellow { background:#FFBD2E; } .dash-dot-green { background:#28CA41; }
.dashboard-topbar-title { margin-left:8px; font-size:0.8125rem; color:var(--text-3); font-weight:500; }
.dashboard-body { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
.dash-metric { background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-md); padding:16px; }
.dash-metric-label { font-size:0.75rem; color:var(--text-3); font-weight:500; margin-bottom:8px; display:flex; align-items:center; gap:6px; }
.dash-metric-dot { width:6px; height:6px; border-radius:50%; }
.dash-metric-dot.green { background:#10B981; } .dash-metric-dot.blue { background:var(--brand); } .dash-metric-dot.purple { background:var(--brand-light); }
.dash-metric-value { font-family:'Plus Jakarta Sans',sans-serif; font-size:1.5rem; font-weight:800; letter-spacing:-0.03em; color:var(--text-0); margin-bottom:4px; }
.dash-metric-trend { font-size:0.75rem; display:flex; align-items:center; gap:4px; }
.dash-metric-trend.down { color:#34D399; }
.dash-bar-row { grid-column:span 3; background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-md); padding:16px; }
.dash-bar-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.dash-bar-title { font-size:0.8125rem; font-weight:600; color:var(--text-2); }
.dash-bars { display:flex; align-items:flex-end; gap:8px; height:60px; }
.dash-bar { flex:1; border-radius:4px 4px 0 0; background:var(--grad-brand); opacity:0.65; transition:opacity var(--t-base); min-width:0; }
.dash-bar:hover { opacity:1; }

/* ========================
   TRUST BAR
   ======================== */
.trust-bar { padding:0; border-top:1px solid var(--border-1); border-bottom:1px solid var(--border-1); background:var(--bg-card); overflow:hidden; }
.trust-bar-inner { max-width:var(--container); margin:0 auto; padding:28px; display:flex; align-items:center; gap:40px; flex-wrap:wrap; justify-content:center; }
.trust-label { font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-4); white-space:nowrap; }
.trust-divider { width:1px; height:24px; background:var(--border-0); }
.trust-logos { display:flex; align-items:center; gap:36px; flex-wrap:wrap; justify-content:center; }
.trust-logo-item { display:flex; align-items:center; gap:8px; opacity:0.38; transition:opacity var(--t-base); }
[data-theme="light"] .trust-logo-item { filter:none; }
.trust-logo-item:hover { opacity:0.7; }
.trust-logo-name { font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:0.9375rem; color:var(--text-1); letter-spacing:-0.02em; }

/* ========================
   PROBLEM SECTION
   ======================== */
.problem { background:linear-gradient(180deg, transparent 0%, rgba(111,81,206,0.04) 40%, transparent 100%); }
.problem-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.problem-left .section-desc { margin-bottom:32px; max-width:100%; }
.problem-items { display:flex; flex-direction:column; gap:12px; }
.problem-item { display:flex; align-items:flex-start; gap:14px; padding:16px 18px; background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-md); transition:border-color var(--t-base), background var(--t-base); }
.problem-item:hover { background:var(--bg-card-hover); border-color:var(--border-0); }
.problem-icon { width:36px; height:36px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:1rem; }
.problem-icon.red { background:rgba(239,68,68,0.14); } .problem-icon.amber { background:rgba(245,158,11,0.14); } .problem-icon.purple { background:rgba(111,81,206,0.14); }
.problem-item-text h4 { font-size:0.9375rem; font-weight:600; margin-bottom:4px; color:var(--text-1); }
.problem-item-text p { font-size:0.875rem; color:var(--text-2); line-height:1.55; margin:0; }
.problem-solution { background:var(--grad-card); border:1px solid var(--border-brand); border-radius:var(--r-2xl); padding:36px; position:relative; overflow:hidden; }
.problem-solution::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-brand); }
.solution-label { display:inline-flex; align-items:center; gap:6px; background:rgba(111,81,206,0.10); border:1px solid rgba(111,81,206,0.22); border-radius:var(--r-full); padding:4px 12px; font-size:0.75rem; font-weight:700; color:var(--brand-light); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:20px; }
.problem-solution h3 { font-size:1.375rem; margin-bottom:14px; }
.problem-solution p { font-size:0.9375rem; color:var(--text-2); line-height:1.7; margin-bottom:28px; }
.solution-features { display:flex; flex-direction:column; gap:12px; }
.solution-feature { display:flex; align-items:center; gap:10px; font-size:0.9rem; color:var(--text-2); }
.solution-check { width:20px; height:20px; border-radius:50%; background:rgba(16,185,129,0.15); border:1px solid rgba(16,185,129,0.3); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:#10B981; font-size:0.7rem; font-weight:700; }

/* ========================
   PRODUCTS GRID
   ======================== */
.products { background:var(--bg-1); }
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.product-card { background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-xl); padding:28px; display:flex; flex-direction:column; transition:transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base), background var(--t-base); position:relative; overflow:hidden; }
.product-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-brand); opacity:0; transition:opacity var(--t-base); }
.product-card:hover { transform:translateY(-5px); border-color:var(--border-brand-sub); box-shadow:var(--shadow-card-hover); background:var(--bg-card-hover); }
.product-card:hover::before { opacity:1; }
.product-card.featured { background:var(--grad-card); border-color:var(--border-brand); grid-column:span 2; }
.product-card.featured::before { opacity:1; }
.product-icon { width:48px; height:48px; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; margin-bottom:20px; flex-shrink:0; }
.product-icon.blue { background:rgba(111,81,206,0.14); border:1px solid rgba(111,81,206,0.22); }
.product-icon.purple { background:rgba(111,81,206,0.10); border:1px solid rgba(111,81,206,0.18); }
.product-icon.cyan { background:rgba(155,119,240,0.12); border:1px solid rgba(155,119,240,0.20); }
.product-icon.green { background:rgba(16,185,129,0.12); border:1px solid rgba(16,185,129,0.20); }
.product-icon svg { width:22px; height:22px; }
.product-card h3 { font-size:1.125rem; margin-bottom:10px; color:var(--text-0); }
.product-card p { font-size:0.9rem; color:var(--text-2); line-height:1.65; flex:1; margin-bottom:20px; }
.product-link { display:inline-flex; align-items:center; gap:6px; font-size:0.875rem; font-weight:600; color:var(--brand-light); transition:gap var(--t-fast), color var(--t-fast); margin-top:auto; }
.product-link:hover { gap:10px; color:var(--brand-xlight); }
.product-link svg { width:14px; height:14px; transition:transform var(--t-fast); }
.product-link:hover svg { transform:translateX(2px); }
.product-tags { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:20px; }
.product-tag { padding:3px 10px; background:rgba(111,81,206,0.08); border:1px solid rgba(111,81,206,0.16); border-radius:var(--r-full); font-size:0.72rem; font-weight:600; color:var(--brand-light); letter-spacing:0.02em; }

/* ========================
   HOW IT WORKS
   ======================== */
.how-it-works { position:relative; }

/* Tag band */
.tagband {
  background: var(--bg-1);
  border-bottom: 1px solid var(--border-1);
  padding: 9px 0;
  text-align: center;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green-light);
}

/* Press strip — below main story sections */
.press-strip {
  padding: 0 0 64px;
}
.press-strip .press-callout {
  margin-top: 0;
  border-color: var(--border-brand-sub);
  background: linear-gradient(135deg, var(--bg-card) 0%, rgba(111,81,206,0.04) 100%);
}
.press-callout-body {
  flex: 1;
  min-width: 0;
}
.press-strip-source {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 6px;
}
.press-callout-btn {
  flex-shrink: 0;
  white-space: nowrap;
}

/* Press / announcement link (hero pill — legacy) */
.press-mention {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 720px;
  margin: 0 auto 22px;
  padding: 9px 18px;
  background: var(--bg-card);
  border: 1px solid var(--border-1);
  border-radius: var(--r-full);
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--text-2);
  text-decoration: none;
  transition: border-color var(--t-base), color var(--t-base), box-shadow var(--t-base);
}
.press-mention:hover {
  border-color: var(--border-brand-sub);
  color: var(--text-1);
  box-shadow: var(--shadow-sm);
}
.press-mention-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-light);
  white-space: nowrap;
}
.press-mention-icon {
  flex-shrink: 0;
  opacity: 0.55;
  transition: opacity var(--t-base);
}
.press-mention:hover .press-mention-icon { opacity: 1; }

.product-press-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 14px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--brand-light);
  text-decoration: none;
}
.product-press-link:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.press-callout {
  margin-top: 48px;
  padding: 20px 24px;
  background: var(--bg-card);
  border: 1px solid var(--border-1);
  border-radius: var(--r-xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.press-callout-text {
  font-size: 0.9375rem;
  color: var(--text-2);
  line-height: 1.6;
  margin: 0;
  max-width: 640px;
}
.press-callout-text strong { color: var(--text-0); font-weight: 600; }

/* Storylane interactive demo */
.storylane-demo {
  background: var(--bg-0);
  scroll-margin-top: 88px;
}
.storylane-embed {
  max-width: 1120px;
  margin: 0 auto 40px;
}
.storylane-embed .sl-embed {
  position: relative;
  padding-bottom: calc(54.06% + 25px);
  width: 100%;
  height: 0;
  transform: scale(1);
}
.storylane-embed .sl-demo {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  border: 1px solid var(--border-brand-sub);
  box-shadow: var(--shadow-lg);
  border-radius: var(--r-xl);
  box-sizing: border-box;
}
.storylane-demo-cta {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
  padding-top: 40px;
  border-top: 1px solid var(--border-0);
}
.storylane-demo-cta > p {
  font-size: 1.0625rem;
  color: var(--text-2);
  line-height: 1.72;
  margin-bottom: 28px;
}
.storylane-seo-fallback {
  display: none;
  visibility: hidden;
  width: 1px;
  height: 1px;
  overflow: hidden;
  position: absolute;
  clip: rect(0, 0, 0, 0);
}

/* APEX closed loop — horizontal track */
.apex-loop { margin: 48px auto 24px; max-width: 1280px; }

.apex-loop-track {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items: stretch;
  gap: 12px;
}

.apex-loop-step { min-width: 0; }

.apex-loop-step-card {
  background: var(--bg-card);
  border: 1px solid var(--border-1);
  border-radius: var(--r-xl);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
}
.apex-loop-step-card:hover {
  transform: translateY(-4px);
  border-color: var(--border-brand-sub);
  box-shadow: var(--shadow-md);
}
.apex-loop-step-accent { height: 3px; flex-shrink: 0; }
.apex-loop-step-head,
.apex-loop-step-card > p,
.apex-loop-step-card > .apex-loop-outcome {
  padding-left: 20px;
  padding-right: 20px;
}
.apex-loop-step-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 20px;
  margin-bottom: 12px;
}
.apex-loop-step-head h4 {
  font-size: 1.0625rem;
  font-weight: 700;
  margin: 0;
  color: var(--text-0);
}
.apex-loop-step-card > p {
  font-size: 0.875rem;
  color: var(--text-2);
  line-height: 1.65;
  margin: 0 0 16px;
  flex: 1;
}

.apex-loop-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-4);
  width: 40px;
  flex-shrink: 0;
}
.apex-loop-arrow svg { width: 40px; height: 24px; }

.apex-loop-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
}
.apex-loop-outcome {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  padding-top: 12px;
  padding-bottom: 18px;
  border-top: 1px solid var(--border-0);
  margin-top: auto;
}

.apex-loop-closure {
  position: relative;
  margin-top: 8px;
  padding-top: 28px;
}
.apex-loop-closure-svg {
  position: absolute;
  top: 0;
  left: 5%;
  width: 90%;
  height: 48px;
  pointer-events: none;
}
.apex-loop-closure-path {
  animation: apex-loop-dash 4s linear infinite;
}
.apex-loop-closure-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  padding-top: 20px;
}
.apex-loop-hub {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.apex-loop-hub--inline {
  flex-direction: row;
  gap: 10px;
  padding: 8px 16px;
  border-radius: var(--r-full);
  background: var(--bg-1);
  border: 1.5px solid var(--border-brand);
  box-shadow: 0 0 24px rgba(111,81,206,0.12);
}
.apex-loop-hub-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--grad-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.apex-loop-hub-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 0.8125rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: var(--text-0);
}
.apex-loop-closure-label {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--green-light);
  letter-spacing: 0.02em;
}
@keyframes apex-loop-dash { from { stroke-dashoffset: 28; } to { stroke-dashoffset: 0; } }

.apex-loop-note {
  max-width: 680px;
  margin: 28px auto 32px;
  padding: 14px 18px;
  font-size: 0.875rem;
  color: var(--text-2);
  line-height: 1.65;
  border-left: 2px solid var(--amber);
}
.apex-loop-note strong { color: var(--amber); }

/* After the loop closes */
.loop-outcomes {
  background: linear-gradient(135deg, rgba(111,81,206,0.06), rgba(34,197,94,0.04));
  border: 1px solid var(--border-brand-sub);
  border-radius: var(--r-2xl);
  padding: 28px 32px;
  text-align: center;
}
.loop-outcomes-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-light);
  margin-bottom: 20px;
}
.loop-outcomes-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
  text-align: left;
}
.loop-outcome-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--bg-card);
  border: 1px solid var(--border-1);
  border-radius: var(--r-lg);
  padding: 18px 20px;
}
.loop-outcome-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.04);
}
.loop-outcome-card strong {
  display: block;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--text-0);
  margin-bottom: 4px;
}
.loop-outcome-card p {
  font-size: 0.8125rem;
  color: var(--text-2);
  line-height: 1.55;
  margin: 0;
}
.loop-outcomes-cta { margin: 0 auto; }

/* What changes */
.what-changes { background: var(--bg-0); }
.what-changes-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.what-changes-card {
  background: var(--bg-card);
  border: 1px solid var(--border-1);
  border-radius: var(--r-xl);
  padding: 26px 28px;
  position: relative;
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
}
.what-changes-card:hover {
  transform: translateY(-3px);
  border-color: var(--border-brand-sub);
  box-shadow: var(--shadow-md);
}
.what-changes-num {
  display: inline-block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: var(--brand-light);
  background: rgba(111,81,206,0.1);
  border: 1px solid rgba(111,81,206,0.2);
  border-radius: var(--r-full);
  padding: 3px 10px;
  margin-bottom: 14px;
}
.what-changes-card h3 {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--text-0);
  margin-bottom: 10px;
}
.what-changes-card p {
  font-size: 0.875rem;
  color: var(--text-2);
  line-height: 1.65;
  margin: 0;
}

.steps-row { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:64px; position:relative; }
.steps-connector { position:absolute; top:28px; left:calc(12.5% + 18px); right:calc(12.5% + 18px); height:1px; background:linear-gradient(90deg, var(--border-brand), var(--border-1), var(--border-brand)); z-index:0; }
.step-card { background:var(--bg-1); border:1px solid var(--border-1); border-radius:var(--r-xl); padding:28px 24px; position:relative; z-index:1; transition:transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base); }
.step-card:hover { transform:translateY(-5px); border-color:var(--border-brand); box-shadow:var(--shadow-md); }
.step-num { width:36px; height:36px; border-radius:50%; background:var(--grad-brand); display:flex; align-items:center; justify-content:center; font-family:'Plus Jakarta Sans',sans-serif; font-size:0.8125rem; font-weight:800; color:white; margin-bottom:18px; position:relative; z-index:2; box-shadow:0 0 0 4px rgba(111,81,206,0.12); }
.step-card h4 { font-size:1rem; font-weight:700; margin-bottom:8px; color:var(--text-0); }
.step-card p { font-size:0.875rem; color:var(--text-2); line-height:1.6; margin:0; }

/* ========================
   RESULTS STRIP
   ======================== */
.results-strip { padding:0; background:var(--bg-1); border-top:1px solid var(--border-1); border-bottom:1px solid var(--border-1); }
.results-strip-inner { max-width:var(--container); margin:0 auto; padding:64px 28px; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; text-align:center; position:relative; }
.results-strip-inner::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 100% at 50% 50%, rgba(111,81,206,0.06), transparent); pointer-events:none; }
.result-item { position:relative; z-index:1; }
.result-value { font-family:'Plus Jakarta Sans',sans-serif; font-size:clamp(2.25rem,4vw,3rem); font-weight:800; letter-spacing:-0.04em; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; line-height:1; margin-bottom:8px; }
.result-label { font-size:0.875rem; color:var(--text-2); font-weight:500; }

/* ========================
   TESTIMONIALS
   ======================== */
.testimonials-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.testimonial-card { background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-xl); padding:28px; transition:transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base); }
.testimonial-card:hover { transform:translateY(-3px); border-color:var(--border-brand-sub); box-shadow:var(--shadow-md); }
.testimonial-stars { display:flex; gap:3px; margin-bottom:18px; color:#F59E0B; font-size:0.875rem; }
.testimonial-quote { font-size:1rem; line-height:1.72; color:var(--text-1); margin-bottom:24px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:13px; }
.testimonial-avatar { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:0.9375rem; color:white; flex-shrink:0; }
.avatar-blue { background:linear-gradient(135deg,#6f51ce,#5842B5); }
.avatar-purple { background:linear-gradient(135deg,#8B6FE5,#6f51ce); }
.avatar-cyan { background:linear-gradient(135deg,#9B77F0,#7A5CD8); }
.avatar-green { background:linear-gradient(135deg,#10B981,#059669); }
.testimonial-name { font-family:'Plus Jakarta Sans',sans-serif; font-weight:700; font-size:0.9375rem; color:var(--text-0); margin-bottom:2px; }
.testimonial-role { font-size:0.8rem; color:var(--text-3); }
.testimonial-result { margin-top:18px; padding:10px 14px; background:rgba(16,185,129,0.08); border:1px solid rgba(16,185,129,0.18); border-radius:var(--r-sm); font-size:0.8375rem; font-weight:600; color:#34D399; display:flex; align-items:center; gap:7px; }

/* ========================
   PRICING
   ======================== */
.pricing { background:var(--bg-1); }
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:start; }
.pricing-card { background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-2xl); padding:32px; position:relative; transition:transform var(--t-base), box-shadow var(--t-base); }
.pricing-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.pricing-card.popular { background:var(--grad-card); border-color:var(--border-brand); -webkit-transform:scale(1.02); transform:scale(1.02); }
.pricing-card.popular:hover { -webkit-transform:scale(1.02) translateY(-4px); transform:scale(1.02) translateY(-4px); }
.popular-badge { position:absolute; top:-13px; left:50%; -webkit-transform:translateX(-50%); transform:translateX(-50%); padding:4px 18px; background:var(--grad-brand); border-radius:var(--r-full); font-family:'Plus Jakarta Sans',sans-serif; font-size:0.72rem; font-weight:700; color:white; text-transform:uppercase; letter-spacing:0.1em; white-space:nowrap; box-shadow:0 4px 12px rgba(111,81,206,0.3); }
.pricing-tier { font-size:0.75rem; font-weight:700; color:var(--brand-light); text-transform:uppercase; letter-spacing:0.12em; margin-bottom:14px; }
.pricing-price-row { display:flex; align-items:baseline; gap:4px; margin-bottom:6px; }
.pricing-currency { font-family:'Plus Jakarta Sans',sans-serif; font-size:1.5rem; font-weight:700; color:var(--text-0); }
.pricing-amount { font-family:'Plus Jakarta Sans',sans-serif; font-size:3rem; font-weight:800; letter-spacing:-0.04em; color:var(--text-0); line-height:1; }
.pricing-period { font-size:0.875rem; color:var(--text-3); font-weight:500; }
.pricing-scope { font-size:0.8rem; color:var(--text-3); margin-bottom:18px; }
.pricing-desc { font-size:0.9rem; color:var(--text-2); line-height:1.65; padding-bottom:20px; border-bottom:1px solid var(--border-1); margin-bottom:20px; }
.pricing-features-list { list-style:none; display:flex; flex-direction:column; gap:11px; margin-bottom:28px; }
.pricing-feature-item { display:flex; align-items:flex-start; gap:10px; font-size:0.875rem; color:var(--text-2); line-height:1.5; }
.feature-check { width:18px; height:18px; border-radius:50%; background:rgba(16,185,129,0.12); border:1px solid rgba(16,185,129,0.25); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.feature-check svg { width:9px; height:9px; color:#10B981; }
.pricing-cta { width:100%; display:flex; justify-content:center; }
.pricing-cta .btn { width:100%; }
.pricing-note { text-align:center; margin-top:36px; font-size:0.875rem; color:var(--text-3); }
.pricing-note a { color:var(--brand-light); text-decoration:underline; text-underline-offset:3px; }

.pricing-billing-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin: 0 auto 40px;
  padding: 4px;
  background: var(--bg-card);
  border: 1px solid var(--border-1);
  border-radius: var(--r-full);
  width: fit-content;
}
.billing-opt {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border: none;
  border-radius: var(--r-full);
  background: transparent;
  color: var(--text-2);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--t-base), color var(--t-base);
}
.billing-opt.is-active {
  background: var(--grad-brand);
  color: white;
  box-shadow: 0 4px 12px rgba(111,81,206,0.25);
}
.billing-save-badge {
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--r-full);
  background: rgba(16,185,129,0.15);
  color: var(--green-light);
  letter-spacing: 0.02em;
}
.billing-opt.is-active .billing-save-badge {
  background: rgba(255,255,255,0.2);
  color: white;
}
.pricing.is-yearly .pricing-currency[data-hide-yearly] { display: none; }
.pricing-amount--text { font-size: 2.25rem !important; }
.pricing-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 24px;
  margin-top: 36px;
}
.pricing-trust-item {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text-3);
  display: flex;
  align-items: center;
  gap: 8px;
}
.pricing-trust-item::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
}

/* ========================
   COMPARISON
   ======================== */
.comparison { background:var(--bg-0); }
.comparison-table { border:1px solid var(--border-1); border-radius:var(--r-xl); overflow:hidden; margin-top:56px; overflow-x:auto; }
.comparison-table table { width:100%; border-collapse:collapse; min-width:600px; }
.comparison-table th, .comparison-table td { padding:16px 24px; text-align:left; border-bottom:1px solid var(--border-1); font-size:0.9rem; }
.comparison-table thead th { background:var(--bg-1); font-family:'Plus Jakarta Sans',sans-serif; font-size:0.8125rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-2); }
.comparison-table thead th.highlight { color:var(--brand-light); background:rgba(111,81,206,0.06); }
.comparison-table tbody tr:last-child td { border-bottom:none; }
.comparison-table tbody tr:hover td { background:var(--bg-card); }
.comparison-table td:first-child { color:var(--text-2); font-weight:500; }
.comparison-table td.highlight { background:rgba(111,81,206,0.04); color:var(--text-1); font-weight:500; }
.check-yes { color:#10B981; font-size:1rem; }
.check-partial { color:#F59E0B; font-size:0.75rem; font-weight:600; }
.check-no { color:var(--text-4); font-size:0.875rem; }

/* ========================
   FAQ
   ======================== */
.faq-grid { max-width:800px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
.faq-item { background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-lg); overflow:hidden; transition:border-color var(--t-base); }
.faq-item.open { border-color:var(--border-brand); }
.faq-question { padding:19px 22px; display:flex; align-items:center; justify-content:space-between; gap:16px; cursor:pointer; font-family:'Plus Jakarta Sans',sans-serif; font-weight:600; font-size:0.9375rem; color:var(--text-1); -webkit-user-select:none; user-select:none; transition:color var(--t-fast); }
.faq-question:hover { color:var(--text-0); }
.faq-toggle { width:26px; height:26px; border-radius:50%; background:var(--bg-card-hover); border:1px solid var(--border-0); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--text-2); transition:background var(--t-base), border-color var(--t-base), transform var(--t-base), color var(--t-base); font-size:1rem; line-height:1; }
.faq-item.open .faq-toggle { background:rgba(111,81,206,0.14); border-color:rgba(111,81,206,0.30); color:var(--brand-light); -webkit-transform:rotate(45deg); transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.38s cubic-bezier(0.4,0,0.2,1); }
.faq-answer-body { padding:0 22px 20px; color:var(--text-2); font-size:0.9375rem; line-height:1.72; }
.faq-answer-body strong { color:var(--text-0); font-weight:600; }
.faq-answer-body a { color:var(--brand-light); text-decoration:underline; text-underline-offset:3px; }
.faq-answer-body a:hover { color:var(--text-0); }

/* ========================
   CTA BANNER
   ======================== */
.cta-banner { background:var(--bg-1); position:relative; overflow:hidden; }
.cta-banner-glow { position:absolute; bottom:-100px; left:50%; -webkit-transform:translateX(-50%); transform:translateX(-50%); width:800px; height:400px; background:radial-gradient(ellipse, rgba(111,81,206,0.14) 0%, transparent 65%); pointer-events:none; }
.cta-banner-content { position:relative; z-index:1; text-align:center; max-width:660px; margin:0 auto; }
.cta-banner h2 { margin-bottom:16px; }
.cta-banner p { font-size:1.0625rem; color:var(--text-2); margin-bottom:40px; line-height:1.72; }
.cta-actions { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.cta-note { margin-top:18px; font-size:0.8125rem; color:var(--text-4); }

/* ========================
   FOOTER
   ======================== */
.footer { background:var(--bg-0); border-top:1px solid var(--border-1); padding:72px 28px 40px; }
.footer-inner { max-width:var(--container); margin:0 auto; }
.footer-top { display:grid; grid-template-columns:2.5fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid var(--border-1); margin-bottom:32px; }
.footer-logo { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.footer-logo-img { height: 24px; width: auto; }
.footer-brand p { font-size:0.875rem; color:var(--text-3); line-height:1.7; max-width:280px; margin-bottom:22px; }
.footer-socials { display:flex; gap:10px; flex-wrap:wrap; }
.footer-social {
  width:36px; height:36px;
  background:var(--bg-card);
  border:1px solid var(--border-1);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-2);
  transition:background var(--t-fast), border-color var(--t-fast), color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.footer-social svg { display:block; width:15px; height:15px; flex-shrink:0; }
.footer-social:hover {
  background:rgba(111,81,206,0.10);
  border-color:rgba(111,81,206,0.35);
  color:var(--brand-light);
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(111,81,206,0.15);
}
.footer-col h5 { font-family:'Plus Jakarta Sans',sans-serif; font-size:0.8rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-2); margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:11px; }
.footer-col a { font-size:0.875rem; color:var(--text-3); transition:color var(--t-fast); }
.footer-col a:hover { color:var(--text-1); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-bottom p { font-size:0.8125rem; color:var(--text-4); margin:0; }
.footer-bottom-links { display:flex; gap:22px; }
.footer-bottom-links a { font-size:0.8125rem; color:var(--text-4); transition:color var(--t-fast); }
.footer-bottom-links a:hover { color:var(--text-2); }

/* ========================
   BLOG STYLES
   ======================== */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.blog-card { background:var(--bg-card); border:1px solid var(--border-1); border-radius:var(--r-xl); overflow:hidden; display:flex; flex-direction:column; transition:transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base); }
.blog-card:hover { transform:translateY(-4px); border-color:var(--border-brand-sub); box-shadow:var(--shadow-card-hover); }
.blog-card-img { width:100%; aspect-ratio:16/9; background:var(--grad-card); display:flex; align-items:center; justify-content:center; font-size:2rem; position:relative; overflow:hidden; }
.blog-card-img img { width:100%; height:100%; object-fit:cover; }
.blog-card-body { padding:20px; flex:1; display:flex; flex-direction:column; }
.blog-card-tag { display:inline-flex; align-items:center; padding:3px 10px; background:rgba(111,81,206,0.10); border:1px solid rgba(111,81,206,0.20); border-radius:var(--r-full); font-size:0.72rem; font-weight:700; color:var(--brand-light); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:12px; width:fit-content; }
.blog-card h3 { font-size:1rem; font-weight:700; line-height:1.4; margin-bottom:10px; color:var(--text-0); }
.blog-card p { font-size:0.875rem; color:var(--text-2); line-height:1.6; flex:1; margin-bottom:16px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.blog-card-footer { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--border-1); }
.blog-card-date { font-size:0.775rem; color:var(--text-3); }
.blog-card-read { font-size:0.775rem; font-weight:600; color:var(--brand-light); display:flex; align-items:center; gap:4px; }
.blog-card-read svg { width:12px; height:12px; transition:transform var(--t-fast); }
.blog-card:hover .blog-card-read svg { transform:translateX(2px); }

/* Blog post article */
.blog-article { max-width: 780px; margin: 0 auto; padding: 80px 28px 60px; }
.blog-article-header { margin-bottom:48px; }
.blog-article-meta { display:flex; align-items:center; gap:16px; margin-bottom:24px; flex-wrap:wrap; }
.blog-article-tag { display:inline-flex; align-items:center; padding:3px 12px; background:rgba(111,81,206,0.10); border:1px solid rgba(111,81,206,0.20); border-radius:var(--r-full); font-size:0.75rem; font-weight:700; color:var(--brand-light); text-transform:uppercase; letter-spacing:0.06em; }
.blog-article-date { font-size:0.875rem; color:var(--text-3); }
.blog-article h1 { font-size:clamp(1.875rem,4vw,2.75rem); line-height:1.2; margin-bottom:20px; }
.blog-article-intro { font-size:1.125rem; color:var(--text-2); line-height:1.75; }
.blog-article-divider { height:1px; background:var(--border-1); margin:40px 0; }
.blog-article-content h2 { font-size:1.625rem; margin:40px 0 16px; }
.blog-article-content h3 { font-size:1.25rem; margin:32px 0 12px; }
.blog-article-content h4 { font-size:1.0625rem; margin:24px 0 10px; }
.blog-article-content p { font-size:1rem; color:var(--text-2); line-height:1.78; margin-bottom:18px; }
.blog-article-content ul, .blog-article-content ol { padding-left:24px; margin-bottom:18px; }
.blog-article-content li { font-size:1rem; color:var(--text-2); line-height:1.72; margin-bottom:8px; }
.blog-article-content code { font-family:'JetBrains Mono','Fira Code',monospace; font-size:0.875rem; background:rgba(111,81,206,0.10); border:1px solid rgba(111,81,206,0.18); border-radius:4px; padding:2px 6px; color:var(--brand-light); }
.blog-article-content pre { background:var(--bg-1); border:1px solid var(--border-1); border-radius:var(--r-md); padding:20px; overflow-x:auto; margin-bottom:20px; }
.blog-article-content pre code { background:none; border:none; padding:0; color:var(--text-1); }
.blog-article-content blockquote { border-left:3px solid var(--brand); padding:4px 0 4px 20px; margin:24px 0; }
.blog-article-content blockquote p { color:var(--text-1); font-style:italic; font-size:1.0625rem; }
.blog-article-cta { margin-top:56px; padding:32px; background:var(--grad-card); border:1px solid var(--border-brand); border-radius:var(--r-xl); text-align:center; }
.blog-article-cta h3 { font-size:1.25rem; margin-bottom:12px; }

/* Article content — tables, figures, exported HTML fixes */
.article-content figure { margin: 24px 0; }
.article-content .table-wrap,
.article-content figure:has(table) {
  overflow-x: auto;
  margin: 24px 0;
  border: 1px solid var(--border-1);
  border-radius: 12px;
  background: var(--bg-card);
  -webkit-overflow-scrolling: touch;
}
.article-content table {
  width: 100%;
  min-width: 280px;
  border-collapse: collapse;
  font-size: 14.5px;
}
.article-content th,
.article-content td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border-1);
  vertical-align: top;
  color: var(--text-1);
}
.article-content th {
  background: rgba(111,81,206,0.08);
  font-weight: 700;
  color: var(--text-0);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.article-content tr:last-child td { border-bottom: 0; }
.article-content td p,
.article-content th p { margin: 0; }
.article-content .anavsan-help {
  border-radius: 12px;
  padding: 16px 20px;
  margin: 20px 0;
  border: 1px solid rgba(111,81,206,0.2);
  background: rgba(111,81,206,0.07);
}
.article-content .anavsan-help-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--brand-light);
  margin-bottom: 8px;
}
.article-content .anavsan-help p { margin: 0; font-size: 14.5px; line-height: 1.65; }
.article-content .workflow-steps { margin: 16px 0 20px; padding-left: 20px; }
.article-content .workflow-steps li { margin-bottom: 10px; }
.article-content .workflow-steps strong { color: var(--text-0); }

.blog-article-cta p { font-size:0.9375rem; color:var(--text-2); margin-bottom:24px; }
.blog-article-cta p { font-size:0.9375rem; margin-bottom:24px; max-width:500px; margin-left:auto; margin-right:auto; }
.blog-article-nav { display:flex; align-items:center; justify-content:space-between; margin-top:48px; padding-top:32px; border-top:1px solid var(--border-1); gap:20px; flex-wrap:wrap; }
.blog-article-nav a { display:flex; align-items:center; gap:8px; font-size:0.9rem; font-weight:600; color:var(--brand-light); transition:color var(--t-fast); max-width:45%; }
.blog-article-nav a:hover { color:var(--brand-xlight); }

/* Blog categories filter */
.blog-filters { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:40px; }
.blog-filter-btn { padding:7px 18px; border-radius:var(--r-full); font-size:0.8375rem; font-weight:600; cursor:pointer; border:1px solid var(--border-0); background:var(--bg-card); color:var(--text-2); transition:all var(--t-fast); }
.blog-filter-btn:hover, .blog-filter-btn.active { background:rgba(111,81,206,0.12); border-color:var(--border-brand); color:var(--brand-light); }

/* ========================
   SCROLL REVEAL
   ======================== */
.reveal { opacity:0; -webkit-transform:translateY(28px); transform:translateY(28px); transition:opacity 0.65s var(--ease-out), -webkit-transform 0.65s var(--ease-out), transform 0.65s var(--ease-out); }
.reveal.visible { opacity:1; -webkit-transform:translateY(0); transform:translateY(0); }
.reveal-left { opacity:0; -webkit-transform:translateX(-28px); transform:translateX(-28px); transition:opacity 0.65s var(--ease-out), -webkit-transform 0.65s var(--ease-out), transform 0.65s var(--ease-out); }
.reveal-left.visible { opacity:1; -webkit-transform:translateX(0); transform:translateX(0); }
.reveal-right { opacity:0; -webkit-transform:translateX(28px); transform:translateX(28px); transition:opacity 0.65s var(--ease-out), -webkit-transform 0.65s var(--ease-out), transform 0.65s var(--ease-out); }
.reveal-right.visible { opacity:1; -webkit-transform:translateX(0); transform:translateX(0); }
.delay-1 { transition-delay:0.08s; } .delay-2 { transition-delay:0.16s; }
.delay-3 { transition-delay:0.24s; } .delay-4 { transition-delay:0.32s; }
.delay-5 { transition-delay:0.40s; }

/* ========================
   KEYFRAMES
   ======================== */
@keyframes orb-drift-1 { 0%,100%{-webkit-transform:translate(0,0) scale(1);transform:translate(0,0) scale(1)} 33%{-webkit-transform:translate(40px,-30px) scale(1.06);transform:translate(40px,-30px) scale(1.06)} 66%{-webkit-transform:translate(-20px,20px) scale(0.95);transform:translate(-20px,20px) scale(0.95)} }
@keyframes orb-drift-2 { 0%,100%{-webkit-transform:translate(0,0) scale(1);transform:translate(0,0) scale(1)} 40%{-webkit-transform:translate(-30px,40px) scale(1.08);transform:translate(-30px,40px) scale(1.08)} 70%{-webkit-transform:translate(20px,-20px) scale(0.92);transform:translate(20px,-20px) scale(0.92)} }
@keyframes orb-drift-3 { 0%,100%{-webkit-transform:translate(0,0);transform:translate(0,0)} 50%{-webkit-transform:translate(-40px,-20px);transform:translate(-40px,-20px)} }
@keyframes pulse-dot { 0%,100%{opacity:1;-webkit-transform:scale(1);transform:scale(1)} 50%{opacity:0.55;-webkit-transform:scale(0.75);transform:scale(0.75)} }
@keyframes fade-in-up { from{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px)} to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)} }
@keyframes fade-in { from{opacity:0} to{opacity:1} }
@keyframes spin { to { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }

/* ========================
   REDUCED MOTION
   ======================== */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
  .orb { display:none; }
  .reveal,.reveal-left,.reveal-right { opacity:1 !important; -webkit-transform:none !important; transform:none !important; }
}

/* ========================
   RESPONSIVE — TABLET
   ======================== */
@media (max-width:960px) {
  .apex-loop-track {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .apex-loop-arrow {
    width: 100%;
    padding: 6px 0;
    transform: rotate(90deg);
  }
  .loop-outcomes-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:1024px) {
  :root { --s-section:88px; }
  .products-grid { grid-template-columns:repeat(2,1fr); }
  .product-card.featured { grid-column:span 1; }
  .steps-row { grid-template-columns:repeat(2,1fr); }
  .steps-connector { display:none; }
  .results-strip-inner { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; }
  .blog-grid { grid-template-columns:repeat(2,1fr); }
  .apex-loop-track { gap: 8px; }
  .apex-loop-arrow { width: 28px; }
  .loop-outcomes-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ========================
   RESPONSIVE — MOBILE
   ======================== */
@media (max-width:768px) {
  :root { --s-section:64px; }
  .container { padding:0 20px; }
  .nav-links, .nav-actions .btn-ghost { display:none; }
  .nav-hamburger { display:flex; }
  .hero { padding:96px 20px 60px; min-height:auto; }
  .hero-stats { gap:28px; }
  .hero-divider { display:none; }
  .hero-preview { display:none; }
  .problem-grid { grid-template-columns:1fr; gap:44px; }
  .products-grid { grid-template-columns:1fr; }
  .steps-row { grid-template-columns:1fr; }
  .results-strip-inner { grid-template-columns:repeat(2,1fr); gap:24px; }
  .testimonials-grid { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; }
  .pricing-card.popular { -webkit-transform:none; transform:none; }
  .pricing-card.popular:hover { -webkit-transform:translateY(-4px); transform:translateY(-4px); }
  .footer-top { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .dashboard-body { grid-template-columns:1fr 1fr; }
  .dash-bar-row { grid-column:span 2; }
  .blog-grid { grid-template-columns:1fr; }
  .blog-article { padding:80px 20px 40px; }
  .what-changes-grid { grid-template-columns:1fr; }
  .loop-outcomes-grid { grid-template-columns: 1fr; }
  .apex-loop-track {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .apex-loop-arrow {
    width: 100%;
    padding: 4px 0;
    transform: rotate(90deg);
  }
  .apex-loop-closure-svg { display: none; }
  .loop-outcomes { padding: 24px 20px; }
  .press-callout { flex-direction: column; align-items: flex-start; }
  .storylane-demo-cta { padding-top: 28px; }
  .storylane-embed { margin-bottom: 28px; }
  .pricing-billing-toggle { flex-wrap: wrap; }
  .billing-opt { padding: 8px 14px; font-size: 0.8125rem; }
}
@media (max-width:480px) {
  .hero-headline { font-size:2.125rem; }
  .hero-actions { flex-direction:column; }
  .hero-actions .btn { width:100%; }
  .results-strip-inner { grid-template-columns:1fr 1fr; }
  .cta-actions { flex-direction:column; }
  .cta-actions .btn { width:100%; }
}
