/* ============================================================
   templates.css — общие стили для шаблонов hero / hero-mirror /
   bullits / cards. Подключается на страницы внутренних модулей
   ПОСЛЕ module-page.css, чтобы при необходимости перекрывать.
   ============================================================ */

/* ============================================================
   1) HERO — pinned 2-slide stage.
   Базовая разметка .agg-stage* лежит в module-page.css; здесь —
   page-agnostic высота + мобильные overrides шаблона hero-template.
   ============================================================ */
.agg-stage {
  position: relative;
  height: 200vh;
  isolation: isolate;
}

@media (max-width: 768px) {
  .agg-stage { height: 200vh; }
  .agg-stage__pin {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: hidden;
  }
  .agg-stage__layout {
    grid-template-columns: 1fr;
    gap: 36px;
    padding: 16px 5vw 70px;
    align-items: start;
    align-content: start;
  }
  .agg-stage__col-text { gap: 12px; }
  .mpage-hero__headline { font-size: clamp(22px, 6vw, 30px); line-height: 1.15; }
  .mpage-hero__sub { font-size: 13px; line-height: 1.4; }
  .mpage-hero__pretitle { font-size: 11px; }

  /* Слоты дышат по контенту активного слайда. */
  .agg-stage__slot-text,
  .agg-stage__slot-mock { min-height: 0; }
  .agg-slide__text.is-visible,
  .agg-slide__mock.is-visible {
    position: relative;
    inset: auto;
  }
  .agg-slide__text:not(.is-visible),
  .agg-slide__mock:not(.is-visible) {
    position: absolute;
    inset: 0;
  }

  /* Компактный мок. */
  .agg-slide__mock .mpage-mock__row { padding: 6px 10px; font-size: 11px; gap: 6px; }
  .agg-slide__mock .mpage-mock__title { font-size: 13px; margin-bottom: 6px; }
  .agg-slide__mock .mpage-mock__body { padding: 10px 12px; gap: 6px; }
  .agg-slide__mock .mpage-mock__chrome { padding: 6px 10px; }

  /* Bubble — мобильная волна (union-f001m.svg, заранее повёрнутая
     версия). Заливка цветом текущей секции. */
  .agg-slide__bubble {
    z-index: 2;
    top: auto;
    bottom: calc(-100vw * 1557 / 613 + 35vw);
    left: 0;
    right: 0;
    width: 100vw;
    height: auto;
    aspect-ratio: 613 / 1557;
    transform: translateY(0);
    background-color: var(--section-current);
    -webkit-mask: url("assets/union-f001m.svg") center / 100% 100% no-repeat;
            mask: url("assets/union-f001m.svg") center / 100% 100% no-repeat;
  }
  .agg-slide__bubble:not(.is-visible) {
    transform: translateY(60px);
    opacity: 0;
  }
  .agg-slide__bubble.is-visible {
    transform: translateY(0);
    opacity: 0.9;
  }

  /* Точечная навигация — горизонтально по нижнему краю. */
  .agg-dots {
    display: flex;
    top: auto;
    right: auto;
    left: 50%;
    bottom: 16px;
    transform: translateX(-50%);
    flex-direction: row;
  }
}

/* ============================================================
   2) HERO MIRROR — мок слева, текст справа, bubble выезжает слева.
   Применяется через класс "hero-mirror" на секции .agg-stage.
   ============================================================ */
.hero-mirror .agg-stage__col-text { order: 2; }
.hero-mirror .agg-stage__slot-mock { order: 1; }

.hero-mirror .agg-slide__bubble {
  right: auto;
  left: -14vw;
  transform: translateY(-50%);
  -webkit-mask-position: left center;
          mask-position: left center;
}
.hero-mirror .agg-slide__bubble:not(.is-visible) {
  transform: translateY(-50%) translateX(-120px);
  opacity: 0;
}
.hero-mirror .agg-slide__bubble.is-visible {
  transform: translateY(-50%);
  opacity: 1;
}

/* На мобильном hero-mirror использует ту же волну снизу, что и hero —
   override left уже не нужен (bubble переопределён @media выше). */

/* ============================================================
   3) BULLITS — pinned 2-slide hero без мока, текст + 5 буллитов.
   Применяется через класс "bullits" на секции .agg-stage.
   ============================================================ */
