/* —— На абордаж · Унифицированный дизайн —— */
:root{
  --bg:#031a2a;
  --glass: rgba(5,25,40,.6);
  --muted:#cfe6ff;
  --accent:#1e8fff;
  --card:#0f344f;
  --gap-section:80px;
  --gap-inner:32px;
  --container:1100px;
  --ocean-1:#07233c; --ocean-2:#0d3b66; --ocean-3:#1f6fb4; --sand:#f3e7c7;
  --ink:#0b1220; --border:#e6e7eb; --card:#ffffff;
  --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:22px; --shadow:0 10px 30px rgba(9,30,66,.10);
}
/* базовая сетка */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
  background:var(--bg);
  color:#eaf4ff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
img{max-width:100%;display:block}

a{color:inherit}
h1,h2,h3{margin:0 0 16px 0}
p{margin:0 0 16px 0}
.section-title{font-weight:900;letter-spacing:.2px;font-size:clamp(28px,2.2vw,40px);margin:0 0 18px}
.lead{font-size:clamp(16px,1.1vw,18px);opacity:.95}
.muted{color:var(--muted)}
.max{max-width:70ch}

/* header */
.site-header{
  background:rgba(5,25,40,.85);
  backdrop-filter:blur(6px);
  padding:14px 0;
  position:sticky;top:0;z-index:60;
  border-bottom:1px solid rgba(255,255,255,.03);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{font-weight:700;color:#fff;text-decoration:none;font-size:18px}
.nav{display:flex;gap:12px}
.nav a{color:#eaf4ff;text-decoration:none;padding:8px 10px;border-radius:8px;font-weight:500}
.nav a[aria-current="page"]{background:rgba(255,255,255,.02)}
.actions{display:flex;align-items:center;gap:10px}
select{border-radius:8px;padding:6px 8px;border:0;background:rgba(255,255,255,.03);color:#eaf4ff}

/* Унифицированные кнопки */
.btn{display:inline-block;padding:10px 16px;border-radius:8px;text-decoration:none;font-weight:600;transition:all .3s ease}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 20px rgba(30,143,255,.12)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(30,143,255,.2)}
.btn-secondary{background:rgba(255,255,255,.1);color:#fff;border:2px solid rgba(255,255,255,.3);backdrop-filter:blur(10px)}
.btn-secondary:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}

/* section spacing unified */
section{padding:calc(var(--gap-section)) 0}
section .container > h2 { text-align:center; margin-bottom:24px; font-size:26px }

/* HERO */
.hero{
  position:relative;
  color:#fff;
  padding:110px 20px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:linear-gradient(180deg, rgba(3,26,42,.6), rgba(3,26,42,.3));
  z-index:1;
}
.hero video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
}
.hero .hero-inner{max-width:880px}
.hero h1{font-size:48px;line-height:1.05;margin-bottom:16px;font-weight:800;text-shadow:0 4px 20px rgba(0,0,0,.5)}
.hero-subtitle{font-size:20px;color:var(--muted);margin-bottom:28px;font-weight:500;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-actions .btn{min-width:200px;padding:14px 24px;font-size:16px;font-weight:600}

/* Glass компоненты */
.glass{
  background:var(--glass);backdrop-filter:blur(6px);
  border-radius:18px;padding:28px;display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 18px 60px rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.04)
}
.glass h2{font-size:22px}
.glass p{color:var(--muted)}

/* about-grid */
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:var(--gap-inner);align-items:stretch}
.photo{border-radius:14px;overflow:hidden;background:var(--card);display:flex;align-items:center;justify-content:center}
.photo img{width:100%;height:100%;object-fit:cover;display:block}

.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
.fact{background:rgba(15,52,79,.85);padding:12px;border-radius:12px;text-align:center}
.fact b{display:block;font-size:18px;color:#fff}

/* info blocks */
.info-block{max-width:880px;margin:0 auto;background:rgba(5,25,40,.45);padding:28px;border-radius:14px;box-shadow:0 12px 34px rgba(0,0,0,.24)}
.info-block h3{text-align:center;margin-bottom:18px}
.info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.info-list li{padding-left:28px;position:relative}
.info-list li::before{content:"⚓";position:absolute;left:0;top:0;color:var(--accent)}

/* gallery */
.gallery-wrap{max-width:1100px;margin:0 auto}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-grid img{width:100%;height:100%;object-fit:cover;border-radius:12px;aspect-ratio:16/10;display:block}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
.team-card{background:rgba(15,52,79,.85);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 18px 60px rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.02)}
.team-card .img{aspect-ratio:16/10;overflow:hidden}
.team-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s}
.team-card:hover img{transform:scale(1.03)}
.team-card .body{padding:16px;background:linear-gradient(180deg,rgba(6,24,38,.6),rgba(6,24,38,.45));flex:1}

