/* ============================================================
   ARTELLION — BLOG · design system (hérité de Clarté)
   Réutilisable : index + articles. Crème, vert pin, corail,
   Hanken Grotesk + Instrument Serif + Spline Sans Mono.
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; }
:root{
  --cream:oklch(0.965 0.017 92); --cream-2:oklch(0.935 0.022 92); --paper:oklch(0.994 0.007 92);
  --ink:oklch(0.245 0.03 162); --ink-2:oklch(0.46 0.028 162);
  --pine:oklch(0.32 0.05 162); --pine-deep:oklch(0.262 0.046 163);
  --coral:oklch(0.645 0.17 35); --coral-deep:oklch(0.575 0.175 33); --saffron:oklch(0.81 0.13 76);
  --line:oklch(0.86 0.02 92);
  --sans:"Hanken Grotesk",system-ui,sans-serif; --serif:"Instrument Serif",Georgia,serif; --mono:"Spline Sans Mono",ui-monospace,monospace;
  --maxw:1180px; --measure:880px; --gutter:clamp(20px,5vw,72px); --sec-y:clamp(56px,9vh,120px);
}
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ margin:0; background:var(--cream); color:var(--ink); font-family:var(--sans); font-size:18px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
body::before{ content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.5; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E"); }
img{ max-width:100%; display:block; } a{ color:inherit; text-decoration:none; } button{ font:inherit; color:inherit; cursor:pointer; }
::selection{ background:var(--coral); color:var(--cream); }
main,header,footer{ position:relative; z-index:2; }

h1,h2,h3,h4{ margin:0; font-weight:800; letter-spacing:-0.03em; line-height:1.05; text-wrap:balance; }
.serif{ font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:-0.01em; }
.eyebrow{ font-family:var(--mono); font-size:12.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--coral-deep); font-weight:500; display:inline-flex; align-items:center; gap:10px; }
.eyebrow::before{ content:""; width:26px; height:1.5px; background:currentColor; }
.lead{ font-size:clamp(18px,2vw,23px); color:var(--ink-2); line-height:1.5; }
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-narrow{ max-width:var(--measure); margin-inline:auto; padding-inline:var(--gutter); }
section{ padding-block:var(--sec-y); position:relative; }

/* buttons */
.btn{ display:inline-flex; align-items:center; gap:11px; padding:15px 26px; font-family:var(--mono); font-size:13.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:600; background:var(--coral); color:var(--cream); border-radius:12px; border:1.5px solid var(--coral); transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background-color .2s,color .2s; box-shadow:0 10px 26px -16px var(--coral-deep); }
.btn:hover{ transform:translateY(-2px); box-shadow:0 16px 34px -16px var(--coral-deep); }
.btn .arrow{ transition:transform .25s; } .btn:hover .arrow{ transform:translate(3px,-3px); }
.btn.ghost{ background:transparent; color:var(--ink); border-color:color-mix(in oklch,var(--ink) 28%,transparent); box-shadow:none; }
.btn.ghost:hover{ background:var(--ink); color:var(--cream); border-color:var(--ink); }
.btn.light{ background:var(--cream); color:var(--ink); border-color:var(--cream); }

/* nav */
.nav{ position:sticky; top:0; z-index:60; display:flex; align-items:center; justify-content:space-between; padding:14px var(--gutter); background:color-mix(in oklch,var(--cream) 82%,transparent); backdrop-filter:blur(14px) saturate(1.4); border-bottom:1px solid var(--line); }
.nav-links{ display:flex; gap:clamp(14px,2vw,30px); align-items:center; }
.nav-links a{ font-family:var(--mono); font-size:12.5px; letter-spacing:.03em; text-transform:uppercase; color:var(--ink-2); transition:color .2s; }
.nav-links a:hover,.nav-links a.on{ color:var(--coral-deep); }
@media(max-width:860px){ .nav-links{ display:none; } }
.logo{ display:inline-flex; align-items:flex-end; }
.logo-word{ font-weight:800; font-size:21px; letter-spacing:-0.03em; line-height:1; }
.logo-spark{ width:9px; height:9px; color:var(--coral); margin:0 0 3px 4px; flex:none; }

