/* ============================================================
   b'steuern — Preisseite v3 (preise-7 final)
   Alles Div Blocks — keine Button-Selektoren
   Feature Deck (serif) · General Sans (sans)
   Alle Maße in rem · Borders in px

   Stand: aktuell korrekt für Webflow-Build.
   ============================================================ */

:root {
  --champagne:   #F9F4EC;
  --panel:       #FFFFFF;
  --panel-2:     #FCF9F3;
  --deep:        #0E0C1C;
  --indigo:      #3D2BD5;
  --indigo-deep: #3120AE;
  --indigo-tint: #ECEAFB;
  --indigo-line: #CFC8F4;
  --ink:         #0E0C1C;
  --ink-2:       #56536A;
  --ink-3:       #8C8AA0;
  --hair:        #EBE3D5;
  --hair-2:      #DCD3C0;
  --star:        #C8943E;
  --ink-line:    rgba(14,12,28,.09);
  --ink-25:      rgba(14,12,28,.22);
  --ease-out:    cubic-bezier(0,0,.2,1);
  --ease-spring: cubic-bezier(.16,1,.3,1);
  --t-fast:      150ms;
  --t-base:      250ms;
}

*, *::before, *::after { box-sizing: border-box; border-radius: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--champagne);
  color: var(--ink);
  font-family: 'General Sans', system-ui, sans-serif;
  font-size: 1.0625rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, .serif {
  font-family: 'Feature Deck', Georgia, serif;
  font-weight: 500;
  line-height: 1.07;
  letter-spacing: -.012em;
}
a { color: inherit; }
::selection { background: var(--indigo); color: #fff; }
html.no-scroll { overflow: hidden; }

/* ── Page Wrap ── */
.page-wrap { max-width: 66.25rem; margin: 0 auto; padding: 0 1.75rem; }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
  html { scroll-behavior: auto; }
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar { height: 0.1875rem; background: var(--indigo); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  border-bottom: 1px solid var(--hair);
  background: rgba(249,244,236,.86);
  backdrop-filter: saturate(140%) blur(0.5rem);
  -webkit-backdrop-filter: saturate(140%) blur(0.5rem);
  position: sticky;
  top: 0;
  z-index: 40;
}
.nav-wrap {
  max-width: 66.25rem;
  margin: 0 auto;
  padding: 0 1.75rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 4.375rem;
}
.nav-logo {
  font-family: 'Feature Deck', Georgia, serif;
  font-size: 1.5625rem;
  font-weight: 600;
  letter-spacing: -.02em;
  text-decoration: none;
  color: var(--deep);
}
.nav-logo b { color: var(--indigo); font-weight: 600; }
.nav-right { display: flex; align-items: center; gap: 1.375rem; }
.nav-link { font-size: 0.90625rem; color: var(--ink-2); text-decoration: none; display: none; }
@media (min-width: 47.5em) { .nav-link { display: inline; } }
.nav-cta {
  display: inline-flex;
  align-items: center;
  font-family: 'General Sans', system-ui, sans-serif;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background .16s, border-color .16s;
  background: var(--indigo);
  color: #fff;
  font-size: 0.90625rem;
  padding: 0.6875rem 1.1875rem;
  border: 1px solid var(--indigo);
}
.nav-cta:hover { background: var(--indigo-deep); border-color: var(--indigo-deep); }

/* ============================================================
   HERO
   ============================================================ */
.hero-section { padding: 3.25rem 0 0.75rem; text-align: center; }
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--indigo);
  background: var(--panel);
  padding: 0.3125rem 0.75rem;
  margin-bottom: 1.25rem;
}
.hero-h1 {
  font-family: 'Feature Deck', Georgia, serif;
  font-size: clamp(2.125rem, 4.8vw, 3.25rem);
  font-weight: 500;
  max-width: 18ch;
  margin: 0 auto 1.375rem;
}
.trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5625rem 0.75rem;
  justify-content: center;
  align-items: center;
  font-size: 0.8125rem;
  color: var(--ink-2);
  font-weight: 500;
}
.trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4375rem;
  background: var(--panel);
  border: 1px solid var(--hair-2);
  padding: 0.375rem 0.75rem;
}
.trust-pill svg { width: 0.8125rem; height: 0.8125rem; stroke-width: 2; color: var(--indigo); }

