/* LAYOUT — контейнеры, секции, сетки */

.container {
  width: var(--container-w);
  margin: 0 auto;
  padding-left: max(0px, env(safe-area-inset-left));
  padding-right: max(0px, env(safe-area-inset-right));
}

section {
  position: relative;
  padding: clamp(48px, 6vw, 120px) 0;
  scroll-margin-top: 100px; /* чтоб sticky-nav не перекрывал title при клике anchor-link */
}

section.tight { padding: var(--sp-lg) 0; }
section.loose { padding: var(--sp-2xl) 0; }

.section-head {
  text-align: center;
  max-width: min(100%, 820px);
  margin: 0 auto clamp(28px, 3.5vw, 72px);
  padding: 0 var(--sp-sm);
}

.section-head h2 { margin-bottom: var(--sp-xs); }
.section-head .lead { margin: 0 auto; }

/* Сетки — mobile-first, плавное наращивание колонок */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-md);
  align-items: stretch;
}
.grid-3, .grid-4 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-md);
  align-items: stretch;
}
.grid-auto {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: var(--sp-md);
  align-items: stretch;
}

/* Tablet portrait+ (600px) — 2 колонки */
@media (min-width: 600px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}

/* Desktop (1024px) — 3/4 колонки */
@media (min-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-4 { grid-template-columns: repeat(4, 1fr); }
}

/* Глобальное выравнивание в гридах секций */
.problem-grid, .solution-grid, .features-grid, .pricing-grid,
.roi-grid, .how-timeline, .presets-grid { align-items: stretch; }

/* Flex утилиты */
.row {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  flex-wrap: wrap;
}

.row-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-sm);
}

.col { display: flex; flex-direction: column; gap: var(--sp-sm); }
.col-lg { display: flex; flex-direction: column; gap: var(--sp-md); }

/* Разделитель */
.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
  margin: var(--sp-lg) 0;
}

.hidden { display: none !important; }

/* Landscape mobile (телефон лёжа) — компактные секции */
@media (max-height: 500px) and (orientation: landscape) {
  section { padding: var(--sp-md) 0; }
  .section-head { margin-bottom: var(--sp-md); }
}
