:root {
  --bg: #F4F5F7;
  --bg-alt: #FFFFFF;
  --bg-dark: #3C4A5C;
  --bg-dark-soft: #4A5A6E;
  --accent: #2FAE9B;
  --accent-warm: #F6B23C;
  --warning: #E26D3D;
  --text: #1F242B;
  --text-secondary: #7B8190;
  --border: #E5E7EB;
  --border-soft: #ECEEF1;
  --white: #FFFFFF;

  --font-body: 'Onest', system-ui, -apple-system, sans-serif;
  --font-display: 'Unbounded', 'Onest', system-ui, sans-serif;

  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-pill: 999px;

  --shadow-card: 0 1px 2px rgba(31, 36, 43, 0.04);
  --shadow-hover: 0 4px 16px rgba(31, 36, 43, 0.06);

  --transition: 0.2s ease;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 80px; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg { display: block; max-width: 100%; }

a { color: inherit; text-decoration: none; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

h1, h2, h3, h4 { margin: 0; line-height: 1.15; letter-spacing: -0.01em; }

p, ul, ol { margin: 0; }

ul, ol { padding: 0; list-style: none; }

.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.container--narrow { max-width: 820px; }

.section { padding: 56px 0; }

.section--alt { background: var(--bg-alt); }

.section__title {
  font-family: var(--font-display);
  font-size: clamp(32px, 4.5vw, 48px);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: 32px;
}

.section__title--centered { text-align: left; }

.section__subtitle {
  font-size: 19px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin-bottom: 40px;
  max-width: 720px;
}

.section__subtitle strong { color: var(--text); }

.topbar {
  background: var(--bg);
  border-bottom: 1px solid var(--border-soft);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: saturate(140%) blur(8px);
  background-color: rgba(244, 245, 247, 0.92);
}

.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}

.logo {
  display: inline-flex;
  align-items: center;
  gap: 1px;
  font-family: var(--font-display);
  font-weight: 800;
  font-style: italic;
  font-size: 22px;
  letter-spacing: -0.04em;
  color: var(--text);
  line-height: 1;
}

.logo__bolt {
  display: inline-flex;
  width: 0.65em;
  height: 1em;
  color: var(--accent-warm);
  transform: skewX(-12deg) translateY(2px);
}

.logo__bolt svg { width: 100%; height: 100%; }

.topbar__brand {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  line-height: 1;
}

.topbar__tagline {
  display: none;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  line-height: 1.2;
  white-space: nowrap;
  letter-spacing: 0;
}

@media (min-width: 480px) { .topbar__tagline { display: inline-block; } }

.topbar__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.topbar__contact {
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-end;
  gap: 2px;
  line-height: 1.2;
}

.topbar__hours {
  font-size: 11px;
  color: var(--text-secondary);
  white-space: nowrap;
  line-height: 1;
}

/* На самых узких экранах (≤359px, iPhone SE 1-го поколения и т.п.)
   текст «Ежедневно с 8:00 до 20:00» вплотную упирается в логотип.
   Прячем, чтобы шапка не «слипалась». График всё равно есть в §7 и в FAQ. */
@media (max-width: 359px) {
  .topbar__hours { display: none; }
}

@media (min-width: 768px) {
  .topbar__contact { flex-direction: row; align-items: center; gap: 12px; }
  .topbar__hours { font-size: 12px; }
}

.topbar__phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 15px;
  color: var(--text);
  padding: 8px 12px;
  border-radius: var(--r-pill);
  transition: background var(--transition);
}

.topbar__phone span { display: none; }

.topbar__phone:hover { background: var(--border-soft); }

.topbar__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  background: var(--accent-warm);
  color: var(--white);
  font-weight: 700;
  font-size: 14px;
  border-radius: var(--r-pill);
  transition: background var(--transition), transform var(--transition);
  white-space: nowrap;
}