/* ============================================================
   STEP HEADER
   ============================================================ */
.step-section { padding: 2.75rem 0 0.5rem; }
.step-header { text-align: center; margin-bottom: 1.5rem; }
.step-kicker {
  display: inline-block;
  font-size: 0.78125rem;
  font-weight: 600;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 0.75rem;
}
.step-h2 {
  font-family: 'Feature Deck', Georgia, serif;
  font-size: clamp(1.75rem, 3.6vw, 2.375rem);
  font-weight: 500;
}

/* ============================================================
   CONFIG BLOCK
   ============================================================ */
.config {
  max-width: 41.25rem;
  margin: 0 auto;
  background: var(--panel);
  border: 1.5px solid var(--hair-2);
  box-shadow:
    0 1px 0.125rem rgba(14,12,28,.04),
    0 1.5rem 3.75rem -1.875rem rgba(14,12,28,.26);
}
.config-sec { padding: 1.625rem 2rem; }
.config-sec + .config-sec { border-top: 1.5px solid var(--hair); }
.config-sec.disc-sec { padding: 0; }
.config-k {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 1rem;
}
.config-k .cc { color: var(--active-cc, var(--indigo)); }

/* ============================================================
   FORM-BTNS — Div Blocks
   ============================================================ */
.forms { display: flex; flex-direction: column; gap: 0.625rem; }

