/* Landing-стили работают в двух режимах:
   на отдельном preview-entrypoint и на корневом `/`, пока пользователь
   ещё не перешёл в authenticated root-home shell. */
body.landing-home-preview-page,
body.page-home.page-root-home:not(.page-root-home-authenticated) {
  background:
    radial-gradient(circle at 18% 12%, rgba(31, 143, 255, 0.12) 0%, rgba(31, 143, 255, 0) 34%),
    radial-gradient(circle at 88% 16%, rgba(31, 143, 255, 0.12) 0%, rgba(31, 143, 255, 0) 28%),
    linear-gradient(180deg, #f7f9ff 0%, #ffffff 42%, #f8fbff 100%);
}

/* Центральный контейнер растягиваем на всю высоту hero-сцены,
   чтобы первый экран ощущался отдельным блоком, а не просто верхней карточкой списка. */
body.landing-home-preview-page .board-content,
body.page-home.page-root-home:not(.page-root-home-authenticated) .board-content {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 26px;
  padding-bottom: 42px;
}

/* Вся страница строится как вертикальный поток секций, но с крупным
   split-hero на первом экране и более спокойными блоками ниже. */
.landing-home {
  display: grid;
  gap: 0;
  align-content: start;
  width: min(100%, 1520px);
  min-height: calc(100dvh - 228px);
  margin: 0 auto;
  padding-inline: 12px;
}

.landing-home__hero-card {
  width: min(100%, 1400px);
  margin: 0 auto;
  min-height: calc(100dvh - 148px);
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.landing-home__hero-card::before {
  content: none;
}

/* Сам hero делим на две крупные колонки:
   слева текст и CTA, справа статичный preview-интерфейс,
   который повторяет композицию референса без растровой картинки. */
.landing-home__hero-body {
  display: grid;
  grid-template-columns: minmax(0, 600px) minmax(560px, 1fr);
  align-items: center;
  gap: clamp(1.8rem, 3vw, 3.35rem);
  width: min(100%, 1420px);
  min-height: inherit;
  padding: clamp(0.85rem, 1.6vw, 1.4rem) clamp(0.75rem, 2vw, 1.5rem);
  margin: 0 auto;
  text-align: left;
}

/* Левую колонку держим компактной по ширине, чтобы заголовок сам
   красиво разбивался на несколько строк и визуально был похож на скриншот. */
.landing-home__hero-copy {
  display: grid;
  gap: 0.88rem;
  align-content: center;
  min-width: 0;
}

.landing-home__title {
  margin: 0;
  max-width: 17.5ch;
  color: var(--text-main);
  font-size: clamp(2.1rem, 3.4vw, 3.56rem);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: -0.028em;
  text-wrap: balance;
}

.landing-home__lead {
  margin: 0;
  max-width: 42ch;
  color: var(--text-muted);
  font-size: clamp(0.96rem, 1.08vw, 1.08rem);
  line-height: 1.58;
  text-wrap: pretty;
}

/* CTA теперь идут отдельной парой: primary и secondary визуально различаются,
   но по продуктовой логике ведут в один и тот же auth-flow. */
.landing-home__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 1rem;
  justify-content: flex-start;
  width: 100%;
  padding-top: 0.5rem;
}

.landing-home__primary-action,
.landing-home__secondary-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 210px;
  min-height: 58px;
  padding: 0.88rem 1.45rem;
  border-radius: 18px;
  box-sizing: border-box;
  font-size: clamp(1rem, 1.25vw, 1.18rem);
  font-weight: 800;
  text-decoration: none;
}

/* Primary CTA делаем чуть тяжелее и глубже по тени,
   чтобы блок "Войти" оставался главным action в паре. */
.landing-home__primary-action {
  box-shadow: 0 24px 48px rgba(31, 143, 255, 0.24);
}

.landing-home__primary-action:hover,
.landing-home__primary-action:focus-visible {
  box-shadow: 0 28px 54px rgba(31, 143, 255, 0.28);
}

