/* ======================================================================
   CLEAN PRODUCT — продуктовое направление по референсу пользователя
   ====================================================================== */
:root{
  --c-brand:#0b8a86;
  --c-brand-2:#0a7773;
  --c-brand-strong:#086663;
  --c-brand-dark:#003D38;
  --c-brand-soft:#e8f3f2;
  --c-brand-tint:#f3faf9;
  --c-accent:#fdad3a;
  --c-accent-2:#e89a25;

  --c-bg:#FFFFFF;
  --c-bg-soft:#F5F7F4;
  --c-paper:#FFFFFF;
  --c-text:#0F1D1C;
  --c-text-2:#3a4644;
  --c-text-muted:#6b7977;
  --c-line:#E6E2D8;
  --c-line-2:#D5D0C3;

  --radius:14px;
  --radius-lg:20px;
  --radius-xl:28px;
  --density:1;
  --font:'Manrope', system-ui, sans-serif;

  --section-pad: calc(80px * var(--density));
  --maxw: 1240px;

  --shadow-sm: 0 2px 8px -4px rgba(15,29,28,.08);
  --shadow: 0 14px 32px -16px rgba(15,29,28,.18), 0 2px 6px -2px rgba(15,29,28,.06);
  --shadow-lg: 0 30px 60px -24px rgba(15,29,28,.22), 0 6px 16px -8px rgba(15,29,28,.08);
  --shadow-green: 0 14px 32px -10px rgba(11,138,134,.35);
}
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth; scroll-padding-top:96px}
html,body{background:var(--c-bg); color:var(--c-text); font-family:var(--font); -webkit-font-smoothing:antialiased; overflow-x:hidden}
body{font-size:16px; line-height:1.55; letter-spacing:-0.005em}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button{font-family:inherit; cursor:pointer; background:none; border:none; color:inherit}
input,select,textarea{font-family:inherit; font-size:inherit; color:inherit}
:focus-visible{outline:3px solid var(--c-brand); outline-offset:3px; border-radius:6px}
.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}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}

/* HEADER */
header.site{position:sticky; top:0; z-index:60; background:color-mix(in srgb, var(--c-bg) 88%, transparent); backdrop-filter:blur(14px) saturate(140%); border-bottom:1px solid var(--c-line); transition:background .3s, border-color .3s}
body.menu-open header.site{background:var(--c-paper); backdrop-filter:none}
.head-row{display:flex; justify-content:space-between; align-items:center; padding:10px 0; gap:24px; min-height:64px}
.head-brand{display:flex; align-items:center; gap:12px}
.brand-logo{height:44px; width:auto; flex:none; transition:opacity .2s; display:block}
.brand-logo:hover{opacity:.85}
@media (max-width:560px){.brand-logo{height:38px}}
.head-nav{display:flex; gap:4px}
.head-nav a{padding:10px 14px; font-size:14px; font-weight:600; color:var(--c-text-2); border-radius:10px; transition:background .2s, color .2s}
.head-nav a:hover{background:var(--c-brand-soft); color:var(--c-brand)}
.head-phone{display:flex; align-items:center; gap:6px}
.head-phone .num{font-weight:800; font-size:15px; white-space:nowrap; letter-spacing:-0.01em; color:var(--c-text); text-decoration:none; transition:color .15s}
.head-phone .num:hover{color:var(--c-brand)}
.head-phone .sub{font-size:11px; color:var(--c-text-muted)}
.head-cta{display:inline-flex; align-items:center; justify-content:center; padding:10px 18px; font-size:14px; font-weight:700; line-height:1; border-radius:10px; white-space:nowrap; flex:none}
@media (max-width:1024px){ .head-nav{display:none} .head-row .head-cta{display:none} }
@media (max-width:560px){ .head-phone{display:none} }

/* HAMBURGER BUTTON */
.head-burger{display:none; width:44px; height:44px; padding:0; background:transparent; border:1px solid var(--c-line); border-radius:10px; cursor:pointer; flex-direction:column; gap:4px; align-items:center; justify-content:center; transition:background .2s, border-color .2s; flex:none}
.head-burger:hover{background:var(--c-brand-soft); border-color:var(--c-brand)}
.head-burger span{display:block; width:18px; height:2px; background:var(--c-text); border-radius:2px; transition:transform .25s ease, opacity .2s ease}
.head-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.head-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.head-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:1024px){ .head-burger{display:flex} }

/* MOBILE OVERLAY MENU */
.mob-menu{position:fixed; top:64px; left:0; right:0; bottom:0; z-index:55; background:var(--c-paper); padding:24px 24px 32px; display:flex; flex-direction:column; gap:0; overflow-y:auto; animation:menuIn .25s ease; border-top:1px solid var(--c-line)}
.mob-menu[hidden]{display:none}
@keyframes menuIn{from{opacity:0; transform:translateY(-8px)} to{opacity:1; transform:translateY(0)}}
.mob-menu-nav{display:flex; flex-direction:column; gap:0}
.mob-menu-nav a{padding:18px 4px; font-size:18px; font-weight:700; color:var(--c-text); letter-spacing:-0.01em; border-bottom:1px solid var(--c-line); transition:color .2s, padding-left .2s; display:flex; align-items:center; justify-content:space-between}
.mob-menu-nav a::after{content:'→'; font-size:18px; color:var(--c-text-muted); opacity:.4; transition:transform .2s, opacity .2s, color .2s}
.mob-menu-nav a:hover{color:var(--c-brand); padding-left:8px}
.mob-menu-nav a:hover::after{transform:translateX(4px); opacity:1; color:var(--c-brand)}
.mob-menu-foot{margin-top:auto; padding-top:32px; display:flex; flex-direction:column; gap:18px}
.mob-menu-phone{display:flex; flex-direction:column; gap:2px; padding:14px 0; border-bottom:1px solid var(--c-line); color:var(--c-text); text-align:center}
.mob-menu-phone .num{font-size:22px; font-weight:800; letter-spacing:-0.01em}
.mob-menu-phone .sub{font-size:12px; color:var(--c-text-muted)}
.mob-menu-foot .btn{justify-content:center; padding:16px 24px; font-size:15px}
body.menu-open{overflow:hidden}


