/* ==========================================================================
   Vulpine — v2: Multi-Million Dollar Tier
   ========================================================================== */

:root {
  --dark-950: #070B14;
  --dark-900: #0B1222;
  --dark-800: #111A2E;
  --dark-700: #1A2540;
  --dark-600: #243352;

  --white: #FFFFFF;
  --gray-50: #F8FAFC;
  --gray-100: #F1F5F9;
  --gray-200: #E2E8F0;
  --gray-300: #CBD5E1;
  --gray-400: #94A3B8;
  --gray-500: #64748B;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-800: #1E293B;
  --gray-900: #0F172A;

  --accent: #FF6B35;
  --accent-hover: #E85D2C;
  --accent-glow: rgba(255, 107, 53, 0.25);
  --accent-soft: rgba(255, 107, 53, 0.08);

  --green: #22C55E;
  --green-dim: rgba(34, 197, 94, 0.15);
  --amber: #F59E0B;
  --amber-dim: rgba(245, 158, 11, 0.15);
  --red: #EF4444;
  --red-dim: rgba(239, 68, 68, 0.15);

  --font-heading: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;

  --section-pad: clamp(4rem, 8vw, 7rem);
  --max-w: 1180px;
  --radius: 8px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* --- Reset --- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:80px; }
body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--gray-800);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { border:none; background:none; cursor:pointer; font-family:inherit; }
ul { list-style:none; }
::selection { background:var(--accent); color:#fff; }

/* Subtle texture for white sections */
.features, .pricing, .testimonials {
  background-image: radial-gradient(circle at 1px 1px, var(--gray-200) 1px, transparent 0);
  background-size: 40px 40px;
}


/* ==========================================================================
   Navigation — colour-aware
   ========================================================================== */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:100;
  background: rgba(7,11,20,0.6);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.nav--scrolled {
  box-shadow: 0 1px 24px rgba(0,0,0,0.15);
}

/* Light mode (on white sections) */
.nav--light {
  background: rgba(255,255,255,0.85);
  border-bottom-color: var(--gray-200);
}
.nav--light .logo-text { color: var(--gray-900); }
.nav--light .nav-link { color: var(--gray-500); }
.nav--light .nav-link:hover { color: var(--gray-900); }
.nav--light .nav-toggle span { background: var(--gray-800); }
.nav--light .nav-mobile { background: rgba(255,255,255,0.98); }
.nav--light .nav-mobile-link { color: var(--gray-600); border-bottom-color: var(--gray-100); }
.nav--light.nav--scrolled { box-shadow: 0 1px 12px rgba(0,0,0,0.06); }

.nav-inner {
  max-width: var(--max-w);
  margin: 0 auto; padding: 0 1.5rem;
  height: 68px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo { display:flex; align-items:center; gap:9px; }
.logo-text {
  font-family: var(--font-heading);
  font-size: 1.35rem; font-weight: 800;
  color: #fff; letter-spacing: -0.03em;
  transition: color var(--transition);
}

.nav-links { display:none; align-items:center; gap:2rem; }
.nav-link {
  font-size: 0.88rem; font-weight: 500;
  color: var(--gray-400);
  transition: color var(--transition);
}
.nav-link:hover { color: #fff; }

.nav-actions { display:none; align-items:center; gap:1.25rem; }

.nav-toggle {
  display:flex; flex-direction:column; gap:5px; padding:8px; z-index:10;
}
.nav-toggle span {
  display:block; width:22px; height:2px; background:#fff; border-radius:1px;
  transition: transform var(--transition), opacity var(--transition), background var(--transition);
}
.nav-toggle[aria-expanded="true"] span:first-child { transform:translateY(3.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav-toggle[aria-expanded="true"] span:last-child { transform:translateY(-3.5px) rotate(-45deg); }

.nav-mobile {
  display:flex; flex-direction:column;
  padding:0 1.5rem; max-height:0; overflow:hidden;
  transition: max-height 0.35s ease, padding 0.35s ease;
  background: rgba(7,11,20,0.95);
}
.nav-mobile.is-open { max-height:320px; padding:0.5rem 1.5rem 1rem; }
.nav-mobile-link {
  padding:0.7rem 0; font-size:0.95rem; font-weight:500;
  color:var(--gray-400);
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition: color var(--transition);
}
.nav-mobile-link:hover { color:#fff; }


/* ==========================================================================
   Buttons
   ========================================================================== */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-heading); font-weight:700; font-size:0.88rem;
  border-radius:var(--radius); padding:0.7rem 1.5rem;
  transition:all var(--transition); cursor:pointer;
  letter-spacing:-0.01em;
}
.btn--accent {
  background:var(--accent); color:#fff;
  box-shadow: 0 0 0 1px rgba(255,107,53,0.3), 0 2px 8px var(--accent-glow);
}
.btn--accent:hover {
  background:var(--accent-hover);
  box-shadow: 0 0 0 1px rgba(255,107,53,0.4), 0 4px 20px var(--accent-glow);
  transform:translateY(-1px);
}
.btn--sm { padding:0.55rem 1.15rem; font-size:0.82rem; }
.btn--lg { padding:0.9rem 2rem; font-size:0.95rem; }
.btn--full { width:100%; }


/* ==========================================================================
   Hero — centered, dashboard-forward
   ========================================================================== */
.hero {
  position: relative;
  background: var(--dark-950);
  color: #fff;
  padding-top: calc(68px + 3.5rem);
  overflow: hidden;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; }
.hero-grid-pattern {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, black 20%, transparent 70%);
}
.hero-glow {
  position:absolute; width:800px; height:800px;
  top:-250px; left:50%; transform:translateX(-50%);
  background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 60%);
}
.hero-glow--2 {
  top:auto; bottom:-300px; left:60%;
  background: radial-gradient(circle, rgba(34,197,94,0.06) 0%, transparent 60%);
}

/* Hero top — centered text */
.hero-top {
  position: relative;
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
  padding: 0 1.5rem;
}

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.78rem; font-weight:600; color:var(--gray-400);
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:100px; padding:6px 16px;
  margin-bottom:1.5rem; letter-spacing:0.02em;
}
.hero-badge-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px rgba(34,197,94,0.5);
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.5} }

.hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.035em;
}
.hero-title-accent { color: var(--accent); }

.hero-desc {
  margin-top: 1.25rem;
  font-size: 1.05rem; line-height: 1.7;
  color: var(--gray-400);
  max-width: 560px;
  margin-left: auto; margin-right: auto;
}

/* URL input */
.hero-input-wrap { margin-top: 2rem; }
.hero-input {
  display:flex; align-items:center;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-lg);
  padding:6px 6px 6px 16px;
  transition:border-color var(--transition), box-shadow var(--transition);
  max-width:520px;
  margin:0 auto;
}
.hero-input:focus-within {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}
.hero-input-icon { color:var(--gray-500); flex-shrink:0; margin-right:10px; }
.hero-input input {
  flex:1; background:transparent; border:none; outline:none;
  color:#fff; font-family:var(--font-body); font-size:0.92rem;
  padding:0.5rem 0; min-width:0;
}
.hero-input input::placeholder { color:var(--gray-500); }
.hero-input-btn {
  background:var(--accent); color:#fff;
  font-family:var(--font-heading); font-weight:700; font-size:0.82rem;
  padding:0.65rem 1.25rem; border-radius:var(--radius);
  white-space:nowrap; transition:background var(--transition);
}
.hero-input-btn:hover { background:var(--accent-hover); }
.hero-input-note {
  margin-top:0.75rem;
  font-size:0.78rem; color:var(--gray-500);
}

@media (max-width:479px) {
  .hero-input { flex-wrap:wrap; padding:12px; gap:8px; }
  .hero-input-icon { display:none; }
  .hero-input input { width:100%; padding:0.4rem 0; }
  .hero-input-btn { width:100%; padding:0.75rem; text-align:center; }
}


/* ==========================================================================
   Dashboard — massive, 3D perspective
   ========================================================================== */
.hero-dash-wrap {
  position: relative;
  margin-top: 3.5rem;
  padding: 0 1.5rem;
}
.hero-dash-perspective {
  max-width: 960px;
  margin: 0 auto;
  perspective: 1800px;
}

.dash {
  background: var(--dark-900);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transform: rotateX(4deg) scale(1.02);
  transform-origin: center top;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.05),
    0 4px 8px rgba(0,0,0,0.2),
    0 12px 40px rgba(0,0,0,0.3),
    0 30px 80px rgba(0,0,0,0.25),
    0 0 120px rgba(255,107,53,0.05);
  transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.dash:hover {
  transform: rotateX(2deg) scale(1.03);
}