.form-btn[data-form="solo"]    { --cc: #3D2BD5; --cm: #3D2BD5; --ci: #fff; }
.form-btn[data-form="team"]    { --cc: #00A1AA; --cm: #00A1AA; --ci: #fff; }
.form-btn[data-form="corp"]    { --cc: #FF0670; --cm: #FF0670; --ci: #fff; }
.form-btn[data-form="holding"] { --cc: #C9A800; --cm: #F6DF35; --ci: #0E0C1C; }

.form-btn {
  position: relative;
  background: var(--panel);
  border: 1.5px solid var(--ink-line);
  cursor: pointer;
  font-family: 'General Sans', system-ui, sans-serif;
  color: var(--ink);
  text-align: left;
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 1rem 1.125rem;
  width: 100%;
  transition:
    border-color var(--t-fast) var(--ease-out),
    box-shadow   var(--t-fast) var(--ease-out);
}
@media (hover: hover) {
  .form-btn:hover { border-color: var(--cc); }
  .form-btn:hover .ic-chip { background: color-mix(in srgb, var(--cm) 14%, #fff); color: var(--cc); }
  .form-btn:hover .form-price { color: var(--cc); }
}
.form-btn[aria-pressed="true"] {
  border-color: var(--cc);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cc) 12%, transparent);
}
.form-btn[aria-pressed="true"] .ic-chip { background: var(--cm); color: var(--ci); }
.form-btn[aria-pressed="true"] .form-price { color: var(--cc); }

.ic-chip {
  flex: 0 0 2.625rem;
  width: 2.625rem;
  height: 2.625rem;
  background: color-mix(in srgb, var(--cm) 10%, #fff);
  display: grid;
  place-items: center;
  color: var(--cc);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast);
}
.ic-chip svg { width: 1.375rem; height: 1.375rem; stroke-width: 1.6; }

.form-txt { flex: 1; min-width: 0; }
.form-tt {
  display: block;
  font-weight: 600;
  font-size: 0.96875rem;
  letter-spacing: -.01em;
  line-height: 1.15;
}
.form-ds {
  display: block;
  font-size: 0.78125rem;
  color: var(--ink-2);
  line-height: 1.3;
  margin-top: 0.1875rem;
}
.form-price {
  flex: 0 0 auto;
  text-align: right;
  font-family: 'Feature Deck', Georgia, serif;
  font-weight: 600;
  font-size: 1rem;
  color: var(--deep);
  white-space: nowrap;
  transition: color var(--t-fast) var(--ease-out);
}
.form-price span {
  font-family: 'General Sans', system-ui, sans-serif;
  font-weight: 400;
  font-size: 0.6875rem;
  color: var(--ink-2);
  margin-left: 0.0625rem;
}
.form-check { display: none; }

/* ============================================================
   FOUNDER
   ============================================================ */
.founder-wrap { margin: 1.125rem 0 0; display: flex; justify-content: center; }
.founder {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--ink);
  border: 1px solid color-mix(in srgb, var(--active-cc, var(--indigo)) 30%, #fff);
  background: color-mix(in srgb, var(--active-cm, var(--indigo)) 7%, #fff);
  padding: 0.6875rem 1.125rem;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
@media (hover: hover) {
  .founder:hover {
    border-color: var(--active-cc, var(--indigo));
    background: color-mix(in srgb, var(--active-cm, var(--indigo)) 11%, #fff);
  }
}
.founder-ic {
  width: 1rem; height: 1rem; flex: 0 0 1rem;
  color: var(--active-cc, var(--indigo));
  margin-left: 0.125rem; margin-right: -0.4375rem;
}
.founder .box {
  width: 1.1875rem; height: 1.1875rem;
  border: 1.5px solid color-mix(in srgb, var(--active-cc, var(--indigo)) 38%, #fff);
  background: #fff;
  display: grid; place-items: center;
  transition: background .14s, border-color .14s;
}
.founder input { position: absolute; opacity: 0; width: 0; height: 0; }
.founder input:checked + .box { background: var(--active-cc, var(--indigo)); border-color: var(--active-cc, var(--indigo)); }
.founder .box svg { width: 0.75rem; height: 0.75rem; color: #fff; stroke-width: 3; opacity: 0; }
.founder input:checked + .box svg { opacity: 1; }

/* ============================================================
   RESULT / RCARD
   ============================================================ */
#priceResult { margin-top: 0.125rem; }

/* rcard und discSec: Initialzustand über das HTML hidden-Attribut (Webflow Custom Attribute).
   Das JS entfernt .hidden per element.hidden=false — keine CSS-ID-Regel nötig oder erlaubt,
   da ID-Selektoren das hidden=false des JS überschreiben würden.
   border:none überschreibt Webflow-eigene Border-Styles auf rcard. */
#rcard { border: none !important; outline: none !important; box-shadow: none !important; }
.rcard[hidden] { display: none !important; }
[hidden] { display: none !important; }

/* rc-opts — leer, JS rendert .rc-opt Div Blocks rein */
.rc-opts { padding: 1rem 0 0; display: flex; flex-direction: column; gap: 0.625rem; }

/* rc-opt — von JS als Div Block generiert */
.rc-opt {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  width: 100%;
  text-align: left;
  background: var(--panel);
  border: 1.5px solid var(--hair-2);
  padding: 0.9375rem 1.125rem;
  cursor: pointer;
  color: var(--ink);
  transition:
    border-color var(--t-fast) var(--ease-out),
    box-shadow   var(--t-fast) var(--ease-out);
}
@media (hover: hover) { .rc-opt:not(.soon):hover { border-color: var(--ink-25); } }
.rc-opt.selected {
  border-color: var(--active-cc, var(--indigo));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--active-cc, var(--indigo)) 11%, transparent);
}
.rc-opt.soon { opacity: .5; cursor: default; pointer-events: none; }
.rc-opt-check {
  flex: 0 0 1.3125rem; width: 1.3125rem; height: 1.3125rem;
  border: 1.5px solid var(--ink-25);
  display: grid; place-items: center;
  color: transparent;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.rc-opt.selected .rc-opt-check {
  background: var(--active-cc, var(--indigo));
  border-color: var(--active-cc, var(--indigo));
  color: #fff;
}
.rc-opt-check svg { width: 0.75rem; height: 0.75rem; stroke-width: 3; }
.rc-opt-main { flex: 1; min-width: 0; }
.rc-opt-name { display: flex; align-items: center; gap: 0.5rem; font-weight: 600; font-size: 0.96875rem; letter-spacing: -.01em; }
.rc-opt-tag { font-size: 0.59375rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 0.125rem 0.4375rem; background: var(--active-cc, var(--indigo)); color: #fff; white-space: nowrap; }
.rc-opt-tag.soon { background: var(--ink); opacity: .72; }
.rc-opt-desc { display: block; font-size: 0.78125rem; color: var(--ink-2); margin-top: 0.1875rem; line-height: 1.3; }
.rc-opt-price {
  font-family: 'Feature Deck', Georgia, serif;
  font-weight: 600;
  font-size: 1.3125rem;
  color: var(--deep);
  white-space: nowrap;
  letter-spacing: -.01em;
}
.rc-opt-price .f { font-family: 'General Sans', system-ui, sans-serif; font-size: 0.6875rem; font-weight: 600; color: var(--ink-3); margin-right: 0.1875rem; letter-spacing: 0; }
.rc-opt-price .p { font-family: 'General Sans', system-ui, sans-serif; font-size: 0.6875rem; font-weight: 400; color: var(--ink-2); margin-left: 0.125rem; letter-spacing: 0; }
.rc-opt-price .soon-lbl { font-family: 'General Sans', system-ui, sans-serif; font-size: 0.78125rem; font-weight: 600; color: var(--ink-3); letter-spacing: 0; }

/* Gründer-Banner */
.rc-founder-1 {
  margin: 1rem 0 0;
  border: 1px solid color-mix(in srgb, var(--active-cc, var(--indigo)) 18%, #fff);
  border-left: 3px solid var(--active-cc, var(--indigo));
  background: color-mix(in srgb, var(--active-cm, var(--indigo)) 7%, #fff);
  padding: 0.75rem 0.9375rem;
  font-size: 0.84375rem;
  color: var(--ink-2);
  line-height: 1.5;
  display: none;
}
.rc-founder-1.show { display: block !important; }
.rc-founder-1 strong { color: var(--ink); font-weight: 600; }

/* Advisor Strip — display:flex, immer sichtbar sobald rcard eingeblendet. */
.rc-advisor {
  display: flex;
  align-items: center;
  gap: 0.8125rem;
  margin-top: 1.125rem;
  padding: 0.8125rem 0.9375rem;
  background: color-mix(in srgb, var(--active-cm, var(--indigo)) 7%, #fff);
  border: 1px solid color-mix(in srgb, var(--active-cc, var(--indigo)) 18%, #fff);
}
.rc-advisor .ph {
  flex: 0 0 2.875rem; width: 2.875rem; height: 2.875rem;
  background: color-mix(in srgb, var(--active-cm, var(--indigo)) 16%, #fff);
  color: var(--active-cc, var(--indigo));
  border: 1.5px solid color-mix(in srgb, var(--active-cc, var(--indigo)) 30%, #fff);
  display: grid; place-items: center; overflow: hidden;
}
.rc-advisor .ph img,
.rc-advisor .ph svg { width: 100%; height: 100%; display: block; object-fit: cover; }
.rc-advisor .tx { font-size: 0.8125rem; color: var(--ink-2); line-height: 1.45; }
.rc-advisor .tx strong { color: var(--ink); font-weight: 600; display: block; }

/* Detail + CTA */
.rc-detail { padding: 1.25rem 0 0; }
.cta-full {
  display: flex; align-items: center; justify-content: center; gap: 0.5625rem;
  width: 100%;
  background: var(--active-cc, var(--indigo));
  color: #fff;
  font-family: 'General Sans', system-ui, sans-serif;
  font-weight: 600;
  font-size: 1rem;
  padding: 1rem;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: filter .16s;
}
.cta-full:hover { filter: brightness(.92); }
.cta-full svg { width: 1.0625rem; height: 1.0625rem; stroke-width: 2.2; }
.rc-reassure { text-align: center; font-size: 0.8125rem; color: var(--ink-2); margin-top: 0.875rem; line-height: 1.5; }
.rc-reassure strong { color: var(--ink); font-weight: 600; }

.rc-hold-price { display: flex; align-items: baseline; gap: 0.4375rem; margin-bottom: 1.125rem; }
.rc-hold-price .f { font-size: 0.8125rem; font-weight: 600; color: var(--ink-3); }
.rc-hold-price .amt { font-family: 'Feature Deck', Georgia, serif; font-weight: 600; font-size: 2.375rem; letter-spacing: -.02em; color: var(--deep); }
.rc-hold-price .per { font-size: 0.8125rem; color: var(--ink-2); }

.hint { text-align: center; font-size: 0.90625rem; color: var(--ink-3); padding: 1.5rem 0; }

/* ============================================================
   DISC-SEC — Aufklapp "Alle Leistungen & Details"
   ============================================================ */
.rc-disc-btn {
  display: flex; align-items: center; justify-content: center; gap: 0.4375rem;
  width: 100%;
  background: none;
  border: none;
  font-family: 'General Sans', system-ui, sans-serif;
  color: var(--ink-2);
  cursor: pointer;
  padding: 1.125rem 2rem;
  font-size: 0.84375rem;
  font-weight: 600;
  transition: color var(--t-fast);
}
@media (hover: hover) { .rc-disc-btn:hover { color: var(--ink); } }
.rc-disc-arrow {
  color: var(--active-cc, var(--indigo));
  font-weight: 700;
  display: inline-block;
  transition: transform var(--t-base) var(--ease-out);
}
.rc-disc-btn[aria-expanded="true"] .rc-disc-arrow { transform: rotate(180deg); }

/* Panel hat immer Padding — [hidden]-Attribut steuert Sichtbarkeit, nicht Padding. */
.rc-disc-panel { padding: 0.125rem 2rem 1.625rem; }
.rc-disc-panel[hidden] { display: none !important; }

/* Disc-panel Inhalte — von JS generiert */
.rc-disc-grp { margin-bottom: 1.125rem; }
.rc-disc-lab { font-size: 0.71875rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 0.625rem; }
.rc-disc-feats { list-style: none; }
.rc-disc-feats li { display: flex; gap: 0.6875rem; align-items: flex-start; padding: 0.3125rem 0; font-size: 0.875rem; line-height: 1.4; }
.rc-disc-feats .ck { flex: 0 0 1.1875rem; width: 1.1875rem; height: 1.1875rem; display: grid; place-items: center; margin-top: 0.125rem; background: color-mix(in srgb, var(--active-cm, var(--indigo)) 14%, #fff); color: var(--active-cc, var(--indigo)); }
.rc-disc-feats .ck svg { width: 0.6875rem; height: 0.6875rem; stroke-width: 2.8; }
.rc-disc-info { display: flex; gap: 0.5625rem; align-items: flex-start; font-size: 0.78125rem; color: var(--ink-2); line-height: 1.5; background: var(--panel-2); border: 1px solid var(--hair); padding: 0.6875rem 0.8125rem; margin-top: 0.375rem; }
.rc-disc-info svg { width: 0.9375rem; height: 0.9375rem; color: var(--active-cc, var(--indigo)); flex: 0 0 0.9375rem; margin-top: 0.125rem; stroke-width: 2; }
.rc-disc-info strong { color: var(--ink); font-weight: 600; }
.rc-size { margin-bottom: 0.625rem; }
.rc-size-tr { display: flex; justify-content: space-between; padding: 0.5625rem 0; border-top: 1px solid var(--hair); font-size: 0.875rem; }
.rc-size-tr:first-child { border-top: none; }
.rc-size-v { font-weight: 600; color: var(--active-cc, var(--indigo)); }
.rc-disc-note { font-size: 0.78125rem; color: var(--ink-2); background: var(--panel-2); border: 1px solid var(--hair); padding: 0.625rem 0.75rem; line-height: 1.5; }
.rc-disc-note strong { color: var(--ink); font-weight: 600; }
.rc-disc-points { list-style: none; }
.rc-disc-points li { font-size: 0.84375rem; color: var(--ink-2); line-height: 1.5; padding: 0.4375rem 0; border-top: 1px solid var(--hair); }
.rc-disc-points li:first-child { border-top: none; padding-top: 0; }
.rc-disc-points strong { color: var(--ink); font-weight: 600; }

/* ============================================================
   COMPARE-DOCK — Div Block
   ============================================================ */
.compare-dock {
  position: fixed; left: 0; right: 0; bottom: 1.625rem;
  display: flex; justify-content: center;
  z-index: 55; pointer-events: none;
}
.compare-dock.hide { display: none; }
@media (max-width: 47.5em) { .compare-dock { display: none; } }

.compare-trigger {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.875rem;
  background: var(--deep);
  color: #fff;
  font-family: 'General Sans', system-ui, sans-serif;
  font-weight: 600;
  font-size: 0.9375rem;
  padding: 0.625rem 0.625rem 0.625rem 1.375rem;
  border: 1px solid var(--deep);
  cursor: pointer;
  box-shadow: 0 0.75rem 2rem rgba(14,12,28,.3);
  transition: background .16s;
}
.compare-trigger:hover { background: #211d38; }
.ct-plus { width: 1.875rem; height: 1.875rem; background: var(--indigo); display: grid; place-items: center; flex: 0 0 1.875rem; }
.ct-plus svg { width: 1rem; height: 1rem; color: #fff; stroke-width: 2.6; }

/* ============================================================
   MODAL — modal-tabs als Div Blocks
   ============================================================ */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(14,12,28,.6);
  backdrop-filter: blur(0.375rem);
  -webkit-backdrop-filter: blur(0.375rem);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 5vh 1.25rem; overflow-y: auto;
}
.modal-backdrop[hidden] { display: none !important; }
.modal {
  position: relative;
  background: var(--panel);
  border: 1.5px solid var(--hair-2);
  border-top: 3px solid var(--indigo);
  max-width: 41.25rem; width: 100%; margin: auto;
}
.modal-head {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  padding: 1.875rem 3.5rem 1.125rem;
  text-align: center;
}
.modal-head h2 { font-family: 'Feature Deck', Georgia, serif; font-size: 1.75rem; font-weight: 500; letter-spacing: -.01em; }
.modal-close {
  position: absolute; top: 1.25rem; right: 1.25rem;
  flex: 0 0 2.375rem; width: 2.375rem; height: 2.375rem;
  background: var(--champagne); border: 1px solid var(--hair-2);
  display: grid; place-items: center;
  cursor: pointer; color: var(--ink); transition: background .16s;
}
.modal-close:hover { background: var(--hair); }
.modal-close svg { width: 1.0625rem; height: 1.0625rem; stroke-width: 2.2; }

.modal-tabs {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.modal-tab {
  font-family: 'General Sans', system-ui, sans-serif;
  background: var(--panel);
  border-left: 1px solid var(--hair);
  cursor: pointer;
  color: var(--ink-2);
  padding: 0.875rem 0.5rem;
  display: flex; flex-direction: column; align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 600;
  transition: background .16s, color .16s;
}
.modal-tab:first-child { border-left: none; }
.modal-tab svg { width: 1.25rem; height: 1.25rem; stroke-width: 1.7; }
.modal-tab:hover { background: var(--panel-2); }
.modal-tab[aria-selected="true"] { background: var(--indigo); color: #fff; }

.cmp-rows { padding: 0.5rem 2rem; }
.cmp-row {
  display: grid; grid-template-columns: 12.375rem 1fr;
  gap: 1.125rem; padding: 1.25rem 0;
  border-top: 1px solid var(--hair);
}
.cmp-row:first-child { border-top: none; }
.cmp-row.sel { box-shadow: inset 3px 0 0 var(--rc, var(--indigo)); padding-left: 1rem; margin-left: -1rem; }
.cmp-name { font-weight: 600; font-size: 1.03125rem; }
.cmp-sub { font-size: 0.8125rem; color: var(--ink-3); margin-top: 0.1875rem; }
.cmp-badge { display: inline-block; font-size: 0.6875rem; font-weight: 600; letter-spacing: .04em; color: var(--rc, var(--indigo)); background: color-mix(in srgb, var(--rc, var(--indigo)) 10%, #fff); border: 1px solid color-mix(in srgb, var(--rc, var(--indigo)) 28%, #fff); padding: 0.125rem 0.5rem; margin-top: 0.375rem; }
.cc-strong { font-family: 'Feature Deck', Georgia, serif; font-size: 1.5rem; font-weight: 600; color: var(--deep); }
.cc-list { list-style: none; }
.cc-list li { display: flex; gap: 0.625rem; align-items: flex-start; padding: 0.25rem 0; font-size: 0.90625rem; color: var(--ink); line-height: 1.4; }
.cc-list strong { font-weight: 600; }
.cc-list li.off { color: var(--ink-3); }
.cc-ck { flex: 0 0 1.0625rem; width: 1.0625rem; height: 1.0625rem; background: var(--indigo-tint); color: var(--indigo); display: grid; place-items: center; margin-top: 0.125rem; }
.cmp-row .cc-ck { background: color-mix(in srgb, var(--rc, var(--indigo)) 14%, #fff); color: var(--rc, var(--indigo)); }
.cc-ck svg { width: 0.6875rem; height: 0.6875rem; stroke-width: 2.8; }
.modal-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
  padding: 1.125rem 2rem 1.625rem;
  border-top: 1px solid var(--hair);
  font-size: 0.78125rem; color: var(--ink-3);
}

/* ============================================================
   MOBILE-BAR
   ============================================================ */
.mobile-bar { display: none; }

@media (max-width: 47.5em) {
  body { padding-bottom: 4.75rem; }
  .mobile-bar {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.6875rem;
    align-items: center;
    position: fixed; left: 0; right: 0; bottom: 0;
    z-index: 60;
    background: var(--champagne);
    border-top: 1px solid var(--hair-2);
    padding: 0.625rem 0.875rem;
    box-shadow: 0 -0.25rem 1.375rem rgba(14,12,28,.16);
  }
  .mb-person { display: flex; align-items: center; gap: 0.625rem; min-width: 0; }
  .mb-advisor {
    flex: 0 0 2.75rem; width: 2.75rem; height: 2.75rem;
    background: color-mix(in srgb, var(--active-cm, var(--indigo)) 16%, #fff);
    color: var(--active-cc, var(--indigo));
    border: 1.5px solid color-mix(in srgb, var(--active-cc, var(--indigo)) 30%, #fff);
    display: grid; place-items: center; overflow: hidden;
    transition: background var(--t-fast) var(--ease-out), color var(--t-fast), border-color var(--t-fast);
  }
  .mb-advisor img,
  .mb-advisor svg { width: 100%; height: 100%; display: block; object-fit: cover; }
  .mb-name { font-size: 0.78125rem; font-weight: 600; color: var(--ink); line-height: 1.22; text-align: left; white-space: nowrap; }
  .mb-book {
    display: flex; align-items: center; justify-content: center; gap: 0.5rem;
    background: var(--active-cc, var(--indigo));
    color: #fff;
    font-family: 'General Sans', system-ui, sans-serif;
    font-weight: 600; font-size: 0.90625rem;
    text-decoration: none;
    padding: 0.9375rem 0.75rem;
    transition: background var(--t-fast) var(--ease-out);
  }
  .mb-book svg { color: #fff; width: 1rem; height: 1rem; }

  /* Modal Mobile — Bottom Sheet */
  .modal-backdrop { padding: 0; align-items: flex-end; }
  .modal { max-width: 100%; max-height: 90vh; overflow-y: auto; border-left: none; border-right: none; border-bottom: none; }
  .modal-head { padding: 1.5rem 1.375rem 1rem; }
  .modal-head h2 { font-size: 1.5625rem; }
  .cmp-rows { padding: 0.375rem 1.375rem; }
  .modal-foot { padding: 1rem 1.375rem 1.375rem; }

  /* Trust + Quotes */
  .quotes { grid-template-columns: 1fr; }
}

/* ============================================================
   RESPONSIVE — Tablet (max 51.25em = 820px)
   ============================================================ */
@media (max-width: 51.25em) {
  .nav-wrap        { padding: 0 1.25rem; height: 4rem; }
  .nav-logo        { font-size: 1.375rem; }
  .nav-cta         { font-size: 0.84375rem; padding: 0.5625rem 0.875rem; }
  .nav-right       { gap: 0.875rem; }
  .hero-section    { padding: 2.5rem 0 0.75rem; }
  .hero-eyebrow    { font-size: 0.71875rem; margin-bottom: 1rem; }
  .trust-row       { font-size: 0.75rem; gap: 0.4rem 0.5rem; }
  .trust-pill      { padding: 0.3rem 0.625rem; }
  .step-section    { padding: 2rem 0 0.5rem; }
  .step-header     { margin-bottom: 1.25rem; }
  .config          { max-width: 100%; }
  .config-sec      { padding: 1.375rem 1.5rem; }
  .form-btn        { padding: 0.875rem 1rem; gap: 0.75rem; }
  .ic-chip         { width: 2.375rem; height: 2.375rem; flex: 0 0 2.375rem; }
  .ic-chip svg     { width: 1.25rem; height: 1.25rem; }
  .form-tt         { font-size: 0.90625rem; }
  .form-ds         { font-size: 0.71875rem; }
  .form-price      { font-size: 0.9375rem; }
  .rc-opt          { padding: 0.8125rem 1rem; gap: 0.75rem; }
  .rc-opt-name     { font-size: 0.90625rem; }
  .rc-opt-price    { font-size: 1.125rem; }
  .rc-advisor      { margin-top: 1rem; }
  .rc-advisor .ph  { width: 2.5rem; height: 2.5rem; flex: 0 0 2.5rem; }
  .cta-full        { font-size: 0.9375rem; padding: 0.9375rem; }
  .rc-disc-btn     { padding: 1rem 1.5rem; font-size: 0.78125rem; }
  .rc-disc-panel { padding: 0.125rem 1.5rem 1.625rem; }
  .compare-trigger { font-size: 0.875rem; padding: 0.5rem 0.5rem 0.5rem 1.125rem; gap: 0.75rem; }
  .compare-dock    { bottom: 1.25rem; }
  .ct-plus         { width: 1.625rem; height: 1.625rem; flex: 0 0 1.625rem; }
  .ct-plus svg     { width: 0.875rem; height: 0.875rem; }
  .modal-tab       { font-size: 0.75rem; padding: 0.75rem 0.375rem; }
  .modal-tab svg   { width: 1.125rem; height: 1.125rem; }
  .cmp-row         { grid-template-columns: 10rem 1fr; }
  .quotes          { grid-template-columns: 1fr; }
}

/* ============================================================
   RESPONSIVE — Mobile (max 30em = 480px)
   ============================================================ */
@media (max-width: 30em) {
  .nav-wrap        { padding: 0 1rem; height: 3.5rem; }
  .nav-logo        { font-size: 1.25rem; }
  .nav-cta         { font-size: 0.8125rem; padding: 0.5rem 0.75rem; }
  .nav-right       { gap: 0.625rem; }
  .hero-section    { padding: 2rem 0 0.625rem; }
  .hero-eyebrow    { font-size: 0.6875rem; padding: 0.25rem 0.625rem; margin-bottom: 0.75rem; }
  .step-section    { padding: 1.75rem 0 0.5rem; }
  .step-kicker     { font-size: 0.71875rem; margin-bottom: 0.5rem; }
  .config-sec      { padding: 1.25rem 1.125rem; }
  .form-btn        { padding: 0.75rem 0.875rem; gap: 0.625rem; }
  .ic-chip         { width: 2.125rem; height: 2.125rem; flex: 0 0 2.125rem; }
  .ic-chip svg     { width: 1.125rem; height: 1.125rem; }
  .form-tt         { font-size: 0.875rem; }
  .form-ds         { font-size: 0.6875rem; }
  .form-price      { font-size: 0.875rem; }
  .forms           { gap: 0.5rem; }
  .founder         { font-size: 0.8125rem; padding: 0.625rem 0.875rem; }
  .founder .box    { width: 1rem; height: 1rem; }
  .rc-opts         { gap: 0.5rem; padding-top: 0.75rem; }
  .rc-opt          { padding: 0.75rem 0.875rem; gap: 0.625rem; }
  .rc-opt-check    { width: 1.125rem; height: 1.125rem; flex: 0 0 1.125rem; }
  .rc-opt-name     { font-size: 0.84375rem; }
  .rc-opt-desc     { font-size: 0.71875rem; }
  .rc-opt-price    { font-size: 1rem; }
  .rc-founder-1      { padding: 0.625rem 0.75rem; font-size: 0.78125rem; margin-top: 0.75rem; }
  .rc-advisor      { gap: 0.625rem; padding: 0.625rem 0.75rem; margin-top: 0.875rem; }
  .rc-advisor .ph  { width: 2.25rem; height: 2.25rem; flex: 0 0 2.25rem; }
  .rc-advisor .tx  { font-size: 0.75rem; }
  .cta-full        { font-size: 0.875rem; padding: 0.875rem; }
  .rc-reassure     { font-size: 0.75rem; }
  .rc-disc-btn     { padding: 0.875rem 1.125rem; font-size: 0.75rem; }
  .rc-disc-panel { padding: 0.125rem 1.125rem 1.25rem; }
  .rc-disc-feats li { font-size: 0.8125rem; }
  .rc-size-tr      { font-size: 0.8125rem; }
  .rc-disc-points li { font-size: 0.78125rem; }
  .cmp-row         { grid-template-columns: 1fr; gap: 0.5rem; }
  .modal-tab       { font-size: 0.6875rem; padding: 0.625rem 0.25rem; gap: 0.25rem; }
  .modal-tab svg   { width: 1rem; height: 1rem; }
  .faq-section h2  { font-size: 1.5rem; }
  .faq-q           { font-size: 0.9375rem; padding: 1rem 0.25rem; }
}
