
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--ink:#0f172a;--ink-muted:#475569;--ink-light:#94a3b8;--surface:#fff;--surface-alt:#f8fafc;--border:#e2e8f0;--accent:#1d4ed8;--accent-dark:#1e40af;--accent-visited:#4338ca;--green:#16a34a;--amber:#b45309;--red:#dc2626;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--shadow-sm:0 1px 4px rgba(15,23,42,.06),0 4px 12px rgba(15,23,42,.04);--shadow-md:0 4px 16px rgba(15,23,42,.08),0 10px 30px rgba(15,23,42,.05);--font-body:'Georgia','Times New Roman',serif;--font-ui:system-ui,-apple-system,'Segoe UI',sans-serif}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--surface);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none;font-weight:600}
a:hover{color:var(--accent-dark);text-decoration:underline}
a:visited{color:var(--accent-visited)}
img{max-width:100%;height:auto}
h1,h2,h3,h4{font-family:var(--font-ui);font-weight:800;line-height:1.25;color:var(--ink)}
h1{font-size:clamp(1.55rem,3.5vw,2.1rem);margin-bottom:1rem}
h2{font-size:clamp(1.2rem,2.5vw,1.55rem);margin-bottom:.75rem}
h3{font-size:1.1rem;margin-bottom:.5rem}
h4{font-size:.95rem;margin-bottom:.4rem}
p{max-width:72ch;margin-bottom:.85rem}
ul,ol{padding-left:1.3rem;margin-bottom:.85rem}
li{margin-bottom:.3rem}
.gtg-container{max-width:860px;margin:0 auto;padding:0 1.25rem}
.gtg-page{padding-bottom:4rem}
.gtg-header{background:var(--ink);position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.06)}
.gtg-header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;gap:1rem}
.gtg-brand{display:flex;align-items:center;gap:.5rem}
.gtg-brand-name{font-family:var(--font-ui);font-weight:900;font-size:1.15rem;color:#fff;letter-spacing:-.02em}
.gtg-brand-name span{color:#60a5fa}
.gtg-nav-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.gtg-nav-links a{font-family:var(--font-ui);font-size:.82rem;font-weight:600;color:rgba(255,255,255,.75);letter-spacing:.02em}
.gtg-nav-links a:hover{color:#fff;text-decoration:none}
.breadcrumbs{font-family:var(--font-ui);font-size:.82rem;color:var(--ink-muted);margin:1.1rem 0}
.breadcrumbs a{font-weight:500;color:var(--ink-muted)}
.breadcrumbs a:hover{color:var(--accent)}
.gtg-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.4rem 1.5rem;margin:1.25rem 0;box-shadow:var(--shadow-sm)}
.gtg-card+.gtg-card{margin-top:1.25rem}
.gtg-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 100%);border-radius:var(--radius-lg);padding:2rem 1.75rem;color:#fff;margin:1rem 0 1.25rem;position:relative;overflow:hidden}
.gtg-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(96,165,250,.15) 0%,transparent 60%);pointer-events:none}
.gtg-eyebrow{font-family:var(--font-ui);font-size:.78rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#60a5fa;margin-bottom:.6rem}
.gtg-hero h1{color:#fff;font-size:clamp(1.45rem,3.2vw,1.95rem)}
.gtg-hero .lead{color:rgba(255,255,255,.82);font-size:1.05rem;max-width:65ch;margin-top:.5rem}
.verdict-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:.75rem;margin-top:1.4rem}
.verdict-cell{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);padding:.8rem 1rem}
.verdict-cell .label{font-family:var(--font-ui);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#93c5fd;margin-bottom:.25rem}
.verdict-cell .value{font-family:var(--font-ui);font-size:.92rem;font-weight:700;color:#fff}
.hero-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem}
.gtg-cta-button{display:inline-block;font-family:var(--font-ui);font-weight:700;font-size:.88rem;padding:.65rem 1.2rem;background:#1d4ed8;color:#fff;border-radius:999px;border:none;cursor:pointer;transition:background .15s ease,transform .1s ease}
.gtg-cta-button:hover{background:#1d4ed8;transform:translateY(-1px);color:#fff;text-decoration:none}
.gtg-cta-button--ghost{background:transparent;color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.25)}
.gtg-cta-button--ghost:hover{background:rgba(255,255,255,.08);color:#fff}
.status-bar{font-family:var(--font-ui);font-size:.82rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:.6rem 1rem;color:#166534;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.status-bar .dot{width:8px;height:8px;border-radius:50%;background:#16a34a;flex-shrink:0}
.status-bar.amber{background:#fffbeb;border-color:#fde68a;color:#92400e}
.status-bar.amber .dot{background:#f59e0b}
.tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin:1rem 0}
.tier-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem 1.1rem;transition:box-shadow .15s ease}
.tier-card:hover{box-shadow:var(--shadow-md)}
.tier-card .tier-badge{font-family:var(--font-ui);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;display:inline-block;padding:.2rem .55rem;border-radius:999px;margin-bottom:.55rem}
.badge-min{background:#fef3c7;color:#92400e}
.badge-rec{background:#dbeafe;color:#1e40af}
.badge-pro{background:#ede9fe;color:#5b21b6}
.badge-max{background:#fce7f3;color:#831843}
.badge-new{background:#dcfce7;color:#166534}
.picks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.1rem;margin:1.1rem 0}
.pick-card{border:1px solid var(--border);border-radius:var(--radius-md);padding:1.2rem 1.25rem;position:relative;transition:box-shadow .15s ease,transform .12s ease}
.pick-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.pick-card.best{border-color:#1d4ed8;border-width:2px}
.pick-card .pick-label{font-family:var(--font-ui);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:.4rem}
.pick-card.new-gen .pick-label{color:#059669}
.pick-card .pick-name{font-family:var(--font-ui);font-weight:800;font-size:1.05rem;margin-bottom:.25rem}
.pick-card .pick-sub{font-family:var(--font-ui);font-size:.82rem;color:var(--ink-muted);margin-bottom:.7rem}
.pick-card .pick-specs{font-family:var(--font-ui);font-size:.8rem;background:var(--surface-alt);border-radius:8px;padding:.5rem .7rem;margin-bottom:.7rem}
.pick-card .pick-specs span{display:block;color:var(--ink-muted);line-height:1.6}
.pick-card .pick-specs strong{color:var(--ink)}
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:.6rem 0}
.pros-cons .pro,.pros-cons .con{font-family:var(--font-ui);font-size:.78rem;border-radius:8px;padding:.45rem .6rem}
.pros-cons .pro{background:#f0fdf4;color:#166534}
.pros-cons .con{background:#fef2f2;color:#991b1b}
.pros-cons .pro::before{content:'✓  '}
.pros-cons .con::before{content:'✗  '}
.pick-price{font-family:var(--font-ui);font-weight:800;font-size:.95rem;color:var(--ink);margin-bottom:.7rem}
.pick-price .range{font-weight:500;color:var(--ink-muted);font-size:.82rem;margin-left:.3rem}
.gtg-table-scroll{overflow-x:auto;margin:1rem 0}
.gtg-table{width:100%;border-collapse:collapse;min-width:560px;font-family:var(--font-ui);font-size:.85rem}
.gtg-table th{background:var(--ink);color:#fff;padding:.7rem .9rem;text-align:left;font-weight:700;white-space:nowrap}
.gtg-table th:first-child{border-radius:8px 0 0 0}
.gtg-table th:last-child{border-radius:0 8px 0 0}
.gtg-table td{padding:.65rem .9rem;border-bottom:1px solid var(--border);vertical-align:top}
.gtg-table tr:last-child td{border-bottom:none}
.gtg-table tr:nth-child(even) td{background:var(--surface-alt)}
.gtg-table .tier-new{font-weight:700;color:#059669}
.gtg-table .tier-rec{font-weight:700;color:#1d4ed8}
.gtg-table .tier-val{color:var(--ink-muted)}
.perf-bar{display:flex;align-items:center;gap:.4rem}
.bar-track{flex:1;height:6px;background:#e2e8f0;border-radius:999px;min-width:60px}
.bar-fill{height:6px;border-radius:999px;background:#1d4ed8}
.bar-fill.green{background:#16a34a}
.bar-fill.gold{background:#d97706}
.advice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1rem 0}
.advice-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem 1.1rem}
.advice-card .icon{font-size:1.4rem;margin-bottom:.4rem}
.advice-card h4{margin-bottom:.35rem}
.advice-card p{font-size:.88rem;color:var(--ink-muted);margin-bottom:0}
.faq-list details{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:.7rem;padding:.9rem 1rem}
.faq-list summary{cursor:pointer;font-family:var(--font-ui);font-weight:700;font-size:.95rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:'+';font-size:1.2rem;color:var(--accent);flex-shrink:0;margin-left:.75rem}
.faq-list details[open] summary::after{content:'−'}
.faq-list details p{margin-top:.7rem;font-size:.92rem;margin-bottom:0}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.8rem;margin:1rem 0}
.related-link{display:block;font-family:var(--font-ui);font-size:.88rem;font-weight:600;padding:.8rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);transition:background .12s ease,border-color .12s ease}
.related-link:hover{background:#eff6ff;border-color:#93c5fd;text-decoration:none}
.related-link .rel-icon{display:block;font-size:.7rem;font-weight:400;color:var(--ink-muted);margin-bottom:.2rem}
.page-meta{font-family:var(--font-ui);font-size:.8rem;color:var(--ink-light);border-top:1px solid var(--border);padding-top:1rem;margin-top:1.5rem}
.gtg-footer{background:transparent;color:#475569;font-family:var(--font-ui);font-size:.85rem;padding:1.25rem 1.25rem;text-align:center;margin-top:3rem;border-top:1px solid rgba(15,23,42,.08)}.gtg-footer .gtg-muted,.gtg-footer .gtg-footer-editorial-note,.gtg-footer-utility a{color:#475569}.gtg-footer-utility{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem .85rem;margin-top:.85rem}body.section-laptops .gtg-hero h1,body.section-laptops .gtg-hero h2,body.section-laptops .gtg-hero p,body.section-laptops .gtg-hero li,body.section-laptops .gtg-hero strong,body.section-laptops .gtg-hero .gtg-eyebrow,body.section-laptops .gtg-hero .lead{color:#0f172a !important}body.section-laptops .gtg-hero p,body.section-laptops .gtg-hero li,body.section-laptops .gtg-hero .lead{color:#334155 !important}body.section-laptops .gtg-hero h1{color:#0f172a !important}
.gtg-footer a{color:rgba(255,255,255,.6)}
.gtg-footer a:hover{color:#fff}
.gtg-footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:.5rem}
@media(max-width:640px){.picks-grid,.tier-grid,.verdict-grid{grid-template-columns:1fr}.pros-cons{grid-template-columns:1fr}.gtg-nav-links{display:none}.gtg-hero{padding:1.5rem 1.2rem}}

/* ── Core CSS conflict overrides ──────────────────────────────────────
   The site core CSS (gtg-site-core-v4823.css?v=20260519) applies !important color
   overrides to h1/h2/h3 and links on page-article pages that clash with
   this page's own colour scheme. Fix with higher-specificity rules.
──────────────────────────────────────────────────────────────────── */

/* Hero: h1 must be white on the dark gradient background */
.gtg-hero h1,
.gtg-hero h2,
.gtg-hero h3 { color: #fff !important; }

/* Hero: eyebrow kicker stays blue-light */
.gtg-hero .gtg-eyebrow { color: #93c5fd !important; }

/* Hero: body copy stays white-ish */
.gtg-hero p,
.gtg-hero .lead { color: rgba(255,255,255,.88) !important; }

/* Hero: verdict chip labels */
.verdict-cell .label { color: #93c5fd !important; }
.verdict-cell .value { color: #fff !important; }

/* Buttons: white text must survive link color overrides */
a.gtg-cta-button,
a.gtg-cta-button:visited,
a.gtg-cta-button:hover { color: #fff !important; text-decoration: none !important; }

/* Ghost button variant */
a.gtg-cta-button.gtg-cta-button--ghost { color: rgba(255,255,255,.88) !important; }
a.gtg-cta-button.gtg-cta-button--ghost:hover { color: #fff !important; }

/* Page h1 outside hero (breadcrumb area / above hero) */
body.page-article h1:not(.gtg-hero h1) { color: var(--ink, #0f172a) !important; }

/* Tier badge labels in pick cards need their background colors */
.verdict-cell { color: #fff !important; }

/* v116 (audit P1): pick-card jump-link buttons rendered at 16px tall on
   mobile (legacy core CSS forces display:inline + padding:0 via its
   a[data-retailer]:not(.gtg-btn) rule, which also catches these). Force
   display + padding with !important so min-height can take effect. These
   are in-page anchor links styled as buttons, not affiliate CTAs. */
@media (max-width:768px){
  .pick-card a.gtg-cta-button,
  .pick-card a.gtg-cta-button--ghost{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    min-height:44px !important;
    padding:11px 18px !important;
    box-sizing:border-box;
  }
}
