/*
Theme Name: TheTestedHub
Theme URI: https://thetestedhub.com
Author: TheTestedHub
Description: Review Hub theme — Review, Roundup, VS and Category templates with Amazon Creators API live data (hotlink images + live price). Light, fast, E-E-A-T first.
Version: 1.0
License: GPL-2.0+
Text Domain: thetestedhub
*/
*{margin:0;padding:0;box-sizing:border-box}
:root{--ink:#11181f;--mut:#5e6b78;--line:#e7ecf1;--bg:#f6f8fb;--card:#fff;--brand:#0a7d5a;--brand2:#0fb27e;--amber:#ff9e1b;--red:#e23b3b;--blue:#2d6cdf;--orange:#e8702a}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);line-height:1.65}
a{color:var(--brand)}
img{max-width:100%;height:auto}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 24px}
.wrap-mid{max-width:1000px;margin:0 auto;padding:0 24px}

/* header */
.site-head{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.hd{display:flex;align-items:center;gap:22px;padding:13px 0}
.logo{font-weight:800;font-size:19px;display:flex;gap:8px;align-items:center;white-space:nowrap;text-decoration:none;color:var(--ink)}
.mk{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px}
.searchbox{flex:1;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:10px 14px;color:var(--mut);font-size:13px}
.mainnav a{color:var(--ink);text-decoration:none;font-size:14px;font-weight:600;margin-left:18px}
.mainnav a:hover{color:var(--brand)}

/* breadcrumb + headings */
.crumb{font-size:13px;color:var(--mut);padding:18px 0 0}.crumb a{color:var(--brand);text-decoration:none}
.kick{font-size:12px;font-weight:800;letter-spacing:1.5px;color:var(--amber);margin-top:12px}
h1{font-size:clamp(28px,4vw,42px);letter-spacing:-1px;line-height:1.12;margin:10px 0 8px}
.entry h2{font-size:23px;letter-spacing:-.4px;margin:30px 0 12px;scroll-margin-top:90px}
.entry h3{font-size:18px;margin:18px 0 6px}
.entry p{margin:12px 0;font-size:16.5px}
.byl{display:flex;flex-wrap:wrap;gap:14px;color:var(--mut);font-size:14px;align-items:center}
.byl b{color:var(--ink)}
.byl .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}

