.container {
    padding-left: var(--side-padding);
    padding-right: var(--side-padding);
    width: 100%;
    max-width: 100% !important;
      margin: 0 auto;
      position: relative;
}

.hero-section {
    position: relative;
    width: 100%;
    height: calc(100vh - 70px);
    overflow: hidden;
    background-color: rgba(238, 252, 255, 1);


}

.hero-background-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 1fr);
    width: 100%;
    height: 100%;
    gap: 5px;

}

.hero-background-grid img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Полупрозрачный блок по центру */
.hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none; /* чтобы не блокировать фон */
}

.hero-content-block {
    background-color: rgba(238, 252, 255, 0.95);
    padding: 40px;
    border-radius: 20px;
    text-align: center;
    max-width: 100%;
    height: 100vh;
    width: 100%;
    pointer-events: auto;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    /* Градиентная маска */
    -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,1) 60%, rgba(0,0,0,0) 100%);
    mask-image: radial-gradient(ellipse at center, rgba(238, 252, 255,1) 50%, rgba(0,0,0,0) 100%);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
}

.hero-logo {
    max-width: 300px;
    width: 100%;
    height: auto;
    margin-bottom: 20px;
}

.hero-organization {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--ch-ink);

}

.hero-slogan {
    font-size: 2rem;
    font-weight: 600;
    color: var(--ch-accent);

}

.hero-background-grid img {
    opacity: 0;
    transition: opacity 1s ease;
}

.hero-background-grid img.visible {
    opacity: 1;
}

/* Затемнение блока */
.hero-content-block {
    opacity: 0;
    transition: opacity 1.5s ease-in-out;
}

.hero-content-block.visible {
    opacity: 1;
}


/* Элементы внутри блока — скрыты отдельно */
.hero-logo,
.hero-organization,
.hero-slogan {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.hero-content-block.show-elements .hero-logo,
.hero-content-block.show-elements .hero-organization,
.hero-content-block.show-elements .hero-slogan {
    opacity: 1;
    transform: translateY(0);
}

/* ===== Адаптив ===== */
@media (max-width: 991px) {
    .hero-background-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(4, 1fr);
    }

    .hero-content-block {
        padding-top: 20px;

    }

    .hero-logo {
        max-width: 200px;
        margin-bottom: 15px;
    }

    .hero-organization {
        font-size: 1.8rem;
    }

    .hero-slogan {
        font-size: 1rem;
    }
}







.construction-hero{
  position: relative;
  padding: clamp(28px, 5vw, 100px) 0 clamp(28px, 5vw, 100px) 0;
}

.ch-container{
  width:100%;
  padding: 0 var(--side-padding);
  margin-inline:auto;

}

/* Eyebrow с оранжевой горизонтальной чертой слева */
.ch-eyebrow{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: .9rem;
  letter-spacing:.02em;
  color: var(--ch-muted);
  margin-bottom: 20px;
}
.ch-eyebrow::before{
  content:"";
  display:inline-block;
  width: 25px;
  height: 2px;
  background: var(--ch-accent);
  border-radius: 2px;
}

/* Отдельный заголовок */
.ch-title{
  font-family: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 700;
  color: var(--ch-ink);
  font-size: clamp(28px, 2.8vw, 44px);
  line-height:1.2;
  margin:0 0 25px;
  /* display:inline-block; transform: scaleY(0.92);  <- если нужен "приплюснутый" эффект */
}
.ch-title .accent{ color: var(--ch-accent); display:block; }

/* Ряд: текст слева — разделитель — услуги справа
   ВЫРАВНИВАНИЕ ПО ВЕРТИКАЛЬНОМУ ЦЕНТРУ */
.ch-head{
  display: grid;
  grid-template-columns: 1fr minmax(var(--ch-divider-width), var(--ch-divider-width)) 1fr;
  column-gap: clamp(16px, 3vw, 32px);    /* одинаковые отступы слева/справа от полосы */
  align-items: center;                    /* центруем левый/правый блок относительно друг друга */
  margin-bottom: clamp(16px, 3vw, 35px);
}
.ch-left, .ch-right { min-width: 0; }

/* Оранжевый вертикальный разделитель, настраиваемый */
.ch-divider{
  justify-self: center;
  width: var(--ch-divider-width);
  height: var(--ch-divider-height);
  background: var(--ch-divider-color);
  border-radius: 2px;
}

/* Модификатор: растянуть разделитель на всю высоту ряда */
.ch-divider--stretch{
  height: auto;
  align-self: stretch;
}

/* Текст слева */
.ch-lead{
  margin: 0;
  color: var(--ch-muted);
    text-align: justify-all;
  font-size: 1rem;
}

/* Услуги справа */
.ch-services{
  list-style:none; padding:0; margin: 0;
  display:flex; gap:15px; flex-wrap:wrap;
  justify-content:flex-start;
}
.ch-chip{
    font-family: "Montserrat", sans-serif;
  border:0;
    color:var(--ch-bg);
    font-weight: 600;
    background-color: var(--ch-ink);
  padding:10px 14px; border-radius:999px; font-size:1rem;
  cursor:default;
}

/* === Нижняя сетка === */
.ch-grid{
  display:grid;
  grid-template-areas: "image stats";
  grid-template-columns: 1fr minmax(260px, 320px);
  gap: 20px;
  align-items: stretch;
  margin-top: clamp(16px, 3vw, 24px);
}

.ch-figure img{ display:block; width:100%; height:100%; object-fit:cover; }

.ch-figure{
  grid-area:image;
    min-height: 350px;
  background:linear-gradient(135deg, #13224b 0, #0b1640 100%);
  border-radius: var(--ch-radius);
  position: relative;
  overflow:hidden;
  box-shadow: var(--ch-shadow);
}

.ch-play{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;

  width: 76px;
  height: 76px;
  border: 0;
  border-radius: 999px;
  display: grid;
  place-items: center;
  cursor: pointer;

  background: rgba(255,255,255,.95);
  color: var(--ch-ink);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.ch-play:hover{ transform: translate(-50%, -50%) scale(1.03); box-shadow: 0 12px 36px rgba(0,0,0,.3); }
.ch-play:active{ transform: translate(-50%, -50%) scale(.98); }

.ch-play-icon{
  font-weight: 800;
  font-size: 2rem;
 padding-left: 5px;
}

/* Пульсирующее кольцо */
.ch-play::after{
  content:"";
  position:absolute;
  inset:-10px;           /* радиус кольца больше круга */
  border: 2px solid rgba(255,255,255,.85);
  border-radius: 999px;
  animation: ch-pulse 1.6s ease-out infinite;
  pointer-events: none;
}
@keyframes ch-pulse{
  0%   { transform: scale(1);   opacity:.85; }
  70%  { transform: scale(1.6); opacity: 0;  }
  100% { opacity: 0; }
}

/* === Модалка полноэкранного видео === */
.ch-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}
.ch-modal.is-open{ display: block; }

.ch-modal__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(2px);
}

.ch-modal__dialog{
  position: absolute;
  inset: 5%;
  background: transparent;
  overflow: hidden;
}

/* Крестик */
.ch-modal__close{
  position: absolute;
  top: max(10px, env(safe-area-inset-top));
  right: max(12px, env(safe-area-inset-right));
  z-index: 2;
  border: 0;
  background: rgba(255,255,255,.12);
  color: #fff;
  width: 40px; height: 40px;
  border-radius: 999px;
  display: grid; place-items: center;
  cursor: pointer;
  backdrop-filter: blur(2px);
}
.ch-modal__close:hover{ background: rgba(255,255,255,.22); }

/* Контейнер игрока — центрируем, даём чёрный фон */
.ch-modal__player{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;           /* границы/письмо-бокс */
  overflow: hidden;
}

/* Само видео/iframe — вписываем без обрезки */
.ch-modal__player > video,
.ch-modal__player > iframe {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;        /* ключевая строка */
  object-position: center center;
  background: #000;
  display: block;
}

/* Мобильные — убираем поля по краям */
@media (max-width: 640px){
  .ch-modal__dialog{ inset: 0; border-radius: 0; }
}

/* Блокируем прокрутку страницы, когда модалка открыта */
.no-scroll { overflow: hidden; }

.ch-stats{
    position: relative;
  grid-area:stats;
    display: flex;
  flex-direction: column;
  justify-content: center; /* чтобы цифры были по центру */
  gap: 35px; /* немного увеличим промежутки */
  padding: 35px; /* больше воздуха */
  background: var(--ch-accent);
  color:#fff;
  border-radius: var(--ch-radius);
  box-shadow: var(--ch-shadow);
}

.ch-stats::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient( -45deg,
      rgba(255,255,255,.2) 0 12px,
      transparent 12px 24px);
  opacity:.25;
}

.ch-stat{ display:flex; flex-direction:column; gap:4px; }
.ch-num{ font-size: clamp(26px, 4vw, 55px); font-weight:800; line-height:1; }
.ch-label{
    font-size: 1rem;
    opacity:.95;
    font-weight: 600;
}



/* ====== АДАПТИВ ====== */
@media (max-width: 1199px){
  .ch-grid{ grid-template-columns: 1fr 320px; }
}

@media (max-width: 767px){
  .ch-head{
    grid-template-columns: 1fr;
    row-gap: 14px;
    align-items: start; /* на мобильных отдаём приоритет верхнему краю */
  }
  .ch-divider{ display:none; }

  .ch-services{
      overflow:auto; padding-bottom:6px;
  }
  .ch-services::-webkit-scrollbar{ height:6px; }
  .ch-services::-webkit-scrollbar-thumb{ background:rgba(0,0,0,.12); border-radius:999px; }

  .ch-grid{
    grid-template-areas:
      "image"
      "stats";
    grid-template-columns: 1fr;
  }
  .ch-stats{
    flex-direction: row;
      flex-wrap: wrap;
    justify-content: space-between;
    gap:12px;
    padding:16px;
  }


  .ch-stat{ flex:1; text-align:center; }
  .ch-label{ font-size:.85rem; }

}

@media (max-width: 450px) {
    .ch-head{
    grid-template-columns: 1fr;
    row-gap: 14px;
    align-items: start;
  }
  .ch-divider{ display:none; }

  .ch-services{
      overflow: auto; padding-bottom: 6px;
  }
  .ch-services::-webkit-scrollbar{ height:6px; }
  .ch-services::-webkit-scrollbar-thumb{ background:rgba(0,0,0,.12); border-radius:999px; }

  .ch-grid{
    grid-template-areas:
      "image"
      "stats";
    grid-template-columns: 1fr;
  }

  .ch-stats{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;                  /* переносим элементы */
    justify-content: flex-start;      /* без растягивания пробелами */
    gap: 12px;
    padding: 16px;
  }

  /* Две колонки: (100% - промежуток) / 2 */
  .ch-stats .ch-stat{
    flex: 0 0 calc((100% - 12px) / 2);
    text-align: center;
  }

  .ch-label{ font-size:.85rem; }

}






.about-section{
  padding: clamp(28px, 5vw, 100px) 0;
    background-color: var(--ch-bg);
}
.about-container{
  width: 100%;
  padding: 0 var(--side-padding);
  margin-inline: auto;
}

/* Eyebrow */
.about-eyebrow{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: .9rem;
  color: var(--ch-muted);
  margin-bottom: 20px;
}
.about-eyebrow::before{
  content:"";
  width: 25px; height: 2px;
  background: var(--ch-accent);
  border-radius: 2px;
}

/* Заголовок */
.about-title{
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  color: var(--ch-ink);
  font-size: clamp(28px, 2.8vw, 44px);
  line-height: 1.2;
  margin: 0 0 20px;
}
.about-title .accent{ color: var(--ch-accent); display:block; }

/* Ряд: текст слева — кнопка справа */
.about-head-row{
  display: flex;
  align-items: center;
  justify-content: space-between; /* текст слева, кнопка справа */
  gap: 20px;
  margin-bottom: 20px;
}
.about-lead{
  margin: 0;
  color: var(--ch-muted);
  font-size: clamp(14px, 1.2vw, 16px);

  max-width: 50%;
  text-align: left; /* выравнивание текста слева */
}
.about-btn{
  padding: 12px 20px;
  border-radius: 999px;
  background: var(--ch-accent);
  color: #fff;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: transform .15s ease, filter .2s ease;
}
.about-btn:hover{ transform: translateY(-1px); filter: brightness(0.95); }

/* Нижний блок */
.about-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: stretch;  /* одинаковая высота */
  margin-top: clamp(16px, 3vw, 35px);
}
.about-photo,
.about-mission{
  min-height: 300px;  /* было 400px, стало ниже */
  border-radius: var(--ch-radius);
  box-shadow: var(--ch-shadow);
}

