/* ─────────────────────────────────────────
   LANDING PAGE BASE
───────────────────────────────────────── */
.landing-page { height: auto; overflow: auto; min-height: 100vh; background: var(--bg); }

/* ─────────────────────────────────────────
   NAV
───────────────────────────────────────── */
.l-nav {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 2.5rem;
  max-width: 1280px; margin: 0 auto;
  transition: background 0.3s, box-shadow 0.3s;
}
.l-nav--scrolled {
  background: rgba(247, 243, 236, 0.92);
  backdrop-filter: blur(16px);
  box-shadow: 0 1px 0 rgba(74,103,65,0.1);
  border-radius: 0;
  max-width: 100%;
  padding: 0.9rem 2.5rem;
}
/* wrapper so sticky works */
.landing-page > .l-nav { max-width: 100%; }

.l-logo { display: flex; align-items: center; gap: 0.75rem; font-family: var(--font-display); font-size: 1.4rem; color: var(--sage); }
.l-logo-mark {
  width: 40px; height: 40px; border-radius: 12px;
  background: linear-gradient(135deg, var(--sage-mist), var(--sage-pale));
  display: flex; align-items: center; justify-content: center; font-size: 20px;
}

.l-nav-center { display: flex; gap: 2rem; }
.l-nav-center a {
  font-size: 0.875rem; color: var(--char-mid); text-decoration: none;
  transition: color 0.2s; font-weight: 400;
}
.l-nav-center a:hover { color: var(--sage); }

.l-nav-actions { display: flex; gap: 0.75rem; align-items: center; }

/* CTA button variants */
.l-btn-primary { background: var(--sage); color: white; }
.l-btn-primary:hover { background: var(--char); }
.l-btn-ghost-dark {
  background: transparent; color: var(--char); border: 1.5px solid rgba(42,42,36,0.2);
}
.l-btn-ghost-dark:hover { background: rgba(42,42,36,0.06); }
.l-btn-white { background: white; color: var(--sage); }
.l-btn-white:hover { background: var(--sage-mist); }

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.l-hero {
  max-width: 1280px; margin: 5rem auto 3rem; padding: 0 2.5rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center;
}

.l-hero-badge {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--sage-mist); border: 1px solid rgba(74,103,65,0.2);
  border-radius: 100px; padding: 0.35rem 0.875rem;
  font-size: 0.78rem; color: var(--sage); font-weight: 500;
  margin-bottom: 1.75rem; letter-spacing: 0.01em;
}
.l-badge-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--sage);
  animation: l-pulse 2s infinite; flex-shrink: 0;
}
@keyframes l-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(0.85)} }

.l-hero-title {
  font-family: var(--font-display); font-size: 5rem; font-weight: 300;
  color: var(--char); line-height: 1.05; margin-bottom: 1.5rem; letter-spacing: -0.02em;
}
.l-hero-title em { font-style: italic; color: var(--sage); }

.l-hero-sub {
  font-size: 1.15rem; color: var(--char-mid); line-height: 1.7;
  margin-bottom: 2.5rem; max-width: 460px;
}

.l-hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 2rem; }

.l-hero-proof {
  display: flex; align-items: center; gap: 0.625rem;
  font-size: 0.875rem; color: var(--char-mid);
}
.l-stars { color: var(--gold); font-size: 1rem; letter-spacing: 0.05em; }
.l-hero-proof strong { color: var(--char); }

/* MOCKUP */
.l-hero-visual { position: relative; }

