/* Components — all styles use tokens.css variables */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-display);font-size:var(--f-base);line-height:var(--lh-normal);color:var(--ink);background:var(--bg)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--container-pad)}
.skip{position:absolute;left:-9999px}.skip:focus{left:var(--s-4);top:var(--s-4);background:var(--ink);color:#fff;padding:var(--s-2) var(--s-4);z-index:var(--z-overlay)}

/* topbar */
.topbar{background:var(--ink);color:#fff;font-size:var(--f-xs);padding:var(--s-2) 0;font-family:var(--font-mono);letter-spacing:var(--track-wide)}
.topbar .container{display:flex;justify-content:space-between;gap:var(--s-4)}
.topbar .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ok);margin-right:var(--s-1)}

/* header */
header{background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:var(--z-header)}
.hdr{display:flex;align-items:center;justify-content:space-between;padding:var(--s-3) 0;gap:var(--s-6)}
.logo{font-weight:900;font-size:1.35rem;letter-spacing:var(--track-snug);display:flex;align-items:center;gap:var(--s-2)}
.logo span{background:var(--accent);color:#fff;padding:2px var(--s-2);border-radius:var(--r-sm);font-size:.72rem;font-weight:800;letter-spacing:var(--track-wide)}
nav ul{display:flex;gap:var(--s-7);list-style:none;font-weight:600;font-size:.92rem}
nav a:hover{color:var(--accent)}
.hdr-cta{background:var(--accent);color:#fff;padding:var(--s-2) var(--s-4);border-radius:var(--r);font-weight:700;font-size:.85rem}
@media(max-width:820px){nav{display:none}}

/* breadcrumbs */
.crumbs{padding:var(--s-4) 0 0;font-size:var(--f-xs);color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wider)}
.crumbs a:hover{color:var(--accent)}
.crumbs span{color:var(--line);margin:0 var(--s-2)}

/* hero */
.hero{padding:var(--hero-top) 0 var(--hero-bot);border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--gap-hero);align-items:start}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:var(--s-6)}}
.eyebrow{display:inline-flex;align-items:center;gap:var(--s-2);background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:var(--track-wider);padding:var(--s-1) var(--s-3);border-radius:var(--r-full);border:1px solid var(--accent-line);margin-bottom:var(--s-4)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
h1{font-size:var(--f-3xl);font-weight:900;letter-spacing:var(--track-tight);line-height:var(--lh-tight);margin-bottom:var(--s-4)}
h1 em{font-style:normal;color:var(--accent);position:relative}
h1 em::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:10px;background:var(--gold);z-index:-1;opacity:.5}
.lede{font-size:var(--f-lg);color:var(--ink-2);max-width:54ch;margin-bottom:var(--s-6);line-height:1.45}

/* trust bar */
.trust-row{display:flex;flex-wrap:wrap;gap:var(--s-5);padding:var(--s-4) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:var(--s-6);font-size:var(--f-xs);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wide);color:var(--ink-2)}
.trust-row b{color:var(--ink);font-weight:700}
.verified{display:inline-flex;align-items:center;gap:var(--s-1)}
.verified::before{content:"✓";color:var(--ok);font-weight:900}

