/* ============================================================
   Programme Santé & Fertilité — Styles
   ============================================================ */

/* ── VARIABLES ── */
:root {
  --bg:         #080b14;
  --surface:    #0f1525;
  --surface2:   #151d30;
  --surface3:   #1c263c;
  --border:     #243050;
  --border2:    #2e3d62;
  --accent:     #f0a820;
  --accent-dim: rgba(240,168,32,.13);
  --accent-glow:rgba(240,168,32,.07);
  --orange:     #e05838;
  --orange-dim: rgba(224,88,56,.13);
  --green:      #6ec8b4;
  --green-dim:  rgba(110,200,180,.12);
  --rose:       #d04050;
  --rose-dim:   rgba(208,64,80,.13);
  --purple:     #a888d0;
  --purple-dim: rgba(168,136,208,.12);
  --text:       #eee8f8;
  --text2:      #98aace;
  --muted:      #586888;
  --white:      #f8f4ff;
  --font:       'Plus Jakarta Sans', system-ui, sans-serif;
  --ease:       cubic-bezier(.22,1,.36,1);
}

/* ── RESET & BASE ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-weight: 400;
  font-size: 15px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── BACKGROUND HALOS ── */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 70% 60% at -8% 108%, rgba(200,25,25,.85)  0%, rgba(160,15,15,.45) 30%, transparent 60%),
    radial-gradient(ellipse 55% 50% at 108%  -8%, rgba(180,20,55,.6)   0%, rgba(140,15,45,.3)  35%, transparent 62%),
    radial-gradient(ellipse 40% 32% at  82%  92%, rgba(220,55,25,.35)  0%, transparent 52%),
    radial-gradient(ellipse 28% 22% at  18%  62%, rgba(130,12,38,.25)  0%, transparent 48%);
}
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background: radial-gradient(ellipse 110% 55% at 50% 105%, rgba(100,8,18,.5) 0%, transparent 58%);
}

/* ── HERO HALO (fade on scroll — driven by JS) ── */
#hero-halo {
  position:fixed; top:0; left:50%; transform:translateX(-50%);
  width:700px; height:420px; pointer-events:none; z-index:0;
  background: radial-gradient(ellipse 80% 75% at 50% 20%,
    rgba(210,80,30,.45) 0%, rgba(170,30,50,.25) 40%, transparent 70%);
  transition: opacity .4s ease;
  will-change: opacity;
}

/* ── LAYOUT ── */
.container { max-width:1080px; margin:0 auto; padding:0 28px; position:relative; z-index:1; }

