/* =====================================================================
   THE FOLD REPORT — Design System v2
   Editorial. Professional. Print-magazine inspired.
   ===================================================================== */

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

:root{
  /* Brand palette */
  --ink:        #0F2A44;
  --ink-soft:   #1d3a5a;
  --gold:       #B8884A;
  --gold-deep:  #8d6635;
  --gold-soft:  #d8b88a;

  --paper:      #FBF8F2;
  --cream:      #F4ECDC;
  --stone:      #EDE3CF;
  --bone:       #FFFDF8;

  --slate-900:  #1a2332;
  --slate-700:  #2f3f55;
  --slate-500:  #5a6b80;
  --slate-300:  #b3bdcb;
  --slate-200:  #d6dde6;
  --slate-100:  #ecf0f5;
  --slate-50:   #f6f8fa;

  --sage:       #889788;
  --terracotta: #b66f53;
  --rose:       #c98a8a;

  --bg:         var(--paper);
  --text:       var(--slate-900);
  --muted:      var(--slate-500);
  --border:     #e5dccb;
  --line:       #e2d8c4;

  --serif:      'Fraunces', 'Garamond', 'Georgia', serif;
  --sans:       'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --radius-sm:  6px;
  --radius:     12px;
  --radius-lg:  20px;
  --shadow-sm:  0 1px 3px rgba(15, 42, 68, 0.06);
  --shadow:     0 6px 24px rgba(15, 42, 68, 0.08);
  --shadow-lg:  0 22px 60px rgba(15, 42, 68, 0.14);
  --shadow-gold: 0 14px 40px rgba(184, 136, 74, 0.22);

  --container:  1200px;
  --gap:        28px;
}

*, *::before, *::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--ink); text-decoration:none; transition:color .18s ease; }
a:hover{ color:var(--gold-deep); }
button{ font-family:inherit; cursor:pointer; }

h1,h2,h3,h4,h5{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.18;
  letter-spacing:-0.015em;
  color:var(--ink);
  margin:0 0 0.5em;
}
h1{ font-size:clamp(2.2rem, 4.6vw, 3.6rem); font-weight:500; }
h2{ font-size:clamp(1.7rem, 3vw, 2.4rem); font-weight:500; }
h3{ font-size:1.3rem; }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans); font-size:.78rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold-deep);
}
.eyebrow::before, .eyebrow::after{
  content:""; display:inline-block; width:32px; height:1px; background:var(--gold);
}
.eyebrow.left::after{ display:none; }

/* HEADER */
header.site-header{
  background:rgba(251, 248, 242, 0.94);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:1000;
  transition:box-shadow .24s ease, background .24s ease;
}
header.site-header.scrolled{
  background:rgba(255, 253, 248, 0.98);
  box-shadow:0 4px 24px rgba(15,42,68,0.06);
}
.utility-bar{
  background:var(--ink);
  color:var(--cream);
  font-size:.78rem;
  letter-spacing:.06em;
  padding:8px 0;
}
.utility-bar .container{
  display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap;
}
.utility-bar .ut-tag{ display:inline-flex; align-items:center; gap:8px; }
.utility-bar .ut-tag .dot{
  width:6px; height:6px; border-radius:50%; background:var(--gold);
  box-shadow:0 0 0 4px rgba(184,136,74,.18);
}
.utility-bar .ut-links{ display:flex; gap:18px; }
.utility-bar a{ color:var(--cream); opacity:.78; }
.utility-bar a:hover{ opacity:1; color:var(--gold-soft); }

.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px;
  gap:32px;
  max-width:var(--container); margin:0 auto;
}
.brand{
  display:flex; align-items:center; gap:14px; text-decoration:none;
  color:var(--ink);
}
.brand-mark{
  width:42px; height:42px; flex:none;
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:8px;
  display:grid; place-items:center;
  position:relative;
  overflow:hidden;
}
.brand-mark img{ width:30px; height:30px; object-fit:contain; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
  font-family:var(--serif);
  font-size:1.32rem; font-weight:600;
  letter-spacing:-0.01em;
  color:var(--ink);
}
.brand-tag{
  margin-top:5px;
  font-size:.66rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
}

