/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   MatrassenGids — Editorial Design System v2
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Palette */
  --paper:#F7F3EB;
  --paper-deep:#EFE9DC;
  --ink:#161412;
  --ink-soft:#3D3934;
  --ink-mute:#7A736A;
  --ink-faint:#B8B0A2;
  --line:#D9D1BF;
  --line-soft:#E8E1D0;
  --card:#FFFFFF;
  --accent:#1F3A8A;
  --accent-soft:#E8EBF6;
  --accent-light:#A4B7E8;
  --winner:#0E5F3A;
  --winner-soft:#E1EFE7;
  --warn:#A8451A;

  /* Type */
  --display:'Fraunces',Georgia,serif;
  --body:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);background:var(--paper);color:var(--ink);
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img,svg{display:block;max-width:100%;height:auto}

/* Paper grain */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.06 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.5;mix-blend-mode:multiply;z-index:1;
}
.layout{position:relative;z-index:2}

/* ━━━━ NAV ━━━━ */
.nav{position:sticky;top:0;z-index:100;background:rgba(247,243,235,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.nav-wrap{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:20px}
.logo{font-family:var(--display);font-weight:900;font-size:22px;letter-spacing:-.6px;font-variation-settings:'opsz' 144}
.logo span{color:var(--accent);font-style:italic;font-weight:700}
.nav-links{display:none;gap:32px;font-size:13.5px;font-weight:500;color:var(--ink-soft)}
.nav-links a:hover{color:var(--accent)}
.nav-links a.active{color:var(--accent)}
.nav-cta{font-size:12px;font-weight:600;padding:8px 16px;border:1px solid var(--ink);border-radius:2px;letter-spacing:.3px;transition:all .2s}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.ham{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:2px;background:var(--card)}
.ham svg{width:18px;height:18px;stroke:var(--ink);stroke-width:2}
@media(min-width:900px){.nav-links{display:flex}.ham{display:none}}
.mob-menu{display:none;background:var(--card);border-bottom:1px solid var(--line-soft);padding:8px 24px 18px}
.mob-menu.open{display:block}
.mob-menu a{display:block;padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:15px;font-weight:500;min-height:48px;display:flex;align-items:center}
.mob-menu a:last-child{border-bottom:none}

/* ━━━━ COMMON SECTIONS ━━━━ */
.kicker{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.kicker::before{content:'';width:24px;height:1.5px;background:var(--accent)}

.section-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink-mute)}
.section-eyebrow::before{content:'';width:32px;height:1.5px;background:var(--ink-mute)}
.section-eyebrow::after{content:'';flex:1;height:1px;background:var(--line);margin-left:8px}

.section-heading{font-family:var(--display);font-size:clamp(28px,5vw,44px);font-weight:700;line-height:1.1;letter-spacing:-.8px;margin-bottom:14px;font-variation-settings:'opsz' 144}
.section-heading em{font-style:italic;color:var(--accent);font-weight:400}
.section-sub{font-size:16px;color:var(--ink-soft);max-width:560px;margin-bottom:32px;line-height:1.55}

/* ━━━━ HERO ━━━━ */
.hero{max-width:1200px;margin:0 auto;padding:48px 24px 32px;position:relative}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(38px,9vw,76px);line-height:1.02;letter-spacing:-2px;margin-bottom:24px;font-variation-settings:'opsz' 144}
.hero h1 em{font-style:italic;font-weight:400;color:var(--accent);font-variation-settings:'opsz' 144}
.hero-lead{font-size:clamp(16px,2.4vw,19px);line-height:1.55;color:var(--ink-soft);max-width:580px;margin-bottom:32px}
.hero-meta{display:flex;flex-wrap:wrap;gap:20px;font-size:12px;font-weight:500;color:var(--ink-mute);letter-spacing:.3px;padding-top:22px;border-top:1px solid var(--line);max-width:580px}
.hero-meta span{display:flex;align-items:center;gap:6px}
.hero-meta svg{width:14px;height:14px;stroke:var(--winner);stroke-width:2;fill:none}

/* ━━━━ ARTICLE HEADER ━━━━ */
.crumb{max-width:780px;margin:0 auto;padding:24px 24px 0;font-size:12px;color:var(--ink-mute);letter-spacing:.3px}
.crumb a{border-bottom:1px solid var(--line)}
.crumb a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.crumb span.sep{color:var(--ink-faint);margin:0 4px}