/* ── ANIMATIONS ── */
@keyframes fadeUp    { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn    { from{opacity:0}                             to{opacity:1} }
@keyframes scaleIn   { from{opacity:0;transform:scale(.94)}        to{opacity:1;transform:scale(1)} }
@keyframes pulse     { 0%,100%{opacity:1} 50%{opacity:.45} }
@keyframes borderPulse { 0%,100%{border-color:rgba(240,168,32,.3)} 50%{border-color:rgba(240,168,32,.7)} }

.reveal        { opacity:0; transform:translateY(20px); transition:opacity .55s var(--ease), transform .55s var(--ease); }
.reveal.visible{ opacity:1; transform:translateY(0); }
.reveal-scale        { opacity:0; transform:scale(.95); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.reveal-scale.visible{ opacity:1; transform:scale(1); }
.stagger>*        { opacity:0; transform:translateY(14px); transition:opacity .45s var(--ease), transform .45s var(--ease); }
.stagger.visible>*{ opacity:1; transform:translateY(0); }

/* ── PROGRESS BAR ── */
#progress-bar {
  position:fixed; top:0; left:0; height:2px; z-index:1000;
  background:linear-gradient(90deg,var(--accent),var(--orange));
  width:0%; transition:width .1s linear;
  box-shadow:0 0 8px rgba(240,168,32,.5);
  will-change: width;
}

/* ── HEADER ── */
header { padding:100px 0 56px; text-align:center; margin-bottom:80px; position:relative; animation:fadeIn 1s ease both; }
header::after { content:''; display:block; height:1px; background:linear-gradient(90deg,transparent,var(--border2) 30%,var(--border2) 70%,transparent); margin-top:56px; }

.badge {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(240,168,32,.1); border:1px solid rgba(240,168,32,.35);
  color:var(--accent); font-size:10.5px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  padding:6px 16px; border-radius:100px; margin-bottom:30px;
  animation:borderPulse 3s ease-in-out infinite;
  backdrop-filter:blur(8px);
}
.badge-dot { width:6px; height:6px; border-radius:50%; background:var(--accent); display:inline-block; animation:pulse 2s ease-in-out infinite; }

h1 {
  font-size:clamp(2.5rem,5.5vw,4.2rem); font-weight:800;
  line-height:1.07; letter-spacing:-.03em; margin-bottom:18px;
  background:linear-gradient(145deg,var(--white) 0%,rgba(250,242,232,.95) 30%,var(--accent) 65%,var(--orange) 100%);
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  animation:fadeUp .8s .2s var(--ease) both;
}
h1.typing { animation:none; opacity:1; transform:none; }
h1 .cursor {
  -webkit-text-fill-color:var(--accent); -webkit-background-clip:unset;
  background:none; font-weight:300;
  animation:blink .6s step-end infinite;
}
@keyframes blink { 50%{opacity:0} }
.subtitle { color:var(--text2); font-size:1rem; max-width:500px; margin:0 auto; line-height:1.75; animation:fadeUp .8s .4s var(--ease) both; }

.stats-row {
  display:flex; flex-wrap:wrap;
  border:1px solid var(--border2); border-radius:16px; overflow:hidden;
  max-width:520px; margin:44px auto 0;
  animation:scaleIn .7s .6s var(--ease) both;
  box-shadow:0 4px 32px rgba(0,0,0,.5),0 0 0 1px rgba(240,168,32,.08);
  backdrop-filter:blur(16px);
}
.stat { flex:1; min-width:100px; text-align:center; padding:22px 16px; border-right:1px solid var(--border2); background:rgba(15,21,37,.6); }
.stat:last-child { border-right:none; }
.stat-val   { font-size:1.6rem; font-weight:700; color:var(--white); letter-spacing:-.02em; line-height:1; margin-bottom:6px; }
.stat-label { font-size:.67rem; color:var(--text2); letter-spacing:1.5px; text-transform:uppercase; font-weight:500; }

/* ── SECTIONS ── */
.section        { margin-bottom:80px; }
.section-header { margin-bottom:36px; }
.section-title  { font-size:1.3rem; font-weight:700; letter-spacing:-.025em; display:flex; align-items:center; gap:10px; margin-bottom:7px; color:var(--white); }
.section-title .icon { font-size:1.15rem; }
.section-sub    { color:var(--text2); font-size:.85rem; line-height:1.55; }
.divider        { height:1px; background:linear-gradient(90deg,transparent,var(--border2) 20%,var(--border2) 80%,transparent); margin:80px 0; }

/* ── SCHEDULE ── */
.schedule-grid { display:flex; flex-direction:column; gap:3px; }
.time-block {
  display:grid; grid-template-columns:84px 1fr;
  background:rgba(15,21,37,.75); border:1px solid var(--border);
  border-radius:11px; overflow:hidden;
  transition:border-color .22s,background .22s,transform .22s,box-shadow .22s;
  backdrop-filter:blur(12px);
  will-change: transform;
}
.time-block:hover {
  border-color:var(--border2); background:rgba(21,29,48,.85);
  transform:translateX(4px);
  box-shadow:-3px 0 0 var(--accent),0 4px 24px rgba(0,0,0,.4);
}
.time-col {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:14px 6px; border-right:1px solid var(--border); gap:4px;
  background:rgba(21,29,48,.8);
}
.time-emoji { font-size:1.05rem; line-height:1; }
.time-text  { font-size:.73rem; font-weight:700; color:var(--accent); letter-spacing:.2px; }
.block-content { padding:14px 18px; display:flex; align-items:center; gap:13px; }
.block-tag {
  font-size:.62rem; font-weight:700; letter-spacing:.8px;
  text-transform:uppercase; padding:3px 10px; border-radius:100px;
  white-space:nowrap; flex-shrink:0;
}
.tag-sleep     { background:rgba(168,136,208,.15); color:var(--purple); border:1px solid rgba(168,136,208,.3); }
.tag-morning   { background:rgba(240,168,32,.15);  color:var(--accent); border:1px solid rgba(240,168,32,.35); }
.tag-work      { background:rgba(224,88,56,.15);   color:var(--orange); border:1px solid rgba(224,88,56,.32); }
.tag-nutrition { background:rgba(110,200,180,.14); color:var(--green);  border:1px solid rgba(110,200,180,.3); }
.tag-exercise  { background:rgba(240,168,32,.14);  color:var(--accent); border:1px solid rgba(240,168,32,.32); }
.tag-recovery  { background:rgba(208,64,80,.15);   color:var(--rose);   border:1px solid rgba(208,64,80,.32); }
.block-desc         { font-size:.875rem; line-height:1.5; color:var(--text); }
.block-desc strong  { color:var(--white); font-weight:600; }
.block-sub          { font-size:.75rem; color:var(--text2); margin-top:3px; line-height:1.5; }

/* ── PILLAR CARDS ── */
.pillars-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:14px; }
.pillar-card {
  background:rgba(15,21,37,.7); border:1px solid var(--border);
  border-radius:14px; padding:24px; position:relative; overflow:hidden;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  backdrop-filter:blur(14px);
  will-change: transform;
}
.pillar-card:hover { transform:translateY(-4px); border-color:var(--border2); box-shadow:0 16px 40px rgba(0,0,0,.5),0 0 0 1px rgba(240,168,32,.1); }
.pillar-card::after { content:''; position:absolute; top:0; left:0; right:0; height:2px; border-radius:14px 14px 0 0; }
.pillar-card.c1::after { background:linear-gradient(90deg,var(--accent),var(--orange)); }
.pillar-card.c2::after { background:linear-gradient(90deg,var(--orange),var(--rose)); }
.pillar-card.c3::after { background:linear-gradient(90deg,var(--green),var(--accent)); }
.pillar-card.c4::after { background:linear-gradient(90deg,var(--purple),var(--rose)); }
.pillar-card.c5::after { background:linear-gradient(90deg,var(--accent),var(--green)); }
.pillar-card.c6::after { background:linear-gradient(90deg,var(--rose),var(--orange)); }
.pillar-header { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.pillar-icon   { font-size:1.5rem; }
.pillar-name   { font-size:.97rem; font-weight:700; color:var(--white); letter-spacing:-.01em; }
.pillar-items  { list-style:none; }
.pillar-items li { padding:7px 0; border-bottom:1px solid var(--border); font-size:.84rem; line-height:1.55; color:var(--text2); display:flex; gap:9px; align-items:flex-start; }
.pillar-items li:last-child  { border-bottom:none; }
.pillar-items li::before     { content:'›'; color:var(--accent); flex-shrink:0; font-size:1rem; margin-top:-1px; font-weight:700; }

/* ── SUPPLEMENTS ── */
.supps-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(195px,1fr)); gap:10px; }
.supp-card {
  background:rgba(15,21,37,.72); border:1px solid var(--border);
  border-radius:12px; padding:16px;
  transition:border-color .2s,transform .2s,box-shadow .2s;
  border-left:3px solid transparent;
  backdrop-filter:blur(10px);
  will-change: transform;
}
.supp-card:hover { transform:translateY(-3px); border-color:var(--border2); box-shadow:0 8px 24px rgba(0,0,0,.35); }
.supp-fertility    { border-left-color:var(--accent); }
.supp-general      { border-left-color:var(--orange); }
.supp-clomid       { border-left-color:var(--purple); background:rgba(168,136,208,.07); }
.supp-name  { font-size:.875rem; font-weight:700; color:var(--white); margin-bottom:4px; letter-spacing:-.01em; }
.supp-dose  { font-size:.76rem; color:var(--accent); margin-bottom:7px; font-weight:600; }
.supp-why   { font-size:.755rem; color:var(--text2); line-height:1.6; }
.supp-rx    { margin-top:8px; font-size:.72rem; color:var(--orange); opacity:.85; line-height:1.5; }

