/*
Theme Name: Picksy Reviews
Theme URI: https://picksyreviews.com/
Author: uGenesys
Author URI: https://ugenesys.info/
Description: Conversion-optimized Amazon affiliate review theme. Renders structured-JSON post meta into single reviews, "Best X" roundups, and category archives. Built for AI/answer-engine discoverability (schema, direct-answer blocks, E-E-A-T signals) and mobile. Pairs with the picksy-engine plugin for AI content generation.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: picksy
*/

:root {
  --bg:#faf8f4; --surface:#fff; --border:#e8e2d9;
  --text-primary:#1a1612; --text-secondary:#5c5650; --text-muted:#9e9890;
  --accent:#c8410a; --accent-light:#fff0ea; --accent-dark:#8f2d07;
  --amazon-bg:#ff9900; --amazon-hover:#e68a00; --dark:#1a1612; --teal:#2a9d8f;
  --verdict-bg:#1a1612; --verdict-text:#faf8f4; --toc-bg:#f5f2ec;
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--bg); font-family:'Source Serif 4',Georgia,serif; color:var(--text-primary); font-size:16px; line-height:1.7; -webkit-font-smoothing:antialiased; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; height:auto; display:block; }
:focus-visible { outline:3px solid var(--accent); outline-offset:2px; border-radius:4px; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior:auto; } * { transition:none !important; } }

