@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url(../fonts/heading.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url(../fonts/heading-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url(../fonts/body.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url(../fonts/body-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
:root {
  --clr-primary: #0ea99c;
  --clr-primary-deep: #077f75;
  --clr-base: #0a1a14;
  --clr-surface: #ffffff;
  --clr-surface-alt: #f0faf5;
  --clr-line: #dde9e2;
  --clr-fg: #0a1a14;
  --clr-fg-soft: rgba(0,0,0,.5);
  --gap: 88px;
  --round: 10px;
  --elevation: 0 1px 4px rgba(0,0,0,.04);
  --fontface-head: 'Space Grotesk', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --fontface-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--fontface-body);
  background: var(--clr-surface-alt);
  color: var(--clr-fg);
  line-height: 1.65;
  font-size: 17px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--clr-primary-deep); }

h1, h2, h3, h4 { font-family: var(--fontface-head); line-height: 1.2; color: var(--clr-fg); font-weight: 700; letter-spacing: -.01em; }
h1 { font-size: clamp(2rem, 4vw, 3rem); margin: 0 0 .5em; }
h2 { font-size: clamp(1.5rem, 2.6vw, 2.1rem); margin: 0 0 .6em; }
h3 { font-size: 1.2rem; margin: 0 0 .4em; }
p { margin: 0 0 1em; }

.icon { display: inline-flex; vertical-align: middle; }
.icon svg { display: block; }

.action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4em;
  padding: .7em 1.4em;
  border-radius: var(--round);
  border: 1px solid transparent;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.1;
  transition: transform .12s ease, background .15s ease, color .15s ease;
}
.action:hover { transform: translateY(-1px); }
.action-acc { background: var(--clr-primary); color: #fff; }
.action-acc:hover { background: var(--clr-primary-deep); }
.action-out { border-color: var(--clr-primary); color: var(--clr-primary-deep); background: transparent; }
.action-out:hover { background: var(--clr-primary); color: #fff; }
.action-ghost { background: transparent; color: var(--clr-fg); border-color: var(--clr-line); }

.shell { max-width: 1320px; margin: 0 auto; padding: 0 24px; }
.shell-narrow { max-width: 760px; }
.panel { padding: var(--gap) 0; background: var(--clr-surface-alt); }
.panel-bare { background: var(--clr-surface); }
.panel-dark { background: var(--clr-base); color: #fff; }
.panel-dark h2, .panel-dark h3 { color: #fff; }
.panel-intro { color: var(--clr-fg-soft); max-width: 640px; margin-bottom: 2em; }

.topbar { background: var(--clr-surface); border-bottom: 1px solid var(--clr-line); padding: 18px 0; }
.topbar-top { display: flex; align-items: center; justify-content: center; position: relative; }
.topbar-logo { font-family: var(--fontface-head); font-size: 1.45rem; font-weight: 700; color: var(--clr-fg); text-decoration: none; letter-spacing: -.02em; }
.topbar-logo span { color: var(--clr-primary); }
.topbar-nav { display: flex; justify-content: center; gap: 28px; margin-top: 14px; }
.topbar-link { color: var(--clr-fg); text-decoration: none; font-weight: 500; font-size: .95rem; }
.topbar-link:hover { color: var(--clr-primary-deep); }
.topbar-toggle { display: none; position: absolute; right: 0; top: 50%; transform: translateY(-50%); background: none; border: 0; width: 40px; height: 40px; cursor: pointer; flex-direction: column; gap: 5px; align-items: center; justify-content: center; }
.topbar-toggle span { display: block; width: 22px; height: 2px; background: var(--clr-fg); }

.banner { background: var(--clr-surface); }
.banner-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items: center; }
.banner-sub { font-size: 1.1rem; color: var(--clr-fg-soft); margin: 0 0 1.6em; }
.banner-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 1.6em; }
.banner-tags { display: flex; gap: 12px; flex-wrap: wrap; }
.banner-tag { background: var(--clr-surface-alt); border: 1px solid var(--clr-line); border-radius: var(--round); padding: .35em 1em; font-size: .85rem; color: var(--clr-fg); }
.value-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.value-list li { display: flex; gap: 14px; align-items: flex-start; background: var(--clr-surface-alt); border: 1px solid var(--clr-line); border-radius: var(--round); padding: 18px 20px; }
.value-list .icon { color: var(--clr-primary); flex-shrink: 0; margin-top: 2px; }
.value-list strong { display: block; font-family: var(--fontface-head); }
.value-list p { margin: 2px 0 0; color: var(--clr-fg-soft); font-size: .95rem; }

.facts { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; text-align: center; }
.fact { flex: 1; min-width: 140px; background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); box-shadow: var(--elevation); padding: 24px 16px; }
.fact-num { display: block; font-family: var(--fontface-head); font-size: 2.1rem; font-weight: 700; color: var(--clr-primary); }
.fact-lbl { display: block; color: var(--clr-fg-soft); font-size: .9rem; margin-top: 4px; }
.fact-lbl-solo { display: block; font-family: var(--fontface-head); font-weight: 700; color: var(--clr-primary); font-size: 1.1rem; }

.board-wrap { display: flex; flex-direction: column; gap: 16px; }
.board-feature { background: var(--clr-surface); border: 2px solid var(--clr-primary); border-radius: var(--round); padding: 26px 26px 22px; box-shadow: var(--elevation); }
.board-feature-top { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 10px; }
.board { width: 100%; border-collapse: collapse; background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); overflow: hidden; }
.board th, .board td { padding: 16px 14px; text-align: left; border-bottom: 1px solid var(--clr-line); vertical-align: middle; font-size: .95rem; }
.board thead th { background: var(--clr-surface-alt); font-family: var(--fontface-head); font-size: .82rem; text-transform: uppercase; letter-spacing: .04em; color: var(--clr-fg-soft); }
.board tbody tr:last-child td { border-bottom: 0; }
.board-rank { font-family: var(--fontface-head); font-weight: 700; color: var(--clr-primary); }
.board-name { font-family: var(--fontface-head); font-weight: 700; color: var(--clr-fg); text-decoration: none; }
.board-name:hover { color: var(--clr-primary-deep); }
.board-name-cell { display: flex; align-items: center; gap: 10px; }
.board-badge { display: inline-block; background: var(--clr-primary); color: #fff; font-size: .68rem; font-weight: 600; padding: .25em .7em; border-radius: var(--round); text-transform: uppercase; letter-spacing: .03em; }
.board-cta { white-space: nowrap; }

.tiny-logo { border-radius: 50%; flex-shrink: 0; }

.stars { display: inline-flex; align-items: center; gap: 6px; font-family: var(--fontface-head); }
.stars-glyph { color: var(--clr-primary); letter-spacing: 1px; font-size: .95rem; }
.stars-num { font-weight: 700; color: var(--clr-fg); }

.spotlight { background: var(--clr-base); border-radius: var(--round); padding: 0; overflow: hidden; display: grid; grid-template-columns: .8fr 1.2fr; }
.spotlight-media { background: var(--clr-primary); display: flex; align-items: center; justify-content: center; padding: 40px; }
.spotlight-media img { width: 96px; height: 96px; border-radius: 22px; background: #fff; padding: 14px; }
.spotlight-body { padding: 32px; color: #fff; }
.spotlight-body h3 { color: #fff; margin-bottom: .3em; }
.spotlight-badge { display: inline-block; background: rgba(255,255,255,.15); color: #fff; font-size: .7rem; font-weight: 600; padding: .3em .8em; border-radius: var(--round); text-transform: uppercase; letter-spacing: .03em; margin-bottom: 12px; }
.spotlight-bullets { margin: 1em 0 1.4em; padding-left: 1.2em; color: rgba(255,255,255,.86); }
.spotlight-bullets li { margin-bottom: .35em; }
.spotlight .stars-num { color: #fff; }

.flow-grid { display: grid; grid-template-columns: 1fr; gap: 0; }
.flow-card { position: relative; padding: 0 0 28px 56px; }
.flow-card:not(:last-child) { border-left: 2px solid var(--clr-line); margin-left: 17px; }
.flow-card:last-child { padding-bottom: 0; margin-left: 17px; padding-left: 56px; }
.flow-num { position: absolute; left: -17px; top: 0; width: 36px; height: 36px; border-radius: 50%; background: var(--clr-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--fontface-head); font-weight: 700; font-size: .95rem; }
.flow-card h3 { margin-top: 2px; }
.flow-card p { color: var(--clr-fg-soft); margin-bottom: 0; }

.accordion { display: flex; flex-direction: column; gap: 12px; max-width: 820px; }
.accordion-item { background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); box-shadow: var(--elevation); overflow: hidden; }
.accordion-q { width: 100%; text-align: left; background: none; border: 0; font: inherit; font-family: var(--fontface-head); font-weight: 600; font-size: 1.02rem; color: var(--clr-fg); padding: 20px 22px; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.accordion-q .icon { flex-shrink: 0; transition: transform .25s ease; color: var(--clr-primary); }
.accordion-item.is-open .accordion-q .icon { transform: rotate(180deg); }
.accordion-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .3s ease; }
.accordion-a > div { overflow: hidden; }
.accordion-item.is-open .accordion-a { grid-template-rows: 1fr; }
.accordion-a p { margin: 0; padding: 0 22px 20px; color: var(--clr-fg-soft); }

.cta-band { text-align: center; background: var(--clr-surface); }
.cta-band .panel-intro { margin-left: auto; margin-right: auto; }

.guide-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.guide-card { background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); box-shadow: var(--elevation); padding: 26px; text-decoration: none; color: var(--clr-fg); display: block; transition: transform .12s ease, border-color .15s ease; }
.guide-card:hover { transform: translateY(-2px); border-color: var(--clr-primary); }
.guide-card p { color: var(--clr-fg-soft); }
.guide-more { color: var(--clr-primary-deep); font-weight: 600; font-size: .9rem; }

.risk-note { background: var(--clr-surface-alt); border-top: 1px solid var(--clr-line); padding: 20px 0; }
.risk-note p { margin: 0; font-size: .88rem; color: var(--clr-fg-soft); text-align: center; display: flex; align-items: center; justify-content: center; gap: 8px; }
.risk-note .icon { color: var(--clr-primary); flex-shrink: 0; }

.crumbs { font-size: .85rem; color: var(--clr-fg-soft); margin-bottom: 1.4em; }
.crumbs a { color: var(--clr-primary-deep); text-decoration: none; }
.review-head-rate { display: flex; align-items: center; gap: 12px; margin-bottom: 1em; flex-wrap: wrap; }
.byline { display: flex; align-items: center; gap: 8px; font-size: .88rem; color: var(--clr-fg-soft); margin-bottom: 1.6em; }
.byline .icon { color: var(--clr-primary); }
.lead-head { text-align: center; margin: 1.6em 0; }
.lead-head-logo { margin: 0 auto 10px; border-radius: 50%; }
.lead-head-cap { font-size: .9rem; color: var(--clr-fg-soft); }
.review-hero-cta { margin-bottom: 1.8em; }
.review-lead { font-size: 1.12rem; }
.proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin: 2em 0; }
.pros, .cons { background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); padding: 22px 24px; }
.pros ul, .cons ul { margin: 0; padding-left: 0; list-style: none; }
.pros li, .cons li { margin-bottom: .5em; display: flex; gap: 8px; align-items: flex-start; }
.pros .icon { color: var(--clr-primary); flex-shrink: 0; margin-top: 3px; }
.cons .icon { color: var(--clr-fg-soft); flex-shrink: 0; margin-top: 3px; }
.score-table { width: 100%; border-collapse: collapse; margin: 1em 0 2em; }
.score-table td { padding: 10px 8px; border-bottom: 1px solid var(--clr-line); vertical-align: middle; }
.score-table td:first-child { font-weight: 500; }
.score-bar { display: inline-block; width: 120px; height: 8px; background: var(--clr-surface-alt); border-radius: var(--round); overflow: hidden; }
.score-bar > span { display: block; height: 100%; background: var(--clr-primary); }
.score-n { text-align: right; font-weight: 700; white-space: nowrap; font-family: var(--fontface-head); }
.alt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.alt-card { background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); padding: 20px; }
.alt-card .tiny-logo { margin-bottom: 8px; }
.alt-card p { color: var(--clr-fg-soft); font-size: .92rem; }

.editor-card { display: flex; gap: 18px; align-items: flex-start; background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); padding: 24px; margin: 1em 0 2em; }
.editor-avatar { flex-shrink: 0; width: 64px; height: 64px; border-radius: 50%; background: var(--clr-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--fontface-head); font-weight: 700; font-size: 1.4rem; }
.editor-name { font-family: var(--fontface-head); font-weight: 700; margin: 0; }
.editor-role { color: var(--clr-primary-deep); font-size: .9rem; margin: 0 0 .6em; }
.editor-bio { color: var(--clr-fg-soft); margin: 0; }

.error-block { text-align: center; }
.error-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 2em; }
.error-card { background: var(--clr-surface); border: 1px solid var(--clr-line); border-radius: var(--round); padding: 22px; text-decoration: none; color: var(--clr-fg); display: flex; flex-direction: column; gap: 4px; }
.error-card span { color: var(--clr-fg-soft); font-size: .9rem; }