/* ---------- INDEX: hero ---------- */
.blog-hero{ padding-top:clamp(40px,6vh,72px); padding-bottom:clamp(20px,3vh,36px); }
.blog-hero h1{ font-size:clamp(40px,7vw,84px); letter-spacing:-0.04em; max-width:16ch; }
.blog-hero h1 .serif{ font-size:1.02em; }
.blog-hero .lead{ margin-top:22px; max-width:52ch; }

/* category pills */
.cats{ display:flex; gap:9px; flex-wrap:wrap; margin-top:30px; }
.cat{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; text-transform:uppercase; padding:9px 15px; border-radius:999px; border:1px solid var(--line); background:var(--paper); color:var(--ink-2); transition:all .18s; }
.cat:hover,.cat.on{ border-color:var(--coral); color:var(--ink); background:color-mix(in oklch,var(--coral) 7%,var(--paper)); }

/* featured */
.feature{ display:grid; grid-template-columns:1.15fr 1fr; gap:clamp(24px,4vw,52px); align-items:center; border-top:1px solid var(--line); padding-top:clamp(36px,5vh,60px); }
@media(max-width:860px){ .feature{ grid-template-columns:1fr; gap:24px; } }
.feature .cover{ aspect-ratio:4/3; border-radius:20px; overflow:hidden; border:1px solid var(--line); box-shadow:0 40px 80px -56px rgba(40,40,30,.5); }
.feature .cover img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.3,1); }
.feature:hover .cover img{ transform:scale(1.04); }
.feature .ftag{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--coral-deep); margin-bottom:16px; display:flex; gap:12px; align-items:center; }
.feature h2{ font-size:clamp(28px,3.6vw,46px); }
.feature h2 .serif{ font-size:1.04em; }
.feature p{ color:var(--ink-2); margin:18px 0 0; max-width:48ch; }
.feature .meta{ font-family:var(--mono); font-size:12px; color:var(--ink-2); margin-top:22px; display:flex; gap:18px; flex-wrap:wrap; }
.feature .meta b{ color:var(--ink); font-weight:600; }

/* article grid */
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.5vw,30px); }
@media(max-width:900px){ .grid{ grid-template-columns:1fr 1fr; } } @media(max-width:560px){ .grid{ grid-template-columns:1fr; } }
.card{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:18px; overflow:hidden; background:var(--paper); transition:transform .25s, box-shadow .25s; }
.card:hover{ transform:translateY(-5px); box-shadow:0 26px 54px -38px rgba(40,40,30,.6); }
.card .cv{ aspect-ratio:3/2; overflow:hidden; background:var(--cream-2); }
.card .cv img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.card:hover .cv img{ transform:scale(1.05); }
.card .body{ padding:22px; display:flex; flex-direction:column; gap:12px; flex:1; }
.card .ctag{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--coral-deep); }
.card h3{ font-size:21px; line-height:1.12; }
.card p{ font-size:14.5px; color:var(--ink-2); margin:0; }
.card .cmeta{ margin-top:auto; font-family:var(--mono); font-size:11.5px; color:var(--ink-2); padding-top:14px; border-top:1px solid var(--line); display:flex; justify-content:space-between; }

/* newsletter */
.news{ background:var(--pine); color:var(--cream); border-radius:24px; padding:clamp(36px,6vw,72px); display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(24px,4vw,56px); align-items:center; }
@media(max-width:780px){ .news{ grid-template-columns:1fr; } }
.news .eyebrow{ color:var(--saffron); }
.news h2{ font-size:clamp(28px,4vw,48px); margin:16px 0 0; }
.news h2 .serif{ font-size:1.04em; }
.news p{ color:color-mix(in oklch,var(--cream) 75%,transparent); margin:16px 0 0; }
.news form{ display:flex; gap:10px; flex-wrap:wrap; }
.news input{ flex:1; min-width:200px; font:inherit; font-size:15px; padding:14px 16px; border-radius:12px; border:1px solid color-mix(in oklch,var(--cream) 30%,transparent); background:color-mix(in oklch,var(--cream) 10%,transparent); color:var(--cream); outline:none; }
.news input::placeholder{ color:color-mix(in oklch,var(--cream) 55%,transparent); }
.news .btn{ background:var(--cream); color:var(--pine-deep); border-color:var(--cream); }