.dash-topbar {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px;
  background:rgba(255,255,255,0.03);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.dash-dots { display:flex; gap:7px; }
.dash-dots span { width:11px; height:11px; border-radius:50%; background:rgba(255,255,255,0.1); }
.dash-dots span:first-child { background:#EF4444; }
.dash-dots span:nth-child(2) { background:#F59E0B; }
.dash-dots span:last-child { background:#22C55E; }
.dash-url { font-size:0.72rem; color:var(--gray-500); font-family:monospace; }

.dash-body {
  display:grid; grid-template-columns:1fr;
  min-height:320px;
}
.dash-sidebar {
  display:none; flex-direction:column; gap:2px;
  padding:14px 12px;
  background:rgba(255,255,255,0.02);
  border-right:1px solid rgba(255,255,255,0.06);
}
.dash-nav-item {
  display:flex; align-items:center; gap:8px;
  font-size:0.72rem; font-weight:500; color:var(--gray-500);
  padding:8px 12px; border-radius:6px;
  transition:all var(--transition);
}
.dash-nav-item--active {
  background:rgba(255,107,53,0.12); color:var(--accent);
}

.dash-main {
  padding:20px;
  display:flex; flex-direction:column; gap:20px;
}
.dash-metrics { display:flex; align-items:center; gap:20px; }
.dash-metric { text-align:center; flex-shrink:0; }
.dash-metric-score { position:relative; width:90px; height:90px; }
.dash-ring { width:100%; height:100%; }
.dash-metric-num {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-heading);
  font-size:1.6rem; font-weight:800; color:#fff;
}
.dash-metric-label {
  font-size:0.62rem; color:var(--gray-500); margin-top:4px;
  text-transform:uppercase; letter-spacing:0.06em; font-weight:600;
}
.dash-stat-group { display:flex; gap:20px; flex:1; }
.dash-stat { text-align:center; flex:1; }
.dash-stat-value {
  font-family:var(--font-heading);
  font-size:1.35rem; font-weight:800; display:block;
}
.dash-stat-value--green { color:var(--green); }
.dash-stat-value--amber { color:var(--amber); }
.dash-stat-value--red { color:var(--red); }
.dash-stat-label {
  font-size:0.6rem; color:var(--gray-500);
  text-transform:uppercase; letter-spacing:0.05em; font-weight:500;
  margin-top:2px; display:block;
}

.dash-issues { display:flex; flex-direction:column; gap:6px; }
.dash-issues-title {
  font-size:0.68rem; font-weight:700; color:var(--gray-400);
  text-transform:uppercase; letter-spacing:0.06em; margin-bottom:4px;
}
.dash-issue {
  display:flex; align-items:center; gap:8px;
  font-size:0.72rem; color:var(--gray-400);
  padding:8px 12px; border-radius:6px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.04);
}
.dash-issue-badge {
  font-size:0.58rem; font-weight:700; padding:2px 7px;
  border-radius:4px; text-transform:uppercase; letter-spacing:0.04em;
  flex-shrink:0;
}
.dash-issue-badge--critical { background:var(--red-dim); color:var(--red); }
.dash-issue-badge--warning { background:var(--amber-dim); color:var(--amber); }
.dash-issue-text { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.dash-issue-fix {
  font-size:0.6rem; font-weight:600; color:var(--accent);
  white-space:nowrap; opacity:0.7;
}

.dash-chart { margin-top:4px; }
.dash-chart-title {
  font-size:0.68rem; font-weight:700; color:var(--gray-400);
  text-transform:uppercase; letter-spacing:0.06em; margin-bottom:12px;
}
.dash-chart-bars { display:flex; align-items:flex-end; gap:8px; height:80px; }
.dash-bar {
  flex:1; border-radius:4px 4px 0 0;
  background:var(--dark-700);
  height:0;
  transition: height 0.8s cubic-bezier(0.4,0,0.2,1);
  position:relative;
}
.dash-bar.in-view { height:var(--h); background:var(--dark-600); }
.dash-bar--current.in-view { background:var(--accent); }
.dash-bar span {
  position:absolute; top:-18px; left:50%; transform:translateX(-50%);
  font-size:0.55rem; font-weight:700; color:var(--gray-500);
  opacity:0; transition:opacity 0.3s ease 0.5s;
}
.dash-bar.in-view span { opacity:1; }
.dash-bar--current span { color:var(--accent); }
.dash-chart-labels { display:flex; gap:8px; margin-top:6px; }
.dash-chart-labels span {
  flex:1; text-align:center;
  font-size:0.55rem; color:var(--gray-600); font-weight:500;
}

/* Scroll cue */
.hero-scroll-cue {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 2.5rem 0 1rem;
  color: var(--gray-500);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  animation: scrollBob 2s ease-in-out infinite;
}
@keyframes scrollBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(6px); }
}

/* Hero fade to white */
.hero-fade {
  height: 200px;
  background: linear-gradient(to bottom, var(--dark-950) 0%, #1a1f2e 40%, var(--gray-50) 100%);
  position: relative;
}


/* ==========================================================================
   Social Proof Strip
   ========================================================================== */
.proof-strip {
  padding: 3.5rem 1.5rem;
  background: var(--gray-50);
  border-bottom: 1px solid var(--gray-200);
}
.proof-strip-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem 4rem;
  text-align: center;
}
.proof-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  opacity:0; transform:translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.proof-stat.in-view { opacity:1; transform:translateY(0); }
.proof-stat:nth-child(2) { transition-delay: 0.1s; }
.proof-stat:nth-child(3) { transition-delay: 0.2s; }

.proof-stat-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--accent-soft);
  border: 1px solid rgba(255,107,53,0.12);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}