/* Secondary CTA приближаем к "светлой кнопке" из референса,
   но сохраняем существующий дизайн-язык проекта через общую базовую кнопку. */
.landing-home__secondary-action {
  border-color: rgba(148, 163, 184, 0.3);
  background: rgba(255, 255, 255, 0.78);
  color: var(--text-main);
  box-shadow: 0 18px 38px rgba(129, 142, 176, 0.12);
}

.landing-home__secondary-action:hover,
.landing-home__secondary-action:focus-visible {
  border-color: rgba(100, 116, 139, 0.24);
  background: rgba(255, 255, 255, 0.92);
  color: var(--text-main);
  box-shadow: 0 22px 42px rgba(129, 142, 176, 0.16);
}

.landing-home__support-note {
  margin: 0;
  max-width: 38ch;
  color: var(--text-soft);
  font-size: clamp(0.94rem, 1.12vw, 1.03rem);
  line-height: 1.52;
}

/* Правый блок теперь показывает реальные project screenshots:
   увеличиваем его долю в hero и оставляем мягкое свечение, чтобы первый экран
   не превращался в сухую галерею без объёма. */
.landing-home__hero-preview {
  position: relative;
  display: grid;
  gap: 0.95rem;
  align-self: center;
  min-width: 0;
  width: min(100%, 860px);
  justify-self: end;
}

.landing-home__hero-preview::before {
  content: "";
  position: absolute;
  inset: 4% 2% 6% 6%;
  border-radius: 38px;
  background:
    radial-gradient(circle at 68% 18%, rgba(31, 143, 255, 0.26) 0%, rgba(31, 143, 255, 0.1) 38%, rgba(31, 143, 255, 0) 72%),
    radial-gradient(circle at 16% 82%, rgba(89, 165, 255, 0.22) 0%, rgba(89, 165, 255, 0) 60%);
  filter: blur(24px);
  z-index: 0;
}

.landing-home__preview-window {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border: 1px solid rgba(204, 212, 231, 0.85);
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 247, 255, 0.98) 100%);
  box-shadow: 0 34px 76px rgba(104, 119, 173, 0.26);
}

/* Верхнюю chrome-полоску окна делаем максимально нейтральной:
   она задаёт нужную метафору "браузерного окна", но не спорит с контентом внутри. */
.landing-home__preview-toolbar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 1.25rem 0.95rem;
  border-bottom: 1px solid rgba(220, 226, 240, 0.92);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 249, 255, 0.92) 100%);
}

.landing-home__preview-dots {
  position: absolute;
  top: 50%;
  left: 1.25rem;
  display: inline-flex;
  gap: 0.5rem;
  transform: translateY(-50%);
}

.landing-home__preview-dot {
  width: 0.95rem;
  height: 0.95rem;
  border-radius: 50%;
}

.landing-home__preview-dot--red {
  background: #ff6d6d;
}

.landing-home__preview-dot--yellow {
  background: #f6c945;
}

.landing-home__preview-dot--green {
  background: #4fd07f;
}

.landing-home__preview-address {
  min-width: 0;
  width: min(100%, 29rem);
  padding: 0.7rem 1.15rem;
  border-radius: 14px;
  background: rgba(248, 250, 252, 0.92);
  color: #526079;
  font-size: clamp(0.94rem, 1.1vw, 1.08rem);
  font-weight: 700;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Контент mockup строим как маленький dashboard/board:
   он должен считываться как продукт Trelio, а не как абстрактная карточка. */
/* Внутри окна держим один большой slideshow-кадр.
   Это позволяет показать реальные проекты крупно, не дробя preview на мелкие элементы. */
.landing-home__preview-stage {
  display: grid;
  gap: 0.95rem;
  padding: 1rem 1rem 1.1rem;
}

.landing-home__preview-screen-stack {
  position: relative;
  overflow: hidden;
  aspect-ratio: 2940 / 1602;
  border: 1px solid rgba(224, 230, 242, 0.94);
  border-radius: 24px;
  background: linear-gradient(180deg, #f7f9ff 0%, #eff4ff 100%);
}

.landing-home__preview-screen-stack::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 24%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(245, 248, 255, 0.18) 100%);
  pointer-events: none;
}