/* ===== HEADER / NAV ===== */
#nav-check { display:none; }
header { background:var(--surface); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:100; }
.nav-wrap { max-width:1180px; margin:0 auto; padding:0 20px; display:flex; align-items:center; justify-content:space-between; min-height:66px; gap:14px; }
.logo { font-family:'Playfair Display',serif; font-size:23px; font-weight:900; display:flex; align-items:center; gap:8px; color:var(--text-primary); }
.logo .logo-mark { background:var(--accent); color:#fff; width:34px; height:34px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:19px; transform:rotate(-6deg); }
.logo .tld { color:var(--accent); }
.custom-logo-link { display:flex; align-items:center; }
.custom-logo { max-height:46px; width:auto; }
ul.main-nav { display:flex; gap:26px; list-style:none; }
ul.main-nav li { list-style:none; }
ul.main-nav a { font-size:15px; font-weight:600; color:var(--text-secondary); transition:color .2s; }
ul.main-nav a:hover { color:var(--accent); }
.nav-right { display:flex; align-items:center; gap:12px; }
.nav-search { background:var(--bg); border:1px solid var(--border); border-radius:30px; padding:8px 14px; font-size:13px; color:var(--text-muted); display:flex; align-items:center; gap:8px; cursor:pointer; }
.menu-toggle { display:none; background:none; border:none; cursor:pointer; padding:8px; width:44px; height:44px; }
.menu-toggle span { display:block; width:22px; height:2px; background:var(--text-primary); margin:4px auto; border-radius:2px; transition:.25s; }
@media (max-width:860px) {
  ul.main-nav { position:absolute; top:66px; left:0; right:0; background:var(--surface); flex-direction:column; gap:0; border-bottom:1px solid var(--border); max-height:0; overflow:hidden; transition:max-height .3s ease; box-shadow:0 12px 24px rgba(0,0,0,.06); }
  ul.main-nav li a { display:block; padding:15px 24px; border-top:1px solid var(--border); font-size:16px; }
  #nav-check:checked ~ header ul.main-nav { max-height:460px; }
  #nav-check:checked ~ header .menu-toggle span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
  #nav-check:checked ~ header .menu-toggle span:nth-child(2) { opacity:0; }
  #nav-check:checked ~ header .menu-toggle span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }
  .menu-toggle { display:block; order:3; }
  .nav-search { display:none; }
}

/* ===== HERO ===== */
.hero { max-width:1180px; margin:0 auto; padding:56px 20px 40px; text-align:center; }
.hero-badge { display:inline-block; background:var(--accent-light); border:1px solid #f4c4a8; color:var(--accent); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; padding:6px 16px; border-radius:30px; margin-bottom:22px; }
.hero h1 { font-family:'Playfair Display',serif; font-size:clamp(32px,6vw,60px); font-weight:900; line-height:1.08; letter-spacing:-.02em; margin-bottom:20px; max-width:900px; margin-inline:auto; }
.hero h1 .highlight { color:var(--accent); font-style:italic; }
.hero p.sub { font-size:clamp(17px,2.4vw,19px); color:var(--text-secondary); max-width:620px; margin:0 auto 28px; }
.hero-cta { display:inline-flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.btn-primary { background:var(--accent); color:#fff; font-weight:600; font-size:16px; padding:14px 30px; border-radius:8px; transition:background .2s; }
.btn-primary:hover { background:var(--accent-dark); }
.btn-secondary { background:var(--surface); border:1px solid var(--border); color:var(--text-primary); font-weight:600; font-size:16px; padding:14px 26px; border-radius:8px; transition:border .2s; }
.btn-secondary:hover { border-color:var(--accent); }
.trust-row { display:flex; justify-content:center; gap:clamp(24px,6vw,44px); margin-top:40px; flex-wrap:wrap; }
.trust-item { text-align:center; }
.trust-item .num { font-family:'Playfair Display',serif; font-size:28px; font-weight:800; }
.trust-item .lbl { font-size:12px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.08em; }

/* ===== SECTIONS ===== */
.section { max-width:1180px; margin:0 auto; padding:clamp(40px,7vw,56px) 20px; }
.section-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:28px; flex-wrap:wrap; gap:10px; }
.section-head h2 { font-family:'Playfair Display',serif; font-size:clamp(26px,4vw,32px); font-weight:800; }
.section-head p { font-size:15px; color:var(--text-muted); margin-top:4px; }
.section-head a.view-all { font-size:14px; font-weight:700; color:var(--accent); white-space:nowrap; }
.guide-bg { background:var(--surface); border-block:1px solid var(--border); }

/* ===== BUYING GUIDES ===== */
.guide-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:880px) { .guide-grid { grid-template-columns:1fr; } }
.guide-card { border:1px solid var(--border); border-radius:14px; overflow:hidden; background:var(--bg); display:flex; flex-direction:column; transition:transform .2s,box-shadow .2s; }
.guide-card:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,.08); }
.guide-top { background:var(--dark); color:#fff; padding:24px; position:relative; overflow:hidden; }
.guide-top::before { content:"\2605"; position:absolute; top:-24px; right:-6px; font-size:130px; color:rgba(255,153,0,.08); line-height:1; }
.guide-kicker { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--amazon-bg); }
.guide-top h3 { font-family:'Playfair Display',serif; font-size:21px; font-weight:800; line-height:1.25; margin-top:8px; }
.guide-body { padding:18px 22px 22px; display:flex; flex-direction:column; flex:1; }
.guide-body p { font-size:14px; color:var(--text-secondary); margin-bottom:14px; flex:1; }
.guide-meta { display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:var(--text-muted); border-top:1px solid var(--border); padding-top:12px; }
.guide-meta .picks { font-weight:700; color:var(--teal); }
.guide-meta .read { font-weight:700; color:var(--accent); }

