*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1a1523; --muted:#6b6478; --line:#e9e4ef; --bg:#faf8fc; --card:#fff;
  --radius:14px; --shadow:0 1px 3px rgba(26,21,35,.08),0 8px 24px rgba(26,21,35,.06);
}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}
img{max-width:100%;display:block}
h1,h2,h3,h4{line-height:1.2;letter-spacing:-.01em}

/* Header */
.site-header{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;gap:20px;padding:14px 20px}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:19px;white-space:nowrap}
.brand-mark{color:var(--primary);font-size:20px}
.brand-name{background:linear-gradient(90deg,var(--primary),var(--secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.search{flex:1;display:flex;max-width:520px}
.search input{flex:1;border:1px solid var(--line);border-right:0;border-radius:10px 0 0 10px;padding:10px 14px;font-size:15px;outline:none}
.search input:focus{border-color:var(--primary)}
.search button{border:0;background:var(--primary);color:#fff;padding:0 18px;border-radius:0 10px 10px 0;font-weight:600;cursor:pointer}
.topnav{display:flex;gap:18px;font-weight:600;font-size:15px}
.topnav a:hover{color:var(--primary)}

.disclosure-strip{font-size:12.5px;color:var(--muted);padding:8px 20px;text-align:center}
.disclosure-strip a{color:var(--primary);font-weight:600}

main.wrap{padding-top:8px;padding-bottom:48px;min-height:60vh}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;border:1px solid transparent;transition:.15s;white-space:nowrap}
.btn.buy{background:var(--primary);color:#fff}
.btn.buy:hover{filter:brightness(1.07)}
.btn.ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn.disabled{background:#f0edf4;color:#a49dad;cursor:not-allowed}
.btn.big{padding:14px 22px;font-size:16px;width:100%}
.btn.full{width:100%;margin-top:8px}

/* Hero */
.hero{padding:44px 0 24px}
.hero h1{font-size:clamp(30px,5vw,46px);margin-bottom:14px}
.lede{font-size:18px;color:var(--muted);max-width:640px}
.hero-search{display:flex;max-width:560px;margin:24px 0 16px}
.hero-search input{flex:1;border:1px solid var(--line);border-right:0;border-radius:12px 0 0 12px;padding:14px 16px;font-size:16px;outline:none}
.hero-search input:focus{border-color:var(--primary)}
.hero-search button{border:0;background:var(--primary);color:#fff;padding:0 26px;border-radius:0 12px 12px 0;font-weight:700;cursor:pointer;font-size:16px}
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:13px;color:var(--muted)}
.pill:hover{border-color:var(--primary);color:var(--primary)}

/* Bands */
.band{margin:40px 0}
.band-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}
.band h2{font-size:24px}
.see-all{color:var(--primary);font-weight:600;font-size:14px}

/* Budget cards */
.budget-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:16px}
.budget-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:4px;transition:.15s}
.budget-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow)}
.budget-range{font-weight:800;font-size:18px}
.budget-count{color:var(--muted);font-size:13px}