/* FTC + callouts */
.ftc{font-size:12.5px;color:var(--mut);background:#fff8ec;border:1px solid #ffe6bf;padding:9px 13px;border-radius:9px;margin:14px 0}
.callout{border-radius:14px;padding:18px 20px;margin:16px 0}
.callout.q,.callout.key{background:#eafaf3;border:1px solid #cdeede}
.callout.pro{background:#f0f6ff;border:1px solid #d4e4fb}
.callout h4{font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:5px;color:var(--brand)}
.callout.pro h4{color:#2563c9}

/* TOC */
.toc{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin:18px 0}
.toc h4{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--mut);margin-bottom:8px}
.toc a{display:block;color:var(--ink);text-decoration:none;font-size:14px;padding:5px 0;border-bottom:1px dashed var(--line)}
.toc a:hover{color:var(--brand)}

/* layout w/ sticky aside (review) */
.layout{display:grid;grid-template-columns:1fr 330px;gap:34px;align-items:start;padding:8px 0 40px}
.aside{position:sticky;top:90px}

/* buy box */
.buy{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 14px 34px rgba(17,24,31,.07)}
.buy .ph{height:200px;background:#fff;display:grid;place-items:center;overflow:hidden;padding:14px}
.buy .ph img{max-width:100%;max-height:100%;object-fit:contain}
.buy .bi{padding:18px}
.scorebig{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.scorebig .n{background:var(--brand);color:#fff;font-weight:800;font-size:22px;border-radius:10px;padding:6px 12px}
.scorebig .lb{font-size:13px;color:var(--mut)}
.buy h3{font-size:18px;margin-bottom:10px}
.livep{display:flex;align-items:baseline;gap:8px;margin:4px 0 2px}
.livep .now{font-size:26px;font-weight:800}.livep .was{color:var(--mut);text-decoration:line-through;font-size:15px}
.livep .off{background:var(--red);color:#fff;font-size:11px;font-weight:800;padding:2px 7px;border-radius:5px}
.livelbl{font-size:11px;color:var(--brand);font-weight:700;margin-bottom:10px}
.livelbl .dot{display:inline-block;width:7px;height:7px;background:var(--brand2);border-radius:50%;margin-right:4px}
.cta{display:block;text-align:center;background:var(--amber);color:#3a2400;font-weight:800;padding:13px;border-radius:10px;text-decoration:none}
.retail{margin-top:10px}.retail a{display:flex;justify-content:space-between;text-decoration:none;color:var(--ink);font-size:14px;padding:9px 0;border-top:1px solid var(--line)}
.noprice{font-size:12px;color:var(--mut);margin-top:10px;line-height:1.4}

/* mini-bar */
.minibar{position:sticky;top:55px;z-index:20;background:#0d2a22;color:#fff;padding:10px 0;font-size:14px}
.minibar .in{display:flex;align-items:center;justify-content:space-between}
.minibar .mb-cta{background:var(--amber);color:#3a2400;padding:7px 16px;border-radius:8px;font-weight:800;text-decoration:none;font-size:13px}

/* pros/cons */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
.pc .box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px}
.pc h4{font-size:15px;margin-bottom:10px}.pc .pros h4{color:var(--brand)}.pc .cons h4{color:var(--red)}
.pc ul{list-style:none}.pc li{font-size:14px;padding:6px 0 6px 24px;position:relative}
.pc .pros li:before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:800}
.pc .cons li:before{content:"✕";position:absolute;left:0;color:var(--red);font-weight:800}

/* rating bars */
.bars{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;margin:16px 0}
.bar{display:flex;align-items:center;gap:12px;padding:7px 0}
.bar .nm{width:160px;font-size:14px;color:var(--mut)}
.bar .tr{flex:1;height:8px;background:var(--bg);border-radius:5px;overflow:hidden}
.bar .fl{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand2))}
.bar .sc{width:34px;text-align:right;font-weight:800;font-size:14px}

/* spec grid */
.specgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0}
.spec{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.spec .sl{color:var(--mut);font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px}
.spec .sv{font-weight:700;font-size:14px;text-align:right}
.spec.amz{border-color:#cdeede;background:#f5fbf8}
.spec.amz .sl:after{content:"LIVE";font-size:9px;font-weight:800;color:#fff;background:var(--brand2);padding:1px 5px;border-radius:4px;margin-left:2px}
.specnote{font-size:12.5px;color:var(--mut);margin-top:10px}

/* tables */
table.cmp,table.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:14px;margin:16px 0}
.cmp th,.cmp td,.tbl th,.tbl td{padding:11px 13px;text-align:left;border-bottom:1px solid var(--line)}
.cmp th,.tbl th{background:#0d2a22;color:#fff;font-size:13px}
.tbl a{color:var(--brand);text-decoration:none;font-weight:700}
.tcta{background:var(--amber);color:#3a2400;font-weight:800;font-size:12px;padding:5px 10px;border-radius:6px;text-decoration:none;white-space:nowrap}
.win{background:#eafaf3}

/* roundup product cards */
.pcard{display:grid;grid-template-columns:130px 1fr;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin:14px 0}
.pcard .pimg{height:130px;background:#fff;border:1px solid var(--line);border-radius:10px;display:grid;place-items:center;padding:8px}
.pcard .pimg img{max-width:100%;max-height:100%;object-fit:contain}
.rank{display:inline-block;background:var(--amber);color:#3a2400;font-size:11px;font-weight:800;padding:3px 9px;border-radius:5px}
.pcard h3{font-size:18px;margin:7px 0 5px;line-height:1.2}
.pcard .why{font-size:14.5px;color:#2c3540;margin:0 0 9px}
.prow{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.price{font-weight:800;font-size:15px}.price s{color:var(--mut);font-weight:500;font-size:12px}
.asof{font-size:10px;color:var(--brand);font-weight:700}
.pcard .cta-inline{background:var(--amber);color:#3a2400;font-weight:800;font-size:13px;padding:9px 16px;border-radius:8px;text-decoration:none}

/* stats bar */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center}
.stat b{font-size:22px;color:var(--brand);display:block}.stat span{font-size:12px;color:var(--mut)}

/* ctabar */
.ctabar{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#0d2a22;color:#fff;border-radius:14px;padding:16px 20px;flex-wrap:wrap;margin:20px 0}
.ctabar b{font-size:15px}.ctabar a{background:var(--amber);color:#3a2400;font-weight:800;padding:10px 18px;border-radius:9px;text-decoration:none;white-space:nowrap}

/* factors / who */
.factors{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
.fct{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:15px}
.fct h4{font-size:15px;margin-bottom:4px}.fct p{font-size:13.5px;color:var(--mut)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:12px 0}
.gitem{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card)}
.gitem.ph{border-style:dashed;border-color:#b9c6d2}
.gph{height:120px;background:repeating-linear-gradient(45deg,#eef3f8,#eef3f8 10px,#e6edf4 10px,#e6edf4 20px);display:grid;place-items:center;color:#8aa0b4;font-size:13px;text-align:center}
.gitem img{width:100%;height:120px;object-fit:cover;display:block}
.gcap{padding:9px 11px;font-size:12px;color:var(--mut);line-height:1.35}
.gnote{font-size:12px;color:var(--mut);margin-top:9px}

/* faq */
.faq .q{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:13px 16px;margin-bottom:9px}
.faq .q b{display:block;margin-bottom:4px}.faq .q p{font-size:14px;color:var(--mut)}

/* author + related */
.authorbox{display:flex;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;margin-top:20px}
.authorbox .av{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;display:grid;place-items:center;font-weight:800;font-size:19px;flex:none}
.authorbox .role{color:var(--mut);font-size:13px}.authorbox .creds span{display:inline-block;background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:3px 10px;margin:4px 4px 0 0;font-size:12px}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.rc{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;text-decoration:none;color:var(--ink);transition:.2s}
.rc:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(17,24,31,.08)}
.rc .rt{height:80px;background:linear-gradient(135deg,#eafaf3,#d4f3e6);display:grid;place-items:center;font-size:30px}
.rc .ri{padding:11px}.rc h4{font-size:14px;line-height:1.25}.rc .sc{color:var(--brand);font-weight:800;font-size:13px}

/* category / homepage grids */
.subchips{display:flex;flex-wrap:wrap;gap:9px;margin:18px 0}
.subchips a{background:var(--card);border:1px solid var(--line);border-radius:30px;padding:8px 15px;text-decoration:none;color:var(--ink);font-size:14px;font-weight:600}
.subchips a:hover{border-color:var(--brand);color:var(--brand)}
.subchips a b{color:var(--mut);font-weight:700;margin-left:4px}
.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin:14px 0}
.tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;text-decoration:none;color:var(--ink);transition:.2s}
.tile:hover{border-color:var(--brand);transform:translateY(-3px)}
.tile .e{font-size:26px}.tile h4{font-size:15px;margin:8px 0 1px}.tile span{font-size:12px;color:var(--mut)}
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:14px 0}
.fc{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.2s;text-decoration:none;color:var(--ink)}
.fc:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(17,24,31,.08)}
.fc .ph{height:118px;background:#fff;display:grid;place-items:center;overflow:hidden;padding:10px;border-bottom:1px solid var(--line)}
.fc .ph img{max-width:100%;max-height:100%;object-fit:contain}.fc .ph .em{font-size:46px}
.fc .in{padding:15px}.fc h3{font-size:16px;margin:9px 0 6px;line-height:1.25}
.fc .meta{display:flex;justify-content:space-between;align-items:center}
.fc .scbadge{background:var(--brand);color:#fff;font-weight:800;border-radius:7px;padding:3px 8px;font-size:13px}
.listrow{display:flex;gap:14px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px;text-decoration:none;color:var(--ink)}
.listrow:hover{border-color:var(--brand)}
.listrow .th{width:54px;height:54px;border-radius:10px;background:#eef7f2;display:grid;place-items:center;font-size:24px;flex:none;overflow:hidden}
.listrow .th img{width:100%;height:100%;object-fit:contain}
.listrow .rin{flex:1;min-width:0}.listrow h4{font-size:15px;line-height:1.2;margin-bottom:2px}.listrow .sub{color:var(--mut);font-size:12.5px}
.listrow .sc{font-weight:800;color:var(--brand);margin-left:auto}

/* hero */
.hero h1{max-width:760px}
.hero .sub{color:var(--mut);font-size:18px;margin-top:12px;max-width:620px}
.trust{display:flex;gap:22px;margin:16px 0;flex-wrap:wrap;color:var(--mut);font-size:13px;font-weight:600}
.trust b{color:var(--ink)}
.sec-h{display:flex;justify-content:space-between;align-items:baseline;margin:30px 0 14px}
.sec-h h2{font-size:21px;letter-spacing:-.5px}.sec-h a{color:var(--brand);text-decoration:none;font-size:14px;font-weight:600}

/* versus */
.versus{display:grid;grid-template-columns:1fr 70px 1fr;gap:0;margin:14px 0}
.vside{border-radius:18px;padding:24px;color:#fff;text-align:center}
.vside.a{background:linear-gradient(135deg,#2d6cdf,#5b8cff)}.vside.b{background:linear-gradient(135deg,#e8702a,#f2994a)}
.vside .em{font-size:44px}.vside h2{font-size:22px;margin:8px 0 4px;color:#fff}.vside p{font-size:14px;opacity:.95}
.vsmid{display:grid;place-items:center;font-weight:900}.vsmid span{background:var(--card);border:2px solid var(--line);border-radius:50%;width:52px;height:52px;display:grid;place-items:center}

/* footer + pager */
.site-foot{border-top:1px solid var(--line);padding:30px 0;color:var(--mut);font-size:13px;text-align:center;margin-top:30px;background:var(--card)}
.site-foot a{color:var(--mut);margin:0 8px}
.pager{display:flex;justify-content:center;gap:8px;margin:26px 0}
.pager a,.pager span{min-width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--line);border-radius:9px;text-decoration:none;color:var(--ink);font-weight:600;padding:0 6px}
.pager .current{background:var(--brand);color:#fff;border-color:var(--brand)}
/* ---- category page (mockup parity) ---- */
.chead{padding:14px 0 4px}
.chead .ic{font-size:34px;line-height:1}
.chead h1{font-size:clamp(28px,4vw,40px);letter-spacing:-1px;margin:6px 0 6px}
.chead p{color:var(--mut);max-width:680px}
.cstat{display:flex;gap:20px;flex-wrap:wrap;margin-top:12px;color:var(--mut);font-size:13px;font-weight:600}
.cstat b{color:var(--ink)}
.subchips a.all{background:var(--brand);color:#fff;border-color:var(--brand)}
.subchips a.all b{color:#bfeede}
.sec-h .sort{font-size:13px;color:var(--mut)}
.fc .ph{cursor:pointer}
.fc .rib{display:inline-block;background:var(--amber);color:#3a2400;font-size:11px;font-weight:800;padding:3px 9px;border-radius:5px}
.fc h3 a{color:inherit;text-decoration:none}
.fc .cta{color:var(--brand);font-weight:700;text-decoration:none;font-size:13px}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.grid .row{display:flex;gap:14px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px;transition:.2s}
.grid .row:hover{border-color:var(--brand)}
.grid .row .th{width:54px;height:54px;border-radius:10px;background:#eef7f2;display:grid;place-items:center;font-size:24px;flex:none;overflow:hidden;text-decoration:none}
.grid .row .th img{width:100%;height:100%;object-fit:contain}
.grid .row .rin{flex:1;min-width:0}
.grid .row h4{font-size:15px;line-height:1.2;margin-bottom:2px}
.grid .row h4 a{color:var(--ink);text-decoration:none}
.grid .row .sub{color:var(--mut);font-size:12.5px}
.grid .row .rrib{display:inline-block;background:#eef7f2;color:var(--brand);font-size:11px;font-weight:700;padding:2px 7px;border-radius:5px;margin-top:3px}
.grid .row .right{text-align:right;flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.grid .row .right .sc{font-weight:800;color:var(--brand)}
.grid .row .right .cta{display:block;background:var(--amber);color:#3a2400;font-weight:800;font-size:11px;padding:5px 10px;border-radius:6px;text-decoration:none;white-space:nowrap}
.intro{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;margin:28px 0;font-size:15px;color:#333}
.intro h2{font-size:19px;margin-bottom:8px;color:var(--ink)}
/* ---- category bottom content (what's covered + method + faq) ---- */
.catabout{margin:34px 0 10px}
.catabout h2{font-size:22px;letter-spacing:-.4px;margin:30px 0 12px}
.catabout .lead{color:var(--mut);max-width:760px;margin-bottom:16px}
.covergrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.coveritem{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:13px 14px;text-decoration:none;color:var(--ink);transition:.2s}
.coveritem:hover{border-color:var(--brand);transform:translateY(-2px)}
.coveritem .ci-ic{font-size:23px;flex:none}
.coveritem .ci-tx{display:flex;flex-direction:column;min-width:0}
.coveritem .ci-tx b{font-size:14px;line-height:1.2}
.coveritem .ci-tx span{color:var(--mut);font-size:12px}
.catabout .method-b{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 22px;color:#333;font-size:15px}
.catabout .method-b p{margin-bottom:12px}.catabout .method-b p:last-child{margin-bottom:0}
.catabout .faq .q{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:15px 17px;margin-bottom:10px}
.catabout .faq .q b{display:block;font-size:15.5px;margin-bottom:5px}
.catabout .faq .q p{color:var(--mut);font-size:14.5px;margin:0}
@media(max-width:900px){.covergrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.covergrid{grid-template-columns:1fr}}

@media(max-width:900px){.layout{grid-template-columns:1fr}.aside{position:static}.cat-grid{grid-template-columns:1fr 1fr 1fr}.feat,.pc,.factors,.specgrid,.gallery,.related,.grid{grid-template-columns:1fr 1fr}.versus{grid-template-columns:1fr}.mainnav,.searchbox{display:none}}
@media(max-width:560px){.cat-grid,.feat,.pc,.factors,.specgrid,.related,.pcard{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}}
.author-social{margin-top:8px;font-size:13px;font-weight:600}
.author-social a{color:var(--brand);text-decoration:none}

/* ===== roundup rich pattern (locked standard) ===== */
.toc{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 18px;margin:16px 0}
.toc b{font-size:14px}.toc ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px 18px;margin:8px 0 0;padding:0}
.toc a{color:var(--brand);font-weight:600;font-size:14px;text-decoration:none}
.entry .callout.q{border-left:4px solid var(--brand2)}
.toppick{background:linear-gradient(135deg,var(--brand),#075f44);color:#fff;border-radius:20px;padding:22px;margin:18px 0;box-shadow:0 14px 34px -18px rgba(10,125,90,.6)}
.tp-badge{display:inline-block;background:var(--brand2);color:#04231a;font-weight:800;font-size:12.5px;letter-spacing:.04em;padding:5px 12px;border-radius:999px;margin-bottom:14px}
.tp-grid{display:grid;grid-template-columns:200px 1fr;gap:22px;align-items:center}
.tp-img{background:#fff;border-radius:14px;min-height:170px;display:flex;align-items:center;justify-content:center;position:relative;padding:12px}
.tp-img img{max-width:100%;max-height:160px;object-fit:contain}
.tp-img .sc{position:absolute;top:8px;left:8px;background:var(--brand);color:#fff;font-weight:800;border-radius:10px;padding:5px 9px;font-size:14px}
.tp-rank{display:inline-block;background:var(--brand2);color:#04231a;font-size:11px;font-weight:800;padding:5px 12px;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}
.tp-name{color:#fff;margin:6px 0 8px;font-size:25px}.tp-body p{color:#e7f5ef;margin:0 0 12px}
.tp-specs{display:flex;flex-wrap:wrap;gap:8px 18px;margin-bottom:14px;font-size:13.5px;color:#cfeae0}.tp-specs b{color:#fff}
.cta.big{display:inline-block;background:var(--brand2);color:#04231a;font-weight:800;padding:13px 26px;border-radius:30px;text-decoration:none;font-size:16px}
.awards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:14px 0 22px}
.award{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px 12px;text-align:center;text-decoration:none}
.award span{display:block;color:var(--brand);font-weight:700;font-size:12px;text-transform:uppercase}.award b{display:block;font-size:13.5px;margin-top:3px;color:var(--ink)}
.method{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 20px;margin:18px 0}.method h2{margin:0 0 6px;font-size:19px}.method-b p{margin:0;color:#3a4650}
.pcard .pbody .pc{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
.pc .box{padding:10px 12px;border-radius:12px;border:1px solid var(--line)}.pc .box.pros{background:#effaf4}.pc .box.cons{background:#fef2f2}
.pc .box h4{font-size:13px;margin:0 0 5px}.pc .box ul{margin:0;padding-left:16px;font-size:13.5px}
.pcard .prow{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.pcard .cta{background:var(--brand);color:#fff;font-weight:800;padding:12px 24px;border-radius:30px;text-decoration:none;font-size:14.5px}
.full-review{color:var(--brand);font-weight:700;padding:11px 22px;border-radius:30px;border:1.5px solid var(--brand);text-decoration:none;font-size:14px}
.updates{margin:24px 0}.ulog{list-style:none;margin:8px 0 0;padding:0;border-left:2px solid var(--line)}
.ulog li{position:relative;padding:7px 0 7px 18px;font-size:14px}.ulog li:before{content:"";position:absolute;left:-5px;top:14px;width:8px;height:8px;border-radius:50%;background:var(--brand2)}
.vembed{position:relative;padding-bottom:56.25%;height:0;border-radius:16px;overflow:hidden;margin:10px 0;background:#000}.vembed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.authorbox .abx-top{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.authorbox .role{color:var(--brand);font-weight:700;font-size:12.5px;text-transform:uppercase}
.authorbox .creds{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px}.authorbox .creds span{background:#eff5f1;border:1px solid #d4e6dc;font-size:12px;padding:3px 10px;border-radius:20px}
@media(max-width:640px){.tp-grid,.pc{grid-template-columns:1fr}}
/* tools index + related-tools grid (TTH themed) */
.tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}
.tools-grid.big{grid-template-columns:repeat(3,1fr);gap:14px}
.tool-card{display:flex;flex-direction:column;gap:5px;background:var(--card,#fff);border:1px solid var(--line,#e7ecf1);border-radius:13px;padding:15px 16px;text-decoration:none;color:var(--ink,#11181f);transition:.18s}
.tool-card:hover{border-color:var(--brand,#0a7d5a);transform:translateY(-3px);box-shadow:0 12px 26px rgba(17,24,31,.08)}
.tool-card .tt{font-size:10px;font-weight:800;letter-spacing:1.2px;color:var(--brand,#0a7d5a);text-transform:uppercase}
.tool-card b{font-size:15px;line-height:1.25}
.tool-card .td{font-size:12.5px;color:var(--mut,#5e6b78)}
.tool-more{margin:36px 0 10px}.tool-more h2{font-size:20px;margin-bottom:6px}
@media(max-width:900px){.tools-grid,.tools-grid.big{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tools-grid,.tools-grid.big{grid-template-columns:1fr}}

/* Fix: related-card image was unconstrained (.rp had no CSS, only .rt) -> huge images */
.rc .rp{height:90px;background:#fff;display:grid;place-items:center;padding:8px;border-bottom:1px solid var(--line)}
.rc .rp img{max-width:100%;max-height:78px;width:auto;object-fit:contain}
.related{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
