/* ═══════════════════════════════════════════════════════════════
   SABE.KG — SHARED STYLES
   Вынесены ТОЛЬКО блоки, идентичные (или эквивалентные)
   во всех страницах, которые их используют.
   Страничные стили остаются в <style> каждого HTML-файла.
   ═══════════════════════════════════════════════════════════════ */


/* ── 1. RESET ─────────────────────────────────────────────────── */
/* Идентично во всех 8 файлах */
*{margin:0;padding:0;box-sizing:border-box}


/* ── 2. CSS-ПЕРЕМЕННЫЕ ────────────────────────────────────────── */
/* Ядро идентично во всех 8 файлах.
   --rose отсутствует в sabe_main.html — добавлен безопасно.
   --white есть только в main и magazin — добавлен для унификации. */
:root{
  --aqua:#00C8FF;
  --green:#00E8A0;
  --yellow:#FFD600;
  --rose:#FF5078;
  --dark:#050D1A;
  --dark2:#071426;
  --dark3:#071E38;
  --card:rgba(255,255,255,0.04);
  --border:rgba(0,200,255,0.18);
  --text:#C8DFF0;
  --muted:#5C7A96;
  --white:#fff;
}


/* ── 3. BASE ──────────────────────────────────────────────────── */
/* Идентично во всех 8 файлах */
html{scroll-behavior:smooth}
body{
  background:var(--dark);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* Сетка-фон.
   sabe_main.html использует 0.025, остальные 7 — 0.022.
   Берём 0.022 (большинство). Разница в 0.003 визуально незаметна. */
body::before{
  content:'';
  position:fixed;inset:0;z-index:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(0,200,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,0.022) 1px, transparent 1px);
  background-size:60px 60px;
}

/* Скроллбар — идентичен в 7 из 8 файлов (нет в sabe_main).
   Добавление в shared безопасно — sabe_main тоже получит скроллбар. */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--dark2)}
::-webkit-scrollbar-thumb{background:rgba(0,200,255,0.3);border-radius:3px}


/* ── 4. NAV ───────────────────────────────────────────────────── */
/* Идентично в about, nashi_raboty, filtry, magazin, cat_* (7 файлов).
   sabe_main.html отличается: background 0.92, gap:6px, breakpoint 1024px.
   sabe_main.html переопределяет эти свойства в своём <style>. */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(5,13,26,0.95);
  backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(0,200,255,0.1);
  padding:0 28px;
  display:flex;align-items:center;justify-content:space-between;
  height:68px;
}
.nav-left{display:flex;align-items:center;gap:14px}
.nav-logo{
  width:42px;height:42px;border-radius:10px;
  background:linear-gradient(135deg,#005F88,#00C8FF);
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:22px;color:#fff;
  text-decoration:none;flex-shrink:0;
}
.nav-brand{display:flex;align-items:center;text-decoration:none;position:relative;}
.nav-brand img{height:36px;width:auto;display:block;animation:sabeFloat 3s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(0,180,255,0.5));position:relative;z-index:2;}
@keyframes sabeFloat{0%,100%{transform:translateY(0);filter:drop-shadow(0 0 8px rgba(0,180,255,0.5));}50%{transform:translateY(-5px);filter:drop-shadow(0 0 14px rgba(0,180,255,0.9)) drop-shadow(0 8px 6px rgba(0,100,180,0.4));}}
.nav-ripple{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:40px;height:6px;border-radius:50%;border:1px solid rgba(0,180,255,0.4);animation:sabeRipple 2.4s ease-out infinite;pointer-events:none;z-index:1;}
.nav-ripple:nth-child(2){animation-delay:.8s;}
.nav-ripple:nth-child(3){animation-delay:1.6s;}
@keyframes sabeRipple{0%{width:20px;height:4px;opacity:.7;}100%{width:90px;height:14px;opacity:0;}}

.nav-sep{width:1px;height:24px;background:rgba(0,200,255,0.2);display:none}
.nav-page{font-size:13px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;display:none}
@media(min-width:640px){.nav-sep,.nav-page{display:block}}

/* breakpoint 1100px — about, nashi, filtry, magazin, cat_*.
   sabe_main.html использует 1024px — переопределяет в своём <style>. */
.nav-links{display:none;align-items:center;gap:4px}
@media(min-width:1100px){.nav-links{display:flex}}

.nav-link{
  font-size:14px;font-weight:500;color:var(--muted);
  text-decoration:none;padding:8px 12px;border-radius:8px;transition:all .2s;
}
.nav-link:hover{color:#fff;background:rgba(0,200,255,0.08)}
.nav-link.active{color:var(--aqua);background:rgba(0,200,255,0.07)}

.nav-right{display:flex;align-items:center;gap:10px}
.nav-phone{display:none;font-size:14px;font-weight:600;color:var(--aqua);text-decoration:none}
@media(min-width:768px){.nav-phone{display:block}}

.nav-wa{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(0,200,255,0.1);
  border:1px solid rgba(0,200,255,0.3);
  color:var(--aqua);padding:9px 16px;border-radius:8px;
  font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;
}
.nav-wa:hover{background:rgba(0,200,255,0.18);border-color:var(--aqua)}

.nav-burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
@media(min-width:1100px){.nav-burger{display:none}}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px}


/* ── 5. MOBILE NAV ────────────────────────────────────────────── */
/* Идентично во всех 8 файлах.
   sabe_main.html дополнительно использует .mobile-nav-link —
   тот класс остаётся в <style> main. */
.mobile-nav{
  position:fixed;top:68px;left:0;right:0;bottom:0;z-index:150;
  background:rgba(5,13,26,.97);backdrop-filter:blur(24px);
  display:none;flex-direction:column;padding:24px;overflow-y:auto;
}
.mobile-nav.open{display:flex}
.mnav-link{
  font-family:'Bebas Neue',sans-serif;font-size:30px;
  color:var(--text);text-decoration:none;
  letter-spacing:.04em;padding:12px 0;
  border-bottom:1px solid rgba(0,200,255,.07);transition:color .2s;
}
.mnav-link:hover,.mnav-link.active{color:var(--aqua)}


/* ── 6. PAGE HEADER ───────────────────────────────────────────── */
/* Идентично в cat_*, filtry, nashi_raboty, magazin (6 файлов).
   Padding нижнего отступа: 52px в cat_*/filtry, 56px в nashi, 48px в magazin.
   Берём 52px (большинство — 4 файла). nashi и magazin переопределяют в <style>. */
.page-header{
  position:relative;z-index:1;
  padding:100px 24px 52px;
  overflow:hidden;
  background:linear-gradient(180deg,#050D1A 0%,#071E38 65%,#050D1A 100%);
}
.page-header::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 60% at 50% 100%,rgba(0,100,180,0.3) 0%,transparent 65%);
}
.ph-bubbles{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ph-wave{position:absolute;bottom:0;left:0;right:0;z-index:1;line-height:0}
.ph-wave svg{width:200%;animation:wavemove 20s linear infinite}
.ph-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto}

.ph-breadcrumb{
  display:flex;align-items:center;gap:8px;
  margin-bottom:20px;font-size:13px;color:var(--muted);flex-wrap:wrap;
}
.ph-breadcrumb a{color:var(--muted);text-decoration:none;transition:color .2s}
.ph-breadcrumb a:hover{color:var(--aqua)}
.ph-breadcrumb span{color:var(--aqua)}

/* ph-title: clamp(40px...) в cat_*/filtry/magazin (5 файлов).
   nashi_raboty использует clamp(48px...) — переопределяет в <style>. */
.ph-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(40px,7vw,86px);
  color:#fff;line-height:.92;letter-spacing:.02em;margin-bottom:14px;
}
.ph-title em{
  -webkit-text-fill-color:transparent;
  background:linear-gradient(135deg,#00C8FF,#00E8A0);
  -webkit-background-clip:text;background-clip:text;font-style:normal;
}
.ph-sub{font-size:15px;color:var(--muted);font-weight:300;line-height:1.65;max-width:560px;margin-bottom:22px}
.ph-tags{display:flex;gap:8px;flex-wrap:wrap}
.ph-tag{
  background:rgba(0,200,255,0.08);border:1px solid rgba(0,200,255,0.2);
  border-radius:20px;padding:5px 14px;
  font-size:12px;font-weight:600;color:var(--aqua);
  letter-spacing:.06em;text-transform:uppercase;
}

/* ph-stats — идентично в nashi_raboty и magazin */
.ph-stats{display:flex;gap:28px;flex-wrap:wrap;margin-top:28px}
.ph-stat{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.ph-stat-num{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--aqua);letter-spacing:.04em}


/* ── 7. LAYOUT + SIDEBAR ─────────────────────────────────────── */
/* Идентично в cat_emkosti, cat_ochistnye, cat_zhiro, filtry (4 файла) */
.layout{
  position:relative;z-index:1;
  max-width:1200px;margin:0 auto;
  padding:36px 24px 80px;
  display:grid;grid-template-columns:260px 1fr;gap:28px;
}
@media(max-width:900px){.layout{grid-template-columns:1fr;padding:24px 16px 60px}}

.sidebar{position:sticky;top:84px;align-self:start;display:flex;flex-direction:column;gap:14px}
@media(max-width:900px){.sidebar{position:static}}

.sb-card{background:var(--card);border:1px solid rgba(255,255,255,0.07);border-radius:16px;padding:20px;overflow:hidden}
.sb-title{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}

.cat-list{list-style:none;display:flex;flex-direction:column;gap:2px}
.cat-item a{
  display:flex;align-items:center;justify-content:space-between;gap:6px;
  padding:8px 10px;border-radius:8px;
  font-size:13px;font-weight:500;color:var(--muted);
  text-decoration:none;transition:all .2s;
}
.cat-item a:hover{background:rgba(0,200,255,0.08);color:var(--text)}
.cat-item.active>a{background:rgba(0,200,255,0.1);color:var(--aqua);font-weight:600}
.cat-count{
  font-size:10px;background:rgba(0,200,255,0.1);color:var(--muted);
  padding:2px 8px;border-radius:10px;min-width:24px;text-align:center;
}
.cat-item.active .cat-count{color:var(--aqua)}

.sb-search{position:relative}
.sb-search input{
  width:100%;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);border-radius:10px;
  padding:10px 14px 10px 38px;font-size:13px;color:var(--text);
  outline:none;transition:border-color .2s;font-family:'DM Sans',sans-serif;
}
.sb-search input:focus{border-color:rgba(0,200,255,0.4)}
.sb-search input::placeholder{color:var(--muted)}
.sb-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}

