@charset "utf-8";
/* CSS Document */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0d1f38;
  --navy-2:#1a3256;
  --accent:#2453bf;
  --accent-hover:#1b3f99;
  --text:#1a2736;
  --muted:#4a5d72;
  --light:#6b7f94;
  --line:#d5dce6;
  --line-light:#e8edf3;
  --bg:#f5f7fa;
  --card:#ffffff;
  --good:#1a6b42;
  --bad:#b5342e;
  --gold:#c9962e;
  --shadow:0 2px 8px rgba(13,31,56,.05);
  --shadow-md:0 4px 16px rgba(13,31,56,.07);
  --shadow-lg:0 8px 28px rgba(13,31,56,.09);
  --r:4px;
  --r-md:5px;
  --max:1140px;
  --serif:'Source Serif 4',Georgia,'Times New Roman',serif;
  --sans:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.72;font-size:17px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* ── HEADER ── */
.topbar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.topbar-inner{max-width:var(--max);margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;height:58px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--navy);transition:opacity .18s ease}
.logo img {width: 200px;}
.logo:hover{opacity:.85}
.logo-mark{width:32px;height:32px;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:10px;font-weight:800;letter-spacing:.04em;border-radius:3px}
.logo-text{line-height:1.2}
.logo-text small{display:block;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--light);font-weight:700}
.logo-text span{display:block;font-size:16px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.anchor-nav{display:flex;flex-wrap:wrap;gap:0;font-size:13px;font-weight:600;color:var(--muted)}
.anchor-nav a{color:inherit;padding:19px 14px;position:relative;transition:color .18s ease}
.anchor-nav a:after{content:'';position:absolute;left:14px;right:14px;bottom:0;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .2s ease}
.anchor-nav a:hover{color:var(--navy)}
.anchor-nav a:hover:after{transform:scaleX(1)}
@media(max-width:860px){.topbar-inner{height:auto;padding:14px 20px;flex-direction:column;align-items:flex-start;gap:8px}.anchor-nav{gap:0}.anchor-nav a{padding:8px 12px 8px 0}.anchor-nav a:after{display:none}}

/* ── PAGE WRAP ── */
.page-wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
.breadcrumb{font-size:12.5px;color:var(--light);padding:16px 0 4px;font-weight:500}
.breadcrumb a{color:var(--light);transition:color .18s ease}
.breadcrumb a:hover{color:var(--navy)}

/* ── HERO ── */
.hero{padding:32px 0 20px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) 310px;gap:40px;align-items:start}
.hero-sub{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px}
.hero h1{font-family:var(--serif);font-size:clamp(32px,5vw,48px);line-height:1.1;letter-spacing:-.025em;color:var(--navy);margin-bottom:14px;font-weight:800}
.hero-title-sub{font-family:var(--serif);font-size:20px;line-height:1.4;color:var(--muted);font-weight:400;font-style:italic;max-width:680px;margin:0 0 18px}
.updated {font-size: 16px;color: var(--muted);line-height: 1.78;padding: 16px 0;border-top: 1px solid var(--line);}
.disclosure{font-size:13px;color:var(--muted);line-height:1.65;padding:12px 16px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--navy);border-radius:0 var(--r) var(--r) 0;margin-bottom:20px}
.hero-body p{font-size:17px;color:var(--muted);margin-bottom:14px;line-height:1.78}
.hero-body strong{color:var(--navy);font-weight:700}

/* ── HERO SIDEBAR ── */
.hero-side{background:#fff;border:1px solid var(--line);border-top:3px solid var(--navy);border-radius:0 0 var(--r-md) var(--r-md);box-shadow:var(--shadow);padding:22px;position:sticky;top:72px}
.hero-side h3{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--navy);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--line-light)}
.hero-side ul{list-style:none;display:grid;gap:10px;margin-bottom:18px}
.hero-side li{font-size:15px;color:var(--muted);padding-left:16px;position:relative;line-height:1.6}
.hero-side li:before{content:'';position:absolute;left:0;top:.65em;width:6px;height:6px;border-radius:1px;background:var(--accent);transform:translateY(-50%) rotate(45deg)}

