/* ============================================================
   LATAM MOVE — main.css
   Источник визуальной системы: одобренный макет latammove-preview
   (токены, кнопки, карточки, hero-слайдшоу — 1:1) + компоненты
   внутренних страниц. Шрифты ТОЛЬКО self-hosted.
   ============================================================ */

/* ---------- Шрифты (subset cyrillic+latin, woff2) ---------- */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/PlayfairDisplay-Regular.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/PlayfairDisplay-Medium.woff2') format('woff2')}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/PlayfairDisplay-SemiBold.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/Inter-Regular.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/Inter-Medium.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/Inter-SemiBold.woff2') format('woff2')}

/* ---------- Токены (из :root одобренного макета) ---------- */
:root{
  --c-navy:#0A2540; --c-navy-deep:#061829; --c-navy-soft:#1A3553;
  --c-gold:#D4A017; --c-gold-bright:#E5B82E;
  --c-off-white:#F6F6F3; --c-white:#FFFFFF;
  --c-text:#0A2540; --c-text-muted:#4A5A70;
  --c-border:rgba(10,37,64,.12); --c-border-gold:rgba(212,160,23,.4);
  --font-serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --container:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans); color:var(--c-text);
  background:var(--c-off-white); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;color:inherit}

/* ---------- Утилиты ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.container--prose{max-width:820px}
.section{padding:clamp(64px,8vw,96px) 0}
.section--dark{background:var(--c-navy);color:var(--c-white)}
.section--deep{background:var(--c-navy-deep);color:var(--c-white)}
.section--white{background:var(--c-white)}

.eyebrow{
  font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-gold);display:inline-block;margin-bottom:18px;
}
.section--dark .eyebrow,.section--deep .eyebrow,.page-hero .eyebrow{color:var(--c-gold-bright)}
.eyebrow-link{border-bottom:1px solid var(--c-border-gold)}
.eyebrow-link:hover{color:var(--c-gold)}

h1,h2,h3,h4{font-family:var(--font-serif);line-height:1.1;font-weight:600}
.h2{font-size:clamp(28px,3.5vw,44px);font-weight:600}
.h3{font-size:clamp(20px,2vw,28px);font-weight:600}
.lead-l{font-size:18px;line-height:1.6}
.muted{color:var(--c-text-muted)}
.section--dark .muted,.section--deep .muted{color:rgba(255,255,255,.7)}
.center{text-align:center}
.mw-720{max-width:720px}
.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}

.section-head{max-width:680px;margin-bottom:clamp(40px,5vw,64px)}
.section-head.center{margin-left:auto;margin-right:auto}

.divider-gold{width:56px;height:1px;background:var(--c-gold);border:0;margin:32px 0}

/* стрелка-ссылка */
.link-arrow{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:500;font-size:15px;color:var(--c-navy);
  border-bottom:1px solid var(--c-border-gold);padding-bottom:4px;
  transition:gap .3s var(--ease),border-color .3s var(--ease);
}
.section--dark .link-arrow,.section--deep .link-arrow{color:var(--c-white)}
.link-arrow .arr{transition:transform .3s var(--ease)}
.link-arrow:hover{gap:16px;border-color:var(--c-gold)}
.link-arrow:hover .arr{transform:translateX(4px)}

/* ---------- Кнопки (4 варианта по макету) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-sans);font-size:15px;font-weight:500;
  padding:18px 32px;border:1px solid transparent;cursor:pointer;
  border-radius:0;transition:all .3s var(--ease);white-space:nowrap;
}
.btn-primary{background:var(--c-navy);color:var(--c-white)}
.btn-primary:hover{background:var(--c-navy-deep)}
.btn-secondary{background:transparent;border-color:var(--c-gold);color:var(--c-navy)}
.btn-secondary:hover{background:var(--c-gold);color:var(--c-navy)}
.btn-gold{background:var(--c-gold);color:var(--c-navy);font-weight:600}
.btn-gold:hover{background:var(--c-gold-bright)}
.btn-ghost-light{background:transparent;border-color:rgba(255,255,255,.35);color:var(--c-white)}
.btn-ghost-light:hover{background:var(--c-white);color:var(--c-navy)}
.btn-block{width:100%}

/* ---------- SVG-флаги (НЕ эмодзи — см. план, раздел 2) ---------- */
.flag{width:26px;height:19px;display:inline-block;vertical-align:middle;border:1px solid rgba(255,255,255,.2)}
.flag--sm{width:20px;height:14px}

