/* =====================================================
   AutoNest · Gear Reviews — Site Design System v2
   ===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700;9..144,800;9..144,900&family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;600&display=swap');

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

:root {
  --ink-1:#0a1224; --ink-2:#0f1a2e; --ink-3:#1a263e; --ink-4:#2c3a55;
  --ink-5:#475569; --ink-6:#94a3b8;
  --copper:#e89b2a; --copper-light:#f4b860; --copper-deep:#b87317;
  --copper-soft:rgba(232,155,42,.12);
  --cream:#faf7f2; --cream-2:#f4f0e7; --paper:#ffffff; --paper-warm:#fdfaf4;
  --line:#e5dcc8; --line-2:#ece4d2;
  --text:#13192b; --text-soft:#3d4660; --muted:#6e7488;
  --good:#15803d; --bad:#b91c1c;
  --shadow-xs:0 1px 2px rgba(15,26,46,.06);
  --shadow-sm:0 4px 14px rgba(15,26,46,.08);
  --shadow-md:0 10px 30px rgba(15,26,46,.12);
  --shadow-lg:0 24px 60px rgba(15,26,46,.18);
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px;
  --font-display:'Fraunces','Georgia',serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-mono:'JetBrains Mono','SFMono-Regular',monospace;
  /* Backwards-compat aliases (existing markup uses --green-*/--gold) */
  --green-900:var(--ink-1); --green-800:var(--ink-2); --green-700:var(--ink-3);
  --green-600:var(--ink-4); --gold:var(--copper); --gold-light:var(--copper-light);
  --bg:var(--cream); --surface:var(--paper); --surface2:var(--cream-2);
  --border:var(--line); --radius:var(--r-md); --radius-sm:var(--r-sm);
  --shadow:var(--shadow-sm); --font-head:var(--font-display); --font:var(--font-body);
}

html { scroll-behavior:smooth; -webkit-text-size-adjust:100% }
body {
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--text);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:'ss01','cv11','liga';
}
a { color:var(--ink-3); text-decoration:none; transition:color .2s }
a:hover { color:var(--copper-deep) }
img, svg { max-width:100%; display:block }
button { font-family:inherit }
::selection { background:var(--copper); color:#fff }

.container { max-width:1280px; margin:0 auto; padding:0 28px }
.section { padding:88px 0 }
.section-tight { padding:56px 0 }

/* =====================================================
   HEADER
   ===================================================== */
header {
  position:sticky; top:0; z-index:200;
  background:linear-gradient(180deg, rgba(10,18,36,.94), rgba(10,18,36,.86));
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  backdrop-filter: blur(18px) saturate(140%);
  border-bottom:1px solid rgba(232,155,42,.18);
  transition:box-shadow .25s, background .25s;
}
header.scrolled { box-shadow:0 10px 30px rgba(0,0,0,.30); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:78px; gap:24px }

.brand, .logo {
  display:flex; align-items:center; gap:14px;
  text-decoration:none; flex-shrink:0; color:#fff;
}
.brand:hover, .logo:hover { color:#fff; text-decoration:none }
.brand-mark, .logo-icon {
  position:relative; width:46px; height:46px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, rgba(232,155,42,.16), rgba(232,155,42,.04));
  border:1px solid rgba(232,155,42,.32);
  border-radius:12px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 6px 18px rgba(232,155,42,.12);
  flex-shrink:0;
}
.brand-mark img, .logo-img { width:30px; height:30px; object-fit:contain; filter:drop-shadow(0 2px 6px rgba(0,0,0,.4)); border-radius:0; background:transparent; padding:0 }
.brand-mark::after {
  content:''; position:absolute; right:-2px; top:-2px; width:8px; height:8px;
  background:var(--copper); border-radius:50%;
  box-shadow:0 0 12px var(--copper);
}
.brand-text { display:flex; flex-direction:column; line-height:1; gap:5px }
.brand-name {
  font-family:var(--font-display);
  font-weight:800; font-size:1.45rem; color:#fff;
  letter-spacing:-0.025em;
  font-variation-settings:"opsz" 80;
}
.brand-name em { font-style:italic; color:var(--copper-light); font-weight:600 }
.brand-tag {
  font-family:var(--font-mono);
  font-size:.62rem; font-weight:600; letter-spacing:.32em;
  color:var(--copper-light); text-transform:uppercase;
}
.brand-tag::before { content:'· '; color:rgba(232,155,42,.5); margin-right:2px }

nav { display:flex; align-items:center; gap:2px }
nav a {
  position:relative;
  color:rgba(255,255,255,.78);
  font-size:.9rem; font-weight:500;
  padding:9px 14px; border-radius:8px;
  transition:color .18s, background .18s;
}
nav a:hover { color:#fff; background:rgba(255,255,255,.06); text-decoration:none }
nav a.active { color:#fff }
nav a.active::after {
  content:''; position:absolute; left:14px; right:14px; bottom:2px; height:2px;
  background:var(--copper); border-radius:1px;
}
.nav-cta {
  background:linear-gradient(135deg, var(--copper), var(--copper-deep)) !important;
  color:#fff !important; font-weight:700 !important;
  padding:10px 20px !important; margin-left:8px;
  box-shadow:0 6px 18px rgba(232,155,42,.30);
  border-radius:10px !important;
}
.nav-cta:hover { transform:translateY(-1px); box-shadow:0 10px 24px rgba(232,155,42,.42) !important; background:linear-gradient(135deg, var(--copper-light), var(--copper)) !important }

.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;flex-shrink:0}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =====================================================
   HERO
   ===================================================== */
.hero {
  position:relative; overflow:hidden;
  background:linear-gradient(180deg, var(--ink-1), var(--ink-2) 60%, var(--ink-3));
  isolation:isolate;
  padding:0;
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center 30%;
  opacity:.42;
  filter:saturate(1.1);
}
.hero-overlay {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 18% 0%, rgba(232,155,42,.20), transparent 60%),
    linear-gradient(95deg, rgba(10,18,36,.86) 0%, rgba(10,18,36,.55) 55%, rgba(10,18,36,.85) 100%);
}
.hero::after {
  content:''; position:absolute; left:0; right:0; bottom:0; height:120px; pointer-events:none;
  background:linear-gradient(180deg, transparent, var(--cream));
  z-index:1;
}
.hero-content-split, .hero-content {
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.15fr .85fr;
  gap:64px; align-items:center;
  padding:104px 0 132px; max-width:1280px; margin:0 auto;
  text-align:left;
}
.hero-text { color:#fff; max-width:620px }

.hero-eyebrow, .hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono);
  font-size:.7rem; font-weight:600; letter-spacing:.3em; text-transform:uppercase;
  color:var(--copper-light);
  padding:6px 14px;
  border:1px solid rgba(232,155,42,.32);
  background:rgba(232,155,42,.08);
  border-radius:30px;
  margin-bottom:28px;
  text-decoration:none;
}
.hero-eyebrow::before, .hero-badge::before { content:''; width:6px; height:6px; background:var(--copper); border-radius:50%; box-shadow:0 0 10px var(--copper) }