.topbar__cta:hover { background: #E8A22C; }
.topbar__cta:active { transform: translateY(1px); }

@media (min-width: 480px) {
  .topbar__phone span { display: inline; }
}

@media (min-width: 768px) {
  .topbar__actions { gap: 12px; }
  .topbar__cta { padding: 11px 20px; font-size: 15px; }
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 24px;
  border-radius: var(--r-md);
  font-family: inherit;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.2;
  color: var(--white);
  transition: transform var(--transition), background var(--transition);
  text-align: center;
  white-space: nowrap;
}

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

.btn--alarm { background: var(--warning); }
.btn--alarm:hover { background: #D55C2D; }

.btn--form { background: var(--accent-warm); }
.btn--form:hover { background: #E8A22C; }

.btn--wide { width: 100%; }

.btn__icon { display: inline-flex; }

.cta-group {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 16px;
}

.cta-group > .reaction-line { justify-self: start; }

.cta-group--centered { display: flex; flex-direction: column; align-items: flex-start; }

@media (min-width: 600px) {
  .cta-group { grid-template-columns: auto auto; align-items: start; justify-content: start; gap: 14px 16px; }
  .cta-group > .reaction-line { grid-column: 1 / -1; margin-top: -2px; }
  .cta-group--centered { flex-direction: row; justify-content: flex-start; flex-wrap: wrap; }
  .btn { padding: 18px 28px; }
}

.hero { padding: 18px 0 0; }

.hero__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding-bottom: 24px;
}

.hero__title {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
  color: var(--text);
}

.hero__title-main {
  font-family: var(--font-display);
  font-size: clamp(28px, 6vw, 52px);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.08;
}

.hero__title-icon {
  display: inline-flex;
  align-items: center;
  vertical-align: -0.2em;
  width: 1.2em;
  height: 1em;
  margin-left: 0.2em;
  color: var(--text);
}

.hero__title-icon svg { width: 100%; height: 100%; display: block; }

.hero__title-sub {
  font-family: var(--font-body);
  font-size: clamp(20px, 2.6vw, 26px);
  font-weight: 400;
  letter-spacing: -0.005em;
  line-height: 1.35;
  color: var(--text-secondary);
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 28px;
}

/* На современных мобильных (всё, что выше iPhone SE 2/3 по высоте) усиливаем
   воздух между «симптомами» (чипы) и УТП-блоком — Коля просил визуально
   развести эти смыслы. iPhone SE 2/3 (667px) остаётся на 28px, иначе кнопки
   уплывают за первый экран (запас был всего 3px). */
@media (min-height: 700px) {
  .chips { margin-bottom: 52px; }
}

@media (min-width: 768px) {
  .chips { margin-bottom: 56px; }
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px 7px 14px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.chip::after {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-right: 1.5px solid var(--text-secondary);
  border-bottom: 1.5px solid var(--text-secondary);
  transform: rotate(45deg);
  opacity: 0.55;
  margin-top: -2px;
  transition: opacity var(--transition), transform var(--transition);
}

.chip:hover {
  background: var(--bg);
  border-color: var(--text-secondary);
  color: var(--text);
}

.chip:hover::after {
  opacity: 1;
  transform: rotate(45deg) translate(1px, 1px);
}

.hero__subtitle {
  font-size: 17px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin-bottom: 18px;
  max-width: 560px;
}

.reaction-line {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  color: var(--text);
  margin: 0;
  line-height: 1.4;
}

.reaction-line__text { flex: 1; min-width: 0; }

.reaction-line strong { color: var(--text); font-weight: 700; }

.reaction-line__sep {
  display: inline-flex;
  align-items: center;
  font-size: 0;
  color: transparent;
  margin: 0 6px;
  vertical-align: middle;
}

.reaction-line__sep::before {
  content: '';
  width: 5px;
  height: 5px;
  background: var(--text-secondary);
  border-radius: 50%;
  flex-shrink: 0;
}

.reaction-line__dot {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(47, 174, 155, 0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.reaction-line__dot::before {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.2); }
}

.master-card {
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  box-shadow: var(--shadow-card);
}

.master-card__photo {
  width: 100%;
  max-width: 280px;
  aspect-ratio: 3 / 4;
  background: var(--bg);
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: 16px;
}

.master-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.master-card__name {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 4px;
}

.master-card__role {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 16px;
}

.badges {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  text-align: left;
}

.badge {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: var(--bg);
  border-radius: var(--r-sm);
  font-size: 13px;
  line-height: 1.4;
}

.badge__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(60, 74, 92, 0.08);
  color: var(--bg-dark);
}

.trust-strip {
  background: var(--bg-dark);
  color: var(--white);
  padding: 24px 0;
}

.trust-strip__inner {
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: center;
  max-width: none;
}

.trust-strip__reviews { font-size: 15px; }
.trust-strip__reviews strong { color: var(--accent-warm); }
.trust-strip__cities {
  font-size: clamp(15px, 1.4vw, 18px);
  color: var(--white);
  font-weight: 500;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .hero { padding: 56px 0 0; }
  .hero__inner {
    grid-template-columns: 1fr 360px;
    gap: 48px;
    padding-bottom: 56px;
  }
  .master-card { position: sticky; top: 88px; }
  .trust-strip__inner { justify-content: center; gap: 24px; }
}

@media (min-width: 1024px) {
  .section { padding: 80px 0; }
  .hero { padding: 80px 0 0; }
  .hero__inner { grid-template-columns: 1fr 420px; gap: 80px; padding-bottom: 96px; }
  .hero__title-main { font-size: clamp(36px, 4.2vw, 56px); }
  .hero__title-sub { font-size: clamp(22px, 2vw, 30px); }
}

.price-anchor {
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 32px 24px;
  text-align: left;
  margin-bottom: 32px;
  border: 1px solid var(--border-soft);
}

.price-anchor__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 4vw, 32px);
  font-weight: 700;
  margin-bottom: 16px;
  color: var(--text);
}

.price-anchor__amount {
  display: block;
  width: fit-content;
  margin: 14px 0 0;
  color: var(--text);
  padding: 6px 14px;
  background: rgba(60, 74, 92, 0.06);
  border-radius: var(--r-sm);
  white-space: nowrap;
  font-weight: 800;
}

.price-anchor__title sup {
  font-size: 0.4em;
  vertical-align: super;
  color: var(--text-secondary);
  font-weight: 500;
}

.price-anchor__body {
  font-size: 16px;
  color: var(--text-secondary);
  max-width: 720px;
  margin: 0 0 12px;
  text-align: left;
}

.price-anchor__footnote {
  font-size: 13px;
  color: var(--text-secondary);
  font-style: italic;
}

.cases__intro {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.8vw, 26px);
  font-weight: 700;
  margin-bottom: 24px;
  text-align: left;
  max-width: 820px;
}

.cases-grid {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 20px 20px;
  margin: 0 -20px 24px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.cases-grid::-webkit-scrollbar { display: none; }

.cases-grid .case-card {
  flex: 0 0 86%;
  scroll-snap-align: start;
}

@media (min-width: 640px) {
  .cases-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    overflow-x: visible;
    padding: 0;
    margin: 0 0 48px;
    scroll-snap-type: none;
  }
  .cases-grid .case-card { flex: initial; }
}

@media (min-width: 1024px) {
  .cases-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; }
}

.case-card {
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  border: 1px solid var(--border-soft);
  scroll-margin-top: 88px;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.case-card:hover { border-color: var(--border); }

.case-card:target {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 174, 155, 0.2);
}

.case-card__head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.case-card__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(60, 74, 92, 0.06);
  color: var(--bg-dark);
}

.case-card__icon--runaway {
  background: rgba(60, 74, 92, 0.06);
  color: var(--bg-dark);
}

.case-card__title {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.25;
  padding-top: 6px;
}