/* WA-блок в сайдбаре — идентичен в cat_* и filtry */
.sb-wa{
  background:linear-gradient(135deg,rgba(0,50,40,0.5),rgba(0,30,25,0.5));
  border:1px solid rgba(0,232,160,0.25);border-radius:16px;padding:20px;text-align:center;
}
.sb-wa-icon{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,#1EBE5D,#25D366);
  display:flex;align-items:center;justify-content:center;margin:0 auto 12px;
}
.sb-wa-title{font-size:15px;font-weight:600;color:#fff;margin-bottom:6px}
.sb-wa-sub{font-size:12px;color:var(--muted);font-weight:300;margin-bottom:14px;line-height:1.5}
.sb-wa-btn{
  display:block;background:linear-gradient(135deg,#1EBE5D,#25D366);
  color:#fff;font-weight:700;font-size:13px;padding:11px 16px;
  border-radius:10px;text-decoration:none;transition:opacity .2s;
}
.sb-wa-btn:hover{opacity:.85}


/* ── 8. CONTROLS (sort / view) ───────────────────────────────── */
/* Идентично в cat_* и filtry (4 файла) */
.main-content{}
.mc-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.mc-count{font-size:13px;color:var(--muted)}
.mc-count strong{color:var(--text)}
.mc-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.view-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);border-radius:8px;
  padding:8px 12px;font-size:12px;font-weight:500;
  color:var(--muted);cursor:pointer;transition:all .2s;
}
.view-btn:hover,.view-btn.active{
  background:rgba(0,200,255,0.1);
  border-color:rgba(0,200,255,0.25);color:var(--aqua);
}
.sort-select{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);border-radius:8px;
  padding:8px 14px;font-size:12px;color:var(--text);
  outline:none;cursor:pointer;font-family:'DM Sans',sans-serif;
}
.sort-select option{background:#071426;color:var(--text)}


/* ── 9. PRODUCT CARD (.pcard) ────────────────────────────────── */
/* Идентично в cat_* и filtry (4 файла).
   magazin использует .pcard с расширенными блоками (featured, wish, badges,
   price-wrap) — они остаются в <style> magazin. */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:1100px){.products-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.products-grid{grid-template-columns:1fr}}
.products-grid.list-view{grid-template-columns:1fr}

.pcard{
  background:var(--card);border:1px solid rgba(255,255,255,0.07);
  border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;transition:all .25s;position:relative;
}
.pcard:hover{border-color:rgba(0,200,255,0.28);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.2)}
.pcard::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--aqua),var(--green));
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.pcard:hover::after{transform:scaleX(1)}

.pc-img{
  aspect-ratio:4/3;background:rgba(7,20,38,0.7);
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.pc-img-shimmer{
  position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 30%,rgba(0,200,255,0.04) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform .5s;
}
.pcard:hover .pc-img-shimmer{transform:translateX(100%)}

.pc-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:8px}
.pc-cat{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.pc-title{font-size:14px;font-weight:600;color:#fff;line-height:1.35;flex:1}
.pc-title a{color:inherit;text-decoration:none;transition:color .2s}
.pc-title a:hover{color:var(--aqua)}
.pc-specs{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.pc-spec{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  border-radius:5px;padding:2px 8px;font-size:10px;color:var(--muted);font-weight:500;
}
.pc-spec.hi{background:rgba(0,200,255,0.07);border-color:rgba(0,200,255,0.18);color:var(--aqua)}
.pc-footer{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding-top:10px;border-top:1px solid rgba(0,200,255,0.08);margin-top:4px;
}
.pc-wa{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,rgba(0,136,187,.15),rgba(0,200,255,.1));
  border:1px solid rgba(0,200,255,0.25);color:var(--aqua);
  padding:8px 14px;border-radius:8px;
  font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;white-space:nowrap;
}
.pc-wa:hover{background:rgba(0,200,255,0.2);border-color:var(--aqua)}

/* List-view — идентично в cat_* и filtry */
.products-grid.list-view .pcard{flex-direction:row}
.products-grid.list-view .pc-img{aspect-ratio:auto;width:140px;flex-shrink:0}
@media(max-width:600px){
  .products-grid.list-view .pcard{flex-direction:column}
  .products-grid.list-view .pc-img{width:100%;aspect-ratio:4/3}
}


/* ── 10. CTA STRIP ───────────────────────────────────────────── */
/* Идентично в cat_* и filtry (4 файла).
   nashi_raboty — .cta-banner (другой класс), about — .cta-section.
   Их не трогаем. */
.cta-strip{
  position:relative;z-index:1;
  background:linear-gradient(90deg,rgba(0,70,120,0.15),rgba(0,30,60,0.2));
  border-top:1px solid rgba(0,200,255,0.1);
  border-bottom:1px solid rgba(0,200,255,0.1);
  padding:44px 24px;
}
.cta-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.cta-text h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(28px,4vw,48px);color:#fff;
  letter-spacing:.02em;line-height:.95;margin-bottom:8px;
}
.cta-text h2 em{
  -webkit-text-fill-color:transparent;
  background:linear-gradient(135deg,#00C8FF,#00E8A0);
  -webkit-background-clip:text;background-clip:text;font-style:normal;
}
.cta-text p{font-size:14px;color:var(--muted);font-weight:300}
.cta-btns{display:flex;flex-wrap:wrap;gap:10px}


/* ── 11. КНОПКИ ──────────────────────────────────────────────── */
/* btn-primary: about/nashi/cat_* — 14px 28px, radius 10px.
   sabe_main.html — 15px 30px, radius 12px — переопределяет в <style>.
   cat_* — 13px 24px — переопределяет в <style>. */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#0088BB,#00C8FF);
  color:#fff;font-weight:600;font-size:15px;
  padding:14px 28px;border-radius:10px;
  border:none;cursor:pointer;
  text-decoration:none;transition:all .22s;
}
.btn-primary:hover{box-shadow:0 10px 32px rgba(0,200,255,0.35);transform:translateY(-2px)}

.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;
  border:1.5px solid rgba(0,200,255,0.3);
  color:var(--aqua);font-weight:600;font-size:15px;
  padding:13px 26px;border-radius:10px;
  text-decoration:none;transition:all .22s;
}
.btn-outline:hover{background:rgba(0,200,255,0.1);border-color:var(--aqua)}

/* btn-green — идентично в main и magazin */
.btn-green{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,232,160,0.12);
  border:1.5px solid rgba(0,232,160,0.35);
  color:var(--green);font-weight:600;font-size:14px;
  padding:13px 24px;border-radius:10px;
  cursor:pointer;text-decoration:none;transition:all .25s;
}
.btn-green:hover{background:rgba(0,232,160,0.2);border-color:var(--green)}


/* ── 12. REVEAL ──────────────────────────────────────────────── */
/* translateY: 20px в cat_*/filtry/magazin (5 файлов), 22px в about/nashi, 24px в main.
   Берём 20px (большинство). about/nashi/main переопределяют при желании.
   Задержки d1–d6: одинаковы в cat_*/filtry/magazin/nashi/about.
   main — другие значения (.06s, .12s…) — переопределяет в <style>. */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.reveal.on{opacity:1;transform:translateY(0)}
.d1{transition-delay:.05s}
.d2{transition-delay:.1s}
.d3{transition-delay:.15s}
.d4{transition-delay:.2s}
.d5{transition-delay:.25s}
.d6{transition-delay:.3s}


/* ── 13. ПУЗЫРЬКИ (.bbl) + ВОЛНА ────────────────────────────── */
/* .bbl — идентично во всех 8 файлах.
   БЕЗОПАСНО: inline style="--bop:X;--drift:Y" на элементах задаёт
   CSS-переменные. @keyframes bbl-rise читает их через var() —
   перенос в shared не нарушает эту связь. */
.bbl{
  position:absolute;bottom:-5%;border-radius:50%;
  border:1px solid rgba(0,200,255,0.28);
  background:radial-gradient(circle at 35% 35%,rgba(0,220,255,0.12),transparent 70%);
  animation:bbl-rise linear infinite;
  will-change:transform,opacity;
}
@keyframes bbl-rise{
  0%  {transform:translateY(0);opacity:0}
  5%  {opacity:var(--bop)}
  80% {opacity:var(--bop)}
  100%{transform:translateY(-90vh) translateX(var(--drift));opacity:0}
}

/* wavemove — идентично в 7 из 8 файлов */
@keyframes wavemove{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}


/* ── 14. FOOTER (упрощённый) ─────────────────────────────────── */
/* Идентичные классы в about, nashi_raboty, magazin, cat_*, filtry (7 файлов).
   sabe_main.html имеет расширенный footer (.footer-top, .social-btn и др.) —
   они остаются в <style> main.
   Padding: 40px/36px между страницами. Берём 40px (большинство). */
footer{
  background:var(--dark);
  border-top:1px solid rgba(0,200,255,0.1);
  padding:40px 24px 28px;
  position:relative;z-index:1;
}
.footer-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;
}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:30px;color:#fff;letter-spacing:.06em}
.footer-logo span{color:var(--aqua)}
.footer-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-lnk{font-size:13px;color:var(--muted);text-decoration:none;transition:color .2s}
.footer-lnk:hover{color:var(--aqua)}
.footer-copy{font-size:12px;color:var(--muted)}


/* ── 15. FLOAT WHATSAPP ──────────────────────────────────────── */
/* Идентично во всех 8 файлах.
   sabe_main.html: width/height 56px вместо 54px, shadow 8px вместо 6px —
   переопределяет в своём <style>. */
.float-wa{
  position:fixed;bottom:24px;right:24px;z-index:100;
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#1EBE5D,#25D366);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,.4);
  text-decoration:none;transition:transform .2s;
}
.float-wa:hover{transform:scale(1.1)}


/* ── 16. DIVIDER ─────────────────────────────────────────────── */
/* Используется в about. Статичный безопасный блок. */
.divider{
  width:100%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,0.15),transparent);
}


/* ── 17. PAGINATION ──────────────────────────────────────────── */
/* Идентично в cat_* и filtry (4 файла) */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:36px;flex-wrap:wrap}
.pg-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  border-radius:8px;padding:10px 18px;
  font-size:13px;font-weight:500;color:var(--muted);
  cursor:pointer;text-decoration:none;transition:all .2s;
}
.pg-btn:hover,.pg-btn.active{
  background:rgba(0,200,255,0.1);
  border-color:rgba(0,200,255,0.3);color:var(--aqua);
}
.pg-btn.active{font-weight:700}


/* ── 18. МОБИЛЬНЫЕ ОТСТУПЫ ───────────────────────────────────── */
/* Общий override для страниц с .page-header и .layout.
   Идентично в cat_* и filtry. */
@media(max-width:480px){
  .page-header{padding:86px 16px 36px}
  .layout{padding:20px 16px 52px}
  .pc-body{padding:14px}
}