.hero h1 {
  font-family:var(--font-display);
  font-size:clamp(2.2rem, 5.6vw, 4.2rem);
  font-weight:600;
  font-variation-settings:"opsz" 144;
  line-height:1.04;
  color:#fff;
  letter-spacing:-0.025em;
  margin-bottom:24px;
}
.hero h1 em, .hero h1 span {
  font-style:italic; font-weight:500;
  background:linear-gradient(120deg, var(--copper-light), var(--copper));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero p {
  font-size:1.12rem; line-height:1.65;
  color:rgba(255,255,255,.78);
  max-width:560px; margin-bottom:36px;
}

.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:38px }
.btn-hero {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px; border-radius:12px;
  font-weight:700; font-size:.95rem; letter-spacing:.01em;
  transition:transform .18s, box-shadow .18s, background .18s;
}
.btn-hero.primary {
  background:linear-gradient(135deg, var(--copper), var(--copper-deep));
  color:#fff;
  box-shadow:0 12px 30px rgba(232,155,42,.32);
}
.btn-hero.primary:hover { transform:translateY(-2px); box-shadow:0 18px 40px rgba(232,155,42,.45); color:#fff; text-decoration:none }
.btn-hero.ghost {
  background:rgba(255,255,255,.06);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
}
.btn-hero.ghost:hover { background:rgba(255,255,255,.12); color:#fff; text-decoration:none }

.hero-meta { display:none }
.hero-meta-item { display:none }

/* Hero brands strip — replaces stat block with editorial credibility cue */
.hero-brands {
  padding-top:26px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex; flex-direction:column; gap:14px;
}
.hero-brands-label {
  font-family:var(--font-mono);
  font-size:.66rem; font-weight:600;
  letter-spacing:.32em; text-transform:uppercase;
  color:rgba(232,155,42,.85);
  display:flex; align-items:center; gap:10px;
}
.hero-brands-label::before, .hero-brands-label::after {
  content:''; height:1px; flex:0 0 18px;
  background:linear-gradient(90deg, transparent, rgba(232,155,42,.45));
}
.hero-brands-label::before { background:linear-gradient(90deg, rgba(232,155,42,.45), transparent) }
.hero-brands-list {
  list-style:none; display:flex; flex-wrap:wrap; gap:8px;
}
.hero-brands-list li {
  font-family:var(--font-display);
  font-size:.86rem; font-weight:600;
  font-variation-settings:"opsz" 80;
  color:rgba(255,255,255,.86);
  padding:6px 14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:30px;
  transition:all .2s;
  letter-spacing:-0.005em;
}
.hero-brands-list li:hover {
  background:rgba(232,155,42,.10);
  border-color:rgba(232,155,42,.4);
  color:#fff;
}
.hero-brands-list li:last-child {
  font-family:var(--font-mono); font-size:.7rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--copper-light);
  background:transparent; border-color:rgba(232,155,42,.32);
}

/* legacy stat block hidden — replaced by .hero-pick */
.hero-stats { display:none }

/* Featured Pick of the Week */
.hero-pick {
  position:relative;
  background:linear-gradient(160deg, rgba(255,255,255,.10), rgba(255,255,255,.03));
  border:1px solid rgba(232,155,42,.28);
  border-radius:24px;
  padding:24px;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  box-shadow:0 30px 70px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.10);
  transform:perspective(1400px) rotateY(-3deg) rotateX(2deg);
  transition:transform .4s ease;
  text-decoration:none;
  color:inherit;
  display:block;
}
.hero-pick:hover { transform:perspective(1400px) rotateY(-1deg) rotateX(0deg) translateY(-4px); text-decoration:none }
.hero-pick-tag {
  position:absolute; top:-14px; left:24px;
  background:linear-gradient(135deg, var(--copper), var(--copper-deep));
  color:#fff;
  font-family:var(--font-mono); font-size:.66rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  padding:7px 14px; border-radius:30px;
  box-shadow:0 8px 18px rgba(232,155,42,.32);
}
.hero-pick-img {
  position:relative; width:100%; aspect-ratio:16/11;
  border-radius:16px; overflow:hidden;
  background:linear-gradient(135deg, var(--ink-2), var(--ink-3));
  margin-bottom:18px;
  box-shadow:0 14px 30px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.08);
}
.hero-pick-img img { width:100%; height:100%; object-fit:cover }
.hero-pick-rank {
  position:absolute; top:14px; left:14px;
  font-family:var(--font-display); font-style:italic;
  font-size:2.4rem; font-weight:700; line-height:1;
  background:linear-gradient(135deg, var(--copper-light), var(--copper));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 0 24px rgba(232,155,42,.4);
}
.hero-pick-score {
  position:absolute; bottom:14px; right:14px;
  background:rgba(0,0,0,.74);
  color:var(--copper-light);
  font-family:var(--font-mono); font-size:.78rem; font-weight:700;
  padding:6px 12px; border-radius:8px;
  border:1px solid rgba(232,155,42,.4);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}