.case-card__desc {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.case-card__price {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 14px 42px 14px 16px;
  background: var(--bg);
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  margin-top: auto;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  width: 100%;
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
}

.case-card__price::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 16px;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--accent-warm);
  border-right: 2px solid var(--accent-warm);
  transform: translateY(-50%) rotate(45deg);
  opacity: 0.6;
  transition: opacity var(--transition), right var(--transition);
}

.case-card__price:hover {
  background: rgba(246, 178, 60, 0.1);
  border-color: rgba(246, 178, 60, 0.4);
}

.case-card__price:hover::after {
  opacity: 1;
  right: 12px;
}

.case-card__price:focus-visible {
  outline: 2px solid var(--accent-warm);
  outline-offset: 2px;
}

.case-card__price-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.case-card__price strong { font-size: 22px; color: var(--text); font-weight: 800; font-family: var(--font-display); letter-spacing: -0.02em; }

.case-card__price--range strong { font-size: 19px; }

.case-card__price-hint {
  display: block;
  font-size: 12px;
  color: var(--text-secondary);
  font-style: italic;
  margin-top: 4px;
}

.case-card--runaway {
  background: #FBF8F4;
  border-color: rgba(226, 109, 61, 0.2);
}

.runaway-divider {
  text-align: left;
  padding: 24px 0 8px;
  margin: 8px 0 16px;
  position: relative;
}

.runaway-divider::before,
.runaway-divider::after {
  content: '';
  display: block;
  height: 1px;
  background: var(--border);
  max-width: 200px;
  margin: 0;
}

.runaway-divider::before { margin-bottom: 16px; }
.runaway-divider::after { margin-top: 16px; }

.runaway-divider__title {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.8vw, 24px);
  font-weight: 700;
  color: var(--warning);
  letter-spacing: -0.01em;
}

.mid-cta {
  background: var(--bg-dark);
  color: var(--white);
  border-radius: var(--r-lg);
  padding: 32px 24px;
  text-align: left;
  margin-top: 16px;
}

.mid-cta__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 3.5vw, 30px);
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--white);
}

.mid-cta__body {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 24px;
  max-width: 600px;
}

.logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  font-family: Arial, system-ui, sans-serif;
  font-weight: 900;
  font-size: 13px;
  color: var(--white);
  flex-shrink: 0;
  line-height: 1;
}

.logo-mark--yandex { background: #FC3F1D; }
.logo-mark--google { background: #4285F4; }
.logo-mark--avito { background: #00BFA5; }

.platforms {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 32px;
}

.platforms__item a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--bg);
  border-radius: var(--r-md);
  border: 1px solid var(--border-soft);
  transition: border-color var(--transition), background var(--transition);
  min-width: 180px;
}

.platforms__item a:hover { border-color: var(--accent); background: var(--white); }

.platforms__item .logo-mark { width: 32px; height: 32px; border-radius: 8px; font-size: 17px; }

.platforms__info { display: flex; flex-direction: column; gap: 2px; }

.platforms__name { font-size: 15px; color: var(--text); font-weight: 700; line-height: 1.2; }

.platforms__meta { font-size: 13px; color: var(--text-secondary); }

.platforms__rating { color: var(--accent-warm); font-weight: 700; }

.platforms__count::before {
  content: '·';
  margin: 0 5px 0 3px;
  color: var(--text-secondary);
}

@media (max-width: 639px) {
  .platforms {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 24px;
  }
  .platforms__item { min-width: 0; }
  .platforms__item a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    min-width: 0;
    border-radius: var(--r-md);
    justify-content: flex-start;
  }
  .platforms__item .logo-mark {
    width: 26px;
    height: 26px;
    font-size: 13px;
    border-radius: 6px;
  }
  .platforms__info {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    min-width: 0;
  }
  .platforms__name {
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
  }
  .platforms__rating { display: none; }
  .platforms__meta { font-size: 12px; color: var(--text-secondary); line-height: 1.2; }
  .platforms__count::before { content: ''; margin: 0; }
}

.reviews-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 24px;
}

.filter-chip {
  padding: 8px 16px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  white-space: nowrap;
}

.filter-chip:hover { background: var(--bg); }

.filter-chip.is-active {
  background: var(--bg-dark);
  border-color: var(--bg-dark);
  color: var(--white);
}

.masonry {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 20px 10px;
  margin: 0 -20px 16px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  align-items: flex-start;
}

.masonry::-webkit-scrollbar { display: none; }

@media (min-width: 640px) {
  .masonry {
    display: block;
    columns: 2;
    column-gap: 20px;
    overflow-x: visible;
    padding: 0;
    margin: 0 0 32px;
    scroll-snap-type: none;
  }
}

@media (min-width: 1024px) { .masonry { columns: 3; column-gap: 20px; } }

.quote {
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 24px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 1px solid var(--border-soft);
  width: 100%;
}

.masonry .quote {
  flex: 0 0 86%;
  scroll-snap-align: start;
  margin: 0;
}

@media (min-width: 640px) {
  .masonry .quote {
    flex: initial;
    margin: 0 0 16px;
    break-inside: avoid;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
  }
}

.quote[hidden] { display: none; }

.hl {
  background: transparent;
  color: inherit;
  font-weight: inherit;
}

.masonry[data-active="speed"]      .hl[data-theme~="speed"],
.masonry[data-active="expert"]     .hl[data-theme~="expert"],
.masonry[data-active="explained"]  .hl[data-theme~="explained"],
.masonry[data-active="rescue"]     .hl[data-theme~="rescue"],
.masonry[data-active="no-upsell"]  .hl[data-theme~="no-upsell"],
.masonry[data-active="price"]      .hl[data-theme~="price"] {
  font-weight: 700;
  color: var(--text);
}

.quote__text {
  font-size: 16px;
  line-height: 1.55;
  color: var(--text);
  position: relative;
}

.quote__meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-style: normal;
  padding-top: 12px;
  border-top: 1px dashed var(--border);
  margin-top: auto;
}

