/* ============ MINIHAUSHALT.DE — DESIGN SYSTEM ============ */
/* Editorial print magazine · warm bone paper, cobalt ink, tomato CTA, ochre accent */
:root{
  /* Surfaces — warm bone paper */
  --bg:        #ece4d2;
  --bg-2:      #e0d6be;
  --paper:     #faf4e6;
  --paper-2:   #fffbf0;

  /* Ink — warm near-black */
  --ink:       #181410;
  --ink-2:     #332e26;
  --muted:     #6e6757;
  --line:      #d6cab0;
  --line-2:    #b9aa88;

  /* Brand — kept variable names, distinct values
     --petrol     = deep cobalt (signature)
     --amber      = warm ochre
     --vermillion = tomato red (CTA)                                  */
  --petrol:        #1f3aa3;
  --petrol-deep:   #14257a;
  --petrol-soft:   #dbe0f1;
  --amber:         #c98a2d;
  --amber-soft:    #eed4a3;
  --vermillion:    #d9421e;
  --vermillion-deep:#a92e10;
  --gold:          #a86b1f;
  --plum:          #5a2a64;       /* secondary editorial accent */
  --plum-soft:     #e3d4e6;

  /* Shadows + radii */
  --shadow-sm: 0 1px 2px rgba(12,24,34,.04), 0 2px 6px rgba(12,24,34,.04);
  --shadow:    0 2px 6px rgba(12,24,34,.05), 0 12px 32px -12px rgba(12,24,34,.20);
  --shadow-lg: 0 30px 60px -30px rgba(12,24,34,.40), 0 8px 18px -10px rgba(12,24,34,.14);
  --r-sm:10px; --r:14px; --r-lg:22px; --r-xl:28px;
  --container: 1240px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter Tight', system-ui, sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -200px, rgba(31,58,163,.07), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(201,138,45,.07), transparent 60%),
    var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  line-height:1.5;
  position:relative;
}
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.09  0 0 0 0 0.07  0 0 0 0 0.06  0 0 0 0.10 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
body > *{position:relative; z-index:2}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.serif{font-family:'Instrument Serif', serif; font-weight:400; letter-spacing:-.01em}
.mono{font-family:'JetBrains Mono', monospace; font-size:.72rem; letter-spacing:.04em; text-transform:uppercase}

/* ============ MARQUEE ============ */
.marquee-bar{
  background:var(--ink); color:#cfd6dc;
  font-size:.78rem; letter-spacing:.04em;
  border-bottom:1px solid #061018;
  overflow:hidden;
}
.marquee-track{display:flex; gap:48px; padding:8px 0; white-space:nowrap; animation:marquee 38s linear infinite}
.marquee-track span{display:inline-flex; align-items:center; gap:10px}
.marquee-track i{width:6px;height:6px;border-radius:50%;background:var(--amber);display:inline-block}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ HEADER ============ */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(233,235,229,.85);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex; align-items:center; gap:28px; padding:14px 0}
.logo{display:flex; align-items:center; gap:12px; min-width:0}
.logo-svg{width:40px; height:40px; flex:none; display:block}
.logo-text{display:flex; flex-direction:column; line-height:1}
.logo-name{font-weight:700; font-size:1.05rem; letter-spacing:-.01em}
.logo-name b{color:var(--petrol)}
.logo-claim{font-size:.7rem; color:var(--muted); margin-top:3px; letter-spacing:.02em}
.nav{display:flex; gap:2px; flex:1; margin-left:8px; align-items:center}
.nav > a, .nav-item > .nav-trigger{
  padding:8px 12px; border-radius:8px; font-size:.92rem; font-weight:500;
  color:var(--ink-2); transition:.15s; display:inline-flex; align-items:center; gap:6px; cursor:pointer;
}
.nav > a:hover, .nav-item:hover > .nav-trigger, .nav-item.open > .nav-trigger{background:var(--bg-2); color:var(--ink)}
.nav > a.active, .nav-item.active > .nav-trigger{background:var(--ink); color:var(--bg)}
.nav-item{position:relative}
.nav-trigger::after{content:"▾"; font-size:.6rem; color:var(--muted); transition:transform .2s}
.nav-item:hover > .nav-trigger::after, .nav-item.open > .nav-trigger::after{transform:rotate(180deg); color:inherit}
.nav-dd{
  position:absolute; top:calc(100% + 8px); left:-8px; min-width:280px;
  background:var(--paper); border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow-lg); padding:8px; opacity:0; pointer-events:none;
  transform:translateY(-4px); transition:.18s opacity, .18s transform; z-index:60;
}
.nav-item:hover > .nav-dd, .nav-item.open > .nav-dd{opacity:1; pointer-events:auto; transform:translateY(0)}
.nav-dd::before{content:""; position:absolute; top:-8px; left:0; right:0; height:8px}
.nav-dd-head{padding:10px 12px 8px; font-family:'JetBrains Mono',monospace; font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--line); margin-bottom:6px}
.nav-dd a{display:flex; flex-direction:column; gap:2px; padding:9px 12px; border-radius:8px; color:var(--ink); font-weight:500; font-size:.92rem}
.nav-dd a:hover{background:var(--bg-2)}
.nav-dd a small{font-size:.74rem; color:var(--muted); font-weight:400}
.nav-dd-foot{margin-top:6px; padding:10px 12px 4px; border-top:1px solid var(--line)}
.nav-dd-foot a{display:inline-flex; align-items:center; gap:6px; color:var(--petrol); font-size:.85rem; font-weight:600; padding:0}
.nav-dd-foot a:hover{background:transparent; color:var(--petrol-deep)}
.header-cta{display:flex; gap:8px; align-items:center}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 18px; border-radius:999px; font-weight:600; font-size:.9rem;
  transition:.18s transform, .18s box-shadow, .18s background, .18s color;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--vermillion); color:#fff; box-shadow:0 6px 16px -6px rgba(210,74,34,.65)}
