:root {
  --bg: #0f1218;
  --bg-soft: #161b24;
  --surface: #1d2431;
  --surface-2: #242d3d;
  --line: rgba(255, 255, 255, 0.14);
  --line-soft: rgba(255, 255, 255, 0.08);
  --text: #eef4ff;
  --muted: #aebbd1;
  --brand: #48d8d2;
  --brand-2: #4f78ff;
  --accent: #ff9550;
  --ok: #82dd84;
  --radius-xl: 28px;
  --radius-lg: 18px;
  --radius-md: 12px;
  --shadow-1: 0 16px 40px rgba(0, 0, 0, 0.34);
  --shadow-2: 0 28px 70px rgba(0, 0, 0, 0.46);
  --font: "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, "Roboto", sans-serif;
  --container: 1180px;
}

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body.page {
  margin: 0;
  color: var(--text);
  font-family: var(--font);
  line-height: 1.55;
  background:
    radial-gradient(760px 420px at 0% -10%, rgba(72,216,210,0.16), transparent 62%),
    radial-gradient(760px 420px at 100% -10%, rgba(79,120,255,0.16), transparent 62%),
    linear-gradient(180deg, #0f1218 0%, #101621 46%, #0b1018 100%);
}

a { color: inherit; }

.container {
  width: min(100% - 36px, var(--container));
  margin-inline: auto;
}

.container--narrow { width: min(100% - 36px, 860px); }

.section { padding: 76px 0; }
.section--tight { padding: 48px 0; }

.section__title {
  margin: 0 0 12px;
  font-size: clamp(1.8rem, 3.8vw, 3rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
}

.section__lead,
.muted {
  margin: 0 0 18px;
  color: var(--muted);
}

.card {
  background: linear-gradient(170deg, rgba(36,45,61,0.96), rgba(25,32,44,0.96));
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-1);
}

.btn {
  min-height: 40px;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 8px 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  transition: transform .16s ease, filter .16s ease;
  cursor: pointer;
}

.btn:hover { transform: translateY(-1px); }

.btn--sm { min-height: 40px; padding: 7px 14px; font-size: .84rem; }
.btn--lg { min-height: 50px; padding: 10px 24px; font-size: .95rem; }
.btn--block { width: 100%; }

.btn--primary {
  color: #051726;
  background: linear-gradient(135deg, var(--brand), #7ef2ee);
  box-shadow: 0 10px 24px rgba(72,216,210,0.3);
}

.btn--outline {
  color: var(--text);
  border-color: var(--line);
  background: rgba(255,255,255,0.04);
}

.btn--light {
  color: #071726;
  background: #f3fbff;
}

.btn--dark {
  color: #fff;
  background: linear-gradient(135deg, #273247, #1d2636);
  border-color: var(--line);
}

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 140;
  background: rgba(12, 16, 23, 0.86);
  border-bottom: 1px solid var(--line-soft);
  backdrop-filter: blur(14px);
}

.site-header__inner {
  min-height: 74px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.site-logo {
  text-decoration: none;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: 1.08rem;
  display: inline-flex;
  align-items: center;
  gap: 9px;
}

.site-logo__mark {
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
}

.site-nav {
  margin-left: auto;
  display: none;
  gap: 8px;
}

.site-nav a {
  text-decoration: none;
  padding: 8px 10px;
  border-radius: 10px;
  color: #dce8ff;
  font-size: .86rem;
  font-weight: 700;
}

.site-nav a:hover {
  color: #fff;
  background: rgba(255,255,255,0.1);
}

.site-header__actions { display: none; }

.burger {
  margin-left: auto;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: rgba(255,255,255,0.05);
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.burger span {
  width: 20px;
  height: 2px;
  background: #e6efff;
  transition: transform .2s ease, opacity .2s ease;
}

body.nav-open .burger span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
body.nav-open .burger span:nth-child(2) { opacity: 0; }
body.nav-open .burger span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

@media (min-width: 992px) {
  .burger { display: none; }
  .site-nav,
  .site-header__actions { display: flex; }
}

@media (max-width: 991px) {
  body.nav-open .site-nav {
    position: absolute;
    top: 74px;
    left: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 14px 18px 18px;
    background: rgba(12,16,23,.98);
    border-bottom: 1px solid var(--line-soft);
  }
}

/* New architecture */
.vault-home { color: var(--text); }

.vault-badge {
  margin: 0 0 12px;
  width: fit-content;
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 12px;
  color: #031726;
  background: linear-gradient(135deg, var(--brand), #8ff5f1);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.vault-hero {
  padding: 66px 0 28px;
}

.vault-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 14px;
}

.vault-hero__copy,
.vault-hero__panel {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-xl);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-2);
}

.vault-hero__copy {
  padding: clamp(24px, 4vw, 50px);
}

.vault-hero__copy h1 {
  margin: 0 0 14px;
  max-width: 14ch;
  font-size: clamp(2.35rem, 5.8vw, 5.2rem);
  line-height: .88;
  letter-spacing: -.06em;
}

.vault-hero__copy p {
  margin: 0 0 20px;
  max-width: 65ch;
  color: #c2cfe4;
}

.vault-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.vault-hero__panel {
  padding: 20px;
  display: grid;
  gap: 10px;
}

.vault-hero__panel article {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.03);
  padding: 12px;
}

.vault-hero__panel small {
  display: block;
  color: #9db0cc;
  margin-bottom: 3px;
}

.vault-hero__panel strong {
  color: #f4f8ff;
}

.vault-section { padding: 72px 0; }
.vault-section--soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
}