nav.primary{ display:flex; align-items:center; gap:6px; }
nav.primary > a{
  position:relative;
  padding:10px 14px;
  font-size:.9rem;
  font-weight:500;
  color:var(--slate-700);
  border-radius:6px;
  transition:color .18s ease, background .18s ease;
}
nav.primary > a:hover{ color:var(--ink); background:var(--cream); }
nav.primary > a.active{ color:var(--ink); }
nav.primary > a.active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:4px;
  height:2px; background:var(--gold); border-radius:2px;
}
nav.primary .nav-cta{
  margin-left:8px;
  padding:10px 18px;
  background:var(--ink);
  color:var(--cream);
  border-radius:999px;
  font-weight:600;
  letter-spacing:.04em;
  font-size:.85rem;
  display:inline-flex; align-items:center; gap:8px;
  transition:background .18s ease, transform .18s ease;
}
nav.primary .nav-cta:hover{ background:var(--gold-deep); color:#fff; transform:translateY(-1px); }
nav.primary .nav-cta::before{ content:"★"; color:var(--gold-soft); }

.nav-toggle{
  display:none;
  border:1px solid var(--border);
  background:var(--bone);
  border-radius:8px;
  width:40px; height:40px;
  flex-direction:column; justify-content:center; align-items:center; gap:5px;
  padding:0;
}
.nav-toggle span{ width:18px; height:2px; background:var(--ink); border-radius:1px; transition:transform .2s ease; }

@media (max-width:880px){
  .nav-toggle{ display:flex; }
  nav.primary{
    display:none;
    position:absolute; top:100%; left:0; right:0;
    background:var(--bone); border-bottom:1px solid var(--border);
    flex-direction:column; padding:18px;
    box-shadow:0 18px 40px rgba(15,42,68,.1);
  }
  nav.primary > a{ padding:14px; width:100%; }
  header.site-header.nav-open nav.primary{ display:flex; }
}

/* HERO */
.hero{
  position:relative;
  overflow:hidden;
  background:var(--cream);
  isolation:isolate;
}
.hero-bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center 35%;
  filter:saturate(1.05);
}
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(95deg, rgba(251,248,242,.96) 0%, rgba(251,248,242,.85) 38%, rgba(251,248,242,.4) 60%, rgba(251,248,242,.05) 100%);
}
.hero-grain{
  position:absolute; inset:0;
  background-image:radial-gradient(rgba(15,42,68,.04) 1px, transparent 1px);
  background-size:6px 6px;
  opacity:.55; mix-blend-mode:multiply;
  pointer-events:none;
}
.hero-inner{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.15fr 1fr;
  gap:64px; align-items:center;
  padding:96px 28px 108px;
  max-width:var(--container); margin:0 auto;
}
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; gap:52px; padding:64px 28px 80px; }
  .hero-bg::after{ background:linear-gradient(180deg, rgba(251,248,242,.96) 0%, rgba(251,248,242,.7) 40%, rgba(251,248,242,.4) 100%); }
}
.hero-text .eyebrow{ margin-bottom:20px; }
.hero-text h1{
  font-size:clamp(2.4rem, 5.2vw, 4.4rem);
  font-weight:400;
  line-height:1.06;
  letter-spacing:-0.02em;
  margin:0 0 22px;
}
.hero-text h1 em{
  font-style:italic; font-weight:300; color:var(--gold-deep);
  position:relative;
}
.hero-text h1 .accent{ position:relative; display:inline-block; }
.hero-text h1 .accent::after{
  content:""; position:absolute; left:-2px; right:-2px; bottom:6px;
  height:14px; background:rgba(184,136,74,.28); z-index:-1; border-radius:2px;
}
.hero-text > p.lead{
  font-family:var(--serif);
  font-size:1.18rem;
  line-height:1.55;
  color:var(--slate-700);
  font-weight:300;
  max-width:520px;
  margin:0 0 32px;
}
.hero-cta-row{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px;
  font-family:var(--sans); font-weight:600; font-size:.92rem;
  letter-spacing:.02em;
  border-radius:999px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  border:1px solid transparent;
}
.btn-primary{ background:var(--ink); color:var(--bone); box-shadow:0 8px 22px rgba(15,42,68,.18); }
.btn-primary:hover{ background:var(--gold-deep); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow-gold); }
.btn-ghost{ background:transparent; color:var(--ink); border:1px solid var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--bone); }

/* Hero visual */
.hero-visual{ position:relative; display:grid; place-items:center; perspective:1200px; }
.hero-frame{
  position:relative;
  width:min(420px, 100%);
  aspect-ratio:1/1.15;
  background:var(--bone);
  border-radius:6px;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border);
  display:flex; flex-direction:column; padding:38px 32px 34px;
  transform:rotate(-2deg);
}
.hero-frame::before, .hero-frame::after{
  content:""; position:absolute; background:var(--gold);
  width:48px; height:1px;
}
.hero-frame::before{ top:18px; left:18px; }
.hero-frame::after{ bottom:18px; right:18px; }
.hero-frame-corner{ position:absolute; width:1px; height:48px; background:var(--gold); }
.hero-frame-corner.tl{ top:18px; left:18px; }
.hero-frame-corner.br{ bottom:18px; right:18px; }
.hero-frame-mast{
  font-family:var(--sans);
  font-size:.62rem; font-weight:700;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold-deep); text-align:center; margin-bottom:14px;
}
.hero-frame-divider{ height:1px; background:var(--line); margin:0 0 22px; }
.hero-frame-logo{ display:flex; align-items:center; justify-content:center; flex:1; }
.hero-frame-logo img{ width:78%; max-width:260px; }
.hero-frame-foot{
  display:flex; justify-content:space-between; align-items:flex-end; margin-top:22px;
  font-family:var(--serif); font-size:.85rem; color:var(--slate-700); font-style:italic;
}
.hero-frame-foot strong{
  font-style:normal; font-family:var(--sans); font-weight:700;
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink); display:block; margin-bottom:4px;
}
.hero-stamp{
  position:absolute; top:-22px; right:-26px;
  width:120px; height:120px;
  background:var(--ink); color:var(--cream);
  border-radius:50%;
  display:grid; place-items:center;
  text-align:center; font-family:var(--serif);
  border:6px double var(--gold-soft);
  transform:rotate(12deg);
  box-shadow:var(--shadow-gold);
  z-index:3;
}
.hero-stamp-inner{ font-size:.78rem; line-height:1.15; letter-spacing:.03em; }
.hero-stamp-inner b{ display:block; font-size:1.55rem; font-style:italic; color:var(--gold-soft); margin:2px 0; }
.hero-ribbon{
  position:absolute; bottom:-18px; left:-22px;
  background:var(--gold); color:var(--ink);
  padding:10px 22px;
  font-family:var(--sans); font-weight:700;
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
  border-radius:2px;
  box-shadow:0 14px 28px rgba(184,136,74,.3);
  transform:rotate(-3deg); z-index:3;
}

