/* ============================================================
   harddisc.net — shared design system
   The single source of truth for every page on the site.
   Keep in sync with the homepage's "spinning-platter" aesthetic.
   ============================================================ */
:root{
  --paper:#f4efe6; --paper-2:#ece5d7; --panel:#fbf8f1;
  --ink:#181511; --ink-2:#37302a; --muted:#6d6254; --line:#ddd3c2; --line-2:#cabfa9;
  --signal:#df531c; --signal-deep:#b23a12; --signal-btn:#c4440f; --teal:#15554c; --teal-2:#1f7367;
  --good:#256a2f;
  --sans:"Hanken Grotesk",-apple-system,system-ui,sans-serif;
  --display:"Bricolage Grotesque",Georgia,serif;
  --mono:"Space Mono",ui-monospace,monospace;
  --maxw:1200px; --r:14px;
  --shadow:0 1px 0 var(--line), 0 8px 30px -18px rgba(24,21,17,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:16.5px;line-height:1.6;letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 1px 1px, rgba(24,21,17,.035) 1px, transparent 0);
  background-size:22px 22px;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.05;letter-spacing:-.02em;margin:0}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--signal)}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--signal-deep)}
.skip{position:absolute;left:-9999px}
.skip:focus{left:12px;top:12px;background:var(--ink);color:#fff;padding:8px 14px;border-radius:8px;z-index:99}

/* ---------- Header ---------- */
.topbar{background:var(--ink);color:#f4efe6;font-family:var(--mono);font-size:12.5px}
.topbar .wrap{display:flex;gap:18px;justify-content:center;align-items:center;padding:7px 22px;flex-wrap:wrap;text-align:center}
.topbar b{color:var(--signal)}
header.site{position:sticky;top:0;z-index:50;background:rgba(244,239,230,.86);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;height:66px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:21px;color:var(--ink);letter-spacing:-.03em}
.brand:hover{color:var(--ink)}
.platter{width:30px;height:30px;border-radius:50%;flex:0 0 auto;
  background:
   radial-gradient(circle at 50% 50%, #fff 0 14%, transparent 14.5%),
   repeating-radial-gradient(circle at 50% 50%, var(--ink) 0 1.4px, #2c2620 1.5px 3px);
  box-shadow:inset 0 0 0 1.5px var(--ink), 0 0 0 1px var(--signal);position:relative}
.platter::after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:var(--signal);top:12px;left:12px;box-shadow:0 0 6px var(--signal)}
.brand b{color:var(--signal)}
.nav .links{display:flex;gap:5px;margin-left:8px}
.nav .links a{font-family:var(--sans);font-weight:600;font-size:14.5px;color:var(--ink-2);padding:8px 11px;border-radius:9px}
.nav .links a:hover{background:var(--paper-2);color:var(--ink)}
.nav .links a[aria-current="page"]{background:var(--paper-2);color:var(--ink);box-shadow:inset 0 -2px 0 var(--signal)}
.nav .right{margin-left:auto;display:flex;gap:10px;align-items:center}
.btn{font-family:var(--sans);font-weight:700;font-size:14.5px;border:0;cursor:pointer;border-radius:10px;padding:10px 16px;background:var(--signal-btn);color:#fff;display:inline-flex;align-items:center;gap:8px;transition:transform .08s ease, background .15s;text-align:center}
.btn:hover{background:var(--signal-deep);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-2)}
.btn.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.menu-toggle{display:none}
@media(max-width:920px){
  .nav .links{display:none}
  .menu-toggle{display:inline-flex}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;inset:0;z-index:0;
  background:
   radial-gradient(circle at 82% 30%, rgba(223,83,28,.10), transparent 45%),
   repeating-radial-gradient(circle at 88% 24%, transparent 0 26px, rgba(24,21,17,.05) 26px 27px);
  pointer-events:none}
.hero .wrap{position:relative;z-index:1;padding:62px 22px 50px;display:grid;grid-template-columns:1.15fr .85fr;gap:46px;align-items:center}
.hero h1{font-size:clamp(40px,6.4vw,72px);font-weight:800;letter-spacing:-.035em}
.hero h1 .hl{color:var(--signal);position:relative;white-space:nowrap}
.hero p.lede{font-size:19px;color:var(--ink-2);max-width:46ch;margin:20px 0 26px}
.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}
.stats{display:flex;gap:0;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:var(--panel);box-shadow:var(--shadow)}
.stats div{flex:1;padding:18px 16px;text-align:center;border-right:1px solid var(--line)}
.stats div:last-child{border-right:0}
.stats .n{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--ink);line-height:1}
.stats .k{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-top:7px}
/* hero panel = mini cheapest-TB board */
.board{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.board .bh{background:var(--ink);color:#f4efe6;padding:13px 18px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:12.5px;letter-spacing:.05em}
.board .bh .dot{width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 8px var(--signal);display:inline-block;margin-right:7px;animation:blink 2.4s infinite}
@keyframes blink{0%,92%{opacity:1}96%{opacity:.25}}
.board ul{list-style:none;margin:0;padding:6px 0}
.board li{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:10px 18px;border-bottom:1px dashed var(--line)}
.board li:last-child{border-bottom:0}
.board .cat{font-weight:600;font-size:14.5px}
.board .cat small{display:block;color:var(--muted);font-weight:400;font-size:12px}
.board .ppt{font-family:var(--mono);font-weight:700;color:var(--teal);font-size:15px}
.board .arrow{color:var(--muted)}
@media(max-width:920px){.hero .wrap{grid-template-columns:1fr;gap:30px;padding:42px 22px 38px}}

/* ---------- Section scaffolding ---------- */
section{padding:58px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(26px,3.6vw,38px)}
.sec-head p{color:var(--ink-2);max-width:58ch;margin:8px 0 0}
.sec-head a.more{font-family:var(--mono);font-size:13px;white-space:nowrap}

/* ---------- Breadcrumb ---------- */
.crumbs{font-family:var(--mono);font-size:12.5px;color:var(--muted);padding:16px 0 0}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:7px;margin:0;padding:0;align-items:center}
.crumbs li{display:flex;align-items:center;gap:7px}
.crumbs li+li::before{content:"/";color:var(--line-2)}
.crumbs a{color:var(--teal)}
.crumbs a:hover{color:var(--signal)}
.crumbs [aria-current="page"]{color:var(--ink-2)}

/* ---------- Page hero (inner pages) ---------- */
.phero{border-bottom:1px solid var(--line);background:var(--paper);position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(circle at 90% 18%, rgba(223,83,28,.08), transparent 42%);pointer-events:none}
.phero .wrap{position:relative;z-index:1;padding:30px 22px 42px}
.phero h1{font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-.03em;max-width:20ch}
.phero .lede{font-size:18px;color:var(--ink-2);max-width:62ch;margin:18px 0 0}
.phero .meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:20px;font-family:var(--mono);font-size:12.5px;color:var(--muted)}
.phero .meta b{color:var(--teal)}

/* ---------- Category grid ---------- */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:980px){.cats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cats{grid-template-columns:1fr}}
.cat-card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px;transition:transform .1s ease,border-color .15s,box-shadow .15s;position:relative;overflow:hidden}
.cat-card:hover{transform:translateY(-3px);border-color:var(--signal);box-shadow:var(--shadow)}
.cat-card .ic{width:38px;height:38px;color:var(--ink);margin-bottom:14px}
.cat-card h3{font-size:18px;color:var(--ink);margin-bottom:6px}
.cat-card p{font-size:13.5px;color:var(--ink-2);margin:0 0 14px;line-height:1.45}
.cat-card .meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:12px;color:var(--muted);border-top:1px dashed var(--line);padding-top:11px}
.cat-card .meta b{color:var(--teal)}

