@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --primary: #0d9488;
  --primary-dark: #0f766e;
  --primary-light: #ccfbf1;
  --primary-soft: #f0fdfa;
  --accent: #f97316;
  --accent-dark: #ea580c;
  --accent-light: #ffedd5;
  --gold: #d97706;
  --gold-light: #fef3c7;
  --success: #059669;
  --danger: #dc2626;
  --text: #0c2e2c;
  --text-secondary: #1f3a37;
  --text-muted: #5f7d7a;
  --bg: #f1f7f6;
  --card: #ffffff;
  --border: #d6e4e2;
  --border-subtle: #ecf3f2;
  --radius: 18px;
  --radius-sm: 10px;
  --shadow: 0 4px 20px rgba(13,148,136,0.07), 0 1px 4px rgba(15,23,42,0.04);
  --shadow-md: 0 12px 40px rgba(13,148,136,0.10), 0 4px 12px rgba(15,23,42,0.05);
  --shadow-hover: 0 16px 48px rgba(13,148,136,0.16), 0 4px 12px rgba(15,23,42,0.06);
  --ease: 0.2s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);color:var(--text);line-height:1.6;font-size:16px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
ul{list-style:none}

/* ── Site Header ── */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.88);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  height:56px;display:flex;align-items:center;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
}
.header-logo{
  display:flex;align-items:center;gap:8px;
  color:var(--text);font-weight:700;font-size:16px;
  text-decoration:none;flex-shrink:0;
}
.header-logo-icon{flex-shrink:0}
.header-logo-text{letter-spacing:-0.01em}
.header-logo-accent{color:var(--primary)}
.header-nav{
  display:flex;align-items:center;gap:2px;
}
.nav-link{
  font-size:14px;font-weight:500;color:var(--text-secondary);
  padding:6px 12px;border-radius:8px;
  transition:color var(--ease),background var(--ease);
  text-decoration:none;white-space:nowrap;
}
.nav-link:hover,.nav-link.active{
  color:var(--primary);background:var(--primary-light);
}
.header-burger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:6px;
  border-radius:8px;flex-shrink:0;
}
.header-burger span{
  display:block;width:22px;height:2px;
  background:var(--text);border-radius:2px;
  transition:transform 0.2s,opacity 0.2s;
}
.header-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.header-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.header-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:640px){
  .header-nav{display:none}
  .header-burger{display:flex}
}

/* ── Mobile Menu overlay (sibling of header, not inside it) ── */
.mobile-menu{
  position:fixed;
  top:56px;left:0;right:0;bottom:0;
  background:#fff;
  z-index:99;
  overflow-y:auto;
  border-top:2px solid var(--primary-light);
  visibility:hidden;
  opacity:0;
  transform:translateY(-8px);
  transition:opacity 0.22s ease,visibility 0.22s ease,transform 0.22s ease;
  /* Only visible on mobile */
  display:none;
}
@media(max-width:640px){
  .mobile-menu{display:block}
}
.mobile-menu.open{
  visibility:visible;
  opacity:1;
  transform:translateY(0);
}
.mobile-nav-link{
  display:flex;
  align-items:center;
  gap:14px;
  padding:17px 24px;
  border-bottom:1px solid var(--border-subtle);
  color:var(--text);
  text-decoration:none;
  transition:background var(--ease),color var(--ease);
}
.mobile-nav-link:last-child{border-bottom:none}
.mobile-nav-link:active,
.mobile-nav-link:hover{background:var(--primary-light);color:var(--primary)}
.mnl-num{
  font-size:11px;font-weight:700;
  color:var(--text-muted);letter-spacing:.05em;
  min-width:20px;flex-shrink:0;
}
.mnl-text{font-size:16px;font-weight:500}
body.menu-open{overflow:hidden}

/* ── Layout ── */
.container{width:100%;max-width:960px;margin:0 auto;padding:0 20px}
section{padding:48px 0;scroll-margin-top:64px}