.proof-stat-num {
  font-family: var(--font-heading);
  font-size: 2.75rem; font-weight: 800;
  color: var(--gray-900);
  letter-spacing: -0.03em;
  display: block;
  line-height: 1;
}
.proof-stat-text {
  font-size: 0.85rem; color: var(--gray-500);
  font-weight: 500; margin-top: 2px;
  max-width: 200px;
}


/* ==========================================================================
   Sections — Shared
   ========================================================================== */
.section-label {
  font-family:var(--font-heading);
  font-size:0.75rem; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--accent); margin-bottom:0.75rem;
}
.section-title {
  font-family:var(--font-heading);
  font-size:clamp(1.75rem, 4vw, 2.75rem);
  font-weight:800; line-height:1.15;
  letter-spacing:-0.03em;
  color:var(--gray-900);
}
.section-sub {
  margin-top:1rem;
  font-size:1.05rem; line-height:1.7;
  color:var(--gray-500);
  max-width:560px;
}


/* ==========================================================================
   Features (merged with problems)
   ========================================================================== */
.features {
  padding: var(--section-pad) 1.5rem;
  background-color: var(--gray-50);
  border-top: 1px solid var(--gray-200);
}
.features-inner { max-width:var(--max-w); margin:0 auto; }

.feature-list {
  margin-top:3.5rem;
  display:flex; flex-direction:column; gap:5rem;
}
.feature-row {
  display:grid; grid-template-columns:1fr;
  gap:2rem; align-items:center;
  opacity:0; transform:translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.feature-row.in-view { opacity:1; transform:translateY(0); }

.feature-num {
  font-family:var(--font-heading);
  font-size:1.1rem; font-weight:800;
  color:var(--accent); letter-spacing:-0.02em;
  margin-bottom:0.75rem;
  opacity: 0.7;
}
.feature-name {
  font-family:var(--font-heading);
  font-size:1.35rem; font-weight:800;
  letter-spacing:-0.02em; margin-bottom:0.75rem;
}
.feature-pain {
  font-size:0.95rem; line-height:1.7; color:var(--gray-500);
  margin-bottom:0.75rem;
}
.feature-solution {
  font-size:0.92rem; line-height:1.7; color:var(--gray-600);
  padding-left:1rem;
  border-left:2px solid var(--accent);
}

/* Feature visual panels */
.fv-panel {
  background:var(--dark-900);
  border-radius:var(--radius-lg);
  padding:16px;
  border:1px solid rgba(255,255,255,0.06);
  box-shadow: 0 4px 24px rgba(0,0,0,0.15), 0 12px 48px rgba(0,0,0,0.1);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1), box-shadow 0.4s cubic-bezier(0.4,0,0.2,1), border-color 0.4s ease;
}
.fv-panel:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.2), 0 20px 60px rgba(0,0,0,0.15), 0 0 40px rgba(255,107,53,0.06);
  border-color: rgba(255,107,53,0.15);
}