.art-head{max-width:780px;margin:0 auto;padding:24px 24px 36px}
.art-head h1{font-family:var(--display);font-weight:700;font-size:clamp(34px,8vw,64px);line-height:1.05;letter-spacing:-1.5px;margin-bottom:18px;font-variation-settings:'opsz' 144}
.art-head h1 em{font-style:italic;color:var(--accent);font-weight:400}
.art-lede{font-size:clamp(16px,2.4vw,19px);line-height:1.55;color:var(--ink-soft);max-width:640px}
.art-byline{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ink-mute);letter-spacing:.3px}
.byline-author{display:flex;align-items:center;gap:10px}
.byline-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:13px}
.byline-author b{color:var(--ink);font-weight:600}

/* ━━━━ TLDR ━━━━ */
.tldr{max-width:780px;margin:0 auto 48px;padding:0 24px}
.tldr-card{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--accent);padding:24px 26px}
.tldr-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.tldr-card p{font-family:var(--display);font-size:18px;line-height:1.55;font-style:italic;color:var(--ink)}
.tldr-card p b{font-style:normal;color:var(--ink);font-weight:700}
.tldr-card p a{color:var(--accent);font-style:normal;font-weight:600;border-bottom:1.5px solid currentColor}

/* ━━━━ QUICK NAV ━━━━ */
.qnav{max-width:780px;margin:-24px auto 48px;padding:0 24px}
.qnav-wrap{background:var(--paper-deep);border:1px solid var(--line-soft);padding:16px 20px}
.qnav-label{font-size:10.5px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-mute);margin-bottom:10px}
.qnav-list{display:flex;flex-wrap:wrap;gap:6px}
.qnav-list a{font-size:12.5px;color:var(--ink);padding:5px 11px;background:var(--card);border:1px solid var(--line);border-radius:2px;font-weight:500;transition:all .2s}
.qnav-list a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ━━━━ THE PICK (hero card) ━━━━ */
.pick-section{max-width:1200px;margin:24px auto 0;padding:0 24px}
.pick-card{background:var(--card);border:1px solid var(--line);border-top:3px solid var(--winner);position:relative;display:grid;grid-template-columns:1fr;overflow:hidden}
.pick-ribbon{position:absolute;top:0;left:24px;background:var(--winner);color:var(--paper);padding:6px 14px;font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;z-index:2}
.pick-img{background:var(--paper-deep);display:flex;align-items:center;justify-content:center;aspect-ratio:1.4;position:relative}
.pick-img svg{width:55%;height:55%;opacity:.85}
.pick-body{padding:42px 28px 32px;display:flex;flex-direction:column;gap:18px}
.pick-cat{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--ink-mute)}
.pick-name{font-family:var(--display);font-size:clamp(28px,5vw,42px);font-weight:700;line-height:1.05;letter-spacing:-1px;font-variation-settings:'opsz' 144}
.pick-rating{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.stars{display:flex;gap:1px;color:var(--accent)}
.stars svg{width:16px;height:16px;fill:currentColor}
.stars svg.empty{fill:var(--ink-faint)}
.score{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.3px}
.score-of{font-size:13px;color:var(--ink-mute);font-weight:400;font-style:italic;font-family:var(--body)}
.review-count{font-size:12px;color:var(--ink-mute)}
.pick-blurb{font-family:var(--display);font-style:italic;font-size:18px;line-height:1.5;color:var(--ink-soft);border-left:2px solid var(--accent);padding:6px 0 6px 16px}
.pick-blurb b{color:var(--ink);font-weight:700;font-style:normal;font-family:var(--body);font-size:14px;letter-spacing:.3px;text-transform:uppercase;display:block;margin-bottom:6px}
.pick-cta-row{display:flex;flex-direction:column;gap:10px;padding-top:20px;border-top:1px solid var(--line-soft);margin-top:6px}
.price-line{display:flex;align-items:baseline;gap:8px}
.price-label{font-size:12px;color:var(--ink-mute);letter-spacing:.3px}
.price-val{font-family:var(--display);font-weight:700;font-size:32px;letter-spacing:-1px}
.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--ink);color:var(--paper);padding:16px 22px;font-size:15px;font-weight:600;letter-spacing:.2px;border-radius:2px;min-height:50px;transition:all .2s}
.btn-primary:hover{background:var(--accent)}
.btn-primary svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .2s}
.btn-primary:hover svg{transform:translateX(3px)}
.btn-secondary{display:flex;align-items:center;justify-content:center;background:transparent;color:var(--ink);padding:13px 22px;font-size:13px;font-weight:600;border:1px solid var(--line);border-radius:2px;min-height:46px;transition:all .2s}
.btn-secondary:hover{border-color:var(--ink);background:var(--paper-deep)}
@media(min-width:780px){.pick-card{grid-template-columns:1.1fr 1fr}.pick-img{aspect-ratio:auto;height:100%;min-height:480px}.pick-cta-row{flex-direction:row;align-items:center}.price-line{flex:1}.btn-primary{padding:14px 26px;flex:0 0 auto}}

