/* =========================================================
   ГРУЗИ-ВЕЗИ — Новый сайт. Фирменная палитра сохранена.
   Главный синий: #5293e0, акцент бирюзовый: #02a1c5
   Зелёно-бирюзовый градиент — из мобильного приложения,
   используется только на CTA, ведущих в приложение.
   ========================================================= */

/* ===== RATE_BLOCK — компактный блок «Средние ставки по направлениям» ===== */
.rate-block {
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 16px;
  padding: 20px 22px;
}
.rate-head {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 16px 20px;
  align-items: center;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.rate-title { font-size: 20px; font-weight: 800; line-height: 1.2; margin: 0 0 4px; }
.rate-sub { font-size: 13px; color: var(--text-muted, #6b7280); margin: 0; }
.rate-ati {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: linear-gradient(135deg, #1e4d8f 0%, #5293e0 100%);
  color: #fff; border-radius: 999px;
  white-space: nowrap;
}
.rate-ati-lbl { font-size: 11px; letter-spacing: .04em; text-transform: uppercase; opacity: .85; }
.rate-ati-num { font-size: 16px; font-weight: 800; }
.rate-ati-link { color: #fff; opacity: .85; text-decoration: none; font-size: 14px; }
.rate-ati-link:hover { opacity: 1; }
.rate-select {
  padding: 8px 12px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  font: inherit; font-size: 14px;
  background: #fff;
}
.rate-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.rate-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 12px;
  align-items: baseline;
  padding: 10px 14px;
  border-radius: 8px;
  text-decoration: none;
  color: var(--text, #0c1a30);
  transition: background-color .15s ease;
}
.rate-row:hover { background: var(--brand-blue-light, #e8f0fc); }
.rate-route { font-size: 14.5px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rate-km { font-size: 12px; color: var(--text-muted, #6b7280); font-family: ui-monospace, 'JetBrains Mono', monospace; }
.rate-price { font-size: 14px; font-weight: 700; color: var(--brand-blue, #5293e0); white-space: nowrap; }
.rate-foot {
  margin: 16px 0 0;
  padding-top: 14px;
  border-top: 1px solid var(--border, #e2e8f0);
  font-size: 12px;
  color: var(--text-muted, #6b7280);
}
.rate-foot a { color: var(--brand-blue, #5293e0); text-decoration: none; font-weight: 600; }
@media (max-width: 720px) {
  .rate-head { grid-template-columns: 1fr; gap: 12px; }
  .rate-grid { grid-template-columns: 1fr; }
}
/* ===== /RATE_BLOCK ===== */

/* ===== GLOSSARY_GRID — компактный двухколоночный словарь ===== */
.glossary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 24px;
  max-width: 1080px;
  margin: 0 auto;
}
.gl-item {
  padding: 10px 0;
  font-size: 14.5px;
  line-height: 1.45;
  color: var(--text-soft, #4a5a72);
  border-top: 1px solid var(--border, #e2e8f0);
}
.gl-item:first-child,
.gl-item:nth-child(2) { border-top: 0; }
.gl-item b {
  color: var(--text, #0c1a30);
  font-weight: 700;
  white-space: nowrap;
}
@media (max-width: 720px) {
  .glossary-grid { grid-template-columns: 1fr; gap: 0; }
  .gl-item:nth-child(2) { border-top: 1px solid var(--border, #e2e8f0); }
}
/* ===== /GLOSSARY_GRID ===== */

/* ===== INSURANCE_MODAL — модалка страхования груза ===== */
.ins-info-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  margin-left: 4px;
  padding: 0;
  border: none;
  background: var(--brand-blue-light, #e8f0fc);
  color: var(--brand-blue, #5293e0);
  border-radius: 50%;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  font-family: inherit;
  vertical-align: middle;
  transition: background .2s ease;
}
.ins-info-btn:hover { background: var(--brand-blue, #5293e0); color: #fff; }

.ins-modal {
  width: 92%;
  max-width: 540px;
  border: 0;
  border-radius: 20px;
  padding: 0;
  background: #fff;
  box-shadow: 0 30px 80px -20px rgba(15,23,42,.4);
}
.ins-modal::backdrop { background: rgba(15,23,42,.55); backdrop-filter: blur(4px); }
.ins-modal-body { padding: 32px 28px 24px; position: relative; }
.ins-modal-close {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  border: 0; border-radius: 50%;
  background: var(--bg-soft, #f5f8fc);
  color: var(--text, #0c1a30);
  font-size: 24px; line-height: 1;
  cursor: pointer;
  transition: background .2s ease;
  z-index: 10;
}
.ins-modal-close:hover { background: var(--brand-blue-light, #e8f0fc); }
.ins-modal-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px; height: 56px;
  margin-bottom: 16px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--accent, #ff8a3d) 0%, var(--accent-dark, #e66a1e) 100%);
  color: #fff;
  box-shadow: 0 8px 20px var(--accent-glow, rgba(255,138,61,.35));
}
.ins-modal h3 { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.ins-modal h4 { font-size: 14px; font-weight: 700; color: var(--text-muted, #6b7280); text-transform: uppercase; letter-spacing: .06em; }
.ins-modal-lede { color: var(--text-muted, #6b7280); margin-bottom: 20px; line-height: 1.5; }
.ins-modal-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  background: var(--bg-soft, #f5f8fc);
  padding: 16px; border-radius: 12px;
}
.ins-modal-item { display: flex; flex-direction: column; gap: 4px; }
.ins-num { font-size: 18px; font-weight: 800; color: var(--brand-blue, #5293e0); line-height: 1.1; }
.ins-label { font-size: 12px; color: var(--text-muted, #6b7280); }
.ins-list { list-style: none; padding: 0; margin: 0; }
.ins-list li {
  position: relative;
  padding: 6px 0 6px 24px;
  font-size: 14px;
  color: var(--text, #0c1a30);
}
.ins-list li::before {
  content: '✓';
  position: absolute; left: 0; top: 6px;
  color: var(--brand-blue, #5293e0); font-weight: 700;
}
.ins-fine { font-size: 13px; color: var(--text-muted, #6b7280); line-height: 1.55; }
.ins-modal-actions {
  display: flex; gap: 10px; margin-top: 24px;
  padding-top: 20px; border-top: 1px solid var(--border, #e2e8f0);
  flex-wrap: wrap;
}
.ins-modal-actions .btn { flex: 1; min-width: 140px; }
@media (max-width: 540px) {
  .ins-modal { width: 96%; }
  .ins-modal-body { padding: 24px 18px 18px; }
  .ins-modal-grid { grid-template-columns: 1fr; }
}
/* ===== /INSURANCE_MODAL ===== */

/* ===== ADDRESS_AUTOCOMPLETE — выпадающий список подсказок адресов ===== */
.form-group { position: relative; }
.addr-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 50;
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 12px;
  box-shadow: 0 16px 40px -8px rgba(15, 23, 42, 0.18), 0 4px 8px -2px rgba(15, 23, 42, 0.08);
  max-height: 320px;
  overflow-y: auto;
  padding: 6px;
  font-family: inherit;
  scrollbar-width: thin;
}
.addr-dropdown[hidden] { display: none !important; }
.addr-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  background: transparent;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  color: var(--text, #0c1a30);
  text-align: left;
  transition: background-color .15s ease;
}
.addr-item:hover,
.addr-item.is-active,
.addr-item:focus-visible {
  background: var(--brand-blue-light, #e8f0fc);
  outline: none;
}
.addr-icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--brand-blue-light, #e8f0fc);
  color: var(--brand-blue, #5293e0);
}
.addr-icon svg { width: 16px; height: 16px; }
.addr-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}
.addr-main {
  font-weight: 500;
  color: var(--text, #0c1a30);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.addr-sub {
  font-size: 12px;
  color: var(--text-muted, #6b7280);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 720px) {
  .addr-dropdown { max-height: 60vh; }
  .addr-item { padding: 12px 10px; font-size: 15px; }
}
/* ===== /ADDRESS_AUTOCOMPLETE ===== */



/* ===== UNIFIED_HEADER — иконка телефона по центру в круглой кнопке =====
   На мобиле скрываем текст внутри .phone-link, чтобы SVG был ровно по центру круга */
@media (max-width: 720px) {
  .phone-link .phone-text { display: none !important; }
}
/* ===== /UNIFIED_HEADER ===== */

/* ===== HIDDEN_TEMP_TRACKING — временная заглушка отслеживания =====
   Скрываем только живые ссылки на track.html (страница в стадии разработки).
   .tracking-widget на for-clients.html — это статичная mock-карточка
   (демонстрация будущей функции), её не скрываем. */
.track-link,
a[href="track.html"],
a[href^="track.html?"],
a[href*="/track.html"] { display: none !important; }
/* Прячем родительский <li> в футере/меню, если внутри только ссылка на трекинг */
li:has(> a[href="track.html"]),
li:has(> a[href^="track.html?"]) { display: none !important; }
/* ===== /HIDDEN_TEMP_TRACKING ===== */

:root {
    /* Brand (с текущего сайта — сохранено) */
    --brand-blue: #5293e0;
    --brand-blue-dark: #3d7bc7;
    --brand-blue-deep: #1e4d8f;
    --brand-blue-light: #e8f0fc;
    --brand-cyan: #02a1c5;
    --brand-cyan-dark: #018aa6;
    /* === V18: тёплый акцент для CTA — янтарь === */
    --accent: #ff8a3d;
    --accent-dark: #e66a1e;
    --accent-light: #fff1e6;
    --accent-glow: rgba(255, 138, 61, .35);

    /* Из мобильного приложения — для интеграционных CTA */
    --app-green: #1FBA72;
    --app-cyan: #0EA5C0;
    --app-gradient: linear-gradient(90deg, #1FBA72 0%, #0EA5C0 100%);

    /* Нейтральные */
    --bg: #ffffff;
    --bg-soft: #f5f4fc;        /* как у Tilda — мягкий фон секций */
    --bg-dark: #0d1426;
    --text: #1a1a2e;
    --text-secondary: #6b7080;
    --text-muted: #9ba0ad;
    --border: #e5e7ee;
    --border-light: #f1f2f6;

    /* Сигнальные */
    --success: #1FBA72;
    --warning: #f5b03a;
    --danger: #e6386a;

    /* Тени и радиусы */
    --shadow-sm: 0 2px 8px rgba(82, 147, 224, 0.08);
    --shadow-md: 0 8px 24px rgba(82, 147, 224, 0.12);
    --shadow-lg: 0 16px 48px rgba(82, 147, 224, 0.16);
    --radius-sm: 12px;
    --radius-md: 18px;
    --radius-lg: 28px;
    --radius-pill: 999px;

    /* Контейнеры */
    --container: 1200px;
    --container-narrow: 920px;

    /* Цвет фона страницы и заголовков (для тёмной темы переопределяется) */
    --heading: var(--text);
    --bg-page: #ffffff;
    --bg-card: #ffffff;
}

/* ========== Тёмная тема ========== */
:root[data-theme="dark"] {
    --bg: #0e1a2e;
    --bg-soft: #15233f;
    --bg-page: #0a1426;
    --bg-card: #15233f;
    --bg-dark: #050b18;
    --text: #e8edf5;
    --text-secondary: #a8b2c7;
    --text-muted: #6b7891;
    --heading: #ffffff;
    --border: #243859;
    --border-light: #1d2c47;
    --brand-blue-light: rgba(82, 147, 224, 0.15);
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.25);
    --shadow-md: 0 8px 24px rgba(0, 0, 0, 0.35);
    --shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.45);
}
:root[data-theme="dark"] body { background: var(--bg-page); }

/* Плавный переход цветов при смене темы */
html, body, .site-header, .site-footer, .nav-dropdown, .form-card, .panel,
.tariff-card, .feature-card, .review-card, .step, .faq-item {
    transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}

/* ========== Кнопка переключения темы в header ========== */
.theme-toggle {
    width: 36px; height: 36px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text);
    display: grid; place-items: center;
    cursor: pointer;
    margin-right: 8px;
    flex-shrink: 0;
    transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.theme-toggle:hover { border-color: var(--brand-blue); transform: scale(1.05); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
:root[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
:root[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* ========== Toast-нотификации ========== */
.toast-container {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    display: flex; flex-direction: column-reverse;
    gap: 10px;
    pointer-events: none;
}
.toast {
    background: #1a1a2e;
    color: #fff;
    padding: 12px 22px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 8px 32px rgba(0,0,0,.25);
    opacity: 0;
    transform: translateY(16px);
    transition: opacity .25s ease, transform .25s ease;
    pointer-events: auto;
    max-width: 88vw;
    text-align: center;
}
.toast.show { opacity: 1; transform: translateY(0); }
:root[data-theme="dark"] .toast { background: var(--brand-blue); }

/* ========== View Transitions API ========== */
@view-transition { navigation: auto; }
::view-transition-old(root) {
    animation: gv-fade-out .22s ease forwards;
}
::view-transition-new(root) {
    animation: gv-fade-in .26s ease forwards;
}
@keyframes gv-fade-out { to { opacity: 0; transform: translateY(-8px); } }
@keyframes gv-fade-in  { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* ========== Value-grid: «что входит в цену» ========== */
.value-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
}
.value-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 26px 24px;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.value-card:hover {
    transform: translateY(-3px);
    border-color: var(--brand-blue);
    box-shadow: 0 12px 32px rgba(82, 147, 224, 0.14);
}
.value-card.highlight {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
    color: #fff;
    border: none;
}
.value-card.highlight h4, .value-card.highlight p { color: #fff; }
.value-card.highlight p { opacity: .92; }
.value-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: var(--brand-blue-light);
    color: var(--brand-blue);
    display: grid; place-items: center;
    margin-bottom: 16px;
}
.value-card.highlight .value-icon {
    background: rgba(255,255,255,.18);
    color: #fff;
}
.value-icon svg { width: 24px; height: 24px; }
.value-card h4 {
    margin: 0 0 8px;
    font-size: 17px;
    font-weight: 700;
    color: var(--heading);
}
.value-card p {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-secondary);
}

/* ========== Hero — глобус, повёрнутый Россией ========== */
/* (вращение отключено — глобус статичен, без 2D-кручения) */
.globe-rotor { /* no animation */ }
.hero-globe {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}
.hero-globe svg {
    max-width: 100%;
    height: auto;
    filter: drop-shadow(0 24px 60px rgba(82, 147, 224, 0.25));
}
.hero-globe-stats {
    display: flex;
    gap: 28px;
    padding: 16px 24px;
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(8px);
    border: 1px solid var(--border-light);
    border-radius: 100px;
    box-shadow: 0 4px 16px rgba(82, 147, 224, 0.08);
}
.hgs-item { text-align: center; }
.hgs-num {
    display: block;
    font-size: 22px;
    font-weight: 800;
    color: var(--brand-blue);
    line-height: 1;
    font-feature-settings: 'tnum';
}
.hgs-lbl {
    display: block;
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-top: 3px;
}

/* ========== Hero — карта России с маршрутами ========== */
.hero-russia-map {
    background: #fff;
    border-radius: 28px;
    padding: 28px;
    box-shadow: 0 20px 60px rgba(82, 147, 224, 0.18), 0 4px 12px rgba(82, 147, 224, 0.08);
    border: 1px solid var(--border-light);
}
.hero-russia-map svg { width: 100%; height: auto; display: block; }
.hero-russia-stats {
    display: flex;
    justify-content: space-around;
    gap: 16px;
    padding: 18px 0 4px;
    margin-top: 8px;
    border-top: 1px solid var(--border-light);
}
.hrs-item { text-align: center; }
.hrs-num {
    display: block;
    font-size: 26px;
    font-weight: 800;
    color: var(--brand-blue);
    line-height: 1;
    margin-bottom: 4px;
    font-feature-settings: 'tnum';
}
.hrs-lbl {
    display: block;
    font-size: 12px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* ========== Hero quick-калькулятор ========== */

.hqc-presets {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}
.hqc-preset {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: rgba(255,255,255,.85);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
    cursor: pointer;
    transition: all .18s ease;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.hqc-preset:hover {
    background: var(--brand-blue);
    color: #fff;
    border-color: var(--brand-blue);
    transform: translateY(-1px);
}
.hqc-preset.active {
    background: var(--brand-blue);
    color: #fff;
    border-color: var(--brand-blue);
}
.hqc-preset-emoji { font-size: 15px; line-height: 1; }

.hero-quick-calc {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 18px;
    box-shadow: 0 12px 40px rgba(82, 147, 224, 0.12);
    max-width: 540px;
    margin-bottom: 6px;
}

.hqc-route { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.hqc-field {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fafbff;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 0 14px;
    transition: border-color .2s ease;
}
.hqc-field:focus-within { border-color: var(--brand-blue); background: #fff; }
.hqc-dot {
    width: 12px; height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}
.hqc-dot.a { background: var(--app-green); box-shadow: 0 0 0 3px rgba(31, 186, 114, 0.2); }
.hqc-dot.b {
    background: #f5b03a;
    border-radius: 0;
    transform: rotate(45deg);
    width: 10px; height: 10px;
}
.hqc-field input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 12px 0;
    font: inherit;
    font-size: 14px;
    outline: none;
    min-width: 0;
}
.hqc-geo {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 6px;
    border-radius: 8px;
    display: grid; place-items: center;
}
.hqc-geo:hover { color: var(--brand-blue); background: var(--brand-blue-light); }
.hqc-geo svg { width: 18px; height: 18px; }

.hqc-add-stop {
    align-self: flex-start;
    background: transparent;
    border: 1px dashed var(--border);
    border-radius: 10px;
    padding: 6px 12px;
    color: var(--text-muted);
    font-size: 12.5px;
    cursor: pointer;
    margin-top: 2px;
}
.hqc-add-stop:hover { border-color: var(--brand-blue); color: var(--brand-blue); }

.hqc-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 12px;
    align-items: center;
}
@media (max-width: 540px) { .hqc-row { grid-template-columns: 1fr; } }

.hqc-row select {
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: 12px;
    font: inherit;
    font-size: 14px;
    background: #fafbff;
}
.hqc-check {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: #f0f9f3;
    border: 1px solid #bee0c8;
    border-radius: 12px;
    font-size: 13px;
    color: #166534;
    cursor: pointer;
}
.hqc-check input { margin: 0; flex-shrink: 0; }

.hqc-submit { width: 100%; }
.hqc-submit svg { vertical-align: middle; }

.hqc-result {
    margin-top: 14px;
    padding: 14px 16px;
    background: linear-gradient(135deg, #eef4fc, #f0f9fb);
    border-radius: 12px;
}
.hqc-result.show { animation: gv-fade-in .3s ease; }
.hqc-result h4 { margin: 0 0 8px; font-size: 15px; color: var(--brand-blue); }
.hqc-result-row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.hqc-result-row.total { font-size: 18px; font-weight: 800; padding-top: 8px; border-top: 1px solid rgba(82,147,224,.2); margin-top: 6px; color: var(--brand-blue); }

/* ========== Live-карта свободных машин ========== */
.lm-stat {
    background: rgba(255,255,255,.08);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 14px;
    padding: 14px 20px;
    min-width: 160px;
}
.lm-stat .num { font-size: 24px; font-weight: 800; color: #5eead4; }
.lm-stat .lbl { font-size: 12px; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: .04em; }
.lm-pulse {
    width: 14px; height: 14px;
    border-radius: 50%;
    background: #1FBA72;
    box-shadow: 0 0 0 0 rgba(31, 186, 114, .8);
    animation: lm-pulse 2s infinite;
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px;
}
@keyframes lm-pulse {
    0% { box-shadow: 0 0 0 0 rgba(31, 186, 114, .9); }
    70% { box-shadow: 0 0 0 14px rgba(31, 186, 114, 0); }
    100% { box-shadow: 0 0 0 0 rgba(31, 186, 114, 0); }
}
.live-truck-marker {
    position: absolute;
    width: 28px; height: 28px;
    background: #5293e0;
    border: 2px solid #fff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,.4);
    display: grid; place-items: center;
    transition: transform .8s cubic-bezier(.4, 0, .2, 1);
    z-index: 3;
}
.live-truck-marker svg { width: 16px; height: 16px; color: #fff; }
.live-truck-marker.moving { animation: lm-truck-bob 1s ease-in-out infinite; }
@keyframes lm-truck-bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }

/* ========== Реферальная программа ========== */
.referral-code-card {
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 18px;
    padding: 24px;
    text-align: center;
    position: relative;
    z-index: 2;
}
.referral-code-label { font-size: 12px; opacity: .8; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.referral-code {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 28px;
    font-weight: 800;
    letter-spacing: .12em;
    background: rgba(0,0,0,.2);
    padding: 12px 20px;
    border-radius: 10px;
    margin-bottom: 14px;
    display: inline-block;
}
.referral-copy-btn {
    background: #fff;
    color: #1FBA72;
    border: none;
    padding: 10px 20px;
    border-radius: 999px;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
    font-size: 14px;
}
.referral-copy-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }

/* ========== Tooltips на тарифных карточках ========== */
.tariff-tooltip {
    position: relative;
    display: inline-block;
    margin-left: 4px;
    color: var(--text-muted);
    cursor: help;
}
.tariff-tooltip svg { width: 14px; height: 14px; vertical-align: -2px; }
.tariff-tooltip:hover { color: var(--brand-blue); }
.tariff-tooltip .tooltip-content {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: #1a1a2e;
    color: #fff;
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 12.5px;
    line-height: 1.4;
    width: 220px;
    text-align: left;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
    z-index: 100;
    font-weight: 400;
    cursor: default;
}
.tariff-tooltip:hover .tooltip-content { opacity: 1; }
.tariff-tooltip .tooltip-content::after {
    content: '';
    position: absolute;
    top: 100%; left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #1a1a2e;
}

/* ========== Реестр ПО / комплаенс-блок в footer ========== */
.compliance-row {
    display: flex; gap: 24px; flex-wrap: wrap;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,.08);
    font-size: 12px;
    color: rgba(255,255,255,.5);
}
.compliance-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 999px;
    padding: 6px 12px;
    color: rgba(255,255,255,.75);
}
.compliance-badge svg { width: 14px; height: 14px; }


/* ========== Skeleton-loader для тарифов ========== */
@keyframes gv-skeleton-pulse {
    0%, 100% { opacity: .5; }
    50% { opacity: 1; }
}
.skeleton {
    display: inline-block;
    background: linear-gradient(90deg, var(--border) 0%, var(--border-light) 50%, var(--border) 100%);
    background-size: 200% 100%;
    animation: gv-skeleton-pulse 1.4s ease-in-out infinite;
    border-radius: 6px;
    color: transparent;
}

/* =========================================================
   Сброс и базовые
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: 'Inter', 'Segoe UI', -apple-system, BlinkMacSystemFont, Arial, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: var(--text);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--brand-blue); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--brand-blue-dark); }
button { font-family: inherit; cursor: pointer; }
h1, h2, h3, h4 { margin: 0 0 .6em; line-height: 1.2; font-weight: 700; letter-spacing: -.01em; }
h1 { font-size: clamp(2rem, 4.2vw, 3.4rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.6rem); }
h4 { font-size: 1.1rem; }
p  { margin: 0 0 1em; color: var(--text-secondary); }
ul, ol { margin: 0 0 1em; padding-left: 1.2em; color: var(--text-secondary); }
li { margin-bottom: .35em; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 24px; }
section { padding: 80px 0; }
@media (max-width: 768px) { section { padding: 56px 0; } }

/* Утилиты */
.text-center { text-align: center; }
.eyebrow {
    display: inline-block;
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--brand-cyan);
    background: rgba(2, 161, 197, .08);
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    margin-bottom: 18px;
}
.section-title { margin-bottom: 14px; }
.section-subtitle { color: var(--text-secondary); max-width: 640px; margin: 0 auto 48px; font-size: 1.05rem; }
.section-head { text-align: center; margin-bottom: 56px; }

/* =========================================================
   Кнопки
   ========================================================= */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 28px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: var(--radius-pill);
    border: none;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
    text-decoration: none;
    white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
    background: var(--brand-blue);
    color: #fff;
    box-shadow: 0 6px 20px rgba(82, 147, 224, .35);
}
.btn-primary:hover { background: var(--brand-blue-dark); color: #fff; }
.btn-outline {
    background: transparent;
    color: var(--brand-blue);
    border: 2px solid var(--brand-blue);
}
.btn-outline:hover { background: var(--brand-blue); color: #fff; }
.btn-ghost {
    background: rgba(255,255,255,.12);
    color: #fff;
    border: 1px solid rgba(255,255,255,.3);
    backdrop-filter: blur(6px);
}
.btn-ghost:hover { background: rgba(255,255,255,.22); color: #fff; }
.btn-app {
    background: var(--app-gradient);
    color: #fff;
    box-shadow: 0 6px 20px rgba(31, 186, 114, .35);
}
.btn-app:hover { color: #fff; filter: brightness(1.05); }
.btn-lg { padding: 18px 36px; font-size: 1.06rem; }
.btn-sm { padding: 10px 18px; font-size: .9rem; }
.btn-block { width: 100%; }

/* =========================================================
   Header / навигация — mega-menu, sticky, современный
   ========================================================= */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255,255,255,.94);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border-light);
    transition: box-shadow .25s ease;
}
.site-header.scrolled { box-shadow: 0 6px 24px rgba(82, 147, 224, .08); }

.header-inner {
    display: flex;
    align-items: center;
    height: 76px;
    gap: 32px;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px;
}
.logo {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -.02em;
    flex-shrink: 0;
}
.logo:hover { color: var(--text); }
.logo-mark {
    width: 40px; height: 40px;
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
    border-radius: 12px;
    display: grid;
    place-items: center;
    color: #fff;
    box-shadow: 0 4px 14px rgba(82,147,224,.35);
}
.logo-mark svg { width: 22px; height: 22px; }

/* === Главное меню с dropdown === */
.nav {
    display: flex;
    gap: 4px;
    flex: 1;
}
.nav-item {
    position: relative;
}
.nav-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text);
    font-weight: 500;
    padding: 10px 16px;
    border-radius: var(--radius-pill);
    font-size: .95rem;
    transition: background .2s ease, color .2s ease;
    cursor: pointer;
    background: none;
    border: none;
    font-family: inherit;
}
.nav-link:hover,
.nav-item:hover .nav-link,
.nav-item.active > .nav-link {
    background: var(--brand-blue-light);
    color: var(--brand-blue-dark);
}
.nav-link .chev {
    width: 14px; height: 14px;
    transition: transform .2s ease;
    color: var(--text-muted);
}
.nav-item:hover .nav-link .chev { transform: rotate(180deg); color: var(--brand-blue); }

/* === Dropdown panel === */
.nav-dropdown {
    position: absolute;
    top: calc(100% + 14px);
    left: 0;
    background: #fff;
    border-radius: var(--radius-md);
    box-shadow: 0 12px 40px rgba(82, 147, 224, .15), 0 4px 12px rgba(0,0,0,.05);
    border: 1px solid var(--border-light);
    padding: 14px;
    min-width: 320px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all .22s cubic-bezier(.2, .8, .3, 1);
    pointer-events: none;
}
.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}
.nav-dropdown::before {
    /* Невидимая «подложка» сверху, чтобы курсор не «терял» меню */
    content: '';
    position: absolute;
    top: -16px; left: 0; right: 0;
    height: 16px;
}

.nav-dropdown-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 14px;
    border-radius: var(--radius-sm);
    color: var(--text);
    transition: background .15s ease;
}
.nav-dropdown-item:hover {
    background: var(--bg-soft);
    color: var(--brand-blue-dark);
}
.nav-dropdown-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    background: var(--brand-blue-light);
    color: var(--brand-blue);
    display: grid; place-items: center;
    flex-shrink: 0;
    transition: background .15s ease;
}
.nav-dropdown-item:hover .nav-dropdown-icon {
    background: var(--brand-blue);
    color: #fff;
}
.nav-dropdown-icon svg { width: 18px; height: 18px; }
/* Текстовый блок справа от иконки в dropdown-пункте */
.nav-dropdown-item > span:last-child {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}
.nav-dropdown-title {
    display: block;
    font-weight: 600;
    font-size: .92rem;
    color: var(--text);
    line-height: 1.3;
}
.nav-dropdown-desc {
    display: block;
    font-size: .78rem;
    color: var(--text-muted);
    line-height: 1.4;
}
.nav-dropdown.wide { min-width: 480px; display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }

/* === Действия в шапке === */
.header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.phone-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text);
    font-weight: 600;
    font-size: .96rem;
    padding: 8px 4px;
}
.phone-link:hover { color: var(--brand-blue); }
.phone-link svg { width: 18px; height: 18px; color: var(--brand-cyan); }

.burger {
    display: none;
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
}
.burger span {
    display: block;
    width: 26px;
    height: 2px;
    background: var(--text);
    margin: 5px 0;
    transition: .3s;
    border-radius: 2px;
}

@media (max-width: 1100px) {
    .nav { gap: 2px; }
    .nav-link { padding: 10px 12px; font-size: .9rem; }
    .header-inner { gap: 16px; padding: 0 24px; }
    .phone-link { display: none; }
}
@media (max-width: 900px) {
    .nav { display: none; }
    .burger { display: block; }
    .header-inner { height: 64px; padding: 0 20px; }
    .header-actions .btn { display: none; }
    .header-actions { gap: 8px; }
}

/* === Мобильное меню (slide-in справа) === */
.mobile-menu {
    position: fixed;
    inset: 0;
    background: var(--bg);
    z-index: 200;
    transform: translateX(100%);
    transition: transform .3s ease;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}
.mobile-menu.open { transform: translateX(0); }
.mobile-menu-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 20px;
    border-bottom: 1px solid var(--border-light);
    position: sticky;
    top: 0;
    background: var(--bg);
    z-index: 1;
}
.mobile-menu-close {
    background: var(--bg-soft);
    border: none;
    width: 40px; height: 40px;
    border-radius: 50%;
    font-size: 1.6rem;
    line-height: 1;
    display: grid;
    place-items: center;
    color: var(--text);
    cursor: pointer;
}
.mobile-menu-body {
    padding: 20px;
    flex: 1;
}

/* Accordion для dropdown в мобильном меню */
.m-section { margin-bottom: 4px; }
.m-section-toggle {
    width: 100%;
    background: none;
    border: none;
    padding: 16px 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: inherit;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background .15s ease;
    text-align: left;
}
.m-section-toggle:hover { background: var(--bg-soft); }
.m-section-toggle .chev {
    width: 18px; height: 18px;
    color: var(--text-muted);
    transition: transform .2s ease;
}
.m-section.open .m-section-toggle { background: var(--brand-blue-light); color: var(--brand-blue-dark); }
.m-section.open .m-section-toggle .chev { transform: rotate(180deg); color: var(--brand-blue); }
.m-section-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
}
.m-section.open .m-section-body { max-height: 500px; padding-bottom: 8px; }
.m-section-body a {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px 12px 24px;
    color: var(--text-secondary);
    font-size: .96rem;
    border-radius: var(--radius-sm);
}
.m-section-body a:hover { color: var(--brand-blue); background: var(--bg-soft); }
.m-section-body .micon {
    width: 28px; height: 28px;
    border-radius: 8px;
    background: var(--brand-blue-light);
    color: var(--brand-blue);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.m-section-body .micon svg { width: 14px; height: 14px; }

.mobile-menu .single-link {
    display: block;
    padding: 16px 12px;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text);
    border-radius: var(--radius-sm);
}
.mobile-menu .single-link:hover { background: var(--bg-soft); color: var(--brand-blue); }
.mobile-menu .single-link.active { background: var(--brand-blue-light); color: var(--brand-blue-dark); }

.mobile-menu-foot {
    padding: 20px;
    border-top: 1px solid var(--border-light);
    background: var(--bg-soft);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
body.menu-open { overflow: hidden; }

/* =========================================================
   Hero
   ========================================================= */
.hero {
    position: relative;
    overflow: hidden;
    padding: 100px 0 120px;
    background:
        radial-gradient(circle at 85% 20%, rgba(2,161,197,.12), transparent 50%),
        radial-gradient(circle at 15% 80%, rgba(82,147,224,.10), transparent 50%),
        var(--bg-soft);
}
.hero-grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 64px;
    align-items: center;
}
.hero h1 { letter-spacing: -.02em; }
.hero h1 .accent { color: var(--brand-blue); }
.hero-lead { font-size: 1.15rem; color: var(--text-secondary); margin-bottom: 36px; max-width: 540px; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 14px; margin-top: 48px;
    padding-top: 28px;
    border-top: 1px solid var(--border);
}
.hero-stat .num { font-size: 1.8rem; font-weight: 800; color: var(--brand-blue); letter-spacing: -.02em; }
.hero-stat .lbl { font-size: .88rem; color: var(--text-muted); }

.hero-visual { position: relative; }
.phone-mockup {
    position: relative;
    width: 320px;
    margin: 0 auto;
    aspect-ratio: 320/650;
    background: #1a1a2e;
    border-radius: 44px;
    padding: 12px;
    box-shadow: 0 30px 80px rgba(82,147,224,.35), 0 10px 30px rgba(0,0,0,.15);
}
.phone-mockup::before {
    content: '';
    position: absolute; top: 14px; left: 50%; transform: translateX(-50%);
    width: 110px; height: 22px;
    background: #1a1a2e;
    border-radius: 0 0 16px 16px;
    z-index: 2;
}
.phone-screen {
    background: var(--bg-soft);
    border-radius: 32px;
    height: 100%;
    overflow: hidden;
    position: relative;
    display: flex;
    flex-direction: column;
}
.phone-status {
    background: var(--bg-soft);
    height: 38px;
    display: flex; align-items: flex-end; justify-content: center;
    padding-bottom: 4px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--text);
}
.phone-content { flex: 1; padding: 16px; overflow: hidden; }

@media (max-width: 900px) {
    .hero { padding: 60px 0 80px; }
    .hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .hero-visual { order: -1; }
    .phone-mockup { width: 260px; }
    .hero-stats { grid-template-columns: repeat(3, 1fr); gap: 8px; }
    .hero-stat .num { font-size: 1.4rem; }
}

/* =========================================================
   Карточки преимуществ
   ========================================================= */
.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
}
.feature-card {
    background: #fff;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 32px 28px;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.feature-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: var(--brand-blue-light);
}
.feature-icon {
    width: 56px; height: 56px;
    border-radius: 16px;
    background: var(--brand-blue-light);
    color: var(--brand-blue);
    display: grid; place-items: center;
    margin-bottom: 18px;
}
.feature-icon svg { width: 28px; height: 28px; }
.feature-card h4 { color: var(--text); margin-bottom: 8px; }
.feature-card p { font-size: .95rem; margin: 0; }

/* =========================================================
   Шаги "Как работает"
   ========================================================= */
.steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 22px;
}
.step {
    background: #fff;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 28px 24px;
    position: relative;
}
.step-num {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--brand-blue);
    color: #fff;
    display: grid; place-items: center;
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 14px;
    box-shadow: 0 6px 16px rgba(82,147,224,.35);
}
.step h4 { color: var(--text); margin-bottom: 8px; font-size: 1.05rem; }
.step p { font-size: .92rem; margin: 0; }

/* =========================================================
   Калькулятор и формы
   ========================================================= */
.form-card {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 40px;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--border-light);
}
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}
.form-row.single { grid-template-columns: 1fr; }
.form-group { display: flex; flex-direction: column; }
.form-group label {
    font-size: .85rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
}
.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 14px 16px;
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 1rem;
    font-family: inherit;
    color: var(--text);
    background: #fff;
    transition: border-color .2s ease, box-shadow .2s ease;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 4px rgba(82,147,224,.12);
}
.form-group textarea { min-height: 100px; resize: vertical; }
.form-hint { font-size: .82rem; color: var(--text-muted); margin-top: 6px; }
.form-checkbox { display: flex; align-items: flex-start; gap: 10px; font-size: .88rem; color: var(--text-secondary); margin-bottom: 18px; }
.form-checkbox input { margin-top: 3px; }
@media (max-width: 640px) {
    .form-card { padding: 28px 22px; }
    .form-row { grid-template-columns: 1fr; }
}

/* =========================================================
   Тарифы
   ========================================================= */
.tariffs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 22px;
}
.tariff-card {
    background: #fff;
    border: 1.5px solid var(--border);
    border-radius: var(--radius-md);
    padding: 32px 28px;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
    position: relative;
}
.tariff-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--brand-blue); }
.tariff-card.featured { border-color: var(--brand-blue); box-shadow: var(--shadow-md); }
.tariff-card.featured::before {
    content: 'Популярный';
    position: absolute;
    top: -14px; left: 28px;
    background: var(--brand-blue);
    color: #fff;
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    font-size: .78rem;
    font-weight: 600;
}
/* Иконка тарифа — простой outline-фургон в светло-синей плашке */
.tariff-truck {
    width: 80px;
    height: 60px;
    background: var(--brand-blue-light);
    border-radius: var(--radius-sm);
    display: grid;
    place-items: center;
    margin-bottom: 18px;
    color: var(--brand-blue);
}
.tariff-truck svg {
    width: 44px;
    height: 44px;
    color: inherit;
}
.tariff-card .tariff-price .num { font-size: 2rem; }
.tariff-card .tariff-price .num small { font-size: .9rem; }
.tariff-name { font-size: 1.2rem; font-weight: 700; margin-bottom: 4px; color: var(--text); }
.tariff-desc { font-size: .88rem; color: var(--text-muted); margin-bottom: 18px; }
.tariff-price { display: baseline; margin-bottom: 18px; }
.tariff-price .from { font-size: .88rem; color: var(--text-muted); display: block; }
.tariff-price .num { font-size: 2rem; font-weight: 800; color: var(--brand-blue); }
.tariff-price .num small { font-size: .9rem; font-weight: 500; color: var(--text-muted); }
.tariff-list { list-style: none; padding: 0; margin: 0 0 24px; }
.tariff-list li { padding: 6px 0 6px 26px; position: relative; font-size: .92rem; color: var(--text-secondary); }
.tariff-list li::before {
    content: '';
    position: absolute; left: 0; top: 11px;
    width: 16px; height: 16px;
    background: var(--brand-cyan);
    mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='%23000' d='M6.4 11.4 3 8l1.4-1.4L6.4 8.6 11.6 3.4 13 4.8z'/></svg>") center/contain no-repeat;
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='%23000' d='M6.4 11.4 3 8l1.4-1.4L6.4 8.6 11.6 3.4 13 4.8z'/></svg>") center/contain no-repeat;
}

/* =========================================================
   Секция "Скачать приложение"
   ========================================================= */
.app-section {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
}
.app-section::before {
    content: '';
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 20% 20%, rgba(255,255,255,.15) 0, transparent 40%),
        radial-gradient(circle at 80% 80%, rgba(255,255,255,.10) 0, transparent 40%);
}
.app-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 60px; align-items: center; position: relative; z-index: 1; }
.app-section h2 { color: #fff; }
.app-section p { color: rgba(255,255,255,.85); font-size: 1.05rem; }
.app-buttons { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 24px; align-items: center; }
.store-btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: #000;
    color: #fff;
    padding: 10px 20px;
    border-radius: 12px;
    transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
    border: 1px solid rgba(255, 255, 255, .12);
    min-width: 180px;
    height: 56px;
    box-sizing: border-box;
}
.store-btn:hover {
    transform: translateY(-2px);
    color: #fff;
    background: #1a1a1a;
}
.store-btn:hover svg { transform: scale(1.06); }
.store-btn svg {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    transition: transform .2s ease;
}
.store-btn > span:last-child {
    display: flex;
    flex-direction: column;
    gap: 1px;
    line-height: 1;
    text-align: left;
}
.store-btn .small {
    font-size: .68rem;
    opacity: .85;
    display: block;
    line-height: 1.1;
    font-weight: 400;
    letter-spacing: 0;
}
.store-btn .big {
    font-size: 1.15rem;
    font-weight: 600;
    line-height: 1.15;
    display: block;
    letter-spacing: -.01em;
    margin-top: 1px;
    white-space: nowrap;
}
.qr-code {
    width: 110px; height: 110px;
    background: #fff;
    border-radius: 14px;
    padding: 10px;
    box-shadow: 0 6px 16px rgba(0,0,0,.15);
}
.qr-code img { width: 100%; height: 100%; }

@media (max-width: 900px) {
    .app-grid { grid-template-columns: 1fr; gap: 40px; }
    .app-grid .phone-mockup { width: 240px; margin: 0 auto; }
}

/* =========================================================
   Отзывы
   ========================================================= */
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 22px;
}
.review-card {
    background: #fff;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 28px;
    display: flex;
    flex-direction: column;
}
.review-stars { color: #f5b03a; margin-bottom: 12px; font-size: 1.05rem; letter-spacing: 2px; }
.review-text { color: var(--text); font-size: .96rem; line-height: 1.6; margin-bottom: 18px; flex: 1; }
.review-author { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.review-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--brand-blue-light);
    color: var(--brand-blue);
    display: grid; place-items: center;
    font-weight: 700;
    font-size: .9rem;
}
.review-name { font-weight: 600; font-size: .92rem; color: var(--text); }
.review-role { font-size: .82rem; color: var(--text-muted); }

/* =========================================================
   FAQ
   ========================================================= */
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-item {
    background: #fff;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    margin-bottom: 12px;
    overflow: hidden;
    transition: border-color .2s ease;
}
.faq-item[open] { border-color: var(--brand-blue); box-shadow: var(--shadow-sm); }
.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 22px 24px;
    font-weight: 600;
    color: var(--text);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
    content: '+';
    font-size: 1.6rem;
    color: var(--brand-blue);
    flex-shrink: 0;
    transition: transform .2s ease;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { padding: 0 24px 22px; margin: 0; color: var(--text-secondary); }

/* =========================================================
   Footer
   ========================================================= */
.site-footer {
    background: var(--bg-dark);
    color: rgba(255,255,255,.75);
    padding: 64px 0 24px;
}
.footer-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
    gap: 48px;
    margin-bottom: 48px;
}
.footer-grid h5 { color: #fff; font-size: .95rem; margin-bottom: 18px; text-transform: uppercase; letter-spacing: .08em; }
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin-bottom: 10px; }
.footer-grid a { color: rgba(255,255,255,.7); font-size: .94rem; }
.footer-grid a:hover { color: #fff; }
.footer-brand p { color: rgba(255,255,255,.6); font-size: .92rem; max-width: 320px; }
.footer-brand .logo { color: #fff; }
.footer-bottom {
    padding-top: 24px;
    border-top: 1px solid rgba(255,255,255,.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: .85rem;
    color: rgba(255,255,255,.5);
    flex-wrap: wrap;
    gap: 16px;
}
.footer-store-btns { display: flex; gap: 10px; margin-top: 16px; }
.footer-store-btns .store-btn {
    padding: 8px 16px;
    min-width: 160px;
    height: 50px;
    background: rgba(255, 255, 255, .06);
    border-color: rgba(255, 255, 255, .14);
}
.footer-store-btns .store-btn:hover { background: rgba(255, 255, 255, .12); }
.footer-store-btns .store-btn svg { width: 24px; height: 24px; }
.footer-store-btns .store-btn .small { font-size: .65rem; }
.footer-store-btns .store-btn .big { font-size: 1rem; }

@media (max-width: 900px) {
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
    .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
    .footer-grid { grid-template-columns: 1fr; }
}

/* =========================================================
   Section variants
   ========================================================= */
.section-soft { background: var(--bg-soft); }
.section-blue { background: var(--brand-blue-light); }

/* =========================================================
   Page hero — для внутренних страниц
   ========================================================= */
.page-hero {
    background: linear-gradient(180deg, var(--brand-blue-light) 0%, var(--bg-soft) 100%);
    padding: 70px 0 60px;
    text-align: center;
}
.page-hero h1 { margin-bottom: 12px; }
.page-hero p { font-size: 1.1rem; color: var(--text-secondary); max-width: 680px; margin: 0 auto; }
.breadcrumbs {
    color: var(--text-muted);
    font-size: .88rem;
    margin-bottom: 18px;
}
.breadcrumbs a { color: var(--text-muted); }
.breadcrumbs a:hover { color: var(--brand-blue); }

/* =========================================================
   Карта & контакты
   ========================================================= */
.contacts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
@media (max-width: 900px) { .contacts-grid { grid-template-columns: 1fr; } }
.contact-item {
    display: flex; gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid var(--border-light);
}
.contact-item:last-child { border-bottom: 0; }
.contact-icon {
    width: 44px; height: 44px;
    border-radius: 14px;
    background: var(--brand-blue-light);
    color: var(--brand-blue);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.contact-icon svg { width: 22px; height: 22px; }
.contact-label { font-size: .82rem; color: var(--text-muted); }
.contact-value { font-size: 1.05rem; font-weight: 600; color: var(--text); }
.contact-value a { color: var(--text); }
.contact-value a:hover { color: var(--brand-blue); }

/* =========================================================
   App-screenshots gallery
   ========================================================= */
.screens-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 22px;
    align-items: start;
}
.screen-mock {
    background: #1a1a2e;
    border-radius: 32px;
    padding: 8px;
    aspect-ratio: 240/500;
    box-shadow: var(--shadow-md);
}
.screen-mock-inner {
    background: var(--bg-soft);
    border-radius: 26px;
    height: 100%;
    overflow: hidden;
    position: relative;
}
.screen-caption { text-align: center; margin-top: 14px; font-size: .92rem; color: var(--text-secondary); }

/* =========================================================
   Highlight blocks
   ========================================================= */
.highlight-block {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
@media (max-width: 900px) { .highlight-block { grid-template-columns: 1fr; gap: 32px; } }
.highlight-block.reverse > *:first-child { order: 2; }
@media (max-width: 900px) { .highlight-block.reverse > *:first-child { order: 0; } }
.highlight-image {
    background: var(--brand-blue-light);
    border-radius: var(--radius-lg);
    aspect-ratio: 4/3;
    display: grid; place-items: center;
    color: var(--brand-blue);
    overflow: hidden;
    position: relative;
}

/* Деко-блок-«карта с пином» — более реалистичный, со стилем настоящей карты */
.deco-map {
    width: 100%; height: 100%;
    background:
        /* зелёные парки */
        radial-gradient(ellipse 80px 60px at 18% 25%, rgba(31, 186, 114, .25) 0, transparent 60%),
        radial-gradient(ellipse 100px 70px at 82% 75%, rgba(31, 186, 114, .22) 0, transparent 60%),
        radial-gradient(ellipse 60px 50px at 70% 20%, rgba(31, 186, 114, .18) 0, transparent 60%),
        /* реки */
        radial-gradient(ellipse 200px 30px at 50% 60%, rgba(82, 147, 224, .25) 0, transparent 70%),
        /* радиальные «улицы» расходящиеся от центра */
        repeating-conic-gradient(from 0deg at 50% 50%, transparent 0 30deg, rgba(255, 255, 255, .35) 30deg 31deg),
        /* сетка дорог */
        repeating-linear-gradient(0deg, rgba(255, 255, 255, .25) 0 1px, transparent 1px 38px),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, .25) 0 1px, transparent 1px 38px),
        /* основной фон */
        linear-gradient(135deg, #f5e6c8 0%, #e8efe6 60%, #d8e3ec 100%);
}
.deco-map::before {
    /* кольцевая дорога — МКАД */
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 65%;
    height: 65%;
    border: 3px solid rgba(82, 147, 224, .4);
    border-radius: 50%;
    pointer-events: none;
}
.deco-pin {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--brand-blue);
    color: #fff;
    display: grid; place-items: center;
    box-shadow: 0 12px 30px rgba(82,147,224,.5);
    animation: pin-pulse 2s infinite;
}
.deco-pin svg { width: 26px; height: 26px; }
@keyframes pin-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(82,147,224,.55), 0 12px 30px rgba(82,147,224,.5); }
    50% { box-shadow: 0 0 0 22px rgba(82,147,224,0), 0 12px 30px rgba(82,147,224,.5); }
}

/* =========================================================
   Mini-app экраны (живые мокапы для интеграции)
   ========================================================= */
.mini-app { font-size: 12px; }
.mini-app .map {
    background:
        repeating-linear-gradient(0deg, rgba(0,0,0,.04) 0 1px, transparent 1px 20px),
        repeating-linear-gradient(90deg, rgba(0,0,0,.04) 0 1px, transparent 1px 20px),
        linear-gradient(135deg, #e8f3f0 0%, #f4eecf 100%);
    height: 50%;
    position: relative;
}
.mini-app .map::after {
    content: ''; position: absolute;
    top: 30%; left: 25%;
    width: 50%; height: 30%;
    background:
        linear-gradient(135deg, transparent 49%, var(--brand-blue) 49% 51%, transparent 51%);
    opacity: .35;
    border-radius: 30%;
}
.mini-app .map-pin {
    position: absolute;
    width: 22px; height: 22px;
    border-radius: 50%;
    color: #fff;
    display: grid; place-items: center;
    font-size: 11px;
    font-weight: 700;
    box-shadow: 0 4px 8px rgba(0,0,0,.2);
}
.mini-app .pin-a { background: var(--app-green); top: 28%; left: 22%; }
.mini-app .pin-b { background: #E8C170; top: 60%; right: 22%; }
.mini-app .sheet {
    background: #fff;
    border-radius: 18px 18px 0 0;
    padding: 14px 12px;
    height: 50%;
    margin-top: -8px;
    position: relative;
    box-shadow: 0 -4px 12px rgba(0,0,0,.06);
}
.mini-app .sheet-handle {
    width: 32px; height: 4px;
    background: #e0e0e8;
    border-radius: 2px;
    margin: 0 auto 10px;
}
.mini-app .row {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 0;
    font-size: 11px;
    color: #4a4a55;
    border-bottom: 1px solid #f0f0f5;
}
.mini-app .dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mini-app .dot-a { background: var(--app-green); }
.mini-app .dot-b { background: #E8C170; }
.mini-app .price-row { display: flex; justify-content: space-between; align-items: baseline; padding: 8px 0; }
.mini-app .price-row .l { font-size: 11px; color: #8a8a98; }
.mini-app .price-row .v { font-weight: 700; color: #1a1a2e; }
.mini-app .accept-btn {
    background: var(--app-gradient);
    color: #fff;
    text-align: center;
    padding: 9px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 11px;
    margin-top: 8px;
}

/* =========================================================
   Tracking widget (мок отслеживания на сайте)
   ========================================================= */
.tracking-widget {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 28px;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--border-light);
}
.tracking-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(31,186,114,.1);
    color: var(--app-green);
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    font-size: .82rem;
    font-weight: 600;
    margin-bottom: 18px;
}
.tracking-status::before {
    content: '';
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--app-green);
    animation: pulse-dot 1.4s infinite;
}
@keyframes pulse-dot {
    0%, 100% { opacity: 1; }
    50% { opacity: .4; }
}
.tracking-route {
    background: var(--bg-soft);
    border-radius: var(--radius-md);
    padding: 18px;
    margin-bottom: 18px;
}
.tracking-point { display: flex; align-items: flex-start; gap: 12px; padding: 8px 0; }
.tracking-point-icon {
    width: 24px; height: 24px;
    border-radius: 50%;
    color: #fff;
    display: grid; place-items: center;
    font-size: .78rem;
    font-weight: 700;
    flex-shrink: 0;
}
.tracking-point-icon.from { background: var(--app-green); }
.tracking-point-icon.to { background: #E8C170; }
.tracking-line {
    margin-left: 11px;
    border-left: 2px dashed var(--border);
    height: 18px;
}
.tracking-driver {
    display: flex; align-items: center; gap: 14px;
    padding: 16px;
    background: var(--bg-soft);
    border-radius: var(--radius-md);
}
.driver-avatar {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--brand-blue);
    color: #fff;
    display: grid; place-items: center;
    font-weight: 700;
    font-size: 1.1rem;
}
.driver-stars { color: #f5b03a; font-size: .82rem; }

/* =========================================================
   CTA-блок для интеграции
   ========================================================= */
.integration-callout {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 32px;
    border: 2px dashed var(--brand-blue);
    text-align: center;
}
.integration-callout h3 { margin-bottom: 8px; }
.integration-callout p { margin-bottom: 18px; }

/* =========================================================
   Утилитарные тосты / попапы
   ========================================================= */
.toast {
    position: fixed;
    bottom: 24px; left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--text);
    color: #fff;
    padding: 14px 22px;
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-lg);
    z-index: 1000;
    transition: transform .3s ease;
    font-size: .92rem;
}
.toast.show { transform: translateX(-50%) translateY(0); }

.calc-result {
    margin-top: 24px;
    padding: 22px;
    background: linear-gradient(135deg, var(--brand-blue-light), #e8f5fa);
    border-radius: var(--radius-md);
    border: 1px solid var(--brand-blue-light);
    display: none;
}
.calc-result.show { display: block; }
.calc-result .price {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--brand-blue);
    margin: 6px 0 4px;
}
.calc-result .price small { font-size: .9rem; color: var(--text-muted); font-weight: 500; }
.calc-result .label { font-size: .88rem; color: var(--text-secondary); }
.calc-breakdown {
    background: rgba(255,255,255,.6);
    border-radius: var(--radius-sm);
    padding: 14px 18px;
    margin-top: 14px;
    backdrop-filter: blur(4px);
}
.calc-row {
    display: flex;
    justify-content: space-between;
    padding: 7px 0;
    font-size: .92rem;
    color: var(--text-secondary);
    border-bottom: 1px solid rgba(82, 147, 224, .08);
}
.calc-row:last-child { border-bottom: 0; }
.calc-row span:last-child { font-weight: 600; color: var(--text); }

/* Сравнение с конкурентами */
.compare-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
.compare-table th, .compare-table td {
    padding: 16px 14px;
    text-align: left;
    border-bottom: 1px solid var(--border-light);
    font-size: .94rem;
}
.compare-table thead th {
    background: var(--bg-soft);
    font-weight: 600;
    color: var(--text);
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.compare-table tr.us {
    background: var(--brand-blue-light);
}
.compare-table tr.us td:first-child { font-weight: 700; color: var(--brand-blue-dark); }
.compare-table tr.us td .badge { background: var(--brand-blue); color: #fff; font-size: .68rem; padding: 2px 8px; border-radius: 999px; margin-left: 6px; vertical-align: middle; }
.compare-table .ok { color: var(--app-green); font-weight: 600; }
.compare-table .miss { color: var(--text-muted); }
@media (max-width: 720px) {
    .compare-table { font-size: .82rem; }
    .compare-table th, .compare-table td { padding: 10px 8px; }
}

/* Бейдж экономии */
.save-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(31, 186, 114, .12);
    color: var(--app-green);
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 600;
}

/* Маленькая «полоска» для бейджа "интеграция с приложением" */
.app-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    background: var(--app-gradient);
    color: #fff;
    border-radius: var(--radius-pill);
    font-size: .8rem;
    font-weight: 600;
    margin-bottom: 18px;
}
.app-badge svg { width: 14px; height: 14px; }

/* =========================================================
   ФИНАЛЬНАЯ ПОЛИРОВКА — современные иллюстрации, типографика
   ========================================================= */

body {
    font-feature-settings: 'cv11', 'ss01', 'ss03';
    text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { font-feature-settings: 'cv11', 'ss01'; }
.eyebrow, .ai-badge, .app-badge { letter-spacing: .08em; }

/* Современные мокапы телефонов — реалистичный корпус */
.phone-mockup {
    background: linear-gradient(145deg, #1a1a2e 0%, #2a2a3e 100%);
    border-radius: 48px;
    padding: 14px;
    box-shadow:
        0 30px 60px rgba(82, 147, 224, .25),
        0 14px 30px rgba(0, 0, 0, .15),
        inset 0 0 0 2px rgba(255, 255, 255, .06);
}
.phone-mockup::before {
    width: 120px; height: 28px;
    background: #1a1a2e;
    border-radius: 0 0 18px 18px;
    box-shadow: inset 0 -2px 4px rgba(0, 0, 0, .3);
}

/* Лучшая «карта» в мокапах: полосы дорог + заливка районов */
.mini-app .map {
    background-image:
        radial-gradient(circle at 30% 30%, rgba(31, 186, 114, .18) 0, transparent 12%),
        radial-gradient(circle at 70% 70%, rgba(82, 147, 224, .15) 0, transparent 12%),
        repeating-linear-gradient(0deg, rgba(0,0,0,.04) 0 1px, transparent 1px 24px),
        repeating-linear-gradient(90deg, rgba(0,0,0,.04) 0 1px, transparent 1px 24px),
        linear-gradient(135deg, #f0e9d5 0%, #e8f3f0 60%, #dde8ed 100%);
    position: relative;
}
.mini-app .map::before {
    content: '';
    position: absolute;
    top: 22%; left: 18%;
    width: 64%; height: 7%;
    background: rgba(255, 255, 255, .6);
    border-radius: 4px;
    transform: rotate(20deg);
    box-shadow: 0 28px 0 rgba(255, 255, 255, .45);
}
.mini-app .map::after { background: none; }
.mini-app .map-pin {
    box-shadow: 0 6px 14px rgba(0, 0, 0, .25), 0 0 0 4px rgba(255, 255, 255, .9);
    z-index: 2;
}

/* Современные feature-card */
.feature-card {
    position: relative;
    overflow: hidden;
    background-image: linear-gradient(180deg, #fff 0%, #fafbff 100%);
}
.feature-card::after {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 80px; height: 80px;
    background: radial-gradient(circle at 100% 0%, rgba(82, 147, 224, .08) 0, transparent 70%);
    pointer-events: none;
}

/* Hero — мягкие декоративные пузыри */
.hero::before {
    content: '';
    position: absolute;
    top: -100px; right: -80px;
    width: 380px; height: 380px;
    background: radial-gradient(circle, rgba(2, 161, 197, .14) 0%, transparent 70%);
    pointer-events: none;
    animation: float-blob 12s ease-in-out infinite;
    z-index: 0;
}
.hero::after {
    content: '';
    position: absolute;
    bottom: -150px; left: -100px;
    width: 480px; height: 480px;
    background: radial-gradient(circle, rgba(82, 147, 224, .12) 0%, transparent 70%);
    pointer-events: none;
    animation: float-blob 16s ease-in-out infinite reverse;
    z-index: 0;
}
.hero > .container { position: relative; z-index: 1; }
@keyframes float-blob {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(30px, -30px); }
}

/* Hero-stat — gradient text */
.hero-stat .num {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* Tariff-card — мягкий градиент */
.tariff-card {
    background-image: linear-gradient(180deg, #fff 0%, rgba(245, 244, 252, .55) 100%);
}
.tariff-card.featured {
    background-image: linear-gradient(180deg, #fff 0%, var(--brand-blue-light) 100%);
}
.tariff-truck {
    background: linear-gradient(135deg, var(--brand-blue-light) 0%, #d8e8f5 100%);
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, .6);
}

/* Кнопки — мягкое свечение */
.btn-primary {
    background-image: linear-gradient(135deg, var(--brand-blue) 0%, #6ba2e8 100%);
    box-shadow:
        0 6px 20px rgba(82, 147, 224, .35),
        inset 0 1px 0 rgba(255, 255, 255, .2);
}
.btn-primary:hover {
    background-image: linear-gradient(135deg, var(--brand-blue-dark) 0%, var(--brand-blue) 100%);
    box-shadow:
        0 10px 26px rgba(82, 147, 224, .45),
        inset 0 1px 0 rgba(255, 255, 255, .25);
}

/* Reviews */
.review-card {
    background-image: linear-gradient(180deg, #fff 0%, #fafbff 100%);
    box-shadow: 0 2px 12px rgba(82, 147, 224, .04);
    transition: all .25s ease;
}
.review-card:hover {
    box-shadow: 0 8px 24px rgba(82, 147, 224, .12);
    transform: translateY(-2px);
}

/* App-section — мягкая внутренняя тень */
.app-section { box-shadow: inset 0 0 80px rgba(0, 0, 0, .15); }

/* Кнопки магазинов */
.store-btn {
    background: linear-gradient(180deg, #1a1a1a 0%, #000 100%);
    box-shadow:
        0 4px 12px rgba(0, 0, 0, .25),
        inset 0 1px 0 rgba(255, 255, 255, .12);
    transition: all .2s ease;
}
.store-btn:hover {
    box-shadow:
        0 8px 20px rgba(0, 0, 0, .35),
        inset 0 1px 0 rgba(255, 255, 255, .15);
}

/* Текстовое выделение */
::selection { background: var(--brand-blue); color: #fff; }
::-moz-selection { background: var(--brand-blue); color: #fff; }

/* Кастомный scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-soft); }
::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
    border-radius: 999px;
    border: 2px solid var(--bg-soft);
}
::-webkit-scrollbar-thumb:hover { filter: brightness(1.1); }

/* SVG-иллюстрация грузовика в hero — изометрический брендовый стиль */
.hero-truck-art {
    position: absolute;
    bottom: 40px;
    right: 4%;
    width: 320px;
    height: auto;
    opacity: .22;
    pointer-events: none;
    z-index: 0;
    animation: truck-roll 8s ease-in-out infinite;
    filter: drop-shadow(0 12px 16px rgba(44, 95, 160, .25));
}
@media (max-width: 900px) { .hero-truck-art { width: 200px; right: -20px; opacity: .14; } }
@keyframes truck-roll {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(-10px); }
}

/* Section-soft — мягкий паттерн вместо плоского цвета */
.section-soft {
    background-image:
        radial-gradient(circle at 0% 0%, rgba(82, 147, 224, .04) 0%, transparent 40%),
        radial-gradient(circle at 100% 100%, rgba(2, 161, 197, .04) 0%, transparent 40%),
        var(--bg-soft);
}

/* Улучшенное оформление iconов в feature */
.feature-card:hover .feature-icon {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
    color: #fff;
    transform: scale(1.05);
    transition: all .25s ease;
}

/* Page-hero — добавляем мягкие декорации */
.page-hero {
    position: relative;
    overflow: hidden;
}
.page-hero::before {
    content: '';
    position: absolute;
    top: -50px; right: -100px;
    width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(2, 161, 197, .12) 0%, transparent 70%);
    pointer-events: none;
}

/* Тарифы — иконка категории с мягким glow */
.tariff-card .tariff-truck {
    transition: transform .25s ease, box-shadow .25s ease;
}
.tariff-card:hover .tariff-truck {
    transform: scale(1.05) rotate(-2deg);
    box-shadow: 0 10px 24px rgba(82, 147, 224, .25);
}

/* Mobile menu — улучшенная иконка-крест */
.mobile-menu-close {
    transition: transform .2s ease;
}
.mobile-menu-close:hover { transform: rotate(90deg); }

/* ============ Чекбоксы дополнительных услуг в калькуляторе ============ */
.extras-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 6px;
}
@media (max-width: 560px) {
    .extras-list { grid-template-columns: 1fr; }
}
.form-group label.extra-opt {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    margin: 0;
    background: #fafbff;
    border: 1px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 400;
    color: var(--text);
    transition: border-color .15s ease, background .15s ease;
}
.form-group label.extra-opt:hover { border-color: var(--brand-blue); background: #fff; }
.form-group .extra-opt input[type="checkbox"] {
    width: 18px !important;
    height: 18px;
    padding: 0 !important;
    margin: 0;
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--brand-blue);
}
.extra-opt-name { flex: 1; min-width: 0; }
.extra-opt-price {
    font-size: 13px;
    font-weight: 600;
    color: var(--brand-blue);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

/* Footer — добавим тонкую разделительную линию */
.site-footer {
    background:
        linear-gradient(to bottom, rgba(82, 147, 224, .03), transparent 200px),
        var(--bg-dark);
}

/* ============ Order flow (статусы перевозки в водительском приложении) ============ */
.order-flow {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-top: 24px;
}
.order-flow .of-arrow { display: none; }
@media (max-width: 980px) {
    .order-flow { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    .order-flow { grid-template-columns: 1fr; }
}
.of-step {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 18px 16px 16px;
    position: relative;
    box-shadow: 0 1px 2px rgba(20, 30, 60, .03);
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.of-step:hover {
    transform: translateY(-2px);
    border-color: var(--brand-blue);
    box-shadow: 0 8px 24px rgba(82, 147, 224, .12);
}
.of-num {
    position: absolute;
    top: -10px;
    left: 14px;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: var(--brand-blue);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    display: grid;
    place-items: center;
    box-shadow: 0 2px 6px rgba(82, 147, 224, .35);
}
/* .of-icon удалён — оставлена только нумерация в углу карточки */
.of-step h5 {
    margin: 8px 0 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--heading);
    line-height: 1.3;
}
.of-step p {
    margin: 0;
    font-size: 13px;
    line-height: 1.5;
    color: var(--text-muted);
}
.of-arrow {
    align-self: center;
    width: 100%;
    height: 2px;
    background: linear-gradient(to right, transparent, var(--brand-blue) 40%, var(--brand-blue) 60%, transparent);
    position: relative;
}
.of-arrow::after {
    content: '';
    position: absolute;
    right: 4px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-top: 2px solid var(--brand-blue);
    border-right: 2px solid var(--brand-blue);
    transform: translateY(-50%) rotate(45deg);
}

/* (Лента живых заказов удалена — секции больше нет) */

/* ========== Свёрнутый блок "Откуда такие цены" ========== */
.market-details {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 0;
    margin: 0 auto;
    max-width: 960px;
    overflow: hidden;
}
.market-details > summary {
    list-style: none;
    cursor: pointer;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    user-select: none;
    transition: background .18s ease;
}
.market-details > summary::-webkit-details-marker { display: none; }
.market-details > summary:hover { background: #fafbfd; }
.market-summary-text { flex: 1; }
.market-summary-toggle {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    position: relative;
    transition: transform .25s ease;
}
.market-summary-toggle::before, .market-summary-toggle::after {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    width: 12px; height: 2px;
    background: var(--brand-blue);
    transform: translate(-50%, -50%);
    transition: transform .25s ease;
}
.market-summary-toggle::after { transform: translate(-50%, -50%) rotate(90deg); }
.market-details[open] .market-summary-toggle::after { transform: translate(-50%, -50%) rotate(0); }
.market-details[open] > summary { border-bottom: 1px solid var(--border); background: #fafbfd; }
.market-details > summary + div { padding: 0 24px 28px; }

/* ========== QR-код для приложения водителя ========== */
.app-buttons-with-qr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
}
.app-buttons-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 0 1 auto;
    min-width: 220px;
}
.driver-qr {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 10px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 12px;
    transition: all .18s ease;
    align-self: center;
    flex: 0 0 auto;
}
.driver-qr:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0,0,0,.08);
    border-color: var(--brand-blue);
}
.driver-qr img {
    display: block;
    width: 88px;
    height: 88px;
    border-radius: 6px;
}
.driver-qr-label {
    font-size: .68rem;
    font-weight: 600;
    color: var(--text-muted);
    text-align: center;
    letter-spacing: .02em;
    max-width: 110px;
    line-height: 1.3;
}
@media (max-width: 600px) {
    .driver-qr { display: none; }
}

/* ========== Глобус: оживление маршрутов и городов ========== */

/* Маршруты — пунктир «течёт» к Москве (эффект движения грузов) */
.gv-route {
    animation: gv-route-flow 18s linear infinite;
}
@keyframes gv-route-flow {
    from { stroke-dashoffset: 0; }
    to   { stroke-dashoffset: -200; }
}
/* Дополнительная подсветка маршрутов при наведении на глобус */
.hero-globe:hover .gv-route { opacity: 1 !important; transition: opacity .3s ease; }

/* Случайный пинг городов: задаём задержки через nth-child */
.gv-city {
    transform-origin: center;
    transform-box: fill-box;
    animation: gv-city-ping 7s ease-in-out infinite;
}
.gv-city:nth-child(1)  { animation-delay: 0s; }
.gv-city:nth-child(3)  { animation-delay: 1.2s; }
.gv-city:nth-child(5)  { animation-delay: 2.4s; }
.gv-city:nth-child(7)  { animation-delay: 3.6s; }
.gv-city:nth-child(9)  { animation-delay: 4.8s; }
.gv-city:nth-child(11) { animation-delay: 6s; }
.gv-city:nth-child(2)  { animation-delay: .6s; }
.gv-city:nth-child(4)  { animation-delay: 1.8s; }
.gv-city:nth-child(6)  { animation-delay: 3s; }
.gv-city:nth-child(8)  { animation-delay: 4.2s; }
@keyframes gv-city-ping {
    0%, 92%, 100% {
        filter: drop-shadow(0 0 0 rgba(94,234,212,0));
    }
    94% {
        filter: drop-shadow(0 0 6px rgba(94,234,212,.9));
    }
    96% {
        filter: drop-shadow(0 0 12px rgba(94,234,212,.6));
    }
}

/* Респект пользовательским настройкам — отключить анимации */
@media (prefers-reduced-motion: reduce) {
    .gv-route { animation: none; }
    .gv-city { animation: none; }
}

/* Мобильные: глобус не должен доминировать */
@media (max-width: 800px) {
    .hero-globe { max-width: 380px; margin: 24px auto 0; }
}
@media (max-width: 480px) {
    .hero-globe { max-width: 320px; }
}

/* ========== Глобус: интерактивные города ========== */
.gv-city-grp {
    cursor: pointer;
    transition: transform .15s ease;
    pointer-events: all;
}
.gv-city-grp:hover .gv-city,
.gv-city-grp:focus .gv-city {
    r: 6;
    fill: #5eead4;
    stroke-width: 2;
    transition: all .2s ease;
}
.gv-city-grp:hover text,
.gv-city-grp:focus text {
    opacity: 1 !important;
    font-weight: 700;
    fill: #fff;
}
.gv-city-grp:focus { outline: none; }

/* Tooltip */
.gv-tooltip {
    position: fixed;
    z-index: 100;
    background: rgba(20, 30, 50, .96);
    color: #fff;
    padding: 12px 14px;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0,0,0,.35);
    font-size: 13px;
    line-height: 1.4;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    pointer-events: none;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity .18s ease, transform .18s ease;
    min-width: 200px;
    max-width: 260px;
}
.gv-tooltip.show {
    opacity: 1;
    transform: translateY(0);
}
.gv-tooltip-name {
    font-weight: 700;
    font-size: 15px;
    margin-bottom: 6px;
    color: #5eead4;
}
.gv-tooltip-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 3px 0;
    color: rgba(255,255,255,.8);
}
.gv-tooltip-row strong { color: #fff; font-weight: 600; }
.gv-tooltip-cta {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,.12);
    font-size: 11px;
    color: #5eead4;
    font-weight: 600;
    text-align: center;
}

/* Точки-«грузовики» — мягкое свечение */
.gv-trucks circle {
    filter: drop-shadow(0 0 4px rgba(94,234,212,.7));
}
@media (prefers-reduced-motion: reduce) {
    .gv-trucks circle animateMotion { display: none; }
}

/* ========== Переключатель Глобус / Карта ========== */
.hero-view-toggle {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid var(--border);
    border-radius: 999px;
    margin-bottom: 12px;
    box-shadow: 0 2px 10px rgba(0,0,0,.05);
}
.hvt-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border: none;
    background: transparent;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    transition: all .18s ease;
}
.hvt-btn svg { width: 14px; height: 14px; }
.hvt-btn:hover { color: var(--text); }
.hvt-btn.active {
    background: var(--brand-blue);
    color: #fff;
    box-shadow: 0 2px 8px rgba(82,147,224,.35);
}

/* Управляем видимостью через data-view на родителе */
.hero-visual[data-view="globe"] .hero-globe { display: block; }
.hero-visual[data-view="globe"] .hero-iso { display: none; }
.hero-visual[data-view="map"] .hero-globe { display: none; }
.hero-visual[data-view="map"] .hero-iso { display: block; }
.hero-iso[hidden] { display: none !important; }

/* ========== Изометрическая карта ========== */
.hero-iso { width: 100%; max-width: 520px; margin: 0 auto; position: relative; }
.hero-iso svg { width: 100%; height: auto; display: block; }

/* Регионы — кликабельные */
.iso-region {
    cursor: pointer;
    transition: transform .18s ease;
    transform-origin: center;
    transform-box: fill-box;
}
.iso-region:hover ellipse,
.iso-region:focus ellipse {
    fill: #fffceb;
    stroke: #FFD166;
    stroke-width: 2;
}
.iso-region:hover circle,
.iso-region:focus circle {
    r: 5;
    fill: #FF8B3D;
}
.iso-region:focus { outline: none; }

/* Подсветка маршрутов при ховере на карту */
.hero-iso svg:hover path[id^="iso-rt"] { opacity: 1; transition: opacity .3s ease; }

/* Парящие коробки */
.iso-cargo-bounce {
    animation: iso-float 4s ease-in-out infinite;
    transform-origin: center;
    transform-box: fill-box;
}
@keyframes iso-float {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-6px); }
}

/* Свечение Москвы пульсирует */
.iso-moscow ellipse:nth-child(2) {
    animation: iso-msc-pulse 3s ease-in-out infinite;
    transform-origin: center;
    transform-box: fill-box;
}
@keyframes iso-msc-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: .85; transform: scale(1.04); }
}

/* Уважение к настройкам */
@media (prefers-reduced-motion: reduce) {
    .iso-cargo-bounce, .iso-moscow ellipse:nth-child(2) { animation: none; }
    .iso-trucks animateMotion { display: none; }
}

@media (max-width: 800px) {
    .hero-iso { max-width: 380px; margin-top: 24px; }
    .hero-view-toggle { font-size: 12px; }
    .hvt-btn { padding: 6px 12px; font-size: 12px; }
}
@media (max-width: 480px) {
    .hero-iso { max-width: 320px; }
}

/* ========== Cookie-баннер ========== */
.cookie-banner {
    position: fixed;
    bottom: 16px;
    left: 16px;
    right: 16px;
    max-width: 760px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 18px 22px;
    box-shadow: 0 10px 40px rgba(0,0,0,.18);
    z-index: 9999;
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 14px;
    line-height: 1.45;
    transform: translateY(120%);
    transition: transform .35s cubic-bezier(.2,.9,.3,1.2);
}
.cookie-banner.show { transform: translateY(0); }
.cookie-banner-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    background: var(--brand-blue-light);
    border-radius: 12px;
    color: var(--brand-blue);
    font-size: 22px;
}
.cookie-banner-text { flex: 1; color: var(--text); }
.cookie-banner-text a { color: var(--brand-blue); text-decoration: underline; }
.cookie-banner-actions { display: flex; gap: 8px; flex-shrink: 0; }
.cookie-banner-btn {
    padding: 9px 16px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: #fff;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all .18s ease;
}
.cookie-banner-btn:hover { background: #fafbfd; }
.cookie-banner-btn.primary {
    background: var(--brand-blue);
    color: #fff;
    border-color: var(--brand-blue);
}
.cookie-banner-btn.primary:hover { background: #4583d0; }
@media (max-width: 700px) {
    .cookie-banner { flex-direction: column; align-items: flex-start; padding: 14px 16px; }
    .cookie-banner-actions { width: 100%; }
    .cookie-banner-btn { flex: 1; }
}

/* ========== Sticky-CTA на мобильных ========== */
.sticky-cta {
    position: fixed;
    bottom: 12px;
    left: 12px;
    right: 12px;
    z-index: 90;
    background: var(--brand-blue);
    color: #fff;
    padding: 14px 18px;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(82,147,224,.5);
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    display: none;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transform: translateY(150%);
    transition: transform .35s cubic-bezier(.2,.9,.3,1.2);
}
.sticky-cta.show { transform: translateY(0); }
.sticky-cta-price { background: rgba(255,255,255,.2); padding: 4px 10px; border-radius: 8px; font-size: 13px; font-weight: 600; }
.sticky-cta-arrow { width: 18px; height: 18px; }
@media (max-width: 800px) {
    .sticky-cta { display: flex; }
    body.has-sticky-cta { padding-bottom: 80px; }
}

/* ========== Плавающая кнопка поддержки ========== */
.support-fab {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 88;
    background: var(--brand-blue);
    color: #fff;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    box-shadow: 0 10px 30px rgba(82,147,224,.45);
    border: none;
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: all .2s ease;
}
.support-fab:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 14px 36px rgba(82,147,224,.55);
}
.support-fab svg { width: 28px; height: 28px; }
.support-fab::after {
    content: '';
    position: absolute;
    top: 4px; right: 4px;
    width: 12px; height: 12px;
    background: #1FBA72;
    border: 2px solid #fff;
    border-radius: 50%;
    animation: support-pulse 2s ease-out infinite;
}
@keyframes support-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(31,186,114,.6); }
    70%      { box-shadow: 0 0 0 8px rgba(31,186,114,0); }
}
.support-menu {
    position: fixed;
    bottom: 96px;
    right: 24px;
    z-index: 89;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: 0 14px 40px rgba(0,0,0,.18);
    padding: 8px;
    min-width: 240px;
    display: none;
    transform-origin: bottom right;
    animation: support-pop .2s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes support-pop {
    from { opacity: 0; transform: scale(.85); }
    to   { opacity: 1; transform: scale(1); }
}
.support-menu.show { display: block; }
.support-menu a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 10px;
    text-decoration: none;
    color: var(--text);
    font-size: 14px;
    transition: background .15s ease;
}
.support-menu a:hover { background: #fafbfd; }
.support-menu a svg { width: 22px; height: 22px; flex-shrink: 0; color: var(--brand-blue); }
.support-menu .support-menu-title {
    font-size: 12px; font-weight: 600; color: var(--text-muted);
    padding: 8px 14px 4px; text-transform: uppercase; letter-spacing: .5px;
}
@media (max-width: 800px) {
    .support-fab { bottom: 90px; right: 16px; width: 52px; height: 52px; }
    .support-fab svg { width: 24px; height: 24px; }
    .support-menu { right: 16px; bottom: 156px; min-width: calc(100vw - 32px); max-width: 320px; }
}

/* ========== PWA install prompt ========== */
.pwa-install-banner {
    position: fixed;
    bottom: 24px;
    left: 24px;
    right: 24px;
    max-width: 420px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 16px;
    box-shadow: 0 16px 50px rgba(0,0,0,.18);
    z-index: 95;
    display: flex;
    align-items: center;
    gap: 14px;
    transform: translateY(150%);
    transition: transform .35s cubic-bezier(.2,.9,.3,1.2);
}
.pwa-install-banner.show { transform: translateY(0); }
.pwa-install-icon {
    flex-shrink: 0;
    width: 48px; height: 48px;
    background: linear-gradient(135deg, #5293e0, #1FBA72);
    border-radius: 12px;
    display: grid; place-items: center;
}
.pwa-install-icon svg { width: 28px; height: 28px; color: #fff; }
.pwa-install-text { flex: 1; font-size: 13px; line-height: 1.4; }
.pwa-install-text strong { display: block; font-size: 14px; margin-bottom: 2px; color: var(--text); }
.pwa-install-actions { display: flex; gap: 6px; flex-shrink: 0; }
.pwa-install-btn {
    padding: 7px 14px;
    border: none; border-radius: 8px;
    font-size: 13px; font-weight: 600;
    background: var(--brand-blue); color: #fff;
    cursor: pointer;
}
.pwa-install-close {
    width: 28px; height: 28px; border: none; background: transparent;
    cursor: pointer; color: var(--text-muted); font-size: 18px;
}
@media (max-width: 480px) {
    .pwa-install-banner { left: 12px; right: 12px; bottom: 80px; padding: 12px; }
}

/* ========== Отзывы: сводный рейтинг + бейджи источников ========== */
.reviews-summary {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 32px;
    margin: 0 auto 36px;
    padding: 22px 28px;
    max-width: 700px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    flex-wrap: wrap;
}
.reviews-rating-big { display: flex; align-items: center; gap: 14px; }
.rating-num { font-size: 36px; font-weight: 900; color: var(--text); }
.rating-stars { color: #FFB347; font-size: 20px; letter-spacing: 2px; }
.rating-meta { font-size: 13px; color: var(--text-muted); }
.rating-meta strong { color: var(--text); font-weight: 700; }
.reviews-sources { display: flex; gap: 10px; flex-wrap: wrap; }
.reviews-source-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: #fafbfd;
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    text-decoration: none;
    transition: all .15s ease;
}
.reviews-source-badge:hover { background: #fff; border-color: var(--brand-blue); transform: translateY(-1px); }

.review-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px;
}
.review-date { font-size: 12px; color: var(--text-muted); }
.review-verified {
    display: inline-block;
    width: 16px; height: 16px;
    background: #1FBA72;
    color: #fff;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 700;
    text-align: center;
    line-height: 16px;
    margin-left: 4px;
    vertical-align: middle;
}
@media (max-width: 600px) {
    .reviews-summary { padding: 16px; gap: 16px; }
    .rating-num { font-size: 28px; }
}

/* ========== Skip-to-content (a11y) ========== */
.skip-to-content {
    position: fixed;
    top: 0;
    left: 12px;
    z-index: 10000;
    padding: 10px 18px;
    background: var(--brand-blue);
    color: #fff;
    font-weight: 600;
    border-radius: 0 0 8px 8px;
    text-decoration: none;
    transform: translateY(-110%);
    transition: transform .2s ease;
    pointer-events: none;
}
.skip-to-content:focus {
    transform: translateY(0);
    outline: 2px solid #fff;
    outline-offset: -4px;
    pointer-events: auto;
}

/* Перекрашиваем «грузовики» в стиле поездов с эффектом светящегося следа */
.metro-trains circle {
    filter: drop-shadow(0 0 4px rgba(255,255,255,.5));
}

/* Бейджи линий — белые кружки с цифрой */
.metro-badge {
    cursor: default;
}

/* Станции метро: крупнее, белее, с чёрной обводкой (как в токийском метро) */
.gv-city-grp .gv-city {
    r: 5;
    fill: #fff !important;
    stroke: #1a1a2e !important;
    stroke-width: 2.2 !important;
}
.gv-city-grp:hover .gv-city,
.gv-city-grp:focus .gv-city {
    r: 7 !important;
    stroke-width: 3 !important;
}
/* Москва — главная станция, крупнее всех */
.gv-city-grp .gv-city.gv-city-hub {
    r: 7;
    fill: #FFD166 !important;
    stroke-width: 3 !important;
}

/* Текст станций — чёрный читаемый */
.gv-city-grp text {
    fill: #fff !important;
    font-weight: 700 !important;
    font-size: 9.5px !important;
    paint-order: stroke;
    stroke: rgba(20,30,50,.9);
    stroke-width: 3px;
    stroke-linejoin: round;
}

/* Легенда линий метро под глобусом */
.metro-legend {
    margin-top: 16px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    padding: 12px 16px;
    background: rgba(255,255,255,.65);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 12px;
    border: 1px solid var(--border);
}
.metro-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
}
.metro-legend-dot {
    width: 18px; height: 18px;
    border-radius: 50%;
    color: #fff;
    display: grid; place-items: center;
    font-size: 10px;
    font-weight: 800;
    border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,.15);
}

/* ========== Глобус: плавные линии и станции ========== */
.metro-network { mix-blend-mode: screen; }
.metro-line { transition: opacity .25s ease, stroke-width .25s ease; }
.metro-network:hover .metro-line { opacity: .9; }
.metro-line:hover { stroke-width: 3.4; opacity: 1 !important; }

/* Станции — небольшие белые с мягким стеклянным эффектом */
.gv-city-grp .gv-city {
    transition: all .2s ease;
}
.gv-city-grp:hover .gv-city,
.gv-city-grp:focus .gv-city {
    r: 6;
    stroke-width: 2;
    filter: drop-shadow(0 0 6px rgba(255,255,255,.6));
}

/* Текст станций — белый с лёгкой тенью */
.gv-city-grp text {
    paint-order: stroke;
    stroke: rgba(20,30,50,.65);
    stroke-width: 2.5px;
    stroke-linejoin: round;
}

/* «Поезда» — мягкое свечение в их цвете */
.metro-trains circle {
    filter: drop-shadow(0 0 5px rgba(255,255,255,.7));
}

/* ========== Yandex-style автокомплит для адресов ========== */
.hqc-field { position: relative; }
.hqc-suggest {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 12px 36px rgba(0,0,0,.14);
    max-height: 360px;
    overflow-y: auto;
    z-index: 80;
    display: none;
    padding: 6px;
    animation: hqc-suggest-pop .15s ease-out;
}
@keyframes hqc-suggest-pop {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}
.hqc-suggest.show { display: block; }
.hqc-suggest-group {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--text-muted);
    padding: 8px 10px 4px;
}
.hqc-suggest-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 9px 10px;
    cursor: pointer;
    border-radius: 10px;
    transition: background .12s ease;
}
.hqc-suggest-item:hover,
.hqc-suggest-item.active {
    background: #f5f4fc;
}
.hqc-suggest-icon {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: var(--brand-blue-light, #e8f0fb);
    display: grid;
    place-items: center;
    color: var(--brand-blue);
    flex-shrink: 0;
}
.hqc-suggest-icon svg { width: 18px; height: 18px; }
.hqc-suggest-icon.airport { background: #fff4e8; color: #FF8B3D; }
.hqc-suggest-icon.region { background: #e8faf2; color: #1FBA72; }
.hqc-suggest-text { flex: 1; min-width: 0; }
.hqc-suggest-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.hqc-suggest-name mark {
    background: transparent;
    color: var(--brand-blue);
    font-weight: 700;
    padding: 0;
}
.hqc-suggest-region {
    font-size: 12px;
    color: var(--text-muted);
    margin-top: 1px;
}
.hqc-suggest-empty {
    padding: 18px 14px;
    text-align: center;
    font-size: 13px;
    color: var(--text-muted);
}

/* ========== Hero photo (заменил глобус) ========== */
.hero-photo {
    position: relative;
    width: 100%;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(20, 30, 50, .25);
    aspect-ratio: 12 / 5;
}
.hero-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .8s ease;
}
.hero-photo:hover img { transform: scale(1.03); }
.hero-photo::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(20,30,50,0) 50%, rgba(20,30,50,.85) 100%);
    pointer-events: none;
}
.hero-photo-stats {
    position: absolute;
    left: 24px; right: 24px; bottom: 20px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    z-index: 2;
    color: #fff;
}
.hero-photo-stats .hgs-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.hero-photo-stats .hgs-num {
    font-size: 1.55rem;
    font-weight: 800;
    line-height: 1.1;
}
.hero-photo-stats .hgs-lbl {
    font-size: .82rem;
    opacity: .85;
    font-weight: 500;
}
@media (max-width: 800px) {
    .hero-photo { border-radius: 16px; aspect-ratio: 16 / 9; }
    .hero-photo-stats { left: 14px; right: 14px; bottom: 12px; gap: 10px; }
    .hero-photo-stats .hgs-num { font-size: 1.15rem; }
    .hero-photo-stats .hgs-lbl { font-size: .7rem; }
}

/* ========== Scroll-анимации (fade-in-up) ========== */
.gv-fade {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .75s cubic-bezier(.2,.65,.3,1), transform .75s cubic-bezier(.2,.65,.3,1);
    will-change: opacity, transform;
}
.gv-fade.visible {
    opacity: 1;
    transform: translateY(0);
}
/* Вариации с задержкой для каскада */
.gv-fade-1 { transition-delay: .08s; }
.gv-fade-2 { transition-delay: .16s; }
.gv-fade-3 { transition-delay: .24s; }
.gv-fade-4 { transition-delay: .32s; }
.gv-fade-5 { transition-delay: .40s; }

/* Слегка параллаксный hero */
.hero-photo img.parallax-img {
    transition: transform .15s linear;
    will-change: transform;
}

/* Hover-lift на карточках */
.feature-card, .review-card, .tariff-card {
    transition: transform .25s cubic-bezier(.2,.65,.3,1), box-shadow .25s ease;
}
.feature-card:hover, .review-card:hover, .tariff-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(20,30,50,.1);
}

/* Уважение к настройкам */
@media (prefers-reduced-motion: reduce) {
    .gv-fade { opacity: 1; transform: none; transition: none; }
    .hero-photo img.parallax-img { transform: none !important; }
}

/* ========== Hero side-photo (на странице водителей) ========== */
.hero-side-photo {
    position: relative;
    width: 100%;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 16px 50px rgba(20,30,50,.18);
    aspect-ratio: 4 / 3;
}
.hero-side-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .6s ease;
}
.hero-side-photo:hover img { transform: scale(1.04); }
.hero-side-photo-badge {
    position: absolute;
    bottom: 14px;
    left: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: rgba(20,30,50,.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    color: #fff;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
}
.hero-side-photo-badge strong { font-weight: 700; }
.hero-side-pulse {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #1FBA72;
    box-shadow: 0 0 0 0 rgba(31,186,114,.6);
    animation: lf-pulse 2s ease-out infinite;
}

/* ========== Page-hero с фоновой фотографией (для-клиентов) ========== */
.page-hero-with-photo {
    position: relative;
    overflow: hidden;
    color: #fff;
    padding-top: 140px !important;
    padding-bottom: 80px !important;
}
.page-hero-with-photo .page-hero-photo {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.page-hero-with-photo .page-hero-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.page-hero-with-photo::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(20,30,50,.78), rgba(82,147,224,.68));
    z-index: 1;
}
.page-hero-with-photo .container {
    position: relative;
    z-index: 2;
}
.page-hero-with-photo h1 { color: #fff; }
.page-hero-with-photo p { color: rgba(255,255,255,.92); }
.page-hero-with-photo .breadcrumbs,
.page-hero-with-photo .breadcrumbs a {
    color: rgba(255,255,255,.85);
}

}
}
}

/* Глобус крутится через JS-rAF (rotate-attribute на SVG-группах) */
}

/* ========== Аватары отзывов как фото вместо инициалов ========== */
.review-avatar-img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,.1);
}

/* Пресеты — чисто и минималистично */
.hqc-preset {
    overflow: hidden;
}
.hqc-preset-img { display: none; }  /* картинки скрыты, оставляем emoji */

/* ========== TTS кнопка в чате ========== */
.ai-msg.bot {
    position: relative;
    padding-right: 36px;
}
.ai-tts-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 24px;
    height: 24px;
    border: none;
    background: rgba(124, 92, 255, .12);
    border-radius: 50%;
    cursor: pointer;
    display: grid;
    place-items: center;
    color: var(--ai-purple, #7c5cff);
    transition: all .15s ease;
    opacity: 0;
}
.ai-msg.bot:hover .ai-tts-btn,
.ai-tts-btn:focus,
.ai-tts-btn.playing { opacity: 1; }
.ai-tts-btn:hover { background: rgba(124, 92, 255, .25); }
.ai-tts-btn svg { width: 14px; height: 14px; }
.ai-tts-btn.playing { background: var(--ai-purple, #7c5cff); color: #fff; }

/* ========== Фикс: отступы между секциями со слипшимися картинками ========== */
.section-soft + .section-soft { padding-top: 0; }
.hero + section { margin-top: 0; }
.hero-photo, .hero-side-photo { margin: 0; }
.review-card { padding: 24px; }
.feature-card { padding: 22px; }
.hero-photo + .hero-photo-stats { margin-top: -1px; }

/* ========== Общая полировка визуала: больше воздуха ========== */
section { padding-block: 56px; }
section.section-soft { padding-block: 64px; }
.hero { padding-block: 32px 56px; }

.section-head { margin-bottom: 36px; }
.section-head h2 {
    font-size: clamp(1.6rem, 3.4vw, 2.1rem);
    line-height: 1.2;
    letter-spacing: -.5px;
}
.section-head .section-subtitle {
    font-size: 1rem;
    color: var(--text-muted);
    max-width: 640px;
    margin: 12px auto 0;
}

/* Карточки — мягкие, тонкие границы, без жёстких теней */
.feature-card,
.review-card,
.tariff-card {
    border: 1px solid rgba(20,30,50,.06);
    box-shadow: 0 1px 2px rgba(20,30,50,.03);
    background: #fff;
    border-radius: 16px;
}
.feature-card:hover,
.review-card:hover,
.tariff-card:hover {
    border-color: rgba(82,147,224,.25);
    box-shadow: 0 8px 24px rgba(20,30,50,.06);
    transform: translateY(-2px);
}

/* Пресеты — чище */
.hqc-presets { gap: 6px; margin-bottom: 14px; }
.hqc-preset {
    padding: 7px 12px;
    background: rgba(255,255,255,.7);
    font-size: 12.5px;
}

/* Аватары отзывов — мягкая рамка */
.review-avatar-img {
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px rgba(20,30,50,.08), 0 2px 6px rgba(20,30,50,.06);
}

/* Hero photo — больше воздуха снизу */
.hero-photo { margin-top: 8px; }
.hero-photo-stats { padding-bottom: 8px; }

/* Секции — чередующийся фон, чтобы зрительно разделять */
section.section-soft { background: #fafbfd; }
section + section.section-soft { border-top: 1px solid rgba(20,30,50,.04); }

/* Тарифные карточки — спокойные акценты */
.tariff-card.featured {
    border-color: rgba(82,147,224,.4);
    background: linear-gradient(180deg, #fff, #f8fbff);
}

/* Кнопки — чуть меньше шума */
.btn { letter-spacing: .01em; font-weight: 600; }
.btn-primary {
    background: linear-gradient(180deg, #5293e0, #4583d0);
    box-shadow: 0 2px 8px rgba(82,147,224,.25);
}

/* Полировка cookie-баннера — поспокойнее */
.cookie-banner { box-shadow: 0 8px 28px rgba(20,30,50,.12); }

/* Поддерживающий fab без агрессивности */
.support-fab { box-shadow: 0 6px 20px rgba(82,147,224,.3); }



/* Mobile: уменьшить отступы */
@media (max-width: 800px) {
    section { padding-block: 40px; }
    section.section-soft { padding-block: 44px; }
    .hero { padding-block: 24px 32px; }
    .section-head { margin-bottom: 24px; }
}


/* ========== QR-код в футере (центрированный, без подписи) ========== */
.footer-store-btns {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 14px;
}
.footer-qr {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    transition: transform .15s ease, box-shadow .15s ease;
    line-height: 0;
}
.footer-qr:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,.25);
}
.footer-qr img {
    display: block;
    width: 50px;
    height: 50px;
    border-radius: 4px;
}
.footer-qr-label { display: none; }



/* ========== Картинки в карточках тарифов ========== */
.tariff-truck {
    width: 100%;
    height: 120px;
    margin-bottom: 12px;
    background: linear-gradient(180deg, #f5f4fc, #fff);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.tariff-truck img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: transform .3s ease;
}
.tariff-card:hover .tariff-truck img { transform: scale(1.06); }


/* ========== Карта России в hero (вместо глобуса) ========== */
.hero-russia {
    position: relative;
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
    background: linear-gradient(180deg, #f0f6fc, #e3eef9);
    aspect-ratio: 16 / 10;
}
.hero-russia img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}
.hero-russia-stats {
    position: absolute;
    left: 18px; right: 18px; bottom: 14px;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    z-index: 2;
}
.hero-russia-stats .hgs-item {
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: 10px 14px;
    border-radius: 12px;
    flex: 1;
    text-align: center;
}
.hero-russia-stats .hgs-num {
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--brand-blue);
    display: block;
}
.hero-russia-stats .hgs-lbl {
    font-size: .78rem;
    color: var(--text-muted);
    font-weight: 500;
}
@media (max-width: 600px) {
    .hero-russia-stats { gap: 8px; }
    .hero-russia-stats .hgs-item { padding: 8px 10px; }
    .hero-russia-stats .hgs-num { font-size: 1.05rem; }
    .hero-russia-stats .hgs-lbl { font-size: .68rem; }
}

/* =============================================================
   v2 — ФИНАЛЬНЫЙ ДИЗАЙН ГЛАВНОЙ (коллаб A+B+C+D в бренд-палитре)
   Май 2026 — поверх существующих стилей, ничего не ломая
   ============================================================= */

:root {
  --warm: #FF8B3D;
  --warm-d: #E36715;
  --gold: #FFC857;
  --serif: 'Fraunces', Georgia, serif;
  --mono: 'JetBrains Mono', monospace;
  --grad-brand-final: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
  --ease-final: cubic-bezier(0.16, 1, 0.3, 1);
}
.serif { font-family: var(--serif); }
.mono-num { font-family: var(--mono); font-feature-settings: 'zero', 'ss01', 'tnum'; }

/* ========== HERO v2 — split typography + plumped calculator ========== */
.hero-v2 {
  padding: 64px 0 56px; position: relative; overflow: hidden;
}
.hero-v2::before {
  content: ''; position: absolute; inset: 0; z-index: -2;
  background:
    radial-gradient(ellipse 800px 500px at 80% 0%, rgba(2,161,197,0.10), transparent 60%),
    radial-gradient(ellipse 700px 600px at 0% 100%, rgba(82,147,224,0.08), transparent 60%);
}
.hero-v2::after {
  content: ''; position: absolute; right: -120px; top: 0; bottom: 0; z-index: -1;
  width: 64%;
  background:
    linear-gradient(90deg, rgba(245,248,252,1) 0%, rgba(245,248,252,.4) 18%, rgba(245,248,252,0) 50%),
    url('../img/hero-truck.jpg') no-repeat right center / cover;

  background:
    linear-gradient(90deg, rgba(245,248,252,1) 0%, rgba(245,248,252,.4) 18%, rgba(245,248,252,0) 50%),
    image-set(url('../img/hero-truck.webp') type('image/webp'), url('../img/hero-truck.jpg') type('image/jpeg')) no-repeat right center / cover;
  pointer-events: none;
  opacity: .55;
  mask-image: linear-gradient(90deg, transparent 0%, #000 30%, #000 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 30%, #000 100%);
}
@media (max-width: 900px) {
  .hero-v2::after {
    width: 100%;
    right: 0;
    top: auto;
    bottom: 0;
    height: 50%;
    opacity: .25;
    mask-image: linear-gradient(180deg, transparent 0%, #000 60%);
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 60%);
  }
}
.hero-v2-grid {
  display: grid; grid-template-columns: 1.2fr 440px; gap: 56px; align-items: center;
}
.hero-v2-tag {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px; border-radius: var(--radius-pill);
  background: #fff; border: 1px solid var(--border);
  font-size: 13px; font-weight: 600; color: var(--text);
  box-shadow: var(--shadow-sm);
}
.hero-v2-tag::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--app-green); animation: pulse-final 1.4s infinite; }
@keyframes pulse-final { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
.hero-v2-title {
  font-size: clamp(40px, 6.4vw, 80px); font-weight: 800; line-height: 0.98;
  letter-spacing: -0.035em; margin-top: 20px; color: var(--heading);
}
.hero-v2-title em {
  font-style: normal; font-family: var(--serif); font-weight: 500; font-style: italic;
  background: var(--grad-brand-final); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-v2-lede { font-size: 18px; color: var(--text-secondary); margin-top: 24px; max-width: 540px; line-height: 1.5; }
.hero-v2-meta { margin-top: 36px; padding-top: 24px; border-top: 1px solid var(--border-light); display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.hero-v2-meta-i .num { font-family: var(--mono); font-size: 28px; font-weight: 700; color: var(--text); letter-spacing: -0.02em; line-height: 1; }
.hero-v2-meta-i .num small { font-size: 15px; color: var(--text-muted); font-weight: 500; margin-left: 2px; }
.hero-v2-meta-i .lbl { font-size: 11px; color: var(--text-muted); margin-top: 6px; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; }

/* hero — calculator card on the right */
.hero-v2-calc {
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px;
  box-shadow: 0 30px 60px -20px rgba(82,147,224,0.25); position: relative;
}
.hero-v2-calc::before {
  content: 'считаем за 2 секунды'; position: absolute; top: -14px; left: 24px;
  padding: 4px 12px; background: var(--warm); color: white; border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.hero-v2-calc-tit { font-size: 17px; font-weight: 700; color: var(--text); }
.hero-v2-calc-d { font-size: 13px; color: var(--text-muted); margin-top: 4px; margin-bottom: 16px; }

/* ========== Trust strip — bouncing routes marquee ========== */
.trust-strip-v2 {
  padding: 14px 0; background: var(--text); color: rgba(255,255,255,0.85);
  border-top: 1px solid rgba(255,255,255,0.08); border-bottom: 1px solid rgba(255,255,255,0.08);
  overflow: hidden;
}
.trust-strip-v2-inner { display: flex; gap: 64px; animation: marq-v2 40s linear infinite; white-space: nowrap; will-change: transform; }
@keyframes marq-v2 { to { transform: translateX(-50%); } }
.trust-strip-v2-inner > div { display: flex; gap: 64px; flex-shrink: 0; }
.trust-strip-v2-inner span { font-family: var(--mono); font-size: 13px; font-weight: 500; }
.trust-strip-v2-inner span b { color: var(--gold); margin-left: 6px; font-weight: 600; }

/* ========== BIG NUMBER MOMENT — "5 минут" ========== */
.bignum-v2 { padding: 100px 0 80px; text-align: center; position: relative; overflow: hidden; }
.bignum-v2::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(ellipse 700px 400px at 50% 50%, rgba(2,161,197,0.06), transparent 70%);
}
.bignum-v2-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--brand-cyan); letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.bignum-v2-num {
  font-family: var(--serif); font-weight: 800;
  font-size: clamp(140px, 24vw, 360px); line-height: 0.86; letter-spacing: -0.07em;
  margin-top: 8px;
  background: linear-gradient(180deg, var(--brand-blue) 20%, var(--brand-cyan) 60%, var(--text) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.bignum-v2-units { font-family: var(--serif); font-style: italic; font-size: 26px; color: var(--text-secondary); margin-top: -16px; }
.bignum-v2-tagline { font-size: clamp(26px, 3.6vw, 40px); font-weight: 700; line-height: 1.1; letter-spacing: -0.02em; max-width: 720px; margin: 48px auto 0; color: var(--heading); }
.bignum-v2-tagline em { font-style: normal; color: var(--brand-blue); }
.bignum-v2-d { font-size: 16px; color: var(--text-secondary); max-width: 560px; margin: 18px auto 0; line-height: 1.55; }

/* ========== PERSONAS — 3 cards (Дом / Бизнес / Водитель) ========== */
.personas-v2 { padding: 80px 0; background: var(--bg-soft); }
.personas-v2-head { max-width: 720px; margin: 0 auto 48px; text-align: center; }
.personas-v2-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--brand-cyan); letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.personas-v2-tit { font-size: clamp(32px, 4.4vw, 52px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; margin-top: 12px; color: var(--heading); }
.personas-v2-tit em { font-style: italic; font-family: var(--serif); font-weight: 500; color: var(--brand-blue); }
.personas-v2-d { font-size: 16px; color: var(--text-secondary); max-width: 580px; margin: 16px auto 0; line-height: 1.5; }
.personas-v2-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.persona-v2 {
  padding: 32px; border-radius: var(--radius-lg); position: relative; overflow: hidden;
  cursor: pointer; transition: all .35s var(--ease-final);
  display: flex; flex-direction: column; gap: 14px; text-decoration: none;
}
.persona-v2:hover { transform: translateY(-6px); box-shadow: 0 24px 48px -12px rgba(82,147,224,0.25); }
.persona-v2-1 { background: #fff; border: 1px solid var(--border); color: var(--text); }
.persona-v2-2 { background: var(--grad-brand-final); color: white; }
.persona-v2-3 { background: var(--text); color: white; }
.persona-v2-emoji { font-size: 48px; line-height: 1; }
.persona-v2-tit { font-size: 26px; font-weight: 800; letter-spacing: -0.025em; line-height: 1.05; }
.persona-v2-d { font-size: 14px; line-height: 1.55; opacity: 0.9; }
.persona-v2-list { padding-top: 14px; border-top: 1px dashed currentColor; opacity: 0.85; list-style: none; padding-left: 0; }
.persona-v2-list li { padding: 5px 0; font-size: 13px; display: flex; gap: 8px; }
.persona-v2-list li::before { content: '✓'; font-weight: 700; flex-shrink: 0; }
.persona-v2-cta { margin-top: auto; display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 14px; align-self: start; }
.persona-v2-cta::after { content: '→'; transition: transform .25s var(--ease-final); }
.persona-v2:hover .persona-v2-cta::after { transform: translateX(4px); }

/* ========== STORY-FIRST — фото + история клиента ========== */
.story-v2 { padding: 80px 0; }
.story-v2-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; align-items: center; }
.story-v2-photo {
  aspect-ratio: 4/3; border-radius: var(--radius-lg); position: relative; overflow: hidden;
  background:
    radial-gradient(ellipse 70% 50% at 50% 70%, rgba(255,200,87,0.3), transparent 60%),
    linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 60%, var(--text) 100%);
  box-shadow: 0 30px 60px -20px rgba(82,147,224,0.35);
}
.story-v2-photo svg { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0.5; }
.story-v2-photo-tag { position: absolute; top: 22px; left: 22px; padding: 8px 14px; background: rgba(255,255,255,0.95); backdrop-filter: blur(8px); border-radius: var(--radius-pill); font-size: 12px; font-weight: 700; color: var(--text); }
.story-v2-photo-tag::before { content: '⭐ '; color: var(--warm); }
.story-v2-cap { position: absolute; bottom: 22px; left: 22px; right: 22px; padding: 16px 20px; background: #fff; border-radius: var(--radius-md); box-shadow: 0 12px 30px rgba(0,0,0,0.18); }
.story-v2-cap-name { font-size: 14px; font-weight: 800; color: var(--text); }
.story-v2-cap-name b { color: var(--brand-blue); }
.story-v2-cap-d { font-size: 13px; color: var(--text-secondary); margin-top: 4px; line-height: 1.4; }
.story-v2-r-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--brand-cyan); letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; }
.story-v2-r-tit { font-size: clamp(32px, 4.2vw, 50px); font-weight: 800; line-height: 1.04; letter-spacing: -0.025em; margin-top: 12px; color: var(--heading); }
.story-v2-r-tit em { font-style: italic; font-family: var(--serif); font-weight: 500; color: var(--brand-blue); }
.story-v2-r-d { font-size: 16px; color: var(--text-secondary); margin-top: 20px; line-height: 1.55; }
.story-v2-r-list { margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--border-light); }
.story-v2-r-list-tit { font-size: 12px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; margin-bottom: 10px; }
.story-v2-r-list ul { list-style: none; padding: 0; }
.story-v2-r-list li { padding: 9px 0; border-bottom: 1px dashed var(--border-light); display: flex; gap: 12px; align-items: baseline; font-size: 14px; color: var(--text-secondary); }
.story-v2-r-list li::before { content: '→'; color: var(--brand-blue); font-weight: 700; }
.story-v2-r-list li b { color: var(--brand-blue-dark); font-weight: 700; }

/* ========== PULL-QUOTE TESTIMONIAL (журнальный разворот) ========== */
.pq-v2 { padding: 80px 0; background: var(--text); color: white; position: relative; overflow: hidden; }
.pq-v2::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 30%, rgba(82,147,224,0.18), transparent 60%),
    radial-gradient(ellipse 600px 400px at 80% 70%, rgba(2,161,197,0.15), transparent 60%);
}
.pq-v2-inner { position: relative; }
.pq-v2-head { padding-bottom: 28px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.pq-v2-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--gold); letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.pq-v2-eyebrow::before { content: '◆ '; }
.pq-v2-tit { font-size: clamp(32px, 4.4vw, 52px); font-weight: 700; letter-spacing: -0.025em; line-height: 1; margin-top: 12px; font-family: var(--serif); color: white; }
.pq-v2-tit em { font-style: italic; color: var(--brand-cyan); font-weight: 500; }
.pq-v2-spread { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: start; margin-top: 40px; }
.pq-v2-main {
  font-family: var(--serif); font-style: italic; font-weight: 500;
  font-size: clamp(24px, 3.4vw, 44px); line-height: 1.18; letter-spacing: -0.02em;
  position: relative; padding-left: 32px;
}
.pq-v2-main::before {
  content: '«'; font-size: 1.4em; color: var(--gold); position: absolute; left: -8px; top: -16px;
  font-weight: 800; line-height: 1;
}
.pq-v2-main .hl { background: linear-gradient(180deg, transparent 60%, rgba(255,200,87,0.35) 60%); padding: 0 4px; }
.pq-v2-author { display: flex; gap: 16px; margin-top: 32px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.18); align-items: center; }
.pq-v2-author-pic { width: 52px; height: 52px; border-radius: 50%; background: var(--grad-brand-final); display: grid; place-items: center; font-family: var(--serif); font-weight: 700; font-size: 19px; color: white; }
.pq-v2-author-info .n { font-weight: 700; font-size: 16px; color: white; }
.pq-v2-author-info .r { font-family: var(--mono); font-size: 12px; color: rgba(255,255,255,0.7); margin-top: 4px; }
.pq-v2-side { display: flex; flex-direction: column; gap: 18px; }
.pq-v2-side-q { padding: 18px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-md); }
.pq-v2-side-q-text { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.45; color: rgba(255,255,255,0.95); }
.pq-v2-side-q-cite { font-family: var(--mono); font-size: 11px; color: rgba(255,255,255,0.6); margin-top: 12px; letter-spacing: 0.08em; }
.pq-v2-side-q-cite b { color: var(--gold); font-weight: 600; }

/* ========== FINAL CTA BLOCK with calculator ========== */
.cta-v2 { padding: 80px 0; }
.cta-v2-block {
  padding: 56px; background: var(--grad-brand-final); border-radius: var(--radius-lg);
  position: relative; overflow: hidden; color: white;
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center;
}
.cta-v2-block::before {
  content: ''; position: absolute; top: -100px; right: -100px; width: 500px; height: 500px;
  border-radius: 50%; background: radial-gradient(circle, rgba(255,200,87,0.25), transparent 60%);
}
.cta-v2-l { position: relative; z-index: 1; }
.cta-v2-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--gold); letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.cta-v2-tit { font-size: clamp(32px, 4.2vw, 48px); font-weight: 800; line-height: 1.02; letter-spacing: -0.025em; margin-top: 12px; }
.cta-v2-tit em { font-style: italic; font-family: var(--serif); font-weight: 500; color: var(--gold); }
.cta-v2-d { font-size: 16px; opacity: 0.9; margin-top: 18px; max-width: 460px; line-height: 1.5; }
.cta-v2-r {
  position: relative; z-index: 1; padding: 24px;
  background: white; color: var(--text); border-radius: var(--radius-lg);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.3);
}
.cta-v2-stats { margin-top: 28px; display: flex; gap: 24px; flex-wrap: wrap; }
.cta-v2-stat .n { font-family: var(--mono); font-size: 26px; font-weight: 700; }
.cta-v2-stat .l { font-size: 11px; opacity: 0.85; text-transform: uppercase; letter-spacing: 0.08em; margin-top: 4px; }

/* ========== Warm CTA button (для оранжевого акцента) ========== */
.btn-warm {
  background: var(--warm); color: white; box-shadow: 0 3px 0 var(--warm-d);
  border: 0; padding: 14px 24px; border-radius: var(--radius-pill);
  font-weight: 700; font-size: 14px; cursor: pointer; transition: all .2s var(--ease-final);
  display: inline-flex; align-items: center; gap: 8px; text-decoration: none; font-family: inherit;
}
.btn-warm:hover { transform: translateY(-2px); box-shadow: 0 5px 0 var(--warm-d); }
.btn-warm.btn-block { width: 100%; justify-content: center; }

/* ========== Driver portraits (для секции «кто за рулём») ========== */
.drivers-v2 { padding: 80px 0; background: var(--bg-soft); }
.drivers-v2-head { margin-bottom: 32px; }
.drivers-v2-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--brand-cyan); letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.drivers-v2-tit { font-size: clamp(28px, 4vw, 44px); font-weight: 800; letter-spacing: -0.025em; line-height: 1; margin-top: 10px; color: var(--heading); }
.drivers-v2-tit em { font-style: italic; font-family: var(--serif); font-weight: 500; color: var(--brand-blue); }
.drivers-v2-d { font-size: 15px; color: var(--text-secondary); margin-top: 12px; max-width: 540px; line-height: 1.5; }
.drivers-v2-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.driver-v2-card { background: #fff; border-radius: var(--radius-lg); border: 1px solid var(--border); overflow: hidden; transition: all .3s var(--ease-final); }
.driver-v2-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.driver-v2-photo { aspect-ratio: 5/4; position: relative; }
.driver-v2-p1 { background: linear-gradient(135deg, var(--brand-blue), var(--brand-blue-dark)); }
.driver-v2-p2 { background: linear-gradient(135deg, var(--brand-cyan), var(--brand-cyan-dark)); }
.driver-v2-p3 { background: linear-gradient(135deg, var(--text), var(--brand-blue-dark)); }
.driver-v2-photo svg { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0.7; }
.driver-v2-photo-tag { position: absolute; bottom: 14px; left: 14px; padding: 6px 12px; background: white; border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; color: var(--text); }
.driver-v2-photo-tag::before { content: '⭐ '; color: var(--warm); }
.driver-v2-body { padding: 22px; }
.driver-v2-name { font-weight: 800; font-size: 17px; color: var(--text); }
.driver-v2-role { font-size: 12px; color: var(--text-muted); margin-top: 2px; font-weight: 500; }
.driver-v2-quote { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.45; margin-top: 14px; color: var(--text-secondary); }
.driver-v2-stats { display: flex; gap: 14px; margin-top: 16px; padding-top: 14px; border-top: 1px dashed var(--border-light); }
.driver-v2-stat .n { font-family: var(--mono); font-weight: 700; color: var(--brand-blue); font-size: 15px; }
.driver-v2-stat .l { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 2px; }

/* ========== Map v2 — clean SVG with brand colors ========== */
.mapsec-v2 { padding: 80px 0; }
.mapsec-v2-head { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: end; margin-bottom: 32px; }
.mapsec-v2-eyebrow { font-family: var(--mono); font-size: 12px; color: var(--brand-cyan); letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.mapsec-v2-tit { font-size: clamp(28px, 4vw, 44px); font-weight: 800; letter-spacing: -0.025em; line-height: 1; margin-top: 10px; color: var(--heading); }
.mapsec-v2-tit em { font-style: italic; font-family: var(--serif); font-weight: 500; color: var(--brand-blue); }
.mapsec-v2-d { font-size: 15px; color: var(--text-secondary); line-height: 1.55; }
.mapsec-v2-stage {
  padding: 28px; background: linear-gradient(180deg, var(--brand-blue-light), #fff);
  border: 1px solid var(--border); border-radius: var(--radius-lg); position: relative;
}
.mapsec-v2-stage svg { width: 100%; height: auto; display: block; }
.mapsec-v2-leg { position: absolute; top: 28px; right: 28px; padding: 14px 16px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); min-width: 200px; box-shadow: var(--shadow-sm); }
.mapsec-v2-leg-tit { font-family: var(--mono); font-size: 10px; color: var(--text-muted); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 8px; font-weight: 600; }
.mapsec-v2-leg-row { display: flex; gap: 10px; align-items: center; padding: 4px 0; font-size: 13px; color: var(--text); }
.mapsec-v2-leg-row .dot { width: 8px; height: 8px; border-radius: 50%; }
.mapsec-v2-leg-row .n { margin-left: auto; font-family: var(--mono); font-size: 12px; color: var(--text-muted); font-weight: 600; }

/* ========== Responsive ========== */
@media (max-width: 1000px) {
  .hero-v2-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-v2-meta { grid-template-columns: 1fr 1fr; }
  .personas-v2-grid { grid-template-columns: 1fr; gap: 16px; }
  .story-v2-grid { grid-template-columns: 1fr; gap: 32px; }
  .pq-v2-spread { grid-template-columns: 1fr; gap: 32px; }
  .cta-v2-block { grid-template-columns: 1fr; gap: 32px; padding: 36px; }
  .drivers-v2-grid { grid-template-columns: 1fr; gap: 16px; }
  .mapsec-v2-head { grid-template-columns: 1fr; gap: 24px; }
  .mapsec-v2-leg { position: static; margin-top: 16px; }
  .bignum-v2 { padding: 64px 0 48px; }
  .personas-v2, .story-v2, .pq-v2, .cta-v2, .drivers-v2, .mapsec-v2 { padding: 56px 0; }
}

/* =============================================================
   v2.1 — ГАРМОНИЗАЦИЯ И ПЛАВНЫЕ ПЕРЕХОДЫ (Май 2026)
   Мягкие градиенты под секциями, soft-фон под фотками тарифов
   ============================================================= */

/* ===== Soft фон под фотками тарифов (пропорции сохраняем) ===== */
.tariff-card .tariff-truck {
  width: 100% !important;
  height: 170px !important;
  background:
    radial-gradient(ellipse 70% 50% at 50% 80%, rgba(82,147,224,0.10), transparent 70%),
    linear-gradient(180deg, #f7faff 0%, #ffffff 80%) !important;
  border-radius: 16px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin-bottom: 16px !important;
  overflow: hidden !important;
  box-shadow: none !important;
  position: relative;
}
.tariff-card .tariff-truck::after {
  content: ''; position: absolute; left: 14%; right: 14%; bottom: 12px;
  height: 5px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(82,147,224,0.16), transparent 70%);
  pointer-events: none;
}
.tariff-card .tariff-truck img {
  width: auto !important;
  max-width: 90% !important;
  height: auto !important;
  max-height: 80% !important;
  object-fit: contain !important;
  mix-blend-mode: normal !important;
  filter: drop-shadow(0 6px 12px rgba(82,147,224,0.12)) !important;
  position: relative; z-index: 1;
  transition: transform .35s cubic-bezier(0.16, 1, 0.3, 1);
}
.tariff-card:hover .tariff-truck img { transform: scale(1.04); }

/* ===== Плавные градиентные переходы между секциями ===== */
/* убираем жёсткие границы, добавляем мягкие переходы */
.hero, .hero-v2 { padding-bottom: 64px; }
.bignum-v2 {
  background: linear-gradient(180deg, transparent 0%, rgba(232,241,251,0.4) 50%, transparent 100%);
  position: relative;
}
.bignum-v2::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 80px;
  background: linear-gradient(180deg, transparent 0%, var(--bg-soft) 100%);
  pointer-events: none;
}
.personas-v2 { padding-top: 60px; }
.personas-v2::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 80px;
  background: linear-gradient(180deg, transparent 0%, var(--bg-soft) 100%);
  pointer-events: none; z-index: -1;
}
.story-v2 {
  background: linear-gradient(180deg, var(--bg-soft) 0%, transparent 80%);
}
.mapsec-v2 {
  background: linear-gradient(180deg, transparent 0%, var(--brand-blue-light) 50%, transparent 100%);
}
.drivers-v2 {
  background: linear-gradient(180deg, transparent 0%, var(--bg-soft) 30%, var(--bg-soft) 70%, transparent 100%);
}
.pq-v2 {
  position: relative;
}
.pq-v2::before {
  content: ''; position: absolute; top: -1px; left: 0; right: 0; height: 60px;
  background: linear-gradient(180deg, var(--bg) 0%, transparent 100%);
  z-index: 1; pointer-events: none;
}
.pq-v2::after {
  content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 60px;
  background: linear-gradient(0deg, var(--bg) 0%, transparent 100%);
  z-index: 1; pointer-events: none;
}
.cta-v2 { padding-top: 100px; }

/* ===== Реальные фото портретов водителей ===== */
.driver-v2-photo {
  position: relative;
  background-size: cover; background-position: center;
}
.driver-v2-photo[style*="--photo-1"], .driver-v2-photo.driver-v2-p1 {
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%), url('../img/drv-1.jpg');

  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%), image-set(url('../img/drv-1.webp') type('image/webp'), url('../img/drv-1.jpg') type('image/jpeg'));
  background-size: cover; background-position: center;
}
.driver-v2-photo[style*="--photo-2"], .driver-v2-photo.driver-v2-p2 {
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%), url('../img/drv-2.jpg');

  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%), image-set(url('../img/drv-2.webp') type('image/webp'), url('../img/drv-2.jpg') type('image/jpeg'));
  background-size: cover; background-position: center;
}
.driver-v2-photo[style*="--photo-3"], .driver-v2-photo.driver-v2-p3 {
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%), url('../img/drv-3.jpg');

  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%), image-set(url('../img/drv-3.webp') type('image/webp'), url('../img/drv-3.jpg') type('image/jpeg'));
  background-size: cover; background-position: center;
}
.driver-v2-photo svg { display: none; } /* убираем SVG-силуэты — теперь реальные фото */

/* ===== Smooth easing на всё ===== */
.feature-card, .tariff-card, .review-card, .step, .persona-v2, .driver-v2-card,
.faq-item, .btn, .nav-link, .hqc-preset, .hqc-pill {
  transition: transform .3s cubic-bezier(0.16, 1, 0.3, 1), 
              box-shadow .3s cubic-bezier(0.16, 1, 0.3, 1),
              border-color .25s ease, 
              background-color .25s ease, 
              color .2s ease;
}

/* ===== Hero — добавим мягкий фон-переход к секции ниже ===== */
.hero-v2::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 100px;
  background: linear-gradient(180deg, transparent 0%, rgba(82,147,224,0.04) 100%);
  pointer-events: none;
}

/* ===== Trust strip — мягкий вход и выход ===== */
.trust-strip-v2 {
  position: relative;
}
.trust-strip-v2::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
}
.trust-strip-v2::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
}