.hero-pick-body { color:#fff }
.hero-pick-cat {
  font-family:var(--font-mono); font-size:.66rem; font-weight:600;
  letter-spacing:.24em; text-transform:uppercase;
  color:var(--copper-light); margin-bottom:8px;
}
.hero-pick-name {
  font-family:var(--font-display);
  font-size:1.32rem; font-weight:700; line-height:1.18;
  color:#fff; margin-bottom:12px;
  font-variation-settings:"opsz" 80;
}
.hero-pick-stars { color:var(--copper); font-size:.95rem; letter-spacing:1.5px; margin-bottom:14px }
.hero-pick-stars b { color:#fff; font-family:var(--font-mono); font-size:.82rem; margin-left:6px; font-weight:600 }
.hero-pick-cta {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 18px; border-radius:10px;
  background:rgba(232,155,42,.14); border:1px solid rgba(232,155,42,.4);
  color:var(--copper-light); font-weight:600; font-size:.86rem;
  transition:all .2s;
}
.hero-pick-cta::after { content:'→'; transition:transform .2s }
.hero-pick:hover .hero-pick-cta { background:var(--copper); color:#fff; border-color:var(--copper) }
.hero-pick:hover .hero-pick-cta::after { transform:translateX(3px) }

/* legacy hero-visual hidden so old "logo badge" block doesn't double up */
.hero-visual { display:none }

/* Affiliate disclosure */
.aff-bar {
  background:linear-gradient(180deg, var(--cream), var(--cream-2));
  border-bottom:1px solid var(--line);
  padding:14px 0;
  text-align:center;
  font-size:.82rem; color:var(--text-soft);
}
.aff-bar strong { color:var(--ink-2); font-weight:700 }
.aff-bar svg { display:inline-block; vertical-align:-3px; margin-right:6px; color:var(--copper-deep) }

/* =====================================================
   SECTION HEADINGS
   ===================================================== */
.section-head { text-align:center; margin-bottom:56px }
.section-head .kicker {
  font-family:var(--font-mono); font-size:.74rem;
  font-weight:600; letter-spacing:.3em; text-transform:uppercase;
  color:var(--copper-deep); margin-bottom:14px;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.section-head .kicker::before, .section-head .kicker::after {
  content:''; height:1px; width:32px;
  background:linear-gradient(90deg, transparent, var(--copper), transparent);
}
.section-head h2 {
  font-family:var(--font-display);
  font-size:clamp(1.9rem, 4vw, 2.7rem);
  font-weight:700;
  font-variation-settings:"opsz" 144;
  letter-spacing:-0.02em;
  color:var(--ink-2);
  line-height:1.12;
  margin-bottom:14px;
}
.section-head h2 em { font-style:italic; color:var(--copper-deep); font-weight:600 }
.section-head p {
  font-size:1.04rem; color:var(--text-soft);
  max-width:600px; margin:0 auto;
}
.section-head .divider { display:none }

/* =====================================================
   EDITOR'S TOP PICKS — magazine layout
   ===================================================== */
.featured-strip {
  background:
    radial-gradient(ellipse at 80% 10%, rgba(232,155,42,.06), transparent 60%),
    linear-gradient(180deg, var(--cream-2), var(--cream));
  padding:96px 0 100px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.featured-strip .section-head h2 { color:var(--ink-2) }
.featured-strip .section-head p { color:var(--text-soft) }

.featured-grid, .editor-picks {
  display:grid;
  grid-template-columns:1.55fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:24px;
}
.featured-card, .editor-pick {
  position:relative; overflow:hidden;
  background:var(--paper);
  border-radius:22px;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:transform .3s, box-shadow .3s, border-color .3s;
  display:flex; flex-direction:column;
  text-decoration:none; color:inherit;
}
.featured-card:hover, .editor-pick:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(232,155,42,.4); color:inherit; text-decoration:none }
.featured-card.lead, .editor-pick.lead {
  grid-row:1 / span 2;
  background:linear-gradient(165deg, var(--ink-2), var(--ink-1));
  color:#fff;
  border-color:rgba(232,155,42,.22);
}
.featured-card.lead:hover, .editor-pick.lead:hover { color:#fff; border-color:rgba(232,155,42,.55) }
.featured-img, .editor-pick-img {
  position:relative; width:100%; aspect-ratio:16/10;
  background:linear-gradient(135deg, var(--ink-3), var(--ink-2));
  overflow:hidden;
}
.featured-card.lead .featured-img, .editor-pick.lead .editor-pick-img { aspect-ratio:16/12 }
.featured-img img, .editor-pick-img img { width:100%; height:100%; object-fit:cover; transition:transform .55s }
.featured-card:hover .featured-img img, .editor-pick:hover .editor-pick-img img { transform:scale(1.05) }
.featured-img.no-img, .editor-pick-img.no-img { display:flex; align-items:center; justify-content:center; font-size:3rem; color:rgba(255,255,255,.18) }

.editor-pick-rank {
  position:absolute; top:18px; left:18px;
  display:flex; align-items:baseline; gap:6px;
  background:rgba(10,18,36,.78);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  border:1px solid rgba(232,155,42,.4);
  padding:8px 14px; border-radius:30px;
  color:var(--copper-light);
  font-family:var(--font-mono);
  font-size:.7rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
}
.editor-pick-rank b {
  font-family:var(--font-display); font-style:italic;
  font-size:1.25rem; line-height:1; color:#fff; font-weight:700;
}

.editor-pick-score-pill {
  position:absolute; top:18px; right:18px;
  background:#fff; color:var(--ink-2);
  padding:6px 12px; border-radius:8px;
  font-family:var(--font-mono); font-size:.78rem; font-weight:700;
  display:flex; align-items:center; gap:5px;
  box-shadow:var(--shadow-sm);
}
.editor-pick-score-pill::before { content:'★'; color:var(--copper) }

.featured-body, .editor-pick-body {
  padding:24px 26px 26px;
  flex:1; display:flex; flex-direction:column;
}
.featured-card.lead .featured-body, .editor-pick.lead .editor-pick-body { padding:32px 36px 36px }
.editor-pick-cat, .featured-cat {
  font-family:var(--font-mono); font-size:.66rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper-deep); margin-bottom:10px;
}
.editor-pick.lead .editor-pick-cat, .featured-card.lead .featured-cat { color:var(--copper-light) }
.editor-pick-title, .featured-title {
  font-family:var(--font-display);
  font-size:1.18rem; font-weight:700; line-height:1.22;
  color:var(--ink-2); margin-bottom:10px;
  font-variation-settings:"opsz" 80;
}
.editor-pick.lead .editor-pick-title, .featured-card.lead .featured-title { color:#fff; font-size:1.85rem; line-height:1.12; margin-bottom:14px }
.editor-pick-blurb, .featured-blurb {
  font-size:.92rem; color:var(--text-soft);
  line-height:1.6; margin-bottom:18px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.editor-pick.lead .editor-pick-blurb, .featured-card.lead .featured-blurb { color:rgba(255,255,255,.72); font-size:1.02rem; -webkit-line-clamp:3 }
.editor-pick-link, .featured-link {
  margin-top:auto;
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:.78rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--copper-deep); padding-top:14px;
  border-top:1px solid var(--line);
}
.editor-pick.lead .editor-pick-link, .featured-card.lead .featured-link { color:var(--copper-light); border-top-color:rgba(255,255,255,.12) }
.editor-pick-link::after, .featured-link::after { content:'→'; font-family:inherit }

/* legacy featured-rank (number badge in old top picks) hidden since lead now shows it */
.featured-rank {
  font-family:var(--font-mono); font-size:.66rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper-deep); margin-bottom:10px;
  display:block;
}
.featured-card.lead .featured-rank { color:var(--copper-light) }
.featured-stars { color:var(--copper); font-size:.88rem; margin-bottom:14px; letter-spacing:1.5px }
.featured-card.lead .featured-stars { color:var(--copper-light) }

@media(max-width:980px){
  .featured-grid, .editor-picks { grid-template-columns:1fr 1fr; }
  .featured-card.lead, .editor-pick.lead { grid-row:auto; grid-column:span 2 }
  .featured-card.lead .featured-title, .editor-pick.lead .editor-pick-title { font-size:1.4rem }
}
@media(max-width:600px){
  .featured-grid, .editor-picks { grid-template-columns:1fr; gap:18px }
  .featured-card.lead, .editor-pick.lead { grid-column:auto }
}

/* =====================================================
   ALL REVIEWS
   ===================================================== */
.content-with-sidebar { display:grid; grid-template-columns:1fr 320px; gap:48px; align-items:start }
@media(max-width:1080px){ .content-with-sidebar { grid-template-columns:1fr } .sidebar { display:none } }
.main-content { min-width:0 }

.filter-bar {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  margin-bottom:32px; padding:18px 22px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow-xs);
}
.filter-label {
  font-family:var(--font-mono);
  font-size:.7rem; font-weight:600; letter-spacing:.18em;
  color:var(--ink-4); text-transform:uppercase; white-space:nowrap;
}
.filter-select {
  padding:9px 14px; border:1.5px solid var(--line);
  border-radius:9px; font-size:.86rem;
  background:var(--cream); color:var(--text);
  cursor:pointer; font-family:var(--font-body);
  transition:border-color .18s, box-shadow .18s;
  appearance:auto;
}
.filter-select:focus { outline:none; border-color:var(--copper); box-shadow:0 0 0 3px var(--copper-soft) }
.filter-reset {
  background:none; border:1.5px solid var(--line);
  border-radius:9px; padding:8px 16px;
  font-size:.82rem; color:var(--ink-5);
  cursor:pointer; transition:all .18s;
  font-family:var(--font-body); font-weight:500;
}
.filter-reset:hover { border-color:var(--copper); color:var(--copper-deep); background:var(--copper-soft) }
.filter-results {
  font-size:.82rem; color:var(--muted); margin-left:auto; white-space:nowrap;
  font-family:var(--font-mono);
}

.products-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
@media(max-width:880px){ .products-grid { grid-template-columns:repeat(2, 1fr); gap:18px } }
@media(max-width:520px){ .products-grid { grid-template-columns:1fr; gap:14px } }

.product-card {
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  display:flex; flex-direction:column;
  transition:transform .3s, box-shadow .3s, border-color .3s;
  box-shadow:var(--shadow-xs);
}
.product-card:hover {
  transform:translateY(-5px);
  box-shadow:var(--shadow-md);
  border-color:rgba(232,155,42,.4);
  text-decoration:none; color:inherit;
}
.product-card.card-horizontal { flex-direction:column; max-height:none }
.card-img-wrap {
  position:relative;
  width:100%; aspect-ratio:16/11;
  overflow:hidden;
  background:linear-gradient(135deg, var(--cream-2), var(--line));
}
.card-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .5s }
.product-card:hover .card-img-wrap img { transform:scale(1.06) }
.card-img-wrap.no-img { display:flex; align-items:center; justify-content:center; font-size:3rem; color:rgba(255,255,255,.18); background:linear-gradient(135deg, var(--ink-2), var(--ink-3)) }
.card-img-wrap.no-img .card-img-placeholder { color:rgba(255,255,255,.18) }

.card-badge {
  position:absolute; top:14px; left:14px;
  background:rgba(255,255,255,.94);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  color:var(--ink-2); font-family:var(--font-mono);
  font-size:.66rem; font-weight:700; letter-spacing:.16em;
  padding:5px 11px; border-radius:30px;
  text-transform:uppercase;
  box-shadow:var(--shadow-xs);
}
.card-rating-badge {
  position:absolute; top:14px; right:14px;
  background:rgba(10,18,36,.82);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  color:var(--copper-light);
  font-family:var(--font-mono);
  font-size:.78rem; font-weight:700;
  padding:5px 10px; border-radius:8px;
  display:flex; align-items:center; gap:4px;
}
.card-rating-badge .si { color:var(--copper) }

.card-body {
  padding:20px 22px 22px;
  flex:1; display:flex; flex-direction:column;
}
.card-brand {
  font-family:var(--font-mono);
  font-size:.66rem; font-weight:600; letter-spacing:.22em;
  color:var(--copper-deep); text-transform:uppercase;
  margin-bottom:8px;
}
.card-title {
  font-family:var(--font-display);
  font-size:1.05rem; font-weight:700; line-height:1.28;
  color:var(--ink-2); margin-bottom:10px;
  font-variation-settings:"opsz" 80;
  letter-spacing:-0.005em;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.card-snippet {
  font-size:.86rem; color:var(--text-soft);
  line-height:1.6; margin-bottom:14px; flex:1;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.stars-row { display:flex; align-items:center; gap:8px; margin-bottom:14px }
.stars-char { color:var(--copper); font-size:.95rem; letter-spacing:1.5px }
.rating-num { font-family:var(--font-mono); font-weight:700; font-size:.84rem; color:var(--ink-2) }
.rating-count { font-size:.78rem; color:var(--muted) }

.btn-review-inline {
  display:inline-flex; align-items:center; gap:8px;
  align-self:flex-start;
  padding:10px 18px; border-radius:10px;
  background:var(--ink-2); color:#fff;
  font-size:.82rem; font-weight:600;
  font-family:var(--font-mono); letter-spacing:.06em;
  transition:background .18s, transform .12s;
  text-decoration:none;
}
.btn-review-inline:hover { background:var(--copper-deep); color:#fff; text-decoration:none; transform:translateX(2px) }
.btn-review { display:block; text-align:center; padding:12px 18px; border-radius:10px; background:var(--ink-2); color:#fff; font-weight:600; font-size:.85rem; transition:background .18s }
.btn-review:hover { background:var(--copper-deep); color:#fff; text-decoration:none }
.card-footer { padding:0 22px 22px }

.pagination { display:flex; justify-content:center; align-items:center; gap:8px; margin-top:48px; flex-wrap:wrap }
.page-btn {
  width:42px; height:42px;
  border:1.5px solid var(--line); background:var(--paper);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:.86rem; font-weight:600;
  cursor:pointer; transition:all .2s; color:var(--ink-3);
}
.page-btn:hover { border-color:var(--copper); color:var(--copper-deep) }
.page-btn.active { background:var(--ink-2); color:#fff; border-color:var(--ink-2) }
.page-btn.disabled { opacity:.3; pointer-events:none }
.page-nav { padding:0 18px; width:auto; font-size:.82rem }

.pg-empty { text-align:center; padding:56px 28px; background:var(--paper); border:1.5px dashed var(--line); border-radius:18px; color:var(--muted); font-size:.95rem; margin-top:24px }
.pg-empty-btn { background:var(--ink-2); color:#fff; border:none; border-radius:10px; padding:10px 20px; margin-left:12px; cursor:pointer; font-size:.85rem; font-weight:600 }

/* =====================================================
   SIDEBAR
   ===================================================== */
.sidebar { min-width:0 }
.sidebar-widget {
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow-xs);
  position:sticky; top:96px;
}
.sidebar-widget h3 {
  font-family:var(--font-display);
  font-size:1.08rem; font-weight:700;
  margin-bottom:18px; padding-bottom:14px;
  border-bottom:1px solid var(--line);
  color:var(--ink-2);
  display:flex; align-items:center; gap:10px;
  letter-spacing:-0.01em;
}
.sidebar-list { display:flex; flex-direction:column; gap:0 }
.sidebar-item {
  display:flex; gap:12px; align-items:center;
  padding:12px 0; border-bottom:1px dashed var(--line-2);
  color:inherit; text-decoration:none;
  transition:transform .18s;
}
.sidebar-item:last-child { border-bottom:none }
.sidebar-item:hover { transform:translateX(3px); text-decoration:none; color:inherit }
.sidebar-item:hover .sidebar-link { color:var(--copper-deep) }
.sidebar-rank {
  font-family:var(--font-display); font-style:italic;
  font-size:1.15rem; font-weight:700;
  color:var(--copper-deep);
  min-width:26px; text-align:center; flex-shrink:0;
}
.sidebar-img {
  width:54px; height:54px; object-fit:cover;
  border-radius:10px; flex-shrink:0;
  background:linear-gradient(135deg, var(--cream-2), var(--line));
  border:1px solid var(--line);
}
.sidebar-info { flex:1; min-width:0 }
.sidebar-name {
  font-size:.82rem; font-weight:600;
  color:var(--ink-2); line-height:1.34;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  margin-bottom:3px;
}
.sidebar-stars { color:var(--copper); font-size:.74rem; letter-spacing:1px }
.sidebar-link { font-size:.7rem; color:var(--ink-4); font-weight:600; display:block; margin-top:3px; font-family:var(--font-mono); letter-spacing:.08em; text-transform:uppercase }

/* =====================================================
   COMPARE TABLE
   ===================================================== */
.compare-section {
  background:linear-gradient(180deg, var(--cream), var(--cream-2));
  border-top:1px solid var(--line);
}
.compare-table-wrap {
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  border-radius:18px; border:1px solid var(--line);
  box-shadow:var(--shadow-sm); background:var(--paper);
}
.compare-table { width:100%; border-collapse:collapse; min-width:780px; background:var(--paper) }
.compare-table th {
  background:var(--ink-2); color:#fff;
  font-family:var(--font-mono); font-size:.7rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.16em;
  padding:18px 16px; text-align:left; white-space:nowrap;
}
.compare-table th:first-child { padding-left:24px }
.compare-table td { padding:18px 16px; border-bottom:1px solid var(--line-2); font-size:.88rem; vertical-align:middle }
.compare-table td:first-child { padding-left:24px }
.compare-table tr:last-child td { border-bottom:none }
.compare-table tr.compare-row { cursor:pointer; transition:background .15s }
.compare-table tr.compare-row:hover td { background:var(--copper-soft) }
.compare-rank { font-size:1.4rem; text-align:center }
.compare-img { width:60px; height:60px; object-fit:cover; border-radius:10px; border:1px solid var(--line) }
.compare-img.placeholder { background:linear-gradient(135deg, var(--ink-2), var(--ink-3)); display:flex; align-items:center; justify-content:center; font-size:1.6rem; opacity:.5; color:#fff }
.compare-name { font-family:var(--font-display); font-weight:700; font-size:.95rem; color:var(--ink-2); line-height:1.3; margin-bottom:4px }
.compare-brand-tag { font-family:var(--font-mono); font-size:.66rem; color:var(--copper-deep); font-weight:600; text-transform:uppercase; letter-spacing:.16em }
.compare-bar { height:6px; background:var(--line-2); border-radius:3px; margin-top:6px; overflow:hidden; max-width:120px }
.compare-bar-fill { height:100%; background:linear-gradient(90deg, var(--copper), var(--copper-deep)); border-radius:3px }
.compare-score { font-family:var(--font-mono); font-weight:700; color:var(--ink-2); font-size:1rem }
.compare-link {
  display:inline-block;
  background:var(--ink-2); color:#fff;
  padding:8px 16px; border-radius:9px;
  font-size:.78rem; font-weight:600; white-space:nowrap;
  font-family:var(--font-mono); letter-spacing:.06em;
  transition:background .18s;
}
.compare-link:hover { background:var(--copper-deep); color:#fff; text-decoration:none }

/* =====================================================
   PRODUCT PAGE
   ===================================================== */
.page-hero {
  background:linear-gradient(180deg, var(--ink-1), var(--ink-2));
  padding:32px 0 28px;
  border-bottom:1px solid rgba(232,155,42,.18);
}
.breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-mono);
  font-size:.74rem; color:rgba(255,255,255,.55);
  flex-wrap:wrap; letter-spacing:.06em;
}
.breadcrumb a { color:rgba(255,255,255,.78); transition:color .18s }
.breadcrumb a:hover { color:var(--copper-light); text-decoration:none }
.breadcrumb sep { color:rgba(255,255,255,.32); margin:0 4px }
.breadcrumb span:last-child { color:#fff }

.product-layout {
  display:grid; grid-template-columns:1.05fr 1fr; gap:64px;
  align-items:start; padding:60px 0 32px;
}
@media(max-width:980px){ .product-layout { grid-template-columns:1fr; gap:32px; padding:40px 0 24px } }

.gallery {
  display:flex; flex-direction:column; gap:14px;
  position:sticky; top:96px;
}
.gallery-main {
  border-radius:20px; overflow:hidden;
  box-shadow:var(--shadow-md);
  aspect-ratio:4/3;
  background:linear-gradient(135deg, var(--cream-2), var(--line));
  border:1px solid var(--line);
}
.gallery-main img { width:100%; height:100%; object-fit:cover }
.gallery-main.no-img { display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg, var(--ink-2), var(--ink-3)); font-size:5rem; color:rgba(255,255,255,.18) }
.gallery-thumbs { display:flex; gap:10px; flex-wrap:wrap }
.gallery-thumb {
  flex:0 0 auto; width:78px; height:78px;
  border-radius:10px; cursor:pointer;
  border:2px solid var(--line); transition:all .2s;
  opacity:.7; background:var(--cream-2);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.gallery-thumb img { max-width:100%; max-height:100%; object-fit:contain }
.gallery-thumb:hover, .gallery-thumb.active { opacity:1; border-color:var(--copper); box-shadow:0 0 0 3px var(--copper-soft) }

.product-info { padding-top:4px }
.p-brand {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--copper-soft);
  color:var(--copper-deep);
  font-family:var(--font-mono);
  font-size:.7rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  padding:6px 14px; border-radius:30px;
  margin-bottom:18px;
}
.p-title {
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 3.2vw, 2.2rem);
  font-weight:700; line-height:1.18;
  color:var(--ink-2);
  margin-bottom:18px;
  letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.p-rating { display:flex; align-items:center; gap:12px; margin-bottom:22px; flex-wrap:wrap }
.p-rating .stars-char { font-size:1.18rem; color:var(--copper); letter-spacing:2px }
.p-rating .score { font-family:var(--font-mono); font-size:1.05rem; font-weight:700; color:var(--ink-2) }
.p-rating .reviews-ct { font-size:.85rem; color:var(--muted) }

.score-bar-wrap {
  background:linear-gradient(135deg, var(--paper-warm), var(--cream-2));
  border:1px solid var(--line);
  border-radius:14px;
  padding:18px 22px;
  margin-bottom:24px;
}
.score-bar-label { display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:.74rem; color:var(--ink-4); margin-bottom:8px; letter-spacing:.12em; text-transform:uppercase }
.score-bar-track { height:10px; background:var(--line); border-radius:5px; overflow:hidden }
.score-bar-fill { height:100%; background:linear-gradient(90deg, var(--copper), var(--copper-deep)); border-radius:5px; box-shadow:0 0 12px rgba(232,155,42,.4) }

.verdict-box {
  background:
    radial-gradient(ellipse at 0% 0%, rgba(232,155,42,.08), transparent 60%),
    var(--paper-warm);
  border:1px solid var(--line);
  border-left:4px solid var(--copper);
  border-radius:14px;
  padding:22px 26px;
  margin-bottom:28px;
}
.verdict-label {
  font-family:var(--font-mono);
  font-size:.7rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  color:var(--copper-deep); margin-bottom:10px;
  display:flex; align-items:center; gap:8px;
}
.verdict-label::before { content:'✦'; color:var(--copper); font-size:.9rem }
.verdict-text { font-size:.96rem; color:var(--text); line-height:1.7 }

.cta-group { display:flex; gap:12px; margin-bottom:8px; flex-wrap:wrap }
.cta-disclosure { font-family:var(--font-mono); font-size:.72rem; color:var(--muted); margin:0 0 28px; line-height:1.55; letter-spacing:.04em }
.cta-disclosure::before { content:'ⓘ '; color:var(--copper-deep); font-style:normal }

.btn-buy {
  flex:1 1 220px; min-width:200px;
  display:flex; align-items:center; justify-content:center; gap:10px;
  background:linear-gradient(135deg, var(--copper), var(--copper-deep));
  color:#fff;
  padding:16px 26px;
  border-radius:12px;
  font-weight:700; font-size:.96rem; letter-spacing:.01em;
  box-shadow:0 12px 30px rgba(232,155,42,.32);
  transition:transform .18s, box-shadow .18s;
}
.btn-buy:hover { transform:translateY(-2px); box-shadow:0 18px 40px rgba(232,155,42,.45); color:#fff; text-decoration:none }
.btn-buy.alt { background:linear-gradient(135deg, var(--ink-2), var(--ink-3)); box-shadow:0 12px 30px rgba(15,26,46,.28) }
.btn-buy.alt:hover { box-shadow:0 18px 40px rgba(15,26,46,.4) }
.btn-buy.outline { background:transparent; color:var(--copper-deep); border:2px solid var(--copper); box-shadow:none }
.btn-buy.outline:hover { background:var(--copper); color:#fff; box-shadow:0 12px 30px rgba(232,155,42,.32) }
.btn-read-reviews {
  flex:1; min-width:160px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  background:var(--paper); color:var(--ink-2);
  padding:14px 22px; border-radius:12px;
  font-weight:600; font-size:.9rem;
  border:1.5px solid var(--line);
  transition:all .18s;
}
.btn-read-reviews:hover { border-color:var(--copper); color:var(--copper-deep); text-decoration:none; background:var(--copper-soft) }

.features-section-label {
  font-family:var(--font-mono);
  font-size:.74rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  color:var(--ink-4); margin-bottom:14px;
}
.features-list { list-style:none; display:flex; flex-direction:column; gap:11px }
.features-list li { display:flex; align-items:flex-start; gap:11px; font-size:.92rem; color:var(--text); line-height:1.55 }
.features-list li::before { content:'✓'; color:var(--copper); font-weight:800; flex-shrink:0; margin-top:1px; font-size:1rem }

.pros-cons { display:grid; grid-template-columns:1fr 1fr; gap:22px; margin:48px 0 }
@media(max-width:600px){ .pros-cons { grid-template-columns:1fr } }
.pros-box, .cons-box {
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:28px;
  box-shadow:var(--shadow-xs);
  position:relative;
  overflow:hidden;
}
.pros-box { border-top:4px solid var(--good) }
.cons-box { border-top:4px solid var(--bad) }
.box-head {
  font-family:var(--font-mono);
  font-size:.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  margin-bottom:18px;
  display:flex; align-items:center; gap:10px;
}
.pros-box .box-head { color:var(--good) }
.cons-box .box-head { color:var(--bad) }
.pros-box ul, .cons-box ul { list-style:none; display:flex; flex-direction:column; gap:12px }
.pros-box li, .cons-box li { display:flex; align-items:flex-start; gap:12px; font-size:.9rem; line-height:1.55; color:var(--text) }
.pros-box li::before { content:'+'; color:var(--good); font-weight:800; flex-shrink:0; font-size:1.05rem; width:18px; height:18px; background:rgba(21,128,61,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; line-height:1 }
.cons-box li::before { content:'−'; color:var(--bad); font-weight:800; flex-shrink:0; font-size:1.05rem; width:18px; height:18px; background:rgba(185,28,28,.10); border-radius:50%; display:flex; align-items:center; justify-content:center; line-height:1 }

.product-desc { margin:0 0 56px; max-width:880px }
.product-desc h2 {
  font-family:var(--font-display);
  font-size:1.6rem; font-weight:700;
  margin-bottom:24px; padding-bottom:16px;
  border-bottom:2px solid var(--line);
  color:var(--ink-2); letter-spacing:-0.01em;
  font-variation-settings:"opsz" 100;
}
.product-desc h2::before { content:'§ '; color:var(--copper); font-weight:600 }
.product-desc p { margin-bottom:18px; color:var(--text); font-size:.97rem; line-height:1.78 }

.reviews-section { margin:0 0 64px }
.reviews-section h2 {
  font-family:var(--font-display);
  font-size:1.6rem; font-weight:700;
  margin-bottom:32px; padding-bottom:16px;
  border-bottom:2px solid var(--line);
  letter-spacing:-0.01em;
  color:var(--ink-2);
}
.reviews-section h2::before { content:'❝ '; color:var(--copper); font-weight:600 }
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px }
.review-card {
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:16px;
  padding:24px;
  box-shadow:var(--shadow-xs);
  transition:transform .18s, box-shadow .18s;
}
.review-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-sm) }
.review-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:10px }
.reviewer-name { font-weight:700; font-size:.92rem; color:var(--ink-2) }
.review-date { font-family:var(--font-mono); font-size:.74rem; color:var(--muted); letter-spacing:.04em }
.review-stars { color:var(--copper); font-size:.92rem; margin-bottom:8px; letter-spacing:1.5px }
.review-title { font-family:var(--font-display); font-weight:700; font-size:.95rem; margin-bottom:10px; color:var(--ink-2); line-height:1.35 }
.review-text { font-size:.88rem; color:var(--text-soft); line-height:1.65 }

.related-section {
  background:linear-gradient(180deg, var(--cream-2), var(--cream));
  padding:80px 0;
  border-top:1px solid var(--line);
}
.related-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:8px }
@media(max-width:880px){ .related-grid { grid-template-columns:repeat(2,1fr) } }
@media(max-width:520px){ .related-grid { grid-template-columns:1fr } }
.related-card {
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  transition:transform .25s, box-shadow .25s, border-color .25s;
  display:block; color:inherit; text-decoration:none;
  box-shadow:var(--shadow-xs);
}
.related-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(232,155,42,.4); text-decoration:none; color:inherit }
.related-img { aspect-ratio:16/11; overflow:hidden; background:linear-gradient(135deg, var(--cream-2), var(--line)) }
.related-img img { width:100%; height:100%; object-fit:cover; transition:transform .35s }
.related-card:hover .related-img img { transform:scale(1.05) }
.related-img.no-img { display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg, var(--ink-2), var(--ink-3)); font-size:2rem; color:rgba(255,255,255,.18) }
.related-body { padding:18px 18px 16px }
.related-brand { font-family:var(--font-mono); font-size:.66rem; font-weight:600; letter-spacing:.18em; color:var(--copper-deep); text-transform:uppercase; margin-bottom:6px }
.related-title { font-family:var(--font-display); font-size:.92rem; font-weight:700; color:var(--ink-2); line-height:1.32; margin-bottom:8px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden }
.related-stars { color:var(--copper); font-size:.82rem; letter-spacing:1.5px; margin-bottom:12px }
.related-link {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-mono);
  font-size:.74rem; font-weight:600;
  color:var(--ink-3); letter-spacing:.16em;
  text-transform:uppercase;
}
.related-card:hover .related-link { color:var(--copper-deep) }

/* =====================================================
   STATIC PAGES
   ===================================================== */
.static-hero {
  background:linear-gradient(135deg, var(--ink-1), var(--ink-2));
  padding:72px 0 64px;
  border-bottom:1px solid rgba(232,155,42,.18);
  position:relative; overflow:hidden;
}
.static-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 80% 50%, rgba(232,155,42,.12), transparent 60%);
  pointer-events:none;
}
.static-hero h1 {
  position:relative;
  font-family:var(--font-display);
  font-size:clamp(2rem, 4.4vw, 3rem);
  color:#fff; font-weight:700;
  letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.static-hero h1 em { font-style:italic; color:var(--copper-light); font-weight:600 }
.static-hero p { position:relative; color:rgba(255,255,255,.78); font-size:1.05rem; margin-top:14px; max-width:620px }

.static-content {
  max-width:820px; margin:0 auto;
  padding:64px 28px 96px;
  font-size:1rem;
}
.static-content h2 {
  font-family:var(--font-display);
  font-size:1.55rem; font-weight:700;
  margin:44px 0 16px;
  color:var(--ink-2);
  letter-spacing:-0.01em;
}
.static-content h2:first-child { margin-top:0 }
.static-content p { margin-bottom:18px; line-height:1.78; color:var(--text); font-size:1rem }
.static-content ul { margin:14px 0 24px 24px; display:flex; flex-direction:column; gap:9px; font-size:.97rem }
.static-content strong { color:var(--ink-2); font-weight:700 }
.static-content em { color:var(--copper-deep); font-style:italic }

.about-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin:40px 0 }
@media(max-width:780px){ .about-grid { grid-template-columns:1fr } }
.about-card {
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:30px 26px;
  text-align:left;
  box-shadow:var(--shadow-xs);
  transition:transform .25s, box-shadow .25s;
}
.about-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md) }
.about-icon {
  width:48px; height:48px; border-radius:12px;
  background:linear-gradient(135deg, var(--copper-soft), rgba(232,155,42,.04));
  border:1px solid rgba(232,155,42,.28);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; margin-bottom:18px;
}
.about-card h3 { font-family:var(--font-display); font-size:1.1rem; font-weight:700; margin-bottom:10px; color:var(--ink-2); letter-spacing:-0.01em }
.about-card p { font-size:.9rem; color:var(--text-soft); line-height:1.65 }