/* ═══════════════════════════════════════════════════════════════
   SABE.KG — MAIN PAGE (catalogue section + modals)
   ═══════════════════════════════════════════════════════════════ */

/* ── CATALOGUE SECTION ── */
.catalogue-section{position:relative;z-index:1;padding:96px 24px}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:52px}
@media(max-width:1100px){.cat-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}}
@media(max-width:420px){.cat-grid{grid-template-columns:1fr}}

.cat-card{
  background:var(--card);border:1px solid rgba(255,255,255,0.07);
  border-radius:18px;padding:24px 20px 20px;cursor:pointer;
  transition:all .25s;display:flex;flex-direction:column;gap:10px;
  position:relative;overflow:hidden;
}
.cat-card::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--aqua),var(--green));
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.cat-card:hover{border-color:rgba(0,200,255,0.32);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.25)}
.cat-card:hover::before{transform:scaleX(1)}
.cat-card-img{
  width:calc(100% + 40px);margin:-24px -20px 18px;
  height:160px;border-radius:16px 16px 0 0;
  background:#1a2535;overflow:hidden;position:relative;flex-shrink:0;
}
.cs-track{display:flex;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.cs-slide{min-width:100%;height:160px;flex-shrink:0;overflow:hidden}
.cs-slide img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.cat-card:hover .cs-slide img{transform:scale(1.04)}
.cs-dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:2}
.cs-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.35);cursor:pointer;transition:all .2s}
.cs-dot.on{background:#fff;width:14px;border-radius:3px}
.cs-slide img[data-broken]{width:100%;height:100%;background:#1e2d42}
.cat-card-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.cat-card-name{font-size:15px;font-weight:600;color:#fff;line-height:1.3}
.cat-card-desc{font-size:12px;color:var(--muted);font-weight:300;line-height:1.6;flex:1}
.cat-card-cta{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--aqua);margin-top:4px}


/* ── CATALOGUE MODAL (умная форма подбора) ── */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(5,13,26,.88);backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:center;
  padding:16px;opacity:0;pointer-events:none;transition:opacity .25s;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:#071426;border:1px solid rgba(0,200,255,0.18);
  border-radius:20px;width:100%;max-width:520px;
  padding:32px 28px 28px;position:relative;max-height:90vh;overflow-y:auto;
}
.modal-close{
  position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.06);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s;
}
.modal-close:hover{background:rgba(255,255,255,0.12);color:#fff}
.modal-cat-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,200,255,0.1);border:1px solid rgba(0,200,255,0.25);
  border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;
  color:var(--aqua);letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;
}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;letter-spacing:.03em;margin-bottom:6px}
.modal-sub{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.55}
.modal-progress{display:flex;gap:6px;margin-bottom:28px}
.mp-dot{height:3px;border-radius:3px;background:rgba(0,200,255,0.18);flex:1;transition:background .3s}
.mp-dot.done{background:var(--aqua)}
.modal-step{display:none}
.modal-step.active{display:block}
.mf-group{margin-bottom:16px}
.mf-label{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;display:block}
.mf-label span{color:#e24b4a;margin-left:2px}
.mf-chips{display:flex;flex-wrap:wrap;gap:8px}
.mf-chip{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  border-radius:8px;padding:8px 14px;font-size:13px;color:var(--muted);
  cursor:pointer;transition:all .2s;user-select:none;
}
.mf-chip:hover{border-color:rgba(0,200,255,0.3);color:var(--text)}
.mf-chip.sel{background:rgba(0,200,255,0.12);border-color:rgba(0,200,255,0.5);color:var(--aqua);font-weight:600}
.mf-chip.err{border-color:rgba(226,75,74,.6)}
.mf-input{
  width:100%;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);border-radius:10px;padding:12px 14px;
  font-size:14px;color:var(--text);outline:none;transition:border-color .2s;font-family:'DM Sans',sans-serif;
}
.mf-input:focus{border-color:rgba(0,200,255,0.4)}
.mf-input::placeholder{color:var(--muted)}
.mf-input.err{border-color:rgba(226,75,74,.6)!important}
.mf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.mf-row{grid-template-columns:1fr}}
.modal-btns{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:24px}
.mf-btn-back{
  background:none;border:1px solid rgba(255,255,255,0.1);border-radius:10px;
  padding:12px 20px;font-size:14px;font-weight:600;color:var(--muted);
  cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;
}
.mf-btn-back:hover{border-color:rgba(255,255,255,0.25);color:var(--text)}
.mf-btn-next{
  background:linear-gradient(135deg,#0088BB,#00C8FF);border:none;border-radius:10px;
  padding:12px 28px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;
  transition:all .22s;font-family:'DM Sans',sans-serif;flex:1;
}
.mf-btn-next:hover{box-shadow:0 8px 24px rgba(0,200,255,.35);transform:translateY(-1px)}
.mf-btn-next:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}
.modal-success{text-align:center;padding:20px 0;display:none}
.modal-success-icon{
  width:64px;height:64px;border-radius:50%;
  background:rgba(0,232,160,0.15);border:2px solid rgba(0,232,160,0.4);
  display:flex;align-items:center;justify-content:center;margin:0 auto 20px;
}
.modal-success h3{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;margin-bottom:8px;letter-spacing:.04em}
.modal-success p{font-size:14px;color:var(--muted);line-height:1.6}


/* ── INFO MODALS (реквизиты, оплата, оферта, политика) ── */
.info-modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(5,13,26,.92);backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;pointer-events:none;transition:opacity .25s;
}
.info-modal-overlay.open{opacity:1;pointer-events:all}
.info-modal{
  background:#071426;border:1px solid rgba(0,200,255,0.2);
  border-radius:22px;width:100%;max-width:620px;
  max-height:85vh;display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.info-modal-head{
  padding:28px 32px 20px;flex-shrink:0;
  border-bottom:1px solid rgba(0,200,255,0.1);position:relative;
}
.info-modal-head::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,255,0.07),transparent 70%);pointer-events:none;
}
.info-modal-icon{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0;
}
.info-modal-title{font-family:'Bebas Neue',sans-serif;font-size:30px;color:#fff;letter-spacing:.03em;line-height:1;margin-bottom:4px}
.info-modal-sub{font-size:13px;color:var(--muted)}
.info-modal-close{
  position:absolute;top:20px;right:20px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,0.06);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s;
}
.info-modal-close:hover{background:rgba(255,255,255,0.12);color:#fff}
.info-modal-body{padding:24px 32px 28px;overflow-y:auto;flex:1}
.info-modal-body::-webkit-scrollbar{width:4px}
.info-modal-body::-webkit-scrollbar-track{background:transparent}
.info-modal-body::-webkit-scrollbar-thumb{background:rgba(0,200,255,0.25);border-radius:2px}
.req-block{margin-bottom:20px}
.req-block:last-child{margin-bottom:0}
.req-block-title{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--aqua);margin-bottom:10px}
.req-row{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.req-row:last-child{border-bottom:none}
.req-label{font-size:13px;color:var(--muted);min-width:160px;flex-shrink:0}
.req-value{font-size:13px;color:#fff;font-weight:500;word-break:break-all}
.req-value.mono{font-family:monospace;letter-spacing:.04em;color:var(--aqua)}
.pay-method{
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);
  border-radius:14px;padding:18px 20px;margin-bottom:12px;
  display:flex;gap:16px;align-items:flex-start;transition:border-color .2s;
}
.pay-method:hover{border-color:rgba(0,200,255,0.2)}
.pay-method:last-child{margin-bottom:0}
.pay-method-icon{
  width:42px;height:42px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.pay-method-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:5px}
.pay-method-desc{font-size:13px;color:var(--muted);line-height:1.6;font-weight:300}
.legal-text h2{font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--aqua);letter-spacing:.06em;margin:20px 0 10px}
.legal-text h2:first-child{margin-top:0}
.legal-text p{font-size:13px;color:var(--text);line-height:1.7;font-weight:300;margin-bottom:10px}
.legal-text p:last-child{margin-bottom:0}
.legal-text ul{margin:8px 0 10px 18px}
.legal-text ul li{font-size:13px;color:var(--muted);line-height:1.7;font-weight:300;margin-bottom:4px}


/* ── CAT-CARD IMAGE EFFECTS ──────────────────────────────────────
   Затемнение + пузырьки + волна поверх фото в карточках каталога
   ─────────────────────────────────────────────────────────────── */

/* Позиционирование для оверлеев */
.cat-card-img{position:relative}

/* Тёмная плёнка поверх фото — постоянная, слегка */
.cat-card-img::after{
  content:'';
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(
    180deg,
    rgba(5,13,26,0.28) 0%,
    rgba(5,13,26,0.08) 40%,
    rgba(5,13,26,0.42) 100%
  );
  transition:opacity .35s ease;
}
/* При наведении чуть темнее */
.cat-card:hover .cat-card-img::after{
  background:linear-gradient(
    180deg,
    rgba(5,13,26,0.45) 0%,
    rgba(5,13,26,0.15) 40%,
    rgba(5,13,26,0.65) 100%
  );
}


/* Пузырьки */
.cat-card-img .ci-bubbles{
  position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden;
}
.cat-card-img .ci-bubbles span{
  position:absolute;bottom:-12px;
  border-radius:50%;
  border:1px solid rgba(0,200,255,0.45);
  background:radial-gradient(circle at 35% 35%,rgba(0,220,255,0.22),transparent 70%);
  opacity:0;
}
.cat-card:hover .ci-bubbles span{
  animation:ci-bbl var(--bd,2.2s) ease-in-out var(--bdd,0s) infinite;
}
@keyframes ci-bbl{
  0%  {bottom:-12px;opacity:0;transform:translateX(0) scale(1)}
  8%  {opacity:.8}
  85% {opacity:.25}
  100%{bottom:108%;opacity:0;transform:translateX(var(--bdx,5px)) scale(.45)}
}

/* cs-dots поверх всех оверлеев */
.cs-dots{z-index:4}


/* ═══════════════════════════════════════════════════════════════
   SABE.KG — MOBILE ADAPTATION
   Breakpoints: 1024px, 768px, 600px, 480px, 360px
   ═══════════════════════════════════════════════════════════════ */