/* ━━━━ ALT CARDS ━━━━ */
.alt-section{max-width:1200px;margin:64px auto 0;padding:0 24px}
.alt-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:720px){.alt-grid{grid-template-columns:1fr 1fr}}
.alt-card{background:var(--card);border:1px solid var(--line);display:flex;flex-direction:column;position:relative;transition:all .2s}
.alt-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.alt-tag{position:absolute;top:0;left:18px;background:var(--ink);color:var(--paper);padding:5px 12px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}
.alt-tag.budget{background:var(--accent)}
.alt-tag.premium{background:var(--ink-soft)}
.alt-img{background:var(--paper-deep);aspect-ratio:1.5;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line-soft)}
.alt-img svg{width:42%;height:42%;opacity:.7}
.alt-body{padding:24px 22px 22px;display:flex;flex-direction:column;gap:12px;flex:1}
.alt-cat{font-size:10.5px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--ink-mute)}
.alt-name{font-family:var(--display);font-weight:700;font-size:24px;line-height:1.1;letter-spacing:-.5px;font-variation-settings:'opsz' 144}
.alt-rating{display:flex;align-items:center;gap:10px;font-size:13px;flex-wrap:wrap}
.alt-blurb{font-size:14px;line-height:1.55;color:var(--ink-soft);flex:1}
.alt-foot{display:flex;align-items:baseline;justify-content:space-between;padding-top:16px;border-top:1px solid var(--line-soft);gap:12px}
.alt-price{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.5px}
.alt-link{font-size:12px;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:4px;letter-spacing:.3px}
.alt-link svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}

/* ━━━━ AUTHORITY BLOCK ━━━━ */
.authority{max-width:1200px;margin:80px auto 0;padding:0 24px}
.auth-card{background:var(--ink);color:var(--paper);padding:40px 28px;position:relative;overflow:hidden}
.auth-card::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(31,58,138,.4),transparent 70%);pointer-events:none}
.auth-grid{display:grid;gap:32px;position:relative;z-index:1;grid-template-columns:1fr}
@media(min-width:720px){.auth-grid{grid-template-columns:auto 1fr;align-items:center;gap:48px}}
.auth-label{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(247,243,235,.6);margin-bottom:14px}
.auth-headline{font-family:var(--display);font-weight:700;font-size:clamp(24px,4vw,32px);line-height:1.15;letter-spacing:-.5px;margin-bottom:14px;font-variation-settings:'opsz' 144}
.auth-headline em{font-style:italic;color:var(--accent-light);font-weight:400}
.auth-text{font-size:14.5px;line-height:1.6;color:rgba(247,243,235,.8);max-width:480px}
.auth-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-left:1px solid rgba(255,255,255,.15)}
@media(max-width:720px){.auth-stats{margin-top:24px;border-left:none;border-top:1px solid rgba(255,255,255,.15);padding-top:24px}}
.auth-stat{padding:0 18px;text-align:center;border-right:1px solid rgba(255,255,255,.15)}
.auth-stat:last-child{border-right:none}
@media(max-width:720px){.auth-stat{padding:0 8px}}
.auth-num{font-family:var(--display);font-weight:700;font-size:36px;letter-spacing:-1px;font-variation-settings:'opsz' 144;color:var(--paper)}
.auth-cap{font-size:10.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(247,243,235,.6);margin-top:4px}