/* ===== Карточки в bento и личностях — гармоничные тени ===== */
.persona-v2 {
  box-shadow: 0 1px 0 rgba(82,147,224,0.04), 0 8px 24px -12px rgba(82,147,224,0.12);
}
.persona-v2:hover {
  box-shadow: 0 4px 0 rgba(82,147,224,0.08), 0 24px 48px -16px rgba(82,147,224,0.25);
}
.driver-v2-card {
  box-shadow: 0 1px 0 rgba(82,147,224,0.04), 0 8px 24px -12px rgba(82,147,224,0.10);
}
.driver-v2-card:hover {
  box-shadow: 0 4px 0 rgba(82,147,224,0.08), 0 20px 40px -16px rgba(82,147,224,0.20);
}

/* ===== Скролл-плавность по всему сайту ===== */
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
  body { scroll-padding-top: 80px; }
}

/* =============================================================
   v2.2 — ЕДИНЫЙ СТИЛЬ: применяется на всех страницах
   ============================================================= */

/* Italic-серифовые акценты в H1/H2 на всех страницах */
.page-hero h1 em,
.section-head h2 em,
h1 em,
h2 em {
  font-style: italic;
  font-family: var(--serif);
  font-weight: 500;
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* page-hero (Тарифы / Клиентам / Водителям и т.д.) — общий v2-стиль */
.page-hero:not(.page-hero-with-photo) {
  padding: 64px 0 32px;
  position: relative;
  overflow: hidden;
}
.page-hero:not(.page-hero-with-photo)::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse 600px 400px at 80% 0%, rgba(2,161,197,0.06), transparent 60%),
    radial-gradient(ellipse 500px 400px at 0% 100%, rgba(82,147,224,0.05), transparent 60%);
}
.page-hero:not(.page-hero-with-photo) h1 {
  font-size: clamp(36px, 5vw, 68px);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--heading);
  margin-top: 12px;
}
.page-hero:not(.page-hero-with-photo) p {
  font-size: 17px;
  color: var(--text-secondary);
  line-height: 1.55;
  max-width: 680px;
  margin-top: 18px;
}
.page-hero:not(.page-hero-with-photo) .breadcrumbs {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.page-hero:not(.page-hero-with-photo) .breadcrumbs a { color: var(--brand-blue); text-decoration: none; }
.page-hero:not(.page-hero-with-photo) .breadcrumbs a:hover { text-decoration: underline; }

/* === Усиление контраста на photo-hero (Клиентам) === */
.page-hero-with-photo::after {
  background: linear-gradient(135deg, rgba(15,27,45,0.85), rgba(15,27,45,0.62), rgba(82,147,224,0.55)) !important;
}
.page-hero-with-photo h1,
.page-hero-with-photo h1 em {
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  background: none !important;
  text-shadow: 0 2px 16px rgba(0,0,0,0.3);
}
.page-hero-with-photo h1 em {
  font-style: italic;
  font-family: var(--serif);
  font-weight: 500;
  color: #FFD080 !important;
  -webkit-text-fill-color: #FFD080 !important;
}
.page-hero-with-photo p {
  color: rgba(255,255,255,0.96) !important;
  font-size: 17px;
  line-height: 1.55;
  text-shadow: 0 1px 8px rgba(0,0,0,0.4);
}
.page-hero-with-photo .breadcrumbs,
.page-hero-with-photo .breadcrumbs a {
  color: rgba(255,255,255,0.88) !important;
}

/* eyebrow (метка-тег) единый */
.eyebrow {
  font-family: var(--mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--brand-cyan) !important;
  font-weight: 600 !important;
}

/* Section-title — applied italic em uniformly */
.section-title em {
  font-style: italic;
  font-family: var(--serif);
  font-weight: 500;
  background: linear-gradient(135deg, var(--brand-blue), var(--brand-cyan));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Highlight-block (страница «order» и Pages where used) — soft transitions */
.highlight-block {
  background: linear-gradient(180deg, var(--bg-soft) 0%, transparent 80%);
}
.highlight-block h2 em {
  font-style: italic;
  font-family: var(--serif);
  font-weight: 500;
  color: var(--brand-blue);
}

/* Кнопки — единый smooth-hover везде */
.btn { transition: all .25s cubic-bezier(0.16, 1, 0.3, 1); }
.btn-primary:hover { transform: translateY(-2px); }

/* Цифры — везде моноширинный шрифт для tabular nums */
.hero-stat .num,
.hero-russia-stats .hgs-num,
.reviews-rating-big .rating-num,
.tracking-driver .driver-stars,
.compliance-badge,
.tariff-price .num,
.feature-card h4 + p strong {
  font-family: var(--mono);
  font-feature-settings: 'tnum', 'zero', 'ss01';
}

/* На всех страницах добавим приятный header-shadow при скролле */
.site-header { transition: box-shadow .3s ease, background .3s ease; }
.site-header.scrolled {
  box-shadow: 0 4px 20px -8px rgba(82,147,224,0.18);
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(20px);
}


/* =============================================================
   v2.3 — Размер контейнера значков унифицирован
   (логотипы Apple/Google в их официальной палитре)
   ============================================================= */
.store-btn svg {
  width: 24px !important;
  height: 24px !important;
  flex-shrink: 0;
}
/* Текстовые лейблы выравниваем единообразно */
.store-btn > span:last-child {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}
.store-btn > span:last-child .small {
  font-size: 10px;
  opacity: 0.78;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 500;
}
.store-btn > span:last-child .big {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-top: 1px;
}

/* QR-ссылки рядом со значками — единый стиль pill */
.footer-qr,
.driver-qr {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(82,147,224,0.10);
  transition: all .25s var(--ease-final);
}
.footer-qr:hover, .driver-qr:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(82,147,224,0.18);
  border-color: var(--brand-blue);
}

/* ==============================================================
   v3 — ФИНАЛЬНАЯ УНИФИКАЦИЯ ДИЗАЙН-СИСТЕМЫ (Май 2026)
   Один радиус, одни тени, один easing, одни акценты.
   Заглушает все конфликты предыдущих v2.x слоёв.
   ============================================================== */

:root {
  /* Радиусы — только 4 значения */
  --r-1: 10px;       /* мелкие элементы */
  --r-2: 16px;       /* карточки */
  --r-3: 24px;       /* большие блоки */
  --r-99: 999px;     /* пилюли */

  /* Тени — 3 уровня (синий-окрашенные) */
  --sh-1: 0 1px 2px rgba(15,27,45,0.04), 0 0 0 1px rgba(15,27,45,0.04);
  --sh-2: 0 4px 12px -4px rgba(82,147,224,0.16), 0 0 0 1px rgba(82,147,224,0.06);
  --sh-3: 0 24px 48px -16px rgba(82,147,224,0.22), 0 0 0 1px rgba(82,147,224,0.08);

  /* Один easing на все переходы */
  --e: cubic-bezier(0.2, 0.9, 0.3, 1);
}

/* ===== УНИФИКАЦИЯ КАРТОЧЕК ===== */
.feature-card,
.tariff-card,
.review-card,
.step,
.persona-v2,
.driver-v2-card,
.faq-item,
.bento {
  border-radius: var(--r-3) !important;
  border: 1px solid var(--border) !important;
  background: #fff !important;
  box-shadow: var(--sh-1) !important;
  transition: transform .35s var(--e), box-shadow .35s var(--e) !important;
}
.feature-card:hover,
.tariff-card:hover,
.review-card:hover,
.persona-v2:hover,
.driver-v2-card:hover,
.bento:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--sh-3) !important;
  border-color: rgba(82,147,224,0.25) !important;
}
/* Тёмные плитки сохраняют свой характер */
.persona-v2-2 { background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%) !important; border-color: transparent !important; color: #fff !important; }
.persona-v2-3 { background: var(--text) !important; border-color: transparent !important; color: #fff !important; }

/* ===== ТИПОГРАФИКА — ОДИН ШРИФТ + ОДИН ITALIC АКЦЕНТ ===== */
h1, h2, h3, h4, h5 { letter-spacing: -0.025em; font-feature-settings: 'cv11', 'ss01'; }
h1 em, h2 em, .section-title em, .hero-v2-title em, .bignum-v2-tagline em,
.cta-v2-tit em, .pq-v2-tit em, .mapsec-v2-tit em, .drivers-v2-tit em,
.story-v2-r-tit em, .personas-v2-tit em, .bento-l h2 em {
  font-style: italic !important;
  font-family: 'Fraunces', Georgia, serif !important;
  font-weight: 500 !important;
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

/* ===== EYEBROW — ОДИН СТИЛЬ ВЕЗДЕ (без "//") ===== */
.eyebrow,
.bignum-v2-eyebrow,
.personas-v2-eyebrow,
.bento-l-eyebrow,
.story-v2-r-eyebrow,
.mapsec-v2-eyebrow,
.drivers-v2-eyebrow,
.cta-v2-eyebrow,
.pq-v2-eyebrow {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--brand-cyan) !important;
  display: inline-block;
}
.bignum-v2-eyebrow::before,
.personas-v2-eyebrow::before,
.bento-l-eyebrow::before,
.story-v2-r-eyebrow::before,
.mapsec-v2-eyebrow::before,
.drivers-v2-eyebrow::before,
.cta-v2-eyebrow::before {
  content: '' !important;
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--brand-cyan);
  vertical-align: middle;
  margin-right: 10px;
}
.cta-v2-eyebrow { color: rgba(255,255,255,0.85) !important; }
.cta-v2-eyebrow::before { background: rgba(255,255,255,0.5) !important; }
.pq-v2-eyebrow { color: rgba(255,255,255,0.7) !important; }
.pq-v2-eyebrow::before { content: '◆' !important; width: auto !important; height: auto !important; background: none !important; color: var(--brand-cyan); margin-right: 8px; }