/* ── TABLET 1024px ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px}
}

/* ── TABLET 900px ──────────────────────────────────────────────── */
@media(max-width:900px){
  .managers-grid{grid-template-columns:1fr}
  .contacts-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── MOBILE 768px ──────────────────────────────────────────────── */
@media(max-width:768px){
  /* Hero */
  section{padding:72px 16px}
  .hero{padding:84px 16px 48px}
  .hero-stats{gap:0;padding-top:28px}
  .stat{min-width:80px;padding:0 12px}

  /* Hero кнопки */
  .hero-btns{flex-direction:column;align-items:stretch;gap:10px}
  .hero-btns .btn-primary,
  .hero-btns .btn-outline{justify-content:center;width:100%}

  /* Секции */
  .section-head{margin-bottom:32px}
  .section-title{font-size:clamp(28px,8vw,48px)}

  /* Services */
  .services-grid{grid-template-columns:1fr;gap:12px}
  .service-card{padding:24px 20px}

  /* Why */
  .why-grid{grid-template-columns:1fr;gap:12px}
  .why-item{padding:22px 18px}

  /* News */
  .news-grid{grid-template-columns:1fr;gap:12px}

  /* Projects */
  .projects-grid{grid-template-columns:1fr}
  .project-card.stat-card{min-height:200px}

  /* Partners */
  .partners-row{gap:8px}
  .partner-card{min-width:100px;padding:12px 16px}
  .partner-card img{width:90px;height:32px}

  /* Contacts */
  .contacts-grid{grid-template-columns:1fr}
  .contact-card{padding:28px 22px}

  /* Managers */
  .managers-grid{grid-template-columns:1fr;gap:12px}

  /* Form */
  .form-wrap{padding:32px 18px;border-radius:14px}
  .fields-2{grid-template-columns:1fr}

  /* Footer */
  .footer-top{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .footer-payment{flex-wrap:wrap}

  /* Info modal */
  .info-modal{border-radius:16px}
  .info-modal-head{padding:22px 20px 16px}
  .info-modal-body{padding:18px 20px 22px}
  .req-label{min-width:120px;font-size:12px}
  .req-value{font-size:12px}
  .request-block{flex-direction:column;gap:16px;padding:24px 20px}

  /* Docs page */
  .docs-page{grid-template-columns:1fr;padding:32px 16px 60px}
  .docs-sidebar{position:static}
  .docs-sidebar-inner{flex-direction:row;flex-wrap:wrap;gap:4px;padding:14px}
  .sidebar-nav-link{font-size:12px;padding:7px 10px}
  .docs-hero{padding:90px 16px 40px}
  .docs-hero-inner{flex-direction:column;gap:20px;text-align:left}
  .docs-hero-divider{display:none}
  .docs-hero-logo img{height:52px}
  .docs-grid{grid-template-columns:1fr}

  /* Nashi raboty */
  .ph-header-row{flex-direction:column;align-items:flex-start;gap:16px}
  .ph-logo-divider{display:none}
  .ph-logo-wrap{margin-left:0}
  .ph-logo-img{height:52px}
  .ph-title{font-size:clamp(36px,10vw,60px)}
  .filter-bar-inner{gap:6px}
  .filter-btn{padding:7px 12px;font-size:12px}
  .projects-grid.pcard-grid{grid-template-columns:1fr}
  .pcard-body.featured-body{grid-template-columns:1fr;padding:18px 16px}

  /* About */
  .about-grid{grid-template-columns:1fr}
  .timeline-item{flex-direction:column;gap:8px}
  .cert-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── MOBILE 600px ──────────────────────────────────────────────── */
@media(max-width:600px){
  /* Cat grid уже 2 колонки, при 420 → 1 */
  .banner-card{padding:22px 18px}
  .banner-name{font-size:22px}

  /* Stat карточка */
  .stat-num{font-size:32px}

  /* Modal catalogue */
  .modal{padding:24px 16px 20px;border-radius:14px}
  .modal-title{font-size:22px}
  .mf-chip{padding:7px 10px;font-size:12px}

  /* Info modals */
  .req-row{flex-direction:column;gap:4px;padding:8px 0}
  .req-label{min-width:unset}
  .info-grid{grid-template-columns:1fr}
  .pay-method{flex-direction:column;gap:10px}
  .pay-method-icon{width:36px;height:36px}
}

/* ── SMALL MOBILE 480px ────────────────────────────────────────── */
@media(max-width:480px){
  nav{padding:0 16px}
  .hero-sub{font-size:14px}
  .hero-badge{font-size:11px;padding:6px 14px}

  .cat-card{padding:18px 14px 16px}
  .cat-card-img{width:calc(100% + 28px);margin:-18px -14px 14px}
  .cat-card-name{font-size:14px}
  .cat-card-desc{font-size:11px}

  .service-num,.why-num{font-size:36px}
  .service-title,.why-title{font-size:15px}

  .manager-card{padding:20px 16px}
  .manager-name{font-size:14px}

  .docs-stats{gap:20px}
  .docs-stat-num{font-size:28px}

  .footer-top{gap:20px}
  .footer-logo{font-size:28px}

  /* Реквизиты */
  .req-block-title{font-size:9px}
}

/* ── TINY 360px ────────────────────────────────────────────────── */
@media(max-width:360px){
  .hero-stats{flex-wrap:wrap}
  .stat{flex:1;min-width:100px;border:none;padding:8px}
  .stat+.stat{border-left:none;border-top:1px solid rgba(0,200,255,0.1)}

  .cat-grid{grid-template-columns:1fr}

  .banner-name{font-size:20px}
  .section-title{font-size:26px}
}


/* ═══════════════════════════════════════════════════════════════
   SABE DOCS — ACCORDION & TABS (sabe_docs.html)
   ═══════════════════════════════════════════════════════════════ */

/* ── Вкладки ── */
.inst-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.inst-tab{padding:8px 18px;border-radius:20px;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .2s;border:1px solid rgba(255,255,255,0.1);
  background:rgba(255,255,255,0.04);color:var(--muted)}
.inst-tab:hover{border-color:rgba(255,80,120,0.3);color:var(--text)}
.inst-tab.active{background:rgba(255,80,120,0.12);border-color:rgba(255,80,120,0.4);color:#FF5078}
.inst-panel{display:none}
.inst-panel.active{display:block}

/* ── Аккордеон ── */
.accordion{display:flex;flex-direction:column;gap:8px}
.acc-item{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);
  border-radius:14px;overflow:hidden;transition:border-color .2s}
.acc-item.open{border-color:rgba(255,80,120,0.25)}
.acc-head{display:flex;align-items:center;gap:16px;padding:16px 20px;
  cursor:pointer;user-select:none;transition:background .2s}
.acc-head:hover{background:rgba(255,255,255,0.03)}
.acc-num{font-family:'Bebas Neue',sans-serif;font-size:24px;
  color:rgba(255,80,120,0.3);line-height:1;flex-shrink:0;width:32px;transition:color .2s}
.acc-item.open .acc-num{color:rgba(255,80,120,0.8)}
.acc-title{font-size:15px;font-weight:600;color:#fff;flex:1}
.acc-arrow{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,0.05);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .25s;color:var(--muted)}
.acc-item.open .acc-arrow{background:rgba(255,80,120,0.12);color:#FF5078;transform:rotate(180deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.acc-item.open .acc-body{max-height:1400px}
.acc-content{padding:0 20px 20px 68px}
.acc-content p{font-size:13px;color:var(--text);line-height:1.75;font-weight:300;margin-bottom:8px}
.acc-content p:last-child{margin-bottom:0}
.acc-content ul{margin:8px 0 8px 16px;display:flex;flex-direction:column;gap:6px}
.acc-content ul li{font-size:13px;color:var(--muted);line-height:1.65;font-weight:300}
.acc-content ul li strong{font-weight:500}
.acc-warning{display:flex;align-items:flex-start;gap:10px;
  background:rgba(255,214,0,0.06);border:1px solid rgba(255,214,0,0.2);
  border-radius:10px;padding:12px 14px;margin-top:12px}
.acc-warning svg{flex-shrink:0;margin-top:1px}
.acc-warning p{font-size:12px;color:#FFD600;margin:0;font-weight:400}
.acc-note{display:flex;align-items:flex-start;gap:10px;
  background:rgba(0,200,255,0.05);border:1px solid rgba(0,200,255,0.15);
  border-radius:10px;padding:12px 14px;margin-top:12px}
.acc-note svg{flex-shrink:0;margin-top:1px}
.acc-note p{font-size:12px;color:var(--aqua);margin:0;font-weight:400}

/* ── Таблица обслуживания ── */
.maint-table{border:1px solid rgba(255,255,255,0.07);border-radius:12px;overflow:hidden;margin-top:12px}
.maint-row{display:grid;grid-template-columns:1fr 140px}
.maint-row.header{background:rgba(255,80,120,0.08)}
.maint-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,0.05)}
.maint-cell{padding:10px 14px;font-size:13px;color:var(--text);font-weight:300;line-height:1.5}
.maint-row.header .maint-cell{font-size:10px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)}
.maint-cell.freq{border-left:1px solid rgba(255,255,255,0.05);color:var(--aqua);
  font-weight:500;text-align:center;display:flex;align-items:center;justify-content:center}
.maint-row.header .maint-cell.freq{color:var(--muted)}

@media(max-width:600px){
  .acc-content{padding:0 14px 16px 14px}
  .acc-num{font-size:20px;width:24px}
  .maint-row{grid-template-columns:1fr}
  .maint-cell.freq{border-left:none;border-top:1px solid rgba(255,255,255,0.05);justify-content:flex-start}
}




.marquee-wrap::before,.marquee-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee-wrap::before{left:0;background:linear-gradient(90deg,var(--dark),transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(-90deg,var(--dark),transparent)}


.marquee-wrap:hover 
100%{transform:translateX(-100%)}}



.marquee-item:hover img{opacity:1}
.marquee-item .pf{
  font-size:13px;font-weight:600;
  color:#333;letter-spacing:.04em;
}


/* ═══════════════════════════════════════════════════
   SABE MAIN — перенесено из инлайна sabe_main.html
   ═══════════════════════════════════════════════════ */

/* ════════════════════════════════════════
   SABE.KG — MAIN WEBSITE
   Design: dark aqua premium (Bebas Neue + DM Sans)
   ════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --aqua:#00C8FF;
  --green:#00E8A0;
  --yellow:#FFD600;
  --dark:#050D1A;
  --dark2:#071426;
  --dark3:#071E38;
  --card:rgba(255,255,255,0.04);
  --border:rgba(0,200,255,0.18);
  --text:#C8DFF0;
  --muted:#5C7A96;
  --white:#fff;
}
html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--text);font-family:'DM Sans',sans-serif;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(rgba(0,200,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,200,255,0.025) 1px,transparent 1px);background-size:60px 60px}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(5,13,26,0.92);backdrop-filter:blur(24px);border-bottom:1px solid rgba(0,200,255,0.1);padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-left{display:flex;align-items:center;gap:14px}
.nav-logo{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#005F88,#00C8FF);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:22px;color:#fff;letter-spacing:.05em;flex-shrink:0}
.nav-brand{font-family:'Bebas Neue',sans-serif;font-size:26px;color:#fff;letter-spacing:.08em;line-height:1}
.nav-brand span{color:var(--aqua)}
.nav-tagline{display:none;font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;padding-left:14px;border-left:1px solid rgba(0,200,255,0.2)}
@media(min-width:768px){.nav-tagline{display:block}}
.nav-links{display:none;align-items:center;gap:6px}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-link{font-size:14px;font-weight:500;color:var(--muted);text-decoration:none;padding:8px 14px;border-radius:8px;transition:all .2s;letter-spacing:.02em}
.nav-link:hover{color:#fff;background:rgba(0,200,255,0.08)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-phone{display:none;font-size:14px;font-weight:600;color:var(--aqua);text-decoration:none;letter-spacing:.02em}
@media(min-width:768px){.nav-phone{display:block}}
.nav-wa{display:inline-flex;align-items:center;gap:8px;background:rgba(0,200,255,0.1);border:1px solid rgba(0,200,255,0.3);color:var(--aqua);padding:9px 18px;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;letter-spacing:.03em}
.nav-wa:hover{background:rgba(0,200,255,0.18);border-color:var(--aqua)}
.nav-burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
@media(min-width:1024px){.nav-burger{display:none}}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}

/* ── HERO ── */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:90px 24px 60px;overflow:hidden;z-index:1}
.hero-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 90% 55% at 50% 100%,rgba(0,100,180,0.5) 0%,transparent 65%),radial-gradient(ellipse 55% 40% at 8% 55%,rgba(0,200,255,0.08) 0%,transparent 60%),radial-gradient(ellipse 40% 45% at 92% 30%,rgba(0,200,120,0.04) 0%,transparent 55%),linear-gradient(180deg,#050D1A 0%,#071E38 48%,#050D1A 100%)}
.hero-bubbles{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bbl{position:absolute;bottom:-5%;border-radius:50%;border:1px solid rgba(0,200,255,0.3);background:radial-gradient(circle at 35% 35%,rgba(0,220,255,0.15) 0%,rgba(0,180,255,0.05) 50%,transparent 100%);animation:bbl-rise linear infinite;will-change:transform,opacity}
.bbl::before{content:'';position:absolute;top:18%;left:22%;width:28%;height:18%;border-radius:50%;background:rgba(255,255,255,0.28);transform:rotate(-30deg)}
@keyframes bbl-rise{0%{transform:translateY(0);opacity:0}5%{opacity:var(--bop)}80%{opacity:var(--bop)}100%{transform:translateY(-110vh) translateX(var(--drift));opacity:0}}
.wave{position:absolute;bottom:0;left:0;right:0;z-index:1;line-height:0;pointer-events:none}
.wave svg{width:200%;animation:wavemove linear infinite}
.w1 svg{animation-duration:16s}
.w2 svg{animation-duration:22s;animation-direction:reverse;opacity:.35}
.w3 svg{animation-duration:30s;opacity:.2}
@keyframes wavemove{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.hero::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--aqua) 30%,var(--aqua) 70%,transparent);opacity:.1;animation:scanline 12s ease-in-out infinite}
@keyframes scanline{0%,100%{top:3%;opacity:.1}50%{top:95%;opacity:.04}}
.hero-inner{position:relative;z-index:2;max-width:900px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(0,200,255,0.1);border:1px solid rgba(0,200,255,0.3);border-radius:40px;padding:7px 20px;font-size:13px;font-weight:500;color:var(--aqua);letter-spacing:.06em;margin-bottom:28px;animation:fadein .6s ease both}
.hero-dot{width:7px;height:7px;background:var(--aqua);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(0,200,255,.6)}50%{box-shadow:0 0 0 6px rgba(0,200,255,0)}}
h1.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(52px,11vw,118px);line-height:.9;letter-spacing:.02em;background:linear-gradient(135deg,#fff 25%,#00C8FF 55%,#00E8A0 88%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:22px;animation:slideup .7s ease both .1s}
.hero-sub{font-size:clamp(15px,2.2vw,19px);color:var(--text);max-width:680px;line-height:1.7;margin:0 auto 44px;font-weight:300;animation:fadein .8s ease both .3s}
.hero-sub strong{color:#fff;font-weight:500}
@keyframes fadein{from{opacity:0}to{opacity:1}}
@keyframes slideup{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;animation:fadein .8s ease both .45s;margin-bottom:60px}
@media(max-width:480px){.hero-btns{flex-direction:column;align-items:stretch}.hero-btns .btn-primary,.hero-btns .btn-outline{justify-content:center}}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#0088BB,#00C8FF);color:#fff;font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;padding:15px 30px;border-radius:12px;border:none;cursor:pointer;text-decoration:none;transition:all .25s;letter-spacing:.02em}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,200,255,0.35)}
.btn-outline{display:inline-flex;align-items:center;gap:10px;background:transparent;color:var(--aqua);font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;padding:14px 30px;border-radius:12px;border:1.5px solid rgba(0,200,255,0.45);cursor:pointer;text-decoration:none;transition:all .25s;letter-spacing:.02em}
.btn-outline:hover{background:rgba(0,200,255,0.08);border-color:var(--aqua);transform:translateY(-2px)}
.btn-green{display:inline-flex;align-items:center;gap:8px;background:rgba(0,232,160,0.12);border:1.5px solid rgba(0,232,160,0.35);color:var(--green);font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;padding:13px 24px;border-radius:10px;cursor:pointer;text-decoration:none;transition:all .25s;letter-spacing:.02em}
.btn-green:hover{background:rgba(0,232,160,0.2);border-color:var(--green)}
.hero-stats{display:flex;justify-content:center;flex-wrap:wrap;border-top:1px solid rgba(0,200,255,0.12);padding-top:38px;width:100%;max-width:720px;margin:0 auto;animation:fadein .8s ease both .6s}
.stat{flex:1;min-width:120px;text-align:center;padding:0 20px}
.stat+.stat{border-left:1px solid rgba(0,200,255,0.1)}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,6vw,52px);color:#fff;line-height:1;letter-spacing:.02em}
.stat-num em{color:var(--aqua);font-style:normal;font-size:.75em}
.stat-lbl{font-size:11px;color:var(--muted);margin-top:5px;font-weight:400;letter-spacing:.07em;text-transform:uppercase}

/* ── SECTIONS ── */
section{position:relative;z-index:1;padding:96px 24px}
.container{max-width:1200px;margin:0 auto}
.section-tag{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--aqua);margin-bottom:12px;display:block}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(34px,5.5vw,68px);color:#fff;line-height:.97;letter-spacing:.02em;margin-bottom:16px}
.section-sub{font-size:16px;color:var(--muted);max-width:540px;line-height:1.65;font-weight:300}
.section-head{margin-bottom:52px}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.reveal.on{opacity:1;transform:translateY(0)}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.19s}
.d4{transition-delay:.26s}.d5{transition-delay:.33s}.d6{transition-delay:.4s}

