:root {
  color-scheme: light;
  --bg: #f8fafc;
  --paper: #ffffff;
  --surface: #ffffff;
  --text: #0b1020;
  --muted: #4b5565;
  --line: #e5e7eb;
  --line-strong: #202020;
  --accent: #ff2b45;
  --accent-dark: #980f1c;
  --soft: #f8fafc;
  --shadow: 0 16px 42px rgba(17, 17, 17, 0.08);
  --text-muted: #6b7280;
  --surface-alt: #f3f4f6;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Arial, Helvetica, sans-serif; color: var(--text); line-height: 1.55; background: var(--bg); }
a { color: var(--text); text-decoration-color: var(--accent); text-decoration-thickness: 0.1em; text-underline-offset: 0.18em; }
a:hover { color: var(--accent-dark); }
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: linear-gradient(180deg, #091325 0%, #081021 100%);
  border-bottom: 1px solid #1a2438;
}
.container {
  width: min(1280px, calc(100% - 40px));
  margin: 0 auto;
}
.header-inner {
  min-height: 84px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 24px;
}
.brand, .brand-logo {
  color: #fff;
  font-weight: 900;
  letter-spacing: -0.03em;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.brand-logo img {
  display: block;
  width: clamp(220px, 22vw, 320px);
  height: auto;
}
nav {
  display: flex;
  align-items: center;
  margin-left: auto;
  gap: 6px;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
}
nav a {
  color: rgba(255, 255, 255, 0.92);
  text-decoration: none;
  padding: 10px 12px;
  border-bottom: 3px solid transparent;
  transition: color 160ms ease, border-color 160ms ease;
}
nav a:hover { color: #fff; }
nav a.active { border-bottom-color: var(--accent); }
.nav-caret { font-size: 0.75em; opacity: 0.85; vertical-align: middle; }
.nav-search {
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
main { width: min(1280px, calc(100% - 40px)); margin: 0 auto; padding: 32px 0 64px; }
.hero, .article { background: var(--paper); border: 1px solid var(--line); border-radius: 0; box-shadow: none; }
.hero { display: grid; grid-template-columns: minmax(0, 0.8fr) minmax(360px, 1fr); gap: 0; padding: 0; overflow: hidden; margin-bottom: 48px; }
.hero::after { content: none; }
.hero-copy { padding: clamp(34px, 5vw, 66px); border-right: 1px solid var(--line); display: flex; flex-direction: column; justify-content: center; }
.hero-panel { min-height: auto; background: #1b1b1b; color: #fff; border-radius: 0; box-shadow: none; padding: clamp(30px, 4.5vw, 54px); display: grid; align-content: center; gap: 18px; }
.hero-panel p { color: rgba(255,255,255,0.78); margin: 0; }
.verdict-chip, .badge { display: inline-flex; width: fit-content; background: var(--accent); color: #fff; padding: 5px 9px; border-radius: 0; font-size: 0.72rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; }
.verdict-chip { margin-bottom: 10px; }
.panel-score { display: grid; gap: 8px; margin: 28px 0; }
.panel-score strong { font-size: clamp(2rem, 4vw, 3.4rem); line-height: 0.98; letter-spacing: -0.07em; font-family: Arial Black, Arial, Helvetica, sans-serif; }
.panel-score span { color: rgba(255,255,255,0.72); }
.eyebrow { color: var(--accent); text-transform: uppercase; font-weight: 900; font-size: 0.72rem; letter-spacing: 0.14em; margin: 0 0 14px; }
h1, h2, h3 { font-family: Arial Black, Arial, Helvetica, sans-serif; line-height: 0.98; letter-spacing: -0.055em; }
h1 { max-width: 650px; font-size: clamp(2.45rem, 4.2vw, 4rem); margin: 0; }
h2 { font-size: clamp(1.45rem, 2.7vw, 2.2rem); margin: 0; }
h3 { font-size: 1.05rem; margin: 0 0 10px; letter-spacing: -0.035em; }
.lede { max-width: 580px; color: var(--muted); font-size: clamp(1rem, 1.55vw, 1.12rem); margin: 20px 0 0; }
.actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 28px; }
.button, .cta-button { display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--text); background: var(--text); color: #fff; border-radius: 0; padding: 11px 14px; font-weight: 900; font-size: 0.82rem; letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none; box-shadow: none; }
.button:hover, .cta-button:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.button.secondary { background: transparent; color: var(--text); }
.button.secondary:hover { background: var(--text); color: #fff; }
.product-hero-card { position: relative; display: grid; grid-template-columns: minmax(160px, 0.38fr) minmax(0, 0.62fr); gap: 26px; align-items: center; background: #fff; border: 1px solid var(--line); padding: 22px; margin-top: 0; box-shadow: var(--shadow); }
.hero-panel .product-hero-card { background: #fffefa; border-color: rgba(255,255,255,0.28); color: var(--text); }
.product-image, .product-art { aspect-ratio: 1 / 1; background: #fff; border: 1px solid var(--line); display: grid; place-items: center; overflow: hidden; }
.product-image img, .product-art img { display: block; width: 100%; height: 100%; object-fit: contain; padding: 18px; background: #fff; }
.product-art.has-image img { padding: 14px; }
.product-image.has-image figcaption { padding: 8px 10px; font-size: 0.78rem; color: var(--muted); text-align: center; border-top: 1px solid var(--line); background: var(--paper); }
.product-art svg { width: 100%; height: 100%; opacity: 0.68; }
.product-image.placeholder { background: linear-gradient(145deg, #fff, #f3f0e8); color: var(--muted); }
.product-image.placeholder figcaption { padding: 8px 10px; font-size: 0.78rem; color: var(--muted); text-align: center; }
.hero-panel .product-image, .hero-panel .product-art { border-color: var(--line); background: #fff; }
.product-meta { display: flex; flex-direction: column; gap: 12px; justify-content: center; }
.product-meta strong { font-family: Arial Black, Arial, Helvetica, sans-serif; font-size: clamp(1.25rem, 2.1vw, 1.8rem); line-height: 1.05; letter-spacing: -0.04em; }
.product-meta p { margin: 0; color: var(--muted); }
.hero-panel .product-meta p { color: var(--muted); }
.price-note { font-size: 0.78rem; color: rgba(255,255,255,0.74); margin-top: 8px; }
.review-hero { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.55fr); gap: 28px; align-items: start; max-width: none; }
.review-hero header { border: 0; margin: 0; padding: 0; }
.review-summary { display: grid; gap: 14px; border: 1px solid var(--line); background: #fff; padding: 18px; box-shadow: var(--shadow); }
.grade { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: center; }
.grade strong { display: grid; place-items: center; width: 74px; height: 74px; border: 4px solid var(--accent); font-family: Arial Black, Arial, Helvetica, sans-serif; font-size: 2rem; line-height: 1; }
.grade span { font-weight: 900; font-size: 1.05rem; }
.review-disclosure { font-size: 0.82rem; color: var(--muted); margin: 8px 0 0; }
.quick-take { border-top: 1px solid var(--line); padding-top: 14px; }
.quick-take p { margin: 0; }
.product-review-layout { display: grid; grid-template-columns: minmax(300px, 0.45fr) minmax(0, 0.55fr); gap: 26px; align-items: start; margin: 34px 0; }
.product-review-layout .product-image { background: #fff; }
.buy-box { display: grid; gap: 14px; border: 1px solid var(--line); background: #fff; padding: 22px; box-shadow: var(--shadow); }
.buy-box h2 { font-size: clamp(1.35rem, 2.2vw, 1.8rem); }
.buy-box ul { margin: 0; }
.compact-note { font-size: 0.86rem; color: var(--muted); }
.section-heading { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(260px, 0.5fr); gap: 28px; align-items: end; border-top: 3px solid var(--text); margin: 52px 0 24px; padding-top: 22px; }
.section-heading p { color: var(--muted); margin: 0; }
/* Archive Product Card (on /reviews.html) */
.archive-list .product-card {
  min-height: 165px; /* User requested min-height */
}

.grid, .product-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; margin: 0 0 42px; border: 0; }
.card, .product-card { position: relative; min-height: 210px; padding: 22px; background: var(--paper); border: 1px solid var(--line); border-radius: 0; box-shadow: none; display: flex; flex-direction: column; justify-content: space-between; }
.card::before { content: none; }
.card p, .product-card p, .notice p, .article p, li { color: var(--muted); }
.card a, .product-card a:not(.cta-button) { font-size: 0.78rem; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; color: var(--accent); }
.card a::after, .product-card a:not(.cta-button)::after { content: " →"; }
.product-card { gap: 18px; }
.product-card .card-art { height: 190px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.product-card .product-art { width: 100%; height: 100%; background: #fff; max-height: none; aspect-ratio: auto; display:flex; align-items:center; justify-content:center; }
.product-card .product-art img { width: auto; height: auto; max-width: 100%; max-height: 100%; object-fit: contain; object-position: center; }
.product-card > div { display: flex; flex-direction: column; gap: 12px; }
.card-overlay-link { position: absolute; inset: 0; z-index: 1; display: block; }
.product-card footer, .product-hero-card .product-meta { position: relative; z-index: 2; }
.product-card footer { border: 0; padding: 0; width: auto; margin: 10px 0 0; display: flex; gap: 10px; flex-wrap: wrap; }
.product-card .cta-button { width: 100%; margin-top: 2px; position: relative; z-index: 2; }
.product-hero-card .cta-button { position: relative; z-index: 2; }
.card:hover, .product-card:hover { transform: none; background: #fff; box-shadow: var(--shadow); }
.archive-list { display: grid; gap: 18px; }
.archive-item { display: grid; grid-template-columns: 160px minmax(0, 1fr); gap: 20px; align-items: start; border: 1px solid var(--line); background: #fff; padding: 18px; }
.archive-item .product-art { width: 160px; }
.archive-item h2 { margin: 0 0 12px; font-size: clamp(1.25rem, 2vw, 1.8rem); }
.archive-item h2 a { color: var(--text); text-decoration: none; }
.archive-item p { margin: 0 0 14px; }
.notice { border: 1px solid var(--line); border-left: 5px solid var(--accent); border-radius: 0; box-shadow: none; padding: 18px; margin: 28px 0; background: #fff; }
.notice.compact { padding: 10px 12px; border-left-width: 4px; font-size: 0.82rem; }
.notice.compact p { margin: 0; font-size: 0.82rem; }
.notice.compact .eyebrow, .notice.compact h2 { display: none; }
.article { padding: clamp(24px, 5vw, 54px); }
.article header { max-width: 900px; margin-bottom: 28px; padding-bottom: 24px; border-bottom: 3px solid var(--text); }
.article h1 { font-size: clamp(2.1rem, 4.6vw, 4.35rem); }
.article p, .article li { font-size: 1.02rem; }
.article ul, .article ol { padding-left: 1.2rem; }
.article section { margin: 30px 0; }
.callout { border: 1px solid var(--line); border-left: 5px solid var(--accent); background: #fff; padding: 18px; border-radius: 0; }
.scorecard { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.scorecard div { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); border-radius: 0; padding: 18px; background: var(--soft); }
footer { width: min(1180px, calc(100% - 32px)); margin: 0 auto; padding: 24px 0 48px; color: var(--muted); font-size: 0.86rem; border-top: 1px solid var(--line); }
/* Archive Product Card (on /reviews.html) */
.archive-list .product-card {
  min-height: 165px; /* User requested min-height */
}

@media (max-width: 920px) { .site-header { align-items: flex-start; flex-direction: column; padding: 14px 16px; } nav a:first-child { border-left: 0; padding-left: 0; } .hero, .review-hero, .product-review-layout { grid-template-columns: 1fr; } .hero-copy { border-right: 0; border-bottom: 1px solid var(--line); } .grid, .product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .section-heading { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .brand-logo img { width: min(76vw, 230px); } nav { font-size: 0.78rem; } nav a { padding: 6px 8px; } main { width: min(100% - 20px, 1180px); padding-top: 20px; } .grid, .product-grid, .scorecard, .archive-item { grid-template-columns: 1fr; } .archive-item .product-art { width: 100%; } .product-hero-card { grid-template-columns: 1fr; } .article { padding: 22px; } .grade { grid-template-columns: 1fr; } }

/* reviews page hard styles (comp fidelity) */
.archive-hero { display:grid; grid-template-columns:minmax(0,1fr) 420px; gap:32px; align-items:start; margin:0 0 24px; }
.archive-lede { font-size:1.2rem; color:#666; max-width:600px; }
.archive-stats { background:#fff; border:1px solid #e8e8ec; border-radius:12px; padding:24px; display:flex; gap:14px; align-items:center; }
.archive-stats-icon { background:#fee2e2; color:var(--accent); width:56px; height:56px; display:flex; align-items:center; justify-content:center; border-radius:12px; font-size:1.5rem; }
.archive-stats-label { font-size:.75rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; }
.archive-stats-date { font-size:1.9rem; font-weight:900; line-height:1.1; letter-spacing:-0.03em; margin:4px 0; }
.archive-stats-copy { font-size:.86rem; color:#7d7f88; }
.filter-bar { display:flex; gap:10px; align-items:center; margin:0 0 24px; }
.filter-search-icon { color:#999; margin-right:12px; display:flex; align-items:center; }
.filter-spacer { flex-grow:1; }
.search-input, .filter-select {
  height:40px; border:1px solid var(--line); background:#fff; color:var(--text);
  font:inherit; font-size:.92rem; line-height:1.2; padding:0 12px;
}
.search-input { min-width:240px; flex:1 1 280px; }
.filter-select { min-width:150px; }
.btn, .btn-outline, .btn-primary {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:40px; padding:0 14px; border:1px solid var(--text); text-decoration:none;
  font-weight:800; font-size:.78rem; letter-spacing:.04em; text-transform:uppercase;
}
.btn { background:var(--text); color:#fff; }
.btn-outline { background:#fff; color:var(--text); border-color:var(--line-strong); }
.btn-primary { background:var(--accent); color:#fff; border-color:var(--accent); }

.archive-listing { display:flex; flex-direction:column; gap:20px; margin:0 0 56px; }
.archive-listing .product-card {
  display:grid !important;
  grid-template-columns:220px minmax(0,1fr) 176px !important;
  gap:28px !important;
  align-items:center !important;
  padding:28px !important;
  min-height:0 !important;
  border-radius:10px;
}
.archive-listing .card-art { height:148px !important; margin:0 !important; }
.archive-listing .card-art .product-art {
  width: 100%;
  height: 100%;
  max-height: none;
  aspect-ratio: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.archive-listing .card-art .product-art img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  padding: 8px;
}

.archive-meta { font-size:.72rem; font-weight:800; text-transform:uppercase; color:var(--accent); letter-spacing:.06em; margin:0 0 8px; }
.archive-card-title { font-size:1.5rem; line-height:1.1; margin:0 0 10px; letter-spacing:-.02em; }
.archive-card-copy { font-size:.98rem; line-height:1.55; color:var(--muted); margin:0; max-width:70ch; }
.archive-card-cta { display:flex; justify-content:flex-end; }
.archive-pagination { display:flex; justify-content:center; gap:8px; margin:0 0 80px; }
.archive-page-current, .archive-page-btn { min-width:40px; padding:0; }
.archive-page-dots { display:flex; align-items:center; color:#999; }
.archive-page-next { padding:0 16px; }
.archive-page-next[disabled] { opacity:.45; cursor:not-allowed; }
.archive-newsletter { background:var(--surface-alt); border:none; padding:60px; display:flex; justify-content:space-between; align-items:center; border-radius:20px; }
.archive-newsletter-meta { display:flex; gap:32px; align-items:center; }
.archive-newsletter-icon { background:#fff; width:64px; height:64px; display:flex; align-items:center; justify-content:center; border-radius:16px; box-shadow:var(--shadow); font-size:1.5rem; }
.archive-newsletter-title { font-size:1.5rem; margin:0 0 8px; }
.archive-newsletter-copy { margin:0; color:#666; }
.archive-newsletter-form { display:flex; gap:12px; width:400px; }
.archive-newsletter-input { flex-grow:1; border:1px solid var(--line); border-radius:8px; padding:0 16px; outline:none; font:inherit; }

.site-footer { background:linear-gradient(180deg,#071126 0%,#040a18 100%); border-top:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.84); margin-top:24px; }
.site-footer { width: 100%; max-width: none; margin-left: 0; margin-right: 0; }
.site-footer .container { width:min(1280px,calc(100% - 40px)); margin:0 auto; padding:18px 0 14px; }
.footer-grid { display:grid; grid-template-columns:1.4fr repeat(4,minmax(0,1fr)); gap:22px; }
.footer-col h4 { margin:0 0 8px; color:#fff; font-size:.95rem; }
.footer-links { list-style:none; margin:0; padding:0; display:grid; gap:4px; }
.footer-links a { color:rgba(255,255,255,.76); text-decoration:none; font-size:.88rem; }
.footer-bottom { margin-top:10px; padding-top:10px; border-top:1px solid rgba(255,255,255,.12); }
.footer-bottom p { margin:0; font-size:.84rem; color:rgba(255,255,255,.68); }
.site-footer-minimal .container { width:100%; max-width:none; padding:0 24px; }
.site-footer-minimal .footer-bottom { margin:0; padding:18px 0; border-top:none; text-align:center; }

/* detail page fidelity */
.breadcrumbs { padding:24px 0; font-size:.8rem; font-weight:600; color:#8a8f98; }
.breadcrumbs a { color:#666; text-decoration:none; }
.review-header { display:grid; grid-template-columns:minmax(0,1fr) 340px; gap:28px; align-items:start; margin:0 0 32px; }
.review-main { min-width:0; }
.review-main h1 { max-width:780px; font-size:clamp(2.7rem,4.8vw,4.2rem); line-height:1.02; letter-spacing:-.04em; }
.review-main .lede { max-width:72ch; }
.review-meta { margin-top:24px !important; display:flex; flex-wrap:wrap; align-items:center; gap:10px; color:var(--muted); font-size:.95rem; font-weight:700; }
.review-meta .stars { font-size:1.1rem !important; color:#f59e0b; letter-spacing:.05em; }

.review-layout { display:block; }
.review-body { min-width:0; }
.content-section { border:1px solid #e7e8ec; border-radius:14px; background:#fff; padding:24px; margin:0 0 20px; }

.grade-box { background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); padding:24px; display:grid; gap:12px; }
.grade-circle { width:68px; height:68px; display:grid; place-items:center; border:3px solid var(--accent); border-radius:10px; color:var(--accent); font:900 1.8rem/1 Arial Black, Arial, sans-serif; }
.grade-label { font-size:.9rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; color:var(--accent); }
.grade-desc { margin:0; font-size:.92rem; color:var(--muted); }
.disclosure-note { font-size:.72rem; color:#8b8f97; margin-top:8px; }

.quick-answer { display:grid; grid-template-columns:220px minmax(0,1fr); gap:24px; align-items:start; }
.quick-answer-art { min-width:0; }
.quick-answer-art .product-art {
  aspect-ratio: 16 / 9;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.quick-answer-art .product-art img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  padding: 10px;
  object-fit: contain;
  object-position: center;
}
.quick-answer-art .image-source-note { margin-top:12px; }
.quick-answer-title { display:flex; align-items:center; gap:12px; margin:0 0 16px; font-size:1.2rem; }
.icon-accent { color:var(--accent); }
.quick-answer-copy { margin:0 0 24px; font-size:.95rem; }
.image-source-note { font-size:.75rem; color:#999; margin-top:16px; }

.scorecard-row { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin:0 0 20px; }
.score-tile { border:1px solid var(--line); border-radius:12px; background:#fff; padding:18px; }
.score-tile-title { display:flex; align-items:center; gap:8px; margin:0 0 10px; font-size:1.05rem; }
.score-tile-title-good { color:#2e7d32; }
.score-tile-title-bad { color:#c62828; }
.score-tile-title-warn { color:#f59e0b; }

.takeaways-section h2 { font-size:2.75rem; line-height:1.02; letter-spacing:-.04em; margin:0 0 18px; }
.takeaways-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; margin:0 0 18px; }
.takeaway-item { display:flex; gap:10px; font-weight:500; font-size:.9rem; line-height:1.35; color:#4b5565; }
.takeaway-icon { color:#f04444; background:#fee2e2; border-radius:999px; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; font-size:.7rem; flex:0 0 18px; }

.pros-cons-grid { display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--line); border-radius:8px 8px 0 0; overflow:hidden; background:#fff; }
.pros-panel, .cons-panel { padding:24px; background:#fff; }
.pros-panel { border-right:1px solid var(--line); }
.panel-title { margin:0 0 24px; display:flex; align-items:center; gap:12px; font-size:1rem; font-weight:700; letter-spacing:0; line-height:1.2; }
.panel-title-badge { width:24px; height:24px; display:grid; place-items:center; border-radius:50%; color:#fff; font-size:.8rem; }
.panel-title-pros { color:#166534; }
.panel-title-pros .panel-title-badge { background:#166534; }
.panel-title-cons { color:#991b1b; }
.panel-title-cons .panel-title-badge { background:#991b1b; }
.pros-panel .sidebar-list li { color:#166534; border-bottom:1px solid #dcfce7; padding-bottom:12px; }
.cons-panel .sidebar-list li { color:#991b1b; border-bottom:1px solid #fee2e2; padding-bottom:12px; }
.bottom-line { background:#fff; border:1px solid var(--line); border-top:none; padding:24px; border-radius:0 0 8px 8px; }
.bottom-line-title { display:flex; align-items:center; gap:12px; margin:0 0 16px; font-size:1.1rem; font-weight:700; letter-spacing:0; line-height:1.2; }
.bottom-line-star { color:#f59e0b; }
.bottom-line-copy { margin:0; font-weight:500; font-size:1rem; line-height:1.45; color:#374151; }

.review-disclosure { background:#f8fafc !important; border:1px solid #e2e8f0 !important; padding:16px 20px !important; border-radius:8px !important; font-size:.85rem; color:#64748b; margin:40px 0; }
.review-disclosure-copy { margin:0; display:flex; align-items:center; gap:12px; }
.review-disclosure-icon { background:#ef4444; color:#fff; width:18px; height:18px; display:flex; align-items:center; justify-content:center; border-radius:50%; font-size:.7rem; font-weight:800; }

.source-link { color:var(--accent); font-weight:600; }
.sources-row { display:grid; grid-template-columns:minmax(0,1fr) 340px; gap:24px; align-items:start; margin-bottom:20px; }
.sources-row .content-section { margin:0; }
.review-meta-stack { display:flex; flex-direction:column; gap:20px; color:#999; font-size:.85rem; font-weight:600; padding-top:40px; border-top:1px solid var(--line); }
.review-meta-item { display:flex; align-items:center; gap:12px; }

.sidebar-box.clean { padding:0; overflow:hidden; background:#fff; box-shadow:var(--shadow); border-radius:14px; }
.sidebar-brand { padding:32px; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:12px; font-weight:800; font-size:1.1rem; }
.sidebar-brand-icon { width:24px; height:24px; font-size:.9rem; display:grid; place-items:center; border-radius:50%; background:#fff1f3; color:var(--accent); border:1px solid #ffd3d9; }
.sidebar-content { padding:32px; }
.sidebar-copy { font-size:.95rem; color:#666; margin:0 0 24px; }
.sidebar-home-link { color:var(--accent); font-weight:800; font-size:.85rem; text-transform:uppercase; letter-spacing:.05em; display:flex; align-items:center; gap:8px; text-decoration:none; }

.btn.btn-black { gap:8px; }
.btn.btn-black:hover { background:var(--accent); border-color:var(--accent); color:#fff; }

/* image fit: no crop */
.product-image img, .product-art img { object-fit:contain; object-position:center; padding:12px; }
.product-art.has-image img { padding:12px; }

@media (max-width: 980px) {
  .archive-hero { grid-template-columns:1fr; }
  .archive-listing .product-card { grid-template-columns:160px 1fr !important; }
  .archive-card-cta { grid-column:1 / -1; justify-content:flex-start; }
  .archive-newsletter { padding:30px; flex-direction:column; align-items:flex-start; gap:18px; }
  .archive-newsletter-form { width:100%; }
  .review-header { grid-template-columns:1fr; gap:20px; }
  .quick-answer, .scorecard-row, .pros-cons-grid, .takeaways-grid { grid-template-columns:1fr; }
  .pros-panel { border-right:none; border-bottom:1px solid var(--line); }
  .sources-row { grid-template-columns:1fr; }
}
@media (max-width: 640px) {
  .filter-bar { flex-wrap:wrap; }
  .filter-search-icon { margin-right:0; }
  .search-input { min-width:100%; flex-basis:100%; }
  .filter-select { flex:1 1 calc(50% - 8px); min-width:140px; }
  .filter-spacer { display:none; }
  .archive-listing .product-card { grid-template-columns:1fr !important; padding:20px !important; gap:16px !important; }
  .archive-listing .card-art { height:180px !important; }
  .archive-newsletter { padding:22px; }
  .archive-newsletter-meta { gap:16px; }
  .archive-newsletter-icon { width:48px; height:48px; border-radius:12px; font-size:1.15rem; }
  .archive-newsletter-form { flex-direction:column; }
  .archive-newsletter-input { min-height:40px; }
  .footer-grid { grid-template-columns:1fr; }
}