/* ===== КНОПКИ — единая система ===== */
.btn,
.hqc-submit,
.cta-r-cta,
.btn-warm {
  border-radius: var(--r-99) !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  transition: transform .25s var(--e), box-shadow .25s var(--e), background .2s ease !important;
  border: 1px solid transparent !important;
}
.btn-primary,
.hqc-submit,
.cta-r-cta,
.btn-warm {
  background: linear-gradient(135deg, #FF8B3D 0%, #FF6E1F 100%) !important;
  color: #fff !important;
  box-shadow: 0 6px 20px -4px rgba(255,139,61,0.4) !important;
}
.btn-primary:hover, .hqc-submit:hover, .cta-r-cta:hover, .btn-warm:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 24px -4px rgba(255,139,61,0.5) !important;
}
.btn-outline {
  background: transparent !important;
  border-color: var(--text) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}
.btn-outline:hover {
  background: var(--text) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* ===== БЭДЖИ ===== */
.app-badge, .ai-badge, .hero-v2-tag, .feed-tag {
  border-radius: var(--r-99) !important;
}
.hero-v2-tag {
  background: rgba(255,255,255,0.85) !important;
  backdrop-filter: blur(12px);
  border: 1px solid rgba(82,147,224,0.18) !important;
  color: var(--text) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  padding: 8px 14px !important;
  box-shadow: var(--sh-1) !important;
}

/* ===== SECTION SPACING — одинаковый ритм ===== */
.bignum-v2,
.personas-v2,
.bento-sec,
.story-v2,
.mapsec-v2,
.drivers-v2,
.feed,
.pq-v2,
.cta-v2,
.section-soft,
section.app-section {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}
@media (max-width: 720px) {
  .bignum-v2, .personas-v2, .bento-sec, .story-v2, .mapsec-v2,
  .drivers-v2, .feed, .pq-v2, .cta-v2, .section-soft, section.app-section {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }
}

/* Убираю избыточные градиенты-«облака» между секциями (они мешали ритму) */
.bignum-v2::after,
.personas-v2::before,
.pq-v2::before,
.pq-v2::after { display: none !important; }

/* ===== Зачищаем разнобой ===== */
.persona-v2-cta { color: inherit !important; }
.persona-v2-1 .persona-v2-cta { color: var(--brand-blue) !important; }
.persona-v2-3 .persona-v2-cta { color: var(--brand-cyan) !important; }

/* Цитаты в pull-quote — единый стиль */
.pq-v2-main {
  padding-left: 0 !important;
  font-size: clamp(24px, 3.2vw, 40px) !important;
  font-weight: 400 !important;
}
.pq-v2-main::before {
  position: relative !important;
  left: 0 !important;
  top: 0 !important;
  display: block;
  margin-bottom: 16px;
  font-size: 64px !important;
  color: var(--brand-cyan) !important;
}

/* Карточки feed — те же закруглённости */
.feed-card { border-radius: var(--r-2) !important; box-shadow: var(--sh-1) !important; }
.feed-card:hover { box-shadow: var(--sh-2) !important; }

/* ===== Унификация compliance-row ===== */
.compliance-badge {
  border-radius: var(--r-99) !important;
  padding: 8px 14px !important;
  font-weight: 500 !important;
  font-size: 12px !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: -0.005em !important;
  font-feature-settings: 'tnum';
}

/* ===== Картинка-пин на карте — лёгкий чёрный обвод ===== */
.mapsec-v2-stage svg circle[stroke="white"] { stroke: rgba(255,255,255,0.85) !important; }

/* ===== Скруглить карточки тарифов до общего ===== */
.tariff-card, .feature-card, .review-card, .step { border-radius: var(--r-3) !important; }

/* Hover на всех CTA — один эффект */
.persona-v2:hover, .feature-card:hover, .tariff-card:hover, .step:hover, .review-card:hover { transition-duration: .3s !important; }

/* ===== УБИРАЕМ Все следы caveat/гель-стилей ===== */
.hand, [class*="hand-"] { font-family: 'Inter', sans-serif !important; font-style: normal !important; }


/* ==============================================================
   v4 — STRIP DOWN: убираем «стенгазету»
   Делаем сайт как у Stripe/Linear/Loadsmart — сдержанно
   ============================================================== */

/* === ТИПОГРАФИКА: только Inter, никаких серифных italic === */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', -apple-system, system-ui, sans-serif !important;
  font-style: normal !important;
  font-weight: 700 !important;
  letter-spacing: -0.022em !important;
  color: var(--heading) !important;
}