.quote__author { font-weight: 700; font-size: 14px; color: var(--text); }

.quote__source {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-secondary);
  flex-wrap: wrap;
}

.quote__rating {
  color: var(--accent-warm);
  font-size: 12px;
  letter-spacing: 1.5px;
  line-height: 1;
}

.quote__date { color: var(--text-secondary); font-variant-numeric: tabular-nums; }

.master-card__docs {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding: 8px 0;
  background: transparent;
  border: none;
  border-top: 1px dashed var(--border);
  width: 100%;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  text-align: left;
  justify-content: flex-start;
  padding-top: 14px;
  transition: color var(--transition), gap var(--transition);
}

.master-card__docs:hover {
  color: var(--text);
  gap: 10px;
}

.master-card__docs:focus-visible {
  outline: 2px solid var(--text-secondary);
  outline-offset: 2px;
  border-radius: 4px;
}

.master-card__docs-icon { display: inline-flex; color: var(--text-secondary); }
.master-card__docs:hover .master-card__docs-icon { color: var(--text); }

.master-card__docs-arrow {
  margin-left: auto;
  font-size: 16px;
  line-height: 1;
  transition: transform var(--transition);
}

.master-card__docs:hover .master-card__docs-arrow { transform: translateX(2px); }

.lead-dialog {
  border: none;
  border-radius: var(--r-lg);
  padding: 24px 22px 22px;
  max-width: 460px;
  width: 94vw;
  max-height: 96vh;
  background: var(--white);
  overflow: auto;
  margin: auto;
  inset: 0;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
}

.lead-dialog::backdrop {
  background: rgba(31, 36, 43, 0.72);
  backdrop-filter: blur(2px);
}

.lead-dialog__close {
  position: absolute;
  top: 10px;
  right: 12px;
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--transition);
  z-index: 2;
}

.lead-dialog__close:hover { color: var(--text); }

.lead-dialog__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 18px;
  color: var(--text);
  padding-right: 36px;
  line-height: 1.15;
}

.lead-form.lead-form--dialog {
  padding: 0;
  background: transparent;
  gap: 12px;
}

.lead-form__prefill-hint {
  margin: 6px 0 0;
  padding: 0 2px;
  font-size: 12px;
  line-height: 1.4;
  color: var(--text-secondary);
}

.lead-form__prefill-hint[hidden] { display: none; }

.lead-form--dialog .lead-form__field { gap: 4px; }

.lead-form--dialog .lead-form__label {
  font-size: 14px;
  font-weight: 600;
}

.lead-form--dialog .lead-form__hint-inline { font-size: 12px; }

.lead-form--dialog .lead-form__input {
  padding: 11px 14px;
  font-size: 15px;
  border-radius: var(--r-sm);
}

.lead-form--dialog .lead-form__input--textarea { min-height: 56px; }

.lead-form--dialog .file-upload-area {
  padding: 10px 12px;
  gap: 6px;
  border-radius: var(--r-sm);
}

.lead-form--dialog .file-upload {
  padding: 7px 14px;
  font-size: 13px;
}

.lead-form--dialog .lead-form__hint {
  font-size: 12px;
  line-height: 1.4;
}

.lead-form--dialog button[type="submit"] {
  padding: 14px 22px;
  font-size: 15px;
  margin-top: 4px;
}

.lead-form--dialog .lead-form__badge {
  font-size: 12px;
  padding: 5px 12px;
  margin: 2px 0 0;
}

.lightbox {
  border: none;
  padding: 0;
  background: transparent;
  max-width: 96vw;
  max-height: 96vh;
  margin: auto;
  inset: 0;
  overflow: visible;
}

.lightbox::backdrop {
  background: rgba(31, 36, 43, 0.9);
  backdrop-filter: blur(2px);
}

.lightbox__stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

.lightbox__image {
  display: block;
  max-width: 92vw;
  max-height: 76vh;
  width: auto;
  height: auto;
  border-radius: var(--r-md);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
}

.lightbox__caption {
  color: rgba(255, 255, 255, 0.85);
  font-size: 14px;
  font-weight: 600;
  text-align: center;
}

.lightbox__close {
  position: fixed;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  border: none;
  color: var(--white);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background var(--transition), transform var(--transition);
}

.lightbox__close:hover {
  background: rgba(0, 0, 0, 0.78);
  transform: rotate(90deg);
}

.lightbox__thumbs {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

.lightbox__thumb {
  width: 54px;
  height: 72px;
  border: 2px solid transparent;
  border-radius: 6px;
  overflow: hidden;
  padding: 0;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  opacity: 0.55;
  transition: opacity var(--transition), border-color var(--transition);
}

.lightbox__thumb:hover { opacity: 0.85; }

.lightbox__thumb.is-active {
  opacity: 1;
  border-color: var(--accent);
}

.lightbox__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.returning {
  background: var(--bg);
  border-radius: var(--r-lg);
  padding: 32px 24px;
}

.returning__title {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.8vw, 26px);
  font-weight: 700;
  margin-bottom: 20px;
}

.returning__grid {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 24px 12px;
  margin: 0 -24px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  align-items: flex-start;
}

.returning__grid::-webkit-scrollbar { display: none; }

.returning__grid .quote--small {
  flex: 0 0 86%;
  scroll-snap-align: start;
}

@media (min-width: 768px) {
  .returning__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    overflow-x: visible;
    padding: 0;
    margin: 0;
    scroll-snap-type: none;
  }
  .returning__grid .quote--small { flex: initial; }
}

.quote--small { padding: 20px; background: var(--white); }
.quote--small .quote__text { font-size: 15px; }

.compare-table {
  display: flex;
  flex-direction: column;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border-soft);
  margin-top: 16px;
}

.compare-table__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.compare-table__row {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid var(--border-soft);
}

@media (min-width: 768px) {
  .compare-table__row { grid-template-columns: 1fr 1fr; }
}