.mockup-window {
  background: var(--cream); border-radius: 20px;
  box-shadow: 0 32px 80px rgba(42,42,36,0.16), 0 0 0 1px rgba(74,103,65,0.08);
  overflow: hidden;
}
.mockup-topbar {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.75rem 1rem; background: white;
  border-bottom: 1px solid rgba(74,103,65,0.08);
}
.mockup-dots { display: flex; gap: 5px; }
.mockup-dots span { width: 10px; height: 10px; border-radius: 50%; background: var(--cream-warm); }
.mockup-dots span:first-child { background: #FC615D; }
.mockup-dots span:nth-child(2) { background: #FDBC40; }
.mockup-dots span:last-child { background: #34C749; }
.mockup-topbar-title { flex: 1; text-align: center; font-size: 0.78rem; font-weight: 500; color: var(--char-mid); }
.mockup-topbar-status {
  display: flex; align-items: center; gap: 4px;
  font-size: 0.72rem; color: var(--sage); font-weight: 500;
}

.mockup-chat { display: flex; flex-direction: column; gap: 0.875rem; padding: 1.25rem; }
.mockup-msg {
  max-width: 88%; padding: 0.8rem 1rem;
  font-size: 0.9rem; line-height: 1.55; border-radius: 16px; position: relative;
}
.mockup-sender {
  display: block; font-size: 0.65rem; font-weight: 600; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--sage); margin-bottom: 0.25rem;
}
.mockup-msg.user {
  align-self: flex-end; background: var(--sage); color: white;
  border-bottom-right-radius: 4px;
}
.mockup-msg.ai {
  align-self: flex-start; background: white; color: var(--char);
  border: 1px solid rgba(74,103,65,0.1); border-bottom-left-radius: 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

/* Floating trust cards */
.l-float {
  position: absolute; display: flex; align-items: center; gap: 0.625rem;
  background: white; border-radius: 14px; padding: 0.75rem 1rem;
  box-shadow: 0 8px 32px rgba(42,42,36,0.12); border: 1px solid rgba(74,103,65,0.1);
  animation: l-float-bob 4s ease-in-out infinite;
}
.l-float-1 { bottom: -1.5rem; left: -2rem; animation-delay: 0s; }
.l-float-2 { top: 2rem; right: -2rem; animation-delay: 2s; }
@keyframes l-float-bob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
.l-float-icon { font-size: 1.25rem; }
.l-float-title { font-size: 0.8rem; font-weight: 600; color: var(--char); }
.l-float-sub { font-size: 0.7rem; color: var(--dust); margin-top: 1px; }

/* ─────────────────────────────────────────
   TRUST STRIP
───────────────────────────────────────── */
.l-trust-strip {
  background: var(--sage); margin: 5rem 0 0;
}
.l-trust-inner {
  max-width: 1280px; margin: 0 auto; padding: 1.75rem 2.5rem;
  display: flex; align-items: center; justify-content: center;
  gap: 0; flex-wrap: wrap;
}
.l-trust-item {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 0.5rem 3rem; text-align: center;
}
.l-trust-item strong { font-family: var(--font-display); font-size: 1.75rem; font-weight: 300; color: white; line-height: 1; }
.l-trust-item span { font-size: 0.78rem; color: rgba(255,255,255,0.7); }
.l-trust-div { width: 1px; height: 36px; background: rgba(255,255,255,0.2); flex-shrink: 0; }

/* ─────────────────────────────────────────
   RESEARCH / SCIENCE
───────────────────────────────────────── */
.l-research { background: var(--cream); padding: 7rem 2.5rem; }
.l-research-inner { max-width: 1100px; margin: 0 auto; text-align: center; }

.l-section-tag {
  display: inline-block; font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--sage);
  background: var(--sage-mist); border: 1px solid rgba(74,103,65,0.2);
  border-radius: 100px; padding: 0.25rem 0.875rem; margin-bottom: 1.25rem;
}

.l-section-h2 {
  font-family: var(--font-display); font-size: 3.25rem; font-weight: 300;
  color: var(--char); line-height: 1.15; margin-bottom: 1.25rem;
}

.l-research-sub {
  font-size: 1.1rem; color: var(--char-mid); max-width: 660px; margin: 0 auto 4rem;
  line-height: 1.7;
}

.l-research-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-bottom: 2rem;
}
.l-research-card {
  background: white; border-radius: 20px; padding: 2.5rem 2rem;
  border: 1px solid rgba(74,103,65,0.1);
  box-shadow: 0 4px 20px rgba(42,42,36,0.05);
  transition: transform 0.3s, box-shadow 0.3s;
}
.l-research-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(42,42,36,0.1);
}
.l-research-card--mid {
  background: var(--sage); color: white;
}
.l-research-card--mid p { color: #FAF7F2; }
.l-rc-stat {
  font-family: var(--font-display); font-size: 3.5rem; font-weight: 300;
  color: var(--sage); line-height: 1; margin-bottom: 1rem;
}
.l-research-card--mid .l-rc-stat { color: white; }
.l-research-card p { font-size: 0.95rem; color: var(--char-mid); line-height: 1.6; }
.l-research-cite { font-size: 0.78rem; color: var(--dust); font-style: italic; }

/* ─────────────────────────────────────────
   HOW IT WORKS
───────────────────────────────────────── */
.l-how { padding: 7rem 2.5rem; background: var(--bg); }
.l-how-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.l-how-inner .l-section-h2 { margin-bottom: 4rem; }

.l-steps {
  display: flex; align-items: flex-start; gap: 0;
  position: relative;
}
.l-step {
  flex: 1; display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 0 1.5rem;
}
.l-step-num {
  font-family: var(--font-display); font-size: 3rem; font-weight: 300;
  color: var(--sage-pale); line-height: 1; margin-bottom: 1rem;
}
.l-step-body h3 { font-size: 1.1rem; font-weight: 600; color: var(--char); margin-bottom: 0.625rem; }
.l-step-body p { font-size: 0.95rem; color: var(--char-mid); line-height: 1.65; }
.l-step-line {
  flex-shrink: 0; width: 60px; height: 1px;
  background: linear-gradient(90deg, var(--sage-pale), transparent);
  margin-top: 1.75rem; align-self: flex-start;
}

/* ─────────────────────────────────────────
   FEATURES
───────────────────────────────────────── */
.l-features {
  background: white; padding: 7rem 2.5rem;
  border-top: 1px solid rgba(74,103,65,0.08);
  border-bottom: 1px solid rgba(74,103,65,0.08);
}
.l-section-header { text-align: center; max-width: 680px; margin: 0 auto 4rem; }
.l-section-header h2 {
  font-family: var(--font-display); font-size: 3rem; font-weight: 300;
  color: var(--char); margin-bottom: 1rem; line-height: 1.2;
}
.l-section-header p { font-size: 1.05rem; color: var(--dust); line-height: 1.6; }

.l-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem;
}
.l-card {
  background: var(--bg); padding: 2rem; border-radius: 20px;
  border: 1px solid rgba(74,103,65,0.07);
  transition: transform 0.3s, box-shadow 0.3s;
}
.l-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(42,42,36,0.08); }
.l-card-icon {
  width: 52px; height: 52px; border-radius: 16px; background: var(--sage-mist);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; margin-bottom: 1.25rem;
}
.l-card h3 { font-size: 1.1rem; font-weight: 600; color: var(--char); margin-bottom: 0.625rem; }
.l-card p { font-size: 0.95rem; color: var(--char-mid); line-height: 1.65; }