/* ── CATALOGUE ── */
.catalogue{background:var(--dark)}
.cat-nav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:44px}
.cat-btn{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:30px;padding:8px 18px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s;text-decoration:none}
.cat-btn:hover,.cat-btn.active{background:rgba(0,200,255,0.1);border-color:rgba(0,200,255,0.3);color:var(--aqua)}
.cat-dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.5}

/* Product cards grid */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.product-card{background:var(--card);border:1px solid rgba(255,255,255,0.07);border-radius:18px;overflow:hidden;transition:all .28s;display:flex;flex-direction:column}
.product-card:hover{border-color:rgba(0,200,255,0.28);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,0.25)}
.product-img{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,rgba(0,80,120,0.3),rgba(0,30,60,0.5));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.product-img-inner{width:80px;height:80px;opacity:.6}
.product-label{position:absolute;top:12px;left:12px;background:linear-gradient(135deg,#FFD600,#FF8C00);color:#000;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:20px}
.product-label-new{background:linear-gradient(135deg,#00E8A0,#00C8FF);color:#050D1A}
.product-body{padding:20px 22px 22px;flex:1;display:flex;flex-direction:column;gap:10px}
.product-cat{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--aqua)}
.product-name{font-size:16px;font-weight:600;color:#fff;line-height:1.3}
.product-desc{font-size:13px;font-weight:300;color:var(--muted);line-height:1.6;flex:1}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px}
.product-price{font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--aqua);letter-spacing:.04em}
.product-wa{display:inline-flex;align-items:center;gap:6px;background:rgba(0,232,160,0.1);border:1px solid rgba(0,232,160,0.3);color:var(--green);padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;letter-spacing:.03em}
.product-wa:hover{background:rgba(0,232,160,0.2);border-color:var(--green)}

/* Featured product */
.product-card.featured{border-color:rgba(0,200,255,0.25);background:linear-gradient(135deg,rgba(0,200,255,0.06),rgba(0,232,160,0.02))}
.product-card.featured::after{content:'★ Flagship';position:absolute;top:0;right:0;background:linear-gradient(135deg,#005F88,#00C8FF);color:#fff;font-size:10px;font-weight:700;letter-spacing:.1em;padding:5px 12px;border-radius:0 18px 0 10px}
.product-card.featured{position:relative}

/* ── CATEGORIES BANNER ── */
.cat-banners{background:linear-gradient(180deg,var(--dark) 0%,var(--dark3) 60%,var(--dark) 100%)}
.banners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}


.banner-card{background:var(--card);border:1px solid rgba(255,255,255,0.07);border-radius:18px;padding:32px 26px;text-decoration:none;display:flex;flex-direction:column;gap:14px;transition:all .28s;position:relative;overflow:hidden}
.banner-card:hover{border-color:rgba(0,200,255,0.3);transform:translateY(-4px);background:rgba(0,200,255,0.04)}
.banner-card::before{content:'';position:absolute;top:-40px;right:-40px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,255,0.07),transparent 70%);pointer-events:none}
.banner-icon{width:56px;height:56px;border-radius:14px;background:rgba(0,200,255,0.1);border:1px solid rgba(0,200,255,0.22);display:flex;align-items:center;justify-content:center}
.banner-card.jade .banner-icon{background:rgba(0,232,160,0.1);border-color:rgba(0,232,160,0.25)}
.banner-card.jade:hover{border-color:rgba(0,232,160,0.35);background:rgba(0,232,160,0.03)}
.banner-card.amber .banner-icon{background:rgba(255,214,0,0.1);border-color:rgba(255,214,0,0.25)}
.banner-card.amber:hover{border-color:rgba(255,214,0,0.35);background:rgba(255,214,0,0.02)}
.banner-card.rose .banner-icon{background:rgba(255,80,120,0.1);border-color:rgba(255,80,120,0.2)}
.banner-card.rose:hover{border-color:rgba(255,80,120,0.3);background:rgba(255,80,120,0.02)}
.banner-name{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;line-height:.95;letter-spacing:.02em}
.banner-text{font-size:13px;font-weight:300;color:var(--muted);line-height:1.6}
.banner-link{font-size:12px;font-weight:600;color:var(--aqua);letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:5px}
.banner-card.jade .banner-link{color:var(--green)}
.banner-card.amber .banner-link{color:#FFD600}

/* ── SERVICES ── */
.services-section{background:var(--dark)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr;gap:12px}}


.service-card{background:var(--card);border:1px solid rgba(255,255,255,0.07);border-radius:18px;padding:34px 28px;transition:all .28s;position:relative;overflow:hidden}
.service-card:hover{border-color:rgba(0,200,255,0.25);transform:translateY(-3px)}
.service-card::before{content:'';position:absolute;bottom:-20px;right:-20px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,255,0.06),transparent 70%)}
.service-num{font-family:'Bebas Neue',sans-serif;font-size:48px;color:rgba(0,200,255,0.12);line-height:1;margin-bottom:14px}
.service-title{font-size:17px;font-weight:600;color:#fff;margin-bottom:10px}
.service-text{font-size:14px;font-weight:300;color:var(--muted);line-height:1.7}

/* ── WHY US ── */
.why-section{background:var(--dark)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr;gap:12px}}