/* ── STATS STRIP ── */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin:26px 0 0}
.stat{background:#fff;padding:16px 12px;text-align:center}
.stat-num{display:block;font-family:var(--serif);font-size:22px;font-weight:800;color:var(--navy)}
.stat-label{display:block;margin-top:2px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--light);font-weight:600}
.hero-transition{font-size:16px;color:var(--muted);margin-top:20px;padding-top:16px;border-top:1px solid var(--line-light)}
.decision-strip{margin-top:16px;padding:14px 16px;background:#f0f4f9;border:1px solid var(--line);border-radius:var(--r);font-size:15px;color:var(--muted);line-height:1.7}
.decision-strip strong{color:var(--navy)}

/* ── SECTIONS ── */
.section{padding:48px 0 0}
.section-title{font-family:var(--serif);font-size:26px;font-weight:800;color:var(--navy);margin-bottom:12px;letter-spacing:-.02em}
.section-kicker{font-size:11.5px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.section-kicker:before{content:"";display:block;width:18px;height:2px;background:var(--accent)}

/* ── RANKINGS TABLE ── */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow)}
.rankings-shell{padding:0;position:relative;overflow:hidden}
.rankings-shell:before{content:'';position:absolute;left:0;right:0;top:0;height:3px;background:var(--navy)}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.table-scroll::-webkit-scrollbar{height:6px}
.table-scroll::-webkit-scrollbar-thumb{background:#c7d2de;border-radius:999px}
.mobile-swipe-hint{display:none;font-size:12.5px;color:var(--light);padding:0 20px 14px}
.rankings-table{width:100%;border-collapse:collapse;font-size:15px;min-width:780px}
.rankings-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--light);padding:14px 16px;border-bottom:2px solid var(--line);background:#f8fafb;font-weight:700}
.rankings-table td{padding:14px 16px;border-bottom:1px solid var(--line-light);vertical-align:middle}
.rankings-table tbody tr:nth-child(even) td{background:#fafbfd}
.rankings-table tr:last-child td{border-bottom:none}
.rankings-table tr.winner td{background:#f0f5ff;font-weight:600}
.rankings-table tr.winner td:first-child{border-left:4px solid var(--accent);padding-left:12px}
.rankings-table .rank-num{font-weight:800;color:var(--navy);font-family:var(--serif);font-size:17px}
.rankings-table .score{font-weight:800;color:var(--navy);font-size:17px;font-family:var(--serif)}
.rankings-table .product-link{color:var(--navy);font-weight:700;text-decoration:none;transition:color .15s ease}
.rankings-table .product-link:hover{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(36,83,191,.3)}
.rankings-table .verdict-link{color:var(--muted);font-weight:600;font-size:13.5px;line-height:1.35;text-decoration:underline;text-decoration-color:rgba(74,93,114,.18);text-underline-offset:3px}
.rankings-table .verdict-link:hover{color:var(--accent);text-decoration-color:rgba(36,83,191,.4)}
.rankings-table .avoid{color:var(--bad);font-weight:700}
.rankings-table td:last-child .verdict-link{display:inline-block;max-width:210px}
.table-note{font-size:13px;color:var(--light);padding:14px 20px;border-top:1px solid var(--line-light)}

/* ── PRODUCT CARDS ── */
.comparison-stack{display:grid;gap:20px}
.product-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow);overflow:hidden;position:relative}
.product-card.winner{border-color:var(--accent);border-left:4px solid var(--accent);box-shadow:var(--shadow-md)}
.card-inner{padding:26px 28px}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px}