/* footer */
.footer{ border-top:1px solid var(--line); padding-block:48px 40px; margin-top:40px; }
.footer-row{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; align-items:center; font-family:var(--mono); font-size:12px; color:var(--ink-2); letter-spacing:.04em; }
.footer-row a:hover{ color:var(--ink); }

/* ============================================================
   ARTICLE
   ============================================================ */
.art-hero{ padding-top:clamp(36px,5vh,64px); }
.art-hero .eyebrow{ margin-bottom:22px; }
.art-hero h1{ font-size:clamp(34px,5.6vw,68px); letter-spacing:-0.035em; max-width:18ch; }
.art-hero h1 .serif{ font-size:1.03em; }
.art-hero .standfirst{ font-family:var(--serif); font-style:italic; font-size:clamp(20px,2.4vw,28px); color:var(--ink-2); line-height:1.4; margin-top:24px; max-width:42ch; }
.art-byline{ display:flex; align-items:center; gap:16px; margin-top:30px; flex-wrap:wrap; }
.art-byline .av{ width:46px; height:46px; border-radius:50%; background:var(--pine); color:var(--cream); display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-size:22px; flex:none; }
.art-byline .who{ font-weight:700; font-size:15px; } .art-byline .role{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--ink-2); }
.art-byline .dot{ width:4px; height:4px; border-radius:50%; background:var(--line); }
.art-byline .m{ font-family:var(--mono); font-size:12px; color:var(--ink-2); letter-spacing:.03em; }
.art-cover{ margin-top:clamp(34px,5vh,56px); border-radius:24px; overflow:hidden; border:1px solid var(--line); box-shadow:0 50px 100px -64px rgba(40,40,30,.55); aspect-ratio:16/8; }
.art-cover img{ width:100%; height:100%; object-fit:cover; }

/* prose */
.prose{ font-size:clamp(18px,1.25vw,19.5px); line-height:1.72; color:var(--ink); max-width:720px; margin-inline:auto; }
.prose > * + *{ margin-top:1.35em; }
.prose p{ margin:0; }
.prose h2{ font-size:clamp(26px,3vw,38px); margin-top:1.9em; letter-spacing:-0.03em; }
.prose h2 .serif{ font-size:1.05em; }
.prose h3{ font-size:clamp(20px,2vw,24px); margin-top:1.6em; }
.prose a{ color:var(--coral-deep); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1.5px; }
.prose strong{ font-weight:700; }
.prose ul,.prose ol{ margin:0; padding-left:1.3em; display:grid; gap:.6em; }
.prose li::marker{ color:var(--coral); }
.prose hr{ border:0; border-top:1px solid var(--line); margin:2.4em 0; }
.first-letter::first-letter{ font-family:var(--serif); font-style:italic; font-size:3.4em; line-height:.8; float:left; margin:.05em .12em 0 0; color:var(--coral-deep); }

/* key takeaways box */
.takeaways{ border:1px solid var(--line); border-left:3px solid var(--coral); border-radius:14px; background:var(--paper); padding:24px 26px; margin-block:2em; }
.takeaways .t{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--coral-deep); margin-bottom:14px; }
.takeaways ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.takeaways li{ display:grid; grid-template-columns:22px 1fr; gap:12px; font-size:16px; }
.takeaways .k{ color:var(--coral); font-family:var(--mono); font-weight:700; }

/* pull quote */
.pullquote{ margin-block:2.4em; padding:6px 0; }
.pullquote blockquote{ margin:0; font-family:var(--serif); font-style:italic; font-size:clamp(26px,3.4vw,40px); line-height:1.25; letter-spacing:-0.01em; color:var(--ink); text-wrap:balance; }
.pullquote blockquote::before{ content:"“"; color:var(--coral); font-size:1.2em; line-height:0; }
.pullquote cite{ display:block; margin-top:18px; font-family:var(--mono); font-style:normal; font-size:12.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); }

