/* ═══════════════════════════════════════════════════
   ОКНА В ДОМ — style.css v9 FINAL
   Mobile-first. Оптимизировано для PageSpeed 90+
   
   1.  CSS переменные
   2.  Сброс + база
   3.  Утилиты + кнопки
   4.  Прогресс-бар
   5.  Header
   6.  Hero
   7.  Ticker
   8.  Stats
   9.  Services
   10. Gallery
   11. Why Us
   12. Steps
   13. Reviews
   14. FAQ
   15. Kaspi секция
   16. Promo секция
   17. Лид-форма
   18. CTA Strip
   19. Footer
   20. Float WA + Scroll Top
   21. Анимации
   22. Медиазапросы
═══════════════════════════════════════════════════ */

/* ═══ 1. ПЕРЕМЕННЫЕ ═══ */
:root {
  --blue:      #0A2463;
  --blue-mid:  #1B4FD8;
  --blue-lt:   #3B82F6;
  --yellow:    #FFD600;
  --yellow-dk: #F5C800;
  --white:     #FFFFFF;
  --bg-light:  #F4F7FF;
  --border:    #E2E8F0;
  --text:      #0A1A3B;
  --muted:     #64748B;
  --wa:        #25D366;

  --ff-head: 'Unbounded', sans-serif;
  --ff-body: 'Golos Text', sans-serif;

  --sec-py: 52px;
  --r-sm:   8px;
  --r-md:   16px;
  --r-lg:   24px;
  --r-xl:   32px;
  --r-full: 9999px;

  --sh-sm: 0 2px 8px rgba(10,36,99,.08);
  --sh-md: 0 8px 30px rgba(10,36,99,.12);
  --sh-lg: 0 20px 60px rgba(10,36,99,.16);
  --tr:    .28s ease;
}

/* ═══ 2. СБРОС ═══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:64px;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);font-size:16px;line-height:1.6;color:var(--text);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:var(--ff-body);cursor:pointer}

/* ═══ 3. УТИЛИТЫ ═══ */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 16px}
.section{padding:var(--sec-py) 0}
.bg-light{background:var(--bg-light)}
.bg-white{background:var(--white)}
.bg-dark{background:linear-gradient(135deg,#071B4E 0%,#0A2463 100%)}

.section__hd{margin-bottom:28px}

.stag{display:inline-block;background:rgba(27,79,216,.1);color:var(--blue-mid);padding:5px 14px;border-radius:var(--r-full);font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:10px}
.stag--gold{background:rgba(255,214,0,.18);color:#B8860B}
.stag--light{background:rgba(255,214,0,.18);color:var(--yellow)}

.stitle{font-family:var(--ff-head);font-size:clamp(19px,4.5vw,34px);font-weight:800;color:var(--blue);line-height:1.2;margin-bottom:10px}
.stitle span{color:var(--blue-mid)}
.stitle--white{color:var(--white)}
.text-gold{color:var(--yellow)}

.ssub{color:var(--muted);font-size:15px;line-height:1.6;max-width:520px}
.sec-foot{text-align:center;margin-top:28px}

/* Лого */
.logo{font-family:var(--ff-head);font-size:17px;font-weight:900;color:var(--white);flex-shrink:0}
.logo__accent{color:var(--yellow)}
.logo--lg{font-size:20px}

/* ─── КНОПКИ ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:13px 22px;border-radius:var(--r-full);font-family:var(--ff-head);font-size:13px;font-weight:700;border:none;cursor:pointer;transition:all var(--tr);white-space:nowrap;text-decoration:none;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}
.btn--lg{padding:15px 28px;font-size:14px}
.btn--sm{padding:9px 16px;font-size:12px}
.btn--full{width:100%}

.btn--yellow{background:var(--yellow);color:var(--blue);box-shadow:0 4px 18px rgba(255,214,0,.4)}
.btn--yellow:hover{background:var(--yellow-dk);transform:translateY(-2px);box-shadow:0 10px 28px rgba(255,214,0,.5)}
.btn--yellow:active{transform:translateY(0)}

.btn--ghost{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.4)}
.btn--ghost:hover{border-color:var(--white);background:rgba(255,255,255,.1)}

.btn--outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.45)}
.btn--outline-white:hover{border-color:var(--white);background:rgba(255,255,255,.1)}

.btn--outline{background:transparent;color:var(--blue);border:2px solid var(--blue)}
.btn--outline:hover{background:var(--blue);color:var(--white)}

.btn--ghost-dark{background:transparent;color:var(--blue);border:2px solid rgba(10,36,99,.3)}
.btn--ghost-dark:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}

.btn--wa{background:var(--wa);color:var(--white);box-shadow:0 4px 14px rgba(37,211,102,.35)}
.btn--wa:hover{background:#20bb5a;transform:translateY(-2px)}

/* ═══ 4. ПРОГРЕСС-БАР ═══ */
/* Используем will-change для плавности на мобилках */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--yellow),var(--blue-lt));
  z-index:2000;
  will-change:width;
  /* Убираем transition — обновляем через JS requestAnimationFrame */
}