.why-item{background:var(--card);border:1px solid rgba(255,255,255,0.06);border-radius:16px;padding:30px 26px;transition:border-color .25s}
.why-item:hover{border-color:rgba(0,200,255,0.2)}
.why-num{font-family:'Bebas Neue',sans-serif;font-size:48px;color:rgba(0,200,255,0.13);line-height:1;margin-bottom:12px}
.why-title{font-size:15px;font-weight:600;color:#fff;margin-bottom:8px}
.why-text{font-size:13px;font-weight:300;color:var(--muted);line-height:1.65}

/* ── NEWS ── */
.news-section{background:linear-gradient(180deg,var(--dark) 0%,var(--dark3) 100%)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.news-grid{grid-template-columns:1fr;gap:12px}}


.news-card{background:var(--card);border:1px solid rgba(255,255,255,0.07);border-radius:18px;overflow:hidden;transition:all .28s;display:flex;flex-direction:column}
.news-card:hover{border-color:rgba(0,200,255,0.25);transform:translateY(-3px)}
.news-thumb{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,rgba(0,60,100,0.5),rgba(0,20,40,0.7));display:flex;align-items:center;justify-content:center;position:relative}
.news-date{position:absolute;top:12px;left:12px;background:rgba(0,200,255,0.15);backdrop-filter:blur(8px);border:1px solid rgba(0,200,255,0.28);color:var(--aqua);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.06em}
.news-cat{position:absolute;bottom:12px;right:12px;background:rgba(0,232,160,0.15);border:1px solid rgba(0,232,160,0.28);color:var(--green);font-size:10px;font-weight:700;padding:3px 10px;border-radius:12px;letter-spacing:.06em;text-transform:uppercase}
.news-body{padding:20px 22px 22px;flex:1;display:flex;flex-direction:column;gap:8px}
.news-title{font-size:15px;font-weight:600;color:#fff;line-height:1.4;flex:1}
.news-excerpt{font-size:13px;font-weight:300;color:var(--muted);line-height:1.6}
.news-link{font-size:12px;font-weight:600;color:var(--aqua);text-decoration:none;letter-spacing:.04em;display:inline-flex;align-items:center;gap:4px;margin-top:4px;transition:color .2s}
.news-link:hover{color:#fff}

/* ── PARTNERS ── */

.partner-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);border-radius:14px;padding:18px 28px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:var(--muted);transition:all .2s;cursor:default;letter-spacing:.04em;min-width:140px;text-align:center}
.partner-card:hover{border-color:rgba(0,200,255,0.2);color:var(--text)}

/* ── CONTACTS ── */
.contacts-section{background:linear-gradient(180deg,var(--dark) 0%,var(--dark3) 100%)}
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}

