/*
 * NicheForge Template v1.0
 * Design system réutilisable pour sites d'affiliation SEO
 * Variables de thème dans :root — surchargées par deploy.sh via config.json
 *
 * Palette par défaut : tons chauds (graindexpert-like)
 * Remplacer les couleurs via %%COLORS%% dans deploy.sh
 */

:root{--primary:#1a2e1a;--primary-mid:#2d4a2d;--primary-soft:#3d6b3d;--cream:#f5f7f2;--cream-deep:#e8ede3;--cream-warm:#dce5d5;--accent:#2e7d32;--accent-hover:#1b5e20;--accent-glow:rgba(46,125,50,0.12);--accent-light:#a5d6a7;--ink:#1a2418;--ink-soft:#4A3F35;--ink-muted:#7A6E62;--ink-faint:#A99E92;--white:#FFFDF9;--border:#DDD5CB;--border-soft:#EDE6DC;--cta:#ef6c00;--cta-hover:#e65100;--font-serif:'Libre Bodoni', Georgia, serif;--font-sans:'Public Sans', -apple-system, BlinkMacSystemFont, sans-serif;--s1:0.25rem;--s2:0.5rem;--s3:0.75rem;--s4:1rem;--s5:1.25rem;--s6:1.5rem;--s8:2rem;--s10:2.5rem;--s12:3rem;--s16:4rem;--s20:5rem;--s24:6rem;--max-w:1320px;--nav-h:64px;--radius:6px;--ease:cubic-bezier(0.4, 0, 0.2, 1);--dur:200ms}

/* ═══ Reset ═══ */
*,::after,::before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;font-size:16px}body,h1,h2,h3{color:var(--ink)}body{font-family:var(--font-sans);font-size:1rem;line-height:1.65;background:var(--cream);overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}ul{list-style:none}button{cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ═══ Layout ═══ */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--s6)}h1,h2,h3{font-family:var(--font-serif);font-weight:400;line-height:1.2}

/* ═══ Buttons ═══ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;font-family:var(--font-sans);font-size:.875rem;font-weight:600;letter-spacing:.01em;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;transition:all var(--dur) var(--ease)}.btn--accent{background:var(--accent);color:var(--primary);border-color:var(--accent)}.btn--accent:#2e7d32;border-color:var(--accent-hover)}.btn--accent:#2e7d32;outline-offset:2px}.btn--light{background:rgba(255,255,255,.12);color:#ffffff;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(4px)}.btn--light:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5)}.btn--ghost{background:0 0;color:var(--ink);border-color:var(--border)}.btn--ghost:hover{border-color:var(--ink)}

/* ═══ Navigation ═══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);background:rgba(250,246,241,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-soft);transition:box-shadow .3s var(--ease)}.nav--scrolled{box-shadow:0 2px 16px rgba(30,17,8,.06)}.nav__container,.nav__logo{display:flex;align-items:center}.nav__container{max-width:var(--max-w);margin:0 auto;padding:0 var(--s6);height:100%;justify-content:space-between}.nav__logo{gap:8px}.nav__logo-img{height:36px;width:auto;display:block}.nav__links{display:flex;align-items:center;gap:var(--s8)}.nav__links>li>a{font-size:.8125rem;font-weight:500;color:var(--ink-muted);letter-spacing:.02em;transition:color var(--dur) var(--ease);cursor:pointer;position:relative}.nav__links>li>a::after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width .3s var(--ease)}.nav__links>li>a.active,.nav__links>li>a:hover{color:var(--ink)}.nav__links>li>a.active::after,.nav__links>li>a:hover::after{width:100%}.nav__dropdown{position:relative}.nav__sub{position:absolute;top:calc(100% + 10px);left:-14px;min-width:230px;background:var(--white);border:1px solid var(--border-soft);border-radius:var(--radius);padding:var(--s2)0;opacity:0;visibility:hidden;transform:translateY(6px);box-shadow:0 8px 32px rgba(30,17,8,.1);transition:all var(--dur) var(--ease)}.nav__dropdown:hover .nav__sub{opacity:1;visibility:visible;transform:translateY(0)}.nav__sub a{display:block;padding:9px 18px;font-size:.8125rem;color:var(--ink-muted);cursor:pointer;transition:all var(--dur) var(--ease)}.nav__sub a:hover{color:var(--ink);background:var(--cream)}.nav__toggle{display:none;flex-direction:column;gap:5px;background:0 0;border:0;padding:8px}.nav__toggle span{display:block;width:20px;height:1.5px;background:var(--ink);transition:all .3s var(--ease)}

/* ═══ Hero ═══ */
.hero{margin-top:var(--nav-h);position:relative;min-height:520px;display:flex;align-items:center;overflow:hidden}.hero__bg,.hero__overlay{position:absolute;inset:0;z-index:0}.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}.hero__overlay{z-index:1;background:linear-gradient(135deg,rgba(26,46,26,.88) 0,rgba(45,74,45,.75) 50%,rgba(61,107,61,.60) 100%)}.hero__content{position:relative;z-index:2;max-width:var(--max-w);margin:0 auto;padding:var(--s24) var(--s6) var(--s20);width:100%}.hero__kicker{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s5)}.hero__title{font-size:clamp(2.2rem,4.5vw,3.4rem);line-height:1.12;color:var(--white);margin-bottom:var(--s6);max-width:680px}.hero__title em{font-style:italic;color:var(--accent)}.hero__subtitle{font-size:1.0625rem;line-height:1.7;color:rgba(255,255,255,.7);margin-bottom:var(--s8);max-width:540px}.hero__actions{display:flex;gap:var(--s4);flex-wrap:wrap}