@media (max-width:560px){
  .hero-stamp{ width:90px; height:90px; top:-12px; right:-8px; }
  .hero-stamp-inner b{ font-size:1.2rem; }
  .hero-ribbon{ left:-8px; }
}

/* TRUST PANEL */
.trust-panel{
  position:relative; z-index:2;
  background:var(--bone);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.trust-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:0; }
.trust-cell{
  padding:32px 28px;
  display:flex; gap:18px; align-items:flex-start;
  position:relative;
}
.trust-cell + .trust-cell::before{
  content:""; position:absolute; left:0; top:24px; bottom:24px;
  width:1px; background:var(--line);
}
.trust-icon{
  width:44px; height:44px; flex:none;
  background:var(--cream);
  border-radius:10px;
  display:grid; place-items:center;
  color:var(--gold-deep);
}
.trust-icon svg{ width:24px; height:24px; }
.trust-body strong{
  font-family:var(--serif);
  font-size:1.18rem; font-weight:500; color:var(--ink);
  display:block; line-height:1.2; margin-bottom:4px;
}
.trust-body span{ font-size:.84rem; color:var(--muted); line-height:1.5; }
@media (max-width:880px){
  .trust-grid{ grid-template-columns:1fr 1fr; }
  .trust-cell:nth-child(odd) + .trust-cell::before{ display:none; }
  .trust-cell:nth-child(n+3){ border-top:1px solid var(--line); }
}
@media (max-width:520px){
  .trust-grid{ grid-template-columns:1fr; }
  .trust-cell + .trust-cell::before{ display:none; }
  .trust-cell + .trust-cell{ border-top:1px solid var(--line); }
}

/* AFFILIATE BAR */
.aff-bar{
  background:var(--cream);
  color:var(--slate-700);
  font-size:.84rem;
  border-bottom:1px solid var(--border);
}
.aff-bar .container{
  padding-top:13px; padding-bottom:13px;
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.aff-bar strong{
  font-family:var(--sans); font-weight:700;
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex; align-items:center; gap:8px;
}
.aff-bar strong::before{
  content:""; display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--gold);
}

/* SECTIONS */
.section{ padding:88px 0; }
.section-tight{ padding:60px 0; }
.section.alt{ background:var(--bone); }
.section-head{ text-align:center; max-width:680px; margin:0 auto 56px; }
.section-head .eyebrow{ margin-bottom:14px; }
.section-head h2{ margin:0 0 14px; font-weight:400; }
.section-head h2 em{ font-style:italic; color:var(--gold-deep); font-weight:300; }
.section-head p{
  color:var(--muted); font-size:1.02rem; line-height:1.55;
  margin:0 auto; max-width:520px;
}

/* TOP PICKS */
.top-picks{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:32px; align-items:stretch;
}
.pick-feature{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--bone);
  border:1px solid var(--border);
  display:grid; grid-template-rows:1fr auto;
  min-height:560px;
  transition:transform .3s ease, box-shadow .3s ease;
  box-shadow:var(--shadow-sm);
}
.pick-feature:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.pick-feature .pick-img{
  position:relative;
  background:linear-gradient(180deg, var(--cream), var(--stone));
  overflow:hidden; min-height:340px;
}
.pick-feature .pick-img img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s ease;
}
.pick-feature:hover .pick-img img{ transform:scale(1.04); }
.pick-feature .pick-rank{
  position:absolute; top:24px; left:24px;
  background:var(--ink); color:var(--gold-soft);
  padding:8px 16px;
  font-family:var(--serif); font-style:italic; font-size:1.05rem;
  border-radius:999px;
  display:inline-flex; align-items:center; gap:8px;
  box-shadow:var(--shadow-sm);
}
.pick-feature .pick-rank b{ font-style:normal; font-weight:700; color:var(--bone); }
.pick-feature .pick-stamp{
  position:absolute; top:24px; right:24px;
  background:var(--gold); color:var(--ink);
  padding:8px 14px;
  font-size:.7rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  border-radius:3px;
  box-shadow:0 4px 14px rgba(184,136,74,.3);
}
.pick-feature .pick-body{ padding:32px 36px 36px; }
.pick-feature .pick-cat{
  font-family:var(--sans); font-size:.72rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold-deep);
  margin-bottom:10px;
}
.pick-feature h3{
  font-size:1.7rem; margin:0 0 14px; font-weight:500; line-height:1.2;
}
.pick-feature .pick-quote{
  font-family:var(--serif); font-style:italic; font-size:1.05rem;
  color:var(--slate-700); line-height:1.55;
  border-left:2px solid var(--gold); padding:4px 0 4px 16px;
  margin:0 0 18px;
}
.pick-feature .pick-meta{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:18px; border-top:1px solid var(--line);
}
.pick-feature .pick-meta .pick-score{
  display:flex; align-items:center; gap:10px;
  font-family:var(--serif); font-weight:600; color:var(--ink);
}
.pick-feature .pick-meta .pick-score b{ font-size:1.4rem; }
.pick-feature .pick-meta .pick-score .stars{ color:var(--gold); letter-spacing:.04em; }
.pick-feature .pick-link{
  font-family:var(--sans); font-weight:600; font-size:.86rem;
  color:var(--ink); display:inline-flex; align-items:center; gap:8px;
}
.pick-feature .pick-link::after{ content:"→"; transition:transform .2s ease; }
.pick-feature:hover .pick-link::after{ transform:translateX(4px); }