.landing-home__preview-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  z-index: 0;
  pointer-events: none;
  transition: opacity 420ms ease;
}

.landing-home__preview-slide.is-active {
  opacity: 1;
  z-index: 1;
}

/* `picture` должен занимать весь slot кадра, иначе браузер оставит inline-box
   и у browser-frame появятся лишние зазоры/нестабильная высота. */
.landing-home__preview-picture {
  display: block;
  width: 100%;
  height: 100%;
}

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

.landing-home__preview-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding-top: 0.05rem;
}

.landing-home__preview-footer-steps {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.landing-home__preview-footer-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 2.75rem;
  height: 0.7rem;
  padding: 0;
  border: 0;
  position: relative;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.35);
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  transition:
    background-color 320ms ease,
    box-shadow 320ms ease;
}

.landing-home__preview-footer-pill:hover {
  background: rgba(31, 143, 255, 0.14);
}

.landing-home__preview-footer-pill:focus-visible {
  outline: 2px solid rgba(21, 95, 206, 0.38);
  outline-offset: 3px;
}

.landing-home__preview-footer-pill::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #2b9dff 0%, #155fce 100%);
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left center;
  will-change: transform;
}

.landing-home__preview-footer-pill.is-active {
  background: rgba(31, 143, 255, 0.18);
  box-shadow: 0 8px 18px rgba(31, 143, 255, 0.18);
}

.landing-home__preview-footer-pill.is-active::before {
  opacity: 1;
  animation: landing-home-preview-progress var(--landing-home-preview-duration, 10000ms) linear forwards;
}

@keyframes landing-home-preview-progress {
  from {
    transform: scaleX(0);
  }

  to {
    transform: scaleX(1);
  }
}

/* Секции ниже hero оставляем спокойнее: они должны поддерживать оффер,
   а не конкурировать с первым экраном. */
.landing-home__advantages {
  display: grid;
  gap: 1.8rem;
  width: min(100%, 1024px);
  margin: clamp(4.5rem, 7vw, 6.5rem) auto 0;
}

.landing-home__advantages-heading {
  display: grid;
  gap: 0.8rem;
  justify-items: center;
  text-align: center;
}

.landing-home__advantages-title {
  margin: 0;
  color: var(--text-main);
  font-size: clamp(1.92rem, 2.5vw, 2.7rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.landing-home__advantages-title-accent {
  background: linear-gradient(135deg, #1f8fff 0%, #155fce 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.landing-home__advantages-lead {
  margin: 0;
  max-width: 70ch;
  color: var(--text-soft);
  font-size: var(--font-size-base);
  line-height: 1.65;
}

.landing-home__advantages-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1.1rem;
  align-items: stretch;
}

.landing-home__advantage-card {
  position: relative;
  height: 100%;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(212, 220, 244, 0.9);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 251, 255, 0.96) 100%);
  box-shadow: 0 18px 42px rgba(116, 128, 177, 0.1);
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
  /* На touch даём странице обычный вертикальный scroll.
     Сам drag стартует long-press-логикой в JS и только после этого
     начинает перехватывать перемещение пальца. */
  touch-action: pan-y;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease,
    opacity 180ms ease;
}

.landing-home__advantage-card::after {
  content: none;
}

.landing-home__advantage-card:hover,
.landing-home__advantage-card:focus-within {
  box-shadow: 0 24px 60px rgba(31, 143, 255, 0.14);
}

.landing-home__advantage-card.is-dragging {
  opacity: 0.42;
  transform: scale(0.98);
  box-shadow: 0 18px 40px rgba(31, 143, 255, 0.1);
}

.landing-home__advantage-card.is-drop-target {
  border-color: rgba(31, 143, 255, 0.38);
  box-shadow: 0 26px 62px rgba(31, 143, 255, 0.18);
  transform: translateY(-2px);
}

