@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700;9..144,800&family=Inter:wght@400;500;600;700;800&display=swap');

/* ==========================================================================
   Zip & Style — Editorial Design System
   ========================================================================== */

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

:root{
  /* Editorial palette: ink, cream, cognac brass */
  --ink:#1a1d24;
  --ink-2:#2a2e38;
  --ink-3:#4a4e58;
  --paper:#fbf8f1;
  --paper-2:#f4eee2;
  --paper-3:#ebe3d1;
  --line:#e1d8c5;
  --line-soft:#f0e9d9;
  --brass:#a87c4f;
  --brass-2:#b88a5d;
  --brass-light:#d6b285;
  --champagne:#e8d4ae;
  --terracotta:#b86a47;
  --olive:#7a7a4d;
  --burgundy:#7a3433;

  --text:#1a1d24;
  --text-2:#3a3e48;
  --muted:#6b6f7a;
  --bg:#fbf8f1;
  --surface:#ffffff;
  --surface-2:#f4eee2;

  --radius-xs:4px;
  --radius-sm:8px;
  --radius:14px;
  --radius-lg:22px;

  --shadow-xs:0 1px 2px rgba(26,29,36,.04);
  --shadow-sm:0 4px 14px rgba(26,29,36,.06);
  --shadow:0 10px 32px rgba(26,29,36,.08);
  --shadow-lg:0 24px 60px rgba(26,29,36,.14);

  --font-display:'Fraunces','Cormorant Garamond','Playfair Display',serif;
  --font:'Inter','Helvetica Neue',Arial,sans-serif;

  --container:1240px;
  --header-h:84px;
}

/* ==========================================================================
   Base
   ========================================================================== */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--paper);
  color:var(--text);
  line-height:1.65;
  font-size:16px;
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
::selection{background:var(--brass);color:#fff}
img{max-width:100%;display:block}
a{color:var(--ink);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--brass)}

.container{max-width:var(--container);margin:0 auto;padding:0 28px}

.section{padding:96px 0}
.section-sm{padding:56px 0}
.section-tight{padding:48px 0}

/* Editorial section headings */
.section-head{text-align:center;margin-bottom:64px;position:relative}
.section-eyebrow{display:inline-block;font-size:.74rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);margin-bottom:14px}
.section-head h2{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2rem,3.6vw,3rem);
  letter-spacing:-.02em;
  line-height:1.05;
  color:var(--ink);
  margin-bottom:14px;
  font-variation-settings:"opsz" 144;
}
.section-head h2 em{font-style:italic;font-weight:500;color:var(--brass-2)}
.section-head p{color:var(--muted);font-size:1.05rem;max-width:600px;margin:0 auto;line-height:1.7}
.section-head .ornament{display:flex;align-items:center;justify-content:center;gap:14px;margin:22px auto 0}
.section-head .ornament::before,.section-head .ornament::after{content:"";display:block;width:48px;height:1px;background:linear-gradient(90deg,transparent,var(--brass),transparent)}
.section-head .ornament span{display:block;width:6px;height:6px;border-radius:50%;background:var(--brass);box-shadow:0 0 0 4px rgba(168,124,79,.12)}
.section-head .divider{display:none}

/* ==========================================================================
   Header — editorial masthead
   ========================================================================== */
header{
  position:sticky;top:0;z-index:200;
  background:rgba(251,248,241,.86);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s ease,background .3s ease;
}
header.scrolled{box-shadow:0 4px 24px rgba(26,29,36,.06);background:rgba(251,248,241,.95)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:32px}

.brand{display:flex;align-items:center;gap:14px;color:var(--ink);text-decoration:none}
.brand:hover{color:var(--ink)}
.brand-mono{
  width:46px;height:46px;
  display:grid;place-items:center;
  border-radius:12px;
  background:linear-gradient(135deg,#fffaee 0%,#f1e6cc 100%);
  border:1px solid var(--champagne);
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 4px 12px rgba(168,124,79,.18);
  flex-shrink:0;
  overflow:hidden;
}
.brand-mono img{width:80%;height:80%;object-fit:contain;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.45rem;
  letter-spacing:-.01em;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.brand-name em{font-style:italic;font-weight:500;color:var(--brass)}
.brand-tag{
  font-family:var(--font);
  font-size:.62rem;
  font-weight:600;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--brass);
  margin-top:4px;
}

/* Primary nav */
nav.primary-nav{display:flex;align-items:center;gap:6px}
nav.primary-nav a{
  position:relative;
  color:var(--ink-2);
  font-family:var(--font);
  font-size:.88rem;
  font-weight:500;
  letter-spacing:.02em;
  padding:10px 14px;
  border-radius:8px;
  transition:color .18s ease,background .18s ease;
}
nav.primary-nav a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:6px;height:1px;
  background:var(--brass);transform:scaleX(0);transform-origin:left center;transition:transform .25s ease;
}
nav.primary-nav a:hover{color:var(--ink)}
nav.primary-nav a:hover::after{transform:scaleX(1)}
nav.primary-nav a.is-active{color:var(--ink)}
nav.primary-nav a.is-active::after{transform:scaleX(1)}