/* =====================================================
   COOKIE BANNER
   ===================================================== */
#cookie-banner {
  position:fixed; bottom:18px; left:18px; right:18px;
  z-index:9999; max-width:540px; margin:0 auto;
  background:linear-gradient(135deg, var(--ink-1), var(--ink-2));
  border:1px solid rgba(232,155,42,.32);
  border-radius:18px; padding:18px 22px;
  box-shadow:0 30px 60px rgba(0,0,0,.4);
  transform:translateY(calc(100% + 28px)); transition:transform .45s ease;
}
#cookie-banner.visible { transform:translateY(0) }
.cookie-inner { display:flex; align-items:center; gap:18px; flex-wrap:wrap }
.cookie-text { flex:1; font-size:.84rem; color:rgba(255,255,255,.85); min-width:200px; line-height:1.55 }
.cookie-text a { color:var(--copper-light); font-weight:600 }
.cookie-text strong { color:#fff }
.cookie-btns { display:flex; gap:10px; flex-shrink:0 }
.cookie-accept { background:linear-gradient(135deg, var(--copper), var(--copper-deep)); color:#fff; border:none; padding:10px 22px; border-radius:9px; font-size:.85rem; font-weight:700; cursor:pointer; transition:transform .15s, box-shadow .15s; box-shadow:0 8px 22px rgba(232,155,42,.32) }
.cookie-accept:hover { transform:translateY(-1px) }
.cookie-decline { background:transparent; color:rgba(255,255,255,.7); border:1px solid rgba(255,255,255,.2); padding:9px 18px; border-radius:9px; font-size:.85rem; cursor:pointer; transition:all .18s }
.cookie-decline:hover { border-color:rgba(255,255,255,.5); color:#fff }

/* =====================================================
   FOOTER
   ===================================================== */
footer {
  background:linear-gradient(180deg, var(--ink-1), #060d1c);
  color:rgba(255,255,255,.7);
  padding:80px 0 32px;
  position:relative;
  border-top:1px solid rgba(232,155,42,.2);
}
footer::before {
  content:''; position:absolute; left:0; right:0; top:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--copper), transparent);
}
.footer-grid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:48px; margin-bottom:56px }
@media(max-width:980px){ .footer-grid { grid-template-columns:1fr 1fr; gap:36px } .footer-brand { grid-column:span 2 } }
@media(max-width:560px){ .footer-grid { grid-template-columns:1fr } .footer-brand { grid-column:auto } }

.footer-brand .footer-logo { display:flex; align-items:center; gap:14px; margin-bottom:16px; color:#fff; font-family:var(--font-display) }
.footer-logo-mark, .footer-logo-img-wrap {
  width:44px; height:44px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, rgba(232,155,42,.16), rgba(232,155,42,.04));
  border:1px solid rgba(232,155,42,.32);
  border-radius:11px;
}
.footer-logo-mark img, .footer-logo-img { width:28px; height:28px; object-fit:contain; background:transparent; padding:0; border-radius:0 }
.footer-logo-text { display:flex; flex-direction:column; line-height:1; gap:5px }
.footer-logo-name { font-family:var(--font-display); font-size:1.3rem; font-weight:800; color:#fff; letter-spacing:-0.02em }
.footer-logo-tag { font-family:var(--font-mono); font-size:.6rem; letter-spacing:.32em; color:var(--copper-light); text-transform:uppercase }
.footer-brand p { font-size:.88rem; line-height:1.7; color:rgba(255,255,255,.62); max-width:340px }
.footer-disclaimer {
  margin-top:18px; padding:14px 16px;
  font-size:.78rem; color:rgba(255,255,255,.5);
  line-height:1.6;
  background:rgba(255,255,255,.03);
  border-left:3px solid var(--copper);
  border-radius:0 8px 8px 0;
}
footer h4 {
  color:#fff;
  font-family:var(--font-mono);
  font-size:.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  margin-bottom:18px;
  position:relative; padding-bottom:10px;
}
footer h4::after { content:''; position:absolute; left:0; bottom:0; width:24px; height:2px; background:var(--copper) }
footer ul { list-style:none; display:flex; flex-direction:column; gap:11px }
footer ul li a { color:rgba(255,255,255,.68); font-size:.88rem; transition:color .18s, transform .18s; display:inline-block }
footer ul li a:hover { color:var(--copper-light); text-decoration:none; transform:translateX(3px) }

.footer-bottom {
  border-top:1px solid rgba(255,255,255,.10);
  padding-top:28px;
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:14px;
  font-family:var(--font-mono);
  font-size:.78rem; color:rgba(255,255,255,.42);
  letter-spacing:.06em;
}
.footer-bottom a { color:rgba(255,255,255,.62) }
.footer-bottom a:hover { color:var(--copper-light); text-decoration:none }

/* Ad placement */
.ad-placement { margin:48px auto; text-align:center }
.ad-placement-inner { display:inline-flex; gap:18px; justify-content:center; flex-wrap:wrap }
.ad-unit { width:300px; height:250px; background:transparent; border:1px dashed rgba(15,26,46,.10); border-radius:8px }

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media(max-width:1020px){
  .hero-content-split, .hero-content { grid-template-columns:1fr; gap:42px; padding:80px 0 110px }
  .hero-pick { transform:none; max-width:520px; margin:0 auto }
  .hero-pick:hover { transform:translateY(-4px) }
}
@media(max-width:768px){
  .header-inner { height:60px; gap:12px; padding:0 4px }
  .brand { gap:10px }
  .brand-name { font-size:1.1rem; letter-spacing:-0.02em }
  .brand-tag { font-size:.52rem; letter-spacing:.26em }
  .brand-mark { width:36px; height:36px; border-radius:10px }
  .brand-mark img { width:22px; height:22px }
  .brand-mark::after { width:6px; height:6px; right:-1px; top:-1px }
  .container { padding:0 18px }
  .section { padding:60px 0 }
  .featured-strip { padding:64px 0 }
  .related-section { padding:60px 0 }

  /* HERO — mobile rebuild */
  .hero::after { height:60px }
  .hero-bg { background-position:center center; opacity:.35 }
  .hero-overlay {
    background:
      radial-gradient(ellipse at 50% 0%, rgba(232,155,42,.18), transparent 65%),
      linear-gradient(180deg, rgba(10,18,36,.92) 0%, rgba(10,18,36,.78) 60%, rgba(10,18,36,.92) 100%);
  }
  .hero-content-split, .hero-content {
    padding:48px 0 60px; gap:30px;
    grid-template-columns:1fr;
  }
  .hero-text { max-width:none }
  .hero-eyebrow, .hero-badge {
    font-size:.56rem; letter-spacing:.22em;
    padding:5px 11px; gap:7px; margin-bottom:18px;
  }
  .hero-eyebrow::before, .hero-badge::before { width:5px; height:5px }
  .hero h1 {
    font-size:clamp(1.85rem, 8.6vw, 2.4rem);
    line-height:1.08;
    margin-bottom:16px;
    letter-spacing:-0.025em;
  }
  .hero p {
    font-size:.96rem; line-height:1.6;
    margin-bottom:24px;
    color:rgba(255,255,255,.78);
  }
  .hero-actions { gap:10px; margin-bottom:24px }
  .btn-hero { padding:13px 22px; font-size:.88rem; flex:1 1 auto; justify-content:center }
  .btn-hero.primary, .btn-hero.ghost { min-width:0 }

  /* Brand chips strip on mobile */
  .hero-brands { padding-top:20px; gap:10px }
  .hero-brands-label { font-size:.6rem; letter-spacing:.24em }
  .hero-brands-list { gap:6px }
  .hero-brands-list li { font-size:.78rem; padding:4px 10px }

  /* Editor's Choice card on mobile — clean tilted-free vertical card */
  .hero-pick {
    transform:none !important;
    max-width:none; margin:0;
    padding:18px;
    border-radius:18px;
  }
  .hero-pick:hover { transform:none }
  .hero-pick-tag { left:18px; padding:6px 11px; font-size:.6rem; letter-spacing:.18em; top:-13px }
  .hero-pick-img { aspect-ratio:16/10; margin-bottom:14px; border-radius:12px }
  .hero-pick-rank { font-size:1.8rem; top:10px; left:12px }
  .hero-pick-score { font-size:.7rem; padding:5px 10px; bottom:10px; right:10px }
  .hero-pick-cat { font-size:.6rem; letter-spacing:.2em }
  .hero-pick-name { font-size:1.12rem; margin-bottom:10px }
  .hero-pick-stars { font-size:.85rem; margin-bottom:12px }
  .hero-pick-cta { padding:10px 14px; font-size:.78rem }

  /* general */
  .hero h1 em, .hero h1 span { display:inline }
  .product-layout { gap:28px; padding:32px 0 20px }
  .footer-grid { gap:32px }
  .nav-toggle { display:flex }
  header nav {
    display:none !important;
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch;
    gap:4px; background:var(--ink-1);
    padding:16px 18px 22px;
    box-shadow:0 16px 40px rgba(0,0,0,.4);
    z-index:199;
    border-top:1px solid rgba(232,155,42,.2);
  }
  header.nav-open nav { display:flex !important }
  header nav a { padding:13px 16px; font-size:.96rem; border-radius:9px }
  .nav-cta { margin-left:0 }
}
@media(max-width:420px){
  .header-inner { height:56px }
  .brand-name { font-size:1.02rem }
  .brand-tag { display:none }
  .brand-mark { width:34px; height:34px }
  .hero h1 { font-size:1.78rem }
  .hero-content-split, .hero-content { padding:36px 0 52px }
}
@media(max-width:480px){
  .gallery { position:static }
  .compare-table th, .compare-table td { padding:14px 12px }
  .static-content { padding:48px 22px 72px }
}
@media(max-width:520px){
  .products-grid .product-card { flex-direction:row !important; max-height:none }
  .products-grid .product-card .card-img-wrap { width:140px !important; min-width:140px !important; aspect-ratio:1/1; flex-shrink:0 }
  .products-grid .product-card .card-img-wrap img { width:100% !important; height:100% !important; object-fit:cover }
  .products-grid .product-card .card-body { padding:14px 16px !important; display:flex; flex-direction:column; justify-content:center }
  .products-grid .product-card .card-snippet { display:none }
  .products-grid .product-card .card-footer { padding:8px 0 0 !important }
}