/* ═══ Intro bar ═══ */
.intro{background:var(--primary);padding:var(--s8)0}.intro__inner{display:flex;align-items:center;justify-content:center;gap:var(--s10)}.intro__stat{text-align:center;flex-shrink:0}.intro__stat-num{display:block;font-family:var(--font-serif);font-size:1.6rem;color:var(--accent);line-height:1.2}.intro__stat-label{font-size:.75rem;color:rgba(255,255,255,.52);letter-spacing:.03em}.intro__divider{width:1px;height:36px;background:rgba(255,255,255,.12);flex-shrink:0}.intro__text{font-size:.9375rem;line-height:1.65;color:rgba(255,255,255,.6);max-width:560px;text-align:center}.intro__text strong{color:rgba(255,255,255,.9);font-weight:600}

/* ═══ Sections ═══ */
.section{padding:var(--s20)0}.section--cream{background:var(--cream-deep)}.section--dark{background:var(--primary-mid);background-image:radial-gradient(ellipse at 20% 50%,rgba(200,150,62,.05)0,transparent 60%),radial-gradient(ellipse at 80% 50%,rgba(200,150,62,.03)0,transparent 60%)}.section__header{margin-bottom:var(--s10)}.section__header--light .section__title{color:var(--white)}.section__header--light .section__desc{color:rgba(255,255,255,.5)}.section__accent{display:block;width:32px;height:3px;border-radius:2px;background:var(--accent);margin-bottom:var(--s4)}.section__title{font-size:clamp(1.5rem,2.5vw,2.1rem);margin-bottom:var(--s3)}.section__desc{font-size:.9375rem;color:var(--ink-muted);max-width:480px}.section--cream .section__desc{color:#6F6357}

/* ═══ Grid ═══ */
.grid{display:grid;gap:var(--s5)}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}

/* ═══ Cards ═══ */
.card{position:relative;padding:var(--s8);border:1px solid var(--border);border-radius:var(--radius);background:var(--white);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);cursor:pointer;display:flex;flex-direction:column}.card:hover{border-color:var(--ink-faint);box-shadow:0 4px 20px rgba(30,17,8,.06)}.card--highlight{border-color:var(--accent);border-left-width:4px;background:linear-gradient(135deg,var(--white) 0%,var(--accent-light) 100%)}.card--highlight:hover{border-color:var(--accent-hover);box-shadow:0 4px 24px rgba(200,150,62,.12)}.card__label{display:inline-block;font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s4)}.card__title{font-size:1.1875rem;margin-bottom:var(--s3);line-height:1.3}.card__title a{color:var(--ink);transition:color var(--dur) var(--ease)}.card__title a::after{content:"";position:absolute;inset:0;z-index:1}.card:hover .card__title a{color:var(--accent-hover)}.card__desc{font-size:.875rem;color:var(--ink-muted);line-height:1.6;flex:1}.card__foot{display:flex;justify-content:space-between;margin-top:var(--s6);padding-top:var(--s4);border-top:1px solid var(--border-soft);font-size:.75rem;color:#6F6660;font-weight:500}

/* ═══ Brand cards ═══ */
.brands-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4)}.brand-card{display:flex;align-items:center;gap:var(--s5);padding:var(--s5) var(--s6);border:1px solid var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;transition:all var(--dur) var(--ease)}.brand-card:hover{border-color:var(--accent);box-shadow:0 2px 16px rgba(200,150,62,.08)}.brand-card__initial{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--cream-deep);font-family:var(--font-serif);font-size:1.25rem;color:var(--primary-soft);flex-shrink:0;transition:all var(--dur) var(--ease)}.brand-card:hover .brand-card__initial{background:var(--accent);color:var(--white)}.brand-card__logo{width:48px;height:48px;border-radius:12px;object-fit:contain;background:var(--white);padding:4px;border:1px solid var(--border-soft);flex-shrink:0}.brand-card:hover .brand-card__logo{border-color:var(--accent);box-shadow:0 0 0 2px rgba(200,150,62,.15)}.brand-card__body{flex:1;min-width:0}.brand-card__name{display:block;font-family:var(--font-serif);font-size:1.125rem;color:var(--ink);margin-bottom:2px}.brand-card__desc{font-size:.8rem;color:var(--ink-muted);line-height:1.45}.brand-card__arrow{color:var(--ink-faint);flex-shrink:0;transition:all var(--dur) var(--ease)}.brand-card:hover .brand-card__arrow{color:var(--accent);transform:translateX(3px)}