/* ---------- Catalog (the dynamic feature) ---------- */
.catalog-band{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cat-tools{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow);padding:16px;margin-bottom:18px}
.searchrow{display:flex;gap:10px;flex-wrap:wrap}
.searchbox{flex:1;min-width:220px;display:flex;align-items:center;gap:9px;background:var(--paper);border:1.5px solid var(--line-2);border-radius:10px;padding:0 12px}
.searchbox:focus-within{border-color:var(--signal)}
.searchbox input{border:0;background:transparent;outline:0;font-family:var(--sans);font-size:15px;padding:11px 0;width:100%;color:var(--ink)}
.searchbox svg{color:var(--muted);flex:0 0 auto}
select{font-family:var(--sans);font-weight:600;font-size:14px;border:1.5px solid var(--line-2);background:var(--paper);color:var(--ink);border-radius:10px;padding:11px 14px;cursor:pointer}
select:focus{outline:0;border-color:var(--signal)}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.chip{font-family:var(--sans);font-weight:600;font-size:13px;border:1.5px solid var(--line-2);background:var(--paper);color:var(--ink-2);border-radius:999px;padding:7px 13px;cursor:pointer;transition:.12s;display:inline-flex;align-items:center;gap:6px}
.chip:hover{border-color:var(--ink-2)}
.chip[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip .c{font-family:var(--mono);font-size:11px;opacity:.7}
.toolbar2{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.toolbar2 .count{font-family:var(--mono);font-size:13px;color:var(--ink-2)}
.toolbar2 .count b{color:var(--ink)}
.toolbar2 .grp{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toolbar2 label{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid{grid-template-columns:1fr}}
.prod{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:11px;transition:border-color .15s,box-shadow .15s}
.prod:hover{border-color:var(--line-2);box-shadow:var(--shadow)}
.prod .badges{display:flex;gap:6px;flex-wrap:wrap}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;padding:3px 7px;border-radius:6px;background:var(--paper-2);color:var(--ink-2);border:1px solid var(--line)}
.tag.tech{background:#efe7d6;color:var(--signal-deep);border-color:#e3d6bd}
.tag.used{background:#f1e8de;color:#8a5a1e}
.tag.new{background:#e6efe7;color:var(--good);border-color:#cfe2d2}
.prod .pname{font-weight:600;font-size:14.5px;line-height:1.35;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}
.prod .specs{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;font-size:12.5px;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);padding:11px 0}
.prod .specs div span{display:block;color:var(--muted);font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px}
.prod .specs div b{font-weight:600;color:var(--ink)}
.prod .pricerow{display:flex;justify-content:space-between;align-items:flex-end;margin-top:auto}
.prod .price{font-family:var(--mono);font-weight:700;font-size:23px;color:var(--ink);line-height:1}
.prod .ppt{text-align:right}
.prod .ppt b{font-family:var(--mono);font-weight:700;color:var(--teal);font-size:15px}
.prod .ppt span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-family:var(--mono)}
.prod .deal{margin-top:2px}
.prod .deal a{display:flex;justify-content:center;align-items:center;gap:7px;background:var(--ink);color:#fff;font-weight:700;font-size:14px;border-radius:9px;padding:11px;transition:.13s}
.prod .deal a:hover{background:var(--signal-deep)}
.skeleton .prod{min-height:230px}
.shimmer{position:relative;overflow:hidden;background:var(--paper-2);border-radius:6px}
.shimmer::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);transform:translateX(-100%);animation:sh 1.3s infinite}
@keyframes sh{100%{transform:translateX(100%)}}
.pager{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:26px;flex-wrap:wrap}
.pager button{font-family:var(--mono);font-size:13px;border:1.5px solid var(--line-2);background:var(--panel);color:var(--ink);border-radius:9px;padding:9px 13px;cursor:pointer;min-width:42px}
.pager button:hover:not(:disabled){border-color:var(--ink)}
.pager button[aria-current="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager button:disabled{opacity:.4;cursor:default}
.noresults{text-align:center;padding:50px 20px;color:var(--muted);font-family:var(--mono)}

/* ---------- Catalog table view ---------- */
.tablewrap{border:1px solid var(--line-2);border-radius:var(--r);overflow:auto;background:var(--panel);box-shadow:var(--shadow);-webkit-overflow-scrolling:touch}
table.cat-table{width:100%;border-collapse:collapse;font-size:14px;min-width:680px}
table.cat-table thead th{position:sticky;top:0;background:var(--ink);color:#f4efe6;font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:12px 14px;white-space:nowrap;z-index:2}
table.cat-table thead th.sortable{cursor:pointer;user-select:none}
table.cat-table thead th.sortable:hover{color:var(--signal)}
table.cat-table thead th .ar{opacity:.5;font-size:10px}
table.cat-table thead th[aria-sort="ascending"] .ar,table.cat-table thead th[aria-sort="descending"] .ar{opacity:1;color:var(--signal)}
table.cat-table tbody td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
table.cat-table tbody tr:hover{background:var(--paper-2)}
table.cat-table .t-name{font-weight:600;color:var(--ink);max-width:340px}
table.cat-table .t-name a{color:var(--ink)}
table.cat-table .t-name a:hover{color:var(--signal)}
table.cat-table .t-ppt{font-family:var(--mono);font-weight:700;color:var(--teal);white-space:nowrap}
table.cat-table .t-price,table.cat-table .t-cap{font-family:var(--mono);white-space:nowrap}
table.cat-table .t-cat{font-size:12px;color:var(--muted)}

/* ---------- Best-value highlight ---------- */
.bestval{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;background:var(--ink);color:#f4efe6;border-radius:var(--r);padding:20px 22px;margin-bottom:18px;box-shadow:var(--shadow)}
.bestval .lab{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--signal);writing-mode:vertical-rl;transform:rotate(180deg)}
.bestval .bv-name{font-weight:600;font-size:15px;color:#fff;line-height:1.35}
.bestval .bv-sub{font-family:var(--mono);font-size:12px;color:#cfc7b9;margin-top:5px}
.bestval .bv-num{text-align:right}
.bestval .bv-num b{font-family:var(--mono);font-size:26px;color:var(--signal);line-height:1}
.bestval .bv-num span{display:block;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#cfc7b9;margin-top:4px}
.bestval .bv-num a{display:inline-block;margin-top:10px;background:var(--signal);color:#fff;font-weight:700;font-size:13px;border-radius:8px;padding:8px 14px}
.bestval .bv-num a:hover{background:#fff;color:var(--ink)}
@media(max-width:600px){.bestval{grid-template-columns:1fr}.bestval .lab{writing-mode:horizontal-tb;transform:none}.bestval .bv-num{text-align:left}}

/* ---------- Prose / article body ---------- */
.prose{max-width:760px;margin:0 auto;font-size:17px;line-height:1.7;color:var(--ink-2)}
.prose.wide{max-width:880px}
.prose h2{font-size:clamp(24px,3.2vw,32px);color:var(--ink);margin:42px 0 14px;letter-spacing:-.02em}
.prose h3{font-size:21px;color:var(--ink);margin:30px 0 10px}
.prose p{margin:0 0 18px}
.prose ul,.prose ol{margin:0 0 20px;padding-left:22px}
.prose li{margin:0 0 9px}
.prose strong{color:var(--ink);font-weight:700}
.prose a{font-weight:600;text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:3px}
.prose a:hover{text-decoration-color:var(--signal)}
.prose blockquote{margin:24px 0;padding:14px 20px;border-left:3px solid var(--signal);background:var(--panel);border-radius:0 10px 10px 0;color:var(--ink-2);font-size:16px}
.prose code{font-family:var(--mono);font-size:.88em;background:var(--paper-2);padding:2px 6px;border-radius:5px;color:var(--signal-deep)}
.prose figure{margin:24px 0}
.prose .lead{font-size:19px;color:var(--ink);font-weight:500}
.callout{background:var(--panel);border:1px solid var(--line-2);border-left:4px solid var(--teal);border-radius:0 12px 12px 0;padding:18px 22px;margin:26px 0}
.callout.warn{border-left-color:var(--signal)}
.callout .callout-h{font-family:var(--display);font-weight:700;font-size:17px;line-height:1.15;color:var(--ink);margin:0 0 8px}
.callout p{margin:0;font-size:15.5px}
.callout p+p{margin-top:10px}

/* ---------- Data tables in prose ---------- */
.dtable{width:100%;border-collapse:collapse;font-size:14.5px;margin:24px 0;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden}
.dtable caption{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);text-align:left;padding:0 0 10px}
.dtable th,.dtable td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line)}
.dtable thead th{background:var(--paper-2);font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-2)}
.dtable tbody tr:last-child td{border-bottom:0}
.dtable tbody tr:nth-child(even){background:rgba(236,229,215,.4)}
.dtable td.y{color:var(--good);font-weight:700}
.dtable td.n{color:var(--signal-deep);font-weight:700}
.tablescroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ---------- Mini picks (guides/brands) ---------- */
.picks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:26px 0}
@media(max-width:780px){.picks{grid-template-columns:1fr}}

/* ---------- TOC ---------- */
.toc{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r);padding:18px 22px;margin:0 auto 30px;max-width:760px}
.toc h2{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 10px}
.toc ol{margin:0;padding-left:20px;columns:2;column-gap:30px}
.toc li{margin:0 0 7px;font-size:14.5px}
@media(max-width:600px){.toc ol{columns:1}}

/* ---------- Guides ---------- */
.guides{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.guides{grid-template-columns:1fr}}
.guide{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;transition:.13s;display:block}
.guide:hover{border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-2px)}
.guide .k{font-family:var(--mono);font-size:11px;color:var(--signal-deep);text-transform:uppercase;letter-spacing:.12em}
.guide h3{font-size:20px;margin:9px 0 9px;color:var(--ink)}
.guide p{font-size:14px;color:var(--ink-2);margin:0 0 14px}
.guide a.rd,.guide .rd{font-family:var(--mono);font-size:13px;font-weight:700}

/* ---------- Split / brands / trust ---------- */
.split{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:24px}}
.brands{display:flex;flex-wrap:wrap;gap:9px}
.brands a{font-family:var(--mono);font-size:13.5px;font-weight:700;border:1.5px solid var(--line-2);border-radius:999px;padding:9px 16px;color:var(--ink);background:var(--panel);transition:.12s}
.brands a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.trust{background:var(--ink);color:#f4efe6;border-radius:var(--r);padding:28px}
.trust h3{color:#fff;font-size:23px;margin-bottom:14px}
.trust ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.trust li{display:flex;gap:11px;font-size:14.5px;color:#e7e0d4;line-height:1.45}
.trust li svg{flex:0 0 auto;color:var(--signal);margin-top:2px}

/* ---------- Brand grid ---------- */
.brandgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:820px){.brandgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.brandgrid{grid-template-columns:1fr}}
.brandcard{display:block;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px;transition:.12s}
.brandcard:hover{border-color:var(--signal);box-shadow:var(--shadow);transform:translateY(-2px)}
.brandcard h3{font-size:19px;color:var(--ink);margin-bottom:6px}
.brandcard p{font-size:13.5px;color:var(--ink-2);margin:0 0 14px;line-height:1.45}
.brandcard .meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;color:var(--muted);border-top:1px dashed var(--line);padding-top:11px}
.brandcard .meta b{color:var(--teal)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{border:1px solid var(--line-2);border-radius:12px;background:var(--panel);margin-bottom:11px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:18px 20px;font-family:var(--display);font-weight:700;font-size:18px;display:flex;justify-content:space-between;align-items:center;gap:14px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{font-family:var(--mono);color:var(--signal);font-size:22px;transition:transform .2s;line-height:1;flex:0 0 auto}
.faq details[open] summary .pl{transform:rotate(45deg)}
.faq .ans{padding:0 20px 20px;color:var(--ink-2);font-size:15px;line-height:1.65}
.faq .ans a{font-weight:600}

/* ---------- CTA band ---------- */
.band{background:var(--teal);color:#fff}
.band .wrap{padding:54px 22px;text-align:center}
.band h2{color:#fff;font-size:clamp(26px,4vw,40px)}
.band p{color:#d6ebe6;max-width:54ch;margin:14px auto 24px;font-size:17px}
.band .btn{background:#fff;color:var(--teal)}
.band .btn:hover{background:var(--paper);color:var(--teal)}

/* ---------- Tools: compare / calculator ---------- */
.tool-card{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow);padding:24px;margin-bottom:24px}
.tool-card h2{font-size:23px;color:var(--ink);margin-bottom:6px}
.tool-card .hint{color:var(--muted);font-size:14px;margin:0 0 18px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-2)}
.field input[type=number],.field input[type=text],.field select{font-family:var(--sans);font-size:15px;border:1.5px solid var(--line-2);background:var(--paper);color:var(--ink);border-radius:10px;padding:11px 13px;width:100%}
.field input:focus{outline:0;border-color:var(--signal)}
.field .row{display:flex;gap:12px;flex-wrap:wrap}
.rangeval{font-family:var(--mono);font-weight:700;color:var(--teal)}
.fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 22px}
@media(max-width:600px){.fields-grid{grid-template-columns:1fr}}
.result-box{background:var(--ink);color:#f4efe6;border-radius:12px;padding:22px;margin-top:8px}
.result-box .big{font-family:var(--mono);font-size:34px;font-weight:700;color:var(--signal);line-height:1}
.result-box .lbl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#cfc7b9;margin-top:6px}
.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:18px}
.result-grid>div{border-left:2px solid #2e2820;padding-left:14px}
.result-grid>div:first-child{border-left:0;padding-left:0}
.fits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-top:14px}
.fits-grid .ft{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:14px;text-align:center}
.fits-grid .ft b{display:block;font-family:var(--mono);font-size:22px;color:var(--ink)}
.fits-grid .ft span{font-size:12px;color:var(--muted)}
.seg{display:inline-flex;border:1.5px solid var(--line-2);border-radius:10px;overflow:hidden;flex-wrap:wrap}
.seg button{font-family:var(--sans);font-weight:600;font-size:13.5px;border:0;background:var(--paper);color:var(--ink-2);padding:10px 14px;cursor:pointer;border-right:1px solid var(--line-2)}
.seg button:last-child{border-right:0}
.seg button[aria-pressed="true"]{background:var(--ink);color:#fff}

/* compare table */
.cmp-add{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.cmp-results{position:relative}
.cmp-suggest{list-style:none;margin:6px 0 0;padding:0;border:1px solid var(--line-2);border-radius:10px;background:var(--panel);max-height:280px;overflow:auto;box-shadow:var(--shadow)}
.cmp-suggest li{padding:10px 14px;border-bottom:1px solid var(--line);cursor:pointer;font-size:14px;display:flex;justify-content:space-between;gap:12px}
.cmp-suggest li:last-child{border-bottom:0}
.cmp-suggest li:hover,.cmp-suggest li[aria-selected="true"]{background:var(--paper-2)}
.cmp-suggest .s-ppt{font-family:var(--mono);color:var(--teal);font-weight:700;white-space:nowrap}
.cmp-table{overflow-x:auto}
.cmp-table table{width:100%;border-collapse:collapse;min-width:520px}
.cmp-table th,.cmp-table td{padding:13px 15px;border:1px solid var(--line);text-align:left;font-size:14px;vertical-align:top}
.cmp-table thead th{background:var(--panel);font-family:var(--display);font-size:15px;color:var(--ink);position:relative}
.cmp-table thead th .rm{position:absolute;top:8px;right:8px;background:var(--paper-2);border:1px solid var(--line-2);border-radius:6px;width:22px;height:22px;cursor:pointer;color:var(--muted);font-family:var(--mono);line-height:1}
.cmp-table thead th .rm:hover{background:var(--signal);color:#fff;border-color:var(--signal)}
.cmp-table tbody th{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--paper-2);white-space:nowrap}
.cmp-table .best{color:var(--good);font-weight:700}
.cmp-table .winrow{background:rgba(47,125,58,.07)}

/* ---------- Mini board / stat list ---------- */
.statline{display:flex;gap:0;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:var(--panel);box-shadow:var(--shadow);flex-wrap:wrap}
.statline div{flex:1;min-width:120px;padding:16px;text-align:center;border-right:1px solid var(--line)}
.statline div:last-child{border-right:0}
.statline .n{font-family:var(--mono);font-size:24px;font-weight:700;color:var(--ink);line-height:1}
.statline .k{font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-top:7px}

/* ---------- Related links row ---------- */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:10px}
@media(max-width:780px){.related{grid-template-columns:1fr}}
.related a{display:block;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;transition:.12s}
.related a:hover{border-color:var(--signal);box-shadow:var(--shadow);transform:translateY(-2px)}
.related a .k{font-family:var(--mono);font-size:11px;color:var(--signal-deep);text-transform:uppercase;letter-spacing:.1em}
.related a h3{font-size:17px;color:var(--ink);margin:7px 0 5px}
.related a p{font-size:13px;color:var(--ink-2);margin:0}

/* ---------- Footer ---------- */
footer.site{background:var(--ink);color:#cfc7b9;padding:54px 0 30px;font-size:14px}
footer.site a{color:#cfc7b9}
footer.site a:hover{color:var(--signal)}
.fgrid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:28px;margin-bottom:34px}
@media(max-width:900px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}}
.fcol h3{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:14px;font-weight:700}
.fcol ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.fcol .brand{color:#fff;margin-bottom:12px}
.fabout{font-size:13.5px;color:#b8ae9c;max-width:34ch;line-height:1.6}
.fbottom{border-top:1px solid #2e2820;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:#a89e8f;font-family:var(--mono)}
.disc{background:#221d18;border:1px solid #2e2820;border-radius:10px;padding:14px 18px;font-size:12.5px;color:#b8ae9c;margin-bottom:30px;line-height:1.55}
.disc b{color:#e7e0d4}
.disc a{color:#f2925a;text-decoration:underline;text-underline-offset:2px}
.disc a:hover{color:#ffb27e}

/* ---------- Utility ---------- */
.center{text-align:center}
.muted{color:var(--muted)}
.mt0{margin-top:0}
.narrow{max-width:760px;margin-left:auto;margin-right:auto}
.divider{border:0;border-top:1px solid var(--line);margin:36px 0}
.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}
.pill{font-family:var(--mono);font-size:12px;border:1.5px solid var(--line-2);border-radius:999px;padding:6px 12px;color:var(--ink-2);background:var(--panel)}
:focus-visible{outline:2px solid var(--signal);outline-offset:2px;border-radius:4px}