.btn-primary:hover{background:var(--vermillion-deep); box-shadow:0 10px 20px -6px rgba(210,74,34,.6)}
.btn-dark{background:var(--ink); color:#fff}
.btn-dark:hover{background:#020a14}
.btn-ghost{background:transparent; color:var(--ink); border:1px solid var(--line-2)}
.btn-ghost:hover{background:var(--bg-2)}
.btn-petrol{background:var(--petrol); color:#fff}
.btn-petrol:hover{background:var(--petrol-deep)}
.btn-amber{background:var(--amber); color:#3b2a09}
.btn-amber:hover{background:#b87c1f; color:#fff}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}
.burger{display:none; width:42px; height:42px; border-radius:10px; border:1px solid var(--line-2); align-items:center; justify-content:center}
.burger span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.burger span::before{top:-6px}.burger span::after{top:6px}
@media (max-width:1080px){
  .nav{
    display:none; position:fixed; top:0; right:0; bottom:0; width:min(360px, 86vw);
    background:var(--paper); border-left:1px solid var(--line); box-shadow:var(--shadow-lg);
    flex-direction:column; align-items:stretch; gap:2px; padding:80px 16px 24px; margin:0;
    overflow-y:auto; z-index:55;
  }
  .nav.open{display:flex}
  body.nav-open{overflow:hidden}
  body.nav-open::after{
    content:""; position:fixed; inset:0; background:rgba(13,27,42,.4); z-index:50;
  }
  .burger{display:flex; z-index:60; position:relative}
  .nav > a, .nav-item > .nav-trigger{padding:14px 14px; font-size:1rem; border-radius:10px; width:100%; justify-content:space-between}
  .nav-item{width:100%}
  .nav-dd{
    position:static; opacity:1; pointer-events:auto; transform:none; box-shadow:none;
    border:none; border-radius:0; padding:4px 0 8px 12px; background:transparent;
    display:none; min-width:0;
  }
  .nav-item.open > .nav-dd{display:block}
  .nav-item:hover > .nav-dd{display:none}
  .nav-item.open > .nav-dd{display:block}
  .nav-dd-head{display:none}
  .nav-dd a{padding:10px 12px; font-size:.9rem}
  .nav-dd-foot{padding:8px 12px 0}
}

/* ============ HERO ============ */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(20,82,94,.20), transparent 60%),
    radial-gradient(700px 600px at 0% 20%, rgba(210,148,47,.22), transparent 60%),
    var(--bg);
}
.hero-grid{
  display:grid; grid-template-columns: 1.05fr .95fr; gap:48px;
  padding:56px 0 72px;
  align-items:start;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 12px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:.78rem; font-weight:500;
  box-shadow:var(--shadow-sm);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--petrol);box-shadow:0 0 0 4px var(--petrol-soft)}
.h1{
  font-family:'Instrument Serif', serif; font-weight:400;
  font-size:clamp(2.6rem, 5.2vw, 4.6rem);
  line-height:1.02; letter-spacing:-.02em;
  margin:18px 0 18px;
  color:var(--ink);
}
.h1 em{font-style:italic; color:var(--petrol)}
.h1 .accent{
  background: linear-gradient(180deg, transparent 65%, rgba(201,138,45,.55) 65%);
  padding:0 6px;
  font-style:italic;
}
.lede{font-size:1.08rem; color:var(--ink-2); max-width:560px; margin-bottom:28px}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px}
.trust-row{
  display:grid; grid-template-columns: repeat(4,1fr); gap:14px;
  max-width:600px;
}
.trust{
  display:flex; flex-direction:column; gap:6px;
  padding:14px; border-radius:14px;
  background:rgba(255,255,255,.6);
  border:1px solid var(--line);
}
.trust .ti{width:22px;height:22px;border-radius:6px;background:var(--petrol-soft);display:grid;place-items:center;color:var(--petrol)}
.trust b{font-size:.85rem; font-weight:600}
.trust span{font-size:.72rem; color:var(--muted)}

/* ============ PRODUCT CARDS / SHOWCASE ============ */
.showcase{position:relative; display:grid; grid-template-columns: 1fr 1fr; gap:14px}
.pcard{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:14px; box-shadow:var(--shadow);
  display:flex; flex-direction:column;
  position:relative; transition:.25s;
}
.pcard:hover{transform:translateY(-3px); box-shadow:var(--shadow-lg)}
.pcard-img{
  aspect-ratio: 4/3; border-radius:14px;
  background:
    repeating-linear-gradient(135deg, rgba(12,24,34,.04) 0 6px, transparent 6px 14px),
    var(--bg-2);
  display:grid; place-items:center; color:var(--muted);
  font-family:'JetBrains Mono',monospace; font-size:.65rem; letter-spacing:.05em;
  text-align:center; padding:8px;
  position:relative; overflow:hidden;
}
.pcard-img.petrol{background:repeating-linear-gradient(135deg, rgba(20,82,94,.14) 0 6px, transparent 6px 14px), var(--petrol-soft)}
.pcard-img.amber{background:repeating-linear-gradient(135deg, rgba(210,148,47,.16) 0 6px, transparent 6px 14px), var(--amber-soft)}
.pcard-img.ink{background:repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 6px, transparent 6px 14px), #1a2632; color:#8b96a3}
.pcard-img.vermillion{background:repeating-linear-gradient(135deg, rgba(210,74,34,.10) 0 6px, transparent 6px 14px), #f4d8cc}
.badge{
  position:absolute; top:10px; left:10px; z-index:2;
  background:#fff; color:var(--ink); border:1px solid var(--line);
  padding:5px 10px; border-radius:999px;
  font-size:.7rem; font-weight:600; box-shadow:var(--shadow-sm);
}
.badge.vermillion{background:var(--vermillion); color:#fff; border-color:transparent}
.badge.petrol{background:var(--petrol); color:#fff; border-color:transparent}
.badge.amber{background:var(--amber); color:#3b2a09; border-color:transparent}
.badge.ink{background:var(--ink); color:#fff; border-color:transparent}
.pcard h4{margin:12px 0 2px; font-size:1rem; font-weight:600; letter-spacing:-.01em}
.pcard p{margin:0 0 12px; font-size:.82rem; color:var(--muted)}
.pcard-foot{display:flex; align-items:center; justify-content:space-between; margin-top:auto}
.pcard-foot .pl{font-size:.78rem; font-weight:600; color:var(--ink)}
.pcard-foot a{font-size:.78rem; font-weight:600; color:var(--petrol); display:inline-flex; gap:4px; align-items:center}
.pcard-foot a:hover{color:var(--ink)}
.pcard.featured{grid-column:span 2; flex-direction:row; gap:18px}
.pcard.featured .pcard-img{flex:0 0 46%; aspect-ratio: 5/4}
.pcard.featured .pcard-body{flex:1; display:flex; flex-direction:column; padding:4px 4px 4px 0}
.pcard.featured h4{font-size:1.25rem; margin-top:0}
.pcard.featured p{font-size:.9rem; color:var(--ink-2); margin-bottom:14px}
.stars{display:inline-flex; gap:2px; font-size:.78rem; color:var(--amber); margin-right:6px}
.stars + .rate{font-size:.74rem; color:var(--muted)}

.hero-strip{border-top:1px solid var(--line); padding:14px 0; background:rgba(233,235,229,.6)}
.hero-strip-inner{display:flex; gap:32px; flex-wrap:wrap; justify-content:space-between; align-items:center; font-size:.82rem}
.hero-strip-inner strong{font-weight:600}
.hero-strip-inner span{color:var(--muted)}

@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr; gap:36px; padding:32px 0 48px}
  .trust-row{grid-template-columns:repeat(2,1fr)}
  .pcard.featured{grid-column:span 2; flex-direction:column}
  .pcard.featured .pcard-img{flex:none; aspect-ratio: 16/10}
}

/* ============ SECTIONS / HEADS ============ */
section{padding:80px 0; position:relative}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:36px; flex-wrap:wrap}
.section-head .h2{
  font-family:'Instrument Serif',serif; font-weight:400;
  font-size:clamp(1.9rem,3.4vw,2.8rem); letter-spacing:-.02em;
  line-height:1.05; margin:8px 0 0; max-width:720px;
}
.section-head .h2 em{color:var(--petrol)}
.section-head p{margin:0; max-width:520px; color:var(--ink-2)}
.section-head .right{display:flex; gap:10px; align-items:center}
.section-head .kicker{font-family:'JetBrains Mono',monospace; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--petrol)}

/* ============ CATEGORIES ============ */
.cats{display:grid; grid-template-columns: repeat(5,1fr); gap:14px}
.cat{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:22px; min-height:260px;
  display:flex; flex-direction:column;
  transition:.2s; position:relative; overflow:hidden;
}
.cat:hover{transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--petrol)}
.cat::after{
  content:""; position:absolute; right:-30px; bottom:-30px;
  width:140px; height:140px; border-radius:50%;
  background:var(--petrol-soft); opacity:.6; transition:.3s;
}
.cat:hover::after{transform:scale(1.15)}
.cat .num{font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--muted); letter-spacing:.1em}
.cat .ic{width:46px;height:46px;border-radius:12px; background:var(--bg); border:1px solid var(--line); display:grid;place-items:center; margin:10px 0 18px; position:relative; z-index:1; color:var(--petrol)}
.cat h3{margin:0 0 6px; font-size:1.15rem; font-weight:700; letter-spacing:-.01em; z-index:1; position:relative}
.cat .cdesc{font-size:.84rem; color:var(--ink-2); margin:0 0 14px; z-index:1; position:relative}
.cat ul{list-style:none; padding:0; margin:0 0 16px; z-index:1; position:relative; font-size:.82rem}
.cat ul li{padding:5px 0; border-top:1px dashed var(--line); color:var(--ink-2); display:flex; justify-content:space-between}
.cat ul li:first-child{border-top:0}
.cat ul li::after{content:"→"; color:var(--muted); transition:.2s}
.cat ul li:hover::after{color:var(--petrol); transform:translateX(2px)}
.cat-cta{margin-top:auto; font-weight:600; font-size:.85rem; color:var(--ink); display:inline-flex; align-items:center; gap:6px; z-index:1; position:relative}
.cat-cta::after{content:"→"; transition:.2s}
.cat:hover .cat-cta::after{transform:translateX(4px); color:var(--vermillion)}