nav.primary-nav .nav-cta{
  background:var(--ink);color:#fffaee;font-weight:600;
  padding:11px 20px;border-radius:999px;margin-left:10px;
  letter-spacing:.04em;font-size:.82rem;text-transform:uppercase;
}
nav.primary-nav .nav-cta::after{display:none}
nav.primary-nav .nav-cta:hover{background:var(--brass);color:#fff}

/* Hamburger */
.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:26px;height:2px;background:var(--ink);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 — editorial split with featured logo
   ========================================================================== */
.hero{
  position:relative;
  background:var(--paper);
  padding:80px 0 100px;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 50% at 90% 10%,rgba(168,124,79,.10),transparent 60%),
    radial-gradient(50% 40% at 5% 90%,rgba(184,106,71,.06),transparent 60%);
  pointer-events:none;
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.05fr .95fr;gap:72px;
  align-items:center;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--brass);
  margin-bottom:24px;
}
.hero-eyebrow::before{content:"";width:32px;height:1px;background:var(--brass);display:block}
.hero h1{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2.4rem,5.4vw,4.4rem);
  line-height:1.02;
  letter-spacing:-.025em;
  color:var(--ink);
  margin-bottom:24px;
  font-variation-settings:"opsz" 144;
}
.hero h1 em{font-style:italic;font-weight:500;color:var(--brass)}
.hero-lede{
  font-size:1.15rem;line-height:1.65;color:var(--text-2);
  max-width:520px;margin-bottom:36px;
}
.hero-cta-row{display:flex;align-items:center;gap:18px;margin-bottom:48px;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--ink);color:#fffaee;
  padding:16px 30px;border-radius:999px;
  font-family:var(--font);font-weight:600;font-size:.92rem;letter-spacing:.03em;
  border:1px solid var(--ink);
  transition:transform .2s ease,background .2s ease,box-shadow .2s ease;
}
.btn-primary:hover{background:var(--brass);border-color:var(--brass);color:#fff;transform:translateY(-2px);box-shadow:0 14px 30px rgba(168,124,79,.32)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:var(--ink);
  padding:14px 26px;border-radius:999px;
  font-weight:500;font-size:.92rem;letter-spacing:.02em;
  border:1px solid var(--ink-2);
  transition:background .2s ease,color .2s ease;
}
.btn-secondary:hover{background:var(--ink);color:var(--paper)}

/* Hero pillars (replaces stats block) */
.hero-pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin-top:8px;
  border-top:1px solid var(--line);
}
.hero-pillar{padding:24px 22px 4px 0;position:relative}
.hero-pillar+.hero-pillar{padding-left:26px}
.hero-pillar+.hero-pillar::before{
  content:"";position:absolute;left:0;top:24px;bottom:8px;width:1px;
  background:linear-gradient(180deg,var(--line),transparent);
}
.hero-pillar-icon{
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#fff,#f5ecd9);
  border:1px solid var(--champagne);
  margin-bottom:14px;
  color:var(--brass);
  font-size:1rem;
  box-shadow:0 4px 10px rgba(168,124,79,.15);
}
.hero-pillar-icon svg{width:18px;height:18px}
.hero-pillar-title{
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  letter-spacing:-.01em;color:var(--ink);margin-bottom:4px;
}
.hero-pillar-text{font-size:.85rem;color:var(--muted);line-height:1.55}