/* ═══ Test cards (dark bg) ═══ */
.test-card{display:flex;align-items:flex-start;gap:var(--s6);padding:var(--s6) var(--s8);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);background:rgba(255,255,255,.03);cursor:pointer;transition:all var(--dur) var(--ease)}.test-card:hover{background:rgba(255,255,255,.06);border-color:var(--accent)}.test-card__score{position:relative;width:64px;height:64px;flex-shrink:0}.test-card__ring{width:64px;height:64px;transform:rotate(-90deg)}.test-card__num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:1.25rem;color:var(--accent)}.test-card__body h2,.test-card__body h3{font-size:1.0625rem;color:var(--white);margin-bottom:var(--s2)}.test-card__body p{font-size:.8125rem;color:rgba(255,255,255,.55);line-height:1.55;margin-bottom:var(--s3)}.test-card__meta{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.3)}

/* ═══ Criteria cards ═══ */
.criteria-card{display:flex;flex-direction:column;gap:var(--s3);padding:var(--s6);border:1px solid var(--border);border-radius:var(--radius);background:var(--white);transition:all var(--dur) var(--ease);cursor:pointer;text-align:center;align-items:center}.criteria-card:hover{border-color:var(--accent);background:var(--accent-glow)}.criteria-card svg{color:var(--accent)}.criteria-card h3{font-family:var(--font-sans);font-size:.9375rem;font-weight:600}.criteria-card p{font-size:.8rem;color:var(--ink-muted)}

/* ═══ Guide cards ═══ */
.guide-card{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s6);padding:var(--s6) var(--s8);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);background:var(--white);transition:all var(--dur) var(--ease);cursor:pointer}.guide-card:hover{border-color:var(--accent);box-shadow:0 4px 20px rgba(200,150,62,.08)}.guide-card:hover h3{color:var(--accent-hover)}.guide-card__type{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8B6A2B;margin-bottom:var(--s2)}.guide-card__content h3{font-size:1.0625rem;margin-bottom:var(--s2);transition:color var(--dur) var(--ease)}.guide-card__content p{font-size:.8125rem;color:var(--ink-muted);line-height:1.55}.guide-card__time{flex-shrink:0;font-size:.75rem;color:#6F6660;font-weight:500;padding-top:var(--s1)}

/* ═══ Newsletter ═══ */
.newsletter{padding:var(--s16)0;background:var(--cream-deep);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}.newsletter__inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s8)}.newsletter__title{font-size:1.4rem;margin-bottom:var(--s2)}.newsletter__desc{font-size:.875rem;color:#6F6357}.newsletter__form{display:flex;gap:var(--s3);flex-shrink:0}.newsletter__form input{width:260px;padding:12px 16px;font-family:var(--font-sans);font-size:.875rem;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--ink);transition:border-color var(--dur) var(--ease)}.newsletter__form input::placeholder{color:var(--ink-faint)}.newsletter__form input:focus{outline:0;border-color:var(--accent)}

/* ═══ Footer ═══ */
.footer{padding:var(--s16)0 var(--s8);background:var(--primary)}.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--s8);margin-bottom:var(--s12)}.footer .nav__logo{margin-bottom:var(--s4)}.footer .nav__logo-img{height:32px}.footer__about{font-size:.8125rem;color:rgba(255,255,255,.4);line-height:1.6;max-width:260px}.footer__col h3{font-family:var(--font-sans);font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:var(--s4)}.footer__col ul{display:flex;flex-direction:column;gap:var(--s3)}.footer__col a{font-size:.8125rem;color:rgba(255,255,255,.5);transition:color var(--dur) var(--ease);cursor:pointer}.footer__col a:hover{color:var(--accent)}.footer__bottom{padding-top:var(--s8);border-top:1px solid rgba(255,255,255,.06)}.footer__bottom p{font-size:.75rem;color:rgba(255,255,255,.25)}.footer__disclosure{margin-top:var(--s2);font-size:.6875rem!important}.footer__legal{display:flex;align-items:center;gap:var(--s4);margin-top:var(--s3);flex-wrap:wrap}.footer__legal a{font-size:.75rem;color:rgba(255,255,255,.35);transition:color var(--dur) var(--ease);cursor:pointer}.footer__legal a:hover{color:var(--accent)}.footer__legal-sep{color:rgba(255,255,255,.15);font-size:.75rem}

