/* =========================================================================
   Будь собой — Юлия Алакбан · стиль лендинга
   Палитра выстроена по фирменному стилю (логотип + фото):
   тёплый песок/крем, золото, шалфейный зелёный (рост),
   мягкий «сердечный» голубой как акцент. Без холодного корпоративного синего.
   ========================================================================= */

:root{
  /* нейтральные — прохладные голубоватые */
  --bg:#ffffff;
  --cream:#eef6fb;          /* мягкие секции (бледная лазурь) */
  --sand:#e0eef7;           /* карточки alt */
  --line:#d2e4ef;           /* границы */
  --ink:#1f3744;            /* основной текст/заголовки (тёмный сине-серый) */
  --muted:#51707e;          /* приглушённый текст */

  /* фирменные акценты — ларимар / лазурь / голубой */
  --brand:#0f6d96;          /* основной лазурно-голубой (текст/ссылки/акцент) */
  --brand-deep:#0b5274;     /* глубокий — заголовки/ховер */
  --sage:#2f9fd4;           /* голубой акцент (маркеры/точки) */
  --sage-deep:#1a6f9c;
  --sky:#36abda;           /* светло-голубой «сердечный» акцент */
  --gold:#74c7e0;          /* светлая лазурь (декор) */

  --radius:22px;
  --radius-lg:30px;
  --shadow:0 18px 50px rgba(15,82,116,.12);
  --shadow-sm:0 8px 24px rgba(15,82,116,.10);
  --ring:0 0 0 4px rgba(15,109,150,.30);
  --maxw:1240px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Onest',-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Onest',-apple-system,'Segoe UI',sans-serif;color:var(--ink);font-weight:700;letter-spacing:-.015em;margin:0}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;z-index:100}
.skip-link:focus{left:0}

/* heart accent (decorative svg, not emoji) */
.heart{display:inline-block;width:.82em;height:.82em;vertical-align:-.06em;margin-left:.18em;color:var(--sky)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:0;cursor:pointer;font-family:inherit;font-weight:600;font-size:16px;
  padding:16px 26px;border-radius:14px;
  color:#fff;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);
  box-shadow:0 12px 26px rgba(15,109,150,.30);
  transition:transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(15,109,150,.36)}