/* Hero visual — decorated logo display */
.hero-visual{position:relative;display:grid;place-items:center;min-height:520px}
.hero-visual::before{
  content:"";position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,250,238,.95), rgba(244,238,226,.4) 50%, transparent 75%);
  z-index:0;
}
.hero-stage{
  position:relative;z-index:2;
  width:min(100%,460px);aspect-ratio:1/1;
  display:grid;place-items:center;
}
.hero-stage::before{
  content:"";position:absolute;inset:18px;border-radius:50%;
  border:1px dashed rgba(168,124,79,.45);
  animation:rotate 60s linear infinite;
}
.hero-stage::after{
  content:"";position:absolute;inset:60px;border-radius:50%;
  background:linear-gradient(135deg,#fffaee 0%,#f5e9d2 100%);
  border:1px solid var(--champagne);
  box-shadow:0 30px 80px rgba(168,124,79,.22),0 0 0 8px rgba(255,250,238,.6);
}
.hero-stage img{
  position:relative;z-index:3;
  width:62%;height:62%;object-fit:contain;
  filter:drop-shadow(0 10px 28px rgba(168,124,79,.28));
}
@keyframes rotate{to{transform:rotate(360deg)}}

/* Floating ornaments around the logo */
.hero-orb{
  position:absolute;z-index:4;
  background:linear-gradient(135deg,#fff,#fff3dc);
  border:1px solid var(--champagne);
  border-radius:14px;
  padding:14px 18px;
  box-shadow:0 18px 40px rgba(26,29,36,.10);
  font-family:var(--font);font-size:.78rem;
  display:flex;align-items:center;gap:10px;
}
.hero-orb-1{top:20px;left:0;animation:float 8s ease-in-out infinite}
.hero-orb-2{bottom:32px;right:0;animation:float 8s ease-in-out -4s infinite}
.hero-orb-3{top:48%;right:-8px;animation:float 7s ease-in-out -2s infinite;padding:10px 16px}
.hero-orb-icon{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--brass),var(--brass-light));
  display:grid;place-items:center;color:#fff;
  box-shadow:0 4px 10px rgba(168,124,79,.3);
  flex-shrink:0;
}
.hero-orb-title{
  font-family:var(--font-display);font-weight:600;
  font-size:.92rem;line-height:1.05;color:var(--ink);
  letter-spacing:-.005em;
}
.hero-orb-label{
  display:block;font-size:.62rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);margin-top:4px;
}
.hero-orb-est{
  font-family:var(--font);font-weight:700;font-size:.74rem;
  letter-spacing:.24em;color:var(--ink);
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ==========================================================================
   Affiliate disclosure bar
   ========================================================================== */
.aff-bar{
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
  padding:14px 0;
  text-align:center;
  font-size:.84rem;color:var(--ink-3);
  letter-spacing:.01em;
}
.aff-bar strong{color:var(--ink);font-weight:600}
.aff-bar svg{display:inline-block;vertical-align:-3px;margin-right:8px;color:var(--brass)}

/* ==========================================================================
   Editor's Top Picks — Magazine podium
   ========================================================================== */
.featured-strip{
  padding:96px 0 88px;
  background:linear-gradient(180deg,var(--paper) 0%,#f8f3e7 100%);
  position:relative;
}
.featured-strip::before,.featured-strip::after{
  content:"";position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);
}
.featured-strip::before{top:0}.featured-strip::after{bottom:0}

.podium{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:32px;
  margin-top:8px;
}
.podium-feature{
  position:relative;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .35s ease,box-shadow .35s ease;
  display:flex;flex-direction:column;
}
.podium-feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.podium-feature-img{
  position:relative;
  aspect-ratio:16/10;overflow:hidden;background:var(--paper-2);
}
.podium-feature-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.podium-feature:hover .podium-feature-img img{transform:scale(1.05)}
.medal{
  position:absolute;top:24px;left:24px;
  display:flex;align-items:center;gap:10px;
  background:rgba(26,29,36,.92);
  backdrop-filter:blur(8px);
  color:#fff;
  padding:10px 18px;border-radius:999px;
  font-family:var(--font);font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
}
.medal-1{background:linear-gradient(135deg,#a87c4f,#c79a64);box-shadow:0 8px 20px rgba(168,124,79,.4)}
.medal-2{background:linear-gradient(135deg,#5d6168,#8a8e96)}
.medal-3{background:linear-gradient(135deg,#7c5933,#a07a4f)}
.medal-num{
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;
  letter-spacing:0;
}
.podium-feature-body{padding:32px 36px 36px;display:flex;flex-direction:column;flex:1}
.podium-feature-brand{font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:10px}
.podium-feature-title{
  font-family:var(--font-display);font-weight:600;font-size:1.65rem;line-height:1.15;
  letter-spacing:-.018em;color:var(--ink);margin-bottom:16px;
}
.podium-feature-rating{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.podium-feature-rating .stars-char{color:var(--brass);font-size:1.05rem;letter-spacing:2px}
.podium-feature-rating .score{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink)}
.podium-feature-pull{
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:1.05rem;line-height:1.55;color:var(--text-2);
  border-left:2px solid var(--brass);
  padding:6px 0 6px 18px;margin-bottom:24px;
}
.podium-feature-link{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:auto;align-self:flex-start;
  font-family:var(--font);font-size:.85rem;font-weight:600;letter-spacing:.04em;
  color:var(--ink);padding-bottom:4px;border-bottom:1px solid var(--ink);
  transition:gap .2s ease,color .2s ease,border-color .2s ease;
}
.podium-feature-link:hover{gap:14px;color:var(--brass);border-color:var(--brass)}

.podium-rest{display:grid;grid-template-rows:1fr 1fr;gap:24px}
.podium-card{
  position:relative;
  display:grid;grid-template-columns:.95fr 1.05fr;gap:0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .3s ease,box-shadow .3s ease;
}
.podium-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.podium-card-img{
  position:relative;
  background:var(--paper-2);
  overflow:hidden;
}
.podium-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.podium-card:hover .podium-card-img img{transform:scale(1.06)}
.podium-card-body{padding:28px 30px;display:flex;flex-direction:column;justify-content:center}
.podium-card-rank{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font);font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);margin-bottom:10px;
}
.podium-card-rank b{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);font-weight:700;letter-spacing:0}
.podium-card-brand{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.podium-card-title{
  font-family:var(--font-display);font-weight:600;font-size:1.18rem;line-height:1.25;
  color:var(--ink);margin-bottom:10px;letter-spacing:-.012em;
}
.podium-card-rating{display:flex;align-items:center;gap:10px}
.podium-card-rating .stars-char{color:var(--brass);font-size:.92rem;letter-spacing:1.2px}
.podium-card-rating .score{font-weight:600;color:var(--ink);font-size:.88rem}
.podium-card-link{margin-top:14px;font-size:.82rem;font-weight:500;color:var(--brass);display:inline-flex;align-items:center;gap:6px;letter-spacing:.02em}
.podium-card-link::after{content:"→";transition:transform .2s ease}
.podium-card:hover .podium-card-link::after{transform:translateX(4px)}

/* ==========================================================================
   Reviews / Product grid
   ========================================================================== */
.content-with-sidebar{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;align-items:flex-start}
.main-content{min-width:0}

/* Filter bar */
.filter-bar{
  display:flex;align-items:center;flex-wrap:wrap;gap:14px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px 22px;
  margin-bottom:28px;
  box-shadow:var(--shadow-xs);
}
.filter-label{
  font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
}
.filter-select{
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--line);
  border-radius:8px;
  padding:9px 30px 9px 14px;
  font-family:var(--font);font-size:.86rem;font-weight:500;
  cursor:pointer;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%231a1d24' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  transition:border-color .2s ease;
}
.filter-select:hover{border-color:var(--brass)}
.filter-select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(168,124,79,.18)}
.filter-reset{
  background:transparent;color:var(--ink);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 16px;
  font-size:.82rem;font-weight:500;cursor:pointer;
  transition:all .2s ease;
}
.filter-reset:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.filter-results{margin-left:auto;font-size:.82rem;color:var(--muted)}

/* Product cards
 * 4 cols on desktop, 3 mid, 2 small, 1 tiny.
 * Combined with perPage=12 in script.js this means:
 *   - 4 cols × 3 rows = 12 per page (clean)
 *   - 3 cols × 4 rows = 12 per page (clean)
 *   - 2 cols × 6 rows = 12 per page (clean)
 *   - 52 total / 12 per page = 4 full pages + 1 page of 4 items (= exactly 1 row at 4 cols).
 */
.products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
@media(min-width:1180px){.products-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:880px) and (max-width:1179px){.products-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:540px) and (max-width:879px){.products-grid{grid-template-columns:repeat(2,1fr)}}

.product-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;flex-direction:column;
  color:inherit;
  text-decoration:none;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.product-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:var(--brass-light);
  text-decoration:none;color:inherit;
}
.card-img-wrap{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:linear-gradient(135deg,#f4eee2,#ebe3d1);
}
.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.product-card:hover .card-img-wrap img{transform:scale(1.06)}
.card-img-wrap.no-img{display:flex;align-items:center;justify-content:center}
.card-img-placeholder{font-size:3.2rem;opacity:.35;filter:grayscale(.4)}
.card-badge{
  position:absolute;top:14px;left:14px;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(6px);
  color:var(--ink);font-size:.66rem;font-weight:700;
  padding:6px 12px;border-radius:999px;
  letter-spacing:.16em;text-transform:uppercase;
}
.card-rating-badge{
  position:absolute;top:14px;right:14px;
  background:var(--ink);color:#fffaee;
  font-family:var(--font-display);font-weight:600;font-size:.86rem;
  padding:6px 12px;border-radius:999px;
  display:flex;align-items:center;gap:5px;
}
.card-rating-badge .si{color:var(--brass-light);font-family:var(--font);font-size:.85rem}
.card-body{padding:22px 24px 16px;flex:1;display:flex;flex-direction:column}
.card-brand{
  font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:8px;
}
.card-title{
  font-family:var(--font-display);font-weight:600;font-size:1.08rem;line-height:1.3;
  color:var(--ink);margin-bottom:10px;letter-spacing:-.012em;
}
.stars-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.stars-char{color:var(--brass);font-size:.92rem;letter-spacing:1.2px}
.rating-num{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--ink)}
.rating-count{font-size:.78rem;color:var(--muted)}
.card-snippet{font-size:.88rem;color:var(--text-2);line-height:1.62;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-footer{
  padding:14px 24px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.btn-review{
  font-family:var(--font);font-size:.84rem;font-weight:600;letter-spacing:.04em;
  color:var(--ink);position:relative;padding-bottom:3px;
  border-bottom:1px solid var(--ink);
  transition:color .2s ease,border-color .2s ease;
}
.product-card:hover .btn-review{color:var(--brass);border-color:var(--brass)}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:48px;flex-wrap:wrap}
.page-btn{
  background:var(--surface);color:var(--ink);
  border:1px solid var(--line);
  border-radius:999px;
  min-width:40px;height:40px;padding:0 14px;
  font-family:var(--font);font-size:.88rem;font-weight:500;
  cursor:pointer;transition:all .2s ease;
}
.page-btn:hover:not(.disabled){background:var(--ink);color:var(--paper);border-color:var(--ink)}
.page-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink);font-weight:600}
.page-btn.disabled{opacity:.4;cursor:not-allowed}
.page-nav{font-weight:500}
.pg-empty{
  text-align:center;padding:48px 24px;
  background:var(--paper-2);border:1px dashed var(--line);
  border-radius:var(--radius);color:var(--muted);font-size:.95rem;
  margin-top:32px;
}
.pg-empty-btn{
  background:var(--ink);color:var(--paper);border:none;
  padding:8px 18px;border-radius:999px;font-size:.82rem;font-weight:500;
  cursor:pointer;margin-left:10px;
}

/* ==========================================================================
   Sidebar — Top 10
   ========================================================================== */
.sidebar{position:sticky;top:calc(var(--header-h) + 24px);align-self:flex-start}
.sidebar-widget{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow-xs);
}
.sidebar-widget h3{
  font-family:var(--font-display);font-weight:600;font-size:1.15rem;
  color:var(--ink);margin-bottom:6px;letter-spacing:-.01em;
}
.sidebar-widget .sidebar-eyebrow{
  display:block;font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:6px;
}
.sidebar-widget>p{font-size:.84rem;color:var(--muted);margin-bottom:18px;line-height:1.6}
.sidebar-list{display:flex;flex-direction:column;gap:6px}
.sidebar-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 10px;border-radius:10px;
  color:var(--ink);transition:background .2s ease;
}
.sidebar-item:hover{background:var(--paper-2);text-decoration:none;color:var(--ink)}
.sidebar-rank{
  font-family:var(--font-display);font-weight:700;font-size:1.1rem;
  color:var(--brass);min-width:28px;
}
.sidebar-img{
  width:54px;height:54px;border-radius:8px;object-fit:cover;
  background:var(--paper-2);flex-shrink:0;
}
.sidebar-info{flex:1;min-width:0}
.sidebar-name{
  font-family:var(--font-display);font-weight:600;font-size:.93rem;line-height:1.25;
  color:var(--ink);margin-bottom:4px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.sidebar-stars{font-size:.78rem;color:var(--brass);letter-spacing:.5px}
.sidebar-link{font-size:.74rem;color:var(--muted);display:block;margin-top:3px}
.sidebar-item:hover .sidebar-link{color:var(--brass)}

/* ==========================================================================
   Brand cloud
   ========================================================================== */
.brand-cloud-section{
  padding:72px 0;
  background:var(--paper-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.brand-cloud-label{
  text-align:center;
  font-size:.74rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;
  color:var(--brass);margin-bottom:8px;
}
.brand-cloud-title{
  text-align:center;font-family:var(--font-display);font-weight:600;
  font-size:1.85rem;color:var(--ink);margin-bottom:32px;letter-spacing:-.01em;
}
.brand-cloud{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;max-width:980px;margin:0 auto}
.brand-tag{
  background:var(--surface);
  color:var(--ink-2);
  border:1px solid var(--line);
  padding:9px 18px;
  border-radius:999px;
  font-family:var(--font);font-size:.82rem;font-weight:500;
  cursor:pointer;transition:all .18s ease;
}
.brand-tag:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.brand-tag.active{background:var(--ink);color:var(--paper);border-color:var(--ink);font-weight:600}

/* ==========================================================================
   Ad placement
   ========================================================================== */
.ad-placement{padding:48px 0;background:var(--paper)}
.ad-placement-inner{display:flex;justify-content:center;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 24px}
.ad-unit{flex:0 0 auto}

/* ==========================================================================
   Footer
   ========================================================================== */
footer{
  background:var(--ink);
  color:rgba(251,248,241,.8);
  padding:80px 0 28px;
  position:relative;
  overflow:hidden;
}
footer::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 80% 0%,rgba(168,124,79,.18),transparent 60%);
  pointer-events:none;
}
footer .container{position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:1.5fr .8fr .8fr .8fr;gap:56px;padding-bottom:56px;border-bottom:1px solid rgba(255,250,238,.08)}
.footer-brand{max-width:380px}
.footer-logo{
  display:flex;align-items:center;gap:14px;
  margin-bottom:22px;
}
.footer-logo-mono{
  width:48px;height:48px;border-radius:12px;
  background:linear-gradient(135deg,#fffaee 0%,#f1e6cc 100%);
  border:1px solid rgba(232,212,174,.3);
  display:grid;place-items:center;flex-shrink:0;
  overflow:hidden;
}
.footer-logo-mono img{width:80%;height:80%;object-fit:contain}
.footer-logo-text{display:flex;flex-direction:column;line-height:1.05}
.footer-logo-name{
  font-family:var(--font-display);font-weight:700;font-size:1.4rem;color:#fffaee;letter-spacing:-.01em;
  font-variation-settings:"opsz" 144;
}
.footer-logo-name em{font-style:italic;color:var(--brass-light);font-weight:500}
.footer-logo-tag{
  font-size:.62rem;font-weight:600;letter-spacing:.32em;text-transform:uppercase;
  color:var(--brass-light);margin-top:4px;
}
.footer-brand p{color:rgba(251,248,241,.7);font-size:.92rem;line-height:1.7;margin-bottom:16px}
.footer-disclaimer{
  font-size:.78rem;color:rgba(251,248,241,.5);
  padding:12px 14px;border-left:2px solid var(--brass);background:rgba(255,255,255,.03);
  border-radius:0 6px 6px 0;
}
footer h4{
  font-family:var(--font);
  font-size:.74rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass-light);margin-bottom:18px;
}
footer ul{list-style:none}
footer ul li{margin-bottom:11px}
footer ul a{color:rgba(251,248,241,.78);font-size:.92rem;transition:color .2s ease}
footer ul a:hover{color:#fffaee;text-decoration:none}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  padding-top:24px;font-size:.82rem;color:rgba(251,248,241,.5);
}
.footer-bottom a{color:rgba(251,248,241,.7);margin:0 4px}
.footer-bottom a:hover{color:#fffaee}

/* ==========================================================================
   Cookie banner
   ========================================================================== */
#cookie-banner{
  position:fixed;left:0;right:0;bottom:0;
  background:var(--ink);color:var(--paper);
  border-top:1px solid var(--ink-3);
  z-index:300;
  transform:translateY(100%);transition:transform .35s ease;
}
#cookie-banner.visible{transform:translateY(0)}
.cookie-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap;padding:18px 0}
.cookie-text{flex:1;min-width:280px;font-size:.88rem;color:rgba(251,248,241,.8);line-height:1.6}
.cookie-text a{color:var(--brass-light);text-decoration:underline;margin-left:4px}
.cookie-text strong{color:#fffaee}
.cookie-btns{display:flex;gap:10px}
.cookie-accept{
  background:var(--brass);color:#fff;border:none;
  padding:11px 22px;border-radius:999px;font-weight:600;font-size:.84rem;cursor:pointer;
  letter-spacing:.04em;transition:background .2s ease;
}
.cookie-accept:hover{background:var(--brass-2)}
.cookie-decline{
  background:transparent;color:var(--paper);
  border:1px solid rgba(255,255,255,.3);
  padding:11px 22px;border-radius:999px;font-weight:500;font-size:.84rem;cursor:pointer;
}
.cookie-decline:hover{background:rgba(255,255,255,.1)}

/* ==========================================================================
   Page hero (interior pages)
   ========================================================================== */
.page-hero{
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
  padding:36px 0;
}
.breadcrumb{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  font-size:.84rem;color:var(--muted);
}
.breadcrumb a{color:var(--ink-2);font-weight:500}
.breadcrumb a:hover{color:var(--brass)}
.breadcrumb sep{color:var(--brass);font-weight:600}
.breadcrumb span{color:var(--ink)}

/* ==========================================================================
   Product page layout
   ========================================================================== */
.product-page{padding:48px 0 24px}
.product-layout{
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;
  align-items:flex-start;
}

/* Gallery */
.gallery{position:sticky;top:calc(var(--header-h) + 24px)}
.gallery-main{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:4/3;
  margin-bottom:14px;
  box-shadow:var(--shadow);
}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:10px}
.gallery-thumb{
  aspect-ratio:1/1;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:8px;
  overflow:hidden;cursor:pointer;
  transition:border-color .2s ease,transform .2s ease;
}
.gallery-thumb:hover{transform:translateY(-2px)}
.gallery-thumb.active{border-color:var(--brass);box-shadow:0 0 0 3px rgba(168,124,79,.16)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}