/* Italic em — теперь просто бренд-синий, БЕЗ серифа, БЕЗ градиента */
h1 em, h2 em, h3 em, h4 em,
.section-title em, .hero-v2-title em, .bignum-v2-tagline em,
.cta-v2-tit em, .pq-v2-tit em, .mapsec-v2-tit em, .drivers-v2-tit em,
.story-v2-r-tit em, .personas-v2-tit em, .bento-l h2 em,
.page-hero h1 em, .highlight-block h2 em {
  font-style: normal !important;
  font-family: inherit !important;
  font-weight: 700 !important;
  background: none !important;
  -webkit-text-fill-color: var(--brand-blue) !important;
  color: var(--brand-blue) !important;
}

/* page-hero-with-photo — em остаётся золотистым на тёмном фоне, белым основной */
.page-hero-with-photo h1 em {
  -webkit-text-fill-color: #FFD080 !important;
  color: #FFD080 !important;
}

/* === ЦИФРЫ: оставить tabular Inter, НО НЕ JetBrains Mono === */
.hero-v2-meta-i .num, .bignum-v2-num, .b3-stat-num, .h3-stat-num,
.feed-card-meta-i .n, .driver-v2-stat .n, .cta-v2-stat .n,
.hero-stat .num, .hero-russia-stats .hgs-num, .reviews-rating-big .rating-num,
.compliance-badge, .tariff-price .num, .hero-v2-calc-out-num,
.hqc-result-price, .pq-v2-author-info .r,
.bs2-card-meta-i .n, .b1-meta-item .num, .h3-stat-num,
.feed-card-rt {
  font-family: 'Inter', sans-serif !important;
  font-feature-settings: 'tnum', 'cv11', 'ss01' !important;
}

/* === BIG NUMBER: уменьшить, обычный sans-serif === */
.bignum-v2 { padding: 80px 0 !important; background: none !important; }
.bignum-v2::after, .bignum-v2::before { display: none !important; }
.bignum-v2-num {
  font-family: 'Inter', sans-serif !important;
  font-style: normal !important;
  font-weight: 800 !important;
  font-size: clamp(96px, 14vw, 200px) !important;
  letter-spacing: -0.04em !important;
  line-height: 1 !important;
  background: none !important;
  -webkit-text-fill-color: var(--text) !important;
  color: var(--text) !important;
}
.bignum-v2-units {
  font-family: 'Inter', sans-serif !important;
  font-style: normal !important;
  font-size: 18px !important;
  color: var(--text-secondary) !important;
  margin-top: 4px !important;
  font-weight: 500 !important;
}
.bignum-v2-tagline {
  font-size: clamp(22px, 2.6vw, 32px) !important;
  font-weight: 600 !important;
  margin-top: 32px !important;
}

/* === EYEBROWS: убрать "//" префикс, упростить === */
.eyebrow,
.bignum-v2-eyebrow,
.personas-v2-eyebrow,
.bento-l-eyebrow,
.story-v2-r-eyebrow,
.mapsec-v2-eyebrow,
.drivers-v2-eyebrow,
.cta-v2-eyebrow,
.pq-v2-eyebrow,
.story-v2-photo-tag,
.driver-v2-photo-tag {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--brand-blue) !important;
}
.bignum-v2-eyebrow::before,
.personas-v2-eyebrow::before,
.bento-l-eyebrow::before,
.story-v2-r-eyebrow::before,
.mapsec-v2-eyebrow::before,
.drivers-v2-eyebrow::before,
.cta-v2-eyebrow::before,
.pq-v2-eyebrow::before {
  display: none !important;
}

/* === КНОПКИ: ПРИМАРНАЯ = БРЕНД-СИНИЙ (не оранжевый) === */
.btn-primary, .hqc-submit, .cta-r-cta, .btn-warm,
.h1-btn-primary, .b1-btn-primary {
  background: var(--brand-blue) !important;
  background-image: none !important;
  color: #fff !important;
  border-radius: 10px !important;
  font-weight: 600 !important;
  box-shadow: none !important;
  border: 1px solid var(--brand-blue) !important;
  letter-spacing: -0.005em !important;
}
.btn-primary:hover, .hqc-submit:hover, .cta-r-cta:hover, .btn-warm:hover {
  background: var(--brand-blue-dark) !important;
  border-color: var(--brand-blue-dark) !important;
  transform: none !important;
  box-shadow: 0 4px 12px -2px rgba(82,147,224,0.4) !important;
}
.btn-outline {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: 10px !important;
  font-weight: 600 !important;
}
.btn-outline:hover {
  background: var(--bg-soft) !important;
  border-color: var(--text) !important;
  color: var(--text) !important;
  transform: none !important;
}

/* === КАРТОЧКИ: сдержанные, без агрессивного hover === */
.feature-card, .tariff-card, .review-card, .step,
.persona-v2, .driver-v2-card, .faq-item, .bento, .feed-card {
  border-radius: 16px !important;
  border: 1px solid var(--border-light) !important;
  background: #fff !important;
  box-shadow: none !important;
  transition: border-color .2s ease, transform .2s ease !important;
}
.feature-card:hover, .tariff-card:hover, .review-card:hover,
.persona-v2:hover, .driver-v2-card:hover, .bento:hover, .feed-card:hover {
  border-color: var(--brand-blue) !important;
  transform: none !important;
  box-shadow: 0 4px 16px -8px rgba(82,147,224,0.2) !important;
}

/* === PERSONAS: тёмные плитки убираем, делаем все белыми === */
.persona-v2-2, .persona-v2-3 {
  background: #fff !important;
  color: var(--text) !important;
  border: 1px solid var(--border-light) !important;
}
.persona-v2-2 .persona-v2-d, .persona-v2-3 .persona-v2-d { color: var(--text-secondary) !important; }
.persona-v2-2 .persona-v2-list, .persona-v2-3 .persona-v2-list { color: var(--text-secondary) !important; }
.persona-v2-cta, .persona-v2-2 .persona-v2-cta, .persona-v2-3 .persona-v2-cta {
  color: var(--brand-blue) !important;
}

/* Убираем emoji из persona-tit (визуально читать чище) */
.persona-v2-emoji {
  font-size: 32px !important;
  opacity: 0.8;
}

/* === PULL-QUOTE: упростить, убрать «◆» и сериф === */
.pq-v2 {
  background: var(--bg-soft) !important;
  color: var(--text) !important;
}
.pq-v2::before, .pq-v2::after { display: none !important; }
.pq-v2-tit {
  font-family: 'Inter', sans-serif !important;
  font-style: normal !important;
  color: var(--text) !important;
}
.pq-v2-main {
  font-family: 'Inter', sans-serif !important;
  font-style: normal !important;
  font-weight: 500 !important;
  color: var(--text) !important;
  font-size: clamp(20px, 2.6vw, 30px) !important;
  line-height: 1.4 !important;
}
.pq-v2-main::before { display: none !important; }
.pq-v2-main .hl { background: none !important; padding: 0 !important; color: var(--brand-blue) !important; }
.pq-v2-author-info .n { color: var(--text) !important; font-weight: 600 !important; }
.pq-v2-author-info .r { color: var(--text-muted) !important; font-family: 'Inter', sans-serif !important; }
.pq-v2-author { border-color: var(--border-light) !important; }
.pq-v2-author-pic { background: var(--brand-blue) !important; }
.pq-v2-side-q {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
}
.pq-v2-side-q-text { color: var(--text-secondary) !important; font-style: normal !important; font-family: 'Inter', sans-serif !important; }
.pq-v2-side-q-cite { color: var(--text-muted) !important; font-family: 'Inter', sans-serif !important; }
.pq-v2-side-q-cite b { color: var(--brand-blue) !important; }