.vault-head { margin-bottom: 20px; }
.vault-head p {
  margin: 0 0 8px;
  color: var(--brand);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.vault-head h2 {
  margin: 0;
  font-size: clamp(1.85rem, 3.8vw, 3rem);
  line-height: .98;
  letter-spacing: -.04em;
}

.vault-note {
  margin: 0;
  color: #b8c7df;
}

.vault-card {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.vault-screening {
  display: grid;
  grid-template-columns: .88fr 1.12fr;
  gap: 18px;
  align-items: start;
}

.vault-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 12px;
}

.vault-form-grid label {
  display: block;
  font-size: .84rem;
  font-weight: 600;
  color: #dce8ff;
}

.vault-form-grid select {
  width: 100%;
  min-height: 42px;
  margin-top: 4px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.04);
  color: #eaf2ff;
  padding: 8px 10px;
}

.vault-score {
  margin-top: 12px;
  border: 1px solid rgba(72,216,210,0.32);
  border-radius: 12px;
  padding: 12px;
  background: rgba(72,216,210,0.08);
}

.vault-score p {
  margin: 0 0 6px;
  color: #dffbfa;
}

.vault-score p:last-child { margin-bottom: 0; }

.vault-scenario {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 12px;
}

.vault-scenario__controls,
.vault-scenario__result {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.vault-field { margin-bottom: 14px; }
.vault-field:last-child { margin-bottom: 0; }

.vault-field label {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
  color: #d7e4fa;
}

.vault-field strong { color: #fff; }
.vault-field input[type="range"] { width: 100%; accent-color: var(--brand); }

.vault-scenario__result p {
  margin: 0 0 8px;
  color: #b6c6e0;
}

.vault-scenario__result strong {
  display: block;
  margin-bottom: 8px;
  font-size: 2rem;
  letter-spacing: -.03em;
}

.vault-scenario__result small {
  display: block;
  margin: 10px 0 12px;
  color: #9fb0ca;
}

.vault-tariffs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}

.vault-tariffs article {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 18px;
}

.vault-tariffs article.is-recommended {
  border-color: rgba(72,216,210,0.45);
  background:
    radial-gradient(340px 120px at 100% 0, rgba(72,216,210,0.14), transparent 62%),
    linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
}

.vault-tariffs h3 { margin: 0 0 8px; }
.vault-tariffs p { margin: 0 0 10px; color: #c0cfe6; }
.vault-tariffs__range {
  font-weight: 800;
  color: #f5fbff !important;
}

.vault-checklist {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 18px;
  align-items: start;
}

.vault-check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin-bottom: 10px;
  color: #d6e3f8;
}

.vault-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
  margin-top: 2px;
}