/* ═══ Article ═══ */
.article{margin-top:var(--nav-h);padding:var(--s10)0 var(--s20)}.article__header{margin:0 auto var(--s10);padding:0 var(--s6)}.article__breadcrumb{display:flex;align-items:center;gap:6px;margin-bottom:var(--s6);font-size:.8125rem;color:var(--ink-faint)}.article__breadcrumb a{color:var(--ink-muted);transition:color var(--dur) var(--ease);cursor:pointer}.article__breadcrumb a:hover{color:var(--ink)}.article__category{display:inline-block;font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s4)}.article__title{font-size:clamp(1.75rem,3.5vw,2.5rem);margin-bottom:var(--s4)}.article__meta{display:flex;align-items:center;gap:var(--s4);font-size:.8125rem;color:var(--ink-faint)}.article__content{margin:0 auto;padding:0 var(--s6)}.article__content h2{font-size:1.625rem;margin:var(--s10)0 var(--s4);padding-top:var(--s6);border-top:1px solid var(--border-soft)}.article__content h3{font-size:1.1875rem;margin:var(--s8)0 var(--s3)}.article__content p{margin-bottom:var(--s4)}.article__content ol,.article__content ul{margin-bottom:var(--s4);padding-left:var(--s6)}.article__content li{margin-bottom:var(--s2);list-style:disc}.article__content ol li{list-style:decimal}.article__content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.article__content a:hover{color:var(--accent-hover)}

/* ═══ TOC ═══ */
.toc{padding:var(--s6);margin-bottom:var(--s8);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);background:var(--cream)}.toc__title{font-family:var(--font-sans);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-bottom:var(--s4)}.toc ol{counter-reset:toc;padding:0}.toc li{counter-increment:toc;list-style:none!important;margin-bottom:6px}.toc li::before{content:counter(toc)".";font-weight:700;color:var(--accent);margin-right:8px;font-size:.8125rem}.toc a{font-size:.875rem;color:var(--ink-muted);text-decoration:none!important;cursor:pointer;transition:color var(--dur) var(--ease)}.toc a:hover{color:var(--ink)}