/* === FINAL CTA-блок: упростить === */
.cta-v2-block {
  background: var(--text) !important;
  color: #fff !important;
}
.cta-v2-block::before { display: none !important; }
.cta-v2-eyebrow { color: rgba(255,255,255,0.5) !important; }
.cta-v2-tit em { -webkit-text-fill-color: var(--brand-cyan) !important; color: var(--brand-cyan) !important; }
.cta-v2-r { background: rgba(255,255,255,0.06) !important; backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.12) !important; color: #fff; }
.cta-v2-r > div:first-child { color: #fff !important; }
.cta-v2-r-tit { color: #fff !important; }

/* === TRUST STRIP: убрать марки золотом, делать аккуратно серым === */
.trust-strip-v2 {
  background: #fff !important;
  color: var(--text-secondary) !important;
  border-top: 1px solid var(--border-light) !important;
  border-bottom: 1px solid var(--border-light) !important;
  padding: 12px 0 !important;
}
.trust-strip-v2-inner span { font-size: 13px !important; color: var(--text-secondary) !important; font-weight: 500 !important; font-family: 'Inter', sans-serif !important; }
.trust-strip-v2-inner span b { color: var(--text) !important; font-weight: 700 !important; }
.trust-strip-v2::before, .trust-strip-v2::after { display: none !important; }

/* === HERO TAG: спокойный === */
.hero-v2-tag {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  color: var(--text-secondary) !important;
  font-weight: 500 !important;
  box-shadow: none !important;
  font-size: 13px !important;
  padding: 6px 14px !important;
}
.hero-v2-tag::before { background: var(--brand-blue) !important; }

/* === HERO CALC: убрать оранжевый стикер === */
.hero-v2-calc::before { display: none !important; }
.hero-v2-calc { box-shadow: 0 8px 32px -12px rgba(82,147,224,0.16) !important; }
.hero-v2-calc-out {
  background: var(--bg-soft) !important;
  border: 1px solid var(--border-light) !important;
}
.hero-v2-calc-out-num { color: var(--text) !important; }

/* === PAGE-HERO простой === */
.page-hero:not(.page-hero-with-photo) { padding: 64px 0 32px !important; }
.page-hero:not(.page-hero-with-photo)::before { display: none !important; }

/* === ТАРИФЫ: убрать тяжёлый фон под фотками — пусть будет чисто === */
.tariff-card .tariff-truck {
  background: var(--bg-soft) !important;
  height: 160px !important;
}
.tariff-card .tariff-truck::after { display: none !important; }

/* === LIVE-FEED — спокойная подсветка статусов === */
.feed-card-rt { font-family: 'Inter', sans-serif !important; font-size: 11px !important; font-weight: 600 !important; color: var(--brand-blue) !important; text-transform: uppercase !important; letter-spacing: 0.06em !important; }
.feed-card-rt::before { background: var(--brand-blue) !important; }
.feed-card-rt.warm { color: var(--text-secondary) !important; } .feed-card-rt.warm::before { background: var(--text-muted) !important; }
.feed-card-rt.blue { color: var(--brand-blue) !important; } .feed-card-rt.blue::before { background: var(--brand-blue) !important; }

/* === КАРТА — один синий на всё === */
.mapsec-v2-stage svg path[stroke="#02A1C5"] { stroke: var(--brand-blue) !important; }
.mapsec-v2-stage svg circle[fill="#02A1C5"] { fill: var(--brand-blue) !important; }
.mapsec-v2-stage svg circle[fill="#FF8B3D"] { fill: var(--brand-blue) !important; }
.mapsec-v2-stage svg circle[stroke="#FF8B3D"] { stroke: var(--brand-blue) !important; }

/* Compliance — ровные бэйджи */
.compliance-badge {
  background: var(--bg-soft) !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  color: var(--text-secondary) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
}

/* === Драйверы: сдержанная тень, без оранжевой звезды на бейдже === */
.driver-v2-photo-tag::before { color: var(--brand-blue) !important; }
.driver-v2-stat .n { color: var(--text) !important; font-weight: 700 !important; }

/* === Site-header — лёгкая граница, без слоистых эффектов === */
.site-header.scrolled { box-shadow: 0 1px 0 var(--border-light) !important; }


/* ==============================================================
   v5 — ЧИСТКА КАЛЬКУЛЯТОРА (зеленый кружок + ромб + плашка → ушли)
   ============================================================== */

/* Унификация маркеров «откуда / куда» — оба нейтральные синие точки */
.hqc-dot.a, .hqc-dot.b {
  width: 10px !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: #fff !important;
  border: 2px solid var(--brand-blue) !important;
  box-shadow: none !important;
  transform: none !important;
}
.hqc-dot.b { border-color: var(--text) !important; }

/* Поля «Откуда/Куда» — спокойные, без зеленовато-сирен */
.hqc-field { background: #fff !important; border: 1px solid var(--border-light) !important; }
.hqc-field:focus-within { border-color: var(--brand-blue) !important; box-shadow: 0 0 0 3px rgba(82,147,224,0.12) !important; }

/* Селект машины — выровнен с чекбоксом */
.hqc-row {
  grid-template-columns: 1.4fr 1fr !important;
  gap: 12px !important;
  align-items: stretch !important;
}
.hqc-row select {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  font-weight: 500 !important;
  height: 46px !important;
}

/* Чекбокс «Страхование» — БЕЛЫЙ, без зелёной плашки */
.hqc-check {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  color: var(--text-secondary) !important;
  height: 46px !important;
  padding: 0 14px !important;
  font-weight: 500 !important;
  font-size: 13px !important;
  display: flex !important;
  align-items: center !important;
}
.hqc-check input[type="checkbox"] {
  accent-color: var(--brand-blue);
  width: 16px;
  height: 16px;
}
/* Эмодзи 🛡️ убираем — пусть только текст */
.hqc-check span { font-weight: 500; }

/* CTA-кнопка калькулятора — точно синий, без оранжевого */
.hqc-submit {
  background: var(--brand-blue) !important;
  background-image: none !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 12px !important;
  height: 52px !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  letter-spacing: -0.005em !important;
  margin-top: 6px !important;
  box-shadow: 0 4px 14px -4px rgba(82,147,224,0.4) !important;
  transition: background .2s ease, box-shadow .2s ease, transform .2s ease !important;
}
.hqc-submit:hover {
  background: var(--brand-blue-dark) !important;
  box-shadow: 0 6px 18px -4px rgba(82,147,224,0.5) !important;
  transform: none !important;
}

/* Убираем стикер «считаем за 2 секунды» (он перекрывал верх) */
.hero-v2-calc::before { content: none !important; display: none !important; }

/* Trust-line под формой: текст без эмодзи и иконок */
.hero-v2-calc + div,
.hero-v2-calc ~ div[style*="display:flex"] { display: none !important; }

/* Trust-line + appLink под калькулятором — спокойно */
.hero-v2-trust {
  display: flex; justify-content: center; align-items: center;
  gap: 8px; margin-top: 14px;
  font-size: 12px; color: var(--text-muted); font-weight: 500;
  flex-wrap: wrap;
}
.hero-v2-trust .dot { color: var(--text-muted); opacity: 0.5; }
.hero-v2-applink {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border-light);
  text-align: center;
  font-size: 12px;
  color: var(--text-muted);
}
.hero-v2-applink a { color: var(--brand-blue); font-weight: 600; text-decoration: none; }
.hero-v2-applink a:hover { text-decoration: underline; }

/* ==============================================================
   v6 — ФИНАЛЬНЫЕ ПРАВКИ ВИДИМЫХ БАГОВ
   ============================================================== */

/* === Pull-quote rating block (заменяет инлайн-стили) === */
.pq-rating {
  display: flex; align-items: center; gap: 24px;
  margin-top: 20px; flex-wrap: wrap;
}
.pq-rating-num { display: flex; align-items: center; gap: 14px; }
.pq-rating-num .n {
  font-family: 'Inter', sans-serif !important;
  font-style: normal !important;
  font-size: 44px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--text);
}
.pq-rating-r .stars { color: #F5B03A; font-size: 14px; letter-spacing: 0.06em; }
.pq-rating-r .meta { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.pq-rating-r .meta strong { color: var(--text); font-weight: 700; }
.pq-rating-sources { display: flex; gap: 8px; flex-wrap: wrap; }
.pq-rating-sources .src {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px; background: #fff; border: 1px solid var(--border-light);
  border-radius: 999px; color: var(--text-secondary); font-size: 12px;
  text-decoration: none; font-weight: 500;
  transition: border-color .2s ease;
}
.pq-rating-sources .src:hover { border-color: var(--brand-blue); color: var(--text); }
.pq-rating-sources .src.all { color: var(--brand-blue); font-weight: 600; }

/* === Story-list: убираем flex, делаем естественный текст === */
.story-v2-r-list ul { list-style: none !important; padding: 0 !important; }
.story-v2-r-list li {
  display: block !important;
  padding: 10px 0 10px 22px !important;
  border-bottom: 1px solid var(--border-light) !important;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-secondary);
  position: relative;
}
.story-v2-r-list li::before {
  content: '→' !important;
  position: absolute !important;
  left: 0 !important;
  top: 10px !important;
  color: var(--brand-blue) !important;
  font-weight: 600 !important;
  width: auto !important;
  height: auto !important;
  background: none !important;
  margin: 0 !important;
  display: inline !important;
}
.story-v2-r-list li b {
  color: var(--text) !important;
  font-weight: 600 !important;
  white-space: nowrap;
}
.story-v2-r-list-tit {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  margin-bottom: 8px;
}

/* === Footer: усиление контраста заголовков колонок === */
.site-footer h5 {
  color: rgba(255,255,255,0.95) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin-bottom: 14px !important;
  opacity: 1 !important;
}
.site-footer ul a {
  color: rgba(255,255,255,0.72) !important;
  font-size: 14px !important;
}
.site-footer ul a:hover { color: #fff !important; }
.site-footer p { color: rgba(255,255,255,0.7) !important; }

/* === App-section (download app) — спокойнее === */
.app-section {
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-blue-dark) 100%) !important;
}
.app-section h2 { color: #fff !important; }
.app-section .eyebrow { color: rgba(255,255,255,0.8) !important; background: rgba(255,255,255,0.12) !important; padding: 4px 12px; border-radius: 999px; }
.app-section p { color: rgba(255,255,255,0.92) !important; }

/* === Section-head — единая центровка и пропорции === */
.section-head { text-align: center; margin-bottom: 48px; }
.section-head .section-title { font-size: clamp(28px, 3.6vw, 44px); font-weight: 700; letter-spacing: -0.025em; line-height: 1.1; }
.section-head .section-subtitle { font-size: 16px; color: var(--text-secondary); margin-top: 12px; max-width: 580px; margin-left: auto; margin-right: auto; line-height: 1.5; }


/* ==============================================================
   v7 — КАЛЬКУЛЯТОР: чистая финальная вёрстка
   ============================================================== */

/* Карточка калькулятора */
.hero-v2-calc {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 20px !important;
  padding: 24px !important;
  box-shadow: 0 4px 24px -8px rgba(82,147,224,0.12) !important;
}
.hero-v2-calc-tit {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
}
.hero-v2-calc-d {
  font-size: 13px !important;
  color: var(--text-muted) !important;
  margin-bottom: 16px !important;
}

/* Внешний бокс полей маршрута */
.hero-quick-calc {
  background: var(--bg-soft) !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 16px !important;
  padding: 12px !important;
  box-shadow: none !important;
  max-width: none !important;
}

/* Поле адреса */
.hqc-field {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 12px !important;
  height: 50px !important;
  padding: 0 14px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.hqc-field input {
  font-size: 14px !important;
  padding: 0 !important;
  height: 100% !important;
  color: var(--text) !important;
}
.hqc-field input::placeholder { color: var(--text-muted); }

/* Маркеры — оба одинаковые, синие сплошные точки */
.hqc-dot.a, .hqc-dot.b {
  width: 8px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: var(--brand-blue) !important;
  border: none !important;
  box-shadow: 0 0 0 4px rgba(82,147,224,0.18) !important;
  transform: none !important;
}
.hqc-dot.b { background: var(--text) !important; box-shadow: 0 0 0 4px rgba(15,27,45,0.10) !important; }

/* Иконка геолокации */
.hqc-geo svg { width: 18px; height: 18px; color: var(--text-muted); }
.hqc-geo:hover { background: rgba(82,147,224,0.08) !important; }

/* Ряд: селект + чекбокс */
.hqc-row {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
  margin-top: 10px !important;
}

/* Кастомный селект — без уродливой нативной стрелочки */
.hqc-row select {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  background: #fff url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%235293E0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 14px center/10px no-repeat !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 12px !important;
  padding: 0 36px 0 14px !important;
  height: 50px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--text) !important;
  cursor: pointer !important;
}
.hqc-row select:hover { border-color: var(--brand-blue) !important; }
.hqc-row select:focus { outline: none; border-color: var(--brand-blue) !important; box-shadow: 0 0 0 3px rgba(82,147,224,0.12) !important; }

/* Чекбокс «Страхование» */
.hqc-check {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 12px !important;
  padding: 0 14px !important;
  height: 50px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--text) !important;
  cursor: pointer !important;
  transition: border-color .2s ease;
}
.hqc-check:hover { border-color: var(--brand-blue) !important; }
.hqc-check input[type="checkbox"] {
  appearance: auto !important;
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  accent-color: var(--brand-blue) !important;
  cursor: pointer;
}

/* Кнопка CTA */
.hqc-submit {
  width: 100% !important;
  height: 52px !important;
  background: var(--brand-blue) !important;
  background-image: none !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 12px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  margin-top: 4px !important;
  box-shadow: 0 4px 14px -4px rgba(82,147,224,0.4) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  cursor: pointer;
}
.hqc-submit:hover {
  background: var(--brand-blue-dark) !important;
  box-shadow: 0 6px 18px -4px rgba(82,147,224,0.5) !important;
  transform: none !important;
}
.hqc-submit svg { width: 16px; height: 16px; }

/* Trust-line — сдержанная, чистая */
.hero-v2-trust {
  display: flex; justify-content: center; align-items: center;
  gap: 8px; margin-top: 16px;
  font-size: 12px; color: var(--text-muted); font-weight: 500;
}
.hero-v2-trust .dot { color: var(--border-light); }
.hero-v2-applink {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid var(--border-light);
  text-align: center; font-size: 13px; color: var(--text-muted);
}
.hero-v2-applink a { color: var(--brand-blue); font-weight: 600; text-decoration: none; }
.hero-v2-applink a:hover { text-decoration: underline; }


/* === v7.1 — фикс overflow в hqc-row === */
.hqc-row {
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.hqc-row select,
.hqc-check {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}
.hero-quick-calc { box-sizing: border-box !important; }
.hqc-route, .hqc-field { box-sizing: border-box !important; width: 100% !important; }

/* На очень узких экранах селект + чекбокс становятся друг под другом */
@media (max-width: 480px) {
  .hqc-row { grid-template-columns: 1fr !important; }
}


/* === v8 — Story-photo с реальным изображением === */
.story-v2-photo {
  background: var(--bg-soft) !important;
  position: relative;
  overflow: hidden;
}
.story-v2-photo img {
  position: absolute; inset: 0;
  width: 100% !important; height: 100% !important;
  object-fit: cover !important; display: block;
}
.story-v2-photo::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.35) 100%);
  pointer-events: none;
}
.story-v2-photo-tag {
  z-index: 2;
  background: rgba(255,255,255,0.96) !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  font-size: 11px !important;
  color: var(--text) !important;
  text-transform: uppercase !important;
  padding: 6px 12px !important;
}
.story-v2-photo-tag::before { content: '★ ' !important; color: #F5B03A !important; }
.story-v2-cap { z-index: 2; }


/* === v8 — CTA bottom: реальная рабочая форма === */
.cta-v2-block {
  background: var(--text) !important;
  color: #fff !important;
  border-radius: 24px !important;
  padding: 56px !important;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; align-items: center;
}
.cta-v2-block::before { display: none !important; }
.cta-v2-eyebrow {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.5) !important;
}
.cta-v2-eyebrow::before { display: none !important; }
.cta-v2-tit { color: #fff !important; }
.cta-v2-tit em { -webkit-text-fill-color: var(--brand-cyan) !important; color: var(--brand-cyan) !important; }
.cta-v2-d { color: rgba(255,255,255,0.85) !important; font-size: 17px; line-height: 1.5; margin-top: 16px; }
.cta-v2-stats { display: flex; gap: 28px; margin-top: 28px; flex-wrap: wrap; }
.cta-v2-stat .n { font-size: 26px; font-weight: 700; color: #fff !important; line-height: 1; }
.cta-v2-stat .l { font-size: 11px; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 6px; font-weight: 600; }

/* Форма — стеклянная карточка */
.cta-v2-r {
  background: rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 18px !important;
  padding: 24px !important;
  display: flex; flex-direction: column; gap: 10px;
}
.cta-form-tit {
  font-size: 14px; font-weight: 700; color: #fff;
  margin-bottom: 6px;
}
.cta-field {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 12px;
  padding: 0 14px;
  height: 48px;
  transition: border-color .2s ease, background .2s ease;
}
.cta-field:hover, .cta-field:focus-within {
  border-color: rgba(255,255,255,0.4);
  background: rgba(255,255,255,0.1);
}
.cta-field svg { color: rgba(255,255,255,0.55); flex-shrink: 0; }
.cta-field input,
.cta-field select {
  flex: 1; min-width: 0;
  background: transparent; border: 0; outline: 0;
  color: #fff; font-family: inherit; font-size: 14px; font-weight: 500;
  height: 100%; padding: 0;
  cursor: text;
}
.cta-field input::placeholder { color: rgba(255,255,255,0.45); }
.cta-field-select {
  cursor: pointer;
}
.cta-field-select select {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  cursor: pointer; padding-right: 24px;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%23ffffff' stroke-opacity='0.6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-size: 10px;
}
.cta-field-select select option { background: #14213d; color: #fff; }
.cta-submit {
  margin-top: 4px;
  height: 50px;
  background: var(--brand-blue) !important;
  color: #fff !important;
  border: 0; border-radius: 12px;
  font-weight: 600; font-size: 15px; cursor: pointer;
  font-family: inherit;
  transition: background .2s ease, transform .15s ease;
}
.cta-submit:hover { background: var(--brand-blue-dark) !important; }
.cta-hint {
  text-align: center;
  font-size: 11px;
  color: rgba(255,255,255,0.55);
  margin-top: 2px;
}

@media (max-width: 900px) {
  .cta-v2-block { grid-template-columns: 1fr; gap: 32px; padding: 32px !important; }
}


/* === v8.1 — CTA: ряд селект + чекбокс страхования === */
.cta-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 8px;
}
.cta-check {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 12px;
  padding: 0 14px;
  height: 48px;
  font-size: 14px; font-weight: 500;
  color: #fff;
  cursor: pointer;
  transition: border-color .2s ease, background .2s ease;
}
.cta-check:hover { border-color: rgba(255,255,255,0.4); background: rgba(255,255,255,0.1); }
.cta-check input[type="checkbox"] {
  appearance: auto;
  width: 18px; height: 18px;
  margin: 0; flex-shrink: 0;
  accent-color: var(--brand-blue);
  cursor: pointer;
}
@media (max-width: 480px) { .cta-row { grid-template-columns: 1fr; } }

/* ==============================================================
   v9 — ФИНАЛЬНАЯ ГАРМОНИЗАЦИЯ ВСЕГО САЙТА
   Все 8 страниц: единые формы, кнопки, секции, бэйджи
   ============================================================== */

/* === Все формы (заявки, заказы, регистрация водителей) — один стиль === */
.form-card {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 20px !important;
  padding: 28px !important;
  box-shadow: 0 4px 24px -8px rgba(82,147,224,0.10) !important;
}
.form-card h3 { font-size: 20px !important; font-weight: 700 !important; margin-bottom: 20px !important; }
.form-group label {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--text-secondary) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 6px !important;
  display: block;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100% !important;
  height: 48px !important;
  padding: 0 14px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 12px !important;
  font-family: inherit !important;
  font-size: 14px !important;
  background: #fff !important;
  color: var(--text) !important;
  transition: border-color .2s ease, box-shadow .2s ease !important;
}
.form-group textarea {
  height: auto !important;
  min-height: 96px !important;
  padding: 12px 14px !important;
  resize: vertical;
  line-height: 1.5;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: 0 !important;
  border-color: var(--brand-blue) !important;
  box-shadow: 0 0 0 3px rgba(82,147,224,0.12) !important;
}
.form-checkbox {
  display: flex; align-items: flex-start; gap: 10px;
  margin: 16px 0;
  font-size: 13px;
  color: var(--text-secondary);
  cursor: pointer;
  line-height: 1.4;
}
.form-checkbox input[type="checkbox"] {
  width: 16px; height: 16px;
  margin-top: 2px;
  accent-color: var(--brand-blue);
  flex-shrink: 0;
}
.form-checkbox a { color: var(--brand-blue); text-decoration: none; }
.form-checkbox a:hover { text-decoration: underline; }

/* === Все кнопки .btn-block — единый размер === */
.btn-block, .btn.btn-block { width: 100% !important; }
.btn-lg { height: 52px !important; font-size: 15px !important; }
.btn-sm { height: 40px !important; font-size: 13px !important; padding: 0 16px !important; }

/* === Highlight-block (страница «order», «register», «hero-side») === */
.highlight-block {
  display: grid !important;
  grid-template-columns: 1.05fr 1fr !important;
  gap: 48px !important;
  align-items: center !important;
  padding: 48px !important;
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 24px !important;
  box-shadow: 0 4px 32px -16px rgba(82,147,224,0.10) !important;
}
.highlight-block.reverse > div:first-child { order: 2 }
@media (max-width: 800px) {
  .highlight-block { grid-template-columns: 1fr !important; gap: 32px !important; padding: 28px !important; }
  .highlight-block.reverse > div:first-child { order: 0 }
}
.highlight-block h2 { font-size: clamp(24px, 3vw, 36px) !important; font-weight: 700 !important; line-height: 1.1; }

/* === Tracking-widget — единый чистый стиль === */
.tracking-widget {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 20px !important;
  padding: 24px !important;
  box-shadow: 0 4px 24px -8px rgba(82,147,224,0.10) !important;
}

/* === FAQ — единый стиль === */
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq-item {
  border: 1px solid var(--border-light) !important;
  border-radius: 16px !important;
  background: #fff !important;
  padding: 0 !important;
  overflow: hidden;
  transition: border-color .2s ease;
}
.faq-item[open] { border-color: var(--brand-blue) !important; }
.faq-item summary {
  padding: 18px 22px !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  cursor: pointer;
  list-style: none;
  display: flex; justify-content: space-between; align-items: center;
}
.faq-item summary::after {
  content: '+';
  color: var(--brand-blue);
  font-weight: 400;
  font-size: 22px;
  line-height: 1;
  transition: transform .2s ease;
}
.faq-item[open] summary::after { content: '−'; }
.faq-item p {
  padding: 0 22px 18px !important;
  margin: 0 !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  color: var(--text-secondary) !important;
}
.faq-item p a { color: var(--brand-blue); }

/* === Steps (Как работает / Регистрация) — единый сетчатый ритм === */
.steps {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 16px !important;
}
.step {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 18px !important;
  padding: 24px !important;
  box-shadow: none !important;
}
.step-num {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 32px !important; height: 32px !important;
  border-radius: 999px !important;
  background: var(--brand-blue-light) !important;
  color: var(--brand-blue) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  margin-bottom: 12px;
}
.step h4 { font-size: 16px !important; font-weight: 700 !important; margin-bottom: 6px !important; }
.step p { font-size: 14px !important; color: var(--text-secondary) !important; line-height: 1.5; }

/* === Order-flow (8 шагов) — упрощаем стрелки === */
.order-flow {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 16px !important;
}
.of-step {
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 16px !important;
  padding: 20px !important;
}
.of-num {
  display: inline-block !important;
  background: var(--brand-blue-light) !important;
  color: var(--brand-blue) !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  margin-bottom: 8px;
}
.of-arrow { display: none !important; }
.of-step h5 { font-size: 15px !important; font-weight: 700 !important; margin-bottom: 4px !important; }
.of-step p { font-size: 13px !important; color: var(--text-secondary) !important; line-height: 1.5; }

/* === Tariff cards — единая grid и аккуратный вид === */
.tariffs {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: 16px !important;
}
.tariff-card {
  padding: 24px !important;
  background: #fff !important;
}
.tariff-card.featured {
  border-color: var(--brand-blue) !important;
  box-shadow: 0 8px 32px -12px rgba(82,147,224,0.25) !important;
}

/* === Reviews и review-card — упрощённо === */
.reviews-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 16px !important;
}
.review-card { padding: 24px !important; }
.review-stars { color: #F5B03A; font-size: 14px; letter-spacing: 0.06em; }
.review-text { font-size: 14px !important; line-height: 1.55 !important; color: var(--text-secondary) !important; margin: 12px 0 !important; }
.review-name { font-weight: 600 !important; font-size: 14px !important; }
.review-role { font-size: 12px !important; color: var(--text-muted) !important; }
.review-avatar {
  width: 40px; height: 40px;
  border-radius: 999px;
  background: var(--brand-blue-light);
  color: var(--brand-blue);
  display: grid; place-items: center;
  font-weight: 700; font-size: 13px;
  flex-shrink: 0;
}
.review-author { display: flex; gap: 12px; align-items: center; padding-top: 12px; border-top: 1px dashed var(--border-light); }
.review-verified { color: var(--brand-blue); font-size: 12px; }
.review-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.review-date { font-size: 11px; color: var(--text-muted); }

/* === Phone-mockup в app-section — выровнен === */
.phone-mockup { box-shadow: 0 30px 60px -20px rgba(0,0,0,0.3) !important; }

/* === Compliance row — flex и pill-стиль === */
.compliance-row {
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin: 32px 0 16px;
}

/* === Page-hero (без фото) — единая высота и центровка === */
.page-hero:not(.page-hero-with-photo) {
  text-align: left;
  padding-top: 80px !important;
  padding-bottom: 40px !important;
}
.page-hero:not(.page-hero-with-photo) h1 { margin-top: 8px !important; }
.page-hero:not(.page-hero-with-photo) p { margin-top: 16px !important; }

/* === Universal sections spacing === */
section.section-soft, section:not([class*="hero"]):not(.trust-strip-v2):not(.cta-v2):not(.pq-v2):not(.app-section) {
  padding-top: 80px;
  padding-bottom: 80px;
}
@media (max-width: 720px) {
  section.section-soft, section:not([class*="hero"]):not(.trust-strip-v2):not(.cta-v2):not(.pq-v2):not(.app-section) {
    padding-top: 56px;
    padding-bottom: 56px;
  }
}


/* === v9.1 — фикс tariff-truck (убираем внутренний синий бокс) === */
.tariff-card .tariff-truck {
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  border: 0 !important;
}
.tariff-card .tariff-truck::after,
.tariff-card .tariff-truck::before { display: none !important; }
.tariff-card .tariff-truck img {
  width: auto !important;
  max-width: 90% !important;
  height: auto !important;
  max-height: 100% !important;
  filter: none !important;
}

/* === v9.2 — Inline-QR рядом со store-btn === */
.inline-qr {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px; height: 80px;
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: 14px;
  padding: 6px;
  box-shadow: 0 4px 12px rgba(82,147,224,0.10);
  transition: all .25s ease;
  flex-shrink: 0;
}
.inline-qr img { width: 100%; height: 100%; display: block; }
.inline-qr:hover { transform: translateY(-2px); border-color: var(--brand-blue); }


/* v10 — анимированный грузовик в hero — удалён по запросу пользователя */
.hero-v2 { position: relative; }


/* ==============================================================
   v9.3 — ГРУЗОВИКИ И КАРТОЧКИ: единый фон, ничего не "приклеено"
   ============================================================== */

/* Карточка тарифа — белая плоскость, без градиентов внутри */
.tariff-card,
.tariff-card.featured {
  background: #fff !important;
  background-image: none !important;
}
.tariff-card.featured {
  border-color: var(--brand-blue) !important;
  box-shadow: 0 8px 32px -12px rgba(82,147,224,0.22) !important;
}

/* Контейнер картинки грузовика — полностью прозрачный */
.tariff-card .tariff-truck {
  background: transparent !important;
  background-image: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  border: 0 !important;
  padding: 0 !important;
  height: 160px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative;
  margin-bottom: 16px !important;
}
.tariff-card .tariff-truck::before,
.tariff-card .tariff-truck::after { display: none !important; }
.tariff-card .tariff-truck img {
  width: auto !important;
  max-width: 92% !important;
  height: auto !important;
  max-height: 100% !important;
  object-fit: contain !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  display: block;
}

/* ==============================================================
   v9.4 — KillBot защита (бэйдж в футере + плейсхолдер для скрипта)
   ============================================================== */
.killbot-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: rgba(255,255,255,0.55);
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-decoration: none;
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  transition: color .2s ease, border-color .2s ease;
}
.killbot-badge:hover { color: rgba(255,255,255,0.9); border-color: rgba(255,255,255,0.3); }
.killbot-badge svg { width: 12px; height: 12px; flex-shrink: 0; }

/* ==============================================================
   v10 — АНИМАЦИИ САЙТА (стиль gruzi-vezi.com / Tilda)
   ============================================================== */

/* Page-level fade-in всего контента (200ms, 400ms delay) */
body { opacity: 0; transition: opacity .35s ease-out; }
body.is-ready { opacity: 1; }

/* Базовые состояния анимаций (scroll-triggered) */
[data-animate] {
  opacity: 0;
  transition: opacity .8s cubic-bezier(0.16, 1, 0.3, 1), transform .8s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}
[data-animate="fadeinup"]    { transform: translateY(40px); }
[data-animate="fadeindown"]  { transform: translateY(-40px); }
[data-animate="fadeinleft"]  { transform: translateX(-40px); }
[data-animate="fadeinright"] { transform: translateX(40px); }
[data-animate="zoomin"]      { transform: scale(0.92); }

[data-animate].is-visible {
  opacity: 1;
  transform: translate(0, 0) scale(1);
}

/* Stagger-задержки для рядов карточек (0..7) */
[data-animate-delay="0"]   { transition-delay: 0ms; }
[data-animate-delay="1"]   { transition-delay: 80ms; }
[data-animate-delay="2"]   { transition-delay: 160ms; }
[data-animate-delay="3"]   { transition-delay: 240ms; }
[data-animate-delay="4"]   { transition-delay: 320ms; }
[data-animate-delay="5"]   { transition-delay: 400ms; }
[data-animate-delay="6"]   { transition-delay: 480ms; }
[data-animate-delay="7"]   { transition-delay: 560ms; }

/* Shine-анимация на главной CTA (как btneffects-flash на gruzi-vezi.com) */
.btn-primary, .hqc-submit, .cta-submit {
  position: relative;
  overflow: hidden;
}
.btn-primary::after, .hqc-submit::after, .cta-submit::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.28) 50%, transparent 100%);
  transform: translateX(-150%) skewX(-25deg);
  pointer-events: none;
}
.btn-primary:not(:hover)::after,
.hqc-submit:not(:hover)::after,
.cta-submit:not(:hover)::after {
  animation: btn-shine 4s linear infinite;
  animation-delay: 1.5s;
}
@keyframes btn-shine {
  0%   { transform: translateX(-150%) skewX(-25deg); }
  60%  { transform: translateX(250%) skewX(-25deg); }
  100% { transform: translateX(250%) skewX(-25deg); }
}

/* Pulse-ring на главной CTA-кнопке hero — мягкое внимание */
.hqc-submit { isolation: isolate; }
.hqc-submit::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 0 0 0 rgba(82,147,224,0.45);
  pointer-events: none;
  animation: pulse-ring 2.4s cubic-bezier(0.66, 0, 0, 1) infinite;
  animation-delay: 2s;
}
@keyframes pulse-ring {
  0%   { box-shadow: 0 0 0 0 rgba(82,147,224,0.45); }
  70%  { box-shadow: 0 0 0 14px rgba(82,147,224,0); }
  100% { box-shadow: 0 0 0 0 rgba(82,147,224,0); }
}

/* Sticky header — фон становится плотнее при скролле */
.site-header {
  transition: background .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.site-header.scrolled {
  background: rgba(255,255,255,0.96) !important;
  backdrop-filter: blur(20px);
  box-shadow: 0 1px 0 var(--border-light);
}

/* Анимация счётчика на data-count-up — лёгкий "set" */
[data-count-up] { font-variant-numeric: tabular-nums; }

/* Hover-эффекты на карточки тарифов и водителей — лифт + блик */
.tariff-card, .driver-v2-card, .persona-v2, .feature-card {
  position: relative;
  transition: transform .35s cubic-bezier(0.16, 1, 0.3, 1), box-shadow .35s cubic-bezier(0.16, 1, 0.3, 1), border-color .25s ease !important;
}
.tariff-card:hover img,
.driver-v2-card:hover .driver-v2-photo {
  transform: scale(1.02);
  transition: transform .5s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Reduced motion — отключаем всё для тех, кто этого требует */
@media (prefers-reduced-motion: reduce) {
  body, [data-animate] { opacity: 1 !important; transition: none !important; transform: none !important; }
  .btn-primary::after, .hqc-submit::after, .cta-submit::after,
  .hqc-submit::before { animation: none !important; }
}

/* === v10.1 — финальный фикс PNG-грузовиков на тарифах === */
.tariff-card .tariff-truck img {
  background: transparent !important;
  filter: drop-shadow(0 8px 20px rgba(82,147,224,0.12)) !important;
  transition: transform .5s cubic-bezier(0.16, 1, 0.3, 1) !important;
}


/* ==============================================================
   v11 — Social buttons (Telegram + MAX) для футера
   ============================================================== */
.social-row {
  display: flex;
  gap: 8px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.social-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  font-size: 13px;
  font-weight: 600;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  transition: all .25s cubic-bezier(0.16, 1, 0.3, 1);
  width: auto !important;
  height: auto !important;
}
.social-btn svg {
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0;
  display: inline-block !important;
}
.social-btn span {
  display: inline !important;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
}
.social-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,0.3);
  color: #fff;
}
.social-btn.social-tg:hover  { background: #229ED9; border-color: #229ED9; }
.social-btn.social-max:hover { background: #2787F5; border-color: #2787F5; }

/* ==============================================================
   v12 — Header social-icons (Telegram + MAX рядом с телефоном)
   ============================================================== */
.header-social {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 36px !important;
  height: 36px !important;
  border-radius: 999px !important;
  background: var(--brand-blue-light) !important;
  color: var(--brand-blue) !important;
  border: 1px solid transparent !important;
  transition: all .2s cubic-bezier(0.16, 1, 0.3, 1) !important;
  flex-shrink: 0;
  text-decoration: none !important;
}
.header-social svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
}
.header-social:hover {
  transform: translateY(-1px);
  background: var(--brand-blue) !important;
  color: #fff !important;
  border-color: var(--brand-blue) !important;
}
.header-social.header-tg:hover  { background: #229ED9 !important; border-color: #229ED9 !important; color: #fff !important; }
@media (max-width: 600px) {
  .header-social { width: 32px !important; height: 32px !important; }
  .header-social svg { width: 16px !important; height: 16px !important; }
}

/* === v13 — Фикс пустой карточки «Фикс-пакеты» (SVG вместо img) === */
.tariff-card .tariff-truck:has(svg:not(:scope > img)) {
  background: var(--brand-blue) !important;
  color: #fff !important;
}
.tariff-card .tariff-truck > svg {
  width: 56px !important;
  height: 56px !important;
  color: inherit;
  flex-shrink: 0;
  display: block;
}
/* Fallback для браузеров без :has() */
.tariff-card .tariff-truck svg {
  width: 56px;
  height: 56px;
  color: var(--brand-blue);
}
.tariff-card .tariff-truck svg:only-child {
  width: 56px !important;
  height: 56px !important;
}

/* === Спец-вариант .tariff-truck-icon (для иконки вместо фото грузовика) === */
.tariff-card .tariff-truck.tariff-truck-icon {
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-blue-dark) 100%) !important;
  color: #fff !important;
  border-radius: 16px !important;
}
.tariff-card .tariff-truck.tariff-truck-icon svg {
  width: 56px !important;
  height: 56px !important;
  color: #fff;
  stroke: currentColor;
}