.consent { position: fixed; left: 0; right: 0; bottom: 0; background: var(--clr-surface); border-top: 1px solid var(--clr-line); box-shadow: 0 -6px 28px rgba(0,0,0,.08); padding: 18px 0; z-index: 50; }
.consent-text { margin: 0 0 12px; font-size: .9rem; color: var(--clr-fg-soft); }
.consent-prefs { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.consent-row { font-size: .9rem; display: flex; gap: 8px; align-items: center; }
.consent-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.consent-reopen { position: fixed; left: 16px; bottom: 16px; width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--clr-line); background: var(--clr-surface); color: var(--clr-fg); cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 40; box-shadow: var(--elevation); }

.pagefoot { background: var(--clr-surface); border-top: 1px solid var(--clr-line); padding: 40px 0 28px; }
.pagefoot-grid { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; padding-bottom: 20px; border-bottom: 1px solid var(--clr-line); }
.pagefoot-logo { font-family: var(--fontface-head); font-size: 1.3rem; font-weight: 700; color: var(--clr-fg); text-decoration: none; }
.pagefoot-logo span { color: var(--clr-primary); }
.pagefoot-nav { display: flex; gap: 20px; flex-wrap: wrap; }
.pagefoot-nav a { color: var(--clr-fg); text-decoration: none; font-size: .92rem; }
.pagefoot-nav a:hover { color: var(--clr-primary-deep); }
.pagefoot-copy { margin: 0; color: var(--clr-fg-soft); font-size: .88rem; }
.ft-bottom { padding-top: 18px; }
.pagefoot-disclosure { font-size: .82rem; color: var(--clr-fg-soft); margin: 0 0 10px; }
.pagefoot-legal { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 10px; }
.pagefoot-legal a { font-size: .82rem; color: var(--clr-fg-soft); text-decoration: none; }
.pagefoot-legal a:hover { color: var(--clr-primary-deep); }
.pagefoot-entity { font-size: .8rem; color: var(--clr-fg-soft); margin: 0; }
.pagefoot-entity a { color: var(--clr-primary-deep); }