/* ═══ Product cards ═══ */
.product-card{padding:var(--s8);margin:var(--s8)0;border:1px solid var(--border);border-radius:var(--radius);background:var(--cream)}.product-card__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--s4)}.product-card__name,.product-card__price{font-family:var(--font-serif);font-size:1.25rem}.product-card__price{font-size:1.125rem;color:var(--accent)}.product-card__cta{display:flex;gap:var(--s3);margin-top:var(--s6)}
.product-card--full{padding:var(--s8);margin:var(--s8)0;border:1px solid var(--border);border-radius:var(--radius);background:var(--white)}.product-card__image{text-align:center;margin-bottom:var(--s6);padding:var(--s4);background:var(--cream);border-radius:var(--radius)}.product-card__image img{max-width:100%;height:auto;max-height:320px;object-fit:contain;display:inline-block}.product-card__top{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s6);margin-bottom:var(--s6)}.product-card__identity{flex:1;min-width:0}.product-card__brand{display:block;font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s2)}.product-card__name--lg{font-family:var(--font-serif);font-size:1.375rem;color:var(--ink);line-height:1.25;margin-bottom:var(--s2)}.product-card__price--lg{font-family:var(--font-serif);font-size:1.5rem;color:var(--accent);font-weight:600}.product-card__score{position:relative;width:72px;height:72px;flex-shrink:0}.product-card__score-ring{width:72px;height:72px;transform:rotate(-90deg)}.product-card__score-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:1.375rem;font-weight:600;color:var(--accent)}.product-card__proscons{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);margin-bottom:var(--s6);padding-bottom:var(--s6);border-bottom:1px solid var(--border-soft)}.product-card__pros,.product-card__cons{padding:0}.product-card__pros-title,.product-card__cons-title{display:flex;align-items:center;gap:6px;font-family:var(--font-sans);font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--s3)}.product-card__pros-title{color:#2d7a3a}.product-card__cons-title{color:#b5342b}.product-card__pros ul,.product-card__cons ul{padding:0;list-style:none}.product-card__pros li,.product-card__cons li{position:relative;padding-left:20px;font-size:.8125rem;line-height:1.55;color:var(--ink-soft);margin-bottom:6px;list-style:none!important}.product-card__pros li::before{content:"";position:absolute;left:0;top:5px;width:12px;height:12px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232D7A3A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")no-repeat center}.product-card__cons li::before{content:"";position:absolute;left:0;top:5px;width:12px;height:12px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B5342B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E")no-repeat center}.product-card__actions{display:flex;gap:var(--s3);align-items:center}

/* ═══ CTA buttons ═══ */
.article__content a.btn--cta-buy,.btn--cta-buy{background:var(--cta);color:#fff;border-color:var(--cta);font-weight:700;text-decoration:none}.btn--cta-buy svg{stroke:#fff}.article__content a.btn--cta-buy:hover,.btn--cta-buy:hover{background:var(--cta-hover);border-color:var(--cta-hover);color:#fff}.cta-inline{margin:1.5rem 0;padding:1rem 1.25rem;background:rgba(255,153,0,.06);border:1px solid rgba(255,153,0,.2);border-radius:12px;display:flex;align-items:center;gap:.5rem}.cta-inline .btn--cta-buy{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:8px;font-size:.95rem}

/* ═══ Author box ═══ */
.author-box{display:flex;align-items:flex-start;gap:var(--s5);padding:var(--s6);margin-bottom:var(--s8);border:1px solid var(--border);border-radius:var(--radius);background:var(--cream)}.author-box__avatar{width:56px;height:56px;border-radius:50%;background:var(--cream-deep);border:2px solid var(--border-soft);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--ink-faint)}.author-box__avatar img{width:100%;height:100%;object-fit:cover}.author-box__info{flex:1;min-width:0}.author-box__name{font-family:var(--font-sans);font-size:.9375rem;font-weight:600;color:var(--ink);margin-bottom:2px}.author-box__bio{font-size:.8125rem;color:var(--ink-muted);line-height:1.55;margin-bottom:var(--s2)}.author-box__meta{display:flex;align-items:center;gap:var(--s4);flex-wrap:wrap;font-size:.75rem;color:var(--ink-faint)}.author-box__meta a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;cursor:pointer;transition:color var(--dur) var(--ease)}.author-box__meta a:hover{color:var(--accent-hover)}.author-box__sep{width:3px;height:3px;border-radius:50%;background:var(--ink-faint);flex-shrink:0}

/* ═══ Comparison table ═══ */
.comparison-table{width:100%;margin:var(--s8)0;-webkit-overflow-scrolling:touch;--table-max-w:1320px;width:calc(100% + (var(--table-max-w) - var(--max-w)));max-width:var(--table-max-w);margin-left:calc(-1*(var(--table-max-w) - var(--max-w))/2);overflow-x:visible}.comparison-table table{width:100%;border-collapse:collapse;font-size:.875rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);overflow:hidden}.comparison-table thead{background:var(--primary)}.comparison-table th{padding:var(--s3) var(--s4);text-align:left;font-family:var(--font-sans);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--cream)}.comparison-table td{padding:var(--s3) var(--s4);border-bottom:1px solid var(--border-soft);color:var(--ink);vertical-align:middle}.comparison-table tbody tr{transition:background var(--dur) var(--ease)}.comparison-table tbody tr:hover{background:var(--accent-glow)}.comparison-table tbody tr:last-child td{border-bottom:none}.comparison-table__highlight{background:var(--accent-glow);font-weight:600}.comparison-table__badge{display:inline-block;font-size:.625rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:3px;background:var(--accent);color:var(--primary)}.comparison-table .td-cta{text-align:center;white-space:nowrap}.comparison-table .btn--cta-buy--sm{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .8rem;font-size:.8rem;font-weight:700;background:var(--cta);color:#fff;border-radius:6px;text-decoration:none;transition:background .2s}.comparison-table .btn--cta-buy--sm:hover{background:var(--cta-hover);color:#fff}.comparison-table .btn--cta-buy--sm svg{stroke:#fff;flex-shrink:0}@media (max-width:1400px){.comparison-table{width:calc(100vw - 2*var(--s6));margin-left:calc(-1*(100vw - 2*var(--s6) - 100%)/2);overflow-x:auto}}

/* ═══ Comparison cards (mobile) ═══ */
.comparison-cards{display:flex;flex-direction:column;gap:var(--s4)}.comparison-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:var(--s4);display:flex;flex-direction:column;gap:var(--s2)}.comparison-card--highlight{border-color:var(--accent);box-shadow:0 2px 8px rgba(200,150,62,.15)}.comparison-card__field{display:flex;justify-content:space-between;align-items:baseline;padding:var(--s1)0;border-bottom:1px solid var(--border-soft)}.comparison-card__field:last-child{border-bottom:none}.comparison-card__label{font-family:var(--font-sans);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);flex-shrink:0;margin-right:var(--s3)}.comparison-card__value{font-size:.875rem;text-align:right;color:var(--ink)}