/* === v15 — Логотип-марка: голубой градиент вместо плоской заливки === */
.logo-mark {
  background: linear-gradient(135deg, #5293E0 0%, #02A1C5 100%) !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 6px rgba(82,147,224,0.25);
}
.logo-mark svg {
  width: 22px !important;
  height: 22px !important;
}

/* ==============================================================
   v16 — Соц-кнопки в ОФИЦИАЛЬНЫХ цветах брендов
   (а не серые, чтоб не терялись на тёмном фоне)
   ============================================================== */

/* === FOOTER: pill-кнопки с лейблами === */
.social-btn.social-tg {
  background: #229ED9 !important;
  border-color: #229ED9 !important;
  color: #fff !important;
}
.social-btn.social-tg:hover {
  background: #1A8AC0 !important;
  border-color: #1A8AC0 !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(34,158,217,0.35);
}
.social-btn.social-max {
  background: linear-gradient(135deg, #5B7FFF 0%, #9C56FF 50%, #FF4FA8 100%) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.social-btn.social-max:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(155,86,255,0.4);
}
.social-btn.social-tg svg path { fill: #fff !important; }
/* MAX-иконка использует собственный градиент url(#mxXXX) — НЕ переопределяем fill */
.social-btn span { color: #fff !important; font-weight: 600; }

/* === HEADER: круглые иконки-кнопки === */
.header-social.header-tg {
  background: #229ED9 !important;
  border-color: #229ED9 !important;
  color: #fff !important;
}
.header-social.header-tg:hover {
  background: #1A8AC0 !important;
  border-color: #1A8AC0 !important;
  box-shadow: 0 4px 12px rgba(34,158,217,0.35);
}
.header-social.header-tg svg path { fill: #fff !important; }

/* === v17 — Финальный фикс skip-to-content (синяя плашка сверху) === */
.skip-to-content {
  position: fixed !important;
  top: 0 !important;
  left: -9999px !important;
  z-index: 10000;
  padding: 10px 18px;
  background: var(--brand-blue);
  color: #fff;
  font-weight: 600;
  border-radius: 0 0 8px 8px;
  text-decoration: none;
  transform: none !important;
  pointer-events: none !important;
  opacity: 0;
}
.skip-to-content:focus {
  left: 12px !important;
  opacity: 1;
  pointer-events: auto !important;
  outline: 2px solid #fff;
  outline-offset: -4px;
}

/* === v18 — Inline 152-ФЗ уведомление под формами без чекбокса === */
.form-consent-inline {
  font-size: 11px !important;
  color: var(--text-muted) !important;
  text-align: center !important;
  line-height: 1.4;
  margin-top: 10px !important;
  padding: 0 !important;
}
.form-consent-inline a {
  color: var(--brand-blue) !important;
  text-decoration: underline;
  text-decoration-color: rgba(82,147,224,0.3);
  text-underline-offset: 2px;
}
.cta-v2-r .form-consent-inline { color: rgba(255,255,255,0.55) !important; }
.cta-v2-r .form-consent-inline a { color: rgba(255,255,255,0.85) !important; }

/* ==============================================================
   v19 — Конкурентные улучшения: промо, newsletter, docs
   ============================================================== */

/* (Промо-баннер первого заказа удалён — секции больше нет) */

/* === Newsletter (подписка в футере) === */
.newsletter-row {
  max-width: var(--container);
  margin: 24px auto;
  padding: 24px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: center;
}
.newsletter-text strong {
  display: block;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
}
.newsletter-text p {
  color: rgba(255,255,255,0.7);
  font-size: 13px;
  margin-top: 4px;
}
.newsletter-form {
  display: flex;
  gap: 8px;
  align-items: center;
  min-width: 320px;
}
.newsletter-form input[type="email"] {
  flex: 1;
  height: 42px;
  padding: 0 14px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  color: #fff;
  font-size: 14px;
  outline: none;
}
.newsletter-form input[type="email"]:focus { border-color: rgba(255,255,255,0.35); }
.newsletter-form input[type="email"]::placeholder { color: rgba(255,255,255,0.4); }
.newsletter-form button {
  height: 42px;
  padding: 0 22px;
  background: var(--brand-blue);
  color: #fff;
  border: 0;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: background .2s ease;
}
.newsletter-form button:hover { background: var(--brand-blue-dark); }
@media (max-width: 720px) {
  .newsletter-row { grid-template-columns: 1fr; }
  .newsletter-form { min-width: 0; flex-direction: column; }
  .newsletter-form input[type="email"], .newsletter-form button { width: 100%; }
}

/* === Скачиваемые документы (Docs grid) === */
.docs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}
.doc-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  text-decoration: none;
  color: var(--text);
  transition: all .2s ease;
}
.doc-card:hover {
  border-color: var(--brand-blue);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -8px rgba(82,147,224,0.18);
  color: var(--text);
}
.doc-icon {
  width: 44px; height: 44px;
  background: var(--brand-blue-light);
  color: var(--brand-blue);
  border-radius: 10px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.doc-icon svg { width: 22px; height: 22px; }
.doc-meta { flex: 1; min-width: 0; }
.doc-meta strong { display: block; font-size: 14px; font-weight: 700; }
.doc-meta span { display: block; font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.doc-arrow {
  font-size: 20px;
  color: var(--text-muted);
  transition: transform .2s ease, color .2s ease;
  flex-shrink: 0;
}
.doc-card:hover .doc-arrow { color: var(--brand-blue); transform: translate(2px, -2px); }

/* ==============================================================
   v19 — Личный кабинет + сезонные акции + промо-блоки
   ============================================================== */

/* === Авторизация === */
.cabinet-auth { padding: 80px 0; }
.auth-card { max-width: 440px; margin: 0 auto; padding: 40px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: 0 30px 60px -20px rgba(82,147,224,0.18); }
.auth-card h1 { font-size: 28px; margin-bottom: 8px; }
.auth-card p { color: var(--text-muted); margin-bottom: 24px; }
.auth-form { display: flex; flex-direction: column; gap: 16px; }

/* === Кабинет: layout === */
.cabinet-app { padding: 32px 0 80px; }
.cabinet-grid { display: grid; grid-template-columns: 280px 1fr; gap: 32px; }
@media (max-width: 900px) { .cabinet-grid { grid-template-columns: 1fr; } }

/* Sidebar */
.cabinet-sidebar { display: flex; flex-direction: column; gap: 16px; }
.user-card { display: flex; gap: 12px; align-items: center; padding: 16px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); }
.user-avatar { width: 44px; height: 44px; border-radius: 999px; background: linear-gradient(135deg, var(--brand-blue), var(--brand-cyan)); color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 18px; }
.user-name { font-weight: 700; font-size: 15px; }
.user-phone { font-size: 12px; color: var(--text-muted); }

.cabinet-nav { display: flex; flex-direction: column; gap: 4px; padding: 8px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); }
.cab-link { display: flex; align-items: center; gap: 12px; padding: 10px 14px; border-radius: 10px; font-size: 14px; color: var(--text-2); text-decoration: none; transition: all .2s; }
.cab-link svg { width: 18px; height: 18px; flex-shrink: 0; }
.cab-link:hover { background: var(--bg-soft); color: var(--text); }
.cab-link.active { background: var(--brand-blue-light); color: var(--brand-blue); font-weight: 600; }
.cab-link .badge { margin-left: auto; padding: 2px 8px; background: var(--bg-soft); border-radius: 999px; font-size: 11px; font-weight: 700; color: var(--text-muted); }
.cab-link .badge.badge-active { background: var(--green); color: #fff; }
.cab-link.active .badge { background: rgba(82,147,224,0.2); color: var(--brand-blue); }

/* Content */
.cabinet-content { min-width: 0; }
.cab-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; margin-bottom: 28px; }
.cab-stat { padding: 16px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); }
.cab-stat .n { font-size: 22px; font-weight: 700; line-height: 1; }
.cab-stat .l { font-size: 11px; color: var(--text-muted); margin-top: 6px; text-transform: uppercase; letter-spacing: 0.06em; }
.cab-section h2 { margin-bottom: 16px; }

/* Orders */
.orders-list { display: flex; flex-direction: column; gap: 12px; }
.order-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); padding: 18px; }
.order-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
.order-id { font-weight: 700; font-size: 15px; }
.order-date { font-size: 12px; color: var(--text-muted); }
.order-status { padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 600; white-space: nowrap; }
.order-status.active { background: rgba(31,186,114,0.12); color: #1FBA72; }
.order-status.done { background: var(--bg-soft); color: var(--text-muted); }
.order-route { display: flex; flex-direction: column; gap: 6px; padding: 12px 0; border-top: 1px dashed var(--border); border-bottom: 1px dashed var(--border); margin-bottom: 12px; font-size: 13px; }
.order-route .dot { display: inline-block; width: 8px; height: 8px; border-radius: 999px; margin-right: 8px; }
.order-route .dot.from { background: var(--brand-blue); }
.order-route .dot.to { background: var(--text); }
.order-meta { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 13px; color: var(--text-muted); }
.order-meta strong { color: var(--text); font-size: 16px; }

/* Документы для скачивания (на about, в кабинете) */
.docs-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; margin-top: 20px; }
.doc-card { display: flex; align-items: center; gap: 14px; padding: 16px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); transition: all .2s; text-decoration: none; color: inherit; }
.doc-card:hover { border-color: var(--brand-blue); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.doc-icon { width: 40px; height: 40px; background: var(--brand-blue-light); border-radius: 10px; display: grid; place-items: center; color: var(--brand-blue); flex-shrink: 0; }
.doc-icon svg { width: 20px; height: 20px; }
.doc-meta { flex: 1; min-width: 0; }
.doc-meta strong { display: block; font-size: 14px; font-weight: 600; }
.doc-meta span { display: block; font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.doc-arrow { font-size: 18px; color: var(--text-muted); flex-shrink: 0; }

/* (Промо-баннеры и сезонные акции удалены — секции больше нет) */

/* === Newsletter форма в footer === */
.newsletter-row { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; padding: 24px 0; margin-top: 24px; border-top: 1px solid rgba(255,255,255,0.08); }
.newsletter-text strong { display: block; color: #fff; font-size: 15px; font-weight: 600; }
.newsletter-text p { color: rgba(255,255,255,0.65); font-size: 13px; margin: 4px 0 0; }
.newsletter-form { display: flex; gap: 8px; min-width: 320px; }
.newsletter-form input[type="email"] { flex: 1; min-width: 0; padding: 10px 14px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.14); border-radius: 10px; color: #fff; font: inherit; font-size: 14px; }
.newsletter-form input[type="email"]::placeholder { color: rgba(255,255,255,0.4); }
.newsletter-form input[type="email"]:focus { outline: 0; border-color: var(--brand-blue); background: rgba(255,255,255,0.12); }
.newsletter-form button { padding: 10px 18px; background: var(--brand-blue); color: #fff; border: 0; border-radius: 10px; font: inherit; font-weight: 600; cursor: pointer; transition: background .2s; }
.newsletter-form button:hover { background: var(--brand-blue-dark); }
@media (max-width: 720px) { .newsletter-row { grid-template-columns: 1fr; } .newsletter-form { min-width: 0; } }

/* ==============================================================
   v20 — track-link в шапке + уникальный калькулятор объёма
   ============================================================== */

/* === Track-link в шапке (заметная кнопка «Отследить») === */
.track-link {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  border: 1px solid var(--brand-blue);
  border-radius: 999px;
  font-size: 13px; font-weight: 600;
  color: var(--brand-blue);
  text-decoration: none;
  transition: all .2s;
  white-space: nowrap;
}
.track-link svg { width: 14px; height: 14px; }
.track-link:hover { background: var(--brand-blue); color: #fff; transform: translateY(-1px); }
@media (max-width: 700px) {
  .track-link span { display: none; }
  .track-link { padding: 8px; width: 36px; height: 36px; justify-content: center; }
}

/* (Старый Visual Volume Calculator удалён — заменён 3D-планировщиком .lp-section) */

/* ==============================================================
   v21 — ПРЕМИАЛЬНЫЙ РЕДИЗАЙН: Onest + округлости + мягкие тени
   Уход от «квадратности», более элегантный визуал
   ============================================================== */

/* === Шрифт: Onest вместо Inter (более изящный, Cyrillic) === */
body, html, input, select, textarea, button {
  font-family: 'Onest', -apple-system, system-ui, sans-serif !important;
  font-feature-settings: 'cv11', 'ss01', 'ss03' !important;
}
h1, h2, h3, h4, h5, h6 {
  font-family: 'Onest', -apple-system, system-ui, sans-serif !important;
  letter-spacing: -0.025em !important;
}
.mono, [class*="mono"], code, pre {
  font-family: 'JetBrains Mono', ui-monospace, monospace !important;
}
em, .serif {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
}

/* === Radii: бóльше скругления вместо «коробок» === */
:root {
  --r-1: 14px !important;
  --r-2: 22px !important;
  --r-3: 30px !important;
  --r-pill: 999px !important;
  --radius-sm: 14px !important;
  --radius-md: 22px !important;
  --radius-lg: 30px !important;
  --radius-pill: 999px !important;
}

/* === Карточки: повышаем округлость и мягкость === */
.feature-card, .tariff-card, .review-card, .step,
.persona-v2, .driver-v2-card, .faq-item, .bento, .feed-card,
.tracking-widget, .form-card, .doc-card, .auth-card,
.user-card, .cabinet-nav, .order-card, .cab-stat,
.hero-v2-calc, .mb-card, .order-flow .of-step {
  border-radius: 24px !important;
  border: 1px solid rgba(82,147,224,0.10) !important;
  box-shadow: 0 1px 2px rgba(15,27,45,0.04), 0 0 0 1px rgba(82,147,224,0.04) !important;
  transition: transform .35s cubic-bezier(0.16, 1, 0.3, 1), box-shadow .35s cubic-bezier(0.16, 1, 0.3, 1) !important;
}
.feature-card:hover, .tariff-card:hover, .review-card:hover,
.persona-v2:hover, .driver-v2-card:hover, .bento:hover, .feed-card:hover,
.doc-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 32px -12px rgba(82,147,224,0.18), 0 0 0 1px rgba(82,147,224,0.12) !important;
  border-color: rgba(82,147,224,0.25) !important;
}

/* === Кнопки: pill-форма во всё === */
.btn, .btn-primary, .btn-outline, .hqc-submit, .cta-submit, .btn-warm {
  border-radius: 999px !important;
  font-weight: 600 !important;
}

/* === Поля ввода: округлые === */
.form-group input, .form-group select, .form-group textarea,
.hqc-field, .hqc-row select, .hqc-check, .cta-field, .cta-check {
  border-radius: 16px !important;
}

/* === Хэдер: больше воздуха, меньше «квадрата» === */
.site-header {
  border-bottom: 0 !important;
  background: rgba(255,255,255,0.78) !important;
  backdrop-filter: saturate(180%) blur(28px) !important;
  -webkit-backdrop-filter: saturate(180%) blur(28px) !important;
}
.site-header.scrolled {
  box-shadow: 0 8px 32px -16px rgba(15,27,45,0.12) !important;
  background: rgba(255,255,255,0.92) !important;
}

/* === Section spacing — больше воздуха === */
section { padding: 96px 0 !important; }
@media (max-width: 720px) { section { padding: 64px 0 !important; } }
.section-head { margin-bottom: 56px !important; }

/* === Заголовки: weight 600/700 + tighter tracking === */
h1 { font-weight: 800 !important; letter-spacing: -0.035em !important; }
h2 { font-weight: 700 !important; }
h3 { font-weight: 700 !important; }

/* === Hero-title: специальное большое правило === */
.hero-v2-title, .page-hero h1, .h1-title {
  letter-spacing: -0.04em !important;
  line-height: 0.96 !important;
  font-weight: 800 !important;
}

/* === Footer: чуть «мягче», без жёсткой нижней рамки === */
.site-footer {
  background: linear-gradient(180deg, #0d1426 0%, #0a121f 100%) !important;
  background-color: #0d1426 !important;
  border-top: 0 !important;
  color: #ffffff !important;
}
.site-footer h5,
.site-footer .footer-grid h5,
.site-footer .footer-col h5 {
  color: #ffffff !important;
}
.site-footer ul li a,
.site-footer .footer-grid a,
.site-footer .footer-col a,
.site-footer p,
.site-footer .footer-bottom,
.site-footer .footer-bottom div,
.site-footer .footer-bottom a {
  color: rgba(255, 255, 255, 0.78) !important;
}
.site-footer ul li a:hover {
  color: #ffffff !important;
}
.site-footer .news-input,
.site-footer input[type="email"] {
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  color: #ffffff !important;
}
.site-footer .news-input::placeholder,
.site-footer input::placeholder {
  color: rgba(255, 255, 255, 0.45) !important;
}
.site-footer .store-btn,
.site-footer .footer-store-btns .store-btn,
.site-footer .store-btn .small,
.site-footer .store-btn .big {
  color: #ffffff !important;
}

/* === Sticky-CTA mobile — pill-форма === */
.sticky-cta { border-radius: 16px 16px 0 0 !important; }

/* === Чекбоксы и радио — bespoke === */
input[type="checkbox"], input[type="radio"] {
  accent-color: var(--brand-blue);
}

/* === AI badge: pill === */
.ai-badge { border-radius: 999px !important; }


/* ==============================================================
   v21 — Onest шрифт (мягко, без !important на всё)
   ============================================================== */
body { font-family: 'Onest', 'Inter', -apple-system, system-ui, sans-serif; }
h1, h2, h3, h4, h5, h6 { font-family: inherit; }
.mono, code, pre, [data-count-up] { font-family: 'JetBrains Mono', monospace; }

/* === Лёгкое усиление округления (только на крупных карточках) === */
.feature-card, .tariff-card, .review-card, .step,
.persona-v2, .driver-v2-card, .faq-item,
.form-card, .highlight-block, .hero-v2-calc,
.tracking-widget {
  border-radius: 22px;
}
.driver-v2-card .driver-v2-photo { border-radius: 22px 22px 0 0; }
.tariff-card .tariff-truck img { filter: drop-shadow(0 8px 16px rgba(82,147,224,0.12)); }

/* ==================================================================
   3D Load Planner (lp-*)  — замена volume-calc
   ================================================================== */
.lp-section {
    padding: 88px 0;
    background:
        radial-gradient(circle at 12% 18%, rgba(82,147,224,0.08), transparent 40%),
        radial-gradient(circle at 88% 80%, rgba(2,161,197,0.06), transparent 45%),
        var(--bg);
}
.lp-section .section-head { margin-bottom: 28px; }

/* Toolbar — табы машин */
.lp-toolbar {
    position: relative;
    margin: 0 0 24px;
    overflow-x: auto;
    overflow-y: visible;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
}
.lp-toolbar::-webkit-scrollbar { height: 6px; }
.lp-toolbar::-webkit-scrollbar-track { background: transparent; }
.lp-toolbar::-webkit-scrollbar-thumb {
    background: rgba(82,147,224,0.30);
    border-radius: 3px;
}
.lp-toolbar::-webkit-scrollbar-thumb:hover { background: rgba(82,147,224,0.50); }
.lp-trucks {
    display: flex; gap: 8px;
    padding: 4px 2px 8px;
    min-width: max-content;
}
.lp-truck-tab {
    flex: 0 0 auto;
    min-width: 140px;
    scroll-snap-align: start;
    padding: 11px 14px;
    border-radius: 14px;
    border: 1.5px solid var(--border);
    background: var(--bg-card, #fff);
    text-align: left;
    cursor: pointer;
    transition: all .18s ease;
    display: flex; flex-direction: column; gap: 4px;
}
.lp-truck-tab:hover {
    border-color: var(--brand-blue);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}
.lp-truck-tab.is-active {
    border-color: var(--brand-blue);
    background: var(--brand-blue-light);
    box-shadow: 0 4px 12px rgba(82,147,224,0.18);
}
.lp-truck-tab .lp-truck-name {
    font-weight: 700;
    color: var(--text);
    font-size: 14px;
}
.lp-truck-tab .lp-truck-dim {
    font-size: 11px;
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', monospace;
    letter-spacing: -0.02em;
}
.lp-truck-tab.is-active .lp-truck-name { color: var(--brand-blue-dark); }

/* Сетка ввод/просмотр */
.lp-grid {
    display: grid;
    grid-template-columns: minmax(360px, 1fr) minmax(420px, 1.5fr);
    gap: 24px;
    align-items: stretch;
}
@media (max-width: 1024px) {
    .lp-grid { grid-template-columns: 1fr; }
}

/* Левая панель — ввод */
.lp-input {
    background: var(--bg-card, #fff);
    border: 1px solid var(--border);
    border-radius: 22px;
    padding: 24px;
    box-shadow: var(--shadow-sm);
}
.lp-input h4 {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
    color: var(--text);
}
.lp-input-hint {
    margin: 0 0 16px;
    font-size: 13px;
    color: var(--text-secondary);
}

/* Готовые наборы для квартир */
.lp-room-presets {
    display: flex; flex-wrap: wrap; gap: 8px;
    align-items: center;
    margin-bottom: 14px;
    padding: 12px 14px;
    background: linear-gradient(135deg, rgba(82,147,224,0.08), rgba(2,161,197,0.06));
    border: 1px solid rgba(82,147,224,0.16);
    border-radius: 14px;
}
.lp-room-tit {
    font-size: 12px;
    font-weight: 600;
    color: var(--brand-blue-dark);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-right: 4px;
}
.lp-room {
    padding: 7px 14px;
    font-size: 13px;
    font-weight: 600;
    border: 1.5px solid rgba(82,147,224,0.28);
    background: #fff;
    color: var(--brand-blue-dark);
    border-radius: 10px;
    cursor: pointer;
    transition: all .15s ease;
}
.lp-room:hover {
    background: var(--brand-blue);
    color: #fff;
    border-color: var(--brand-blue);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(82,147,224,0.32);
}

/* Прессеты-кнопки */
.lp-presets {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px dashed var(--border);
}
.lp-preset {
    padding: 7px 12px;
    font-size: 13px;
    border: 1px solid var(--border);
    background: var(--bg-soft);
    border-radius: 10px;
    cursor: pointer;
    transition: all .15s ease;
    color: var(--text);
}
.lp-preset:hover {
    border-color: var(--brand-blue);
    background: var(--brand-blue-light);
    transform: translateY(-1px);
}

/* Таблица */
.lp-table-wrap {
    margin-bottom: 12px;
    overflow-x: auto;
    border-radius: 12px;
    border: 1px solid var(--border-light);
}
.lp-table {
    width: 100%;
    min-width: 540px;
    border-collapse: collapse;
    font-size: 13px;
}
.lp-table thead th {
    background: var(--bg-soft);
    padding: 10px 6px;
    text-align: left;
    font-weight: 600;
    color: var(--text-secondary);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 1px solid var(--border-light);
}
.lp-table thead th:first-child { padding-left: 12px; }
.lp-table tbody td {
    padding: 6px;
    border-bottom: 1px solid var(--border-light);
    vertical-align: middle;
}
.lp-table tbody td:first-child { padding-left: 12px; }
.lp-table tbody tr:last-child td { border-bottom: 0; }
.lp-table tbody tr.is-highlight {
    background: rgba(82, 147, 224, 0.10);
    box-shadow: inset 3px 0 0 var(--brand-blue);
}
.lp-table tbody tr.is-highlight td:first-child { color: var(--brand-blue-dark); font-weight: 600; }

.lp-in {
    width: 100%;
    border: 1px solid transparent;
    background: transparent;
    padding: 6px 8px;
    border-radius: 6px;
    font-size: 13px;
    color: var(--text);
    font-family: inherit;
    transition: all .15s ease;
}
.lp-in:hover { background: var(--bg-soft); }
.lp-in:focus {
    outline: none;
    background: var(--bg-soft);
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 3px rgba(82,147,224,0.12);
}
.lp-num { font-family: 'JetBrains Mono', monospace; }
.lp-color-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
    margin-right: 6px;
    vertical-align: middle;
}
.lp-row-x {
    width: 24px; height: 24px;
    border: 0; background: transparent;
    color: var(--text-muted);
    font-size: 18px; line-height: 1;
    cursor: pointer;
    border-radius: 6px;
    transition: all .15s ease;
}
.lp-row-x:hover { background: rgba(230,56,106,0.12); color: var(--danger); }

.lp-actions {
    display: flex; gap: 8px;
    margin: 12px 0 16px;
    flex-wrap: wrap;
}
.btn-sm { padding: 8px 14px; font-size: 13px; }
.btn-ghost {
    background: transparent;
    color: var(--text-secondary);
    border: 1px dashed var(--border);
}
.btn-ghost:hover { background: var(--bg-soft); color: var(--text); }

.lp-check {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px;
    color: var(--text-secondary);
    cursor: pointer;
    user-select: none;
    margin-top: 10px;
}
.lp-check input { width: 18px; height: 18px; accent-color: var(--brand-blue); cursor: pointer; }

/* Правая панель — 3D и результат */
.lp-viewer {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
}
.lp-canvas-wrap {
    position: relative;
    border-radius: 22px;
    background:
        linear-gradient(180deg, #eaf2fb 0%, #f7faff 60%, #ffffff 100%);
    border: 1px solid var(--border);
    overflow: hidden;
    aspect-ratio: 16 / 10;
    min-height: 360px;
    box-shadow: var(--shadow-sm);
}
#lpCanvas { display: block; width: 100%; height: 100%; }
.lp-canvas-empty {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 12px;
    color: var(--text-secondary);
    text-align: center;
    pointer-events: none;
    background: linear-gradient(180deg, #f3f7fc 0%, #ffffff 100%);
    z-index: 2;
}
.lp-canvas-empty p { margin: 0; font-size: 14px; max-width: 240px; }
.lp-canvas-toolbar {
    position: absolute;
    top: 12px; right: 12px;
    display: flex; gap: 6px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 6px;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
    z-index: 3;
}
.lp-cv-btn {
    width: 34px; height: 34px;
    border: 0;
    background: transparent;
    border-radius: 8px;
    cursor: pointer;
    line-height: 1;
    color: var(--text-secondary);
    transition: background-color .15s ease, color .15s ease;
    display: grid;
    place-items: center;
    padding: 0;
}
.lp-cv-btn svg { width: 18px; height: 18px; display: block; }
.lp-cv-btn:hover { background: var(--brand-blue-light); color: var(--brand-blue); }
.lp-cv-btn.is-on { background: var(--brand-blue); color: #fff; }
.lp-canvas-hint {
    position: absolute;
    bottom: 10px; left: 12px;
    font-size: 11px;
    color: var(--text-muted);
    font-family: 'JetBrains Mono', monospace;
    letter-spacing: -0.01em;
    background: rgba(255,255,255,0.6);
    padding: 4px 8px;
    border-radius: 6px;
    z-index: 3;
}

/* Stats */
.lp-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
@media (max-width: 540px) {
    .lp-stats { grid-template-columns: 1fr; }
}
.lp-stat {
    background: var(--bg-card, #fff);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px 16px;
    box-shadow: var(--shadow-sm);
}
.lp-stat-num {
    font-size: 28px;
    font-weight: 800;
    color: var(--text);
    line-height: 1;
    font-family: 'JetBrains Mono', monospace;
    letter-spacing: -0.04em;
}
.lp-stat-num span {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-left: 2px;
    letter-spacing: 0;
}
.lp-stat-lbl {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    margin: 4px 0 8px;
}
.lp-progress {
    height: 6px;
    background: var(--border-light);
    border-radius: 999px;
    overflow: hidden;
}
.lp-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #5293E0, #02A1C5);
    border-radius: inherit;
    transition: width .35s cubic-bezier(.2,.6,.2,1);
}
.lp-progress-fill.weight {
    background: linear-gradient(90deg, #F5B03A, #E6386A);
}
.lp-progress-fill.placed {
    background: linear-gradient(90deg, #1FBA72, #0EA5C0);
}
.lp-stat-sub {
    margin-top: 6px;
    font-size: 12px;
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', monospace;
}

/* Recommendation block */
.lp-recommend {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    background: linear-gradient(135deg, var(--brand-blue-light) 0%, rgba(2,161,197,0.06) 100%);
    border: 1px solid rgba(82,147,224,0.22);
    border-radius: 18px;
}
.lp-rec-icon {
    font-size: 32px;
    line-height: 1;
}
.lp-rec-text {
    display: flex; flex-direction: column; gap: 2px;
    min-width: 0;
}
.lp-rec-text strong {
    font-size: 16px;
    font-weight: 700;
    color: var(--text);
}
.lp-rec-text span {
    font-size: 13px;
    color: var(--text-secondary);
}
@media (max-width: 640px) {
    .lp-recommend {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .lp-rec-icon { margin: 0 auto; }
}

/* Тёмная тема */
:root[data-theme="dark"] .lp-canvas-wrap {
    background: linear-gradient(180deg, #15233f 0%, #0e1a2e 100%);
}
:root[data-theme="dark"] .lp-canvas-empty {
    background: linear-gradient(180deg, #15233f 0%, #0e1a2e 100%);
}
:root[data-theme="dark"] .lp-canvas-toolbar {
    background: rgba(21,35,63,0.92);
}
:root[data-theme="dark"] .lp-canvas-hint {
    background: rgba(21,35,63,0.6);
    color: var(--text-muted);
}

/* ==================================================================
   v23 — POLISH (urgent cleanup edition)
   Без блобов, без пульсации, без shimmer. Только то, что нужно.
   ================================================================== */

/* Типографика */
.hero-v2-title,
.hero-v2 h1,
.section-title {
    letter-spacing: -0.045em;
    line-height: 1.04;
    text-wrap: balance;
}
.hero-v2-title { font-size: clamp(2.4rem, 5.6vw, 4.6rem) !important; }
.section-title { font-size: clamp(1.85rem, 3.6vw, 2.85rem); }
h3, .h3 { font-size: clamp(1.25rem, 2vw, 1.5rem); letter-spacing: -0.02em; }
h4, .h4 { letter-spacing: -0.015em; }
.section-subtitle {
    font-size: clamp(0.98rem, 1.2vw, 1.12rem);
    line-height: 1.55;
    color: var(--text-secondary);
    text-wrap: pretty;
    max-width: 60ch;
}
.section-head { margin-bottom: 40px; max-width: 720px; margin-left: auto; margin-right: auto; text-align: center; }
.section-head .section-subtitle { margin-left: auto; margin-right: auto; }

/* Eyebrow без пульсирующей точки */
.section-head .eyebrow {
    display: inline-block;
    padding: 5px 12px;
    background: rgba(82,147,224,0.08);
    border: 1px solid rgba(82,147,224,0.16);
    border-radius: 999px;
    font-size: 11px; font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.10em;
    color: var(--brand-blue-dark);
}

/* Hero — без блобов, без анимаций */
.hero-v2 { position: relative; }
.hero-v2-tag {
    display: inline-block;
    padding: 5px 12px;
    background: rgba(82,147,224,0.08);
    border: 1px solid rgba(82,147,224,0.16);
    border-radius: 999px;
    font-size: 12px; font-weight: 600;
    color: var(--brand-blue-dark);
    margin-bottom: 16px;
}

/* Hero calculator card — статичная тень */
.hero-v2-calc {
    box-shadow:
        0 1px 3px rgba(13,20,38,0.04),
        0 18px 48px -12px rgba(82,147,224,0.16) !important;
    border-radius: 22px !important;
    border: 1px solid rgba(82,147,224,0.10) !important;
    background: #ffffff !important;
}

/* Hero meta-числа */
.hero-v2-meta {
    margin-top: 36px;
    padding-top: 28px;
    border-top: 1px solid rgba(82,147,224,0.14);
    gap: clamp(20px, 3vw, 36px) !important;
}
.hero-v2-meta-i .num {
    font-weight: 800;
    font-size: clamp(1.65rem, 2.4vw, 2.1rem);
    color: var(--text);
    letter-spacing: -0.04em;
    line-height: 1;
}
.hero-v2-meta-i .num small {
    font-size: 0.55em;
    margin-left: 2px;
    color: var(--brand-cyan);
    font-weight: 700;
}
.hero-v2-meta-i .lbl {
    margin-top: 6px;
    font-size: 12px;
    color: var(--text-secondary);
    letter-spacing: 0.02em;
}

/* Карточки — мягкие тени, hover-lift без избыточности */
.feature-card,
.tariff-card,
.review-card,
.persona-v2,
.driver-v2-card,
.faq-item,
.step,
.lp-stat {
    box-shadow: 0 1px 3px rgba(13,20,38,0.04), 0 8px 24px -12px rgba(82,147,224,0.10) !important;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease !important;
}
.feature-card:hover,
.tariff-card:hover,
.review-card:hover,
.persona-v2:hover,
.driver-v2-card:hover,
.faq-item:hover,
.step:hover {
    transform: translateY(-3px);
    box-shadow: 0 1px 3px rgba(13,20,38,0.05), 0 16px 36px -12px rgba(82,147,224,0.18) !important;
    border-color: rgba(82,147,224,0.22) !important;
}

/* Step-номер */
.step { position: relative; padding-top: 28px; }
.step .step-num {
    width: 40px; height: 40px;
    display: grid; place-items: center;
    border-radius: 12px;
    background: var(--brand-blue);
    color: #fff;
    font-weight: 800;
    font-size: 16px;
}

/* Иконки feature-card */
.feature-card .feature-icon {
    width: 52px; height: 52px;
    border-radius: 14px;
    background: rgba(82,147,224,0.10);
    display: grid; place-items: center;
    color: var(--brand-blue);
    margin-bottom: 16px;
}
.feature-card .feature-icon svg { width: 26px; height: 26px; }

/* Кнопки — без shimmer, простые transitions */
.btn, .btn-primary, .btn-warm, .btn-outline, .hqc-submit, button.btn-primary {
    transition: transform .15s ease, box-shadow .2s ease, background-color .2s ease, border-color .2s ease, color .2s ease !important;
}
.btn:active, .btn-primary:active, .btn-warm:active, .hqc-submit:active {
    transform: translateY(1px);
}
.btn-primary:hover, .hqc-submit:hover {
    transform: translateY(-1px);
}

/* Reveal-анимации — оставляем (пользовательские data-animate) */
[data-animate] {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .55s ease-out, transform .55s ease-out;
}
[data-animate="fadeinleft"]  { transform: translateX(-24px); }
[data-animate="fadeinright"] { transform: translateX(24px); }
[data-animate="zoomin"]      { transform: scale(0.96); }
[data-animate].is-visible { opacity: 1; transform: none; }
[data-animate-delay="1"] { transition-delay: .06s; }
[data-animate-delay="2"] { transition-delay: .12s; }
[data-animate-delay="3"] { transition-delay: .18s; }
[data-animate-delay="4"] { transition-delay: .24s; }
[data-animate-delay="5"] { transition-delay: .30s; }
[data-animate-delay="6"] { transition-delay: .36s; }
@media (prefers-reduced-motion: reduce) {
    [data-animate] { opacity: 1; transform: none; transition: none; }
}

/* Sections: единое расстояние */
.section-soft, .personas-v2, .lp-section {
    padding-top: clamp(72px, 8vw, 120px);
    padding-bottom: clamp(72px, 8vw, 120px);
}
.section-soft { background: var(--bg-soft); }

/* Trust-strip — без fade-маски (упрощено) */
.trust-strip-v2 {
    background: #0d1426;
    color: rgba(255,255,255,0.85);
    padding: 14px 0;
    overflow: hidden;
}
.trust-strip-v2 b {
    color: var(--brand-cyan);
    font-weight: 700;
    margin-left: 4px;
}
.trust-strip-v2 span {
    margin: 0 28px;
    font-size: 14px;
}

/* Header — простой scroll-state */
.site-header { transition: background-color .25s ease, box-shadow .25s ease; }
.site-header.scrolled {
    background: rgba(255,255,255,0.92);
    box-shadow: 0 2px 16px rgba(13,20,38,0.06);
}

/* Driver cards — лёгкий zoom фото при hover */
.driver-v2-photo img, .driver-v2-card img {
    transition: transform .4s ease;
}
.driver-v2-card:hover img { transform: scale(1.03); }

/* Формы — фокус */
.hero-quick-calc input[type="text"]:focus,
.hero-quick-calc select:focus,
.form-card input:focus,
.form-card select:focus,
.form-card textarea:focus {
    outline: none;
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 3px rgba(82,147,224,0.12);
}

/* lp-cv-btn — отменяем общий transform */
.lp-cv-btn { transform: none !important; }

/* Smooth scroll */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
}

/* em-акцент в заголовках */
.section-head .section-title em {
    font-style: italic;
    color: var(--brand-blue);
    font-weight: inherit;
}

/* Footer */
.site-footer {
    padding-top: clamp(60px, 7vw, 96px);
    padding-bottom: 32px;
}

/* Компактные шаги — 3 колонки на десктопе, 1 на мобиле */
.steps-compact {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
@media (max-width: 720px) {
    .steps-compact { grid-template-columns: 1fr; gap: 12px; }
}

/* «Считаем…» оверлей в 3D-планировщике */
.lp-computing {
    position: absolute;
    inset: 0;
    z-index: 5;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: var(--brand-blue-dark);
    font-size: 14px;
    font-weight: 500;
    pointer-events: none;
}
.lp-computing-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid rgba(82, 147, 224, 0.20);
    border-top-color: var(--brand-blue);
    border-radius: 50%;
    animation: lp-spin .7s linear infinite;
}
@keyframes lp-spin {
    to { transform: rotate(360deg); }
}

/* Карта России — компактная высота на десктопе, fit-to-width на мобиле */
.mapsec-v2 .mapsec-v2-stage {
    max-height: 480px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
}
.mapsec-v2 .mapsec-v2-stage svg {
    max-height: 480px;
    max-width: 100%;
    width: auto;
    height: auto;
    display: block;
    margin: 0 auto;
}
@media (max-width: 720px) {
    /* На мобильном: даём SVG занять полную ширину, высота сама подстроится
       по соотношению сторон (1200×580 ≈ 2.07:1). max-height отключаем. */
    .mapsec-v2 .mapsec-v2-stage {
        max-height: none;
        overflow: visible;
        display: block;
    }
    .mapsec-v2 .mapsec-v2-stage svg {
        width: 100%;
        height: auto;
        max-height: none;
        max-width: 100%;
    }
}

/* Раскрывающийся блок «Дополнительные параметры» в калькуляторе */
.calc-advanced {
    margin: 16px 0 18px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--bg-soft);
    overflow: hidden;
}
.calc-advanced > summary {
    list-style: none;
    cursor: pointer;
    padding: 14px 18px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 12px;
}
.calc-advanced > summary::-webkit-details-marker { display: none; }
.calc-advanced-title {
    font-weight: 600;
    color: var(--text);
    font-size: 14.5px;
}
.calc-advanced-hint {
    color: var(--text-secondary);
    font-size: 13px;
}
.calc-advanced-chev {
    width: 18px;
    height: 18px;
    color: var(--text-secondary);
    transition: transform .2s ease;
}
.calc-advanced[open] .calc-advanced-chev { transform: rotate(180deg); }
.calc-advanced[open] > summary {
    border-bottom: 1px solid var(--border);
    background: rgba(82, 147, 224, 0.06);
}
.calc-advanced > .form-row,
.calc-advanced > label.form-checkbox {
    padding: 0 18px;
    margin: 14px 0;
}
.calc-advanced[open] > *:last-child { padding-bottom: 14px; }
@media (max-width: 540px) {
    .calc-advanced-hint { display: none; }
}
.site-footer h5 {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 16px;
}

/* App buttons */
.store-btn { transition: transform .2s ease; }
.store-btn:hover { transform: translateY(-2px); }

/* Адаптивность hero */
@media (max-width: 900px) {
    .hero-v2 { padding-top: 32px; padding-bottom: 48px; }
    .hero-v2-meta { gap: 18px !important; padding-top: 22px; margin-top: 24px; }
    .hero-v2-meta-i .num { font-size: 1.4rem !important; }
    .hero-v2-meta-i .lbl { font-size: 11px; }
}

/* ==================================================================
   v24 — MOBILE FINAL PASS (≤ 720px)
   Адаптация под телефоны: вся вёрстка в одну колонку, читаемые
   шрифты, корректный 3D-планировщик, без горизонтального скролла.
   ================================================================== */
@media (max-width: 720px) {
    /* Контейнеры — компактнее */
    .container { padding-left: 16px !important; padding-right: 16px !important; }
    .container-narrow { padding-left: 16px; padding-right: 16px; }

    /* Hero — снижаем размеры заголовка и аккуратнее spacing */
    .hero-v2 { padding-top: 24px !important; padding-bottom: 36px !important; }
    .hero-v2-title { font-size: clamp(1.9rem, 8.5vw, 2.6rem) !important; }
    .hero-v2-lede { font-size: 0.95rem !important; line-height: 1.5; }
    .hero-v2-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
    .hero-v2-meta { grid-template-columns: repeat(2, 1fr) !important; gap: 14px !important; padding-top: 18px; margin-top: 20px; }
    .hero-v2-meta-i .num { font-size: 1.3rem !important; }
    .hero-v2-meta-i .lbl { font-size: 10.5px; }
    .hero-v2-tag { font-size: 11px; padding: 4px 10px; }

    /* Hero quick calc — внутренние отступы поменьше */
    .hero-v2-calc { padding: 18px !important; }
    .hero-v2-calc-tit { font-size: 1.05rem !important; }
    .hqc-route, .hqc-row { gap: 8px !important; }

    /* Header — на мобиле: логотип слева, телефон + отслеживание + бургер справа.
       Остальное (заказ, контакты, разделы) — в боковом меню. */
    .header-actions .btn { display: none !important; }
    .header-actions {
        gap: 10px;
        align-items: center;
        margin-left: auto;   /* прижимает блок к правому краю */
    }
    .site-header .header-inner {
        padding: 0 16px;
        height: 60px;
        gap: 0;
        justify-content: space-between;
    }

    /* Общий стиль для круглых кнопок-действий в шапке */
    .phone-link,
    .track-link {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 38px !important;
        height: 38px !important;
        padding: 0 !important;
        border: 1.5px solid var(--brand-blue) !important;
        border-radius: 50% !important;
        color: var(--brand-blue) !important;
        font-size: 0 !important;
        background: #fff;
        transition: background-color .15s ease, color .15s ease, transform .15s ease;
    }
    .phone-link svg,
    .track-link svg {
        width: 18px !important;
        height: 18px !important;
        margin: 0 !important;
    }
    .track-link span { display: none !important; }
    .phone-link:hover, .phone-link:active,
    .track-link:hover, .track-link:active {
        background: var(--brand-blue) !important;
        color: #fff !important;
        transform: none !important;
    }

    /* Section paddings и заголовки */
    section { padding-block: 48px !important; }
    .section-soft, .personas-v2, .lp-section { padding-block: 56px !important; }
    .section-head { margin-bottom: 28px !important; }
    .section-head h2, .section-title { font-size: clamp(1.5rem, 5.5vw, 2rem) !important; }
    .section-subtitle { font-size: 0.95rem !important; }

    /* Trust-strip — компактные пилюли */
    .trust-strip-v2 { padding: 10px 0 !important; }
    .trust-strip-v2 span { margin: 0 16px !important; font-size: 12px !important; }

    /* Personas / Features / Drivers / CTA — одна колонка */
    .personas-v2-grid,
    .features-grid,
    .drivers-v2-grid,
    .steps,
    .cta-v2-block,
    .highlight-block,
    .footer-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }
    .cta-v2-block { padding: 24px !important; }
    .highlight-block { padding: 24px !important; gap: 24px !important; }

    /* Карточки — меньше внутренних отступов */
    .feature-card, .persona-v2, .driver-v2-card, .step, .faq-item {
        padding: 20px !important;
    }
    .review-card { padding: 18px !important; }

    /* Step number — нормальный размер */
    .step .step-num { width: 36px; height: 36px; font-size: 14px; }

    /* Map — берём ширину контейнера, без принудительной высоты */
    .mapsec-v2-stage { overflow-x: auto; }
    .mapsec-v2-stage svg { min-width: 720px; }

    /* Story — фото сверху, текст снизу */
    .story-v2-grid { grid-template-columns: 1fr !important; gap: 24px !important; }

    /* Pull-quote — стек */
    .pq-v2-spread { grid-template-columns: 1fr !important; gap: 24px !important; }
    .pq-v2-main { font-size: 1.1rem !important; line-height: 1.45 !important; }

    /* Order form — стек, поле полная ширина */
    #order .highlight-block { grid-template-columns: 1fr !important; }
    .form-card { padding: 22px !important; }
    .form-card input, .form-card select, .form-card textarea {
        font-size: 16px !important; /* iOS не зумит при фокусе */
    }
    .hero-quick-calc input[type="text"],
    .hero-quick-calc select,
    .cta-v2-r input, .cta-v2-r select {
        font-size: 16px !important;
    }

    /* App buttons — в один ряд на ширину контейнера */
    .app-buttons { gap: 8px !important; flex-wrap: wrap; }
    .store-btn { padding: 8px 14px !important; flex: 1 0 calc(50% - 8px); justify-content: center; min-width: 0; }
    .store-btn .small { font-size: 0.62rem; }
    .store-btn .big { font-size: 0.88rem; }

    /* ===== 3D Load Planner ===== */
    .lp-section { padding: 48px 0 !important; }
    .lp-section .container { max-width: 100% !important; }

    /* Контентная сетка — стек, минимальная ширина */
    .lp-grid { grid-template-columns: 1fr !important; gap: 16px !important; }

    /* Табы машин — горизонтальный скролл */
    .lp-toolbar { margin: 0 0 16px !important; }
    .lp-trucks { padding: 4px 2px !important; gap: 6px !important; }
    .lp-truck-tab { min-width: 130px !important; padding: 10px 12px !important; border-radius: 12px !important; }
    .lp-truck-tab .lp-truck-name { font-size: 13px; }
    .lp-truck-tab .lp-truck-dim { font-size: 10px; }

    /* Левая панель ввода */
    .lp-input { padding: 16px !important; border-radius: 18px !important; }
    .lp-input h4 { font-size: 16px; }
    .lp-input-hint { font-size: 12.5px !important; margin-bottom: 12px !important; }
    .lp-room-presets { padding: 10px !important; gap: 6px !important; border-radius: 12px !important; }
    .lp-room { padding: 6px 11px !important; font-size: 12px !important; }
    .lp-room-tit { font-size: 10.5px !important; width: 100%; margin-right: 0; }

    /* Пресеты */
    .lp-presets { gap: 5px !important; padding-bottom: 12px !important; margin-bottom: 12px !important; }
    .lp-preset { padding: 6px 10px !important; font-size: 12px !important; }

    /* Таблица груза — горизонтальный скролл */
    .lp-table-wrap { border-radius: 10px !important; }
    .lp-table { min-width: 460px !important; font-size: 12px !important; }
    .lp-table thead th { padding: 8px 4px !important; font-size: 10px !important; }
    .lp-table tbody td { padding: 4px !important; }
    .lp-in { font-size: 16px !important; padding: 4px 6px !important; min-width: 0; } /* iOS-zoom prevention */
    .lp-table thead th:first-child,
    .lp-table tbody td:first-child { padding-left: 8px !important; }

    .lp-actions { margin: 10px 0 12px !important; gap: 6px !important; }
    .btn-sm { padding: 7px 12px !important; font-size: 12.5px !important; }
    .lp-check { font-size: 12.5px !important; gap: 6px !important; }
    .lp-check input { width: 16px !important; height: 16px !important; }

    /* Правая колонка — viewer */
    .lp-viewer { gap: 12px !important; }

    /* 3D-canvas: фиксированная высота, БЕЗ aspect-ratio (стабильнее на мобиле) */
    .lp-canvas-wrap {
        aspect-ratio: auto !important;
        height: 340px !important;
        min-height: 0 !important;
        border-radius: 18px !important;
        touch-action: pan-y;
    }
    #lpCanvas {
        width: 100% !important;
        height: 100% !important;
        display: block;
        touch-action: pan-y;
    }
    .lp-canvas-toolbar { top: 8px !important; right: 8px !important; padding: 4px !important; gap: 3px !important; border-radius: 10px !important; }
    .lp-cv-btn { width: 30px !important; height: 30px !important; }
    .lp-cv-btn svg { width: 16px !important; height: 16px !important; }
    .lp-canvas-hint { font-size: 9.5px !important; bottom: 6px !important; left: 8px !important; padding: 3px 6px !important; }
    .lp-canvas-empty p { font-size: 13px !important; max-width: 200px !important; }
    .lp-canvas-empty svg { width: 44px; height: 44px; }

    /* Stats — одна колонка, компактнее */
    .lp-stats { grid-template-columns: 1fr !important; gap: 8px !important; }
    .lp-stat { padding: 12px 14px !important; border-radius: 14px !important; }
    .lp-stat-num { font-size: 20px !important; }
    .lp-stat-num span { font-size: 12px !important; }
    .lp-stat-lbl { font-size: 10.5px !important; margin: 3px 0 6px !important; }
    .lp-stat-sub { font-size: 11px !important; }

    /* Recommend — стек */
    .lp-recommend { grid-template-columns: 1fr !important; padding: 14px !important; gap: 10px !important; text-align: center; border-radius: 14px !important; }
    .lp-rec-icon { font-size: 26px !important; margin: 0 auto !important; }
    .lp-rec-text strong { font-size: 14.5px !important; }
    .lp-rec-text span { font-size: 12px !important; }
    .lp-recommend .btn { width: 100%; padding: 10px 16px !important; }

    /* Footer — отступы и пилюли */
    .site-footer { padding-top: 48px !important; padding-bottom: 24px !important; }
    .site-footer h5 { font-size: 12px; }
    .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
    .footer-store-btns { justify-content: center; }

    /* Sticky-CTA mobile — лёгкий пэддинг */
    .sticky-cta { padding: 10px 14px; }
}

/* Совсем узкие экраны (≤ 380px) — ещё больше ужимаем */
@media (max-width: 380px) {
    .hero-v2-meta { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
    .hero-v2-title { font-size: 1.7rem !important; }
    .lp-truck-tab { min-width: 110px !important; }
    .store-btn { flex: 1 0 100%; }
    .phone-link { display: none; } /* совсем нет места — оставляем только трек и заказ */
}

/* Запретить горизонтальный скролл всей страницы */
html, body { overflow-x: hidden; max-width: 100%; }

/* Hero-tag — компактная пилюля, не растягивается на всю ширину */
.hero-v2-tag {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    padding: 5px 12px !important;
    font-size: 11px !important;
    font-weight: 600;
    line-height: 1.4 !important;
    letter-spacing: 0.04em;
    width: auto !important;
    max-width: 100%;
    white-space: normal;
    text-transform: none;
    margin-bottom: 14px !important;
}
@media (max-width: 480px) {
    .hero-v2-tag { font-size: 10.5px !important; padding: 4px 10px !important; }
}

/* ==================================================================
   v25 — MOBILE QUICK FIXES (после реальных скриншотов с iPhone)
   ================================================================== */
@media (max-width: 720px) {
    /* На мобиле дублируется чат: оставляем ОДНУ кнопку поддержки.
       Внутри её меню уже есть пункт «ИИ-помощник», который открывает чат. */
    .ai-chat-fab { display: none !important; }

    /* Sticky-CTA полоса внизу — выключаем (цена устарела, дублирует lp-recommend) */
    .sticky-cta { display: none !important; }
    body.has-sticky-cta { padding-bottom: 0 !important; }

    /* Пресеты груза: жёстко не выходить за родителя */
    .lp-input { overflow: hidden; }
    .lp-presets { width: 100%; max-width: 100%; }
    .lp-preset {
        max-width: 100%;
        white-space: nowrap;
        text-overflow: ellipsis;
        overflow: hidden;
        flex: 0 1 auto;
    }
    /* Готовые наборы — пилюли не должны быть слишком широкими */
    .lp-room { flex: 0 1 auto; max-width: calc(50% - 4px); }

    /* Канва 3D — корректный фон у самого верха (был артефакт «полосы») */
    .lp-canvas-wrap {
        background: linear-gradient(180deg, #f3f7fc 0%, #ffffff 100%) !important;
    }

    /* Убрать кнопку чата/поддержки в самый угол, чтобы не залезала на контент */
    .support-fab {
        bottom: 16px !important;
        right: 16px !important;
        width: 52px !important;
        height: 52px !important;
        z-index: 90 !important;
    }
}

/* ==================================================================
   v25 — TILDA PREMIUM (тихий слой)
   Только типография, отступы, тонкие акценты. Никаких блобов,
   мерцаний, плавающих карточек. Не трогает 3D-планировщик,
   формы и адаптивную сетку.
   ================================================================== */

/* Section heads — крупно, центрировано, с воздухом */
.section-head {
    margin-bottom: clamp(28px, 4vw, 48px);
    text-align: center;
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}
.section-head .eyebrow {
    display: inline-block;
    padding: 6px 14px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--brand-blue-dark);
    background: rgba(82, 147, 224, 0.06);
    border-radius: 999px;
    margin-bottom: 18px;
}
.section-title,
.section-head h2 {
    font-size: clamp(1.85rem, 3.6vw, 2.85rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.035em !important;
    font-weight: 700 !important;
    text-wrap: balance;
    margin-bottom: 14px !important;
    color: var(--text);
}
.section-head .section-title em,
.section-head h2 em {
    font-style: italic;
    color: var(--brand-blue);
    font-weight: 700;
    position: relative;
}
.section-subtitle {
    font-size: clamp(0.98rem, 1.2vw, 1.1rem) !important;
    line-height: 1.55 !important;
    color: var(--text-secondary) !important;
    text-wrap: pretty;
    max-width: 60ch;
    margin: 0 auto !important;
}

/* Премиальные отступы между секциями */
section { padding-block: clamp(56px, 7vw, 96px); }
.hero, .hero-v2 { padding-block: clamp(48px, 5vw, 72px) !important; }
.section-soft { padding-block: clamp(56px, 7vw, 96px); }

/* Hero h1 — крупнее, чище */
.hero-v2-title,
.hero-v2 h1,
.page-hero h1 {
    font-size: clamp(2.4rem, 5.4vw, 4.4rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.045em !important;
    font-weight: 800 !important;
    text-wrap: balance;
}
.page-hero h1 em,
.hero-v2-title em {
    font-style: italic;
    color: var(--brand-blue);
}

/* Body text readability */
p { line-height: 1.65; }
.hero-v2-lede { font-size: clamp(1rem, 1.3vw, 1.18rem) !important; line-height: 1.6 !important; }

/* Кнопки primary — солиднее */
.btn-primary,
.btn.btn-primary {
    padding: 13px 24px !important;
    font-weight: 600 !important;
    letter-spacing: 0.005em !important;
    border-radius: 10px !important;
    box-shadow: 0 1px 2px rgba(13,20,38,0.08), 0 4px 12px rgba(82,147,224,0.18) !important;
}
.btn-primary.btn-lg {
    padding: 16px 32px !important;
    font-size: 16px !important;
}
.btn-primary:hover {
    box-shadow: 0 2px 4px rgba(13,20,38,0.10), 0 8px 18px rgba(82,147,224,0.28) !important;
    transform: translateY(-1px);
    transition: all .2s ease;
}

/* Карточки — мягкие, сдержанные */
.feature-card,
.tariff-card,
.persona-v2,
.driver-v2-card,
.faq-item,
.step,
.review-card {
    border-radius: 16px !important;
    box-shadow:
        0 1px 2px rgba(13,20,38,0.04),
        0 1px 1px rgba(13,20,38,0.02) !important;
    border: 1px solid rgba(13,20,38,0.06) !important;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.feature-card:hover,
.tariff-card:hover,
.persona-v2:hover,
.driver-v2-card:hover {
    transform: translateY(-3px);
    box-shadow:
        0 1px 2px rgba(13,20,38,0.06),
        0 12px 28px -8px rgba(82,147,224,0.18) !important;
    border-color: rgba(82,147,224,0.18) !important;
}

/* Tighter feature-icon */
.feature-card .feature-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(82,147,224,0.10);
    color: var(--brand-blue);
    display: grid;
    place-items: center;
    margin-bottom: 14px;
}
.feature-card .feature-icon svg { width: 24px; height: 24px; }

/* Hero meta-блок — солиднее */
.hero-v2-meta {
    border-top: 1px solid rgba(82,147,224,0.16);
    padding-top: 24px;
    margin-top: 32px;
}
.hero-v2-meta-i .num {
    font-weight: 800;
    font-size: clamp(1.5rem, 2vw, 1.95rem);
    letter-spacing: -0.04em;
    line-height: 1;
    color: var(--text);
}
.hero-v2-meta-i .lbl {
    margin-top: 6px;
    font-size: 12px;
    color: var(--text-secondary);
    letter-spacing: 0.02em;
}

/* Footer — больше воздуха в верхушке */
.site-footer {
    padding-top: clamp(64px, 8vw, 110px) !important;
}
.site-footer h5 {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 16px;
    color: rgba(255,255,255,0.95);
}

/* Trust strip — лаконичнее */
.trust-strip-v2 {
    padding: 16px 0;
    background: #0d1426;
}
.trust-strip-v2 b {
    color: var(--brand-cyan);
    font-weight: 600;
    margin-left: 4px;
}

/* Smooth scroll */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .btn-primary:hover { transform: none; transition: none; }
}

/* ============================================================
   V18 — REDESIGN PASS:
   • тёплый акцент #ff8a3d для CTA (--accent)
   • Fraunces italic для display-заголовков
   • современные тени, motion, кнопки
   ============================================================ */

/* Главные «Заказать»-кнопки — теплый акцент */
.btn-primary,
.hqc-submit,
.bb-btn-primary,
.bb-header-cta {
  background: linear-gradient(135deg, var(--accent, #ff8a3d) 0%, var(--accent-dark, #e66a1e) 100%) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 6px 18px var(--accent-glow, rgba(255, 138, 61, .35));
  transition: transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s, filter .2s;
}
.btn-primary:hover,
.hqc-submit:hover,
.bb-btn-primary:hover,
.bb-header-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 28px var(--accent-glow, rgba(255, 138, 61, .45));
  filter: brightness(1.05);
}
.btn-primary:active,
.hqc-submit:active { transform: translateY(0); filter: brightness(.96); }

/* Display-шрифт Fraunces ТОЛЬКО для италик-акцентов (em внутри H1).
   Сами H1 остаются в Onest 800 — это даёт чистый контраст
   и убирает «винтажный» оттенок Fraunces из всего сайта */
.hero-v2-title em,
.page-hero h1 em,
.jp-hero h1 em,
.bb-hero h1 em,
section h2 em,
h2 em.accent {
  font-family: 'Fraunces', 'Onest', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
  color: var(--accent, #ff8a3d) !important;
  letter-spacing: -0.01em;
}

/* === HERO v4 — CINEMATIC FULL-BLEED === */
.hero-v2 {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate;
  padding: 0 !important;
  min-height: 88vh;
  display: flex;
  align-items: center;
  margin-top: -1px;
}
.hero-v2 .hero-truck-bg {
  position: absolute !important;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(110deg, rgba(14, 28, 56, .88) 0%, rgba(14, 28, 56, .6) 45%, rgba(14, 28, 56, .35) 100%),
    url('../img/hero-truck.jpg') no-repeat center / cover;

  background:
    linear-gradient(110deg, rgba(14, 28, 56, .88) 0%, rgba(14, 28, 56, .6) 45%, rgba(14, 28, 56, .35) 100%),
    image-set(url('../img/hero-truck.webp') type('image/webp'), url('../img/hero-truck.jpg') type('image/jpeg')) no-repeat center / cover;
}
.hero-v2 .hero-truck-bg::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 600px 400px at 80% 30%, rgba(255, 138, 61, .18), transparent 60%);
}

/* Hero-сетка переделывается на одну колонку с текстом по левому краю */
.hero-v2 .hero-v2-grid {
  display: block !important;
  max-width: 1200px;
  padding: 100px 24px 120px !important;
}
.hero-v2 .hero-v2-grid > div:first-child { max-width: 720px; }

/* Tag и текст — белым */
.hero-v2 .hero-v2-tag {
  background: rgba(255, 255, 255, .14) !important;
  border: 1px solid rgba(255, 255, 255, .25) !important;
  color: #fff !important;
  backdrop-filter: blur(8px);
}
.hero-v2 .hero-v2-tag::before { background: #4ade80 !important; box-shadow: 0 0 0 4px rgba(74, 222, 128, .25); }

.hero-v2-title {
  color: #fff !important;
  font-size: clamp(2.6rem, 6vw, 5rem) !important;
  margin-bottom: 22px !important;
}
.hero-v2-title em {
  color: #ffd84d !important;
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
}
.hero-v2 .hero-v2-lede {
  color: rgba(255, 255, 255, .85) !important;
  font-size: 19px !important;
  max-width: 56ch;
  line-height: 1.6 !important;
  margin-bottom: 36px !important;
}

/* Скрываем встроенный калькулятор/aside внутри hero — он переезжает в отдельную секцию ниже */
.hero-v2 .hero-v2-grid > aside,
.hero-v2 .hero-v2-grid > div:nth-child(2) { display: none !important; }

/* Скрываем пресеты-кнопки, старую meta, AI-бейдж и расширенный калькулятор-ссылку из hero */
.hero-v2 .hqc-form,
.hero-v2 .hqc-presets,
.hero-v2 .hero-v2-meta,
.hero-v2 .ai-badge,
.hero-v2 .hero-v2-grid > div:first-child > div[style*="margin-top: 28px"] { display: none !important; }

/* Большие CTA-кнопки в hero */
.hero-cta-row {
  display: flex; gap: 14px; flex-wrap: wrap;
  margin-top: 12px;
}
.hero-cta-row .btn-primary,
.hero-cta-row .btn-outline {
  font-size: 16px !important;
  padding: 16px 28px !important;
  border-radius: 12px !important;
}
.hero-cta-row .btn-outline {
  border: 1.5px solid rgba(255,255,255,.4) !important;
  color: #fff !important;
  background: rgba(255,255,255,.06) !important;
  backdrop-filter: blur(6px);
}
.hero-cta-row .btn-outline:hover {
  background: rgba(255,255,255,.12) !important;
  border-color: rgba(255,255,255,.7) !important;
}

/* Hero-stats — ОЧЕНЬ крупные числа поверх фото */
.hero-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  max-width: 760px;
  margin-top: 72px;
  padding-top: 40px;
  border-top: 1px solid rgba(255,255,255,.18);
}
.hero-stats-row > div { display: flex; flex-direction: column; gap: 6px; }
.hero-stats-row .stat-num {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: clamp(2.6rem, 4.5vw, 4rem) !important;
  color: #ffd84d !important;
  line-height: 0.95 !important;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 12px rgba(0,0,0,.5);
  white-space: nowrap;
  display: block !important;
  opacity: 1 !important;
}
.hero-stats-row .stat-lbl {
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
}
.hero-stats-row .stat-num small {
  font-size: 0.45em;
  font-weight: 500;
  margin-left: 2px;
  font-style: normal;
  vertical-align: top;
}
.hero-stats-row .stat-lbl {
  font-size: 12px;
  color: rgba(255,255,255,.7);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 500;
}

/* Кнопка hero-cta-row .btn-primary — крупная без default !important перебивающего gradient */
.hero-cta-row .btn-primary {
  background: linear-gradient(135deg, var(--accent, #ff8a3d) 0%, var(--accent-dark, #e66a1e) 100%) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px var(--accent-glow, rgba(255,138,61,.4));
}

/* Mobile: уменьшаем высоту, паддинги */
@media (max-width: 900px) {
  .hero-v2 { min-height: 72vh; }
  .hero-v2 .hero-v2-grid { padding: 80px 20px 100px !important; }
  .hero-stats-row { grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 40px; }
}

/* === STICKY CTA-BAR — появляется снизу при скролле === */
.sticky-cta {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 90;
  padding: 14px 24px;
  background: rgba(14, 28, 56, 0.95);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: #fff;
  pointer-events: none;
}
.sticky-cta.is-visible {
  transform: translateY(0);
  pointer-events: auto;
}
.sticky-cta-text {
  display: flex; flex-direction: column; gap: 2px;
}
.sticky-cta-title {
  font-weight: 700;
  font-size: 15px;
  color: #fff;
}
.sticky-cta-sub {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.7);
}
.sticky-cta-actions {
  display: flex; align-items: center; gap: 10px;
}
.sticky-cta-phone {
  display: inline-flex; align-items: center; gap: 6px;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  padding: 10px 14px;
  border-radius: 10px;
  transition: background .2s;
}
.sticky-cta-phone:hover { background: rgba(255,255,255,.1); }
.sticky-cta-phone svg { width: 16px; height: 16px; }
.sticky-cta-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  background: linear-gradient(135deg, #ff8a3d 0%, #e66a1e 100%);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  border-radius: 10px;
  box-shadow: 0 6px 16px rgba(255,138,61,.4);
  transition: transform .2s, box-shadow .2s, filter .2s;
}
.sticky-cta-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(255,138,61,.5);
  filter: brightness(1.06);
}
@media (max-width: 720px) {
  .sticky-cta { padding: 10px 14px; }
  .sticky-cta-text { display: none; }
  .sticky-cta-phone span { display: none; }
  .sticky-cta-phone { padding: 10px; }
  .sticky-cta-btn { padding: 12px 18px; flex: 1; justify-content: center; }
}

/* === Тёмная секция «Скачайте приложение» перед футером === */
.app-section {
  background:
    radial-gradient(ellipse 800px 500px at 80% 0%, rgba(255,138,61,.18), transparent 60%),
    linear-gradient(135deg, #0e1c38 0%, #1e4d8f 100%) !important;
  color: #fff !important;
  padding: 80px 0 !important;
}
.app-section h2,
.app-section h3 { color: #fff !important; }
.app-section p { color: rgba(255,255,255,.85) !important; }
.app-section .eyebrow {
  background: rgba(255,255,255,.14) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.25);
}

/* === B2B-hero на for-clients.html === */
.b2b-hero-section {
  position: relative;
  isolation: isolate;
  padding: 90px 0 100px !important;
  overflow: hidden;
}
.b2b-hero-section .b2b-hero-bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(135deg, rgba(14,28,56,.92) 0%, rgba(30,77,143,.78) 60%, rgba(14,28,56,.85) 100%),
    url('../img/warehouse-loading.jpg') no-repeat center / cover;

  background:
    linear-gradient(135deg, rgba(14,28,56,.92) 0%, rgba(30,77,143,.78) 60%, rgba(14,28,56,.85) 100%),
    image-set(url('../img/warehouse-loading.webp') type('image/webp'), url('../img/warehouse-loading.jpg') type('image/jpeg')) no-repeat center / cover;
}
.b2b-hero-section .features-grid .feature-card {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  backdrop-filter: blur(8px);
}
.b2b-hero-section .features-grid .feature-card h4 { color: #fff; }
.b2b-hero-section .features-grid .feature-card p { color: rgba(255,255,255,.78); }
.b2b-hero-section .features-grid .feature-icon {
  background: rgba(255,216,77,.15) !important;
  color: #ffd84d !important;
}

/* === Отдельная секция «Калькулятор» поверх hero (overlap) === */
.calc-section {
  position: relative;
  z-index: 2;
  margin-top: -80px;
  padding: 0 0 80px;
}
.calc-section .container { max-width: 720px; }
.calc-section .calc-card {
  background: #fff;
  border-radius: 24px;
  padding: 28px;
  box-shadow:
    0 30px 80px -20px rgba(15, 23, 42, .35),
    0 12px 24px -8px rgba(15, 23, 42, .12),
    0 0 0 1px rgba(82, 147, 224, .08);
}
.calc-section .calc-card h3 {
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.calc-section .calc-card .sub {
  font-size: 14px;
  color: var(--text-muted, #6b7280);
  margin-bottom: 20px;
}

/* Уголки/тени современнее: немного мягче */
.feature-card,
.form-card,
.hqc-form,
.persona-v2 {
  box-shadow:
    0 1px 3px rgba(15, 23, 42, .04),
    0 4px 12px rgba(15, 23, 42, .04),
    0 24px 48px -12px rgba(15, 23, 42, .06);
  transition: transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s;
}
.feature-card:hover,
.persona-v2:hover {
  transform: translateY(-3px);
  box-shadow:
    0 1px 3px rgba(15, 23, 42, .05),
    0 8px 18px rgba(15, 23, 42, .06),
    0 32px 64px -16px rgba(82, 147, 224, .15);
}

/* Магнетический эффект CTA через outline-glow при hover */
.btn-primary::before { content: none !important; }

/* Анимированные счётчики стартуют невидимыми */
[data-counter] { opacity: 0; transition: opacity .4s ease-out; }
[data-counter].in-view { opacity: 1; }

/* Smooth-scroll работает уже из html { scroll-behavior:smooth }, добавим offset */
section[id] { scroll-margin-top: 80px; }

/* Reveal-анимация для блоков при появлении в viewport */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s cubic-bezier(.16,1,.3,1), transform .6s cubic-bezier(.16,1,.3,1);
  will-change: opacity, transform;
}
.reveal.in-view { opacity: 1; transform: none; }

/* Универсальная иконка-плитка (Lucide-стиль), заменяет эмодзи в карточках */
.icon-tile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand-blue-light, #e8f0fc) 0%, rgba(82, 147, 224, 0.06) 100%);
  color: var(--brand-blue-dark, #3d7bc7);
  flex-shrink: 0;
  transition: transform .2s cubic-bezier(.16,1,.3,1), background .2s, color .2s;
}
.icon-tile svg { width: 22px; height: 22px; }
.feature-card:hover .icon-tile,
.form-card:hover .icon-tile {
  background: linear-gradient(135deg, var(--brand-blue, #5293e0) 0%, var(--brand-blue-deep, #1e4d8f) 100%);
  color: #fff;
  transform: scale(1.05) rotate(-3deg);
}

/* === Иконка грузовика в lp-rec-icon (3D-планировщик) === */
.lp-rec-icon {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand-blue-light, #e8f0fc) 0%, rgba(82, 147, 224, 0.06) 100%);
  color: var(--brand-blue-dark, #3d7bc7);
  font-size: 0 !important;
}
.lp-rec-icon svg { width: 26px; height: 26px; }

/* === Иконка-плитка для карточек персон === */
.persona-v2-emoji {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 56px !important;
  height: 56px !important;
  font-size: 0 !important;
  background: linear-gradient(135deg, var(--brand-blue-light, #e8f0fc) 0%, rgba(82, 147, 224, 0.06) 100%);
  color: var(--brand-blue-dark, #3d7bc7);
  border-radius: 14px;
  margin-bottom: 18px;
  transition: transform .25s cubic-bezier(.16,1,.3,1), background .25s, color .25s;
}
.persona-v2-emoji svg {
  width: 28px !important;
  height: 28px !important;
}
.persona-v2:hover .persona-v2-emoji {
  background: linear-gradient(135deg, var(--brand-blue, #5293e0) 0%, var(--brand-blue-deep, #1e4d8f) 100%);
  color: #fff;
  transform: scale(1.08) rotate(-3deg);
}

/* /V18 ============================================ */

/* ================================================================
   V19 — UNIFIED DESIGN SYSTEM
   Гармонизация: одна палитра, одна типографика, одна сетка тонов.
   Этот слой идёт В САМОМ КОНЦЕ файла и побеждает все предыдущие.
   ================================================================ */

:root {
  /* Финальная палитра — никаких жёлтых, серебряных, фиолетовых */
  --gv-blue:        #5293e0;
  --gv-blue-deep:   #1e4d8f;
  --gv-blue-soft:   #e8f0fc;
  --gv-orange:      #ff8a3d;
  --gv-orange-dark: #e66a1e;
  --gv-ink:         #0c1a30;
  --gv-ink-soft:    #4a5a72;
  --gv-ink-muted:   #8a96a8;
  --gv-line:        #e2e8f0;
  --gv-bg:          #ffffff;
  --gv-bg-soft:     #f7f9fc;
}

/* ===== HERO — sober dark-blue без жёлтого ===== */
.hero-v2 .hero-truck-bg {
  background:
    linear-gradient(110deg, rgba(14, 28, 56, .92) 0%, rgba(30, 77, 143, .72) 50%, rgba(14, 28, 56, .55) 100%) !important,
    url('../img/hero-truck.jpg') no-repeat right 30% center / 70% auto !important;

  background:
    linear-gradient(110deg, rgba(14, 28, 56, .92) 0%, rgba(30, 77, 143, .72) 50%, rgba(14, 28, 56, .55) 100%) !important,
    image-set(url('../img/hero-truck.webp') type('image/webp'), url('../img/hero-truck.jpg') type('image/jpeg')) no-repeat right 30% center / 70% auto !important;
}
.hero-v2-title em {
  color: var(--gv-orange) !important;
}
.hero-stats-row .stat-num {
  color: #fff !important;
  font-family: 'Onest', sans-serif !important;
  font-style: normal !important;
  font-weight: 800 !important;
  font-size: clamp(1.8rem, 3vw, 2.6rem) !important;
  letter-spacing: -0.02em;
  text-shadow: none !important;
}
.hero-stats-row .stat-num small {
  font-size: 0.55em;
  font-weight: 600;
  color: var(--gv-orange) !important;
  margin-left: 4px;
}
.hero-stats-row .stat-lbl {
  font-size: 11px !important;
  color: rgba(255,255,255,.65) !important;
  text-shadow: none !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
}
.hero-stats-row {
  border-top: 1px solid rgba(255,255,255,.14) !important;
  margin-top: 56px !important;
  padding-top: 32px !important;
}

/* CTA-кнопки — стандартизуем */
.btn-primary,
.hqc-submit,
.hero-cta-row .btn-primary {
  background: var(--gv-orange) !important;
  background-image: none !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 10px !important;
  padding: 14px 24px !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 14px rgba(255, 138, 61, 0.28) !important;
  transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease !important;
  filter: none !important;
}
.btn-primary:hover,
.hqc-submit:hover,
.hero-cta-row .btn-primary:hover {
  background: var(--gv-orange-dark) !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(255, 138, 61, 0.36) !important;
  filter: none !important;
}

/* Outline-кнопки в hero */
.hero-cta-row .btn-outline {
  background: transparent !important;
  border: 1.5px solid rgba(255,255,255,.35) !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 14px 24px !important;
}
.hero-cta-row .btn-outline:hover {
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.6) !important;
}

/* ===== СЕКЦИИ — единое чередование белый ↔ soft ===== */
main > section { background: var(--gv-bg); }
main > section.section-soft,
main > section:nth-of-type(even).auto-soft { background: var(--gv-bg-soft); }

/* H2 / eyebrow — одинаковый ритм везде */
.section-head { text-align: center; max-width: 720px; margin: 0 auto 48px; }
.section-head .eyebrow {
  display: inline-block;
  padding: 6px 14px;
  background: var(--gv-blue-soft);
  color: var(--gv-blue-deep);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
main h2,
.section-title {
  font-family: 'Onest', sans-serif !important;
  font-size: clamp(1.8rem, 3.4vw, 2.4rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  color: var(--gv-ink) !important;
  line-height: 1.15 !important;
  margin-bottom: 16px !important;
}
main h2 em {
  color: var(--gv-blue) !important;
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
}
.section-subtitle {
  font-size: 16px !important;
  line-height: 1.55 !important;
  color: var(--gv-ink-soft) !important;
  margin: 0 auto !important;
}

/* ===== КАРТОЧКИ — единый стиль ===== */
.feature-card,
.form-card,
.persona-v2,
.tariff-card,
.faq-item,
.bb-fleet-card {
  background: #fff !important;
  border: 1px solid var(--gv-line) !important;
  border-radius: 14px !important;
  box-shadow: 0 1px 3px rgba(15, 23, 42, .04) !important;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease !important;
}
.feature-card:hover,
.persona-v2:hover,
.tariff-card:hover,
.bb-fleet-card:hover {
  border-color: var(--gv-blue) !important;
  box-shadow: 0 8px 24px -6px rgba(82, 147, 224, 0.18) !important;
  transform: translateY(-2px);
}

/* Иконки в карточках — одинаковая плитка */
.feature-icon,
.persona-v2-emoji,
.icon-tile,
.lp-rec-icon,
.ins-modal-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: 10px !important;
  background: var(--gv-blue-soft) !important;
  color: var(--gv-blue-deep) !important;
  background-image: none !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transform: none !important;
}
.feature-icon svg,
.persona-v2-emoji svg,
.icon-tile svg,
.lp-rec-icon svg,
.ins-modal-icon svg {
  width: 22px !important;
  height: 22px !important;
}
.feature-card:hover .feature-icon,
.persona-v2:hover .persona-v2-emoji,
.feature-card:hover .icon-tile,
.form-card:hover .icon-tile {
  background: var(--gv-blue) !important;
  color: #fff !important;
  transform: none !important;
}

/* ===== B2B — без full-bleed тёмного фона, мягкая секция со складом сбоку ===== */
.b2b-hero-section {
  padding: 80px 0 !important;
  background: var(--gv-bg-soft) !important;
}
.b2b-hero-section .b2b-hero-bg { display: none !important; }
.b2b-hero-section .section-head .eyebrow {
  background: var(--gv-blue-soft) !important;
  color: var(--gv-blue-deep) !important;
  border: 0 !important;
}
.b2b-hero-section .section-head h2,
.b2b-hero-section .section-title {
  color: var(--gv-ink) !important;
}
.b2b-hero-section .section-head h2 em,
.b2b-hero-section .section-title em {
  color: var(--gv-blue) !important;
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
}
.b2b-hero-section .section-head p,
.b2b-hero-section .section-subtitle {
  color: var(--gv-ink-soft) !important;
}
.b2b-hero-section .features-grid .feature-card {
  background: #fff !important;
  border: 1px solid var(--gv-line) !important;
  backdrop-filter: none !important;
}
.b2b-hero-section .features-grid .feature-card h4 { color: var(--gv-ink) !important; }
.b2b-hero-section .features-grid .feature-card p { color: var(--gv-ink-soft) !important; }
.b2b-hero-section .features-grid .feature-icon {
  background: var(--gv-blue-soft) !important;
  color: var(--gv-blue-deep) !important;
}

/* ===== APP-секция — мягкий бренд-синий ===== */
.app-section {
  background: linear-gradient(135deg, var(--gv-blue-deep) 0%, var(--gv-blue) 100%) !important;
  padding: 72px 0 !important;
}
.app-section h2,
.app-section h3 { color: #fff !important; }
.app-section h2 em { color: #fff !important; opacity: .9; }
.app-section p { color: rgba(255,255,255,.8) !important; }

/* ===== STICKY-BAR — мягче, sobriety ===== */
.sticky-cta {
  background: rgba(14, 28, 56, 0.96) !important;
}
.sticky-cta-btn {
  background: var(--gv-orange) !important;
  background-image: none !important;
  box-shadow: 0 4px 14px rgba(255, 138, 61, 0.32) !important;
}
.sticky-cta-btn:hover {
  background: var(--gv-orange-dark) !important;
  filter: none !important;
}

/* ===== РАЗНОЕ — убираем агрессивные акценты ===== */
.bb-hero h1 em,
.page-hero h1 em,
.jp-hero h1 em {
  color: var(--gv-blue) !important;
  font-family: 'Fraunces', Georgia, serif !important;
}
.preview-banner { background: var(--gv-ink) !important; }

/* badges/pills — без неона */
.save-badge,
.tag-pill {
  background: var(--gv-blue-soft) !important;
  color: var(--gv-blue-deep) !important;
  border: 0 !important;
}

/* ===== Trust-strip (бегущая лента) — спокойнее ===== */
.trust-strip-v2 {
  background: var(--gv-bg-soft) !important;
  border-top: 1px solid var(--gv-line) !important;
  border-bottom: 1px solid var(--gv-line) !important;
}
.trust-strip-v2 b { color: var(--gv-blue-deep) !important; }

/* ===== КАЛЬКУЛЯТОР-карточка ===== */
.calc-section .calc-card {
  background: #fff !important;
  border: 1px solid var(--gv-line) !important;
  box-shadow: 0 24px 48px -16px rgba(15, 23, 42, 0.18) !important;
  border-radius: 18px !important;
  backdrop-filter: none !important;
}

/* /V19 ============================================ */

/* ================================================================
   V20 — FORCE-FIX: убираем выцветшие текст-градиенты на заголовках
   и делаем карточки плотнее
   ================================================================ */

/* Все H2 — solid тёмно-синий, никаких прозрачных gradient-fill */
main h2,
main .section-title,
main h2 .section-title,
.section-head h2,
.section-head .section-title,
section h2,
section .section-title {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  -webkit-text-fill-color: var(--gv-ink) !important;
  color: var(--gv-ink) !important;
  text-shadow: none !important;
  filter: none !important;
}

/* Em-акценты внутри H2 — bright синий/курсивный */
main h2 em,
main .section-title em,
section h2 em,
.section-head h2 em {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  -webkit-text-fill-color: var(--gv-blue) !important;
  color: var(--gv-blue) !important;
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
}

/* Reveal-блокировка выцветания: in-view возвращает в норму */
.reveal,
[data-animate] {
  opacity: 1 !important;
  transform: none !important;
}

/* Карточки — плотнее. Иконка слева от заголовка, не сверху */
.feature-card,
.persona-v2,
.form-card {
  padding: 24px 22px !important;
}
.feature-card h4,
.persona-v2 h3,
.persona-v2-tit,
.form-card h3 {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--gv-ink) !important;
  margin: 14px 0 8px !important;
  line-height: 1.3 !important;
}
.feature-card p,
.persona-v2 p,
.persona-v2-d,
.form-card p {
  font-size: 14.5px !important;
  line-height: 1.55 !important;
  color: var(--gv-ink-soft) !important;
}

/* Иконки в карточках — ярче и крупнее */
.feature-icon,
.persona-v2-emoji,
.icon-tile,
.lp-rec-icon {
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  background: var(--gv-blue-soft) !important;
  color: var(--gv-blue) !important;
  margin-bottom: 4px !important;
}
.feature-icon svg,
.persona-v2-emoji svg,
.icon-tile svg,
.lp-rec-icon svg {
  width: 24px !important;
  height: 24px !important;
}

/* Persona-карточки — список ✓ компактнее */
.persona-v2-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 14px 0 !important;
  border-top: 1px solid var(--gv-line);
  padding-top: 14px !important;
}
.persona-v2-list li {
  font-size: 14px !important;
  color: var(--gv-ink-soft) !important;
  padding: 4px 0 !important;
}

/* Section-head — больше места снизу, чтобы дышать */
.section-head { margin-bottom: 56px !important; }

/* /V20 ============================================ */

/* ================================================================
   V21 — LIVE-FEED + TRUST LOGOS
   ================================================================ */

/* === Live-feed «Сейчас в пути» === */
.live-feed-section {
  padding: 64px 0 !important;
  background: var(--gv-bg) !important;
}
.live-feed-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 24px;
  max-width: 100%;
  margin-bottom: 28px;
}
.live-feed-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  background: rgba(74, 222, 128, .12);
  color: #16a34a;
  border-radius: 999px;
  font-size: 13px; font-weight: 600;
  margin-bottom: 12px;
}
.live-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #4ade80;
  box-shadow: 0 0 0 4px rgba(74,222,128,.18);
  animation: live-pulse 1.4s ease-in-out infinite;
}
@keyframes live-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.45; }
}
.live-feed-title {
  font-size: clamp(1.6rem, 2.8vw, 2.2rem) !important;
  font-weight: 800 !important;
  margin: 0 !important;
  color: var(--gv-ink) !important;
}
.live-feed-title em {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
  color: var(--gv-blue) !important;
  font-weight: 400 !important;
}
.live-feed-counter {
  text-align: right;
}
.live-feed-counter-num {
  font-size: 38px;
  font-weight: 800;
  color: var(--gv-blue-deep);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.live-feed-counter-lbl {
  font-size: 13px;
  color: var(--gv-ink-muted);
  margin-top: 4px;
}
.live-feed-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.live-feed-item {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  background: #fff;
  border: 1px solid var(--gv-line);
  border-radius: 12px;
  transition: opacity .4s ease, transform .4s ease, border-color .2s ease;
  animation: feed-slide-in .5s cubic-bezier(.16,1,.3,1);
}
@keyframes feed-slide-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: none; }
}
.live-feed-item.is-fading {
  opacity: 0;
  transform: translateX(-12px);
}
.live-feed-status {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #4ade80;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(74,222,128,.18);
}
.live-feed-route {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
  color: var(--gv-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.live-feed-route b { font-weight: 600; }
.live-feed-truck {
  font-size: 12px;
  color: var(--gv-ink-muted);
  white-space: nowrap;
}
.live-feed-time {
  font-size: 12px;
  color: var(--gv-ink-muted);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
@media (max-width: 720px) {
  .live-feed-list { grid-template-columns: 1fr; }
  .live-feed-counter { text-align: left; }
}

/* /V21 ============================================ */

/* ================================================================
   V22 — Telegram + WhatsApp в шапке: чистые brand-круги
   как полноцветные иконки, без обводки/плашки сайта
   ================================================================ */
.header-social,
.header-social.header-tg,
.header-social.header-wa {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 36px !important;
  height: 36px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-decoration: none !important;
  flex-shrink: 0;
  transition: transform .2s cubic-bezier(.16,1,.3,1), filter .2s ease;
}
.header-social svg {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  border-radius: 50%;
}
.header-social:hover {
  transform: translateY(-1px) scale(1.05);
  filter: brightness(1.05);
}
@media (max-width: 600px) {
  .header-social,
  .header-social.header-tg,
  .header-social.header-wa { width: 34px !important; height: 34px !important; }
}
/* /V22 ============================================ */
/* === Карта России: убираем дёргание (reveal/parallax/transform) === */
.mapsec-v2,
.mapsec-v2 *,
.mapsec-v2-stage,
.mapsec-v2-stage svg,
.mapsec-v2-stage svg * {
  animation-name: revert !important;
  transform: none !important;
  transition: none !important;
}
/* Возвращаем ТОЛЬКО SVG <animate> для пульсирующих кругов городов — они зашиты внутрь SVG */
.mapsec-v2-stage svg circle[fill="none"] { /* это пульсирующие хабы */
  animation-name: revert !important;
}
/* hover на точках городов оставляем плавным, без скачков */
.mapsec-v2-stage svg .city {
  transition: r 0.2s ease, opacity 0.2s ease !important;
  transform-origin: center;
}
.mapsec-v2-stage svg .city.city-active {
  filter: brightness(1.1);
}
/* убираем reveal opacity-fade на детях карты */
.mapsec-v2 .reveal { opacity: 1 !important; }
.mapsec-v2 [data-animate] { opacity: 1 !important; transform: none !important; }
/* === Карта: убираем абсолютно ВСЕ hover-эффекты и transition === */
.mapsec-v2-stage svg .city {
  transition: none !important;
  filter: none !important;
}
.mapsec-v2-stage svg .city:hover {
  filter: none !important;
  transform: none !important;
}
.mapsec-v2-stage svg .city.city-active {
  filter: none !important;
  transform: none !important;
}
.mapsec-v2-stage svg * {
  transition: none !important;
}
/* tooltip полностью отключаем */
#mapTooltip { display: none !important; }


/* === V25: карточки блога — фирменная унификация фото === */
.blog-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid rgba(15, 27, 45, 0.08);
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px -18px rgba(15, 27, 45, 0.24);
  border-color: rgba(82, 147, 224, 0.4);
}
.blog-card-cover {
  height: 200px;
  overflow: hidden;
  position: relative;
  background: #0f1b2d;  /* фон, чтобы при загрузке фото не было белой вспышки */
}
.blog-card-cover img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s ease, filter 0.45s ease;
  /* Слегка приглушаем — фото становятся более «брендовыми», менее пёстрыми */
  filter: saturate(0.85) contrast(1.04) brightness(0.96);
}
.blog-card:hover .blog-card-cover img {
  transform: scale(1.05);
  filter: saturate(1) contrast(1.04) brightness(1);
}
/* Фирменный gradient-overlay — связывает разные фото в единый визуальный язык */
.blog-card-cover::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(15,27,45,0) 45%, rgba(15,27,45,0.55) 100%),
    linear-gradient(135deg, rgba(82,147,224,0.18) 0%, rgba(2,161,197,0.10) 100%);
  pointer-events: none;
  z-index: 1;
  transition: opacity 0.4s ease;
}
.blog-card:hover .blog-card-cover::before { opacity: 0.7; }
/* Бейдж с тегом — поверх фото, в левом верхнем углу. Создаёт общий UI-слой на всех карточках */
.blog-card .blog-card-tag {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  padding: 5px 12px;
  background: rgba(255,255,255,0.94);
  color: var(--brand-blue, #5293e0);
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 2px 8px rgba(15,27,45,0.12);
}
.blog-card-body {
  padding: 18px 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.blog-card-date {
  font-size: 12px;
  color: var(--text-muted, #6b7280);
  font-weight: 500;
  letter-spacing: 0.2px;
  margin-bottom: 2px;
}
.blog-card-title {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--gv-ink, #0f1b2d);
  background: none !important;
  -webkit-text-fill-color: var(--gv-ink, #0f1b2d) !important;
  transition: color 0.25s ease;
}
.blog-card:hover .blog-card-title {
  color: var(--brand-blue, #5293e0);
  -webkit-text-fill-color: var(--brand-blue, #5293e0) !important;
}
.blog-card-desc {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-muted, #6b7280);
}
@media (max-width: 600px) {
  .blog-card-cover { height: 160px; }
  .blog-card-body { padding: 14px 16px 18px; }
  .blog-card-title { font-size: 15.5px; }
  .blog-card-desc { font-size: 13.5px; }
  .blog-card .blog-card-tag { top: 10px; left: 10px; padding: 4px 10px; font-size: 10.5px; }
}
/* /V25 ============================================ */

/* === V26: пометка под app-CTA («приложение vs сайт») === */
.hero-v2-applink-note {
  display: block;
  margin-top: 6px;
  font-size: 11.5px;
  color: var(--text-muted);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0;
}
/* /V26 ============================================ */

/* === V24: статусные сообщения форм (forms.js) === */
.gv-form-status {
  margin-top: 14px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 14px;
  line-height: 1.4;
  border: 1px solid transparent;
}
.gv-form-status--info {
  background: #f0f6ff;
  color: #1e3a5f;
  border-color: #c7daf3;
}
.gv-form-status--success {
  background: #ecfdf5;
  color: #065f46;
  border-color: #a7f3d0;
  font-weight: 600;
}
.gv-form-status--error {
  background: #fef2f2;
  color: #991b1b;
  border-color: #fecaca;
}
/* SmartCaptcha-виджет — отступ сверху */
.smart-captcha {
  margin: 14px 0;
  min-height: 80px;
}
/* Форма подписки в подвале — даём перенос строки для согласия */
.newsletter-form { flex-wrap: wrap !important; }
/* Подпись под формой подписки — на всю ширину строки flex-формы */
.newsletter-consent {
  flex-basis: 100% !important;
  width: 100%;
  order: 99;                /* всегда последний элемент в форме */
  margin: 8px 0 0;
  font-size: 11px;
  color: rgba(255,255,255,0.55);
  line-height: 1.4;
}
.newsletter-consent a {
  color: rgba(255,255,255,0.8);
  text-decoration: underline;
}
.newsletter-consent a:hover {
  color: #fff;
}
/* В .newsletter-row тоже даём перенос — на случай узких десктопов */
.newsletter-row { row-gap: 8px; }
@media (max-width: 720px) {
  .newsletter-consent { font-size: 11.5px; text-align: left; }
}
/* /V24 ============================================ */

/* === V23: подсветка поля калькулятора при клике на город на карте === */
@keyframes gv-city-flash {
  0%   { box-shadow: 0 0 0 0 rgba(255, 139, 61, 0.55); background-color: #fff8f0; }
  60%  { box-shadow: 0 0 0 8px rgba(255, 139, 61, 0.0); background-color: #fff3e6; }
  100% { box-shadow: 0 0 0 0 rgba(255, 139, 61, 0); background-color: ''; }
}
.city-flash {
  animation: gv-city-flash 0.9s ease-out;
  border-color: #FF8B3D !important;
  outline: 2px solid rgba(255, 139, 61, 0.45) !important;
  outline-offset: 1px;
}
/* Курсор-pointer + лёгкая обводка для городов на карте — чтобы было понятно, что они кликабельны */
.mapsec-v2-stage svg .city {
  cursor: pointer;
}
/* /V23 ============================================ */

/* === V27: фикс .cards-grid (отсутствовал в CSS — карточки ехали друг на друга) === */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  align-items: stretch;
}
@media (max-width: 720px) {
  .cards-grid { grid-template-columns: 1fr; gap: 14px; }
}
/* Внутри .cards-grid карточки берут всю ширину колонки */
.cards-grid > .form-card,
.cards-grid > a.form-card {
  margin: 0;
  width: 100%;
  height: auto;
  display: flex;
  flex-direction: column;
  /* мягче padding на узких экранах — иначе с 28px на 320px карточка не помещается */
}
@media (max-width: 480px) {
  .cards-grid > .form-card,
  .cards-grid > a.form-card { padding: 20px !important; }
}
/* /V27 ============================================ */

/* === V28: Глоссарий — компактный карточный grid с категориями === */
.glossary-cats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  align-items: start;
}
.glossary-cat {
  background: #fff;
  border: 1px solid rgba(15, 27, 45, 0.08);
  border-radius: 14px;
  padding: 16px 18px 14px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04), 0 4px 12px rgba(15, 23, 42, 0.04);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.glossary-cat:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px -4px rgba(82, 147, 224, 0.18);
  border-color: rgba(82, 147, 224, 0.25);
}
.glossary-cat-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(15, 27, 45, 0.06);
}
.glossary-cat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 9px;
  flex-shrink: 0;
}
.glossary-cat-icon svg {
  width: 16px;
  height: 16px;
}
.glossary-cat-title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--gv-ink, #0F1B2D);
  background: none !important;
  -webkit-text-fill-color: var(--gv-ink, #0F1B2D) !important;
  letter-spacing: -0.01em;
}
.glossary-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.glossary-list li {
  padding: 7px 0;
  border-top: 1px solid rgba(15, 27, 45, 0.05);
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 10px;
  align-items: baseline;
  font-size: 13px;
  line-height: 1.45;
}
.glossary-list li:first-child { border-top: 0; padding-top: 2px; }
.glossary-list li b {
  color: var(--gv-ink, #0F1B2D);
  font-weight: 700;
  font-size: 12.5px;
  letter-spacing: -0.01em;
}
.glossary-list li span {
  color: var(--text-muted, #6b7280);
  font-size: 12.5px;
}
@media (max-width: 600px) {
  .glossary-cats { grid-template-columns: 1fr; gap: 12px; }
  .glossary-cat { padding: 14px 14px 12px; }
  .glossary-list li {
    grid-template-columns: 1fr;
    gap: 2px;
    padding: 7px 0;
  }
  .glossary-list li b { font-size: 13.5px; }
  .glossary-list li span { font-size: 13px; }
}
/* Карточка «Свежее в 2026» — мягкий золотисто-янтарный акцент */
.glossary-cat.glossary-cat--fresh {
  background: linear-gradient(180deg, #fffbf0 0%, #ffffff 60%);
  border-color: rgba(255, 184, 77, 0.35);
}
.glossary-cat.glossary-cat--fresh:hover {
  border-color: rgba(255, 184, 77, 0.55);
  box-shadow: 0 6px 20px -4px rgba(255, 139, 61, 0.18);
}
.glossary-cat-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.6px;
  color: #c87b00;
  background: linear-gradient(135deg, #fff3d6 0%, #ffe399 100%);
  border-radius: 6px;
  vertical-align: middle;
  position: relative;
  top: -1px;
}
/* /V28 ============================================ */

/* === V29: Глоссарий — CTA на блог о регуляторике === */
.glossary-cta {
  margin-top: 18px;
  padding: 14px 18px;
  background: linear-gradient(135deg, rgba(82,147,224,0.08), rgba(82,147,224,0.02));
  border: 1px solid rgba(82,147,224,0.18);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}
.glossary-cta strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 2px;
}
.glossary-cta p {
  margin: 0;
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.45;
  max-width: 60ch;
}
.glossary-cta .btn {
  flex: 0 0 auto;
}
@media (max-width: 720px) {
  .glossary-cta {
    padding: 14px 14px;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .glossary-cta .btn {
    align-self: stretch;
    text-align: center;
  }
}
/* /V29 ============================================ */

/* === V30: Утилиты для консистентной типографики и отступов === */
/* Заголовок без внешних отступов — для блоков типа card-head, contact-item */
.h-tight { margin: 0 !important; }
/* Пара иконка + заголовок — внутри карточек/секций */
.h-with-icon {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.h-with-icon h2,
.h-with-icon h3,
.h-with-icon h4 { margin: 0; line-height: 1.2; }

/* Цветовые точки для легенд — единые токены */
.dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; vertical-align: middle; margin-right: 6px; }
.dot--brand   { background: var(--brand-blue); }
.dot--accent  { background: var(--accent); }
.dot--cyan    { background: var(--brand-cyan); }
.dot--green   { background: var(--app-green); }
.dot--warn    { background: var(--warning); }
.dot--danger  { background: var(--danger); }

/* Утилитарные отступы — заменяют большую часть inline-style margin */
.mt-0  { margin-top: 0 !important; }
.mt-8  { margin-top: 8px !important; }
.mt-12 { margin-top: 12px !important; }
.mt-16 { margin-top: 16px !important; }
.mt-24 { margin-top: 24px !important; }
.mt-32 { margin-top: 32px !important; }
.mt-48 { margin-top: 48px !important; }
.mb-0  { margin-bottom: 0 !important; }
.mb-8  { margin-bottom: 8px !important; }
.mb-12 { margin-bottom: 12px !important; }
.mb-16 { margin-bottom: 16px !important; }
.mb-24 { margin-bottom: 24px !important; }
.text-center { text-align: center; }
.text-muted-c { color: var(--text-muted); }

/* Page-hero модификаторы (вместо inline-style padding) */
.page-hero--tall   { padding-top: 90px; padding-bottom: 90px; }
.page-hero--center { text-align: center; padding: 80px 0 40px; }

/* Карточка-ссылка (form-card как <a>) — без подчёркивания и наследования цвета */
a.form-card { text-decoration: none; color: inherit; }
a.form-card:hover { color: inherit; }

/* Шапка карточки: иконка-плитка + заголовок (унифицированная замена inline-style) */
.card-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.card-head h3 { margin: 0; font-size: 17px; line-height: 1.25; }
/* /V30 ============================================ */

/* === V31: Канонический .feature-card — перекрывает 17 предыдущих деклараций ===
   Цель: одинаковый вид карточек на всех страницах сайта.
   Этот блок последний в файле — побеждает все прежние правила через каскад.
   Перекрывается только локально-скоупными правилами вида .b2b-hero-section .feature-card. */
.feature-card {
  background: #fff !important;
  border: 1px solid rgba(15, 27, 45, 0.08) !important;
  border-radius: 16px !important;
  padding: 22px 24px !important;
  box-shadow: 0 1px 3px rgba(13, 20, 38, 0.04), 0 8px 24px -12px rgba(82, 147, 224, 0.10) !important;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease !important;
  position: relative;
  overflow: hidden;
}
.feature-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 1px 3px rgba(13, 20, 38, 0.05), 0 16px 36px -12px rgba(82, 147, 224, 0.18) !important;
  border-color: rgba(82, 147, 224, 0.22) !important;
}
.feature-card h3,
.feature-card h4 {
  margin: 0 0 8px !important;
  color: var(--gv-ink, #0F1B2D);
  font-size: 17px;
  line-height: 1.3;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.feature-card p {
  margin: 0 !important;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-muted);
}
.feature-card .feature-icon {
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  background: rgba(82, 147, 224, 0.10);
  display: grid;
  place-items: center;
  color: var(--brand-blue);
  margin-bottom: 14px !important;
  flex-shrink: 0;
}
.feature-card .feature-icon svg {
  width: 24px !important;
  height: 24px !important;
}
@media (max-width: 600px) {
  .feature-card { padding: 18px 18px !important; }
  .feature-card h3, .feature-card h4 { font-size: 16px; }
  .feature-card p { font-size: 14px; }
}
/* /V31 ============================================ */

/* === V32: Премиальный hero — стиль БЕЗ увеличения размеров =================
   Принцип: меняем ВЫРАЗИТЕЛЬНОСТЬ (вес, цвет акцента, ширина markup)
   но НЕ ТРОГАЕМ font-size / letter-spacing / line-height / padding hero-блока.
   Размер фото грузовика = тот же right 30% center / 70% auto. */

/* 1. Лёгкий градиент поверх грузовика — фото видно, текст читается */
.hero-v2 .hero-truck-bg {
  background:
    linear-gradient(
      100deg,
      rgba(14, 28, 56, 0.55) 0%,
      rgba(14, 28, 56, 0.30) 35%,
      rgba(14, 28, 56, 0.10) 65%,
      rgba(14, 28, 56, 0)    100%
    ) !important,
    url('../img/hero-truck.jpg') no-repeat right 30% center / 70% auto !important;

  background:
    linear-gradient(
      100deg,
      rgba(14, 28, 56, 0.55) 0%,
      rgba(14, 28, 56, 0.30) 35%,
      rgba(14, 28, 56, 0.10) 65%,
      rgba(14, 28, 56, 0)    100%
    ) !important,
    image-set(url('../img/hero-truck.webp') type('image/webp'), url('../img/hero-truck.jpg') type('image/jpeg')) no-repeat right 30% center / 70% auto !important;
}

/* 2. H1 премиум — тоньше вес и читаемая тень. БЕЗ изменения size/letter-spacing/line-height */
.hero-v2 .hero-v2-title,
.hero-v2 h1 {
  font-weight: 750 !important;       /* было 800 — премиум-feel, без увеличения */
  font-feature-settings: "tnum" on, "lnum" on;
  color: #fff !important;
  text-shadow: 0 1px 2px rgba(13,20,38,0.30), 0 4px 24px rgba(13,20,38,0.40);
}

/* 3. Italic-акцент — мягкое золото поверх синего фото = премиум-сигнал */
.hero-v2 .hero-v2-title em,
.hero-v2 h1 em {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic;
  font-weight: 500 !important;
  color: #ffd84d !important;
  -webkit-text-fill-color: #ffd84d !important;
  background: none !important;
}

/* 4. Лид — мягкий тёплый белый, без размеров */
.hero-v2 .hero-v2-lede {
  color: rgba(255, 255, 255, 0.86) !important;
  text-shadow: 0 1px 2px rgba(13,20,38,0.20);
}

/* 5. Trust-row — тонкие точки-разделители вместо ярких */
.hero-v2 .hero-v2-trust .dot {
  background: none !important;
  color: rgba(255, 255, 255, 0.30) !important;
}
/* /V32 ============================================ */

/* === V33: Премиальная типографика на ВНУТРЕННИХ страницах БЕЗ увеличений ===
   Принцип: тоньше вес, лучше italic-акцент, без увеличения размеров. */

/* 1. Internal page hero — тоньше H1 */
.page-hero h1,
.page-hero .h1-title {
  font-weight: 750 !important;
  font-feature-settings: "tnum" on, "lnum" on;
}
.page-hero h1 em {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic;
  font-weight: 500 !important;
}

/* 2. Section-title — тоньше вес и italic-em через Fraunces */
.section-title {
  font-weight: 750 !important;
  font-feature-settings: "tnum" on, "lnum" on;
}
.section-title em {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic;
  font-weight: 500 !important;
}

/* 3. Хлебные крошки — тоньше bg, hover на брендовый */
.breadcrumbs a:hover { color: var(--brand-blue) !important; }

/* 4. Кнопки — единый радиус, БЕЗ изменения padding */
.btn-primary {
  font-weight: 600 !important;
  border-radius: 12px !important;
}
.btn-outline {
  border-width: 1.5px !important;
  font-weight: 500 !important;
  border-radius: 12px !important;
}
/* /V33 ============================================ */

/* === V34: Секция «Дополнительные услуги» — 5 карточек в одну строку ====== */
/* Раньше сетка была auto-fit 4+1 (одна карточка одиноко на втором ряду).
   Делаем строго 5 колонок на широком десктопе, 3+пара по центру на среднем,
   2 на планшете, 1 на мобильном. */
#extras .features-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(5, 1fr);
  align-items: stretch;
}
@media (max-width: 1200px) {
  #extras .features-grid {
    grid-template-columns: repeat(3, 1fr);
    max-width: 920px;
    margin: 0 auto;
  }
  /* Последние 2 карточки центрируются на втором ряду */
  #extras .features-grid > .feature-card:nth-child(4) { grid-column: 1 / 2; justify-self: center; width: 100%; }
  #extras .features-grid > .feature-card:nth-child(5) { grid-column: 2 / 3; justify-self: center; width: 100%; }
  /* Сместим пару последних в центр, оставив пустую первую колонку */
  #extras .features-grid > .feature-card:nth-child(4) { grid-column: 1 / 2; }
  #extras .features-grid > .feature-card:nth-child(5) { grid-column: 2 / 3; }
}
@media (max-width: 900px) {
  #extras .features-grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 640px;
  }
  #extras .features-grid > .feature-card:nth-child(4),
  #extras .features-grid > .feature-card:nth-child(5) { grid-column: auto; }
  /* Последняя 5-я карточка одна — центрируем */
  #extras .features-grid > .feature-card:nth-child(5) {
    grid-column: 1 / -1;
    max-width: 320px;
    justify-self: center;
  }
}
@media (max-width: 540px) {
  #extras .features-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  #extras .features-grid > .feature-card:nth-child(5) {
    grid-column: auto;
    max-width: none;
  }
}
/* /V34 ============================================ */

/* === V35: Финальная гармонизация — убираем inline-styles на CTA-блоках === */

/* Модификатор для кнопок на тёмном фоне (B2B CTA, hero на тёмной заливке) */
.btn--on-dark.btn-primary {
  background: #fff !important;
  color: var(--brand-blue-deep, #1e4d8f) !important;
  border-color: #fff !important;
}
.btn--on-dark.btn-primary:hover {
  background: rgba(255, 255, 255, 0.92) !important;
  color: var(--brand-blue, #5293e0) !important;
}
.btn--on-dark.btn-outline {
  background: transparent !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.55) !important;
}
.btn--on-dark.btn-outline:hover {
  background: rgba(255, 255, 255, 0.10) !important;
  border-color: #fff !important;
  color: #fff !important;
}

/* H2 на тёмной секции (CTA-блок «Корпоративный аккаунт») */
.section--dark h2,
.section--dark h3,
.section--dark p {
  color: #fff !important;
}
.section--dark .section-subtitle,
.section--dark p:not(.section-title) {
  color: rgba(255, 255, 255, 0.86) !important;
}
.section--dark em {
  color: #ffd84d !important;
  -webkit-text-fill-color: #ffd84d !important;
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic;
  font-weight: 500 !important;
}

/* H4 без отступов сверху-снизу (для inline-style замены в hero/screen-mock) */
.h4--tight {
  margin: 0 !important;
}

/* Eyebrow на тёмном фоне */
.eyebrow--on-dark {
  background: rgba(255, 255, 255, 0.14) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
}

/* B2B CTA карточка-блок (была inline-style div в for-clients.html) */
.b2b-cta-card {
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-cyan) 100%);
  color: #fff;
  border-radius: 24px;
  padding: 40px 32px;
  text-align: center;
  margin-top: 48px;
  position: relative;
  z-index: 2;
}
.b2b-cta-card h3 {
  color: #fff;
  margin: 0 0 12px;
  font-size: clamp(22px, 2vw, 26px);
  font-weight: 700;
}
.b2b-cta-card p {
  color: rgba(255, 255, 255, 0.92);
  margin: 0 auto 24px;
  max-width: 560px;
  line-height: 1.55;
}
.b2b-cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}
@media (max-width: 540px) {
  .b2b-cta-card { padding: 30px 20px; border-radius: 20px; }
  .b2b-cta-actions .btn { width: 100%; }
}

/* Page-hero модификаторы (вместо inline-style padding на track/thanks) */
.page-hero.page-hero--tall {
  padding-top: 90px !important;
  padding-bottom: 90px !important;
}
.page-hero.page-hero--center {
  text-align: center !important;
  padding: 80px 0 40px !important;
}
.page-hero.page-hero--center .container,
.page-hero.page-hero--tall .container { text-align: inherit; }

/* Утилита text-center (если ещё нет) */
.text-center { text-align: center; }

/* /V35 ============================================ */

/* === V36: Документы (#docs) — 4 карточки в одну строку, без сирот ======== */
/* На about.html в секции "Юридическая прозрачность" 4 карточки. На auto-fit
   minmax(280px) на узком container-narrow выходит 3+1 — последняя сирота.
   Принудительно: 4 в ряд на десктопе, 2×2 на планшете, 1 на мобильном. */
@media (min-width: 980px) {
    #docs .docs-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }
    /* Чуть компактнее padding и иконка, чтобы 4 в ряд не сплющивались */
    #docs .doc-card {
        padding: 14px !important;
        gap: 10px !important;
    }
    #docs .doc-card strong { font-size: .94rem; }
    #docs .doc-card span { font-size: .78rem; line-height: 1.3; }
    #docs .doc-icon { width: 36px !important; height: 36px !important; }
    #docs .doc-icon svg { width: 18px; height: 18px; }
}
@media (min-width: 640px) and (max-width: 979px) {
    #docs .docs-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}
@media (max-width: 639px) {
    #docs .docs-grid {
        grid-template-columns: 1fr !important;
    }
}
/* /V36 ============================================ */

/* === V37: Live-feed «Машины в пути» — анимации обновлений ================ */
/* Лёгкая зелёная подсветка при обновлении карточки (ETA -1 мин, смена статуса) */
.live-feed-item.live-flash {
    animation: live-flash-anim 1.2s ease-out;
}
@keyframes live-flash-anim {
    0%   { background: #fff; box-shadow: 0 0 0 0 rgba(74, 222, 128, 0); }
    20%  { background: #f0fdf4; box-shadow: 0 0 0 4px rgba(74, 222, 128, .18); }
    100% { background: #fff; box-shadow: 0 0 0 0 rgba(74, 222, 128, 0); }
}

/* Замена карточки: плавный fade-out / fade-in */
.live-feed-item.live-fade-out {
    opacity: 0;
    transform: translateY(-6px) scale(.98);
    transition: opacity .35s ease, transform .35s ease;
}
.live-feed-item.live-fade-in {
    animation: live-fade-in-anim .55s cubic-bezier(.16, 1, .3, 1);
}
@keyframes live-fade-in-anim {
    from { opacity: 0; transform: translateY(8px) scale(.98); }
    to   { opacity: 1; transform: none; }
}

/* Пульс-анимация счётчика заказов */
#liveOrdersToday {
    display: inline-block;
    transition: color .2s ease;
}
#liveOrdersToday.live-tick {
    animation: live-tick-anim .6s ease-out;
}
@keyframes live-tick-anim {
    0%   { transform: translateY(0); color: var(--gv-ink); }
    30%  { transform: translateY(-3px); color: #16a34a; }
    100% { transform: translateY(0); color: var(--gv-ink); }
}

/* Точка "live" — пульсирующий зелёный (если ещё нет) */
.live-feed-meta .live-dot,
.live-feed-eyebrow .live-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #22c55e;
    display: inline-block;
    margin-right: 8px;
    box-shadow: 0 0 0 0 rgba(34, 197, 94, .55);
    animation: live-dot-pulse 2s ease-out infinite;
    flex-shrink: 0;
    vertical-align: middle;
}
@keyframes live-dot-pulse {
    0%   { box-shadow: 0 0 0 0 rgba(34, 197, 94, .55); }
    70%  { box-shadow: 0 0 0 8px rgba(34, 197, 94, 0); }
    100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0); }
}

@media (prefers-reduced-motion: reduce) {
    .live-feed-item.live-flash,
    .live-feed-item.live-fade-in,
    #liveOrdersToday.live-tick,
    .live-feed-meta .live-dot,
    .live-feed-eyebrow .live-dot { animation: none !important; }
}
/* /V37 ============================================ */

/* === V38: AI-чат-fab не должен накладываться на sticky-cta-bar ============ */
/* Когда sticky-cta видна — поднимаем чат-fab и support-fab над ней,
   плюс резервируем место справа в самой полосе чтобы не накрывало кнопку. */
body.has-sticky-cta-visible .ai-chat-fab,
body.has-sticky-cta-visible .support-fab {
    bottom: 88px !important;
    transition: bottom .3s cubic-bezier(.16, 1, .3, 1);
}

/* На совсем узких экранах sticky-cta уже скрыт (V25), но на случай если
   что-то пойдёт не так — на мобильном чат всегда в правом нижнем углу,
   sticky-cta не показываем */
@media (max-width: 720px) {
    body.has-sticky-cta-visible .ai-chat-fab,
    body.has-sticky-cta-visible .support-fab {
        bottom: 16px !important;
    }
    .sticky-cta { display: none !important; }
}

/* На планшетах (721-900px), где sticky-cta показывается, оставляем
   справа запас чтобы кнопка «Заказать перевозку» не уезжала под чат-fab */
@media (min-width: 721px) and (max-width: 900px) {
    .sticky-cta { padding-right: 84px !important; }
}
/* /V38 ============================================ */

/* === V39: View Transitions API — ОТКЛЮЧЕНО ===== */
/* Анимация переходов между страницами вызывала проморгивание и казалась
   некрасивой. Без `<meta name="view-transition">` в HTML — этот блок
   не активен и оставлен для возможного будущего возврата. */
/*
@view-transition {
    navigation: auto;
}*/

/* Плавный fade-через-вверх для всей страницы */
::view-transition-old(root) {
    animation: vt-fade-out 220ms cubic-bezier(.4, 0, 1, 1) forwards;
}
::view-transition-new(root) {
    animation: vt-fade-in 280ms cubic-bezier(0, 0, .2, 1) forwards;
}

@keyframes vt-fade-out {
    from { opacity: 1; transform: translateY(0); }
    to   { opacity: 0; transform: translateY(-8px); }
}
@keyframes vt-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Шапка и футер — не мигают (общие элементы).
   ВАЖНО: view-transition-name должен быть УНИКАЛЬНЫМ для каждого элемента,
   иначе API падает с InvalidStateError. */
.site-header { view-transition-name: shared-header; }
.site-footer { view-transition-name: shared-footer; }
::view-transition-old(shared-header),
::view-transition-new(shared-header),
::view-transition-old(shared-footer),
::view-transition-new(shared-footer) {
    animation: none;
}

/* Для пользователей с prefers-reduced-motion — без анимаций */
@media (prefers-reduced-motion: reduce) {
    ::view-transition-old(root),
    ::view-transition-new(root) {
        animation: none !important;
    }
}
/* /V39 ============================================ */