/* ── Hero v2 (full redesign — теплая бирюза + оранжевый акцент) ── */
.hero{
  background:#04222a;color:#fff;padding:32px 0 36px;
  position:relative;overflow:hidden;
}
.hero-v2-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-v2-blob{
  position:absolute;border-radius:50%;
  filter:blur(80px);opacity:.55;
}
.hero-v2-blob-1{
  width:520px;height:520px;
  background:radial-gradient(circle,#0ea5a4 0%,#0d9488 40%,transparent 70%);
  top:-160px;left:-120px;
}
.hero-v2-blob-2{
  width:420px;height:420px;
  background:radial-gradient(circle,#f97316 0%,#ea580c 40%,transparent 70%);
  bottom:-160px;right:-90px;opacity:.45;
}
.hero-v2-orbit{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,black 30%,transparent 90%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,black 30%,transparent 90%);
}
.hero-v2-container{position:relative;z-index:1}

.hero-v2-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:26px;
  align-items:start;
}

.hero-v2-status{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(20,184,166,.13);
  border:1px solid rgba(94,234,212,.32);
  color:#5eead4;
  border-radius:50px;
  padding:5px 12px 5px 8px;
  font-size:12px;font-weight:600;
  margin-bottom:18px;letter-spacing:.1px;
}
.hero-v2-pulse{
  width:8px;height:8px;border-radius:50%;
  background:#34d399;
  position:relative;
  box-shadow:0 0 12px rgba(52,211,153,.7);
}
.hero-v2-pulse::after{
  content:'';position:absolute;inset:-4px;
  border:2px solid rgba(52,211,153,.45);border-radius:50%;
  animation:hero-v2-ring 1.8s ease-out infinite;
}
@keyframes hero-v2-ring{
  0%{transform:scale(.5);opacity:1}
  100%{transform:scale(1.7);opacity:0}
}

