/* ============================================================
   Read Vault — premium editorial stylesheet (lightweight, fast)
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
:root{
  --ink:#0d1320; --body:#475063; --muted:#7a8290; --line:#eaecf1; --line2:#e1e4ea;
  --bg:#ffffff; --bg-soft:#f7f8fb; --bg-soft2:#eef1f6;
  --accent:#4f46e5; --accent-d:#3a31bd; --accent-2:#8b5cf6; --accent-soft:#eef0ff;
  --grad:linear-gradient(115deg,#4f46e5 0%,#7c3aed 55%,#c026d3 110%);
  --grad-soft:linear-gradient(115deg,#eef0ff,#f6eefe);
  --star:#f59e0b; --ok:#16a34a; --warn:#dc2626;
  --shadow:0 1px 2px rgba(13,19,32,.04),0 8px 24px rgba(13,19,32,.06);
  --shadow-md:0 10px 30px rgba(13,19,32,.10);
  --shadow-lg:0 24px 60px rgba(13,19,32,.16);
  --radius:16px; --radius-sm:11px; --maxw:1200px;
  --c-shopping:#f25c3b; --c-travel:#0ea5e9; --c-home:#0d9488; --c-smart:#7c3aed; --c-stream:#e0397f;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:"Plus Jakarta Sans","Inter",-apple-system,Segoe UI,sans-serif;
  --serif:"Georgia","Times New Roman",serif;
}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--body);background:var(--bg);
  font-size:15.5px;line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.18;font-weight:800;margin:0 0 .5em;letter-spacing:-.02em}
h1{font-size:clamp(1.7rem,3.2vw,2.45rem)}
h2{font-size:clamp(1.25rem,2vw,1.6rem)}
h3{font-size:1.1rem;letter-spacing:-.012em}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
::selection{background:var(--accent);color:#fff}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line)}
.hdr-inner{display:flex;align-items:center;gap:16px;height:64px}
.brand{display:flex;align-items:center;gap:9px;flex-shrink:0}
.brand svg{display:block}
.brand b{font-family:var(--display);font-size:1.28rem;font-weight:800;color:var(--ink);letter-spacing:-.04em}
.brand b span{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav{display:flex;align-items:center;gap:2px;margin-left:10px;flex:1}
.nav a{padding:8px 13px;border-radius:9px;font-size:.9rem;font-weight:600;color:#3b424f;white-space:nowrap;
  transition:background .15s,color .15s;position:relative}
.nav a:hover{background:var(--bg-soft);color:var(--accent)}
.hdr-tools{display:flex;align-items:center;gap:8px;margin-left:auto}
.icon-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;border:1px solid var(--line2);
  background:#fff;cursor:pointer;color:var(--ink);transition:.15s}
.icon-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.menu-btn{display:none}

/* ---------- Search ---------- */
.search{position:relative;flex:1;max-width:440px;display:none}
.search.open{display:block}
.search input{width:100%;height:42px;border:1px solid var(--line2);border-radius:11px;padding:0 16px;
  font-size:.92rem;font-family:inherit;outline:none;background:var(--bg-soft)}
.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff}
.ac{position:absolute;top:50px;left:0;right:0;background:#fff;border:1px solid var(--line2);
  border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;display:none;max-height:72vh;overflow-y:auto;z-index:80}
.ac.show{display:block}
.ac a{display:flex;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line);align-items:center}
.ac a:last-child{border-bottom:0}
.ac a:hover,.ac a.active{background:var(--bg-soft)}
.ac img{width:56px;height:42px;object-fit:cover;border-radius:8px;flex-shrink:0;background:var(--bg-soft2)}
.ac .t{font-weight:700;color:var(--ink);font-size:.9rem;line-height:1.3}
.ac .c{font-size:.7rem;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.ac .none{padding:16px;color:var(--muted);font-size:.9rem}

/* ---------- Mobile drawer ---------- */
.drawer{position:fixed;inset:0;z-index:90;background:rgba(8,11,18,.5);opacity:0;visibility:hidden;transition:opacity .2s}
.drawer.open{opacity:1;visibility:visible}
.drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(84vw,360px);background:#fff;
  transform:translateX(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);padding:22px;overflow-y:auto}