.compare-table__cell {
  padding: 18px 24px;
  font-size: 15px;
  line-height: 1.5;
}

.compare-table__cell--head {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 24px;
}

@media (max-width: 767px) {
  .compare-table__cell--head {
    padding: 12px 14px;
    font-size: 11px;
    letter-spacing: 0.05em;
    gap: 8px;
  }
  .compare-table__cell--head .compare-table__mark {
    width: 22px;
    height: 22px;
  }
  .compare-table__cell--head .compare-table__mark svg {
    width: 12px;
    height: 12px;
  }
  .compare-table__row .compare-table__cell {
    position: relative;
    padding: 16px 18px 16px 52px;
    font-size: 14px;
  }
  .compare-table__row .compare-table__cell::before {
    position: absolute;
    left: 18px;
    top: 16px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    line-height: 22px;
  }
  .compare-table__row .compare-table__cell--others::before {
    content: '✕';
    background: rgba(226, 109, 61, 0.18);
    color: var(--warning);
  }
  .compare-table__row .compare-table__cell--ours::before {
    content: '✓';
    background: var(--accent);
    color: var(--white);
  }
}

.compare-table__cell--head.compare-table__cell--others {
  background: var(--bg-dark);
  color: var(--white);
}

.compare-table__cell--head.compare-table__cell--ours {
  background: var(--accent);
  color: var(--white);
}

.compare-table__row .compare-table__cell--others {
  background: var(--bg);
  color: var(--text-secondary);
}

.compare-table__row .compare-table__cell--ours {
  background: var(--white);
  color: var(--text);
}

@media (max-width: 767px) {
  .compare-table__row .compare-table__cell--others {
    border-bottom: 1px solid var(--border-soft);
  }
}

@media (min-width: 768px) {
  .compare-table__row .compare-table__cell--ours {
    border-left: 1px solid var(--border-soft);
  }
  .compare-table__cell--head + .compare-table__cell--head { border-left: 1px solid rgba(255, 255, 255, 0.15); }
}

.compare-table__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--white);
  flex-shrink: 0;
}

.compare-table__mark--bad { color: var(--warning); }
.compare-table__mark--good { color: var(--accent); }

.promises__list {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 20px 20px;
  margin: 0 -20px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  align-items: flex-start;
}

.promises__list::-webkit-scrollbar { display: none; }

.promises__list .promise {
  flex: 0 0 86%;
  scroll-snap-align: start;
}

@media (min-width: 640px) {
  .promises__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
    overflow-x: visible;
    padding: 0;
    margin: 0;
    scroll-snap-type: none;
  }
  .promises__list .promise { flex: initial; }
}

@media (min-width: 1024px) { .promises__list { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

.promise {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 36px 32px;
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--border-soft);
}

.promise__head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.promise__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(60, 74, 92, 0.06);
  color: var(--bg-dark);
  flex-shrink: 0;
}

.promise__label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--text-secondary);
  text-transform: uppercase;
}

.promise__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--text);
}

.promise__text {
  font-size: 15px;
  line-height: 1.55;
  color: var(--text-secondary);
}

.promise--cta {
  background: var(--bg-dark);
  border-color: var(--bg-dark);
  color: var(--white);
}

.promise__badge--dark {
  background: rgba(255, 255, 255, 0.1);
  color: var(--accent-warm);
}

.promise__title--light { color: var(--white); }

.promise__text--light { color: rgba(255, 255, 255, 0.75); }

.promise__cta-btn { margin-top: auto; }

.first-call__grid {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 20px 20px;
  margin: 0 -20px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  align-items: flex-start;
}

.first-call__grid::-webkit-scrollbar { display: none; }

.first-call__grid .call-part {
  flex: 0 0 86%;
  scroll-snap-align: start;
}

@media (min-width: 768px) {
  .first-call__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    overflow-x: visible;
    padding: 0;
    margin: 0;
    scroll-snap-type: none;
  }
  .first-call__grid .call-part { flex: initial; }
}

.call-part {
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 24px;
  border: 1px solid var(--border-soft);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.call-part__step {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  background: var(--bg-dark);
  color: var(--white);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.call-part__title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
}

.call-part p, .call-part li { font-size: 15px; line-height: 1.5; color: var(--text-secondary); }

.call-part__list { display: flex; flex-direction: column; gap: 10px; }
.call-part__list li { padding-left: 24px; position: relative; }
.call-part__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.5;
}
.call-part__list--numbered { counter-reset: step; }
.call-part__list--numbered li { padding-left: 32px; counter-increment: step; }
.call-part__list--numbered li::before {
  width: 22px;
  height: 22px;
  background: var(--accent);
  opacity: 1;
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  content: counter(step);
  top: 1px;
}
.call-part li strong { color: var(--text); font-weight: 700; }

.accordion {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.accordion__item {
  background: var(--bg);
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--border-soft);
}

.accordion__head {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 24px;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  user-select: none;
  transition: background var(--transition);
}

.accordion__head::-webkit-details-marker { display: none; }
.accordion__head:hover { background: var(--white); }

.accordion__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: transform var(--transition), background var(--transition);
}

.accordion__icon::before,
.accordion__icon::after {
  content: '';
  position: absolute;
  background: var(--text);
  border-radius: 1px;
  transition: opacity var(--transition);
}

.accordion__icon::before { width: 10px; height: 2px; }
.accordion__icon::after { width: 2px; height: 10px; }

.accordion__item[open] .accordion__icon { background: var(--accent); }
.accordion__item[open] .accordion__icon::before { background: var(--white); }
.accordion__item[open] .accordion__icon::after { opacity: 0; }