/* Link checker */
.fv-link {
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:8px;
  font-size:0.75rem; font-family:monospace;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.04);
  margin-bottom:6px;
}
.fv-link:last-child { margin-bottom:0; }
.fv-link-status { font-weight:700; min-width:28px; text-align:center; }
.fv-link--ok .fv-link-status { color:var(--green); }
.fv-link--broken .fv-link-status { color:var(--red); }
.fv-link-url {
  flex:1; color:var(--gray-400);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.fv-link-badge {
  font-size:0.6rem; font-weight:700; padding:2px 8px;
  border-radius:4px; text-transform:uppercase; letter-spacing:0.03em;
}
.fv-link-badge--ok { background:var(--green-dim); color:var(--green); }
.fv-link-badge--broken { background:var(--red-dim); color:var(--red); }
.fv-link-badge--redirect { background:var(--amber-dim); color:var(--amber); }

/* Speed */
.fv-speed { display:flex; flex-direction:column; gap:16px; padding:20px; }
.fv-speed-header { display:flex; justify-content:space-between; margin-bottom:6px; }
.fv-speed-name {
  font-family:var(--font-heading); font-size:0.72rem; font-weight:700;
  color:var(--gray-400); letter-spacing:0.04em;
}
.fv-speed-val { font-family:var(--font-heading); font-size:0.85rem; font-weight:800; }
.fv-speed-val--good { color:var(--green); }
.fv-speed-val--warn { color:var(--amber); }
.fv-speed-bar { height:6px; background:var(--dark-700); border-radius:3px; overflow:hidden; }
.fv-speed-fill {
  height:100%; border-radius:3px; background:var(--c);
  width:0; transition:width 1s cubic-bezier(0.4,0,0.2,1);
}

/* SEO */
.fv-seo { display:flex; flex-direction:column; gap:8px; }
.fv-seo-item {
  display:flex; align-items:center; gap:10px;
  font-size:0.76rem; color:var(--gray-400); padding:6px 0;
}
.fv-seo-item svg { flex-shrink:0; }

/* Security */
.fv-security { padding:20px; }
.fv-sec-header {
  display:flex; align-items:center; gap:10px;
  font-size:0.82rem; font-weight:700; color:#fff;
  margin-bottom:16px; padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.fv-sec-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,0.04);
}
.fv-sec-row:last-child { border-bottom:none; }
.fv-sec-label { font-size:0.76rem; color:var(--gray-400); font-weight:500; }
.fv-sec-status { font-size:0.72rem; font-weight:600; }
.fv-sec-status--ok { color:var(--green); }
.fv-sec-status--warn { color:var(--amber); }


/* ==========================================================================
   How It Works — timeline strip
   ========================================================================== */