/* Фото */
.about-photo{
  position: relative;
    max-height: 340px;
  overflow: hidden;
  background: linear-gradient(135deg, #13224b 0, #0b1640 100%);
}
.about-photo img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.about-badge{
  position:absolute; right:16px; bottom:16px;
  display:flex; flex-direction:row; /* число слева, текст справа */
  align-items:center;
  gap:12px;
  padding: 14px 18px;
  background: var(--ch-accent);
  color:#fff;
  border-radius: var(--ch-radius);
  box-shadow: var(--ch-shadow);
}

/* Число */
.about-badge strong{
  font-size: 2.4rem;   /* ещё больше */
  font-weight: 800;
  line-height: 1;
}

/* Текст справа от числа */
.about-badge-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  line-height: 1.2;
}

/* "Років" */
.about-badge .years{
  font-size: 1.2rem;
  font-weight: 700;

}

/* "досвіду" */
.about-badge .exp{
  font-size: 1rem;
  font-weight: 500;
  opacity:.9;
}


/* Миссия */
.about-mission{
    position: relative;
  background: color-mix(in oklab, var(--ch-surface) 92%, #000 8%);
  color:#fff;
  padding: 24px;
  display:flex; flex-direction:column; justify-content:space-between;
}

.about-mission::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient( -45deg,
      rgba(255,255,255,.06) 0 12px,
      transparent 12px 24px);
  opacity:.25;
}

.about-mission p{
  margin:0 0 20px;
  font-size: 1.15rem;
  opacity:.95;
}
.about-mission-footer{
  display:flex; align-items:center; justify-content:space-between;
}
.about-mission-title{ color: var(--ch-accent); font-weight:700; }
.about-mission-btn{
  width: 36px; height: 36px;
  border-radius: 50%;
  border: none;
  background: var(--ch-accent);
  color:#fff;
  font-size: 1.2rem;
  cursor: pointer;
}

/* Контейнер миссии остаётся прежним: .about-mission ... */

/* Слайды */
.mission-slides{
  position: relative;
  isolation: isolate;
  min-height: 140px; /* фиксируем оптическую высоту, чтобы при переключении не прыгало */
}
.mission-slide{
  display: none;
  animation: missionFade .25s ease;
}
.mission-slide.is-active{ display: block; }

@keyframes missionFade{
  from{ opacity: 0; transform: translateY(6px); }
  to{ opacity: 1; transform: translateY(0); }
}