/* videos */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.video{border-radius:12px;overflow:hidden;background:var(--card);aspect-ratio:16/9;position:relative;box-shadow:0 12px 34px rgba(0,0,0,.18)}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-caption{text-align:center;margin-top:8px;color:var(--muted)}

/* CTA */
.cta__box{max-width:820px;margin:0 auto;padding:36px;border-radius:14px;background:rgba(5,25,40,.6);text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.cta__title{font-size:28px;margin-bottom:12px;font-weight:700}
.cta__text{color:var(--muted);margin-bottom:24px;font-size:16px;line-height:1.5}
.cta__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* footer */
.site-footer{background:linear-gradient(180deg,rgba(7,35,60,.95),rgba(7,35,60,.85));padding:20px 0;border-top:1px solid rgba(255,255,255,.04)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.socials a{margin-left:12px;color:var(--muted);text-decoration:none}

/* Карточки услуг */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--card);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);transform:translateY(0);transition:transform .18s ease, box-shadow .18s ease;position:relative;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(120deg,#cddff7,#9cd1ff) border-box;border:1px solid transparent}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 60px rgba(31,111,180,.20)}
.card img{aspect-ratio:16/9;object-fit:cover;transition:transform .6s ease}
.card:hover img{transform:scale(1.04)}
.card-body{padding:16px}
.price-row{display:flex;align-items:center;gap:10px;margin:12px 0 4px}
.badge{background:#eef6ff;border:1px solid #c6ddff;padding:6px 10px;border-radius:999px;font-size:12px}
.sep{width:1px;height:14px;background:#e5e7eb;display:inline-block;margin:0 6px}

/* Сетки и галереи */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gallery-grid img{border-radius:var(--r-md);border:1px solid var(--border)}
.masonry{columns:3;column-gap:12px}
.masonry img{margin:0 0 12px;border-radius:var(--r-md);border:1px solid var(--border);background:#fff;box-shadow:0 6px 20px rgba(0,0,0,.06)}

/* Формы */
.form{padding:20px}
.form h3{margin:0 0 10px;} /* фикс опечатки */
.form label{display:block;font-size:14px;margin:10px 0}
.form input,.form select,.form textarea{width:100%;padding:12px;border-radius:var(--r-md);border:1px solid var(--border);background:#fff;transition:border-color .15s ease, box-shadow .15s ease}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:#1f6fb4;box-shadow:0 0 0 3px rgba(31,111,180,.15)}

/* Футер */
.site-footer{background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));border-top:1px solid rgba(255,255,255,.22);padding:18px 0;color:#fff}
.footer-flex{display:flex;align-items:center;justify-content:space-between}
.socials a{color:#fff;margin-left:14px;opacity:.9}

/* FABs */
.chat-fab{position:fixed;right:16px;bottom:16px;padding:13px 15px;border-radius:999px;color:#fff;text-decoration:none;font-weight:800;box-shadow:0 10px 30px rgba(0,0,0,.2)}
.chat-fab.wa{background:#25D366;bottom:80px}
.chat-fab.tg{background:#229ED9}

/* Reveal-анимация */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.show{opacity:1;transform:translateY(0)}

/* Адаптив */
@media (max-width:1080px){
  .hero-copy h1{font-size:clamp(32px,4.2vw,48px); color:#ffffff;} /* фикс ; */
}
@media (max-width:960px){
  .hero-grid,.grid-2{grid-template-columns:1fr}
  .cards-3{grid-template-columns:1fr}
  .masonry{columns:2}
}
@media (max-width:560px){
  .masonry{columns:1}
  .section{padding:64px 0}
}

/* Prevent anchor overlap with sticky header */
[id]{scroll-margin-top:72px}

/* Better keyboard focus */
:where(a,button,.btn,input,select,textarea):focus-visible{outline:3px solid #1f6fb4;outline-offset:2px}

/* Лёгкие правки по просьбе */
.ambient{display:none !important} /* скрыть «летающие» */
.section-title{color:#fff;} /* белые заголовки */

/* === HERO (вариант A) — поддержка текущей вёрстки на главной === */
.hero--card { padding: 64px 0 40px; }
.hero__wrap { 
  display:grid; grid-template-columns:minmax(320px,1fr) minmax(420px,560px);
  gap:40px; align-items:center;
}
.eyebrow{
  display:inline-block; padding:6px 10px; border-radius:999px;
  font-weight:600; font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  background:rgba(255,255,255,.08); color:#eaf4ff; margin-bottom:10px;
}
.hero__title{ font-size:56px; line-height:1.05; margin:0 0 12px; color:#fff; }
.hero__lead{ color:#eaf4ff; opacity:.95; margin:0 0 18px; }
.hero__actions{display:flex; gap:12px; margin:22px 0}
.hero__bullets{ display:flex; flex-wrap:wrap; gap:10px 14px; padding:0; margin:18px 0 0; list-style:none; color:#eaf4ff; opacity:.9; }
.hero__bullets li{ position:relative; padding-left:14px; }
.hero__bullets li::before{ content:"•"; position:absolute; left:0; opacity:.6; }

.hero__photo{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
  padding:10px; border-radius:24px; box-shadow:0 18px 50px rgba(0,0,0,.35);
}
.hero__photo img{ width:100%; display:block; border-radius:18px; }

/* Адаптив для hero A */
@media (max-width: 960px){
  .hero__wrap{ grid-template-columns:1fr; }
  .hero__title{ font-size:44px; }
}

/* === Ken Burns hero slideshow (no extra classes) === */
.hero__photo{
  position:relative; overflow:hidden; padding:10px;
  border-radius:var(--r-xl); box-shadow:0 18px 60px rgba(0,0,0,.30);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
  aspect-ratio: 16 / 10;
  min-height: clamp(220px, 32vw, 520px);
}
.hero__photo > img{
  position:absolute !important; inset:10px !important;
  width:calc(100% - 20px) !important; height:calc(100% - 20px) !important;
  object-fit:cover !important; display:block !important;
  border-radius:calc(var(--r-xl) - 6px) !important;
  opacity:0; animation:kbFade 30s linear infinite, kbMove 30s ease-in-out infinite;
}
.hero__photo > img:nth-child(1){animation-delay:0s}
.hero__photo > img:nth-child(2){animation-delay:5s}
.hero__photo > img:nth-child(3){animation-delay:10s}
.hero__photo > img:nth-child(4){animation-delay:15s}
.hero__photo > img:nth-child(5){animation-delay:20s}
.hero__photo > img:nth-child(6){animation-delay:25s}

@keyframes kbFade{0%{opacity:0}4%{opacity:1}16%{opacity:1}20%{opacity:0}100%{opacity:0}}
@keyframes kbMove{0%{transform:scale(1.08) translate3d(-2%,-2%,0)}16%{transform:scale(1.16) translate3d(2%,2%,0)}20%,100%{transform:scale(1.08) translate3d(-2%,-2%,0)}}
@media (prefers-reduced-motion: reduce){.hero__photo > img{animation:none;opacity:1}}
/* === HERO: размер + адаптив (фикс) === */

/* ограничиваем ширину правой колонки с фото */
.hero__wrap{
  /* текст — свободно, фото — не шире 40% экрана и не шире 560px */
  grid-template-columns:minmax(320px,1fr) min(40vw, 560px);
}

/* сама карточка с футажем: контролируем высоту */
.hero__photo{
  aspect-ratio: 16 / 10;      /* чтобы высота считалась от ширины */
  max-height: min(42vh, 420px);/* не выше 42% высоты экрана и 420px */
  min-height: 220px;           /* запас на старые браузеры */
  border-radius: var(--r-xl);
  overflow: hidden;
}

/* внутри ничего не меняем — твой Ken Burns останется таким же */

/* планшеты и телефоны */
@media (max-width: 1024px){
  .hero__wrap{ grid-template-columns:1fr; } /* фото под/над текстом, одна колонка */
  .hero__photo{
    max-width: min(92vw, 520px);
    margin: 0 auto 18px;      /* центрируем фото */
    aspect-ratio: 16 / 9;
    max-height: 320px;
    min-height: 200px;
  }
}

/* очень большие экраны — не даём растягиваться слишком сильно */
@media (min-width: 1600px){
  .hero__wrap{ grid-template-columns:minmax(420px,1fr) 560px; }
}
/* ====== Общие для внутренних страниц ====== */
.page-header{padding:48px 0 16px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,0));border-bottom:1px solid #ffffff22}
.page-header h1{margin:0 0 8px;font-size:clamp(28px,3.2vw,40px);color:#fff}
.illustration img{border-radius:18px;border:1px solid #ffffff22}
.checklist{margin:12px 0 0;padding:0 0 0 18px}
.checklist li{margin:6px 0}

/* Галерея уже есть; на всякий случай подправим отступы */
.gallery-grid{gap:12px}

/* Контакты */
.contact-card{padding:16px;background:#0f344f;border:1px solid #ffffff22;border-radius:14px}
.map-embed{position:relative;padding-top:56%;border-radius:14px;overflow:hidden;border:1px solid #ffffff22}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ====== Блок "Почему мы" на главной ====== */
.features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.feat{background:#0f344f;border:1px solid #ffffff22;border-radius:14px;padding:14px;height:100%}
.feat__icon{font-size:22px;line-height:1;margin-bottom:6px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}
.feat__title{margin:0 0 6px;color:#fff;font-size:18px}
.feat__text{margin:0;color:#cfe3fa}

/* CTA */
.cta__box{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));border:1px solid #ffffff22;border-radius:18px;padding:18px}
.cta__title{margin:0 0 6px;font-size:clamp(22px,2.4vw,28px);color:#fff}
.cta__text{margin:0 0 12px;color:#cfe3fa}
.cta__actions{display:flex;gap:10px}

/* Адаптив */
@media (max-width: 960px){
  .features__grid{grid-template-columns:1fr 1fr}
  .cta__box{flex-direction:column;align-items:flex-start}
}
@media (max-width: 560px){
  .features__grid{grid-template-columns:1fr}
}
/* === Контраст текста для внутренних страниц (.page) === */

/* Шапка страницы: белый текст + лёгкая тень для читаемости */
.page-header h1{
  color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.35);
}
.page-header .lead{
  color:#fff;
  opacity:.96;                 /* чтобы не «слепило» */
  text-shadow:0 1px 10px rgba(0,0,0,.3);
}

/* Ниже по странице — чуть более тёмный текст */
.page .section,
.page .section p,
.page .section li,
.page .section .muted{
  color:#cfe3fa;               /* мягкий голубовато-серый */
}

/* Заголовки секций остаются белыми */
.page .section .section-title{
  color:#fff;
}

/* На всякий случай — ссылки внутри текста */
.page .section a{
  color:#eaf4ff;
  text-decoration:underline;
  text-underline-offset:2px;
}

/* === Команда: читаемость карточек (светлый фон) === */
.page .cards-3 .card{
  background:#ffffff;
  border:1px solid #e6eef7;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
}
.page .cards-3 .card .card-body{
  background:linear-gradient(180deg,#ffffff 0%, #f5f9ff 100%);
  color:#123953;
}
.page .cards-3 .card .card-body h3{ color:#0b2a42; }
.page .cards-3 .card .muted{ color:#385d7a; }
.page .cards-3 .card .card-body p,
.page .cards-3 .card .card-body li { color:inherit; }

/* ===== Команда: ровные карточки по высоте ===== */
.team-grid{
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;           /* растягиваем треки, чтобы все колонки были одинаковой высоты */
}

/* Карточка занимает всю высоту своей колонки */
.team-card{
  display: flex;
  flex-direction: column;
  height: 100%;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid #ffffff22;
  background: #0f344f;
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
}

/* Картинка фиксированного соотношения сторон */
.team-card .img{
  flex: 0 0 auto;
  aspect-ratio: 16 / 10;
  overflow: hidden;
}
.team-card .img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background:#0f344f; /* на случай, если фото не подгрузится */
}

/* Тело карточки растягивается, лишняя высота поглощается здесь */
.team-card .body{
  flex: 1 1 auto;                 /* занимает всё доступное пространство */
  display: flex;
  flex-direction: column;
  padding: 16px;
  background: linear-gradient(180deg, rgba(6,24,38,.65), rgba(6,24,38,.45));
}

/* Заголовок сверху, текст прижат вниз — выглядит ровно при любой высоте */
.team-card .body h4{
  margin: 0 0 8px;
  color:#fff;
}
.team-card .body p{
  margin: auto 0 0;               /* текст опускается к низу блока */
  color:#eaf4ff;
}

/* Адаптив — как было */
@media (max-width:1024px){
  .team-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:720px){
  .team-grid{ grid-template-columns:1fr; }
}
/* ===== Reviews (glass) ===== */
.reviews {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, 1fr);
}
.review-card {
  background: linear-gradient(180deg, rgba(5,25,40,.58), rgba(5,25,40,.40));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 16px;
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
  padding: 14px;
  color: #eaf4ff;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.review-head{ display:flex; align-items:center; gap:10px }
.review-ava{
  width:42px; height:42px; border-radius:50%;
  object-fit:cover; background:#0f344f; border:1px solid #ffffff22;
}
.review-name{ font-weight:800; color:#fff; line-height:1.1 }
.review-meta{ opacity:.8; font-size:13px }
.badge{
  display:inline-block; padding:2px 8px; border-radius:999px;
  border:1px solid #ffffff26; background:#0d2f49; margin-right:6px; font-size:12px;
}
.badge.google{ background:#0F5BDF; border-color:#0F5BDF }
.badge.trip{ background:#34A853; border-color:#34A853 }
.badge.ig{ background:#C13584; border-color:#C13584 }

.review-stars{ color:#ffd15b; letter-spacing:2px; font-size:16px; }
.review-body{ margin:0; }
.review-link{ color:#cfe7ff; font-size:13px; text-decoration:underline; opacity:.9 }
.review-photos{ display:flex; gap:8px; }
.review-photos img{
  width:74px; height:74px; object-fit:cover; border-radius:8px;
  border:1px solid #ffffff20; background:#0f344f;
}

@media (max-width: 1024px){ .reviews{ grid-template-columns: 1fr 1fr } }
@media (max-width: 640px){ .reviews{ grid-template-columns: 1fr } }

/* responsive */
@media (max-width:1024px){
  .about-grid{grid-template-columns:1fr}
  .gallery-grid,.video-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .facts{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .hero{padding:80px 20px}
  .gallery-grid,.video-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  section{padding:48px 0}
  .facts{grid-template-columns:1fr}
}