/* stat band (full-bleed within measure) */
.statband{ background:var(--pine); color:var(--cream); border-radius:22px; padding:clamp(28px,4vw,44px); margin-block:2.4em; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background-clip:padding-box; }
@media(max-width:560px){ .statband{ grid-template-columns:1fr; gap:20px; } }
.statband .s{ padding:6px 20px; }
.statband .s:not(:last-child){ border-right:1px solid color-mix(in oklch,var(--cream) 18%,transparent); }
@media(max-width:560px){ .statband .s:not(:last-child){ border-right:0; border-bottom:1px solid color-mix(in oklch,var(--cream) 18%,transparent); padding-bottom:18px; } }
.statband .n{ font-weight:800; font-size:clamp(34px,5vw,52px); letter-spacing:-0.04em; color:var(--saffron); line-height:.9; }
.statband .l{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; color:color-mix(in oklch,var(--cream) 75%,transparent); margin-top:12px; }

/* avant / après */
.beforeafter{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-block:2.2em; }
@media(max-width:600px){ .beforeafter{ grid-template-columns:1fr; } }
.ba{ border:1px solid var(--line); border-radius:16px; padding:24px; background:var(--paper); }
.ba.now{ border-color:var(--coral); background:color-mix(in oklch,var(--coral) 5%,var(--paper)); }
.ba .tag{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; margin-bottom:14px; }
.ba.before .tag{ color:var(--ink-2); } .ba.now .tag{ color:var(--coral-deep); }
.ba ul{ list-style:none; margin:0; padding:0; display:grid; gap:10px; font-size:15px; }
.ba li{ display:grid; grid-template-columns:20px 1fr; gap:10px; }
.ba.before li{ color:var(--ink-2); } .ba.before .i{ color:var(--ink-2); opacity:.7; }
.ba.now .i{ color:var(--coral); font-weight:700; }

/* callout / tip */
.callout{ display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start; border-radius:16px; background:var(--cream-2); padding:22px 24px; margin-block:2em; }
.callout .ico{ width:42px; height:42px; border-radius:12px; background:var(--saffron); color:var(--pine-deep); display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-size:22px; flex:none; }
.callout .ct{ font-weight:700; margin-bottom:5px; } .callout p{ margin:0; font-size:15.5px; color:var(--ink-2); }

/* inline figure */
.figure{ margin-block:2.2em; }
.figure img{ width:100%; border-radius:18px; border:1px solid var(--line); }
.figure figcaption{ font-family:var(--mono); font-size:11.5px; letter-spacing:.03em; color:var(--ink-2); margin-top:12px; text-align:center; }

/* numbered steps */
.steps-list{ counter-reset:s; display:grid; gap:14px; margin-block:1.6em; }
.steps-list .st{ counter-increment:s; display:grid; grid-template-columns:auto 1fr; gap:18px; border:1px solid var(--line); border-radius:14px; padding:20px 22px; background:var(--paper); }
.steps-list .st::before{ content:counter(s,decimal-leading-zero); font-family:var(--mono); font-size:13px; color:var(--coral-deep); font-weight:600; padding-top:3px; }
.steps-list .st h4{ font-size:18px; margin-bottom:6px; } .steps-list .st p{ margin:0; font-size:15px; color:var(--ink-2); }

/* mini faq */
.mfaq{ margin-block:2em; border-top:1px solid var(--line); }
.mfaq details{ border-bottom:1px solid var(--line); }
.mfaq summary{ list-style:none; cursor:pointer; padding:18px 0; font-weight:700; font-size:17px; display:flex; align-items:center; gap:14px; }
.mfaq summary::-webkit-details-marker{ display:none; }
.mfaq summary::after{ content:"+"; margin-left:auto; color:var(--coral-deep); font-size:22px; font-weight:400; transition:transform .25s; }
.mfaq details[open] summary::after{ transform:rotate(45deg); }
.mfaq .a{ padding:0 0 20px; color:var(--ink-2); font-size:15.5px; max-width:60ch; }