/* ============================================================
   HEADER (sticky, минималистичный)
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(246,246,243,.88);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--c-border);
}
.header__inner{display:flex;align-items:center;gap:32px;height:76px}
.brand{display:flex;align-items:center;gap:11px;font-weight:600}
.brand__mark{width:26px;height:26px;flex:none}
.brand__name{
  font-size:17px;letter-spacing:.08em;color:var(--c-navy);
  font-family:var(--font-sans);font-weight:600;white-space:nowrap;
}
.brand__name b{color:var(--c-navy);font-weight:700}
.brand__name span{color:var(--c-gold);font-weight:600}
.brand__name--light{color:#fff!important}

.nav{display:flex;align-items:center;gap:28px;margin-left:14px}
.nav__link{
  font-size:15px;font-weight:500;color:var(--c-navy);position:relative;
  padding:6px 0;transition:color .25s var(--ease);
  background:none;border:0;cursor:pointer;
}
.nav__link::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;
  background:var(--c-gold);transition:width .3s var(--ease);
}
.nav__link:hover{color:var(--c-text-muted)}
.nav__link:hover::after{width:100%}

.nav__more{position:relative}
.nav__more-btn{display:inline-flex;align-items:center;gap:6px}
.dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--c-white);border:1px solid var(--c-border);min-width:210px;padding:8px;
  opacity:0;visibility:hidden;transition:all .25s var(--ease);
  box-shadow:0 24px 48px -24px rgba(10,37,64,.25);
}
.nav__more:hover .dropdown,.nav__more:focus-within .dropdown,.nav__more.is-open .dropdown{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)
}
.dropdown a{display:block;padding:11px 14px;font-size:14px;font-weight:500;transition:background .2s}
.dropdown a:hover{background:var(--c-off-white);color:var(--c-gold)}

.header__right{margin-left:auto;display:flex;align-items:center;gap:22px}
.lang{display:flex;align-items:center;gap:2px;font-size:13px;font-weight:600;letter-spacing:.04em}
.lang__item{padding:4px 7px;color:var(--c-text-muted);transition:color .2s}
.lang__item.is-active{color:var(--c-navy)}
.lang__item:not(.is-active):hover{color:var(--c-gold)}
.lang__sep{color:var(--c-border)}
.header__cta{padding:13px 24px;font-size:14px}

.burger{display:none;flex-direction:column;gap:5px;width:26px;background:none;border:0;cursor:pointer;padding:4px 0}
.burger span{height:1.5px;background:var(--c-navy);width:100%;transition:transform .25s var(--ease),opacity .2s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* мобильное меню */
.mobile-nav{
  position:fixed;inset:76px 0 0 0;z-index:49;background:var(--c-off-white);
  padding:24px clamp(20px,5vw,48px) 48px;overflow-y:auto;
}
.mobile-nav__link{
  display:block;padding:16px 0;font-size:19px;font-weight:500;color:var(--c-navy);
  font-family:var(--font-serif);border-bottom:1px solid var(--c-border);
}
.mobile-nav__cta{margin-top:28px;width:100%}

/* ============================================================
   01 · HERO главной (слайдшоу — режим MVP; видео-режим отложен)
   ============================================================ */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;color:#fff}