.hero-v2-title{
  font-size:clamp(28px,7vw,52px);font-weight:900;
  line-height:1.07;margin-bottom:16px;letter-spacing:-1.5px;
  color:#fff;
}
.hero-v2-title-mark{
  background:linear-gradient(120deg,#5eead4 0%,#fbbf24 60%,#fb923c 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-v2-lead{
  font-size:clamp(15px,2.4vw,17px);
  color:rgba(255,255,255,.72);
  line-height:1.65;margin-bottom:18px;
  max-width:620px;
}

.hero-v2-bullets{
  display:flex;flex-direction:column;gap:7px;
  margin-bottom:22px;
}
.hero-v2-bullets li{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:rgba(255,255,255,.82);font-weight:500;
}
.hero-v2-check{
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#14b8a6,#0d9488);
  color:#fff;font-size:13px;font-weight:800;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(20,184,166,.35);
}

.hero-v2-cta-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.hero-v2-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#f97316,#ea580c);
  color:#fff;padding:13px 22px;border-radius:50px;
  font-size:15px;font-weight:700;letter-spacing:-.2px;
  transition:transform var(--ease),box-shadow var(--ease);
  box-shadow:0 8px 22px rgba(249,115,22,.35);
}
.hero-v2-cta:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(249,115,22,.5);color:#fff}
.hero-v2-cta-ghost{
  display:inline-flex;align-items:center;gap:6px;
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.04);
  padding:12px 18px;border-radius:50px;
  font-size:14px;font-weight:600;
  transition:background var(--ease),border-color var(--ease);
}
.hero-v2-cta-ghost:hover{background:rgba(255,255,255,.10);border-color:rgba(94,234,212,.5);color:#fff}

/* Side panel — stats + quick top */
.hero-v2-side{
  display:flex;flex-direction:column;gap:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;padding:18px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.hero-v2-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
.hero-v2-stat{
  background:rgba(20,184,166,.10);
  border:1px solid rgba(94,234,212,.18);
  border-radius:12px;padding:11px 12px;
}
.hero-v2-stat-num{
  font-size:24px;font-weight:900;letter-spacing:-1px;
  background:linear-gradient(135deg,#5eead4,#fb923c);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.1;
}
.hero-v2-stat-lbl{
  font-size:11px;color:rgba(255,255,255,.6);
  font-weight:500;margin-top:2px;letter-spacing:.1px;
}

.hero-v2-quick{
  display:flex;flex-direction:column;gap:8px;
  border-top:1px dashed rgba(255,255,255,.12);
  padding-top:14px;
}
.hero-v2-quick-row{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:rgba(255,255,255,.85);
}
.hero-v2-quick-medal{
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:#fff;flex-shrink:0;
}
.hero-v2-quick-gold{background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 0 0 2px rgba(251,191,36,.25)}
.hero-v2-quick-silver{background:linear-gradient(135deg,#94a3b8,#cbd5e1);color:#1e293b}
.hero-v2-quick-bronze{background:linear-gradient(135deg,#b45309,#d97706)}
.hero-v2-quick-name{font-weight:700;color:#fff;flex-shrink:0}
.hero-v2-quick-tag{
  font-size:11.5px;color:rgba(94,234,212,.85);
  background:rgba(20,184,166,.12);
  padding:2px 8px;border-radius:50px;
  margin-left:auto;white-space:nowrap;
  border:1px solid rgba(94,234,212,.18);
}

/* Author block — теперь в hero v2 */
.hero-v2-author{
  margin-top:24px;
}
.author-block{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(94,234,212,.18);
  border-radius:14px;
  padding:16px 18px;
  display:flex;align-items:flex-start;gap:14px;
  backdrop-filter:blur(8px);
}
.author-photo-wrap{flex-shrink:0}
.author-photo{
  width:60px;height:60px;border-radius:50%;
  display:block;
  box-shadow:0 0 0 2px rgba(94,234,212,.4),0 8px 22px rgba(20,184,166,.25);
}
.author-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}
.author-name{font-size:15px;font-weight:800;color:#fff;line-height:1.2}
.author-title{font-size:12.5px;color:#5eead4;font-weight:500}
.author-block p{font-size:12.5px;color:rgba(255,255,255,.7);line-height:1.6;margin-top:4px}
.author-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.author-badge{
  font-size:11px;font-weight:600;color:#5eead4;
  background:rgba(20,184,166,.13);border:1px solid rgba(94,234,212,.25);
  border-radius:50px;padding:3px 10px;
}

/* Tablet: side panel slides in next to main */
@media(min-width:760px){
  .hero{padding:48px 0 44px}
  .hero-v2-grid{grid-template-columns:minmax(0,1.35fr) minmax(280px,1fr);gap:32px}
  .hero-v2-side{padding:20px}
}

/* Larger desktops */
@media(min-width:960px){
  .hero{padding:64px 0 56px}
  .hero-v2-stats{grid-template-columns:1fr 1fr}
}

/* ── Editorial Choice ── */
.editorial{
  background:linear-gradient(135deg,#f0fdfa 0%,#fff7ed 100%);
  border:1.5px solid rgba(13,148,136,.22);
  border-radius:var(--radius);padding:28px;
  position:relative;overflow:hidden;
}
.editorial::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#0d9488,#14b8a6,#f97316);
}
.editorial-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,#0d9488,#0f766e);
  color:#fff;border-radius:20px;padding:5px 14px;
  font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:16px;
  box-shadow:0 4px 14px rgba(13,148,136,.3);
}
.editorial h2{font-size:22px;font-weight:900;margin-bottom:10px;letter-spacing:-.5px}
.editorial-benefit{font-size:14px;color:var(--text-secondary);margin-bottom:14px;line-height:1.65}
.editorial-why{
  font-size:14px;color:#134e4a;
  background:rgba(255,255,255,.7);
  border-radius:var(--radius-sm);padding:12px 16px;
  border-left:3px solid #0d9488;line-height:1.65;
  backdrop-filter:blur(4px);
}
.editorial-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:22px;
  background:linear-gradient(135deg,#f97316,#ea580c);
  color:#fff;padding:13px 28px;border-radius:50px;
  font-weight:700;font-size:15px;letter-spacing:-.2px;
  transition:transform var(--ease),box-shadow var(--ease);
  box-shadow:0 6px 20px rgba(249,115,22,.34);
}
.editorial-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(249,115,22,.5);color:#fff}

/* ── Filter Tags ── */
.filter-section{margin-bottom:4px}
.filter-label{font-size:13px;color:var(--text-muted);margin-bottom:12px;font-weight:500}
.filter-tags{display:flex;flex-wrap:wrap;gap:8px}
.filter-tag{
  background:var(--card);border:1.5px solid var(--border);
  border-radius:50px;padding:7px 16px;
  font-size:13px;cursor:pointer;
  transition:all var(--ease);
  color:var(--text-muted);font-weight:500;
  white-space:nowrap;font-family:inherit;letter-spacing:-.1px;
}
.filter-tag:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.filter-tag.active{
  background:var(--primary);border-color:var(--primary);color:#fff;
  box-shadow:0 4px 14px rgba(99,102,241,.28);
}

/* ── Rating section ── */
.rating-section h2{font-size:clamp(20px,4vw,28px);font-weight:900;margin-bottom:8px;letter-spacing:-.6px}
.rating-section .section-desc{font-size:15px;color:var(--text-muted);margin-bottom:28px}

/* ── Cards Grid ── */
.pinned-label{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;
  color:var(--text-muted);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.pinned-label::after{content:'';flex:1;height:1px;background:var(--border)}
.cards-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.cards-grid{grid-template-columns:1fr 1fr}}

/* ── VPN Card ── */
.vpn-card{
  background:var(--card);border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--border);
  overflow:hidden;display:flex;flex-direction:column;
  transition:box-shadow var(--ease),transform var(--ease),border-color var(--ease);
  position:relative;
}
.vpn-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--border);transition:background var(--ease);
}
.vpn-card.rank-1::before{background:linear-gradient(90deg,#d97706,#fbbf24)}
.vpn-card.rank-2::before{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}
.vpn-card.rank-3::before{background:linear-gradient(90deg,#b45309,#d97706)}
.vpn-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px);border-color:rgba(99,102,241,.2)}
.vpn-card.rank-1{box-shadow:var(--shadow),0 0 0 1px rgba(217,119,6,.12)}
.vpn-card.rank-1:hover{box-shadow:0 16px 50px rgba(217,119,6,.14),0 4px 12px rgba(15,23,42,.06)}

.card-header{
  padding:18px 18px 14px;display:flex;align-items:flex-start;gap:14px;
  border-bottom:1px solid var(--border-subtle);
}
.card-logo{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:14px;color:#fff;flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.12);
}
.card-logo.logo-vt{background:linear-gradient(135deg,#0d9488,#14b8a6)}
.card-logo.logo-ag{background:linear-gradient(135deg,#059669,#10b981)}
.card-logo.logo-hn{background:linear-gradient(135deg,#dc2626,#f97316)}
.card-logo.logo-ol{background:linear-gradient(135deg,#2563eb,#0d9488)}
.card-logo.logo-pv{background:linear-gradient(135deg,#7c3aed,#db2777)}
.card-logo.logo-am{background:linear-gradient(135deg,#0f766e,#fb923c)}
.card-logo.logo-cw{background:linear-gradient(135deg,#f97316,#fbbf24)}
.card-logo.logo-ws{background:linear-gradient(135deg,#0d9488,#0891b2)}
.card-logo.logo-ps{background:linear-gradient(135deg,#0891b2,#2563eb)}
.card-logo.logo-br{background:linear-gradient(135deg,#1e40af,#0ea5e9)}

.card-title-area{flex:1;min-width:0}
.card-rank-badge{
  display:inline-flex;align-items:center;gap:4px;
  border-radius:6px;padding:3px 9px;
  font-size:11px;font-weight:700;margin-bottom:5px;letter-spacing:.2px;
}
.rank-gold{background:#fef3c7;color:#92400e}
.rank-silver{background:#f1f5f9;color:#475569}
.rank-bronze{background:#fef0e0;color:#7c2d12}
.rank-default{background:#f1f5f9;color:#475569}
.card-name{font-size:17px;font-weight:800;line-height:1.2;letter-spacing:-.3px}
.card-tags-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}
.card-tag{
  background:#f8fafc;border:1px solid var(--border);
  border-radius:5px;padding:2px 8px;
  font-size:11px;color:var(--text-muted);font-weight:500;
}

.card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:14px}

.free-badge{
  background:#f0fdf4;border:1px solid #bbf7d0;
  border-radius:var(--radius-sm);padding:10px 14px;
  font-size:13px;color:#065f46;font-weight:500;
  display:flex;align-items:flex-start;gap:8px;
}
.free-badge-icon{font-size:15px;flex-shrink:0;margin-top:1px}
.free-badge span{font-weight:700}

.why-block h4{font-size:13px;font-weight:700;margin-bottom:5px;letter-spacing:-.1px}
.why-block p{font-size:13px;color:var(--text-secondary);line-height:1.65}

.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pros-cons-col{border-radius:var(--radius-sm);padding:10px 12px}
.pros-cons-col h5{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.6px;margin-bottom:7px;
}
.pros-col{background:#f0fdf4}
.pros-col h5{color:#059669}
.cons-col{background:#fff5f5}
.cons-col h5{color:#dc2626}
.pros-cons-col ul li{
  font-size:12px;color:#334155;
  padding-left:14px;position:relative;
  margin-bottom:4px;line-height:1.45;
}
.pros-col li::before{content:"✓";position:absolute;left:0;color:#059669;font-weight:700}
.cons-col li::before{content:"✗";position:absolute;left:0;color:#dc2626;font-weight:700}

.speed-price{display:flex;gap:10px}
.metric{
  flex:1;background:#fafafa;border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:12px;text-align:center;
}
.metric-label{font-size:10px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.metric-value{font-size:22px;font-weight:900;color:var(--text);letter-spacing:-1px;line-height:1}
.metric-unit{font-size:11px;color:var(--text-muted);margin-top:2px}
.speed-bar-wrap{margin-top:7px}
.speed-bar{height:5px;background:#e2e8f0;border-radius:5px;overflow:hidden}
.speed-bar-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,#059669,#34d399)}

.review-block{
  background:#fafafa;border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:11px 14px;
  font-size:13px;color:var(--text-secondary);
  font-style:italic;border-left:3px solid var(--primary);line-height:1.65;
}

.lifehack{
  background:linear-gradient(135deg,#fffbeb,#fefce8);
  border:1px solid #fde68a;border-radius:var(--radius-sm);
  padding:12px 14px;display:flex;gap:10px;align-items:flex-start;
}
.lifehack-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.lifehack-label{font-size:11px;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px}
.lifehack p{font-size:13px;color:#78350f;line-height:1.55}

.card-cta{padding:14px 18px;border-top:1px solid var(--border-subtle);background:#fafafa}
.cta-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:12px;border-radius:50px;
  font-size:14px;font-weight:700;letter-spacing:-.2px;
  transition:transform var(--ease),box-shadow var(--ease);color:#fff;
  font-family:inherit;
}
.cta-btn:hover{transform:translateY(-1px);color:#fff}
.cta-primary{background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 6px 20px rgba(249,115,22,.32)}
.cta-primary:hover{box-shadow:0 10px 30px rgba(249,115,22,.45)}
.cta-secondary{background:linear-gradient(135deg,#0d9488,#0f766e);box-shadow:0 6px 20px rgba(13,148,136,.3)}
.cta-secondary:hover{box-shadow:0 10px 30px rgba(13,148,136,.45)}
.cta-tertiary{background:linear-gradient(135deg,#1e40af,#0d9488);box-shadow:0 6px 20px rgba(30,64,175,.3)}
.cta-tertiary:hover{box-shadow:0 10px 30px rgba(30,64,175,.45)}

/* ── Methodology ── */
.methodology{
  background:var(--card);border-radius:var(--radius);
  padding:32px;box-shadow:var(--shadow);border:1px solid var(--border);
}
.methodology h2{font-size:22px;font-weight:900;margin-bottom:8px;letter-spacing:-.5px}
.methodology .section-desc{font-size:14px;color:var(--text-muted);margin-bottom:26px;line-height:1.7}
.method-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.method-grid{grid-template-columns:1fr 1fr}}
.method-block h3{font-size:14px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px;letter-spacing:-.2px}
.method-block h3 span{background:var(--primary);color:#fff;border-radius:6px;padding:2px 9px;font-size:12px}
.method-block ul li{
  font-size:13px;color:var(--text-secondary);
  padding-left:18px;position:relative;margin-bottom:7px;line-height:1.55;
}
.method-block ul li::before{
  content:'';position:absolute;left:5px;top:7px;
  width:5px;height:5px;border-radius:50%;background:var(--primary);
}
.note-block{
  background:#fff7ed;border:1px solid #fed7aa;
  border-radius:var(--radius-sm);padding:13px 16px;
  font-size:13px;color:#9a3412;margin-top:14px;
  grid-column:1/-1;line-height:1.65;
}
.criteria-list{display:flex;flex-direction:column;gap:8px;grid-column:1/-1}
.criteria-item{
  background:#fafafa;border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:11px 14px;
  display:flex;align-items:flex-start;gap:10px;
  transition:background var(--ease);
}
.criteria-item:hover{background:var(--primary-light)}
.criteria-tag{
  background:var(--primary);color:#fff;
  border-radius:6px;padding:3px 9px;
  font-size:11px;font-weight:700;white-space:nowrap;
  margin-top:1px;flex-shrink:0;
}
.criteria-text{font-size:13px;color:var(--text-secondary);line-height:1.6}
.criteria-text strong{color:var(--text)}

.fit-lists{display:grid;grid-template-columns:1fr 1fr;gap:16px;grid-column:1/-1}
.fit-col h3{font-size:13px;font-weight:700;margin-bottom:10px}
.fit-yes h4{color:#059669}
.fit-no h4{color:#dc2626}
.fit-col ul li{font-size:13px;color:var(--text-secondary);padding-left:18px;position:relative;margin-bottom:5px}
.fit-yes li::before{content:"✓";position:absolute;left:0;color:#059669;font-weight:700}
.fit-no li::before{content:"✗";position:absolute;left:0;color:#dc2626;font-weight:700}

/* ── Comparison Table ── */
.table-section h2{font-size:22px;font-weight:900;margin-bottom:8px;letter-spacing:-.5px}
.table-section .section-desc{font-size:14px;color:var(--text-muted);margin-bottom:18px}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;background:var(--card);font-size:13px}
thead{background:linear-gradient(135deg,#04222a,#0c4641);color:#fff}
th{padding:14px 16px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}
td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f8fafc}
.tr-gold td:first-child{border-left:3px solid #f59e0b}
.tr-silver td:first-child{border-left:3px solid #94a3b8}
.tr-bronze td:first-child{border-left:3px solid #b45309}
.yes-icon{color:#059669;font-weight:700}
.no-icon{color:#dc2626}
.partial-icon{color:#d97706}

/* ── Alt Methods ── */
.alt-section h2{font-size:22px;font-weight:900;margin-bottom:8px;letter-spacing:-.5px}
.alt-intro{font-size:14px;color:var(--text-secondary);margin-bottom:22px;max-width:700px;line-height:1.75}
.alt-cards{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.alt-cards{grid-template-columns:1fr 1fr 1fr}}
.alt-card{
  background:var(--card);border-radius:var(--radius);padding:20px;
  box-shadow:var(--shadow);border:1px solid var(--border);
  transition:box-shadow var(--ease),transform var(--ease);
}
.alt-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.alt-card h3{font-size:15px;font-weight:700;margin-bottom:9px;letter-spacing:-.2px}
.alt-card p{font-size:13px;color:var(--text-secondary);margin-bottom:12px;line-height:1.65}
.alt-tags{display:flex;flex-wrap:wrap;gap:6px}
.alt-tag{background:#f8fafc;border:1px solid var(--border);border-radius:6px;padding:3px 9px;font-size:11px;color:var(--text-muted);font-weight:500}
.express-block{
  background:linear-gradient(135deg,#fffbeb,#fff7ed);
  border:1.5px solid #fde68a;border-radius:var(--radius);
  padding:22px;margin-top:18px;
}
.express-block h3{font-size:17px;font-weight:800;margin-bottom:14px;color:#92400e;letter-spacing:-.3px}
.express-block ul li{font-size:14px;color:#374151;padding-left:22px;position:relative;margin-bottom:8px;line-height:1.6}
.express-block ul li::before{content:"→";position:absolute;left:0;color:#d97706;font-weight:700}

/* ── Expert Advice ── */
.expert-section h2{font-size:22px;font-weight:900;margin-bottom:8px;letter-spacing:-.5px}
.expert-intro{font-size:14px;color:var(--text-secondary);margin-bottom:22px;max-width:700px;line-height:1.75}
.expert-card{
  background:var(--card);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);margin-bottom:14px;border:1px solid var(--border);
}
.expert-card h3{font-size:17px;font-weight:800;margin-bottom:14px;letter-spacing:-.3px}
.expert-card ul li{font-size:13px;color:var(--text-secondary);padding-left:20px;position:relative;margin-bottom:7px;line-height:1.6}
.expert-card ul li::before{content:"⚠";position:absolute;left:0;font-size:11px;color:#dc2626}
.expert-card p{font-size:13px;color:var(--text-secondary);line-height:1.75}
.expert-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.expert-tag{border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600}
.etag-danger{background:#fee2e2;color:#991b1b}
.etag-warning{background:#fef3c7;color:#92400e}
.flags-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}
.flags-col h4{font-size:13px;font-weight:700;margin-bottom:10px}
.flags-green h5{color:#059669}
.flags-red h5{color:#dc2626}
.flags-col ul li{font-size:13px;color:var(--text-secondary);padding-left:20px;position:relative;margin-bottom:6px}
.flags-green li::before{content:"🟢";position:absolute;left:0;font-size:10px;top:2px}
.flags-red li::before{content:"🔴";position:absolute;left:0;font-size:10px;top:2px}

/* ── FAQ ── */
.faq-section h2{font-size:22px;font-weight:900;margin-bottom:8px;letter-spacing:-.5px}
.faq-intro{font-size:14px;color:var(--text-muted);margin-bottom:22px}
.faq-item{
  background:var(--card);border-radius:var(--radius-sm);
  margin-bottom:8px;border:1px solid var(--border);overflow:hidden;
  transition:border-color var(--ease);
}
.faq-item.open{border-color:rgba(99,102,241,.3)}
.faq-q{
  width:100%;background:none;border:none;
  padding:17px 20px;font-size:15px;font-weight:600;
  color:var(--text);cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  text-align:left;font-family:inherit;letter-spacing:-.2px;
  transition:background var(--ease);
}
.faq-q:hover{background:#f8fafc}
.faq-item.open .faq-q{background:var(--primary-light);color:var(--primary-dark)}
.faq-icon{
  width:26px;height:26px;border-radius:50%;
  background:#f1f5f9;color:var(--primary);
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:400;
  transition:transform var(--ease),background var(--ease),color var(--ease);
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--primary);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .32s ease}
.faq-item.open .faq-a{max-height:400px}
.faq-a-inner{padding:0 20px 18px;font-size:14px;color:var(--text-secondary);line-height:1.75;border-top:1px solid var(--border)}

/* ── Reviews ── */
.reviews-section h2{font-size:22px;font-weight:900;margin-bottom:8px;letter-spacing:-.5px}
.reviews-intro{font-size:14px;color:var(--text-muted);margin-bottom:22px}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.reviews-grid{grid-template-columns:1fr 1fr}}
.review-card{
  background:var(--card);border-radius:var(--radius);padding:20px;
  box-shadow:var(--shadow);border:1px solid var(--border);
  transition:box-shadow var(--ease),transform var(--ease);
}
.review-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.review-avatar{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;color:#fff;flex-shrink:0;
}
.rv1{background:linear-gradient(135deg,#0d9488,#14b8a6)}
.rv2{background:linear-gradient(135deg,#f97316,#fb923c)}
.rv3{background:linear-gradient(135deg,#dc2626,#ea580c)}
.rv4{background:linear-gradient(135deg,#0ea5e9,#0d9488)}
.review-meta{flex:1}
.review-name{font-size:14px;font-weight:700;letter-spacing:-.1px}
.review-service{font-size:12px;color:var(--text-muted);margin-top:1px}
.review-stars{color:#f59e0b;font-size:14px;letter-spacing:1px}
.review-text{font-size:13px;color:var(--text-secondary);line-height:1.65}

/* ── Footer ── */
footer{background:linear-gradient(180deg,#04222a,#02161c);color:rgba(255,255,255,.55);padding:32px 0;text-align:center;font-size:13px;line-height:1.75}
footer a{color:#5eead4}

/* ── Shared ── */
.section-title{font-size:clamp(20px,4vw,26px);font-weight:900;margin-bottom:8px;letter-spacing:-.6px}
.mt-24{margin-top:28px}
.rest-label{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--text-muted);
  margin:28px 0 14px;
  display:flex;align-items:center;gap:10px;
}
.rest-label::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── Quick Pick (TL;DR) ── */
.quickpick-section{padding:48px 0 24px}
.quickpick-grid{
  display:grid;grid-template-columns:1fr;gap:14px;
  margin-top:24px;
}
@media(min-width:560px){.quickpick-grid{grid-template-columns:1fr 1fr}}
@media(min-width:880px){.quickpick-grid{grid-template-columns:1fr 1fr 1fr}}
.quickpick-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 18px 20px;
  position:relative;overflow:hidden;
  transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease);
  box-shadow:var(--shadow);
}
.quickpick-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#0d9488,#14b8a6,#fb923c);
}
.quickpick-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:rgba(13,148,136,.25);
}
.quickpick-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;
  background:var(--primary-soft);color:var(--primary-dark);
  padding:4px 12px;border-radius:50px;
  border:1px solid rgba(13,148,136,.2);
  margin-bottom:10px;letter-spacing:-.1px;
}
.quickpick-card h3{
  font-size:16px;font-weight:800;
  margin-bottom:8px;letter-spacing:-.3px;
  color:var(--text);
}
.quickpick-card p{
  font-size:13.5px;color:var(--text-secondary);
  line-height:1.65;
}
.quickpick-card strong{color:var(--primary-dark);font-weight:700}

/* ── HowTo ── */
.howto-section{padding:48px 0}
.howto-steps{
  list-style:none;padding:0;margin-top:24px;
  display:grid;grid-template-columns:1fr;gap:14px;
  counter-reset:step;
}
.howto-steps li{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  display:flex;gap:14px;align-items:flex-start;
  box-shadow:var(--shadow);
  transition:border-color var(--ease),box-shadow var(--ease);
}
.howto-steps li:hover{
  border-color:rgba(13,148,136,.25);
  box-shadow:var(--shadow-md);
}
.howto-num{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0d9488,#14b8a6);
  color:#fff;font-weight:800;font-size:15px;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(13,148,136,.32);
}
.howto-steps h3{
  font-size:15.5px;font-weight:800;
  margin-bottom:5px;letter-spacing:-.2px;
  color:var(--text);
}
.howto-steps p{
  font-size:13.5px;color:var(--text-secondary);
  line-height:1.65;
}

/* ── Glossary ── */
.glossary-section{padding:48px 0}
.glossary-grid{
  display:grid;grid-template-columns:1fr;gap:12px;
  margin-top:24px;
}
@media(min-width:640px){.glossary-grid{grid-template-columns:1fr 1fr}}
.glossary-item{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:14px 16px;
  border-left:3px solid var(--primary);
  transition:background var(--ease),border-color var(--ease);
}
.glossary-item:hover{
  background:var(--primary-soft);
  border-left-color:var(--accent);
}
.glossary-term{
  font-size:14px;font-weight:800;
  color:var(--primary-dark);
  margin-bottom:5px;letter-spacing:-.2px;
}
.glossary-item p{
  font-size:13px;color:var(--text-secondary);
  line-height:1.6;
}

/* ── Mobile-first refinements ── */
@media(max-width:540px){
  section{padding:36px 0;scroll-margin-top:60px}
  .container{padding:0 16px}
  .editorial{padding:22px 18px}
  .editorial h2{font-size:19px}
  .editorial-cta{padding:12px 20px;font-size:14px;width:100%;justify-content:center}
  .methodology{padding:22px 18px}
  .methodology h2{font-size:20px}
  .express-block{padding:18px}
  .express-block h3{font-size:16px}
  .alt-card,.expert-card{padding:18px}
  .expert-card h3{font-size:16px}
  .alt-card h3{font-size:15px}
  .faq-q{padding:15px 16px;font-size:14px}
  .faq-a-inner{padding:0 16px 16px;font-size:13.5px}
  .reviews-grid{gap:12px}
  .review-card{padding:16px}
  .table-section .section-desc{font-size:13px}
  th,td{padding:10px 12px}
  .quickpick-section,.howto-section,.glossary-section{padding:36px 0}
  .quickpick-card{padding:16px}
  .howto-steps li{padding:14px;gap:12px}
  .howto-num{width:32px;height:32px;font-size:14px}
  .hero{padding:24px 0 28px}
  .hero-v2-side{padding:14px}
  .hero-v2-stat{padding:10px 11px}
  .hero-v2-stat-num{font-size:20px}
  .hero-v2-quick-row{font-size:12.5px}
  .hero-v2-cta-row{flex-direction:column;align-items:stretch}
  .hero-v2-cta,.hero-v2-cta-ghost{justify-content:center;width:100%}
  .author-block{padding:14px;gap:12px}
  .author-photo{width:52px;height:52px}
}

/* Tiny phones */
@media(max-width:380px){
  .hero-v2-stats{grid-template-columns:1fr}
  .hero-v2-quick-tag{display:none}
  .filter-tag{font-size:12px;padding:6px 12px}
  .card-name{font-size:15.5px}
  .card-rank-badge{font-size:10px}
  .hero-v2-status{font-size:11px}
}