.pick-side{ display:grid; grid-template-rows:1fr 1fr; gap:24px; }
.pick-card{
  position:relative;
  display:grid; grid-template-columns:160px 1fr;
  background:var(--bone);
  border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease;
  box-shadow:var(--shadow-sm);
}
.pick-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.pick-card .pick-img{ background:var(--cream); overflow:hidden; min-height:180px; }
.pick-card .pick-img img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s ease;
}
.pick-card:hover .pick-img img{ transform:scale(1.05); }
.pick-card .pick-body{ padding:22px 24px; display:flex; flex-direction:column; justify-content:center; }
.pick-card .pick-rank-num{
  font-family:var(--serif); font-style:italic;
  font-size:1.05rem; color:var(--gold-deep);
  margin-bottom:6px;
}
.pick-card .pick-rank-num b{ font-style:normal; font-weight:700; color:var(--ink); }
.pick-card h3{ font-size:1.05rem; margin:0 0 10px; line-height:1.3; }
.pick-card .pick-mini-meta{
  display:flex; align-items:center; gap:10px; font-size:.85rem;
  color:var(--slate-700);
}
.pick-card .pick-mini-meta .stars{ color:var(--gold); }
@media (max-width:880px){
  .top-picks{ grid-template-columns:1fr; }
  .pick-side{ grid-template-rows:auto; grid-template-columns:1fr; }
}
@media (max-width:520px){
  .pick-card{ grid-template-columns:1fr; }
  .pick-card .pick-img{ min-height:160px; }
}

/* PRODUCT GRID */
.product-section{ padding:88px 0; }
.filter-bar{
  display:flex; flex-wrap:wrap; gap:14px; align-items:center;
  background:var(--bone);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:18px 22px;
  margin-bottom:28px;
}
.filter-label{
  font-size:.74rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted);
}
.filter-select{
  font-family:var(--sans); font-size:.9rem;
  padding:9px 14px; padding-right:34px;
  border:1px solid var(--border); border-radius:8px;
  background:var(--bone) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'><path fill='none' stroke='%230F2A44' stroke-width='1.6' d='M3 5l4 4 4-4'/></svg>") no-repeat right 12px center;
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  color:var(--ink);
}
.filter-select:focus{ outline:2px solid var(--gold); outline-offset:1px; border-color:transparent; }
.filter-reset{
  margin-left:auto;
  background:transparent; border:1px solid var(--border);
  border-radius:999px; padding:9px 16px;
  font-size:.82rem; font-weight:600; color:var(--ink);
}
.filter-reset:hover{ background:var(--ink); color:var(--bone); border-color:var(--ink); }
.filter-results{ font-size:.82rem; color:var(--muted); }