.drawer.open .drawer-panel{transform:none}
.drawer-panel h4{font-family:var(--font);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:18px 0 6px}
.drawer-panel a{display:block;padding:13px 14px;border-radius:11px;font-weight:700;color:var(--ink);font-size:1.02rem}
.drawer-panel a:hover{background:var(--bg-soft);color:var(--accent)}
.drawer-close{float:right;border:0;background:var(--bg-soft);width:42px;height:42px;border-radius:12px;font-size:1.3rem;cursor:pointer;color:var(--ink)}

/* ---------- Badges / eyebrows ---------- */
.badge{display:inline-flex;align-items:center;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  padding:5px 10px;border-radius:999px;color:#fff;background:var(--accent);line-height:1}
.badge.shopping{background:var(--c-shopping)}.badge.travel{background:var(--c-travel)}
.badge.home{background:var(--c-home)}.badge.smart{background:var(--c-smart)}.badge.stream{background:var(--c-stream)}
.tag-type{display:inline-flex;align-items:center;font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  color:var(--accent);background:var(--accent-soft);padding:5px 10px;border-radius:6px;line-height:1}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.74rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent)}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--accent);border-radius:2px}

/* ---------- Cards ---------- */
.grid{display:grid;gap:26px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .22s,border-color .22s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card .thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft2)}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.card:hover .thumb img{transform:scale(1.07)}
.card .thumb .badge{position:absolute;top:12px;left:12px;box-shadow:0 4px 12px rgba(0,0,0,.18)}
.card .body{padding:15px 18px 18px;display:flex;flex-direction:column;flex:1}
.card .meta-top{display:flex;gap:8px;align-items:center;margin-bottom:9px}
.card h3{font-size:1.04rem;line-height:1.32;margin:0 0 8px;letter-spacing:-.015em}
.card h3 a{background-image:linear-gradient(var(--accent),var(--accent));background-size:0 1.5px;background-repeat:no-repeat;
  background-position:0 100%;transition:background-size .25s}
.card:hover h3 a{color:var(--accent)}
.card .excerpt{font-size:.86rem;color:var(--muted);margin:0 0 14px;line-height:1.55}
.card .foot{margin-top:auto;display:flex;align-items:center;gap:9px;font-size:.76rem;color:var(--muted);font-weight:500}
.card .foot .dot{width:3px;height:3px;border-radius:50%;background:var(--line2)}

/* ---------- Hero (bento) ---------- */
.hero{padding:30px 0 8px}
.hero-grid{display:grid;grid-template-columns:1.62fr 1fr;gap:22px}
.hero-main{position:relative;border-radius:var(--radius);overflow:hidden;min-height:460px;color:#fff;
  display:flex;align-items:flex-end;box-shadow:var(--shadow-md)}