/* Навигация */
.mission-nav{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.mission-btn{
  width: 36px; height: 36px;
  border-radius: 50%;
  border: none;
  background: var(--ch-accent);
  color:#fff;
  font-size: 16px;
  cursor: pointer;
  transition: transform .15s ease, filter .2s ease, opacity .2s ease;
}
.mission-btn:hover{ transform: translateY(-1px); filter: brightness(0.95); }

/* Недоступные кнопки */
.mission-btn:disabled{
  cursor: not-allowed;
  opacity: .45;
  transform: none;
  filter: none;
}

/* Чуть ужмём нижний отступ абзацев внутри слайдов, чтобы компоновка не плавала */
.mission-slide p{ margin: 0 0 12px; font-size: 1.15rem; line-height: 1.55; opacity: .95; }


/* Адаптив */
@media (max-width: 991px){
  .about-head-row{ flex-direction: column; align-items: flex-start; }
  .about-lead{ max-width: 100%; }
  .about-grid{ grid-template-columns: 1fr; }
  .about-photo, .about-mission{ min-height: 320px; }

}

@media (max-width: 991px) {
    .about-mission p {
        margin: 0 0 20px;
        font-size: 16px;
        opacity: .95;
    }
}








/* ===== Services Section (slider edition) ===== */
.services{ padding: clamp(40px,5vw,90px) 0; background: rgba(238, 252, 255, 1); }
.svc-container{ width:100%; margin-inline:auto; padding:0 var(--side-padding); }

/* Заголовок секции по центру */
.svc-head{ text-align:center; }
.svc-eyebrow{
  display:inline-flex; align-items:center; gap:10px; justify-content:center;
  color:var(--ch-muted); font-size:.9rem; margin-bottom:20px; position:relative;
}
.svc-eyebrow::before{ content:""; width:25px; height:2px; background:var(--ch-accent); border-radius:2px; }

.svc-title{
  font-family:"Montserrat",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  font-weight:700; color:var(--ch-ink);
  font-size: clamp(28px,2.6vw,42px); line-height:1.2; margin:0 0 35px;
  text-align:center;
}
.svc-title .accent{ color:var(--ch-accent); display:block; }

/* === Swiper контейнер вместо grid === */
.svc-swiper{ overflow:hidden; }
.svc-swiper .swiper-wrapper{ align-items: stretch; }
.svc-swiper .swiper-slide{ height:auto; display:flex; }
.svc-swiper .swiper-slide > .svc-card{ width:100%; display:flex; flex-direction:column; }

/* Отступы между слайдами управляются через JS: spaceBetween */

/* Карточка */
.svc-card{
  background:#fff; border-radius:16px;  border: 2px solid rgba(250, 158,0,.25);
  overflow:hidden; position:relative; display:flex; flex-direction:column;
  transition: box-shadow .2s ease, border-color .2s ease, transform .15s ease;
}
.svc-card:hover{
    border: 2px solid rgba(250, 158,0,1);

}

/* Медиа */
.svc-media{ position:relative; height:250px; overflow:hidden; background:#eee; }
.svc-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.svc-media::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  -webkit-mask:
    radial-gradient(40px at top left, transparent 98%, #000 100%) top left,
    linear-gradient(#000 0 0) center/100% 100%;
  -webkit-mask-composite: destination-out;
  mask:
    radial-gradient(40px at top left, transparent 98%, #000 100%) top left,
    linear-gradient(#000 0 0) center/100% 100%;
  mask-composite: exclude;
}

/* Тело карточки */
.svc-body{ padding:18px 18px; padding-top:40px; position:relative; display:flex; flex-direction:column; gap:15px; flex:1; }

/* Иконка */
.svc-icon{
  position:absolute; top:-35px; left:35px;
  width:70px; height:70px; border-radius:50%;
  background:var(--ch-surface); color:#fff; display:grid; place-items:center;
  box-shadow: 0 6px 16px rgba(0,0,0,.15);
}
.svc-icon i{ font-size:30px; }

/* Тексты */
.svc-name{ margin:10px 0 0; font-size:1.15rem; color:var(--ch-surface); font-weight:700; }
.svc-text{ margin-top:10px; color:var(--ch-muted); font-size:.95rem; line-height:1.5; }

/* Ссылка */
.svc-link{
  margin-top:auto; display:inline-flex; align-items:center; gap:6px;
  color: var(--ch-surface);
  font-weight:600; text-decoration:none;
  transition: color .2s ease, transform .15s ease;
}
.svc-link:hover{ color: var(--ch-accent); transform: translateY(-1px); }

/* Навигация/пагинация слайдера */
.svc-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  z-index:3; width:36px; height:36px; border:0; border-radius:50%;
  background: color-mix(in oklab, var(--ch-ink) 100%, transparent 50%);
  color:#fff; display:grid; place-items:center; cursor:pointer;
  box-shadow: var(--ch-shadow);
}
.svc-prev{ left:6px; }
.svc-next{ right:6px; }
.svc-nav i{ font-size:18px; line-height:1; }

.svc-pagination{
  position:relative; margin-top:16px; text-align:center;
}
.svc-pagination .swiper-pagination-bullet{ background: rgba(255,255,255,.65); }
.svc-pagination .swiper-pagination-bullet-active{ background:#fff; }

/* Footer */
.svc-footer{ display:flex; justify-content:center; margin-top:35px; }
.svc-all{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 22px; border-radius:999px;
  background:var(--ch-accent); color:#fff; font-weight:700; text-decoration:none;
  transition: transform .15s ease, filter .2s ease;
}
.svc-all:hover{ transform: translateY(-1px); filter: brightness(0.95); }

@media (min-width: 1024px){
  .svc-nav{ display:none !important; }
}

/* Responsive */
@media (max-width: 640px){
  .svc-title{ text-align:left; }
  .svc-media{ height:200px; }
  /* Скрыть стрелки на узких экранах (по желанию) */

}







/* ===== Workflow Section ===== */
.workflow{
  padding: clamp(40px, 5vw, 90px) 0;
  background: var(--ch-bg);
}
.wf-container{
  width: 100%;
  margin-inline: auto;
  padding: 0 var(--side-padding);
}

/* Заголовок */
.wf-head{ margin-bottom: 50px;   }
.wf-eyebrow{
  display: inline-flex; align-items: center; gap: 10px; justify-content: center;
  color: var(--ch-muted); font-size: .9rem; margin-bottom: 12px; position: relative;
}
.wf-eyebrow::before{
  content:""; width:25px; height:2px; background: var(--ch-accent); border-radius: 2px;
}
.wf-title{
  font-family:"Montserrat", sans-serif;
  font-weight: 700; color: var(--ch-ink);
  font-size: clamp(28px, 2.6vw, 42px); line-height: 1.2;
}
.wf-title .accent{ color: var(--ch-accent); }

/* ===== Steps timeline ===== */
.wf-steps{
  display: grid;
  grid-template-columns: repeat(3,1fr);
  position: relative;
  gap: 30px;
  margin-bottom: 40px;
}

/* Горизонтальная линия под шагами */
.wf-steps::before{
  content:"";
  position: absolute;
  top: 45%;
  left: 10%;
  right: 10%;
  height: 2px;
  background: var(--ch-accent);
  z-index: 1;
}



/* Шаги (без рамок — чистые карты) */
.wf-step{
  background: #fff;
  position: relative;
  padding: 30px 20px;
  border-radius: var(--ch-radius);
  z-index: 2;

  /* Базовая «спящая» рамка */
  border: 2px solid rgba(250, 158, 0, 0.23);

  /* Параметры подсветки и цикл */
  --wf-highlight: var(--ch-accent);
  --wf-shadow: rgba(250,158,0,.35);
  --wf-cycle: 3s;      /* длительность полного круга из 3 шагов */
  --wf-lift: 2px;      /* подъём при подсветке */

  /* Синхронная анимация: общий таймер и отрицательные задержки */
  animation: wfPulse var(--wf-cycle) cubic-bezier(.22,.61,.36,1) infinite;
  animation-delay: 0s; /* будет переопределено ниже через --i */
  will-change: border-color, box-shadow, transform;
  transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}

.wf-step::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient( -45deg,
      rgba(250,158,0,.11) 0 12px,
      transparent 12px 24px);
  opacity:.25;
}

/* Индексы шагов (для фаз анимации) */
.wf-step:nth-child(1){ --i: 0; animation-delay: calc(var(--i) * 1s); }
.wf-step:nth-child(2){ --i: 1; animation-delay: calc(var(--i) * 1s); }
.wf-step:nth-child(3){ --i: 2; animation-delay: calc(var(--i) * 1s); }

/* Ключевые кадры — плавное «набор → держим → затухание» */
@keyframes wfPulse{
  /* старт: погашен */
  0%{
    border-color: rgba(250,158,0,.23);
    box-shadow: none;
    transform: none;
  }
  /* мягкий набор (~0.3с) */
  10%{
    border-color: var(--wf-highlight);
    box-shadow: 0 14px 36px var(--wf-shadow);
    transform: translateY(calc(-1 * var(--wf-lift)));
  }
  /* держим до 33% цикла (1 секунда из 3) */
  33%{
    border-color: var(--wf-highlight);
    box-shadow: 0 14px 36px var(--wf-shadow);
    transform: translateY(calc(-1 * var(--wf-lift)));
  }
  /* плавное затухание (~0.3с) */
  45%{
    border-color: rgba(250,158,0,.23);
    box-shadow: none;
    transform: none;
  }
  /* остаток цикла — ждём своей очереди */
  100%{
    border-color: rgba(250,158,0,.23);
    box-shadow: none;
    transform: none;
  }
}

/* Контент шага */
.wf-step-num{
  font-size: .9rem;
  font-weight: 700;
  color: #fff;
  background: var(--ch-surface);
  padding: 6px 14px;
  border-radius: 999px;
  display: inline-block;
  margin-bottom: 20px;
}
.wf-step-title{
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ch-surface);
  margin: 0;
}
.wf-step-text{
  font-size: .95rem;
  color: var(--ch-muted);
  margin: 10px 0 0;
  line-height: 1.5;
}

/* Доступность: отключаем анимации при reduced motion */
@media (prefers-reduced-motion: reduce){
  .wf-step{ animation: none; }
}

/* Адаптив */
/* Адаптив */
@media (max-width: 991px){
  .wf-steps{
    grid-template-columns: 1fr;
    gap: 50px; /* расстояние между шагами по вертикали */
    position: relative;
  }

    /* Линия становится вертикальной */
  .wf-steps::before{
    top: 0;
    bottom: 0;
    left: 50%;
    right: auto;
    width: 2px;
    height: 100%;
    transform: translateX(-50%);
  }
}








/* =========================================================
   Spilna Peremoha — Production Section (polished)
   File: sp-production.css
   Depends on: Swiper v10+ (классики .swiper-*)
   Icons: Bootstrap Icons (по желанию)
   ========================================================= */

/* ---------- CSS Vars & Fallbacks ---------- */


/* ---------- Section Shell ---------- */
/* ========== CSS: SP Production (merged showcase) ========== */


/* Section */
/* ===== Spilna Peremoha — Production Section (FULL) ===== */

/* ===== Section ===== */
.sp-prod{
  background: var(--ch-surface);
  padding: clamp(40px,5vw,110px) 0;
  position: relative;
  overflow: hidden;
}

.sp-prod__container{
  width:100%;
  margin-inline:auto;
  padding:0 var(--side-padding);
}

/* ===== Head ===== */
.sp-prod__head{
  display:grid;

  gap:clamp(16px,3vw,28px);
  align-items:center;
  margin-bottom:clamp(22px,3.5vw,40px);
    text-align: center;
}


.sp-prod__eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  color:var(--ch-bg); font-size:.95rem;
    margin-bottom: 10px;
}
.sp-prod__eyebrow::before{
  content:""; width:24px; height:2px; background:var(--ch-accent); border-radius:2px;
}

.sp-prod__title{
  margin:.25rem 0 0;
  font-family:"Montserrat",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-weight:700; color:#fff; font-size:clamp(28px,3vw,44px); line-height:1.1;
    text-align: center;
}
.sp-prod__title .accent{ color:var(--ch-accent); display:block; }

.sp-prod__lead{
  margin:0; color:rgba(255,255,255,.85);
  max-width:880px; font-size:clamp(15px,1.2vw,18px);
}

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

/* ===== Stage (left mission / right showcase) ===== */
.sp-prod__stage{
  display:grid;
  grid-template-columns: 1fr 2fr;
  gap:clamp(18px,3vw,28px);
  align-items:stretch;
}
@media (max-width:1100px){
  .sp-prod__stage{ grid-template-columns:1fr; }
}

/* ===== Mission (left) ===== */
.sp-prod__mission{
  position: sticky; top: 90px;
  background: rgba(31,42,68,.9);
  color:#fff; padding: clamp(18px,2vw,22px);
  border-radius:20px; box-shadow: var(--ch-shadow);
  border:1px solid rgba(255,255,255,.08);
  height:100%;
  backdrop-filter: blur(6px);
}
@media (max-width:1100px){ .sp-prod__mission{ position:static; } }

.sp-prod__mission-title{ margin:0 0 10px; color:#fff; font-size:1.1rem; letter-spacing:.02em; }
.sp-prod__mission-text{ margin:0 0 16px; font-size:1rem; opacity:.95; }
.sp-prod__bullets{ list-style:none; padding:0; margin:0 0 16px; display:grid; gap:10px; }
.sp-prod__bullets li{ display:flex; align-items:center; gap:10px; font-weight:600; opacity:.95; }
.sp-prod__bullets i{ color:var(--ch-accent); font-size:1.05em; }

.sp-prod__portfolio{ margin:16px 0; }
.sp-prod__portfolio-title{ margin:0 0 8px; color:#fff; font-weight:800; }
.sp-prod__portfolio-list{ margin:0; padding-left:18px; color:#fff; opacity:.95; line-height:1.5; }

.sp-prod__cta{
  display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px;
  text-decoration:none; font-weight:700; background:var(--ch-accent); color:#111;
  box-shadow: 0 12px 26px rgba(250,158,0,.25);
}
.sp-prod__cta:focus-visible{ outline:2px solid #fff; outline-offset:2px; }

/* ===== Showcase (right) ===== */
.sp-prod__showcase{ height:100%; min-width:0; }
.sp-prod__showcase-inner{
  display:flex; flex-direction:column;
  background:#0b0d12; border:1px solid rgba(255,255,255,.06);
  border-radius:20px; padding:14px; height:100%;
}

/* Header над слайдером */
.sp-prod__films-head{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  margin-bottom:10px;
}
.sp-prod__films-title{ margin:0; font-size:1.05rem; font-weight:800; color:#fff; }
.sp-prod__nav{ display:flex; gap:8px; }
.sp-prod__nav-btn{
  width:40px; height:40px; border-radius:12px; border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.14); color:#fff; display:grid; place-items:center;
  box-shadow: var(--ch-shadow); cursor:pointer; transition: background .25s ease, transform .2s ease;
}
.sp-prod__nav-btn:hover{ background: rgba(255,255,255,.22); transform: translateY(-1px); }
.sp-prod__nav-btn:disabled{ opacity:.4; cursor:not-allowed; }

/* ===== Viewport: центрируем содержимое ===== */
.sp-prod__films-viewport{
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  padding: 8px;
  background: #0b0d12;
  display: flex;
  justify-content: center;   /* центр по горизонтали */
  align-items: center;
}

/* ===== Swiper: ограничиваем ширину и центрируем ===== */
.prod-films-swiper{
  width: 100%;
  max-width: clamp(640px, 88vw, 1120px);
  margin: 0 auto;    /* центр */
  overflow: hidden;
  box-sizing: border-box;
}

.prod-films-swiper .swiper-wrapper{
  align-items: stretch;
}

/* Ширина слайда = ширине контейнера */
.prod-films-swiper .swiper-slide{
  flex: 0 0 100% !important;
  width: 100% !important;
  height: auto;
}

/* ===== Пара постеров внутри одного слайда ===== */
.sp-prod__pair{
  display: grid;
  grid-template-columns: 1fr 1fr;  /* два постера на слайд */
  gap: 16px;
  align-items: stretch;
}

/* ===== Карточка постера ===== */
.sp-prod__poster{
  position: relative;
  background:#0b0d12;
  border-radius: 16px;
  overflow: hidden;
  margin: 0;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.sp-prod__poster img{
  width:100%;
  height:auto;
  object-fit: cover;
  display:block;
  transition: transform .45s ease;
}

.sp-prod__poster:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.14);
}
.sp-prod__poster:hover img{ transform: scale(1.03); }

/* Название фильма (видимое) */
.sp-prod__film-title{
  text-align:center;
  color:#fff;
  font-weight:800;
  font-size:1.05rem;
  letter-spacing:.01em;
  padding:12px 12px 14px;
  background:#0b0d12;
}

/* (Старый) caption оставлен для совместимости, но не используется как основной заголовок */
.sp-prod__caption{ display:none; }

/* Кнопка трейлера / бейдж статуса */
.sp-prod__watch{
  position:absolute; right:12px; bottom:56px;
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 12px; border-radius:999px; border:0;
  background:rgba(255,255,255,.92); color:#111; font-weight:800;
  box-shadow: 0 10px 24px rgba(0,0,0,.25); cursor:pointer;
}
.is-inprogress .sp-prod__watch{ display:none; }

.sp-prod__badge{
  position:absolute; left:12px; top:12px;
  padding:6px 12px; border-radius:999px; background:var(--ch-accent); color:#111;
  font-weight:700; font-size:.85rem;
}
.is-released .sp-prod__badge{ display:none; }

/* ===== Modal ===== */
.prod-modal{ position:fixed; inset:0; z-index:1000; display:none; }
.prod-modal.is-open{ display:block; }
.prod-modal__backdrop{ position:absolute; inset:0; background: rgba(0,0,0,.7); backdrop-filter: blur(2px); }
.prod-modal__dialog{ position:absolute; inset:5%; background:#000; overflow:hidden; border-radius:14px; }
@media (max-width:640px){ .prod-modal__dialog{ inset:0; border-radius:0; } }
.prod-modal__close{
  position:absolute; top:max(10px, env(safe-area-inset-top)); right:max(12px, env(safe-area-inset-right));
  z-index:2; width:40px; height:40px; border-radius:999px; border:0;
  background: rgba(255,255,255,.12); color:#fff; display:grid; place-items:center;
}
.prod-modal__close:focus-visible{ outline:2px solid #fff; outline-offset:2px; }
.prod-modal__player{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:#000; }
.prod-modal__player > video, .prod-modal__player > iframe{ width:100%; height:100%; object-fit:contain; background:#000; display:block; }

/* ===== Lock scroll when modal open ===== */
html.no-scroll, body.no-scroll{ overflow:hidden; }

/* ===== Адаптив ===== */
@media (max-width:780px){
  .sp-prod__pair{ grid-template-columns: 1fr; }
  .prod-films-swiper{ max-width: 100%; }
}

.sp-prod .prj-card {
    grid-template-columns: none;
}


/* Play overlay */
.pv-slide { position: relative; }
.pv-play{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;

  width: 76px;
  height: 76px;
  border: 0;
  border-radius: 999px;
  display: grid;
  place-items: center;
  cursor: pointer;

  background: rgba(255,255,255,.95);
  color: var(--ch-ink);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.pv-play:hover{ transform: translate(-50%, -50%) scale(1.04); }
.pv-play:focus{ outline: 2px solid rgba(255,255,255,.8); outline-offset: 2px; }

.pv-play::after{
  content:"";
  position:absolute;
  inset:-10px;           /* радиус кольца больше круга */
  border: 2px solid rgba(255,255,255,.85);
  border-radius: 999px;
  animation: ch-pulse 1.6s ease-out infinite;
  pointer-events: none;
}
@keyframes ch-pulse{
  0%   { transform: scale(1);   opacity:.85; }
  70%  { transform: scale(1.6); opacity: 0;  }
  100% { opacity: 0; }
}

.pv-play__icon{
  width: 0; height: 0;
  border-left: 18px solid var(--ch-ink);
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  margin-left: 4px;

}

.ch-play{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;

  width: 76px;
  height: 76px;
  border: 0;
  border-radius: 999px;
  display: grid;
  place-items: center;
  cursor: pointer;

  background: rgba(255,255,255,.95);
  color: var(--ch-ink);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.ch-play:hover{ transform: translate(-50%, -50%) scale(1.03); box-shadow: 0 12px 36px rgba(0,0,0,.3); }
.ch-play:active{ transform: translate(-50%, -50%) scale(.98); }

.ch-play-icon{
  font-weight: 800;
  font-size: 2rem;
 padding-left: 5px;
}

/* Пульсирующее кольцо */
.ch-play::after{
  content:"";
  position:absolute;
  inset:-10px;           /* радиус кольца больше круга */
  border: 2px solid rgba(255,255,255,.85);
  border-radius: 999px;
  animation: ch-pulse 1.6s ease-out infinite;
  pointer-events: none;
}
@keyframes ch-pulse{
  0%   { transform: scale(1);   opacity:.85; }
  70%  { transform: scale(1.6); opacity: 0;  }
  100% { opacity: 0; }
}

@media (max-width: 576px){
  .pv-play{ width: 56px; height: 56px; }
  .pv-play__icon{ border-left-width: 16px; border-top-width: 10px; border-bottom-width: 10px; }
}

/* Modal */
.prod-modal[aria-hidden="true"]{ display: none; }
.prod-modal[aria-hidden="false"]{ display: block; }

.prod-modal__backdrop{
  position: fixed; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(2px);
}
.prod-modal__dialog{
  position: fixed; inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: min(100vw - 40px, 960px);
  background: #000; border-radius: 12px; overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
}
.prod-modal__player{
  position: relative; width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
}
.prod-modal__player iframe,
.prod-modal__player video{
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: 0; display: block;
  background: #000;
}
.prod-modal__close{
  position: absolute; top: 8px; right: 8px;
  width: 36px; height: 36px; border-radius: 999px;
  border: 0; background: rgba(255,255,255,.12); color: #fff;
  cursor: pointer; font-size: 18px; line-height: 1;
}
.prod-modal__close:hover{ background: rgba(255,255,255,.22); }

.body--lock { overflow: hidden; }




/* ===== Projects (Completed Projects) =====
   использует только переменные из твоего :root
   --ch-bg, --ch-ink, --ch-accent, --ch-muted, --ch-surface, --ch-radius, --ch-shadow
*/
/* ===== Projects (Completed Projects) ===== */
.projects{
    position: relative;
  background: color-mix(in oklab, var(--ch-surface) 92%, #000 8%);
  padding: clamp(40px, 6vw, 120px) 0;
  color: #fff;
}


.prj-container{
  width: 100%;
  margin-inline: auto;
  padding: 0 var(--side-padding);
}

/* Заголовок */
.prj-head{ text-align:center; margin-bottom: clamp(24px,3vw,40px); }
.prj-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  color: rgba(255,255,255,.8); font-size:.95rem; margin-bottom:10px;
}
.prj-eyebrow::before{ content:""; width:24px; height:2px; background: var(--ch-accent); border-radius:2px; }
.prj-title{
  font-family:"Montserrat",sans-serif; font-weight:700;
  font-size: clamp(28px,3vw,42px); line-height:1.15; margin:0; color:#fff;
}
.prj-title .accent{ color: var(--ch-accent); }

/* Карта проекта: ЕДИНЫЙ полупрозрачный блок (фото + описание) */
.prj-card{
  display:grid;
  grid-template-columns: 1fr 1fr;
  padding: 10px;
  border-radius: var(--ch-radius);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--ch-shadow);
  margin-bottom: clamp(18px,3vw,28px);
}
.prj-card.is-reverse{ grid-auto-flow: dense; }
.prj-card.is-reverse .prj-media{ order: 2; }
.prj-card.is-reverse .prj-content{ order: 1; }

/* Медиа */
.prj-media{
  position: relative;
  border-radius: calc(var(--ch-radius) - 6px);
  overflow: hidden;
  min-height: 280px;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--ch-surface) 78%, #000 22%) 0%,
    color-mix(in oklab, var(--ch-surface) 62%, #000 38%) 100%);
}
.prj-media img{ width:100%; height:100%; object-fit:cover; display:block; }
/* Срез угла сверху справа */
.prj-media::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  -webkit-mask:
    radial-gradient(46px at top right, transparent 98%, #000 100%) top right,
    linear-gradient(#000 0 0) center/100% 100%;
  -webkit-mask-composite: destination-out;
  mask:
    radial-gradient(46px at top right, transparent 98%, #000 100%) top right,
    linear-gradient(#000 0 0) center/100% 100%;
  mask-composite: exclude;
}

/* Бейджи на фото */
.prj-badges{
  position:absolute; left:14px; bottom:14px;
  display:flex; gap:10px; flex-wrap:wrap;
}
.prj-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 12px; border-radius:999px;
  background:transparent; color: #ffffff;
    border: 1px solid #ffffff;
  font-weight:500; font-size:.85rem; backdrop-filter: blur(6px);
}

/* Контент (без собственного фона) */
.prj-content{ display:flex; flex-direction:column; justify-content:center;  padding: 20px}
.prj-name{ margin:0 0 8px; font-size: clamp(18px,2vw,26px); font-weight:600; color:#fff; }
.prj-lead{ margin:0; color: rgba(255,255,255,.85); font-size:1rem; line-height:1.55; }

/* Метаданные */
.prj-meta{ list-style:none; padding:0; margin:35px 0; display:grid; gap:12px; }
.prj-meta li{ display:flex; align-items:center; gap:12px; font-weight:500; color:#fff; }
.prj-meta li span strong{
    font-weight: 600;
    color:var(--ch-accent);
}

/* Оранжевые кружки с белыми иконками */
.prj-ico{
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--ch-accent); color:#fff;
  display:grid; place-items:center; flex:0 0 34px;
  box-shadow: 0 8px 18px rgba(250,158,0,.25);
}
.prj-ico i{ font-size: 16px; line-height: 1; }

/* Ссылка */
.prj-link{
  display:inline-flex; align-items:center; justify-content:center;
  padding:8px 16px; border-radius:999px; background: var(--ch-accent);
  color:#fff; font-weight:600; text-decoration:none;
  box-shadow: 0 10px 24px rgba(250,158,0,.25);
  transition: transform .15s ease, filter .2s ease;
    width: 100%;
    max-width: 215px;
}
.prj-link:hover{ transform: translateY(-1px); opacity:1; }

/* Footer CTA */
.prj-footer{ display:flex; justify-content:center; margin-top: 50px; }
.prj-cta{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 22px; border-radius:999px; background: var(--ch-accent);
  color:#fff; font-weight:600; text-decoration:none;
  box-shadow: 0 10px 24px rgba(250,158,0,.25);
  transition: transform .15s ease, filter .2s ease;
}
.prj-cta:hover{ transform: translateY(-1px); filter: brightness(.95); }


/* Контейнер слайдера занимает всю медиа-зону */
.prj-media { position: relative; }
.prj-swiper { height: 100%; }
.prj-swiper .swiper-wrapper,
.prj-swiper .swiper-slide { height: 100%; }

.prj-swiper .swiper-slide img{
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* Бейджи поверх всего */
.prj-badges{ position:absolute; left:14px; bottom:14px; z-index: 4; }

/* Навигация и пагинация поверх, но под бейджами */
.prj-media .swiper-button-next,
.prj-media .swiper-button-prev{
  --btn-bg: color-mix(in oklab, var(--ch-ink) 100%, transparent 50%);
  width: 36px; height: 36px; border-radius: 999px;
  background: var(--btn-bg);
  backdrop-filter: blur(2px);
  box-shadow: var(--ch-shadow);
}
.prj-media .swiper-button-next:after,
.prj-media .swiper-button-prev:after{ font-size: 16px; color: #fff; }

.prj-media .swiper-button-next,
.prj-media .swiper-button-prev{ z-index: 3; }

.prj-media .swiper-pagination{
  z-index: 3;
  --dot: color-mix(in oklab, var(--ch-surface) 30%, #fff 70%);
  --dot-active: #fff;
  text-align: right;
  padding-right: 12px; padding-bottom: 12px;
}
.prj-media .swiper-pagination .swiper-pagination-bullet{
  background: var(--dot); opacity: .8;
}
.prj-media .swiper-pagination .swiper-pagination-bullet-active{
  background: var(--dot-active); opacity: 1;
}




/* Мобилка: кнопки компактнее */
@media (max-width: 576px){
  .prj-media .swiper-button-next,
  .prj-media .swiper-button-prev{ width: 30px; height: 30px; }
  .prj-media .swiper-button-next:after,
  .prj-media .swiper-button-prev:after{ font-size: 14px; }
}


/* ===== Responsive ===== */
@media (max-width: 991px){
  .prj-card{ grid-template-columns: 1fr; }
  .prj-card.is-reverse .prj-media{ order: 0; }
  .prj-media{ min-height: 220px; }
}










/* ===== Why Choose Us ===== */
.choose{
  background: var(--ch-bg);
  padding: clamp(40px, 6vw, 110px) 0;
}

/* Шапка секции (вынесена отдельно) */
.choose-head{
  width: 100%;
  padding: 0 var(--side-padding);
  margin-inline: auto;
  margin-bottom: clamp(18px, 3vw, 28px);
}
.choose-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  color: var(--ch-muted); font-size:.95rem; margin-bottom:10px; position:relative;
}
.choose-eyebrow::before{
  content:""; width:24px; height:2px; border-radius:2px; background: var(--ch-accent);
}
.choose-title{
  font-family:"Montserrat",sans-serif; font-weight:700; line-height:1.15;
  margin:0; font-size: clamp(28px, 3vw, 42px); color: var(--ch-ink);
}
.choose-title .accent{ color: var(--ch-accent); display:block; }

/* Сетка карточек */
.choose-container{
  width: 100%;
  margin-inline: auto;
  padding: 0 var(--side-padding);
  display: grid;
  grid-template-columns: 1.1fr .9fr; /* можно 1fr 1fr, если нужен идеальный паритет */
  gap: clamp(18px, 3vw, 28px);
  align-items: stretch; /* выравниваем по высоте */
}

/* Общий стиль карт (левый и правый блоки одинаковые по коробке) */
.choose-card{
  position: relative;
  display: flex;
  flex-direction: column;
  background: color-mix(in oklab, var(--ch-surface) 92%, #000 8%);
  border-radius: 22px;
  box-shadow: var(--ch-shadow);
  overflow: hidden;
  min-height: 360px; /* опционально, чтобы красиво тянуться */
}
.choose-card::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: repeating-linear-gradient(-45deg, rgba(255,255,255,.06) 0 12px, transparent 12px 24px);
  opacity:.25;
}

/* Левая media-карта: картинка занимает всю высоту карты */

.choose-media{
  position: relative; margin: 0;
  border-radius: 18px; overflow: hidden; flex: 1 1 auto;
  background: linear-gradient(135deg,#13224b 0,#0b1640 100%);
    max-height: 600px;
}
.choose-media img{ width:100%; height:100%; object-fit:cover; display:block; }

/* Play */
.choose-play{
  position:absolute; inset:auto auto 16px 16px;
  width: 56px; height: 56px; border-radius: 50%; border: 0; cursor: pointer;
  background: #fff; color: var(--ch-surface); display:grid; place-items:center;
  box-shadow: 0 8px 20px rgba(0,0,0,.25);
}
.choose-play .ring{
  position:absolute; inset:-10px; border-radius:50%;
  border: 2px solid rgba(255,255,255,.75);
  animation: choosePulse 1.6s ease-out infinite;
}
.choose-play i{ font-size: 28px; margin-left: 2px; }
@keyframes choosePulse{
  0%{ transform: scale(.8); opacity:.9; }
  100%{ transform: scale(1.2); opacity:0; }
}

/* Правая карта с преимуществами */
.choose-card--features{ padding: clamp(16px, 2.4vw, 24px); }

/* Список преимуществ */
.choose-list{ list-style:none; padding:0; margin:0; display:grid; gap:14px; height:100%; }
.choose-item{
  display:grid;
  grid-template-columns: 52px 1fr;
  gap: 12px;
  align-items: center;           /* <-- иконка ПО ЦЕНТРУ по вертикали */
  color:#fff;
  padding: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.choose-ico{
  width:52px; height:52px; border-radius:50%;
  background: var(--ch-accent); color:#fff;
  display:grid; place-items:center;
  box-shadow: 0 10px 22px rgba(250,158,0,.28);
}
.choose-ico i{ font-size: 24px; line-height:1; }

/* Тексты */
.choose-text h3{
  margin:0 0 4px; font-size:1.05rem; font-weight:600; color:#fff;
}
.choose-text p{
  margin:0; font-size:.95rem; line-height:1.55; color: rgba(255,255,255,.85);
}



/* Слайдер внутри блока choose-media */
.choose-media { position: relative; }
.choose-media .choose-swiper { height: 100%; }
.choose-media .swiper-wrapper,
.choose-media .swiper-slide { height: 100%; }

.choose-media .swiper-slide img{
  width:100%; height:100%; object-fit:cover; display:block;
}

/* Кнопки/пагинация поверх изображения */
.choose-media .swiper-button-next,
.choose-media .swiper-button-prev{
  --btn-bg: color-mix(in oklab, var(--ch-ink) 100%, transparent 50%);
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--btn-bg); backdrop-filter: blur(2px);
  box-shadow: var(--ch-shadow);
}
.choose-media .swiper-button-next:after,
.choose-media .swiper-button-prev:after{ font-size:16px; color:#fff; }

.choose-media .swiper-pagination{
  text-align:right; padding: 0 12px 12px 0; z-index:3;
}
.choose-media .swiper-pagination-bullet{ background: rgba(255,255,255,.7); opacity:.9; }
.choose-media .swiper-pagination-bullet-active{ background:#fff; }

@media (max-width:576px){
  .choose-media .swiper-button-next,
  .choose-media .swiper-button-prev{ width:30px; height:30px; }
  .choose-media .swiper-button-next:after,
  .choose-media .swiper-button-prev:after{ font-size:14px; }
}



/* Адаптив */
@media (max-width: 991px){
  .choose-container{ grid-template-columns: 1fr; }
  .choose-card{ min-height: 320px; }
  .choose-item{ grid-template-columns: 48px 1fr; }
  .choose-ico{ width:48px; height:48px; }
}






/* ===== Meet Our Team (slider) ===== */
.team{
  background: rgba(238, 252, 255, 1);
  padding: clamp(40px,6vw,110px) 0;
}
.tm-head{
  width:100%;
  padding:0 var(--side-padding);
  margin-inline:auto;
  margin-bottom: clamp(18px,3vw,26px);
  text-align: center;
}
.tm-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  color: var(--ch-muted); font-size:.95rem; margin-bottom:10px;
}
.tm-eyebrow::before{ content:""; width:24px; height:2px; background:var(--ch-accent); border-radius:2px; }

.tm-title{
  font-family:"Montserrat",sans-serif; font-weight:700; line-height:1.12; margin:0;
  font-size: clamp(28px,3vw,42px); color: var(--ch-accent);
}
.tm-title .accent{ color: var(--ch-ink); display:block; }

/* Cards */
.tm-card{
  background:#fff;
  border-radius: var(--ch-radius);
    border: 2px solid rgba(250, 158, 0, 0.25);
  overflow:hidden; position:relative;
  transition: transform .15s ease, box-shadow .2s ease, border .2s ease-in-out;
  display:flex; flex-direction:column;
}
.tm-card:hover{ border: 2px solid rgba(250, 158, 0, 1); }

/* Photo */
.tm-photo{
  position:relative; margin:0; height: 400px; overflow:hidden;
  background: linear-gradient(135deg,#13224b 0,#0b1640 100%);
}
.tm-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.tm-photo::before{
  content:""; position:absolute; inset:auto 0 0 0; height:22px;
  background: repeating-linear-gradient(-45deg, rgba(255,255,255,.12) 0 12px, transparent 12px 24px);
  opacity:.25;
}

/* Body */
.tm-body{ padding: 16px 18px 14px; position:relative; }
.tm-name{ margin:0 0 4px; font-weight:700; font-size:1.1rem; color: var(--ch-surface); }
.tm-role{ margin:0 0 10px; font-size:.95rem; color: var(--ch-muted); }

/* Accent line */
.tm-accent{
  position:absolute; left:18px; right:18px; bottom:0; height:4px;
  background: linear-gradient(90deg, var(--ch-accent), transparent 70%);
  border-bottom-left-radius: 999px;
  border-bottom-right-radius: 10px;
}

/* === Swiper layout (вместо grid) === */
.tm-swiper{ overflow: hidden; padding: 0 var(--side-padding); }
.tm-swiper .swiper-wrapper{ align-items: stretch; }
.tm-swiper .swiper-slide{ height:auto; display:flex; }
.tm-swiper .swiper-slide > .tm-card{ width:100%; }

/* Навигация/пагинация */
.tm-nav{
  position:absolute; top:50%; transform: translateY(-50%);
  z-index:3; width:36px; height:36px; border:0; border-radius:50%;
  background: color-mix(in oklab, var(--ch-ink) 100%, transparent 50%);
  color:#fff; display:grid; place-items:center; cursor:pointer;
  box-shadow: var(--ch-shadow);
}
.tm-prev{ left: calc(var(--side-padding) - -5px); }
.tm-next{ right: calc(var(--side-padding) - -5px); }
.tm-nav i{ font-size:18px; line-height:1; }

.tm-pagination{
  position:relative; margin-top:16px; text-align:center;
}
.tm-pagination .swiper-pagination-bullet{ background: rgba(255,255,255,.65); }
.tm-pagination .swiper-pagination-bullet-active{ background:#fff; }

/* Чёткая обрезка содержимого карусели */
.tm-swiper { overflow: hidden; }

/* На некоторых движках overflow:clip даёт ещё более чистый край */
@supports (overflow: clip) {
  .tm-swiper { overflow: clip; }
}

/* Подстрахуемся от субпиксельных артефактов вычисления ширины */
.tm-swiper .swiper-slide { box-sizing: border-box; }


/* Responsive */
@media (max-width: 640px){
  .tm-photo{ height: 400px; }
}

/* Скрыть стрелки, когда видны 3 слайда (>=1024px) */
@media (min-width: 1024px){
  .tm-nav{ display:none !important; }
}








/* ===== Award Section (unified right column) ===== */
.award{
  padding: clamp(40px,5vw,90px) 0;
  background: var(--ch-bg);
}
.awd-container{ width:100%; margin-inline:auto; padding:0 var(--side-padding); }

/* Заголовок */
.awd-head{ text-align:center; margin-bottom: clamp(22px,4vw,36px); }
.awd-eyebrow{
  display:inline-flex; align-items:center; gap:10px; justify-content:center;
  color:var(--ch-muted); font-size:.95rem; margin-bottom:10px; position:relative;
}
.awd-eyebrow::before{ content:""; width:24px; height:2px; background:var(--ch-accent); border-radius:2px; }
.awd-title{
  font-family:"Montserrat",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  font-weight:700; color:var(--ch-ink);
  font-size: clamp(28px,2.8vw,44px); line-height:1.2; margin:0;
}
.awd-title .accent{ color:var(--ch-accent); display:block; }
.awd-subtitle{ margin:8px 0 0; color:var(--ch-muted); font-style:italic; font-size:clamp(14px,1.2vw,16px); }

/* Сетка */
.awd-grid{
  display:grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 22px;
  align-items: stretch;
  margin-top: clamp(16px,3vw,28px);
}

/* Фото */
.awd-media{
  position:relative; overflow:hidden; border-radius: var(--ch-radius);
  min-height: 320px;

}
.awd-media img{ width:100%; height:auto; object-fit:cover; display:block; }

/* Правая колонка: аутентичный карточный блок */
.awd-body{
  position: relative;
  background: color-mix(in oklab, var(--ch-surface) 92%, #000 8%);
  border-radius: var(--ch-radius);
  box-shadow: var(--ch-shadow);
  padding: clamp(18px,2vw,26px);
  overflow: hidden;
}

.awd-body::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: repeating-linear-gradient(-45deg, rgba(255, 255, 255, .06) 0 12px, transparent 12px 24px);
    opacity: .25;
}

.awd-body::after{
  content:""; position:absolute; left:0; top:0; bottom:0; width:10px;
  background: linear-gradient(180deg, var(--ch-accent), color-mix(in oklab, var(--ch-accent) 60%, transparent));
  border-top-left-radius: var(--ch-radius); border-bottom-left-radius: var(--ch-radius); z-index: 100;
}

/* Вертикальная акцентная линия слева */


/* Шапка описания */
.awd-body-head{
  display:flex; align-items:baseline; gap:12px; flex-wrap:wrap;
  margin-bottom: 10px;
}
.awd-body-title{
  margin:0; color: var(--ch-surface); font-size:1.1rem; font-weight:800; letter-spacing:.02em;
}
.awd-body-k.motto{
  color: var(--ch-ink); font-weight:700; font-style: italic; opacity:.9; font-size:.95rem;
}

/* Текстовая часть */
.awd-body-text{ position:relative; z-index:1; }
.awd-lead{
  margin: 0 0 10px;
  color: #ffffff;
  font-weight: 600;
  font-size: clamp(16px,1.2vw,18px);
}
.awd-text{ margin:0; color: #ffffff; font-size:1rem; line-height:1.6; }

/* Декоративный разделитель внутри карточки */
.awd-sep{
  height: 2px; width: 100%; margin: clamp(12px,2vw,18px) 0;
  background: linear-gradient(90deg, transparent, var(--ch-accent), transparent);
  opacity: .6;
}

/* Лауреати внутри правой карточки */
.awd-laureates.in-body{ margin: 0; }
.awd-list-title{
  margin: 0 0 10px; text-align:left;
  color: var(--ch-accent); font-weight:600; font-size:1rem; letter-spacing:.02em;
}

/* Сетка чипов: 5 → 3 → 2 → 1 */
.awd-list{
  list-style:none; padding:0; margin:0;
  display:grid; gap: 10px;

}
.awd-chip{
  display:flex; align-items:center; justify-content:center;
  gap: 8px; padding: 12px 14px; min-height: 44px;
  border-radius: 999px; background:#fff;
  border: 2px solid rgba(250,158,0,.25);
  box-shadow: var(--ch-shadow);
  color: var(--ch-ink); font-weight:700; text-align:center; white-space:nowrap;
  transition: transform .15s ease, border-color .2s ease, background .2s ease;
}
.awd-chip i{ font-size:18px; color: var(--ch-accent); }
.awd-chip:hover{ transform: translateY(-1px); border-color: var(--ch-accent); background:#fff; }

/* Адаптив */
@media (max-width: 768px){
  .awd-grid{ grid-template-columns: 1fr; }
  .awd-media{ min-height: 280px; }

}








/* ===== Ambassadors (Swiper) ===== */
.ambassadors{ background: var(--ch-bg); padding: clamp(40px,6vw,110px) 0; }
.amb-head{ width:100%; padding:0 var(--side-padding); margin-inline:auto; margin-bottom: clamp(18px,3vw,26px);  }
.amb-eyebrow{ display:inline-flex; align-items:center; gap:10px; color: var(--ch-muted); font-size:.95rem; margin-bottom:10px; }
.amb-eyebrow::before{ content:""; width:24px; height:2px; background:var(--ch-accent); border-radius:2px; }
.amb-title{ font-family:"Montserrat",sans-serif; font-weight:700; margin:0; font-size: clamp(28px,3vw,42px); line-height:1.15; color: var(--ch-ink); }
.amb-title .accent{ color: var(--ch-accent); display:block; }

.amb-shell{ position: relative; padding: 0 var(--side-padding); }

/* Стрелки */
.amb-nav{
  position:absolute; top:50%; transform: translateY(-50%);
  z-index:5; width:44px; height:44px; border-radius:50%; border:none; cursor:pointer;
  display:grid; place-items:center; background: color-mix(in oklab, var(--ch-ink) 25%, transparent 75%);
  color:#fff;
  box-shadow: var(--ch-shadow);
  transition: transform .15s ease, filter .2s ease, background .2s ease, color .2s ease;
}
.amb-prev{ left: calc(var(--side-padding) - -5px); }
.amb-next{ right: calc(var(--side-padding) - -5px); }
.amb-nav:hover{ transform: translateY(-50%) translateY(-1px); filter: brightness(.98); }
.amb-nav i{ font-size:20px; }

/* Слайды / карточки */
.amb-swiper{ overflow: hidden; background-color: var(--ch-bg);}
.amb-swiper .swiper-wrapper{ align-items: stretch; }
.amb-swiper .swiper-slide{ height:auto; }

.amb-card {
  border: 2px solid rgba(250,158,0,.25);
  background: transparent;
  border-radius: var(--ch-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: all .2s ease;
}

.amb-card:hover{ border: 2px solid rgba(250,158,0,.8); }

.amb-photo {
  position: relative;
  margin: 0;
  height: 260px;
  overflow: hidden;
  background: #eee;
  flex-shrink: 0; /* фото фиксированной высоты */
}
.amb-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.amb-photo::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  -webkit-mask:
    radial-gradient(38px at top right, transparent 98%, #000 100%) top right,
    linear-gradient(#000 0 0) center/100% 100%;
  -webkit-mask-composite: destination-out;
  mask:
    radial-gradient(38px at top right, transparent 98%, #000 100%) top right,
    linear-gradient(#000 0 0) center/100% 100%;
  mask-composite: exclude;
}

.amb-body {
  flex: 1; /* растягиваем блок описания */
  display: flex;
  flex-direction: column;
  padding: 16px 16px 18px;
  gap: 8px;
}
.amb-name{ margin:0; font-weight:700; font-size:1.05rem; color: var(--ch-surface); }
.amb-desc{ margin-bottom:10px; color: var(--ch-muted); font-size:.95rem; line-height:1.55; }
.amb-wiki{
  margin-top:auto;   align-items:center; gap:8px;
   color:var(--ch-surface); text-decoration:none; font-weight:700;

  transition: transform .15s ease, filter .2s ease, color .2s ease;

}
.amb-wiki:hover{ transform: translateY(-1px); filter: brightness(.95); color: var(--ch-accent)}


@media (max-width: 640px){
  .amb-photo{ height:220px; }
  .amb-prev{ left: 10px; } .amb-next{ right: 10px; }
}









/* ===== Award Section (unified right column) ===== */
.award{
  padding: clamp(40px,5vw,90px) 0;
  background: var(--ch-bg);
}
.awd-container{ width:100%; margin-inline:auto; padding:0 var(--side-padding); }

/* Заголовок */
.awd-head{ text-align:center; margin-bottom: clamp(22px,4vw,36px); }
.awd-eyebrow{
  display:inline-flex; align-items:center; gap:10px; justify-content:center;
  color:var(--ch-muted); font-size:.95rem; margin-bottom:10px; position:relative;
}
.awd-eyebrow::before{ content:""; width:24px; height:2px; background:var(--ch-accent); border-radius:2px; }
.awd-title{
  font-family:"Montserrat",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  font-weight:700; color:var(--ch-ink);
  font-size: clamp(28px,2.8vw,44px); line-height:1.2; margin:0;
}
.awd-title .accent{ color:var(--ch-accent); display:block; }
.awd-subtitle{ margin:8px 0 0; color:var(--ch-muted); font-style:italic; font-size:clamp(14px,1.2vw,16px); }

/* Сетка */
.awd-grid{
  display:grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 22px;
  align-items: stretch;
  margin-top: clamp(16px,3vw,28px);
}

/* Фото */
.awd-media{
  position:relative; overflow:hidden; border-radius: var(--ch-radius);
  min-height: 320px;

}
.awd-media img{ width:100%; height:auto; object-fit:cover; display:block; }

/* Правая колонка: аутентичный карточный блок */
.awd-body{
  position: relative;
  background: color-mix(in oklab, var(--ch-surface) 92%, #000 8%);
  border-radius: var(--ch-radius);
  box-shadow: var(--ch-shadow);
  padding: clamp(18px,2vw,26px);
  overflow: hidden;
}

.awd-body::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: repeating-linear-gradient(-45deg, rgba(255, 255, 255, .06) 0 12px, transparent 12px 24px);
    opacity: .25;
}

.awd-body::after{
  content:""; position:absolute; left:0; top:0; bottom:0; width:10px;
  background: linear-gradient(180deg, var(--ch-accent), color-mix(in oklab, var(--ch-accent) 60%, transparent));
  border-top-left-radius: var(--ch-radius); border-bottom-left-radius: var(--ch-radius); z-index: 100;
}

/* Вертикальная акцентная линия слева */


/* Шапка описания */
.awd-body-head{
  display:flex; align-items:baseline; gap:12px; flex-wrap:wrap;
  margin-bottom: 10px;
}
.awd-body-title{
  margin:0; color: var(--ch-surface); font-size:1.1rem; font-weight:800; letter-spacing:.02em;
}
.awd-body-k.motto{
  color: var(--ch-ink); font-weight:700; font-style: italic; opacity:.9; font-size:.95rem;
}

/* Текстовая часть */
.awd-body-text{ position:relative; z-index:1; }
.awd-lead{
  margin: 0 0 10px;
  color: #ffffff;
  font-weight: 600;
  font-size: clamp(16px,1.2vw,18px);
}
.awd-text{ margin:0; color: #ffffff; font-size:1rem; line-height:1.6; }

/* Декоративный разделитель внутри карточки */
.awd-sep{
  height: 2px; width: 100%; margin: clamp(12px,2vw,18px) 0;
  background: linear-gradient(90deg, transparent, var(--ch-accent), transparent);
  opacity: .6;
}

/* Лауреати внутри правой карточки */
.awd-laureates.in-body{ margin: 0; }
.awd-list-title{
  margin: 0 0 10px; text-align:left;
  color: var(--ch-accent); font-weight:600; font-size:1rem; letter-spacing:.02em;
}

/* Сетка чипов: 5 → 3 → 2 → 1 */
.awd-list{
  list-style:none; padding:0; margin:0;
  display:grid; gap: 10px;

}
.awd-chip{
  display:flex; align-items:center; justify-content:center;
  gap: 8px; padding: 12px 14px; min-height: 44px;
  border-radius: 999px; background:#fff;
  border: 2px solid rgba(250,158,0,.25);
  box-shadow: var(--ch-shadow);
  color: var(--ch-ink); font-weight:700; text-align:center; white-space:nowrap;
  transition: transform .15s ease, border-color .2s ease, background .2s ease;
}
.awd-chip i{ font-size:18px; color: var(--ch-accent); }
.awd-chip:hover{ transform: translateY(-1px); border-color: var(--ch-accent); background:#fff; }

/* Адаптив */
@media (max-width: 768px){
  .awd-grid{ grid-template-columns: 1fr; }
  .awd-media{ min-height: 280px; }

}











/* ===== Sponsors Section ===== */
.sponsors {
  background: rgba(238, 252, 255, 1);
  padding: clamp(40px, 6vw, 110px) 0;
}

.sp-head {
  width: 100%;
  padding: 0 var(--side-padding);
  margin-inline: auto;
  margin-bottom: clamp(18px, 3vw, 28px);
  text-align: center;
}

.sp-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ch-muted);
  font-size: .95rem;
  margin-bottom: 10px;
  position: relative;
}
.sp-eyebrow::before {
  content: "";
  width: 24px;
  height: 2px;
  background: var(--ch-accent);
  border-radius: 2px;
}

.sp-title {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  line-height: 1.15;
  margin: 0;
  font-size: clamp(28px, 3vw, 42px);
  color: var(--ch-ink);
}
.sp-title .accent {
  color: var(--ch-accent);
  display: block;
}

.sp-container {
  width: 100%;
  padding: 0 var(--side-padding);
  margin-inline: auto;
}

/* Сетка: всегда симметрично */
.sp-grid {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr); /* на десктопе 5 × 2 */
  gap: clamp(14px, 2vw, 20px);
     margin: 40px 0;
  justify-content: center;   /* попытка центрировать последний ряд (для auto-fit); при фикс. кол-ве колонок добавим хак ниже */
}


/* ≤1199px — 4 колонки, последний ряд из двух */
@media (max-width: 1199px) {
  .sp-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}




/* Плитки логотипов */
.sp-item {
  display: flex;
    align-items: center;
    justify-content: center;
}
.sp-logo {
  display: grid;
  place-items: center;
  padding: 14px;
  transition: transform .15s ease, box-shadow .25s ease, border-color .2s ease;
  overflow: hidden;
    max-width: 200px;
}
.sp-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  filter: grayscale(100%) contrast(1.05) opacity(.85);
  transition: filter .2s ease;
}




.sp-logo:hover img {
  filter: none;
}

/* Кнопка CTA */
.sp-footer {
  display: flex;
  justify-content: center;
  margin-top: clamp(18px, 3vw, 28px);
}
.sp-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  border-radius: 999px;
  background: var(--ch-accent);
  color: #fff;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(250, 158, 0, .25);
  transition: transform .15s ease, filter .2s ease;
}
.sp-cta:hover {
  transform: translateY(-1px);
  filter: brightness(.95);
}

/* ===== ДОБАВЛЕНО: центрируем последний ряд из двух элементов при 4 колонках ===== */
@media (max-width: 1199px){
  .sp-grid > :nth-last-child(2):nth-child(4n + 1){
    grid-column: 2; /* пара станет во 2 и 3 колонки — по центру ряда */
  }
}

@media (max-width: 768px){
    .sp-grid > :nth-last-child(2):nth-child(4n + 1){
    grid-column: auto !important;
  }
  .sp-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}











/* ===== Contact Section (fits site palette) ===== */
.contact-section{
  background: var(--ch-bg);
  padding: clamp(40px,6vw,110px) 0;
}

/* Head */
.ct-head{
  width:100%;
  padding:0 var(--side-padding);
  margin-inline:auto;
  text-align:center;
  margin-bottom: clamp(18px,3vw,28px);
}
.ct-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--ch-muted);
  font-size:.95rem;
  margin-bottom:10px;
}
.ct-eyebrow::before{
  content:"";
  width:24px;
  height:2px;
  background:var(--ch-accent);
  border-radius:2px;
}
.ct-title{
  font-family:"Montserrat",sans-serif;
  font-weight:700;
  margin:0;
  color:var(--ch-ink);
  font-size: clamp(28px,3vw,42px);
  line-height:1.15;
}
.ct-title .accent{ color: var(--ch-accent); display:block; }

/* Grid (две колонки, одинаковая высота) */
.ct-grid{
  width:100%;
  padding:0 var(--side-padding);
  margin-inline:auto;
  display:grid;
  grid-template-columns: 1.5fr .9fr;
  gap: clamp(18px,3vw,28px);
  align-items: stretch;            /* ключ — тянем обе колонки по высоте */
}

/* ===== Form (левая колонка) ===== */
.ct-form{

  display:flex;
  flex-direction: column;
  height: 100%;
}
.ct-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.ct-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:12px;
}
.ct-field label{
  font-weight:600;
  color:var(--ch-surface);
  font-size:.95rem;
}
.ct-field input,
.ct-field textarea{
  width:100%;
  border:1px solid rgba(2,40,156,.08);
  border-radius:12px;
  padding:12px 14px;
  font: inherit;
  background:#f8fafc;
}
.ct-field textarea{ min-height: 140px; resize: vertical; }
.ct-field input:focus,
.ct-field textarea:focus{
  outline:none;
  border-color: rgba(250,158,0,.45);
  background:#fff;
  box-shadow: 0 0 0 3px rgba(250,158,0,.12);
}
.err{ color:#c62828; font-size:.85rem; }

.ct-submit{
    width: 100%;
    max-width: 130px;
  justify-content:center;
  gap:8px;
  padding:12px 20px;
  border-radius:999px;
  border:0;
  cursor:pointer;
  background: var(--ch-accent);
  color:#fff;
    font-size: 1rem;
  font-weight:600;
    font-family: "Montserrat", sans-serif;
  box-shadow: 0 10px 24px rgba(250,158,0,.25);
  transition: transform .15s ease, filter .2s ease;
  margin-top: 6px;
}
.ct-submit:hover{ transform: translateY(-1px); filter: brightness(.95); }

/* ===== Aside (правая колонка) ===== */
.ct-aside{
  border-radius: 22px;
  background: var(--ch-surface);
  color:#fff;
  box-shadow: var(--ch-shadow);
  display:flex;            /* чтобы тянуться по высоте строки */
  height: 100%;
}
.ct-aside-inner{
  position:relative;
  width:100%;
  height:100%;             /* ключ — заполняем высоту карточки */
  padding: clamp(18px,2.4vw,24px);
  display:flex;
  flex-direction: column;
  gap: 14px;
}
.ct-aside-inner::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:22px;
  background: repeating-linear-gradient(-45deg, rgba(255,255,255,.08) 0 12px, transparent 12px 24px);
  opacity:.25;
}

/* Контентные блоки и распределение пространства */
.ct-block + .ct-block{ margin-top: 6px; }
.ct-block h3{
  margin:.2rem 0 .35rem;
  font-weight:600;
}
.ct-block p{
  margin:.15rem 0;
  opacity:.9;
}

/* Соц-сети — прижаты к низу карточки без пустоты */
.ct-aside .ct-block:last-child{ margin-top: auto; }

.ct-socials{
  list-style:none;
  padding:0;
  margin:.2rem 0 0;
  display:flex;
  gap:10px;
}
.ct-socials a{
  width:40px;
  height:40px;
  border-radius:50%;
  display:grid;
  place-items:center;
  text-decoration:none;
  background:#fff;
  color: var(--ch-accent);
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
  transition: transform .15s ease, filter .2s ease, background .2s ease, color .2s ease;
}

.ct-socials a i {
    font-size: 24px;
}

.ct-socials a:hover{
  transform: translateY(-1px);
  filter: brightness(.95);
  background: var(--ch-accent);
  color:#fff;
}

/* Django messages */
.ct-messages{
  width:100%;
  padding:0 var(--side-padding);
  margin-inline:auto;
  margin-bottom:14px;
}
.ct-msg{
  padding:10px 14px;
  border-radius:12px;
}
.ct-msg.success{ background:#ecfdf5; color:#065f46; }
.ct-msg.error{   background:#fef2f2; color:#991b1b; }

.ct-contacts{
  list-style: none;
    display: flex;
    gap: 15px;
  margin: 0;
  padding: 0;
}

/* в линию + перенос при нехватке места */
.ct-contacts--row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 18px; /* [row-gap] [column-gap] */
}

.ct-contacts--row li{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;

}


.ct-contacts--orange a{
  text-decoration: none;
  transition: color .15s ease, opacity .15s ease;
}


.ct-contacts--orange a:hover{
  color: var(--ct-orange-hover);
  text-decoration: underline;
}

/* (необязательно) чуть крупнее иконки, чтобы читалось ровнее */
.ct-contacts i{ font-size: 1.8rem; color: var(--ch-bg); transition: color .2s ease-in-out}

.ct-contacts i:hover{color: var(--ch-accent)}

/* адаптив: на совсем узких делаем промежутки поменьше */
@media (max-width: 420px){
  .ct-contacts--row{ gap: 8px 12px; }
}

/* ===== Responsive ===== */
@media (max-width: 991px){
  .ct-grid{ grid-template-columns: 1fr; }
  .ct-row{ grid-template-columns: 1fr; }
  .ct-form,
  .ct-aside,
  .ct-aside-inner{ height:auto; }
  .ct-aside .ct-block:last-child{ margin-top: 12px; }
}







/* ===== Newsletter ===== */
.newsletter{
  position: relative;
  background: var(--ch-bg);
  padding: clamp(40px,6vw,110px) 0;
  overflow: hidden;
}

.nl-shell{
  width: 100%;
  padding: 0 var(--side-padding);
  margin-inline: auto;
  text-align: center;
}

.nl-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  color: var(--ch-muted); font-size:.95rem; margin-bottom:10px; position:relative;
}
.nl-eyebrow::before{
  content:""; width:24px; height:2px; border-radius:2px; background: var(--ch-accent);
}

.nl-title{
  font-family:"Montserrat",sans-serif; font-weight:700; margin:0 0 18px;
  color: var(--ch-accent ); font-size: clamp(28px,3vw,42px); line-height:1.15;
}
.nl-title .accent{ color: var(--ch-ink); display:block; }

/* form */
.nl-form{ max-width: 820px; margin: 0 auto; }
.nl-inputwrap{
  display:flex; align-items: center; gap: 8px;
  background: #fff;
  border: 1px solid rgba(2,40,156,.08);
  border-radius: 999px;
  padding: 8px;
  box-shadow: var(--ch-shadow);
}
.nl-ico{
  width: 42px; height: 42px; border-radius:50%;
  display:grid; place-items:center;
  color: var(--ch-surface);
  background: rgba(2,40,156,.06);
  flex: 0 0 42px;
}
.nl-form input[type="email"]{
  flex:1 1 auto; min-width: 0;
  border: none; outline: none;
  padding: 12px 12px;
  background: transparent;
  font: inherit; color: #111827;
}
.nl-form input[type="email"]::placeholder{ color:#9ca3af; }

.nl-btn{
  flex: 0 0 auto;
  padding: 12px 20px;
  border: 0; border-radius: 999px;
  font-weight: 800; cursor: pointer;
  background: var(--ch-accent); color:#fff;
  box-shadow: 0 10px 24px rgba(250,158,0,.25);
  transition: transform .15s ease, filter .2s ease;
}
.nl-btn:hover{ transform: translateY(-1px); filter: brightness(.95); }

.nl-error{ display:block; margin-top:8px; color:#c62828; }

/* messages */
.nl-messages{ max-width:820px; margin: 0 auto 10px; }
.nl-msg{ padding:10px 14px; border-radius:12px; }
.nl-msg.success{ background:#ecfdf5; color:#065f46; }
.nl-msg.error{   background:#fef2f2; color:#991b1b; }

/* decor */
.nl-decor{ position:absolute; pointer-events:none; user-select:none; opacity:.95; }
.nl-decor--left{ left: 0; top: 0; height: 140px; transform: translateY(-10%); }
.nl-decor--right{ right: 0; bottom: -8px; height: clamp(120px, 20vw, 180px); }

/* responsive */
@media (max-width: 640px){
  .nl-inputwrap{ padding: 6px; }
  .nl-ico{ display:none; }
  .nl-btn{ padding: 12px 16px; }
  .nl-decor--left{ height: 90px; }
  .nl-decor--right{ height: 120px; }
}


/*
.video-section {
  position: relative;

  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: rgba(238, 252, 255, 1);
  overflow: hidden;
  z-index: 1;
}

.scroll-indicator {
  position: absolute;
  bottom: 100px; !* заходим на предыдущую секцию *!
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 10;
}

.line-animation {
  position: relative;
  width: 2px;
  height: 80px;
  overflow: hidden;
  background: transparent;
  z-index: 1;
}

.line-animation::before {
  content: "";
  position: absolute;
  top: -100%;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, transparent 0%, #2e2e2e 50%, transparent 100%);
  animation: falling-line 1.2s linear infinite;
  z-index: 1;
}

@keyframes falling-line {
  0% {
    top: -100%;
  }
  100% {
    top: 100%;
  }
}



.scroll-indicator {
  opacity: 0;

  transition: opacity 1s ease, transform 1s ease;
}

.scroll-indicator.visible {
  opacity: 1;

}


!* Видео *!
.video-wrapper {
  width: 60vw;
  height: 100vh;
  transition: width 0.3s ease, height 0.3s ease;
  overflow: hidden;
  margin: 0 auto; !* центрирование *!
  display: flex;
  align-items: center;
  justify-content: center;
}

.scroll-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  box-shadow: 0 0 30px rgba(255, 255, 255, 0.15);
}








.about-section {
  background-color: rgba(238, 252, 255, 1);

}

.highlighted-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


.about-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;

  margin: 100px auto;

  position: relative;
}

!* Левая и правая части *!
.about-column {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  max-width: 33%;
}

!* Левая — фото вверху *!
.about-column.left {
  align-items: flex-start;
}

.about-column.right {
  align-items: flex-end;
}

!* Изображения *!
.about-image {
  width: 100%;
  max-width: 100%;
  height: 400px;
  object-fit: cover;
}

!* Центральный текст *!
.about-text-block {
  flex: 1;
  max-width: 34%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: justify-all;
    z-index: 10;
    background-color: #d7f1f7;
    padding: 40px;
    -webkit-box-shadow: 5px 5px 10px 0px rgba(0,0,0,0.4);
box-shadow: 5px 5px 10px 0px rgba(0,0,0,0.4);
}

.about-title {
  font-size: 2.5rem;
  margin-bottom: 20px;
  color: #2e2e2e;
  font-weight: 700;
}

.about-paragraph {
  font-size: 18px;
  line-height: 1.6;
  margin-bottom: 16px;
  color: #2e2e2e;
}

.about-column.left {
  align-items: flex-start;
  padding-bottom: 200px; !* Сдвигает левое фото выше *!
}

.about-column.right {
  align-items: flex-end;
  padding-top: 200px; !* Сдвигает правое фото ниже *!
}


!* Адаптив *!
@media (max-width: 991px) {
  .about-container {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }

  .about-column {
    max-width: 100%;
    align-items: center;
    padding: 0;
  }

  .about-text-block {
    text-align: center;
    padding: 30px;
  }

  .about-title {
    font-size: 2rem;
  }

  .about-paragraph {
    font-size: 1rem;
  }

  .about-image {
    height: 300px;
  }
}






.info-cards-section {
  padding: 100px 0;
  background-color: rgba(238, 252, 255, 1);
}

.info-cards-container {
  display: flex;
  gap: 2px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 auto;
}

.info-card {
  flex: 1 1 calc(33.333% - 20px);
  min-width: 280px;
  height: 500px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.info-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
  display: block;
}

.info-card-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: background-color 0.3s ease;
  z-index: 2;
}

!* Заголовок *!
.info-card-title {
  color: white;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0;
}

!* Описание — появляется с анимацией слева *!
.info-card-description {
  color: white;
  font-size: 1rem;
  margin-top: 10px;
  margin-bottom: 20px;
  opacity: 0;
  transform: translateX(-20px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.info-card:hover .info-card-description {
  opacity: 1;
  transform: translateX(0);
}

!* Кнопка *!
.info-card-btn {
  align-self: flex-end;
  padding: 10px 16px;
  background-color: rgba(255, 255, 255, 0.9);
  color: #2e2e2e;
  font-weight: 600;
  text-decoration: none;
  font-size: 0.9rem;
  transition: all 0.3s ease;
}

.info-card-btn:hover {
  background-color: #2e2e2e;
  color: white;
}

!* Hover эффекты *!
.info-card:hover .info-card-overlay {
  background-color: rgba(0, 0, 0, 0.75);
}

.info-card:hover .info-card-image {
  transform: scale(1.05);
}








!* === Секция с фото и текстом === *!
.highlighted-container {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  min-height: 400px;
    margin-top: 100px;
    padding-left: var(--side-padding);
    padding-right: var(--side-padding);
    gap: 20px;
}

.highlighted-image,
.highlighted-text {
  flex: 1 1 50%;
  max-width: calc(50% - 10px); !* учитываем gap 30px *!
  min-width: 0; !* предотвращает переполнение *!
  box-sizing: border-box;
    border-radius: 20px;
}


.highlighted-image {
  position: relative;
  overflow: hidden;
}

.highlighted-image img {
  width: 100%;
  height: 100%;


    max-height: 450px;
    object-fit: cover;
  display: block;
}

.highlighted-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0 20px;
}

.scroll-btn {

  background: #d7f1f7;
  border: 2px solid rgba(238, 252, 255, 1);
  color: #2e2e2e;
  padding: 10px 20px;
    margin-top: 30px;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  text-transform: uppercase;
  position: relative;
  z-index: 2;
  animation: pulseInward 1.8s ease-in-out infinite;
  transition: all 0.5s ease-in-out;
  font-family: "Manrope", sans-serif;
}


!* 🟡 Эффект при наведении *!
.scroll-btn:hover {
  background-color: rgba(238, 252, 255, 1);
  color: #2e2e2e;
}

!* Кнопка внизу справа *!
.highlighted-text .scroll-btn {
  align-self: flex-start;

}



.highlighted-caption {
  color: white;
  font-size: 100px;
  font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    line-height: 1.4;
    font-style: inherit;
}

.highlighted-text {
  background-color: #d7f1f7;
  padding: 30px;
  display: flex;
  flex-direction: column;


}

.highlighted-text h2 {
  font-size: 2rem;
  margin-bottom: 16px;
  color: #2e2e2e;
}

.highlighted-text p {
  font-size: 20px;
  margin: 20px 0;
  color: #2e2e2e;
  line-height: 1.6;
}

!* Адаптив *!
@media (max-width: 991px) {
  .highlighted-container {
    flex-direction: column;
  }

  .highlighted-image,
  .highlighted-text {
    max-width: 100%;
    flex: 1 1 100%;
  }

  .highlighted-text {
    padding: 20px;
  }

  .highlighted-text h2 {
    font-size: 1.6rem;
  }
}


!* === Swiper Slider === *!
.photo-slider {
  background-color: rgba(238, 252, 255, 1);
    margin: 100px  0;


}

.photo-slider .swiper {
  width: 100%;
    height: 400px;
    background-color: rgba(238, 252, 255, 1);
}

.swiper-slide {
  background: #fff;
  overflow: hidden;

}

.swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;

}

!* Переопределяем стандартные стрелки *!
.swiper-button-next,
.swiper-button-prev {
  color: #ffffff;
  font-size: 2rem;
  width: auto;
  height: auto;
  top: 50%;

  background: transparent;
}

.swiper-button-next::after,
.swiper-button-prev::after {
  display: none !important;
}


.swiper-button-next i,
.swiper-button-prev i {
  font-size: 2.5rem;
  pointer-events: none;
}

.swiper-button-prev {
  left: 10px;
}

.swiper-button-next {
  right: 10px;
}


.swiper-pagination-bullet {
  background: #2e2e2e;
}







.equal-grid-section {
  display: grid;
  grid-template-columns: repeat(2, 1fr); !* 2 колонки *!
  gap: 20px;
  margin: 100px var(--side-padding) 0;
  grid-auto-rows: auto; !* по умолчанию *!
  height: auto;
}

.equal-box {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  min-height: 350px;
}

!* Первый блок с текстом *!
.overlay-box {
  background-color: #d7f1f7;
  display: flex;
  flex-direction: column;
  padding: 30px;
  justify-content: flex-start;
}

.overlay-caption {
  color: #000230;
  font-size: 32px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.2;
}

.overlay-description {
  color: #000230;
  font-size: 18px;
  line-height: 1.6;
  font-weight: 500;
  margin-top: 20px;
  opacity: 0.8;
  text-align: justify-all;
}

!* Общие стили для карточек *!
.info-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.info-box-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.2));
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px;
  transition: background 0.4s ease-in-out;
}

.info-box:hover .info-box-overlay {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.7));
}

.info-text h3 {
  color: #fff;
  font-size: 1.4rem;
  margin-bottom: 10px;
  font-weight: 600;
}

.info-text p {
  color: #fff;
  font-size: 16px;
  opacity: 0;
  transform: translateX(-20px);
  transition: all 0.5s ease;
}

.info-box:hover .info-text p {
  opacity: 1;
  transform: translateX(0);
}

.info-btn {
  align-self: flex-end;
  background-color: rgba(255, 255, 255, 0.9);
  color: #2e2e2e;
  padding: 8px 16px;
  font-weight: 600;
  text-decoration: none;
  font-size: 0.9rem;
  transition: all 0.3s ease;
}

.info-btn:hover {
  background-color: #2e2e2e;
  color: #fff;
}

!* ✅ Правильное выравнивание по высоте первого блока от 768px и выше *!
@media (min-width: 768px) {
  .equal-grid-section {
    grid-auto-rows: 1fr; !* Все строки одинаковой высоты *!
  }

  .equal-box {
    height: 100%; !* Подстраиваются под высоту строки *!
    max-height: 350px; !* Убираем ограничение *!
  }

  .overlay-box {
    height: auto; !* Высота по содержимому *!
  }
}


@media (max-width: 1100px) {
    .equal-box {
    height: 100%; !* Подстраиваются под высоту строки *!
    max-height: 450px; !* Убираем ограничение *!
  }
}

@media (max-width: 991px) {
     .overlay-description {
      color: #000230;
      font-size: 16px;
      line-height: 1.6;
      font-weight: 500;
      margin-top: 20px;
      opacity: 0.8;
      text-align: justify-all;
    }
}

!* 📱 Адаптив для мобильных устройств до 768px *!
@media (max-width: 768px) {
  .equal-grid-section {
    grid-template-columns: 1fr;
  }

  .equal-box {
    height: 100%;
    max-height: 350px;
    min-height: unset;
  }

  .overlay-caption {
    font-size: 24px;
  }

  .overlay-description {
    font-size: 16px;
  }
}





.section-wrapper {
  padding: 0px var(--side-padding);
  margin-top: 100px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

!* ВЕРХНИЙ РЯД *!
.top-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: stretch;
}

.top-box {
  border-radius: 20px;
  overflow: hidden;
  min-height: 350px;
  height: 100%;
  position: relative;
}

.image-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.image-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: 20px;
  background: linear-gradient(rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0));
}

.overlay-title {
  color: white;
  font-size: 1.7rem;
  font-weight: 600;
}

.section-wrapper .text-box {
  background-color: #d7f1f7;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.text-box p {
  font-size: 18px;
  line-height: 1.6;
  color: #2e2e2e;
  margin-bottom: 20px;
}

.info-btn {
  align-self: flex-start;
  background-color: #2e2e2e;
  color: #fff;
  padding: 10px 20px;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: 8px;
  transition: all 0.3s ease;
}

.info-btn:hover {
  background-color: #000;
}

!* ОБЁРТКА *!
.video-slider-section {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background-color: rgba(238, 252, 255, 1);
  gap: 30px;
  align-items: center;
}

.video-swiper {
  width: 100%;
  max-width: 100%;
  border-radius: 20px;
  overflow: hidden;
  background-color: rgba(238, 252, 255, 1);
}

!* СЛАЙД: одинаковая высота и растяжение колонок *!
.video-swiper .swiper-slide {
  display: flex; !* чтобы внутри растягивалось по высоте *!
}

.video-description-slide {
    --slide-min-height: 370px; !* можно подстроить под дизайн *!
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;      !* ключ: тянем колонки на одну высоту *!
  justify-content: space-between;
  background-color: #d7f1f7;
  overflow: hidden;
  width: 100%;
  min-height: var(--slide-min-height);
}

!* ЛЕВАЯ КОЛОНКА (постер вместо видео) *!
.video-column {
  flex: 1 1 50%;
  overflow: hidden;
  !* сохраним пропорции постера, но колонка тянется по высоте слайда *!
  display: flex;
  align-items: stretch;
}

.video-column img.slide-poster {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: #000;
}

!* Если где-то будет использоваться <video> внутри колонки *!
.video-column video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #000;
}

!* ПРАВАЯ КОЛОНКА (текст + кнопка внизу) *!
.text-column {
  flex: 1 1 50%;
  padding: 30px;

  !* добавлено для правильной «прижатости» кнопки *!
  display: flex;
  flex-direction: column;
  justify-content: space-between; !* текст сверху, кнопка снизу *!
}

.text-inner {
  flex-grow: 1;                 !* занимает всё доступное пространство *!
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.text-column h3 {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 15px;
  color: #2e2e2e;
}

.text-column p {
  font-size: 18px;
  line-height: 1.6;
  color: #333;
}

!* КНОПКА ТРЕЙЛЕРА — всегда внизу слева *!
.trailer-btn {
  margin-top: auto;           !* ключ: уводит кнопку к низу колонки *!
  align-self: flex-start;     !* выравнивание по левому краю *!
  padding: 10px 20px;
  background-color: #2e2e2e;
  color: white;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.trailer-btn:hover {
  background-color: #000;
}

!* МИНИАТЮРЫ *!
.thumbs-swiper {
  width: 100%;
  max-width: 800px;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.thumbs-swiper .swiper-slide {
  width: 100px;
  height: 150px;
  opacity: 0.5;
  cursor: pointer;
  transition: 0.3s;
}

.thumbs-swiper .swiper-slide-thumb-active {
  opacity: 1;
  border: 2px solid #000;
  border-radius: 10px;
}

.thumbs-swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}



!* АДАПТИВ *!
@media (max-width: 991px) {
  .trailer-btn {
      margin-top: 30px;
  }

  .video-column,
  .text-column {
    flex: 1 1 100%;
  }
}

!* === АДАПТИВ === *!
@media (max-width: 991px) {
  .top-grid {
    grid-template-columns: 1fr;
  }

  .bottom-grid {
    grid-template-columns: 1fr;
  }

  .video-box {
    aspect-ratio: 16 / 9;
  }

  .text-box h2 {
    font-size: 1.6rem;
  }

  .text-box p {
    font-size: 16px;
  }
}




.gallery-slider-section {
  width: 100%;

  background-color: rgba(238, 252, 255, 1);
}

.imageGallerySwiper {
  width: 100%;
  box-sizing: border-box;
  position: relative;

}

.imageGallerySwiper .swiper-wrapper {
  align-items: center;
}

.imageGallerySwiper .swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
    aspect-ratio: 3 / 2;
  transition: transform 0.3s ease;
}

.imageGallerySwiper .swiper-slide img {
  width: 100%;

   height: 100%;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

!* Стрелки *!
.gallery-button-prev,
.gallery-button-next {
  color: #ffffff;

  border-radius: 50%;
  width: 44px;
  height: 44px;
  top: 50%;
  z-index: 10;
}



!* Пагинация *!
.gallery-pagination .swiper-pagination-bullet {
  background: #000;
}




.values-section {
  background: #d7f1f7;
    margin-top: 100px;
}

.section-title {
  font-size: 2.5rem;
  font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
    padding-top: 40px;
  color: #000230;
    text-align: center;


}

.section-subtitle {
  font-size: 18px;
  color: #000230;
    opacity: 0.6;

 margin: 20px auto;
    margin-bottom: 40px;
  line-height: 1.6;
    text-align: center;
}


!* Grid-контейнер *!
.values-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));


  margin: 0 auto;
}

!* Элемент *!
.value-item {
  background-color: #d7f1f7;

  padding: 30px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;

}


.value-item .icon {
  font-size: 35px;
  color: #2c4373;

  width: 80px;
  height: 80px;
  background-color: #ffffff;
  border-radius: 50%;

  display: flex;
  align-items: center;
  justify-content: center;

  margin-bottom: 15px;
  transition: color 0.3s ease, transform 0.3s ease;
}

.value-item:hover .icon {
  color: #80bfff;
  transform: scale(1.15);
}

.value-item p {
  font-weight: 600;
  font-size: 18px;
  color: #2e2e2e;
}









.team-section {
  background-color: rgba(238, 252, 255, 1);
  padding: 100px var(--side-padding);
}

.team-container {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  width: 100%;
}

.team-card {
  flex: 1 1 calc((100% - 40px) / 3); !* 3 карточки и два gap по 20px *!
  aspect-ratio: 3/4;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
}

.team-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.card-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 20px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent 20%);
  color: white;
  height: 100%;
  box-sizing: border-box;
}

.card-info {
  text-align: left;
}

.team-name {
  font-size: 18px;
  font-weight: 700;
  margin: 0;
}

.team-role {
  font-size: 14px;
  margin-top: 4px;
  opacity: 0.85;
}

.team-button {
  background-color: rgba(255, 255, 255, 0.9);
  color: #2e2e2e;
  padding: 8px 14px;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 4px;
  transition: all 0.3s ease;
}

.team-button:hover {
  background-color: #2e2e2e;
  color: white;
}

!* Адаптив *!
@media (max-width: 768px) {
  .team-container {
    flex-direction: column;
    gap: 30px;
  }

  .team-card {
    width: 100%;
  }
}











.text-photo-grid-section {
  display: grid;
  grid-template-columns: repeat(2, 1fr); !* 2 колонки *!
  gap: 20px;
  padding: 100px var(--side-padding);
  grid-auto-rows: auto; !* по умолчанию *!
  height: auto;
}

!* Общие блоки *!
.grid-box {
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  min-height: 350px;
}

!* Текстовый блок *!
.text-photo-grid-section .text-box {
  background-color: #d7f1f7;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.text-box h2 {
  font-size: 2.5rem;
    line-height: 1.2;
  font-weight: 700;
  color: #2e2e2e;
  margin-bottom: 20px;
}

.text-box p {
  font-size: 18px;
  line-height: 1.6;
  color: #2e2e2e;
  margin-bottom: 16px;
}

!* Фото-блоки *!
.photo-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
}

!* ✅ Выравнивание по высоте первого блока от 768px *!
@media (min-width: 768px) {
  .text-photo-grid-section {
    grid-auto-rows: 1fr; !* Все строки одинаковой высоты *!
  }

  .grid-box {
    height: 100%; !* все блоки тянутся до высоты строки *!
    min-height: unset;
  }

  .text-box {
    height: auto; !* определяет высоту строки *!
  }
}

!* 📱 Мобильный адаптив *!
@media (max-width: 768px) {
  .text-photo-grid-section {
    grid-template-columns: 1fr;
  }

  .grid-box {
    height: auto;
    min-height: unset;
  }

  .text-box h2 {
    font-size: 2rem;
  }

  .text-box p {
    font-size: 16px;
  }
}





.ambassadors-section {
    padding: 0px var(--side-padding);
    padding-bottom: 50px;
    background-color: #d7f1f7;
}

!* Внутри слайдера превращаем grid в ленту *!
.ambassadors-swiper .ambassadors-grid {
  display: flex !important;
}

!* Слайды одной высоты по карточке + плавные анимации перелистывания *!
.ambassadors-swiper .swiper-wrapper {
  align-items: stretch;
}
.ambassadors-swiper .swiper-slide {
  display: flex;
  height: auto;
  transition: transform 400ms ease, opacity 400ms ease;
}
.ambassadors-swiper .swiper-slide .ambassador-card {
  width: 100%;
}

!* Красивый акцент активного слайда (легкий подъём) *!


!* Стрелки управления *!
.ambassadors-button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: none;
  background: rgba(0,0,0,0.45);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: saturate(140%) blur(2px);
  transition: background 0.25s ease, transform 0.15s ease, opacity 0.25s ease;
  opacity: 0.9;
}


!* поверх картинки *!
.ambassador-overlay {
  z-index: 2;
}

!* за картинку отвечаем явно *!
.ambassador-card img {
  position: relative;
  z-index: 1;
}

.ambassador-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.75), transparent 40%);
  transition: background 0.4s ease-in-out;
  pointer-events: none;
}

.ambassador-name {
  font-size: 18px;
  font-weight: 700;
  color: white;
  transition: transform 0.4s ease-in-out;
  z-index: 2;
  pointer-events: auto;
}

!* Вот тут магия *!
.ambassador-title {
  font-size: 14px;
  color: white;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.4s ease-in-out;
  pointer-events: auto;
}

!* Hover эффекты *!


.ambassador-card:hover .ambassador-overlay {
  background: linear-gradient(to top, rgba(0, 0, 0, 0.95), transparent 60%);
}

.ambassador-card:hover .ambassador-title {
  opacity: 1;
  max-height: 100px; !* любое, главное > высоты строки *!
  transform: translateY(0);

}

.ambassador-card:hover .ambassador-name {
  transform: translateY(-4px);
}



.ambassadors-button:hover { background: rgba(0,0,0,0.7); }
.ambassadors-button:active { transform: translateY(-50%) scale(0.96); }
.ambassadors-button-prev { left: 8px; }
.ambassadors-button-next { right: 8px; }

!* Пагинация (по желанию) *!
.ambassadors-pagination {
  position: relative;
  margin-top: 18px;
}
.ambassadors-pagination .swiper-pagination-bullet {
  width: 8px; height: 8px; opacity: .4;
  background: #2e2e2e; transition: opacity .25s ease, transform .25s ease;
}
.ambassadors-pagination .swiper-pagination-bullet-active {
  opacity: 1; transform: scale(1.1);
}

!* Респонсив-подсказки — ширина контейнера и «воздух» между слайдами задаются в JS через spaceBetween и slidesPerView *!




*/