.products-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
@media (max-width:1100px){ .products-grid{ grid-template-columns:repeat(3, 1fr); } }
@media (max-width:780px){  .products-grid{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width:480px){  .products-grid{ grid-template-columns:1fr; } }

.product-card{
  position:relative;
  display:flex; flex-direction:column;
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  text-decoration:none; color:inherit;
}
.product-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:var(--gold-soft);
}
.card-img-wrap{
  position:relative;
  aspect-ratio:1/1;
  background:var(--cream);
  overflow:hidden;
}
.card-img-wrap img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s ease;
}
.product-card:hover .card-img-wrap img{ transform:scale(1.05); }
.card-brand-tag{
  position:absolute; top:12px; left:12px;
  background:rgba(255,253,248,.96);
  color:var(--ink);
  font-size:.7rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  padding:6px 10px; border-radius:4px;
  border:1px solid var(--border);
}
.card-price-badge{
  position:absolute; top:12px; right:12px;
  font-size:.66rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  padding:6px 10px; border-radius:4px;
  color:var(--bone); background:var(--ink);
  box-shadow:var(--shadow-sm);
}
.card-price-badge.value{ background:#3a7a4d; }
.card-price-badge.budget{ background:var(--terracotta); }
.card-price-badge.editor{ background:var(--gold-deep); }
.card-price-badge.premium{ background:var(--ink); }
.card-price-badge.staff{ background:#5d4783; }

.card-body{
  padding:18px 18px 16px;
  display:flex; flex-direction:column; gap:8px;
  flex:1;
}
.card-meta-row{
  display:flex; justify-content:space-between; align-items:center;
  font-size:.72rem; color:var(--muted); font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
}
.card-rating{
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--sans); font-size:.8rem; font-weight:700; color:var(--ink);
}
.card-rating .stars{ color:var(--gold); letter-spacing:.04em; }
.card-title{
  font-family:var(--serif); font-size:1.05rem; font-weight:500;
  line-height:1.32; color:var(--ink);
  margin:2px 0 4px;
}
.card-snippet{
  font-size:.86rem; color:var(--slate-700);
  line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden;
  margin:0;
}
.card-footer{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 18px;
  border-top:1px solid var(--line);
  background:var(--paper);
}
.card-price{ display:flex; flex-direction:column; line-height:1.1; }
.card-price-label{
  font-size:.62rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted);
}
.card-price-value{
  font-family:var(--serif); font-weight:600; color:var(--ink);
  font-size:1.1rem; margin-top:2px;
}
.card-price-value .from{
  font-size:.7rem; color:var(--muted); font-weight:500; margin-right:4px;
}
.card-cta{
  font-family:var(--sans); font-size:.78rem; font-weight:600;
  color:var(--ink); display:inline-flex; align-items:center; gap:5px;
}
.card-cta::after{ content:"→"; transition:transform .2s ease; }
.product-card:hover .card-cta::after{ transform:translateX(3px); }

/* PRODUCT DETAIL PAGE */
.breadcrumb{
  padding:22px 0; font-size:.84rem; color:var(--muted);
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
}
.breadcrumb a{ color:var(--muted); }
.breadcrumb a:hover{ color:var(--ink); }
.breadcrumb sep{ color:var(--gold); font-weight:600; }
.breadcrumb span{ color:var(--ink); font-weight:600; }

.product-page{
  background:var(--bg);
  padding-bottom:60px;
}
.p-hero{
  display:grid; grid-template-columns:1.1fr 1fr; gap:56px;
  padding:24px 0 56px;
  align-items:start;
}
@media (max-width:980px){ .p-hero{ grid-template-columns:1fr; gap:40px; } }

.gallery{
  position:sticky; top:96px;
  display:grid; grid-template-columns:80px 1fr; gap:16px;
}
.gallery-thumbs{ display:flex; flex-direction:column; gap:12px; }
.gallery-thumb{
  aspect-ratio:1/1;
  border:1px solid var(--border); border-radius:8px;
  overflow:hidden; cursor:pointer;
  background:var(--cream);
  transition:border-color .2s ease, transform .2s ease;
}
.gallery-thumb img{ width:100%; height:100%; object-fit:cover; }
.gallery-thumb.active{ border-color:var(--gold); border-width:2px; }
.gallery-thumb:hover{ transform:translateY(-2px); }
.gallery-main{
  background:var(--bone);
  border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; aspect-ratio:1/1;
}
.gallery-main img{ width:100%; height:100%; object-fit:cover; }
@media (max-width:560px){
  .gallery{ position:static; grid-template-columns:1fr; }
  .gallery-thumbs{ flex-direction:row; overflow-x:auto; }
  .gallery-thumb{ width:64px; flex:none; }
}

.p-info .p-cat{
  display:inline-block;
  font-size:.7rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-deep); margin-bottom:12px;
}
.p-info .p-brand{
  font-size:.86rem; font-weight:600; color:var(--muted);
  margin-bottom:6px;
}
.p-info h1{
  font-size:clamp(1.8rem, 3.2vw, 2.6rem);
  font-weight:500; line-height:1.18; margin:0 0 16px;
}
.p-rating-row{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  padding:14px 0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  margin-bottom:22px;
}
.p-rating-row .stars{ color:var(--gold); font-size:1.1rem; letter-spacing:.04em; }
.p-rating-row .score{
  font-family:var(--serif); font-size:1.2rem; font-weight:600; color:var(--ink);
}
.p-rating-row .score-out{ color:var(--muted); font-size:.85rem; }
.p-rating-row .recommendation{
  margin-left:auto;
  font-size:.74rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--gold-deep);
}

.price-box{
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 24px;
  margin-bottom:22px;
  display:grid; grid-template-columns:1fr auto; gap:18px; align-items:center;
}
.price-box .price-meta{
  font-size:.7rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted);
  margin-bottom:6px;
}
.price-box .price-amount{
  font-family:var(--serif); font-size:2rem; font-weight:600; color:var(--ink);
  line-height:1; display:flex; align-items:baseline; gap:6px;
}
.price-box .price-amount .from{ font-size:.85rem; color:var(--muted); font-weight:500; }
.price-box .price-note{ font-size:.78rem; color:var(--muted); margin-top:6px; }
.price-box .price-badge{
  align-self:start;
  padding:8px 14px; font-size:.7rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  background:var(--gold); color:var(--ink); border-radius:4px;
}