/* Product info column */
.product-info{padding:0 4px}
.p-brand{
  font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:14px;
  display:inline-flex;align-items:center;gap:8px;
}
.p-brand::before{content:"";width:18px;height:1px;background:var(--brass)}
.p-title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.8rem,3.2vw,2.6rem);line-height:1.1;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:20px;
  font-variation-settings:"opsz" 144;
}
.p-rating{display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.p-rating .stars-char{font-size:1.15rem;letter-spacing:2px}
.p-rating .score{
  font-family:var(--font-display);font-weight:700;font-size:1.4rem;color:var(--ink);letter-spacing:-.01em;
}
.p-rating .reviews-ct{font-size:.86rem;color:var(--muted)}

.score-bar-wrap{margin-bottom:28px}
.score-bar-label{
  display:flex;justify-content:space-between;
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;font-weight:600;
}
.score-bar-label span:last-child{color:var(--ink);font-family:var(--font-display)}
.score-bar-track{
  height:6px;background:var(--paper-2);border-radius:999px;overflow:hidden;
  border:1px solid var(--line);
}
.score-bar-fill{
  height:100%;background:linear-gradient(90deg,var(--brass-2),var(--brass-light));border-radius:999px;
  transition:width .6s ease;
}

.verdict-box{
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 26px;margin-bottom:28px;position:relative;
}
.verdict-box::before{
  content:"\201C";
  position:absolute;top:6px;left:18px;
  font-family:var(--font-display);font-size:5rem;line-height:.5;color:var(--brass);opacity:.3;
}
.verdict-label{
  font-size:.7rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:10px;position:relative;
}
.verdict-text{
  font-family:var(--font-display);font-weight:500;font-size:1.05rem;line-height:1.55;
  color:var(--ink);font-style:italic;letter-spacing:-.005em;position:relative;
}

.cta-group{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}
.btn-buy{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--ink);color:#fffaee;
  padding:15px 28px;border-radius:999px;
  font-family:var(--font);font-weight:600;font-size:.92rem;letter-spacing:.03em;
  border:1px solid var(--ink);
  transition:transform .2s ease,background .2s ease,box-shadow .2s ease;
}
.btn-buy:hover{background:var(--brass);border-color:var(--brass);color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 12px 28px rgba(168,124,79,.32)}
.btn-buy.alt{background:var(--brass);border-color:var(--brass)}
.btn-buy.alt:hover{background:var(--brass-2);border-color:var(--brass-2)}
.btn-read-reviews{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:var(--ink);
  padding:14px 24px;border-radius:999px;
  font-weight:500;font-size:.9rem;
  border:1px solid var(--line);
  transition:background .2s ease;
}
.btn-read-reviews:hover{background:var(--paper-2);text-decoration:none;color:var(--ink)}
.cta-disclosure{
  font-size:.76rem;color:var(--muted);margin-bottom:30px;
  padding-left:14px;border-left:2px solid var(--line-soft);
}