.contact-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:40px 36px;position:relative;overflow:hidden}
.contact-card::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,255,0.07),transparent 70%);pointer-events:none}
.contact-title{font-family:'Bebas Neue',sans-serif;font-size:36px;color:#fff;letter-spacing:.02em;margin-bottom:24px}
.contact-items{display:flex;flex-direction:column;gap:14px}
.contact-item{display:flex;align-items:flex-start;gap:14px}
.ci-icon{width:38px;height:38px;border-radius:10px;background:rgba(0,200,255,0.1);border:1px solid rgba(0,200,255,0.2);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px}
.ci-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.ci-value{font-size:15px;font-weight:500;color:#fff}
.ci-value a{color:#fff;text-decoration:none}
.ci-value a:hover{color:var(--aqua)}
.map-placeholder{background:linear-gradient(135deg,rgba(0,40,80,0.6),rgba(0,20,50,0.8));border-radius:16px;height:320px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,200,255,0.1);flex-direction:column;gap:14px}
.map-placeholder-text{font-size:14px;color:var(--muted);text-align:center;line-height:1.6}
.cta-buttons{display:flex;flex-direction:column;gap:10px;margin-top:28px}

/* ── FORM ── */
.form-section{background:linear-gradient(180deg,var(--dark3) 0%,var(--dark) 100%)}
.form-wrap{max-width:680px;margin:0 auto;background:rgba(7,20,38,0.9);border:1px solid rgba(0,200,255,0.2);border-radius:24px;padding:56px 48px;backdrop-filter:blur(24px);position:relative;overflow:hidden}
.form-wrap::before{content:'';position:absolute;top:0;right:0;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,255,0.055),transparent 70%);transform:translate(50%,-40%);pointer-events:none}
@media(max-width:640px){.form-wrap{padding:36px 22px;border-radius:16px}}
.form-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,7vw,60px);color:#fff;line-height:.95;letter-spacing:.02em;margin-bottom:10px}
.form-sub{font-size:15px;color:var(--muted);margin-bottom:34px;line-height:1.6;font-weight:300}
.fields-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:540px){.fields-2{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea,.field select{background:rgba(255,255,255,0.04);border:1px solid rgba(0,200,255,0.16);border-radius:10px;padding:12px 15px;color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;width:100%}
.field input:focus,.field textarea:focus,.field select:focus{border-color:rgba(0,200,255,0.5);background:rgba(0,200,255,0.04)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field textarea{resize:none;height:84px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235C7A96' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.field select option{background:#071426;color:#fff}
.submit-btn{width:100%;padding:16px;background:linear-gradient(135deg,#0088BB,#00C8FF);color:#fff;font-family:'DM Sans',sans-serif;font-weight:700;font-size:15px;letter-spacing:.04em;border:none;border-radius:12px;cursor:pointer;transition:all .25s;margin-top:4px}
.submit-btn:hover{box-shadow:0 10px 36px rgba(0,200,255,0.32);transform:translateY(-2px)}
.privacy{font-size:11px;color:var(--muted);margin-top:12px;text-align:center;line-height:1.6}
.privacy a{color:rgba(0,200,255,0.5);text-decoration:none}
.form-success{display:none;text-align:center;padding:40px 0}
.form-success h3{font-family:'Bebas Neue',sans-serif;font-size:48px;color:var(--green);text-transform:uppercase;margin-bottom:10px}
.form-success p{font-size:15px;color:var(--muted);line-height:1.6;margin-bottom:24px}

/* ── FOOTER ── */
footer{background:var(--dark);border-top:1px solid rgba(0,200,255,0.1);padding:56px 24px 36px;position:relative;z-index:1}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
@media(max-width:1024px){.footer-top{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:540px){.footer-top{grid-template-columns:1fr;gap:20px}}


.footer-logo-block{}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:38px;color:#fff;letter-spacing:.06em;line-height:1;margin-bottom:8px}
.footer-logo span{color:var(--aqua)}
.footer-tagline{font-size:13px;color:var(--muted);font-weight:300;line-height:1.6;margin-bottom:20px;max-width:240px}
.footer-socials{display:flex;gap:10px}
.social-btn{width:36px;height:36px;border-radius:8px;background:rgba(0,200,255,0.08);border:1px solid rgba(0,200,255,0.15);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all .2s}
.social-btn:hover{background:rgba(0,200,255,0.16);border-color:rgba(0,200,255,0.35)}
.footer-col-title{font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;letter-spacing:.06em;margin-bottom:16px}
.footer-links-list{display:flex;flex-direction:column;gap:9px}
.footer-link{font-size:13px;color:var(--muted);text-decoration:none;transition:color .2s;line-height:1.4}
.footer-link:hover{color:var(--aqua)}
.footer-contact-item{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:13px;color:var(--text)}
.footer-contact-item a{color:var(--text);text-decoration:none}
.footer-contact-item a:hover{color:var(--aqua)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;border-top:1px solid rgba(0,200,255,0.08);padding-top:28px}
.footer-copy{font-size:13px;color:var(--muted)}
.footer-copy a{color:var(--muted);text-decoration:none}
.footer-copy a:hover{color:var(--aqua)}
.footer-payment{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pay-badge{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.06em}

/* ── FLOATING WHATSAPP ── */
.float-wa{position:fixed;bottom:24px;right:24px;z-index:100;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#1EBE5D,#25D366);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(37,211,102,0.4);text-decoration:none;transition:transform .2s}
.float-wa:hover{transform:scale(1.08)}
 
/* ── MOBILE MENU ── */





 
@media(max-width:500px){
  section{padding:72px 16px}
  .hero{padding:84px 16px 52px}
  .hero-btns .btn-primary,.hero-btns .btn-outline{flex:1;justify-content:center}
}
 
/* ── MANAGERS ── */
.managers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:0}
@media(max-width:900px){.managers-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}}

.manager-card{background:linear-gradient(135deg,rgba(0,200,255,0.06),rgba(0,232,160,0.03));border:1px solid rgba(0,200,255,0.2);border-radius:18px;padding:26px 24px;display:flex;flex-direction:column;gap:14px;transition:all .28s;position:relative;overflow:hidden}
.manager-card::before{content:'';position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,255,0.08),transparent 70%);pointer-events:none}
.manager-card:hover{border-color:rgba(0,200,255,0.4);transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,200,255,0.1)}
.manager-top{display:flex;align-items:center;gap:14px}
.manager-avatar{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:22px;color:#fff;letter-spacing:.04em;flex-shrink:0}
.manager-name{font-size:15px;font-weight:600;color:#fff;line-height:1.25;margin-bottom:3px}
.manager-role{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--aqua)}
.manager-divider{height:1px;background:linear-gradient(90deg,rgba(0,200,255,0.2),transparent)}
.manager-contacts{display:flex;flex-direction:column;gap:9px}
.manager-contact-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);text-decoration:none;transition:color .2s}
a.manager-contact-item:hover{color:var(--aqua)}
.manager-contact-icon{width:28px;height:28px;border-radius:7px;background:rgba(0,200,255,0.08);border:1px solid rgba(0,200,255,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.manager-wa-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:rgba(37,211,102,0.1);border:1px solid rgba(37,211,102,0.28);color:#25D366;padding:9px 16px;border-radius:9px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;letter-spacing:.03em}
.manager-wa-btn:hover{background:rgba(37,211,102,0.18);border-color:#25D366}

/* ══════════════════════════════════════════════
   PRODUCT IMAGES — водные эффекты при наведении
   ══════════════════════════════════════════════ */

/* Фото поверх SVG-заглушки */
.product-img{position:relative;overflow:hidden}
.product-img img.prod-photo{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .6s cubic-bezier(.25,.46,.45,.94), filter .5s ease;
  filter:brightness(.78) saturate(1.1);
  z-index:1;
}
.product-card:hover .product-img img.prod-photo{
  transform:scale(1.08);
  filter:brightness(.65) saturate(1.2);
}

/* Тёмный градиент поверх фото */
.product-img .img-overlay{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(5,13,26,.1) 0%,rgba(5,13,26,.6) 100%);
  opacity:0;transition:opacity .4s ease;
}
.product-card:hover .product-img .img-overlay{opacity:1}

/* Водный блик снизу */
.product-img .water-glow{
  position:absolute;bottom:0;left:0;right:0;height:50%;z-index:3;pointer-events:none;
  background:
    radial-gradient(ellipse 90% 40% at 50% 110%,rgba(0,200,255,.28) 0%,transparent 65%),
    radial-gradient(ellipse 60% 25% at 50% 110%,rgba(0,232,160,.12) 0%,transparent 55%);
  opacity:0;transform:translateY(12px);
  transition:opacity .45s ease, transform .45s ease;
}
.product-card:hover .product-img .water-glow{opacity:1;transform:translateY(0)}

/* Линия-волна снизу */
.product-img .wave-line{
  position:absolute;bottom:0;left:0;right:0;z-index:4;pointer-events:none;overflow:hidden;height:4px;
}
.product-img .wave-line::after{
  content:'';position:absolute;bottom:0;left:-100%;width:300%;height:100%;
  background:linear-gradient(90deg,transparent 0%,var(--aqua) 25%,rgba(0,232,160,.9) 50%,var(--aqua) 75%,transparent 100%);
  opacity:0;transform:scaleX(0);transform-origin:left;
  transition:opacity .35s ease .08s, transform .5s cubic-bezier(.25,.46,.45,.94) .08s;
}
.product-card:hover .product-img .wave-line::after{opacity:1;transform:scaleX(1)}

/* Пузырьки */
.product-img .bubbles{position:absolute;inset:0;z-index:3;pointer-events:none;overflow:hidden}
.product-img .bubbles span{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(0,200,255,.4);
  background:radial-gradient(circle at 35% 35%,rgba(0,220,255,.2),transparent 70%);
  opacity:0;
  bottom:-10px;
}
.product-card:hover .product-img .bubbles span{
  animation:bbl-prod var(--bd) ease-in-out var(--bdd) infinite;
}
@keyframes bbl-prod{
  0%  {bottom:-10px;opacity:0;transform:translateX(0) scale(1)}
  8%  {opacity:.75}
  85% {opacity:.3}
  100%{bottom:105%;opacity:0;transform:translateX(var(--bdx)) scale(.5)}
}

/* SVG-иконка — прячем если есть фото */
.product-img:has(img.prod-photo) .product-img-inner{display:none}
/* Fallback если :has не поддерживается — иконка перекрывается фото */
.product-img .product-img-inner{position:relative;z-index:0}






  60% {opacity:1;transform:translateX(10px)}
  80% {transform:translateX(-4px)}
  100%{opacity:1;transform:translateX(0)}
}

  60% {opacity:.85;transform:scale(1.03)}
  100%{opacity:1;transform:scale(1)}
}




/* On mobile — stack vertically */
@media(max-width:768px){
  
  
  
  
}



.hero-logo-main{
  opacity:0;
  transform:scale(.9);
  animation:logo-appear 1.2s cubic-bezier(.22,.68,0,1.1) .15s forwards;
  margin-bottom:22px;
  display:inline-block;
}
@keyframes logo-appear{
  0%  {opacity:0;transform:scale(.9)}
  55% {opacity:1;transform:scale(1.05)}
  75% {transform:scale(.98)}
  100%{opacity:1;transform:scale(1)}
}
.hero-logo-main img{
  width:clamp(220px,32vw,380px);
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 0 32px rgba(0,200,255,.4)) drop-shadow(0 4px 16px rgba(0,0,0,.5));
}


/* ══ PROJECTS — ВАУ КАРТОЧКИ С КАРУСЕЛЬЮ ══ */

/* Сетка */
.projects-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
@media(max-width:900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.projects-grid{grid-template-columns:1fr}}
@media(max-width:900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.projects-grid{grid-template-columns:1fr}}

/* Карточка */
.project-card{
  background:var(--card);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:20px;
  overflow:hidden;
  transition:border-color .3s, transform .35s cubic-bezier(.25,.46,.45,.94), box-shadow .35s;
  position:relative;
  cursor:default;
}
.project-card:hover{
  border-color:rgba(0,200,255,.35);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(0,0,0,.35), 0 0 0 1px rgba(0,200,255,.12);
}

/* ── THUMB — карусель ── */
.project-thumb{
  width:100%;
  aspect-ratio:16/9;
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,rgba(0,60,110,.7),rgba(0,20,50,.9));
}

/* Слайды */
.project-slides{
  display:flex;
  width:100%;
  height:100%;
  transition:transform .6s cubic-bezier(.77,0,.18,1);
}
.project-slide{
  min-width:100%;
  height:100%;
  position:relative;
  flex-shrink:0;
  overflow:hidden;
}
.project-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transition:transform .6s ease, filter .4s ease;
  filter:brightness(.75) saturate(1.05);
}
.project-card:hover .project-slide img{
  transform:scale(1.06);
  filter:brightness(.6) saturate(1.15);
}

/* Оверлей градиент */
.project-slide::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(5,13,26,.75) 100%);
  pointer-events:none;
  z-index:1;
}

/* SVG-заглушка (если нет фото) */
.project-thumb-icon{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  opacity:.22;
  z-index:0;
}

/* Точки-индикаторы */
.project-dots{
  position:absolute;
  bottom:10px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:5px;
  z-index:3;
}
.project-dot{
  width:6px;height:6px;
  border-radius:50%;
  background:rgba(255,255,255,.4);
  transition:background .25s, transform .25s;
  cursor:pointer;
}
.project-dot.active{
  background:#fff;
  transform:scale(1.3);
}

/* Стрелки */
.project-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:3;
  width:32px;height:32px;
  border-radius:50%;
  background:rgba(5,13,26,.65);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  opacity:0;
  transition:opacity .25s, background .2s;
}
.project-arrow:hover{background:rgba(0,200,255,.25);border-color:rgba(0,200,255,.5)}
.project-arrow.prev{left:10px}
.project-arrow.next{right:10px}
.project-card:hover .project-arrow{opacity:1}

/* Тег локации */
.project-thumb-tag{
  position:absolute;
  bottom:12px;left:12px;
  background:rgba(0,200,255,.15);
  border:1px solid rgba(0,200,255,.3);
  backdrop-filter:blur(8px);
  color:var(--aqua);
  font-size:11px;font-weight:600;
  letter-spacing:.08em;
  padding:4px 12px;
  border-radius:20px;
  z-index:2;
}

/* Счётчик фото */
.project-counter{
  position:absolute;
  top:12px;right:12px;
  background:rgba(5,13,26,.6);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.8);
  font-size:11px;font-weight:600;
  padding:3px 10px;
  border-radius:12px;
  z-index:3;
  letter-spacing:.04em;
}

/* Авто-прогресс бар */
.project-progress{
  position:absolute;
  bottom:0;left:0;right:0;
  height:2px;
  z-index:4;
  overflow:hidden;
}
.project-progress-bar{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,var(--aqua),var(--green));
  transition:width linear;
}

/* ── BODY ── */
.project-body{
  padding:20px 22px 22px;
  position:relative;
}

/* Линия-акцент слева при hover */
.project-card::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:3px;
  background:linear-gradient(180deg,var(--aqua),var(--green));
  border-radius:3px 0 0 3px;
  transform:scaleY(0);
  transform-origin:bottom;
  transition:transform .4s cubic-bezier(.25,.46,.45,.94);
  z-index:1;
}
.project-card:hover::before{transform:scaleY(1)}

.project-name{
  font-size:15px;font-weight:600;color:#fff;
  margin-bottom:8px;line-height:1.35;
  transition:color .2s;
}
.project-card:hover .project-name{color:var(--aqua)}

.project-meta{
  font-size:13px;font-weight:300;color:var(--muted);
  line-height:1.6;margin-bottom:12px;
}

.project-tags{display:flex;flex-wrap:wrap;gap:6px}
.project-tag{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;padding:3px 10px;
  font-size:11px;color:var(--muted);
  transition:border-color .2s, color .2s;
}
.project-card:hover .project-tag{
  border-color:rgba(0,200,255,.2);
  color:var(--text);
}