/* ═══ 5. HEADER ═══ */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,36,99,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.25)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:12px}
.nav{display:none;gap:24px}
.nav__link{color:rgba(255,255,255,.8);font-size:14px;font-weight:500;transition:color var(--tr);position:relative;padding-bottom:2px}
.nav__link::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--yellow);transform:scaleX(0);transition:transform var(--tr)}
.nav__link:hover,.nav__link--active{color:var(--white)}
.nav__link--active::after,.nav__link:hover::after{transform:scaleX(1)}
.header__right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.header__phone{display:none;font-family:var(--ff-head);font-size:13px;font-weight:700;color:var(--yellow)}
.burger{display:flex;flex-direction:column;gap:5px;background:none;border:none;padding:6px;-webkit-tap-highlight-color:transparent}
.burger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all var(--tr)}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0;transform:translateX(-8px)}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav.open{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:rgba(10,36,99,.98);padding:12px 16px;gap:0;border-top:1px solid rgba(255,255,255,.1);animation:slideDown .22s ease}
.nav.open .nav__link{padding:13px 8px;border-bottom:1px solid rgba(255,255,255,.07);font-size:15px}
.nav.open .nav__link:last-child{border-bottom:none}
.nav.open .nav__link::after{display:none}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ═══ 6. HERO ═══ */
.hero{
  background:linear-gradient(145deg,#071B4E 0%,#0A2463 45%,#0f3099 100%);
  padding:88px 0 64px;
  position:relative;overflow:hidden;
  min-height:100svh;
  display:flex;align-items:center;
}
.hero::before{content:'';position:absolute;top:-30%;right:-20%;width:65vw;height:65vw;background:radial-gradient(circle,rgba(255,214,0,.1) 0%,transparent 65%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-20%;left:-15%;width:55vw;height:55vw;background:radial-gradient(circle,rgba(59,130,246,.13) 0%,transparent 65%);pointer-events:none}

.hero__particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.particle{position:absolute;border-radius:50%;background:rgba(255,214,0,.12);animation:floatP 9s ease-in-out infinite}
.p1{width:55px;height:55px;top:22%;left:7%;animation-delay:0s}
.p2{width:36px;height:36px;top:62%;left:14%;animation-delay:2s;animation-duration:7s}
.p3{width:70px;height:70px;top:28%;right:7%;animation-delay:1s;animation-duration:11s;background:rgba(59,130,246,.1)}
.p4{width:28px;height:28px;top:72%;right:18%;animation-delay:3s}
@keyframes floatP{0%,100%{transform:translateY(0) scale(1);opacity:.6}50%{transform:translateY(-28px) scale(1.08);opacity:.3}}

.hero__inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:36px;width:100%}

.hero__badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,214,0,.12);border:1px solid rgba(255,214,0,.28);color:var(--yellow);padding:6px 14px;border-radius:var(--r-full);font-size:11px;font-weight:600;margin-bottom:18px}
.badge__dot{width:7px;height:7px;background:var(--yellow);border-radius:50%;animation:blink 1.6s ease infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* H1 — белый на тёмном */
.hero__title{font-family:var(--ff-head);font-size:clamp(24px,6.5vw,52px);font-weight:900;color:var(--white);line-height:1.12;margin-bottom:14px;letter-spacing:-.4px}
.hero__accent{color:var(--yellow)}
.hero__sub{font-size:clamp(13px,3vw,16px);color:rgba(255,255,255,.8);line-height:1.6;margin-bottom:22px}
.hero__features{display:flex;flex-wrap:wrap;gap:7px 14px;margin-bottom:24px}
.hero__features li{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.9);font-size:13px;font-weight:500}
.fcheck{width:18px;height:18px;background:var(--yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:10px;font-weight:700;flex-shrink:0}

/* CTA — вертикально на мобилке */
.hero__cta{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;max-width:320px}
.hero__cta .btn{width:100%}

.hero__proof{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.65);font-size:12px}
.avatars{display:flex}
.av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-head);font-size:10px;font-weight:700;color:var(--white);border:2px solid rgba(255,255,255,.25);margin-left:-6px}
.av:first-child{margin-left:0}