/* author + share */
.author{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:center; border:1px solid var(--line); border-radius:18px; padding:24px; background:var(--paper); margin-block:2.4em; }
.author .av{ width:60px; height:60px; border-radius:50%; background:var(--pine); color:var(--cream); display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-size:28px; }
.author .who{ font-weight:800; font-size:18px; } .author .bio{ font-size:14.5px; color:var(--ink-2); margin-top:4px; }

/* ============================================================
   ARTICLE 2 — nouvelles sections
   ============================================================ */
/* alt hero: full-bleed cover with overlaid title */
.art-hero-full{ position:relative; min-height:clamp(440px,70vh,660px); display:flex; align-items:flex-end; overflow:hidden; }
.art-hero-full > img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.art-hero-full::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(22,32,27,.15) 0%, rgba(22,32,27,.55) 55%, rgba(22,32,27,.86) 100%); }
.art-hero-full .inner{ position:relative; z-index:2; color:var(--cream); width:100%; max-width:var(--maxw); margin-inline:auto; padding:clamp(28px,5vw,68px) var(--gutter); }
.art-hero-full .eyebrow{ color:var(--saffron); }
.art-hero-full h1{ color:var(--cream); font-size:clamp(34px,5.6vw,70px); letter-spacing:-0.035em; max-width:20ch; margin-top:18px; }
.art-hero-full h1 .serif{ font-size:1.03em; color:var(--cream); }
.art-hero-full .standfirst{ font-family:var(--serif); font-style:italic; font-size:clamp(18px,2vw,24px); color:color-mix(in oklch,var(--cream) 88%,transparent); margin-top:18px; max-width:46ch; line-height:1.4; }
.art-hero-full .hmeta{ display:flex; gap:16px; flex-wrap:wrap; margin-top:24px; align-items:center; font-family:var(--mono); font-size:12.5px; letter-spacing:.03em; color:color-mix(in oklch,var(--cream) 80%,transparent); }
.art-hero-full .hmeta .av{ width:38px;height:38px;border-radius:50%; background:var(--saffron); color:var(--pine-deep); display:grid;place-items:center; font-family:var(--serif); font-style:italic; font-size:19px; }
.art-hero-full .hmeta .dot{ width:4px;height:4px;border-radius:50%;background:var(--saffron); }

/* table of contents */
.toc{ border:1px solid var(--line); border-radius:16px; background:var(--paper); padding:24px 26px; margin-block:2.2em; }
.toc .t{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--coral-deep); margin-bottom:12px; }
.toc ol{ margin:0; padding:0; list-style:none; counter-reset:toc; display:grid; gap:2px; }
.toc li{ counter-increment:toc; }
.toc a{ display:flex; gap:14px; align-items:baseline; padding:10px 0; border-bottom:1px dashed var(--line); transition:color .15s; }
.toc li:last-child a{ border-bottom:0; }
.toc a::before{ content:counter(toc,decimal-leading-zero); font-family:var(--mono); font-size:12px; color:var(--coral-deep); }
.toc a .lbl{ font-weight:600; }
.toc a:hover{ color:var(--coral-deep); }

/* inline mini-calculator */
.minicalc{ background:var(--cream-2); border:1px solid var(--line); border-radius:18px; padding:clamp(24px,4vw,38px); margin-block:2.4em; }
.minicalc .mc-top{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; flex-wrap:wrap; margin-bottom:16px; }
.minicalc .mc-q{ font-weight:700; font-size:17px; }
.minicalc .mc-v{ font-family:var(--mono); font-size:14px; color:var(--coral-deep); font-weight:600; }
.minicalc input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:999px; background:var(--line); outline:none; }
.minicalc input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; width:24px;height:24px;border-radius:50%; background:var(--coral); border:4px solid var(--paper); box-shadow:0 2px 8px -1px var(--coral-deep); cursor:pointer; }
.minicalc input[type=range]::-moz-range-thumb{ width:22px;height:22px;border-radius:50%;background:var(--coral);border:4px solid var(--paper);cursor:pointer; }
.minicalc .mc-out{ margin-top:24px; display:flex; gap:clamp(20px,4vw,52px); flex-wrap:wrap; align-items:flex-end; }
.minicalc .mc-num{ font-weight:800; font-size:clamp(40px,6.5vw,68px); letter-spacing:-0.04em; color:var(--pine); line-height:.85; }
.minicalc .mc-num small{ font-size:.4em; font-weight:700; }
.minicalc .mc-eur{ font-weight:800; font-size:clamp(22px,3vw,30px); letter-spacing:-0.03em; color:var(--coral-deep); }
.minicalc .mc-lbl{ font-family:var(--mono); font-size:11px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); margin-top:8px; max-width:20ch; }
.minicalc .mc-note{ font-family:var(--mono); font-size:11px; color:var(--ink-2); margin-top:18px; }