/* decision card */
.decision{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:var(--card-pad);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.decision::before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:var(--accent);border-radius:50%;filter:blur(80px);opacity:.5}
.decision-label{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:var(--track-wider);color:var(--gold);margin-bottom:var(--s-2);position:relative}
.decision h2{font-size:1.5rem;font-weight:900;letter-spacing:var(--track-snug);line-height:1.1;margin-bottom:var(--s-1);position:relative}
.decision .op-sub{font-size:var(--f-sm);color:var(--muted-2);margin-bottom:var(--s-4);position:relative}
.rating-row{display:flex;align-items:center;gap:var(--s-3);margin-bottom:var(--s-4);position:relative}
.stars{color:var(--gold);font-size:1.1rem;letter-spacing:2px}
.rating-num{font-family:var(--font-mono);font-weight:700;font-size:1rem}
.rating-num small{color:var(--muted-2);font-weight:500}
.payid-chip{display:inline-flex;align-items:center;gap:var(--s-1);background:var(--ok);color:#fff;padding:var(--s-1) var(--s-3);border-radius:var(--r-sm);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:var(--track-wide)}
.bonus{background:var(--ink-2);border:1px solid var(--ink-3);border-radius:var(--r);padding:var(--s-3);margin-bottom:var(--s-4);position:relative}
.bonus-label{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:var(--track-wider);color:var(--gold);margin-bottom:var(--s-1)}
.bonus-val{font-size:1.35rem;font-weight:900;letter-spacing:var(--track-snug);line-height:1.1}
.bonus-small{font-size:.75rem;color:var(--muted-2);margin-top:var(--s-1)}
.cta{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);background:var(--accent);color:#fff;padding:var(--s-4);border-radius:var(--r);font-weight:800;font-size:.95rem;text-transform:uppercase;letter-spacing:var(--track-wide);width:100%;position:relative;transition:transform var(--dur-fast) var(--ease)}
.cta:hover{transform:translateY(-1px)}
.cta::after{content:"→";font-weight:400}
.decision-foot{display:flex;justify-content:space-between;font-size:.7rem;font-family:var(--font-mono);color:var(--muted-2);margin-top:var(--s-3);text-transform:uppercase;letter-spacing:var(--track-wide);position:relative}

/* sections */
.section{padding:var(--section-y) 0;border-bottom:1px solid var(--line)}
.section-alt{background:var(--surface-alt)}
.section-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:var(--s-5);gap:var(--s-6);flex-wrap:wrap}
.section h2{font-size:var(--f-2xl);font-weight:900;letter-spacing:var(--track-tight);line-height:1}
.section-sub{font-size:var(--f-sm);color:var(--ink-2);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wide)}
.route-grid,.signal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-4)}
.route-card,.signal-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm)}
.route-step{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--ink);color:#fff;font-family:var(--font-mono);font-size:.8rem;margin-bottom:var(--s-3)}
.route-card h3,.signal-card h3{font-size:1.05rem;font-weight:800;margin-bottom:var(--s-2)}
.route-card p,.signal-card p{color:var(--ink-2);line-height:1.6;margin-bottom:var(--s-3)}
.route-card a{color:var(--accent);font-weight:700}
.route-card a:hover{text-decoration:underline}
@media(max-width:980px){.route-grid,.signal-grid{grid-template-columns:1fr}}

/* comparison table */
.table-wrap{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--bg);box-shadow:var(--shadow-sm)}
.row{display:grid;grid-template-columns:48px 1.5fr 1fr 1.8fr .8fr 1fr;gap:var(--s-3);padding:var(--row-pad) var(--s-4);align-items:center;border-bottom:1px solid var(--line);transition:background var(--dur-fast) var(--ease)}
.row:last-child{border-bottom:0}
.row:hover{background:var(--surface-alt)}
.row.head{background:var(--ink);color:#fff;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:var(--track-wider);padding:var(--s-3) var(--s-4)}
.rank{font-family:var(--font-mono);font-weight:800;font-size:1.1rem;color:var(--muted)}
.row.top .rank{color:var(--accent)}
.op{display:flex;align-items:center;gap:var(--s-3);min-width:0}
.op-logo{display:none}
.op-name{font-weight:800;font-size:.95rem;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.op-meta{font-size:.72rem;color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wide)}
.cell-rating strong{font-family:var(--font-mono);font-size:1.05rem;font-weight:800;display:block}
.cell-rating small{color:var(--muted);font-size:.7rem;font-family:var(--font-mono)}
.cell-bonus{font-weight:700;font-size:.92rem;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;min-width:0}
.cell-bonus small{display:block;color:var(--muted);font-weight:500;font-size:.72rem;margin-top:2px}
.yes{background:var(--ok);color:#fff;font-size:.7rem;font-weight:800;padding:var(--s-1) var(--s-3);border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:var(--track-wide);display:inline-block}
.row .cta{padding:var(--s-3) var(--s-3);font-size:.75rem;width:auto}
@media(max-width:900px){
  .row{grid-template-columns:40px minmax(0,1fr) auto auto;grid-template-areas:"rank op rating cta" "rank bonus rating cta";gap:var(--s-2) var(--s-3);padding:var(--s-4)}
  .row.head{display:none}
  .row .rank{grid-area:rank}
  .row .op{grid-area:op}
  .row .op-meta{display:none}
  .row .cell-bonus{grid-area:bonus;display:block;font-size:.78rem;font-weight:700;color:var(--ink-2);line-height:1.25;min-width:0}
  .row .cell-bonus small{display:none}
  .row .cell-rating{grid-area:rating;display:flex;align-items:center;gap:var(--s-2);justify-self:end}
  .row .cell-rating strong{display:inline;font-size:.85rem}
  .row .cell-rating .stars{font-size:.82rem;letter-spacing:1px}
  .row .cell-payid{display:none}
  .row .cta{grid-area:cta;justify-self:end}
}

/* faq */
.faq details{border-bottom:1px solid var(--line);padding:var(--s-4) 0}
.faq summary{font-size:var(--f-lg);font-weight:800;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:var(--s-4);letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.8rem;font-weight:400;color:var(--accent);transition:transform var(--dur) var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details[open] p{margin-top:var(--s-3);color:var(--ink-2);max-width:70ch;line-height:var(--lh-loose)}

/* author */
.author{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-4);background:var(--surface-alt);border:1px solid var(--line);border-radius:var(--r-lg);margin-top:var(--s-8);font-size:var(--f-sm)}
.author-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--gold));flex-shrink:0}
.author b{display:block;font-weight:800;font-size:.95rem}
.author span{color:var(--ink-2);font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:var(--track-wide)}