/* ═══ FAQ ═══ */
.faq-section{margin:var(--s10)0;padding-top:var(--s6);border-top:1px solid var(--border-soft)}.faq-section__title{font-size:1.625rem;margin-bottom:var(--s6)}.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--s3);background:var(--white);overflow:hidden}.faq-item__question{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--s5) var(--s6);font-family:var(--font-sans);font-size:.9375rem;font-weight:600;text-align:left;color:var(--ink);background:0 0;border:0;cursor:pointer;transition:color var(--dur) var(--ease)}.faq-item__question:hover{color:var(--accent)}.faq-item__icon{flex-shrink:0;color:var(--ink-faint);transition:transform .3s var(--ease),color var(--dur) var(--ease)}.faq-item.open .faq-item__icon{transform:rotate(45deg);color:var(--accent)}.faq-item__answer{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}.faq-item__answer-inner{padding:0 var(--s6) var(--s6);font-size:.875rem;color:var(--ink-muted);line-height:1.65}.faq-item.open .faq-item__answer{max-height:500px}

/* ═══ Affiliation disclosure ═══ */
.affiliation-disclosure{margin:var(--s10)0;padding:var(--s5) var(--s6);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);background:var(--cream);font-size:.8125rem;color:var(--ink-muted);line-height:1.6}.affiliation-disclosure strong{color:var(--ink-soft)}

/* ═══ Related articles ═══ */
.related-articles{margin:var(--s10)0;padding-top:var(--s6);border-top:1px solid var(--border-soft)}.related-articles__title{font-size:1.25rem;margin-bottom:var(--s6)}.related-articles__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}.related-card{padding:var(--s6);border:1px solid var(--border);border-radius:var(--radius);background:var(--white);display:flex;flex-direction:column;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);cursor:pointer;text-decoration:none}.related-card:hover{border-color:var(--accent);box-shadow:0 4px 20px rgba(200,150,62,.08)}.related-card__category{font-size:.625rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s3)}.related-card__title{font-family:var(--font-serif);font-size:1rem;color:var(--ink);line-height:1.3;margin-bottom:var(--s3);transition:color var(--dur) var(--ease)}.related-card:hover .related-card__title{color:var(--accent-hover)}.related-card__meta{font-size:.75rem;color:var(--ink-faint);margin-top:auto}

/* ═══ Legal pages ═══ */
.legal-page{margin-top:var(--nav-h);padding:var(--s12)0 var(--s20)}.legal-page__header{margin:0 auto var(--s8);padding:0 var(--s6)}.legal-page__kicker{display:inline-block;font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s4)}.legal-page__title{font-size:clamp(1.75rem,3.5vw,2.5rem);margin-bottom:var(--s3)}.legal-page__subtitle{margin:0 auto;font-size:.9375rem;color:var(--ink-muted);max-width:540px}.legal-page__content{margin:0 auto;padding:0 var(--s6)}.legal-page__content h2{font-size:1.5rem;margin:var(--s10)0 var(--s4);border-top:1px solid var(--border-soft);padding-top:var(--s6)}.legal-page__content h2:first-child{border-top:none;padding-top:0;margin-top:0}.legal-page__content h3{font-size:1.125rem;margin:var(--s6)0 var(--s3)}.legal-page__content p,.legal-page__content li{margin-bottom:var(--s4);font-size:.9375rem;line-height:1.7;color:var(--ink-soft)}.legal-page__content ol,.legal-page__content ul{margin-bottom:var(--s4);padding-left:var(--s6)}.legal-page__content li{margin-bottom:var(--s2);list-style:disc}.legal-page__content ol li{list-style:decimal}.legal-page__content strong{color:var(--ink);font-weight:600}.legal-page__content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;cursor:pointer;transition:color var(--dur) var(--ease)}.legal-page__content a:hover{color:var(--accent-hover)}