.hero__slideshow{position:absolute;inset:0;z-index:0;background:#061829;overflow:hidden}
.scene{position:absolute;inset:0;opacity:0;will-change:opacity,transform;animation:sceneCycle 27s linear infinite}
.scene--1{animation-delay:0s;background:linear-gradient(180deg,#f7cd8a 0%,#ee9f5c 18%,#cf7a59 34%,#7e5c6f 54%,#2a4364 76%,#0A2540 100%)}
.scene--2{animation-delay:9s;background:linear-gradient(180deg,#dcebf3 0%,#b2cfe2 20%,#86acc9 40%,#4e7197 62%,#23415f 82%,#0A2540 100%)}
.scene--3{animation-delay:18s;background:linear-gradient(180deg,#eee7ac 0%,#cdd47e 16%,#90b46d 34%,#46835f 58%,#194a3a 80%,#0A2540 100%)}
.scene__sun{position:absolute;inset:0}
.scene--1 .scene__sun{background:radial-gradient(circle at 72% 30%,rgba(255,224,158,.9),rgba(255,200,120,.22) 16%,transparent 40%)}
.scene--2 .scene__sun{background:radial-gradient(circle at 28% 24%,rgba(255,255,255,.55),transparent 36%)}
.scene--3 .scene__sun{background:radial-gradient(circle at 60% 26%,rgba(255,247,200,.55),transparent 40%)}
.scene__art{position:absolute;left:0;right:0;bottom:0;width:100%;height:64%}

/* видео-режим (отложенная опция; включается классом hero--video — см. план) */
.hero__video{display:none;position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;object-position:50% 50%}
.hero--video .hero__video{display:block}
.hero--video .scene-caption{display:none}

.hero__scrim{position:absolute;inset:0;z-index:2;background:
  radial-gradient(ellipse 72% 64% at 50% 46%, transparent 0%, rgba(6,24,41,.34) 100%),
  linear-gradient(180deg, rgba(6,24,41,.5) 0%, rgba(6,24,41,.18) 34%, rgba(6,24,41,.58) 100%);}

.scene-caption{position:absolute;z-index:3;left:clamp(20px,5vw,48px);bottom:36px}
.cap{position:absolute;left:0;white-space:nowrap;font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85);opacity:0;animation:capCycle 27s linear infinite}
.cap::before{content:"";display:inline-block;width:24px;height:1px;background:var(--c-gold);vertical-align:middle;margin-right:13px;transform:translateY(-3px)}
.cap--1{animation-delay:0s}.cap--2{animation-delay:9s}.cap--3{animation-delay:18s}

.hero__glow{position:absolute;left:0;right:0;bottom:0;height:1px;z-index:4;
  background:linear-gradient(90deg,transparent,var(--c-gold) 25%,var(--c-gold-bright) 50%,var(--c-gold) 75%,transparent);}

.hero__scroll{position:absolute;z-index:4;left:50%;bottom:26px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;color:rgba(255,255,255,.6);font-size:10px;letter-spacing:.2em;text-transform:uppercase}
.hero__scroll svg{width:22px;height:22px;animation:bob 1.9s var(--ease) infinite}

.hero__inner{position:relative;z-index:5;padding:88px 0;max-width:900px;margin:0 auto}
.hero__title{
  font-family:var(--font-serif);font-weight:500;color:#fff;
  font-size:clamp(40px,6.4vw,84px);line-height:1.08;letter-spacing:-.005em;
  margin:0 auto;max-width:17ch;text-shadow:0 2px 28px rgba(6,24,41,.5);
}
.hero__title .hl{position:relative;display:inline-block;white-space:nowrap;font-weight:600;z-index:0}
.hero__title .swoosh{position:absolute;left:-2%;top:100%;margin-top:-.10em;width:104%;height:.22em;overflow:visible;z-index:-1}
.hero__title .swoosh path{fill:none;stroke:var(--c-gold);stroke-width:8;stroke-linecap:round}
.hero__sub{font-size:clamp(16px,1.5vw,19px);color:rgba(255,255,255,.85);margin:28px auto 0;max-width:52ch;text-shadow:0 1px 14px rgba(6,24,41,.45)}
.hero__actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:40px;justify-content:center}
.hero__meta{
  display:flex;flex-wrap:wrap;gap:clamp(24px,4vw,44px);margin:52px auto 0;padding-top:26px;
  border-top:1px solid rgba(255,255,255,.18);max-width:680px;justify-content:center;
}
.hero__meta div{font-size:13px;color:rgba(255,255,255,.72)}
.hero__meta b{display:block;font-size:22px;color:#fff;font-weight:600;margin-bottom:2px;font-family:var(--font-sans)}

@keyframes sceneCycle{0%{opacity:0;transform:scale(1.06)}5%{opacity:1}29%{opacity:1}34%{opacity:0}100%{opacity:0;transform:scale(1.16)}}
@keyframes capCycle{0%{opacity:0;transform:translateY(6px)}6%{opacity:1;transform:none}28%{opacity:1}33%{opacity:0}100%{opacity:0}}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.6}50%{transform:translateY(5px);opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.hero__inner>*{animation:fadeUp .8s var(--ease) both}
.hero__inner>*:nth-child(1){animation-delay:.05s}
.hero__inner>*:nth-child(2){animation-delay:.15s}
.hero__inner>*:nth-child(3){animation-delay:.25s}
.hero__inner>*:nth-child(4){animation-delay:.45s}
.hero__inner>*:nth-child(5){animation-delay:.6s}

/* ============================================================
   01a · LEAD (LLM-friendly прямой ответ, серифный)
   ============================================================ */
.lead{background:var(--c-off-white);padding:clamp(56px,7vw,88px) 0}
.lead__text{
  font-family:var(--font-serif);font-weight:400;
  font-size:clamp(20px,2.4vw,27px);line-height:1.5;color:var(--c-navy);
  max-width:760px;margin:0 auto;text-align:center;
}
.lead__text b{font-weight:600}
.lead__rule{margin:0 auto 32px;width:56px;height:1px;background:var(--c-gold);border:0}

/* ============================================================
   02 · TRUST BAR
   ============================================================ */
.trust{background:var(--c-white);padding:clamp(40px,5vw,56px) 0;border-block:1px solid var(--c-border)}
.trust__caption{text-align:center;font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--c-text-muted);margin-bottom:32px}
.trust__logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(28px,6vw,72px)}
.logo-ph{display:flex;align-items:center;gap:10px;opacity:.42;filter:grayscale(1);transition:opacity .3s}
.logo-ph:hover{opacity:.7}
.logo-ph svg{width:26px;height:26px}
.logo-ph span{font-family:var(--font-serif);font-weight:600;font-size:17px;letter-spacing:.02em;color:var(--c-navy)}

/* ============================================================
   03 · USP
   ============================================================ */
.usp{background:var(--c-off-white)}
.usp__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px)}
.usp__item{padding:40px 36px;background:var(--c-white);border:1px solid var(--c-border);transition:border-color .3s var(--ease),transform .3s var(--ease)}
.usp__item:hover{border-color:var(--c-gold);transform:translateY(-4px)}
.usp__icon{width:48px;height:48px;color:var(--c-gold);margin-bottom:26px}
.usp__icon svg{width:100%;height:100%}
.usp__title{font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--c-navy);margin-bottom:14px;font-family:var(--font-sans)}
.usp__desc{color:var(--c-text-muted);font-size:16px}

/* ============================================================
   04 · STATS (gold-on-navy, oversized)
   ============================================================ */
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px 32px;margin-block:clamp(40px,5vw,64px)}
.stat{text-align:center;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-16px;top:18%;bottom:18%;width:1px;background:rgba(255,255,255,.1)}
.stat__num{
  font-family:var(--font-sans);font-weight:500;color:var(--c-gold-bright);
  font-size:clamp(52px,8vw,104px);line-height:1;letter-spacing:-.02em;
}
.stat__label{font-size:14px;color:rgba(255,255,255,.7);margin-top:14px;max-width:18ch;margin-inline:auto}
.stats__sub{text-align:center;max-width:62ch;margin:0 auto;color:rgba(255,255,255,.65);font-size:16px}