.hero__visual{display:none}
.hero__img{width:100%;height:420px;object-fit:cover;border-radius:var(--r-xl);box-shadow:var(--sh-lg)}
.hero__photo-wrap{position:relative}
.hero__frame{position:absolute;inset:-8px;border:2px solid rgba(255,214,0,.28);border-radius:calc(var(--r-xl) + 8px);pointer-events:none}

/* Плавающие карточки */
.fcard{position:absolute;background:var(--white);border-radius:var(--r-md);padding:9px 13px;display:flex;align-items:center;gap:9px;box-shadow:var(--sh-md);font-size:12px}
.fcard strong{display:block;font-weight:700;color:var(--blue);font-size:12px}
.fcard span{color:var(--muted);font-size:11px}
.fcard__icon{font-size:24px}
.fcard--kaspi{bottom:-14px;left:-14px;animation:floatCard 3s ease-in-out infinite}
.fcard--guarantee{top:20px;right:-14px;animation:floatCard 3s ease-in-out infinite .8s}
.fcard--rating{bottom:56px;right:-8px;flex-direction:column;align-items:flex-start;gap:2px;animation:floatCard 3s ease-in-out infinite 1.6s}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

.hero__wave{position:absolute;bottom:-1px;left:0;right:0;line-height:0}
.hero__wave svg{width:100%;height:48px}