/* ━━━━ CATEGORIES ━━━━ */
.cats{max-width:1200px;margin:80px auto 0;padding:0 24px}
.cat-grid{display:grid;gap:14px;grid-template-columns:1fr}
@media(min-width:540px){.cat-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
.cat-card{background:var(--card);border:1px solid var(--line);padding:22px 22px 20px;display:flex;flex-direction:column;gap:10px;position:relative;transition:all .2s;min-height:200px}
.cat-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.cat-num{font-family:var(--display);font-style:italic;font-weight:400;font-size:42px;line-height:1;color:var(--accent);letter-spacing:-2px;opacity:.5;font-variation-settings:'opsz' 144}
.cat-name{font-family:var(--display);font-weight:700;font-size:20px;line-height:1.15;letter-spacing:-.4px;margin-top:auto;font-variation-settings:'opsz' 144}
.cat-meta{font-size:12px;color:var(--ink-mute);letter-spacing:.2px}
.cat-arrow{position:absolute;top:22px;right:22px;width:32px;height:32px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}
.cat-card:hover .cat-arrow{background:var(--accent);border-color:var(--accent)}
.cat-arrow svg{width:13px;height:13px;stroke:var(--ink);stroke-width:2;transition:stroke .2s}
.cat-card:hover .cat-arrow svg{stroke:#fff}

/* ━━━━ METHOD ━━━━ */
.method{max-width:1200px;margin:80px auto 0;padding:0 24px}
.method-wrap{display:grid;gap:32px;align-items:start;grid-template-columns:1fr}
@media(min-width:840px){.method-wrap{grid-template-columns:1fr 1.4fr;gap:64px}}
.method-text h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,5vw,42px);line-height:1.05;letter-spacing:-.8px;margin:14px 0 18px;font-variation-settings:'opsz' 144}
.method-text h2 em{font-style:italic;color:var(--accent);font-weight:400}
.method-text p{font-size:15.5px;line-height:1.65;color:var(--ink-soft);margin-bottom:14px}
.method-steps{display:flex;flex-direction:column;gap:1px;background:var(--line)}
.step{background:var(--card);padding:22px 22px;display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start}
.step-n{font-family:var(--display);font-weight:900;font-size:36px;line-height:1;color:var(--accent);letter-spacing:-1.5px;font-variation-settings:'opsz' 144;min-width:54px}
.step-h{font-family:var(--display);font-weight:700;font-size:18px;line-height:1.2;letter-spacing:-.3px;margin-bottom:6px;font-variation-settings:'opsz' 144}
.step-t{font-size:14px;line-height:1.55;color:var(--ink-soft)}