/* comparison table */
.ctable{ margin-block:2.4em; border:1px solid var(--line); border-radius:16px; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.ctable table{ width:100%; border-collapse:collapse; font-size:15px; min-width:520px; }
.ctable th,.ctable td{ text-align:left; padding:15px 18px; border-bottom:1px solid var(--line); vertical-align:top; }
.ctable thead th{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-2); background:var(--cream-2); }
.ctable thead th:last-child{ color:var(--coral-deep); }
.ctable tbody tr:last-child td{ border-bottom:0; }
.ctable td:first-child{ font-weight:600; }
.ctable td:last-child,.ctable th:last-child{ background:color-mix(in oklch,var(--coral) 5%,transparent); }
.ctable .yes{ color:var(--coral-deep); font-weight:700; } .ctable .no{ color:var(--ink-2); }

/* vertical timeline */
.timeline2{ margin-block:2.4em; }
.tl-item{ display:grid; grid-template-columns:130px 1fr; gap:26px; padding-bottom:28px; position:relative; }
@media(max-width:560px){ .tl-item{ grid-template-columns:84px 1fr; gap:18px; } }
.tl-item::before{ content:""; position:absolute; left:141px; top:9px; bottom:-4px; width:2px; background:var(--line); }
@media(max-width:560px){ .tl-item::before{ left:95px; } }
.tl-item:last-child::before{ display:none; }
.tl-when{ font-family:var(--mono); font-size:12px; letter-spacing:.03em; text-transform:uppercase; color:var(--coral-deep); text-align:right; padding-top:2px; position:relative; }
.tl-when::after{ content:""; position:absolute; right:-21px; top:5px; width:12px; height:12px; border-radius:50%; background:var(--coral); border:2px solid var(--cream); }
@media(max-width:560px){ .tl-when::after{ right:-15px; } }
.tl-body h4{ font-size:18px; margin-bottom:6px; } .tl-body p{ margin:0; font-size:15px; color:var(--ink-2); }

/* testimonials */
.testimonials{ margin-block:2.4em; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:640px){ .testimonials{ grid-template-columns:1fr; } }
.tcard{ border:1px solid var(--line); border-radius:18px; padding:26px; background:var(--paper); display:flex; flex-direction:column; gap:18px; }
.tcard .q{ font-family:var(--serif); font-style:italic; font-size:19px; line-height:1.4; color:var(--ink); }
.tcard .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.tcard .av{ width:42px;height:42px;border-radius:50%; background:var(--pine); color:var(--cream); display:grid;place-items:center; font-family:var(--serif); font-style:italic; font-size:20px; flex:none; }
.tcard .nm{ font-weight:700; font-size:14.5px; } .tcard .rl{ font-family:var(--mono); font-size:11px; color:var(--ink-2); letter-spacing:.03em; }

/* glossary */
.glossary{ margin-block:2.4em; display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:16px; overflow:hidden; }
.gl{ background:var(--paper); padding:20px 24px; display:grid; grid-template-columns:210px 1fr; gap:24px; margin:0; }
@media(max-width:560px){ .gl{ grid-template-columns:1fr; gap:6px; } }
.gl dt{ font-weight:800; font-size:16px; }
.gl dd{ margin:0; font-size:15px; color:var(--ink-2); }