@media (max-width:1080px){ .cats{grid-template-columns:repeat(3,1fr)} .cats > :nth-child(4){grid-column:1/3} .cats > :nth-child(5){grid-column:3/4} }
@media (max-width:700px){ .cats{grid-template-columns:1fr 1fr} .cats > :nth-child(4),.cats > :nth-child(5){grid-column:auto} }
@media (max-width:480px){ .cats{grid-template-columns:1fr} }

/* ============ BESTSELLER GRID ============ */
.bestsellers{background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%)}
.bgrid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.product{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; display:flex; flex-direction:column; transition:.2s;
}
.product:hover{transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--line-2)}
.product-img{aspect-ratio:1.1; position:relative;
  background:repeating-linear-gradient(135deg, rgba(12,24,34,.04) 0 6px, transparent 6px 14px), var(--bg);
  display:grid; place-items:center; color:var(--muted); font-family:'JetBrains Mono',monospace; font-size:.65rem;
}
.product-img.s1{background:repeating-linear-gradient(135deg, rgba(20,82,94,.14) 0 6px, transparent 6px 14px), var(--petrol-soft)}
.product-img.s2{background:repeating-linear-gradient(135deg, rgba(210,148,47,.20) 0 6px, transparent 6px 14px), var(--amber-soft)}
.product-img.s3{background:repeating-linear-gradient(135deg, rgba(210,74,34,.10) 0 6px, transparent 6px 14px), #f4d8cc}
.product-img.s4{background:repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 6px, transparent 6px 14px), #1a2632; color:#8b96a3}
.product-body{padding:16px 16px 18px; display:flex; flex-direction:column; flex:1; gap:8px}
.product-cat{font-family:'JetBrains Mono',monospace; font-size:.66rem; color:var(--petrol); letter-spacing:.08em}
.product h4{margin:0; font-size:1.02rem; font-weight:600; letter-spacing:-.01em}
.product .bul{margin:6px 0 8px; padding:0; list-style:none; font-size:.8rem; color:var(--ink-2); display:flex; flex-direction:column; gap:4px}
.product .bul li{display:flex; gap:8px; align-items:flex-start; position:relative; padding-left:22px}
.product .bul li::before{content:""; flex:none; width:14px; height:14px; border-radius:50%; background:var(--petrol-soft); position:absolute; left:0; top:2px}
.product .bul li::after{content:"✓"; position:absolute; left:3px; top:0; font-size:.65rem; color:var(--petrol); font-weight:700}
.product-meta{display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:8px; border-top:1px dashed var(--line)}
.price{font-weight:700; font-size:.98rem; color:var(--ink)}
.price small{font-weight:500; color:var(--muted); font-size:.72rem}
.product-actions{display:flex; gap:8px; padding:0 16px 16px}
.btn-block{flex:1; justify-content:center; padding:10px 12px; font-size:.85rem}

@media (max-width:1080px){ .bgrid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:780px){ .bgrid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:480px){ .bgrid{grid-template-columns:1fr} }

/* ============ COMPARE / TABS ============ */
.compare{background:var(--ink); color:#dbe0e6; position:relative; overflow:hidden}
.compare::before{content:""; position:absolute; inset:0;
  background:
    radial-gradient(800px 400px at 90% 0%, rgba(20,82,94,.30), transparent 60%),
    radial-gradient(600px 400px at -10% 100%, rgba(210,148,47,.12), transparent 60%);
  pointer-events:none;
}
.compare .section-head .h2{color:#fff}
.compare .section-head p{color:#c4cbd2}
.compare .section-head .kicker{color:var(--amber)}
.tabs{display:flex; gap:6px; flex-wrap:wrap; margin-bottom:20px; position:relative}
.tab{
  padding:9px 16px; border-radius:999px; font-size:.86rem; font-weight:600;
  background:rgba(255,255,255,.06); color:#d6dae3;
  border:1px solid rgba(255,255,255,.08); transition:.18s;
}
.tab:hover{background:rgba(255,255,255,.12)}
.tab.active{background:var(--amber); color:#3b2a09; border-color:transparent}
.ctab{background:#fff; color:var(--ink); border-radius:var(--r-lg); overflow:hidden;
  box-shadow:0 30px 70px -30px rgba(0,0,0,.5); position:relative;}
.ctab-head{padding:18px 22px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line); gap:12px; flex-wrap:wrap}
.ctab-head h4{margin:0; font-size:1.05rem}
.ctab-head .meta{font-size:.78rem; color:var(--muted)}
.ctable-wrap{overflow-x:auto}
table.ctable{width:100%; border-collapse:collapse; min-width:780px; font-size:.82rem}
table.ctable thead{position:sticky; top:0; background:var(--bg)}
table.ctable th{text-align:left; padding:12px 14px; font-weight:600;
  color:var(--ink-2); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase;
  border-bottom:1px solid var(--line);}
table.ctable td{padding:14px; border-bottom:1px solid var(--line); vertical-align:middle}
table.ctable tr:last-child td{border-bottom:0}
table.ctable tr:hover td{background:var(--bg)}
.rowprod{display:flex; gap:12px; align-items:center; min-width:220px}
.rowprod-img{width:48px; height:48px; border-radius:10px; flex:none;
  background:repeating-linear-gradient(135deg, rgba(12,24,34,.06) 0 4px, transparent 4px 10px), var(--bg-2)}
.rowprod b{display:block; font-weight:600; margin-bottom:2px}
.rowprod span{font-size:.74rem; color:var(--muted)}
.pill{display:inline-flex; align-items:center; gap:4px; background:var(--petrol-soft); color:var(--petrol);
  padding:4px 9px; border-radius:999px; font-size:.7rem; font-weight:600;}
.pill.vermillion{background:#fad9cc; color:var(--vermillion-deep)}
.pill.amber{background:var(--amber-soft); color:#7a5a13}
.pill.ink{background:#dfe3e8; color:var(--ink)}
.score{display:inline-flex; align-items:center; gap:6px; font-weight:700}
.score b{font-size:.9rem}
.score span{font-size:.7rem; color:var(--muted); font-weight:500}
.scorebar{width:48px; height:5px; border-radius:99px; background:var(--bg-2); overflow:hidden}
.scorebar i{display:block; height:100%; background:linear-gradient(90deg, var(--petrol), var(--amber))}
.check-btn{display:inline-flex; align-items:center; gap:6px; background:var(--vermillion); color:#fff;
  padding:8px 14px; border-radius:999px; font-size:.78rem; font-weight:600; white-space:nowrap;}
.check-btn:hover{background:var(--vermillion-deep)}

/* ============ KAUFBERATER ============ */
.finder{background: radial-gradient(700px 400px at 80% 100%, rgba(20,82,94,.18), transparent 60%), var(--bg);}
.finder-grid{display:grid; grid-template-columns: .9fr 1.1fr; gap:48px; align-items:center}
.finder-left .badge-eyebrow{display:inline-flex; gap:8px; align-items:center; background:#fff; padding:6px 12px; border-radius:999px;
  font-size:.74rem; border:1px solid var(--line); margin-bottom:14px;}
.finder-left h2{font-family:'Instrument Serif',serif; font-weight:400; font-size:clamp(2rem,3.6vw,3rem); letter-spacing:-.02em; margin:6px 0 14px; line-height:1.05}
.finder-left h2 em{color:var(--petrol)}
.finder-left p{color:var(--ink-2); max-width:460px; margin-bottom:22px}
.progress{display:flex; gap:6px; margin-bottom:18px; max-width:460px}
.progress i{flex:1; height:5px; border-radius:99px; background:var(--bg-2)}
.progress i.on{background:var(--petrol)}
.finder-tiles{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.tile{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:18px; cursor:pointer; transition:.2s; display:flex; flex-direction:column; gap:10px; min-height:130px; text-align:left;}
.tile:hover{border-color:var(--petrol); transform:translateY(-2px); box-shadow:var(--shadow)}
.tile.active{border-color:var(--petrol); background:linear-gradient(180deg,#fff, var(--petrol-soft))}
.tile-ic{width:36px; height:36px; border-radius:10px; background:var(--petrol-soft); display:grid; place-items:center; color:var(--petrol)}
.tile b{font-size:.95rem; font-weight:600}
.tile .res{font-size:.74rem; color:var(--petrol); display:flex; align-items:center; gap:4px; margin-top:auto; font-weight:600}

@media (max-width:880px){ .finder-grid{grid-template-columns:1fr; gap:30px} }
@media (max-width:480px){ .finder-tiles{grid-template-columns:1fr} }

/* ============ SUBCATS GRID ============ */
.subwrap{background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.sub-cluster{margin-bottom:40px}
.sub-cluster-head{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--line); gap:16px; flex-wrap:wrap}
.sub-cluster-head h3{margin:0; font-family:'Instrument Serif',serif; font-weight:400; font-size:1.6rem; letter-spacing:-.01em}
.sub-cluster-head h3 small{font-family:'JetBrains Mono',monospace; font-size:.65rem; color:var(--muted); margin-right:10px; vertical-align:middle; letter-spacing:.1em}
.sub-cluster-head a{font-size:.84rem; color:var(--petrol); font-weight:600}
.subgrid{display:grid; grid-template-columns:repeat(4,1fr); gap:10px}
.sub{background:var(--bg); border:1px solid var(--line); border-radius:var(--r);
  padding:14px 16px; transition:.18s; display:flex; flex-direction:column; gap:6px; min-height:120px;}
.sub:hover{background:#fff; border-color:var(--petrol); transform:translateY(-2px)}
.sub-name{font-weight:600; font-size:.95rem; letter-spacing:-.005em}
.sub-tag{font-size:.72rem; color:var(--muted)}
.sub-foot{display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:6px}
.sub-foot .ideal{font-size:.66rem; font-family:'JetBrains Mono',monospace; color:var(--petrol); letter-spacing:.06em; text-transform:uppercase}
.sub-foot .go{font-size:.76rem; font-weight:600; color:var(--ink)}
.sub-foot .go::after{content:"→"; margin-left:4px; transition:.2s}
.sub:hover .go::after{transform:translateX(3px); color:var(--vermillion)}

@media (max-width:980px){ .subgrid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:680px){ .subgrid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:420px){ .subgrid{grid-template-columns:1fr} }

/* ============ TRUST + AFFNOTE ============ */
.trust-section{background:var(--bg)}
.trust-grid{display:grid; grid-template-columns: 1fr 1.4fr; gap:48px; align-items:start}
.trust-points{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.tp{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; display:flex; flex-direction:column; gap:10px}
.tp-ic{width:38px; height:38px; border-radius:10px; background:var(--petrol-soft); color:var(--petrol); display:grid; place-items:center}
.tp b{font-size:.98rem; font-weight:600}
.tp p{margin:0; font-size:.84rem; color:var(--ink-2)}
.affnote{margin-top:24px; padding:14px 16px; border:1px dashed var(--line-2); border-radius:var(--r);
  font-size:.8rem; color:var(--muted); background:rgba(255,255,255,.5); display:flex; gap:10px;}
.affnote::before{content:"i"; flex:none; width:22px; height:22px; border-radius:50%; background:var(--ink); color:#fff; display:grid; place-items:center; font-weight:700; font-size:.7rem; font-family:'Instrument Serif',serif}
@media (max-width:880px){ .trust-grid{grid-template-columns:1fr} .trust-points{grid-template-columns:1fr 1fr} }
@media (max-width:480px){ .trust-points{grid-template-columns:1fr} }

/* ============ RATGEBER ============ */
.ratgeber{background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%)}
.ratgeber-grid{display:grid; grid-template-columns: 1fr 1fr 1fr; gap:18px}
.article{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; display:flex; flex-direction:column; gap:10px}
.article .atag{font-family:'JetBrains Mono',monospace; font-size:.66rem; color:var(--petrol); letter-spacing:.08em}
.article h3{margin:4px 0 0; font-family:'Instrument Serif',serif; font-weight:400; font-size:1.45rem; letter-spacing:-.01em; line-height:1.15}
.article p{margin:0; color:var(--ink-2); font-size:.9rem; line-height:1.55}
.article ul{margin:6px 0 0; padding-left:18px; font-size:.84rem; color:var(--ink-2)}
.article ul li{margin-bottom:4px}
.article .more{margin-top:auto; padding-top:12px; font-weight:600; font-size:.84rem; color:var(--ink); display:inline-flex; align-items:center; gap:6px}
.article .more::after{content:"→"}
.article.featured{grid-column:span 2; flex-direction:row; gap:24px}
.article.featured .article-img{flex:0 0 42%; min-height:240px; border-radius:var(--r);
  background:repeating-linear-gradient(135deg, rgba(20,82,94,.16) 0 8px, transparent 8px 16px), var(--petrol-soft);
  display:grid; place-items:center; color:var(--petrol); font-family:'JetBrains Mono',monospace; font-size:.7rem;}
.article.featured .article-body{flex:1; display:flex; flex-direction:column; gap:10px}
@media (max-width:980px){ .ratgeber-grid{grid-template-columns:1fr 1fr} .article.featured{grid-column:span 2; flex-direction:column} }
@media (max-width:600px){ .ratgeber-grid{grid-template-columns:1fr} .article.featured{grid-column:auto} }

.internal-row{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:30px}
.ibox{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:18px 20px; display:flex; flex-direction:column; gap:8px; border-left:3px solid var(--petrol);}
.ibox.amber{border-left-color:var(--amber)}
.ibox.vermillion{border-left-color:var(--vermillion)}
.ibox .ihost{font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--muted); letter-spacing:.06em}
.ibox b{font-size:1rem; font-weight:600}
.ibox p{margin:0; font-size:.84rem; color:var(--ink-2)}
.ibox a{margin-top:6px; font-size:.78rem; font-weight:600; color:var(--ink); display:inline-flex; gap:4px; align-items:center}
.ibox a::after{content:"↗"}
@media (max-width:780px){ .internal-row{grid-template-columns:1fr} }

/* ============ FOOTER ============ */
footer{background:var(--ink); color:#c0c8d0; padding:64px 0 28px}
.foot-top{display:grid; grid-template-columns: 1.3fr 1fr 1fr 1fr 1fr; gap:36px; padding-bottom:36px; border-bottom:1px solid #1d2c3a}
.foot-top h5{color:#fff; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; margin:0 0 14px; font-family:'JetBrains Mono',monospace; font-weight:500}
.foot-top ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; font-size:.88rem}
.foot-top ul a:hover{color:#fff}
.foot-brand .logo-name{color:#fff}
.foot-brand .logo-name b{color:var(--amber)}
.foot-brand .logo-claim{color:#7c8995}
.foot-brand p{font-size:.88rem; margin:18px 0 0; max-width:340px; line-height:1.55}
.foot-bottom{display:flex; align-items:center; justify-content:space-between; padding-top:24px; flex-wrap:wrap; gap:14px; font-size:.78rem; color:#7c8995}
.foot-bottom .legal{display:flex; gap:18px}
.foot-bottom .legal a:hover{color:#fff}
@media (max-width:980px){ .foot-top{grid-template-columns:1fr 1fr 1fr; gap:28px} .foot-brand{grid-column:span 3} }
@media (max-width:560px){ .foot-top{grid-template-columns:1fr 1fr} .foot-brand{grid-column:span 2} }

/* icons */
.ic-svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ic-svg.lg{width:22px;height:22px}

/* ============ HERO CAROUSEL — modern editorial ============ */
.hero-slider{
  position:relative; overflow:hidden;
  background:var(--ink);
  color:#f4ede0;
  border-bottom:0;
}
.hero-slider::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(900px 600px at 90% -10%, rgba(31,58,163,.45), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(217,66,30,.30), transparent 55%),
    radial-gradient(500px 400px at 50% 50%, rgba(201,138,45,.18), transparent 70%);
}
.hero-slider::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:1; opacity:.4;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: calc(100% / 12) 100%, 100% 80px;
}
.slider-stage{position:relative; min-height:580px; z-index:2}
.slide{
  position:absolute; inset:0;
  display:grid; grid-template-columns: 1.1fr 1fr;
  align-items:stretch;
  opacity:0; pointer-events:none;
  transition: opacity .5s ease, transform .5s ease;
  transform: translateY(6px);
}
.slide.active{opacity:1; pointer-events:auto; transform:translateY(0); z-index:2}
.slide-left{
  padding:32px 56px 28px;
  display:flex; flex-direction:column; justify-content:center; gap:14px;
  position:relative;
  border-right:1px solid rgba(255,255,255,.08);
}
.slide-num{
  font-family:'Instrument Serif', serif;
  font-size:clamp(6rem, 14vw, 12rem); line-height:.82;
  color:#f4ede0; letter-spacing:-.04em;
  position:absolute; bottom:14px; right:36px; opacity:.06;
  pointer-events:none; user-select:none; z-index:0;
}
.slide-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'JetBrains Mono', monospace;
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:#f4ede0; position:relative; z-index:2;
}
.slide-eyebrow .tag{
  padding:6px 12px; border-radius:999px;
  font-weight:600; font-size:.7rem;
  display:inline-flex; align-items:center; gap:6px;
}
.slide-eyebrow .tag::before{content:""; width:6px; height:6px; border-radius:50%; background:currentColor; opacity:.9}
.slide-eyebrow .tag.cobalt{background:rgba(31,58,163,.25); color:#a9bbff; border:1px solid rgba(169,187,255,.4)}
.slide-eyebrow .tag.amber{background:rgba(201,138,45,.20); color:#f0c878; border:1px solid rgba(240,200,120,.4)}
.slide-eyebrow .tag.tomato{background:rgba(217,66,30,.22); color:#ffa48a; border:1px solid rgba(255,164,138,.4)}
.slide-eyebrow .tag.plum{background:rgba(90,42,100,.30); color:#deb6e7; border:1px solid rgba(222,182,231,.4)}
.slide-eyebrow .tag.ink{background:rgba(255,255,255,.10); color:#f4ede0; border:1px solid rgba(244,237,224,.3)}
.slide-eyebrow .count{color:rgba(244,237,224,.5)}
.slide-title{
  font-family:'Instrument Serif', serif; font-weight:400;
  font-size:clamp(2.8rem, 6.4vw, 5.4rem);
  line-height:.96; letter-spacing:-.03em;
  color:#fbf6ea; margin:4px 0 2px;
  position:relative; z-index:2;
}
.slide-title em{font-style:italic; color:#ffb46b}
.slide[data-cw="cobalt"] .slide-title em{color:#9bb0ff}
.slide[data-cw="amber"]  .slide-title em{color:#ffb46b}
.slide[data-cw="ink"]    .slide-title em{color:#f0c878}
.slide[data-cw="plum"]   .slide-title em{color:#e5beea}
.slide[data-cw="tomato"] .slide-title em{color:#ffa48a}
.slide-title .uline{
  background: linear-gradient(180deg, transparent 68%, rgba(201,138,45,.45) 68%);
  padding:0 4px;
}
.slide-lede{
  font-size:1.05rem; color:rgba(244,237,224,.78);
  max-width:520px; margin:0; line-height:1.55; position:relative; z-index:2;
}
.spec-strip{
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr));
  border-top:1px solid rgba(255,255,255,.15);
  border-bottom:1px solid rgba(255,255,255,.15);
  margin-top:10px;
  max-width:600px; position:relative; z-index:2;
}
.spec-strip .sp{
  padding:12px 14px 12px 0;
  border-right:1px solid rgba(255,255,255,.08);
  display:flex; flex-direction:column; gap:3px;
}
.spec-strip .sp:last-child{border-right:0; padding-right:0}
.spec-strip .sp:not(:first-child){padding-left:14px}
.spec-strip b{
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(244,237,224,.5); font-weight:500;
}
.spec-strip span{font-weight:600; font-size:1rem; color:#fbf6ea; letter-spacing:-.01em}
.slide-foot{display:flex; align-items:center; gap:24px; margin-top:8px; flex-wrap:wrap; position:relative; z-index:2}
.slide-price{display:flex; flex-direction:column; gap:2px}
.slide-price b{font-family:'JetBrains Mono',monospace; font-size:.6rem; letter-spacing:.14em; color:rgba(244,237,224,.5); text-transform:uppercase; font-weight:500}
.slide-price span{font-family:'Instrument Serif',serif; font-size:2rem; color:#fbf6ea; line-height:1}
.slide-price small{display:block; font-size:.76rem; color:rgba(244,237,224,.45); text-decoration:line-through; margin-top:2px}
.slide-cta-row{display:flex; gap:10px; flex-wrap:wrap}
.slide .btn-primary{background:var(--vermillion); color:#fff; box-shadow:0 10px 30px -10px rgba(217,66,30,.7)}
.slide .btn-primary:hover{background:var(--vermillion-deep)}
.slide .btn-ghost{background:rgba(255,255,255,.06); color:#f4ede0; border:1px solid rgba(255,255,255,.18); backdrop-filter:blur(8px)}
.slide .btn-ghost:hover{background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.35)}

/* slide visual / right column */
.slide-right{
  position:relative; overflow:hidden;
  display:grid; place-items:center;
  padding:32px 56px 32px 0;
}
.slide-vis{
  position:relative; width:100%; height:100%;
  border-radius:28px;
  display:grid; place-items:center;
  overflow:hidden;
  box-shadow: 0 40px 80px -30px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.08) inset;
}
.slide-vis::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.35), transparent 50%),
    radial-gradient(circle at 80% 90%, rgba(0,0,0,.20), transparent 60%);
}
.slide-vis::after{
  content:""; position:absolute; inset:14px; pointer-events:none; z-index:2;
  border:1px dashed rgba(255,255,255,.25); border-radius:18px;
}

.vis-tag{
  position:absolute; top:22px; left:22px; z-index:3;
  font-family:'JetBrains Mono',monospace;
  font-size:.64rem; letter-spacing:.14em; text-transform:uppercase;
  color:#1a1a1a;
  background:rgba(255,255,255,.85); backdrop-filter:blur(8px);
  padding:6px 12px; border-radius:999px;
  font-weight:500;
}
.vis-rule{
  position:absolute; right:22px; bottom:22px; z-index:3;
  display:flex; align-items:center; gap:8px;
  font-family:'JetBrains Mono',monospace; font-size:.64rem; letter-spacing:.1em;
  color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.25); backdrop-filter:blur(8px);
  padding:6px 12px; border-radius:999px;
}
.vis-rule i{display:inline-block; width:50px; height:1px; background:rgba(255,255,255,.7)}

/* slide colorways — vivid */
.slide[data-cw="cobalt"] .slide-vis{
  background:
    radial-gradient(circle at 25% 25%, #4a6fea 0%, transparent 55%),
    linear-gradient(135deg, #1f3aa3 0%, #14257a 100%);
}
.slide[data-cw="amber"]  .slide-vis{
  background:
    radial-gradient(circle at 30% 20%, #ffc266 0%, transparent 50%),
    linear-gradient(135deg, #c98a2d 0%, #7a5a13 100%);
}
.slide[data-cw="ink"]    .slide-vis{
  background:
    radial-gradient(circle at 30% 20%, #2e3650 0%, transparent 55%),
    linear-gradient(135deg, #181410 0%, #0a0806 100%);
}
.slide[data-cw="ink"] .vis-tag{background:rgba(201,138,45,.95); color:#181410}
.slide[data-cw="plum"]   .slide-vis{
  background:
    radial-gradient(circle at 30% 20%, #9159a0 0%, transparent 55%),
    linear-gradient(135deg, #5a2a64 0%, #2e1335 100%);
}
.slide[data-cw="tomato"] .slide-vis{
  background:
    radial-gradient(circle at 30% 20%, #ff7553 0%, transparent 55%),
    linear-gradient(135deg, #d9421e 0%, #8c2407 100%);
}

/* product shape inside visual */
.vis-art{
  width:78%; height:74%; max-width:440px;
  display:grid; place-items:center;
  position:relative; z-index:3;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,.35));
}
.vis-art svg{width:100%; height:100%; overflow:visible}
/* invert SVG strokes against vivid bg */
.slide-vis .vis-art svg [stroke]{stroke:#fbf6ea !important}
.slide-vis .vis-art svg [stroke][stroke-width="1"]{opacity:.55}
.slide-vis .vis-art svg rect[fill="#fbfaf3"]{fill:rgba(255,255,255,.95)}
.slide-vis .vis-art svg rect[fill="#dbe0f1"]{fill:rgba(255,255,255,.30)}
.slide-vis .vis-art svg text{fill:#fbf6ea !important; font-weight:600}

/* stat overlay chip — modern card */
.vis-stat{
  position:absolute; right:30px; top:50%;
  transform:translateY(-50%) translateX(10px) rotate(-4deg);
  background:#fbf6ea; color:var(--ink);
  padding:14px 18px; border-radius:14px;
  z-index:4; max-width:200px; line-height:1.25;
  box-shadow: 0 20px 50px -10px rgba(0,0,0,.5), 0 0 0 4px rgba(255,255,255,.1);
  font-family:'Inter Tight',sans-serif;
}
.vis-stat b{display:block; font-family:'JetBrains Mono',monospace; font-size:.6rem; letter-spacing:.14em; color:var(--vermillion); text-transform:uppercase; margin-bottom:4px; font-weight:600}
.vis-stat span{font-size:.92rem; color:var(--ink); font-weight:500}

/* CONTROLS — integrated, modern, top-right floating */
.slider-controls{
  position:absolute; top:20px; right:56px; z-index:10;
  display:flex; align-items:center; gap:14px;
  padding:0;
}
.slider-dots{display:flex; gap:5px}
.slider-dots button{
  width:28px; height:3px; background:rgba(255,255,255,.18); border:0; border-radius:99px;
  position:relative; overflow:hidden; cursor:pointer; padding:0; transition:.2s;
}
.slider-dots button:hover{background:rgba(255,255,255,.35)}
.slider-dots button::after{
  content:""; position:absolute; left:0; top:0; bottom:0; width:0;
  background:var(--amber); border-radius:99px;
}
.slider-dots button.active{width:48px}
.slider-dots button.active::after{width:100%; transition: width 6s linear}
.slider-dots button.done::after{width:100%}
.slider-meta{
  font-family:'JetBrains Mono',monospace; font-size:.7rem; letter-spacing:.12em;
  color:rgba(244,237,224,.6); text-transform:uppercase; padding:0 8px; border-left:1px solid rgba(255,255,255,.15); border-right:1px solid rgba(255,255,255,.15);
}
.slider-meta b{color:#fbf6ea; font-weight:600}
.slider-arrows{display:flex; gap:6px}
.slider-arrows button{
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); color:#fbf6ea;
  display:grid; place-items:center; cursor:pointer; transition:.18s;
  backdrop-filter:blur(8px);
}
.slider-arrows button:hover{background:var(--amber); color:#181410; border-color:var(--amber); transform:scale(1.05)}

/* below carousel: trust strip */
.hero-strip{border-top:1px solid var(--line); padding:14px 0; background:var(--paper)}
.hero-strip-inner{display:flex; gap:32px; flex-wrap:wrap; justify-content:space-between; align-items:center; font-size:.82rem}
.hero-strip-inner strong{font-weight:600}
.hero-strip-inner span{color:var(--ink-2)}

@media (max-width:980px){
  .slider-stage{min-height:auto}
  .slide{position:relative; grid-template-columns:1fr; opacity:1; pointer-events:auto; transform:none; display:none}
  .slide.active{display:grid}
  .slide-left{padding:80px 24px 24px; border-right:0; border-bottom:1px solid rgba(255,255,255,.08)}
  .slide-num{font-size:5rem; bottom:auto; top:12px; right:20px}
  .slide-right{min-height:280px; padding:20px}
  .slide-vis{height:280px}
  .vis-stat{right:24px; transform:translateY(-50%) translateX(0) rotate(-3deg); padding:10px 14px}
  .slider-controls{top:14px; right:14px; left:14px; justify-content:flex-end}
}
@media (max-width:560px){
  .spec-strip{grid-template-columns:1fr 1fr}
  .spec-strip .sp{border-right:0; border-bottom:1px solid var(--line-2); padding:10px 0}
  .spec-strip .sp:nth-child(odd){padding-left:0; border-right:1px solid var(--line-2); padding-right:14px}
  .spec-strip .sp:nth-child(even){padding-left:14px}
  .spec-strip .sp:nth-last-child(-n+2){border-bottom:0}
}

/* scrollbar + tab visibility */
::-webkit-scrollbar{height:8px;width:8px}
::-webkit-scrollbar-thumb{background:var(--line-2); border-radius:99px}
.ctab[data-tab]:not(.show){display:none}

/* ============ CATEGORY PAGE SPECIFIC ============ */
.crumb{font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--muted); letter-spacing:.06em; padding:18px 0 0; display:flex; gap:8px; align-items:center; flex-wrap:wrap}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--ink)}
.crumb .sep{color:var(--line-2)}
.crumb .cur{color:var(--ink); font-weight:500}

.cat-hero{padding:32px 0 56px; position:relative; overflow:hidden}
.cat-hero-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap:48px; align-items:end}
.cat-hero h1{font-family:'Instrument Serif',serif; font-weight:400; font-size:clamp(2.4rem,5vw,4rem); letter-spacing:-.02em; line-height:1.02; margin:14px 0 14px}
.cat-hero h1 em{color:var(--petrol); font-style:italic}
.cat-hero .lede{font-size:1.05rem; color:var(--ink-2); max-width:540px; margin-bottom:24px}
.cat-meta{display:flex; gap:24px; flex-wrap:wrap; font-size:.85rem; color:var(--ink-2)}
.cat-meta b{font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--petrol); letter-spacing:.08em; display:block; margin-bottom:2px}
.cat-hero-art{
  border-radius:var(--r-xl); aspect-ratio:1.1;
  background:
    radial-gradient(circle at 30% 30%, var(--amber-soft), transparent 60%),
    repeating-linear-gradient(135deg, rgba(20,82,94,.12) 0 8px, transparent 8px 18px),
    var(--petrol-soft);
  display:grid; place-items:center; color:var(--petrol);
  font-family:'JetBrains Mono',monospace; font-size:.75rem; letter-spacing:.06em;
  border:1px solid var(--line); position:relative;
}
.cat-hero-art .kic{
  position:absolute; top:18px; left:18px;
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; padding:8px 14px; border-radius:999px;
  font-size:.74rem; color:var(--ink); font-weight:600;
  border:1px solid var(--line); font-family:'Inter Tight',sans-serif; letter-spacing:0; text-transform:none;
}
@media (max-width:880px){ .cat-hero-grid{grid-template-columns:1fr} .cat-hero-art{aspect-ratio:16/10} }

/* subcategory chips on category page */
.subnav{
  display:flex; gap:8px; flex-wrap:wrap; padding:16px 0; border-top:1px solid var(--line);
  border-bottom:1px solid var(--line); margin:24px 0 0;
}
.subnav a{font-size:.85rem; padding:8px 14px; border-radius:999px; background:#fff; border:1px solid var(--line); font-weight:500}
.subnav a:hover{border-color:var(--petrol); color:var(--petrol)}
.subnav a.active{background:var(--petrol); color:#fff; border-color:transparent}

/* tall compare page */
.compare-hero{padding:32px 0 40px}
.compare-hero h1{font-family:'Instrument Serif',serif; font-weight:400; font-size:clamp(2.2rem,4.4vw,3.6rem); letter-spacing:-.02em; margin:10px 0 14px; line-height:1.04}
.compare-hero h1 em{color:var(--petrol)}
.compare-hero .lede{font-size:1rem; color:var(--ink-2); max-width:680px}
.compare-summary{display:grid; grid-template-columns: repeat(4,1fr); gap:14px; margin-top:24px}
.csum{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:14px 16px}
.csum b{font-family:'JetBrains Mono',monospace; font-size:.68rem; color:var(--muted); letter-spacing:.08em; display:block; margin-bottom:6px}
.csum span{font-weight:600; font-size:.98rem}
@media (max-width:780px){ .compare-summary{grid-template-columns:repeat(2,1fr)} }

/* award/winner cards in compare pages */
.podium{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:28px}
.podium .pod{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:18px; display:flex; flex-direction:column; gap:10px; position:relative}
.podium .pod.top{border-color:var(--vermillion); box-shadow:var(--shadow)}
.podium .pod-rank{position:absolute; top:-12px; left:18px; background:var(--ink); color:#fff;
  padding:5px 12px; border-radius:999px; font-size:.7rem; font-weight:700; font-family:'JetBrains Mono',monospace; letter-spacing:.08em}
.podium .pod.top .pod-rank{background:var(--vermillion)}
.podium .pod-img{aspect-ratio:1.2; border-radius:var(--r);
  background:repeating-linear-gradient(135deg, rgba(20,82,94,.14) 0 6px, transparent 6px 14px), var(--petrol-soft);
  display:grid; place-items:center; color:var(--petrol); font-family:'JetBrains Mono',monospace; font-size:.7rem}
.podium .pod-img.a{background:repeating-linear-gradient(135deg, rgba(210,148,47,.18) 0 6px, transparent 6px 14px), var(--amber-soft); color:#7a5a13}
.podium .pod-img.b{background:repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 6px, transparent 6px 14px), #1a2632; color:#8b96a3}
.podium .pod h4{margin:0; font-size:1.1rem; font-weight:600}
.podium .pod .pod-pros{margin:6px 0 0; padding:0; list-style:none; font-size:.82rem; color:var(--ink-2); display:flex; flex-direction:column; gap:4px}
.podium .pod .pod-pros li{display:flex; gap:8px; padding-left:18px; position:relative}
.podium .pod .pod-pros li::before{content:"+"; position:absolute; left:0; color:var(--petrol); font-weight:700}
.podium .pod-foot{display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:10px; border-top:1px dashed var(--line)}
@media (max-width:780px){ .podium{grid-template-columns:1fr} }

/* deep-dive content for compare pages */
.deep{background:var(--paper)}
.deep-grid{display:grid; grid-template-columns: 220px 1fr; gap:40px; align-items:start}
.deep-toc{position:sticky; top:90px; font-size:.86rem}
.deep-toc h5{margin:0 0 10px; font-family:'JetBrains Mono',monospace; font-size:.68rem; letter-spacing:.08em; color:var(--muted); text-transform:uppercase; font-weight:500}
.deep-toc ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px}
.deep-toc a{color:var(--ink-2); padding:6px 10px; border-radius:6px; display:block}
.deep-toc a:hover{background:var(--bg); color:var(--ink)}
.deep-body h2{font-family:'Instrument Serif',serif; font-weight:400; font-size:2rem; letter-spacing:-.02em; margin:0 0 14px}
.deep-body h3{font-family:'Inter Tight',sans-serif; font-weight:600; font-size:1.15rem; margin:36px 0 10px; letter-spacing:-.01em}
.deep-body p{color:var(--ink-2); font-size:.96rem; line-height:1.65}
.deep-body ul.checks{list-style:none; padding:0; margin:14px 0; display:flex; flex-direction:column; gap:8px}
.deep-body ul.checks li{padding-left:28px; position:relative; color:var(--ink-2); font-size:.94rem}
.deep-body ul.checks li::before{content:"✓"; position:absolute; left:0; top:0; width:20px; height:20px; border-radius:50%; background:var(--petrol-soft); color:var(--petrol); display:grid; place-items:center; font-size:.7rem; font-weight:700}
.callout{margin:20px 0; padding:18px 20px; background:#fff; border:1px solid var(--line); border-radius:var(--r); border-left:3px solid var(--amber); font-size:.92rem; color:var(--ink-2)}
.callout b{color:var(--ink)}
@media (max-width:880px){ .deep-grid{grid-template-columns:1fr} .deep-toc{position:static} }
