*,*::before,*::after{box-sizing:border-box}
:root{
  --ink:#16181d;--body:#41474f;--muted:#7c828c;--line:#ececE7;--line2:#e2e2db;
  --bg:#ffffff;--bg-soft:#f7f6f2;--bg-soft2:#eeece5;
  --accent:#0f766e;--accent-d:#115e59;--accent-soft:#eef6f4;
  --grad:linear-gradient(118deg,#0f766e 0%,#115e59 100%);
  --grad-soft:linear-gradient(118deg,#eff7f5,#fdf3ee);
  --star:#e8910b;--ok:#15803d;--warn:#dc2626;
  --shadow:0 1px 2px rgba(16,18,22,.04),0 10px 26px rgba(16,18,22,.06);
  --shadow-md:0 14px 34px rgba(16,18,22,.10);--shadow-lg:0 28px 64px rgba(16,18,22,.16);
  --radius:14px;--radius-sm:10px;--maxw:1180px;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --display:"Fraunces","Georgia",serif;--serif:"Fraunces","Georgia",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.16;font-weight:700;margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(1.8rem,3.4vw,2.6rem)}
h2{font-size:clamp(1.3rem,2.1vw,1.7rem)}
h3{font-size:1.12rem}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
::selection{background:var(--accent);color:#fff}

/* header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.85);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:66px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand b{font-family:var(--display);font-size:1.34rem;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.brand b span{color:var(--accent)}
.nav{display:flex;align-items:center;gap:2px;margin-left:8px;flex:1;min-width:0}
.nav a{padding:8px 13px;border-radius:9px;font-size:.9rem;font-weight:600;color:#3a414b;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s}
.nav-more{position:relative;flex-shrink:0}
.nav-more>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:8px 13px;border-radius:9px;font-size:.9rem;font-weight:600;color:#3a414b}
.nav-more>summary::-webkit-details-marker{display:none}
.nav-more>summary:hover,.nav-more[open]>summary{background:var(--bg-soft);color:var(--accent)}
.nav-more-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;max-height:70vh;overflow-y:auto;background:#fff;border:1px solid var(--line2);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;z-index:70;display:flex;flex-direction:column;gap:2px}
.nav-more-menu a{padding:10px 12px;border-radius:9px;font-size:.9rem;font-weight:600;color:var(--ink);white-space:nowrap}
.nav-more-menu a:hover{background:var(--bg-soft);color:var(--accent)}
.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 modal */
.search-modal{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-start;justify-content:center;padding:11vh 20px 20px;background:rgba(16,18,22,.5);backdrop-filter:saturate(160%) blur(4px);-webkit-backdrop-filter:saturate(160%) blur(4px);opacity:0;visibility:hidden;transition:opacity .18s}
.search-modal.open{opacity:1;visibility:visible}
.search-box{width:min(640px,100%);background:#fff;border:1px solid var(--line2);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;transform:translateY(-10px);transition:transform .2s}
.search-modal.open .search-box{transform:none}
.search-bar{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--line)}
.search-bar .si{color:var(--muted);flex-shrink:0}
.search-bar input{flex:1;min-width:0;border:0;outline:none;font-family:inherit;font-size:1.05rem;color:var(--ink);background:transparent}
.search-bar input::placeholder{color:var(--muted)}
.search-esc{border:1px solid var(--line2);background:var(--bg-soft);color:var(--muted);font-size:.7rem;font-weight:700;border-radius:7px;padding:6px 10px;cursor:pointer;flex-shrink:0}
.search-esc:hover{color:var(--ink);border-color:var(--accent)}
.ac{display:none;max-height:62vh;overflow-y:auto}
.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;font-family:var(--display)}
.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}

/* 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 */
.badge{display:inline-flex;align-items:center;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:5px 10px;border-radius:7px;color:#fff;background:var(--accent);line-height:1}
.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.08rem;line-height:1.3;margin:0 0 8px}
.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 */
.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,16,.05) 0%,rgba(10,12,16,.46) 52%,rgba(8,9,12,.9) 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.6rem,2.7vw,2.2rem);color:#fff;margin:14px 0 10px;text-shadow:0 2px 18px rgba(0,0,0,.3)}
.hero-main .excerpt{color:rgba(255,255,255,.84);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,.8);font-weight:500}
.hero-meta .av{width:30px;height:30px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-weight:700;font-size:.78rem;color:#fff;font-family:var(--display)}
.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:.97rem;line-height:1.3;margin:7px 0 0;color:var(--ink)}
.hero-s:hover h3{color:var(--accent)}

/* trending */
.trend{border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:26px}
.trend-inner{display:flex;align-items:stretch;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:700;color:var(--ink);font-size:.84rem;text-transform:uppercase;letter-spacing:.05em;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(--accent);box-shadow:0 0 0 0 rgba(0,0,0,.2);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(15,118,110,.4)}70%{box-shadow:0 0 0 7px rgba(15,118,110,0)}100%{box-shadow:0 0 0 0 rgba(15,118,110,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:700;color:var(--accent);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)}

/* sections */
.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:700;font-size:1.06rem;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 */
.cta{margin:48px 0 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,.88);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)}

/* crumb */
.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.85rem,3.6vw,2.6rem);line-height:1.1}
.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:700;font-size:.92rem;font-family:var(--display)}
.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.03rem;line-height:1.74;color:#3a414b}
.a-body h2{margin:1.85em 0 .55em;font-size:1.5rem}
.a-body h3{margin:1.5em 0 .45em;font-size:1.18rem}
.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.18rem;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.2rem;color:var(--ink);font-style:italic}

/* callout */
.callout{background:var(--grad-soft);border:1px solid #dcebe7;border-radius:var(--radius);padding:22px 24px;margin:1.9em 0}
.callout h3{margin:0 0 12px;font-size:1.05rem;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:1px;color:#fff;background:var(--accent);width:18px;height:18px;border-radius:50%;font-size:.66rem;display:grid;place-items:center;font-weight:800}

/* winner */
.winner{position:relative;border:1.5px solid #d6e9e4;border-radius:var(--radius);margin:2em 0;background:linear-gradient(180deg,#fbfdfc 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.4rem}
.winner .wscore{display:flex;align-items:center;gap:10px;margin:0 0 .6em}
.winner .wscore b{font-size:1.55rem;font-weight:800;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)}

/* ratebox */
.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:700;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}

/* 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:.98rem;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 (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:#d6e9e4}
.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:700;font-family:var(--display);font-size:1.05rem}
.item.top .rank{background:var(--grad)}
.item .ihead h3{margin:2px 0 0;font-size:1.3rem}
.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:#d6e9e4}
.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:1rem}
.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)}

/* foot of article */
.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{background:var(--bg-soft);padding:48px 0;border-top:1px solid var(--line)}
.bio{display:flex;gap:16px;background:var(--grad-soft);border:1px solid #dcebe7;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:700;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 */
.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}
.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 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.4rem}
.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:#101317;color:#aab1bc;padding:56px 0 28px}
.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{color:#fff;opacity:.85}
.site-footer p{font-size:.9rem;color:#878f9b;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:#aab1bc;font-size:.92rem}.foot-grid a:hover{color:#fff}
.foot-bottom{border-top:1px solid #232a33;padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:#767f8c}

/* 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-modal{padding:0}
  .search-box{width:100%;border-radius:0 0 16px 16px;border-top:0;border-left:0;border-right:0}
  .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}}