.bullits .agg-stage__layout {
  grid-template-columns: 1fr;
  max-width: 760px;
}
.bullits .agg-stage__slot-text { min-height: 0; }
.bullits .agg-slide__text.is-visible {
  position: relative;
  inset: auto;
}
.bullits .agg-slide__text:not(.is-visible) {
  position: absolute;
  inset: 0;
}
.bullits .feature-block__bullets {
  margin: 0 0 36px;
}

/* ============================================================
   4) CARDS — секция с заголовком + 3×3 сетка карточек.
   Каждая карточка: цветной фон + bubble (union-f002.svg) поверх.
   Цветовые пары — атрибут data-color из брендбука fleetx, без
   полупрозрачности и наложений.
   ============================================================ */
.cards-section {
  padding: 80px clamp(20px, 5vw, 60px);
  max-width: 1280px;
  margin: 0 auto;
}
.cards-section__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
}
.cards-section__title {
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 800;
  line-height: 1.1;
  color: var(--ink, #0d3947);
  margin: 0 0 16px;
}
.cards-section__sub {
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.55;
  color: var(--fx-muted, #4a5b6a);
  margin: 0;
}
.cards-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
.cards-card {
  position: relative;
  overflow: hidden;
  padding: 28px 28px 32px;
  min-height: 220px;
  border-radius: 20px;
  background: var(--card-bg, #ffffff);
  color: var(--card-text, #0d3947);
  isolation: isolate;
}

/* Цветовые пары (фон / bubble / текст). */
.cards-card[data-color="green"]       { --card-bg: #79F395; --card-bubble: #0D3947; --card-text: #0D3947; }
.cards-card[data-color="yellow"]      { --card-bg: #F4C201; --card-bubble: #3E3100; --card-text: #3E3100; }
.cards-card[data-color="purple"]      { --card-bg: #D288E4; --card-bubble: #5A2776; --card-text: #5A2776; }
.cards-card[data-color="blue"]        { --card-bg: #3FBAE2; --card-bubble: #0D3947; --card-text: #0D3947; }
.cards-card[data-color="red"]         { --card-bg: #FF7B3D; --card-bubble: #470D0D; --card-text: #470D0D; }
.cards-card[data-color="dark-green"]  { --card-bg: #0D3947; --card-bubble: #79F395; --card-text: #FFFFFF; }
.cards-card[data-color="dark-purple"] { --card-bg: #5A2776; --card-bubble: #D288E4; --card-text: #FFFFFF; }
.cards-card[data-color="dark-yellow"] { --card-bg: #3E3100; --card-bubble: #F4C201; --card-text: #FFFFFF; }
.cards-card[data-color="dark-red"]    { --card-bg: #470D0D; --card-bubble: #FF7B3D; --card-text: #FFFFFF; }
.cards-card[data-color="white"]       { --card-bg: #FFFFFF; --card-bubble: #080609; --card-text: #080609; }
.cards-card[data-color="blue-swap"]   { --card-bg: #0D3947; --card-bubble: #3FBAE2; --card-text: #FFFFFF; }

.cards-card::after {
  content: "";
  position: absolute;
  top: 35%;
  left: 25%;
  width: 140%;
  aspect-ratio: 900 / 480;
  background-color: var(--card-bubble, var(--ink));
  -webkit-mask: url("assets/union-f002.svg") center / contain no-repeat;
          mask: url("assets/union-f002.svg") center / contain no-repeat;
  pointer-events: none;
  z-index: 0;
}
.cards-card > * {
  position: relative;
  z-index: 1;
}
.cards-card__title {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--card-text);
  margin: 0 0 12px;
}
.cards-card__desc {
  font-size: 14px;
  line-height: 1.5;
  color: var(--card-text);
  margin: 0;
}

@media (max-width: 768px) {
  .cards-section { padding: 48px 5vw; }
  .cards-section__header { margin-bottom: 32px; }
  .cards-section__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .cards-card {
    padding: 22px 22px 26px;
    min-height: 180px;
  }
  .cards-card__title { font-size: 18px; }
  .cards-card__desc { font-size: 13px; }
}
