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

: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 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:48px;align-items:center;padding-block:64px}
.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:72px}
.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:30px;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}
.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:52px}
  .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:#e9f6f8}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(38rem 38rem at 10% 6%, rgba(63,176,216,.20), transparent 60%),
    radial-gradient(34rem 34rem at 90% 16%, rgba(54,171,218,.16), transparent 60%),
    radial-gradient(44rem 44rem at 72% 94%, rgba(15,109,150,.14), transparent 62%),
    linear-gradient(180deg,#f1fbfc 0%,#e4f4f6 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}

/* ---- липкая нижняя кнопка (только смартфон/планшет) ---- */
.mobile-cta{display:none}
@media (max-width:760px){
  .mobile-cta{
    display:block;position:fixed;left:0;right:0;bottom:0;z-index:40;
    padding:10px 16px calc(10px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);
    border-top:1px solid rgba(255,255,255,.6);box-shadow:0 -10px 34px rgba(15,82,116,.14);
    transform:translateY(130%);transition:transform .32s cubic-bezier(.22,1,.36,1);pointer-events:none;
  }
  .mobile-cta.show{transform:translateY(0);pointer-events:auto}
  .mobile-cta .btn{width:100%;margin:0;padding:15px 22px;box-shadow:none}
  /* чтобы липкая кнопка не перекрывала самый низ */
  footer{padding-bottom:calc(28px + env(safe-area-inset-bottom))}
}

/* ---- мягкое появление блоков при скролле (добавляется через 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:48px}
  .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;justify-content:space-between;gap:10px;width:100%;
    margin:6px 0 2px;padding:12px 2px;border:0;border-top:1px solid var(--line);
    background:transparent;cursor:pointer;font:inherit;font-weight:600;color:var(--brand-deep)}
  .plan-toggle .chev{transition:transform .3s ease;font-size:12px;color:var(--brand)}
  .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}
}