/* ─────────────────────────────────────────
   CHANNELS
───────────────────────────────────────── */
.l-channels { background: var(--cream); padding: 7rem 2.5rem; }
.l-channels-inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center;
}
.l-channels-text .l-section-h2 { margin-bottom: 1.25rem; }
.l-channels-text > p { font-size: 1.05rem; color: var(--char-mid); line-height: 1.7; margin-bottom: 2.5rem; }

.l-channel-list { display: flex; flex-direction: column; gap: 1.25rem; }
.l-channel-item { display: flex; align-items: flex-start; gap: 1rem; }
.l-channel-icon {
  width: 44px; height: 44px; border-radius: 14px; background: var(--sage-mist);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.l-channel-item strong { font-size: 0.95rem; font-weight: 600; color: var(--char); display: block; margin-bottom: 3px; }
.l-channel-item p { font-size: 0.875rem; color: var(--char-mid); line-height: 1.55; margin: 0; }

/* Phone mockup */
.l-phone-mock {
  background: var(--char); border-radius: 32px; overflow: hidden;
  box-shadow: 0 32px 80px rgba(42,42,36,0.24), 0 0 0 1px rgba(255,255,255,0.05);
  max-width: 320px; margin: 0 auto; position: relative;
}
.l-phone-header {
  background: #1A1A14; padding: 1.25rem 1rem 0.875rem;
  display: flex; align-items: center; gap: 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.l-phone-avatar {
  width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--sage-pale), var(--sage));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: white;
}
.l-phone-name { font-size: 0.875rem; font-weight: 600; color: white; }
.l-phone-status { font-size: 0.72rem; color: #4CAF50; margin-top: 1px; }

.l-phone-chat { padding: 1.25rem 1rem; display: flex; flex-direction: column; gap: 0.625rem; }
.l-phone-msg {
  max-width: 85%; padding: 0.625rem 0.875rem;
  font-size: 0.875rem; line-height: 1.5; border-radius: 16px;
}
.l-phone-msg--received {
  align-self: flex-start; background: #2A2A24; color: rgba(255,255,255,0.88);
  border-bottom-left-radius: 4px;
}
.l-phone-msg--sent {
  align-self: flex-end; background: var(--sage); color: white;
  border-bottom-right-radius: 4px;
}
.l-phone-badge {
  text-align: center; font-size: 0.7rem; color: rgba(255,255,255,0.3);
  padding: 0.625rem; border-top: 1px solid rgba(255,255,255,0.06);
}

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
.l-testi { background: var(--bg); padding: 7rem 2.5rem; }
.l-testi-inner { max-width: 1200px; margin: 0 auto; }
.l-testi-inner .l-section-h2 { margin-bottom: 3.5rem; }

.l-testi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; align-items: start;
}
.l-testi-card {
  background: white; border-radius: 20px; padding: 2rem;
  border: 1px solid rgba(74,103,65,0.1);
  box-shadow: 0 4px 20px rgba(42,42,36,0.05);
  transition: transform 0.3s, box-shadow 0.3s;
}
.l-testi-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(42,42,36,0.1); }
.l-testi-card--featured {
  background: var(--sage); border-color: transparent;
  box-shadow: 0 16px 48px rgba(74,103,65,0.25);
  transform: translateY(-8px);
}
.l-testi-card--featured:hover { transform: translateY(-12px); }
.l-testi-stars { color: var(--gold); font-size: 0.875rem; margin-bottom: 1rem; }
.l-testi-card--featured .l-testi-stars { color: #FFD700; }
.l-testi-card blockquote {
  font-family: var(--font-display); font-size: 1.05rem; font-style: italic;
  font-weight: 300; color: var(--char); line-height: 1.65; margin-bottom: 1.5rem;
  border: none; padding: 0;
}
.l-testi-card--featured blockquote { color: white; }
.l-testi-author { display: flex; align-items: center; gap: 0.75rem; }
.l-testi-av {
  width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: white;
}
.l-testi-author strong { display: block; font-size: 0.875rem; color: var(--char); }
.l-testi-author span { font-size: 0.75rem; color: var(--dust); }
.l-testi-card--featured .l-testi-author strong { color: white; }
.l-testi-card--featured .l-testi-author span { color: rgba(255,255,255,0.65); }

/* ─────────────────────────────────────────
   PRICING
───────────────────────────────────────── */
.l-premium { padding: 7rem 2.5rem; background: white; }
.l-premium-content { text-align: center; max-width: 1200px; margin: 0 auto; }
.l-premium-content h2 {
  font-family: var(--font-display); font-size: 3.25rem; font-weight: 300;
  color: var(--char); margin-bottom: 1rem;
}
.l-premium-content > p { font-size: 1.05rem; color: var(--dust); margin-bottom: 4rem; }

.l-pricing { display: flex; justify-content: center; gap: 2rem; flex-wrap: wrap; }
.l-price-card {
  background: var(--bg); border: 1px solid rgba(74,103,65,0.15);
  border-radius: 24px; padding: 3rem 2.25rem;
  width: 100%; max-width: 380px; text-align: left;
  position: relative; display: flex; flex-direction: column;
  transition: transform 0.3s, box-shadow 0.3s;
}
.l-price-card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(42,42,36,0.08); }
.l-price-card.featured {
  background: var(--cream); border: 2px solid var(--sage);
  box-shadow: 0 24px 64px rgba(74,103,65,0.15); transform: scale(1.04);
}
.l-price-card.featured:hover { transform: scale(1.04) translateY(-4px); }
.l-price-badge {
  display: inline-block; background: var(--sage); color: white;
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.25rem 0.75rem; border-radius: 100px; margin-bottom: 1.25rem;
}
.l-price-card h4 {
  font-size: 1rem; font-weight: 600; color: var(--dust);
  text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 0.875rem;
}
.l-price {
  font-family: var(--font-display); font-size: 3.5rem; color: var(--char);
  margin-bottom: 0.75rem; line-height: 1;
}
.l-price span { font-size: 1rem; color: var(--dust); font-family: var(--font-body); }
.l-price-desc { font-size: 0.875rem; color: var(--char-mid); line-height: 1.5; margin-bottom: 1.75rem; }
.l-price-features { list-style: none; margin-bottom: 2.5rem; flex: 1; }
.l-price-features li {
  padding: 0.55rem 0; font-size: 0.9rem; color: var(--char-mid);
  border-bottom: 1px solid rgba(74,103,65,0.08);
}
.l-price-features li:last-child { border-bottom: none; }
.l-pricing-note { margin-top: 2.5rem; font-size: 0.85rem; color: var(--dust); font-style: italic; }