.hero-main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s}
.hero-main:hover img{transform:scale(1.04)}
.hero-main .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,12,20,.04) 0%,rgba(10,12,20,.45) 52%,rgba(8,9,16,.88) 100%)}
.hero-main .htext{position:relative;padding:34px;z-index:2;width:100%}
.hero-main .eyebrow{color:#fff}.hero-main .eyebrow::before{background:#fff}
.hero-main h2{font-size:clamp(1.5rem,2.6vw,2.1rem);color:#fff;margin:14px 0 10px;letter-spacing:-.025em;text-shadow:0 2px 18px rgba(0,0,0,.3)}
.hero-main .excerpt{color:rgba(255,255,255,.82);font-size:.98rem;max-width:48ch;margin:0 0 14px}
.hero-meta{display:flex;align-items:center;gap:10px;font-size:.82rem;color:rgba(255,255,255,.78);font-weight:500}
.hero-meta .av{width:30px;height:30px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-weight:800;font-size:.78rem;color:#fff}
.hero-meta b{color:#fff;font-weight:700}.hero-meta .dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.5)}
.hero-side{display:flex;flex-direction:column;gap:18px}
.hero-s{position:relative;display:flex;gap:14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:11px;background:#fff;transition:transform .2s,box-shadow .2s;flex:1;align-items:center}
.hero-s:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.hero-s .him{width:108px;height:86px;flex-shrink:0;border-radius:10px;overflow:hidden;background:var(--bg-soft2)}
.hero-s .him img{width:100%;height:100%;object-fit:cover}
.hero-s .ht{min-width:0}
.hero-s h3{font-size:.96rem;line-height:1.3;margin:7px 0 0;color:var(--ink);letter-spacing:-.01em}
.hero-s:hover h3{color:var(--accent)}

/* ---------- Trending strip ---------- */
.trend{border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:26px}
.trend-inner{display:flex;align-items:stretch;gap:0;overflow-x:auto;scrollbar-width:none}
.trend-inner::-webkit-scrollbar{display:none}
.trend-lab{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:800;color:var(--ink);
  font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;padding:18px 22px 18px 0;border-right:1px solid var(--line);white-space:nowrap}
.trend-lab .pulse{width:8px;height:8px;border-radius:50%;background:var(--c-stream);box-shadow:0 0 0 0 rgba(224,57,127,.5);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(224,57,127,.45)}70%{box-shadow:0 0 0 7px rgba(224,57,127,0)}100%{box-shadow:0 0 0 0 rgba(224,57,127,0)}}
.trend-item{display:flex;align-items:center;gap:11px;padding:16px 22px;border-right:1px solid var(--line);min-width:260px;flex:1}
.trend-item:last-child{border-right:0}
.trend-item .n{font-family:var(--display);font-size:1.5rem;font-weight:800;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;flex-shrink:0}
.trend-item span{font-size:.86rem;font-weight:600;color:var(--ink);line-height:1.3}
.trend-item:hover span{color:var(--accent)}

/* ---------- Section headers ---------- */
.section{padding:42px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.sec-head h2{margin:0;display:flex;align-items:center;gap:12px;font-size:1.5rem}
.sec-head .bar{width:5px;height:24px;border-radius:3px;background:var(--accent);display:inline-block}
.sec-head .more{font-size:.86rem;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:5px}
.sec-head .more:hover{gap:9px;transition:gap .15s}
.section.alt{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- Category strip ---------- */
.cat-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.cat-chip{display:flex;flex-direction:column;gap:6px;padding:20px 18px;border-radius:var(--radius);color:#fff;
  position:relative;overflow:hidden;min-height:122px;justify-content:flex-end;font-family:var(--display);font-weight:800;
  font-size:1.04rem;letter-spacing:-.01em;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow)}
.cat-chip span{font-family:var(--font);font-size:.74rem;font-weight:500;opacity:.92}
.cat-chip::after{content:"→";position:absolute;top:16px;right:18px;font-size:1.1rem;opacity:.5;transition:.2s}
.cat-chip:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.cat-chip:hover::after{opacity:1;right:14px}

/* ---------- CTA band ---------- */
.cta{margin:48px 0 0;border-radius:0}
.cta-inner{position:relative;overflow:hidden;border-radius:24px;background:var(--grad);color:#fff;
  padding:48px 44px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;box-shadow:var(--shadow-md)}
.cta-inner::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;
  background:rgba(255,255,255,.12);top:-150px;right:-60px}
.cta-inner::after{content:"";position:absolute;width:220px;height:220px;border-radius:50%;
  background:rgba(255,255,255,.1);bottom:-130px;left:10%}
.cta-inner h2{color:#fff;position:relative;margin:0 0 6px;font-size:1.7rem}
.cta-inner p{color:rgba(255,255,255,.86);position:relative;margin:0;max-width:46ch}
.cta-btns{display:flex;gap:12px;position:relative;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:7px;padding:13px 22px;border-radius:12px;font-weight:700;font-size:.92rem;transition:.18s}
.btn-w{background:#fff;color:var(--accent)}.btn-w:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.18)}
.btn-o{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.4)}.btn-o:hover{background:rgba(255,255,255,.26)}

/* ---------- Breadcrumb ---------- */
.crumb{font-size:.82rem;color:var(--muted);padding:18px 0 0;display:flex;gap:7px;flex-wrap:wrap;font-weight:500}
.crumb a:hover{color:var(--accent)}
.crumb .sep{opacity:.5}

/* ---------- Article ---------- */
.article{max-width:730px;margin:0 auto;padding:8px 0 30px}
.article .a-head{padding:14px 0 6px}
.a-head .badge,.a-head .tag-type{vertical-align:middle}
.article h1{margin:14px 0 16px;font-size:clamp(1.75rem,3.4vw,2.5rem);line-height:1.12}
.a-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:.88rem;margin-bottom:24px;font-weight:500}
.a-author{display:flex;align-items:center;gap:9px}
.a-author .av{width:38px;height:38px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.92rem}
.a-author b{color:var(--ink);font-weight:700}
.a-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--line2)}
.a-hero{border-radius:var(--radius);overflow:hidden;margin:0 0 10px;box-shadow:var(--shadow-md)}
.a-hero img{width:100%;aspect-ratio:16/9;object-fit:cover}
.a-hero figcaption{font-size:.74rem;color:var(--muted);padding:9px 2px;text-align:center}
.a-body{font-size:1.02rem;line-height:1.72;color:#3c4452}
.a-body>p:first-of-type::first-letter{}
.a-body h2{margin:1.85em 0 .55em;font-size:1.42rem}
.a-body h3{margin:1.5em 0 .45em;font-size:1.14rem}
.a-body p{margin:0 0 1.05em}
.a-body ul,.a-body ol{margin:0 0 1.25em;padding-left:1.25em}
.a-body li{margin:0 0 .5em}
.a-body li::marker{color:var(--accent)}
.a-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;font-weight:500}
.a-body img{border-radius:var(--radius-sm);margin:1.4em 0}
.a-body figure{margin:1.5em 0}
.a-body figcaption{font-size:.76rem;color:var(--muted);text-align:center;margin-top:7px}
.lead{font-size:1.16rem;color:var(--ink);font-weight:450;line-height:1.55}
.a-body blockquote{margin:1.6em 0;padding:6px 0 6px 22px;border-left:4px solid var(--accent);
  font-family:var(--serif);font-size:1.18rem;color:var(--ink);font-style:italic}

/* key takeaways callout */
.callout{background:var(--grad-soft);border:1px solid #e2e0ff;border-radius:var(--radius);padding:22px 24px;margin:1.9em 0;position:relative}
.callout h3{margin:0 0 12px;font-size:1.02rem;color:var(--accent-d);display:flex;gap:8px;align-items:center}
.callout ul{margin:0;padding-left:0;list-style:none}
.callout li{margin:.5em 0;color:var(--ink);padding-left:26px;position:relative;font-size:.95rem}
.callout li::before{content:"✓";position:absolute;left:0;top:0;color:#fff;background:var(--accent);width:18px;height:18px;
  border-radius:50%;font-size:.66rem;display:grid;place-items:center;font-weight:800}

/* Editor's Choice winner block */
.winner{position:relative;border:1.5px solid #d9d6ff;border-radius:var(--radius);margin:2em 0;
  background:linear-gradient(180deg,#fbfaff 0%,#fff 70%);box-shadow:var(--shadow-md);overflow:hidden}
.winner::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad)}
.winner .wbadge{display:inline-flex;align-items:center;gap:6px;background:var(--grad);color:#fff;
  font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:7px 14px;border-radius:0 0 12px 0}
.winner .wgrid{display:grid;grid-template-columns:210px 1fr;gap:22px;padding:8px 24px 24px;align-items:center}
.winner .wimg{border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow)}
.winner .wimg img{width:100%;height:100%;object-fit:cover;margin:0}
.winner .wsub{font-size:.7rem;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}
.winner h3{margin:.25em 0 .4em;font-size:1.34rem}
.winner .wscore{display:flex;align-items:center;gap:10px;margin:0 0 .6em}
.winner .wscore b{font-size:1.55rem;font-weight:900;color:var(--ink);font-family:var(--display)}
.winner .wscore small{color:var(--muted);font-weight:600;font-size:.78rem}
.winner .wscore .stars{color:var(--star);font-size:1rem;letter-spacing:1px}
.winner p{margin:0 0 .8em;font-size:.95rem;color:var(--body)}
.winner .wspecs{display:flex;flex-wrap:wrap;gap:7px}
.winner .wspecs span{background:#fff;border:1px solid var(--line2);border-radius:8px;padding:5px 11px;font-size:.78rem;font-weight:600;color:var(--ink)}

/* rating box */
.ratebox{border:1px solid var(--line2);border-radius:var(--radius);padding:24px;margin:1.9em 0;
  background:linear-gradient(180deg,var(--bg-soft),#fff);display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center}
.ratebox .score{text-align:center;padding-right:26px;border-right:1px solid var(--line)}
.ratebox .score b{font-family:var(--display);font-size:2.8rem;color:var(--ink);font-weight:800;line-height:1;display:block}
.ratebox .score small{color:var(--muted);font-size:.78rem;font-weight:600}
.stars{color:var(--star);font-size:1.05rem;letter-spacing:2px;margin-top:6px}
.ratebox .bars{display:grid;gap:9px}
.rbar{display:grid;grid-template-columns:118px 1fr 36px;gap:10px;align-items:center;font-size:.84rem;font-weight:500}
.rbar .track{height:7px;border-radius:4px;background:var(--bg-soft2);overflow:hidden}
.rbar .fill{height:100%;background:var(--grad);border-radius:4px}

/* comparison table */
.table-wrap{overflow-x:auto;margin:1.9em 0;border:1px solid var(--line2);border-radius:var(--radius);box-shadow:var(--shadow)}
table.cmp{width:100%;border-collapse:collapse;font-size:.9rem;min-width:560px}
table.cmp th,table.cmp td{padding:13px 15px;text-align:left;border-bottom:1px solid var(--line)}
table.cmp thead th{background:var(--ink);color:#fff;font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em}
table.cmp tbody tr:last-child td{border-bottom:0}
table.cmp tbody tr:nth-child(even){background:var(--bg-soft)}
table.cmp td:first-child{font-weight:700;color:var(--ink)}
table.cmp tbody tr.win td{background:var(--accent-soft)!important}
table.cmp tbody tr.win td:first-child{box-shadow:inset 4px 0 0 var(--accent)}
.pick{display:inline-flex;align-items:center;gap:4px;font-size:.62rem;font-weight:800;background:var(--grad);color:#fff;
  padding:3px 8px;border-radius:5px;margin-left:7px;vertical-align:middle;letter-spacing:.03em;text-transform:uppercase}

/* pros/cons */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:1.9em 0}
.pc .col{border:1px solid var(--line2);border-radius:var(--radius);padding:20px 22px}
.pc .col.pros{background:#f0fdf6;border-color:#bbf7d0}
.pc .col.cons{background:#fef3f3;border-color:#fecdd0}
.pc h4{margin:0 0 11px;display:flex;align-items:center;gap:8px;font-size:.96rem;font-family:var(--display)}
.pc ul{margin:0;padding-left:0;list-style:none;font-size:.9rem}
.pc li{margin:.5em 0;padding-left:24px;position:relative}
.pc .pros li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:800}
.pc .cons li::before{content:"✕";position:absolute;left:0;color:var(--warn);font-weight:800}
.pc .pros h4{color:var(--ok)}.pc .cons h4{color:var(--warn)}

/* item block (best-of list) */
.item{border:1px solid var(--line2);border-radius:var(--radius);overflow:hidden;margin:2em 0;box-shadow:var(--shadow);transition:box-shadow .2s}
.item:hover{box-shadow:var(--shadow-md)}
.item.top{border-color:#d9d6ff}
.item.top::before{content:"";display:block;height:4px;background:var(--grad)}
.item .ihead{display:flex;align-items:flex-start;gap:14px;padding:18px 22px 8px}
.item .rank{flex-shrink:0;width:38px;height:38px;border-radius:11px;background:var(--ink);color:#fff;
  display:grid;place-items:center;font-weight:800;font-family:var(--display);font-size:1.05rem}
.item.top .rank{background:var(--grad)}
.item .ihead h3{margin:2px 0 0;font-size:1.26rem}
.item .ihead .sub{font-size:.72rem;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.item .ibody{padding:0 22px 22px}
.item .specs{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 14px}
.item .specs span{background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:5px 11px;font-size:.78rem;color:var(--ink);font-weight:600}
.item>img{aspect-ratio:16/8;object-fit:cover;width:100%}

/* faq */
.faq details{border:1px solid var(--line2);border-radius:var(--radius-sm);margin:0 0 11px;background:#fff;overflow:hidden;transition:border-color .15s}
.faq details[open]{border-color:#d9d6ff}
.faq summary{padding:16px 19px;font-weight:700;color:var(--ink);cursor:pointer;list-style:none;font-family:var(--display);
  display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.98rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--accent);font-weight:600;line-height:1;transition:transform .2s}
.faq details[open] summary::after{content:"\2212"}
.faq .ans{padding:2px 19px 17px;font-size:.93rem;color:var(--body)}

/* share + tags */
.a-foot{margin-top:32px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;
  align-items:center;gap:16px;flex-wrap:wrap}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chips a{font-size:.8rem;background:var(--bg-soft);border:1px solid var(--line2);padding:7px 13px;border-radius:999px;color:var(--body);font-weight:600}
.chips a:hover{background:var(--accent-soft);color:var(--accent);border-color:transparent}

/* related */
.related{background:var(--bg-soft);padding:48px 0;border-top:1px solid var(--line)}

/* author bio */
.bio{display:flex;gap:16px;background:var(--grad-soft);border:1px solid #e6e3ff;border-radius:var(--radius);
  padding:22px;margin:32px 0 0;align-items:center}
.bio .av{width:58px;height:58px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;
  font-weight:800;font-size:1.35rem;flex-shrink:0;font-family:var(--display)}
.bio b{color:var(--ink);font-family:var(--display)}
.bio p{margin:4px 0 0;font-size:.88rem;color:var(--body)}

/* ---------- Category page header ---------- */
.cat-hero{padding:54px 0;color:#fff;position:relative;overflow:hidden}
.cat-hero::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.1);top:-180px;right:-40px}
.cat-hero h1{color:#fff;margin:0 0 10px;font-size:clamp(2rem,4vw,2.8rem);position:relative}
.cat-hero p{color:rgba(255,255,255,.92);max-width:62ch;margin:0;font-size:1.04rem;position:relative}
.cat-hero .badge{background:rgba(255,255,255,.22);margin-bottom:16px;position:relative;backdrop-filter:blur(4px)}

/* pagination */
.pager{display:flex;justify-content:center;align-items:center;gap:8px;padding:18px 0 0;flex-wrap:wrap}
.pager a,.pager span{min-width:44px;height:44px;display:grid;place-items:center;border:1px solid var(--line2);
  border-radius:12px;font-weight:700;font-size:.9rem;padding:0 14px;background:#fff;color:var(--ink)}
.pager a:hover{background:var(--bg-soft);border-color:var(--accent);color:var(--accent)}
.pager .cur{background:var(--grad);color:#fff;border-color:transparent}
.pager .dis{opacity:.4;pointer-events:none}

/* ---------- Static / legal pages ---------- */
.page{max-width:790px;margin:0 auto;padding:10px 0 40px}
.page h1{margin:18px 0 8px}
.page .eff{color:var(--muted);font-size:.88rem;margin-bottom:24px}
.page h2{margin:1.7em 0 .5em;font-size:1.36rem}
.page ul{padding-left:1.3em}
.page li{margin:.4em 0}
.page li::marker{color:var(--accent)}
.page .infobox{background:var(--bg-soft);border:1px solid var(--line2);border-radius:var(--radius);padding:18px 22px;margin:1.4em 0}
.contact-form{display:grid;gap:15px;margin:1.4em 0;max-width:540px}
.contact-form label{font-weight:700;color:var(--ink);font-size:.88rem;display:block;margin-bottom:6px}
.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line2);border-radius:11px;padding:12px 15px;
  font-family:inherit;font-size:.98rem;outline:none}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.contact-form button{background:var(--grad);color:#fff;border:0;border-radius:12px;padding:14px 26px;font-weight:700;
  font-size:.96rem;cursor:pointer;justify-self:start}
.contact-form button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ---------- Footer ---------- */
.site-footer{background:#0b1020;color:#aeb6c4;padding:56px 0 28px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:40px;margin-bottom:38px}
.site-footer .brand b{color:#fff}
.site-footer .brand b span{-webkit-text-fill-color:transparent}
.site-footer p{font-size:.9rem;color:#8a93a4;margin:16px 0 0;max-width:42ch;line-height:1.6}
.foot-grid h4{font-family:var(--display);color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;margin:0 0 16px}
.foot-grid ul{list-style:none;margin:0;padding:0}
.foot-grid li{margin:.6em 0}
.foot-grid a{color:#aeb6c4;font-size:.92rem}
.foot-grid a:hover{color:#fff}
.foot-bottom{border-top:1px solid #20283b;padding-top:24px;display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;font-size:.84rem;color:#79859a}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .grid.cols-4{grid-template-columns:repeat(3,1fr)}
  .cat-strip{grid-template-columns:repeat(3,1fr)}
  .trend-item{min-width:230px}
}
@media(max-width:860px){
  .nav{display:none}
  .menu-btn{display:grid}
  .hero-grid{grid-template-columns:1fr}
  .hero-main{min-height:360px}
  .hero-side{flex-direction:row}
  .hero-s{flex-direction:column;align-items:flex-start}
  .hero-s .him{width:100%;height:120px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .ratebox{grid-template-columns:1fr;text-align:center}
  .ratebox .score{border-right:0;border-bottom:1px solid var(--line);padding:0 0 18px}
  .winner .wgrid{grid-template-columns:1fr}
  .cta-inner{padding:36px 28px}
}
@media(max-width:680px){
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr);gap:16px}
  .cat-strip{grid-template-columns:repeat(2,1fr)}
  .pc{grid-template-columns:1fr}
  .card h3{font-size:.98rem}
  .hero-side{flex-direction:column}
  .hero-s{flex-direction:row;align-items:center}
  .hero-s .him{width:108px;height:84px}
  .trend-lab{display:none}
  .search{position:fixed;top:64px;left:0;right:0;max-width:none;padding:12px 16px;background:#fff;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .ac{left:16px;right:16px;top:60px}
  .foot-bottom{flex-direction:column}
  .cta-inner{flex-direction:column;align-items:flex-start;text-align:left}
}
@media(max-width:460px){
  .grid.cols-3,.grid.cols-4{grid-template-columns:1fr}
  .cat-strip{grid-template-columns:1fr 1fr}
  .rbar{grid-template-columns:84px 1fr 32px}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto}}