.accordion__body { padding: 0 24px 20px; }
.accordion__body p { font-size: 15px; line-height: 1.6; color: var(--text-secondary); margin-bottom: 10px; }
.accordion__body p:last-child { margin-bottom: 0; }
.accordion__body ul { display: flex; flex-direction: column; gap: 6px; margin: 10px 0; padding-left: 16px; list-style: disc; }
.accordion__body li { font-size: 15px; line-height: 1.5; color: var(--text-secondary); }
.accordion__body strong { color: var(--text); font-weight: 600; }

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.final-cta__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border-soft);
}

@media (min-width: 900px) { .final-cta__grid { grid-template-columns: 1fr 1fr; } }

.final-cta__pitch {
  background: var(--bg-dark);
  color: var(--white);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@media (min-width: 900px) { .final-cta__pitch { padding: 56px 44px; gap: 24px; } }

.final-cta__label {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--accent-warm);
  text-transform: uppercase;
  margin-bottom: -4px;
}

.final-cta__title {
  font-family: var(--font-display);
  font-size: clamp(34px, 6vw, 60px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1;
  margin: 0;
  color: var(--white);
}

.final-cta__desc {
  font-size: 17px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
}

.final-geo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  align-self: flex-start;
  max-width: 100%;
  padding: 14px 20px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--white);
  border-radius: var(--r-pill);
  font-size: 16px;
  font-weight: 600;
  margin: 4px 0;
  line-height: 1.3;
}

.final-geo__text { flex: 1; min-width: 0; }

.final-geo[hidden] { display: none; }

.final-geo__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  animation: pulse 2s ease-in-out infinite;
}

.final-cta__reassurance {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.5;
  margin: 0;
}

.final-cta__phone {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  color: var(--white);
  font-family: var(--font-display);
  font-size: clamp(15px, 2vw, 18px);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.3;
  flex-wrap: wrap;
  transition: color var(--transition);
}

.final-cta__phone:hover { color: var(--accent-warm); }
.final-cta__phone-icon { color: var(--white); display: inline-flex; opacity: 0.7; flex-shrink: 0; }
.final-cta__phone-num { white-space: nowrap; }
.final-cta__phone-text { white-space: nowrap; }

/* Правая колонка финального блока: контейнер для inline-lead-формы. */
.final-cta__form-block {
  background: var(--white);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

@media (min-width: 900px) { .final-cta__form-block { padding: 24px 28px; gap: 8px; } }

@media (min-width: 900px) {
  /* Финал должен помещаться в один экран на лаптопах 1366×768 — поэтому здесь
     компактные размеры формы и pitch-блока, плюс срезан большой нижний воздух
     самой секции (она и так последняя перед футером). */
  .final-cta.section { padding: 56px 0 28px; }
  .final-cta__form-block .lead-form { gap: 8px; }
  .final-cta__form-block .lead-form__field { gap: 4px; }
  .final-cta__form-block .lead-form__input { padding: 10px 14px; font-size: 15px; }
  .final-cta__form-block .lead-form__input--textarea { min-height: 48px; }
  .final-cta__form-block .file-upload-area { padding: 9px 12px; gap: 6px; }
  .final-cta__form-block .file-upload { padding: 7px 14px; font-size: 14px; }
  .final-cta__form-block button[type="submit"] { padding: 12px 22px; font-size: 15px; margin-top: 2px; }
  .final-cta__form-block .lead-form__badge { font-size: 12px; padding: 4px 12px; margin: 2px 0 0; }
  .final-cta__form-title { font-size: 20px; }
  .final-cta__form-desc { font-size: 14px; }
  .final-cta__title { font-size: clamp(28px, 3.8vw, 42px); }
  .final-cta__pitch { padding: 28px 32px; gap: 14px; }
  .final-cta__desc { font-size: 15px; }
}

.final-cta__form-title {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text);
  margin: 0;
}

.final-cta__form-desc {
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin: 0;
}

/* Inline-форма внутри final-cta: фон/паддинг уже задаёт родитель. */
.final-cta__form-block .lead-form {
  background: transparent;
  padding: 0;
}

@media (min-width: 900px) {
  .final-cta__form-block .lead-form { padding: 0; }
}

.lead-form {
  background: var(--white);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

@media (min-width: 900px) { .lead-form { padding: 48px 40px; } }

.lead-form__field { display: flex; flex-direction: column; gap: 8px; }

.lead-form__label {
  /* block + inline hint-span: текст label идёт обычным потоком, hint встаёт
     рядом, если место есть, и переносится естественно, если нет. Раньше
     был inline-flex с двумя flex-items — это создавало 2-колоночный layout,
     где «по желанию» уходило в правую колонку, а сам label-текст ломался
     на 2 строки в узких контейнерах (модалка на 375px). */
  display: block;
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.005em;
}

.lead-form__hint-inline {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: lowercase;
  letter-spacing: 0;
  margin-left: 6px;
  white-space: nowrap;
}

.lead-form__input {
  font-family: inherit;
  font-size: 16px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--white);
  color: var(--text);
  transition: border-color var(--transition), background var(--transition);
}

.lead-form__input::placeholder { color: var(--text-secondary); }

.lead-form__input:focus {
  outline: none;
  border-color: var(--accent);
}

.lead-form__input--textarea { resize: vertical; min-height: 96px; line-height: 1.5; }

.lead-form__hint { font-size: 13px; line-height: 1.5; color: var(--text-secondary); margin: 0; }

.lead-form__badge {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(47, 174, 155, 0.12);
  color: var(--accent);
  border-radius: var(--r-pill);
  font-size: 14px;
  font-weight: 600;
  margin: 4px 0 0;
}

.lead-form__badge::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  animation: pulse 2s ease-in-out infinite;
}

.btn--large { padding: 18px 28px; font-size: 17px; }

.file-upload-area {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 18px;
  background: var(--bg);
  border: 1px dashed var(--border);
  border-radius: var(--r-md);
}

.file-upload {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: var(--border-soft);
  border-radius: var(--r-pill);
  cursor: pointer;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  transition: background var(--transition);
  align-self: flex-start;
}