/* ─────────────────────────────────────────
   HSA / FSA WAITLIST
───────────────────────────────────────── */
.l-waitlist {
  background: var(--cream-warm); padding: 6rem 2.5rem;
  margin: 0; text-align: center;
}
.l-waitlist-inner { max-width: 600px; margin: 0 auto; }
.l-waitlist-icon { font-size: 2.5rem; margin-bottom: 1rem; }
.l-waitlist h3 {
  font-family: var(--font-display); font-size: 2.75rem; font-weight: 300;
  margin-bottom: 1rem; color: var(--char);
}
.l-waitlist p { color: var(--char-mid); margin-bottom: 2rem; font-size: 1.05rem; line-height: 1.65; }
.l-waitlist-form { display: flex; gap: 0.625rem; justify-content: center; flex-wrap: wrap; }
.l-waitlist-form input { flex: 1; max-width: 300px; }
.l-waitlist-note { margin-top: 0.875rem; font-size: 0.78rem; color: var(--dust); }

/* ─────────────────────────────────────────
   FAQ
───────────────────────────────────────── */
.l-faq { background: var(--bg); padding: 7rem 2.5rem; }
.l-faq-inner { max-width: 760px; margin: 0 auto; }
.l-faq-inner .l-section-h2 { margin-bottom: 3rem; }