/* ═══ Selection cards ═══ */
.selection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:2.5rem;max-width:960px}.selection-card{position:relative;display:flex;align-items:flex-start;gap:1.25rem;padding:1.75rem 1.5rem;background:var(--white);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:var(--ink);transition:all .25s ease;overflow:hidden}.selection-card::before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;border-radius:12px 0 0 12px;background:var(--accent);transition:width .3s ease}.selection-card:hover{border-color:transparent;box-shadow:0 8px 32px rgba(30,17,8,.1),0 2px 8px rgba(30,17,8,.06);transform:translateY(-2px)}.selection-card:hover::before{width:6px}.selection-card__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;flex-shrink:0;background:var(--accent-glow);color:var(--accent);transition:transform .3s ease}.selection-card:hover .selection-card__icon{transform:scale(1.05)}.selection-card__content{flex:1;min-width:0}.selection-card__title{font-family:var(--font-serif);font-size:1.2rem;font-weight:600;margin:0 0 .4rem;color:var(--primary)}.selection-card__desc{font-size:.875rem;line-height:1.5;color:var(--ink-muted);margin:0 0 .75rem}.selection-card__cta{font-family:var(--font-sans);font-size:.8125rem;font-weight:600;letter-spacing:.01em;color:var(--accent);transition:color .2s}.selection-card__badge{position:absolute;top:1rem;right:1rem;font-family:var(--font-sans);font-size:.6875rem;font-weight:600;letter-spacing:.03em;padding:.25rem .6rem;border-radius:20px;background:var(--cream-deep);color:var(--primary-soft)}.selection-grid .selection-card:first-child{grid-column:1/-1}