.file-upload:hover, .file-upload:focus-within {
  background: #DDE1E6;
}

.file-upload__icon { color: var(--text); display: inline-flex; }
.file-upload__input { position: absolute; opacity: 0; pointer-events: none; }

.file-upload__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.file-upload__list:empty { display: none; }

.file-upload__thumb {
  position: relative;
  width: 72px;
  height: 72px;
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--white);
  border: 1px solid var(--border);
}

.file-upload__thumb img { width: 100%; height: 100%; object-fit: cover; }

.file-upload__remove {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 22px;
  height: 22px;
  background: rgba(31, 36, 43, 0.7);
  color: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
}

.footer {
  background: var(--bg-dark);
  color: rgba(255, 255, 255, 0.8);
  padding: 40px 0;
}

.footer__inner { display: flex; flex-direction: column; gap: 16px; }

.footer__brand { display: flex; flex-direction: column; gap: 6px; }

.footer__tagline {
  font-size: 14px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.65);
  margin: 0;
}

.logo--footer { color: var(--white); }

.footer__about { font-size: 14px; line-height: 1.55; max-width: 720px; }

.footer__copy { font-size: 13px; color: rgba(255, 255, 255, 0.5); }

.floating-cta {
  position: fixed;
  bottom: 20px;
  right: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 40;
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity 200ms ease, transform 200ms ease;
}

.floating-cta.is-visible {
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

.floating-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  color: var(--white);
  box-shadow: 0 4px 14px rgba(31, 36, 43, 0.18);
  transition: transform var(--transition);
}

.floating-cta__btn:hover { transform: scale(1.05); }
.floating-cta__btn--phone { background: var(--warning); }
.floating-cta__btn--tg { background: #2AABEE; }

@media (min-width: 1024px) {
  .floating-cta { bottom: 32px; right: 32px; }
  .floating-cta__btn { width: 56px; height: 56px; }
}

/* ==========================================================================
   T-3 — Стили под новую разметку (T-2): модалка-overlay, валидация формы,
   success-блок, карточки кейсов (плашка + кнопка), мобильный header,
   sticky-блок мобильной связи.
   ========================================================================== */

/* --- Модалка-overlay -----------------------------------------------------
   В index.html модалка имеет атрибут [hidden]. Открытое состояние = снят
   hidden И/ИЛИ добавлен класс .is-open. Поддержаны оба сценария — T-4
   (script.js) может использовать любой из них.
   Согласовано с T-4: открытие через removeAttribute('hidden') и/или
   classList.add('is-open'), закрытие — обратное. Атрибут [hidden] имеет
   приоритет: пока он стоит, модалка всегда display:none. */

.modal-overlay {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 20px 16px;
  background: rgba(31, 36, 43, 0.72);
  backdrop-filter: blur(2px);
  z-index: 1000;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* Атрибут hidden — стандартное скрытие. Сохраняем поведение через !important,
   чтобы перебить display:flex выше при любых наследованиях. */
.modal-overlay[hidden] { display: none !important; }

/* Опциональный JS-флаг открытия (если T-4 пойдёт через класс, а не hidden). */
.modal-overlay.is-open { display: flex; }

.modal-content {
  position: relative;
  width: 100%;
  max-width: 480px;
  margin: auto;
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 22px 20px 20px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
}

@media (min-width: 480px) {
  .modal-content { padding: 32px 32px 28px; }
}

.modal-close {
  position: absolute;
  top: 10px;
  right: 12px;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  border-radius: 50%;
  transition: background var(--transition), color var(--transition);
  z-index: 2;
}

.modal-close:hover { background: var(--border-soft); color: var(--text); }
.modal-close:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.modal-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
  color: var(--text);
  padding-right: 40px;
  line-height: 1.15;
}

/* Блокировка скролла страницы при открытой модалке (ставит T-4). */
body.no-scroll { overflow: hidden; }

/* --- Чекбокс согласия ----------------------------------------------------- */

.consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--text-secondary);
  cursor: pointer;
}

.consent input[type="checkbox"] {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  accent-color: var(--accent);
  cursor: pointer;
}

.consent a { color: var(--accent); text-decoration: underline; }
.consent a:hover { color: var(--text); }

.lead-form__field--consent { gap: 4px; }

/* --- Валидация ----------------------------------------------------------- */

/* Пустой span невидим естественно (нет контента → нет высоты). */
.field-error {
  display: block;
  min-height: 0;
  margin-top: 4px;
  color: #D64545;
  font-size: 13px;
  line-height: 1.35;
}

.field-error:empty { margin: 0; }

input.invalid,
textarea.invalid,
.lead-form__input.invalid {
  border-color: #D64545;
  outline-color: #D64545;
}

input.invalid:focus,
textarea.invalid:focus,
.lead-form__input.invalid:focus {
  border-color: #D64545;
  outline: none;
  box-shadow: 0 0 0 3px rgba(214, 69, 69, 0.15);
}

/* Состояние загрузки на любой submit-кнопке (T-4 ставит data-loading="true"). */
.btn[data-loading="true"],
.btn-primary[data-loading="true"] {
  opacity: 0.6;
  cursor: progress;
  pointer-events: none;
}

/* Общая ошибка вверху формы. */
.form-error-global {
  margin: 0 0 14px;
  padding: 12px 14px;
  background: rgba(214, 69, 69, 0.08);
  border: 1px solid rgba(214, 69, 69, 0.35);
  border-radius: var(--r-sm);
  color: #B53636;
  font-size: 14px;
  line-height: 1.45;
}

.form-error-global[hidden] { display: none; }

.form-error-global a { color: inherit; text-decoration: underline; font-weight: 700; }

/* --- Success-блок -------------------------------------------------------- */

/* Атрибут hidden скрывает по умолчанию. Когда T-4 убирает hidden — блок виден. */
.form-success[hidden] { display: none; }

