/* ── Sleep page ambient ── */
.sleep-orb { position:fixed; border-radius:50%; pointer-events:none; z-index:0; }
.sleep-orb-1 { width:500px; height:500px; top:-100px; left:-80px;
  background:radial-gradient(circle, rgba(139,124,186,0.22) 0%, transparent 70%);
  animation: sleep-float1 18s ease-in-out infinite; }
.sleep-orb-2 { width:380px; height:380px; bottom:-80px; right:-60px;
  background:radial-gradient(circle, rgba(201,132,114,0.18) 0%, transparent 70%);
  animation: sleep-float2 22s ease-in-out infinite; }
.sleep-orb-3 { width:260px; height:260px; top:40%; left:55%;
  background:radial-gradient(circle, rgba(217,188,148,0.12) 0%, transparent 70%);
  animation: sleep-float3 14s ease-in-out infinite; }
@keyframes sleep-float1 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(30px,-40px)} }
@keyframes sleep-float2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-25px,35px)} }
@keyframes sleep-float3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(20px,25px)} }

/* ── Hero ── */
.sleep-bc-wrap{background:#1c1624;padding:96px 56px 0;}
.sleep-bc{max-width:1080px;margin:0 auto;font-size:12px;color:rgba(253,249,244,.45);font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:0;}
.sleep-bc a{color:rgba(253,249,244,.45);text-decoration:none;transition:color .3s;}
.sleep-bc a:hover{color:rgba(253,249,244,.75);}
.sleep-bc-sep{margin:0 8px;opacity:.4;}
.sleep-bc-current{color:rgba(189,213,234,.70);}

.sl-hero { min-height:100vh; background:#1c1624; padding:50px; max-width:1200px;
  display:grid; grid-template-columns:50% 45%; align-items:center; gap:48px; margin:0 auto; position:relative; z-index:1; }
.sl-hero-badge { display:inline-flex; align-items:center; gap:8px;
  background:rgba(200,191,231,0.12); border:1px solid rgba(200,191,231,0.25);
  border-radius:999px; padding:8px 18px; font-size:12px;
  color:#c8bfe7; letter-spacing:0.10em; text-transform:uppercase; margin-bottom:28px; }
.sl-h1 { font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(52px,6vw,60px); line-height:1.10; color:#fdf9f4; margin-bottom:24px; }
.sl-h1 em { font-style:italic;
  background:linear-gradient(135deg,#c8bfe7,#c98472); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; }
.sl-hero-sub { font-family:'DM Sans',sans-serif; font-size:18px; line-height:1.75;
  color:rgba(253,249,244,0.65); max-width:460px; margin-bottom:32px; }
.sl-pills { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:36px; }
.sl-pill { background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.14);
  border-radius:999px; padding:8px 16px; font-size:13px; color:rgba(253,249,244,0.75);
  font-family:'DM Sans',sans-serif; }
.sl-cta-row { display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-bottom:14px; }
.sl-btn-primary { background:linear-gradient(135deg,#8b7cba,#c98472); color:#fff;
  border:none; border-radius:999px; height:56px; padding:0 44px; font-size:17px;
  font-family:'DM Sans',sans-serif; font-weight:500; cursor:pointer; transition:all 0.45s;
  text-decoration:none; display:inline-flex; align-items:center; }
.sl-btn-primary:hover { transform:translateY(-3px);
  box-shadow:0 16px 48px rgba(139,124,186,0.45); }
.sl-btn-ghost { background:rgba(255,255,255,0.06);
  border:1.5px solid rgba(255,255,255,0.20); border-radius:999px; height:56px;
  padding:0 32px; font-size:15px; font-family:'DM Sans',sans-serif; color:#fdf9f4;
  text-decoration:none; display:inline-flex; align-items:center; transition:all 0.3s; }
.sl-btn-ghost:hover { background:rgba(255,255,255,0.12); }
.sl-trust-micro { font-size:13px; color:rgba(253,249,244,0.40);
  font-family:'DM Sans',sans-serif; font-weight:300; }

/* ── Phone mockup ── */
.sl-phone-wrap { position:relative; display:flex; justify-content:center; align-items:center; padding:60px 20px; }
.sl-phone-glow { position:absolute; width:300px; height:300px; border-radius:50%;
  background:radial-gradient(circle, rgba(139,124,186,0.28) 0%, transparent 70%);
  z-index:0; filter:blur(40px); }
.sl-phone { width:270px; height:540px; position:relative; z-index:1;
  background:linear-gradient(160deg,#2a2240,#1e1928);
  border-radius:44px; border:1.5px solid rgba(200,191,231,0.20);
  box-shadow:0 40px 120px rgba(0,0,0,0.60), inset 0 1px 0 rgba(255,255,255,0.08);
  animation:float-phone 6s ease-in-out infinite; overflow:hidden; }
@keyframes float-phone { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.sl-phone-island { width:80px; height:24px; background:#000; border-radius:20px;
  margin:12px auto 0; }
.sl-phone-content { padding:16px 18px 18px; }
.sl-phone-status { display:flex; justify-content:space-between; align-items:center;
  font-size:10px; color:rgba(253,249,244,0.60); margin-bottom:16px; }
.sl-sleep-hdr-lbl { font-size:9px; text-transform:uppercase; letter-spacing:0.08em;
  color:rgba(200,191,231,0.60); display:block; margin-bottom:4px; }
.sl-sleep-big { font-family:'Cormorant Garamond',serif; font-size:38px;
  font-weight:300; color:#fdf9f4; line-height:1; display:block; }
.sl-sleep-trend { font-size:12px; color:#b8cfc4; display:block; margin-bottom:14px; }
.sl-chart { display:flex; gap:5px; align-items:flex-end; height:70px; margin-bottom:8px; }
.sl-bar { flex:1; border-radius:4px 4px 2px 2px; transform-origin:bottom;
  transform:scaleY(0); transition:transform 0.7s cubic-bezier(0.16,1,0.3,1); }
.sl-bar.animated { transform:scaleY(1); }
.sl-bar-default { background:rgba(200,191,231,0.45); }
.sl-bar-best   { background:rgba(139,124,186,0.80); }
.sl-bar-worst  { background:rgba(201,132,114,0.60); }
.sl-day-labels { display:flex; gap:5px; margin-bottom:10px; }
.sl-day-label { flex:1; text-align:center; font-size:8px; color:rgba(253,249,244,0.40); }
.sl-phase-row { display:flex; gap:8px; margin-bottom:12px; flex-wrap:wrap; }
.sl-phase-item { display:flex; align-items:center; gap:4px; font-size:10px;
  color:rgba(253,249,244,0.65); }
.sl-phase-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.sl-ai-chip { background:rgba(139,124,186,0.15); border:1px solid rgba(200,191,231,0.25);
  border-radius:10px; padding:8px 10px; font-size:11px; color:rgba(253,249,244,0.85);
  font-family:'DM Sans',sans-serif; line-height:1.4; }

/* ── Floating cards ── */
.sl-float-card { position:absolute; background:rgba(255,255,255,0.90);
  backdrop-filter:blur(20px); border:1.5px solid rgba(255,255,255,0.75);
  border-radius:16px; padding:12px 16px; box-shadow:0 12px 40px rgba(46,37,53,0.15);
  min-width:140px; z-index:2; }
.sl-float-card-label { font-size:10px; font-family:'DM Sans',sans-serif;
  color:#7b6e8f; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:3px; }
.sl-float-card-val { font-family:'Cormorant Garamond',serif; font-size:18px;
  font-weight:300; color:#1c1624; line-height:1.2; }
.sl-float-card-sub { font-size:11px; font-family:'DM Sans',sans-serif; margin-top:2px; }
.sl-fc-a { top:30px; right:-30px; animation:float-card1 5s ease-in-out infinite; }
.sl-fc-b { bottom:60px; left:-30px; animation:float-card2 7s ease-in-out infinite 1s; }
.sl-fc-c { top:50%; right:-35px; transform:translateY(-50%);
  animation:float-card3 5.5s ease-in-out infinite 0.5s; }
@keyframes float-card1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes float-card2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(8px)} }
@keyframes float-card3 { 0%,100%{transform:translateY(-50%) translateX(0)} 50%{transform:translateY(-50%) translateX(5px)} }

/* ── Proof strip ── */
.sl-proof-strip { background:rgba(255,255,255,0.04);
  border-top:1px solid rgba(200,191,231,0.10); border-bottom:1px solid rgba(200,191,231,0.10);
  padding:28px 56px; display:flex; justify-content:space-around; align-items:center;
  flex-wrap:wrap; gap:24px; position:relative; z-index:1; }
.sl-proof-item { text-align:center; }
.sl-proof-num { font-family:'Cormorant Garamond',serif; font-size:36px; font-weight:300;
  background:linear-gradient(135deg,#c8bfe7,#c98472); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; line-height:1; }
.sl-proof-lbl { font-family:'DM Sans',sans-serif; font-size:13px;
  color:rgba(253,249,244,0.55); margin-top:4px; }
.sl-proof-div { width:1px; height:40px; background:rgba(200,191,231,0.15); }

/* ── Shared section utility ── */
.sl-section { padding:50px; position:relative; z-index:1; }
.sl-section-inner { max-width:1080px; margin:0 auto; }
.sl-label { display:inline-flex; align-items:center; gap:8px; font-size:12px;
  font-family:'DM Sans',sans-serif; letter-spacing:0.08em; text-transform:uppercase;
  color:#8b7cba; margin-bottom:20px; }
.sl-h2-ink { font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(36px,4vw,52px); color:#1c1624; line-height:1.18; margin-bottom:20px; }
.sl-h2-cream { font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(36px,4vw,52px); color:#fdf9f4; line-height:1.18; margin-bottom:20px; }
.sl-h2-ink em, .sl-h2-cream em { font-style:italic;
  background:linear-gradient(135deg,#8b7cba,#c98472); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; }
.sl-body { font-family:'DM Sans',sans-serif; font-size:17px; line-height:1.80;
  color:#7b6e8f; margin-bottom:20px; }
.sl-body-cream { font-family:'DM Sans',sans-serif; font-size:17px; line-height:1.80;
  color:rgba(253,249,244,0.65); margin-bottom:20px; }
.sl-bullets { list-style:none; display:flex; flex-direction:column; gap:12px; margin:24px 0; }
.sl-bullet { font-family:'DM Sans',sans-serif; font-size:16px; color:#3d3250;
  display:flex; align-items:flex-start; gap:12px; }
.sl-bullet::before { content:"✓"; color:#8b7cba; font-weight:600; flex-shrink:0; }
.sl-feat-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.sl-feat-grid.flip { direction:rtl; }
.sl-feat-grid.flip > * { direction:ltr; }

/* ── Glass card ── */
.sl-glass { background:rgba(255,255,255,0.55); border:1.5px solid rgba(255,255,255,0.75);
  backdrop-filter:blur(20px) saturate(1.4); -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-radius:28px; box-shadow:0 24px 72px rgba(46,37,53,0.13); }
.sl-glass-dark { background:rgba(255,255,255,0.05); border:1.5px solid rgba(200,191,231,0.18);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-radius:28px; box-shadow:0 24px 72px rgba(0,0,0,0.30); }

/* ── SVG wave ── */
.sl-wave { display:block; width:100%; line-height:0; }

/* ── Problem cards ── */
.sl-problem-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; }
.sl-problem-card { padding:36px 32px; border-radius:28px; }
.sl-problem-icon { font-size:40px; margin-bottom:20px; display:block; }
.sl-problem-text { font-family:'DM Sans',sans-serif; font-size:15px; color:#7b6e8f;
  line-height:1.60; text-decoration:line-through; opacity:0.60; margin-bottom:16px; }
.sl-problem-arrow { font-size:20px; color:#8b7cba; margin-bottom:12px; display:block; }
.sl-solution-text { font-family:'DM Sans',sans-serif; font-size:15px; color:#1c1624;
  line-height:1.65; }

/* ── Sleep log visual ── */
.sl-log-card { padding:28px; }
.sl-log-title { font-family:'DM Sans',sans-serif; font-size:13px; font-weight:500;
  color:rgba(253,249,244,0.90); margin-bottom:4px; }
.sl-log-sub { font-size:12px; color:rgba(253,249,244,0.45); margin-bottom:20px; }
.sl-timeline { display:flex; flex-direction:column; gap:8px; }
.sl-tl-row { display:flex; align-items:center; gap:10px; }
.sl-tl-time { font-size:10px; color:rgba(253,249,244,0.45); width:40px; flex-shrink:0; }
.sl-tl-bar { height:22px; border-radius:6px; flex:1; }
.sl-tl-night { background:rgba(139,124,186,0.65); }
.sl-tl-nap   { background:rgba(200,191,231,0.40); }
.sl-tl-gap   { background:rgba(255,255,255,0.06); }
.sl-tl-label { font-size:10px; color:rgba(253,249,244,0.55); width:60px; }
.sl-log-summary { display:flex; gap:16px; margin-top:18px; padding-top:16px;
  border-top:1px solid rgba(255,255,255,0.08); flex-wrap:wrap; }
.sl-log-stat { font-size:11px; color:rgba(253,249,244,0.55); }
.sl-log-stat strong { color:rgba(253,249,244,0.90); font-weight:500; }
.sl-quick-chip { display:inline-flex; align-items:center; gap:6px;
  background:rgba(139,124,186,0.20); border:1px solid rgba(200,191,231,0.30);
  border-radius:999px; padding:6px 14px; font-size:11px; color:#c8bfe7;
  margin-bottom:14px; }

/* ── Regression visual ── */
.sl-reg-card { padding:28px; }
.sl-reg-title { font-size:13px; font-family:'DM Sans',sans-serif;
  color:rgba(253,249,244,0.90); margin-bottom:16px; font-weight:500; }
.sl-reg-bars { display:flex; gap:5px; align-items:flex-end; height:60px; margin-bottom:6px; }
.sl-reg-bar { flex:1; border-radius:3px 3px 2px 2px; }
.sl-reg-bar-normal { background:rgba(139,124,186,0.65); }
.sl-reg-bar-shift  { background:rgba(201,132,114,0.55); }
.sl-reg-bar-low    { background:rgba(201,132,114,0.35); height:40%; }
.sl-reg-day-labels { display:flex; gap:5px; margin-bottom:16px; }
.sl-reg-day { flex:1; text-align:center; font-size:8px; color:rgba(253,249,244,0.35); }
.sl-reg-alert { border:1px solid rgba(240,201,184,0.40); border-radius:14px; padding:14px; margin-bottom:14px; }
.sl-reg-alert-title { font-size:12px; color:#f0c9b8; font-weight:500; margin-bottom:6px; }
.sl-reg-alert-text { font-size:11px; color:rgba(253,249,244,0.60); line-height:1.55; }
.sl-conf-row { display:flex; align-items:center; gap:10px; }
.sl-conf-label { font-size:11px; color:rgba(253,249,244,0.55); white-space:nowrap; }
.sl-conf-bar { flex:1; height:6px; background:rgba(255,255,255,0.10); border-radius:999px; }
.sl-conf-fill { height:100%; border-radius:999px;
  background:linear-gradient(90deg,#8b7cba,#c98472); width:87%; }
.sl-reg-note { font-size:10px; color:rgba(253,249,244,0.35); margin-top:12px; }

/* ── Clock / bedtime visual ── */
.sl-clock-wrap { display:flex; flex-direction:column; align-items:center; gap:24px; }
.sl-clock { width:200px; height:200px; border-radius:50%; position:relative;
  background:rgba(255,255,255,0.55); border:1.5px solid rgba(255,255,255,0.75);
  backdrop-filter:blur(20px); box-shadow:0 24px 72px rgba(46,37,53,0.13); }
.sl-clock-arc { position:absolute; inset:0; border-radius:50%; }
.sl-clock-center { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  text-align:center; }
.sl-clock-time { font-family:'Cormorant Garamond',serif; font-size:22px;
  font-weight:300; color:#1c1624; }
.sl-clock-sub { font-size:10px; color:#7b6e8f; }
.sl-window-card { padding:24px 28px; width:100%; }
.sl-window-title { font-size:12px; color:#7b6e8f; text-transform:uppercase;
  letter-spacing:0.07em; margin-bottom:8px; font-family:'DM Sans',sans-serif; }
.sl-window-time { font-family:'Cormorant Garamond',serif; font-size:28px;
  font-weight:300; color:#1c1624; margin-bottom:6px; }
.sl-window-sub { font-size:12px; color:#7b6e8f; margin-bottom:16px; }
.sl-window-compare { display:flex; flex-direction:column; gap:8px; }
.sl-compare-row { display:flex; justify-content:space-between; font-size:12px;
  color:#7b6e8f; padding:8px 0; border-bottom:1px solid rgba(28,22,36,0.07); }
.sl-compare-row:last-child { border:none; }
.sl-compare-highlight { color:#3d3250; font-weight:500; }

/* ── Partner sync ── */
.sl-sync-card { padding:48px; max-width:860px; margin:0 auto;
  border-radius:40px; position:relative; }
.sl-sync-accent { position:absolute; left:0; top:10%; bottom:10%; width:4px;
  background:linear-gradient(180deg,#8b7cba,#c98472); border-radius:999px; }
.sl-sync-hdr { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.sl-sync-icon-lbl { font-size:13px; color:#8b7cba; font-family:'DM Sans',sans-serif;
  letter-spacing:0.07em; text-transform:uppercase; }
.sl-sync-h2 { font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(32px,3.5vw,48px); color:#1c1624; text-align:center;
  margin-bottom:16px; line-height:1.2; }
.sl-sync-h2 em { font-style:italic;
  background:linear-gradient(135deg,#8b7cba,#c98472); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; }
.sl-sync-body { font-family:'DM Sans',sans-serif; font-size:17px; color:#7b6e8f;
  text-align:center; max-width:560px; margin:0 auto 32px; line-height:1.75; }
.sl-sync-features { display:flex; flex-direction:column; gap:14px; max-width:420px;
  margin:0 auto 36px; }
.sl-sync-row { display:flex; align-items:center; gap:14px; font-family:'DM Sans',sans-serif;
  font-size:15px; color:#3d3250; }
.sl-phones-pair { display:flex; justify-content:center; align-items:center; gap:24px; }
.sl-mini-phone { width:90px; background:rgba(42,34,64,0.90); border-radius:18px;
  border:1px solid rgba(200,191,231,0.25); padding:10px 8px; text-align:center; }
.sl-mini-phone-label { font-size:9px; color:rgba(253,249,244,0.50); margin-bottom:6px; }
.sl-mini-screen { height:54px; background:rgba(255,255,255,0.05);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:18px; }
.sl-sync-connector { display:flex; align-items:center; gap:6px; }
.sl-sync-line { width:36px; height:1px; background:linear-gradient(90deg,#8b7cba,#c98472); }
.sl-sync-pulse { width:8px; height:8px; border-radius:50%; background:#8b7cba;
  animation:pulse-sync 1.5s ease-in-out infinite; }
@keyframes pulse-sync { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(1.4)} }

/* ── Age cards ── */
.sl-age-section { background:#1c1624; padding:50px; position:relative; z-index:1; }
.sl-age-inner { max-width:1080px; margin:0 auto; }
.sl-age-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.sl-age-card { padding:32px; border-radius:28px; }
.sl-age-h3 { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300;
  color:#fdf9f4; margin-bottom:12px; }
.sl-age-body { font-family:'DM Sans',sans-serif; font-size:14px;
  color:rgba(253,249,244,0.60); line-height:1.65; margin-bottom:16px; }
.sl-age-stat { font-size:12px; color:#c8bfe7;
  background:rgba(200,191,231,0.12); border-radius:999px; padding:5px 12px;
  display:inline-block; }

/* ── Comparison table ── */
.sl-comp-table-wrap { overflow-x:auto; margin-top:40px; }
.sl-comp-table { width:100%; border-collapse:collapse;
  background:rgba(255,255,255,0.55); border:1.5px solid rgba(255,255,255,0.75);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-radius:28px; overflow:hidden;
  box-shadow:0 24px 72px rgba(46,37,53,0.13); }
.sl-comp-table caption { font-family:'DM Sans',sans-serif; font-size:12px;
  color:#7b6e8f; padding:12px 24px; text-align:left; caption-side:bottom;
  font-style:italic; }
.sl-comp-table th { font-family:'DM Sans',sans-serif; font-size:13px; font-weight:500;
  padding:18px 24px; text-align:left; border-bottom:1px solid rgba(28,22,36,0.08); }
.sl-comp-table th.col-lunara { background:rgba(139,124,186,0.15); color:#3d3250; }
.sl-comp-table th.col-other  { color:#7b6e8f; }
.sl-comp-table td { font-family:'DM Sans',sans-serif; font-size:14px;
  padding:14px 24px; color:#3d3250; border-bottom:1px solid rgba(28,22,36,0.05); }
.sl-comp-table tr:last-child td { border:none; }
.sl-comp-table tr:nth-child(even) td { background:rgba(28,22,36,0.025); }
.sl-comp-yes  { color:#4a7f6f; font-weight:500; }
.sl-comp-no   { color:#c98472; }
.sl-comp-note { font-size:13px; color:#7b6e8f; font-style:italic; margin-top:14px;
  font-family:'DM Sans',sans-serif; }

/* ── Testimonials ── */
.sl-testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:48px; }
.sl-testi-card { padding:32px; border-radius:28px; }
.sl-testi-stars { color:#d9bc94; font-size:16px; margin-bottom:16px; }
.sl-testi-quote { font-family:'Cormorant Garamond',serif; font-style:italic;
  font-size:18px; color:#1c1624; line-height:1.55; margin-bottom:20px; }
.sl-testi-author { font-family:'DM Sans',sans-serif; font-size:13px; color:#7b6e8f; }
.sl-testi-tag { display:inline-block; margin-top:8px; font-size:11px;
  background:rgba(139,124,186,0.12); color:#8b7cba; border-radius:999px;
  padding:4px 12px; }

/* ── Stats bar ── */
.sl-stats-bar { background:#1c1624; padding:56px;
  border-top:1px solid rgba(200,191,231,0.10); border-bottom:1px solid rgba(200,191,231,0.10);
  display:flex; justify-content:space-around; align-items:center;
  flex-wrap:wrap; gap:32px; position:relative; z-index:1; }
.sl-stat-item { text-align:center; }
.sl-stat-num { font-family:'Cormorant Garamond',serif; font-size:42px; font-weight:300;
  background:linear-gradient(135deg,#c8bfe7,#c98472); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; line-height:1; }
.sl-stat-lbl { font-family:'DM Sans',sans-serif; font-size:13px;
  color:rgba(253,249,244,0.55); margin-top:6px; }

/* ── FAQ ── */
.sl-faq-section { background:#fdf9f4; padding:50px; position:relative; z-index:1; }
.sl-faq-inner { max-width:720px; margin:0 auto; }
.sl-faq-list { margin-top:44px; display:flex; flex-direction:column; gap:0; }
.sl-faq-item { border-bottom:1px solid rgba(28,22,36,0.08); }
.sl-faq-q { width:100%; background:none; border:none; display:flex;
  justify-content:space-between; align-items:center; padding:20px 0; cursor:pointer;
  font-family:'DM Sans',sans-serif; font-size:17px; font-weight:400; color:#1c1624;
  text-align:left; gap:16px; }
.sl-faq-icon { font-size:20px; color:#8b7cba; flex-shrink:0;
  transition:transform 0.3s; font-weight:300; }
.sl-faq-item.open .sl-faq-icon { transform:rotate(45deg); }
.sl-faq-a { display:none; padding-bottom:20px; }
.sl-faq-item.open .sl-faq-a { display:block; }
.sl-faq-a p { font-family:'DM Sans',sans-serif; font-size:16px; color:#7b6e8f;
  line-height:1.75; }

/* ── Final CTA ── */
.sl-finalcta { background:#1c1624; padding:80px; text-align:center;
  position:relative; z-index:1; overflow:hidden; }
.sl-finalcta-inner { max-width:640px; margin:0 auto; position:relative; z-index:1; }
.sl-finalcta-eyebrow { font-size:13px; color:rgba(253,249,244,0.45);
  letter-spacing:0.10em; text-transform:uppercase; margin-bottom:24px;
  font-family:'DM Sans',sans-serif; }
.sl-finalcta-h2 { font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(48px,6vw,74px); color:#fdf9f4; line-height:1.10; margin-bottom:20px; }
.sl-finalcta-h2 em { font-style:italic;
  background:linear-gradient(135deg,#c8bfe7,#c98472); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; }
.sl-finalcta-sub { font-family:'DM Sans',sans-serif; font-size:17px;
  color:rgba(253,249,244,0.65); max-width:440px; margin:0 auto 36px; line-height:1.70; }
.sl-finalcta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:14px; }
.sl-finalcta-trust { font-size:13px; color:rgba(253,249,244,0.40); font-family:'DM Sans',sans-serif; }
.sl-mini-phones { display:flex; justify-content:center; align-items:flex-end;
  gap:16px; margin-bottom:48px; }
.sl-mini-phone-cta { background:linear-gradient(160deg,#2a2240,#1e1928);
  border:1px solid rgba(200,191,231,0.20); border-radius:24px; overflow:hidden; }
.sl-mp-sm { width:70px; height:130px; }
.sl-mp-lg { width:90px; height:168px; }

/* ── Responsive ── */
@media (max-width:768px) {
  .sl-hero { grid-template-columns:1fr; min-height:auto; padding:100px 24px 60px; gap:32px; }
  .sl-phone-wrap { display:none; }
  .sl-section { padding:64px 24px; }
  .sl-proof-strip { padding:24px; gap:16px; }
  .sl-proof-div { display:none; }
  .sl-problem-grid { grid-template-columns:1fr; }
  .sl-feat-grid, .sl-feat-grid.flip { grid-template-columns:1fr; direction:ltr; }
  .sl-age-grid { grid-template-columns:1fr; }
  .sl-testi-grid { grid-template-columns:1fr; }
  .sl-stats-bar { padding:40px 24px; }
  .sl-faq-section { padding:64px 24px; }
  .sl-finalcta { padding:80px 24px; }
  .sl-sync-card { padding:28px 24px; }
}
@media (max-width:640px) { 
  .sl-age-grid .card { padding: 16px; border-radius: 18px;}
  .sl-age-grid h3 { font-size: 16px;line-height: 22px;}
  .sl-age-grid p { font-size: 13px; line-height: 20px;}
  .sl-age-card { min-width:260px; scroll-snap-align:start; flex-shrink:0; }
  .sl-age-section{padding: 64px 24px;}
  .sl-section { padding: 25px 24px; }
  .sl-btn-primary{padding: 0 11px;}
  .sleep-bc-wrap{padding:70px 16px 0;}
   .sl-hero {padding: 40px 24px 60px;} 
}

/* ════════════════════════════════════════════════════════════════
   NAV — page-features-sleep dark lavender nav scroll effect.
════════════════════════════════════════════════════════════════ */
body.page-features-sleep nav.site-nav {
  transition:background 0.5s ease,box-shadow 0.5s ease,padding 0.5s ease;
}
body.page-features-sleep nav.site-nav.scrolled {
  padding:16px 48px;
  background:rgba(28,22,36,0.92);
  backdrop-filter:blur(28px) saturate(1.4);
  -webkit-backdrop-filter:blur(28px) saturate(1.4);
  border-bottom:1px solid rgba(200,191,231,0.12);
  box-shadow:0 2px 40px rgba(0,0,0,0.28);
}
body.page-features-sleep .logo,
body.page-features-sleep .nav-logo { color:#fdf9f4; font-size:26px; }
body.page-features-sleep .nav-links a { color:rgba(253,249,244,0.65); }
body.page-features-sleep .nav-links a:hover,
body.page-features-sleep .nav-links a.active { color:#fdf9f4; }
body.page-features-sleep .nav-hamburger span { background:#fdf9f4; }
body.page-features-sleep .nav-cta {
  background:linear-gradient(135deg,#8b7cba,#c98472);
  color:#fff; border:none; padding:10px 24px;
  border-radius:var(--r-pill); font-size:14px; font-weight:500;
  cursor:pointer; transition:transform 0.3s,box-shadow 0.3s;
  box-shadow:0 4px 20px rgba(139,124,186,0.40);
}
body.page-features-sleep .nav-cta:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(139,124,186,0.55);
}
@media (max-width:900px) {
  body.page-features-sleep nav.site-nav { padding:18px 24px; }
  body.page-features-sleep nav.site-nav.scrolled { padding:14px 24px; }
}