/* Badges */
.card-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;padding:7px 14px;border-radius:var(--r);margin-bottom:12px;line-height:1}
.badge-winner{background:var(--accent);color:#fff;font-size:11.5px;padding:8px 16px;letter-spacing:.12em;position:relative}
.badge-winner:before{content:"★";font-size:10px;margin-right:3px}
.badge-niche{background:#edf1f7;color:var(--navy-2);font-size:11px}

/* Score box */
.score-box{min-width:90px;border:1px solid var(--line);border-radius:var(--r);padding:10px 12px;text-align:center;background:#fff;position:relative}
.score-box:before{content:'';position:absolute;left:0;right:0;top:0;height:3px;border-radius:var(--r) var(--r) 0 0;background:var(--accent)}
.score-box strong{display:block;font-family:var(--serif);font-size:28px;line-height:1;color:var(--navy);font-weight:800}
.score-box span{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--light);font-weight:700}

.card-name{font-family:var(--serif);font-size:26px;font-weight:800;color:var(--navy);letter-spacing:-.015em}
.secondary .card-name{font-size:22px}
.card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:8px 0 12px}
.stars{font-size:17px;color:#d4a22c;letter-spacing:1px}
.review-count{font-size:13px;color:var(--muted);font-weight:600;padding:5px 10px;border-radius:var(--r);background:#f3f6fa;border:1px solid var(--line-light)}
.key-specs{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin:12px 0 8px;padding:10px 0;border-top:1px solid var(--line-light);border-bottom:1px solid var(--line-light)}
.key-spec{font-size:13px;font-weight:700;color:var(--navy-2);letter-spacing:.02em;position:relative;padding:0 14px 0 0;margin-right:14px}
.key-spec:last-child{margin-right:0;padding-right:0}
.key-spec:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:14px;background:var(--line)}
.key-spec b{color:var(--navy);font-weight:800}
.card-best-for{font-size:16px;color:var(--muted);margin-bottom:14px;line-height:1.7}
.card-best-for strong{color:var(--text)}
.product-layout{display:grid;grid-template-columns:250px 1fr;gap:22px;align-items:start}
.product-image{aspect-ratio:1/1;background:linear-gradient(180deg,#f5f8fb,#eaeff5);border:1px solid var(--line);border-radius:var(--r);display:grid;place-items:center;color:var(--light);font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;position:relative;overflow:hidden}
/*.product-image:after{content:'';position:absolute;inset:8px;border:1px dashed #c9d4e1;border-radius:3px}*/
.product-card.winner .product-image{border-color:#b8c8e0}

/* Pros/Cons */
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:16px}
.pros-cons h4{font-size:12px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-weight:700}
.pros h4{color:var(--good)}
.cons h4{color:var(--bad)}
.pros-cons ul{list-style:none;display:grid;gap:7px}
.pros-cons li{font-size:14.5px;color:var(--muted);line-height:1.65;padding-left:16px;position:relative}
.pros li:before,.cons li:before{position:absolute;left:0;top:0;font-weight:800;font-size:14px;line-height:1.65}
.pros li:before{content:'+';color:var(--good)}
.cons li:before{content:'–';color:var(--bad)}

/* Verdict */
.card-verdict{font-size:16px;color:var(--muted);line-height:1.78;padding:16px 0;border-top:1px solid var(--line-light)}
.card-verdict strong{color:var(--navy)}
.punchline{display:block;margin-top:12px;padding:11px 14px;background:#f2f6fb;border:1px solid #d7e1ee;border-left:3px solid var(--accent);border-radius:0 var(--r) var(--r) 0;font-size:14.5px;font-weight:700;color:var(--navy)}

/* Card CTAs */
.card-cta{display:flex;align-items:center;gap:14px;padding-top:16px;border-top:1px solid var(--line-light)}
.btn-card,.btn-primary,.btn-card-secondary,.btn-sm{display:inline-flex;align-items:center;justify-content:center;font-weight:700;text-decoration:none;border-radius:var(--r);transition:background .16s ease, box-shadow .16s ease, transform .12s ease}
.btn-card,.btn-primary{background:var(--accent);color:#fff}
.btn-card{min-height:50px;padding:0 24px;font-size:15px;box-shadow:0 2px 8px rgba(36,83,191,.16)}
.btn-card:hover,.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 14px rgba(36,83,191,.24);transform:translateY(-1px)}
.btn-card-secondary{min-height:44px;padding:0 18px;border:1px solid var(--line);color:var(--navy-2);background:#fff;font-size:14px}
.btn-card-secondary:hover{border-color:#9fb0c3;color:var(--navy);background:#f8fafe}
.card-cta-sub{font-size:12.5px;color:var(--light);font-weight:600}

/* Reject block */
.reject-block{padding:20px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow)}
.reject-block h4{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--light);margin-bottom:10px;font-weight:700}
.reject-item{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:8px}
.reject-item:last-child{margin-bottom:0}
.reject-item strong{color:var(--text)}
.avoid-tag{color:var(--bad);font-weight:800}

/* CTA inline */
.cta-inline{text-align:center;padding:20px 0}
.cta-inline a{font-size:15px;font-weight:700;color:var(--accent);transition:color .15s ease}
.cta-inline a:hover{color:var(--accent-hover)}

/* ── CTA BLOCK ── */
.cta-block{background:var(--navy);color:#fff;border-radius:var(--r-md);padding:38px 28px;text-align:center;box-shadow:var(--shadow-lg);margin:42px 0;position:relative;overflow:hidden}
.cta-block:before{content:'';position:absolute;left:0;right:0;top:0;height:3px;background:var(--accent)}
.cta-label{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:#a3b5cc;margin-bottom:8px;font-weight:700}
.cta-product{font-family:var(--serif);font-size:28px;font-weight:800;margin-bottom:6px}
.cta-offer{font-size:17px;font-weight:600;color:#d5e0ef;margin-bottom:6px}
.cta-specs{font-size:13.5px;color:#9aadc4;margin-bottom:22px;font-weight:500}
.btn-primary{padding:15px 38px;font-size:15.5px;box-shadow:0 4px 16px rgba(36,83,191,.28);letter-spacing:.01em}
.cta-trust{font-size:12.5px;color:#8fa2ba;margin-top:14px;font-weight:600}

/* ── LONG REVIEW ── */
.long-review h2,.compact-section h2{font-family:var(--serif);font-size:24px;font-weight:800;color:var(--navy);margin-bottom:8px;letter-spacing:-.015em}
.skip-link{font-size:14px;color:var(--accent);font-weight:600;display:inline-block;margin-bottom:20px;transition:color .15s ease}
.skip-link:hover{color:var(--accent-hover)}
.long-review h3{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--navy);margin-top:26px;margin-bottom:8px}
.long-review p{font-size:16px;color:var(--muted);margin-bottom:14px;line-height:1.78}
.timeline{margin:16px 0;padding-left:20px;border-left:3px solid var(--navy)}
.timeline-item{padding:7px 0 7px 14px;font-size:15px;color:var(--muted);line-height:1.7}
.timeline-item strong{color:var(--navy)}
.timeline-note{font-size:15px;font-weight:700;color:var(--navy);margin-top:8px;padding-left:14px}

/* ── SPLIT COMPACT ── */
.split-compact{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.compact-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:22px 24px;box-shadow:var(--shadow)}
.warning-compact,.faq-compact,.method-compact{padding:12px 0;border-bottom:1px solid var(--line-light)}
.warning-compact:last-of-type,.faq-compact:last-of-type,.method-compact:last-of-type{border-bottom:none}
.warning-compact strong,.method-compact strong{display:block;font-size:15px;color:var(--navy);font-weight:700;margin-bottom:4px}
.warning-compact span,.method-compact span{display:block;font-size:14.5px;color:var(--muted);line-height:1.7}
.faq-compact dt{display:block;font-size:15px;color:var(--navy);font-weight:700;margin-bottom:4px}
.faq-compact dd{font-size:14.5px;color:var(--muted);line-height:1.7}
.method-compact{position:relative;padding-left:16px}
.method-compact:before{content:"";position:absolute;left:0;top:18px;width:6px;height:6px;border-radius:1px;background:var(--accent);transform:rotate(45deg)}
.method-compact strong{display:inline-block;margin-bottom:4px}
.method-compact span{padding-left:0}
.section-note{font-size:12px;color:var(--light);font-style:italic;margin-top:10px;padding-top:10px;border-top:1px solid var(--line-light)}

/* ── FAQ ── */
.faq-compact a{color:var(--accent);font-weight:600;transition:color .15s ease}
.faq-compact a:hover{color:var(--accent-hover)}

/* ── CTA FINAL ── */
.cta-final{text-align:center;padding:44px 0;border-top:1px solid var(--line)}
.final-lead{font-size:15px;color:var(--muted);margin-bottom:6px}
.final-summary{font-size:16px;color:var(--muted);max-width:680px;margin:0 auto 22px;line-height:1.78}
.trust-badges{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:16px;font-size:13px;color:var(--light);font-weight:700}
.trust-badges span{display:flex;align-items:center;gap:5px}
.trust-badges span:before{content:"✓";font-size:12px;color:var(--good);font-weight:800}

/* ── AUTHOR ── */
.author-block{display:flex;gap:16px;align-items:center;padding:28px 0;border-top:1px solid var(--line);margin-top:36px}
.author-avatar{width:46px;height:46px;border-radius:50%;background:#e4e9ef;border:1px solid var(--line);flex-shrink:0;border-radius: 50%;overflow: hidden;}
.author-name{font-size:14px;font-weight:700;color:var(--navy)}
.author-title{font-size:12px;color:var(--light);font-weight:500}
.author-bio{font-size:11.5px;color:#8a96a6;margin-top:2px;line-height:1.6}

/* ── STICKY CTA ── */
.sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;background:rgba(13,31,56,.97);padding:10px 16px;z-index:100;box-shadow:0 -4px 16px rgba(13,31,56,.15);backdrop-filter:blur(8px)}
.sticky-cta-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:14px}
.sticky-cta-text{color:#fff;font-size:14px;font-weight:700}
.sticky-cta-text span{display:block;font-size:11.5px;color:#a8b9ce;font-weight:500}
.btn-sm{background:var(--accent);color:#fff;font-size:13.5px;font-weight:700;padding:10px 18px;border-radius:var(--r);white-space:nowrap;box-shadow:0 2px 8px rgba(36,83,191,.2)}
.btn-sm:hover{background:var(--accent-hover)}

/* ── FOOTER ── */
.full-footer{width:100%;background:#0c1826;color:#b5c1d1;margin-top:44px}
.full-footer a{color:#cdd7e5;text-decoration:none;transition:color .15s ease}
.full-footer a:hover{color:#fff}
.full-footer-inner{max-width:var(--max);margin:0 auto;padding:0 28px}
.footer-top{display:flex;justify-content:space-between;gap:28px;padding:30px 0 22px;border-bottom:1px solid rgba(255,255,255,.1);align-items:flex-start}
.footer-brand{max-width:420px}
.footer-brand-title{font-family:var(--serif);font-size:15px;font-weight:700;color:#fff;margin-bottom:5px}
.footer-brand-copy{font-size:13px;line-height:1.7;color:#8d9db2}
.footer-links{display:flex;gap:20px;flex-wrap:wrap;align-content:flex-start;font-size:13px;font-weight:600}
.footer-bottom{padding:20px 0 28px}
.footer-copy{font-size:11.5px;color:#6e8099;margin-bottom:12px}
.footer-disclosures{display:grid;gap:10px}
.footer-disclosure-item{font-size:11.5px;line-height:1.7;color:#8d9db2}
.footer-disclosure-item strong{color:#c8d2e0}

/* ── RESPONSIVE ── */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-side{position:static}
  .split-compact{grid-template-columns:1fr}
  .product-layout{grid-template-columns:180px 1fr}
}
@media(max-width:760px){
  body{font-size:16px}
  .page-wrap{padding:0 18px}
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .table-scroll{margin:0;padding-bottom:4px}
  .mobile-swipe-hint{display:block}
  .product-layout{grid-template-columns:1fr}
  .product-image{max-width:200px}
  .card-top{flex-direction:column}
  .card-inner{padding:20px 18px}
  .pros-cons{grid-template-columns:1fr}
  .card-cta{flex-direction:column;align-items:stretch}
  .sticky-cta{display:block}
  .full-footer-inner{padding:0 18px}
  .footer-top{flex-direction:column;padding:24px 0 18px}
  .footer-links{gap:14px}
  .footer-bottom{padding:16px 0 90px}
  .hero h1{font-size:30px}
  .hero-title-sub{font-size:18px}
  .cta-product{font-size:24px}
  .section-title{font-size:22px}
  .card-name{font-size:22px}
}