.how {
  padding: var(--section-pad) 1.5rem;
  background: var(--dark-950);
  color: #fff;
  overflow: hidden;
}
.how-inner { max-width:var(--max-w); margin:0 auto; }
.how-header { margin-bottom:3rem; }
.how .section-label { color:var(--accent); }
.how .section-title { color:#fff; }

.how-timeline {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}
.how-line {
  display: none;
}
.how-step {
  position: relative;
  padding-left: 56px;
  opacity:0; transform:translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.how-step.in-view { opacity:1; transform:translateY(0); }
.how-step:nth-child(2) { transition-delay:0s; }
.how-step:nth-child(3) { transition-delay:0.1s; }
.how-step:nth-child(4) { transition-delay:0.2s; }

.how-step-marker {
  position: absolute;
  left: 0; top: 0;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 20px var(--accent-glow);
}

.how-step h3 {
  font-family: var(--font-heading);
  font-size: 1.1rem; font-weight: 700;
  margin-bottom: 0.35rem;
  letter-spacing: -0.02em;
}
.how-step p {
  font-size: 0.9rem; line-height: 1.6;
  color: var(--gray-400);
  max-width: 400px;
}


/* ==========================================================================
   Testimonials
   ========================================================================== */
.testimonials {
  padding: var(--section-pad) 1.5rem;
  background-color: var(--white);
  border-top: 1px solid var(--gray-200);
}
.testimonials-inner {
  max-width: var(--max-w);
  margin: 0 auto;
}

.testimonial-grid {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

.testimonial-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 2rem;
  transition: box-shadow var(--transition), transform var(--transition);
  opacity:0; transform:translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.25s ease;
}
.testimonial-card.in-view { opacity:1; transform:translateY(0); }
.testimonial-card:nth-child(2) { transition-delay:0.1s; }
.testimonial-card:nth-child(3) { transition-delay:0.2s; }
.testimonial-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.testimonial-card--featured {
  border-color: var(--accent);
  background: linear-gradient(135deg, var(--white) 0%, rgba(255,107,53,0.03) 100%);
  box-shadow: 0 0 0 1px var(--accent-soft), 0 8px 32px rgba(255,107,53,0.08);
}
.testimonial-card--featured .testimonial-quote {
  font-size: 1.02rem;
}

.testimonial-stars {
  color: var(--amber);
  font-size: 0.9rem;
  letter-spacing: 2px;
  margin-bottom: 1rem;
}

.testimonial-quote {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--gray-700);
  margin-bottom: 1.5rem;
  font-style: italic;
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.testimonial-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading);
  font-size: 0.72rem; font-weight: 800;
  color: #fff;
}
.testimonial-avatar--sc { background: #6366F1; }
.testimonial-avatar--jw { background: #0EA5E9; }
.testimonial-avatar--et { background: #EC4899; }

.testimonial-name {
  font-family: var(--font-heading);
  font-size: 0.88rem; font-weight: 700;
  color: var(--gray-900);
}
.testimonial-role {
  font-size: 0.78rem; color: var(--gray-500);
}


/* ==========================================================================
   Pricing
   ========================================================================== */
.pricing {
  padding: var(--section-pad) 1.5rem;
  background-color: var(--gray-50);
  border-top: 1px solid var(--gray-200);
}
.pricing-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  text-align: center;
}
.pricing-subtitle {
  margin-top:0.75rem;
  font-size:1rem; color:var(--gray-500);
}

/* Toggle */
.pricing-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 2rem;
}
.pricing-toggle-label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--gray-400);
  transition: color var(--transition);
  cursor: pointer;
}
.pricing-toggle-label--active { color: var(--gray-900); }
.pricing-save {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--green);
  background: var(--green-dim);
  padding: 2px 8px;
  border-radius: 100px;
  margin-left: 4px;
}

.pricing-toggle-switch {
  width: 44px; height: 24px;
  background: var(--gray-200);
  border-radius: 12px;
  position: relative;
  transition: background var(--transition);
}
.pricing-toggle-switch[data-state="annual"] { background: var(--accent); }
.pricing-toggle-thumb {
  position: absolute;
  top: 3px; left: 3px;
  width: 18px; height: 18px;
  background: #fff;
  border-radius: 50%;
  transition: transform var(--transition);
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}
.pricing-toggle-switch[data-state="annual"] .pricing-toggle-thumb {
  transform: translateX(20px);
}

.pricing-card {
  max-width:480px; margin:2rem auto 0;
  background:var(--white);
  border:2px solid var(--gray-200);
  border-radius:var(--radius-xl);
  padding:2.5rem;
  text-align:left;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 32px rgba(0,0,0,0.06);
  transition:border-color var(--transition), box-shadow var(--transition);
}
.pricing-card:hover {
  border-color:var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow), 0 8px 32px rgba(0,0,0,0.08);
}

.pricing-top { text-align:center; }
.pricing-amount {
  font-family:var(--font-heading);
  font-size:4rem; font-weight:800;
  line-height:1; letter-spacing:-0.04em;
  color:var(--gray-900);
}
.pricing-currency {
  font-size:1.5rem; font-weight:700;
  vertical-align:top; margin-top:0.5rem;
  color:var(--gray-500);
}
.pricing-period {
  display:block; margin-top:0.5rem;
  font-size:0.88rem; color:var(--gray-500); font-weight:500;
  transition: opacity var(--transition);
}

.pricing-comparison {
  margin-top:1.25rem;
  padding:1rem 1.25rem;
  background: var(--accent-soft);
  border-radius: var(--radius);
  font-size:0.85rem;
  line-height:1.6;
  color:var(--gray-700);
  text-align:center;
}

.pricing-divider { height:1px; background:var(--gray-200); margin:1.75rem 0; }