/* ============================================================
   05 · SERVICES
   ============================================================ */
.services__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.5vw,32px)}
.service-card{
  position:relative;background:var(--c-off-white);border:1px solid var(--c-border);
  padding:clamp(36px,4vw,56px);display:flex;flex-direction:column;
  transition:border-color .3s var(--ease),transform .3s var(--ease);overflow:hidden;
}
.service-card::before{content:"";position:absolute;left:0;top:0;width:3px;height:0;background:var(--c-gold);transition:height .4s var(--ease)}
.service-card:hover{border-color:var(--c-border-gold);transform:translateY(-4px)}
.service-card:hover::before{height:100%}
.service-card__icon{width:44px;height:44px;color:var(--c-navy);margin-bottom:24px}
.service-card__icon svg{width:100%;height:100%}
.service-card__eyebrow{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--c-gold);margin-bottom:12px}
.service-card__title{font-family:var(--font-serif);font-size:clamp(24px,2.4vw,32px);font-weight:600;color:var(--c-navy);margin-bottom:18px}
.service-card__list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.service-card__list li{font-size:13px;color:var(--c-text-muted);border:1px solid var(--c-border);padding:6px 12px}
.service-card .link-arrow{margin-top:auto;align-self:flex-start}

/* ============================================================
   06 · STEPS
   ============================================================ */
.steps{background:var(--c-white)}
.steps__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px);margin-top:clamp(40px,5vw,56px);position:relative}
.step{position:relative;padding-top:24px}
.step__num{font-family:var(--font-sans);font-weight:500;font-size:clamp(48px,6vw,76px);line-height:1;color:var(--c-gold);opacity:.85;letter-spacing:-.02em}
.step__title{font-family:var(--font-serif);font-size:22px;font-weight:600;color:var(--c-navy);margin:18px 0 12px}
.step__desc{color:var(--c-text-muted);font-size:15px;max-width:36ch}
.step:not(:last-child)::after{content:"";position:absolute;top:46px;right:-20px;width:40px;height:1px;background:var(--c-border-gold)}

/* ============================================================
   07 · DESTINATIONS
   ============================================================ */