/* Grid + cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.15s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.card-img{position:relative;aspect-ratio:1;background:#f4f1f7;overflow:hidden;display:block}
.card-img img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.03em}
.badge.sale{background:var(--secondary);color:#fff}
.badge.oos{background:#4b4453;color:#fff;left:auto;right:10px}
.card-body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-title{font-size:14px;font-weight:600;line-height:1.35;min-height:38px}
.card-title:hover{color:var(--primary)}
.card-price{display:flex;align-items:baseline;gap:8px}
.card-price .now{font-size:18px;font-weight:800}
.was{text-decoration:line-through;color:var(--muted);font-size:13px;font-weight:500}
.card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.chip{font-size:11px;background:#f4f1f7;color:var(--muted);padding:3px 8px;border-radius:6px}
.chip.merchant{background:#eef7f0;color:#2f7d4f}
.card-actions{display:flex;gap:8px;margin-top:8px}
.card-actions .btn{flex:1;padding:8px 10px;font-size:13px}

/* Listing layout */
.listing-head{padding:24px 0 8px}
.listing-head h1{font-size:28px}
.listing-layout{display:grid;grid-template-columns:250px 1fr;gap:28px;align-items:start}
.filters{position:sticky;top:80px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.filter-group{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.filter-group h4{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:10px}
.filters select,.filters input{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 10px;font-size:14px;outline:none}
.filters select:focus,.filters input:focus{border-color:var(--primary)}
.price-inputs{display:flex;align-items:center;gap:8px}
.facet-list{list-style:none}
.facet-list li a{display:flex;justify-content:space-between;padding:5px 0;font-size:14px;color:var(--muted)}
.facet-list li a:hover{color:var(--primary)}
.facet-count{font-size:12px;background:#f4f1f7;padding:1px 7px;border-radius:6px}
.pager{display:flex;align-items:center;justify-content:center;gap:16px;margin:32px 0}
.pageinfo{color:var(--muted);font-size:14px}
.empty{text-align:center;padding:60px 20px;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:14px}
.empty.tall{padding:100px 20px}
.empty h1{color:var(--ink)}

/* Product page */
.crumbs{padding:16px 0;font-size:13px;color:var(--muted)}
.crumbs a:hover{color:var(--primary)}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;margin-bottom:20px}
.gallery img#mainimg{width:100%;aspect-ratio:1;object-fit:contain;background:#f4f1f7;border:1px solid var(--line);border-radius:var(--radius)}
.thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.thumbs img{width:64px;height:64px;object-fit:cover;border:1px solid var(--line);border-radius:8px;cursor:pointer}
.product-info h1{font-size:26px;margin-bottom:12px}
.pd-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.pd-price{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}
.pd-price .now{font-size:32px;font-weight:800}
.pd-availability{font-size:14px;font-weight:600;margin-bottom:16px}
.pd-availability.ok{color:#2f7d4f}
.pd-availability.no{color:#a4682f}
.fineprint{font-size:12.5px;color:var(--muted);margin-top:10px}
.fineprint a{color:var(--primary)}
.pd-desc,.pd-specs,.pd-history{margin-top:24px}
.pd-desc h3,.pd-specs h3,.pd-history h3{font-size:16px;margin-bottom:10px}
.pd-specs table,.pd-history table{width:100%;border-collapse:collapse;font-size:14px}
.pd-specs th,.pd-history th{text-align:left;color:var(--muted);font-weight:600;padding:7px 12px 7px 0;vertical-align:top;white-space:nowrap}
.pd-specs td,.pd-history td{padding:7px 0;border-bottom:1px solid var(--line)}
.pd-history th{border-bottom:1px solid var(--line)}

/* Compare */
.compare-scroll{overflow-x:auto}
.compare-table{width:100%;border-collapse:collapse;min-width:600px}
.compare-table td,.compare-table th{border:1px solid var(--line);padding:12px;text-align:center;vertical-align:top;font-size:14px}
.rowhead{background:#f4f1f7;font-weight:600;text-align:left;color:var(--muted);white-space:nowrap}
.cmp-head img{width:110px;height:110px;object-fit:cover;border-radius:8px;margin:0 auto 8px}
.cmp-title{font-weight:600;font-size:13px}
.cmp-title:hover{color:var(--primary)}
.cmp-price{font-weight:800;font-size:16px}

/* Prose */
.prose{max-width:760px;margin:20px auto;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:36px}
.prose h1{font-size:30px;margin-bottom:16px}
.prose h2{font-size:20px;margin:26px 0 10px}
.prose p{margin-bottom:12px}
.prose ul{margin:0 0 12px 20px}
.prose li{margin-bottom:6px}
.prose code{background:#f4f1f7;padding:1px 6px;border-radius:5px;font-size:13px}

/* Footer */
.site-footer{background:var(--card);border-top:1px solid var(--line);margin-top:40px;padding-top:36px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;padding-bottom:28px}
.footer-grid h4{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:12px}
.footer-grid a{display:block;color:var(--muted);font-size:14px;padding:3px 0}
.footer-grid a:hover{color:var(--primary)}
.footer-grid .muted{margin-top:8px;font-size:13px}
.sub-footer{border-top:1px solid var(--line);padding:16px 20px;display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted)}
.sub-footer a{color:var(--primary)}

/* Explainer */
.explainer{margin:48px 0}
.explainer h2{font-size:24px;margin-bottom:18px}
.explainer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.explainer-grid>div{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.explainer-grid h3{font-size:16px;margin-bottom:8px;color:var(--primary)}
.explainer-grid p{font-size:14px;color:var(--muted)}

@media(max-width:860px){
  .listing-layout{grid-template-columns:1fr}
  .filters{position:static}
  .product-layout{grid-template-columns:1fr;gap:20px}
  .topnav{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .header-inner{flex-wrap:wrap}
  .search{order:3;max-width:none;flex-basis:100%}
  .footer-grid{grid-template-columns:1fr}
}

/* ---- Editorial: hubs & guides ---- */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.hub-grid.wide,.guide-grid.wide{margin-top:8px}
.hub-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:8px;transition:.15s}
.hub-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow)}
.hub-title{font-size:19px;font-weight:800}
.hub-meta{font-size:13.5px;color:var(--muted);flex:1}
.hub-cta,.guide-cta{font-size:13px;font-weight:700;color:var(--primary)}
.guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.guide-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:8px;transition:.15s}
.guide-card:hover{border-color:var(--secondary);transform:translateY(-3px);box-shadow:var(--shadow)}
.guide-kicker{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary)}
.guide-title{font-size:18px;font-weight:800;line-height:1.25}
.guide-desc{font-size:13.5px;color:var(--muted);flex:1}

/* Hub landing head + intro */
.hub-head{margin:12px 0 8px}
.hub-head h1{font-size:30px;margin-bottom:8px}
.prose-inline p{margin-bottom:10px;color:#3a3444;max-width:760px}
.pick-note{background:#fbf3e8;border:1px solid #f0dcc2;color:#7a4f1d;border-radius:10px;padding:10px 14px;font-size:14px;margin:14px 0 20px;max-width:820px}

/* Guide article */
.guide{max-width:820px;margin:0 auto}
.guide-header{margin:8px 0 20px}
.guide-header h1{font-size:clamp(26px,4vw,36px);margin-top:6px}
.guide-body h2{font-size:21px;margin:26px 0 8px}
.guide-body p{margin-bottom:12px;color:#3a3444}
.guide-body ul{margin:0 0 12px 22px}
.guide-body li{margin-bottom:6px;color:#3a3444}
.guide-body em{color:var(--ink)}
.embed{margin-top:32px;padding-top:8px;border-top:1px solid var(--line)}

/* Related */
.related{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:36px auto 0;max-width:820px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.related h3{font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:10px}
.related-link{display:block;padding:5px 0;color:var(--primary);font-weight:600;font-size:14.5px}
.related-link:hover{text-decoration:underline}
.footer-grid-4{grid-template-columns:2fr 1fr 1fr 1fr}
@media(max-width:860px){.related{grid-template-columns:1fr}.footer-grid-4{grid-template-columns:1fr 1fr}}