/* interactive checklist */
.checklist{ margin-block:2.4em; border:1px solid var(--line); border-radius:18px; background:var(--paper); padding:clamp(22px,3vw,32px); }
.checklist .cl-t{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; margin-bottom:18px; flex-wrap:wrap; }
.checklist .cl-h{ font-weight:800; font-size:19px; }
.checklist .cl-score{ font-family:var(--mono); font-size:13px; color:var(--coral-deep); font-weight:600; }
.checklist ul{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.checklist li{ display:flex; align-items:center; gap:14px; padding:13px 16px; border:1px solid var(--line); border-radius:12px; cursor:pointer; transition:background .15s, border-color .15s; user-select:none; }
.checklist li:hover{ border-color:var(--coral); }
.checklist li .box{ width:22px;height:22px;border-radius:6px; border:2px solid var(--ink-2); flex:none; display:grid; place-items:center; transition:all .15s; }
.checklist li .box::after{ content:"\2713"; color:var(--cream); font-size:13px; opacity:0; transform:scale(.5); transition:.15s; }
.checklist li.checked{ background:color-mix(in oklch,var(--coral) 7%,var(--paper)); border-color:var(--coral); }
.checklist li.checked .box{ background:var(--coral); border-color:var(--coral); }
.checklist li.checked .box::after{ opacity:1; transform:scale(1); }
.checklist li .tx{ font-size:15.5px; }
.checklist .cl-verdict{ margin-top:16px; font-size:15px; color:var(--ink-2); padding-top:16px; border-top:1px solid var(--line); }
.checklist .cl-verdict b{ color:var(--ink); }

/* ---------- mobile menu (blog + pages) ---------- */
.burger{ display:none; flex-direction:column; gap:5px; width:42px; height:42px; align-items:center; justify-content:center; background:none; border:1px solid var(--line); border-radius:999px; }
.burger span{ width:17px; height:2px; background:var(--ink); transition:transform .3s,opacity .3s; }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media(max-width:860px){ .nav > .btn{ display:none; } .burger{ display:flex; } }
.mobile-menu{ position:fixed; inset:0; z-index:80; background:var(--cream); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; opacity:0; pointer-events:none; transition:opacity .3s; }
.mobile-menu.open{ opacity:1; pointer-events:auto; }
.mobile-menu a{ font-weight:800; font-size:clamp(28px,8vw,42px); letter-spacing:-.03em; color:var(--ink); }
.mobile-menu a:hover{ color:var(--coral-deep); }
.mobile-menu .btn{ font-family:var(--mono); font-size:13.5px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; padding:14px 26px; border-radius:12px; margin-top:14px; background:var(--coral); color:var(--cream); border:1.5px solid var(--coral); box-shadow:none; }
.mobile-menu .btn:hover{ transform:none; box-shadow:none; }
.mobile-menu .mm-close{ position:absolute; top:16px; right:var(--gutter); width:48px; height:48px; display:grid; place-items:center; background:none; border:1px solid var(--line); border-radius:999px; color:var(--ink); cursor:pointer; }
.mobile-menu .mm-close::before, .mobile-menu .mm-close::after{ content:""; position:absolute; width:20px; height:2px; background:var(--ink); }
.mobile-menu .mm-close::before{ transform:rotate(45deg); } .mobile-menu .mm-close::after{ transform:rotate(-45deg); }
.mobile-menu .mm-close:hover{ border-color:var(--coral); }

/* progress bar */
.readbar{ position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,var(--coral),var(--coral-deep)); z-index:70; }

/* reveal */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.3,1), transform .8s cubic-bezier(.2,.7,.3,1); }
[data-reveal].in{ opacity:1; transform:none; }
[data-rd="1"]{transition-delay:.08s;}[data-rd="2"]{transition-delay:.16s;}[data-rd="3"]{transition-delay:.24s;}[data-rd="4"]{transition-delay:.32s;}
@media(prefers-reduced-motion:reduce){ *,*::before,*::after{ animation-duration:.001ms!important; transition-duration:.001ms!important; } [data-reveal]{opacity:1;transform:none;} html{scroll-behavior:auto;} }