.verdict-box{
  background:var(--cream);
  border-left:3px solid var(--gold);
  padding:22px 24px;
  border-radius:0 var(--radius) var(--radius) 0;
  margin-bottom:24px;
}
.verdict-label{
  font-family:var(--sans); font-size:.7rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold-deep);
  margin-bottom:10px;
}
.verdict-text{
  font-family:var(--serif); font-style:italic; font-size:1.04rem;
  line-height:1.55; color:var(--ink); margin:0;
}

.cta-group{ display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 8px; }
.btn-buy{
  flex:1; min-width:200px;
  padding:16px 24px; font-weight:700; font-size:.95rem;
  background:var(--ink); color:var(--bone);
  border-radius:999px;
  text-align:center; letter-spacing:.04em;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  transition:background .18s ease, transform .18s ease, box-shadow .18s ease;
  box-shadow:0 8px 22px rgba(15,42,68,.18);
}
.btn-buy:hover{ background:var(--gold-deep); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow-gold); }
.btn-buy.alt{ background:var(--gold); color:var(--ink); box-shadow:0 8px 22px rgba(184,136,74,.28); }
.btn-buy.alt:hover{ background:var(--ink); color:var(--bone); }
.btn-secondary{
  padding:16px 24px;
  background:transparent; color:var(--ink);
  border:1px solid var(--ink); border-radius:999px;
  font-weight:600; font-size:.92rem;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.btn-secondary:hover{ background:var(--ink); color:var(--bone); }

.cta-disclosure{ font-size:.74rem; color:var(--muted); margin:8px 0 0; }

.features-key{ margin:34px 0 0; }
.features-key h3{
  font-family:var(--sans); font-size:.78rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--ink);
  margin:0 0 16px;
}
.features-list{
  display:grid; grid-template-columns:1fr 1fr;
  gap:10px 22px;
  list-style:none; padding:0; margin:0;
}
.features-list li{
  display:flex; gap:10px; font-size:.94rem; color:var(--slate-700);
  line-height:1.45;
}
.features-list li::before{
  content:""; flex:none;
  width:6px; height:6px; border-radius:50%; background:var(--gold);
  margin-top:9px;
}
@media (max-width:680px){ .features-list{ grid-template-columns:1fr; } }

.score-breakdown{
  background:var(--bone);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:30px 32px;
  margin:48px 0;
}
.score-breakdown h2{ font-size:1.4rem; margin:0 0 18px; }
.score-breakdown .sb-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
}
@media (max-width:780px){ .score-breakdown .sb-grid{ grid-template-columns:1fr; gap:32px; } }
.score-breakdown .sb-bars{ display:flex; flex-direction:column; gap:18px; }
.sb-row{ display:flex; flex-direction:column; gap:6px; }
.sb-row .sb-row-top{
  display:flex; justify-content:space-between; font-size:.92rem;
  font-weight:600; color:var(--ink);
}
.sb-row .sb-row-top span:last-child{ color:var(--gold-deep); font-family:var(--serif); }
.sb-bar{ height:8px; background:var(--cream); border-radius:99px; overflow:hidden; }
.sb-bar-fill{
  height:100%; background:linear-gradient(90deg, var(--gold), var(--gold-deep));
  border-radius:99px;
}

.pros-cons{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  margin:48px 0;
}
@media (max-width:680px){ .pros-cons{ grid-template-columns:1fr; } }
.pc-box{
  background:var(--bone); border:1px solid var(--border);
  border-radius:var(--radius); padding:26px 28px;
}
.pc-box .pc-head{
  display:flex; align-items:center; gap:10px;
  font-family:var(--sans); font-size:.78rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  margin-bottom:18px;
}
.pc-box.pros .pc-head{ color:#3a7a4d; }
.pc-box.cons .pc-head{ color:var(--terracotta); }
.pc-box .pc-head::before{
  width:30px; height:1px; background:currentColor; content:"";
}
.pc-box ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.pc-box li{
  display:flex; gap:10px; font-size:.94rem; color:var(--slate-700);
  line-height:1.5;
}
.pc-box.pros li::before{
  content:"+"; color:#3a7a4d; font-weight:700; flex:none; margin-top:1px;
}
.pc-box.cons li::before{
  content:"−"; color:var(--terracotta); font-weight:700; flex:none; margin-top:1px;
}

.product-desc{
  margin:48px 0;
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:38px 42px;
}
.product-desc h2{ font-size:1.7rem; margin:0 0 18px; }
.product-desc p{ font-size:1.02rem; line-height:1.78; color:var(--slate-700); margin:0 0 18px; }
.product-desc p:first-of-type::first-letter{
  font-family:var(--serif); font-size:3.5rem; line-height:.92;
  float:left; padding:6px 12px 0 0; color:var(--gold-deep); font-weight:600;
}

.reviews-section{ margin:48px 0; }
.reviews-section h2{ font-size:1.7rem; margin:0 0 24px; }
.reviews-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
}
@media (max-width:680px){ .reviews-grid{ grid-template-columns:1fr; } }
.review-card{
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 24px;
}
.review-top{
  display:flex; justify-content:space-between; align-items:center;
  font-size:.84rem; color:var(--muted); margin-bottom:8px;
}
.reviewer-name{ font-weight:700; color:var(--ink); }
.review-stars{ color:var(--gold); margin-bottom:6px; }
.review-title{
  font-family:var(--serif); font-size:1.05rem; font-weight:600; color:var(--ink);
  margin-bottom:8px;
}
.review-text{ font-size:.94rem; line-height:1.6; color:var(--slate-700); margin:0; }