.features-list{list-style:none;padding:0;margin:0}
.features-list li{
  position:relative;padding-left:28px;padding-block:10px;
  font-size:.93rem;color:var(--text-2);line-height:1.6;
  border-bottom:1px dashed var(--line-soft);
}
.features-list li:last-child{border-bottom:0}
.features-list li::before{
  content:"";position:absolute;left:0;top:18px;
  width:14px;height:1px;background:var(--brass);
}
.features-heading{
  font-family:var(--font);
  font-size:.74rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin:32px 0 14px;
}

/* Pros/Cons */
.pros-cons{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  margin-top:48px;
}
.pros-box,.cons-box{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 30px;
}
.pros-box{border-top:3px solid var(--olive)}
.cons-box{border-top:3px solid var(--terracotta)}
.box-head{
  font-family:var(--font);
  font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:18px;
  display:flex;align-items:center;gap:10px;
}
.pros-box .box-head{color:var(--olive)}
.cons-box .box-head{color:var(--terracotta)}
.pros-box ul,.cons-box ul{list-style:none;padding:0;margin:0}
.pros-box li,.cons-box li{
  position:relative;padding-left:28px;padding-block:9px;
  font-size:.92rem;color:var(--text-2);line-height:1.6;
}
.pros-box li::before{
  content:"✓";position:absolute;left:0;top:9px;
  color:var(--olive);font-weight:700;
}
.cons-box li::before{
  content:"×";position:absolute;left:0;top:7px;
  color:var(--terracotta);font-weight:700;font-size:1.1rem;
}