.l-faq-list { display: flex; flex-direction: column; gap: 0.75rem; }
.l-faq-item {
  background: white; border-radius: 16px;
  border: 1px solid rgba(74,103,65,0.1); overflow: hidden;
  transition: border-color 0.2s;
}
.l-faq-item[open] { border-color: var(--sage); }
.l-faq-item summary {
  padding: 1.25rem 1.5rem; font-size: 1rem; font-weight: 500; color: var(--char);
  cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center;
  user-select: none;
}
.l-faq-item summary::-webkit-details-marker { display: none; }
.l-faq-item summary::after {
  content: '+'; font-size: 1.25rem; color: var(--sage); font-weight: 300; flex-shrink: 0;
  transition: transform 0.2s;
}
.l-faq-item[open] summary::after { transform: rotate(45deg); }
.l-faq-item p {
  padding: 0 1.5rem 1.25rem; font-size: 0.95rem; color: var(--char-mid); line-height: 1.7;
}

/* ─────────────────────────────────────────
   FINAL CTA
───────────────────────────────────────── */
.l-final-cta {
  background: linear-gradient(160deg, #2A3D26 0%, var(--sage) 100%);
  padding: 7rem 2.5rem; text-align: center;
}
.l-final-cta-inner { max-width: 600px; margin: 0 auto; }
.l-final-logo-mark {
  width: 64px; height: 64px; border-radius: 20px; font-size: 32px;
  background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center;
  margin: 0 auto 2rem;
}
.l-final-cta h2 {
  font-family: var(--font-display); font-size: 3.5rem; font-weight: 300;
  color: white; margin-bottom: 1rem; line-height: 1.1;
}
.l-final-cta p { font-size: 1.1rem; color: rgba(255,255,255,0.7); margin-bottom: 2.5rem; }
.l-final-cta .l-btn-primary { background: white; color: var(--sage); font-size: 1rem; padding: 1rem 2.5rem; }
.l-final-cta .l-btn-primary:hover { background: var(--sage-mist); color: var(--sage); }

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
.l-footer { background: white; padding: 4rem 2.5rem 2rem; border-top: 1px solid rgba(74,103,65,0.1); }
.l-footer-top {
  max-width: 1200px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 3rem; flex-wrap: wrap; gap: 2rem;
}
.l-footer-brand { display: flex; align-items: center; gap: 0.75rem; font-family: var(--font-display); font-size: 1.2rem; color: var(--sage); }
.l-footer-links { display: flex; gap: 2rem; flex-wrap: wrap; }
.l-footer-links a { color: var(--dust); text-decoration: none; font-size: 0.875rem; transition: color 0.2s; }
.l-footer-links a:hover { color: var(--sage); }
.l-footer-bottom {
  max-width: 1200px; margin: 0 auto;
  border-top: 1px solid rgba(74,103,65,0.1); padding-top: 2rem;
  display: flex; flex-direction: column; gap: 0.75rem;
  font-size: 0.82rem; color: var(--dust); text-align: center;
}
.l-disclaimer { font-style: italic; opacity: 0.8; max-width: 800px; margin: 0 auto; line-height: 1.5; }

/* Doc pages (privacy, terms) */
.l-doc-page { max-width: 800px; margin: 4rem auto 6rem; padding: 0 2rem; }
.l-doc-page h1 { font-family: var(--font-display); font-size: 3.5rem; font-weight: 300; color: var(--char); margin-bottom: 2rem; }
.l-doc-page h2 { font-size: 1.5rem; color: var(--char); margin-top: 2.5rem; margin-bottom: 1rem; font-weight: 500; }
.l-doc-page p { margin-bottom: 1rem; color: var(--char-mid); line-height: 1.6; }
.l-doc-page ul { margin-left: 1.5rem; margin-bottom: 1.5rem; color: var(--char-mid); line-height: 1.6; }
.l-doc-page li { margin-bottom: 0.5rem; }

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 1024px) {
  .l-hero { gap: 3rem; }
  .l-hero-title { font-size: 4rem; }
  .l-channels-inner { gap: 3rem; }
}