.supp-section-label {
  font-size:.72rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  margin:28px 0 12px; display:flex; align-items:center; gap:10px;
}
.supp-section-label::after { content:''; flex:1; height:1px; background:var(--border2); }
.label-amber { color:var(--accent); }
.label-accent { color:var(--green); }
.label-blue   { color:var(--orange); }
.label-rose   { color:var(--purple); }

/* ── METRICS ── */
.metrics-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:12px; }
.metric-card {
  background:rgba(15,21,37,.72); border:1px solid var(--border);
  border-radius:13px; padding:22px; position:relative; overflow:hidden;
  transition:border-color .22s,transform .22s,box-shadow .22s;
  backdrop-filter:blur(12px);
  will-change: transform;
}
.metric-card::before { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--accent),transparent); opacity:0; transition:opacity .25s; }
.metric-card:hover { border-color:var(--border2); transform:translateY(-3px); box-shadow:0 10px 28px rgba(0,0,0,.35); }
.metric-card:hover::before { opacity:1; }
.metric-label   { font-size:.7rem; color:var(--text2); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:10px; font-weight:600; }
.metric-target  { font-size:1.5rem; font-weight:700; color:var(--accent); letter-spacing:-.025em; line-height:1.1; margin-bottom:9px; }
.metric-context { font-size:.78rem; color:var(--text2); line-height:1.6; }