.related-section{
  background:var(--bone);
  border-top:1px solid var(--border);
  padding:64px 0 80px;
}
.related-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:22px;
}
@media (max-width:980px){ .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(--border);
  border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease;
}
.related-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.related-img{ aspect-ratio:1/1; background:var(--cream); overflow:hidden; }
.related-img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.related-card:hover .related-img img{ transform:scale(1.05); }
.related-body{ padding:16px 18px 20px; display:flex; flex-direction:column; gap:6px; }
.related-brand{ font-size:.7rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.related-title{ font-family:var(--serif); font-size:1rem; font-weight:500; color:var(--ink); line-height:1.3; }
.related-stars{ font-size:.86rem; color:var(--ink); }
.related-stars b{ color:var(--gold-deep); }
.related-link{ margin-top:auto; font-size:.8rem; font-weight:600; color:var(--ink); }

/* COMPARE TABLE */
.compare-section{ padding:0 0 88px; }
.compare-wrap{
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.compare-table{ width:100%; border-collapse:collapse; }
.compare-table th{
  background:var(--ink); color:var(--cream);
  padding:18px 16px; text-align:left;
  font-family:var(--sans); font-size:.74rem; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
}
.compare-table td{
  padding:18px 16px; border-top:1px solid var(--line);
  font-size:.94rem; vertical-align:middle;
}
.compare-row{ cursor:pointer; transition:background .15s ease; }
.compare-row:hover{ background:var(--cream); }
.compare-rank{ font-family:var(--serif); font-size:1.2rem; color:var(--gold-deep); font-weight:600; }
.compare-img{ width:60px; height:60px; object-fit:cover; border-radius:6px; border:1px solid var(--border); }
.compare-name{ font-family:var(--serif); font-weight:600; color:var(--ink); font-size:1rem; }
.compare-brand-tag{ font-size:.74rem; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; }
.compare-score{ font-family:var(--serif); font-size:1.1rem; font-weight:600; color:var(--ink); }
.compare-bar{ height:6px; background:var(--line); border-radius:99px; margin-top:6px; max-width:120px; }
.compare-bar-fill{
  height:100%; border-radius:99px;
  background:linear-gradient(90deg, var(--gold), var(--gold-deep));
}
.compare-link{
  font-weight:600; color:var(--ink); font-size:.86rem;
  display:inline-flex; align-items:center; gap:4px;
}
.compare-link::after{ content:"→"; }

@media (max-width:780px){
  .compare-wrap{ overflow-x:auto; }
  .compare-table{ min-width:760px; }
}

/* STATIC PAGES */
.static-hero{
  background:linear-gradient(180deg, var(--cream), var(--paper));
  padding:80px 0 56px;
  border-bottom:1px solid var(--border);
  text-align:center;
}
.static-hero h1{ font-size:clamp(2rem, 4.4vw, 3.2rem); font-weight:400; }
.static-hero p{ color:var(--muted); font-size:1.08rem; max-width:560px; margin:8px auto 0; }

.static-content{
  max-width:780px; margin:0 auto;
  padding:60px 28px;
  font-family:var(--sans);
}
.static-content h2{
  font-family:var(--serif); font-size:1.7rem; font-weight:500;
  margin:32px 0 14px; padding-top:8px;
}
.static-content h2::before{
  content:""; display:block; width:36px; height:2px; background:var(--gold);
  margin-bottom:14px;
}
.static-content p, .static-content li{
  font-size:1.02rem; line-height:1.78; color:var(--slate-700);
}
.static-content ul, .static-content ol{ padding-left:22px; margin:14px 0; }
.static-content li{ margin-bottom:8px; }
.static-content a{ color:var(--gold-deep); border-bottom:1px solid var(--gold-soft); }
.static-content strong{ color:var(--ink); }

.callout{
  background:var(--cream);
  border-radius:var(--radius);
  padding:22px 26px;
  font-family:var(--serif); font-style:italic;
  color:var(--ink);
  margin:24px 0;
}

/* DIAGRAM CARD */
.diagram-card{
  background:var(--bone);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:28px 32px;
  margin:48px 0;
}
.diagram-card .dc-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:18px; gap:12px; flex-wrap:wrap;
}
.diagram-card h3{
  font-family:var(--serif); font-size:1.25rem; font-weight:500;
  margin:0;
}
.diagram-card .dc-meta{
  font-size:.74rem; color:var(--muted);
  letter-spacing:.16em; text-transform:uppercase; font-weight:700;
}
.diagram-grid{
  display:grid; grid-template-columns:1.1fr 1fr; gap:32px; align-items:center;
}
@media (max-width:780px){ .diagram-grid{ grid-template-columns:1fr; gap:24px; } }
.diagram-key{ display:flex; flex-direction:column; gap:14px; }
.dk-row{
  display:flex; align-items:center; gap:14px;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
  font-size:.92rem;
}
.dk-row:last-child{ border-bottom:none; }
.dk-swatch{ width:14px; height:14px; border-radius:3px; flex:none; }
.dk-label{ flex:1; color:var(--slate-700); }
.dk-value{ font-family:var(--serif); font-weight:600; color:var(--ink); }

.divider-rule{
  display:flex; align-items:center; gap:14px; justify-content:center;
  color:var(--gold); margin:18px auto;
}
.divider-rule::before, .divider-rule::after{
  content:""; flex:1; max-width:80px; height:1px; background:var(--gold-soft);
}

/* FOOTER */
footer.site-footer{
  background:var(--ink);
  color:var(--cream);
  padding:72px 0 0;
  position:relative;
  overflow:hidden;
}
footer.site-footer::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--gold-deep), var(--gold), var(--gold-deep));
}
.footer-top{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:56px; border-bottom:1px solid rgba(255,253,248,.15);
}
@media (max-width:880px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer-top{ grid-template-columns:1fr; gap:30px; } }
.footer-brand{ max-width:380px; }
.footer-brand .footer-logo{
  display:flex; align-items:center; gap:14px; margin-bottom:18px;
}
.footer-brand .footer-logo .fl-mark{
  width:46px; height:46px; background:var(--bone);
  border-radius:8px; display:grid; place-items:center;
  border:1px solid rgba(255,253,248,.16);
}
.footer-brand .footer-logo .fl-mark img{ width:30px; height:30px; }
.footer-brand .footer-logo .fl-text{
  font-family:var(--serif); font-weight:600; font-size:1.32rem; color:var(--cream);
}
.footer-brand p{
  font-size:.94rem; line-height:1.65; color:rgba(255,253,248,.78);
  margin-bottom:18px;
}
.footer-brand .footer-disclaimer{
  font-size:.78rem; color:rgba(255,253,248,.58); padding-top:14px;
  border-top:1px solid rgba(255,253,248,.12);
}
footer h4{
  font-family:var(--sans); font-size:.74rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
  margin:0 0 18px;
}
footer ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
footer ul a{ color:rgba(255,253,248,.82); font-size:.92rem; }
footer ul a:hover{ color:var(--gold-soft); }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding:24px 0; flex-wrap:wrap; gap:14px;
  font-size:.82rem; color:rgba(255,253,248,.6);
}
.footer-bottom a{ color:rgba(255,253,248,.78); }
.footer-bottom a:hover{ color:var(--gold-soft); }