/* Full review prose */
.product-desc{
  margin:56px 0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:48px 56px;
}
.product-desc h2{
  font-family:var(--font-display);font-weight:600;
  font-size:1.85rem;letter-spacing:-.018em;color:var(--ink);
  margin-bottom:20px;position:relative;padding-bottom:18px;
}
.product-desc h2::after{
  content:"";position:absolute;left:0;bottom:0;
  width:48px;height:2px;background:var(--brass);
}
.product-desc p{
  font-size:1rem;line-height:1.8;color:var(--text-2);margin-bottom:18px;
}
.product-desc p:first-of-type::first-letter{
  font-family:var(--font-display);
  font-size:3.6rem;font-weight:700;line-height:.9;
  float:left;margin:6px 12px 0 0;color:var(--brass);
}

/* Customer reviews */
.reviews-section{margin:56px 0}
.reviews-section h2{
  font-family:var(--font-display);font-weight:600;
  font-size:1.85rem;letter-spacing:-.018em;color:var(--ink);
  margin-bottom:32px;text-align:center;position:relative;
}
.reviews-section h2::after{
  content:"";display:block;width:48px;height:2px;background:var(--brass);
  margin:14px auto 0;
}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.review-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px 28px;position:relative;
  transition:transform .25s ease,box-shadow .25s ease;
}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.review-card::before{
  content:"\201C";
  position:absolute;top:14px;right:22px;
  font-family:var(--font-display);font-size:3rem;line-height:.5;color:var(--brass);opacity:.18;
}
.review-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.82rem}
.reviewer-name{font-weight:600;color:var(--ink)}
.review-date{color:var(--muted);font-size:.78rem}
.review-stars{color:var(--brass);letter-spacing:1.5px;font-size:.92rem;margin-bottom:8px}
.review-title{
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  color:var(--ink);margin-bottom:8px;letter-spacing:-.01em;
}
.review-text{font-size:.9rem;color:var(--text-2);line-height:1.65}