/* ── SCIENCE NOTE ── */
.science-note {
  background:rgba(18,26,45,.7); border:1px solid rgba(240,168,32,.22);
  border-radius:14px; padding:28px 32px; margin:28px 0;
  backdrop-filter:blur(12px);
}
.science-note h3 { font-size:.82rem; font-weight:700; color:var(--accent); margin-bottom:11px; letter-spacing:1px; text-transform:uppercase; }
.science-note p  { font-size:.855rem; line-height:1.85; color:var(--text2); }
.science-note p strong { color:var(--text); font-weight:600; }

/* ── HIGHLIGHT BOXES ── */
.highlight-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:12px; margin-bottom:28px; }
.highlight-box {
  background:rgba(18,26,45,.65); border-radius:12px; padding:18px;
  border:1px solid var(--border); border-left:3px solid var(--orange);
  backdrop-filter:blur(10px);
  font-size:.83rem; line-height:1.7; color:var(--text2);
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.highlight-box:hover { border-color:var(--border2); border-left-color:var(--accent); transform:translateY(-2px); box-shadow:0 6px 18px rgba(0,0,0,.3); }
.highlight-box strong { color:var(--white); display:block; font-size:.76rem; font-weight:700; text-transform:uppercase; letter-spacing:.8px; margin-bottom:7px; }

/* ── TOOLTIP ── */
[data-tip] { position:relative; cursor:default; }
[data-tip]::after {
  content:attr(data-tip); position:absolute; bottom:calc(100% + 8px); left:50%;
  transform:translateX(-50%) translateY(4px); opacity:0; pointer-events:none;
  background:var(--surface3); border:1px solid var(--border2); color:var(--text);
  font-size:.72rem; line-height:1.5; padding:7px 11px; border-radius:8px;
  white-space:normal; text-align:center; max-width:220px; z-index:10;
  transition:opacity .2s,transform .2s;
  box-shadow:0 6px 20px rgba(0,0,0,.5);
}
[data-tip]:hover::after { opacity:1; transform:translateX(-50%) translateY(0); }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  height:60px;
  background:rgba(8,11,20,.82);
  border-bottom:1px solid rgba(46,61,98,.5);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  display:flex; align-items:center; padding:0 28px;
  transition:background .3s,border-color .3s;
}
nav.scrolled {
  background:rgba(8,11,20,.95);
  border-bottom-color:rgba(46,61,98,.8);
}
.nav-inner {
  max-width:1080px; width:100%; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  font-size:.84rem; font-weight:800; letter-spacing:-.02em;
  color:var(--white); text-decoration:none;
  display:flex; align-items:center; gap:9px;
}
.nav-logo-dot { width:8px; height:8px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--orange)); display:inline-block; flex-shrink:0; }
.nav-logo em { color:var(--accent); font-style:normal; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-link {
  font-size:.8rem; font-weight:600; color:var(--text2);
  text-decoration:none; padding:7px 14px; border-radius:8px;
  transition:color .2s,background .2s; letter-spacing:-.01em;
}
.nav-link:hover { color:var(--white); background:rgba(255,255,255,.06); }
.nav-link.active { color:var(--accent); background:rgba(240,168,32,.1); border:1px solid rgba(240,168,32,.2); }

/* ── HAMBURGER ── */
.nav-burger {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  background:none; border:none; cursor:pointer;
  padding:8px; border-radius:8px; flex-shrink:0;
  transition:background .2s;
}
.nav-burger:hover { background:rgba(255,255,255,.07); }
.nav-burger span {
  display:block; width:22px; height:2px;
  background:var(--white); border-radius:2px;
  transition:transform .25s ease, opacity .2s ease;
  transform-origin:center;
}
.nav-burger[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-burger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── PROGRESS STORY ── */
.progress-story-block {
  background:rgba(15,21,37,.75); border:1px solid var(--border2);
  border-radius:16px; padding:32px 36px; margin-bottom:64px;
  backdrop-filter:blur(14px);
}
.psb-label { font-size:.72rem; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:2px; margin-bottom:24px; }
.psb-row { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.psb-point { text-align:center; min-width:120px; }
.psb-val { font-size:1.9rem; font-weight:800; color:var(--white); letter-spacing:-.03em; line-height:1; }
.psb-start .psb-val { color:var(--rose); }
.psb-end .psb-val { color:var(--green); }
.psb-date { font-size:.72rem; color:var(--text2); margin:5px 0; text-transform:uppercase; letter-spacing:1px; }
.psb-tag { display:inline-block; font-size:.65rem; font-weight:700; padding:3px 10px; border-radius:100px; letter-spacing:.5px; }
.tag-orange { background:rgba(224,88,56,.15); color:var(--orange); border:1px solid rgba(224,88,56,.3); }
.tag-mid    { background:rgba(240,168,32,.13); color:var(--accent); border:1px solid rgba(240,168,32,.3); }
.tag-green  { background:rgba(110,200,180,.14); color:var(--green); border:1px solid rgba(110,200,180,.3); }
.psb-mid .psb-val { color:var(--accent); }
.psb-bar-wrap { flex:1; min-width:80px; display:flex; flex-direction:column; gap:8px; align-items:center; }
.psb-bar { width:100%; height:6px; background:var(--border); border-radius:100px; overflow:hidden; }
.psb-fill { height:100%; width:0%; border-radius:100px; transition:width 1.2s cubic-bezier(.22,1,.36,1); }
.psb-fill-left  { background:linear-gradient(90deg,var(--rose),var(--accent)); transition-delay:.1s; }
.psb-fill-right { background:linear-gradient(90deg,var(--accent),var(--green)); transition-delay:.5s; }
.psb-fill.animated { width:100%; }
.psb-arrow { font-size:.72rem; color:var(--text2); letter-spacing:.5px; font-weight:600; white-space:nowrap; }
.psb-note { margin-top:18px; font-size:.75rem; color:var(--muted); border-top:1px solid var(--border); padding-top:14px; }
@media (max-width:600px) {
  .psb-row { flex-direction:column; }
  .psb-bar-wrap { width:100%; }
  .progress-story-block { padding:22px 18px; }
}

/* ── STORY PAGE ── */
.story-hero { padding:120px 0 60px; text-align:center; position:relative; animation:fadeIn 1s ease both; }
.story-hero::after { content:''; display:block; height:1px; background:linear-gradient(90deg,transparent,var(--border2) 30%,var(--border2) 70%,transparent); margin-top:56px; }
.story-lead { color:var(--text2); font-size:1rem; max-width:540px; margin:0 auto; line-height:1.8; animation:fadeUp .8s .4s var(--ease) both; }

.chapter-block {
  display:grid; grid-template-columns:80px 1fr; gap:0 32px;
  margin-bottom:64px; position:relative;
}
.chapter-block::before {
  content:''; position:absolute; left:38px; top:60px; bottom:-64px;
  width:1px; background:linear-gradient(to bottom, var(--border2), transparent);
}
.chapter-block:last-child::before { display:none; }
.chapter-num {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding-top:4px;
}
.chapter-num-circle {
  width:44px; height:44px; border-radius:50%;
  border:2px solid var(--border2); background:var(--surface);
  display:flex; align-items:center; justify-content:center;
  font-size:.75rem; font-weight:800; color:var(--accent);
  letter-spacing:.5px; flex-shrink:0;
  backdrop-filter:blur(10px);
}
/* Variante mois — page suivi */
.chapter-num-pill {
  min-width:52px; padding:8px 10px; border-radius:10px;
  border:2px solid var(--border2); background:var(--surface);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1px;
  flex-shrink:0; backdrop-filter:blur(10px); text-align:center;
}
.chapter-num-pill .pill-month { font-size:.64rem; font-weight:800; color:var(--accent); text-transform:uppercase; letter-spacing:1.5px; line-height:1.2; }
.chapter-num-pill .pill-year  { font-size:.58rem; font-weight:600; color:var(--text2); letter-spacing:.5px; }
/* Entrée "à venir" — grisée */
.chapter-block.pending { opacity:.45; }
.chapter-block.pending .chapter-num-pill { border-color:var(--border); }
.chapter-block.pending .pill-month { color:var(--muted); }

.chapter-content { padding-bottom:12px; }
.chapter-title {
  font-size:1.2rem; font-weight:800; color:var(--white);
  letter-spacing:-.025em; margin-bottom:16px; line-height:1.2;
}
.chapter-title em { font-style:normal; background:linear-gradient(90deg,var(--accent),var(--orange)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.chapter-text { font-size:.9rem; line-height:1.9; color:var(--text2); }
.chapter-text p { margin-bottom:14px; }
.chapter-text p:last-child { margin-bottom:0; }
.chapter-text strong { color:var(--text); font-weight:600; }

.quote-block {
  background:rgba(18,26,45,.7); border:1px solid rgba(240,168,32,.25);
  border-left:3px solid var(--accent); border-radius:12px;
  padding:22px 26px; margin:24px 0; backdrop-filter:blur(12px);
  font-size:.92rem; line-height:1.8; color:var(--text);
  font-style:italic; position:relative;
}
.quote-block::before { content:'\201C'; position:absolute; top:-4px; left:12px; font-size:3rem; color:var(--accent); opacity:.25; font-style:normal; line-height:1; }

.info-pill-row { display:flex; flex-wrap:wrap; gap:8px; margin:18px 0; }
.info-pill {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(15,21,37,.8); border:1px solid var(--border2);
  border-radius:100px; padding:6px 14px;
  font-size:.75rem; font-weight:600; color:var(--text2);
  backdrop-filter:blur(8px);
}
.info-pill span { font-weight:700; }
.info-pill.orange { border-color:rgba(224,88,56,.4); color:var(--orange); }
.info-pill.accent { border-color:rgba(240,168,32,.4); color:var(--accent); }
.info-pill.purple { border-color:rgba(168,136,208,.4); color:var(--purple); }
.info-pill.green  { border-color:rgba(110,200,180,.4); color:var(--green); }

.clomid-box {
  background:rgba(168,136,208,.08); border:1px solid rgba(168,136,208,.25);
  border-radius:14px; padding:24px 28px; margin:20px 0;
  backdrop-filter:blur(12px);
}
.clomid-box h4 { font-size:.78rem; font-weight:700; color:var(--purple); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:14px; }
.clomid-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:10px; }
.clomid-item { text-align:center; padding:14px; background:rgba(15,21,37,.6); border-radius:10px; border:1px solid rgba(168,136,208,.2); }
.clomid-item .ci-val { font-size:1.1rem; font-weight:700; color:var(--purple); margin-bottom:4px; }
.clomid-item .ci-lab { font-size:.7rem; color:var(--text2); text-transform:uppercase; letter-spacing:1px; }

.cta-box {
  background:rgba(240,168,32,.06); border:1px solid rgba(240,168,32,.3);
  border-radius:16px; padding:40px 36px; text-align:center;
  margin-top:56px; backdrop-filter:blur(12px);
  animation:borderPulse 3s ease-in-out infinite;
}
.cta-box h3 { font-size:1.3rem; font-weight:800; color:var(--white); margin-bottom:10px; letter-spacing:-.02em; }
.cta-box p { color:var(--text2); font-size:.88rem; margin-bottom:28px; line-height:1.7; }
.cta-btn {
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--accent),var(--orange));
  color:#0a0600; font-size:.87rem; font-weight:800;
  padding:13px 28px; border-radius:100px; text-decoration:none;
  letter-spacing:-.01em; transition:transform .2s,box-shadow .2s;
  box-shadow:0 4px 24px rgba(240,168,32,.35);
}
.cta-btn:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(240,168,32,.5); }

/* ── BLOG GRID ── */
.blog-grid { display:flex; flex-direction:column; gap:18px; }
.blog-card {
  display:block; text-decoration:none; color:inherit;
  background:rgba(15,21,37,.75); border:1px solid var(--border);
  border-radius:16px; padding:28px 32px;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  backdrop-filter:blur(14px);
  will-change: transform;
  position:relative; overflow:hidden;
}
.blog-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--accent),var(--orange));
  border-radius:16px 16px 0 0;
  opacity:0; transition:opacity .25s;
}
.blog-card:hover { border-color:var(--border2); transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.5),0 0 0 1px rgba(240,168,32,.1); }
.blog-card:hover::after { opacity:1; }
.blog-card-meta { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.blog-tag {
  font-size:.63rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  background:rgba(240,168,32,.1); border:1px solid rgba(240,168,32,.3);
  color:var(--accent); padding:4px 12px; border-radius:100px;
}
.blog-date { font-size:.72rem; color:var(--muted); font-weight:500; }
.blog-card-title {
  font-size:1.15rem; font-weight:800; color:var(--white);
  letter-spacing:-.025em; margin-bottom:12px; line-height:1.25;
}
.blog-card-title em { font-style:normal; background:linear-gradient(90deg,var(--accent),var(--orange)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.blog-card-excerpt { font-size:.875rem; line-height:1.85; color:var(--text2); margin-bottom:20px; }
.blog-card-footer { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.blog-card-tags { display:flex; flex-wrap:wrap; gap:7px; }
.blog-card-read { font-size:.8rem; font-weight:700; color:var(--accent); white-space:nowrap; letter-spacing:.3px; transition:transform .2s; }
.blog-card:hover .blog-card-read { transform:translateX(4px); }

/* ── ARTICLE PAGE ── */
.article-hero { padding:120px 0 56px; text-align:center; position:relative; animation:fadeIn 1s ease both; }
.article-hero::after { content:''; display:block; height:1px; background:linear-gradient(90deg,transparent,var(--border2) 30%,var(--border2) 70%,transparent); margin-top:56px; }
.article-lead { color:var(--text2); font-size:1rem; max-width:580px; margin:0 auto; line-height:1.8; animation:fadeUp .8s .4s var(--ease) both; }
.article-breadcrumb {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.73rem; color:var(--text2); margin-bottom:24px; font-weight:500;
  animation:fadeUp .6s .1s var(--ease) both;
}
.article-breadcrumb a { color:var(--text2); text-decoration:none; transition:color .2s; }
.article-breadcrumb a:hover { color:var(--accent); }
.article-breadcrumb .sep { opacity:.5; }
.article-body { max-width:760px; margin:0 auto; }
.article-section { margin-bottom:64px; }
.article-section h2 {
  font-size:1.15rem; font-weight:800; color:var(--white);
  letter-spacing:-.025em; margin-bottom:20px; line-height:1.2;
}
.article-section h2 em { font-style:normal; background:linear-gradient(90deg,var(--accent),var(--orange)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.article-section p { font-size:.9rem; line-height:1.9; color:var(--text2); margin-bottom:14px; }
.article-section p:last-child { margin-bottom:0; }
.article-section p strong { color:var(--text); font-weight:600; }
.article-section ul { list-style:none; padding:0; margin:12px 0 14px; display:flex; flex-direction:column; gap:9px; }
.article-section ul li { font-size:.875rem; line-height:1.65; color:var(--text2); display:flex; gap:10px; align-items:flex-start; }
.article-section ul li::before { content:'›'; color:var(--accent); flex-shrink:0; font-size:1rem; font-weight:700; margin-top:-1px; }
.article-section ul li strong { color:var(--text); font-weight:600; }

.leviers-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:14px; margin-top:20px; }
.levier-card {
  background:rgba(15,21,37,.7); border:1px solid var(--border);
  border-radius:14px; padding:22px; position:relative; overflow:hidden;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  backdrop-filter:blur(14px);
}
.levier-card:hover { transform:translateY(-3px); border-color:var(--border2); box-shadow:0 10px 28px rgba(0,0,0,.35); }
.levier-card::after { content:''; position:absolute; top:0; left:0; right:0; height:2px; border-radius:14px 14px 0 0; }
.levier-card.l1::after { background:linear-gradient(90deg,var(--purple),var(--rose)); }
.levier-card.l2::after { background:linear-gradient(90deg,var(--green),var(--accent)); }
.levier-card.l3::after { background:linear-gradient(90deg,var(--accent),var(--orange)); }
.levier-card.l4::after { background:linear-gradient(90deg,var(--orange),var(--rose)); }
.levier-header { display:flex; align-items:center; gap:9px; margin-bottom:14px; }
.levier-icon { font-size:1.35rem; }
.levier-name { font-size:.92rem; font-weight:700; color:var(--white); letter-spacing:-.01em; }
.levier-body { font-size:.82rem; line-height:1.7; color:var(--text2); }
.levier-body strong { color:var(--text); font-weight:600; }
.levier-impact {
  display:inline-flex; align-items:center; gap:6px; margin-top:12px;
  font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:1px;
  padding:3px 10px; border-radius:100px;
}
.impact-high { background:rgba(110,200,180,.13); color:var(--green); border:1px solid rgba(110,200,180,.3); }
.impact-med  { background:rgba(240,168,32,.12); color:var(--accent); border:1px solid rgba(240,168,32,.3); }
.impact-low  { background:rgba(168,136,208,.12); color:var(--purple); border:1px solid rgba(168,136,208,.3); }

.article-personal-note {
  background:rgba(168,136,208,.07); border:1px solid rgba(168,136,208,.22);
  border-radius:14px; padding:28px 32px; margin:32px 0;
  backdrop-filter:blur(12px);
}
.article-personal-note h3 { font-size:.8rem; font-weight:700; color:var(--purple); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:12px; }
.article-personal-note p { font-size:.88rem; line-height:1.85; color:var(--text2); }
.article-personal-note p strong { color:var(--text); }

.warning-box {
  background:rgba(224,88,56,.07); border:1px solid rgba(224,88,56,.25);
  border-left:3px solid var(--orange); border-radius:12px; padding:20px 24px; margin:20px 0;
  font-size:.84rem; line-height:1.75; color:var(--text2); backdrop-filter:blur(10px);
}
.warning-box strong { color:var(--orange); display:block; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }

/* ── FOOTER ── */
footer {
  border-top:1px solid var(--border); padding:40px 0;
  text-align:center; color:var(--text2); font-size:.78rem; margin-top:40px; line-height:1.85;
}

/* ── RESPONSIVE ── */
@media (max-width:600px) {
  h1 { font-size:2.2rem; }
  .container { padding:0 16px; }
  .time-block { grid-template-columns:68px 1fr; }
  .stats-row  { max-width:100%; }
  .science-note { padding:20px; }
  nav { padding:0 16px; }
  .chapter-block { grid-template-columns:1fr; }
  .chapter-num { flex-direction:row; justify-content:flex-start; margin-bottom:12px; }
  .chapter-block::before { display:none; }
  .cta-box { padding:28px 20px; }

  /* Mobile nav drawer */
  .nav-burger { display:flex; }
  .nav-links {
    display:none;
    position:absolute; top:60px; left:0; right:0;
    background:rgba(8,11,20,.97);
    border-bottom:1px solid rgba(46,61,98,.8);
    backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
    flex-direction:column; gap:4px;
    padding:12px 16px 20px;
    transform:translateY(-8px); opacity:0;
    transition:transform .22s var(--ease), opacity .22s var(--ease);
  }
  .nav-links.open {
    display:flex;
    transform:translateY(0); opacity:1;
  }
  .nav-link {
    font-size:.9rem; padding:13px 16px;
    border-radius:10px; width:100%;
    display:flex; align-items:center; gap:8px;
  }
  .nav-link.active { border:1px solid rgba(240,168,32,.25); }
}