.vault-ready {
  margin-top: 12px;
  border-top: 1px solid var(--line-soft);
  padding-top: 12px;
}

.vault-ready p {
  margin: 0 0 10px;
  color: #d6e3f8;
}

.is-disabled {
  opacity: .5;
  pointer-events: none;
}

.review-slider {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 22px;
}

.review-slider__name { margin: 0 0 4px; font-weight: 700; }
.review-slider__title { margin: 0 0 10px; font-weight: 700; }
.review-slider__text { margin: 0 0 12px; color: #c1d0e7; }

.review-slider__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.faq__item {
  margin-bottom: 10px;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-md);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  overflow: hidden;
}

.faq__item summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  font-weight: 700;
}

.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after { content: "+"; float: right; color: var(--brand); }
.faq__item[open] summary::after { content: "−"; }

.faq__item p {
  margin: 0;
  padding: 0 16px 14px;
  color: #c1d0e7;
}

/* Generic blocks for inner pages */
.promo-strip,
.quick-cta,
.dark-offer {
  padding: 22px;
  border-radius: 22px;
  border: 1px solid var(--line-soft);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.promo-strip h2,
.quick-cta h2,
.dark-offer h2 { margin: 0 0 8px; }
.promo-strip p,
.quick-cta p,
.dark-offer p { margin: 0; color: #c1d0e7; }

.cab-hero,
.app-hero {
  border: 1px solid var(--line-soft);
  border-radius: 24px;
  padding: 24px;
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 16px;
}

.cab-hero h1,
.app-hero h1 {
  margin: 0 0 10px;
  font-size: clamp(1.8rem, 3.7vw, 3rem);
  line-height: 1.05;
}

.cab-hero__lead,
.app-hero p { margin: 0; color: #c1d0e7; }

.cab-hero__stats,
.app-hero__stats {
  margin: 14px 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
}

.cab-hero__stats article,
.app-hero__stats article {
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255,255,255,.03);
}

.cab-hero__stats strong,
.app-hero__stats strong { display: block; margin-bottom: 3px; }

.cab-phone,
.app-phone {
  max-width: 320px;
  margin-left: auto;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.03);
  padding: 16px;
}

.cab-phone__title { margin: 0; color: #c1d0e7; font-size: .84rem; }
.cab-phone__sum { margin: 5px 0 10px; font-size: 1.7rem; font-weight: 800; }
.cab-phone__row { display: flex; justify-content: space-between; margin-bottom: 6px; }
.cab-phone__row span { color: #c1d0e7; }
.cab-phone__mini {
  margin-top: 10px;
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  background: rgba(255,255,255,.02);
  padding: 8px 10px;
  font-size: .8rem;
}

.cab-feature-grid,
.cab-tools-grid,
.app-benefits-grid,
.app-pay-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}

.cab-feature-grid .card,
.cab-tools-grid .card,
.app-benefits-grid .card,
.app-pay-grid .card,
.app-docs-list .card { padding: 16px; }

.cab-feature-grid h3,
.cab-tools-grid h3,
.app-benefits-grid h3,
.app-pay-grid h3 { margin: 0 0 8px; }

.cab-feature-grid p,
.cab-tools-grid p,
.app-benefits-grid p,
.app-pay-grid p { margin: 0; color: #c1d0e7; }

.cab-steps-layout { display: grid; grid-template-columns: 1.1fr .9fr; gap: 12px; }
.cab-steps-list { display: grid; gap: 10px; }
.cab-steps-list .card { padding: 14px; display: flex; gap: 10px; align-items: flex-start; }
.cab-steps-list strong {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: #031726;
  background: linear-gradient(135deg, var(--brand), #8ff5f1);
}
.cab-steps-list p { margin: 0; color: #c1d0e7; }

.cab-login { padding: 16px; }
.cab-login h3 { margin: 0 0 10px; }
.cab-login label {
  display: block;
  margin-bottom: 10px;
  color: #d4e3f9;
  font-size: .85rem;
  font-weight: 600;
}
.cab-login input {
  width: 100%;
  min-height: 40px;
  margin-top: 4px;
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  background: rgba(255,255,255,.03);
  color: #eaf2ff;
  padding: 8px 10px;
}

.cab-security {
  border: 1px solid var(--line-soft);
  border-radius: 22px;
  padding: 22px;
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
}
.cab-security h2 { margin: 0 0 12px; }
.cab-security__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.cab-security__grid article {
  border-radius: 12px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.03);
  padding: 12px;
}
.cab-security__grid h3 { margin: 0 0 6px; font-size: 1rem; }
.cab-security__grid p { margin: 0; color: #c1d0e7; }

.cab-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cab-compare .card { padding: 16px; }
.cab-compare h3 { margin: 0 0 8px; }
.cab-compare ul { margin: 0; padding-left: 18px; color: #c1d0e7; display: grid; gap: 6px; }

.app-store-buttons { display: flex; gap: 10px; flex-wrap: wrap; }
.app-hero__note { margin-top: 12px !important; font-size: .84rem; }

.app-phone { border-radius: 30px; }
.app-phone__screen {
  border-radius: 20px;
  padding: 14px;
  background: #f2fcff;
  color: #102940;
}
.app-phone__hello { margin: 0 0 5px !important; color: #5f7695 !important; font-size: .8rem; }
.app-phone__sum { margin: 0 0 8px !important; font-size: 1.55rem; font-weight: 800; }
.app-phone__screen button {
  min-height: 40px;
  width: 100%;
  border: 0;
  border-radius: 10px;
  color: #031726;
  font-weight: 700;
  background: linear-gradient(135deg, var(--brand), #8ff5f1);
}
.app-phone__grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 7px;
}
.app-phone__grid span {
  text-align: center;
  font-size: .72rem;
  border-radius: 8px;
  background: #dcf8ff;
  padding: 8px 4px;
}

.app-tabs,
.faq-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.app-tabs button,
.faq-tabs button {
  border: 1px solid var(--line);
  border-radius: 10px;
  min-height: 40px;
  padding: 8px 12px;
  color: #dce8ff;
  background: rgba(255,255,255,.03);
  font-weight: 700;
}
.app-tabs .is-active,
.faq-tabs .is-active {
  color: #031726;
  border-color: transparent;
  background: linear-gradient(135deg, var(--brand), #8ff5f1);
}

.app-panel {
  display: none;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 16px;
  gap: 16px;
}
.app-panel.is-active { display: grid; }
.app-panel__text h3 { margin: 0 0 8px; }
.app-panel__text ul { margin: 0; padding-left: 18px; color: #c1d0e7; display: grid; gap: 6px; }
.app-panel__flow { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; }
.app-panel__flow article {
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  text-align: center;
  padding: 12px 8px;
  font-size: 1.32rem;
  font-weight: 800;
}
.app-panel__flow span { display: block; margin-top: 4px; color: #c1d0e7; font-size: .75rem; font-weight: 600; }
.app-panel__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.app-panel__cards .card { padding: 12px; }
.app-panel__cards strong { display: block; margin-bottom: 3px; }
.app-panel__cards span { color: #c1d0e7; font-size: .8rem; }
.app-pay-grid span {
  display: inline-flex;
  margin-top: 8px;
  min-height: 24px;
  align-items: center;
  border-radius: 999px;
  padding: 3px 8px;
  background: rgba(72,216,210,.14);
  color: #bff5f2;
  font-size: .75rem;
}
.app-docs-list { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.app-profile { padding: 14px; }
.app-profile__name { margin: 0 0 6px; font-size: 1.2rem; font-weight: 800; }
.app-profile p { margin: 0; color: #c1d0e7; }
.app-profile__stats { margin-top: 10px; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.app-profile__stats span {
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  padding: 8px 10px;
  text-align: center;
  background: rgba(255,255,255,.03);
  font-weight: 700;
}
.app-shots { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; }
.app-shot {
  min-height: 220px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.03);
}
.app-shot p { margin: 0; font-weight: 700; color: #dce8ff; }

.table-wrap { overflow-x: auto; padding: 12px; }
.compare-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.compare-table th,
.compare-table td {
  text-align: left;
  border-bottom: 1px solid var(--line-soft);
  padding: 12px 10px;
}
.compare-table th { color: #dce8ff; font-size: .86rem; }
.compare-table td { color: #c1d0e7; }

/* Footer */
.site-footer {
  margin-top: 30px;
  border-top: 1px solid var(--line-soft);
  background: #0a0f16;
  color: #e1edff;
  padding: 54px 0 28px;
}

.site-footer__grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 18px; }
.site-footer__brand { display: inline-block; margin-bottom: 8px; font-size: 1.06rem; color: #f3f9ff; }
.site-footer__lead { margin: 0; color: #9fb1cc; }
.site-footer__title {
  margin: 0 0 10px;
  color: #d0dff5;
  font-size: .9rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.site-footer__links { margin: 0; padding: 0; list-style: none; }
.site-footer__links li { margin-bottom: 8px; }
.site-footer a { color: #f3f9ff; }
.site-footer__legal {
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.12);
  color: #8da2bf;
  font-size: .84rem;
}
.site-footer__legal p { margin: 0 0 8px; }

.mobile-sticky-cta {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 98;
  min-height: 50px;
  border-radius: 12px;
  display: none;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  color: #051726;
  background: linear-gradient(135deg, var(--brand), #8ff5f1);
  box-shadow: var(--shadow-2);
}

@media (max-width: 1120px) {
  .vault-hero__grid,
  .vault-screening,
  .vault-scenario,
  .vault-checklist,
  .cab-hero,
  .cab-steps-layout,
  .app-hero,
  .app-panel { grid-template-columns: 1fr; }

  .promo-strip,
  .quick-cta,
  .dark-offer { flex-direction: column; align-items: flex-start; }

  .cab-phone,
  .app-phone { margin-left: 0; }
}

@media (max-width: 900px) {
  .section,
  .vault-section { padding: 56px 0; }
  .vault-form-grid,
  .vault-tariffs,
  .quiz__answers,
  .cab-hero__stats,
  .cab-feature-grid,
  .cab-tools-grid,
  .cab-security__grid,
  .cab-compare,
  .app-hero__stats,
  .app-benefits-grid,
  .app-panel__flow,
  .app-panel__cards,
  .app-pay-grid,
  .app-docs-list,
  .app-profile__stats,
  .app-shots,
  .site-footer__grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  body.page { padding-bottom: 74px; }
  .mobile-sticky-cta { display: inline-flex; }
}

/* New logic layout: atlas */
.atlas-home { color: var(--text); }

.atlas-chip {
  margin: 0 0 12px;
  width: fit-content;
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 12px;
  color: #031726;
  background: linear-gradient(135deg, var(--brand), #9af8f3);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.atlas-hero { padding: 66px 0 30px; }

.atlas-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 14px;
}

.atlas-hero__copy,
.atlas-hero__stats {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-xl);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-2);
}

.atlas-hero__copy { padding: clamp(24px, 4vw, 50px); }

.atlas-hero__copy h1 {
  margin: 0 0 14px;
  max-width: 14ch;
  font-size: clamp(2.35rem, 5.8vw, 5.2rem);
  line-height: .88;
  letter-spacing: -.06em;
}

.atlas-hero__copy p {
  margin: 0 0 20px;
  max-width: 64ch;
  color: #c2cfe4;
}

.atlas-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.atlas-hero__stats {
  padding: 20px;
  display: grid;
  gap: 10px;
}

.atlas-hero__stats article {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.03);
  padding: 12px;
}

.atlas-hero__stats small {
  display: block;
  margin-bottom: 3px;
  color: #9eb1cd;
}

.atlas-hero__stats strong { color: #f2f8ff; }

.atlas-section { padding: 72px 0; }
.atlas-section--soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
}

.atlas-head { margin-bottom: 20px; }
.atlas-head p {
  margin: 0 0 8px;
  color: var(--brand);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.atlas-head h2 {
  margin: 0;
  font-size: clamp(1.85rem, 3.8vw, 3rem);
  line-height: .98;
  letter-spacing: -.04em;
}

.atlas-note {
  margin: 0;
  color: #b8c7df;
}

.atlas-card {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.atlas-goals {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}

.atlas-goal-btn {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  color: #eaf2ff;
  text-align: left;
  padding: 18px;
  cursor: pointer;
  transition: border-color .18s ease, transform .18s ease;
}

.atlas-goal-btn:hover { transform: translateY(-1px); }

.atlas-goal-btn strong {
  display: block;
  margin-bottom: 6px;
  font-size: 1rem;
}

.atlas-goal-btn span {
  color: #b6c7e0;
  font-size: .86rem;
}

.atlas-goal-btn.is-active {
  border-color: rgba(72,216,210,.5);
  background:
    radial-gradient(260px 100px at 100% 0, rgba(72,216,210,.16), transparent 62%),
    linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
}

.atlas-builder {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 12px;
}

.atlas-fields,
.atlas-result {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.atlas-field { margin-bottom: 14px; }
.atlas-field:last-child { margin-bottom: 0; }

.atlas-field label {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
  color: #d7e4fa;
}

.atlas-field strong { color: #fff; }
.atlas-field input[type="range"] { width: 100%; accent-color: var(--brand); }

.atlas-modes {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 8px;
}

.atlas-modes button {
  min-height: 40px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: #deebff;
  font-weight: 700;
  cursor: pointer;
}

.atlas-modes .is-active {
  color: #031726;
  border-color: transparent;
  background: linear-gradient(135deg, var(--brand), #9af8f3);
}

.atlas-result p {
  margin: 0 0 8px;
  color: #b6c6e0;
}

.atlas-total {
  margin: 10px 0;
  border: 1px solid rgba(72,216,210,.32);
  border-radius: 12px;
  padding: 12px;
  background: rgba(72,216,210,.08);
}

.atlas-total span {
  display: block;
  color: #c4f8f5;
}

.atlas-total strong {
  display: block;
  font-size: 2rem;
  letter-spacing: -.03em;
  color: #ecffff;
}

.atlas-flow {
  display: grid;
  gap: 14px;
}

.atlas-pipeline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 12px;
}

.atlas-pipeline__steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
}

.atlas-pipeline__steps article {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.03);
  padding: 12px;
}

.atlas-pipeline__steps article.is-active {
  border-color: rgba(72,216,210,.48);
  background: rgba(72,216,210,.08);
}

.atlas-pipeline__steps b {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  color: #031726;
  font-weight: 800;
  background: linear-gradient(135deg, var(--brand), #9af8f3);
}

.atlas-pipeline__steps h3 {
  margin: 8px 0 6px;
  font-size: .98rem;
}

.atlas-pipeline__steps p {
  margin: 0;
  color: #b9cae4;
  font-size: .84rem;
}

.atlas-pipeline__panel {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 16px;
}

.atlas-pipeline__panel p {
  margin: 0 0 10px;
  color: #bfd0e8;
}

.atlas-ready {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 18px;
  align-items: start;
}

.atlas-ready__card {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  background: linear-gradient(170deg, rgba(36,45,61,.95), rgba(24,31,43,.95));
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.atlas-check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin-bottom: 10px;
  color: #d6e3f8;
}

.atlas-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
  margin-top: 2px;
}

.atlas-ready__footer {
  margin-top: 12px;
  border-top: 1px solid var(--line-soft);
  padding-top: 12px;
}

.atlas-ready__footer p {
  margin: 0 0 10px;
  color: #d6e3f8;
}

.is-disabled {
  opacity: .5;
  pointer-events: none;
}

@media (max-width: 1120px) {
  .atlas-hero__grid,
  .atlas-builder,
  .atlas-pipeline,
  .atlas-ready,
  .atlas-pipeline__steps { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .atlas-section { padding: 56px 0; }
  .atlas-goals,
  .atlas-form-grid,
  .atlas-modes { grid-template-columns: 1fr; }
}