.pricing-list {
  display:flex; flex-direction:column; gap:12px;
  margin-bottom:2rem;
}
.pricing-list li {
  display:flex; align-items:center; gap:10px;
  font-size:0.92rem; color:var(--gray-600);
}
.pricing-list li svg { flex-shrink:0; }

.pricing-note {
  text-align:center; margin-top:1rem;
  font-size:0.78rem; color:var(--gray-500);
}


/* ==========================================================================
   Final CTA
   ========================================================================== */
.cta {
  position: relative;
  padding: var(--section-pad) 1.5rem;
  background: var(--dark-900);
  color: #fff;
  text-align: center;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.cta-bg {
  position:absolute; inset:0; pointer-events:none;
}
.cta-glow {
  position: absolute;
  width: 600px; height: 600px;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(255,107,53,0.08) 0%, transparent 60%);
}
.cta-inner {
  position: relative;
  max-width: 500px;
  margin: 0 auto;
}
.cta-fox {
  margin-bottom: 1.5rem;
  opacity: 0.9;
}
.cta-title {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.03em;
}
.cta-desc {
  margin-top: 0.75rem;
  font-size: 1.05rem;
  color: var(--gray-400);
}
.cta-btn {
  margin-top: 2rem;
  padding: 1rem 2.5rem;
  font-size: 1rem;
}
.cta-sub {
  margin-top: 1rem;
  font-size: 0.78rem;
  color: var(--gray-500);
}


/* ==========================================================================
   Footer
   ========================================================================== */
.footer {
  padding:3.5rem 1.5rem 2rem;
  border-top:1px solid var(--gray-200);
  background: var(--gray-50);
}
.footer-inner { max-width:var(--max-w); margin:0 auto; }
.footer-top {
  display:grid; grid-template-columns:1fr;
  gap:2.5rem;
  padding-bottom:2rem;
  border-bottom:1px solid var(--gray-100);
}
.footer-brand .logo-text { color:var(--gray-900); }
.footer-tagline {
  margin-top:0.75rem;
  font-size:0.85rem; color:var(--gray-500); line-height:1.6;
}
.footer-social {
  display: flex;
  gap: 12px;
  margin-top: 1rem;
}
.footer-social a {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  display: flex; align-items: center; justify-content: center;
  color: var(--gray-500);
  transition: all var(--transition);
}
.footer-social a:hover {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-soft);
}
.footer-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.footer-col { display:flex; flex-direction:column; gap:8px; }
.footer-col h4 {
  font-family:var(--font-heading);
  font-size:0.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:0.08em;
  color:var(--gray-800); margin-bottom:4px;
}
.footer-col a {
  font-size:0.85rem; color:var(--gray-500);
  transition:color var(--transition);
}
.footer-col a:hover { color:var(--accent); }
.footer-bottom { padding-top:1.5rem; }
.footer-bottom p { font-size:0.78rem; color:var(--gray-400); }


/* ==========================================================================
   Responsive
   ========================================================================== */
@media (min-width:640px) {
  .testimonial-grid { grid-template-columns:1fr 1fr; }
  .testimonial-card--featured { grid-column:1/-1; }
}

@media (min-width:768px) {
  .nav-links { display:flex; }
  .nav-actions { display:flex; }
  .nav-toggle { display:none; }
  .nav-mobile { display:none !important; }

  .dash-body { grid-template-columns:150px 1fr; }
  .dash-sidebar { display:flex; }
  .dash-metric-score { width:110px; height:110px; }
  .dash-metric-num { font-size:2rem; }

  .feature-row { grid-template-columns:1fr 1fr; gap:3rem; }
  .feature-row--reverse .feature-info { order:2; }
  .feature-row--reverse .feature-visual { order:1; }

  .how-timeline {
    flex-direction: row;
    gap: 0;
  }
  .how-step {
    flex: 1;
    padding-left: 0;
    padding-top: 60px;
    text-align: center;
  }
  .how-step-marker {
    left: 50%;
    transform: translateX(-50%);
    top: 0;
  }
  .how-step p { max-width:280px; margin:0 auto; }
  .how-line {
    display: block;
    position: absolute;
    top: 20px;
    left: 15%;
    right: 15%;
    height: 2px;
    background: var(--accent);
    opacity: 0.6;
    box-shadow: 0 0 12px rgba(255,107,53,0.3);
  }

  .testimonial-grid { grid-template-columns:1fr 1fr; }
  .footer-top { grid-template-columns:1.2fr 2fr; }
}