/* Related products */
.related-section{
  background:var(--paper-2);
  padding:80px 0;border-top:1px solid var(--line);
}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:1080px;margin:0 auto}
.related-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;color:inherit;
  transition:transform .3s ease,box-shadow .3s ease;
}
.related-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);text-decoration:none;color:inherit}
.related-img{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2)}
.related-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.related-card:hover .related-img img{transform:scale(1.06)}
.related-body{padding:20px 22px}
.related-brand{font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:6px}
.related-title{
  font-family:var(--font-display);font-weight:600;font-size:1rem;line-height:1.3;
  color:var(--ink);margin-bottom:8px;letter-spacing:-.01em;
}
.related-stars{color:var(--brass);font-size:.84rem;margin-bottom:6px}
.related-link{font-size:.78rem;color:var(--ink);font-weight:500}

/* ==========================================================================
   Static pages (about, privacy, terms, cookies)
   ========================================================================== */
.page-content{
  max-width:760px;margin:0 auto;padding:64px 0 80px;
}
.page-content h1{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.2rem,4vw,3rem);letter-spacing:-.02em;color:var(--ink);
  margin-bottom:24px;line-height:1.1;
}
.page-content h2{
  font-family:var(--font-display);font-weight:600;font-size:1.6rem;
  color:var(--ink);margin-top:40px;margin-bottom:14px;letter-spacing:-.015em;
}
.page-content h3{
  font-family:var(--font-display);font-weight:600;font-size:1.2rem;
  color:var(--ink);margin-top:28px;margin-bottom:10px;
}
.page-content p{font-size:1rem;line-height:1.8;color:var(--text-2);margin-bottom:16px}
.page-content ul,.page-content ol{margin:0 0 18px 24px;color:var(--text-2)}
.page-content li{margin-bottom:8px;line-height:1.7}
.page-content a{color:var(--brass);font-weight:500;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1099px){
  .content-with-sidebar{grid-template-columns:1fr;gap:40px}
  .sidebar{position:relative;top:0}
  .product-layout{grid-template-columns:1fr;gap:40px}
  .gallery{position:relative;top:0}
  .podium{grid-template-columns:1fr;gap:24px}
  .podium-rest{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
}
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr;gap:48px;text-align:center}
  .hero-eyebrow{justify-content:center}
  .hero-lede{margin-left:auto;margin-right:auto}
  .hero-cta-row{justify-content:center}
  .hero-pillars{max-width:680px;margin:0 auto}
  .hero-visual{min-height:380px}
  .hero-stage{width:min(320px,80vw)}
  .product-desc{padding:36px 32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width: 768px){
  .container{padding:0 22px}
  .section{padding:64px 0}
  nav.primary-nav{
    position:absolute;top:var(--header-h);left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;
    padding:8px 24px;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .25s ease,opacity .25s ease;
    box-shadow:0 24px 40px rgba(26,29,36,.1);
  }
  header.nav-open nav.primary-nav{transform:translateY(0);opacity:1;pointer-events:auto}
  nav.primary-nav a{padding:14px 8px;border-bottom:1px solid var(--line-soft)}
  nav.primary-nav a:last-child{border-bottom:0}
  nav.primary-nav .nav-cta{margin:14px 0 8px;align-self:flex-start}
  .nav-toggle{display:flex}
  .hero{padding:56px 0 72px}
  .hero h1{font-size:clamp(2rem,8vw,2.8rem)}
  .hero-pillars{grid-template-columns:1fr;border-top:0}
  .hero-pillar{padding:18px 0;border-top:1px solid var(--line)}
  .hero-pillar+.hero-pillar{padding-left:0}
  .hero-pillar+.hero-pillar::before{display:none}
  .hero-orb{display:none}
  .pros-cons{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px;padding-bottom:32px}
  .product-desc{padding:28px 24px}
  .product-desc p:first-of-type::first-letter{font-size:2.8rem}
  .featured-strip{padding:64px 0}
  .related-section{padding:56px 0}
}
@media (max-width: 540px){
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-results{margin-left:0}
  .header-inner{height:72px}
  .brand-mono{width:42px;height:42px}
  .brand-name{font-size:1.25rem}
  .footer-bottom{flex-direction:column;text-align:center}
}
