-->


<style>
/* ============ MANROPE SELF-HOSTED (152-ФЗ: no cross-border) ============ */
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-ext-400.woff2') format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-400.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-ext-500.woff2') format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-500.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-ext-600.woff2') format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-600.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-ext-700.woff2') format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-700.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-ext-700.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-ext-800.woff2') format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-cyrillic-800.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-ext-800.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/templates/first-aid/fonts/manrope-latin-800.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ============ RESET + TOKENS ============ */
*,*::before,*::after{box-sizing:border-box; min-width:0}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; max-width:100%}
body{margin:0; font-family:'Manrope', system-ui, -apple-system, Segoe UI, Arial, sans-serif; color:var(--c-text); line-height:1.5; background:#fff; -webkit-font-smoothing:antialiased; overflow-x:clip; max-width:100vw; width:100%}
img, picture, video, canvas, svg{max-width:100%; height:auto}
.wrap{width:100%}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
button{font:inherit; cursor:pointer; border:0; background:none}
input,textarea,select,button{font:inherit; color:inherit}

:root{
  /* BRAND PALETTE: #003D38 dark / #01948E teal / #C2E2DE mint / #FDAD3A orange */
  --c-white:#FFFFFF;
  --c-bg-soft:#EAF4F2;
  --c-bg-mint:#C2E2DE;
  --c-bg-cream:#FAF6EE;
  --c-teal:#01948E;
  --c-teal-hero:#01948E;
  --c-teal-deep:#003D38;
  --c-teal-icon:#01948E;
  --c-teal-dark:#003D38;
  --c-orange:#FDAD3A;
  --c-orange-2:#E89220;
  --c-text:#2C3D3D;
  --c-text-2:#4A5B5B;
  --c-text-muted:#6F8080;
  --c-text-dark:#003D38;
  --c-line:#DAE5E3;
  --c-line-soft:#EAF1F0;
  --shadow-sm:0 2px 4px rgba(0,61,56,.06);
  --shadow-md:0 8px 20px -4px rgba(0,61,56,.10);
  --shadow-lg:0 24px 48px -16px rgba(0,61,56,.22);
  --shadow-card:0 4px 12px rgba(0,61,56,.07), 0 1px 3px rgba(0,61,56,.05);
  --shadow-orange:0 12px 28px -10px rgba(253,173,58,.55);
  --radius-sm:8px;
  --radius:12px;
  --radius-lg:16px;
  --radius-xl:24px;
}

.wrap{max-width:1320px; margin:0 auto; padding:0 32px}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}
:focus-visible{outline:3px solid var(--c-teal); outline-offset:3px; border-radius:6px}
.skip-link{position:absolute; left:-9999px; top:0; padding:10px 16px; background:var(--c-teal-dark); color:#fff; z-index:1000}
.skip-link:focus{left:8px; top:8px}

/* ============ BUTTONS ============ */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 24px; border-radius:var(--radius-sm); font-weight:700; font-size:15px; letter-spacing:.01em; transition:transform .18s ease, background .18s ease, box-shadow .18s ease; cursor:pointer; white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-orange{background:var(--c-orange); color:var(--c-teal-dark); box-shadow:var(--shadow-orange)}
.btn-orange:hover{background:var(--c-orange-2); color:var(--c-teal-dark)}
.btn-outline-white{background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.6)}
.btn-outline-white:hover{background:rgba(255,255,255,.1); border-color:#fff}
.btn-outline-orange{background:transparent; color:var(--c-orange); border:1.5px solid var(--c-orange); box-shadow:none}
.btn-outline-orange:hover{background:var(--c-orange); color:#fff}
.btn-block{width:100%}

/* ============ HEADER ============ */
.site-header{position:sticky; top:0; z-index:50; background:rgba(255,255,255,.96); backdrop-filter:saturate(180%) blur(8px); -webkit-backdrop-filter:saturate(180%) blur(8px); border-bottom:1px solid var(--c-line-soft)}
.head-row{display:flex; align-items:center; gap:24px; padding:14px 0}
.brand{display:flex; align-items:center; gap:12px; flex:none; transition:opacity .2s}
.brand:hover{opacity:.85}
.brand-logo{height:44px; width:auto; flex:none; display:block}
@media (max-width:600px){.brand-logo{height:38px}}
.head-nav{display:flex; gap:4px; margin:0 auto}
.head-nav a{padding:8px 12px; font-size:15px; font-weight:600; color:var(--c-text-dark); border-radius:8px; transition:color .2s, background .2s; white-space:nowrap}
.head-nav a:hover{color:var(--c-teal); background:var(--c-bg-soft)}
.head-phone{display:flex; align-items:center; gap:10px; flex:none; transition:opacity .2s}
.head-phone:hover{opacity:.85}
/* Иконка-телефон без круглой плашки, крупнее */
.head-phone-icon{display:grid; place-items:center; color:var(--c-teal); flex:none}
.head-phone-icon svg{width:26px; height:26px}
.head-phone-info{display:flex; flex-direction:column; line-height:1.2}
.head-phone-num{font-size:18px; font-weight:800; color:var(--c-teal-dark); letter-spacing:-.005em}
.head-phone-sub{font-size:11.5px; color:var(--c-text-muted); margin-top:3px}
/* Кнопка в шапке — компактнее */
.head-cta{flex:none; padding:11px 18px; font-size:14px; border-radius:10px}
.head-burger{display:none; width:42px; height:42px; border-radius:10px; background:var(--c-bg-soft); align-items:center; justify-content:center; color:var(--c-teal-dark); margin-left:auto}
.head-burger svg{width:22px; height:22px}

/* ============ HERO ============ */
/* header + hero = 100vh — высота считается через CSS var (см. ниже) */
.hero{
  --header-h:78px;
  padding:20px 0 20px;
  background:#fff;
  min-height:calc(100svh - var(--header-h));
  min-height:calc(100vh - var(--header-h));
  display:flex; flex-direction:column;
}
.hero .wrap{display:flex; flex-direction:column; gap:16px; flex:1; min-height:0; min-width:0}
/* Hero-card: фоновая картинка во всю карточку + gradient-overlay (100→0 alpha до ~70%) */
.hero-card{
  position:relative; border-radius:var(--radius-xl); overflow:hidden;
  background:var(--c-teal-deep);
  /* flex-grow занимает оставшееся пространство, но не меньше 500 и не больше 720 */
  flex:1 1 auto;
  min-height:500px;
  max-height:720px;
  min-width:0; /* allow shrink below intrinsic content (mobile) */
  box-shadow:0 30px 80px -30px rgba(0,61,56,.35)
}
.hero-media{position:absolute; inset:0; z-index:0; overflow:hidden}
.hero-media img{width:100%; height:100%; object-fit:cover; object-position:center}
/* Полупрозрачный градиент поверх картинки: слева 100% teal-deep, к 70% — transparent */
.hero-card::before{
  content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(95deg,
    rgba(0,61,56,1)     0%,
    rgba(0,61,56,.98)   25%,
    rgba(1,108,103,.92) 45%,
    rgba(1,148,142,.55) 60%,
    rgba(1,148,142,0)   75%);
}
.hero-text{position:relative; z-index:2; padding:48px 32px 44px 56px; display:flex; flex-direction:column; gap:18px; color:#fff; min-width:0; max-width:62%}
/* Оптическое выравнивание: глиф "Ч" в font-weight:800 имеет шире left side-bearing
   чем "К/П" в weight 600/500 — компенсируем negative margin-left. */
.hero-title{font-size:clamp(32px, 3.6vw, 52px); line-height:1.04; font-weight:800; color:#fff; margin:0 0 0 -3px}
.hero-sub{font-size:clamp(16px, 1.35vw, 19px); font-weight:600; color:#D4ECE9; margin:0; max-width:540px; line-height:1.35}
.hero-desc{font-size:15px; color:rgba(255,255,255,.92); line-height:1.5; margin:0; max-width:520px}
/* Иконки 4 в ряд:
   - Первый chip левым краем под title (выравнивание сохранено)
   - Иконка по центру своего текста
   - Каждый chip имеет ЯВНУЮ ширину = ширине реального текста (без пустого пространства внутри)
   - Правый край последнего chip = X-позиции буквы «и» в первой строке подзаголовка */
.hero-chips{display:flex; flex-wrap:nowrap; gap:14px 28px; margin-top:6px}
.hero-chip{display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; flex:0 0 auto}
.hero-chip:nth-child(1){width:62px}   /* «16 часов» — 1 строка */
.hero-chip:nth-child(2){width:80px}   /* «2 дня очно» — 1 строка */
.hero-chip:nth-child(3){width:90px}   /* «Практика на тренажёрах» — 2 строки: «Практика на» / «тренажёрах» */
.hero-chip:nth-child(4){width:108px}  /* «Навыки, которые могут спасти жизнь» — 3 строки */
.hero-chip-icon{color:#fff; flex:none; display:block}
.hero-chip-icon svg{width:44px; height:44px; stroke-width:1.5}
.hero-chip-text{font-size:14.5px; font-weight:600; color:#fff; line-height:1.3}
/* Кнопки — правый край примерно по букве «и» в первой строке подзаголовка */
.hero-ctas{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:10px; max-width:420px; align-items:stretch}
.hero-ctas .btn{padding:13px 16px; font-size:14.5px; white-space:normal; line-height:1.2; min-height:50px; text-align:center; width:100%; border-radius:10px}
.hero-microtrust{display:flex; align-items:center; gap:10px; font-size:14px; color:rgba(255,255,255,.9); margin-top:6px}
.hero-microtrust svg{width:16px; height:16px; flex:none}

/* ============ HERO PRICE CARD — медицинская тематика, маркетинговый акцент ============ */
.hero-price{
  position:absolute; right:28px; bottom:28px;
  background:#fff;
  border-radius:18px;
  padding:18px 30px 16px;
  box-shadow:0 24px 56px -18px rgba(0,61,56,.32), 0 0 0 1px rgba(0,61,56,.06);
  min-width:230px;
  text-align:center;
  z-index:3;
  overflow:hidden;
  transition:transform .28s ease, box-shadow .28s ease;
  cursor:default;
  animation:hero-price-glow 3.4s ease-in-out infinite;
}
/* Брендовая оранжевая полоса сверху (вместо красного — в палитру) */
.hero-price::before{
  content:''; position:absolute; top:0; left:0; right:0; height:5px;
  background:linear-gradient(90deg, var(--c-orange) 0%, #FFC04D 50%, var(--c-orange) 100%);
}
/* Бледный teal-крест на фоне в правом верхнем углу */
.hero-price::after{
  content:''; position:absolute; right:-14px; top:6px;
  width:62px; height:62px;
  background:
    linear-gradient(var(--c-teal), var(--c-teal)) center / 100% 22% no-repeat,
    linear-gradient(var(--c-teal), var(--c-teal)) center / 22% 100% no-repeat;
  opacity:.08;
  border-radius:6px;
  pointer-events:none;
}
.hero-price:hover{
  transform:translateY(-3px);
  box-shadow:0 30px 64px -20px rgba(253,173,58,.35), 0 0 0 1px rgba(253,173,58,.18);
}
.hero-price-from{
  font-size:12px; color:var(--c-text-muted);
  font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  margin-top:6px;
}
.hero-price-value{
  font-size:46px; font-weight:800; color:var(--c-teal-deep);
  line-height:1; margin:4px 0 6px; letter-spacing:-.02em;
}
.hero-price-value small{font-size:28px; font-weight:700; margin-left:2px}
.hero-price-sub{
  font-size:12.5px; color:var(--c-text-muted); font-weight:500;
}
/* Маркетинговая плашка-фичи: сертификат включён */
.hero-price-feat{
  display:flex; align-items:center; justify-content:center; gap:7px;
  margin-top:12px; padding-top:11px;
  border-top:1px dashed rgba(0,61,56,.18);
  font-size:11.5px; font-weight:700; color:var(--c-teal-deep);
  text-transform:uppercase; letter-spacing:.04em;
}
.hero-price-feat svg{width:14px; height:14px; color:#1E9E54; flex:none}
/* Лёгкое «дыхание» shadow — orange-glow к палитре */
@keyframes hero-price-glow{
  0%, 100% {box-shadow:0 24px 56px -18px rgba(0,61,56,.32), 0 0 0 1px rgba(0,61,56,.06)}
  50%      {box-shadow:0 28px 64px -18px rgba(253,173,58,.20), 0 0 0 1px rgba(253,173,58,.10)}
}
@media (prefers-reduced-motion:reduce){
  .hero-price{animation:none}
}

/* ============ HERO MARQUEE (бегущая строка под hero-card) ============ */
.hero-marquee{
  position:relative; overflow:hidden;
  background:linear-gradient(90deg, var(--c-orange) 0%, #FFC04D 50%, var(--c-orange) 100%);
  border-radius:14px;
  padding:13px 0;
  box-shadow:0 10px 24px -10px rgba(253,173,58,.55);
  flex:0 0 auto;
  /* Critical for mobile: marquee-track inside has width:max-content (3541px) —
     min-width:0 prevents that intrinsic width from forcing parent flex containers wide */
  min-width:0;
  width:100%;
}
.hero-marquee::before,
.hero-marquee::after{content:''; position:absolute; top:0; bottom:0; width:48px; z-index:2; pointer-events:none}
.hero-marquee::before{left:0; background:linear-gradient(90deg, var(--c-orange) 0%, rgba(253,173,58,0) 100%)}
.hero-marquee::after{right:0; background:linear-gradient(90deg, rgba(253,173,58,0) 0%, var(--c-orange) 100%)}
.hero-marquee-track{
  display:flex; gap:0; white-space:nowrap;
  /* width:max-content замешано на min-width родительского flex chain;
     используем fit-content + min-width:0 для безопасного shrink */
  width:max-content; min-width:100%;
  animation:marquee 38s linear infinite;
  will-change:transform;
}
.hero-marquee:hover .hero-marquee-track{animation-play-state:paused}
.hero-marquee-item{
  display:inline-flex; align-items:center; gap:10px;
  padding:0 26px;
  font-size:14.5px; font-weight:700; color:var(--c-teal-dark);
  letter-spacing:.005em;
}
.hero-marquee-item svg{width:18px; height:18px; flex:none; opacity:.85}
.hero-marquee-item + .hero-marquee-item{border-left:1px solid rgba(0,61,56,.18)}
@keyframes marquee{
  from{transform:translateX(0)}
  to  {transform:translateX(-50%)}
}
@media (prefers-reduced-motion:reduce){
  .hero-marquee-track{animation:none; transform:none}
}

/* ============ SECTION CHROME ============ */
.section{padding:56px 0}
.section-head{text-align:center; margin-bottom:36px}
.section-title{font-size:clamp(22px, 2.6vw, 32px); font-weight:800; color:var(--c-teal-dark); margin:0; letter-spacing:-.01em; display:inline-block; position:relative; padding-bottom:12px}
.section-title::after{content:''; display:block; width:80px; height:3px; background:var(--c-teal); border-radius:3px; position:absolute; left:50%; bottom:0; transform:translateX(-50%)}

/* ============ LEARN (Чему вы научитесь) — 4 white cards ============ */
.learn-section{background:#fff}
.learn-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:20px}
.learn-card{
  background:#fff;
  border-radius:18px;
  padding:32px 22px;
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
  gap:18px;
  box-shadow:0 2px 8px rgba(0,61,56,.04), 0 1px 2px rgba(0,61,56,.04);
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, border-color .3s;
  border:1px solid rgba(0,61,56,.06);
  position:relative;
  overflow:hidden;
}
.learn-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--c-teal), var(--c-teal-deep));
  transform:scaleX(0); transform-origin:left center;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.learn-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 36px -16px rgba(0,61,56,.22), 0 4px 8px rgba(0,61,56,.06);
  border-color:rgba(1,148,142,.18);
}
.learn-card:hover::before{transform:scaleX(1)}
.learn-icon{
  width:72px; height:72px; border-radius:50%;
  background:var(--c-bg-mint);
  display:grid; place-items:center;
  color:var(--c-teal-deep);
  flex:none;
  transition:background .35s ease, color .35s ease, transform .35s cubic-bezier(.2,.7,.2,1);
  position:relative;
}
.learn-icon svg{width:34px; height:34px; stroke-width:1.7; transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.learn-card:hover .learn-icon{background:var(--c-teal); color:#fff; transform:scale(1.08)}
.learn-card:hover .learn-icon svg{transform:scale(1.08)}
/* Badge "112" над иконкой телефона */
.learn-icon-badge{
  position:absolute; top:-4px; right:-6px;
  background:#D62839; color:#fff;
  font-size:10px; font-weight:800; letter-spacing:.04em;
  padding:2px 6px; border-radius:8px;
  box-shadow:0 2px 4px rgba(214,40,57,.4);
  pointer-events:none;
}
.learn-text{font-size:14px; line-height:1.45; color:var(--c-text); font-weight:500}
/* Stagger reveal: gate'нуто через .js-reveal-ready — без JS карточки видимы сразу */
.js-reveal-ready .learn-card.reveal{opacity:0; transform:translateY(16px); transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1)}
.js-reveal-ready .learn-card.reveal.is-in{opacity:1; transform:translateY(0)}
.js-reveal-ready .learn-grid .learn-card.reveal:nth-child(1){transition-delay:0s}
.js-reveal-ready .learn-grid .learn-card.reveal:nth-child(2){transition-delay:.08s}
.js-reveal-ready .learn-grid .learn-card.reveal:nth-child(3){transition-delay:.16s}
.js-reveal-ready .learn-grid .learn-card.reveal:nth-child(4){transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .js-reveal-ready .learn-card.reveal{opacity:1; transform:none; transition:none}
  .learn-card:hover{transform:none}
  .learn-card:hover .learn-icon{transform:none}
}

/* ============ AUDIENCE (Кому подойдёт) — фото-карточки с overlay ============ */
.audience-section{background:#fff; padding-top:0}
.audience-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; max-width:1180px; margin:0 auto}
.aud-card{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  background:var(--c-teal-deep);
  box-shadow:0 2px 8px rgba(0,61,56,.06), 0 6px 18px rgba(0,61,56,.06);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
  cursor:default;
}
.aud-photo{
  position:relative; margin:0; display:block;
  aspect-ratio:3/4;
  overflow:hidden;
  background:var(--c-teal-deep);
}
.aud-photo img{
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  display:block;
  filter:saturate(.88) contrast(1.04);
  transform:scale(1) translateZ(0);
  transition:filter .4s ease, transform .7s cubic-bezier(.2,.7,.2,1);
  backface-visibility:hidden;
}
/* Двухстопный диагональный overlay: teal-оттенок в верхнем углу + затемнение снизу для текста */
.aud-overlay{
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(160deg,
    rgba(0,61,56,.20)  0%,
    rgba(0,0,0,0)      35%,
    rgba(0,0,0,0)      42%,
    rgba(0,0,0,.55)    72%,
    rgba(0,0,0,.82)    100%);
  transition:opacity .35s ease;
}
/* Номерной бейдж — современный акцент */
.aud-num{
  position:absolute; top:14px; left:14px;
  width:40px; height:40px;
  background:var(--c-teal); color:#fff;
  border-radius:10px;
  font-weight:800; font-size:15px;
  display:grid; place-items:center;
  box-shadow:0 2px 10px rgba(1,148,142,.48);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);
  z-index:2;
  letter-spacing:.01em;
}
/* Текстовый блок — поверх фото внизу */
.aud-caption{
  position:absolute; left:0; right:0; bottom:0;
  padding:18px 18px 20px;
  display:flex; flex-direction:column; gap:5px;
  z-index:2;
}
.aud-title{
  font-family:'Manrope', system-ui, sans-serif;
  font-weight:700;
  font-size:clamp(15px, 1.15vw + 8px, 18px);
  color:#fff;
  line-height:1.2;
  letter-spacing:-.015em;
  text-shadow:0 1px 6px rgba(0,0,0,.55);
}
.aud-desc{
  font-family:'Manrope', system-ui, sans-serif;
  font-weight:500;
  font-size:13px;
  color:rgba(255,255,255,.88);
  line-height:1.45;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  opacity:0; transform:translateY(8px);
  transition:opacity .28s ease-out .08s, transform .28s ease-out .08s;
}
/* HOVER: card поднимается, фото зумится, бейдж проворачивается, subtitle slide-in */
.aud-card:hover,
.aud-card:focus-within{
  transform:translateY(-8px);
  box-shadow:0 22px 44px -14px rgba(0,61,56,.32), 0 6px 14px rgba(0,61,56,.10);
}
.aud-card:hover .aud-photo img,
.aud-card:focus-within .aud-photo img{
  transform:scale(1.07) translateZ(0);
  filter:saturate(1.08) contrast(1.06);
}
.aud-card:hover .aud-num,
.aud-card:focus-within .aud-num{
  transform:rotate(-8deg) scale(1.08);
}
.aud-card:hover .aud-desc,
.aud-card:focus-within .aud-desc{
  opacity:1; transform:translateY(0);
}
/* На сенсорных устройствах подпись видна всегда */
@media (hover:none){
  .aud-desc{opacity:1; transform:none}
}
/* Stagger reveal — gated через .js-reveal-ready */
.js-reveal-ready .aud-card.reveal{opacity:0; transform:translateY(20px) scale(.97); transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1)}
.js-reveal-ready .aud-card.reveal.is-in{opacity:1; transform:translateY(0) scale(1)}
.js-reveal-ready .audience-grid .aud-card.reveal:nth-child(1){transition-delay:0s}
.js-reveal-ready .audience-grid .aud-card.reveal:nth-child(2){transition-delay:.08s}
.js-reveal-ready .audience-grid .aud-card.reveal:nth-child(3){transition-delay:.16s}
.js-reveal-ready .audience-grid .aud-card.reveal:nth-child(4){transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .js-reveal-ready .aud-card.reveal{opacity:1; transform:none; transition:none}
  .aud-card:hover, .aud-card:focus-within{transform:none}
  .aud-card:hover .aud-photo img, .aud-card:focus-within .aud-photo img{transform:none; filter:saturate(.88) contrast(1.04)}
  .aud-card:hover .aud-num, .aud-card:focus-within .aud-num{transform:none}
  .aud-desc{opacity:1; transform:none}
}
/* Адаптив: 4→2→1 columns */
@media (max-width:1024px){
  .audience-grid{grid-template-columns:repeat(2, 1fr); gap:16px; max-width:760px}
}
@media (max-width:600px){
  .audience-grid{grid-template-columns:1fr; gap:14px; max-width:420px}
  .aud-photo{aspect-ratio:4/3}
  .aud-caption{padding:14px 16px 16px}
  .aud-num{width:36px; height:36px; font-size:13px; border-radius:8px; top:12px; left:12px}
  .aud-desc{opacity:1; transform:none}
}

/* ============ FORMAT (Формат обучения) — карточки с номерами и quote-banner внутри ============ */
.format-section{background:#fff; padding-top:0; padding-bottom:72px}
.format-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:20px}
.format-card{
  position:relative;
  background:#fff;
  border:1px solid var(--c-line-soft);
  border-radius:var(--radius-lg);
  padding:28px 22px 26px;
  display:flex; flex-direction:column; align-items:flex-start;
  gap:16px;
  overflow:hidden;
  box-shadow:var(--shadow-card);
  transition:transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s cubic-bezier(.22,1,.36,1), border-color .18s ease;
}
/* Top accent stripe — slides in on hover */
.format-card::before{
  content:''; position:absolute; top:0; left:0;
  height:3px; width:0;
  background:var(--c-orange);
  border-radius:0 0 3px 0;
  transition:width .2s ease-out;
}
/* Большой декоративный номер на фоне card */
.format-card-num{
  position:absolute; top:8px; right:14px;
  font-size:80px; font-weight:800; line-height:1;
  color:var(--c-bg-mint);
  letter-spacing:-.04em;
  pointer-events:none; user-select:none;
  transition:color .18s ease;
}
.format-card-icon{
  width:52px; height:52px; border-radius:14px;
  background:var(--c-bg-soft);
  display:grid; place-items:center;
  color:var(--c-teal);
  flex:none;
  transition:background .18s ease, color .18s ease;
  position:relative; z-index:1;
}
.format-card-icon svg{width:26px; height:26px}
.format-card-text{
  font-size:14.5px; line-height:1.5;
  color:var(--c-text); font-weight:500;
  margin:0;
  position:relative; z-index:1;
}
.format-card-text strong{color:var(--c-teal-dark); font-weight:700}

/* Hover-состояния — только на pointer-устройствах */
@media (hover:hover){
  .format-card:hover{
    transform:translateY(-5px);
    box-shadow:0 16px 36px -10px rgba(0,61,56,.16);
    border-color:var(--c-bg-mint);
  }
  .format-card:hover::before{width:100%}
  .format-card:hover .format-card-icon{background:var(--c-teal); color:#fff}
  .format-card:hover .format-card-num{color:rgba(1,148,142,.08)}
}

/* Связка с quote: тонкая горизонтальная черта */
.format-divider{width:64px; height:1px; background:var(--c-line); margin:40px auto 32px}

/* Quote-banner — тёмный, авторитетный, с оранжевым акцентом */
.format-quote{
  background:linear-gradient(135deg, var(--c-teal-deep) 0%, #015F5B 100%);
  border-radius:var(--radius-xl);
  padding:28px 32px;
  display:flex; align-items:center; gap:24px;
  border-left:4px solid var(--c-orange);
  box-shadow:0 14px 36px -16px rgba(0,61,56,.36);
}
.format-quote-icon{
  width:56px; height:56px; border-radius:14px;
  background:rgba(255,255,255,.08);
  display:grid; place-items:center;
  color:var(--c-orange);
  flex:none;
}
.format-quote-icon svg{width:28px; height:28px; stroke-width:1.7}
.format-quote-text{
  font-size:15.5px; line-height:1.6;
  color:rgba(255,255,255,.92); font-weight:500;
  margin:0;
}

/* Stagger reveal через --i */
.js-reveal-ready .format-card,
.js-reveal-ready .format-quote{
  opacity:0; transform:translateY(20px);
  transition:opacity .48s cubic-bezier(.22,1,.36,1), transform .48s cubic-bezier(.22,1,.36,1), box-shadow .22s cubic-bezier(.22,1,.36,1), border-color .18s ease;
  transition-delay:calc(var(--i, 0) * 80ms);
}
.js-reveal-ready .format-card.is-in,
.js-reveal-ready .format-quote.is-in{
  opacity:1; transform:translateY(0);
}

@media (prefers-reduced-motion:reduce){
  .format-card, .format-quote,
  .js-reveal-ready .format-card, .js-reveal-ready .format-quote{
    opacity:1 !important; transform:none !important;
    transition-duration:0ms !important; transition-delay:0ms !important;
  }
  .format-card::before{transition:none}
}

/* ============ TEACHER (Преподаватель) — одна объединённая card ============ */
.teacher-section{background:#fff}
.teacher-card{
  display:grid;
  grid-template-columns:360px 1fr 440px;
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:0 4px 16px rgba(0,61,56,.08), 0 1px 4px rgba(0,61,56,.05);
  overflow:hidden;
  align-items:stretch;
  transition:transform .28s cubic-bezier(.22,.68,0,1.2), box-shadow .28s ease;
}
.teacher-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px -12px rgba(0,61,56,.16), 0 4px 8px rgba(0,61,56,.06);
}
/* Фото — flush-left, шире (360px), высокое (540px) */
.teacher-photo{position:relative; overflow:hidden; background:var(--c-bg-soft); align-self:stretch; min-height:540px}
.teacher-photo img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center top;
  display:block; will-change:transform;
  transition:transform .55s cubic-bezier(.22,.68,0,1.2); backface-visibility:hidden;
}
.teacher-card:hover .teacher-photo img{transform:scale(1.04)}
/* Info — sub-panel: tinted bg + teal border-left для anchor'а */
.teacher-info{
  display:flex; flex-direction:column; justify-content:center;
  padding:40px 32px 40px 36px; gap:0;
  background:var(--c-bg-soft);
  border-left:4px solid var(--c-teal);
  border-right:1px solid var(--c-line);
}
.teacher-info::before{display:none}
.teacher-name{
  font-size:clamp(26px, 2.4vw, 34px);
  font-weight:800;
  color:var(--c-teal-dark);
  margin:0 0 8px;
  line-height:1.1;
  letter-spacing:-.025em;
}
.teacher-role{
  font-size:clamp(14px, 1.2vw, 17px);
  font-weight:600;
  color:var(--c-teal);
  margin:0 0 28px;
  line-height:1.4;
  letter-spacing:.015em;
}
/* Stats: 2 числа со подписями (стаж) */
.teacher-stats{
  display:flex; gap:28px;
  margin-bottom:24px;
  padding-bottom:24px;
  border-bottom:1px solid rgba(0,61,56,.08);
}
.teacher-stat{display:flex; flex-direction:column; gap:6px}
.teacher-stat-num{
  font-size:38px; font-weight:800;
  color:var(--c-teal);
  line-height:1; letter-spacing:-.03em;
  font-feature-settings:"tnum";
}
.teacher-stat-label{
  font-size:11px; font-weight:700;
  color:var(--c-text-muted);
  text-transform:uppercase;
  letter-spacing:.06em;
  line-height:1.3;
}
/* Tags: преподаваемые направления */
.teacher-tags{
  display:flex; flex-wrap:wrap; gap:6px;
  margin-bottom:24px;
}
.teacher-tag{
  display:inline-flex; align-items:center;
  padding:5px 11px;
  background:rgba(1,148,142,.08);
  color:var(--c-teal-deep);
  font-size:12px; font-weight:600;
  border-radius:6px;
  border:1px solid rgba(1,148,142,.18);
  transition:background .22s ease, border-color .22s ease;
}
.teacher-card:hover .teacher-tag{
  background:rgba(1,148,142,.14);
  border-color:rgba(1,148,142,.28);
}
/* Credential — белый rectangular pill 10px на tinted column */
.teacher-credential{
  display:inline-flex; align-items:flex-start; gap:10px;
  padding:10px 14px;
  background:#fff;
  border-radius:10px;
  border:1.5px solid var(--c-line);
  margin-bottom:28px;
  transition:border-color .22s ease, background .22s ease;
}
.teacher-card:hover .teacher-credential{
  border-color:var(--c-teal);
  background:var(--c-bg-soft);
}
.teacher-credential-icon{
  flex:none; width:18px; height:18px;
  color:var(--c-teal); display:grid; place-items:center;
  margin-top:2px;
}
.teacher-credential-icon svg{width:18px; height:18px; flex:none}
.teacher-credential-text{
  font-size:13.5px; font-weight:600; color:var(--c-text); line-height:1.5;
}
/* CTA — filled orange (как primary button), а не outlined */
.btn-teacher-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 24px; border-radius:var(--radius-sm);
  font-weight:700; font-size:15px; letter-spacing:.005em;
  background:var(--c-orange); color:var(--c-teal-dark);
  border:none; cursor:pointer;
  align-self:flex-start;
  box-shadow:0 8px 20px -8px rgba(253,173,58,.45);
  transition:background .2s ease, transform .18s ease, box-shadow .2s ease;
}
.btn-teacher-cta:hover{
  background:var(--c-orange-2);
  transform:translateY(-2px);
  box-shadow:0 12px 28px -10px rgba(253,173,58,.55);
}
.btn-teacher-cta:focus-visible{outline:3px solid var(--c-teal-deep); outline-offset:3px}
.btn-teacher-cta:active{transform:translateY(0); box-shadow:none}
.btn-teacher-cta svg{flex:none; transition:transform .2s ease}
.btn-teacher-cta:hover svg{transform:scale(1.15)}
/* Video block — тinted bg (совпадает с info-колонкой), видео как card-in-card */
.teacher-video-block{
  display:flex; flex-direction:column;
  padding:24px 20px 24px 16px;
  gap:16px;
  justify-content:center;
  background:var(--c-bg-soft);
}
/* Sub-card: белый прямоугольник на тинтованном фоне — каждое видео в своём контейнере */
.teacher-video-item{
  margin:0;
  display:flex; flex-direction:column; gap:0;
  background:#fff;
  border-radius:12px;
  box-shadow:0 2px 8px rgba(0,61,56,.07), 0 0 0 1px rgba(0,61,56,.04);
  overflow:hidden;
  transition:box-shadow .22s ease, transform .22s cubic-bezier(.22,.68,0,1.2);
}
.teacher-video-item:hover{
  box-shadow:0 6px 18px rgba(0,61,56,.12), 0 0 0 1px rgba(1,148,142,.18);
  transform:translateY(-2px);
}
.teacher-lite-embed{
  position:relative; width:100%; aspect-ratio:16/9;
  background:#000; cursor:pointer; overflow:hidden;
  border-radius:0; /* скругление уже у sub-card */
  box-shadow:none;
}
.teacher-lite-embed::after{
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Ccircle cx='40' cy='40' r='36' fill='rgba(0,0,0,.52)'/%3E%3Cpolygon points='32,24 60,40 32,56' fill='%23fff'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center;
  background-size:72px 72px;
  transition:background-size .22s cubic-bezier(.22,.68,0,1.2), opacity .2s ease;
  pointer-events:none; z-index:2;
}
.teacher-lite-embed:hover::after{background-size:82px 82px}
.teacher-lite-embed.is-playing::after{display:none}
.teacher-lite-embed__poster{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  display:block;
  filter:brightness(.92);
  transition:filter .25s ease, transform .55s cubic-bezier(.22,.68,0,1.2);
  z-index:1;
}
.teacher-lite-embed:hover .teacher-lite-embed__poster{filter:brightness(.85); transform:scale(1.03)}
.teacher-lite-embed.is-playing .teacher-lite-embed__poster{display:none}
.teacher-lite-embed__iframe{
  position:absolute; inset:0; width:100%; height:100%;
  border:0; display:block; z-index:3;
}
.teacher-video-caption{
  padding:12px 14px 14px;
  font-size:14px; font-weight:600; color:var(--c-text-2);
  text-align:left; line-height:1.45;
  margin:0;
}
/* Адаптив */
@media (max-width:1100px){
  .teacher-card{grid-template-columns:300px 1fr 400px}
}
@media (max-width:1024px){
  .teacher-card{grid-template-columns:240px 1fr; max-width:760px; margin:0 auto}
  .teacher-video-block{grid-column:1 / -1; padding:16px 20px 20px; flex-direction:row; gap:16px}
  .teacher-video-item{flex:1 1 0; min-width:0}
  .teacher-info{padding:32px 28px 32px 30px}
}
@media (max-width:600px){
  .teacher-card{grid-template-columns:1fr; max-width:460px}
  .teacher-photo{aspect-ratio:4/3; min-height:auto}
  .teacher-info{padding:24px 20px; border-left-width:3px; border-right:none}
  .teacher-name{font-size:24px}
  .teacher-role{font-size:15px}
  .teacher-stats{gap:20px; margin-bottom:20px; padding-bottom:20px}
  .teacher-stat-num{font-size:32px}
  .teacher-video-block{flex-direction:column; padding:16px 16px 20px}
}
/* ============ TEACHER MODAL (видео-overlay) ============ */
.teacher-modal{
  border:0; padding:0; background:transparent;
  width:100%; max-width:none; height:100%; max-height:none;
  position:fixed; inset:0; margin:0;
}
.teacher-modal::backdrop{
  background:rgba(0,30,28,.85);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.teacher-modal[open]{display:flex; align-items:center; justify-content:center}
.teacher-modal-inner{
  position:relative;
  width:min(1100px, 92vw);
  aspect-ratio:16/9;
  max-height:calc(100vh - 100px);
}
.teacher-modal-video{
  position:absolute; inset:0;
  background:#000;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.08);
}
.teacher-modal-video iframe{
  position:absolute; inset:0; width:100%; height:100%; border:0;
}
.teacher-modal-close{
  position:absolute; top:-48px; right:0;
  width:40px; height:40px;
  background:rgba(255,255,255,.12);
  color:#fff; border:0; border-radius:50%;
  display:grid; place-items:center;
  cursor:pointer;
  transition:background .2s ease, transform .2s ease;
}
.teacher-modal-close:hover{background:rgba(255,255,255,.22); transform:rotate(90deg)}
.teacher-modal-close:focus-visible{outline:3px solid #fff; outline-offset:2px}
.teacher-modal-close svg{width:20px; height:20px}
@media (max-width:600px){
  .teacher-modal-inner{
    width:96vw;
    max-height:calc(100vh - 80px);
  }
  .teacher-modal-close{top:-44px; right:0; width:36px; height:36px}
  .teacher-modal-video{border-radius:10px}
}
@media (prefers-reduced-motion:reduce){
  .teacher-modal-close{transition:none}
}

@media (prefers-reduced-motion:reduce){
  .teacher-photo img, .teacher-card, .teacher-video-item,
  .teacher-lite-embed__poster, .teacher-lite-embed::after,
  .btn-teacher-cta, .teacher-credential{
    transition:none !important; transform:none !important; animation:none !important;
  }
}

/* ============ FORM SECTION — белая на bg-soft с rounded form-shell ============ */
.form-section{background:var(--c-bg-soft); color:#fff; padding:72px 0}
/* form-shell — единая rounded card с tinted dark teal внутри */
.form-shell{
  background:var(--c-teal-deep);
  color:#fff;
  border-radius:var(--radius-xl);
  padding:56px;
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:52px;
  position:relative;
  overflow:hidden;
  box-shadow:0 40px 80px -32px rgba(0,61,56,.45), 0 8px 24px -12px rgba(0,0,0,.16);
}
/* radial atmosphere — orbs для глубины */
.form-shell::before{
  content:''; position:absolute;
  top:-100px; right:-120px;
  width:340px; height:340px;
  background:radial-gradient(circle, rgba(1,148,142,.45), transparent 70%);
  border-radius:50%; pointer-events:none;
}
.form-shell::after{
  content:''; position:absolute;
  bottom:-100px; left:-100px;
  width:280px; height:280px;
  background:radial-gradient(circle, rgba(253,173,58,.16), transparent 70%);
  border-radius:50%; pointer-events:none;
}
.form-intro{display:flex; flex-direction:column; gap:18px; position:relative; z-index:1; justify-content:center}
.form-title{
  font-size:clamp(28px, 3vw, 40px); font-weight:800;
  color:#fff; margin:0; line-height:1.08;
  letter-spacing:-.02em;
}
.form-title em{font-style:normal; color:var(--c-orange)}
.form-desc{
  font-size:15.5px; line-height:1.55;
  color:rgba(255,255,255,.78); margin:0; max-width:46ch;
}
/* Trust-bullets для intro */
.form-bullets{display:flex; flex-direction:column; gap:10px; margin-top:8px}
.form-bullet{
  display:grid; grid-template-columns:28px 1fr; gap:12px;
  align-items:start;
  padding:12px 14px;
  background:rgba(255,255,255,.06);
  border-radius:12px;
  transition:background .2s ease, transform .2s ease;
}
.form-bullet .ck{
  width:24px; height:24px; border-radius:50%;
  background:var(--c-orange);
  display:grid; place-items:center;
  color:var(--c-teal-deep);
  flex:none;
}
.form-bullet .ck svg{width:13px; height:13px}
.form-bullet span{font-size:13.5px; line-height:1.45; color:rgba(255,255,255,.92)}
.form-bullet b{color:#fff; font-weight:700}
@media (hover:hover){
  .form-bullet:hover{background:rgba(253,173,58,.12); transform:translateX(4px)}
}
/* Stat strip */
.form-stats{
  display:grid; grid-template-columns:repeat(3, 1fr);
  margin-top:22px; padding-top:22px;
  border-top:1px solid rgba(255,255,255,.12);
}
.form-stat{
  display:flex; flex-direction:column; gap:4px;
  padding-right:18px;
  border-right:1px solid rgba(255,255,255,.12);
}
.form-stat:nth-child(2){padding-left:18px}
.form-stat:last-child{border-right:none; padding-left:18px; padding-right:0}
.form-stat-n{
  font-size:clamp(20px, 1.8vw, 24px); font-weight:800;
  color:#fff; line-height:1; letter-spacing:-.02em;
}
.form-stat-l{
  font-size:11px; font-weight:600;
  color:rgba(255,255,255,.55);
  text-transform:uppercase; letter-spacing:.06em;
  line-height:1.3;
}
.form-microtrust{display:none}
.form-card{
  background:#fff; border-radius:18px; padding:30px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.35);
  color:var(--c-text);
  position:relative; z-index:1;
}

/* ============ LEAD TOGGLE (segmented control) ============ */
.lead-toggle{
  display:grid; grid-template-columns:1fr 1fr;
  gap:6px;
  background:var(--c-bg-soft);
  padding:6px;
  border-radius:14px;
  margin-bottom:20px;
}
.lead-toggle-opt{
  position:relative;
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 12px;
  border-radius:10px;
  font-size:14px; font-weight:700;
  color:var(--c-text-muted);
  cursor:pointer;
  transition:background .22s ease, color .22s ease, box-shadow .22s ease, transform .15s ease;
  user-select:none;
  line-height:1.2;
  text-align:center;
}
.lead-toggle-opt:hover{color:var(--c-teal-deep)}
.lead-toggle-opt input{position:absolute; opacity:0; pointer-events:none; width:1px; height:1px}
.lead-toggle:has(input:checked) .lead-toggle-opt:has(input:checked){
  background:#fff;
  color:var(--c-teal-deep);
  box-shadow:0 2px 6px rgba(0,61,56,.14), 0 0 0 1px rgba(0,61,56,.04);
}
.lead-toggle-opt:focus-within{outline:none}
.lead-toggle-opt:has(input:focus-visible){box-shadow:0 0 0 3px rgba(1,148,142,.35)}
.lead-toggle-opt svg{width:16px; height:16px; flex:none}
@media (max-width:480px){
  .lead-toggle{grid-template-columns:1fr}
  .lead-toggle-opt{padding:10px}
}

.form-fields{display:flex; flex-direction:column; gap:16px}
.field{position:relative}
.field input,
.field textarea{width:100%; padding:18px 18px 8px; border:1.5px solid var(--c-line); border-radius:var(--radius); font-size:15px; background:#fff; color:var(--c-text-dark); transition:border-color .2s, box-shadow .2s}
.field textarea{min-height:100px; resize:vertical; padding-top:24px}
.field input:focus,
.field textarea:focus{outline:none; border-color:var(--c-teal); box-shadow:0 0 0 3px rgba(30,138,135,.15)}
.field label{position:absolute; top:14px; left:18px; font-size:13px; color:var(--c-text-muted); transition:top .15s, font-size .15s; pointer-events:none; background:transparent}
.field-required{color:var(--c-orange); margin-left:2px}
.honey{position:absolute; left:-9999px; top:-9999px; opacity:0; pointer-events:none}
.form-card .btn-block{margin-top:8px; padding:18px 24px; font-size:16px}
.form-card .agreement{margin-top:14px; font-size:12px; line-height:1.5; color:var(--c-text-muted); text-align:center}
.form-card .agreement a{color:var(--c-teal); text-decoration:underline}
/* Visible agreement checkbox (152-ФЗ-compliant) */
.form-agree{
  display:grid; grid-template-columns:20px 1fr; gap:10px;
  font-size:12px; line-height:1.5; color:var(--c-text-muted);
  align-items:flex-start;
  margin-top:8px; margin-bottom:12px;
}
.form-agree input[type="checkbox"]{
  margin:2px 0 0; accent-color:var(--c-teal);
  width:18px; height:18px; flex:none; cursor:pointer;
}
.form-agree .form-agree-text{display:block}
.form-agree .form-agree-text strong{color:var(--c-text); font-weight:700}
.form-agree .form-agree-text a{color:var(--c-teal); text-decoration:underline}
.form-agree:has(input:focus-visible){outline:3px solid rgba(1,148,142,.4); outline-offset:4px; border-radius:6px}
.form-err{display:none; color:var(--c-orange); font-size:12px; margin-top:4px}
.field.has-err input,
.field.has-err textarea{border-color:var(--c-orange)}
.field.has-err .form-err{display:block}

/* ============ FOOTER — dark teal, 4-кол. layout, 4px accent-bar сверху ============ */
.site-footer{
  background:var(--c-teal-dark);
  color:rgba(255,255,255,.85);
  padding:0 0 24px;
  font-size:14px;
  position:relative;
}
/* 4px accent-bar — резкий cut между form-section и footer */
.foot-accent-bar{
  height:4px;
  background:linear-gradient(90deg, var(--c-teal) 0%, var(--c-orange) 60%, transparent 100%);
  margin-bottom:48px;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:40px;
  align-items:start;
}
.foot-brand-col{display:flex; flex-direction:column; gap:14px}
.foot-brand-col .brand-logo{height:46px; width:auto; display:block}
.foot-brand-col p{
  font-size:13px; line-height:1.6;
  color:rgba(255,255,255,.55);
  max-width:34ch; margin:0;
}
.foot-col-nav h5{
  font-size:11px; letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--c-orange);
  margin:0 0 14px;
  font-weight:700;
}
.foot-col-nav ul{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:9px;
}
.foot-col-nav a{
  font-size:14px; color:rgba(255,255,255,.72);
  text-decoration:none;
  transition:color .15s ease;
}
.foot-col-nav a:hover{color:#fff}
.foot-contact{display:flex; flex-direction:column; gap:14px}
.foot-contact h5{
  font-size:11px; letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--c-orange);
  margin:0 0 0;
  font-weight:700;
}
.foot-phone{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:700; font-size:18px; color:#fff;
  text-decoration:none;
  transition:color .15s ease;
}
.foot-phone svg{width:16px; height:16px; opacity:.7; flex:none}
.foot-phone:hover{color:var(--c-orange)}
.foot-hours{
  font-size:12px; color:rgba(255,255,255,.45);
  line-height:1.5; padding-left:26px; margin-top:-8px;
}
.foot-addr, .foot-email{
  display:flex; align-items:flex-start; gap:10px;
  font-size:13.5px; color:rgba(255,255,255,.72);
  text-decoration:none;
  line-height:1.5;
  transition:color .15s ease;
}
.foot-addr svg, .foot-email svg{width:14px; height:14px; opacity:.6; flex:none; margin-top:3px}
.foot-email:hover{color:#fff}
/* Bottom bar */
.foot-bot{
  margin-top:36px; padding-top:22px;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; align-items:center;
  gap:18px; flex-wrap:wrap;
  font-size:12px; color:rgba(255,255,255,.45);
}
.foot-license-pill{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:6px;
  padding:5px 12px;
  font-size:11px;
  color:rgba(255,255,255,.55);
  letter-spacing:.01em;
  white-space:nowrap;
}
.foot-pdl{
  margin-top:14px;
  font-size:11px;
  color:rgba(255,255,255,.32);
  line-height:1.55;
}
.foot-pdl a{color:inherit; text-decoration:underline}
.foot-pdl strong{color:rgba(255,255,255,.45); font-weight:600}
@media (max-width:980px){
  .foot-grid{grid-template-columns:1fr 1fr; gap:32px}
}
@media (max-width:600px){
  .foot-grid{grid-template-columns:1fr}
  .form-shell{grid-template-columns:1fr; padding:32px; gap:32px}
  .form-stats{grid-template-columns:repeat(3, 1fr)}
  .foot-accent-bar{margin-bottom:36px}
}

/* ============ COOKIE BAR ============ */
.cookie-bar{position:fixed; left:16px; right:16px; bottom:16px; max-width:520px; margin:0 auto; background:#fff; box-shadow:0 24px 60px -20px rgba(0,0,0,.3); border-radius:var(--radius-lg); padding:18px 22px; z-index:1000; transform:translateY(120%); transition:transform .35s ease; font-size:13.5px; color:var(--c-text); border:1px solid var(--c-line-soft)}
.cookie-bar.show{transform:translateY(0)}
.cookie-bar p{margin:0 0 12px}
.cookie-bar a{color:var(--c-teal); text-decoration:underline}
.cookie-bar .row{display:flex; gap:10px; flex-wrap:wrap}
.cookie-bar .btn{padding:10px 16px; font-size:13px}
.cookie-bar .btn-min{background:#fff; color:var(--c-teal); border:1.5px solid var(--c-teal)}
/* Cookie granular settings (152-ФЗ — per-purpose consent) */
.cookie-settings{margin:8px 0 12px; font-size:12.5px}
.cookie-settings summary{cursor:pointer; color:var(--c-teal); font-weight:600; user-select:none; padding:6px 0}
.cookie-settings summary:hover{text-decoration:underline}
.cookie-categories{display:flex; flex-direction:column; gap:8px; padding:10px 0 4px; border-top:1px dashed var(--c-line-soft); margin-top:6px}
.cookie-cat{display:grid; grid-template-columns:18px 1fr; gap:10px; align-items:flex-start; cursor:pointer; line-height:1.45}
.cookie-cat input{accent-color:var(--c-teal); width:16px; height:16px; margin-top:1px; flex:none}
.cookie-cat input:disabled{opacity:.6}
.cookie-cat strong{color:var(--c-text-dark); font-weight:700}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .head-nav{display:none}
  .head-burger{display:flex}
  /* Phone number остаётся видимым на mobile/tablet — высокая ценность для конверсии */
  .head-phone-info{display:flex}
  .head-phone-sub{display:none}
  .head-phone-num{font-size:15px}
  /* На планшетах/мобильных снимаем 100vh-привязку — контент длиннее экрана */
  .hero{min-height:0}
  .hero-card{height:auto; min-height:auto; max-height:none; flex:none; background:var(--c-teal-deep)}
  /* На узких — картинка снова блочная (под текстом, сверху), gradient-overlay скрываем */
  .hero-card::before{display:none}
  .hero-media{position:relative; inset:auto; width:100%; height:auto; min-height:280px; max-height:340px}
  .hero-media img{height:280px}
  .hero-text{max-width:none; padding:32px 24px 28px; gap:14px}
  .hero-price{right:14px; bottom:auto; top:14px; padding:10px 16px; min-width:140px}
  .hero-price-value{font-size:24px}
  .hero-price-value small{font-size:16px}
  .hero-chips{max-width:none}
  .hero-ctas{max-width:none}
  .hero-marquee-item{font-size:13.5px; padding:0 20px}
  /* Картинку (media) переносим над текстом */
  .hero-card{display:flex; flex-direction:column-reverse}
  .learn-grid{grid-template-columns:repeat(2, 1fr)}
  .format-grid{grid-template-columns:repeat(2, 1fr); gap:16px}
  .format-section{padding-bottom:56px}
  .format-quote{padding:24px 26px}
  .format-divider{margin:32px auto 24px}
  .form-grid{grid-template-columns:1fr; gap:32px}
  .foot-grid{grid-template-columns:1fr 1fr; gap:24px}
  .section{padding:48px 0}
}
@media (max-width:600px){
  .head-row{padding:10px 0; gap:12px}
  .brand-sub{display:none}
  .brand-title{font-size:15px}
  .brand-logo{height:34px}
  .head-cta{padding:10px 16px; font-size:13px}
  .hero{padding:16px 0 24px}
  .hero .wrap{gap:14px}
  .hero-text{padding:28px 20px 24px; max-width:none}
  .hero-title{font-size:26px}
  .hero-sub{font-size:14.5px; max-width:100%}
  .hero-desc{font-size:13.5px; max-width:100%}
  /* На мобильных — 4 равные колонки 1fr (не fixed nth-child width!) */
  .hero-chips{display:grid !important; grid-template-columns:repeat(4, 1fr) !important; gap:10px 6px; max-width:none}
  .hero-chip{gap:6px; width:auto !important}
  .hero-chip:nth-child(n){width:auto !important}
  .hero-chip-icon svg{width:24px; height:24px}
  .hero-chip-text{font-size:11px; line-height:1.2}
  /* Скрыть head-cta button на mobile (не помещается с phone+burger) */
  .head-cta{display:none}
  .head-phone-num{font-size:14px}
  .hero-ctas{grid-template-columns:1fr; gap:10px}
  .hero-ctas .btn{min-height:48px; padding:13px 16px; font-size:14px}
  .hero-price{right:12px; top:12px; padding:8px 14px; min-width:120px}
  .hero-price-value{font-size:20px}
  .hero-price-value small{font-size:14px}
  .hero-media{min-height:220px; max-height:260px}
  .hero-marquee{padding:11px 0; border-radius:12px}
  .hero-marquee-item{font-size:12.5px; padding:0 16px; gap:8px}
  .hero-marquee-item svg{width:14px; height:14px}
  .hero-marquee-track{animation-duration:30s}
  .learn-grid{grid-template-columns:1fr}
  .audience-grid{grid-template-columns:1fr}
  .format-grid{grid-template-columns:1fr; max-width:400px; margin-inline:auto}
  .format-card{padding:22px 18px 20px}
  .format-card-num{font-size:64px; right:10px; top:-4px}
  .format-quote{flex-direction:column; align-items:flex-start; gap:16px; padding:20px 20px 20px 24px}
  .format-quote-text{font-size:14.5px}
  .format-section{padding-bottom:44px}
  .form-card{padding:22px}
  .foot-grid{grid-template-columns:1fr; gap:18px}
  .section{padding:40px 0}
  .section-head{margin-bottom:28px}
}
/* Очень узкие — на 3 колонки переходит лучше выглядит, но эталон — 4 в ряд, оставляем */
@media (max-width:380px){
  .hero-chip-text{font-size:10.5px}
  .hero-chip-icon svg{width:22px; height:22px}
}

/* ============ ANIMATIONS ============ */
/* Контент ВСЕГДА видимый — IntersectionObserver добавляет .is-in только как hook,
   но никогда не скрывает контент если JS/IO не отработает */
.reveal{opacity:1; transform:none}
.reveal.is-in{opacity:1; transform:none}