/* HERO */
section.hero{padding:24px 0 0}
.hero-card{position:relative; border-radius:var(--radius-xl); overflow:hidden; background:#dde5dd; display:grid; grid-template-columns:minmax(0, 1fr) minmax(420px, 560px); min-height:560px; box-shadow:var(--shadow)}
.hero-text{position:relative; z-index:2; padding:48px 40px 40px; display:flex; flex-direction:column; gap:24px; justify-content:center; min-width:0; max-width:100%}
.hero-eyebrow{display:inline-flex; align-items:center; gap:10px; padding:7px 14px; background:#fff; border-radius:999px; font-size:12px; font-weight:700; color:var(--c-brand-dark); letter-spacing:.06em; text-transform:uppercase; align-self:flex-start; box-shadow:var(--shadow-sm)}
.hero-eyebrow .dot{width:8px; height:8px; border-radius:50%; background:var(--c-accent); animation:pulse 1.6s ease infinite}
@keyframes pulse{0%,100%{opacity:1; transform:scale(1)} 50%{opacity:.55; transform:scale(.8)}}
.hero-title{font-size:clamp(30px, 4vw, 52px); font-weight:800; letter-spacing:-0.035em; line-height:1.08; color:var(--c-text); overflow-wrap:break-word; hyphens:manual; word-break:normal}
.hero-title .acc{color:#fff; display:inline; position:relative; background:linear-gradient(120deg, var(--c-brand) 0%, var(--c-brand-dark, #066b68) 100%); padding:.04em .28em; border-radius:.18em; box-decoration-break:clone; -webkit-box-decoration-break:clone; box-shadow:0 6px 20px -8px rgba(11,138,134,.45)}
.hero-title .acc::after{content:''; position:absolute; left:0; right:0; bottom:-2px; height:3px; background:var(--c-accent); transform:scaleX(0); transform-origin:left; transition:transform .9s ease .35s}
.hero-title.in .acc::after{transform:scaleX(1)}
.hero-title .acc::after{display:none}
.hero-sub{font-size:16px; line-height:1.55; color:var(--c-text-2); max-width:46ch; font-weight:500}
.hero-prereq{
  font-size:12.5px; line-height:1.5;
  color:var(--c-text-muted, #5B7472);
  max-width:54ch;
  margin:0;
  padding:8px 12px;
  background:rgba(0,0,0,.03);
  border-left:2px solid var(--c-accent, #FDAD3A);
  border-radius:6px;
  font-weight:400;
}
@media (max-width:600px){.hero-prereq{font-size:11.5px; padding:7px 10px}}
.hero-ctas{display:flex; gap:12px; flex-wrap:wrap}
.btn{display:inline-flex; align-items:center; gap:10px; padding:14px 22px; border-radius:12px; font-size:14px; font-weight:700; transition:transform .2s ease, background .2s ease, color .2s, box-shadow .2s; letter-spacing:-0.005em; white-space:nowrap}
.btn-primary{background:var(--c-brand-strong); color:#fff; box-shadow:var(--shadow-green)}
.btn-primary:hover{background:var(--c-brand-dark); transform:translateY(-2px); box-shadow:0 18px 36px -10px rgba(11,138,134,.5)}
.btn-primary .arr{width:22px; height:22px; background:rgba(255,255,255,.18); border-radius:50%; display:grid; place-items:center; transition:background .2s}
.btn-primary:hover .arr{background:rgba(255,255,255,.32)}
.btn-ghost{background:#fff; color:var(--c-text); border:1.5px solid var(--c-line-2)}
.hero-card .btn-ghost{border-color:rgba(15,29,28,.18); box-shadow:0 2px 8px -4px rgba(15,29,28,.12)}
.btn-ghost:hover{border-color:var(--c-brand); color:var(--c-brand); transform:translateY(-2px); box-shadow:0 6px 16px -8px rgba(11,138,134,.25)}
.btn-white{background:#fff; color:var(--c-brand-dark)}
.btn-white:hover{background:var(--c-brand-soft); transform:translateY(-2px)}
.hero-chips{display:flex; gap:8px; flex-wrap:wrap; margin-top:4px}
.chip{display:inline-flex; align-items:center; gap:8px; padding:8px 14px; background:#fff; border:1px solid rgba(11,138,134,0.15); border-radius:999px; font-size:13px; font-weight:600; color:var(--c-text-2); transition:transform .2s, background .2s, border-color .2s; box-shadow:var(--shadow-sm)}
.chip:hover{transform:translateY(-2px)}
.chip svg{width:14px; height:14px; color:var(--c-brand); flex:none}

.hero-photo{position:relative; overflow:hidden; min-width:0}
.hero-photo img{width:100%; height:100%; object-fit:cover; object-position:center right; image-rendering:-webkit-optimize-contrast}
.hero-photo::after{content:''; position:absolute; inset:0; background:linear-gradient(90deg, rgba(221,229,221,.85) 0%, rgba(221,229,221,0) 30%); pointer-events:none}

@media (max-width:980px){
  .hero-card{grid-template-columns:1fr; min-height:auto}
  .hero-text{padding:32px 24px; order:2}
  .hero-photo{order:1; aspect-ratio:16/10}
  .hero-photo::after{background:linear-gradient(180deg, rgba(221,229,221,0) 60%, rgba(221,229,221,.8) 100%)}
}

/* GENERIC SECTION */
section.std{padding:var(--section-pad) 0; position:relative}
.sec-head{text-align:center; max-width:740px; margin:0 auto 48px}
.sec-eyebrow{display:inline-flex; align-items:center; gap:10px; padding:6px 14px; background:var(--c-brand-soft); color:var(--c-brand-strong); border-radius:999px; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:18px}
.sec-eyebrow::before{content:''; width:6px; height:6px; border-radius:50%; background:var(--c-brand)}
.sec-title{font-size:clamp(28px, 3.6vw, 44px); font-weight:800; letter-spacing:-0.03em; line-height:1.08}
.sec-title em{font-style:normal; color:var(--c-brand)}
.sec-sub{margin-top:14px; font-size:16px; color:var(--c-text-muted); line-height:1.55; max-width:60ch; margin-inline:auto}

/* TRUST */
.trust-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.trust-card{background:var(--c-paper); border-radius:var(--radius-lg); padding:30px 26px; display:flex; flex-direction:column; gap:14px; position:relative; transition:transform .3s ease, box-shadow .3s ease; border:1px solid var(--c-line); overflow:hidden; color:inherit; text-decoration:none; box-shadow:0 4px 16px -8px rgba(15,29,28,.10), 0 2px 6px -3px rgba(15,29,28,.06)}
a.trust-card:hover h3{color:var(--c-brand)}
.trust-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.trust-card .ico{width:54px; height:54px; border-radius:14px; background:var(--c-brand-soft); display:grid; place-items:center; color:var(--c-brand); transition:background .3s, transform .3s}
.trust-card:hover .ico{background:var(--c-brand); color:#fff; transform:rotate(-6deg) scale(1.05)}
.trust-card h3{font-size:17px; font-weight:700; letter-spacing:-0.015em; line-height:1.25}
.trust-card p{font-size:13.5px; color:var(--c-text-muted); line-height:1.55}
@media(max-width:980px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.trust-grid{grid-template-columns:1fr}}

/* AUDIENCES */
.aud-pager{display:flex; justify-content:center; gap:8px; margin-bottom:28px}
.aud-pager button{width:44px; height:44px; border:1.5px solid var(--c-line); background:var(--c-paper); border-radius:50%; font-weight:700; font-size:14px; transition:all .25s; display:grid; place-items:center; color:var(--c-text-muted); flex:none}
.aud-pager button[aria-pressed="true"]{background:var(--c-brand-strong); color:#fff; border-color:var(--c-brand-strong); transform:scale(1.08); box-shadow:var(--shadow-green)}
.aud-pager button:hover:not([aria-pressed="true"]){border-color:var(--c-brand); color:var(--c-brand)}

.aud-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.aud-card{position:relative; border-radius:var(--radius-lg); overflow:hidden; background:var(--c-paper); border:1px solid var(--c-line); box-shadow:0 4px 14px -6px rgba(15,29,28,.10), 0 2px 6px -3px rgba(15,29,28,.06); transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .3s; display:flex; flex-direction:column}
.aud-card:hover{transform:translateY(-8px); box-shadow:var(--shadow-lg)}
.aud-card .photo{aspect-ratio:3/4; position:relative; overflow:hidden}
.aud-card .photo img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease; image-rendering:-webkit-optimize-contrast; backface-visibility:hidden; transform:translateZ(0)}
.aud-card:hover .photo img{transform:scale(1.06) translateZ(0)}
.aud-num{position:absolute; top:14px; left:14px; width:42px; height:42px; background:var(--c-brand); color:#fff; border-radius:12px; font-weight:800; font-size:16px; display:grid; place-items:center; z-index:2; box-shadow:var(--shadow-green); transition:transform .3s}
.aud-card:hover .aud-num{transform:rotate(-8deg) scale(1.08)}
.aud-body{padding:20px; display:flex; flex-direction:column; gap:8px}
.aud-title{font-size:16px; font-weight:700; letter-spacing:-0.015em; line-height:1.25}
.aud-desc{font-size:13px; color:var(--c-text-muted); line-height:1.55}
@media(max-width:980px){.aud-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.aud-grid{grid-template-columns:1fr}}

/* INLINE FORM BANNER */
.inline-form-section{padding:var(--section-pad) 0}
.inline-form{position:relative; border-radius:var(--radius-xl); overflow:hidden; background:var(--c-brand); color:#fff; display:grid; grid-template-columns:1.05fr .95fr; gap:0; min-height:360px; box-shadow:var(--shadow-lg)}
.inline-form .info{position:relative; z-index:2; padding:40px 36px; display:flex; flex-direction:column; gap:20px; justify-content:center}
.inline-form .info h3{font-size:clamp(26px,3vw,36px); font-weight:800; letter-spacing:-0.03em; line-height:1.05}
.inline-form .info h3 em{font-style:normal; color:var(--c-accent)}
.inline-form .info > p{font-size:14.5px; line-height:1.55; color:rgba(255,255,255,.85); max-width:42ch}
.inline-form .bullets{display:flex; flex-direction:column; gap:10px}
.inline-form .bullet{display:flex; gap:10px; align-items:flex-start; font-size:13.5px; color:rgba(255,255,255,.95)}
.inline-form .bullet svg{flex:none; width:22px; height:22px; padding:3px; background:rgba(255,255,255,.18); border-radius:50%; color:#fff; margin-top:1px}
.inline-form .bullet b{color:#fff; font-weight:700}

.inline-form .photo-bg{position:absolute; inset:0; opacity:.18; pointer-events:none; mix-blend-mode:overlay}
.inline-form .photo-bg img{width:100%; height:100%; object-fit:cover}

.mini-form{padding:32px 28px; background:rgba(15,29,28,.18); display:flex; flex-direction:column; gap:12px; position:relative; z-index:2; backdrop-filter:blur(6px); justify-content:center}
.mini-form .field input{background:rgba(255,255,255,.95); border:1.5px solid transparent; padding:13px 16px; border-radius:10px; font-size:14px; width:100%; transition:border-color .2s, background .2s; font-weight:500; color:var(--c-text)}
.mini-form .field input::placeholder{color:var(--c-text-muted)}
.mini-form .field input:focus{outline:none; border-color:var(--c-accent); background:#fff}
.mini-form .field input[aria-invalid="true"]{border-color:#fde2e2; background:#fff}
.mini-form .field .err{font-size:11px; color:#fff; min-height:14px; font-weight:600; opacity:.95}
.mini-form button[type="submit"]{padding:15px 20px; background:var(--c-brand-dark); color:#fff; border-radius:10px; font-size:14px; font-weight:700; display:inline-flex; align-items:center; justify-content:center; gap:10px; transition:background .2s, transform .2s; margin-top:4px}
.mini-form button[type="submit"]:hover{background:#01615a; transform:translateY(-2px)}
.mini-form .agree{display:grid; grid-template-columns:18px 1fr; gap:10px; font-size:11.5px; color:rgba(255,255,255,.8); line-height:1.45; align-items:start}
.mini-form .agree input{margin-top:2px; accent-color:var(--c-accent); width:16px; height:16px}
.mini-form .agree a{color:var(--c-accent); text-decoration:underline; font-weight:600}

@media(max-width:980px){
  .inline-form{grid-template-columns:1fr; min-height:auto}
  .inline-form .info{padding:32px 24px}
  .mini-form{padding:24px}
}
@media(max-width:560px){
  .inline-form .info{padding:24px 20px}
  .inline-form .info h3{font-size:24px}
  .inline-form .bullet{font-size:13px}
}

/* FORMAT */
.format-section{background:var(--c-bg-soft); position:relative}
.format-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:36px; position:relative; padding-top:48px}
.format-grid::before{content:''; position:absolute; top:24px; left:14%; right:14%; height:2px; background-image:linear-gradient(to right, var(--c-brand) 50%, transparent 50%); background-size:12px 2px; background-repeat:repeat-x; z-index:0}
.format-step{position:relative; display:flex; flex-direction:column; gap:14px; z-index:1; text-align:center}
.format-num{width:52px; height:52px; background:var(--c-bg); border:3px solid var(--c-brand); color:var(--c-brand); border-radius:50%; display:grid; place-items:center; font-weight:800; font-size:18px; margin:0 auto 14px; transition:transform .3s, background .25s, color .25s}
.format-step:hover .format-num{background:var(--c-brand); color:#fff; transform:scale(1.08)}
.format-photo{aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden; background:var(--c-paper); border:1px solid var(--c-line); transition:transform .3s}
.format-photo img{width:100%; height:100%; object-fit:cover}
.format-step:hover .format-photo{transform:translateY(-4px); box-shadow:var(--shadow)}
.format-step h3{font-size:20px; font-weight:700; letter-spacing:-0.02em}
.format-step p{font-size:14px; color:var(--c-text-muted); line-height:1.55}
.format-days{display:flex; flex-direction:column; gap:6px; padding:14px 18px; background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--radius); margin-top:6px; text-align:left}
.format-days .d{display:grid; grid-template-columns:auto 1fr; gap:12px; font-size:13px}
.format-days .d b{color:var(--c-brand); font-weight:700; min-width:60px}
.format-days .d span{color:var(--c-text-2)}
@media(max-width:980px){.format-grid{grid-template-columns:1fr; gap:24px; padding-top:24px} .format-grid::before{display:none} .format-photo{aspect-ratio:16/10}}
@media(max-width:520px){.format-grid{gap:20px} .format-days{padding:12px 14px}}

/* PROGRAMS */
.prog-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px; align-items:stretch; max-width:1180px; margin-inline:auto}
.prog-card{background:var(--c-paper); border:1.5px solid var(--c-line); border-radius:var(--radius-lg); padding:30px 28px; display:flex; flex-direction:column; gap:14px; position:relative; transition:transform .3s, box-shadow .3s, border-color .25s}
.prog-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.prog-card.featured{background:linear-gradient(180deg, var(--c-brand-tint) 0%, #fff 60%); border:2.5px solid var(--c-brand); box-shadow:0 24px 48px -20px rgba(11,138,134,.35), 0 8px 20px -12px rgba(11,138,134,.18)}
.prog-card.featured:hover{transform:translateY(-8px); box-shadow:0 32px 56px -20px rgba(11,138,134,.45), 0 12px 24px -12px rgba(11,138,134,.22)}
@media(min-width:1025px){.prog-card.featured{transform:translateY(-8px)}}
.prog-card .pop{position:absolute; top:-16px; left:50%; transform:translateX(-50%); padding:8px 16px; background:var(--c-accent); color:var(--c-text); font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:800; border-radius:999px; box-shadow:0 12px 28px -8px rgba(253,173,58,.65); white-space:nowrap; border:2px solid #fff}
.prog-name{font-size:22px; font-weight:800; letter-spacing:-0.025em; line-height:1.15}
.prog-price{font-size:38px; font-weight:800; color:var(--c-brand); letter-spacing:-0.04em; line-height:1; display:flex; align-items:baseline; gap:6px}
.prog-price small{font-size:15px; font-weight:600; color:var(--c-text-muted); letter-spacing:0}
.prog-meta{display:flex; gap:10px; flex-wrap:wrap; font-size:13px; color:var(--c-text-muted); padding-bottom:14px; border-bottom:1px dashed var(--c-line)}
.prog-meta b{color:var(--c-text); font-weight:700}
.prog-desc{font-size:14px; color:var(--c-text-muted); line-height:1.55}
.prog-includes{list-style:none; display:flex; flex-direction:column; gap:10px; padding-top:14px; border-top:1px solid var(--c-line)}
.prog-includes li{font-size:13.5px; display:grid; grid-template-columns:18px 1fr; gap:10px; align-items:start; line-height:1.45}
/* prog-includes li::before removed — checkmark уже рисует inline <span class="ck"> в HTML, ::before создавал дубликат. См. v6 fix. */
.prog-cta{margin-top:auto; padding:13px 20px; background:var(--c-brand-dark); color:#fff; border-radius:10px; font-size:14px; font-weight:700; display:inline-flex; align-items:center; justify-content:space-between; gap:10px; transition:background .2s, transform .2s}
.prog-card.featured .prog-cta{background:var(--c-brand)}
.prog-cta:hover{background:var(--c-brand); transform:translateY(-2px); box-shadow:var(--shadow-green)}
.prog-card.featured .prog-cta:hover{background:var(--c-brand-dark)}
@media(max-width:1024px){.prog-grid{grid-template-columns:1fr; max-width:520px; margin-inline:auto; gap:18px} .prog-card{padding:26px 24px}}

/* DRONES — тёмный teal-фон, белые «листы» под рендеры */
.drones-section{background:linear-gradient(180deg, var(--c-brand-dark) 0%, #002b27 100%); color:#fff; position:relative; overflow:hidden}
.drones-section::before{content:''; position:absolute; top:-100px; right:-80px; width:380px; height:380px; background:radial-gradient(circle, rgba(11,138,134,.35), transparent 70%); pointer-events:none}
.drones-section::after{content:''; position:absolute; bottom:-120px; left:-100px; width:340px; height:340px; background:radial-gradient(circle, rgba(253,173,58,.12), transparent 70%); pointer-events:none}
.drones-section .sec-title{color:#fff}
.drones-section .sec-title em{color:var(--c-accent)}
.drones-section .sec-eyebrow{background:rgba(255,255,255,.1); color:var(--c-accent)}
.drones-grid{display:grid; grid-template-columns:1fr 1fr; gap:20px; position:relative; z-index:1}
.drone-card{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:24px; display:grid; grid-template-columns:1fr 1.2fr; gap:24px; align-items:center; transition:transform .3s, border-color .3s, background .3s; position:relative; overflow:hidden; backdrop-filter:blur(8px)}
.drone-card:hover{transform:translateY(-4px); border-color:rgba(11,138,134,.5); background:rgba(255,255,255,.06)}
.drone-card .photo{aspect-ratio:1; position:relative; z-index:1; border-radius:18px; overflow:hidden; background:linear-gradient(135deg, #ffffff 0%, #f3faf9 100%); display:grid; place-items:center; box-shadow:inset 0 0 0 1px rgba(11,138,134,.18), 0 12px 28px rgba(0,0,0,.25); max-width:280px}
.drone-card .photo img{width:100%; height:100%; object-fit:contain; padding:14px; mix-blend-mode:multiply}
.drone-card .body{display:flex; flex-direction:column; gap:10px; position:relative; z-index:1}
.drone-card h3{font-size:22px; font-weight:800; letter-spacing:-0.025em; line-height:1.15; color:#fff}
.drone-card p{font-size:14px; color:rgba(232,236,231,.78); line-height:1.55}
.drone-card .specs{display:grid; grid-template-columns:auto 1fr; gap:6px 16px; padding-top:12px; border-top:1px dashed rgba(255,255,255,.18); font-size:13px; margin-top:4px}
.drone-card .specs .k{color:rgba(232,236,231,.5); font-size:11px; letter-spacing:.04em; text-transform:uppercase; font-weight:700}
.drone-card .specs .v{font-weight:700; color:#fff}
@media(max-width:1100px){.drones-grid{grid-template-columns:1fr; max-width:760px; margin-inline:auto}}
@media(max-width:620px){.drone-card{grid-template-columns:1fr; padding:20px; gap:16px}
  .drone-card .photo{max-width:280px; margin:0 auto}}

/* TEACHERS */
.teachers-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.teacher{background:var(--c-paper); border:1px solid var(--c-line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:transform .3s, box-shadow .3s}
.teacher:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.teacher .photo{aspect-ratio:4/5; position:relative; overflow:hidden; background:#dde5dd}
.teacher .photo img{width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .6s ease; image-rendering:-webkit-optimize-contrast; backface-visibility:hidden; transform:translateZ(0)}
.teacher:hover .photo img{transform:scale(1.04) translateZ(0)}
.teacher .photo-tag{position:absolute; top:14px; left:14px; padding:5px 10px; background:rgba(255,255,255,.95); backdrop-filter:blur(6px); font-size:10px; letter-spacing:.1em; text-transform:uppercase; font-weight:700; color:var(--c-brand-dark); border-radius:999px; z-index:1; box-shadow:var(--shadow-sm)}
.teacher.lead .photo-tag{background:var(--c-accent); color:var(--c-text)}
.teacher-body{padding:18px 20px 22px; display:flex; flex-direction:column; gap:8px; flex:1}
.teacher-name{font-size:15px; font-weight:700; letter-spacing:-0.01em; line-height:1.25}
.teacher-role{font-size:11px; color:var(--c-brand-strong); letter-spacing:.08em; text-transform:uppercase; font-weight:700}
.teacher-bio{font-size:12.5px; color:var(--c-text-muted); line-height:1.5; flex:1}
.teacher-city{margin-top:auto; padding-top:8px; font-size:12px; color:var(--c-text-muted); font-weight:600; display:inline-flex; align-items:center; gap:6px}
.teacher-city svg{width:13px; height:13px; color:var(--c-brand)}
@media(max-width:980px){.teachers-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.teachers-grid{grid-template-columns:1fr}}

/* CTA card in last teacher slot */
.teacher-cta{background:var(--c-brand-soft); border:1px solid var(--c-brand-soft); display:grid; place-items:center; text-align:center; padding:32px; gap:14px}
.teacher-cta .ic{width:54px; height:54px; border-radius:50%; background:var(--c-brand); color:#fff; display:grid; place-items:center}
.teacher-cta h4{font-weight:800; font-size:16px; color:var(--c-brand-dark); letter-spacing:-0.02em; line-height:1.2}
.teacher-cta a{padding:10px 16px; font-size:13px}

/* COUNTERS — embedded after teachers */
.counters-block{margin-top:64px; padding:44px 48px; background:var(--c-brand-dark); color:#fff; border-radius:var(--radius-xl); position:relative; overflow:hidden}
.counters-block::before{content:''; position:absolute; inset:0; background:radial-gradient(circle at 90% 20%, rgba(11,138,134,.35), transparent 50%), radial-gradient(circle at 10% 90%, rgba(253,173,58,.18), transparent 50%); pointer-events:none}
.counters-head{display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:18px; margin-bottom:32px; position:relative; z-index:1}
.counters-head .sec-eyebrow{background:rgba(255,255,255,.1); color:var(--c-accent)}
.counters-head h3{font-size:clamp(22px,2.6vw,30px); font-weight:800; letter-spacing:-0.025em; color:#fff; max-width:18ch; margin-top:8px}
.counters-head .timestamp{font-size:11px; color:rgba(255,255,255,.5); text-align:right; font-weight:600; letter-spacing:.04em}
.counters-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; z-index:1}
.counter-item{display:flex; flex-direction:column; gap:6px}
.counter-num{font-size:clamp(36px,4.6vw,60px); font-weight:800; letter-spacing:-0.04em; line-height:1; color:#fff}
.counter-num .num-val{font-variant-numeric:tabular-nums}
.counter-num .suf{color:var(--c-accent); margin-left:4px; letter-spacing:.02em}
.counter-lab{font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.55); font-weight:600}
@media(max-width:768px){.counters-grid{grid-template-columns:repeat(2,1fr)} .counters-block{padding:32px 24px}}

/* REVIEWS */
.reviews-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.review{background:var(--c-paper); border-radius:var(--radius-lg); padding:28px; display:flex; flex-direction:column; gap:14px; position:relative; border:1px solid var(--c-line); transition:transform .3s, border-color .25s, box-shadow .3s}
.review:hover{transform:translateY(-4px); border-color:var(--c-brand-soft); box-shadow:var(--shadow)}
.review-head{display:flex; align-items:center; gap:12px}
.review-avatar{width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg, var(--c-brand-soft), var(--c-brand)); display:grid; place-items:center; font-weight:800; color:#fff; font-size:18px; flex:none}
.review-meta{flex:1}
.review-name{font-weight:700; font-size:15px; line-height:1.2}
.review-city{font-size:12px; color:var(--c-text-muted); margin-top:2px}
.review-stars{color:var(--c-accent); font-size:14px; letter-spacing:1px}
.review p{font-size:14px; line-height:1.55; color:var(--c-text-2)}
@media(max-width:1100px){.reviews-grid{grid-template-columns:repeat(2,1fr)} .reviews-grid .review:nth-child(3){grid-column:1/-1; max-width:600px; margin-inline:auto}}
@media(max-width:600px){.reviews-grid{grid-template-columns:1fr} .reviews-grid .review:nth-child(3){grid-column:auto; max-width:none; margin:0}}

/* OFFICES */
.offices-section{background:var(--c-bg-soft)}
.offices-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.office{background:var(--c-paper); border:1px solid var(--c-line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:transform .3s, box-shadow .3s}
.office:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.office .photo{aspect-ratio:4/3; position:relative; overflow:hidden}
.office .photo img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease; image-rendering:-webkit-optimize-contrast; backface-visibility:hidden; transform:translateZ(0)}
.office:hover .photo img{transform:scale(1.06) translateZ(0)}
.office .photo::after{content:''; position:absolute; inset:0; background:linear-gradient(to bottom, transparent 50%, rgba(15,29,28,.4)); pointer-events:none}
.office .city-tag{position:absolute; top:14px; left:14px; padding:7px 14px; background:rgba(255,255,255,.95); backdrop-filter:blur(6px); font-size:12px; font-weight:700; color:var(--c-brand-dark); border-radius:999px; z-index:1; display:inline-flex; align-items:center; gap:6px; box-shadow:var(--shadow-sm)}
.office .city-tag svg{width:12px; height:12px; color:var(--c-brand)}
.office-body{padding:20px 22px 22px; display:flex; flex-direction:column; gap:8px; flex:1}
.office-city{font-size:22px; font-weight:800; letter-spacing:-0.025em; line-height:1.1; margin-bottom:2px}
.office-legal{display:flex; flex-direction:column; gap:2px; padding-bottom:10px; border-bottom:1px dashed var(--c-line)}
.office-ano{font-size:13px; font-weight:700; color:var(--c-text); letter-spacing:-0.005em}
.office-id{font-size:11px; color:var(--c-text-muted); font-family:'JetBrains Mono', ui-monospace, monospace; letter-spacing:.01em; word-break:break-word; line-height:1.4}
.office-addr{font-size:13.5px; color:var(--c-text-2); line-height:1.5; padding-top:8px; display:flex; align-items:flex-start; gap:6px}
.office-addr svg{flex:none; color:var(--c-brand); margin-top:2px}
.office-phones{display:flex; flex-direction:column; gap:2px; padding-top:6px}
.office-phones a{font-size:14px; font-weight:700; color:var(--c-brand-dark); display:flex; align-items:center; gap:6px; transition:color .15s}
.office-phones a:hover{color:var(--c-brand)}
.office-phones a svg{color:var(--c-brand); flex:none}
.office-phones .pn-sub{font-size:11.5px; color:var(--c-text-muted); font-weight:600; margin-left:18px}
.office-site{font-size:12.5px; padding-top:6px; color:var(--c-brand-strong); font-weight:600; display:inline-flex; align-items:center; gap:5px; transition:color .15s}
.office-site:hover{color:var(--c-brand-dark); text-decoration:underline}
.office-site svg{flex:none; opacity:.7}
.office-cta{margin-top:auto; padding:11px 16px; background:var(--c-brand); color:#fff; border-radius:10px; font-size:13.5px; font-weight:700; display:inline-flex; align-items:center; justify-content:space-between; gap:8px; transition:background .2s, transform .2s; box-shadow:var(--shadow-sm)}
.office-cta:hover{background:var(--c-brand-2); transform:translateY(-2px); box-shadow:var(--shadow-green)}
@media(max-width:1100px){.offices-grid{grid-template-columns:repeat(2,1fr)} .offices-grid .office:nth-child(3){grid-column:1/-1; max-width:560px; margin-inline:auto}}
@media(max-width:600px){.offices-grid{grid-template-columns:1fr} .offices-grid .office:nth-child(3){grid-column:auto; max-width:none; margin:0}}

/* FAQ */
.faq-grid{display:grid; grid-template-columns:.7fr 1.3fr; gap:48px; align-items:start}
.faq-aside h2{font-size:clamp(26px,3vw,36px); font-weight:800; letter-spacing:-0.025em; line-height:1.1; margin-bottom:14px}
.faq-aside h2 em{font-style:normal; color:var(--c-brand)}
.faq-aside > p{font-size:15px; color:var(--c-text-muted); line-height:1.6}
.faq-contact{margin-top:24px; padding:24px; background:var(--c-brand-soft); border-radius:var(--radius-lg)}
.faq-contact .k{font-size:11px; color:var(--c-brand-strong); letter-spacing:.12em; text-transform:uppercase; font-weight:700; margin-bottom:6px}
.faq-contact .v{font-size:20px; font-weight:800; color:var(--c-brand-dark); letter-spacing:-0.02em; margin-bottom:14px}
.faq-contact .v.sm{font-size:14px}
.faq-list{display:flex; flex-direction:column; gap:10px}
.faq-item{background:var(--c-paper); border:1px solid var(--c-line); border-radius:var(--radius); overflow:hidden; transition:border-color .2s, box-shadow .2s}
.faq-item:hover{border-color:var(--c-brand-soft); box-shadow:var(--shadow-sm)}
.faq-item[open]{border-color:var(--c-brand); box-shadow:var(--shadow)}
.faq-item summary{padding:20px 22px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q{font-size:16px; font-weight:600; letter-spacing:-0.01em; line-height:1.35; flex:1}
.faq-toggle{width:32px; height:32px; flex:none; background:var(--c-brand-soft); color:var(--c-brand); border-radius:50%; display:grid; place-items:center; font-size:20px; line-height:1; transition:transform .25s, background .25s, color .25s; font-weight:700}
.faq-item[open] .faq-toggle{background:var(--c-brand); color:#fff; transform:rotate(45deg)}
.faq-toggle::before{content:'+'}
.faq-ans{padding:0 22px 22px; font-size:14px; color:var(--c-text-muted); line-height:1.65}
@media(max-width:1100px){.faq-grid{grid-template-columns:1fr; gap:32px} .faq-aside{max-width:680px}}
@media(max-width:520px){.faq-grid{gap:20px} .faq-item summary{padding:16px 18px} .faq-q{font-size:15px} .faq-ans{padding:0 18px 18px}}

/* MAIN FORM */
.form-section{padding:var(--section-pad) 0}
.form-shell{background:var(--c-brand-dark); color:#fff; border-radius:var(--radius-xl); padding:56px; display:grid; grid-template-columns:1.05fr 1fr; gap:60px; position:relative; overflow:hidden}
.form-shell::before{content:''; position:absolute; top:-80px; right:-80px; width:340px; height:340px; background:radial-gradient(circle, rgba(11,138,134,.5), transparent 70%); border-radius:50%; pointer-events:none}
.form-shell::after{content:''; position:absolute; bottom:-80px; left:-100px; width:300px; height:300px; background:radial-gradient(circle, rgba(253,173,58,.18), transparent 70%); border-radius:50%; pointer-events:none}
.form-intro{position:relative; z-index:1}
.form-intro .sec-eyebrow{background:rgba(255,255,255,.1); color:var(--c-accent)}
.form-intro h2{font-size:clamp(28px,3.4vw,44px); font-weight:800; letter-spacing:-0.03em; line-height:1.06; margin-bottom:18px}
.form-intro h2 em{font-style:normal; color:var(--c-accent)}
.form-intro > p{font-size:15px; color:rgba(255,255,255,.75); line-height:1.55; max-width:46ch}
.form-bullets{display:flex; flex-direction:column; gap:14px; margin-top:24px}
.form-bullet{display:grid; grid-template-columns:32px 1fr; gap:14px; align-items:start; padding:14px 16px; background:rgba(255,255,255,.06); border-radius:12px; transition:background .2s, transform .2s}
.form-bullet:hover{background:rgba(253,173,58,.14); transform:translateX(4px)}
.form-bullet .ck{width:28px; height:28px; background:var(--c-accent); border-radius:50%; display:grid; place-items:center; color:var(--c-text); flex:none}
.form-bullet .ck svg{width:14px; height:14px}
.form-bullet span{font-size:14px; line-height:1.45; color:rgba(255,255,255,.92)}
.form-bullet b{color:#fff; font-weight:700}

.lead-form{background:var(--c-paper); color:var(--c-text); padding:32px; border-radius:20px; display:flex; flex-direction:column; gap:14px; position:relative; z-index:1; box-shadow:0 30px 60px -20px rgba(0,0,0,.45)}
.lead-form h4{font-size:18px; font-weight:700; letter-spacing:-0.015em; margin-bottom:4px}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-size:12px; color:#4a5856; font-weight:600}
.field input, .field select{background:var(--c-bg-soft); border:1.5px solid var(--c-line); padding:13px 16px; border-radius:10px; font-size:14px; transition:border-color .2s, background .2s; font-weight:500; color:var(--c-text)}
.field input:focus, .field select:focus{outline:none; border-color:var(--c-brand); background:var(--c-bg)}
.field .err{font-size:12px; color:#c53030; min-height:14px; font-weight:600}
.field input[aria-invalid="true"], .field select[aria-invalid="true"]{border-color:#c53030}
.agree{display:grid; grid-template-columns:18px 1fr; gap:10px; font-size:12.5px; color:var(--c-text-muted); line-height:1.5; align-items:start}
.agree input{margin-top:2px; accent-color:var(--c-brand); width:16px; height:16px}
.agree a{color:var(--c-brand); text-decoration:underline}
.honey{position:absolute; left:-9999px; visibility:hidden}
.lead-form button[type="submit"]{padding:16px 22px; background:var(--c-brand); color:#fff; border-radius:10px; font-size:14px; font-weight:700; display:inline-flex; align-items:center; justify-content:center; gap:10px; transition:background .2s, transform .2s; box-shadow:var(--shadow-green); margin-top:4px}
.lead-form button[type="submit"]:hover{background:var(--c-brand-2); transform:translateY(-2px)}
.legal{font-size:11px; color:var(--c-text-muted); line-height:1.5}
.legal a{color:var(--c-brand); text-decoration:underline}
@media(max-width:980px){.form-shell{grid-template-columns:1fr; padding:32px; gap:32px}}
@media(max-width:560px){.form-shell{padding:24px}}

/* FINAL CTA — legacy v1 block removed; authoritative styles at line ~1280 */

/* FOOTER — legacy v7 block removed (used .foot-grid/.foot-social/.foot-col h5 — cascade collision with newer .foot-row/.foot-bot rules at 1595+). */
footer.site{background:var(--c-brand-dark); color:rgba(255,255,255,.85); padding:56px 0 28px}

/* MOBILE STICKY BAR */
.mob-bar{position:fixed; bottom:0; left:0; right:0; z-index:55; background:var(--c-paper); border-top:1px solid var(--c-line); padding:10px 16px; display:none; gap:12px; align-items:center; box-shadow:0 -10px 30px -10px rgba(0,0,0,.15); transform:translateY(100%); transition:transform .3s}
.mob-bar.show{transform:translateY(0)}
.mob-bar .info{flex:1; min-width:0}
.mob-bar .info .t{font-size:13px; font-weight:700; line-height:1.2; margin-bottom:2px}
.mob-bar .info .s{font-size:11px; color:var(--c-text-muted); font-weight:600}
.mob-bar a{padding:12px 18px; background:var(--c-brand); color:#fff; border-radius:10px; font-size:13px; font-weight:700; box-shadow:var(--shadow-green)}
@media(max-width:1024px){.mob-bar{display:flex}}

/* COOKIE BANNER (granular consent) */
.cookie-bar{position:fixed; left:16px; bottom:16px; z-index:85; max-width:420px; background:var(--c-paper); border:1px solid var(--c-line); border-radius:var(--radius-lg); padding:18px 20px; box-shadow:var(--shadow-lg); display:none; flex-direction:column; gap:14px; font-size:13px; line-height:1.5; color:var(--c-text-2)}
.cookie-bar.show{display:flex}
.cookie-bar strong{color:var(--c-text); font-weight:700; font-size:13px}
.cookie-bar a{color:var(--c-brand); text-decoration:underline}
.cookie-bar .cb-text{font-size:13px}
.cookie-bar .cb-categories{display:flex; flex-direction:column; gap:10px; padding:10px 0 4px; border-top:1px dashed var(--c-line)}
.cookie-bar .cb-cat{display:grid; grid-template-columns:18px 1fr; gap:10px; font-size:12.5px; cursor:pointer; align-items:start; line-height:1.4}
.cookie-bar .cb-cat input{margin-top:2px; accent-color:var(--c-brand); width:16px; height:16px}
.cookie-bar .cb-cat input:disabled{opacity:.5; cursor:not-allowed}
.cookie-bar .cb-actions{display:flex; gap:8px; flex-wrap:wrap}
.cookie-bar .cb-actions button{padding:9px 14px; border-radius:8px; font-size:12px; font-weight:700; transition:background .2s, transform .2s, border-color .2s; cursor:pointer; border:1px solid transparent}
.cookie-bar .cb-accept{background:var(--c-brand); color:#fff}
.cookie-bar .cb-accept:hover{background:var(--c-brand-2); transform:translateY(-1px)}
.cookie-bar .cb-customize{background:transparent; color:var(--c-text-2); border-color:var(--c-line)}
.cookie-bar .cb-customize:hover{border-color:var(--c-brand); color:var(--c-brand)}
.cookie-bar .cb-reject{background:transparent; color:var(--c-text-muted); border-color:transparent; text-decoration:underline; padding:9px 8px}
.cookie-bar .cb-reject:hover{color:var(--c-text)}
.cookie-bar .cb-save{background:var(--c-brand); color:#fff}
.cookie-bar .cb-save:hover{background:var(--c-brand-2); transform:translateY(-1px)}
@media(max-width:768px){.cookie-bar{left:12px; right:12px; max-width:none; bottom:84px}}

/* TOAST */
.toast{position:fixed; bottom:120px; right:24px; z-index:90; background:var(--c-text); color:var(--c-bg); padding:16px 22px; border-radius:14px; font-size:13.5px; font-weight:600; max-width:340px; opacity:0; transform:translateY(20px); transition:all .3s; pointer-events:none; box-shadow:var(--shadow-lg)}
.toast.show{opacity:1; transform:translateY(0)}
.toast.error{background:#c53030; color:#fff}
.toast.success{background:var(--c-brand); color:#fff}

/* ============================================================
   RESPONSIVE FIXES — small-screen overrides
   ============================================================ */
@media(max-width:520px){
  /* hero card padding tighter on phones */
  .hero-text{padding:28px 22px 24px; gap:18px}
  .hero-title{font-size:clamp(32px, 7vw, 44px)}
  .hero-ctas{flex-direction:column; gap:10px}
  .hero-ctas .btn{width:100%; justify-content:center; padding:16px 22px}
  /* radial decoration circles shrink */
  .drones-section::before{width:240px; height:240px; top:-60px; right:-50px}
  .drones-section::after{width:200px; height:200px; bottom:-80px; left:-60px}
  .form-shell::before{width:200px; height:200px; top:-40px; right:-40px}
  .form-shell::after{width:180px; height:180px; bottom:-40px; left:-60px}
  .final-shell::before{width:200px; height:200px; top:-40px; right:-40px}
  .final-shell::after{width:140px; height:140px; bottom:-40px}
  .counters-block::before{background:radial-gradient(circle at 70% 20%, rgba(11,138,134,.25), transparent 60%)}
  /* form fields touch-friendly */
  .lead-form{padding:24px 20px; gap:12px}
  .form-shell{padding:28px 20px; gap:28px}
  .field input, .field select{padding:14px 14px; min-height:48px}
  .mini-form{padding:22px 18px}
  .mini-form .field input{padding:14px 14px; min-height:48px}
  /* trust/aud cards tighter padding */
  .trust-card{padding:24px 20px; gap:12px}
  .trust-card .ico{width:48px; height:48px}
  .aud-body{padding:16px}
  /* counters-block padding tighter */
  .counters-block{padding:28px 20px; margin-top:40px}
  .counters-grid{gap:18px}
  /* section padding reduced on phones */
  :root{--section-pad: 56px}
}

/* landscape phone — squashed height */
@media(max-width:900px) and (max-height:500px){
  .hero-card{min-height:auto}
  .hero-photo{aspect-ratio:21/9}
  .inline-form{min-height:auto}
}

/* tablet improvements */
@media(min-width:769px) and (max-width:1100px){
  .head-row{gap:16px}
  .brand-logo{height:42px}
  .head-phone .sub{display:none}
  .head-phone .num{font-size:14px}
}

/* wide screens — slightly larger padding */
@media(min-width:1600px){
  .wrap{padding:0 48px}
}

/* mob-bar pushes cookie banner up */
.cookie-bar{transition:bottom .3s, transform .3s, opacity .3s}
@media(max-width:980px){
  .cookie-bar{bottom:84px}
}
@media(max-width:560px){
  .cookie-bar{bottom:78px; padding:14px 16px; font-size:12.5px}
}

/* ============================================================
   BROWSER COMPAT FIXES
   ============================================================ */

/* iOS Safari zoom-on-focus prevention (font-size < 16px triggers autozoom) */
@media(max-width:768px){
  input, select, textarea{font-size:16px !important}
  .field input, .field select, .mini-form .field input{font-size:16px}
}

/* backdrop-filter fallback for old Android Chrome / iOS Safari < 13 */
@supports not (backdrop-filter: blur(1px)){
  header.site{background:var(--c-bg) !important}
  .mini-form{background:rgba(15,29,28,.4) !important}
  .drone-card{background:rgba(255,255,255,.08) !important}
  .cookie-bar{background:var(--c-paper) !important}
  .city-tag{background:#fff !important}
  .aud-card__stamp{background:#fff !important}
}

/* Reveal */
.js-reveal-ready .reveal{opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important}
  .reveal{opacity:1; transform:none}
}
/* ========================================================
   v5 SECTION ADDITIONS — Hero + Programs / Audience+Teachers / Content / Form+Bottom
   ======================================================== */

/* === BAS-Krasnodar_-_Hero_and_Programs__CSS.css === */
/* group: BAS-Krasnodar — Hero + Programs */

/* === Hero accent eyebrow (orange) === */
.hero-eyebrow.hero-eyebrow--accent{
  background:rgba(253,173,58,.14);
  color:var(--c-accent);
}
.hero-eyebrow.hero-eyebrow--accent .dot{background:var(--c-accent)}

/* === Hero micro-features (3 small cards under CTAs) === */
.hero-features{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:22px;
}
.hero-feat{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  background:#fff;
  border:1px solid rgba(11,138,134,.14);
  border-radius:14px;
  box-shadow:0 2px 8px -6px rgba(15,29,28,.18);
}
.hero-feat__ico{
  flex:0 0 36px;
  width:36px; height:36px;
  display:grid; place-items:center;
  border-radius:10px;
  background:var(--c-brand-soft);
  color:var(--c-brand);
}
.hero-feat__text{
  font-size:13px;
  line-height:1.3;
  font-weight:600;
  color:var(--c-dark);
}
@media (max-width:900px){
  .hero-features{grid-template-columns:1fr; gap:8px}
  .hero-feat{padding:10px 12px}
}

/* === Hero program teasers (2 cards under hero-card) === */
.hero-teasers{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.hero-teaser{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  padding:18px 22px;
  background:#fff;
  border:1px solid rgba(11,138,134,.14);
  border-radius:var(--radius-lg, 18px);
  text-decoration:none;
  color:var(--c-dark);
  box-shadow:0 4px 16px -10px rgba(15,29,28,.18);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.hero-teaser:hover{
  transform:translateY(-2px);
  border-color:var(--c-brand);
  box-shadow:0 10px 24px -12px rgba(11,138,134,.32);
}
.hero-teaser__num{
  font-family:var(--font-display, Manrope), Manrope, sans-serif;
  font-size:34px;
  font-weight:800;
  line-height:1;
  color:var(--c-brand);
  letter-spacing:-0.02em;
}
.hero-teaser__title{
  margin:0 0 4px;
  font-size:16px;
  font-weight:700;
  line-height:1.25;
  color:var(--c-dark);
}
.hero-teaser__meta{
  margin:0;
  font-size:14px;
  color:#5a6a68;
}
.hero-teaser__meta b{color:var(--c-brand); font-weight:800}
.hero-teaser__arr{
  display:grid; place-items:center;
  width:36px; height:36px;
  border-radius:50%;
  background:var(--c-brand-soft);
  color:var(--c-brand);
  transition:background .18s ease, color .18s ease;
}
.hero-teaser:hover .hero-teaser__arr{background:var(--c-brand); color:#fff}
@media (max-width:900px){
  .hero-teasers{grid-template-columns:1fr}
  .hero-teaser{padding:14px 16px; gap:12px}
  .hero-teaser__num{font-size:28px}
}

/* === Programs (minimal mockup-style) === */
.prog-card.prog-card--minimal{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:32px 28px 28px;
  background:#fff;
  border:1px solid rgba(11,138,134,.14);
  border-radius:var(--radius-xl, 22px);
  box-shadow:0 6px 24px -16px rgba(15,29,28,.2);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.prog-card.prog-card--minimal:hover{
  transform:translateY(-3px);
  border-color:var(--c-brand);
  box-shadow:0 14px 32px -16px rgba(11,138,134,.28);
}
.prog-card.prog-card--minimal .prog-num{
  position:absolute;
  top:20px; right:24px;
  font-family:var(--font-display, Manrope), Manrope, sans-serif;
  font-size:42px;
  font-weight:800;
  line-height:1;
  color:rgba(11,138,134,.14);
  letter-spacing:-0.03em;
}
.prog-card.prog-card--minimal .prog-ico{
  width:60px; height:60px;
  display:grid; place-items:center;
  border-radius:16px;
  background:var(--c-brand-soft);
  color:var(--c-brand);
}
.prog-card.prog-card--minimal .prog-name{
  margin:0;
  font-size:22px;
  font-weight:800;
  line-height:1.2;
  letter-spacing:-0.01em;
  color:var(--c-dark);
}
.prog-card.prog-card--minimal .prog-hours{
  font-size:15px;
  color:#5a6a68;
  font-weight:500;
}
.prog-card.prog-card--minimal .prog-hours b{
  display:inline-block;
  margin-right:4px;
  padding:2px 10px;
  background:var(--c-brand-soft);
  color:var(--c-brand);
  border-radius:8px;
  font-size:18px;
  font-weight:800;
  letter-spacing:-0.01em;
}
.prog-card.prog-card--minimal .prog-includes{
  list-style:none;
  margin:4px 0 8px;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.prog-card.prog-card--minimal .prog-includes li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  line-height:1.45;
  color:var(--c-dark);
}
.prog-card.prog-card--minimal .prog-includes .ck{
  flex:0 0 20px;
  width:20px; height:20px;
  display:grid; place-items:center;
  border-radius:50%;
  background:var(--c-brand-soft);
  color:var(--c-brand);
  margin-top:1px;
}
.prog-card.prog-card--minimal .prog-cta{
  align-self:flex-start;
  margin-top:auto;
}
@media (max-width:900px){
  .prog-card.prog-card--minimal{padding:24px 20px}
  .prog-card.prog-card--minimal .prog-name{font-size:19px}
  .prog-card.prog-card--minimal .prog-num{font-size:34px; top:16px; right:18px}
}

/* === BAS-Krasnodar_Audience_Teachers__CSS.css === */
/* group: BAS-Krasnodar Audience Teachers */

.teachers-grid.teachers-grid--3{grid-template-columns:repeat(3,1fr)} @media(max-width:980px){.teachers-grid.teachers-grid--3{grid-template-columns:repeat(2,1fr)}} @media(max-width:520px){.teachers-grid.teachers-grid--3{grid-template-columns:1fr}} .teacher-bullets{list-style:none;margin:6px 0 4px;padding:0;display:flex;flex-direction:column;gap:8px} .teacher-bullets li{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;line-height:1.4;color:var(--c-text-muted)} .teacher-bullets li svg{width:14px;height:14px;flex-shrink:0;color:var(--c-brand);margin-top:2px} .teacher-bullets li span{font-weight:500} .teacher.lead .photo-tag{background:var(--c-accent);color:var(--c-text);font-weight:700} @media(max-width:520px){.teacher-bullets{gap:6px}.teacher-bullets li{font-size:12px}}
/* === BAS-Krasnodar_-_Content_sections__Why_BAS___Format___How_to_choose___CSS.css === */
/* group: BAS-Krasnodar — Content sections (Why BAS / Format / How to choose) */

/* ======================================================================
   WHY BAS — актуальность направления
   ====================================================================== */
.why-section{background:linear-gradient(180deg, var(--c-bg) 0%, var(--c-brand-tint) 100%)}
.why-grid{display:grid; grid-template-columns:1.05fr 1fr; gap:48px; align-items:center; margin-top:48px}
.why-text p{font-size:17px; line-height:1.65; color:var(--c-text-2); margin-bottom:16px}
.why-text p:last-child{margin-bottom:0}
.why-text p b{color:var(--c-brand-dark); font-weight:700}
.industries-row{display:flex; flex-wrap:wrap; gap:10px}
.industries-row .industry-chip{padding:10px 16px; font-size:13.5px; background:#fff; border:1px solid var(--c-line); box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, color .25s ease}
.industries-row .industry-chip:hover{transform:translateY(-3px); border-color:var(--c-brand); color:var(--c-brand-dark); box-shadow:var(--shadow)}
.industries-row .industry-chip svg{width:16px; height:16px; color:var(--c-brand)}

@media (max-width:900px){
  .why-grid{grid-template-columns:1fr; gap:28px; margin-top:32px}
  .industries-row{justify-content:flex-start}
}
@media (max-width:520px){
  .why-text p{font-size:16px}
  .industries-row .industry-chip{padding:8px 13px; font-size:12.5px}
}

/* ======================================================================
   FORMAT — info-card 4 rows
   ====================================================================== */
.format-section{background:var(--c-bg-soft)}
.format-info-card{max-width:880px; margin:48px auto 0; background:var(--c-paper); border:1px solid var(--c-line); border-radius:var(--radius-lg); padding:8px 8px; box-shadow:var(--shadow); overflow:hidden}
.info-row{display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; padding:24px 24px; border-bottom:1px solid var(--c-line)}
.info-row:last-child{border-bottom:none}
.info-row__ic{width:48px; height:48px; flex:none; border-radius:14px; background:var(--c-brand-soft); display:grid; place-items:center; color:var(--c-brand); transition:background .25s ease, color .25s ease, transform .25s ease}
.info-row__ic svg{width:24px; height:24px}
.info-row:hover .info-row__ic{background:var(--c-brand); color:#fff; transform:scale(1.05)}
.info-row__body{min-width:0}
.info-row__k{font-size:12px; letter-spacing:.08em; text-transform:uppercase; font-weight:700; color:var(--c-brand); margin-bottom:6px}
.info-row__v{font-size:16.5px; line-height:1.5; color:var(--c-text); font-weight:500}
.info-row__v b{color:var(--c-brand-dark); font-weight:700}
.info-row__sep{color:var(--c-line-2); margin:0 4px}
.info-row__sub{display:block; margin-top:4px; font-size:13.5px; color:var(--c-text-muted); font-weight:400}

@media (max-width:640px){
  .format-info-card{margin-top:32px; border-radius:var(--radius)}
  .info-row{grid-template-columns:1fr; gap:12px; padding:20px 18px}
  .info-row__ic{width:40px; height:40px}
  .info-row__ic svg{width:20px; height:20px}
  .info-row__v{font-size:15.5px}
}

/* ======================================================================
   HOW TO CHOOSE — 3 cards + CTA
   ====================================================================== */
.choose-section{background:var(--c-bg)}
.choose-section .sec-sub{margin-top:14px; font-size:16px; color:var(--c-text-muted); max-width:640px}
.choose-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; margin-top:48px}
.choose-card{position:relative; background:var(--c-paper); border:1px solid var(--c-line); border-radius:var(--radius-lg); padding:32px 28px; display:flex; flex-direction:column; gap:18px; transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease, border-color .3s ease}
.choose-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--c-brand-soft)}
.choose-ic{width:56px; height:56px; border-radius:16px; background:var(--c-brand-soft); display:grid; place-items:center; color:var(--c-brand); transition:background .3s ease, color .3s ease, transform .3s ease}
.choose-ic svg{width:28px; height:28px}
.choose-card:hover .choose-ic{background:var(--c-brand); color:#fff; transform:rotate(-4deg) scale(1.06)}
.choose-body{display:flex; flex-direction:column; gap:12px; flex:1}
.choose-tag{display:inline-flex; align-self:flex-start; padding:5px 12px; font-size:11px; letter-spacing:.1em; text-transform:uppercase; font-weight:700; color:var(--c-brand); background:var(--c-brand-soft); border-radius:999px}
.choose-card h3{font-size:19px; line-height:1.3; font-weight:700; color:var(--c-text); letter-spacing:-0.01em}
.choose-card h3 em{font-style:normal; color:var(--c-brand)}
.choose-card p{font-size:15px; line-height:1.6; color:var(--c-text-2); flex:1}
.choose-card p b{color:var(--c-brand-dark); font-weight:700}
.choose-link{display:inline-flex; align-items:center; gap:8px; align-self:flex-start; font-size:14px; font-weight:700; color:var(--c-brand); text-decoration:none; padding-top:6px; transition:color .2s ease, gap .2s ease}
.choose-link:hover{color:var(--c-brand-dark); gap:12px}
.choose-link svg{transition:transform .2s ease}

.choose-card--accent{background:linear-gradient(160deg, var(--c-brand-dark) 0%, var(--c-brand-strong) 100%); border-color:transparent; color:#fff}
.choose-card--accent .choose-ic{background:rgba(253,173,58,.15); color:var(--c-accent)}
.choose-card--accent:hover .choose-ic{background:var(--c-accent); color:var(--c-brand-dark)}
.choose-card--accent .choose-tag{background:rgba(253,173,58,.18); color:var(--c-accent)}
.choose-card--accent h3{color:#fff}
.choose-card--accent h3 em{color:var(--c-accent)}
.choose-card--accent p{color:rgba(255,255,255,.82)}
.choose-card--accent p b{color:#fff}
.choose-card--accent .choose-link{color:var(--c-accent)}
.choose-card--accent .choose-link:hover{color:#fff}

.choose-cta{margin-top:40px; display:flex; flex-direction:column; align-items:center; gap:12px; text-align:center}
.choose-cta__note{font-size:13.5px; color:var(--c-text-muted)}

@media (max-width:980px){
  .choose-grid{grid-template-columns:1fr 1fr; gap:20px}
  .choose-card--accent{grid-column:span 2}
}
@media (max-width:640px){
  .choose-grid{grid-template-columns:1fr; margin-top:32px; gap:16px}
  .choose-card--accent{grid-column:auto}
  .choose-card{padding:26px 22px}
  .choose-card h3{font-size:17.5px}
  .choose-card p{font-size:14.5px}
  .choose-cta{margin-top:28px}
}
/* === form_faq_contacts_bottom_features__CSS.css === */
/* group: form_faq_contacts_bottom_features */

/* ============ FORM-SECTION (rewrite) ============ */
.form-section{
  padding:clamp(64px,8vw,120px) 0;
  background:linear-gradient(180deg,#fff 0%,#f4faf9 100%);
  position:relative;
}
.form-section .wrap{max-width:1240px;margin:0 auto;padding:0 24px;}

/* TOP: form + photo */
.form-grid{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:48px;
  align-items:stretch;
}
@media (max-width:960px){.form-grid{grid-template-columns:1fr;gap:32px;}}

/* LEFT: form-shell */
.form-shell{
  background:#fff;
  border:1px solid rgba(11,138,134,.10);
  border-radius:24px;
  padding:clamp(28px,3.5vw,44px);
  box-shadow:0 24px 60px -32px rgba(0,61,56,.18),0 2px 8px rgba(0,61,56,.04);
  display:flex;flex-direction:column;gap:24px;
}
.form-intro .sec-eyebrow{color:#086663;}
.form-intro h2{margin:10px 0 12px;}
.form-intro h2 .acc{color:#FDAD3A;font-style:normal;font-size:.82em;font-weight:700;letter-spacing:-.005em;display:inline-block;line-height:1.2;}
.form-lead{color:#4b5d5b;margin:0;font-size:16px;line-height:1.55;max-width:46ch;}

/* form fields */
.lead-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px;position:relative;}
.lead-form .field{display:flex;flex-direction:column;gap:6px;}
.lead-form .field:nth-child(1),
.lead-form .field:nth-child(2){grid-column:span 1;}
.lead-form .field:nth-child(3),
.lead-form .field:nth-child(4){grid-column:span 1;}
@media (max-width:560px){.lead-form{grid-template-columns:1fr;} .lead-form .field{grid-column:1/-1;}}

.lead-form label{font-size:13px;font-weight:600;color:#003D38;letter-spacing:.01em;}
.lead-form .req{color:#FDAD3A;}
.lead-form input[type=text],
.lead-form input[type=tel],
.lead-form input[type=email]{
  width:100%;
  padding:13px 14px;
  border:1.5px solid #e3ecea;
  background:#fafdfc;
  border-radius:12px;
  font:inherit;font-size:15px;color:#003D38;
  transition:border-color .18s, box-shadow .18s, background .18s;
}
.lead-form input::placeholder{color:#9aaaa8;}
.lead-form input:focus{
  outline:none;border-color:#0B8A86;background:#fff;
  box-shadow:0 0 0 4px rgba(11,138,134,.12);
}
.lead-form input:invalid:not(:placeholder-shown){border-color:#d97757;}

/* agreement */
.form-agree{
  grid-column:1/-1;
  display:grid;grid-template-columns:22px 1fr;gap:10px;align-items:flex-start;
  font-size:12.5px;line-height:1.5;color:#4b5d5b;cursor:pointer;
  margin-top:4px;
}
.form-agree input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;}
.form-agree .agree-box{
  width:20px;height:20px;border:1.5px solid #c6d4d2;border-radius:6px;background:#fff;
  position:relative;flex:none;transition:all .18s;margin-top:2px;
}
.form-agree input:checked + .agree-box{background:#0B8A86;border-color:#0B8A86;}
.form-agree input:checked + .agree-box::after{
  content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
.form-agree input:focus-visible + .agree-box{box-shadow:0 0 0 4px rgba(11,138,134,.18);}
.form-agree .consent-text a{color:#0B8A86;text-decoration:underline;text-underline-offset:2px;}

.captcha-slot{grid-column:1/-1;min-height:78px;}
.server-msg{grid-column:1/-1;font-size:14px;color:#0B8A86;min-height:1em;}
.server-msg.is-error{color:#d97757;}

.btn-submit{
  grid-column:1/-1;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 28px;border-radius:14px;font-size:16px;font-weight:700;
  background:linear-gradient(135deg,#FDAD3A 0%,#f59e0b 100%);
  color:#003D38;border:none;cursor:pointer;
  box-shadow:0 12px 30px -10px rgba(253,173,58,.55);
  transition:transform .18s, box-shadow .18s, filter .18s;
}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 18px 38px -12px rgba(253,173,58,.6);filter:brightness(1.03);}
.btn-submit:active{transform:translateY(0);}
.btn-submit svg{transition:transform .2s;}
.btn-submit:hover svg{transform:translateX(3px);}

/* trust-bullets */
.trust-bullets{
  list-style:none;margin:8px 0 0;padding:18px 0 0;
  border-top:1px dashed rgba(11,138,134,.18);
  display:grid;gap:14px;
}
.trust-bullets li{display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:flex-start;}
.trust-bullets .tb-icon{
  width:36px;height:36px;border-radius:10px;
  background:rgba(11,138,134,.10);color:#0B8A86;
  display:inline-flex;align-items:center;justify-content:center;flex:none;
}
.trust-bullets strong{display:block;color:#003D38;font-size:14.5px;font-weight:700;margin-bottom:2px;}
.trust-bullets span{display:block;color:#5b6e6c;font-size:13px;line-height:1.45;}

/* RIGHT: form-aside / photo + overlay */
.form-aside{position:relative;}
.form-photo{
  position:relative;height:100%;min-height:560px;margin:0;
  border-radius:24px;overflow:hidden;
  box-shadow:0 24px 60px -28px rgba(0,61,56,.32);
}
.form-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.form-photo-grad{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,61,56,0) 40%,rgba(0,61,56,.85) 100%);
}
.overlay-card{
  position:absolute;left:24px;right:24px;bottom:24px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px);
  border:1px solid rgba(11,138,134,.18);
  border-radius:18px;
  padding:20px 22px;
  display:grid;grid-template-columns:52px 1fr;gap:16px;align-items:center;
  box-shadow:0 16px 40px -16px rgba(0,61,56,.35);
}
.overlay-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,#FDAD3A,#f59e0b);
  color:#003D38;display:inline-flex;align-items:center;justify-content:center;
  flex:none;box-shadow:0 8px 20px -6px rgba(253,173,58,.5);
}
.overlay-text h3{margin:0 0 4px;font-size:18px;line-height:1.3;color:#003D38;}
.overlay-text h3 .acc{color:#0B8A86;font-style:normal;}
.overlay-text p{margin:0;font-size:13.5px;color:#4b5d5b;line-height:1.45;}
@media (max-width:960px){.form-photo{min-height:380px;}}
@media (max-width:560px){
  .form-photo{min-height:320px;}
  .overlay-card{grid-template-columns:44px 1fr;padding:16px;left:14px;right:14px;bottom:14px;}
  .overlay-icon{width:44px;height:44px;}
  .overlay-text h3{font-size:16px;}
}

/* UNDER: FAQ + contact-card */
.form-info-grid{
  margin-top:clamp(48px,6vw,72px);
  display:grid;grid-template-columns:6fr 4fr;gap:36px;align-items:start;
}
@media (max-width:960px){.form-info-grid{grid-template-columns:1fr;gap:28px;}}
.info-title{
  font-size:clamp(22px,2.2vw,28px);
  color:#003D38;margin:0 0 18px;font-weight:800;letter-spacing:-.01em;
}

/* FAQ list (uses existing .faq-item but ensures spacing) */
.faq-list{display:flex;flex-direction:column;gap:12px;}
.faq-list > .info-title{margin-bottom:8px;}
.faq-list .faq-item{
  background:#fff;border:1px solid rgba(11,138,134,.10);
  border-radius:14px;padding:0;overflow:hidden;
  transition:box-shadow .2s, border-color .2s;
}
.faq-list .faq-item[open]{
  border-color:rgba(11,138,134,.30);
  box-shadow:0 12px 30px -16px rgba(0,61,56,.18);
}
.faq-list .faq-item summary{
  list-style:none;cursor:pointer;
  padding:18px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-weight:600;color:#003D38;font-size:15.5px;
}
.faq-list .faq-item summary::-webkit-details-marker{display:none;}
.faq-list .faq-chev{
  width:32px;height:32px;border-radius:50%;
  background:rgba(11,138,134,.10);color:#0B8A86;
  display:inline-flex;align-items:center;justify-content:center;flex:none;
  transition:transform .25s, background .2s;
}
.faq-list .faq-item[open] .faq-chev{transform:rotate(180deg);background:#0B8A86;color:#fff;}
.faq-list .faq-body{padding:0 20px 18px;color:#4b5d5b;font-size:14.5px;line-height:1.6;}
.faq-list .faq-body p{margin:0;}

/* Contact card */
.contact-card{
  background:linear-gradient(160deg,#003D38 0%,#0B8A86 100%);
  color:#fff;
  border-radius:20px;
  padding:clamp(24px,2.8vw,32px);
  box-shadow:0 20px 50px -24px rgba(0,61,56,.4);
  position:sticky;top:96px;
}
.contact-card .info-title{color:#fff;}
.contact-row{
  display:grid;grid-template-columns:46px 1fr;gap:14px;align-items:center;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.12);
  color:inherit;text-decoration:none;
  transition:transform .18s;
}
.contact-row:last-child{border-bottom:none;}
a.contact-row:hover{transform:translateX(3px);}
.contact-row .cc-icon{
  width:46px;height:46px;border-radius:12px;
  background:rgba(253,173,58,.18);color:#FDAD3A;
  display:inline-flex;align-items:center;justify-content:center;flex:none;
}
.contact-row .cc-text strong{display:block;font-size:17px;font-weight:700;margin-bottom:2px;color:#fff;}
.contact-row .cc-text span{display:block;font-size:13px;color:rgba(255,255,255,.70);line-height:1.4;}
@media (max-width:960px){.contact-card{position:static;}}

/* ============ BOTTOM-FEATURES BAR ============ */
.bottom-features{
  padding:clamp(48px,6vw,80px) 0;
  background:#003D38;
  color:#fff;
  position:relative;
  overflow:hidden;
}
.bottom-features::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 300px at 10% 0%,rgba(11,138,134,.35),transparent 60%),
    radial-gradient(700px 280px at 90% 100%,rgba(253,173,58,.14),transparent 60%);
  pointer-events:none;
}
.bottom-features .wrap{max-width:1240px;margin:0 auto;padding:0 24px;position:relative;}
.bf-title{margin:0 0 clamp(28px,3vw,40px);font-size:clamp(26px,3.2vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1.15;color:#fff;text-align:center;}
.bf-title::after{content:"";display:block;width:48px;height:3px;background:#FDAD3A;margin:14px auto 0;border-radius:2px;}
.bf-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
@media (max-width:960px){.bf-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.bf-grid{grid-template-columns:1fr;}}

.bf-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:24px 22px;
  display:flex;flex-direction:column;gap:12px;
  transition:transform .22s, border-color .22s, background .22s;
  backdrop-filter:blur(6px);
}
.bf-card:hover{
  transform:translateY(-4px);
  border-color:rgba(253,173,58,.45);
  background:rgba(255,255,255,.07);
}
.bf-card .bf-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(253,173,58,.18),rgba(11,138,134,.18));
  border:1px solid rgba(253,173,58,.35);
  color:#FDAD3A;
  display:inline-flex;align-items:center;justify-content:center;
}
.bf-card h4{
  margin:0;font-size:16px;font-weight:700;color:#fff;line-height:1.3;
  letter-spacing:-.005em;
}
.bf-card p{margin:0;font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.68);}

/* ============ Honeypot safety ============ */
.honey{position:absolute;left:-9999px;top:-9999px;height:0;width:0;overflow:hidden;}

/* ============ Reduced motion ============ */
@media (prefers-reduced-motion:reduce){
  .btn-submit,.contact-row,.bf-card,.faq-chev,.faq-item{transition:none;}
  .btn-submit:hover{transform:none;}
}

/* === v4 patch: .has-err visual feedback for form validation === */
.field.has-err input,
.field.has-err select,
.field.has-err textarea{
  border-color:#c53030 !important;
  background-color:#fef5f5;
}
.field.has-err input:focus,
.field.has-err select:focus,
.field.has-err textarea:focus{
  outline:2px solid rgba(197, 48, 48, .25);
  outline-offset:1px;
}
.form-agree.has-err{
  color:#c53030;
}
.form-agree.has-err input[type="checkbox"]{
  outline:2px solid #c53030;
  outline-offset:2px;
}
.field .err{
  display:block;
  font-size:12px;
  color:#c53030;
  margin-top:4px;
  min-height:14px;
}
.field.has-err .err::before{
  content:"⚠ ";
}

/* =================================================== */
/* === BAS-KRASNODAR v7 REBUILD — appended @v7   === */
/* =================================================== */

/* === v7 group A === */
/* ===== HERO — FPV-style for BAS ===== */
.hero-card{position:relative; border-radius:var(--radius-xl,28px); overflow:hidden; background:#dde5dd; display:grid; grid-template-columns:.95fr 1.05fr; min-height:560px; box-shadow:var(--shadow,0 14px 32px -16px rgba(15,29,28,.18))}
.hero-text{position:relative; z-index:2; padding:48px 40px 40px; display:flex; flex-direction:column; gap:22px; justify-content:center}
.hero-eyebrow{display:inline-flex; align-items:center; gap:10px; padding:7px 14px; background:#fff; border-radius:999px; font-size:12px; font-weight:700; color:var(--c-brand-dark,#003D38); letter-spacing:.06em; text-transform:uppercase; align-self:flex-start; box-shadow:var(--shadow-sm,0 2px 8px -4px rgba(15,29,28,.08))}
.hero-eyebrow .dot{width:8px; height:8px; border-radius:50%; background:var(--c-accent,#fdad3a); animation:pulse 1.6s ease infinite}
@keyframes pulse{0%,100%{transform:scale(1); opacity:1}50%{transform:scale(1.35); opacity:.6}}
.hero-title{font-size:clamp(28px,4vw,52px); font-weight:800; letter-spacing:-0.035em; line-height:1.04; color:var(--c-text,#0F1D1C)}
.hero-title .acc{color:var(--c-brand,#0b8a86); position:relative; display:inline-block; white-space:nowrap}
.hero-title .acc::after{content:''; position:absolute; left:0; right:0; bottom:-2px; height:3px; background:var(--c-accent,#fdad3a)}
.hero-sub{font-size:16px; line-height:1.55; color:var(--c-text-2,#3a4644); max-width:46ch; font-weight:500}
.hero-chips{display:flex; gap:8px; flex-wrap:wrap}
.hero-chips .chip{display:inline-flex; align-items:center; gap:8px; padding:8px 14px; background:#fff; border-radius:999px; font-size:13px; font-weight:600; color:var(--c-text-2,#3a4644); box-shadow:var(--shadow-sm,0 2px 8px -4px rgba(15,29,28,.08))}
.hero-chips .chip svg{width:14px; height:14px; color:var(--c-brand,#0b8a86); flex:none}
.hero-ctas{display:flex; gap:12px; flex-wrap:wrap}
.hero-features{display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:6px}
.hero-feat{display:flex; align-items:center; gap:10px; padding:12px 14px; background:#fff; border-radius:14px; box-shadow:var(--shadow-sm,0 2px 8px -4px rgba(15,29,28,.08))}
.hero-feat-ico{flex:none; width:32px; height:32px; border-radius:9px; display:grid; place-items:center; background:var(--c-brand-soft,#e8f3f2); color:var(--c-brand,#0b8a86)}
.hero-feat-ico svg{width:16px; height:16px}
.hero-feat-txt{font-size:12.5px; font-weight:600; line-height:1.3; color:var(--c-text,#0F1D1C); letter-spacing:-0.005em}
.hero-photo{position:relative; overflow:hidden}
.hero-photo img{width:100%; height:100%; object-fit:cover; object-position:center right}
.hero-photo::after{content:''; position:absolute; inset:0; background:linear-gradient(90deg, rgba(221,229,221,.85) 0%, rgba(221,229,221,0) 30%); pointer-events:none}

/* ===== PROGRAMS v2 ===== */
.programs-section .sec-sub{margin-top:14px; font-size:15.5px; color:var(--c-text-muted,#6b7977); max-width:62ch; margin-inline:auto; line-height:1.5}
.prog-grid-v2{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1280px; margin-inline:auto}
@media(max-width:1180px){.prog-grid-v2{grid-template-columns:1fr; max-width:640px; margin-inline:auto; gap:20px}}
.prog-card-v2{background:var(--c-paper,#fff); border:1.5px solid var(--c-line,#E6E2D8); border-radius:var(--radius-lg,20px); padding:clamp(20px,3vw,32px); display:flex; flex-direction:column; gap:22px; transition:transform .3s, box-shadow .3s, border-color .25s}
.prog-card-v2:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg,0 30px 60px -24px rgba(15,29,28,.22)); border-color:var(--c-brand,#0b8a86)}
.prog-head{display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start}
.prog-num{font-size:34px; font-weight:800; color:var(--c-brand,#0b8a86); line-height:1; letter-spacing:-0.04em; padding:8px 14px; background:var(--c-brand-soft,#e8f3f2); border-radius:14px; min-width:62px; text-align:center; align-self:flex-start}
.prog-head-text{display:flex; flex-direction:column; gap:8px}
.prog-name{font-size:clamp(18px,2.2vw,22px); font-weight:800; letter-spacing:-0.025em; line-height:1.18; color:var(--c-text,#0F1D1C)}
.prog-desc{font-size:14px; color:var(--c-text-muted,#6b7977); line-height:1.55}
.prog-meta-row{display:flex; flex-wrap:wrap; gap:8px}
.prog-chip{display:inline-flex; align-items:center; gap:7px; padding:7px 12px; background:var(--c-bg-soft,#F5F7F4); border:1px solid var(--c-line,#E6E2D8); border-radius:999px; font-size:12.5px; font-weight:600; color:var(--c-text-2,#3a4644); letter-spacing:-0.005em}
.prog-chip svg{width:13px; height:13px; color:var(--c-brand,#0b8a86); flex:none}
.prog-chip b{color:var(--c-brand-dark,#003D38); font-weight:800}
.prog-block{display:flex; flex-direction:column; gap:10px; padding-top:18px; border-top:1px solid var(--c-line,#E6E2D8)}
.prog-block-label{font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--c-brand,#0b8a86)}
.prog-includes{list-style:none; display:flex; flex-direction:column; gap:10px; padding:0; margin:0}
.prog-includes li{font-size:13.5px; display:grid; grid-template-columns:18px 1fr; gap:10px; align-items:start; line-height:1.45; color:var(--c-text,#0F1D1C)}
.ck{width:16px; height:16px; margin-top:2px; background:var(--c-brand-soft,#e8f3f2); border-radius:50%; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%230b8a86' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' d='m5 8 2 2 4-4'/></svg>"); background-position:center; background-size:16px; flex:none; display:block}
.prog-block-split{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.prog-block-split > div{display:flex; flex-direction:column; gap:10px}
.prog-mini, .prog-result{display:flex; align-items:center; gap:8px; font-size:13px; color:var(--c-text-2,#3a4644); line-height:1.4}
.prog-mini svg, .prog-result svg{width:15px; height:15px; color:var(--c-brand,#0b8a86); flex:none}
.prog-mini b, .prog-result b{color:var(--c-text,#0F1D1C); font-weight:700}
.prog-cta-row{display:flex; gap:10px; flex-wrap:wrap; margin-top:auto; padding-top:6px}
.prog-cta-row .btn{flex:1 1 auto; justify-content:center; min-width:140px}

/* ===== FINAL CTA ===== */
.final-cta{padding:var(--section-pad,80px) 0}
.final-shell{background:var(--c-brand-dark,#003D38); color:#fff; border-radius:var(--radius-xl,28px); padding:56px; display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:center; position:relative; overflow:hidden; box-shadow:0 30px 60px -24px rgba(0,61,56,.4)}
.final-shell::before{content:''; position:absolute; top:-80px; right:-100px; width:340px; height:340px; background:radial-gradient(circle, rgba(253,173,58,.35), transparent 70%); border-radius:50%; pointer-events:none}
.final-shell::after{content:''; position:absolute; bottom:-80px; right:30%; width:200px; height:200px; background:radial-gradient(circle, rgba(11,138,134,.4), transparent 70%); border-radius:50%; pointer-events:none}
.final-text{position:relative; z-index:1}
.final-text h2{font-size:clamp(24px,3vw,40px); font-weight:800; letter-spacing:-0.03em; line-height:1.08; margin-bottom:14px; color:#fff}
.final-text h2 em{font-style:normal; color:var(--c-accent,#fdad3a)}
.final-text p{font-size:16px; line-height:1.55; color:rgba(255,255,255,.86); max-width:50ch}
.final-license{display:inline-flex; align-items:center; gap:8px; margin-top:18px; padding:8px 14px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); border-radius:999px; font-size:12px; font-weight:600; color:rgba(255,255,255,.86); letter-spacing:-0.005em}
.final-license svg{color:var(--c-accent,#fdad3a); flex:none}
.final-actions{display:flex; flex-direction:row; flex-wrap:wrap; gap:14px; position:relative; z-index:1; align-items:center}
.final-actions .btn{justify-content:center; padding:18px 24px; font-size:15px; flex:1 1 200px}
@media(max-width:768px){.final-actions{flex-direction:column} .final-actions .btn{flex:1 1 100%; width:100%}}
.btn-ghost-white{background:rgba(255,255,255,.06); color:#fff; border:1.5px solid rgba(255,255,255,.55); transition:background .2s, border-color .2s, transform .2s}
.btn-ghost-white:hover{background:rgba(255,255,255,.14); border-color:#fff; transform:translateY(-2px)}
.btn-ghost-white:focus-visible{background:#fff; color:var(--c-brand-dark,#003D38); border-color:#fff}
/* Final CTA section-scoped focus-ring override — orange (~7:1 on #003D38, ~3.4:1 on #fff) */
.final-shell :focus-visible{outline:3px solid #fdad3a; outline-offset:3px; box-shadow:0 0 0 6px rgba(253,173,58,.25)}
.final-shell .btn-white:focus-visible{outline-color:#fdad3a}

/* ===== RESPONSIVE ===== */
/* 1920+ - максимальная ширина hero-photo */
@media (min-width:1920px){
  .hero-card{min-height:620px}
  .hero-text{padding:60px 56px}
  .prog-grid-v2{gap:28px}
}

/* 1366 desktop default - всё работает */
@media (max-width:1366px){
  .hero-text{padding:44px 36px 36px}
}

/* 1024 - small desktop / tablet landscape */
@media (max-width:1024px){
  .hero-card{grid-template-columns:1fr; min-height:auto}
  .hero-text{padding:36px 28px; order:2; gap:18px}
  .hero-photo{order:1; aspect-ratio:16/9}
  .hero-photo::after{background:linear-gradient(180deg, rgba(221,229,221,0) 60%, rgba(221,229,221,.85) 100%)}
  .hero-features{grid-template-columns:repeat(3,1fr)}
  .prog-grid-v2{grid-template-columns:1fr; max-width:640px; margin-inline:auto; gap:20px}
  .prog-card-v2{padding:26px 24px}
}

/* 768 - tablet portrait */
@media (max-width:900px){
  .prog-grid-v2{max-width:560px}
}
@media (max-width:768px){
  .hero-card{border-radius:22px}
  .hero-text{padding:30px 22px; gap:16px}
  .hero-photo{aspect-ratio:16/10}
  .hero-features{grid-template-columns:1fr; gap:8px}
  .hero-feat{padding:11px 14px}
  .hero-ctas{flex-direction:column; width:100%}
  .hero-ctas .btn{width:100%; justify-content:center; padding:16px 22px}
  .prog-card-v2{padding:24px 20px; gap:18px}
  .prog-head{grid-template-columns:auto 1fr; gap:14px}
  .prog-num{font-size:28px; padding:6px 10px; min-width:52px}
  .prog-block-split{grid-template-columns:1fr; gap:18px}
  .prog-cta-row{flex-direction:column; gap:8px}
  .prog-cta-row .btn{width:100%}
  .final-shell{grid-template-columns:1fr; padding:40px 28px; gap:32px}
  .final-shell::before{width:200px; height:200px; top:-40px; right:-40px}
  .final-shell::after{width:140px; height:140px; bottom:-40px}
}

/* 414 - large phone */
@media (max-width:480px){
  .hero-text{padding:26px 20px 22px; gap:14px}
  .hero-title{font-size:clamp(26px,7vw,36px); letter-spacing:-0.03em}
  .hero-sub{font-size:15px}
  .hero-eyebrow{font-size:11px; padding:6px 12px}
  .hero-chips .chip{font-size:12px; padding:7px 12px}
  .hero-feat-txt{font-size:12px}
  .prog-name{font-size:18px}
  .prog-desc{font-size:13.5px}
  .prog-num{font-size:24px; min-width:48px; padding:6px 9px}
  .prog-chip{font-size:11.5px; padding:6px 10px}
  .prog-includes li{font-size:13px}
  .final-shell{padding:32px 22px; border-radius:22px}
  .final-text h2{font-size:clamp(22px,6vw,28px)}
  .final-text p{font-size:15px}
  .final-license{font-size:11px}
}

/* 375 - small phone */
@media (max-width:380px){
  .hero-text{padding:22px 16px 20px}
  .hero-title{font-size:26px}
  .hero-card{border-radius:18px}
  .prog-card-v2{padding:20px 16px; border-radius:16px}
  .prog-head{grid-template-columns:1fr; gap:10px}
  .prog-num{align-self:flex-start; min-width:auto; padding:5px 12px; font-size:22px}
  .prog-meta-row{gap:6px}
  .prog-chip{font-size:11px; padding:5px 9px}
  .final-shell{padding:28px 18px}
  .final-text h2{font-size:22px}
}


/* === v7 group B === */
/* === BLOCK B: TRUST / WHY / FORMAT / CHOOSE (v7) === */

/* --- TRUST (без цифр, 4 карточки) --- */
.trust-section{background:var(--c-bg, #ffffff)}
.trust-section .trust-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:20px}
.trust-section .trust-card{background:var(--c-paper, #ffffff); border-radius:var(--radius-lg, 20px); padding:32px 28px; display:flex; flex-direction:column; gap:14px; border:1px solid var(--c-line, #E6EAEA); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; color:inherit; text-decoration:none; position:relative; overflow:hidden}
.trust-section .trust-card::before{content:""; position:absolute; inset:0; background:linear-gradient(135deg, rgba(11,138,134,.04) 0%, rgba(253,173,58,.02) 100%); opacity:0; transition:opacity .3s ease; pointer-events:none}
.trust-section .trust-card:hover{transform:translateY(-6px); box-shadow:0 18px 40px -18px rgba(0, 61, 56, .18); border-color:rgba(11,138,134,.25)}
.trust-section .trust-card:hover::before{opacity:1}
.trust-section .trust-card .ico{width:56px; height:56px; border-radius:16px; background:rgba(11,138,134,.10); display:grid; place-items:center; color:#0B8A86; transition:background .3s, color .3s, transform .3s; flex-shrink:0}
.trust-section .trust-card:hover .ico{background:#0B8A86; color:#ffffff; transform:rotate(-6deg) scale(1.06)}
a.trust-card{cursor:pointer}
a.trust-card:hover h3{color:#0B8A86}
.trust-section .trust-card h3{font-size:17px; font-weight:700; letter-spacing:-0.015em; line-height:1.3; color:#003D38; margin:0}
.trust-section .trust-card p{font-size:14px; line-height:1.6; color:#4A5A58; margin:0}

/* --- WHY BAS (6 industry-cards) --- */
.why-section{background:linear-gradient(180deg, #F8FAFA 0%, #ffffff 100%); position:relative}
.why-section .sec-head{text-align:center; max-width:780px; margin:0 auto 48px}
.why-section .sec-sub{font-size:clamp(15px, 1.4vw, 17px); line-height:1.6; color:#4A5A58; margin-top:18px}
.why-section .acc{font-style:normal; color:#FDAD3A; font-weight:800}
.why-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px}
.why-card{background:#ffffff; border-radius:20px; padding:32px 26px; border:1px solid #E6EAEA; display:flex; flex-direction:column; gap:14px; transition:transform .35s ease, box-shadow .3s ease, border-color .3s ease; position:relative; overflow:hidden}
.why-card::after{content:""; position:absolute; top:-50%; right:-30%; width:160px; height:160px; background:radial-gradient(circle, rgba(11,138,134,.06) 0%, transparent 70%); border-radius:50%; transition:transform .5s ease; pointer-events:none}
.why-card:hover{transform:translateY(-6px); box-shadow:0 20px 40px -18px rgba(0,61,56,.18); border-color:rgba(11,138,134,.20)}
.why-card:hover::after{transform:scale(1.4) translate(-10%, 10%)}
.why-ico{width:64px; height:64px; border-radius:18px; background:rgba(11,138,134,.10); display:grid; place-items:center; color:#0B8A86; transition:background .3s, color .3s, transform .3s; flex-shrink:0; position:relative; z-index:1}
.why-card:hover .why-ico{background:#0B8A86; color:#ffffff; transform:rotate(-5deg) scale(1.05)}
.why-card h3{font-size:19px; font-weight:700; letter-spacing:-0.015em; color:#003D38; margin:0; line-height:1.3; position:relative; z-index:1}
.why-card p{font-size:14.5px; line-height:1.6; color:#4A5A58; margin:0; position:relative; z-index:1}

/* --- FORMAT v7 (4 big-icon cards) --- */
.format-section-v7{background:#ffffff}
.format-section-v7 .sec-head{text-align:center; max-width:680px; margin:0 auto 48px}
.format-section-v7 .acc{font-style:normal; color:#FDAD3A; font-weight:800}
.format-grid-v7{display:grid; grid-template-columns:repeat(4, 1fr); gap:22px}
.format-card{background:#F8FAFA; border-radius:20px; padding:34px 26px; display:flex; flex-direction:column; gap:16px; border:1px solid #E6EAEA; transition:transform .3s ease, box-shadow .3s ease, background .3s ease, border-color .3s ease; position:relative; overflow:hidden}
.format-card:hover{transform:translateY(-6px); box-shadow:0 20px 40px -18px rgba(0,61,56,.16); background:#ffffff; border-color:rgba(11,138,134,.25)}
.format-ico{width:72px; height:72px; border-radius:20px; background:linear-gradient(135deg, rgba(11,138,134,.12) 0%, rgba(253,173,58,.08) 100%); display:grid; place-items:center; color:#0B8A86; transition:transform .35s ease, background .3s; flex-shrink:0}
.format-card:hover .format-ico{background:linear-gradient(135deg, #0B8A86 0%, #003D38 100%); color:#ffffff; transform:rotate(-6deg) scale(1.06)}
.format-card h3{font-size:20px; font-weight:700; letter-spacing:-0.02em; color:#003D38; margin:0; line-height:1.25}
.format-card p{font-size:14.5px; line-height:1.65; color:#4A5A58; margin:0}
.format-card p b{color:#003D38; font-weight:700}

/* --- CHOOSE (3 bullet с ck-checkmark + CTA) --- */
.choose-section{background:linear-gradient(180deg, #ffffff 0%, #F8FAFA 100%)}
.choose-section .sec-head{text-align:center; max-width:680px; margin:0 auto 40px}
.choose-section .acc{font-style:normal; color:#FDAD3A; font-weight:800}
.choose-shell{max-width:820px; margin:0 auto; background:#ffffff; border:1px solid #E6EAEA; border-radius:24px; padding:44px 48px; box-shadow:0 14px 40px -20px rgba(0,61,56,.10)}
.choose-list{list-style:none; padding:0; margin:0 0 36px; display:flex; flex-direction:column; gap:18px}
.choose-item{display:grid; grid-template-columns:32px 1fr; gap:16px; align-items:start; font-size:clamp(15px, 1.5vw, 17px); line-height:1.6; color:#1F2F2D}
.choose-item .ck{width:28px; height:28px; border-radius:50%; background:rgba(11,138,134,.12); color:#0B8A86; display:grid; place-items:center; flex-shrink:0; margin-top:2px; transition:background .3s, color .3s, transform .3s}
.choose-item:hover .ck{background:#0B8A86; color:#ffffff; transform:scale(1.08)}
.choose-text b{color:#003D38; font-weight:700}
.choose-meta{color:#7A8A87; font-size:0.92em; font-weight:400}
.choose-cta{display:flex; justify-content:center}
.choose-cta .btn-primary{padding:16px 36px; font-size:16px; font-weight:700; border-radius:14px; background:#FDAD3A; color:#003D38; border:none; transition:transform .25s ease, box-shadow .25s ease, background .25s ease; text-decoration:none; display:inline-flex; align-items:center; gap:10px}
.choose-cta .btn-primary:hover{background:#FFB94D; transform:translateY(-2px); box-shadow:0 12px 28px -10px rgba(253,173,58,.55)}

/* === RESPONSIVE — 1920 / 1366 / 1024 / 768 / 414 / 375 === */

/* 1920+ (default desktop large) */
@media (min-width: 1920px){
  .trust-section .trust-card{padding:36px 30px}
  .why-card{padding:36px 30px}
  .format-card{padding:38px 30px}
  .choose-shell{padding:52px 60px; max-width:880px}
}

/* 1366 — небольшое поджатие */
@media (max-width: 1366px){
  .trust-section .trust-grid{gap:18px}
  .why-grid{gap:22px}
  .format-grid-v7{gap:20px}
  .format-card{padding:30px 22px}
  .why-card{padding:30px 22px}
}

/* 1024 — планшет landscape: 4→3 / 3→3 / 4→2 */
@media (max-width: 1024px){
  .trust-section .trust-grid{grid-template-columns:repeat(2, 1fr); gap:18px}
  .why-grid{grid-template-columns:repeat(2, 1fr); gap:20px}
  .format-grid-v7{grid-template-columns:repeat(2, 1fr); gap:18px}
  .choose-shell{padding:38px 36px}
  .why-section .sec-head{margin-bottom:40px}
  .format-section-v7 .sec-head{margin-bottom:40px}
}

/* 768 — планшет portrait */
@media (max-width: 768px){
  .trust-section .trust-card{padding:26px 22px; gap:12px}
  .trust-section .trust-card .ico{width:48px; height:48px; border-radius:14px}
  .trust-section .trust-card .ico svg{width:24px; height:24px}
  .trust-section .trust-card h3{font-size:16px}
  .trust-section .trust-card p{font-size:13.5px}
  .why-card{padding:26px 22px}
  .why-ico{width:56px; height:56px; border-radius:16px}
  .why-ico svg{width:26px; height:26px}
  .why-card h3{font-size:18px}
  .format-card{padding:28px 22px}
  .format-ico{width:64px; height:64px; border-radius:18px}
  .format-ico svg{width:32px; height:32px}
  .format-card h3{font-size:18.5px}
  .choose-shell{padding:32px 28px; border-radius:20px}
  .choose-list{gap:16px; margin-bottom:30px}
}

/* 414 — крупный мобильный (iPhone Pro Max) */
@media (max-width: 520px){
  .trust-section .trust-grid{grid-template-columns:1fr; gap:14px}
  .why-grid{grid-template-columns:1fr; gap:14px}
  .format-grid-v7{grid-template-columns:1fr; gap:14px}
}

/* 414 узко */
@media (max-width: 440px){
  .trust-section .trust-card{padding:22px 20px}
  .why-card{padding:24px 20px}
  .why-card h3{font-size:17px}
  .why-card p{font-size:14px}
  .format-card{padding:26px 20px}
  .format-ico{width:60px; height:60px}
  .format-card h3{font-size:18px}
  .format-card p{font-size:14px}
  .choose-shell{padding:26px 22px; border-radius:18px}
  .choose-item{grid-template-columns:26px 1fr; gap:12px; font-size:14.5px}
  .choose-item .ck{width:24px; height:24px}
  .choose-item .ck svg{width:12px; height:12px}
  .choose-cta .btn-primary{padding:14px 28px; font-size:15px; width:100%; justify-content:center}
}

/* 375 — стандартный iPhone */
@media (max-width: 380px){
  .trust-section .trust-card{padding:20px 18px}
  .trust-section .trust-card h3{font-size:15.5px}
  .trust-section .trust-card p{font-size:13px}
  .why-card{padding:22px 18px}
  .why-ico{width:52px; height:52px}
  .why-card h3{font-size:16.5px}
  .why-card p{font-size:13.5px}
  .format-card{padding:24px 18px}
  .format-card h3{font-size:17px}
  .format-card p{font-size:13.5px}
  .choose-shell{padding:22px 18px}
  .choose-item{font-size:14px}
}

/* Уменьшение отступов от sec-head на мобильных */
@media (max-width: 768px){
  .why-section .sec-head, .format-section-v7 .sec-head, .choose-section .sec-head{margin-bottom:32px}
  .why-section .sec-sub{font-size:14.5px; margin-top:14px}
}

/* Поддержка reduce-motion */
@media (prefers-reduced-motion: reduce){
  .trust-section .trust-card, .why-card, .format-card, .choose-item .ck, .choose-cta .btn-primary{transition:none}
  .trust-section .trust-card:hover, .why-card:hover, .format-card:hover{transform:none}
  .trust-section .trust-card:hover .ico, .why-card:hover .why-ico, .format-card:hover .format-ico{transform:none}
}

/* === v7 group C === */
/* ============================================================
   BLOCK C — Teachers (4 instructors) + FAQ standalone (10 Q)
   FPV palette: teal #0B8A86, orange #FDAD3A, dark-green #003D38
   Reuses FPV tokens via existing CSS vars (--c-brand, --c-accent,
   --c-brand-dark, --c-brand-soft, --c-paper, --c-line, --c-text,
   --c-text-muted, --radius, --radius-lg, --shadow, --shadow-sm,
   --shadow-lg). If vars missing, fall back below.
   ============================================================ */

:root{
  --c-brand: #0B8A86;
  --c-brand-dark: #003D38;
  --c-accent: #FDAD3A;
  --c-brand-soft: #E6F2F1;
  --c-paper: #FFFFFF;
  --c-line: #E5EAE9;
  --c-text: #0E1A19;
  --c-text-muted: #5C6B69;
  --radius: 12px;
  --radius-lg: 18px;
  --shadow-sm: 0 1px 2px rgba(0,61,56,.06);
  --shadow: 0 6px 18px rgba(0,61,56,.08);
  --shadow-lg: 0 18px 44px rgba(0,61,56,.14);
}

/* ---------- Section header (shared FPV pattern) ---------- */
.sec-head{ max-width: 760px; margin: 0 auto 36px; }
.sec-eyebrow{
  display: inline-block;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--c-brand);
  margin-bottom: 12px;
}
.sec-title{
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: clamp(26px, 3.4vw, 40px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.08;
  color: var(--c-brand-dark);
  margin: 0 0 14px;
}
.sec-title em{ font-style: normal; color: var(--c-brand); }
.sec-sub{
  font-size: clamp(14px, 1.4vw, 16px);
  color: var(--c-text-muted);
  line-height: 1.6;
  margin: 0 auto;
  max-width: 640px;
}

/* ============================================================
   TEACHERS GRID — 4 cards
   Desktop ≥1100  : 4 columns
   Tablet ≤900    : 2 columns
   Mobile ≤480    : 1 column
   ============================================================ */
.teachers-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.teacher{
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  font-family: 'Manrope', system-ui, sans-serif;
}
.teacher:hover{
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--c-brand-soft);
}

.teacher .photo{
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: linear-gradient(135deg, #dde5dd 0%, #eef3ef 100%);
}
.teacher .photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .6s ease;
  image-rendering: -webkit-optimize-contrast;
  backface-visibility: hidden;
  transform: translateZ(0);
}
.teacher:hover .photo img{ transform: scale(1.04) translateZ(0); }

.teacher .photo-tag{
  position: absolute;
  top: 14px; left: 14px;
  padding: 5px 11px;
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--c-brand-dark);
  border-radius: 999px;
  z-index: 1;
  box-shadow: var(--shadow-sm);
}
.teacher.lead .photo-tag{
  background: var(--c-accent);
  color: var(--c-brand-dark);
}

.teacher-body{
  padding: 20px 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.teacher-role{
  font-size: 11px;
  color: var(--c-brand);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
}
.teacher-name{
  font-size: clamp(15px, 1.3vw, 17px);
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1.22;
  color: var(--c-brand-dark);
  margin: 0;
}
.teacher-bio{
  font-size: clamp(13.5px, 1.2vw, 15px);
  color: var(--c-text-muted);
  line-height: 1.5;
  flex: 1;
  margin: 0;
}
.teacher-city{
  margin-top: auto;
  padding-top: 10px;
  font-size: 12.5px;
  color: var(--c-text-muted);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.teacher-city svg{
  width: 13px;
  height: 13px;
  color: var(--c-brand);
  flex: none;
}

/* Lead card accent — orange ring */
.teacher.lead{
  border-color: rgba(253, 173, 58, .35);
  box-shadow: 0 12px 32px rgba(253, 173, 58, .08);
}
.teacher.lead .teacher-role{ color: var(--c-accent); color: #C97A0E; }

/* ============================================================
   FAQ STANDALONE — 10 details
   ============================================================ */
.faq-list{
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 880px;
  margin: 0 auto;
}

.faq-item{
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color .25s ease, box-shadow .25s ease;
}
.faq-item:hover{
  border-color: var(--c-brand-soft);
  box-shadow: var(--shadow-sm);
}
.faq-item[open]{
  border-color: var(--c-brand);
  box-shadow: var(--shadow);
}

.faq-item summary{
  padding: 20px 22px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  list-style: none;
  user-select: none;
}
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-item summary::marker{ display: none; content: ''; }

.faq-q{
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: clamp(16px, 1.5vw, 18px);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.35;
  color: var(--c-brand-dark);
  flex: 1;
}

.faq-toggle{
  width: 34px;
  height: 34px;
  flex: none;
  background: var(--c-brand-soft);
  color: var(--c-brand);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 22px;
  line-height: 1;
  font-weight: 700;
  transition: transform .28s ease, background .28s ease, color .28s ease;
}
.faq-toggle::before{ content: '+'; }
.faq-item[open] .faq-toggle{
  background: var(--c-brand);
  color: #fff;
  transform: rotate(45deg); /* + → × */
}

.faq-ans{
  padding: 0 22px 22px;
  font-size: clamp(14px, 1.3vw, 16px);
  color: var(--c-text-muted);
  line-height: 1.65;
  animation: faqFadeIn .35s ease;
}
@keyframes faqFadeIn{
  from{ opacity: 0; transform: translateY(-4px); }
  to  { opacity: 1; transform: translateY(0);    }
}

/* ============================================================
   RESPONSIVE — required breakpoints
   1920 / 1366 / 1024 / 768 / 414 / 375
   ============================================================ */

/* ---------- 1920+ (large desktop) ---------- */
@media (min-width: 1600px){
  .teachers-grid{ gap: 24px; }
  .teacher .photo-tag{ font-size: 11px; padding: 6px 12px; }
  .teacher-body{ padding: 22px 22px 24px; }
  .faq-list{ max-width: 960px; }
  .faq-item summary{ padding: 22px 26px; }
  .faq-ans{ padding: 0 26px 24px; }
}

/* ---------- 1366 (laptop) ---------- */
@media (max-width: 1440px){
  .teachers-grid{ gap: 18px; }
  .teacher-body{ padding: 18px 18px 20px; }
}

/* ---------- 1024 (small laptop / large tablet landscape) ---------- */
@media (max-width: 1100px){
  .teachers-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
  .teacher .photo{ aspect-ratio: 4 / 5; }
  .faq-item summary{ padding: 18px 20px; }
  .faq-ans{ padding: 0 20px 20px; }
}

/* ---------- 768 (tablet portrait) ---------- */
@media (max-width: 900px){
  .sec-head{ margin-bottom: 28px; }
  .teachers-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .teacher-body{ padding: 16px 16px 18px; gap: 7px; }
  .teacher-name{ font-size: 15px; }
  .teacher-bio{ font-size: 13.5px; }
  .faq-q{ font-size: 16px; }
  .faq-ans{ font-size: 14.5px; }
  .faq-toggle{ width: 30px; height: 30px; font-size: 20px; }
}

/* ---------- 414 (large mobile) ---------- */
@media (max-width: 520px){
  .teachers-grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .teacher .photo{ aspect-ratio: 3 / 4; }
  .teacher-body{ padding: 18px 18px 20px; }
  .teacher .photo-tag{
    top: 12px; left: 12px;
    padding: 4px 9px;
    font-size: 9.5px;
  }

  .faq-list{ gap: 8px; }
  .faq-item summary{ padding: 16px 16px; gap: 12px; }
  .faq-q{ font-size: 15px; line-height: 1.3; }
  .faq-ans{ padding: 0 16px 18px; font-size: 14px; }
  .faq-toggle{ width: 28px; height: 28px; font-size: 18px; }
}

/* ---------- 375 (small mobile — iPhone SE) ---------- */
@media (max-width: 400px){
  .sec-head{ margin-bottom: 22px; }
  .teachers-grid{ gap: 14px; }
  .teacher-body{ padding: 16px 14px 18px; }
  .teacher-name{ font-size: 14.5px; }
  .teacher-bio{ font-size: 13px; line-height: 1.5; }
  .teacher-city{ font-size: 12px; padding-top: 8px; }

  .faq-item summary{ padding: 14px 14px; }
  .faq-q{ font-size: 14.5px; }
  .faq-ans{ padding: 0 14px 16px; font-size: 13.5px; line-height: 1.6; }
  .faq-toggle{ width: 26px; height: 26px; font-size: 17px; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  .teacher,
  .teacher .photo img,
  .faq-item,
  .faq-toggle,
  .faq-ans{
    transition: none !important;
    animation: none !important;
  }
}

/* ---------- Print ---------- */
@media print{
  .faq-item{ break-inside: avoid; border-color: #ccc; }
  .faq-item[open] .faq-toggle,
  .faq-toggle{ display: none; }
  .faq-ans{ display: block !important; padding: 6px 0 12px; }
  .teacher{ break-inside: avoid; box-shadow: none; }
}


/* === v7 group D === */
/* ============================================================
   ZONE D — FORM + FOOTER + GLOBAL RESPONSIVE
   FPV palette: --teal #0B8A86, --orange #FDAD3A, --dark #003D38
   Font: Manrope
   ============================================================ */

:root {
  --teal: #0B8A86;
  --teal-2: #0a7a76;
  --orange: #FDAD3A;
  --dark: #003D38;
  --dark-2: #002c28;
  --ink: #0f1f1e;
  --mute: #5e7370;
  --line: #e3ebea;
  --bg-soft: #f4f8f7;
  --white: #ffffff;
  --shadow-card: 0 18px 48px -22px rgba(0, 61, 56, 0.35);
}

/* ============================================================
   TYPOGRAPHY — clamp() scale (mobile-first)
   ============================================================ */
.hero-title, h1 { font-size: clamp(28px, 5vw, 52px); line-height: 1.08; letter-spacing: -0.02em; }
.sec-title, h2 { font-size: clamp(24px, 4vw, 40px); line-height: 1.12; letter-spacing: -0.018em; }
.prog-name, .aud-title, .teacher-name, .form-overlay-title, h3 { font-size: clamp(18px, 2.2vw, 24px); line-height: 1.22; }
body, p, .hero-sub, .sec-sub, .prog-meta { font-size: clamp(14px, 1.5vw, 16px); line-height: 1.6; }
.sec-sub { font-size: clamp(15px, 1.6vw, 18px); }
.foot-pdn, .form-overlay-text, .sm { font-size: clamp(12px, 1.2vw, 13px); line-height: 1.55; }

/* ============================================================
   FORM SECTION
   ============================================================ */
.form-section {
  position: relative;
  padding: clamp(56px, 8vw, 110px) 0;
  background:
    radial-gradient(circle at 90% 10%, rgba(11, 138, 134, 0.08), transparent 55%),
    radial-gradient(circle at 8% 92%, rgba(253, 173, 58, 0.06), transparent 50%),
    var(--white);
  overflow: hidden;
}

.form-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(28px, 4vw, 56px);
  align-items: stretch;
}

.form-intro { display: flex; flex-direction: column; }
.form-intro .sec-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 700; letter-spacing: 0.14em;
  color: var(--teal); text-transform: uppercase;
  padding: 6px 14px; border: 1px solid rgba(11, 138, 134, 0.25);
  border-radius: 999px; background: rgba(11, 138, 134, 0.06);
  align-self: flex-start;
  margin-bottom: 16px;
}
.form-intro .sec-title { color: var(--dark); margin: 0 0 14px; font-weight: 800; }
.form-intro .sec-title .acc { color: var(--orange); font-style: normal; font-weight: 800; }
.form-intro .sec-sub { color: var(--mute); margin: 0 0 28px; max-width: 540px; }

/* bullets */
.form-bullets { list-style: none; padding: 0; margin: 0 0 32px; display: grid; gap: 14px; }
.form-bullet {
  display: grid; grid-template-columns: 38px 1fr; gap: 14px; align-items: start;
  padding: 14px 16px; border-radius: 14px;
  background: var(--bg-soft); border: 1px solid var(--line);
  transition: transform .25s ease, border-color .25s ease;
}
.form-bullet:hover { transform: translateY(-2px); border-color: rgba(11, 138, 134, 0.3); }
.form-bullet .ck {
  width: 38px; height: 38px; border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--teal); color: var(--white);
  box-shadow: 0 8px 18px -10px rgba(11, 138, 134, .7);
}
.form-bullet-body { display: flex; flex-direction: column; gap: 2px; }
.form-bullet-body b { color: var(--dark); font-weight: 700; font-size: clamp(14px, 1.5vw, 16px); }
.form-bullet-body span { color: var(--mute); font-size: clamp(13px, 1.35vw, 14px); }

/* lead-form */
.lead-form {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: clamp(20px, 2.4vw, 28px);
  box-shadow: var(--shadow-card);
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.lead-form .field { position: relative; grid-column: span 1; }
.lead-form .field:nth-of-type(3),
.lead-form .field:nth-of-type(4) { grid-column: span 1; }
.lead-form .field input {
  width: 100%; box-sizing: border-box;
  height: 56px; padding: 22px 16px 8px;
  font: 500 15px/1.2 Manrope, system-ui, sans-serif;
  color: var(--ink);
  background: var(--bg-soft);
  border: 1.5px solid transparent;
  border-radius: 12px;
  transition: border-color .2s ease, background .2s ease;
}
.lead-form .field input:focus {
  outline: none; border-color: var(--teal); background: var(--white);
}
.lead-form .field label {
  position: absolute; left: 16px; top: 18px;
  font: 500 14px/1 Manrope, sans-serif;
  color: var(--mute); pointer-events: none;
  transition: transform .18s ease, color .18s ease, font-size .18s ease;
  transform-origin: left top;
}
.lead-form .field input:focus + label,
.lead-form .field input:not(:placeholder-shown) + label {
  transform: translateY(-10px) scale(.78);
  color: var(--teal);
}
.lead-form .field input:invalid:not(:placeholder-shown):not(:focus) {
  border-color: #e6553c;
}

.lead-form .honey { position: absolute; left: -10000px; opacity: 0; pointer-events: none; }

/* agree */
.lead-form .form-agree {
  grid-column: 1 / -1;
  display: grid; grid-template-columns: 22px 1fr; gap: 12px;
  padding: 12px 4px 0;
  font-size: 12px; line-height: 1.55; color: var(--mute);
}
.lead-form .form-agree input[type=checkbox] {
  width: 22px; height: 22px; margin: 2px 0 0;
  accent-color: var(--teal); cursor: pointer;
}
.lead-form .form-agree a { color: var(--teal); text-decoration: underline; text-underline-offset: 2px; }
.lead-form .form-agree a:hover { color: var(--orange); }

.form-msg { grid-column: 1 / -1; min-height: 0; font-size: 13px; }
.form-msg[data-state="success"] { color: var(--teal); }
.form-msg[data-state="error"] { color: #c8442c; }

.form-submit {
  grid-column: 1 / -1;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  height: 56px; padding: 0 28px;
  font: 700 16px/1 Manrope, sans-serif;
  color: var(--dark);
  background: var(--orange);
  border: none; border-radius: 12px;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .25s ease, background .2s ease;
  box-shadow: 0 14px 30px -14px rgba(253, 173, 58, 0.7);
}
.form-submit:hover { background: #ffba51; transform: translateY(-2px); box-shadow: 0 20px 38px -16px rgba(253, 173, 58, 0.8); }
.form-submit:active { transform: translateY(0); }

[data-bas-captcha] { grid-column: 1 / -1; min-height: 0; }

/* RIGHT photo */
.form-photo {
  position: relative;
  border-radius: 22px; overflow: hidden;
  min-height: 480px;
  background: linear-gradient(160deg, var(--dark) 0%, var(--teal) 100%);
  box-shadow: var(--shadow-card);
}
.form-photo img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  mix-blend-mode: luminosity; opacity: .55;
}
.form-photo::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(0,44,40,0.85) 100%);
  z-index: 1;
}
.form-overlay-card {
  position: absolute; left: 24px; right: 24px; bottom: 24px;
  z-index: 2;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 22px 22px 24px;
  box-shadow: 0 18px 40px -18px rgba(0, 61, 56, 0.55);
}
.form-overlay-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: 14px;
  background: linear-gradient(140deg, var(--orange), #ffc36a);
  color: var(--dark);
  margin-bottom: 12px;
}
.form-overlay-title {
  margin: 0 0 8px;
  color: var(--dark); font-weight: 800;
}
.form-overlay-title .acc { color: var(--teal); font-style: normal; }
.form-overlay-text { margin: 0; color: var(--mute); }

/* ============================================================
   FOOTER
   ============================================================ */
footer.site {
  background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 100%);
  color: rgba(255, 255, 255, 0.86);
  padding: clamp(48px, 7vw, 80px) 0 clamp(20px, 3vw, 32px);
  margin-top: 0;
}

footer.site .foot-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: clamp(24px, 3vw, 48px);
  padding-bottom: clamp(32px, 4.5vw, 56px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.foot-col { display: flex; flex-direction: column; gap: 12px; min-width: 0; }

.foot-brand .brand-logo--white {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--white); text-decoration: none;
  font-weight: 800; font-size: 18px; letter-spacing: -0.01em;
  margin-bottom: 8px;
}
.foot-brand .brand-text { color: var(--white); }
.foot-about { color: rgba(255, 255, 255, 0.7); margin: 0; max-width: 340px; }

.foot-h {
  margin: 0 0 4px;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--orange);
}

.foot-nav { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-nav a {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  font-size: clamp(14px, 1.4vw, 15px);
  transition: color .2s ease, transform .2s ease;
  display: inline-block;
}
.foot-nav a:hover { color: var(--orange); transform: translateX(3px); }

.foot-contact .vc {
  display: flex; flex-direction: column; gap: 2px;
  color: var(--white); text-decoration: none;
  padding: 8px 0;
  transition: color .2s ease;
}
.foot-contact .vc:hover { color: var(--orange); }
.foot-contact .vc-main { font-weight: 700; font-size: clamp(15px, 1.6vw, 17px); }
.foot-contact .sm {
  color: rgba(255, 255, 255, 0.55);
  font-size: clamp(12px, 1.2vw, 13px);
  line-height: 1.5;
}
.foot-contact .sm-block { margin: 8px 0 0; }

.foot-bot { padding-top: clamp(20px, 2.5vw, 28px); display: flex; flex-direction: column; gap: 14px; }
.foot-bot-row {
  display: flex; flex-wrap: wrap; gap: 12px 28px; align-items: center; justify-content: space-between;
  color: rgba(255, 255, 255, 0.55);
  font-size: clamp(12px, 1.2vw, 13px);
}
.foot-license { color: rgba(255, 255, 255, 0.7); }
.foot-pdn {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: clamp(12px, 1.1vw, 13px); line-height: 1.6;
  max-width: 100%;
}
.foot-pdn a { color: rgba(255, 255, 255, 0.7); text-decoration: underline; text-underline-offset: 2px; }
.foot-pdn a:hover { color: var(--orange); }

/* Footer focus-visible override — teal-on-dark fails WCAG 1.4.11 (~2.8:1). Orange #FDAD3A on #003D38 ~8.6:1 */
footer.site a:focus-visible,
footer.site button:focus-visible {
  outline: 3px solid #FDAD3A;
  outline-offset: 3px;
  border-radius: 4px;
}
footer.site .foot-nav a:focus-visible { color: var(--orange); transform: translateX(3px); }

/* ============================================================
   RESPONSIVE — @media stack (375 / 414 / 480 / 768 / 1024 / 1366 / 1920)
   Mobile-first: base above is desktop default; queries collapse from largest grid down.
   ============================================================ */

/* Full HD desktop+ : wider container, larger gaps */
@media (min-width: 1920px) {
  .std, .hero-card, .form-shell, footer .foot-row {
    max-width: 1340px;
    margin-left: auto;
    margin-right: auto;
  }
  .form-section { padding: 130px 0; }
  .form-photo { min-height: 560px; }
}

/* Standard laptop ~1366 — slight density */
@media (max-width: 1366px) {
  .form-shell { gap: 40px; }
  .form-photo { min-height: 460px; }
  footer.site .foot-row { gap: 36px; }
}

/* Tablet landscape / small laptop ~1024 */
@media (max-width: 1024px) {
  .form-section { padding: 64px 0; }
  .form-shell { grid-template-columns: 1.15fr 0.85fr; gap: 28px; }
  .lead-form { padding: 22px; }
  .form-photo { min-height: 420px; }
  .form-overlay-card { left: 18px; right: 18px; bottom: 18px; padding: 18px; }
  footer.site .foot-row { grid-template-columns: 1.2fr 1fr 1fr 1.3fr; gap: 28px; }
  .foot-about { max-width: 100%; }
}

/* Tablet portrait ~768 — collapse all large grids to 1-col / 2-col */
@media (max-width: 768px) {
  .hero-card { grid-template-columns: 1fr; }
  .programs { grid-template-columns: 1fr; }
  .teachers { grid-template-columns: repeat(2, 1fr); }
  .trust-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .format-grid { grid-template-columns: repeat(2, 1fr); }
  .form-shell { grid-template-columns: 1fr; gap: 24px; }

  .form-section { padding: 48px 0; }
  .lead-form { grid-template-columns: 1fr; gap: 12px; padding: 20px; }
  .lead-form .field { grid-column: 1 / -1; }
  .form-photo { min-height: 320px; order: -1; }
  .form-overlay-card { padding: 16px; }
  .form-overlay-icon { width: 44px; height: 44px; margin-bottom: 8px; }

  footer.site { padding: 48px 0 24px; }
  footer .foot-row { grid-template-columns: repeat(2, 1fr); gap: 28px 24px; }
  .foot-brand { grid-column: 1 / -1; }
  .foot-contact { grid-column: 1 / -1; }
  .foot-bot { border-top: 1px solid rgba(255, 255, 255, 0.14); margin-top: 8px; }
  .foot-bot-row { gap: 8px 20px; }
}

/* very small phones / portrait ≤480 — fully stacked */
@media (max-width: 480px) {
  .teachers { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; }
  .format-grid { grid-template-columns: 1fr; }
  footer .foot-row { grid-template-columns: 1fr; }

  .form-section { padding: 40px 0; }
  .form-intro .sec-title { font-size: 26px; }
  .form-bullets { gap: 10px; margin-bottom: 22px; }
  .form-bullet { padding: 12px 14px; grid-template-columns: 34px 1fr; gap: 12px; }
  .form-bullet .ck { width: 34px; height: 34px; border-radius: 10px; }
  .lead-form { padding: 16px; border-radius: 18px; }
  .lead-form .field input { height: 52px; }
  .form-submit { height: 52px; font-size: 15px; }
  .form-photo { min-height: 260px; border-radius: 18px; }
  .form-overlay-card { left: 12px; right: 12px; bottom: 12px; border-radius: 14px; padding: 14px; }
  .form-overlay-title { font-size: 17px; }

  footer.site { padding: 40px 0 20px; }
  footer .foot-row { gap: 22px; padding-bottom: 28px; }
  .foot-brand, .foot-contact { grid-column: auto; }
  .foot-bot-row { flex-direction: column; align-items: flex-start; }
  .foot-pdn { font-size: 12px; color: rgba(255, 255, 255, 0.72); }
}

/* iPhone Pro / стандарт mobile ~414 */
@media (max-width: 414px) {
  .form-section { padding: 36px 0; }
  .form-intro .sec-title { font-size: 24px; }
  .form-intro .sec-sub { font-size: 14px; margin-bottom: 22px; }
  .lead-form { padding: 14px; }
  .form-overlay-card { padding: 12px 14px; }
  .form-overlay-title { font-size: 16px; line-height: 1.25; }
  .form-overlay-text { font-size: 12.5px; }
  footer.site { padding: 36px 0 18px; }
}

/* small mobile / iPhone SE ~375 — tightest density */
@media (max-width: 375px) {
  :root { --shadow-card: 0 12px 28px -16px rgba(0, 61, 56, 0.3); }

  .form-section { padding: 32px 0; }
  .form-intro .sec-eyebrow { font-size: 11px; padding: 5px 10px; }
  .form-intro .sec-title { font-size: 22px; line-height: 1.15; }
  .form-intro .sec-sub { font-size: 13.5px; }
  .form-bullet { padding: 10px 12px; }
  .form-bullet-body b { font-size: 13.5px; }
  .form-bullet-body span { font-size: 12.5px; }
  .lead-form { padding: 12px; gap: 10px; }
  .lead-form .field input { height: 48px; padding: 18px 14px 6px; font-size: 14px; }
  .lead-form .field label { left: 14px; top: 16px; font-size: 13px; }
  .lead-form .form-agree { font-size: 11.5px; gap: 10px; }
  .lead-form .form-agree input[type=checkbox] { width: 20px; height: 20px; }
  .form-submit { height: 50px; font-size: 14.5px; padding: 0 20px; }
  .form-photo { min-height: 220px; }
  .form-overlay-card { padding: 12px; left: 10px; right: 10px; bottom: 10px; }
  .form-overlay-icon { width: 40px; height: 40px; margin-bottom: 6px; }

  footer.site { padding: 32px 0 16px; }
  .foot-h { font-size: 11px; letter-spacing: 0.14em; }
  .foot-nav a { font-size: 13.5px; }
  .foot-contact .vc-main { font-size: 15px; }
  .foot-pdn { font-size: 12px; line-height: 1.55; color: rgba(255, 255, 255, 0.72); }
  .foot-bot-row { font-size: 12px; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  .form-bullet, .form-submit, .foot-nav a, .form-contact .vc { transition: none !important; }
  .form-bullet:hover, .form-submit:hover, .foot-nav a:hover { transform: none !important; }
}

/* Print — hide form & footer interactive bits */
@media print {
  .form-section, footer.site { box-shadow: none; }
  .form-submit, .form-photo { display: none; }
  footer.site { background: transparent; color: #000; padding: 12px 0; }
  .foot-pdn { color: #333; }
}


/* === prog-price (brand-palette: brand-tint + left brand-line) === */
.prog-price{display:flex;flex-direction:column;gap:4px;padding:14px 18px 14px 22px;margin:8px 0 0;background:var(--c-brand-soft,#e8f3f2);border:1px solid rgba(11,138,134,.18);border-left:4px solid var(--c-brand,#0b8a86);border-radius:12px}
.prog-price-amount{font-size:clamp(20px,2.5vw,26px);font-weight:800;color:var(--c-brand-dark,#003D38);letter-spacing:-.01em}
.prog-price-note{font-size:13.5px;color:#3f5755;line-height:1.45}
@media (max-width:560px){.prog-price{padding:12px 14px 12px 18px}.prog-price-amount{font-size:20px}}

/* === v8 A: hero rebuild === */
/* ============================================================
   HERO v8 — mockup-aligned rebuild
   Left: H1 + mini-form + trust-chips. Right: workshop photo.
   Below grid: 4 icon-features row spanning full card width.
   ============================================================ */
.hero.hero-v8{padding:24px 0 18px}
.hero-v8 .wrap{display:flex; flex-direction:column; gap:18px}

/* Desktop: fit header+hero into ~100vh — card grows so the photo is large and there's no empty space below */
@media(min-width:1025px){
  .hero.hero-v8{ padding:16px 0; }
  .hero-v8 .wrap{ min-height:calc(100vh - 65px - 32px); min-height:calc(100svh - 65px - 32px); }
  .hero-card-v8{ flex:1 1 auto; }
}

.hero-card-v8{
  position:relative;
  border-radius:var(--radius-xl,28px);
  overflow:hidden;
  background:linear-gradient(135deg,#e9f1ef 0%,#dde7e4 100%);
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(420px,1fr);
  min-height:560px;
  box-shadow:var(--shadow,0 14px 32px -16px rgba(15,29,28,.18));
  isolation:isolate;
}

.hero-text-v8{
  position:relative; z-index:2;
  padding:40px 38px 36px;
  display:flex; flex-direction:column; gap:18px;
  justify-content:center;
  min-width:0;
}

.hero-title-v8{
  font-size:clamp(28px,3.6vw,46px);
  font-weight:800;
  letter-spacing:-0.035em;
  line-height:1.07;
  color:var(--c-text,#0F1D1C);
  margin:0;
}
.hero-title-v8 .acc{
  color:var(--c-brand,#0b8a86);
  display:inline;
  background:none;
  padding:0;
  box-shadow:none;
  position:relative;
}
.hero-title-v8 .acc::after{display:none}

.hero-sub-v8{
  font-size:15.5px; line-height:1.55;
  color:var(--c-text-2,#3a4644);
  max-width:54ch; font-weight:500;
  margin:0;
}

/* ----- HERO CTAs (FPV-style: no form, 2 buttons + phone link) ----- */
.hero-ctas-v8{ margin-top:6px; }
.hero-call-link{
  display:none; align-items:center; gap:9px; align-self:flex-start;
  margin-top:12px; color:var(--c-text-2,#3a4644); font-size:14px; font-weight:600;
  text-decoration:none; transition:color .2s;
}
.hero-call-link svg{ color:var(--c-brand,#0b8a86); flex-shrink:0 }
.hero-call-link b{ color:var(--c-text,#0F1D1C); font-weight:800 }
.hero-call-link:hover{ color:var(--c-brand,#0b8a86) }

/* ----- MINI FORM (legacy — hero form removed; kept harmless) ----- */
.hero-mini-form{
  background:#fff;
  border:1px solid rgba(11,138,134,.10);
  border-radius:18px;
  padding:18px;
  display:flex; flex-direction:column; gap:12px;
  box-shadow:0 6px 24px -14px rgba(15,29,28,.18);
  margin-top:4px;
}
.hero-mini-form__fields{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.hero-mini-field{position:relative}
.hero-mini-field input{
  width:100%;
  padding:13px 14px;
  border:1.5px solid #dfe7e5;
  border-radius:10px;
  background:#fafcfc;
  font-size:14px; font-weight:500;
  color:var(--c-text,#0F1D1C);
  font-family:inherit;
  transition:border-color .2s, background .2s;
}
.hero-mini-field input:focus{
  outline:none;
  border-color:var(--c-brand,#0b8a86);
  background:#fff;
}
.hero-mini-field label{
  position:absolute;
  left:14px; top:13px;
  font-size:13.5px;
  color:#5a6a67;
  pointer-events:none;
  transition:transform .18s ease, font-size .18s ease, color .18s ease, background .18s;
  background:transparent;
  padding:0 4px;
}
.hero-mini-field input:focus + label,
.hero-mini-field input:not(:placeholder-shown) + label{
  transform:translateY(-22px) scale(.85);
  color:var(--c-brand,#0b8a86);
  background:#fff;
  font-weight:600;
}
.hero-mini-field input[aria-invalid="true"]{ border-color:#e76262; background:#fff5f5 }

.hero-mini-form__agree{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:10px;
  font-size:11.5px; line-height:1.45;
  color:#5a6a67;
  align-items:start;
}
.hero-mini-form__agree input{
  margin-top:2px; width:16px; height:16px;
  accent-color:var(--c-brand,#0b8a86);
  flex:none;
}
.hero-mini-form__agree .agree-text a{
  color:var(--c-brand,#0b8a86);
  text-decoration:underline;
  font-weight:600;
}

.hero-mini-form__msg{ font-size:12.5px; min-height:0; }
.hero-mini-form__msg:empty{ display:none }

.hero-mini-form__ctas{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:2px;
}
.hero-mini-form__submit{
  background:var(--c-brand,#0b8a86);
  color:#fff;
  padding:13px 16px;
  border-radius:11px;
  font-weight:700; font-size:14px;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:none; cursor:pointer;
  transition:background .2s, transform .2s, box-shadow .2s;
  box-shadow:0 6px 16px -8px rgba(11,138,134,.5);
}
.hero-mini-form__submit:hover{
  background:#097a76;
  transform:translateY(-1px);
  box-shadow:0 10px 22px -10px rgba(11,138,134,.6);
}
.hero-mini-form__call{
  padding:13px 14px;
  border-radius:11px;
  background:#fff;
  color:var(--c-brand-dark,#003D38);
  border:1.5px solid #d6e0de;
  font-weight:700; font-size:13.5px;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition:border-color .2s, color .2s, background .2s;
  text-decoration:none;
}
.hero-mini-form__call:hover{
  border-color:var(--c-brand,#0b8a86);
  color:var(--c-brand,#0b8a86);
  background:#f5fbfa;
}
.hero-mini-form__call svg{ color:var(--c-brand,#0b8a86) }

/* ----- TRUST CHIPS ----- */
.hero-trust-chips{
  display:flex; gap:8px; flex-wrap:wrap;
  margin-top:2px;
}
.hero-trust-chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 12px;
  background:rgba(255,255,255,.85);
  border:1px solid rgba(11,138,134,.14);
  border-radius:999px;
  font-size:12.5px; font-weight:600;
  color:var(--c-brand-dark,#003D38);
  backdrop-filter:blur(4px);
}
.hero-trust-chip svg{
  width:14px; height:14px;
  color:var(--c-brand,#0b8a86);
  flex:none;
}

/* ----- PHOTO ----- */
.hero-photo-v8{
  position:relative; overflow:hidden;
  min-width:0;
  min-height:560px;
}
.hero-photo-v8 img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:75% 34%;
  display:block;
}
/* Soft melt: photo's left edge blends into the card background (desktop split) */
.hero-photo-v8::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(90deg, #e6eeeb 0%, rgba(230,238,235,.72) 13%, rgba(230,238,235,0) 42%);
  pointer-events:none;
}

/* ----- 4 ICON FEATURES ROW (below card, full width) ----- */
.hero-icon-features-row{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
  padding:0;
}
.hero-icon-feat{
  display:flex; align-items:flex-start; gap:12px;
  padding:14px 16px;
  background:#fff;
  border:1px solid rgba(15,29,28,.06);
  border-radius:14px;
  box-shadow:var(--shadow-sm,0 2px 8px -4px rgba(15,29,28,.08));
  min-width:0;
}
.hero-icon-feat__ico{
  flex:none;
  width:38px; height:38px;
  border-radius:10px;
  display:grid; place-items:center;
  background:var(--c-brand-soft,#e8f3f2);
  color:var(--c-brand,#0b8a86);
}
.hero-icon-feat__ico svg{ width:18px; height:18px }
.hero-icon-feat__txt{
  display:flex; flex-direction:column; gap:3px;
  min-width:0;
}
.hero-icon-feat__txt b{
  font-size:13px; font-weight:700;
  color:var(--c-text,#0F1D1C);
  line-height:1.25;
  letter-spacing:-0.005em;
}
.hero-icon-feat__txt span{
  font-size:11.5px; font-weight:500;
  color:var(--c-text-2,#5a6a67);
  line-height:1.35;
}

/* ===== RESPONSIVE ===== */
@media (max-width:1180px){
  .hero-card-v8{ grid-template-columns:minmax(0,1.15fr) minmax(360px,1fr); }
  .hero-text-v8{ padding:36px 30px 32px; gap:16px }
  .hero-icon-features-row{ gap:10px }
  .hero-icon-feat{ padding:12px 14px }
}

@media (max-width:1024px){
  .hero-card-v8{ grid-template-columns:1fr 1fr; min-height:520px }
  .hero-photo-v8{ min-height:520px }
  .hero-mini-form__ctas{ grid-template-columns:1fr }
  .hero-icon-features-row{ grid-template-columns:repeat(2,1fr) }
}

@media (max-width:860px){
  .hero.hero-v8{ padding:16px 0 14px }
  .hero-card-v8{
    grid-template-columns:1fr;
    min-height:auto;
  }
  /* Mobile stack order: H1+sub -> photo -> mini-form -> chips */
  .hero-text-v8{
    display:contents;
  }
  .hero-card-v8{
    display:flex;
    flex-direction:column;
  }
  .hero-text-v8 > .hero-eyebrow{ order:1; margin:24px 22px 0 }
  .hero-title-v8{ order:2; margin:10px 22px 0 }
  .hero-sub-v8{ order:3; margin:8px 22px 0 }
  .hero-ctas-v8{ order:4; margin:18px 22px 0; width:auto }
  .hero-call-link{ order:5; margin:10px 22px 0 }
  .hero-trust-chips{ order:6; margin:14px 18px 18px; justify-content:center }
  .hero-photo-v8{
    order:7;
    min-height:240px; max-height:300px;
    margin:16px 0 0;
  }
  /* photo fills to the card's rounded bottom (full-width); soft top-fade blends it from the card */
  .hero-photo-v8::after{ background:linear-gradient(180deg, #e6eeeb 0%, rgba(230,238,235,.55) 9%, rgba(230,238,235,0) 30%) }
}

@media (max-width:560px){
  .hero-title-v8{ font-size:clamp(26px,7.4vw,34px); }
  .hero-sub-v8{ font-size:14.5px }
  .hero-mini-form{ padding:16px; gap:11px }
  .hero-mini-form__fields{ grid-template-columns:1fr; gap:9px }
  .hero-mini-form__submit{ padding:14px 16px }
  .hero-icon-features-row{ grid-template-columns:1fr; gap:9px }
  .hero-icon-feat{ padding:12px 14px }
  .hero-photo-v8{ min-height:240px; max-height:280px }
}

@media (max-width:414px){
  .hero-text-v8 > .hero-eyebrow,
  .hero-title-v8, .hero-sub-v8{ margin-left:14px; margin-right:14px }
  .hero-mini-form{ margin:14px 10px 0 }
  .hero-trust-chips{ margin:12px 12px 18px }
}

/* === v8 C: why rebuild === */
/* ======================================================================
   v8 — Why БАС: dark-teal section, 4 big photo-cards in one row
   Replaces .why-section / .why-grid / .why-card visual treatment.
   ====================================================================== */
.why-section-v8{
  background:#003D38; /* dark-green from brand */
  color:#fff;
  padding:96px 0;
  position:relative;
  overflow:hidden;
}
.why-section-v8::before{
  /* subtle teal accent on top */
  content:"";
  position:absolute; left:0; right:0; top:0; height:4px;
  background:linear-gradient(90deg, #0B8A86 0%, #FDAD3A 100%);
  opacity:.85;
}

/* Header on dark */
.why-section-v8 .sec-head--on-dark{ text-align:center; margin:0 auto 56px; max-width:880px; }
.why-section-v8 .sec-eyebrow{
  display:inline-block;
  color:#FDAD3A;
  font-size:13px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  margin-bottom:14px;
}
.why-section-v8 .sec-title{
  color:#fff;
  font-size:clamp(28px, 3.4vw, 44px);
  line-height:1.15;
  font-weight:800;
  margin:0 0 18px;
}
.why-section-v8 .acc-on-dark{
  font-style:normal;
  color:#FDAD3A;
}
.why-section-v8 .sec-sub--on-dark{
  color:rgba(255,255,255,.78);
  font-size:17px; line-height:1.6;
  margin:0;
}

/* Grid: 4 in one row on desktop */
.why-grid-v8{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
  margin-top:8px;
}

/* Card */
.why-card-v8{
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 10px 30px rgba(0,0,0,.25), 0 2px 6px rgba(0,0,0,.15);
  transition:transform .25s ease, box-shadow .25s ease;
}
.why-card-v8:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(0,0,0,.32), 0 4px 10px rgba(0,0,0,.18);
}

/* Photo with 4:3 aspect */
.why-photo-v8{
  position:relative;
  aspect-ratio: 4 / 3;
  background:#e8efee;
  overflow:hidden;
}
.why-photo-v8 img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  transition:transform .5s ease;
}
.why-card-v8:hover .why-photo-v8 img{ transform:scale(1.04); }

/* Body */
.why-body-v8{
  padding:20px 20px 24px;
  display:flex; flex-direction:column; gap:8px;
  flex:1;
}
.why-body-v8 h3{
  margin:0;
  font-size:18px; line-height:1.3;
  font-weight:700;
  color:#003D38;
}
.why-body-v8 p{
  margin:0;
  font-size:14.5px; line-height:1.55;
  color:#4a5654;
}

/* Tablet: 2x2 */
@media (max-width:1100px){
  .why-grid-v8{ grid-template-columns:repeat(2, 1fr); gap:20px; }
}

/* Mobile: 1 col */
@media (max-width:640px){
  .why-section-v8{ padding:64px 0; }
  .why-section-v8 .sec-head--on-dark{ margin-bottom:36px; }
  .why-grid-v8{ grid-template-columns:1fr; gap:18px; }
  .why-body-v8{ padding:18px 18px 22px; }
  .why-body-v8 h3{ font-size:17px; }
}

/* Defensive: neutralise inherited gradient/light variant of old .why-section
   when both classes coexist during transition */
.why-section-v8.why-section{ background:#003D38 !important; }
.why-section-v8 .why-grid{ display:none; } /* legacy grid sibling guard */

/* === v8 D: format + choose rebuild === */
/* ============================================================
   FORMAT + CHOOSE — 2-col split sections (mockup-aligned)
   ============================================================ */

/* shared 2-col grid */
.format-split,
.choose-split{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 40px;
  align-items: stretch;
  margin-top: 28px;
}

/* media tiles share visuals */
.format-split__media,
.choose-split__media{
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(180deg,#eef5f4 0%,#dde9e7 100%);
  min-height: 360px;
  box-shadow: 0 8px 24px -16px rgba(0, 61, 56, .25);
}
.format-split__media img,
.choose-split__media img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* ---------- FORMAT: checkmark list (RIGHT) ---------- */
.format-split__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 22px;
  align-content: start;
}
.format-split__media{ aspect-ratio: 4/3; }
.format-split__footer{
  grid-column: 1 / -1;
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
}
.format-split__cta{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  background: #0B8A86;
  color: #ffffff;
  border-radius: 999px;
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  transition: background .18s ease, transform .18s ease, box-shadow .18s ease;
  box-shadow: 0 8px 22px -12px rgba(11,138,134,.5);
}
.format-split__cta:hover{
  background: #003D38;
  transform: translateY(-2px);
  box-shadow: 0 12px 26px -12px rgba(0,61,56,.5);
}
.format-split__cta:focus-visible{
  outline: 3px solid #FDAD3A;
  outline-offset: 3px;
}
.format-split__note{
  margin: 0;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 13.5px;
  color: #4a615e;
}
.format-split__item{
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: start;
  padding: 14px 16px;
  background: #ffffff;
  border: 1px solid #e6efee;
  border-radius: 14px;
  transition: border-color .18s ease;
}
.format-split__item:hover{
  border-color: #c8dedb;
}
.format-split__check{
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #0B8A86;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 40px;
}
.format-split__text{ display: grid; gap: 4px; }
.format-split__text strong{
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.35;
  color: #003D38;
}
.format-split__text span{
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.5;
  color: #56706d;
}

/* ---------- CHOOSE: bullets + CTA (RIGHT) ---------- */
.choose-split__body{
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 22px;
}
.choose-split__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 18px;
}
.choose-split__item{
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: start;
  padding: 14px 16px;
  background: #ffffff;
  border: 1px solid #e6efee;
  border-radius: 14px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.choose-split__item:hover{
  transform: translateY(-2px);
  border-color: #0B8A86;
  box-shadow: 0 10px 22px -16px rgba(11,138,134,.45);
}
.choose-split__icon{
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #0B8A86;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 40px;
}
.choose-split__icon--orange{ background: #FDAD3A; color: #003D38; }
.choose-split__icon--dark{ background: #003D38; color: #FDAD3A; }
.choose-split__divider{
  display: flex;
  align-items: center;
  gap: 12px;
  list-style: none;
  padding: 4px 0;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #6b8582;
}
.choose-split__divider::before,
.choose-split__divider::after{
  content: '';
  flex: 1;
  height: 1px;
  background: #d6e3e1;
}
.choose-split__item--help{
  background: #f3f8f7;
  border-style: dashed;
  border-color: #b5cfcc;
}
.choose-split__dot{
  display: none;
}
.choose-split__dot--orange,
.choose-split__dot--dark{ display: none; }
.choose-split__item strong{
  display: block;
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 700;
  font-size: 17px;
  line-height: 1.35;
  color: #003D38;
  margin-bottom: 4px;
}
.choose-split__item span{
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 500;
  font-size: 14.5px;
  line-height: 1.55;
  color: #56706d;
}

.choose-split__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  align-self: flex-start;
  padding: 16px 28px;
  background: #0B8A86;
  color: #ffffff;
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  border-radius: 12px;
  text-decoration: none;
  box-shadow: 0 10px 24px -12px rgba(11,138,134,.55);
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}
.choose-split__cta:hover{
  background: #0a7975;
  transform: translateY(-1px);
  box-shadow: 0 14px 28px -14px rgba(11,138,134,.7);
}
.choose-split__note{
  margin: 0;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: #3f5755;
}

/* ============================================================
   RESPONSIVE — 1366 / 1024 / 768 / 414 / 375
   ============================================================ */
@media (max-width: 1366px){
  .format-split,
  .choose-split{ gap: 32px; }
  .format-split__media,
  .choose-split__media{ min-height: 340px; }
}

@media (max-width: 1024px){
  .format-split,
  .choose-split{ gap: 28px; }
  .format-split__media,
  .choose-split__media{ min-height: 320px; border-radius: 18px; }
  .format-split__item{ padding: 12px 14px; }
  .format-split__text strong{ font-size: 15.5px; }
  .choose-split__item strong{ font-size: 16px; }
}

@media (max-width: 860px){
  .format-split,
  .choose-split{
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .format-split__media,
  .choose-split__media{
    min-height: 240px;
    aspect-ratio: 16 / 10;
  }
  .format-split__list{ gap: 14px; }
  .choose-split__body{ gap: 20px; }
  .choose-split__cta{
    align-self: stretch;
    width: 100%;
  }
}

@media (max-width: 480px){
  .format-split__media,
  .choose-split__media{
    min-height: 200px;
    border-radius: 14px;
  }
  .format-split__item{
    grid-template-columns: 36px 1fr;
    gap: 12px;
    padding: 12px;
    border-radius: 12px;
  }
  .format-split__check{
    width: 36px; height: 36px;
    flex: 0 0 36px;
  }
  .format-split__check svg{ width: 18px; height: 18px; }
  .format-split__text strong{ font-size: 15px; }
  .format-split__text span{ font-size: 13.5px; }
  .choose-split__item{
    grid-template-columns: 12px 1fr;
    gap: 12px;
    padding: 12px 14px 12px 14px;
  }
  .choose-split__item strong{ font-size: 15.5px; }
  .choose-split__item span{ font-size: 13.5px; }
  .choose-split__cta{
    padding: 14px 22px;
    font-size: 15px;
  }
}

@media (max-width: 375px){
  .format-split,
  .choose-split{ gap: 18px; }
  .format-split__media,
  .choose-split__media{ min-height: 180px; }
}

/* === v8 E: faq+form merge === */
/* ===== E: Merged FAQ + Form section (mockup-aligned) ===== */
.contact-section{padding:var(--section-pad) 0; background:#f6f9f8; position:relative;}
.contact-section .anchor-alias{position:absolute; top:-90px; width:1px; height:1px; pointer-events:none;}
.contact-section .sec-head{text-align:center; max-width:760px; margin:0 auto 40px;}
.contact-section .sec-title em.acc{font-style:normal; color:#FDAD3A;}

.contact-split{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  align-items:start;
}

/* ----- LEFT column: FAQ ----- */
.contact-faq{
  background:#fff;
  border:1px solid #e3ebe9;
  border-radius:20px;
  padding:32px;
  box-shadow:0 8px 28px -16px rgba(0,61,56,.18);
}
.contact-col-head{margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid #e7eeec;}
.contact-col-eyebrow{
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:#0B8A86; background:rgba(11,138,134,.08);
  padding:6px 12px; border-radius:999px; margin-bottom:10px;
}
.contact-col-title{
  font-family:Manrope,sans-serif; font-size:22px; font-weight:800;
  letter-spacing:-.02em; color:#003D38; margin:0; line-height:1.2;
}

.contact-faq .faq-list{display:flex; flex-direction:column; gap:10px;}
.contact-faq .faq-item{
  background:#fafcfb; border:1px solid #e7eeec; border-radius:12px;
  overflow:hidden; transition:border-color .2s, box-shadow .2s, background .2s;
}
.contact-faq .faq-item:hover{border-color:#bcd6d3; background:#fff;}
.contact-faq .faq-item[open]{
  background:#fff; border-color:#0B8A86;
  box-shadow:0 6px 18px -10px rgba(11,138,134,.35);
}
.contact-faq .faq-item summary{
  padding:16px 18px; cursor:pointer; display:flex; align-items:center;
  justify-content:space-between; gap:14px; list-style:none;
}
.contact-faq .faq-item summary::-webkit-details-marker{display:none;}
.contact-faq .faq-q{
  font-size:15px; font-weight:700; color:#003D38;
  letter-spacing:-.005em; line-height:1.35; flex:1;
}
.contact-faq .faq-toggle{
  flex-shrink:0; width:28px; height:28px; border-radius:50%;
  background:#eef4f3; color:#0B8A86; display:flex; align-items:center; justify-content:center;
  position:relative; transition:background .2s, color .2s, transform .25s;
}
.contact-faq .faq-toggle::before,
.contact-faq .faq-toggle::after{
  content:''; position:absolute; background:currentColor; border-radius:1px;
}
.contact-faq .faq-toggle::before{width:12px; height:2px;}
.contact-faq .faq-toggle::after{width:2px; height:12px;}
.contact-faq .faq-item[open] .faq-toggle{
  background:#0B8A86; color:#fff; transform:rotate(45deg);
}
.contact-faq .faq-ans{
  padding:0 18px 18px; font-size:14px; color:#52605e; line-height:1.6;
}

/* ----- RIGHT column: Form card ----- */
.contact-form-card{
  background:#fff;
  border:1px solid #e3ebe9;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 14px 38px -18px rgba(0,61,56,.28);
  position:sticky; top:96px;
}
.contact-form-photo{
  position:relative; width:100%; height:170px; overflow:hidden;
  background:#003D38;
}
.contact-form-photo img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; display:block;
}
.contact-form-photo-grad{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,61,56,.15) 0%, rgba(0,61,56,.55) 70%, rgba(0,61,56,.78) 100%);
}
.contact-form-photo-badge{
  position:absolute; left:20px; bottom:16px; z-index:2;
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.95); color:#003D38;
  padding:8px 14px; border-radius:999px;
  font-size:12px; font-weight:700; letter-spacing:.01em;
  box-shadow:0 4px 14px -4px rgba(0,0,0,.25);
}
.contact-form-photo-badge svg{color:#0B8A86;}

.contact-form-body{padding:28px 28px 30px;}
.contact-form-eyebrow{
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:#0B8A86; background:rgba(11,138,134,.08);
  padding:6px 12px; border-radius:999px; margin-bottom:12px;
}
.contact-form-title{
  font-family:Manrope,sans-serif; font-size:26px; font-weight:800;
  letter-spacing:-.025em; line-height:1.1; color:#003D38;
  margin:0 0 10px;
}
.contact-form-title .acc{color:#FDAD3A; font-style:normal;}
.contact-form-sub{
  font-size:14px; color:#52605e; line-height:1.55; margin:0 0 20px;
}

.contact-lead-form{
  display:grid; grid-template-columns:1fr 1fr; gap:12px 12px;
  background:transparent; padding:0; box-shadow:none; border-radius:0;
  position:relative; color:#003D38;
}
.contact-lead-form .field{
  position:relative; display:block; grid-column:span 1;
}
.contact-lead-form .field:nth-child(3),
.contact-lead-form .field:nth-child(4){grid-column:1 / -1;}
.contact-lead-form .field input{
  width:100%; padding:14px 14px 14px 14px;
  background:#fafcfb; border:1.5px solid #dde6e4; border-radius:10px;
  font-family:Manrope,sans-serif; font-size:14px; color:#003D38;
  transition:border-color .15s, background .15s, box-shadow .15s;
  outline:none;
}
.contact-lead-form .field input::placeholder{color:transparent;}
.contact-lead-form .field label{
  position:absolute; left:14px; top:14px; pointer-events:none;
  font-size:14px; font-weight:500; color:#8a9997;
  background:transparent; padding:0 4px;
  transition:transform .15s, font-size .15s, color .15s, background .15s, top .15s;
}
.contact-lead-form .field input:focus{
  border-color:#0B8A86; background:#fff;
  box-shadow:0 0 0 3px rgba(11,138,134,.12);
}
.contact-lead-form .field input:focus + label,
.contact-lead-form .field input:not(:placeholder-shown) + label{
  top:-7px; font-size:11px; font-weight:700; color:#0B8A86;
  background:#fff; letter-spacing:.02em;
}
.contact-lead-form .honey{position:absolute; left:-9999px; opacity:0; pointer-events:none;}

.contact-lead-form .form-agree{
  grid-column:1 / -1; display:flex; gap:10px; align-items:flex-start;
  font-size:11.5px; color:#6b7977; line-height:1.5; margin-top:4px;
}
.contact-lead-form .form-agree input[type=checkbox]{
  width:16px; height:16px; flex-shrink:0; margin-top:2px;
  accent-color:#0B8A86; cursor:pointer;
}
.contact-lead-form .form-agree a{color:#0B8A86; text-decoration:underline;}
.contact-lead-form [data-bas-captcha]{grid-column:1 / -1; min-height:0;}
.contact-lead-form .form-msg{grid-column:1 / -1; font-size:13px; min-height:0;}
.contact-lead-form .form-msg:empty{display:none;}

.contact-form-submit{
  grid-column:1 / -1;
  width:100%; padding:15px 22px;
  background:#0B8A86; color:#fff; border:none; border-radius:10px;
  font-family:Manrope,sans-serif; font-size:15px; font-weight:700;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  cursor:pointer; transition:background .2s, transform .15s, box-shadow .2s;
  box-shadow:0 8px 22px -10px rgba(11,138,134,.6);
  margin-top:4px;
}
.contact-form-submit:hover{
  background:#097672; transform:translateY(-1px);
  box-shadow:0 12px 28px -10px rgba(11,138,134,.7);
}

.contact-form-trust{
  grid-column:1 / -1;
  display:flex; flex-wrap:wrap; gap:6px 14px;
  padding-top:14px; margin-top:6px; border-top:1px dashed #e3ebe9;
}
.contact-form-trust-item{
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; font-weight:600; color:#52605e;
}
.contact-form-trust-item svg{color:#0B8A86;}

/* ----- Responsive ----- */
@media (max-width:1100px){
  .contact-split{grid-template-columns:1fr; gap:24px;}
  .contact-form-card{position:static;}
}
@media (max-width:720px){
  .contact-section{padding:48px 0;}
  .contact-section .sec-head{margin-bottom:28px;}
  .contact-faq{padding:22px 20px;}
  .contact-col-title{font-size:19px;}
  .contact-faq .faq-q{font-size:14px;}
  .contact-faq .faq-item summary{padding:14px 16px;}
  .contact-faq .faq-ans{padding:0 16px 16px; font-size:13.5px;}
  .contact-form-photo{height:140px;}
  .contact-form-body{padding:22px 20px 24px;}
  .contact-form-title{font-size:22px;}
  .contact-lead-form{grid-template-columns:1fr;}
  .contact-lead-form .field,
  .contact-lead-form .field:nth-child(3),
  .contact-lead-form .field:nth-child(4){grid-column:1 / -1;}
}
@media (prefers-reduced-motion: reduce){
  .contact-faq .faq-toggle,
  .contact-faq .faq-item,
  .contact-form-submit{transition:none;}
}

/* === v8 B: audience section === */
/* === Audience section: 5-card layout override === */
.audience-section{background:var(--c-bg, #fff)}
.audience-section .sec-sub{margin-top:14px; color:var(--c-text-muted); font-size:15px; line-height:1.55; max-width:680px; margin-left:auto; margin-right:auto}
.aud-grid.aud-grid-5{grid-template-columns:repeat(5,1fr); gap:16px}
.aud-grid.aud-grid-5 .aud-card .photo{aspect-ratio:4/5}
.aud-grid.aud-grid-5 .aud-body{padding:18px 16px; display:flex; flex-direction:column; gap:8px}
.aud-grid.aud-grid-5 .aud-title{font-size:clamp(15px, 1.05vw + 8px, 17px); font-weight:700; line-height:1.3; color:var(--c-text)}
.aud-grid.aud-grid-5 .aud-desc{font-size:13.5px; line-height:1.5; color:var(--c-text-muted)}
.aud-grid.aud-grid-5 .aud-num{width:38px; height:38px; font-size:14px; border-radius:10px; top:12px; left:12px}
@media(max-width:1180px) and (min-width:761px){.aud-grid.aud-grid-5{grid-template-columns:repeat(3,1fr)} .aud-grid.aud-grid-5 .aud-card:nth-child(4){grid-column:1/span 2; flex-direction:row} .aud-grid.aud-grid-5 .aud-card:nth-child(4) .photo{width:45%; aspect-ratio:auto} .aud-grid.aud-grid-5 .aud-card:nth-child(5){grid-column:auto}}
@media(max-width:760px) and (min-width:481px){.aud-grid.aud-grid-5{grid-template-columns:repeat(2,1fr)} .aud-grid.aud-grid-5 .aud-card:nth-child(5){grid-column:1/-1; flex-direction:row} .aud-grid.aud-grid-5 .aud-card:nth-child(5) .photo{width:45%; aspect-ratio:auto}}
@media(max-width:480px){.aud-grid.aud-grid-5{grid-template-columns:1fr; gap:14px} .aud-grid.aud-grid-5 .aud-card .photo{aspect-ratio:16/10} .aud-grid.aud-grid-5 .aud-card:nth-child(4),.aud-grid.aud-grid-5 .aud-card:nth-child(5){flex-direction:column} .aud-grid.aud-grid-5 .aud-card:nth-child(4) .photo,.aud-grid.aud-grid-5 .aud-card:nth-child(5) .photo{width:100%}}

/* === v8.1 Hero fixes === */
.skip-link{
  position:absolute; left:-9999px; top:0;
  background:var(--c-brand-dark,#003D38); color:#fff;
  padding:10px 16px; border-radius:0 0 8px 0;
  font-weight:600; font-size:14px;
  z-index:10000; text-decoration:none;
}
.skip-link:focus{ left:0; outline:3px solid #fdad3a; outline-offset:2px }

.hero-mini-form__call-link{
  display:inline-flex; align-items:center; gap:8px;
  color:var(--c-brand-dark,#003D38);
  text-decoration:none;
  font-size:14px; font-weight:500;
  padding:8px 4px;
  transition:color .2s;
}
.hero-mini-form__call-link b{ color:var(--c-brand,#0b8a86); font-weight:700; white-space:nowrap }
.hero-mini-form__call-link:hover{ color:var(--c-brand,#0b8a86) }
.hero-mini-form__call-link svg{ color:var(--c-brand,#0b8a86); flex-shrink:0 }
.hero-mini-form__call-link:focus-visible{ outline:2px solid var(--c-brand,#0b8a86); outline-offset:3px; border-radius:4px }
@media(max-width:480px){.aud-grid.aud-grid-5{grid-template-columns:1fr; gap:14px} .aud-grid.aud-grid-5 .aud-card .photo{aspect-ratio:16/10} .aud-grid.aud-grid-5 .aud-card:nth-child(4),.aud-grid.aud-grid-5 .aud-card:nth-child(5){flex-direction:column} .aud-grid.aud-grid-5 .aud-card:nth-child(4) .photo,.aud-grid.aud-grid-5 .aud-card:nth-child(5) .photo{width:100%}}
.aud-badges{display:flex; flex-wrap:wrap; gap:6px; margin-bottom:4px}
.aud-badge{display:inline-flex; align-items:center; gap:4px; padding:4px 10px; border-radius:999px; font-size:11.5px; font-weight:700; letter-spacing:.02em; line-height:1; text-transform:uppercase; white-space:nowrap}
.aud-badge--free{background:#003D38; color:#fff}
.aud-badge--svo{background:#FDAD3A; color:#1a1f1e}
.aud-grid.aud-grid-5 .aud-badge{font-size:10.5px; padding:4px 8px}
@media(max-width:480px){.aud-grid.aud-grid-5{grid-template-columns:1fr; gap:14px} .aud-grid.aud-grid-5 .aud-card .photo{aspect-ratio:16/10}}

/* ============================================================
   v8.1 TRUST SECTION — фиксы агента: sec-head, focus-visible,
   chevron-аффорданс, нейтрализация регрессии от literal 

   в строке 1377. Этот блок ОБЯЗАТЕЛЬНО идёт после неё, чтобы
   перебить любой повреждённый каскад.
   ============================================================ */
.trust-section .sec-head.trust-sec-head{ text-align:center; max-width:720px; margin:0 auto 36px; }
.trust-section .sec-head.trust-sec-head .sec-eyebrow{ display:inline-block; font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:#0B8A86; margin-bottom:10px; }
.trust-section .sec-head.trust-sec-head .sec-title{ font-family:'Manrope',system-ui,sans-serif; font-size:clamp(24px, 3vw, 36px); font-weight:800; letter-spacing:-0.025em; line-height:1.1; color:#003D38; margin:0; }

/* CTA-affordance: «Перейти к заявке →» только для ссылки-карточки */
.trust-section .trust-card{ position:relative; }
.trust-section a.trust-card .trust-card__cta{ display:inline-flex; align-items:center; gap:6px; margin-top:auto; padding-top:10px; font-size:13px; font-weight:700; color:#0B8A86; letter-spacing:-0.01em; transition:gap .25s ease, color .25s ease; }
.trust-section a.trust-card .trust-card__cta svg{ transition:transform .25s ease; }
.trust-section a.trust-card:hover .trust-card__cta{ gap:10px; color:#003D38; }
.trust-section a.trust-card:hover .trust-card__cta svg{ transform:translateX(2px); }

/* Focus-visible: используем inset box-shadow вместо outline,
   чтобы не клипалось overflow:hidden родителя (WCAG 2.4.7) */
.trust-section a.trust-card:focus-visible{ outline:none; box-shadow:inset 0 0 0 3px #0B8A86, 0 0 0 4px rgba(11,138,134,.18); border-color:#0B8A86; }
.trust-section a.trust-card:focus-visible h3{ color:#0B8A86; }

/* Breakpoint-консистентность: на ровно 1024px переключаемся на 2 колонки,
   чтобы текст лицензии не сжимался в 5 строк на tablet-1024 (issue #3) */
@media (min-width:1025px) and (max-width:1180px){
  .trust-section .trust-grid{ grid-template-columns:repeat(2, 1fr); gap:18px; }
}

/* Mobile-консистентность 414–520: одна колонка с увеличенной читаемостью */
@media (max-width:520px){
  .trust-section .sec-head.trust-sec-head{ margin-bottom:24px; }
  .trust-section .sec-head.trust-sec-head .sec-title{ font-size:22px; }
}


/* ============================================================
   TEACHERS — fixes v8.1 (consolidate, remove false affordance,
   cleanup dead rules, adjust breakpoints, mobile aspect-ratio)
   ============================================================ */

/* Disable false-affordance hover lift/zoom on non-link teacher cards.
   Cards are not links; lift+zoom implied clickability. Keep subtle border accent. */
.teacher:not(.teacher-cta):not(a):hover{
  transform: none;
  box-shadow: var(--shadow-sm);
  border-color: var(--c-brand-soft);
}
.teacher:not(.teacher-cta):not(a):hover .photo img{
  transform: translateZ(0);
}

/* Dead legacy rules cleanup — neutralize obsolete .teachers selector
   (real class is .teachers-grid; .teachers existed in legacy CSS) */
.teachers{ all: unset; }

/* Breakpoint correction: keep 4-up on tablet landscape 1024px.
   Switch to 2-col only ≤980px (was 1100px) to avoid cramped 2-up on 1024. */
@media (min-width: 981px) and (max-width: 1100px){
  .teachers-grid{
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 16px;
  }
  .teacher .photo{ aspect-ratio: 3 / 4; }
  .teacher-name{ font-size: clamp(14px, 1.2vw, 16px); }
  .teacher-bio{ font-size: 13px; }
}

/* Mobile <480 — cap photo height, square ratio to compress vertical scroll */
@media (max-width: 480px){
  .teacher .photo{
    aspect-ratio: 1 / 1;
    max-height: 60vw;
  }
  .teacher .photo img{
    object-position: center 22%;
  }
}

/* CTA card slot — fills 5th grid cell */
.teacher.teacher-cta{
  background: var(--c-brand-soft);
  border: 1px dashed var(--c-brand);
  display: grid;
  place-items: center;
  text-align: center;
  padding: 28px 22px;
  gap: 14px;
  align-content: center;
}
.teacher.teacher-cta:hover{ transform: none; box-shadow: var(--shadow); }
.teacher.teacher-cta .ic{
  width: 54px; height: 54px;
  border-radius: 50%;
  background: var(--c-brand);
  color: #fff;
  display: grid; place-items: center;
  flex: none;
}
.teacher.teacher-cta h4{
  font-weight: 800;
  font-size: clamp(15px, 1.3vw, 17px);
  color: var(--c-brand-dark);
  letter-spacing: -0.015em;
  line-height: 1.25;
  margin: 0;
  max-width: 24ch;
}
.teacher.teacher-cta .btn{
  padding: 11px 22px;
  font-size: 13.5px;
  font-weight: 700;
}
@media (max-width: 520px){
  .teacher.teacher-cta{ padding: 26px 18px; }
}

/* === v8.1 contact: a11y focus + per-field errors + mobile order === */
.contact-form-submit:focus-visible{outline:3px solid #003D38; outline-offset:3px; box-shadow:0 0 0 5px rgba(255,255,255,.9);}
.contact-faq .faq-item summary:focus-visible{outline:none; box-shadow:inset 0 0 0 3px #0B8A86; border-radius:12px;}
.contact-lead-form .field{position:relative;}
.contact-lead-form .field-err{display:none; grid-column:1 / -1; margin-top:6px; font-size:12.5px; line-height:1.4; color:#c53030; font-weight:600;}
.contact-lead-form .field.has-err .field-err:not(:empty){display:block;}
.contact-lead-form .field.has-err input{border-color:#c53030; background:#fff5f5;}
.contact-lead-form .req-star{color:#c53030; margin-left:2px; font-weight:700;}
.contact-form-sub .req-legend{display:block; margin-top:6px; font-size:12.5px; color:#6b8582;}
@media (max-width:1100px){
  .contact-split{display:flex; flex-direction:column;}
  .contact-split .contact-form-card{order:1;}
  .contact-split .contact-faq{order:2;}
}

/* ===== bas-* structural aliases (Tier0): #how-to-choose uses bas-section/-container/-head/-title/-sub which were undefined ===== */
.bas-section{ padding:var(--section-pad) 0; position:relative; }
.bas-container{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.bas-section-head{ text-align:center; max-width:740px; margin:0 auto 48px; }
.bas-section-title{ font-size:clamp(28px,3.6vw,44px); font-weight:800; letter-spacing:-.03em; line-height:1.08; color:#003D38; }
.bas-section-sub{ margin-top:14px; font-size:16px; color:var(--c-text-muted); line-height:1.55; max-width:60ch; margin-inline:auto; }
@media(max-width:768px){ .bas-section-head{ margin-bottom:32px; } }

/* ===== Teachers 3-card authoritative grid (Tier: overrides legacy .teachers-grid soup incl. 981-1100 repeat(4)!important) ===== */
#teachers .teachers-grid{ grid-template-columns:repeat(3,1fr) !important; max-width:1040px; margin-inline:auto; gap:20px; }
@media(max-width:760px){ #teachers .teachers-grid{ grid-template-columns:1fr !important; max-width:420px; gap:18px; } }

/* ===== COMPACT PROGRAM CARDS (pcA / Essentials) ===== */
/* =====================================================
   pcA — "Essentials" program cards (scoped, self-contained)
   Requires brand CSS custom props from main.css :root
   ===================================================== */

/* Grid: 3 cols ≥1180 px, 1 col below — no orphan risk */
.pcA-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1220px;
  margin-inline: auto;
  align-items: stretch;
}
@media (max-width: 1179px) {
  .pcA-grid {
    grid-template-columns: 1fr;
    max-width: 560px;
    margin-inline: auto;
    gap: 16px;
  }
}

/* Card shell */
.pcA-card {
  position: relative;
  background: var(--c-paper, #fff);
  border: 1.5px solid var(--c-line, #E6E2D8);
  border-radius: var(--radius-lg, 20px);
  padding: 24px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition: transform .28s, box-shadow .28s, border-color .22s;
}
.pcA-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg, 0 30px 60px -24px rgba(15,29,28,.22));
  border-color: var(--c-brand, #0b8a86);
}

/* Featured (Механик) */
.pcA-card.pcA-featured {
  background: linear-gradient(160deg, var(--c-brand-tint, #f3faf9) 0%, #fff 55%);
  border: 2px solid var(--c-brand, #0b8a86);
  box-shadow: 0 18px 40px -16px rgba(11,138,134,.28), 0 4px 12px -6px rgba(11,138,134,.14);
}
.pcA-card.pcA-featured:hover {
  transform: translateY(-7px);
  box-shadow: 0 28px 52px -18px rgba(11,138,134,.42), 0 8px 20px -10px rgba(11,138,134,.18);
}
@media (min-width: 1180px) {
  .pcA-card.pcA-featured {
    transform: translateY(-6px);
  }
  .pcA-card.pcA-featured:hover {
    transform: translateY(-10px);
  }
}

/* "Рекомендуем" badge */
.pcA-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  padding: 5px 14px;
  background: var(--c-accent, #fdad3a);
  color: var(--c-text, #0F1D1C);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 2px solid #fff;
  box-shadow: 0 8px 22px -6px rgba(253,173,58,.6);
  white-space: nowrap;
}

/* Header row: num + name */
.pcA-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
  margin-bottom: 14px;
}
.pcA-num {
  font-size: 26px;
  font-weight: 800;
  color: var(--c-brand, #0b8a86);
  line-height: 1;
  letter-spacing: -.04em;
  padding: 6px 11px;
  background: var(--c-brand-soft, #e8f3f2);
  border-radius: 12px;
  min-width: 52px;
  text-align: center;
  align-self: flex-start;
}
.pcA-name {
  font-size: clamp(16px, 1.9vw, 19px);
  font-weight: 800;
  letter-spacing: -.025em;
  line-height: 1.2;
  color: var(--c-text, #0F1D1C);
  margin: 0;
}

/* Meta chips row */
.pcA-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}
.pcA-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: var(--c-bg-soft, #F5F7F4);
  border: 1px solid var(--c-line, #E6E2D8);
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--c-text-2, #3a4644);
  line-height: 1;
}
.pcA-chip svg {
  width: 12px;
  height: 12px;
  color: var(--c-brand, #0b8a86);
  flex: none;
}
.pcA-chip b {
  color: var(--c-brand-dark, #003D38);
  font-weight: 800;
}

/* Tiny meta line (age / format / requirements) */
.pcA-meta-line {
  font-size: 11.5px;
  color: var(--c-text-muted, #6b7977);
  margin-bottom: 12px;
  line-height: 1.4;
}
.pcA-meta-line b {
  color: var(--c-text-2, #3a4644);
  font-weight: 700;
}

/* Price block */
.pcA-price-block {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 10px 14px 10px 16px;
  background: var(--c-brand-soft, #e8f3f2);
  border-left: 3px solid var(--c-brand, #0b8a86);
  border-radius: 10px;
  margin-bottom: 16px;
}
.pcA-price-amount {
  font-size: clamp(22px, 2.4vw, 26px);
  font-weight: 800;
  color: var(--c-brand-dark, #003D38);
  letter-spacing: -.03em;
  line-height: 1;
  white-space: nowrap;
}
.pcA-price-note {
  font-size: 11.5px;
  color: var(--c-text-muted, #6b7977);
  line-height: 1.35;
}

/* Skills section */
.pcA-skills-label {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-brand, #0b8a86);
  margin-bottom: 8px;
}
.pcA-skills {
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.pcA-skills li {
  display: grid;
  grid-template-columns: 15px 1fr;
  gap: 8px;
  align-items: start;
  font-size: 13px;
  line-height: 1.4;
  color: var(--c-text, #0F1D1C);
}
/* Checkmark dot */
.pcA-ck {
  display: block;
  width: 15px;
  height: 15px;
  margin-top: 1px;
  flex: none;
  background: var(--c-brand-soft, #e8f3f2);
  border-radius: 50%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%230b8a86' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' d='m5 8 2 2 4-4'/></svg>");
  background-position: center;
  background-size: 15px;
}

/* Spacer to push footer down */
.pcA-spacer {
  flex: 1;
}

/* Outcome chip — highlighted footer */
.pcA-outcome {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  background: var(--c-brand-dark, #003D38);
  color: #fff;
  border-radius: 10px;
  font-size: 12.5px;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 12px;
}
.pcA-outcome svg {
  width: 15px;
  height: 15px;
  flex: none;
  opacity: .85;
}
.pcA-card.pcA-featured .pcA-outcome {
  background: var(--c-brand, #0b8a86);
}

/* CTA row */
.pcA-cta-row {
  display: flex;
  gap: 8px;
}
.pcA-cta-row .btn {
  flex: 1 1 0;
  justify-content: center;
  padding: 11px 14px;
  font-size: 13px;
  min-width: 0;
}
.pcA-cta-row .btn .arr {
  width: 18px;
  height: 18px;
  background: rgba(255,255,255,.18);
  border-radius: 50%;
  display: grid;
  place-items: center;
}

/* Mobile tightening */
@media (max-width: 600px) {
  .pcA-card {
    padding: 20px 16px 16px;
  }
  .pcA-cta-row {
    flex-direction: column;
  }
  .pcA-cta-row .btn {
    width: 100%;
  }
  .pcA-price-amount {
    font-size: 22px;
  }
  .pcA-name {
    font-size: 16px;
  }
}

/* ===== pcA v2 — marketing benefit pills + cross-card row alignment ===== */

/* Benefit / discount pills (visual marketing) */
.pcA-perks {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}
.pcA-perk {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px 5px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: .005em;
  white-space: nowrap;
}
.pcA-perk svg { width: 12px; height: 12px; flex: none; }
.pcA-perk--svo  { background: #FFF1DC; color: #A85B00; border: 1px solid #F6D9AE; }
.pcA-perk--free { background: #E6F5EC; color: #1C7A41; border: 1px solid #C3E7CF; }
.pcA-perk--fast { background: #E7F1FB; color: #2A5B9E; border: 1px solid #CFE0F4; }

/* Floor so 1-line and 2-line document plates match */
.pcA-outcome { min-height: 54px; }

/* Desktop: align every internal "plate" row across the 3 cards via subgrid */
@media (min-width: 1180px) {
  .pcA-grid {
    grid-template-rows: repeat(9, auto);
  }
  .pcA-card {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 9;
    gap: 0;
  }
  .pcA-card > .pcA-spacer { display: none; }      /* subgrid bottom-aligns; spacer not needed */
  .pcA-card.pcA-featured { transform: none; }      /* keep rows level; stands out via border/shadow/badge */
  .pcA-card.pcA-featured:hover { transform: translateY(-6px); }
}

/* ===== Audience polish: overlay badges + desktop row alignment ===== */
.aud-badge--overlay {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  box-shadow: 0 6px 16px -6px rgba(0,0,0,.45);
  border: 1.5px solid rgba(255,255,255,.85);
}
.aud-badge--overlay.aud-badge--svo  { background: #FDAD3A; color: #1a1f1e; }
.aud-badge--overlay.aud-badge--free { background: #003D38; color: #fff; }

/* subtle gradient unifies varied photos and lifts the number/badge */
.aud-card .photo::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: linear-gradient(to bottom, rgba(15,29,28,.20), transparent 26%, transparent 78%, rgba(15,29,28,.14));
}
.aud-card .photo img { object-position: center 30%; }

/* desktop 5-up: equalize title block so descriptions line up across cards */
@media (min-width: 1181px) {
  .aud-grid.aud-grid-5 .aud-title { min-height: 68px; }
}

/* ===== Trust section: feature tags + MAX action card ===== */
.trust-tag {
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px 6px 10px;
  background: rgba(11,138,134,.08);
  color: #0B6B68;
  border: 1px solid rgba(11,138,134,.16);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -.01em;
}
.trust-tag::before {
  content: "";
  width: 14px; height: 14px; flex: none;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%230B8A86' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round' d='m4 8 2.5 2.5L12 5'/></svg>") center/14px no-repeat;
}
.trust-tag--mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0;
}
/* MAX = clearly the interactive action card */
.trust-section .trust-card--max {
  background: linear-gradient(160deg, rgba(11,138,134,.08) 0%, rgba(11,138,134,.02) 60%);
  border-color: rgba(11,138,134,.30);
}
.trust-section .trust-card--max .ico { background: #0B8A86; color: #ffffff; }
.trust-section .trust-card--max:hover .ico { background: #003D38; color: #ffffff; }

/* ===== #why "Актуальность" redesign: clean icon-cards (same language as trust) ===== */
.why-section-v8 .sec-sub--on-dark { max-width: 720px; margin-left: auto; margin-right: auto; }

.why-grid-v9 {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.whyi-card {
  background: #fff;
  border-radius: 18px;
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.22), 0 2px 6px rgba(0,0,0,.12);
  transition: transform .25s ease, box-shadow .25s ease;
}
.whyi-card:hover { transform: translateY(-5px); box-shadow: 0 20px 44px rgba(0,0,0,.30); }
.whyi-ico {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: rgba(11,138,134,.10);
  color: #0B8A86;
  display: grid; place-items: center;
  flex: none;
  transition: background .25s, color .25s, transform .25s;
}
.whyi-ico svg { width: 26px; height: 26px; }
.whyi-card:hover .whyi-ico { background: #0B8A86; color: #fff; transform: rotate(-6deg) scale(1.06); }
.whyi-title {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.28;
  letter-spacing: -.02em;
  color: #003D38;
}
.whyi-desc {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: #4a5654;
}
.whyi-stat {
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 13px;
  background: #FFF3E0;
  color: #A85B00;
  border: 1px solid #F6DCAE;
  border-radius: 12px;
  font-size: 12.5px;
  font-weight: 700;
  line-height: 1.3;
}
.whyi-stat svg { width: 15px; height: 15px; flex: none; }
.whyi-stat b { color: #8a4a00; font-weight: 800; }

@media (min-width: 1101px) { .whyi-title { min-height: 44px; } }
@media (max-width: 1100px) { .why-grid-v9 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .why-grid-v9 { grid-template-columns: 1fr; gap: 16px; } .whyi-card { padding: 22px 20px; } }

/* ===== #why: rounded inset panel + diversified background ===== */
.why-section-v8 {
  width: min(calc(100% - 2 * clamp(14px, 3vw, 40px)), 1400px);
  max-width: none;            /* neutralize .std's ultra-wide max-width so the panel stays centred */
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(14px, 2vw, 28px);
  margin-bottom: clamp(14px, 2vw, 28px);
  border-radius: clamp(24px, 3vw, 44px);
  background:
    radial-gradient(115% 80% at 88% -12%, rgba(11,138,134,.42) 0%, rgba(11,138,134,0) 55%),
    radial-gradient(95% 80% at -6% 112%, rgba(253,173,58,.13) 0%, rgba(253,173,58,0) 55%),
    linear-gradient(150deg, #013a34 0%, #003D38 52%, #02493f 100%);
  box-shadow: 0 34px 80px -44px rgba(0,61,56,.60);
}
.why-section-v8::before { display: none; }
.why-section-v8::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(rgba(255,255,255,.055) 1px, transparent 1.6px);
  background-size: 24px 24px;
  -webkit-mask-image: radial-gradient(130% 90% at 50% 0%, #000 22%, transparent 72%);
          mask-image: radial-gradient(130% 90% at 50% 0%, #000 22%, transparent 72%);
}
.why-section-v8 .wrap { position: relative; z-index: 1; }

@media (max-width: 560px) {
  .why-section-v8 { width: min(calc(100% - 24px), 1400px); border-radius: 22px; }
}

/* ===== #why CTA: amber default -> teal on hover ===== */
#why .why-cta-v8 .btn-primary {
  background: var(--c-accent, #fdad3a);
  color: #003D38;
  box-shadow: 0 12px 28px -10px rgba(253,173,58,.50);
}
#why .why-cta-v8 .btn-primary:hover {
  background: var(--c-brand-strong, #086663);
  color: #ffffff;
  box-shadow: 0 18px 38px -12px rgba(11,138,134,.55);
}

/* ===== #format redesign: format-mode cards + "included" panel ===== */
.bas-format .fmt-modes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 14px 0 22px;
}
.fmt-mode {
  position: relative;
  background: #fff;
  border: 1.5px solid var(--c-line, #E6EAEA);
  border-radius: 18px;
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.fmt-mode:hover {
  transform: translateY(-5px);
  box-shadow: 0 22px 46px -24px rgba(0,61,56,.24);
  border-color: rgba(11,138,134,.30);
}
.fmt-mode--featured {
  border-color: var(--c-brand, #0b8a86);
  background: linear-gradient(160deg, var(--c-brand-tint, #f3faf9) 0%, #fff 60%);
  box-shadow: 0 16px 38px -20px rgba(11,138,134,.32);
}
.fmt-badge {
  position: absolute;
  top: -12px; left: 24px;
  background: var(--c-accent, #fdad3a);
  color: #003D38;
  font-size: 11px; font-weight: 800;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 999px;
  border: 2px solid #fff;
  box-shadow: 0 8px 20px -6px rgba(253,173,58,.55);
}
.fmt-ico {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: rgba(11,138,134,.10);
  color: #0B8A86;
  display: grid; place-items: center;
  flex: none;
  transition: background .25s, color .25s, transform .25s;
}
.fmt-ico svg { width: 26px; height: 26px; }
.fmt-mode:hover .fmt-ico { transform: rotate(-6deg) scale(1.06); }
.fmt-mode--featured .fmt-ico { background: #0B8A86; color: #fff; }
.fmt-mode__name { margin: 0; font-size: 19px; font-weight: 800; letter-spacing: -.02em; color: #003D38; }
.fmt-mode__desc { margin: 0; font-size: 14px; line-height: 1.55; color: #4a5654; }

.fmt-extras {
  background: var(--c-brand-soft, #e8f3f2);
  border: 1px solid rgba(11,138,134,.14);
  border-radius: 18px;
  padding: 22px 26px;
}
.fmt-extras__title {
  margin: 0 0 16px;
  font-size: 11px; font-weight: 800;
  letter-spacing: .12em; text-transform: uppercase;
  color: #0B8A86;
}
.fmt-extras__list {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.fmt-extras__list li { display: flex; gap: 12px; align-items: flex-start; }
.fmt-extras__ico {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: #fff;
  color: #0B8A86;
  display: grid; place-items: center;
  flex: none;
  box-shadow: 0 4px 12px -6px rgba(0,61,56,.20);
}
.fmt-extras__ico svg { width: 20px; height: 20px; }
.fmt-extras__list strong { display: block; font-size: 14.5px; font-weight: 700; color: #003D38; line-height: 1.3; margin-bottom: 3px; }
.fmt-extras__list span { font-size: 12.5px; line-height: 1.5; color: #52605e; }

@media (max-width: 1024px) {
  .bas-format .fmt-modes { grid-template-columns: 1fr; }
  .fmt-extras__list { grid-template-columns: 1fr; gap: 16px; }
}

/* ===== #programs picker (merged "Как выбрать") ===== */
.programs-section .prog-pick {
  margin-top: 30px;
  background: linear-gradient(160deg, var(--c-brand-soft, #e8f3f2) 0%, #ffffff 72%);
  border: 1px solid rgba(11,138,134,.16);
  border-radius: 20px;
  padding: 26px 28px;
}
.prog-pick__title { margin: 0 0 4px; font-size: 19px; font-weight: 800; letter-spacing: -.02em; color: #003D38; }
.prog-pick__sub { margin: 0 0 18px; font-size: 14px; color: #52605e; }
.prog-pick__intents { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 18px; }
.prog-pick__intent {
  display: flex; gap: 12px; align-items: center;
  background: #fff; border: 1px solid rgba(11,138,134,.14);
  border-radius: 14px; padding: 14px 16px;
  transition: border-color .2s, transform .2s;
}
.prog-pick__intent:hover { border-color: rgba(11,138,134,.32); transform: translateY(-2px); }
.prog-pick__ico { width: 42px; height: 42px; border-radius: 11px; background: rgba(11,138,134,.10); color: #0B8A86; display: grid; place-items: center; flex: none; }
.prog-pick__ico svg { width: 22px; height: 22px; }
.prog-pick__if { display: block; font-size: 12px; color: #6b7977; line-height: 1.25; margin-bottom: 2px; }
.prog-pick__intent strong { display: block; font-size: 14.5px; font-weight: 800; color: #003D38; line-height: 1.25; letter-spacing: -.01em; }
.prog-pick__help { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; border-top: 1px dashed rgba(11,138,134,.22); padding-top: 18px; }
.prog-pick__help-text { margin: 0; font-size: 14px; line-height: 1.5; color: #3a4644; max-width: 560px; }
.prog-pick__cta { flex: none; }
@media (max-width: 860px) {
  .programs-section .prog-pick { padding: 22px 20px; }
  .prog-pick__intents { grid-template-columns: 1fr; }
  .prog-pick__help { flex-direction: column; align-items: stretch; }
  .prog-pick__cta { width: 100%; justify-content: center; }
}

/* ===== #audience redesign: icon-cards (no photos) ===== */
.audience-section .audi-grid {
  list-style: none; margin: 8px 0 0; padding: 0;
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 18px;
}
.audi-card {
  flex: 1 1 210px;
  max-width: 250px;
  background: #fff;
  border: 1.5px solid var(--c-line, #E6EAEA);
  border-radius: 18px;
  padding: 24px 22px;
  display: flex; flex-direction: column; gap: 10px;
  box-shadow: 0 6px 18px -10px rgba(15,29,28,.12);
  transition: transform .25s ease, box-shadow .25s ease, border-color .22s ease;
}
.audi-card:hover { transform: translateY(-5px); box-shadow: 0 20px 42px -22px rgba(0,61,56,.22); border-color: rgba(11,138,134,.30); }
.audi-ico {
  width: 50px; height: 50px; border-radius: 14px;
  background: rgba(11,138,134,.10); color: #0B8A86;
  display: grid; place-items: center; flex: none;
  transition: background .25s, color .25s, transform .25s;
}
.audi-ico svg { width: 25px; height: 25px; }
.audi-card:hover .audi-ico { background: #0B8A86; color: #fff; transform: rotate(-6deg) scale(1.06); }
.audi-title { margin: 0; font-size: 15.5px; font-weight: 700; line-height: 1.3; letter-spacing: -.015em; color: #003D38; }
.audi-desc { margin: 0; font-size: 13px; line-height: 1.5; color: #52605e; }
.audi-chip {
  margin-top: auto; align-self: flex-start;
  display: inline-flex; align-items: center;
  padding: 5px 11px; border-radius: 999px;
  font-size: 11.5px; font-weight: 700; line-height: 1.2; letter-spacing: -.01em;
}
.audi-chip--brand { background: rgba(11,138,134,.08); color: #0B6B68; border: 1px solid rgba(11,138,134,.16); }
.audi-chip--svo   { background: #FFF3E0; color: #A85B00; border: 1px solid #F6DCAE; }
.audi-chip--free  { background: #E6F5EC; color: #1C7A41; border: 1px solid #C3E7CF; }

@media (max-width: 560px) {
  .audi-card { flex: 1 1 100%; max-width: 100%; }
}

/* ===== Lead form: FirstAid-style toggle + program select + comment ===== */
.lead-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  background: var(--c-bg-soft, #F5F7F4);
  padding: 6px;
  border-radius: 14px;
  margin-bottom: 18px;
}
.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, #6b7977);
  cursor: pointer;
  transition: background .22s ease, color .22s ease, box-shadow .22s ease;
  user-select: none;
  line-height: 1.2;
  text-align: center;
}
.lead-toggle-opt:hover { color: var(--c-brand-dark, #003D38); }
.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-brand-dark, #003D38);
  box-shadow: 0 2px 6px rgba(0,61,56,.14), 0 0 0 1px rgba(0,61,56,.04);
}
.lead-toggle-opt:has(input:focus-visible) { box-shadow: 0 0 0 3px rgba(11,138,134,.35); }
.lead-toggle-opt svg { width: 16px; height: 16px; flex: none; }

.lead-select { margin-bottom: 12px; }
.lead-select select {
  width: 100%; box-sizing: border-box;
  height: 52px;
  padding: 0 40px 0 16px;
  font: 500 15px/1.2 Manrope, system-ui, sans-serif;
  color: var(--c-text, #0F1D1C);
  background-color: var(--c-bg-soft, #F5F7F4);
  border: 1.5px solid var(--c-line, #E6EAEA);
  border-radius: 10px;
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7977' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px;
  cursor: pointer;
}
.lead-select select:focus { outline: none; border-color: var(--c-brand, #0b8a86); background-color: #fff; }
.lead-select select:required:invalid { color: var(--c-text-muted, #6b7977); }
.lead-select select option { color: var(--c-text, #0F1D1C); }

.lead-form .field textarea {
  width: 100%; box-sizing: border-box;
  min-height: 56px;
  padding: 22px 16px 8px;
  font: 500 15px/1.35 Manrope, system-ui, sans-serif;
  color: var(--c-text, #0F1D1C);
  background: var(--c-bg-soft, #F5F7F4);
  border: 1.5px solid transparent;
  border-radius: 10px;
  resize: vertical;
}
.lead-form .field textarea:focus { outline: none; border-color: var(--c-brand, #0b8a86); background: #fff; }
.lead-form .field textarea:focus + label,
.lead-form .field textarea:not(:placeholder-shown) + label {
  transform: translateY(-10px) scale(.78);
  color: var(--c-brand, #0b8a86);
}
/* toggle, program select and the comment textarea span the full form width */
.lead-form .lead-toggle,
.lead-form .lead-select,
.lead-form .field:has(textarea) { grid-column: 1 / -1; }

/* ===== #contact: single centred column — form on top, FAQ below ===== */
/* base (<=1023px): single column, form first then FAQ */
.contact-split {
  display: flex;
  flex-direction: column;
  gap: 22px;
  max-width: 720px;
  margin-inline: auto;
  align-items: stretch;
}
.contact-split .contact-form-card { order: 1; position: static; }
.contact-split .contact-faq { order: 2; }

/* large screens: form + FAQ side by side, section fits ~100vh */
@media (min-width: 1024px) {
  .contact-section {
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding-top: 28px;
    padding-bottom: 28px;
  }
  .contact-section > .wrap { width: 100%; }
  .contact-section .sec-head { margin-bottom: 22px; }
  .contact-split {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 28px;
    max-width: 1080px;
    align-items: center;
  }
  .contact-split .contact-faq,
  .contact-split .contact-form-card { order: 0; }
  .contact-form-body { padding: 20px 24px 18px; }
  .contact-lead-form { gap: 9px; }
  .contact-form-title { font-size: clamp(22px, 1.2vw + 12px, 26px); margin: 6px 0 4px; }
  .contact-form-sub { margin-bottom: 12px; font-size: 13px; }
  .contact-form-license { margin-bottom: 10px; }
  /* tighter fields so the pair fits one screen */
  .contact-lead-form .field input,
  .contact-lead-form .lead-select select { height: 46px; min-height: 46px; }
  .contact-lead-form .field input { padding: 16px 14px 4px; }
  .contact-lead-form .field textarea { min-height: 46px; padding: 16px 14px 6px; }
  .contact-lead-form .lead-toggle { margin-bottom: 12px; }
  .contact-lead-form .lead-toggle-opt { padding: 9px 10px; }
  .contact-form-trust { display: none; }            /* free vertical space on desktop */
  .contact-section .sec-title { font-size: clamp(26px, 1.8vw + 8px, 34px); }
  .contact-section .sec-sub { margin-top: 8px; font-size: 14px; }
  /* compact FAQ rows so the column stays short next to the form */
  .contact-faq { padding: 22px 24px; align-self: start; }
  .contact-faq .faq-item summary { padding: 13px 16px; }
  /* force compact section padding (beats .std/--section-pad) + drop duplicate section sub */
  #contact.contact-section { padding-top: 22px; padding-bottom: 22px; }
  #contact .sec-head .sec-sub { display: none; }
}

/* ===== Footer logo (white ПРОФИ-Юг) — keep aspect, don't let flex stretch it ===== */
.foot-brand .foot-logo {
  display: block;
  width: 235px;
  height: auto;            /* proportional from width (2230x421) */
  max-width: 100%;
  align-self: flex-start;  /* prevent flex-column stretch */
  margin-bottom: 8px;
}

/* ===== Bigger logos (header + footer), tidy ===== */
.brand-logo { height: 52px; }
@media (max-width: 768px) { .brand-logo { height: 46px; } }

/* ===== Footer: 2 columns on mobile (override the higher-specificity ≤1024 rule) ===== */
@media (max-width: 560px) {
  footer.site .foot-row { grid-template-columns: repeat(2, 1fr); gap: 22px 18px; }
  footer.site .foot-brand { grid-column: 1 / -1; }      /* logo + about full width on top */
  footer.site .foot-contact { grid-column: 1 / -1; }    /* Связь full width (long phone/email) */
}

/* ===== Video section (responsive 16:9 embeds) ===== */
.video-section .video-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 8px;
}
.video-embed {
  position: relative;
  width: 100%;
  padding-top: 56.25%;            /* 16:9 */
  border-radius: 18px;
  overflow: hidden;
  background: #0a1413;
  border: 1px solid var(--c-line, #E6EAEA);
  box-shadow: 0 18px 46px -24px rgba(0,61,56,.30);
}
.video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
@media (max-width: 1000px) {
  .video-section .video-grid { grid-template-columns: 1fr; gap: 18px; }
}

/* ===== Audience photo cards (real photos) ===== */
.audience-section .audp-grid {
  list-style: none; margin: 8px 0 0; padding: 0;
  display: flex; flex-wrap: wrap; justify-content: center; gap: 18px;
}
.audp-card {
  flex: 1 1 195px;
  max-width: 216px;
  background: #fff;
  border: 1px solid var(--c-line, #E6EAEA);
  border-radius: 18px;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 8px 22px -12px rgba(15,29,28,.16);
  transition: transform .28s ease, box-shadow .28s ease;
}
.audp-card:hover { transform: translateY(-6px); box-shadow: 0 24px 48px -22px rgba(0,61,56,.26); }
.audp-photo { aspect-ratio: 4 / 5; overflow: hidden; background: #dde5dd; }
.audp-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 32%; display: block; transition: transform .5s ease; }
.audp-card:hover .audp-photo img { transform: scale(1.05); }
.audp-body { padding: 16px 16px 20px; display: flex; flex-direction: column; gap: 8px; }
.audp-title { margin: 0; font-size: 15.5px; font-weight: 700; line-height: 1.3; letter-spacing: -.015em; color: #003D38; }
.audp-desc { margin: 0; font-size: 12.5px; line-height: 1.5; color: #52605e; }
@media (max-width: 760px) { .audp-card { flex: 1 1 calc(50% - 9px); max-width: none; } }
@media (max-width: 460px) { .audp-card { flex: 1 1 100%; } }
.contact-form-card,
.contact-faq {
  border: 1px solid rgba(11,138,134,.12);
  box-shadow: 0 18px 46px -26px rgba(0,61,56,.26);
}
.contact-form-license {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 12px;
  background: var(--c-brand-soft, #e8f3f2);
  color: #0B6B68;
  border: 1px solid rgba(11,138,134,.16);
  border-radius: 999px;
  font-size: 12px; font-weight: 700;
  margin-bottom: 14px;
}
.contact-form-license svg { width: 14px; height: 14px; color: #0B8A86; flex: none; }

/* ============ THIN TRUST STRIP (proofs after #teachers) ============ */
.trust-strip-section{padding:0 0 clamp(22px,4vw,44px)}
.trust-strip{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px 28px;
  padding:16px clamp(18px,2.5vw,30px);
  background:linear-gradient(180deg,#fff,var(--c-bg-soft));
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.trust-strip__lic{display:inline-flex; align-items:center; gap:10px; font-size:14px; color:var(--c-text-2); font-weight:600}
.trust-strip__lic svg{width:22px; height:22px; color:var(--c-brand); flex:none}
.trust-strip__lic b{color:var(--c-text); font-weight:800; letter-spacing:.01em; font-variant-numeric:tabular-nums; white-space:nowrap}
.trust-strip__items{display:flex; flex-wrap:wrap; gap:10px 18px}
.trust-strip__item{display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:600; color:var(--c-text-2)}
.trust-strip__item svg{width:16px; height:16px; color:var(--c-brand); flex:none}
@media (max-width:820px){
  .trust-strip{flex-direction:column; align-items:flex-start; gap:13px}
  .trust-strip__items{flex-direction:column; gap:9px}
}