/* ═══ 7. TICKER ═══ */
.ticker-wrap{background:var(--yellow);overflow:hidden;padding:11px 0}
.ticker__track{display:flex;gap:36px;width:max-content;animation:ticker 18s linear infinite}
.ticker__track span{white-space:nowrap;font-family:var(--ff-head);font-size:12px;font-weight:700;color:var(--blue)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-wrap:hover .ticker__track{animation-play-state:paused}

/* ═══ 8. STATS ═══ */
.stats{background:var(--blue);padding:40px 0}
.stats__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.stat{text-align:center;padding:18px 10px;border-right:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
.stat:nth-child(2){border-right:none}
.stat:nth-child(3){border-bottom:none}
.stat:nth-child(4){border-right:none;border-bottom:none}
.stat__num{font-family:var(--ff-head);font-size:clamp(24px,5.5vw,40px);font-weight:900;color:var(--yellow)}
.stat__suf{font-family:var(--ff-head);font-size:clamp(14px,2.5vw,22px);font-weight:700;color:var(--yellow)}
.stat__label{display:block;color:rgba(255,255,255,.6);font-size:11px;margin-top:4px}

/* ═══ 9. УСЛУГИ ═══ */
.services-grid{display:grid;grid-template-columns:1fr;gap:14px}
.scard{display:block;background:var(--white);border-radius:var(--r-lg);padding:26px 22px;border:1px solid var(--border);transition:all var(--tr);position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}
.scard:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.scard::before{content:'';position:absolute;left:0;top:14px;bottom:14px;width:3px;background:var(--blue-mid);border-radius:2px;transform:scaleY(0);transition:transform var(--tr)}
.scard:hover::before{transform:scaleY(1)}
.scard--feat{background:var(--blue);border-color:transparent}
.scard--feat .scard__title{color:var(--white)}
.scard--feat .scard__desc{color:rgba(255,255,255,.8)}
.scard--feat .scard__price{color:var(--yellow)}
.scard--feat .scard__arrow{color:var(--yellow)}
.scard--feat::before{background:var(--yellow)}
.scard__badge{position:absolute;top:12px;right:12px;background:var(--yellow);color:var(--blue);padding:3px 10px;border-radius:var(--r-full);font-size:10px;font-weight:700}
.scard__icon{font-size:34px;margin-bottom:12px;display:block}
.scard__title{font-family:var(--ff-head);font-size:16px;font-weight:700;color:var(--blue);margin-bottom:7px}
.scard__desc{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.scard__price{font-family:var(--ff-head);font-size:14px;font-weight:700;color:var(--blue-mid);margin-bottom:7px}
.scard__arrow{font-size:16px;font-weight:700;color:var(--blue-mid)}

/* ═══ 10. ГАЛЕРЕЯ ═══ */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.gitem{border-radius:var(--r-md);overflow:hidden}
.gitem__wrap{position:relative;overflow:hidden;cursor:pointer}
.gitem__wrap img{width:100%;height:180px;object-fit:cover;object-position:center;transition:transform .4s ease;display:block}
.gitem__wrap:hover img{transform:scale(1.05)}
.gitem__ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,36,99,.85) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:10px 12px;opacity:0;transition:opacity var(--tr)}
.gitem__wrap:hover .gitem__ov{opacity:1}
.gitem__ov span{color:rgba(255,255,255,.8);font-size:11px}
.gitem__ov strong{color:var(--white);font-size:13px;font-weight:700}

/* ═══ 11. ПОЧЕМУ МЫ ═══ */
.why-grid{display:grid;grid-template-columns:1fr;gap:24px}
.why-visual{background:linear-gradient(135deg,var(--blue) 0%,#1a4fd8 100%);border-radius:var(--r-xl);padding:28px 24px;color:var(--white);position:relative;overflow:hidden}
.why-visual::after{content:'🪟';position:absolute;right:-14px;bottom:-14px;font-size:130px;opacity:.05;pointer-events:none}
.why-visual__tag{font-family:var(--ff-head);font-size:13px;font-weight:800;color:var(--yellow);margin-bottom:18px}
.why-list{display:flex;flex-direction:column;gap:13px}
.why-list li{display:flex;gap:11px;font-size:13px;color:rgba(255,255,255,.88);line-height:1.5}
.wcheck{width:19px;height:19px;background:var(--yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:10px;font-weight:700;flex-shrink:0;margin-top:2px}
.why-reasons{display:flex;flex-direction:column;gap:14px}
.reasons-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.reason{background:var(--white);border-radius:var(--r-md);padding:16px 14px;border:1px solid var(--border);transition:all var(--tr)}
.reason:hover{border-color:var(--blue-lt);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.reason__icon{font-size:22px;display:block;margin-bottom:7px}
.reason strong{display:block;font-family:var(--ff-head);font-size:11px;font-weight:700;color:var(--blue);margin-bottom:4px}
.reason p{font-size:12px;color:var(--muted);line-height:1.5}

/* ═══ 12. ШАГИ ═══ */
.steps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;position:relative;z-index:1}
.step{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:22px 16px;text-align:center;transition:all var(--tr)}
.step:hover{background:rgba(255,255,255,.11);transform:translateY(-3px)}
.step__n{width:48px;height:48px;background:var(--yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-head);font-size:19px;font-weight:900;color:var(--blue);margin:0 auto 14px;position:relative;z-index:1}
.step h3{font-family:var(--ff-head);font-size:13px;font-weight:700;color:var(--white);margin-bottom:7px}
.step p{font-size:12px;color:rgba(255,255,255,.65);line-height:1.5}

/* ═══ 13. ОТЗЫВЫ ═══ */
.rating-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}
.rating-bar__stars{color:var(--yellow);font-size:18px}
.rating-bar__score{font-family:var(--ff-head);font-size:18px;font-weight:900;color:var(--blue)}
.rating-bar__count{font-size:12px;color:var(--muted)}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:14px}
.review{background:var(--bg-light);border-radius:var(--r-lg);padding:22px;border:1px solid var(--border);position:relative;overflow:hidden;transition:all var(--tr)}
.review:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.review::before{content:'"';position:absolute;top:8px;right:14px;font-size:72px;color:rgba(27,79,216,.07);font-family:Georgia,serif;line-height:1;pointer-events:none}
.review__stars{color:var(--yellow);font-size:15px;margin-bottom:10px}
.review__text{font-size:13px;color:var(--text);line-height:1.65;margin-bottom:16px}
.review__author{display:flex;align-items:center;gap:10px}
.review__av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-head);font-size:14px;font-weight:700;color:var(--white);flex-shrink:0}
.review__author strong{display:block;font-size:13px;font-weight:700;color:var(--blue)}
.review__author span{font-size:11px;color:var(--muted)}