/* ═══ SEO intro ═══ */
.seo-intro{max-width:800px;margin:0 auto;padding:var(--s12) var(--s6) var(--s10);border-top:1px solid var(--border-soft)}.seo-intro h2{font-family:var(--font-serif);font-size:1.375rem;margin-bottom:var(--s4);color:var(--ink)}.seo-intro p{font-size:.9375rem;line-height:1.7;color:var(--ink-muted);margin-bottom:var(--s4)}.seo-intro p:last-child{margin-bottom:0}.seo-intro a{color:#8B6A2B;text-decoration:underline;text-underline-offset:2px;transition:color var(--dur) var(--ease)}.seo-intro a:hover{color:#6B5020}

/* ═══ Key points ═══ */
.key-points,.key-points li,.key-points ul{text-align:left!important}.key-points ul{padding-left:18px!important}.key-points li{line-height:1.6!important;margin-bottom:6px!important}

/* ═══ Animations ═══ */
@media (prefers-reduced-motion:no-preference){.fade-in{opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease),transform .5s var(--ease)}.fade-in.visible{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ═══ Responsive ═══ */
@media (max-width:1024px){.hero{min-height:440px}.brands-grid{grid-template-columns:1fr}.grid--3{grid-template-columns:repeat(2,1fr)}.footer__grid{grid-template-columns:1fr 1fr;gap:var(--s6)}.newsletter__inner{flex-direction:column;text-align:center}.newsletter__form{width:100%;justify-content:center}}
@media (max-width:1024px) and (min-width:769px){.related-articles__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){.nav__toggle{display:flex}.nav__links{position:fixed;top:var(--nav-h);left:0;right:0;height:calc(100vh - var(--nav-h));flex-direction:column;background:var(--cream);padding:var(--s8);gap:var(--s6);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease,visibility .3s ease;z-index:999;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 4px 16px rgba(30,17,8,.1)}.nav__links.open{opacity:1;visibility:visible;pointer-events:auto}.nav__links>li>a{font-size:1rem}.nav__sub{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:0;padding-left:var(--s4);margin-top:var(--s2);background:0 0}.section{padding:var(--s12)0}.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}.intro__inner{flex-direction:column;gap:var(--s6)}.intro__divider{width:40px;height:1px}.footer__grid{grid-template-columns:1fr;gap:var(--s8)}.newsletter__form{flex-direction:column}.newsletter__form input{width:100%}.author-box{flex-direction:column;align-items:center;text-align:center}.author-box__meta{justify-content:center}.product-card__top{flex-direction:column;align-items:stretch}.product-card__score{align-self:center}.product-card__proscons{grid-template-columns:1fr}.product-card__actions{flex-direction:column}.product-card__actions .btn{width:100%;justify-content:center}.related-articles__grid{grid-template-columns:1fr}.selection-grid{grid-template-columns:1fr}.selection-grid .selection-card:first-child{grid-column:auto}.selection-card{padding:1.25rem}.comparison-table{margin-left:calc(-1*var(--s6));margin-right:calc(-1*var(--s6));width:calc(100% + var(--s6)*2);padding:0 var(--s6)}.comparison-table td,.comparison-table th{padding:var(--s2) var(--s3);font-size:.6875rem}.comparison-table td{font-size:.8125rem}.key-points{padding:14px 16px!important;margin:16px 0 24px!important}.key-points p{font-size:1em!important}.key-points ul{padding-left:16px!important}.key-points li{font-size:.95em!important;line-height:1.55!important}}
@media (max-width:480px){.hero__title{font-size:1.875rem}.hero{min-height:380px}.hero__content{padding:var(--s16) var(--s6) var(--s12)}}

/* ═══ Search overlay ═══ */
.search-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--ink-muted);padding:6px;border-radius:var(--radius);transition:background .15s,color .15s;-webkit-tap-highlight-color:transparent}.search-toggle:hover,.search-toggle:focus-visible{background:var(--accent-glow);color:var(--accent);outline:none}.search-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:min(20vh,140px);opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s}.search-overlay[aria-hidden="false"]{opacity:1;visibility:visible}.search-backdrop{position:absolute;inset:0;background:rgba(30,17,8,.45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.search-container{position:relative;width:90%;max-width:620px;background:var(--white);border-radius:calc(var(--radius)*2);box-shadow:0 20px 60px rgba(30,17,8,.25),0 0 0 1px var(--border);overflow:hidden;transform:translateY(-8px) scale(.98);transition:transform .2s ease}.search-overlay[aria-hidden="false"] .search-container{transform:translateY(0) scale(1)}.search-input-wrap{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}.search-input-icon{flex-shrink:0;color:var(--ink-muted)}.search-input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font-sans);font-size:16px;color:var(--ink);line-height:1.4}.search-input::placeholder{color:var(--ink-muted);opacity:.7}.search-input::-webkit-search-cancel-button{display:none}.search-kbd{flex-shrink:0;padding:2px 6px;font-size:11px;font-family:var(--font-sans);color:var(--ink-muted);background:var(--cream);border:1px solid var(--border);border-radius:4px;line-height:1.3}.search-results{max-height:420px;overflow-y:auto;overscroll-behavior:contain}.search-results:empty{display:none}.search-result{display:flex;gap:12px;padding:12px 20px;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--border-soft);transition:background .1s;cursor:pointer;align-items:flex-start}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result[aria-selected="true"]{background:var(--cream)}.search-result[aria-selected="true"]{outline:2px solid var(--accent);outline-offset:-2px;border-radius:2px}.search-badge{flex-shrink:0;display:inline-block;padding:2px 8px;font-size:11px;font-weight:600;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;white-space:nowrap;margin-top:2px}.search-badge--test{background:#FEF3C7;color:#92400E}.search-badge--guide{background:#D1FAE5;color:#065F46}.search-badge--comparatif{background:#DBEAFE;color:#1E40AF}.search-badge--blog{background:#EDE9FE;color:#5B21B6}.search-badge--marque{background:#FDE8D8;color:#7C3A10}.search-badge--selection{background:#CCFBF1;color:#115E59}.search-badge--outil{background:#FFEDD5;color:#9A3412}.search-badge--page{background:var(--cream);color:var(--ink-muted)}.search-result-text{flex:1;min-width:0}.search-result-title{font-family:var(--font-serif);font-size:15px;font-weight:600;line-height:1.3;margin:0 0 3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-desc{font-family:var(--font-sans);font-size:13px;color:var(--ink-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-empty{padding:40px 20px;text-align:center;font-size:14px;color:var(--ink-muted)}.search-hint{padding:16px 20px;text-align:center;font-size:13px;color:var(--ink-faint);border-top:1px solid var(--border-soft)}

/* ═══ Brand pills ═══ */
.brand-pill{display:inline-block;padding:8px 20px;border:1px solid var(--border);border-radius:999px;font-size:.85rem;font-weight:500;color:var(--ink-soft);background:var(--white);transition:all var(--dur) var(--ease)}.brand-pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
/* ═══ Card hover ═══ */
.card--hover:hover{border-color:var(--accent);box-shadow:0 6px 24px rgba(46,125,50,.08);transform:translateY(-2px)}
