/* =========================================================
   TopWebsites — design system (frontend + admin)
   Test-bench aesthetic: cool paper, cobalt + measured emerald,
   Bricolage Grotesque / IBM Plex Sans / Space Mono.
   ========================================================= */
:root{
  --paper:#F3F4F6; --paper-2:#FFFFFF; --paper-3:#ECEEF2;
  --ink:#15171C; --ink-2:#565B66; --ink-3:#8A8F9A;
  --line:#E2E4E9; --line-2:#D3D7DE;
  --cobalt:#1E3AFF; --cobalt-ink:#0E1A80; --cobalt-wash:#EBEEFF;
  --signal:#08A05C; --signal-wash:#E4F6ED; --neg:#D8443C; --neg-wash:#FBEDEC;
  --hot:#FF5B34;
  --shadow:0 1px 2px rgba(21,23,28,.04), 0 8px 24px rgba(21,23,28,.06);
  --shadow-lift:0 2px 6px rgba(21,23,28,.06), 0 18px 40px rgba(21,23,28,.10);
  --r:14px; --r-sm:10px; --maxw:1180px;
  --f-display:"Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --f-body:"IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;
  --f-mono:"Space Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}
*,*::before,*::after{box-sizing:border-box; margin:0; padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--f-body); color:var(--ink); background:var(--paper); line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
::selection{background:var(--cobalt); color:#fff}
:focus-visible{outline:2.5px solid var(--cobalt); outline-offset:3px; border-radius:4px}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.eyebrow{font-family:var(--f-mono); font-size:.72rem; letter-spacing:.09em; text-transform:uppercase; color:var(--ink-2)}
.h-display{font-family:var(--f-display); font-weight:800; line-height:1.0; letter-spacing:-.02em}

/* ---- top bar ---- */
.topbar{position:sticky; top:0; z-index:50; background:rgba(243,244,246,.82); backdrop-filter:saturate(1.4) blur(10px); border-bottom:1px solid var(--line)}
.topbar__row{display:flex; align-items:center; gap:28px; height:66px}
.brand{display:flex; align-items:center; gap:10px; font-family:var(--f-display); font-weight:800; font-size:1.18rem; letter-spacing:-.02em}
.brand__mark{width:26px; height:26px; border-radius:7px; background:var(--ink); position:relative; flex:0 0 auto}
.brand__mark::before{content:""; position:absolute; inset:6px 6px auto 6px; height:3px; border-radius:2px; background:var(--signal)}
.brand__mark::after{content:""; position:absolute; inset:12px 6px auto 6px; height:3px; border-radius:2px; background:var(--cobalt); width:9px}
.nav{display:flex; gap:22px; margin-left:6px}
.nav a{font-size:.94rem; color:var(--ink-2); font-weight:500; padding:6px 0; transition:color .15s}
.nav a:hover{color:var(--ink)}
.topbar__end{margin-left:auto; display:flex; align-items:center; gap:16px}
.link-mono{font-family:var(--f-mono); font-size:.78rem; color:var(--cobalt); letter-spacing:.02em}
.link-mono:hover{color:var(--cobalt-ink)}
.burger{display:none; background:none; border:1px solid var(--line-2); border-radius:9px; width:42px; height:38px; cursor:pointer; align-items:center; justify-content:center}
.burger span,.burger span::before,.burger span::after{content:""; display:block; width:17px; height:2px; background:var(--ink); position:relative}
.burger span::before{position:absolute; top:-5px} .burger span::after{position:absolute; top:5px}

/* ---- buttons ---- */
.btn{display:inline-flex; align-items:center; gap:8px; font-family:var(--f-body); font-weight:600; font-size:.95rem; padding:12px 20px; border-radius:11px; cursor:pointer; border:1px solid transparent; transition:transform .12s ease, box-shadow .15s ease, background .15s; text-align:center}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--cobalt); color:#fff; box-shadow:0 6px 16px rgba(30,58,255,.24)}
.btn--primary:hover{background:#1730E6}
.btn--ghost{background:var(--paper-2); color:var(--ink); border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink)}
.btn--block{width:100%; justify-content:center}
.btn--sm{padding:8px 14px; font-size:.88rem; border-radius:9px}
.btn--danger{background:var(--neg-wash); color:#9E2A24; border-color:#F0C9C6}
.btn--danger:hover{background:#F7DDDB}
.btn__arrow{font-family:var(--f-mono); font-size:.9em}

/* ---- section scaffolding ---- */
.section{padding:76px 0}
.section--tight{padding:56px 0}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:34px; flex-wrap:wrap}
.section-head h2{font-family:var(--f-display); font-weight:700; font-size:clamp(1.6rem,3.4vw,2.35rem); letter-spacing:-.02em; line-height:1.05}
.section-head p{color:var(--ink-2); max-width:44ch; margin-top:8px; font-size:1rem}

/* ---- hero ---- */
.hero{padding:54px 0 40px; position:relative; overflow:hidden}
.hero__ping{margin-bottom:22px; display:inline-flex; align-items:center; gap:10px}
.dot{width:8px; height:8px; border-radius:50%; background:var(--signal); animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(8,160,92,.45)} 70%{box-shadow:0 0 0 8px rgba(8,160,92,0)} 100%{box-shadow:0 0 0 0 rgba(8,160,92,0)}}
.hero__grid{display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.4rem); margin-bottom:22px}
.hero h1 em{font-style:normal; color:var(--cobalt)}
.hero__sub{font-size:1.14rem; color:var(--ink-2); max-width:46ch; margin-bottom:30px}
.hero__cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:26px}
.hero__meta{display:flex; gap:26px; flex-wrap:wrap; font-family:var(--f-mono); font-size:.76rem; color:var(--ink-3); letter-spacing:.03em}
.hero__meta b{color:var(--ink); font-weight:700}