/* ═══ 14. FAQ ═══ */
.faq-grid{display:grid;grid-template-columns:1fr;gap:0}
.faq-list{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:16px 18px;text-align:left;background:var(--white);border:none;font-size:14px;font-weight:600;color:var(--blue);cursor:pointer;transition:background var(--tr);-webkit-tap-highlight-color:transparent}
.faq-q:hover{background:rgba(27,79,216,.04)}
.faq-q[aria-expanded="true"]{background:rgba(27,79,216,.05);color:var(--blue-mid)}
.faq-icon{font-size:18px;font-weight:300;color:var(--blue-mid);transition:transform var(--tr);flex-shrink:0}
.faq-q[aria-expanded="true"] .faq-icon{transform:rotate(45deg)}
/* Плавный аккордеон через grid — без лагов */
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s ease;background:var(--white)}
.faq-a__in{overflow:hidden;min-height:0}
.faq-a.open{grid-template-rows:1fr}
.faq-a p{font-size:13px;color:var(--muted);line-height:1.65;padding:0 18px 16px}

/* ═══ 15. KASPI СЕКЦИЯ ═══ */
.kaspi-section{background:linear-gradient(135deg,var(--blue) 0%,#1B4FD8 100%);padding:var(--sec-py) 0}
.kaspi-inner{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.kaspi-left .stag{background:rgba(255,214,0,.18);color:var(--yellow)}
.kaspi-left .stitle{color:var(--white)}
.kaspi-left p{color:rgba(255,255,255,.8)}
.kaspi-logo-wrap{margin-bottom:16px}
.kaspi-logo-wrap img{height:36px;width:auto}
.kaspi-right{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.kaspi-fact{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-lg);padding:16px 10px;text-align:center;transition:all var(--tr)}
.kaspi-fact:hover{background:rgba(255,255,255,.16)}
.kaspi-fact__num{display:block;font-family:var(--ff-head);font-size:clamp(20px,4.5vw,34px);font-weight:900;color:var(--yellow);margin-bottom:3px}
.kaspi-fact__label{font-size:11px;color:rgba(255,255,255,.75);font-weight:600}

/* ═══ 16. PROMO СЕКЦИЯ ═══ */
.promo-section{background:linear-gradient(135deg,#0d1b3e 0%,#1a2456 50%,#0f3060 100%);padding:var(--sec-py) 0}
.promo-section .stag{background:rgba(255,214,0,.18);color:var(--yellow)}
.promo-section .stitle{color:var(--white)}
.promo-section .ssub{color:rgba(255,255,255,.7)}

.promo-grid{display:grid;grid-template-columns:1fr;gap:14px}
.promo-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);padding:30px 18px 22px;position:relative;overflow:visible;transition:all var(--tr)}
.promo-card:hover{transform:translateY(-3px);background:rgba(255,255,255,.11)}
.promo-card--hot{background:rgba(255,214,0,.07);border-color:rgba(255,214,0,.22)}
.promo-card__badge{position:absolute;top:-10px;right:14px;background:var(--yellow);color:var(--blue);padding:5px 14px;border-radius:var(--r-full);font-size:13px;font-weight:900;box-shadow:0 3px 12px rgba(255,214,0,.5);letter-spacing:.3px}
.promo-card__badge--hot{background:#EF4444;color:var(--white);box-shadow:0 3px 12px rgba(239,68,68,.45)}
.promo-card__icon{font-size:34px;display:block;margin-bottom:10px}
.promo-card__title{font-family:var(--ff-head);font-size:15px;font-weight:800;color:var(--white);margin-bottom:10px}
.promo-card__gift{display:flex;gap:9px;align-items:flex-start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:10px;margin-bottom:10px}
.gift-icon{font-size:19px;flex-shrink:0}
.promo-card__gift span{font-size:12px;color:rgba(255,255,255,.82);font-weight:600}
.promo-card__desc{font-size:12px;color:rgba(255,255,255,.6);line-height:1.55;margin-bottom:14px}

/* Таймер */
.promo-timer{background:rgba(0,0,0,.2);border-radius:var(--r-lg);padding:14px;margin:0 auto 24px;max-width:420px;text-align:center;border:1px solid rgba(255,255,255,.12)}
.promo-timer__label{font-size:11px;color:rgba(255,255,255,.65);margin-bottom:10px}
.promo-timer__blocks{display:flex;align-items:center;justify-content:center;gap:5px}
.timer-block{display:flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.1);border-radius:var(--r-md);padding:9px 10px;min-width:52px;border:1px solid rgba(255,255,255,.14)}
.timer-block span:first-child{font-family:var(--ff-head);font-size:clamp(16px,4vw,26px);font-weight:900;color:var(--yellow);line-height:1;display:block}
.timer-block span:last-child{font-size:9px;color:rgba(255,255,255,.55);margin-top:3px}
.timer-sep{font-family:var(--ff-head);font-size:22px;font-weight:900;color:var(--yellow);margin-top:-8px}

/* ═══ 17. ЛИД-ФОРМА ═══ */
.lform-wrap{display:grid;grid-template-columns:1fr;background:var(--white);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg)}
.lform-promo{padding:28px 22px;background:linear-gradient(135deg,var(--blue) 0%,#1a4fd8 100%);color:var(--white)}
.lform-title{font-family:var(--ff-head);font-size:clamp(17px,3.5vw,26px);font-weight:800;color:var(--yellow);margin-bottom:8px}
.lform-sub{color:rgba(255,255,255,.8);font-size:13px;line-height:1.6;margin-bottom:16px}
.lform-perks{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.lform-perks li{font-size:13px;font-weight:500;color:rgba(255,255,255,.9)}
.urgency{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.7)}
.urgency__dot{width:7px;height:7px;border-radius:50%;background:#4ADE80;animation:blink 1.6s ease infinite;flex-shrink:0}

.lform-form{padding:24px 20px;background:var(--white)}
.lform-form h3{font-family:var(--ff-head);font-size:18px;font-weight:800;color:var(--blue);margin-bottom:4px}
.lform-form>p{font-size:12px;color:var(--muted);margin-bottom:18px}

.fg{margin-bottom:10px}
.fi{width:100%;padding:13px 15px;border:2px solid var(--border);border-radius:var(--r-md);font-family:var(--ff-body);font-size:15px;color:var(--text);background:var(--white);outline:none;transition:border-color var(--tr);-webkit-appearance:none}
.fi:focus{border-color:var(--blue-mid)}
.fi::placeholder{color:var(--muted)}
.fsel{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748B' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:36px}
.fn{font-size:11px;color:var(--muted);margin-top:9px;line-height:1.5}
.fn a{color:var(--blue-mid);text-decoration:underline}
.fsuccess{text-align:center;padding:28px 16px}
.fsuccess span{font-size:40px;display:block;margin-bottom:10px}
.fsuccess strong{display:block;font-family:var(--ff-head);font-size:17px;color:var(--blue);margin-bottom:6px}
.fsuccess p{font-size:13px;color:var(--muted)}

/* ═══ 18. CTA STRIP ═══ */
.cta-strip{background:linear-gradient(135deg,var(--yellow) 0%,#FFB800 100%);padding:22px 0}
.cta-strip__in{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta-strip__txt{font-size:14px;color:var(--blue)}
.cta-strip__txt strong{font-family:var(--ff-head);font-size:16px;display:block;margin-bottom:2px}
.cta-strip__btns{display:flex;gap:9px;flex-wrap:wrap;width:100%}
.cta-strip__btns .btn{flex:1;min-width:120px}

/* ═══ 19. ФУТЕР ═══ */
.footer{background:var(--blue);padding-top:44px}
.footer__in{display:grid;grid-template-columns:1fr;gap:24px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__desc{color:rgba(255,255,255,.55);font-size:13px;margin-top:7px;line-height:1.5}
.footer__nav{display:flex;flex-wrap:wrap;gap:10px 18px}
.footer__lnk{color:rgba(255,255,255,.7);font-size:14px;transition:color var(--tr)}
.footer__lnk:hover{color:var(--yellow)}
.footer__contacts{display:flex;flex-direction:column;gap:7px}
.footer__phone{font-family:var(--ff-head);font-size:18px;font-weight:700;color:var(--yellow)}
.footer__phone:hover{opacity:.85}
.footer__wa{color:var(--wa);font-size:13px;font-weight:600}
.footer__email{color:rgba(255,255,255,.55);font-size:13px}
.footer__hours{color:rgba(255,255,255,.45);font-size:12px}
.footer__bot{padding:14px 0}
.footer__bot-in{display:flex;justify-content:space-between;flex-wrap:wrap;gap:5px}
.footer__bot-in span{color:rgba(255,255,255,.35);font-size:12px}

/* ═══ 20. FLOAT WA + SCROLL TOP ═══ */
.float-wa{position:fixed;bottom:22px;right:18px;width:54px;height:54px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;font-size:25px;box-shadow:0 5px 22px rgba(37,211,102,.5);z-index:999;transition:transform var(--tr)}
.float-wa:hover{transform:scale(1.1)}
.float-wa:active{transform:scale(.95)}
.fwa-pulse{position:absolute;inset:0;border-radius:50%;background:var(--wa);animation:pulseRing 2.4s ease-out infinite;z-index:-1}
@keyframes pulseRing{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

.scroll-top{position:fixed;bottom:88px;right:18px;width:38px;height:38px;border-radius:50%;background:rgba(10,36,99,.82);color:var(--white);border:none;font-size:16px;display:flex;align-items:center;justify-content:center;z-index:999;cursor:pointer;opacity:0;visibility:hidden;transition:all var(--tr);backdrop-filter:blur(6px)}
.scroll-top.visible{opacity:1;visibility:visible}
.scroll-top:hover{background:var(--blue-mid);transform:translateY(-2px)}

/* ═══ 21. АНИМАЦИИ ═══ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .52s ease var(--d,0s),transform .52s ease var(--d,0s)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ═══ 22. МЕДИАЗАПРОСЫ ═══ */

/* 480px — чуть больше мобилки */
@media(min-width:480px){
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gitem__wrap img{height:200px}
}

/* 640px — планшет */
@media(min-width:640px){
  .container{padding:0 24px}
  .hero__cta{flex-direction:row;max-width:none}
  .hero__cta .btn{width:auto;flex:1}
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .gitem__wrap img{height:220px}
  .reviews-grid{grid-template-columns:repeat(3,1fr)}
  .steps-grid{grid-template-columns:repeat(4,1fr)}
  .lform-wrap{grid-template-columns:1fr 1fr}
  .cta-strip__in{flex-direction:row;align-items:center;justify-content:space-between}
  .cta-strip__btns{width:auto}
  .cta-strip__btns .btn{flex:none}
  .footer__in{grid-template-columns:1.4fr 1fr 1.4fr}
  .kaspi-inner{grid-template-columns:1fr 1fr}
  .kaspi-right{grid-template-columns:repeat(4,1fr)}
  .promo-grid{grid-template-columns:repeat(3,1fr)}
  .stats__grid{grid-template-columns:repeat(4,1fr)}
  .stat{border-bottom:none}
  .stat:nth-child(2){border-right:1px solid rgba(255,255,255,.1)}
  .stat:nth-child(3){border-bottom:none}
}

/* 1024px — десктоп */
@media(min-width:1024px){
  :root{--sec-py:72px}
  .container{padding:0 32px}
  .nav{display:flex}
  .header__phone{display:block}
  .burger{display:none}
  .hero__inner{flex-direction:row;align-items:center;gap:56px}
  .hero__content{flex:1}
  .hero__visual{display:block;flex:1;position:relative}
  .hero__cta .btn{flex:none}
  .why-grid{grid-template-columns:1fr 1fr;gap:52px;align-items:center}
  .faq-grid{grid-template-columns:1fr 2fr;gap:52px;align-items:start}
  .gitem__wrap img{height:240px}
}

/* Маленькие экраны 360px и ниже */
@media(max-width:380px){
  .container{padding:0 12px}
  .hero__title{font-size:21px}
  .stitle{font-size:18px}
  .btn--lg{padding:13px 18px;font-size:12px}
  .kaspi-strip__title{font-size:11px}
  .timer-block{min-width:44px;padding:7px 8px}
  .lform-form{padding:20px 14px}
  .lform-promo{padding:22px 14px}
  .fi{padding:11px 12px;font-size:14px}
}