.form-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 14px;
  padding: 12px 4px 4px;
}

.form-success h3 {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text);
  margin: 0;
}

.form-success p {
  font-size: 16px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin: 0;
  max-width: 360px;
}

.form-success .btn,
.form-success .btn-primary {
  margin-top: 4px;
}

/* --- Карточки кейсов: статичная плашка цены + отдельная кнопка ---------- */

/* Плашка: визуально как контейнер с ценой, НЕ как кнопка.
   Нет cursor pointer, нет hover-арки, нет рамки кнопки. */
.case-price {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 12px 16px;
  margin-top: auto;
  background: var(--bg);
  border-radius: var(--r-sm);
  font-family: inherit;
  text-align: left;
}

.case-price__label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.case-price strong {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}

/* Модификатор «беглецов» — диапазон, чуть мельче (две суммы не помещаются крупно). */
.case-price--range strong { font-size: 20px; }

.case-price__hint {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  font-style: italic;
  color: var(--text-secondary);
}

/* Кнопка под плашкой. Берёт основной вид от .btn.btn--form, .case-cta —
   мягкая корректировка размера и ширины под карточку. */
.case-cta {
  margin-top: 10px;
  padding: 14px 20px;
  font-size: 15px;
  width: 100%;
}

@media (min-width: 640px) {
  .case-cta { width: auto; align-self: flex-start; }
}

/* --- Header: телефон на мобильном цифрами ------------------------------- */

/* В существующих стилях есть `.topbar__phone span { display: none }`,
   которое скрывает любые span внутри. Перебиваем для .header-phone__digits
   повышенной специфичностью (.header-phone .header-phone__digits). */

.header-phone {
  /* Структурно совпадает с .topbar__phone — оставляем существующие отступы.
     Здесь только страховочные правила для предсказуемого flex-поведения. */
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Селектор с двойным классом, чтобы перебить .topbar__phone span { display: none }
   (специфичность 0,1,1) — иначе иконка телефона исчезает на мобиле вместе со
   span-цифрами. */
.header-phone .header-phone__icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

.header-phone .header-phone__digits {
  display: inline-block;
  font-weight: 600;
  font-size: 15px;
  white-space: nowrap;
  color: var(--text);
}

/* Telegram-иконка в шапке (без стилей у .topbar__tg width=0). */
.topbar__tg.header-tg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--r-pill);
  color: var(--text);
  flex-shrink: 0;
  transition: background var(--transition), color var(--transition);
}

.topbar__tg.header-tg:hover { background: var(--border-soft); color: #2AABEE; }
.header-tg__icon { display: inline-flex; }

/* Финальная конфигурация мобильной шапки (после обсуждения с Артёмом 2026-05-12):
   - Кнопка «Оставить заявку» скрыта — на странице 12+ точек CTA в потоке;
     в шапке она вылезала за viewport на 90px.
   - Telegram-иконка скрыта — для аварийной аудитории главное действие «позвонить»;
     Telegram доступен в плавающих круглых кнопках справа снизу.
   - Номер телефона остаётся **цифрами** (П16 из экспертного анализа Peep Laja):
     номер цифрами совмещает три функции — видимое доказательство номера
     (доверие для настороженного сегмента), кликабельный CTA, узнавание. */
@media (max-width: 768px) {
  .topbar__cta { display: none; }
  .topbar__tg.header-tg { display: none; }
}

/* Узкий мобайл — сжимаем кегль номера, но цифры остаются видны. */
@media (max-width: 479px) {
  .header-phone .header-phone__digits { font-size: 14px; letter-spacing: -0.01em; }
  .topbar__phone { padding: 6px 8px; gap: 6px; }
}

/* Очень узкий (iPhone SE и старее) — прячем иконку телефона, оставляем цифры. */
@media (max-width: 359px) {
  .header-phone .header-phone__icon { display: none; }
  .header-phone .header-phone__digits { font-size: 13px; }
}

/* --- Плавающие кнопки связи (телефон + Telegram) ------------------------ */

/* Разметка из T-2: <div class="mobile-sticky floating-cta">…</div>.
   Кодер T-3 переопределял .floating-cta до «полосы во всю ширину снизу»,
   но Артём вернул исходное поведение 2026-05-12 (после T-8): плавающие
   круги справа снизу, с иконками и без подписей.
   Базовые стили .floating-cta + .floating-cta__btn выше дают круг 52×52
   (на ≥ 1024px — 56×56). Здесь только корректировки под структуру T-2. */

.mobile-sticky__icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

/* Подписи «Позвонить» / «Telegram» в плавающих круглых кнопках не помещаются —
   на мобиле скрываем, оставляем только иконки. */
.mobile-sticky__label { display: none; }

/* === конец T-3 ============================================================ */

/* === Thanks page =========================================================== */

.thanks {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 64px - 200px);
  padding: 60px 0 80px;
}

.thanks__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 22px;
  max-width: 540px;
  margin: 0 auto;
}

.thanks__icon {
  width: 88px;
  height: 88px;
  margin-bottom: 6px;
}

.thanks__icon svg { width: 100%; height: 100%; display: block; }

.thanks__title {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin: 0;
  color: var(--text);
}

.thanks__text {
  font-size: 18px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin: 0;
  max-width: 460px;
}

.thanks__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  width: 100%;
  max-width: 420px;
  margin-top: 8px;
}

.thanks__tg-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-secondary);
  transition: color var(--transition);
}

.thanks__tg-link:hover { color: var(--text); }
.thanks__tg-link svg { color: #2AABEE; }

.thanks__hours {
  font-size: 14px;
  color: var(--text-secondary);
  margin: 8px 0 0;
}

.thanks__home {
  font-size: 14px;
  color: var(--text-secondary);
  margin-top: 16px;
  transition: color var(--transition);
}

.thanks__home:hover { color: var(--text); }

/* === конец Thanks page ===================================================== */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}