@media (max-width: 860px) {
  .l-nav { padding: 1rem 1.5rem; }
  .l-nav-center { display: none; }
  .l-hero { grid-template-columns: 1fr; text-align: center; margin: 3rem auto; padding: 0 1.5rem; }
  .l-hero-badge { justify-content: center; }
  .l-hero-title { font-size: 3.25rem; }
  .l-hero-sub { margin: 0 auto 2.5rem; }
  .l-hero-cta { justify-content: center; }
  .l-hero-proof { justify-content: center; }
  .l-hero-visual { display: none; }

  .l-trust-inner { gap: 0; flex-wrap: wrap; }
  .l-trust-item { padding: 0.75rem 1.5rem; }
  .l-trust-div { display: none; }

  .l-research-grid { grid-template-columns: 1fr; gap: 1rem; }

  .l-steps { flex-direction: column; align-items: center; }
  .l-step-line { width: 1px; height: 40px; background: linear-gradient(180deg, var(--sage-pale), transparent); }
  .l-step { max-width: 460px; }

  .l-features { padding: 5rem 1.5rem; }
  .l-section-header h2 { font-size: 2.5rem; }

  .l-channels-inner { grid-template-columns: 1fr; }
  .l-channels-visual { order: -1; }
  .l-phone-mock { max-width: 280px; }

  .l-testi-grid { grid-template-columns: 1fr; }
  .l-testi-card--featured { transform: none; }
  .l-testi-card--featured:hover { transform: translateY(-4px); }

  .l-price-card.featured { transform: none; }
  .l-price-card.featured:hover { transform: translateY(-4px); }

  .l-section-h2 { font-size: 2.5rem; }
  .l-final-cta h2 { font-size: 2.75rem; }
  .l-footer-top { flex-direction: column; text-align: center; }
  .l-footer-links { justify-content: center; }
}

@media (max-width: 560px) {
  .l-hero-title { font-size: 2.75rem; }
  .l-hero-cta { flex-direction: column; align-items: center; }
  .l-hero-cta .btn { width: 100%; max-width: 320px; justify-content: center; }
  .l-research, .l-how, .l-features, .l-channels, .l-testi, .l-premium, .l-faq { padding: 4.5rem 1.25rem; }
  .l-waitlist { padding: 4.5rem 1.25rem; }
  .l-waitlist-form { flex-direction: column; align-items: center; }
  .l-waitlist-form input { max-width: 100%; }
}