/* disclaimer + footer */
.disclaimer{background:var(--ink);color:var(--muted-2);padding:var(--s-10) 0;font-size:var(--f-sm)}
.disclaimer-bar{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4);border:1px solid var(--ink-3);border-radius:var(--r);margin-bottom:var(--s-7)}
.eighteen{width:52px;height:52px;border:3px solid var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;color:var(--accent);flex-shrink:0}
.disclaimer-bar p{color:#ccc;line-height:1.5}
.disclaimer-bar a{color:var(--gold);text-decoration:underline}
footer{background:var(--ink);color:var(--muted-2);padding:var(--s-6) 0;border-top:1px solid var(--ink-2);font-size:.78rem;font-family:var(--font-mono);letter-spacing:var(--track-wide)}
.footer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-6);padding-bottom:var(--s-6)}
.footer-col h3{color:#fff;font-size:.85rem;text-transform:uppercase;margin-bottom:var(--s-3)}
.footer-col ul{list-style:none;display:grid;gap:var(--s-2)}
.footer-col a,.footer-col span{color:var(--muted-2);font-size:.78rem}
.footer-col a:hover{color:var(--gold)}
.footer-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--ink-2);text-transform:uppercase}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr}}

.explain-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm)}
.explain-card p{color:var(--ink-2);line-height:1.7;max-width:72ch}
.resource-links{display:flex;gap:var(--s-4);flex-wrap:wrap;margin-top:var(--s-4)}
.resource-links a,.text-link{color:var(--accent);font-weight:700}
.resource-links a:hover,.text-link:hover{text-decoration:underline}
.latest-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-4)}
.latest-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm)}
.latest-card h3{font-size:1rem;font-weight:800;margin-bottom:var(--s-2)}
.latest-card p{color:var(--ink-2);line-height:1.6;margin-bottom:var(--s-3)}
@media(max-width:980px){.latest-grid{grid-template-columns:1fr}}

/* article layouts */
.hero-review,.hero-article{padding-top:calc(var(--hero-top) * .78)}
.chip-row{display:flex;flex-wrap:wrap;gap:var(--s-2);margin-top:var(--s-4)}
.chip{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-full);padding:var(--s-1) var(--s-3);font-size:.76rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wide);color:var(--muted)}
.article-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.7fr);gap:var(--s-7);align-items:start}
.article-card{background:var(--surface-alt);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.2rem,2vw,2rem);box-shadow:var(--shadow-sm)}
.article-rail{display:grid;gap:var(--s-4);position:sticky;top:96px}
.rail-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s-4);box-shadow:var(--shadow-sm)}
.rail-card h3{font-size:1rem;font-weight:800;letter-spacing:var(--track-snug);margin-bottom:var(--s-3)}
.fact-list,.link-list{list-style:none;display:grid;gap:var(--s-3)}
.fact-list li,.link-list li{display:grid;gap:var(--s-1);font-size:.92rem;line-height:1.45}
.fact-list strong{font-size:.72rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wide);color:var(--muted)}
.link-list a{color:var(--accent);font-weight:700}
.link-list a:hover{text-decoration:underline}
.prose h1{font-size:0;line-height:0;margin:0}
.prose h2,.prose h3{margin:var(--s-6) 0 var(--s-3)}
.prose p,.prose ul{color:var(--ink-2);line-height:1.72;max-width:68ch;margin:0 0 var(--s-4)}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:var(--s-2)}
.prose a{color:var(--accent);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.prose h2:first-of-type{margin-top:0}
.review-rail .bonus-val{font-size:1.1rem}
@media(max-width:980px){.article-grid{grid-template-columns:1fr}.article-rail{position:static}.prose p,.prose ul{max-width:none}}

/* sticky cta */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--ink);color:#fff;padding:var(--s-3) var(--s-4);z-index:var(--z-sticky-cta);box-shadow:0 -4px 20px rgba(0,0,0,.2);align-items:center;gap:var(--s-3);border-top:2px solid var(--accent)}
.sticky-cta .info{flex:1;min-width:0}
.sticky-cta .info b{font-size:.88rem;font-weight:800;display:block}
.sticky-cta .info small{font-size:.68rem;color:var(--gold);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--track-wide)}
.sticky-cta .cta{width:auto;padding:var(--s-3) var(--s-4);font-size:.78rem}
@media(max-width:720px){.sticky-cta{display:flex}body{padding-bottom:72px}}