.dest{background:var(--c-off-white)}
.dest__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,28px)}
.dest-card{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid var(--c-border);display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.dest-card__media{position:absolute;inset:0;z-index:0;transition:transform .6s var(--ease);background-size:cover;background-position:center}
.dest-card:hover .dest-card__media{transform:scale(1.05)}
.dest-card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,24,41,.05) 30%,rgba(6,24,41,.9) 100%)}
.dest-card:hover{border-color:var(--c-gold)}
.media-py{background:linear-gradient(150deg,#8a6a32,#0A2540 75%)}
.media-br{background:linear-gradient(150deg,#1d6b5f,#061829 78%)}
.media-ar{background:linear-gradient(150deg,#3f74ac,#0A2540 78%)}
.dest-card__body{position:relative;z-index:2;padding:28px}
.dest-card__flag{margin-bottom:14px;display:block}
.dest-card__eyebrow{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--c-gold-bright);margin-bottom:8px;display:block}
.dest-card__name{font-family:var(--font-serif);font-size:30px;font-weight:600;margin-bottom:8px}
.dest-card__usp{font-size:14px;color:rgba(255,255,255,.82);margin-bottom:18px}
.dest-card__more{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#fff;transition:gap .3s}
.dest-card:hover .dest-card__more{gap:14px;color:var(--c-gold-bright)}
.dest__note{text-align:center;margin-top:40px;font-size:15px;color:var(--c-text-muted)}

/* ============================================================
   08 · CASE TEASER
   ============================================================ */
.case{position:relative;min-height:560px;display:flex;align-items:center;color:#fff;overflow:hidden}
.case__bg{position:absolute;inset:0;z-index:0;background:linear-gradient(115deg,#0A2540 18%,rgba(10,37,64,.55) 60%),linear-gradient(150deg,#2a587f,#061829 80%)}
.case__inner{position:relative;z-index:2;padding:80px 0;max-width:680px}
.case__quote{font-family:var(--font-serif);font-weight:500;font-size:clamp(24px,3vw,38px);line-height:1.3;margin:22px 0 28px}
.case__quote::before{content:"«";color:var(--c-gold-bright)}.case__quote::after{content:"»";color:var(--c-gold-bright)}
.case__author{display:flex;align-items:center;gap:14px;margin-bottom:36px}
.case__avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--c-gold),#a87d12);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--c-navy);font-size:15px;flex:none}
.case__author b{display:block;font-weight:600;font-size:15px}
.case__author span{font-size:13px;color:rgba(255,255,255,.6)}
.case__metrics{display:flex;gap:40px;flex-wrap:wrap;margin-bottom:36px}
.case__metric b{display:block;font-size:30px;font-weight:600;color:var(--c-gold-bright);font-family:var(--font-sans)}
.case__metric span{font-size:13px;color:rgba(255,255,255,.65)}
.tag-illustr{position:absolute;top:24px;right:24px;z-index:3;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.2);padding:6px 12px}

/* ============================================================
   09 · INVESTMENTS (cards)
   ============================================================ */
.invest__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,28px)}
.invest-card{background:var(--c-white);border:1px solid var(--c-border);overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.invest-card:hover{border-color:var(--c-gold);transform:translateY(-4px)}
.invest-card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.invest-card__img{position:absolute;inset:0;transition:transform .6s var(--ease);background-size:cover;background-position:center}
.invest-card:hover .invest-card__img{transform:scale(1.04)}
.img-prop{background:linear-gradient(150deg,#27506f,#0A2540)}
.img-prop2{background:linear-gradient(150deg,#705a3a,#241a30)}
.img-land{background:linear-gradient(150deg,#5f6e3a,#1d3526)}
.img-land2{background:linear-gradient(150deg,#3a6e62,#13261d)}
.img-biz{background:linear-gradient(150deg,#6a3f52,#2a1828)}
.img-biz2{background:linear-gradient(150deg,#33547a,#101c2e)}
.invest-card__tag{position:absolute;top:14px;left:14px;z-index:2;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--c-navy);background:var(--c-gold);padding:6px 11px}
.invest-card__overlay{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:14px 16px;background:linear-gradient(180deg,transparent,rgba(6,24,41,.85));color:#fff;font-size:12px;letter-spacing:.06em}
.invest-card__body{padding:24px;display:flex;flex-direction:column;flex:1}
.invest-card__loc{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.invest-card__name{font-family:var(--font-serif);font-size:20px;font-weight:600;color:var(--c-navy);margin-bottom:10px}
.invest-card__desc{font-size:14px;color:var(--c-text-muted);margin-bottom:20px}
.invest-card__foot{margin-top:auto;border-top:1px solid var(--c-border-gold);padding-top:16px;display:flex;align-items:center;justify-content:space-between}
.invest-card__price{font-family:var(--font-sans);font-size:22px;font-weight:600;color:var(--c-navy)}
.invest-card__roi{font-size:12px;color:var(--c-text-muted);text-align:right}
.invest__foot{display:flex;justify-content:center;margin-top:48px}

/* фильтры каталога (CSS-радио + JS-прогрессив) */
.filter-bar{display:flex;flex-wrap:wrap;gap:24px;align-items:center;margin-bottom:clamp(32px,4vw,48px)}
.filter-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.filter-group__label{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-muted);margin-right:6px}
.filter-chip{font-size:13px;font-weight:500;border:1px solid var(--c-border);padding:8px 16px;cursor:pointer;transition:all .25s var(--ease);background:var(--c-white)}
.filter-chip:hover{border-color:var(--c-gold)}
.filter-chip.is-active{background:var(--c-navy);color:#fff;border-color:var(--c-navy)}
.invest-card.is-hidden{display:none}

/* ============================================================
   10 · FINAL CTA + форма
   ============================================================ */
.cta__inner{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,5vw,80px);align-items:center}
.cta__title{font-family:var(--font-serif);font-size:clamp(30px,4vw,52px);font-weight:600;line-height:1.1;margin-bottom:22px}
.cta__sub{color:rgba(255,255,255,.72);font-size:18px;max-width:42ch}
.cta__contacts{display:flex;gap:24px;margin-top:36px;flex-wrap:wrap}
.cta__contact{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.8)}
.cta__contact svg{width:20px;height:20px;color:var(--c-gold-bright);flex:none}
.cta__form{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);padding:clamp(28px,3vw,40px)}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:500;color:rgba(255,255,255,.7);margin-bottom:8px}
.field input,.field textarea{
  width:100%;font-family:var(--font-sans);font-size:15px;color:#fff;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);
  padding:14px 16px;border-radius:0;transition:border-color .25s;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.4)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--c-gold)}
.field textarea{resize:vertical;min-height:96px}
.cta__note{font-size:12px;color:rgba(255,255,255,.5);margin-top:14px;line-height:1.5}
.cta__note a{color:var(--c-gold-bright);border-bottom:1px solid var(--c-border-gold)}

/* honeypot — визуально скрыт, но доступен ботам */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* статус отправки */
.form-status{margin-top:16px;font-size:14px;padding:14px 16px;border:1px solid}
.form-status--ok{color:#c8e6c9;border-color:rgba(120,200,130,.4);background:rgba(120,200,130,.08)}
.form-status--err{color:#ffcdd2;border-color:rgba(240,120,120,.4);background:rgba(240,120,120,.08)}

/* светлая форма (страница /contact на off-white) */
.form-light .cta__form{background:var(--c-white);border-color:var(--c-border)}
.form-light .field label{color:var(--c-text-muted)}
.form-light .field input,.form-light .field textarea{background:var(--c-off-white);border-color:var(--c-border);color:var(--c-text)}
.form-light .field input::placeholder,.form-light .field textarea::placeholder{color:rgba(74,90,112,.55)}
.form-light .cta__note{color:var(--c-text-muted)}
.form-light .cta__note a{color:var(--c-gold)}
.form-light .form-status--ok{color:#1b5e20;background:rgba(76,175,80,.08);border-color:rgba(76,175,80,.35)}
.form-light .form-status--err{color:#b71c1c;background:rgba(244,67,54,.06);border-color:rgba(244,67,54,.3)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--c-navy-deep);color:rgba(255,255,255,.7);padding:clamp(56px,6vw,80px) 0 32px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__tagline{font-size:14px;margin-top:18px;max-width:34ch;color:rgba(255,255,255,.55)}
.footer__offices{font-size:13px;margin-top:22px;letter-spacing:.04em;color:rgba(255,255,255,.45)}
.footer__col h4{font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--c-gold-bright);margin-bottom:18px}
.footer__col a{display:block;font-size:14px;padding:6px 0;color:rgba(255,255,255,.7);transition:color .2s}
.footer__col a:hover{color:#fff}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;padding-top:28px;font-size:12px;color:rgba(255,255,255,.45)}
.footer__privacy{color:rgba(255,255,255,.6);border-bottom:1px solid rgba(255,255,255,.2)}
.footer__privacy:hover{color:#fff}

/* ============================================================
   FLOATING (Telegram + WhatsApp)
   ============================================================ */
.floating{position:fixed;right:24px;bottom:24px;z-index:60;display:flex;flex-direction:column;gap:12px;
  opacity:0;transform:translateY(12px);transition:opacity .35s var(--ease),transform .35s var(--ease);pointer-events:none}
.floating.is-visible{opacity:1;transform:none;pointer-events:auto}
.fab{
  width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--c-navy);border:1px solid var(--c-border-gold);color:#fff;
  box-shadow:0 12px 28px -10px rgba(10,37,64,.5);transition:all .3s var(--ease);
}
.fab:hover{background:var(--c-gold);color:var(--c-navy);transform:translateY(-3px)}
.fab svg{width:24px;height:24px}

/* ============================================================
   ВНУТРЕННИЕ СТРАНИЦЫ
   ============================================================ */

/* компактный navy-hero подстраниц */
.page-hero{position:relative;background:linear-gradient(160deg,var(--c-navy) 30%,var(--c-navy-deep) 100%);color:#fff;padding:clamp(56px,8vw,104px) 0 clamp(40px,6vw,72px)}
.page-hero--compact{padding:clamp(40px,5vw,64px) 0 clamp(32px,4vw,48px)}
.page-hero__title{font-size:clamp(32px,5vw,58px);font-weight:600;max-width:22ch;line-height:1.12}
.page-hero__sub{font-size:clamp(16px,1.5vw,19px);color:rgba(255,255,255,.78);margin-top:20px;max-width:56ch}

/* типографика контента (markdown) */
.prose{font-size:17px;line-height:1.75;color:var(--c-text)}
.prose>*+*{margin-top:1.1em}
.prose h2{font-size:clamp(24px,2.6vw,34px);margin-top:2em;line-height:1.2}
.prose h3{font-size:clamp(19px,1.8vw,24px);margin-top:1.6em;line-height:1.25}
.prose p:first-child{margin-top:0}
.prose .lead-first,.prose>p:first-of-type{font-size:19px;color:var(--c-navy)}
.prose a{color:var(--c-navy);border-bottom:1px solid var(--c-border-gold);transition:border-color .2s,color .2s}
.prose a:hover{color:var(--c-gold);border-color:var(--c-gold)}
.prose ul{padding-left:0}
.prose ul li{position:relative;padding-left:26px;margin:.5em 0}
.prose ul li::before{content:"";position:absolute;left:2px;top:.66em;width:10px;height:1.5px;background:var(--c-gold)}
.prose ol{padding-left:1.4em}
.prose ol li{margin:.5em 0;padding-left:6px}
.prose blockquote{border-left:2px solid var(--c-gold);padding:8px 0 8px 24px;font-family:var(--font-serif);font-size:1.15em;color:var(--c-navy)}
.prose table{width:100%;border-collapse:collapse;font-size:15px;margin:1.4em 0}
.prose th{font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-muted);text-align:left}
.prose th,.prose td{border-bottom:1px solid var(--c-border);padding:12px 14px 12px 0;vertical-align:top}
.prose tr:last-child td{border-bottom:0}
.prose hr{border:0;height:1px;background:var(--c-border);margin:2.4em 0}
.prose strong{font-weight:600;color:var(--c-navy)}
.prose .callout{background:var(--c-white);border:1px solid var(--c-border);border-left:2px solid var(--c-gold);padding:20px 24px;font-size:15px}
.section--dark .prose,.section--deep .prose{color:rgba(255,255,255,.85)}

/* FAQ (details/summary) */
.faq-section{background:var(--c-white)}
.faq__item{border:1px solid var(--c-border);background:var(--c-off-white);margin-bottom:12px;transition:border-color .25s}
.faq__item[open]{border-color:var(--c-border-gold)}
.faq__q{cursor:pointer;list-style:none;padding:20px 56px 20px 24px;font-weight:500;font-size:16px;color:var(--c-navy);position:relative}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:22px;color:var(--c-gold);font-weight:400;transition:transform .25s var(--ease)}
.faq__item[open] .faq__q::after{transform:translateY(-50%) rotate(45deg)}
.faq__a{padding:0 24px 22px;color:var(--c-text-muted);font-size:15px;line-height:1.7}
.faq__a p+p{margin-top:.8em}

/* TOC (pillar) */
.guide-grid{display:grid;grid-template-columns:260px minmax(0,720px);gap:clamp(32px,4vw,64px);justify-content:center}
.toc{position:sticky;top:108px;align-self:start;font-size:14px;border-left:1px solid var(--c-border);padding-left:20px}
.toc__title{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:14px}
.toc ol{list-style:none;counter-reset:toc}
.toc li{margin:10px 0}
.toc a{color:var(--c-text-muted);transition:color .2s}
.toc a:hover{color:var(--c-gold)}

/* cluster-карточки на pillar */
.cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cluster-card{display:flex;flex-direction:column;gap:10px;background:var(--c-off-white);border:1px solid var(--c-border);padding:28px;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.cluster-card:hover{border-color:var(--c-gold);transform:translateY(-4px)}
.cluster-card__title{font-family:var(--font-serif);font-size:19px;font-weight:600;color:var(--c-navy)}
.cluster-card__desc{font-size:14px;color:var(--c-text-muted);flex:1}
.cluster-card__more{font-size:14px;font-weight:500;color:var(--c-gold)}

/* related */
.related{padding:0 0 clamp(48px,6vw,72px)}
.related__title{margin-bottom:18px}
.related__list li{margin:12px 0}

/* news */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,28px)}
.news-card{display:flex;flex-direction:column;gap:12px;background:var(--c-white);border:1px solid var(--c-border);padding:28px;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.news-card:hover{border-color:var(--c-gold);transform:translateY(-4px)}
.news-card__meta{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-muted)}
.news-card__title{font-family:var(--font-serif);font-size:20px;font-weight:600;color:var(--c-navy);line-height:1.3;flex:1}
.news-card__desc{font-size:14px;color:var(--c-text-muted)}
.news-card__more{font-size:14px;font-weight:500;color:var(--c-gold)}
.post-hero__meta{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(255,255,255,.65);margin-bottom:16px}
.post-hero__meta a{color:var(--c-gold-bright)}
.post-hero__cat{letter-spacing:.08em;text-transform:uppercase;font-weight:600;font-size:12px}
.post-sources{font-size:14px}
.post-sources ul{padding:0}
.post-sources li{margin:8px 0;overflow-wrap:anywhere}
.post-sources a{color:var(--c-text-muted);border-bottom:1px solid var(--c-border)}
.post-sources a:hover{color:var(--c-gold)}

/* glossary */
.term-definition{
  font-family:var(--font-serif);font-size:clamp(19px,2vw,24px);line-height:1.5;color:var(--c-navy);
  border-left:2px solid var(--c-gold);padding:6px 0 6px 24px;margin-bottom:36px;
}
.glossary-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.glossary-list a{display:flex;flex-direction:column;gap:6px;border:1px solid var(--c-border);background:var(--c-white);padding:22px 24px;transition:border-color .3s var(--ease)}
.glossary-list a:hover{border-color:var(--c-gold)}
.glossary-list .term{font-family:var(--font-serif);font-weight:600;font-size:18px;color:var(--c-navy)}
.glossary-list .hint{font-size:13px;color:var(--c-text-muted)}

/* cta-mini (conversion path на content-страницах) */
.cta-mini__text{max-width:52ch;margin:16px auto 0}
.cta-mini__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:32px}

/* steps-страница (how-it-works) */
.steps-page .step{padding:32px;border:1px solid var(--c-border);background:var(--c-white)}

/* объект: галерея + статы */
.object-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--c-border);border:1px solid var(--c-border);margin:32px 0}
.object-stats div{background:var(--c-white);padding:20px}
.object-stats b{display:block;font-size:20px;font-weight:600;color:var(--c-navy);font-family:var(--font-sans)}
.object-stats span{font-size:12px;color:var(--c-text-muted);letter-spacing:.06em;text-transform:uppercase}
.object-gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:8px;margin-bottom:8px}
.object-gallery div{aspect-ratio:4/3;background-size:cover}

/* team / about */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.team-card{text-align:center;padding:32px 20px;background:var(--c-white);border:1px solid var(--c-border)}
.team-card .case__avatar{margin:0 auto 16px;width:64px;height:64px;font-size:18px}
.team-card b{display:block;font-family:var(--font-serif);font-size:18px;color:var(--c-navy)}
.team-card span{font-size:13px;color:var(--c-text-muted)}

/* reveal-анимации при скролле (IO; отключаются reduced-motion) */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
html.no-io .reveal,html.no-js .reveal{opacity:1;transform:none}

/* 404 */
.nf{min-height:60vh;display:flex;align-items:center;background:linear-gradient(160deg,var(--c-navy) 30%,var(--c-navy-deep))}
.nf__num{font-family:var(--font-sans);font-weight:500;font-size:clamp(80px,16vw,180px);line-height:1;color:var(--c-gold-bright)}

/* coming soon (EN/DE заглушки) */
.stub{min-height:70vh;display:flex;align-items:center;text-align:center;background:linear-gradient(160deg,var(--c-navy) 30%,var(--c-navy-deep));color:#fff}
.stub__inner{max-width:560px;margin:0 auto}
.stub h1{font-size:clamp(30px,4.6vw,52px);font-weight:600;color:#fff}
.stub p{margin:22px 0 36px;color:rgba(255,255,255,.75)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav,.header__right .lang{display:none}
  .burger{display:flex}
  .header__right{gap:14px}
  .usp__grid{grid-template-columns:1fr 1fr}
  .footer__top{grid-template-columns:1fr 1fr}
  .guide-grid{grid-template-columns:1fr;justify-content:stretch}
  .toc{position:static;border-left:0;padding-left:0;border-bottom:1px solid var(--c-border);padding-bottom:20px}
  .cluster-grid,.news-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .object-stats{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .header__cta{display:none}
  .stats__grid{grid-template-columns:1fr 1fr;gap:40px 24px}
  .services__grid,.steps__grid,.dest__grid,.invest__grid,.cta__inner,
  .usp__grid,.cluster-grid,.news-grid,.glossary-list{grid-template-columns:1fr}
  .step:not(:last-child)::after{display:none}
  .stat:not(:last-child)::after{display:none}
  .case{min-height:480px}
  .footer__top{grid-template-columns:1fr}
  .hero{min-height:auto}
  .hero__scroll{display:none}
  .scene-caption{bottom:26px}
  .object-gallery{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
}

/* ============================================================
   REDUCED MOTION (заложено в макет — переносится как есть)
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .scene--1,.cap--1{opacity:1!important}
  .reveal{opacity:1!important;transform:none!important}
  .floating{opacity:1;transform:none;pointer-events:auto}
}