.landing-home__advantage-drag-ghost {
  position: fixed;
  inset: auto auto auto 0;
  z-index: 1200;
  margin: 0;
  pointer-events: none;
  transform: rotate(2deg);
  box-shadow: 0 26px 62px rgba(31, 143, 255, 0.2);
}

[data-advantage-slot="kanban"] {
  grid-column: 5 / span 2;
  grid-row: 1;
}

[data-advantage-slot="tasks"] {
  grid-column: 1 / span 4;
  grid-row: 1;
}

[data-advantage-slot="simple"] {
  grid-column: 1 / span 2;
  grid-row: 2;
}

[data-advantage-slot="knowledge"] {
  grid-column: 3 / span 4;
  grid-row: 2;
}

[data-advantage-slot="notifications"] {
  grid-column: 1 / span 2;
  grid-row: 3;
}

[data-advantage-slot="dashboard"] {
  grid-column: 3 / span 2;
  grid-row: 3;
}

[data-advantage-slot="ai-export"] {
  grid-column: 5 / span 2;
  grid-row: 3;
}

.landing-home__advantage-card-body {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1rem;
  align-content: start;
  min-height: 100%;
  padding: 1.5rem 1.55rem 1.55rem;
}

.landing-home__advantage-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 17px;
  background: linear-gradient(180deg, #2b9dff 0%, #155fce 100%);
  color: #ffffff;
  box-shadow: 0 18px 34px rgba(31, 143, 255, 0.24);
  font-size: 1.3rem;
}

.landing-home__advantage-card-title {
  margin: 0;
  color: var(--text-main);
  font-size: clamp(1.15rem, 1.3vw, 1.42rem);
  font-weight: 800;
  line-height: 1.2;
}

.landing-home__advantage-text {
  margin: 0;
  color: var(--text-muted);
  font-size: clamp(0.98rem, 1.05vw, 1.08rem);
  line-height: 1.7;
}

.landing-home__pricing,
.landing-home__faq {
  display: grid;
  gap: 1.8rem;
  width: min(100%, 1024px);
  margin: clamp(4rem, 6vw, 5.75rem) auto 0;
}

.landing-home__pricing-heading,
.landing-home__faq-heading {
  display: grid;
  gap: 0.8rem;
  justify-items: center;
  text-align: center;
}

.landing-home__pricing-title,
.landing-home__faq-title {
  margin: 0;
  color: var(--text-main);
  font-size: clamp(1.85rem, 2.4vw, 2.5rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.landing-home__pricing-lead,
.landing-home__faq-lead {
  margin: 0;
  max-width: 68ch;
  color: var(--text-soft);
  font-size: var(--font-size-base);
  line-height: 1.65;
}

.landing-home__pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.landing-home__pricing-card {
  position: relative;
  min-height: 100%;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(212, 220, 244, 0.9);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 251, 255, 0.96) 100%);
  box-shadow: 0 18px 42px rgba(116, 128, 177, 0.1);
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.landing-home__pricing-card::after {
  content: none;
}

.landing-home__pricing-card:hover,
.landing-home__pricing-card:focus-within {
  box-shadow: 0 24px 60px rgba(31, 143, 255, 0.14);
}

.landing-home__pricing-card-body {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.75rem;
  align-content: start;
  min-height: 100%;
  padding: 1.5rem 1.55rem 1.55rem;
  justify-items: start;
}

.landing-home__pricing-card-title {
  margin: 0;
  max-width: 18ch;
  color: var(--text-main);
  font-size: clamp(1.24rem, 1.5vw, 1.5rem);
  font-weight: 850;
  line-height: 1.12;
  letter-spacing: -0.025em;
}

.landing-home__pricing-summary,
.landing-home__pricing-note {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.98rem;
  line-height: 1.65;
}

.landing-home__pricing-note {
  max-width: 68ch;
  justify-self: center;
  text-align: center;
  color: var(--text-soft);
  font-size: 0.92rem;
}

.landing-home__faq-list {
  display: grid;
  gap: 0.85rem;
}

.landing-home__faq-item {
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(212, 220, 244, 0.9);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(250, 252, 255, 0.94) 100%);
  box-shadow: 0 18px 46px rgba(116, 128, 177, 0.1);
}