/* ── СПЕЦИАЛЬНАЯ КАРТОЧКА "200+" ── */
.project-card.stat-card{
  background:linear-gradient(135deg,rgba(0,200,255,.07),rgba(0,232,160,.04));
  border-color:rgba(0,200,255,.22);
  display:flex;flex-direction:column;
  justify-content:center;align-items:center;
  text-align:center;padding:36px;gap:14px;
  min-height:260px;
}
.project-card.stat-card:hover{
  border-color:rgba(0,200,255,.5);
  box-shadow:0 20px 60px rgba(0,200,255,.12), 0 0 0 1px rgba(0,200,255,.2);
}
.stat-card-num{
  font-family:'Bebas Neue',sans-serif;
  font-size:72px;color:#fff;line-height:1;
  background:linear-gradient(135deg,#fff 30%,var(--aqua) 70%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-card-label{
  font-size:14px;color:var(--muted);line-height:1.55;max-width:180px;
}


/* ── PARTNERS — с логотипами ── */
.partner-card{
  background:rgba(255,255,255,0.92);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:14px;
  padding:16px 22px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:130px;
  min-height:72px;
  transition:all .28s;
  cursor:default;
}
.partner-card:hover{
  background:#fff;
  border-color:rgba(0,200,255,0.4);
  transform:translateY(-3px);
  box-shadow:0 8px 28px rgba(0,200,255,0.15);
}
.partner-card img{
  width:120px;
  height:40px;
  object-fit:contain;
  filter:none;
  opacity:.85;
  transition:opacity .25s;
}
.partner-card:hover img{
  opacity:1;
  filter:none;
}
.partner-fallback{
  display:none;
  font-size:13px;
  font-weight:600;
  color:var(--muted);
  letter-spacing:.04em;
  text-align:center;
  transition:color .25s;
}
.partner-card:hover .partner-fallback{color:var(--text)}



.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(5,13,26,.88);backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:center;
  padding:16px;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:#071426;border:1px solid rgba(0,200,255,0.18);
  border-radius:20px;width:100%;max-width:520px;
  padding:32px 28px 28px;position:relative;
  max-height:90vh;overflow-y:auto;
}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.06);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--muted);
  transition:all .2s;
}
.modal-close:hover{background:rgba(255,255,255,0.12);color:#fff}
.modal-cat-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,200,255,0.1);border:1px solid rgba(0,200,255,0.25);
  border-radius:20px;padding:5px 14px;
  font-size:12px;font-weight:600;color:var(--aqua);
  letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:16px;
}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;letter-spacing:.03em;margin-bottom:6px}
.modal-sub{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.55}

/* progress */
.modal-progress{display:flex;gap:6px;margin-bottom:28px}
.mp-dot{height:3px;border-radius:3px;background:rgba(0,200,255,0.18);flex:1;transition:background .3s}
.mp-dot.done{background:var(--aqua)}

.modal-step{display:none}
.modal-step.active{display:block}

/* form controls */
.mf-group{margin-bottom:16px}
.mf-label{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;display:block}
.mf-label span{color:#e24b4a;margin-left:2px}
.mf-chips{display:flex;flex-wrap:wrap;gap:8px}
.mf-chip{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:8px;padding:8px 14px;
  font-size:13px;color:var(--muted);cursor:pointer;
  transition:all .2s;user-select:none;
}
.mf-chip:hover{border-color:rgba(0,200,255,0.3);color:var(--text)}
.mf-chip.sel{background:rgba(0,200,255,0.12);border-color:rgba(0,200,255,0.5);color:var(--aqua);font-weight:600}
.mf-chip.err{border-color:rgba(226,75,74,.6)}

.mf-input{
  width:100%;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:10px;padding:12px 14px;
  font-size:14px;color:var(--text);
  outline:none;transition:border-color .2s;
  font-family:'DM Sans',sans-serif;
}
.mf-input:focus{border-color:rgba(0,200,255,0.4)}
.mf-input::placeholder{color:var(--muted)}
.mf-input.err{border-color:rgba(226,75,74,.6)!important}

.mf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.mf-row{grid-template-columns:1fr}}

/* buttons */
.modal-btns{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:24px}
.mf-btn-back{
  background:none;border:1px solid rgba(255,255,255,0.1);
  border-radius:10px;padding:12px 20px;
  font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;
  transition:all .2s;font-family:'DM Sans',sans-serif;
}
.mf-btn-back:hover{border-color:rgba(255,255,255,0.25);color:var(--text)}
.mf-btn-next{
  background:linear-gradient(135deg,#0088BB,#00C8FF);
  border:none;border-radius:10px;padding:12px 28px;
  font-size:14px;font-weight:600;color:#fff;cursor:pointer;
  transition:all .22s;font-family:'DM Sans',sans-serif;
  flex:1;
}
.mf-btn-next:hover{box-shadow:0 8px 24px rgba(0,200,255,.35);transform:translateY(-1px)}
.mf-btn-next:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}

/* success */
.modal-success{text-align:center;padding:20px 0;display:none}
.modal-success-icon{width:64px;height:64px;border-radius:50%;background:rgba(0,232,160,0.15);border:2px solid rgba(0,232,160,0.4);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.modal-success h3{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;margin-bottom:8px;letter-spacing:.04em}
.modal-success p{font-size:14px;color:var(--muted);line-height:1.6}




/* ── MOBILE NAV (единый стиль) ── */
.mobile-nav{position:fixed;top:68px;left:0;right:0;bottom:0;z-index:150;
  background:rgba(5,13,26,0.98);backdrop-filter:blur(24px);
  display:none;flex-direction:column;padding:28px 24px;overflow-y:auto}
.mobile-nav.open{display:flex}
.mobile-nav-link{font-family:'Bebas Neue',sans-serif;font-size:32px;
  color:var(--text);text-decoration:none;letter-spacing:.04em;
  padding:14px 0;border-bottom:1px solid rgba(0,200,255,0.08);transition:color .2s}
.mobile-nav-link:hover{color:var(--aqua)}
.mobile-nav-contacts{margin-top:32px;display:flex;flex-direction:column;gap:14px}
/* Убираем старые mnav-link стили если были */
.mnav-link{font-family:'Bebas Neue',sans-serif;font-size:32px;
  color:var(--text);text-decoration:none;letter-spacing:.04em;
  padding:14px 0;border-bottom:1px solid rgba(0,200,255,0.08);transition:color .2s}
.mnav-link:hover,.mnav-link.active{color:var(--aqua)}


/* ── WORKS CTA BLOCK ── */
.projects-section{position:relative;z-index:1;padding:80px 24px}
.section-inner{max-width:1200px;margin:0 auto}
.works-cta-block{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media(max-width:900px){.works-cta-block{grid-template-columns:1fr;gap:48px}}
.works-cta-sub{font-size:16px;color:var(--muted);line-height:1.7;font-weight:300;margin:16px 0 28px}
.works-cta-stats{display:flex;gap:36px;margin-bottom:40px;flex-wrap:wrap}
.works-stat{display:flex;flex-direction:column;gap:4px}
.works-stat-num{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--aqua);letter-spacing:.04em;line-height:1}
.works-stat-lbl{font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.works-cta-btn{
  display:inline-flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,#0088BB,#00C8FF);
  color:#fff;padding:16px 36px;border-radius:14px;
  font-size:15px;font-weight:700;text-decoration:none;
  transition:all .25s;letter-spacing:.02em;box-shadow:0 4px 20px rgba(0,200,255,0.2);
}
.works-cta-btn:hover{box-shadow:0 12px 40px rgba(0,200,255,0.45);transform:translateY(-2px)}
.works-cta-btn svg{transition:transform .25s}
.works-cta-btn:hover svg{transform:translateX(5px)}
/* Preview grid */
.works-preview-grid{
  display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:200px 200px;
  gap:14px;
}
.wp-card{border-radius:16px;overflow:hidden;position:relative;transition:transform .3s;cursor:pointer}
.wp-card:hover{transform:scale(1.03)}
.wp-card-1{
  grid-row:1/3;
  background:linear-gradient(135deg,rgba(0,80,160,0.5),rgba(0,30,80,0.9));
  border:1px solid rgba(0,200,255,0.2);
}
.wp-card-2{background:linear-gradient(135deg,rgba(0,150,80,0.4),rgba(0,60,30,0.9));border:1px solid rgba(0,232,160,0.15)}
.wp-card-3{background:linear-gradient(135deg,rgba(0,60,180,0.4),rgba(0,20,80,0.9));border:1px solid rgba(100,170,255,0.15)}
.wp-card-4{display:none}
.wp-card-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.wp-card-1 .wp-card-inner::before{content:'ЛОС';font-family:'Bebas Neue',sans-serif;font-size:48px;color:rgba(0,200,255,0.6);letter-spacing:.1em}
.wp-card-2 .wp-card-inner::before{content:'КНС';font-family:'Bebas Neue',sans-serif;font-size:36px;color:rgba(0,232,160,0.6);letter-spacing:.1em}
.wp-card-3 .wp-card-inner::before{content:'БАССЕЙН';font-family:'Bebas Neue',sans-serif;font-size:24px;color:rgba(100,170,255,0.6);letter-spacing:.1em}


/* ── WORKS PHOTO CLOUD ── */
.works-photo-cloud{
  position:relative;
  width:100%;height:420px;
}
@media(max-width:900px){.works-photo-cloud{height:280px}}
.wpc-placeholder{
  position:absolute;inset:0;border-radius:20px;
  background:linear-gradient(135deg,rgba(0,80,160,0.2),rgba(0,30,60,0.4));
  border:1px solid rgba(0,200,255,0.1);
}
.wpc-img{
  position:absolute;
  border-radius:12px;overflow:hidden;
  border:2px solid rgba(255,255,255,0.08);
  box-shadow:0 8px 32px rgba(0,0,0,0.5);
  transition:transform .3s,box-shadow .3s;
  cursor:pointer;
}
.wpc-img:hover{
  transform:scale(1.06) !important;
  box-shadow:0 16px 48px rgba(0,0,0,0.7);
  z-index:20 !important;
  border-color:rgba(0,200,255,0.4);
}
.wpc-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(0.75);transition:filter .3s;
}
.wpc-img:hover img{filter:brightness(0.95)}


/* ── PARTNERS MARQUEE ── */
.partners-section{padding:64px 0;overflow:hidden}
.marquee-wrap{width:100%;overflow:hidden;position:relative;margin-top:40px}
.marquee-wrap::before,.marquee-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee-wrap::before{left:0;background:linear-gradient(90deg,var(--dark),transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(-90deg,var(--dark),transparent)}
.marquee-track{display:flex;width:max-content}
.marquee-inner{display:flex;gap:16px;animation:marquee-scroll 60s linear infinite}
.marquee-wrap:hover .marquee-inner{animation-play-state:paused}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
.marquee-item{
  flex-shrink:0;
  background:rgba(255,255,255,0.92) !important;
  border:1px solid rgba(255,255,255,0.15) !important;
  border-radius:14px;padding:16px 24px;
  display:flex;align-items:center;justify-content:center;
  min-width:140px;height:80px;
  transition:all .28s;
}
.marquee-item:hover{
  background:#fff !important;
  border-color:rgba(0,200,255,0.4) !important;
  transform:translateY(-3px);
  box-shadow:0 8px 28px rgba(0,200,255,0.15);
}
.marquee-item img{max-height:44px;max-width:110px;object-fit:contain;filter:none !important;opacity:.85;transition:all .25s}
.marquee-item:hover img{opacity:1;filter:none !important}
.marquee-item .pf{font-size:13px;font-weight:600;color:#333;letter-spacing:.04em}