/* ─────────────────────────────────────────
   HOW IT WORKS — REDESIGNED STEPS
───────────────────────────────────────── */

/* 6. Section background */
.l-how { background: #FAF7F2; }

/* 7. Grid gap */
.l-steps { gap: 1.5rem; }

/* 2. Hide connecting lines */
.l-step-line { display: none; }

/* 3. Step cards */
.l-step {
  background: #FFFFFF;
  border-radius: 16px;
  padding: 2rem 1.75rem;
  box-shadow: 0 2px 16px rgba(0,0,0,0.06);
  border: 1px solid rgba(0,0,0,0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.l-step:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 28px rgba(0,0,0,0.10);
}

/* 1. Step numbers */
.l-step-num {
  font-size: clamp(3.5rem, 6vw, 5rem);
  font-weight: 700;
  color: rgba(45, 74, 62, 0.15);
  margin-bottom: 0.25rem;
}

/* 4. Step titles */
.l-step-body h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--forest, #2D4A3E);
  margin-top: 0.5rem;
  margin-bottom: 0.75rem;
}

/* 5. Step descriptions */
.l-step-body p {
  text-align: left;
  font-size: 0.95rem;
  line-height: 1.7;
  color: #555550;
}

/* ─────────────────────────────────────────
   FEATURES — TABBED SHOWCASE
───────────────────────────────────────── */

/* Wrapper */
.l-feature-tabs {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  border-radius: 20px;
  border: 1px solid rgba(0,0,0,0.07);
  overflow: hidden;
  min-height: 380px;
}

/* Tab list */
.l-ftab-list {
  width: 40%;
  flex-shrink: 0;
  background: #F5F2ED;
  padding: 1rem 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.l-ftab {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  border: none;
  border-left: 3px solid transparent;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background 0.15s;
}
.l-ftab:hover { background: rgba(45,74,62,0.06); }
.l-ftab.active {
  background: white;
  border-left-color: #2D4A3E;
  box-shadow: 0 1px 6px rgba(0,0,0,0.08);
}
.l-ftab-icon { font-size: 1rem; flex-shrink: 0; }
.l-ftab-label { font-size: 0.875rem; font-weight: 500; color: #8A8A78; }
.l-ftab.active .l-ftab-label { color: #2D4A3E; font-weight: 600; }

/* Panel area */
.l-fpanel-wrap {
  flex: 1;
  background: white;
  padding: 2rem;
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
}
.l-fpanel {
  grid-area: 1 / 1;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
  visibility: hidden;
}
.l-fpanel.active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  visibility: visible;
}

/* Title bar */
.l-fpanel-titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  padding-bottom: 0.875rem;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.l-fpanel-dots { display: flex; gap: 6px; align-items: center; }
.l-fpanel-dots span { width: 10px; height: 10px; border-radius: 50%; display: block; }
.l-fpanel-dots span:nth-child(1) { background: #FF5F57; }
.l-fpanel-dots span:nth-child(2) { background: #FFBD2E; }
.l-fpanel-dots span:nth-child(3) { background: #28CA41; }
.l-fpanel-title { font-size: 0.85rem; font-weight: 600; color: #4A4A40; }
.l-fpanel-spacer { width: 54px; }

/* Chat mock (Panel 0) */
.l-mock-chat { display: flex; flex-direction: column; gap: 0.75rem; }
.l-mock-msg {
  max-width: 82%;
  padding: 0.6rem 0.875rem;
  font-size: 0.875rem;
  line-height: 1.6;
}
.l-mock-msg--ai {
  background: #E8F0E6;
  color: #2A2A24;
  border-radius: 4px 12px 12px 12px;
  align-self: flex-start;
}
.l-mock-msg--user {
  background: #4A6741;
  color: white;
  border-radius: 12px 4px 12px 12px;
  align-self: flex-end;
}
.l-mock-sender { display: block; font-size: 0.7rem; font-weight: 600; color: #4A6741; margin-bottom: 0.2rem; }

/* Chart mock (Panel 1) */
.l-mock-chart-wrap { display: flex; flex-direction: column; gap: 4px; }
.l-mock-chart-tags { display: flex; gap: 8px; margin-bottom: 2px; }
.l-mock-chart-tags span { flex: 1; text-align: center; }
.l-mock-bars { display: flex; align-items: flex-end; gap: 8px; height: 90px; }
.l-mock-bar { flex: 1; border-radius: 4px 4px 0 0; background: #B8D4B0; }
.l-mock-bar-labels { display: flex; gap: 8px; }
.l-mock-bar-labels span { flex: 1; text-align: center; font-size: 0.6rem; color: #8A8A78; }
.l-mock-chart-note { font-size: 0.85rem; font-style: italic; color: #4A4A40; margin-top: 0.5rem; }

/* Channel rows (Panel 2) */
.l-mock-channels { display: flex; flex-direction: column; }
.l-mock-channel-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.l-mock-channel-row:last-child { border-bottom: none; }
.l-mock-channel-icon { font-size: 1.25rem; flex-shrink: 0; }
.l-mock-channel-info { flex: 1; }
.l-mock-channel-name { font-size: 0.875rem; font-weight: 600; color: #2A2A24; margin-bottom: 2px; }
.l-mock-channel-sub { font-size: 0.78rem; color: #8A8A78; }
.l-mock-pill { padding: 0.2rem 0.625rem; border-radius: 20px; font-size: 0.68rem; font-weight: 600; background: #E8F0E6; color: #4A6741; flex-shrink: 0; }

/* Kit card (Panel 3) */
.l-mock-kit { border: 1.5px solid #2D4A3E; border-radius: 12px; padding: 1.25rem 1.25rem 1rem; position: relative; }
.l-mock-kit-title { font-size: 0.85rem; font-weight: 600; color: #2D4A3E; margin-bottom: 1rem; }
.l-mock-kit-badge {
  position: absolute; top: 1rem; right: 1rem;
  background: #B8912A; color: white;
  font-size: 0.65rem; font-weight: 700;
  padding: 0.2rem 0.5rem; border-radius: 6px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.l-mock-kit-items { list-style: none; display: flex; flex-direction: column; gap: 0.625rem; }
.l-mock-kit-item { font-size: 0.875rem; color: #4A4A40; line-height: 1.5; display: flex; align-items: center; gap: 0.5rem; }
.l-mock-kit-check { color: #4A6741; font-weight: 700; flex-shrink: 0; }

/* Mood timeline (Panel 4) */
.l-mock-mood-row { display: flex; justify-content: space-between; margin-bottom: 1.25rem; }
.l-mock-mood-day { display: flex; flex-direction: column; align-items: center; gap: 6px; flex: 1; }
.l-mock-mood-dot { width: 32px; height: 32px; border-radius: 50%; }
.l-mock-mood-label { font-size: 0.6rem; color: #8A8A78; }
.l-mock-streak { font-size: 0.85rem; font-style: italic; color: #4A4A40; margin-bottom: 0.5rem; }
.l-mock-streak-badge { display: inline-flex; align-items: center; gap: 0.375rem; font-size: 0.85rem; font-weight: 600; color: #2D4A3E; }

/* Privacy rows (Panel 5) */
.l-mock-privacy { display: flex; flex-direction: column; }
.l-mock-privacy-row {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
  padding: 0.875rem 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.l-mock-privacy-row:last-child { border-bottom: none; }
.l-mock-privacy-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.l-mock-privacy-title { font-size: 0.875rem; font-weight: 600; color: #2A2A24; margin-bottom: 2px; }
.l-mock-privacy-sub { font-size: 0.78rem; color: #8A8A78; line-height: 1.5; }

/* Mobile: stack + horizontal pill tabs */
@media (max-width: 768px) {
  .l-feature-tabs { flex-direction: column; border-radius: 16px; }
  .l-ftab-list {
    width: 100%;
    flex-direction: row;
    overflow-x: auto;
    padding: 0.75rem;
    gap: 6px;
    scrollbar-width: none;
  }
  .l-ftab-list::-webkit-scrollbar { display: none; }
  .l-ftab {
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    padding: 0.5rem 0.75rem;
    border-left: none;
    border-bottom: 2px solid transparent;
    gap: 0.25rem;
    border-radius: 8px;
  }
  .l-ftab.active { border-left-color: transparent; border-bottom-color: #2D4A3E; }
  .l-ftab-label { font-size: 0.72rem; white-space: nowrap; }
  .l-fpanel-wrap { padding: 1.25rem; }
}
