/* ======================================================================
   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}
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)}
@media (max-width:1024px){ .head-nav{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}

/* STICKY SIDE TAB */
.side-tab{position:fixed; top:50%; right:0; transform:translateY(-50%); z-index:50; background:var(--c-brand); color:#fff; padding:18px 14px; border-radius:14px 0 0 14px; font-weight:700; font-size:13px; letter-spacing:.04em; box-shadow:0 10px 30px -8px rgba(11,138,134,.5); transition:padding-right .25s, background .2s; writing-mode:vertical-rl; transform-origin:right; display:none; align-items:center; gap:12px}
.side-tab:hover{background:var(--c-brand-2); padding-right:18px}
.side-tab svg{width:14px; height:14px; transform:rotate(-90deg)}
@media (min-width:1025px){.side-tab{display:flex}}

/* 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:.95fr 1.05fr; 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}
.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(36px, 5.2vw, 64px); font-weight:800; letter-spacing:-0.035em; line-height:1.02; color:var(--c-text)}
.hero-title .acc{color:var(--c-brand); display:inline-block; position:relative; white-space:nowrap}
.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-sub{font-size:16px; line-height:1.55; color:var(--c-text-2); max-width:46ch; font-weight:500}
.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-radius:999px; font-size:13px; font-weight:600; color:var(--c-text-2); transition:transform .2s, background .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}
.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); 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}
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); 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:920px; 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{content:''; width:16px; height:16px; margin-top:2px; background:var(--c-brand-soft); 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}
.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); 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); 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); 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:var(--c-text-muted); 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 */
.final-cta{padding:var(--section-pad) 0}
.final-shell{background:var(--c-brand); color:#fff; border-radius:var(--radius-xl); padding:56px; display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:center; position:relative; overflow:hidden; box-shadow:var(--shadow-green)}
.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(255,255,255,.18), transparent 70%); border-radius:50%; pointer-events:none}
.final-text{position:relative; z-index:1}
.final-text h2{font-size:clamp(32px,4.4vw,52px); font-weight:800; letter-spacing:-0.03em; line-height:1.05; margin-bottom:14px}
.final-text h2 em{font-style:normal; color:var(--c-accent)}
.final-text p{font-size:16px; line-height:1.5; color:rgba(255,255,255,.85); max-width:44ch}
.final-actions{display:flex; flex-direction:column; gap:12px; position:relative; z-index:1}
.final-actions .btn{justify-content:center; padding:18px 24px; font-size:15px}
.final-info{font-size:12px; color:rgba(255,255,255,.75); text-align:center; padding-top:6px}
.final-info b{color:#fff}
@media(max-width:768px){.final-shell{grid-template-columns:1fr; padding:40px 28px}}

/* FOOTER */
footer.site{background:var(--c-brand-dark); color:rgba(255,255,255,.85); padding:56px 0 28px}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:48px}
.foot-brand .brand-logo{height:48px}
.foot-brand h4{font-size:18px; font-weight:800; margin-bottom:10px; color:#fff; letter-spacing:-0.02em}
.foot-brand p{font-size:13px; line-height:1.6; color:rgba(255,255,255,.65); max-width:36ch}
.foot-social{display:flex; gap:8px; margin-top:18px}
.foot-social a{width:38px; height:38px; background:rgba(255,255,255,.08); border-radius:50%; display:grid; place-items:center; transition:background .2s, transform .2s}
.foot-social a:hover{background:var(--c-brand); transform:translateY(-2px)}
.foot-col h5{font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:var(--c-accent); margin-bottom:14px; font-weight:700}
.foot-col ul{list-style:none; display:flex; flex-direction:column; gap:8px}
.foot-col ul li a{font-size:14px; color:rgba(255,255,255,.85); transition:color .2s}
.foot-col ul li a:hover{color:var(--c-accent)}
.foot-contact .vc{font-weight:700; font-size:16px; color:#fff; margin-bottom:4px}
.foot-contact .sm{font-size:12px; color:rgba(255,255,255,.55); margin-bottom:14px}
.foot-bot{margin-top:40px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:12px; color:rgba(255,255,255,.5)}
@media(max-width:980px){.foot-grid{grid-template-columns:1fr 1fr; gap:32px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}

/* 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 */
.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}
}