/* ===== REVIEW CARD GRID ===== */
.card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:900px) { .card-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px) { .card-grid { grid-template-columns:1fr; } }
.review-card { background:var(--surface); border:1px solid var(--border); border-radius:14px; overflow:hidden; transition:transform .2s,box-shadow .2s; display:flex; flex-direction:column; }
.review-card:hover { transform:translateY(-4px); box-shadow:0 10px 30px rgba(0,0,0,.08); }
.card-img { aspect-ratio:16/10; background:linear-gradient(135deg,#f0ebe2,#e4ddd0); display:flex; align-items:center; justify-content:center; font-size:52px; position:relative; overflow:hidden; }
.card-img img { width:100%; height:100%; object-fit:cover; }
.card-img .badge { position:absolute; top:12px; left:12px; background:var(--surface); color:var(--accent); font-size:11px; font-weight:700; padding:4px 10px; border-radius:16px; text-transform:uppercase; letter-spacing:.05em; }
.card-body { padding:18px 20px; display:flex; flex-direction:column; flex:1; }
.card-cat { font-size:11px; font-weight:700; color:var(--teal); text-transform:uppercase; letter-spacing:.1em; margin-bottom:8px; }
.card-body h3 { font-family:'Playfair Display',serif; font-size:18px; font-weight:700; line-height:1.3; margin-bottom:10px; }
.card-body p { font-size:14px; color:var(--text-secondary); margin-bottom:14px; flex:1; }
.card-foot { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--border); padding-top:12px; }
.card-rating { font-size:13px; color:var(--text-muted); }
.card-rating .stars { color:#f5a623; }
.card-rating .score { font-weight:700; color:var(--text-primary); }
.card-foot .read { font-size:13px; font-weight:700; color:var(--accent); }

/* ===== CATEGORIES ===== */
.cat-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
@media (max-width:980px) { .cat-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:540px) { .cat-grid { grid-template-columns:repeat(2,1fr); } }
.cat-card { background:var(--bg); border:1px solid var(--border); border-radius:12px; padding:24px 18px; text-align:center; transition:all .2s; }
.guide-bg .cat-card { background:var(--bg); }
.cat-card:hover { border-color:var(--accent); transform:translateY(-3px); }
.cat-card .ico { font-size:36px; margin-bottom:10px; }
.cat-card h4 { font-family:'Playfair Display',serif; font-size:16px; font-weight:700; margin-bottom:4px; }
.cat-card span { font-size:12.5px; color:var(--text-muted); }

/* ===== HOW WE TEST ===== */
.how-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:780px) { .how-grid { grid-template-columns:1fr; } }
.how-item { text-align:center; padding:0 10px; }
.how-num { font-family:'Playfair Display',serif; font-size:44px; font-weight:900; color:var(--accent); opacity:.25; line-height:1; margin-bottom:8px; }
.how-item h4 { font-family:'Playfair Display',serif; font-size:19px; font-weight:700; margin-bottom:8px; }
.how-item p { font-size:14px; color:var(--text-secondary); }

/* ===== NEWSLETTER ===== */
.newsletter { background:var(--dark); border-radius:18px; padding:clamp(32px,6vw,48px); text-align:center; color:#fff; position:relative; overflow:hidden; }
.newsletter::before { content:"\2726"; position:absolute; bottom:-20px; left:30px; font-size:140px; color:rgba(255,153,0,.06); }
.newsletter h2 { font-family:'Playfair Display',serif; font-size:clamp(24px,4vw,30px); font-weight:800; margin-bottom:12px; }
.newsletter p { color:rgba(255,255,255,.7); margin-bottom:24px; max-width:460px; margin-inline:auto; }
.news-form { display:flex; gap:10px; max-width:440px; margin:0 auto; flex-wrap:wrap; justify-content:center; }
.news-form input { flex:1; min-width:220px; padding:13px 18px; border-radius:8px; border:none; font-size:15px; font-family:inherit; }
.news-form button { background:var(--amazon-bg); color:#111; border:none; font-weight:700; font-size:15px; padding:13px 26px; border-radius:8px; cursor:pointer; font-family:inherit; }

/* ===== FOOTER ===== */
footer { background:var(--surface); border-top:1px solid var(--border); margin-top:48px; }
.foot-wrap { max-width:1180px; margin:0 auto; padding:44px 20px 26px; }
.disclosure { background:var(--bg); border:1px solid var(--border); border-radius:8px; padding:14px 18px; font-size:12.5px; color:var(--text-muted); line-height:1.6; margin-bottom:24px; }
.foot-cols { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:30px; margin-bottom:32px; }
@media (max-width:780px) { .foot-cols { grid-template-columns:1fr 1fr; } }
@media (max-width:460px) { .foot-cols { grid-template-columns:1fr; } }
.foot-brand .logo { margin-bottom:14px; }
.foot-brand p { font-size:14px; color:var(--text-muted); max-width:280px; }
.foot-social { display:flex; gap:10px; margin-top:14px; }
.foot-social a { width:36px; height:36px; border:1px solid var(--border); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:var(--text-secondary); }
.foot-social a:hover { border-color:var(--accent); color:var(--accent); }
.foot-col h5 { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px; }
.foot-col a { display:block; font-size:14px; color:var(--text-secondary); padding:5px 0; }
.foot-col a:hover { color:var(--accent); }
.foot-bottom { border-top:1px solid var(--border); padding-top:22px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:13px; color:var(--text-muted); }

/* ========================================================================
   SINGLE REVIEW + ROUNDUP (article pages)
   ===================================================================== */
.page-wrap { max-width:780px; margin:0 auto; padding:24px 20px 110px; }
.page-wrap.roundup { max-width:820px; }

.crumbs { font-size:12.5px; color:var(--text-muted); margin-bottom:18px; display:flex; flex-wrap:wrap; gap:6px; }
.crumbs a:hover { color:var(--accent); }
.crumbs .sep { color:var(--border); }
.last-updated { display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:var(--text-muted); margin-bottom:14px; }

h1.post-headline { font-family:'Playfair Display',serif; font-size:clamp(27px,5vw,40px); font-weight:900; line-height:1.18; margin-bottom:18px; }
.single-review h1.post-headline { border-bottom:3px solid var(--accent); padding-bottom:18px; }

/* Byline */
.byline { display:flex; align-items:center; gap:12px; margin-bottom:26px; flex-wrap:wrap; }
.roundup .byline { padding-bottom:22px; border-bottom:3px solid var(--accent); }
.byline .av { width:42px; height:42px; border-radius:50%; background:var(--accent); color:#fff; font-family:'Playfair Display',serif; font-weight:800; font-size:16px; display:flex; align-items:center; justify-content:center; flex-shrink:0; overflow:hidden; }
.byline .av img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.byline .who { font-size:13.5px; line-height:1.4; }
.byline .who strong { color:var(--text-primary); }
.byline .who span { color:var(--text-muted); }
.byline .checked { margin-left:auto; font-size:11.5px; font-weight:700; color:var(--teal); background:#eef8f6; border:1px solid #bfe3dd; padding:5px 11px; border-radius:20px; }
@media (max-width:520px) { .byline .checked { margin-left:0; } }

/* Direct-answer box */
.answer-box { background:#fffdf8; border:1px solid #f0d080; border-left:5px solid var(--amazon-bg); border-radius:0 10px 10px 0; padding:22px 24px; margin-bottom:30px; }
.answer-box .ab-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:#a06010; margin-bottom:8px; }
.answer-box p { font-size:16px; color:var(--text-primary); line-height:1.7; margin:0; }
.answer-box .ab-cta { margin-top:12px; }
.answer-box .verdict-score { font-family:'Playfair Display',serif; font-weight:900; font-size:18px; }

/* Buttons */
.amazon-btn { display:inline-block; background:var(--amazon-bg); color:#111; font-family:'Source Serif 4',serif; font-weight:700; font-size:14.5px; padding:12px 24px; border-radius:7px; transition:background .2s; border:none; cursor:pointer; }
.amazon-btn:hover { background:var(--amazon-hover); }
.amazon-btn .arrow { margin-left:6px; }
.ftc { font-size:12px; color:var(--text-muted); font-style:italic; margin:10px 0 0; }
.roundup .ftc { margin:2px 0 26px; }

/* Prose */
.prose-section p { font-size:16.5px; color:var(--text-secondary); line-height:1.85; margin-bottom:16px; }
.prose-section p strong { color:var(--text-primary); font-weight:600; }
.prose-section a { color:var(--accent); text-decoration:underline; text-underline-offset:3px; }

/* Best-for */
.best-for-box { background:#fffbf0; border:1px solid #f0d080; border-left:4px solid #e6a817; border-radius:0 8px 8px 0; padding:14px 20px; margin:24px 0 28px; font-size:14px; color:var(--text-secondary); display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.best-for-box .bf-label { font-weight:700; color:#a06010; font-size:13px; text-transform:uppercase; letter-spacing:.08em; }
.bf-tags { display:flex; gap:6px; flex-wrap:wrap; }
.bf-tag { background:#fef3c7; border:1px solid #f0d080; color:#7a4f10; font-size:12px; font-weight:600; padding:3px 10px; border-radius:20px; }

/* TOC */
.toc-block { background:var(--toc-bg); border-left:4px solid var(--accent); border-radius:0 8px 8px 0; padding:6px 26px; margin-bottom:38px; }
.toc-block summary { font-family:'Playfair Display',serif; font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--accent); padding:16px 0; cursor:pointer; list-style:none; }
.toc-block summary::-webkit-details-marker { display:none; }
.toc-block summary::after { content:"\FF0B"; float:right; }
.toc-block[open] summary::after { content:"\FF0D"; }
.toc-block ol { list-style:none; counter-reset:toc; padding:0 0 16px; }
.toc-block ol li { counter-increment:toc; display:flex; gap:10px; padding:4px 0; font-size:14px; }
.toc-block ol li::before { content:counter(toc,decimal-leading-zero); font-family:'Courier New',monospace; font-size:11px; color:var(--accent); font-weight:700; min-width:24px; }
.toc-block ol li a { border-bottom:1px dashed var(--border); }
.toc-block ol li a:hover { color:var(--accent); }

/* Product block */
.product-block { display:grid; grid-template-columns:200px 1fr; gap:26px; background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:26px; margin-bottom:14px; box-shadow:0 2px 12px rgba(0,0,0,.05); }
@media (max-width:560px) { .product-block { grid-template-columns:1fr; } }
.product-image-wrap { background:#f5f2ec; border-radius:8px; display:flex; align-items:center; justify-content:center; min-height:160px; font-size:64px; position:relative; overflow:hidden; }
.product-image-wrap img { width:100%; height:100%; object-fit:cover; border-radius:8px; }
.product-image-wrap .owner-tag, .pick-img .owner-tag { position:absolute; bottom:8px; left:8px; background:rgba(26,22,18,.82); color:#fff; font-size:10px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:3px 8px; border-radius:5px; }
.product-details h3 { font-family:'Playfair Display',serif; font-size:20px; font-weight:700; margin-bottom:12px; }
.features-list { list-style:none; margin-bottom:18px; }
.features-list li { display:flex; align-items:center; gap:8px; font-size:14px; padding:3px 0; color:var(--text-secondary); }
.features-list li::before { content:"\2192"; color:var(--accent); font-weight:700; }

/* Section titles */
h2.section-title { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; margin:44px 0 18px; padding-bottom:10px; border-bottom:2px solid var(--border); scroll-margin-top:80px; }
.roundup h2.section-title { font-size:24px; font-weight:800; margin-top:48px; }

/* Rating block */
.star-rating-block { display:flex; align-items:center; gap:18px; background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:20px 22px; flex-wrap:wrap; }
.star-score { font-family:'Playfair Display',serif; font-size:46px; font-weight:900; line-height:1; }
.star-details { display:flex; flex-direction:column; gap:4px; }
.stars { display:inline-flex; gap:3px; }
.star { font-size:20px; color:#f5a623; }
.star-label { font-size:13px; font-weight:600; color:var(--text-secondary); }
.star-count { font-size:12px; color:var(--text-muted); }
.star-bars { flex:1; min-width:200px; }
.star-bar-row { display:flex; align-items:center; gap:8px; margin-bottom:5px; font-size:12px; color:var(--text-muted); }
.bar-label { width:84px; flex-shrink:0; }
.bar-track { flex:1; background:#e8e2d9; border-radius:4px; height:7px; overflow:hidden; }
.bar-fill { height:100%; background:#f5a623; border-radius:4px; }
.bar-pct { width:34px; text-align:right; }

/* Editor / hands-on */
.editor-review { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:22px 24px; margin-top:12px; }
.editor-header { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.editor-avatar { width:40px; height:40px; background:var(--accent); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:16px; font-family:'Playfair Display',serif; flex-shrink:0; overflow:hidden; }
.editor-avatar.av-photo { background:none; }
.editor-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.editor-name { font-weight:700; font-size:14px; }
.editor-role { font-size:12px; color:var(--text-muted); }
.editor-body { font-size:15px; color:var(--text-secondary); line-height:1.8; font-style:italic; }
.handson { background:#eef8f6; border:1px solid #bfe3dd; border-radius:10px; padding:20px 24px; margin-top:12px; }
.handson .ho-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--teal); margin-bottom:8px; }
.handson p { font-size:15px; color:var(--text-secondary); line-height:1.8; }

/* Pros & cons */
.pros-cons-grid { display:grid; grid-template-columns:1fr 1fr; border-radius:10px; overflow:hidden; border:1px solid #ccc; }
@media (max-width:520px) { .pros-cons-grid { grid-template-columns:1fr; } }
.pros-col,.cons-col { display:flex; flex-direction:column; }
.pros-col .col-header { background:#2a9d8f; color:#fff; font-weight:700; font-size:16px; padding:14px 20px; }
.cons-col .col-header { background:#e63946; color:#fff; font-weight:700; font-size:16px; padding:14px 20px; }
.pros-col .col-body { background:#c8e6e0; padding:16px 20px 20px; flex:1; }
.cons-col .col-body { background:#f4b8b8; padding:16px 20px 20px; flex:1; }
.pros-col ul,.cons-col ul { list-style:none; }
.pros-col ul li,.cons-col ul li { font-size:14px; font-weight:600; padding:6px 0; display:flex; gap:8px; align-items:flex-start; line-height:1.5; color:#3d3d3d; }
.pros-col ul li::before { content:"\2022"; color:#1a6b60; font-weight:900; font-size:16px; }
.cons-col ul li::before { content:"\2022"; color:#8b1a1a; font-weight:900; font-size:16px; }

/* Specs */
.table-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.specs-table { width:100%; border-collapse:collapse; font-size:14px; }
.specs-table tr:nth-child(even) td { background:#f5f2ec; }
.specs-table td { padding:10px 14px; border:1px solid var(--border); }
.specs-table td:first-child { font-weight:600; color:var(--text-secondary); width:38%; }

/* Use case */
.use-case-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:520px) { .use-case-grid { grid-template-columns:1fr; } }
.use-for,.use-not-for { padding:18px 20px; border-radius:8px; font-size:14px; line-height:1.6; }
.use-for { background:#f0faf4; border:1px solid #b8dfc7; }
.use-not-for { background:#fff8f0; border:1px solid #f0c88a; }
.use-for strong,.use-not-for strong { display:block; font-size:12px; text-transform:uppercase; letter-spacing:.1em; margin-bottom:8px; }
.use-for strong { color:#2d7a4f; }
.use-not-for strong { color:#a06010; }

/* Verdict */
.verdict-box { background:var(--verdict-bg); color:var(--verdict-text); border-radius:12px; padding:30px; margin:44px 0; position:relative; overflow:hidden; }
.verdict-box::before { content:"VERDICT"; position:absolute; top:-8px; right:20px; font-family:'Playfair Display',serif; font-size:64px; font-weight:900; color:rgba(255,255,255,.04); }
.verdict-box h3 { font-family:'Playfair Display',serif; font-size:18px; color:var(--amazon-bg); margin-bottom:16px; text-transform:uppercase; letter-spacing:.08em; }
.verdict-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:20px; }
@media (max-width:520px) { .verdict-grid { grid-template-columns:1fr; } }
.verdict-item { background:rgba(255,255,255,.07); border-radius:6px; padding:12px 14px; }
.verdict-item .label { font-size:10px; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.45); margin-bottom:4px; }
.verdict-item .value { font-size:13px; color:#faf8f4; font-weight:600; }
.verdict-text { font-size:15px; color:rgba(255,255,255,.8); line-height:1.7; margin-bottom:20px; font-style:italic; }

/* FAQ */
.faq-item { border-bottom:1px solid var(--border); padding:16px 0; }
.faq-item:last-child { border-bottom:none; }
.faq-q { font-weight:600; font-size:15.5px; margin-bottom:8px; display:flex; gap:10px; align-items:flex-start; }
.faq-q::before { content:"Q."; color:var(--accent); font-family:'Courier New',monospace; font-size:12px; font-weight:700; margin-top:2px; }
.faq-a { font-size:14.5px; color:var(--text-secondary); line-height:1.7; padding-left:24px; }

/* Related */
.related-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:560px) { .related-grid { grid-template-columns:1fr; } }
.related-card { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:16px 18px; display:flex; gap:12px; align-items:center; transition:border .2s; }
.related-card:hover { border-color:var(--accent); }
.related-card .ri { font-size:30px; flex-shrink:0; width:46px; height:46px; display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius:8px; }
.related-card .ri img { width:100%; height:100%; object-fit:cover; border-radius:8px; }
.related-card .rc-cat { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--teal); }
.related-card h4 { font-family:'Playfair Display',serif; font-size:15px; font-weight:700; line-height:1.3; }

/* Final CTA */
.final-cta { text-align:center; background:var(--accent-light); border:1px solid #f4c4a8; border-radius:12px; padding:34px 26px; margin-top:44px; }
.final-cta p { font-size:16px; color:var(--text-secondary); margin-bottom:18px; font-style:italic; }
.final-cta .amazon-btn { font-size:16px; padding:14px 32px; }

/* Mobile sticky CTA */
.sticky-cta { position:fixed; bottom:0; left:0; right:0; background:var(--surface); border-top:1px solid var(--border); box-shadow:0 -4px 20px rgba(0,0,0,.08); padding:10px 16px; display:none; align-items:center; gap:12px; z-index:200; }
.sticky-cta .sc-info { flex:1; min-width:0; }
.sticky-cta .sc-name { font-size:13px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sticky-cta .sc-rating { font-size:12px; color:var(--text-muted); }
.sticky-cta .sc-rating .stars { color:#f5a623; }
.sticky-cta .amazon-btn { padding:11px 18px; font-size:14px; white-space:nowrap; }
@media (max-width:720px) { .sticky-cta { display:flex; } }

/* ===== ROUNDUP-SPECIFIC ===== */
.glance { background:var(--dark); color:#fff; border-radius:14px; padding:26px; margin:24px 0 30px; position:relative; overflow:hidden; }
.glance::before { content:"\2605"; position:absolute; top:-30px; right:-8px; font-size:170px; color:rgba(255,153,0,.07); line-height:1; }
.glance h2 { font-family:'Playfair Display',serif; font-size:15px; text-transform:uppercase; letter-spacing:.1em; color:var(--amazon-bg); margin-bottom:16px; }
.glance-row { display:flex; align-items:center; gap:14px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.glance-row:last-child { border-bottom:none; }
.glance-rank { font-family:'Playfair Display',serif; font-weight:900; font-size:22px; color:var(--amazon-bg); width:28px; flex-shrink:0; }
.glance-info { flex:1; min-width:0; }
.glance-award { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,.55); }
.glance-name { font-size:15px; font-weight:700; color:#fff; }
.glance-btn { background:var(--amazon-bg); color:#111; font-weight:700; font-size:13px; padding:9px 16px; border-radius:6px; white-space:nowrap; }
@media (max-width:560px) { .glance-btn { padding:8px 12px; font-size:12px; } .glance-name { font-size:14px; } }

.compare-table { width:100%; border-collapse:collapse; font-size:14px; min-width:560px; border:1px solid var(--border); border-radius:10px; }
.compare-table th { background:#f5f2ec; font-weight:700; text-align:left; padding:12px 14px; border-bottom:2px solid var(--border); font-size:13px; }
.compare-table td { padding:12px 14px; border-bottom:1px solid var(--border); color:var(--text-secondary); }
.compare-table tr:last-child td { border-bottom:none; }
.compare-table .pname { font-weight:700; color:var(--text-primary); }
.compare-table .award-cell { color:var(--accent); font-weight:700; font-size:12.5px; }
.compare-table .stars { color:#f5a623; }

.how-picked { background:#eef8f6; border:1px solid #bfe3dd; border-radius:10px; padding:22px 24px; margin:10px 0; }
.how-picked .hp-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--teal); margin-bottom:8px; }
.how-picked p { font-size:15px; color:var(--text-secondary); line-height:1.8; }
.crit-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.crit-list span { background:#fff; border:1px solid #bfe3dd; color:#1a6b60; font-size:12.5px; font-weight:600; padding:4px 12px; border-radius:20px; }

.pick { background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:26px; margin-bottom:24px; box-shadow:0 2px 12px rgba(0,0,0,.04); scroll-margin-top:80px; }
.pick-head { display:flex; align-items:flex-start; gap:14px; margin-bottom:18px; flex-wrap:wrap; }
.pick-rank { font-family:'Playfair Display',serif; font-weight:900; font-size:34px; color:var(--accent); opacity:.3; line-height:1; }
.pick-titles { flex:1; min-width:200px; }
.award-badge { display:inline-block; background:var(--accent-light); border:1px solid #f4c4a8; color:var(--accent); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; padding:4px 12px; border-radius:20px; margin-bottom:8px; }
.pick-titles h3 { font-family:'Playfair Display',serif; font-size:22px; font-weight:800; line-height:1.25; }
.pick-score { text-align:center; flex-shrink:0; }
.pick-score .ps-num { font-family:'Playfair Display',serif; font-weight:900; font-size:30px; line-height:1; }
.pick-score .ps-stars { color:#f5a623; font-size:13px; }
.pick-body { display:grid; grid-template-columns:160px 1fr; gap:22px; }
@media (max-width:560px) { .pick-body { grid-template-columns:1fr; } }
.pick-img { background:#f5f2ec; border-radius:8px; display:flex; align-items:center; justify-content:center; min-height:140px; font-size:56px; position:relative; overflow:hidden; }
.pick-img img { width:100%; height:100%; object-fit:cover; border-radius:8px; }
.pick-one-liner { font-size:15px; font-style:italic; color:var(--text-secondary); margin-bottom:12px; }
.pick-why { font-size:15px; color:var(--text-secondary); line-height:1.75; margin-bottom:14px; }
.pick-handson { background:#fffdf8; border:1px solid #f0d080; border-radius:8px; padding:12px 16px; font-size:13.5px; color:var(--text-secondary); margin-bottom:14px; }
.pick-handson strong { color:#a06010; }
.pc-mini { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:16px; }
@media (max-width:440px) { .pc-mini { grid-template-columns:1fr; } }
.pc-mini div.pros, .pc-mini div.cons { font-size:13px; }
.pc-mini .pc-h { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; margin-bottom:5px; }
.pc-mini .pros .pc-h { color:#2a9d8f; }
.pc-mini .cons .pc-h { color:#e63946; }
.pc-mini ul { list-style:none; }
.pc-mini li { padding:2px 0; color:var(--text-secondary); display:flex; gap:6px; }
.pc-mini .pros li::before { content:"+"; color:#2a9d8f; font-weight:900; }
.pc-mini .cons li::before { content:"\2212"; color:#e63946; font-weight:900; }
.best-for-line { font-size:13px; color:var(--text-muted); margin-bottom:14px; }
.best-for-line strong { color:var(--text-primary); }

/* Pagination */
.pagination { margin-top:36px; text-align:center; }
.pagination .page-numbers { display:inline-block; padding:8px 14px; margin:0 3px; border:1px solid var(--border); border-radius:8px; font-size:14px; font-weight:600; color:var(--text-secondary); }
.pagination .page-numbers.current { background:var(--accent); color:#fff; border-color:var(--accent); }
.pagination a.page-numbers:hover { border-color:var(--accent); color:var(--accent); }

.archive .section-head h2, .archive { }