/* COOKIE BANNER */
#cookie-banner{
  position:fixed; bottom:24px; left:24px; right:24px;
  max-width:980px; margin:0 auto;
  background:var(--ink); color:var(--cream);
  padding:18px 22px;
  border-radius:var(--radius);
  box-shadow:0 22px 60px rgba(15,42,68,.36);
  transform:translateY(140%); transition:transform .35s ease;
  z-index:200;
}
#cookie-banner.visible{ transform:translateY(0); }
.cookie-inner{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.cookie-text{ flex:1; font-size:.9rem; margin:0; line-height:1.5; }
.cookie-text a{ color:var(--gold-soft); border-bottom:1px solid var(--gold-soft); }
.cookie-btns{ display:flex; gap:10px; }
.cookie-accept{
  background:var(--gold); color:var(--ink);
  border:none; border-radius:999px;
  padding:10px 20px; font-weight:700; letter-spacing:.04em;
  font-size:.84rem;
}
.cookie-accept:hover{ background:var(--gold-soft); }
.cookie-decline{
  background:transparent; border:1px solid rgba(255,253,248,.4);
  color:var(--cream); border-radius:999px;
  padding:10px 20px; font-weight:600; font-size:.84rem;
}
.cookie-decline:hover{ background:rgba(255,253,248,.1); }

/* ADS */
.ad-placement{ padding:32px 0; }
.ad-placement-inner{
  display:flex; gap:18px; justify-content:center; flex-wrap:wrap;
}
.ad-unit{ min-height:0; }

/* PAGINATION */
.pagination{ display:flex; gap:8px; justify-content:center; margin:40px 0 0; }
.pagination .pg-btn{
  width:40px; height:40px; border-radius:8px;
  border:1px solid var(--border); background:var(--bone);
  font-weight:600; color:var(--ink);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:.9rem;
}
.pagination .pg-btn:hover{ background:var(--ink); color:var(--bone); }
.pagination .pg-btn.active{ background:var(--ink); color:var(--bone); border-color:var(--ink); }
.pagination .pg-btn[disabled]{ opacity:.4; cursor:not-allowed; }

/* ACCESSIBILITY */
.sr-only{
  position:absolute !important; width:1px; height:1px; padding:0;
  margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
:focus-visible{
  outline:2px solid var(--gold); outline-offset:2px; border-radius:4px;
}

/* PRINT */
@media print{
  header, footer, .ad-placement, #cookie-banner, .nav-toggle, .cta-group{ display:none !important; }
  body{ background:#fff; }
  .product-card, .pick-feature, .pick-card{ break-inside:avoid; }
}