/* ━━━━ PRODUCT LIST (top 10) ━━━━ */
.products{max-width:780px;margin:0 auto;padding:0 24px}
.product{background:var(--card);border:1px solid var(--line);margin-bottom:20px;scroll-margin-top:80px}
.product.winner{border-color:var(--winner);border-width:1.5px;border-top:3px solid var(--winner)}
.product.budget{border-top:3px solid var(--accent)}
.product.premium{border-top:3px solid var(--ink-soft)}
.product-rank-bar{background:var(--paper-deep);padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid var(--line-soft)}
.product.winner .product-rank-bar{background:var(--winner-soft)}
.product.budget .product-rank-bar{background:var(--accent-soft)}
.product.premium .product-rank-bar{background:#EEEAE0}
.rank-left{display:flex;align-items:center;gap:14px}
.rank-num{font-family:var(--display);font-weight:900;font-size:32px;line-height:1;letter-spacing:-1.5px;color:var(--ink);font-variation-settings:'opsz' 144}
.product.winner .rank-num{color:var(--winner)}
.product.budget .rank-num{color:var(--accent)}
.rank-tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;background:var(--ink);color:var(--paper);white-space:nowrap}
.product.winner .rank-tag{background:var(--winner)}
.product.budget .rank-tag{background:var(--accent)}
.product.premium .rank-tag{background:var(--ink-soft)}
.rank-right{font-size:11px;font-weight:600;letter-spacing:.4px;color:var(--ink-mute);text-transform:uppercase}
.product-body{padding:24px 22px}
.product-grid{display:grid;grid-template-columns:90px 1fr;gap:18px;align-items:start;margin-bottom:18px}
@media(min-width:600px){.product-grid{grid-template-columns:140px 1fr;gap:24px}}
.product-img{background:var(--paper-deep);aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-soft)}
.product-img svg{width:75%;height:75%;opacity:.85}
.product-info h2{font-family:var(--display);font-weight:700;font-size:clamp(20px,4vw,26px);line-height:1.1;letter-spacing:-.5px;font-variation-settings:'opsz' 144;margin-bottom:6px}
.product-cat{font-size:12px;font-weight:600;letter-spacing:.3px;color:var(--ink-mute);text-transform:uppercase;margin-bottom:10px}
.product-rating{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.score-block{display:flex;align-items:baseline;gap:4px}
.product-blurb{font-size:15px;line-height:1.65;color:var(--ink-soft);margin-bottom:16px}
.product-pros{display:grid;gap:8px;margin-bottom:18px}
.pro-item,.con-item{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;line-height:1.5}
.pro-icon,.con-icon{flex-shrink:0;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;margin-top:2px}
.pro-icon{background:var(--winner)}
.con-icon{background:var(--warn)}
.product-cta{display:flex;flex-direction:column;gap:10px;padding-top:18px;border-top:1px solid var(--line-soft)}
.cta-price{display:flex;align-items:baseline;justify-content:space-between;gap:14px}
.price-from{font-size:11.5px;color:var(--ink-mute);letter-spacing:.3px;text-transform:uppercase;font-weight:600}
.price-amount{font-family:var(--display);font-weight:700;font-size:30px;letter-spacing:-.8px;line-height:1}
.price-side{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.price-was{font-size:12px;color:var(--ink-faint);text-decoration:line-through;font-weight:500}
.btn-bol{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--ink);color:var(--paper);padding:15px 22px;font-size:14.5px;font-weight:600;letter-spacing:.2px;border-radius:2px;min-height:48px;transition:all .2s}
.btn-bol:hover{background:var(--accent)}
.btn-bol svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .2s}
.btn-bol:hover svg{transform:translateX(3px)}
.product.winner .btn-bol{background:var(--winner)}
.product.winner .btn-bol:hover{background:#0a4a2c}
@media(min-width:600px){.product-cta{flex-direction:row;align-items:center}.cta-price{flex:1}.btn-bol{flex:0 0 auto}}

.divider{max-width:780px;margin:48px auto 32px;padding:0 24px;display:flex;align-items:center;gap:14px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--line)}
.divider span{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink-mute)}

/* ━━━━ METHOD MINI ━━━━ */
.method-mini{max-width:780px;margin:64px auto 0;padding:0 24px}
.method-mini-card{background:var(--ink);color:var(--paper);padding:36px 28px}
.method-mini h3{font-family:var(--display);font-weight:700;font-size:24px;line-height:1.15;letter-spacing:-.5px;margin-bottom:12px;font-variation-settings:'opsz' 144}
.method-mini h3 em{font-style:italic;color:var(--accent-light);font-weight:400}
.method-mini p{font-size:14.5px;line-height:1.6;color:rgba(247,243,235,.8);margin-bottom:14px}
.method-mini a.method-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--accent-light);border-bottom:1.5px solid currentColor;padding-bottom:1px}

/* ━━━━ FAQ ━━━━ */
.faq{max-width:780px;margin:80px auto 0;padding:0 24px}
.faq-list{margin-top:14px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 0;text-align:left;font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:-.3px;line-height:1.3;font-variation-settings:'opsz' 144;color:var(--ink)}
.faq-q-icon{flex-shrink:0;width:24px;height:24px;border:1px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .25s ease;font-family:var(--body);font-weight:300;font-size:18px;line-height:1;padding-bottom:1px}
.faq-item.open .faq-q-icon{transform:rotate(45deg);background:var(--accent);color:var(--paper);border-color:var(--accent)}
.faq-a{display:none;padding:0 0 22px;font-size:15px;line-height:1.65;color:var(--ink-soft);max-width:680px}
.faq-item.open .faq-a{display:block}