/* ---- scorecard (signature) ---- */
.card-score{background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow-lift); overflow:hidden}
.card-score__top{display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--line)}
.card-score__id{display:flex; align-items:center; gap:12px}
.card-score__logo{width:40px; height:40px; border-radius:10px; background:var(--ink); color:#fff; font-family:var(--f-display); font-weight:800; display:flex; align-items:center; justify-content:center; font-size:1.05rem}
.card-score__name{font-family:var(--f-display); font-weight:700; font-size:1.15rem; line-height:1.1}
.card-score__cat{font-family:var(--f-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3)}
.score-badge{display:flex; flex-direction:column; align-items:center; justify-content:center; width:66px; height:66px; border:2px solid var(--cobalt); border-radius:14px; color:var(--cobalt); flex:0 0 auto}
.score-badge b{font-family:var(--f-mono); font-weight:700; font-size:1.5rem; line-height:1}
.score-badge span{font-family:var(--f-mono); font-size:.58rem; letter-spacing:.06em; margin-top:2px; color:var(--ink-3)}
.card-score__body{padding:18px 20px}
.bar-row{display:grid; grid-template-columns:92px 1fr 34px; align-items:center; gap:12px; margin-bottom:12px}
.bar-row:last-child{margin-bottom:0}
.bar-label{font-family:var(--f-mono); font-size:.72rem; color:var(--ink-2); letter-spacing:.02em}
.bar-track{height:7px; background:var(--paper-3); border-radius:6px; overflow:hidden}
.bar-fill{height:100%; width:0; background:var(--signal); border-radius:6px; transition:width 1.1s cubic-bezier(.2,.7,.2,1)}
.bar-fill.static{width:var(--w)}
.bar-val{font-family:var(--f-mono); font-size:.72rem; color:var(--ink); text-align:right; font-weight:700}
.card-score__best{margin-top:16px; padding-top:16px; border-top:1px dashed var(--line-2); font-size:.92rem}
.card-score__best b{font-family:var(--f-mono); font-size:.68rem; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-3); display:block; margin-bottom:3px}
.card-score__foot{display:flex; gap:16px; flex-wrap:wrap; padding:14px 20px; background:var(--paper-3); font-family:var(--f-mono); font-size:.7rem; color:var(--ink-2); letter-spacing:.03em; border-top:1px solid var(--line)}
.card-score__foot b{color:var(--ink); font-weight:700}