.landing-home__faq-item[open] {
  border-color: rgba(31, 143, 255, 0.24);
  box-shadow: 0 22px 54px rgba(31, 143, 255, 0.12);
}

.landing-home__faq-question {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  padding: 1.2rem 1.25rem;
  color: var(--text-main);
  font-size: clamp(1.04rem, 1.22vw, 1.18rem);
  font-weight: 850;
  line-height: 1.28;
  cursor: pointer;
  list-style: none;
}

.landing-home__faq-question::-webkit-details-marker {
  display: none;
}

.landing-home__faq-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background: rgba(31, 143, 255, 0.12);
  color: #155fce;
  font-size: 0.95rem;
  transition:
    transform 180ms ease,
    background-color 180ms ease,
    color 180ms ease;
}

.landing-home__faq-item[open] .landing-home__faq-toggle {
  transform: rotate(45deg);
  background: linear-gradient(180deg, #2b9dff 0%, #155fce 100%);
  color: #ffffff;
}

.landing-home__faq-answer {
  display: grid;
  gap: 0.8rem;
  padding: 0 1.25rem 1.25rem;
  color: var(--text-muted);
  font-size: var(--font-size-base);
  line-height: 1.68;
}

.landing-home__faq-answer p {
  max-width: 72ch;
  margin: 0;
}

/* На desktop первый экран должен жить как чистый fold:
   следующий content-block не должен выглядывать снизу под hero даже
   в браузерах с отличиями между `vh` и реальной видимой высотой окна. */
@media (min-width: 992px) {
  .landing-home__hero-card {
    min-height: calc(100dvh - 132px);
  }
}

/* На ноутбуках немного притормаживаем масштаб hero,
   чтобы заголовок не перетягивал слишком много внимания на узких ширинах. */
@media (max-width: 1199.98px) {
  .landing-home__hero-body {
    grid-template-columns: minmax(0, 500px) minmax(460px, 1fr);
    gap: clamp(1.75rem, 3vw, 3rem);
  }

  .landing-home__title {
    max-width: 17ch;
    font-size: clamp(2rem, 3.38vw, 3.14rem);
  }

}

/* На планшетах hero складываем в одну колонку:
   пользователь сначала читает оффер и CTA, затем видит preview ниже. */
@media (max-width: 991.98px) {
  .landing-home {
    width: min(100%, 1180px);
    min-height: auto;
  }

  .landing-home__hero-card,
  .landing-home__advantages,
  .landing-home__pricing,
  .landing-home__faq {
    width: min(100%, 960px);
  }

  .landing-home__hero-body {
    grid-template-columns: minmax(0, 1fr);
    min-height: auto;
    gap: 2rem;
    padding: 0.5rem 0.25rem 0;
  }

  .landing-home__hero-copy {
    max-width: 760px;
  }

  .landing-home__title {
    max-width: 18ch;
    font-size: clamp(2.28rem, 5vw, 3.34rem);
  }

  .landing-home__lead {
    max-width: 46ch;
  }

  .landing-home__hero-preview {
    width: min(100%, 920px);
  }

  .landing-home__advantages {
    margin-top: clamp(3.5rem, 8vw, 5rem);
  }

  .landing-home__pricing,
  .landing-home__faq {
    margin-top: clamp(3rem, 7vw, 4.25rem);
  }

  .landing-home__advantages-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* На небольших планшетах desktop-мозаика в 3 условных блока уже не работает:
     wide-карточки начинают занимать всю строку, а компактные элементы,
     идущие раньше них в DOM, оставляют пустые "дыры" справа.
     Поэтому здесь задаём отдельную slot-композицию именно для 2-колоночного режима.
     Важно, что мы по-прежнему опираемся на data-advantage-slot:
     drag-demo продолжает менять местами именно позиции, а не содержимое карточек. */
  .landing-home__advantage-card {
    grid-column: auto;
    grid-row: auto;
  }

  [data-advantage-slot="tasks"] {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  [data-advantage-slot="kanban"] {
    grid-column: 1;
    grid-row: 2;
  }

  [data-advantage-slot="simple"] {
    grid-column: 2;
    grid-row: 2;
  }

  [data-advantage-slot="knowledge"] {
    grid-column: 1 / -1;
    grid-row: 3;
  }

  [data-advantage-slot="notifications"] {
    grid-column: 1;
    grid-row: 4;
  }

  [data-advantage-slot="dashboard"] {
    grid-column: 2;
    grid-row: 4;
  }

  [data-advantage-slot="ai-export"] {
    grid-column: 1 / -1;
    grid-row: 5;
  }

  .landing-home__pricing-grid {
    grid-template-columns: minmax(0, 1fr);
  }

}

/* На мобильных сохраняем ту же идею, но делаем hero плотнее,
   чтобы важные тексты, кнопки и часть mockup попадали в первый scroll-screen. */
@media (max-width: 767.98px) {
  body.landing-home-preview-page .board-content,
  body.page-home.page-root-home:not(.page-root-home-authenticated) .board-content {
    padding-top: 20px;
    padding-bottom: 30px;
  }

  .landing-home {
    padding-inline: 4px;
  }

  .landing-home__advantages {
    margin-top: 3rem;
  }

  .landing-home__pricing,
  .landing-home__faq {
    margin-top: 2.75rem;
    gap: 1.45rem;
  }

  .landing-home__hero-body {
    gap: 1.45rem;
    padding: 0;
  }

  .landing-home__hero-copy {
    gap: 1.05rem;
  }

  .landing-home__title {
    max-width: 17ch;
    font-size: clamp(1.86rem, 7.6vw, 2.58rem);
    line-height: 1;
    letter-spacing: -0.03em;
  }

  .landing-home__lead {
    max-width: none;
    font-size: 1rem;
    line-height: 1.62;
  }

  .landing-home__actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
  }

  .landing-home__primary-action,
  .landing-home__secondary-action {
    width: 100%;
    min-width: 0;
    min-height: 56px;
    padding: 0.85rem 1.2rem;
    border-radius: 16px;
    font-size: 1rem;
  }

  .landing-home__support-note {
    font-size: 0.95rem;
  }

  .landing-home__hero-preview::before {
    inset: 8% 4% 6% 4%;
  }

  .landing-home__preview-window {
    border-radius: 24px;
  }

  .landing-home__preview-toolbar {
    padding: 0.9rem 1rem 0.85rem;
  }

  .landing-home__preview-dot {
    width: 0.82rem;
    height: 0.82rem;
  }

  .landing-home__preview-dots {
    left: 1rem;
  }

  .landing-home__preview-address {
    padding: 0.62rem 0.85rem;
    font-size: 0.92rem;
  }

  .landing-home__preview-stage {
    padding: 0.85rem;
    gap: 0.75rem;
  }

  .landing-home__preview-screen-stack {
    border-radius: 18px;
  }

  .landing-home__preview-footer {
    justify-content: center;
  }

  .landing-home__advantages-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .landing-home__advantage-card-body {
    padding: 1.3rem 1.2rem 1.25rem;
  }

  .landing-home__advantage-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 15px;
    font-size: 1.15rem;
  }

  .landing-home__advantages-title,
  .landing-home__pricing-title,
  .landing-home__faq-title {
    font-size: clamp(1.6rem, 7vw, 2.1rem);
  }

  .landing-home__pricing-card-body {
    padding: 1.3rem 1.2rem 1.25rem;
  }

  .landing-home__faq-question {
    padding: 1.05rem 1rem;
  }

  .landing-home__faq-answer {
    padding: 0 1rem 1.05rem;
  }
}