/* ━━━━ PROSE (article body) ━━━━ */
.prose{max-width:680px;margin:48px auto 0;padding:0 24px;font-size:17px;line-height:1.75;color:var(--ink-soft)}
.prose h2{font-family:var(--display);font-weight:700;font-size:28px;line-height:1.15;letter-spacing:-.5px;margin-top:48px;margin-bottom:16px;color:var(--ink);font-variation-settings:'opsz' 144}
.prose h3{font-family:var(--display);font-weight:700;font-size:21px;line-height:1.2;letter-spacing:-.3px;margin-top:32px;margin-bottom:10px;color:var(--ink);font-variation-settings:'opsz' 144}
.prose p{margin-bottom:18px}
.prose strong{color:var(--ink);font-weight:700}
.prose em{font-style:italic}
.prose ul,.prose ol{margin:18px 0 18px 22px}
.prose li{margin-bottom:8px}
.prose blockquote{font-family:var(--display);font-style:italic;font-size:21px;line-height:1.45;color:var(--ink);border-left:3px solid var(--accent);padding:8px 0 8px 24px;margin:32px 0}
.prose a{color:var(--accent);font-weight:600;border-bottom:1px solid currentColor}
.prose .pull-quote{font-family:var(--display);font-size:24px;line-height:1.3;color:var(--ink);font-style:italic;text-align:center;padding:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:40px 0;letter-spacing:-.3px}

/* ━━━━ FOOTER ━━━━ */
.foot{margin-top:96px;background:var(--ink);color:var(--paper);padding:48px 24px 28px}
.foot-wrap{max-width:1200px;margin:0 auto}
.foot-top{display:grid;gap:32px;grid-template-columns:1fr;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:24px}
@media(min-width:720px){.foot-top{grid-template-columns:1.5fr 1fr 1fr 1fr}}
.foot-brand .logo{color:var(--paper);margin-bottom:14px}
.foot-tag{font-size:14px;line-height:1.55;color:rgba(247,243,235,.7);max-width:280px}
.foot-col h4{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(247,243,235,.5);margin-bottom:14px}
.foot-col a{display:block;padding:5px 0;font-size:14px;color:rgba(247,243,235,.85)}
.foot-col a:hover{color:var(--accent-light)}
.foot-bot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;font-size:12px;color:rgba(247,243,235,.55)}

/* ━━━━ COOKIE BANNER ━━━━ */
.cookie{position:fixed;bottom:14px;left:14px;right:14px;background:var(--ink);color:var(--paper);padding:18px 20px;border-radius:4px;display:none;z-index:200;box-shadow:0 12px 40px rgba(0,0,0,.18);align-items:center;flex-wrap:wrap;gap:14px;max-width:680px;margin:0 auto}
.cookie.show{display:flex;animation:slideUp .35s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-text{flex:1;font-size:13.5px;line-height:1.5;min-width:240px}
.cookie-text a{text-decoration:underline;text-underline-offset:3px}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
.cookie-btn{padding:10px 18px;font-size:12.5px;font-weight:600;border-radius:2px;letter-spacing:.2px;min-height:42px;transition:all .2s}
.cookie-btn.refuse{background:transparent;color:var(--paper);border:1px solid rgba(255,255,255,.25)}
.cookie-btn.refuse:hover{border-color:var(--paper)}
.cookie-btn.accept{background:var(--paper);color:var(--ink);border:1px solid var(--paper)}
.cookie-btn.accept:hover{background:var(--accent-light);border-color:var(--accent-light)}
@media(max-width:540px){.cookie{flex-direction:column;align-items:stretch}.cookie-btns{display:flex;width:100%}.cookie-btn{flex:1}}

/* ━━━━ FADE IN ━━━━ */
.fade{opacity:0;transform:translateY(8px);animation:fadeIn .8s ease forwards}
.fade-1{animation-delay:.05s}.fade-2{animation-delay:.15s}.fade-3{animation-delay:.25s}.fade-4{animation-delay:.35s}
@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}

/* ━━━ AFFILIATE BADGES ━━━ */
.aff-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-bottom: 6px;
}
.aff-badge.bol {
  background: #0000A4;
  color: white;
}
.aff-badge.merk {
  background: var(--accent);
  color: white;
}
.product-cta .aff-badge {
  margin-right: 8px;
  align-self: center;
}