@media (min-width:1024px) {
  .hero-title { font-size:3.25rem; }

  .hero-dash-perspective { max-width:1000px; }
  .dash-metric-score { width:120px; height:120px; }
  .dash-metric-num { font-size:2.2rem; }

  .feature-row { gap:4rem; }

  .testimonial-grid {
    grid-template-columns: 1.2fr 1fr 1fr;
  }
  .testimonial-card--featured {
    grid-column: auto;
    grid-row: auto;
  }
}


/* ==========================================================================
   Accessibility & Motion
   ========================================================================== */
:focus-visible {
  outline:2px solid var(--accent);
  outline-offset:3px;
  border-radius:4px;
}
.btn:focus-visible { outline-offset:4px; }

/* ==========================================================================
   Content Pages (Blog, Legal, Contact)
   ========================================================================== */
.page-header {
  background: var(--dark-950);
  color: #fff;
  padding: calc(68px + 3rem) 1.5rem 3rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.page-header-bg {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black 20%, transparent 70%);
}
.page-header-glow {
  position: absolute;
  width: 600px; height: 600px;
  top: -200px; left: 50%; transform: translateX(-50%);
  background: radial-gradient(circle, rgba(255,107,53,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.page-header h1 {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.15;
  position: relative;
}
.page-header p {
  margin-top: 0.75rem;
  font-size: 1.05rem;
  color: var(--gray-400);
  max-width: 520px;
  margin-left: auto; margin-right: auto;
  position: relative;
}

.page-content {
  max-width: 720px;
  margin: 0 auto;
  padding: 3rem 1.5rem 4rem;
}
.page-content h2 {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--gray-900);
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
}
.page-content h2:first-child { margin-top: 0; }
.page-content h3 {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--gray-800);
  margin-top: 1.75rem;
  margin-bottom: 0.5rem;
}
.page-content p {
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--gray-600);
  margin-bottom: 1rem;
}
.page-content ul, .page-content ol {
  margin-bottom: 1rem;
  padding-left: 1.5rem;
}
.page-content li {
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--gray-600);
  margin-bottom: 0.35rem;
  list-style: disc;
}
.page-content ol li { list-style: decimal; }
.page-content a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition);
}
.page-content a:hover { color: var(--accent-hover); }
.page-content strong { color: var(--gray-800); }
.page-content .last-updated {
  font-size: 0.82rem;
  color: var(--gray-400);
  margin-bottom: 2rem;
  font-weight: 500;
}

/* Contact form */
.contact-wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 3rem 1.5rem 4rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
.contact-info { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-info h2 {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--gray-900);
}
.contact-info p {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--gray-500);
}
.contact-detail {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.contact-detail-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--accent-soft);
  border: 1px solid rgba(255,107,53,0.12);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  flex-shrink: 0;
}
.contact-detail-text h3 {
  font-family: var(--font-heading);
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 2px;
}
.contact-detail-text p {
  font-size: 0.85rem;
  color: var(--gray-500);
  margin: 0;
}

.contact-form {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl);
  padding: 2rem;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 32px rgba(0,0,0,0.06);
}
.form-group { margin-bottom: 1.25rem; }
.form-label {
  display: block;
  font-family: var(--font-heading);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--gray-700);
  margin-bottom: 0.4rem;
}
.form-input, .form-textarea {
  width: 100%;
  padding: 0.7rem 1rem;
  font-family: var(--font-body);
  font-size: 0.92rem;
  color: var(--gray-800);
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.form-input:focus, .form-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.form-textarea { min-height: 140px; resize: vertical; }
.form-input::placeholder, .form-textarea::placeholder { color: var(--gray-400); }

@media (min-width:768px) {
  .contact-wrap { grid-template-columns: 1fr 1.2fr; }
}
@media (prefers-reduced-motion:reduce) {
  *, *::before, *::after {
    animation-duration:0.01ms !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
  .feature-row, .how-step, .testimonial-card, .proof-stat, .dash-bar {
    opacity:1 !important;
    transform:none !important;
  }
  .dash { transform:none !important; }
  .dash-bar { height:var(--h) !important; }
  .fv-speed-fill { width:var(--w) !important; }
}