@media (max-width: 1024px) {
  .flow-grid, .guide-grid, .alt-grid, .error-cards { }
  .alt-grid, .error-cards { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .topbar-toggle { display: flex; }
  .topbar-nav { display: none; flex-direction: column; gap: 14px; margin-top: 16px; }
  .topbar-nav.open { display: flex; }
  .banner-grid { grid-template-columns: 1fr; }
  .spotlight { grid-template-columns: 1fr; }
  .spotlight-media { padding: 28px; }
  .proscons { grid-template-columns: 1fr; }
  .guide-grid, .alt-grid, .error-cards { grid-template-columns: 1fr; }
  .board thead { display: none; }
  .board, .board tbody, .board tr, .board td { display: block; width: 100%; }
  .board tr { border-bottom: 1px solid var(--clr-line); padding: 8px 0; }
  .board td { border: 0; padding: 6px 14px; }
  .board td::before { content: attr(data-label); font-weight: 600; color: var(--clr-fg-soft); display: block; font-size: .78rem; text-transform: uppercase; letter-spacing: .03em; }
  .board-name-cell::before { content: none; }
  .pagefoot-grid { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
  body { font-size: 16px; }
  .shell { padding: 0 18px; }
  .banner-actions { flex-direction: column; }
  .banner-actions .action { width: 100%; }
}