.btn:active{transform:translateY(0)}
.btn-sage{background:linear-gradient(135deg,#0f7ba6 0%,#0c5f86 100%);box-shadow:0 12px 26px rgba(13,95,134,.30)}
.btn-sage:hover{box-shadow:0 16px 32px rgba(13,95,134,.36)}
.btn.outline{background:#fff;color:var(--brand-deep);border:1.6px solid var(--line);box-shadow:none}
.btn.outline:hover{border-color:var(--brand);background:var(--cream)}
.btn-small{padding:12px 20px;font-size:15px}
.btn-block{width:100%}

/* ---------- Header ---------- */
.topbar{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar .wrap{display:flex;align-items:center;gap:20px;min-height:74px}
.logo{display:flex;flex-direction:column;line-height:1.1;margin-right:auto}
.logo b{font-family:'Onest',-apple-system,'Segoe UI',sans-serif;font-size:23px;color:var(--brand-deep);font-weight:700;letter-spacing:-.015em}
.logo small{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.nav{display:flex;gap:26px;font-weight:500}
.nav a{padding:6px 2px;color:var(--ink);position:relative}
.nav .btn{color:#fff}            /* CTA в меню — белый текст на лазурном (контраст) */
.nav a:hover,.nav a[aria-current="page"]{color:var(--brand-deep)}
.nav a:after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--brand);transition:right .25s ease}
.nav a:hover:after{right:0}
.nav .btn{display:none}            /* кнопка-CTA в меню видна только в мобильной шторке */
.nav-cta{margin-left:6px}

/* burger */
.burger{display:none;width:46px;height:46px;border:1px solid rgba(15,109,150,.28);border-radius:13px;
  background:rgba(255,255,255,.5);backdrop-filter:blur(8px) saturate(1.2);-webkit-backdrop-filter:blur(8px) saturate(1.2);
  cursor:pointer;align-items:center;justify-content:center;color:var(--brand-deep);box-shadow:0 6px 16px rgba(15,82,116,.12)}
.burger:hover{background:rgba(255,255,255,.7);border-color:var(--brand)}
.burger span,.burger span:before,.burger span:after{content:"";display:block;width:20px;height:2px;background:var(--brand-deep);border-radius:2px;transition:transform .25s ease,opacity .2s ease;position:relative}
.burger span:before{position:absolute;top:-6px}
.burger span:after{position:absolute;top:6px}
body.menu-open .burger span{background:transparent}
body.menu-open .burger span:before{transform:translateY(6px) rotate(45deg)}
body.menu-open .burger span:after{transform:translateY(-6px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(180deg,#fff 0%,var(--cream) 100%)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-block:76px}
.eyebrow{color:var(--brand);text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-size:13px;margin:0 0 14px}
.hero h1{font-size:clamp(40px,7vw,72px);font-weight:700;line-height:1.04;letter-spacing:-.025em;margin-bottom:18px}
.hero .subtitle{display:block;font-family:'Onest',-apple-system,'Segoe UI',sans-serif;font-size:clamp(20px,2.6vw,28px);font-weight:600;line-height:1.25;letter-spacing:-.01em;color:var(--brand-deep);margin:14px 0 0}
.lead{font-size:clamp(17px,2vw,21px);color:#365057;max-width:560px;margin:0}
.mini-list{list-style:none;padding:0;margin:24px 0}
.mini-list li{margin:11px 0;padding-left:30px;position:relative}
.mini-list li:before{content:"";position:absolute;left:0;top:.55em;width:14px;height:14px;border-radius:50%;
  background:var(--sage);box-shadow:0 0 0 4px rgba(47,159,212,.18)}
.hero .btn{margin-top:6px}
.features{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:26px;color:var(--muted);font-size:14px}
.features span{display:inline-flex;align-items:center;gap:8px}
.features span:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold)}

.hero-photo{position:relative;justify-self:center}
.hero-photo img{width:min(420px,80vw);height:auto;border-radius:50%;
  box-shadow:0 30px 60px rgba(15,82,116,.22);background:var(--cream)}
.hero-photo:after{content:"";position:absolute;inset:-14px;border-radius:50%;
  border:1px dashed rgba(121,205,214,.6);z-index:-1}

/* ---------- Sections ---------- */
.section{padding-block:92px}
.section.alt{background:var(--cream)}
.section-head{text-align:center;max-width:680px;margin:0 auto 44px}
.section-head h2{font-size:clamp(28px,4vw,44px);margin-bottom:12px}
.section-head p{color:var(--muted);font-size:18px;margin:0}

/* requests cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm)}
.section.alt .card{background:#fff}
.card .icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;
  background:rgba(47,159,212,.14);color:var(--sage-deep)}
.card h3{font-size:21px;margin-bottom:8px;color:var(--ink)}
.card p{color:#41595f;margin:0}

/* about */
.about .wrap{display:grid;grid-template-columns:420px 1fr;gap:54px;align-items:center}
.about img{width:100%;height:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.about h2{font-size:clamp(28px,4vw,42px);margin:6px 0 18px}
.about p{color:#365057;margin:0 0 14px}

/* stats */
.stats{text-align:center}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 18px;box-shadow:var(--shadow-sm)}
.stat b{display:block;font-family:'Onest',-apple-system,'Segoe UI',sans-serif;color:var(--brand-deep);font-size:30px}
.stat span{display:block;color:var(--muted);margin-top:8px;font-size:15px}

/* pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
.plan{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:34px 28px;box-shadow:var(--shadow-sm)}
.plan.popular{border:2px solid var(--brand);box-shadow:var(--shadow);transform:translateY(-8px)}
.plan h3{font-size:22px;margin-bottom:6px}
.badge{position:absolute;top:-15px;left:50%;transform:translateX(-50%);white-space:nowrap;
  background:var(--brand);color:#fff;border-radius:999px;padding:7px 16px;font-size:13px;font-weight:700}
.badge.green{background:var(--sage-deep)}
.price{font-family:'Onest',-apple-system,'Segoe UI',sans-serif;font-size:42px;color:var(--brand-deep);font-weight:700;margin:8px 0}
.save{display:inline-block;background:rgba(47,159,212,.16);color:var(--sage-deep);font-weight:600;
  padding:5px 12px;border-radius:999px;font-size:14px;margin-bottom:10px}
.plan ul{list-style:none;padding:0;margin:12px 0 22px;flex:1}
.plan li{padding-left:26px;position:relative;margin:9px 0;color:#365057}
.plan li:before{content:"";position:absolute;left:0;top:.5em;width:12px;height:12px;border-radius:50%;
  background:var(--sage);opacity:.85}

/* program */
.program .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.pay{display:flex;flex-wrap:wrap;gap:14px;margin:22px 0}
.pay div{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 20px;flex:1;min-width:180px}
.pay span{display:block;color:var(--muted);font-size:14px}
.pay b{font-size:22px;color:var(--brand-deep)}
.program-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow)}
.program-card h3{font-size:clamp(24px,3vw,34px);margin-bottom:14px;color:var(--brand-deep)}
.program-card p{color:#365057;margin:0}

/* ---------- Contact form ---------- */
.contact{background:linear-gradient(180deg,var(--cream),#fff)}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.contact h2{font-size:clamp(28px,4vw,44px);margin-bottom:14px}
.contact .lead{margin-bottom:18px}
.contact .tg{display:inline-flex;align-items:center;gap:10px;color:var(--brand);font-weight:600}
/* Контактные ссылки с цветными бейджами мессенджеров */
.contact .msg-link{display:inline-flex;align-items:center;gap:12px;color:var(--ink);font-weight:600;text-decoration:none;margin:2px 0}
.contact .msg-link:hover{color:var(--brand-deep)}
.msg-ic{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;flex:0 0 auto;border-radius:50%;color:#fff}
.msg-ic svg{width:20px;height:20px}
.cdock-ic svg,.msg-ic svg{display:block}
/* цвета каналов (узнаваемость), в прохладной гамме сайта */
.ic-phone{background:linear-gradient(135deg,var(--sky),var(--brand))}
.ic-tg{background:linear-gradient(135deg,#2aabee,#1f8fcc)}
.ic-max{background:linear-gradient(135deg,#3f7bff,#6b4fe0)}
.ic-bip{background:linear-gradient(135deg,#00c2cf,#0096c7)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.field input,.field textarea{width:100%;font:inherit;color:var(--ink);background:var(--cream);
  border:1px solid var(--line);border-radius:12px;padding:13px 15px;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring)}
.field textarea{min-height:96px;resize:vertical}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted)}
.consent input{margin-top:3px}
.consent a{color:var(--brand);font-weight:600;text-decoration:underline}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{margin-top:12px;font-size:14px;min-height:20px}
.form-note.ok{color:var(--sage-deep)}
.form-note.err{color:#c0492f}

/* ---------- CTA ---------- */
.cta{text-align:center}
.cta .box{background:linear-gradient(135deg,var(--sand),#fff);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:56px 28px;box-shadow:var(--shadow-sm)}
.cta h2{font-size:clamp(28px,4.5vw,46px);margin-bottom:12px}
.cta p{color:var(--muted);max-width:520px;margin:0 auto 24px;font-size:18px}

/* ---------- Footer ---------- */
footer{background:var(--cream);border-top:1px solid var(--line)}
footer .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 14px;text-align:center;
  padding-block:30px;color:var(--muted);font-size:15px}
footer a{color:var(--brand-deep);font-weight:600}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;gap:0;
    background:rgba(255,255,255,.82);backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);
    border-bottom:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow);
    padding:8px 24px 20px;transform:translateY(-130%);transition:transform .28s ease;
  }
  body.menu-open .nav{transform:translateY(0)}
  .nav a{padding:14px 0;border-bottom:1px solid var(--line)}
  .nav a:after{display:none}
  .nav .btn{display:inline-flex;width:100%;margin-top:14px}
  .nav .btn:after{display:none}
  .nav-cta{display:none}
  .burger{display:inline-flex}
  .hero .wrap{grid-template-columns:1fr;padding-block:44px;text-align:left}
  .hero-photo{order:-1}
  .hero-photo img{width:min(280px,68vw)}
  .about .wrap,.program .wrap,.contact .wrap{grid-template-columns:1fr;gap:32px}
  .about img{max-height:62vh;object-fit:cover;object-position:50% 28%}
  .cards{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .pricing{grid-template-columns:1fr}
  .plan.popular{transform:none}
}
@media (max-width:560px){
  .wrap{padding-inline:18px}
  .section{padding-block:64px}
  .cards,.stat-grid{grid-template-columns:1fr}
  .features{gap:8px 16px}
  .btn{width:100%}
  .nav-cta{display:none}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important;animation:none!important}
}

/* ========================================================================
   Glassmorphism — сквозной стеклянный слой (бирюза / ларимар)
   Дозированно: стекло на поверхностях, текст контрастный, блюр щадящий.
   ======================================================================== */
body{background:#f7fcfd}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(42rem 42rem at 8% 2%, rgba(63,176,216,.10), transparent 64%),
    radial-gradient(40rem 40rem at 94% 12%, rgba(54,171,218,.08), transparent 64%),
    linear-gradient(180deg,#ffffff 0%,#f4fafd 100%);
}
/* секции прозрачные — фон просвечивает сквозь стекло */
.hero,.section,.section.alt,.contact{background:transparent}

/* шапка — стекло */
.topbar{background:rgba(255,255,255,.55);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3)}

/* стеклянные поверхности */
.card,.plan,.stat,.program-card,.form,.cta .box,.pay div,footer{
  background:rgba(255,255,255,.66);
  backdrop-filter:blur(14px) saturate(1.25);
  -webkit-backdrop-filter:blur(14px) saturate(1.25);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 12px 40px rgba(15,82,116,.10);
}
.section.alt .card{background:rgba(255,255,255,.66)}
.btn.outline{background:rgba(255,255,255,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.field input,.field textarea{background:rgba(255,255,255,.55)}
footer{box-shadow:none;border:0;border-top:1px solid rgba(255,255,255,.6)}

/* фолбэк без backdrop-filter — делаем поверхности плотнее, чтобы текст читался */
@supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){
  .topbar,.card,.plan,.stat,.program-card,.form,.cta .box,.pay div,footer{background:rgba(255,255,255,.93)}
  .field input,.field textarea{background:rgba(255,255,255,.9)}
}
/* на узких экранах ослабляем блюр ради плавности */
@media (max-width:560px){
  .card,.plan,.stat,.program-card,.form,.cta .box,.pay div{
    backdrop-filter:blur(9px) saturate(1.2);-webkit-backdrop-filter:blur(9px) saturate(1.2)}
}

/* ========================================================================
   Полировка под смартфоны (iPhone 13–17): safe-area, тап-цели, липкая CTA
   ======================================================================== */
html{-webkit-text-size-adjust:100%;scroll-padding-top:86px}
a,button,input,textarea,label,summary{-webkit-tap-highlight-color:transparent}

/* безопасные зоны (вырез/Dynamic Island/боковые в ландшафте) */
.topbar{padding-top:env(safe-area-inset-top)}
@media (max-width:560px){
  .wrap{padding-inline:max(18px,env(safe-area-inset-left)) max(18px,env(safe-area-inset-right))}
}

/* тактильный отклик на нажатие (на тач-устройствах нет ховера) */
.btn{will-change:transform}
.btn:active{transform:scale(.97)}
.burger:active{transform:scale(.94)}
.nav a:active{opacity:.6}

/* инпуты ровно 16px — iOS не зумит форму при фокусе */
.field input,.field textarea{font-size:16px}

/* ---- липкая нижняя кнопка (только смартфон/планшет) ---- */
/* ---- мягкое появление блоков при скролле (добавляется через JS) ---- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
}

/* чуть больше «воздуха» и крупнее тап-цели в меню на смартфоне */
@media (max-width:560px){
  .nav a{padding:15px 0;font-size:17px}
  .section{padding-block:62px}
  .hero .wrap{padding-block:36px 40px}
}

/* ========================================================================
   Премиум-детали: блик кнопок, плавный аккордеон тарифов, параллакс hero
   ======================================================================== */
/* блик-свип по кнопке при наведении */
.btn{position:relative;overflow:hidden;isolation:isolate}
.btn::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(120deg,transparent 25%,rgba(255,255,255,.4) 50%,transparent 75%);
  transform:translateX(-130%) skewX(-18deg);transition:transform .65s cubic-bezier(.22,1,.36,1)}
.btn:hover::after{transform:translateX(130%) skewX(-18deg)}
.btn.outline::after{background:linear-gradient(120deg,transparent 25%,rgba(15,109,150,.14) 50%,transparent 75%)}
.btn>*{position:relative;z-index:1}

/* hero-фото — плавный параллакс (transform задаёт JS) */
.hero-photo{will-change:transform}

/* аккордеон тарифов: десктоп — всё раскрыто; тоггл только на смартфоне */
.plan-toggle{display:none}
.features-wrap{display:block}
@media (max-width:760px){
  .plan-toggle{display:flex;align-items:center;gap:11px;width:100%;
    margin:8px 0 4px;padding:12px 14px;border:1px solid var(--line);border-radius:13px;
    background:var(--cream);cursor:pointer;font:inherit;font-weight:700;color:var(--brand-deep);
    transition:background .15s ease,border-color .15s ease}
  .plan-toggle:hover{border-color:var(--brand)}
  .plan-toggle .chev{display:inline-flex;align-items:center;justify-content:center;
    width:26px;height:26px;flex:0 0 auto;border-radius:50%;background:var(--brand);color:#fff;
    transition:transform .3s ease}
  .plan-toggle .chev svg{width:15px;height:15px}
  .plan.is-open .plan-toggle{background:#e7f2fa;border-color:var(--sage)}
  .plan.is-open .plan-toggle .chev{transform:rotate(180deg)}
  .plan.js-accordion .features-wrap{display:grid;grid-template-rows:0fr;
    transition:grid-template-rows .35s cubic-bezier(.22,1,.36,1)}
  .plan.js-accordion.is-open .features-wrap{grid-template-rows:1fr}
  .plan.js-accordion .features-wrap>ul{overflow:hidden;min-height:0;margin:0}
}

/* ========================================================================
   Нижний док: «Записаться» + контакты (Telegram / MAX / BiP)
   Десктоп: кружок справа снизу. Смартфон: лента «Записаться» + кружок вместе.
   ======================================================================== */
.cdock{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:45}
.cdock-row{display:flex;align-items:center;justify-content:flex-end;gap:12px}
.cdock-cta{display:none}                 /* «Записаться» — только на смартфоне */
.cdock-menu{position:absolute;right:0;bottom:calc(100% + 12px);
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
  opacity:0;transform:translateY(10px) scale(.96);transform-origin:bottom right;pointer-events:none;
  transition:opacity .22s ease,transform .22s cubic-bezier(.22,1,.36,1)}
.cdock.open .cdock-menu{opacity:1;transform:none;pointer-events:auto}
.cdock-item{display:inline-flex;align-items:center;gap:10px;text-decoration:none;
  background:#fff;color:var(--ink);font-weight:600;font-size:15px;
  padding:9px 16px 9px 9px;border-radius:999px;border:1px solid var(--line);
  box-shadow:0 8px 22px rgba(15,82,116,.16);white-space:nowrap;transition:transform .15s ease,border-color .15s ease}
.cdock-item:hover{border-color:var(--brand);transform:translateX(-2px)}
.cdock-ic{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex:0 0 auto;
  border-radius:50%;color:#fff}
.cdock-ic svg{width:18px;height:18px}
.cdock-btn{position:relative;width:58px;height:58px;border-radius:50%;border:0;cursor:pointer;flex:0 0 auto;
  background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;
  box-shadow:0 12px 30px rgba(15,82,116,.34);display:flex;align-items:center;justify-content:center;
  transition:transform .2s ease,box-shadow .2s ease}
.cdock-btn:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(15,82,116,.40)}
.cdock-btn:active{transform:scale(.95)}
.cdock-btn svg{position:absolute;width:26px;height:26px;transition:opacity .2s ease,transform .25s ease}
.cdock-close{opacity:0;transform:rotate(-90deg)}
.cdock.open .cdock-open{opacity:0;transform:rotate(90deg)}
.cdock.open .cdock-close{opacity:1;transform:rotate(0)}

/* Смартфон: док превращается в нижнюю ленту «Записаться» + кружок */
@media (max-width:760px){
  .cdock{left:0;right:0;bottom:0;
    background:#fff;border-top:1px solid var(--line);box-shadow:0 -8px 28px rgba(15,82,116,.12);
    padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    transform:translate3d(0,130%,0);opacity:0;pointer-events:none;
    transition:transform .38s cubic-bezier(.4,0,.2,1),opacity .3s ease;
    will-change:transform,opacity;backface-visibility:hidden}
  .cdock.show{transform:translate3d(0,0,0);opacity:1;pointer-events:auto}
  .cdock-cta{display:inline-flex;flex:1 1 auto;margin:0;padding:15px 20px;box-shadow:none}
  .cdock-btn{width:52px;height:52px}
  .cdock-btn svg{width:24px;height:24px}
  .cdock-menu{right:14px;bottom:calc(100% + 12px)}
  footer{padding-bottom:calc(30px + env(safe-area-inset-bottom))}
}
@media (prefers-reduced-motion:reduce){
  .cdock,.cdock-menu,.cdock-btn svg{transition:none}
}

/* ========================================================================
   Отзывы / Регалии / FAQ
   ======================================================================== */
.sec-head{max-width:680px;margin:0 auto 40px;text-align:center}
.sec-head .lead{margin-top:10px}
.wrap.narrow{max-width:780px}

/* Отзывы — карусель вертикальных медиа */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.review-card{display:flex;flex-direction:column;gap:13px}
.rc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.rc-head figcaption{font-weight:700;color:var(--brand-deep)}
.stars{display:flex;gap:3px}
.star{width:19px;height:19px;fill:#d7e4ec;flex:0 0 auto}
.star.on{fill:#f3b53f}
.review-card blockquote{margin:0;color:var(--ink);line-height:1.6}

/* Медиа-карусель (вертикальный формат 9:16, свайп на смартфоне) */
.media-carousel{position:relative;border-radius:16px;overflow:hidden;background:#0b1418;box-shadow:0 8px 22px rgba(15,82,116,.12)}
.media-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.media-track::-webkit-scrollbar{display:none}
.media-slide{position:relative;flex:0 0 100%;scroll-snap-align:center;aspect-ratio:9/16;background:#0b1418}
.rv-media{display:block;width:100%;height:100%;border:0;margin:0;padding:0;background:#0b1418}
.rv-img{cursor:zoom-in}
.media-slide img,.media-slide video{width:100%;height:100%;object-fit:cover;display:block}
.media-badge{position:absolute;left:10px;top:10px;background:rgba(11,20,24,.66);color:#fff;font-size:11px;font-weight:600;
  padding:4px 10px;border-radius:999px;letter-spacing:.02em;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.media-badge.vid{background:rgba(15,109,150,.88)}
.media-dots{position:absolute;left:0;right:0;bottom:11px;display:flex;justify-content:center;gap:6px;pointer-events:none}
.media-dots .dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.5);transition:width .2s,height .2s,background .2s}
.media-dots .dot.on{background:#fff;width:9px;height:9px}

/* Регалии — те же вертикальные фреймы (симметрия с отзывами) */
.regalia-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:0}
.regalia-item{margin:0;display:flex;flex-direction:column;gap:10px}
.regalia-item .rv-img{width:100%;aspect-ratio:9/16;border-radius:16px;overflow:hidden;background:#0b1418;box-shadow:0 8px 22px rgba(15,82,116,.12);transition:transform .2s ease}
.regalia-item .rv-img:hover{transform:translateY(-3px)}
.regalia-item img{display:block;width:100%;height:100%;object-fit:cover}
.regalia-item figcaption{color:var(--muted);font-size:14px;text-align:center}

/* Лайтбокс (фото отзывов и дипломы в полном размере) */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(8,14,18,.93);display:flex;align-items:center;justify-content:center;
  padding:max(20px,env(safe-area-inset-top)) max(18px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left))}
.lightbox[hidden]{display:none}
.lb-img{max-width:100%;max-height:100%;border-radius:12px;object-fit:contain;box-shadow:0 24px 60px rgba(0,0,0,.55)}
.lb-close{position:absolute;top:max(12px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right));width:46px;height:46px;
  border-radius:50%;border:0;background:rgba(255,255,255,.16);color:#fff;font-size:30px;line-height:1;cursor:pointer;-webkit-tap-highlight-color:transparent}
.lb-close:hover{background:rgba(255,255,255,.26)}

/* FAQ (нативный details — без JS, хорошо для SEO) */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;padding:18px 20px;font-weight:700;color:var(--ink);list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--brand-deep)}
.faq-chev{position:relative;width:24px;height:24px;flex:0 0 auto;border-radius:50%;background:var(--cream);transition:background .2s ease}
.faq-chev::before,.faq-chev::after{content:"";position:absolute;left:50%;top:50%;width:11px;height:2.4px;background:var(--brand);transform:translate(-50%,-50%);border-radius:2px;transition:transform .25s ease}
.faq-chev::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item[open] .faq-chev{background:#e7f2fa}
.faq-item[open] .faq-chev::after{transform:translate(-50%,-50%) rotate(0)}
.faq-a{padding:0 20px 18px;color:var(--muted);line-height:1.65}

@media (max-width:860px){
  .reviews-grid,.regalia-grid{grid-template-columns:1fr 1fr;gap:16px}
}
@media (max-width:560px){
  .reviews-grid,.regalia-grid{grid-template-columns:1fr;gap:24px}
  .review-card,.regalia-item{width:100%;max-width:480px;margin-inline:auto}
  .media-slide,.regalia-item .rv-img{max-height:74vh}
}

/* Результаты программы (Что вы получите) */
.outcomes{margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.outcomes-title{font-weight:700;color:var(--brand-deep);margin:0 0 12px}
.check-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.check-list li{position:relative;padding-left:32px;color:#365057;line-height:1.5}
.check-list li::before{content:"";position:absolute;left:0;top:2px;width:21px;height:21px;border-radius:50%;background:#e7f2fa}
.check-list li::after{content:"";position:absolute;left:7px;top:5px;width:6px;height:11px;border:solid var(--brand);border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}

/* Корректные подписи полей (.field — это label со span внутри) */
.field > span{display:block;font-weight:600;font-size:14px;margin-bottom:7px;color:var(--ink)}

/* Лид-магнит */
.lead-magnet{background:linear-gradient(180deg,#fff,var(--cream))}
.lm-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.lm-info h2{margin-bottom:14px}
.lm-info .lead{margin-bottom:18px}
.lm-info .check-list{gap:12px}
.lm-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow)}
.lm-done{text-align:center}
.lm-done-title{font-weight:700;color:var(--brand-deep);font-size:19px;margin:0 0 14px}
.lm-note{margin-top:12px;color:var(--muted);font-size:12.5px;line-height:1.5;text-align:center}
@media (max-width:860px){
  .lm-wrap{grid-template-columns:1fr;gap:26px}
}