/* ---- process ---- */
.process{background:var(--ink); color:#fff; border-radius:20px; padding:44px 40px; margin-top:8px}
.process__head{display:flex; justify-content:space-between; align-items:baseline; gap:20px; flex-wrap:wrap; margin-bottom:28px}
.process__head h2{font-family:var(--f-display); font-weight:700; font-size:clamp(1.5rem,3vw,2.1rem); letter-spacing:-.02em}
.process__head p{color:#A6ABB6; font-family:var(--f-mono); font-size:.76rem; letter-spacing:.04em}
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:#2A2E38; border:1px solid #2A2E38; border-radius:14px; overflow:hidden}
.step{background:var(--ink); padding:26px 24px}
.step__n{font-family:var(--f-mono); font-size:.8rem; color:var(--cobalt); font-weight:700; letter-spacing:.05em}
.step h3{font-family:var(--f-display); font-weight:700; font-size:1.28rem; margin:14px 0 8px; letter-spacing:-.01em}
.step p{color:#B4B9C3; font-size:.95rem}

/* ---- categories ---- */
.cats{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.cat{display:block; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); padding:28px 26px; box-shadow:var(--shadow); transition:transform .16s, box-shadow .18s, border-color .18s; position:relative}
.cat:hover{transform:translateY(-4px); box-shadow:var(--shadow-lift); border-color:var(--line-2)}
.cat__tag{font-family:var(--f-mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--cobalt)}
.cat h3{font-family:var(--f-display); font-weight:700; font-size:1.5rem; margin:12px 0 8px; letter-spacing:-.02em}
.cat p{color:var(--ink-2); font-size:.95rem; margin-bottom:18px}
.cat__count{font-family:var(--f-mono); font-size:.72rem; color:var(--ink-3)}
.cat__go{position:absolute; top:26px; right:26px; font-family:var(--f-mono); color:var(--ink-3); transition:transform .16s, color .16s}
.cat:hover .cat__go{color:var(--cobalt); transform:translate(3px,-3px)}

/* ---- verdict grid ---- */
.verdicts{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.vcard{background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); transition:transform .16s, box-shadow .18s; display:flex; flex-direction:column}
.vcard:hover{transform:translateY(-4px); box-shadow:var(--shadow-lift)}
.vcard__media{height:132px; background:linear-gradient(135deg,#EDEFF3,#E1E4EA); position:relative; display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--line)}
.vcard__ph{font-family:var(--f-mono); font-size:.66rem; color:var(--ink-3); letter-spacing:.05em; text-transform:uppercase}
.vcard__pick{position:absolute; top:12px; left:12px; display:inline-flex; align-items:center; gap:6px; background:var(--paper-2); border:1px solid var(--line); padding:5px 10px; border-radius:20px; font-family:var(--f-mono); font-size:.64rem; letter-spacing:.05em; text-transform:uppercase; color:var(--ink)}
.vcard__pick i{width:6px; height:6px; border-radius:50%; background:var(--hot); display:inline-block}
.vcard__body{padding:18px 18px 20px; display:flex; flex-direction:column; flex:1}
.vcard__top{display:flex; align-items:center; justify-content:space-between; margin-bottom:10px}
.vcard__name{font-family:var(--f-display); font-weight:700; font-size:1.18rem; letter-spacing:-.01em}
.vcard__score{font-family:var(--f-mono); font-weight:700; font-size:1rem; color:var(--cobalt); border:1.5px solid var(--cobalt); border-radius:9px; padding:3px 9px}
.vcard__best{font-size:.9rem; color:var(--ink-2); margin-bottom:14px}
.vcard__best b{color:var(--ink); font-weight:600}
.vcard__meta{display:flex; gap:14px; flex-wrap:wrap; font-family:var(--f-mono); font-size:.68rem; color:var(--ink-3); margin-top:auto; padding-top:14px; border-top:1px solid var(--line)}
.vcard__link{color:var(--cobalt); font-weight:600; font-size:.9rem; margin-top:14px; display:inline-flex; align-items:center; gap:6px}

/* ---- head to head ---- */
.h2h{background:var(--paper-2); border:1px solid var(--line); border-radius:20px; box-shadow:var(--shadow); overflow:hidden}
.h2h__label{text-align:center; padding:22px 0 4px; font-family:var(--f-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3)}
.h2h__grid{display:grid; grid-template-columns:1fr 72px 1fr; align-items:stretch}
.h2h__side{padding:26px 30px 34px; text-align:center}
.h2h__side h3{font-family:var(--f-display); font-weight:800; font-size:1.8rem; letter-spacing:-.02em; margin-bottom:6px}
.h2h__side .big{font-family:var(--f-mono); font-weight:700; font-size:2.6rem; margin:12px 0 4px}
.h2h__side.win .big{color:var(--signal)} .h2h__side .big small{font-size:1rem; color:var(--ink-3)}
.h2h__side p{color:var(--ink-2); font-size:.92rem; max-width:26ch; margin:0 auto}
.h2h__vs{display:flex; align-items:center; justify-content:center; background:var(--ink); color:#fff; font-family:var(--f-display); font-weight:800; font-size:1.1rem; border-radius:50%; width:52px; height:52px; margin:auto}
.h2h__foot{border-top:1px solid var(--line); background:var(--paper-3); padding:16px 24px; text-align:center}

/* ---- newsletter ---- */
.news{background:linear-gradient(120deg,#161A2E 0%,#1E2340 60%,#242C5C 100%); color:#fff; border-radius:22px; padding:52px 48px; position:relative; overflow:hidden}
.news::after{content:""; position:absolute; right:-60px; top:-60px; width:280px; height:280px; border-radius:50%; background:radial-gradient(circle,rgba(30,58,255,.5),transparent 70%)}
.news__grid{position:relative; z-index:1; display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center}
.news h2{font-family:var(--f-display); font-weight:800; font-size:clamp(1.7rem,3.2vw,2.4rem); letter-spacing:-.02em; line-height:1.05; margin-bottom:14px}
.news p{color:#C3C8DA; max-width:40ch}
.news__form{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:16px; padding:22px}
.news__pack{font-family:var(--f-mono); font-size:.72rem; letter-spacing:.05em; color:#9AA2C4; margin-bottom:14px; line-height:1.7}
.news__pack b{color:#fff}
.news__input{display:flex; gap:10px; flex-wrap:wrap}
.news__input input{flex:1; min-width:180px; background:rgba(255,255,255,.95); border:0; border-radius:11px; padding:13px 15px; font-family:var(--f-body); font-size:.95rem; color:var(--ink)}
.news__note{font-family:var(--f-mono); font-size:.66rem; color:#8891B4; margin-top:12px}

/* ---- footer ---- */
.footer{border-top:1px solid var(--line); padding:56px 0 40px; margin-top:8px}
.footer__grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:32px; margin-bottom:40px}
.footer__brand p{color:var(--ink-2); font-size:.92rem; max-width:34ch; margin-top:14px}
.fcol h4{font-family:var(--f-mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:14px}
.fcol a{display:block; color:var(--ink-2); font-size:.94rem; padding:5px 0; transition:color .15s}
.fcol a:hover{color:var(--cobalt)}
.footer__disc{border-top:1px solid var(--line); padding-top:22px; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; align-items:center}
.footer__disc p{color:var(--ink-3); font-size:.82rem; max-width:72ch}
.footer__disc .eyebrow{color:var(--ink-3)}

/* ---- reveal ---- */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}

/* ---- breadcrumb ---- */
.crumb{font-family:var(--f-mono); font-size:.74rem; color:var(--ink-3); padding:22px 0 0; letter-spacing:.02em}
.crumb a:hover{color:var(--cobalt)} .crumb .s{color:var(--line-2); margin:0 8px}

/* ---- article / review ---- */
.article{padding:14px 0 40px}
.art-head{max-width:760px; margin-bottom:30px}
.art-tag{color:var(--cobalt)}
.art-head h1{font-family:var(--f-display); font-weight:800; font-size:clamp(2rem,4.6vw,3.1rem); letter-spacing:-.025em; line-height:1.03; margin:14px 0 18px}
.byline{display:flex; align-items:center; gap:14px; flex-wrap:wrap; color:var(--ink-2); font-size:.9rem}
.byline__av{width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--cobalt),#4560ff); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--f-display); font-weight:800; font-size:.9rem; flex:0 0 auto}
.byline b{color:var(--ink); font-weight:600}
.byline .sep{color:var(--line-2)}
.disclosure{margin-top:18px; background:var(--cobalt-wash); border:1px solid #D3DBFF; border-radius:var(--r-sm); padding:12px 15px; font-size:.84rem; color:#2C3466}

.verdict{display:grid; grid-template-columns:.9fr 1.1fr; gap:26px; background:var(--paper-2); border:1px solid var(--line); border-radius:20px; box-shadow:var(--shadow-lift); overflow:hidden; margin:8px 0 44px}
.verdict__left{padding:24px; border-right:1px solid var(--line)}
.verdict__right{padding:26px 28px; display:flex; flex-direction:column}
.verdict .card-score__top{padding:0 0 16px}
.verdict__right h2{font-family:var(--f-display); font-weight:700; font-size:1.3rem; letter-spacing:-.01em; margin-bottom:10px}
.verdict__lead{font-size:1.06rem; color:var(--ink); margin-bottom:16px}
.verdict__lead b{color:var(--cobalt)}
.ver-tags{display:flex; flex-direction:column; gap:8px; margin-bottom:20px}
.ver-tag{display:flex; gap:10px; align-items:flex-start; font-size:.92rem}
.ver-tag .ic{font-family:var(--f-mono); font-weight:700; flex:0 0 auto}
.ver-tag.good .ic{color:var(--signal)} .ver-tag.bad .ic{color:var(--neg)}
.verdict__cta{margin-top:auto}
.verdict__price{font-family:var(--f-mono); font-size:.74rem; color:var(--ink-3); margin-top:10px; text-align:center}
.verdict .card-score__foot{padding:14px 0 0; background:none; border-top:1px dashed var(--line-2); margin-top:16px}

.layout{display:grid; grid-template-columns:1fr 220px; gap:48px; align-items:start}
.prose{max-width:720px}
.prose h2{font-family:var(--f-display); font-weight:700; font-size:clamp(1.5rem,3vw,2rem); letter-spacing:-.02em; line-height:1.1; margin:44px 0 16px; scroll-margin-top:80px}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--f-display); font-weight:700; font-size:1.2rem; margin:28px 0 10px}
.prose p{margin-bottom:16px; font-size:1.06rem; color:#23262E}
.prose a{color:var(--cobalt); font-weight:500; border-bottom:1px solid #C7CFFF}
.prose a:hover{border-color:var(--cobalt)}
.prose ul,.prose ol{margin:0 0 16px 2px; list-style:none}
.prose ul li{position:relative; padding-left:22px; margin-bottom:9px; font-size:1.04rem; color:#23262E}
.prose ul li::before{content:"→"; position:absolute; left:0; color:var(--cobalt); font-family:var(--f-mono)}
.prose ol{counter-reset:li}
.prose ol li{position:relative; padding-left:26px; margin-bottom:9px; font-size:1.04rem; color:#23262E; counter-increment:li}
.prose ol li::before{content:counter(li); position:absolute; left:0; color:var(--cobalt); font-family:var(--f-mono); font-weight:700}

.shot{margin:22px 0; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--paper-2)}
.shot img{width:100%; display:block}
.shot__frame{height:280px; background:repeating-linear-gradient(135deg,#EEF0F4,#EEF0F4 14px,#E8EAEF 14px,#E8EAEF 28px); display:flex; align-items:center; justify-content:center}
.shot__badge{font-family:var(--f-mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); background:var(--paper-2); border:1px solid var(--line); padding:8px 14px; border-radius:20px}
.shot__cap{padding:12px 16px; font-size:.85rem; color:var(--ink-2); border-top:1px solid var(--line); font-family:var(--f-mono); letter-spacing:.01em}

.table-wrap{overflow-x:auto; margin:20px 0; border:1px solid var(--line); border-radius:var(--r)}
table.data{border-collapse:collapse; width:100%; min-width:520px; font-size:.94rem}
table.data thead th{background:var(--ink); color:#fff; font-family:var(--f-mono); font-size:.72rem; letter-spacing:.05em; text-transform:uppercase; text-align:left; padding:14px 16px; font-weight:700}
table.data tbody td{padding:14px 16px; border-top:1px solid var(--line)}
table.data tbody tr:nth-child(even){background:var(--paper-3)}
table.data td b{font-family:var(--f-display)}

.pc{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:22px 0}
.pc__col{border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--paper-2)}
.pc__head{padding:14px 18px; font-family:var(--f-mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; font-weight:700}
.pc--good .pc__head{background:var(--signal-wash); color:#0A6B41}
.pc--bad .pc__head{background:var(--neg-wash); color:#9E2A24}
.pc__col ul{list-style:none; padding:16px 18px; margin:0}
.pc__col li{position:relative; padding-left:22px; margin-bottom:11px; font-size:.96rem; color:#23262E}
.pc--good li::before{content:"+"; position:absolute; left:0; color:var(--signal); font-family:var(--f-mono); font-weight:700}
.pc--bad li::before{content:"\2013"; position:absolute; left:0; color:var(--neg); font-family:var(--f-mono); font-weight:700}

.cta-band{background:var(--ink); color:#fff; border-radius:18px; padding:28px 30px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; margin:30px 0}
.cta-band h3{font-family:var(--f-display); font-weight:700; font-size:1.35rem; letter-spacing:-.01em}
.cta-band p{color:#B4B9C3; font-size:.92rem; margin-top:4px}

.faq{margin-top:8px}
.faq details{border:1px solid var(--line); border-radius:var(--r-sm); background:var(--paper-2); margin-bottom:10px; overflow:hidden}
.faq summary{list-style:none; cursor:pointer; padding:16px 18px; font-family:var(--f-display); font-weight:600; font-size:1.04rem; display:flex; justify-content:space-between; gap:12px; align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; font-family:var(--f-mono); color:var(--cobalt); font-size:1.2rem; flex:0 0 auto}
.faq details[open] summary::after{content:"\2013"}
.faq details p{padding:0 18px 18px; color:#23262E; font-size:1rem}

.author{display:flex; gap:18px; align-items:flex-start; border:1px solid var(--line); border-radius:var(--r); background:var(--paper-2); padding:22px; margin:36px 0}
.author__av{width:64px; height:64px; border-radius:16px; flex:0 0 auto; background:linear-gradient(135deg,var(--cobalt),#4560ff); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--f-display); font-weight:800; font-size:1.4rem}
.author__name{font-family:var(--f-display); font-weight:700; font-size:1.15rem}
.author__role{font-family:var(--f-mono); font-size:.72rem; color:var(--ink-3); text-transform:uppercase; letter-spacing:.05em; margin:2px 0 8px}
.author p{font-size:.94rem; color:var(--ink-2); margin-bottom:10px}
.author__links a{font-family:var(--f-mono); font-size:.78rem; color:var(--cobalt); margin-right:16px}

.toc{position:sticky; top:88px; font-size:.9rem}
.toc h4{font-family:var(--f-mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:12px}
.toc a{display:block; color:var(--ink-2); padding:6px 0 6px 12px; border-left:2px solid var(--line); transition:.15s}
.toc a:hover{color:var(--cobalt); border-color:var(--cobalt)}

.related{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:20px}
.rcard{border:1px solid var(--line); border-radius:var(--r); background:var(--paper-2); padding:18px; box-shadow:var(--shadow); transition:transform .15s}
.rcard:hover{transform:translateY(-3px)}
.rcard .n{font-family:var(--f-display); font-weight:700; font-size:1.1rem; display:flex; justify-content:space-between; align-items:center}
.rcard .s{font-family:var(--f-mono); font-weight:700; color:var(--cobalt); font-size:.85rem; border:1.5px solid var(--cobalt); border-radius:8px; padding:2px 7px}
.rcard p{color:var(--ink-2); font-size:.88rem; margin-top:6px}

/* ---- generic page (category / simple) ---- */
.pagehead{padding:44px 0 10px}
.pagehead h1{font-family:var(--f-display); font-weight:800; font-size:clamp(2rem,4.4vw,3rem); letter-spacing:-.025em; margin:12px 0 10px}
.pagehead p{color:var(--ink-2); max-width:52ch; font-size:1.06rem}
.empty{border:1px dashed var(--line-2); border-radius:var(--r); padding:40px; text-align:center; color:var(--ink-2); font-family:var(--f-mono); font-size:.9rem}

/* =========================================================
   ADMIN
   ========================================================= */
.admin{min-height:100vh; display:grid; grid-template-columns:250px 1fr; background:var(--paper)}
.aside{background:var(--ink); color:#fff; padding:24px 18px; position:sticky; top:0; align-self:start; height:100vh}
.aside .brand{color:#fff; margin-bottom:26px}
.aside .brand__mark{background:#fff}
.aside .brand__mark::before{background:var(--signal)} .aside .brand__mark::after{background:var(--cobalt)}
.anav a{display:flex; align-items:center; gap:10px; color:#B4B9C3; padding:11px 12px; border-radius:9px; font-size:.94rem; font-weight:500; margin-bottom:3px; transition:.15s}
.anav a:hover{background:#23262F; color:#fff}
.anav a.active{background:var(--cobalt); color:#fff}
.anav .grp{font-family:var(--f-mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:#6B7280; margin:20px 0 8px 12px}
.aside__foot{position:absolute; bottom:22px; left:18px; right:18px; font-family:var(--f-mono); font-size:.72rem; color:#6B7280}
.aside__foot a{color:#9AA2C4}
.amain{padding:32px 36px; overflow-x:hidden}
.abar{display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:26px; flex-wrap:wrap}
.abar h1{font-family:var(--f-display); font-weight:800; font-size:1.7rem; letter-spacing:-.02em}
.abar .sub{color:var(--ink-2); font-size:.92rem; margin-top:2px}
.flash{padding:13px 16px; border-radius:var(--r-sm); margin-bottom:20px; font-size:.92rem; font-weight:500}
.flash--ok{background:var(--signal-wash); color:#0A6B41; border:1px solid #BFE6D2}
.flash--err{background:var(--neg-wash); color:#9E2A24; border:1px solid #F0C9C6}

.panel{background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow); padding:24px; margin-bottom:22px}
.panel h2{font-family:var(--f-display); font-weight:700; font-size:1.15rem; margin-bottom:4px}
.panel .hint{color:var(--ink-3); font-size:.85rem; margin-bottom:18px}

.atable{width:100%; border-collapse:collapse; font-size:.93rem; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); overflow:hidden}
.atable th{background:var(--paper-3); text-align:left; padding:12px 15px; font-family:var(--f-mono); font-size:.7rem; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-2)}
.atable td{padding:13px 15px; border-top:1px solid var(--line); vertical-align:middle}
.atable tr:hover td{background:#FAFBFC}
.badge{font-family:var(--f-mono); font-size:.66rem; padding:3px 9px; border-radius:20px; letter-spacing:.03em; text-transform:uppercase; font-weight:700}
.badge--pub{background:var(--signal-wash); color:#0A6B41}
.badge--draft{background:var(--paper-3); color:var(--ink-2)}
.badge--score{background:var(--cobalt-wash); color:var(--cobalt-ink)}

.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px 20px}
.field{display:flex; flex-direction:column; gap:6px; margin-bottom:16px}
.field.col-2{grid-column:span 2}
.field label{font-size:.86rem; font-weight:600; color:var(--ink)}
.field .lh{font-size:.78rem; color:var(--ink-3); font-weight:400}
.field input[type=text],.field input[type=email],.field input[type=password],.field input[type=number],.field input[type=url],.field select,.field textarea{
  font-family:var(--f-body); font-size:.94rem; color:var(--ink); background:var(--paper-2);
  border:1px solid var(--line-2); border-radius:9px; padding:10px 12px; width:100%; transition:border .15s, box-shadow .15s;
}
.field textarea{resize:vertical; min-height:90px; line-height:1.55}
.field textarea.tall{min-height:200px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--cobalt); box-shadow:0 0 0 3px var(--cobalt-wash)}
.field .mono{font-family:var(--f-mono); font-size:.88rem}
.check{display:flex; align-items:center; gap:9px; font-size:.9rem}
.check input{width:17px; height:17px; accent-color:var(--cobalt)}
.scores{display:grid; grid-template-columns:repeat(5,1fr); gap:12px}
.form-actions{display:flex; gap:12px; align-items:center; margin-top:8px; flex-wrap:wrap}
.seo-preview{background:var(--paper-3); border:1px solid var(--line); border-radius:var(--r-sm); padding:16px}
.seo-preview .t{color:#1a0dab; font-size:1.05rem; line-height:1.3}
.seo-preview .u{color:#006621; font-size:.82rem; font-family:var(--f-mono); margin:3px 0}
.seo-preview .d{color:#4d5156; font-size:.86rem}

.login-wrap{min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; background:radial-gradient(1200px 500px at 50% -10%, #E6EAFF, var(--paper))}
.login-card{width:100%; max-width:380px; background:var(--paper-2); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow-lift); padding:34px}
.login-card .brand{justify-content:center; margin-bottom:8px}
.login-card p.sub{text-align:center; color:var(--ink-2); font-size:.9rem; margin-bottom:22px}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .nav,.topbar__end .link-mono{display:none}
  .burger{display:flex}
  .hero__grid{grid-template-columns:1fr; gap:40px}
  .hero__order-media{order:-1}
  .steps,.cats,.verdicts{grid-template-columns:1fr}
  .h2h__grid{grid-template-columns:1fr} .h2h__vs{margin:-6px auto}
  .news,.news__grid{padding:40px 26px} .news__grid{grid-template-columns:1fr; gap:26px}
  .process{padding:34px 24px}
  .footer__grid{grid-template-columns:1fr 1fr}
  .verdict{grid-template-columns:1fr}
  .verdict__left{border-right:0; border-bottom:1px solid var(--line)}
  .layout{grid-template-columns:1fr; gap:0} .toc{display:none}
  .pc,.related{grid-template-columns:1fr}
  .admin{grid-template-columns:1fr}
  .aside{position:static; height:auto; display:flex; flex-wrap:wrap; gap:8px; align-items:center}
  .aside .brand{margin:0 16px 0 0} .anav{display:flex; flex-wrap:wrap; gap:4px} .anav .grp,.aside__foot{display:none}
  .amain{padding:22px 18px}
  .form-grid{grid-template-columns:1fr} .field.col-2{grid-column:auto} .scores{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .footer__grid{grid-template-columns:1fr} .section{padding:56px 0} .wrap{padding:0 18px}
  .related{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important}
  .reveal{opacity:1; transform:none} .bar-fill{transition:none}
}
