/* ==========================================================================
   ASANSIORITE.COM — Brand-clean Redesign
   Design System: Light + bright lime green accent (matches asansiorite.com)
   Typography: Sofia Sans (primary) + Montserrat (secondary)
   Palette: #81E351 (brand-lime), #2B2B2B (ink), #F2F8EE (cream tint), white
   Buttons: 56px pill radius
   ========================================================================== */

/* ---------- FONT FACES ---------- */
@font-face{font-family:'Montserrat';src:url('/fonts/Montserrat-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Montserrat';src:url('/fonts/Montserrat-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Montserrat';src:url('/fonts/Montserrat-ExtraBold.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Sofia Sans';src:url('/fonts/SofiaSans-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Sofia Sans';src:url('/fonts/SofiaSans-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Sofia Sans';src:url('/fonts/SofiaSans-ExtraBold.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Sofia Sans';src:url('/fonts/SofiaSans-Black.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}

/* ---------- DESIGN TOKENS ---------- */
:root{
  /* colour — clone of asansiorite.com brand palette */
  --ink:#2B2B2B;
  --ink-light:#38383A;
  --ink-muted:#3D3D3D;
  --slate:#7D7D7D;
  --ash:#BDBDBD;
  --silver:#E0E0E0;
  --cream:#F2F8EE;
  --cream-tint:#FAFFF6;
  --white:#FFFFFF;
  /* brand lime — matches reference #81E351 */
  --ember:#81E351;
  --ember-light:#6BC93F;
  --ember-dark:#5BB52E;
  --ember-glow:rgba(129,227,81,.18);
  --ember-soft:#E5FFE5;
  --forest:#81E351;
  --forest-light:#6BC93F;
  --forest-glow:rgba(129,227,81,.18);
  --sky:#3B82F6;

  /* type */
  --ff-body:'Montserrat','Sofia Sans',system-ui,sans-serif;
  --ff-heading:'Sofia Sans','Montserrat',system-ui,sans-serif;

  /* sizing */
  --fs-xs:.8125rem;--fs-sm:.9375rem;--fs-base:1.0625rem;--fs-md:1.125rem;
  --fs-lg:1.25rem;--fs-xl:1.5rem;--fs-2xl:1.75rem;--fs-3xl:2.25rem;
  --fs-4xl:3rem;--fs-5xl:3.75rem;--fs-6xl:4.75rem;

  /* spacing */
  --sp-xs:.25rem;--sp-sm:.5rem;--sp-md:1rem;--sp-lg:1.5rem;
  --sp-xl:2rem;--sp-2xl:3rem;--sp-3xl:4rem;--sp-4xl:6rem;--sp-5xl:8rem;

  /* radius */
  --r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-2xl:32px;--r-full:9999px;

  /* shadow */
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow-md:0 4px 16px rgba(0,0,0,.1);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --shadow-xl:0 24px 64px rgba(0,0,0,.16);
  --shadow-glow:0 0 60px rgba(129,227,81,.08);

  /* layout */
  --max-w:1320px;
  --header-h:90px;
  --header-top-h:40px;

  /* glass */
  --glass-bg:rgba(255,255,255,.06);
  --glass-border:rgba(255,255,255,.08);

  /* transitions */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{line-height:1.5;-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--ff-body);font-size:var(--fs-base);color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button,input,select,textarea{font:inherit;border:none;outline:none;background:none}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-heading);font-weight:800;line-height:1.15;letter-spacing:-.02em}

/* ---------- TOP BAR (light) ---------- */
.top-bar{
  background:var(--cream);height:var(--header-top-h);
  display:flex;align-items:center;
  border-bottom:1px solid var(--silver);
  font-size:var(--fs-xs);color:var(--slate);
  position:fixed;top:0;left:0;right:0;z-index:1001;
}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.top-bar-left,.top-bar-right{display:flex;align-items:center;gap:20px}
.top-bar-item{display:flex;align-items:center;gap:6px;color:var(--slate);transition:color .2s var(--ease)}
.top-bar-item:hover{color:var(--ember-dark)}
.top-bar-icon{width:14px;height:14px}
.top-bar-lang{
  padding:3px 12px;border-radius:var(--r-full);
  background:var(--white);border:1px solid var(--silver);
  font-weight:700;letter-spacing:.04em;color:var(--ink);
  transition:all .2s var(--ease);
}
.top-bar-lang:hover{background:var(--ember);color:var(--ink);border-color:var(--ember)}
.top-bar-social{display:flex;gap:8px}
.top-bar-social a{color:var(--slate);transition:color .2s var(--ease)}
.top-bar-social a:hover{color:var(--ember-dark)}
.top-bar-social svg{width:14px;height:14px}

/* ---------- LAYOUT ---------- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.section{padding:clamp(60px,10vw,120px) 0}

/* ---------- TYPOGRAPHY UTILITIES ---------- */
.text-ink{color:var(--ink)}.text-white{color:var(--white)}.text-cream{color:var(--cream)}
.text-ember{color:var(--ember)}.text-forest{color:var(--forest)}.text-slate{color:var(--slate)}
.text-ash{color:var(--ash)}
.text-center{text-align:center}.text-left{text-align:left}

/* ---------- PILL / LABEL ---------- */
.label{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:var(--r-full);
  font-size:var(--fs-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  background:var(--ember-glow);color:var(--ember);
}
.label--forest{background:var(--forest-glow);color:var(--forest)}
.label--white{background:rgba(255,255,255,.12);color:var(--white)}
.label__dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ---------- BUTTONS ---------- */
/* ===== UNIFIED BUTTON — green pill + black circular arrow (reference .secondary-btn), site-wide ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:9px 9px 9px 26px;border-radius:var(--r-full);
  font-family:var(--ff-body);font-size:var(--fs-sm);font-weight:700;
  cursor:pointer;transition:all .3s var(--ease);border:2px solid transparent;
  white-space:nowrap;position:relative;
}
/* Trailing circle + arrow — the signature pill icon on every button */
.btn::after{
  content:"\2192";flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:#000;color:#fff;
  font-size:16px;line-height:1;font-weight:400;
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);
}
.btn:hover::after{transform:translateX(2px)}
.btn--primary{background:var(--ember);color:var(--ink);border-color:var(--ember)}
.btn--primary:hover{background:#000;border-color:#000;color:#fff}
.btn--primary:hover::after{background:var(--ember);color:#000}
.btn--dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--dark::after{background:var(--ember);color:#000}
.btn--dark:hover{background:#000;border-color:#000}
.btn--outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn--outline::after{background:transparent;border:1.5px solid currentColor;color:inherit}
.btn--outline:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--outline:hover::after{border-color:var(--ink);color:var(--ink)}
.btn--white{background:#fff;color:var(--ink);border-color:#fff}
.btn--white:hover{background:var(--ember);border-color:var(--ember);color:var(--ink)}
.btn--white:hover::after{background:#000;color:#fff}
/* Ghost = neutral secondary, no arrow circle */
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--silver);padding:11px 24px}
.btn--ghost::after{display:none}
.btn--ghost:hover{border-color:var(--ink);background:var(--cream)}
.btn--sm{padding:6px 6px 6px 20px;font-size:var(--fs-xs)}
.btn--sm::after{width:28px;height:28px;font-size:13px}
.btn--sm.btn--ghost{padding:9px 18px}
.btn--lg{padding:12px 12px 12px 34px;font-size:var(--fs-md)}
.btn--lg::after{width:40px;height:40px;font-size:18px}
.btn .arrow{display:none}

/* ---------- HEADER (light) ---------- */
.site-header{
  position:fixed;top:var(--header-top-h);left:0;right:0;z-index:1000;
  height:var(--header-h);
  background:var(--white);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--silver);
  transition:all .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(255,255,255,.98);
  box-shadow:0 6px 24px rgba(0,0,0,.08);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);max-width:1680px;margin:0 auto;
  padding:0 clamp(16px,2vw,40px);
}
.site-logo{display:flex;align-items:center;color:var(--ink)}
.site-logo img{height:48px;width:auto;display:block}
/* Wide desktop: keep the logo at full natural size. Narrower screens shrink-to-fit (no cut-off). */
@media(min-width:1600px){.site-logo,.site-logo img{flex-shrink:0}}
@media(max-width:640px){.site-logo img{height:38px}}

/* Nav */
.main-nav{display:flex;align-items:center}
.main-nav>ul{display:flex;align-items:center;gap:6px}
.main-nav>ul>li{position:relative}
.nav-configurator{display:none}
.nav-mobile-only{display:none}
.main-nav>ul>li>a{
  display:flex;align-items:center;gap:4px;
  padding:10px 13px;border-radius:var(--r-full);
  font-size:var(--fs-md);font-weight:600;color:var(--ink);white-space:nowrap;
  transition:all .25s var(--ease);
}
.main-nav>ul>li>a:hover,.main-nav>ul>li.active>a{
  color:var(--ember-dark);background:var(--ember-soft);
}
.has-dropdown>a::after{
  content:'';width:0;height:0;
  border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;
  transition:transform .3s var(--ease);margin-left:2px;
}
/* Dropdown */
.dropdown{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(4px);padding-top:8px;
  background:var(--white);border:1px solid rgba(0,0,0,.06);
  border-radius:var(--r-lg);min-width:280px;padding:8px;
  box-shadow:var(--shadow-xl);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:all .3s var(--ease);
}
.has-dropdown:hover>a::after{transform:rotate(180deg)}
.has-dropdown:hover .dropdown{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);padding-top:8px;
}
.dropdown li a{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:var(--r-md);
  font-size:var(--fs-sm);color:var(--ink);transition:all .2s var(--ease);
}
.dropdown li a:hover{background:var(--cream);color:var(--ember)}
.dropdown li a .dd-icon{
  width:36px;height:36px;border-radius:var(--r-md);
  background:var(--ember-glow);display:flex;align-items:center;justify-content:center;
  color:var(--ember);flex-shrink:0;transition:all .25s var(--ease);
}
.dropdown li a .dd-icon svg{width:16px;height:16px}
.dropdown li a:hover .dd-icon{background:var(--ember);color:var(--white)}

/* Header actions */
.header-actions{display:flex;align-items:center;gap:10px;position:relative;z-index:100}
.header-account{
  width:38px;height:38px;border-radius:var(--r-full);
  display:flex;align-items:center;justify-content:center;
  background:var(--cream);transition:background .3s var(--ease);cursor:pointer;
}
.header-account:hover{background:var(--silver)}
.header-account svg{width:18px;height:18px;color:var(--ink)}
.header-cta{
  padding:13px 22px;border-radius:var(--r-full);
  background:var(--ember);color:var(--ink);
  font-size:var(--fs-md);font-weight:700;letter-spacing:.02em;white-space:nowrap;
  transition:all .3s var(--ease);cursor:pointer;border:2px solid var(--ember);
}
.header-cta:hover{
  background:var(--ember-dark);border-color:var(--ember-dark);color:var(--white);
  transform:translateY(-1px);box-shadow:0 6px 20px rgba(129,227,81,.4);
}
/* Работа (Jobs) header button + dropdown */
.header-job{position:relative}
.header-cta--job{display:inline-flex;align-items:center;gap:11px;padding:7px 7px 7px 22px}
.header-cta-ico{width:30px;height:30px;border-radius:50%;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex:0 0 30px;transition:background .3s}
.header-cta-ico svg{width:16px;height:16px}
.header-cta--job:hover .header-cta-ico{background:#fff;color:var(--ink)}
.header-job-menu{
  position:absolute;top:100%;right:0;margin-top:10px;min-width:270px;list-style:none;
  background:#fff;border:1px solid var(--silver);border-radius:14px;box-shadow:0 18px 44px rgba(0,0,0,.16);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .2s var(--ease);z-index:1200;
}
.header-job:hover .header-job-menu{opacity:1;visibility:visible;transform:translateY(0)}
.header-job-menu li a{display:block;padding:11px 16px;border-radius:9px;color:var(--ink);font-weight:600;font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.02em}
.header-job-menu li a:hover{background:var(--cream);color:var(--ember-dark)}
/* Account icon */
.header-user{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--cream);color:var(--ink);transition:all .25s var(--ease);flex:0 0 42px}
.header-user svg{width:20px;height:20px}
.header-user:hover{background:var(--ember);color:var(--ink)}
.has-transparent-header .header-user{background:rgba(255,255,255,.12);color:#fff}
.has-transparent-header .header-user:hover{background:var(--ember);color:var(--ink)}
.header-phone{
  display:flex;align-items:center;gap:6px;
  font-size:var(--fs-sm);font-weight:600;color:var(--ink);
  padding:8px 12px;border-radius:var(--r-full);
  transition:all .25s var(--ease);
}
.header-phone:hover{color:var(--ember-dark);background:var(--ember-soft)}
.header-phone svg{width:16px;height:16px}

/* Mobile toggle */
.menu-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:48px;height:48px;border-radius:var(--r-md);
  background:none;border:none;cursor:pointer;padding:12px;
  transition:all .3s var(--ease);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  position:relative;z-index:1001;
}
.menu-toggle:hover{background:var(--cream)}
.menu-toggle span{display:block;width:100%;height:2px;background:var(--ink);border-radius:2px;transition:all .3s var(--ease)}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ---------- TRANSPARENT HEADER (homepage, overlapping the dark hero) ---------- */
.has-transparent-header .top-bar{
  position:absolute;background:transparent;
  border-bottom:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.82);
}
.has-transparent-header .top-bar-item,
.has-transparent-header .top-bar-social a{color:rgba(255,255,255,.82)}
.has-transparent-header .top-bar-item:hover,
.has-transparent-header .top-bar-social a:hover{color:var(--ember)}
.has-transparent-header .top-bar-lang{
  background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.28);color:#fff;
}
.has-transparent-header .top-bar-lang:hover{background:var(--ember);color:var(--ink);border-color:var(--ember)}
.has-transparent-header .site-header{
  position:absolute;background:transparent;
  backdrop-filter:none;-webkit-backdrop-filter:none;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.has-transparent-header .main-nav>ul>li>a{color:#fff}
.has-transparent-header .main-nav>ul>li>a:hover,
.has-transparent-header .main-nav>ul>li.active>a{color:#fff;background:rgba(255,255,255,.16)}
.has-transparent-header .menu-toggle span{background:#fff}
.has-transparent-header .menu-toggle:hover{background:rgba(255,255,255,.12)}

/* ---------- HOMEPAGE INTRO (pills + mission + stats) — clone of reference 2nd section ---------- */
.intro-section{padding:clamp(48px,7vw,90px) 0;background:var(--white)}
.pill-row{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,60px)}
.pill-btn{
  display:inline-flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--ember);color:var(--ink);border:1px solid var(--ember);
  border-radius:var(--r-full);padding:8px 12px 8px 28px;
  font-family:var(--ff-body);font-weight:600;font-size:var(--fs-md);
  transition:all .3s var(--ease);flex:1 1 100%;
}
@media(min-width:768px){.pill-btn{flex:0 1 auto;min-width:250px}}
@media(min-width:1280px){.pill-btn{min-width:300px}}
.pill-btn .pill-icon{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:#000;color:#fff;display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease);
}
.pill-btn .pill-icon svg{width:16px;height:16px}
.pill-btn:hover{background:#000;color:#fff;border-color:#000;transform:translateY(-2px)}
.pill-btn:hover .pill-icon{background:var(--ember);color:#fff}

.intro-grid{display:flex;flex-direction:column;gap:36px}
@media(min-width:992px){.intro-grid{flex-direction:row;gap:48px;align-items:flex-start;justify-content:space-between}}
.intro-heading{flex:0 0 40%}
.intro-heading h2{
  font-family:var(--ff-heading);font-weight:800;letter-spacing:-.01em;
  font-size:clamp(2.1rem,4.6vw,3.25rem);line-height:1.02;margin:0;color:var(--ember);
}
.intro-heading h2 .lead{
  color:var(--ink);-webkit-text-stroke:2px var(--ember);paint-order:stroke fill;
}
.intro-heading .pill-btn{margin-top:28px;flex:0 0 auto}
.intro-copy{flex:1 1 60%}
.intro-copy p{font-size:var(--fs-lg);color:var(--ink-light);line-height:1.7;margin:0}
.intro-partners{display:flex;gap:clamp(28px,6vw,80px);align-items:center;flex-wrap:wrap;margin-top:26px}
.intro-partners img{max-width:190px;height:auto;display:block}

.stats-row{display:grid;grid-template-columns:1fr;border-top:1px solid var(--silver);margin-top:clamp(36px,5vw,56px)}
@media(min-width:600px){.stats-row{grid-template-columns:1fr 1fr}}
@media(min-width:992px){.stats-row{grid-template-columns:repeat(4,1fr)}}
.stat-cell{padding:clamp(22px,3vw,44px) clamp(16px,2.5vw,32px);border-bottom:1px solid var(--silver)}
@media(min-width:600px){.stat-cell:nth-child(odd){border-right:1px solid var(--silver)}}
@media(min-width:992px){
  .stat-cell{border-right:1px solid var(--silver);border-bottom:none}
  .stat-cell:last-child{border-right:none}
}
.stat-cell .stat-num{font-family:var(--ff-heading);font-weight:800;font-size:clamp(3.4rem,8vw,7rem);line-height:1;color:var(--ink);margin:0}
.stat-cell .stat-num sup{color:var(--ink);font-size:.42em;vertical-align:super;font-weight:700}
.stat-cell .stat-ico{width:42px;height:42px;color:var(--ink);margin-bottom:16px}
.stat-cell .stat-ico svg{width:100%;height:100%;display:block}
.stat-cell h3{font-family:var(--ff-heading);color:var(--ember);font-weight:800;font-size:var(--fs-2xl);margin:0 0 8px;letter-spacing:-.01em}
.stat-cell .stat-sub{color:var(--slate);font-size:var(--fs-md);font-weight:500;line-height:1.5}

/* ========== HERO ========== */
.hero{position:relative;background:#fff;padding:0}
.hero>.container{max-width:1820px;padding-top:0;padding-bottom:0;padding-left:clamp(14px,1.6vw,24px);padding-right:clamp(14px,1.6vw,24px)}

/* ----- Reference typographic hero (front-page card) ----- */
.front-page{
  position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;
  min-height:760px;padding:32px 24px;overflow:hidden;border-radius:24px;
  background-image:radial-gradient(99.2% 141.42% at 100% 0%, rgba(61,61,61,0) 0%, #000 100%), url('/images/front-page-main-bckg.webp');
  background-repeat:no-repeat,no-repeat;background-position:center,center;background-size:cover,cover;
}
@media(min-width:1200px){.front-page{min-height:780px;padding:32px;border-radius:30px}}
@media(min-width:1600px){.front-page{min-height:880px}}
.front-page .text-block{
  position:relative;z-index:1;width:100%;max-width:1300px;margin:0 auto;padding-top:120px;
}
@media(min-width:1200px){.front-page .text-block{padding-top:0}}
.front-page .text-block::before{
  content:"";position:absolute;z-index:0;pointer-events:none;
  top:40px;left:0;width:240px;height:210px;
  background:url('/images/a-bg-element-new.svg') no-repeat center/contain;
}
@media(min-width:1200px){.front-page .text-block::before{top:-74%;left:-8px;width:47%;height:900px}}
@media(min-width:1600px){.front-page .text-block::before{top:-82%;left:-40px;width:50%;height:900px}}
.hero-eyebrow{
  position:relative;z-index:1;display:inline-block;color:#fff;font-weight:500;
  font-size:var(--fs-base);text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px;
}
.front-page .heading-title{
  position:relative;z-index:1;font-family:var(--ff-heading);font-weight:700;line-height:1;letter-spacing:-.01em;margin:0;
  text-transform:uppercase;font-size:clamp(2.6rem,9vw,8.688rem);
}
.front-page .stroke-text{color:#fff;-webkit-text-stroke:2px var(--ember);paint-order:stroke fill}
@media(min-width:1200px){.front-page .stroke-text{-webkit-text-stroke:4px var(--ember)}}
.front-page .inline-texts{position:relative;z-index:1;display:flex;flex-direction:column;gap:0}
@media(min-width:1200px){.front-page .inline-texts{flex-direction:row;gap:20px;align-items:flex-start}}
.front-page .inline-texts>span{flex:0 0 auto}
.front-page .inline-texts>.hero-quote{flex:1 1 auto;padding-top:30px;max-width:100%}
@media(min-width:1200px){.front-page .inline-texts>.hero-quote{padding-top:6px;padding-left:5%;max-width:70%}}
.hero-quote p{color:#fff;font-size:var(--fs-md);line-height:1.6;margin:0}
.hero-quote .text-green{color:var(--ember);font-weight:700}
.hero-quote-name{margin-top:14px;color:#fff;font-weight:600}
.hero-quote-role{color:var(--ember);font-weight:700;margin:2px 0 0}
.front-page .bottom-section{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  width:100%;z-index:1;padding:0 clamp(24px,4vw,40px);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;
}
.hero-scroll-link{
  display:inline-flex;align-items:center;gap:12px;color:#BDBDBD;
  font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:var(--fs-sm);
  transition:color .25s var(--ease);
}
.hero-scroll-link:hover{color:var(--ember)}
.hero-scroll-link svg{width:20px;height:20px;transition:transform .25s var(--ease)}
.hero-scroll-link:hover svg{transform:translateY(3px)}
/* Decorative grid */
.hero-grid-pattern{
  position:absolute;inset:0;z-index:1;opacity:.04;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-content{
  position:relative;z-index:2;
  max-width:720px;padding:calc(var(--header-h) + var(--header-top-h) + 60px) 0 60px;
}
.hero .label{margin-bottom:var(--sp-lg)}
.hero h1{
  font-size:clamp(2.5rem,6vw,var(--fs-6xl));
  color:var(--white);margin-bottom:var(--sp-xl);line-height:1.05;
  letter-spacing:-.03em;
}
.hero h1 .accent{
  color:var(--ember);
  text-shadow:0 2px 14px rgba(129,227,81,.35);
}
.hero-desc{
  font-size:var(--fs-xl);color:var(--ash);line-height:1.7;
  margin-bottom:var(--sp-2xl);max-width:600px;
}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:var(--sp-3xl)}
.hero-stats{
  display:flex;gap:clamp(24px,4vw,56px);
  padding:var(--sp-xl) 0;margin-top:var(--sp-xl);
  border-top:1px solid rgba(255,255,255,.15);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.hero-stat-item strong{
  display:block;font-family:var(--ff-heading);font-size:var(--fs-4xl);font-weight:900;
  color:var(--white);line-height:1;letter-spacing:-.03em;
}
.hero-stat-item span{font-size:var(--fs-md);color:var(--white);margin-top:8px;display:block;font-weight:500;opacity:.85}
.hero-stat-item .num{
  font-family:var(--ff-heading);font-size:var(--fs-3xl);font-weight:900;
  color:var(--white);line-height:1;letter-spacing:-.03em;
}
.hero-stat-item .num .plus{color:var(--forest)}
.hero-stat-item .txt{font-size:var(--fs-base);color:var(--cream);margin-top:6px}
/* Scroll indicator */
.hero-scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--ash);font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;
}
.hero-scroll-line{width:1px;height:48px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.hero-scroll-line::after{
  content:'';position:absolute;top:-100%;left:0;width:100%;height:50%;
  background:var(--ember);animation:scrollPulse 2s ease infinite;
}
@keyframes scrollPulse{0%{top:-50%}100%{top:150%}}

/* Floating hero image (right side) */
.hero-visual{
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  z-index:2;width:45%;max-width:580px;
  display:none; /* shown on large screens */
}
@media(min-width:1100px){
  .hero-visual{display:block}
  .hero-content{max-width:55%}
}
.hero-visual img{
  border-radius:var(--r-xl);
  box-shadow:0 32px 80px rgba(0,0,0,.4);
}
.hero-visual .glow{
  position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(129,227,81,.2),transparent 70%);
  top:-60px;right:-60px;filter:blur(40px);pointer-events:none;
}

/* ========== TRUST BAR ========== */
.trust-bar{
  padding:32px 0;background:var(--cream);
  border-bottom:1px solid rgba(0,0,0,.05);
}
.trust-bar-inner{
  display:flex;align-items:center;justify-content:center;
  gap:clamp(24px,5vw,64px);flex-wrap:wrap;
}
.trust-bar img{height:28px;opacity:.5;filter:grayscale(1);transition:all .4s var(--ease)}
.trust-bar img:hover{opacity:1;filter:none}
.trust-bar .divider{width:1px;height:24px;background:var(--silver)}

/* ========== STATS SECTION ========== */
.stats-section{
  padding:clamp(48px,8vw,96px) 0;
  background:var(--white);
  border-bottom:1px solid rgba(0,0,0,.05);
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
}
.stat-card{
  text-align:center;padding:clamp(24px,3vw,48px) 20px;
  border-right:1px solid rgba(0,0,0,.06);
  transition:background .4s var(--ease);
}
.stat-card:last-child{border-right:none}
.stat-card:hover{background:var(--cream)}
.stat-number{
  font-family:var(--ff-heading);font-size:clamp(var(--fs-4xl),5vw,var(--fs-5xl));
  font-weight:900;color:var(--ink);line-height:1;letter-spacing:-.03em;
  margin-bottom:8px;
}
.stat-number .accent{color:var(--ember)}
.stat-label{font-size:var(--fs-md);font-weight:700;color:var(--ink);margin-bottom:4px}
.stat-desc{font-size:var(--fs-sm);color:var(--slate);line-height:1.5}

/* ========== ABOUT / MISSION ========== */
.about-mission{padding:clamp(80px,12vw,140px) 0;background:var(--white)}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:center;
}
.about-text .label{margin-bottom:var(--sp-lg)}
.about-text h2{
  font-size:clamp(var(--fs-3xl),4vw,var(--fs-4xl));
  color:var(--ink);margin-bottom:var(--sp-lg);line-height:1.1;letter-spacing:-.03em;
}
.about-text p{font-size:var(--fs-md);color:var(--slate);line-height:1.8;margin-bottom:var(--sp-lg)}
.about-text blockquote{
  border-left:3px solid var(--ember);padding:var(--sp-lg) var(--sp-xl);
  margin:var(--sp-xl) 0;background:var(--ember-glow);border-radius:0 var(--r-md) var(--r-md) 0;
  font-size:var(--fs-base);font-style:italic;color:var(--ink);line-height:1.7;
}
.about-text .author{
  display:flex;align-items:center;gap:10px;
  font-size:var(--fs-sm);font-weight:600;color:var(--ember);font-style:normal;
  margin-top:var(--sp-md);
}
.about-image-group{
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
  gap:12px;
}
.about-image-group .img-wrap{
  border-radius:var(--r-lg);overflow:hidden;position:relative;
}
.about-image-group .img-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease);
}
.about-image-group .img-wrap:hover img{transform:scale(1.05)}
.about-image-group .img-wrap:first-child{grid-row:span 2}
.about-image-group .img-wrap:first-child img{height:100%;min-height:400px}
.about-image-group .img-wrap:not(:first-child) img{height:200px}
/* Accent block */
.about-image-group .accent-block{
  grid-column:2;display:flex;align-items:center;justify-content:center;
  background:var(--ember);border-radius:var(--r-lg);padding:24px;text-align:center;
  color:var(--white);
}
.accent-block .big{font-family:var(--ff-heading);font-size:var(--fs-4xl);font-weight:900;line-height:1}
.accent-block .small{font-size:var(--fs-sm);opacity:.9;margin-top:4px}

/* ========== PRODUCTS / BENTO GRID ========== */
.products-section{
  padding:clamp(80px,12vw,140px) 0;
  background:var(--cream);color:var(--ink);
}
.products-section .section-header h2{color:var(--ink)}
.products-section .section-header p{color:var(--slate)}
.section-header{max-width:680px;margin-bottom:clamp(40px,6vw,72px)}
.section-header .label{margin-bottom:var(--sp-md)}
.section-header h2{
  font-size:clamp(var(--fs-3xl),4vw,var(--fs-4xl));
  line-height:1.1;letter-spacing:-.03em;margin-bottom:var(--sp-md);
}
.section-header p{font-size:var(--fs-base);color:var(--ash);line-height:1.7}
.section-header--center{text-align:center;margin-left:auto;margin-right:auto}

/* Product grid — clean uniform 3-column */
.bento-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
/* 7th product card spans full width as a banner */
.bento-card--wide{grid-column:1 / -1;height:300px}
@media(max-width:640px){.bento-card--wide{height:320px}}

/* Image separator slider (between products and services) */
.image-slider-section{padding:clamp(36px,6vw,72px) 0;background:var(--white)}
.home-slider{border-radius:var(--r-xl);overflow:hidden}
.home-slider .swiper-slide{overflow:hidden}
.home-slider .swiper-slide img{width:100%;height:clamp(240px,40vw,500px);object-fit:cover;display:block}
.home-slider .swiper-pagination{position:static;margin-top:16px}
.home-slider .swiper-pagination-bullet{background:var(--ash);opacity:1}
.home-slider .swiper-pagination-bullet-active{background:var(--ember);width:22px;border-radius:6px}

.bento-card{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  height:380px;cursor:pointer;
  border:2px solid transparent;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s var(--ease);
}
.bento-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(0,0,0,.3);
  border-color:var(--forest);
}

.bento-card .bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .8s var(--ease);
}
.bento-card:hover .bg{transform:scale(1.06)}
.bento-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 10%,rgba(0,0,0,.88) 100%);
  transition:background .5s var(--ease);
}
.bento-card:hover .overlay{
  background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.92) 100%);
}
.bento-card .content{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;
}
.bento-card .tag{
  display:inline-block;padding:4px 10px;border-radius:var(--r-full);
  background:rgba(255,255,255,.12);backdrop-filter:blur(4px);
  font-size:var(--fs-xs);font-weight:600;color:var(--white);
  margin-bottom:10px;width:fit-content;letter-spacing:.04em;text-transform:uppercase;
}
.bento-card h3{
  font-size:var(--fs-2xl);
  color:var(--white);margin-bottom:10px;line-height:1.2;
  text-shadow:0 2px 8px rgba(0,0,0,.4);
}
.bento-card p{font-size:var(--fs-base);color:rgba(255,255,255,.85);line-height:1.6;margin-bottom:14px}
.bento-card .card-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:var(--fs-sm);font-weight:600;color:var(--ember-light);
  transition:gap .3s var(--ease);
}
.bento-card:hover .card-link{gap:10px}
.bento-card .card-link svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.bento-card:hover .card-link svg{transform:translateX(2px)}

/* ========== SERVICES — ZIGZAG TIMELINE ========== */
.services-section{
  padding:clamp(80px,12vw,140px) 0;
  background:var(--white);
  overflow:hidden;
}

/* Timeline container */
.services-timeline{
  position:relative;
  max-width:1100px;margin:0 auto;
}

/* Green center line — static track */
.services-timeline::before{
  content:'';position:absolute;
  left:50%;top:0;bottom:0;width:2px;
  background:rgba(129,227,81,.15);
  transform:translateX(-50%);
  z-index:1;
}

/* Traveling pulse element (added by JS) */
.timeline-pulse{
  position:absolute;left:50%;top:0;
  width:4px;height:0;
  background:linear-gradient(180deg,transparent,var(--forest-light) 30%,var(--forest) 70%,transparent);
  transform:translateX(-50%);
  z-index:2;
  border-radius:4px;
  box-shadow:0 0 16px rgba(91,181,46,.5),0 0 40px rgba(91,181,46,.2);
  pointer-events:none;
}

/* Filled track behind the pulse */
.timeline-fill{
  position:absolute;left:50%;top:0;
  width:3px;height:0;
  background:var(--forest);
  transform:translateX(-50%);
  z-index:1;
  border-radius:2px;
  pointer-events:none;
}

/* Each service row */
.service-row{
  display:grid;grid-template-columns:1fr 60px 1fr;
  gap:0;align-items:center;
  margin-bottom:clamp(40px,6vw,64px);
  position:relative;
}

/* Timeline dot */
.service-dot{
  position:relative;z-index:3;
  display:flex;align-items:center;justify-content:center;
}
.service-dot::before{
  content:'';width:16px;height:16px;border-radius:50%;
  background:var(--white);border:3px solid rgba(129,227,81,.3);
  box-shadow:0 0 0 4px rgba(129,227,81,.06);
  transition:all .6s var(--ease);
}
.service-row:hover .service-dot::before{
  border-color:var(--forest);
  box-shadow:0 0 0 8px rgba(129,227,81,.15);
}
/* Active state — set by JS when pulse reaches the dot */
.service-dot.lit::before{
  background:var(--forest);
  border-color:var(--forest-light);
  box-shadow:0 0 0 10px rgba(91,181,46,.25),0 0 20px rgba(91,181,46,.3);
  transform:scale(1.3);
}
.service-dot.passed::before{
  background:var(--forest);
  border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(129,227,81,.1);
  transform:scale(1);
}

/* Text block */
.service-text{
  padding:clamp(24px,3vw,40px);
}
.service-text .num{
  font-family:var(--ff-heading);font-size:var(--fs-5xl);font-weight:900;
  color:var(--cream);line-height:1;margin-bottom:8px;
  -webkit-text-stroke:1.5px var(--silver);
  transition:all .4s var(--ease);
}
.service-row:hover .service-text .num{
  color:var(--forest-glow);-webkit-text-stroke-color:var(--forest);
}
.service-text .service-card-icon{
  width:48px;height:48px;border-radius:var(--r-lg);
  background:var(--ember-glow);color:var(--ember);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;transition:all .3s var(--ease);
}
.service-text .service-card-icon svg{width:24px;height:24px}
.service-row:hover .service-text .service-card-icon{
  background:var(--forest);color:var(--white);
  transform:scale(1.1);
}
.service-text h4{
  font-size:var(--fs-2xl);margin-bottom:10px;color:var(--ink);
  line-height:1.2;
}
.service-text p{
  font-size:var(--fs-md);color:var(--slate);line-height:1.7;
  margin-bottom:16px;
}
.service-text .link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-base);font-weight:600;color:var(--forest);
  transition:gap .3s var(--ease);
}
.service-row:hover .service-text .link{gap:14px}

/* Image block */
.service-img{
  border-radius:var(--r-xl);overflow:hidden;
  height:320px;position:relative;
}
.service-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease);
}
.service-row:hover .service-img img{transform:scale(1.05)}
.service-img::after{
  content:'';position:absolute;inset:0;
  border:2px solid transparent;border-radius:var(--r-xl);
  transition:border-color .4s var(--ease);
}
.service-row:hover .service-img::after{border-color:var(--forest)}

/* Alternating sides: even rows flip */
.service-row:nth-child(even){direction:rtl}
.service-row:nth-child(even) > *{direction:ltr}
.service-row:nth-child(even) .service-text{text-align:right}
.service-row:nth-child(even) .service-text .link{justify-content:flex-end}

/* Responsive */
@media(max-width:992px){
  .services-timeline::before,.timeline-pulse,.timeline-fill{left:24px}
  .service-row{grid-template-columns:48px 1fr;gap:0}
  .service-dot{justify-content:flex-start}
  .service-img{height:240px;margin-bottom:16px}
  .service-row:nth-child(even){direction:ltr}
  .service-row:nth-child(even) .service-text{text-align:left}
  .service-row:nth-child(even) .service-text .link{justify-content:flex-start}
}
@media(max-width:768px){
  .services-timeline::before,.timeline-pulse,.timeline-fill{display:none}
  .service-row{grid-template-columns:1fr;gap:0}
  .service-dot{display:none}
  .service-img{height:200px;margin-bottom:16px}
}

/* ========== TESTIMONIALS ========== */
.testimonials-section{
  padding:clamp(80px,12vw,140px) 0;
  background:var(--white);
}
.testimonials-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.testimonial-card{
  background:var(--white);border-radius:var(--r-xl);padding:32px;
  border:1px solid rgba(0,0,0,.06);
  transition:all .4s var(--ease);position:relative;
}
.testimonial-card:hover{
  border-color:var(--ember);box-shadow:var(--shadow-lg);transform:translateY(-4px);
}
.testimonial-card .stars{
  display:flex;gap:2px;margin-bottom:16px;
}
.testimonial-card .stars span{color:#F59E0B;font-size:var(--fs-md)}
.testimonial-card .quote{
  font-size:var(--fs-base);color:var(--slate);line-height:1.75;
  margin-bottom:24px;font-style:italic;
}
.testimonial-card .quote::before{
  content:'\201C';display:block;
  font-family:Georgia,serif;font-size:var(--fs-4xl);
  color:var(--ember);line-height:1;margin-bottom:8px;
}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{
  width:44px;height:44px;border-radius:var(--r-full);
  object-fit:cover;border:2px solid var(--cream);
}
.testimonial-name{font-size:var(--fs-sm);font-weight:700;color:var(--ink)}
.testimonial-role{font-size:var(--fs-xs);color:var(--ash)}

/* ========== CTA BANNER ========== */
.cta-banner{
  padding:clamp(80px,12vw,140px) 0;
  background:linear-gradient(135deg,#000 0%,var(--ink) 50%,#000 100%);
  color:var(--white);position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(129,227,81,.16),transparent 70%);
  top:-200px;right:-100px;pointer-events:none;
}
.cta-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:40px;flex-wrap:wrap;
}
.cta-inner h2{
  font-size:clamp(var(--fs-2xl),3.5vw,var(--fs-4xl));
  line-height:1.1;letter-spacing:-.03em;max-width:600px;
}
.cta-inner p{font-size:var(--fs-base);color:var(--ash);margin-top:10px;max-width:500px}

/* ========== FOOTER (dark — cloned layout: brand + CTA, then 4 columns) ========== */
.site-footer{background:#0A0A0A;color:#fff;padding:clamp(56px,8vw,96px) 0 0}

/* Top: brand/contacts (left) + big CTA (right) */
.footer-head{display:flex;flex-direction:column;gap:40px}
@media(min-width:900px){.footer-head{flex-direction:row;align-items:flex-start;gap:clamp(40px,5vw,72px)}}
.footer-brand{display:flex;flex-direction:column;gap:26px;flex:0 0 auto}
@media(min-width:900px){.footer-brand{width:34%}}
.footer-logo{height:44px;width:auto;display:block}
.footer-social{display:flex;gap:12px}
.footer-social a{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.22);color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease);
}
.footer-social a:hover{background:var(--ember);border-color:var(--ember);color:#000;transform:translateY(-2px)}
.footer-social a svg{width:16px;height:16px}
.footer-contacts{display:flex;flex-direction:column;gap:14px}
.footer-contact-item{
  display:flex;align-items:center;gap:12px;
  font-size:var(--fs-sm);color:#BDBDBD;transition:color .25s var(--ease);
}
.footer-contact-item:hover{color:#fff}
.footer-contact-item svg{width:18px;height:18px;color:var(--ember);flex-shrink:0}
.footer-cta{flex:1 1 auto}
.footer-cta-title{
  font-family:var(--ff-heading);font-weight:800;letter-spacing:-.01em;
  font-size:clamp(2rem,4.6vw,4.25rem);line-height:1.04;color:#fff;margin:0 0 30px;
}
.footer-cta-title .accent{color:var(--ember)}

.footer-divider{border:none;border-top:1px solid rgba(255,255,255,.16);margin:clamp(40px,6vw,64px) 0}

/* Columns: newsletter + Полезно + Продукти + Услуги */
.footer-cols{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:600px){.footer-cols{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-cols{grid-template-columns:1.5fr 1fr 1.1fr 1fr;gap:clamp(28px,3vw,52px)}}

.footer-newsletter{max-width:380px}
.footer-nl-intro{font-size:var(--fs-md);color:#fff;font-weight:500;line-height:1.6;margin:0 0 22px}
.footer-nl-form{display:flex;flex-direction:column;gap:14px}
.footer-nl-form input[type="email"]{
  width:100%;padding:14px 22px;border-radius:var(--r-full);
  background:#fff;border:1px solid transparent;color:var(--ink);font-size:var(--fs-sm);
}
.footer-nl-form input[type="email"]::placeholder{color:var(--slate)}
.footer-nl-form input[type="email"]:focus{border-color:var(--ember)}
.footer-nl-btn{width:100%;justify-content:space-between}
.footer-nl-agree{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.footer-nl-agree input{margin-top:3px;width:16px;height:16px;accent-color:var(--ember);flex-shrink:0}
.footer-nl-agree span{font-size:var(--fs-xs);color:#BDBDBD;line-height:1.5}
.footer-nl-msg{font-size:var(--fs-xs);min-height:1em;font-weight:600}
.footer-nl-msg.ok{color:var(--ember)}
.footer-nl-msg.err{color:#EB5757}

.footer-col h4{
  font-family:var(--ff-heading);font-size:var(--fs-sm);font-weight:800;color:#fff;
  margin:0 0 18px;text-transform:uppercase;letter-spacing:.08em;
}
.footer-col ul{display:flex;flex-direction:column;gap:11px}
.footer-col ul li a{
  font-size:var(--fs-sm);color:#BDBDBD;line-height:1.4;
  transition:color .25s var(--ease);
}
.footer-col ul li a:hover{color:var(--ember)}

.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;
  margin-top:clamp(40px,6vw,64px);padding:24px 0;
  border-top:1px solid rgba(255,255,255,.12);
  font-size:var(--fs-xs);color:#BDBDBD;
}
.footer-bottom-links{display:flex;flex-wrap:wrap;gap:22px}
.footer-bottom-links a{color:#BDBDBD;transition:color .25s var(--ease)}
.footer-bottom-links a:hover{color:#fff}

/* ========== BREADCRUMB ========== */
.breadcrumb{padding:14px 0;background:var(--cream);border-bottom:1px solid var(--silver);margin-top:calc(var(--header-h) + var(--header-top-h))}
.breadcrumb-list{
  display:flex;align-items:center;gap:8px;
  font-size:var(--fs-sm);color:var(--slate);
}
.breadcrumb-list a{color:var(--slate);transition:color .2s}
.breadcrumb-list a:hover{color:var(--ember-dark)}
.breadcrumb-list .separator{color:var(--ash)}
.breadcrumb-list .current{color:var(--ink);font-weight:600}

/* ========== INNER-PAGE BANNER (reference rounded dark card) ========== */
.page-banner-section{background:#fff;padding:0 0 clamp(8px,2vw,20px)}
.page-banner-section>.container{max-width:1680px;padding-left:clamp(16px,2.5vw,32px);padding-right:clamp(16px,2.5vw,32px)}
.page-banner{
  position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  min-height:240px;border-radius:24px;overflow:hidden;
  padding:24px clamp(24px,5vw,64px);
  background:#0b0b0c;background-size:cover;background-position:center;background-repeat:no-repeat;
}
@media(min-width:768px){.page-banner{min-height:360px;border-radius:32px;padding-bottom:32px}}
.page-banner--black{background:#0b0b0c}
.page-banner::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 38%, rgba(0,0,0,.5) 100%),
    linear-gradient(90deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.12) 55%, rgba(0,0,0,0) 100%),
    url('/images/bg-line-element.svg') center/cover no-repeat;
}
.page-banner-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:10px}
@media(min-width:1100px){.page-banner-inner{flex-direction:row;align-items:center;gap:32px}}
.page-banner-inner h1{
  margin:0;color:#fff;font-family:var(--ff-heading);font-weight:800;text-transform:uppercase;
  font-size:clamp(24px,4.6vw,48px);line-height:1.05;letter-spacing:-.01em;
}
@media(min-width:1100px){.page-banner-inner h1{white-space:nowrap}}
.page-banner-line{display:none}
@media(min-width:1100px){.page-banner-line{display:block;flex:1 1 auto;height:1px;background:#0C0;border-radius:2px}}
.page-banner-crumbs{margin:0;color:#fff;font-size:16px;font-weight:500;line-height:1.4}
@media(min-width:1100px){.page-banner-crumbs{white-space:nowrap}}
.page-banner-crumbs a{color:#fff;font-weight:500;text-decoration:none}
.page-banner-crumbs a:hover{color:var(--ember)}
.page-banner-crumbs .sep{margin:0 7px;color:rgba(255,255,255,.65)}
.page-banner-crumbs .current{color:rgba(255,255,255,.9)}

/* Phones: top banner / hero bars go edge-to-edge (full display width) */
@media(max-width:767px){
  .page-banner-section>.container{max-width:100%;padding-left:0;padding-right:0}
  .page-banner{border-radius:0}
  .hero>.container{max-width:100%;padding-left:0;padding-right:0}
  .front-page{border-radius:0}
}

/* ========== PAGE HERO (inner) — light brand bg ========== */
.page-hero{
  padding:clamp(140px,16vw,200px) 0 clamp(60px,8vw,100px);
  background:var(--cream);color:var(--ink);
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--silver);
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(129,227,81,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(129,227,81,.06) 1px,transparent 1px);
  background-size:50px 50px;
}
.page-hero .container{position:relative;z-index:2}
.page-hero .label{margin-bottom:var(--sp-md)}
.page-hero h1{
  font-size:clamp(var(--fs-3xl),5vw,var(--fs-5xl));
  margin-bottom:var(--sp-md);letter-spacing:-.03em;line-height:1.05;color:var(--ink);
}
.page-hero p{font-size:var(--fs-xl);color:var(--slate);max-width:650px;line-height:1.7}
.page-hero--with-image{display:flex;align-items:center}
.page-hero--with-image .page-hero-image{
  position:absolute;right:0;top:0;bottom:0;width:45%;
  z-index:1;
}
.page-hero--with-image .page-hero-image img{
  width:100%;height:100%;object-fit:cover;
}
.page-hero--with-image .page-hero-image::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,var(--cream) 0%,transparent 60%);z-index:1;
}

/* ========== SERVICE PAGE LAYOUT ========== */
.service-page{padding:clamp(48px,8vw,80px) 0}
/* No sidebar on inner pages — full-width content like the reference */
.service-page-grid{display:block;width:100%}
.sidebar-menu{display:none}
.sidebar-menu h3{
  font-size:var(--fs-sm);font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--ash);margin-bottom:var(--sp-md);
}
.sidebar-menu ul li{margin-bottom:2px}
.sidebar-menu ul li a{
  display:block;padding:10px 16px;border-radius:var(--r-md);
  font-size:var(--fs-sm);color:var(--slate);
  transition:all .25s var(--ease);
  border-left:2px solid transparent;
}
.sidebar-menu ul li a:hover{
  background:var(--cream);color:var(--ink);
}
.sidebar-menu ul li a.active{
  background:var(--ember-glow);color:var(--ember);
  border-left-color:var(--ember);font-weight:600;
}
.service-content h2{
  font-size:clamp(var(--fs-2xl),3.5vw,var(--fs-4xl));
  color:var(--ember);margin-bottom:var(--sp-lg);letter-spacing:-.02em;
}
.service-content h3{
  font-size:var(--fs-2xl);margin-top:var(--sp-2xl);margin-bottom:var(--sp-md);
  color:var(--ink);
}
.service-content p{
  font-size:var(--fs-md);color:var(--slate);line-height:1.8;margin-bottom:var(--sp-lg);
}
.service-content img{
  border-radius:var(--r-lg);margin:var(--sp-xl) 0;width:100%;
  min-height:300px;object-fit:cover;
}

/* ============================================================
   LEGAL PAGES (Terms / Cookie Policy / Privacy Policy)
   ============================================================ */
.container--narrow{max-width:940px}
.legal-section{padding:clamp(40px,6vw,72px) 0;background:#fff}

/* Accordion (Terms & Conditions, Cookie Policy) */
.legal-accordion{display:flex;flex-direction:column;gap:14px}
.legal-item{
  border:1px solid #E4F0DC;border-radius:16px;background:#fff;overflow:hidden;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.legal-item.open{border-color:var(--forest);box-shadow:0 10px 30px rgba(43,43,43,.06)}
.legal-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:22px clamp(18px,3vw,30px);background:none;border:none;cursor:pointer;
  text-align:left;font-family:inherit;color:var(--ink);
  font-size:clamp(1.05rem,1.6vw,1.25rem);font-weight:700;line-height:1.4;
}
.legal-toggle:hover{color:var(--forest)}
.legal-toggle svg{flex-shrink:0;width:18px;height:11px;color:var(--ash);transition:transform .3s var(--ease)}
.legal-item.open .legal-toggle svg{transform:rotate(180deg);color:var(--forest)}
.legal-content{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s var(--ease)}
.legal-item.open .legal-content{grid-template-rows:1fr}
.legal-content>.legal-text{overflow:hidden}
.legal-text{padding:0 clamp(18px,3vw,30px)}
.legal-item.open .legal-text{padding-bottom:26px}

/* Shared legal typography (accordion body + privacy article) */
.legal-text,.legal-article{color:var(--slate);font-size:var(--fs-md);line-height:1.85}
.legal-text p,.legal-article p{margin:0 0 16px}
.legal-text p:last-child,.legal-article p:last-child{margin-bottom:0}
.legal-text strong,.legal-article strong{color:var(--ink);font-weight:700}
.legal-text a,.legal-article a{color:var(--ember-dark);font-weight:600;word-break:break-word}
.legal-text a:hover,.legal-article a:hover{text-decoration:underline}
.legal-text ol,.legal-text ul,.legal-article ol,.legal-article ul{margin:0 0 16px;padding-left:24px}
.legal-text li,.legal-article li{margin-bottom:8px;line-height:1.75}
.legal-text ol,.legal-article ol{list-style:decimal}
.legal-text ul,.legal-article ul{list-style:disc}

/* Article layout (Privacy Policy) */
.legal-article{background:#fff;border:1px solid #E4F0DC;border-radius:20px;padding:clamp(24px,4vw,48px)}
.legal-article h3{
  margin:34px 0 14px;color:var(--ink);font-weight:800;
  font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.35;
  padding-bottom:10px;border-bottom:2px solid var(--forest-glow);
}
.legal-article h3:first-child{margin-top:0}
.legal-article table{width:100%;border-collapse:collapse;margin:8px 0 24px;font-size:var(--fs-sm)}
.legal-article th,.legal-article td{border:1px solid #E4F0DC;padding:12px 14px;text-align:left;vertical-align:top}
.legal-article th{background:var(--cream);color:var(--ink);font-weight:700}
@media(max-width:600px){
  .legal-article table,.legal-article thead,.legal-article tbody,.legal-article tr,.legal-article th,.legal-article td{display:block;width:100%}
  .legal-article thead{display:none}
  .legal-article td{border-bottom:none}
  .legal-article tr{border:1px solid #E4F0DC;border-radius:10px;margin-bottom:14px;padding:6px;display:block}
  .legal-article td:last-child{border-bottom:1px solid #E4F0DC}
}

/* Feature list */
.feature-list li{
  padding:12px 0 12px 36px;position:relative;
  font-size:var(--fs-md);color:var(--slate);line-height:1.7;
}
.feature-list li::before{
  content:'';position:absolute;left:0;top:16px;
  width:18px;height:18px;border-radius:var(--r-full);
  background:var(--forest-glow);
  border:2px solid var(--forest);
}
.feature-list li::after{
  content:'\2713';position:absolute;left:3px;top:14px;
  font-size:11px;color:var(--forest);font-weight:700;
}

/* Steps */
.steps-list{counter-reset:steps;margin:var(--sp-xl) 0}
.step-item{
  counter-increment:steps;
  display:flex;gap:20px;align-items:flex-start;
  padding:var(--sp-xl);margin-bottom:12px;
  background:var(--cream);border-radius:var(--r-lg);
  transition:all .3s var(--ease);
}
.step-item:hover{background:var(--ember-glow)}
.step-item::before{
  content:counter(steps);flex-shrink:0;
  width:40px;height:40px;border-radius:var(--r-full);
  background:var(--ember);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:var(--fs-sm);font-family:var(--ff-heading);
}
.step-item-body h4{font-size:var(--fs-lg);margin-bottom:6px;color:var(--ink)}
.step-item-body p{font-size:var(--fs-base);color:var(--slate);margin:0;line-height:1.7}

/* Specs table */
.specs-table{
  width:100%;border-collapse:separate;border-spacing:0;
  margin:var(--sp-xl) 0;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid rgba(0,0,0,.08);font-size:var(--fs-sm);
}
.specs-table th{
  background:var(--ink);color:var(--white);
  padding:14px 16px;text-align:left;font-weight:600;font-size:var(--fs-xs);
  letter-spacing:.03em;text-transform:uppercase;
}
.specs-table td{
  padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.05);color:var(--slate);
}
.specs-table tr:hover td{background:var(--cream)}
.specs-table tr:last-child td{border-bottom:none}
/* Mobile: make spec tables horizontally scrollable instead of clipped */
@media(max-width:768px){
  .specs-table{display:block;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap;border-radius:12px}
  .specs-table th,.specs-table td{white-space:nowrap}
}

/* Cert badges */
.cert-badges{display:flex;gap:20px;align-items:center;margin:var(--sp-xl) 0}
.cert-badges img{height:48px;opacity:.7;transition:opacity .3s}
.cert-badges img:hover{opacity:1}

/* ========== PRODUCT DETAIL ========== */
.product-detail{padding:clamp(48px,8vw,80px) 0}
.product-detail-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,64px);align-items:start;
}
.product-detail img{border-radius:var(--r-lg);min-height:350px;object-fit:cover}
.product-detail h2{
  font-size:clamp(var(--fs-2xl),3vw,var(--fs-3xl));
  margin-bottom:var(--sp-md);color:var(--ink);letter-spacing:-.02em;
}
.product-detail p{font-size:var(--fs-base);color:var(--slate);line-height:1.8;margin-bottom:var(--sp-lg)}

/* Feature grid */
.feature-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:var(--sp-2xl) 0;
}
.feature-grid-item{
  padding:28px;border-radius:var(--r-lg);
  background:var(--cream);border:1px solid rgba(0,0,0,.04);
  transition:all .3s var(--ease);
}
.feature-grid-item:hover{border-color:var(--ember);box-shadow:var(--shadow-md)}
.feature-grid-item .icon{
  width:52px;height:52px;border-radius:var(--r-md);
  background:var(--ember-glow);color:var(--ember);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-heading);font-weight:900;font-size:var(--fs-lg);
  margin-bottom:14px;
}
.feature-grid-item .icon svg{width:26px;height:26px}
.feature-grid-item h4{font-size:var(--fs-lg);margin-bottom:8px;color:var(--ink)}
.feature-grid-item p{font-size:var(--fs-base);color:var(--slate);line-height:1.7;margin:0}

/* ========== ACCORDION ========== */
.accordion{margin:var(--sp-xl) 0}
.accordion-item{
  border:1px solid rgba(0,0,0,.06);border-radius:var(--r-lg);
  margin-bottom:8px;overflow:hidden;
  transition:border-color .3s var(--ease);
}
.accordion-item.active{border-color:var(--ember)}
.accordion-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;cursor:pointer;
  font-weight:600;font-size:var(--fs-base);color:var(--ink);
  transition:all .3s var(--ease);
}
.accordion-header:hover{background:var(--cream)}
.accordion-icon{
  width:28px;height:28px;border-radius:var(--r-full);
  background:var(--cream);display:flex;align-items:center;justify-content:center;
  font-size:var(--fs-lg);color:var(--ink);transition:all .3s var(--ease);flex-shrink:0;
}
.accordion-item.active .accordion-icon{background:var(--ember);color:var(--white);transform:rotate(45deg)}
.accordion-panel{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.accordion-panel-inner{padding:0 24px 24px;color:var(--slate);font-size:var(--fs-sm);line-height:1.7}

/* ========== CONTACT ========== */
.contact-section{padding:clamp(48px,8vw,80px) 0}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(32px,5vw,64px)}
.contact-info-card{
  display:flex;align-items:flex-start;gap:16px;
  padding:20px;border-radius:var(--r-lg);
  border:1px solid rgba(0,0,0,.06);margin-bottom:12px;
  transition:all .3s var(--ease);
}
.contact-info-card:hover{border-color:var(--ember);box-shadow:var(--shadow-sm)}
.contact-info-icon{
  width:48px;height:48px;border-radius:var(--r-md);
  background:var(--ember-glow);color:var(--ember);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-info-icon svg{width:20px;height:20px}
.contact-info-card h4{font-size:var(--fs-base);margin-bottom:2px;color:var(--ink)}
.contact-info-card p{font-size:var(--fs-sm);color:var(--slate);margin:0;line-height:1.5}
.contact-info-card a{color:var(--ember);font-weight:500}

/* Contact form */
.contact-form{
  background:var(--cream);padding:clamp(24px,4vw,40px);
  border-radius:var(--r-xl);
}
.contact-form h3{font-size:var(--fs-2xl);margin-bottom:4px;color:var(--ink);letter-spacing:-.02em}
.contact-form .form-subtitle{font-size:var(--fs-sm);color:var(--slate);margin-bottom:var(--sp-xl)}
.form-group{margin-bottom:16px}
.form-group label{
  display:block;font-size:var(--fs-xs);font-weight:600;
  color:var(--ink);margin-bottom:6px;letter-spacing:.02em;text-transform:uppercase;
}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:15px 18px;
  background:var(--white);border:1px solid rgba(0,0,0,.1);
  border-radius:var(--r-md);font-size:var(--fs-sm);color:var(--ink);
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:var(--ember);box-shadow:0 0 0 3px var(--ember-glow);
}
.form-group textarea{height:140px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-agreement{
  display:flex;align-items:flex-start;gap:10px;
  font-size:var(--fs-xs);color:var(--slate);margin-bottom:var(--sp-lg);
}
.form-agreement input[type="checkbox"]{
  width:18px;height:18px;accent-color:var(--ember);
  margin-top:1px;flex-shrink:0;cursor:pointer;
}

/* ========== WHY US ========== */
.why-us-section{padding:clamp(60px,10vw,100px) 0;background:var(--cream)}
.why-us-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:var(--sp-2xl)}
.why-us-card{
  text-align:center;padding:32px 16px;
  background:var(--white);border-radius:var(--r-xl);
  border:1px solid rgba(0,0,0,.04);transition:all .4s var(--ease);
}
.why-us-card:hover{border-color:var(--ember);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.why-us-icon{
  width:56px;height:56px;margin:0 auto var(--sp-md);
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-lg);background:var(--ember-glow);
}
.why-us-icon img{width:28px;height:28px}
.why-us-card h4{font-size:var(--fs-md);margin-bottom:6px;color:var(--ink)}
.why-us-card p{font-size:var(--fs-sm);color:var(--slate);line-height:1.6}

/* ========== SHOP / CATALOG ========== */
.shop-section{padding:clamp(48px,8vw,80px) 0;background:var(--white)}
.shop-filters{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:var(--sp-2xl);
}
.filter-btn{
  padding:10px 22px;border:1px solid var(--silver);border-radius:var(--r-full);
  background:var(--white);font-family:var(--ff-body);font-size:var(--fs-sm);font-weight:600;
  cursor:pointer;transition:all .3s var(--ease);color:var(--ink);
}
.filter-btn:hover{border-color:var(--ink)}
.filter-btn.active{
  background:var(--ember);color:var(--ink);border-color:var(--ember);
}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.shop-item{
  background:var(--white);border-radius:var(--r-xl);overflow:hidden;
  border:1px solid rgba(0,0,0,.06);transition:all .4s var(--ease);
}
.shop-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.shop-item-img-wrap{overflow:hidden;height:220px}
.shop-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.shop-item:hover img{transform:scale(1.06)}
.shop-item-body{padding:20px}
.shop-item h3{font-size:var(--fs-lg);margin-bottom:6px;color:var(--ink)}
.shop-item .category{font-size:var(--fs-xs);color:var(--forest);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:inline-block}
.shop-item-desc{font-size:var(--fs-sm);color:var(--slate);line-height:1.6;margin-bottom:12px}
.shop-item-link{
  display:inline-flex;align-items:center;gap:12px;
  margin-top:4px;padding:7px 7px 7px 20px;border-radius:var(--r-full);
  background:var(--ember);color:var(--ink);
  font-family:var(--ff-body);font-size:var(--fs-sm);font-weight:700;
  transition:all .3s var(--ease);
}
.shop-item-link svg{
  width:30px;height:30px;padding:7px;border-radius:50%;box-sizing:border-box;
  background:#000;color:#fff;flex-shrink:0;transition:all .3s var(--ease);
}
.shop-item:hover .shop-item-link{background:#000;color:#fff}
.shop-item:hover .shop-item-link svg{background:var(--ember);color:#fff}
.shop-item-placeholder{
  height:220px;background:var(--cream);
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid rgba(0,0,0,.04);
}

/* ========== SAFETY GRID ========== */
.safety-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:var(--sp-2xl) 0}
.safety-item{
  text-align:center;padding:24px 16px;
  border:1px solid rgba(0,0,0,.06);border-radius:var(--r-lg);
  transition:all .3s var(--ease);
}
.safety-item:hover{border-color:var(--ember);background:var(--ember-glow)}
.safety-item .num,.safety-item .icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:50%;margin:0 auto 12px;
  background:var(--ember-soft);
  font-family:var(--ff-heading);font-size:var(--fs-xl);font-weight:900;
  color:var(--ember-dark,#5BB52E);
}
.safety-item h4,.safety-item h3{font-size:var(--fs-md);color:var(--ink);margin:0 0 8px;font-weight:700}
.safety-item p{font-size:var(--fs-sm);color:var(--slate);line-height:1.5}

/* ========== PARKING TYPES ========== */
.parking-types{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:var(--sp-2xl) 0}
.parking-type-card{
  background:var(--cream);border-radius:var(--r-xl);padding:32px;
  border:1px solid rgba(0,0,0,.04);transition:all .3s var(--ease);
}
.parking-type-card:hover{border-color:var(--ember);box-shadow:var(--shadow-md)}
.parking-type-card h3,.parking-type-card h4{font-size:var(--fs-xl);margin-bottom:8px;color:var(--ink)}
.parking-type-card p{font-size:var(--fs-sm);color:var(--slate);line-height:1.7;margin:0}

/* ========== FLOATING BUTTONS ========== */
.floating-buttons{
  position:fixed;bottom:24px;right:16px;z-index:999;
  display:flex;flex-direction:column;gap:10px;
}
@media(max-width:768px){
  .floating-buttons{bottom:16px;right:12px;gap:8px}
  .float-btn{width:44px;height:44px}
  /* Hide back-to-top on mobile to reduce FAB clutter — swipe up is native */
  .float-btn-top{display:none!important}
}
.float-btn{
  width:48px;height:48px;border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lg);cursor:pointer;border:none;
  transition:all .3s var(--ease);
}
.float-btn:hover{transform:translateY(-3px) scale(1.05);box-shadow:var(--shadow-xl)}
.float-btn-phone{background:var(--forest)}
.float-btn-whatsapp{background:#25D366}
.float-btn-top{
  background:var(--ink);opacity:0;visibility:hidden;
  transition:all .3s var(--ease);
}
.float-btn-top.visible{opacity:1;visibility:visible}
.float-btn img,.float-btn svg{width:20px;height:20px;filter:brightness(0) invert(1)}

/* ========== BLOG ========== */
.blog-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;
}
.blog-card{
  background:var(--white);border:1px solid rgba(0,0,0,.06);
  border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.08)}
.blog-card-media{display:block;aspect-ratio:16/10;overflow:hidden;background:#F3F4F6}
.blog-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.blog-card:hover .blog-card-media img{transform:scale(1.04)}
.blog-card-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  color:#9CA3AF;background:linear-gradient(135deg,#F3F4F6,#E5E7EB);
}
.blog-card-body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-card-date{font-size:.8125rem;color:var(--slate);font-weight:500}
.blog-card-body h3{font-size:1.1rem;line-height:1.35;margin:0}
.blog-card-body h3 a{color:var(--ink);text-decoration:none}
.blog-card-body h3 a:hover{color:var(--forest)}
.blog-card-body p{font-size:.9375rem;color:var(--slate);line-height:1.6;margin:0;flex:1}
.blog-card-body .link{margin-top:8px;color:var(--forest);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.blog-card-body .link:hover{gap:10px}
.blog-empty{padding:60px 0;text-align:center;color:var(--slate)}

.blog-article-cover{margin-bottom:32px;border-radius:16px;overflow:hidden;max-height:520px}
.blog-article-cover img{width:100%;height:100%;object-fit:cover}
.blog-article-body{max-width:760px;margin:0 auto;font-size:1.0625rem;line-height:1.8;color:var(--ink)}
.blog-article-body p{margin-bottom:1.25em}
.blog-article-body h2{font-size:1.65rem;margin:1.8em 0 .6em;color:var(--ink)}
.blog-article-body h3{font-size:1.3rem;margin:1.6em 0 .5em;color:var(--ink)}
.blog-article-body ul,.blog-article-body ol{margin:0 0 1.25em 1.2em}
.blog-article-body img{max-width:100%;border-radius:12px;margin:1em 0}
.blog-article-body blockquote{
  border-left:3px solid var(--forest);padding:4px 0 4px 20px;
  margin:1.5em 0;color:var(--slate);font-style:italic;
}
.blog-tags{max-width:760px;margin:32px auto 0;display:flex;flex-wrap:wrap;gap:8px}
.blog-tag{
  display:inline-block;padding:4px 12px;border-radius:99px;
  background:rgba(129,227,81,.1);color:var(--forest);font-size:.8125rem;font-weight:600;
}
.post-meta{color:rgba(255,255,255,.7);font-size:.9rem}

@media(max-width:900px){
  .blog-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
}
@media(max-width:600px){
  .blog-grid{grid-template-columns:minmax(0,1fr);gap:18px}
}

/* ========== COOKIE MODAL ========== */
.cookie-modal{
  position:fixed;bottom:24px;left:24px;right:24px;
  max-width:480px;z-index:10000;
  background:var(--white);border-radius:var(--r-xl);
  padding:28px;box-shadow:var(--shadow-xl);
  border:1px solid rgba(0,0,0,.08);
  transform:translateY(120%);transition:transform .5s var(--ease);
}
.cookie-modal.visible{transform:translateY(0)}
.cookie-modal h4{font-size:var(--fs-lg);margin-bottom:8px;color:var(--ink)}
.cookie-modal p{font-size:var(--fs-sm);color:var(--slate);line-height:1.6;margin-bottom:var(--sp-md)}
.cookie-cats{display:flex;flex-direction:column;gap:2px;margin:0 0 var(--sp-lg);border-top:1px solid var(--silver);border-bottom:1px solid var(--silver);padding:6px 0}
.cookie-cat{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 2px;font-size:var(--fs-sm);color:var(--ink);font-weight:600;cursor:pointer}
.cookie-cat input{width:18px;height:18px;accent-color:var(--ember);cursor:pointer}
.cookie-cat input:disabled{opacity:.5;cursor:not-allowed}
.cookie-buttons{display:flex;gap:8px}

/* ========== ANIMATED COUNTERS ========== */
.counter-section{
  padding:clamp(60px,10vw,100px) 0;
  background:var(--ink);color:var(--white);
  position:relative;overflow:hidden;
}
.counter-section::before{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(129,227,81,.08),transparent 70%);
  top:-200px;left:-200px;pointer-events:none;
}
.counter-section::after{
  content:'';position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(129,227,81,.06),transparent 70%);
  bottom:-150px;right:-100px;pointer-events:none;
}
.counter-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center;
  position:relative;z-index:1;
}
.counter-item{
  padding:32px 24px;
  background:rgba(129,227,81,.1);
  border:1px solid rgba(129,227,81,.2);
  border-radius:var(--r-xl);
  transition:all .4s var(--ease);
}
.counter-item:hover{
  background:rgba(129,227,81,.18);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(129,227,81,.15);
}
.counter-value{
  font-family:var(--ff-heading);
  font-size:clamp(3rem,7vw,5rem);
  font-weight:900;line-height:1;letter-spacing:-.03em;
  color:var(--white);margin-bottom:12px;
}
.counter-suffix{color:var(--forest-light)}
.counter-label{font-size:var(--fs-lg);font-weight:700;color:var(--white)}
.counter-desc{font-size:var(--fs-base);color:var(--ash);margin-top:6px}

/* ========== SWIPER TESTIMONIALS ========== */
.testimonials-swiper{padding-bottom:60px!important}
.testimonials-swiper .swiper-pagination-bullet{
  background:var(--ash);opacity:.4;width:10px;height:10px;
}
.testimonials-swiper .swiper-pagination-bullet-active{background:var(--ember);opacity:1}
.testimonials-swiper .swiper-button-prev,
.testimonials-swiper .swiper-button-next{
  color:var(--ember);width:44px;height:44px;
  background:var(--white);border-radius:var(--r-full);
  box-shadow:var(--shadow-md);
}
.testimonials-swiper .swiper-button-prev::after,
.testimonials-swiper .swiper-button-next::after{font-size:16px;font-weight:700}

/* ========== GLASSMORPHISM ========== */
.glass-card{
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(12px) saturate(1.4);
  -webkit-backdrop-filter:blur(12px) saturate(1.4);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-xl);
}

/* ========== GSAP REVEAL HELPERS ========== */
.reveal-text{clip-path:inset(0 0 100% 0)}
.parallax-img{will-change:transform}
.split-line{overflow:hidden}
.split-line>span{display:inline-block;transform:translateY(100%)}

/* ========== ELEVATOR CONFIGURATOR ========== */
.configurator-section{
  padding:clamp(40px,6vw,80px) 0;
  background:var(--white);
  overflow:hidden;
}
.cfg-layout{
  display:grid;grid-template-columns:minmax(0,1fr) 460px;gap:32px;align-items:flex-start;
  width:100%;min-width:0;
}

/* LEFT: Form sections */
.cfg-form-wrap{display:flex;flex-direction:column;gap:20px}
.cfg-section{
  background:var(--white);border:1px solid rgba(0,0,0,.06);
  border-radius:var(--r-xl);padding:clamp(20px,3vw,32px);
  transition:border-color .3s var(--ease);
}
.cfg-section:hover{border-color:var(--forest)}
.cfg-section-header{
  display:flex;align-items:flex-start;gap:16px;margin-bottom:20px;
  padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,.06);
}
.cfg-number{
  width:44px;height:44px;border-radius:var(--r-md);
  background:var(--forest);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-heading);font-weight:900;font-size:var(--fs-md);flex-shrink:0;
}
.cfg-section-header h3{
  font-size:var(--fs-xl);color:var(--ink);margin:0 0 4px;letter-spacing:-.01em;
}
.cfg-section-header p{font-size:var(--fs-sm);color:var(--slate);margin:0;line-height:1.5}

/* Form fields */
.cfg-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.cfg-field:last-child{margin-bottom:0}
.cfg-field label{
  font-size:var(--fs-xs);font-weight:600;color:var(--ink);
  letter-spacing:.03em;text-transform:uppercase;
}
.cfg-select,.cfg-input{
  width:100%;padding:12px 16px;border:1.5px solid rgba(0,0,0,.1);
  border-radius:var(--r-md);font-size:var(--fs-base);color:var(--ink);
  background:var(--white);font-family:inherit;
  transition:all .2s var(--ease);
}
.cfg-select:focus,.cfg-input:focus{
  border-color:var(--forest);box-shadow:0 0 0 3px rgba(129,227,81,.1);outline:none;
}
.cfg-input-center{text-align:center;font-weight:700}
.cfg-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cfg-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* Stepper */
.cfg-stepper{display:flex;align-items:stretch;gap:0}
.cfg-step-btn{
  width:42px;background:var(--cream);border:1.5px solid rgba(0,0,0,.1);
  font-size:var(--fs-xl);font-weight:700;color:var(--ink);cursor:pointer;
  transition:all .2s var(--ease);
}
.cfg-step-btn:hover{background:var(--forest);color:var(--white);border-color:var(--forest)}
.cfg-step-btn:first-child{border-radius:var(--r-md) 0 0 var(--r-md);border-right:none}
.cfg-step-btn:last-child{border-radius:0 var(--r-md) var(--r-md) 0;border-left:none}
.cfg-stepper .cfg-input{border-radius:0}

/* Calculated result */
.cfg-calculated{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:16px;padding:16px 20px;border-radius:var(--r-md);
  background:rgba(129,227,81,.08);border:1.5px solid rgba(129,227,81,.2);
}
.cfg-calculated span{font-size:var(--fs-sm);font-weight:600;color:var(--forest)}
.cfg-calculated strong{
  font-family:var(--ff-heading);font-size:var(--fs-2xl);
  font-weight:900;color:var(--forest);
}

/* Field label with "?" help trigger */
.cfg-label-help{display:flex;align-items:center;gap:8px}
.cfg-help{
  width:18px;height:18px;flex:0 0 18px;border-radius:50%;
  border:1.5px solid var(--silver);background:#fff;color:var(--slate);
  font-size:11px;font-weight:700;line-height:1;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:all .2s;
}
.cfg-help:hover{border-color:var(--forest);color:var(--forest);background:rgba(129,227,81,.1)}

/* Metal construction checkbox */
.cfg-metal-check{
  display:flex;align-items:center;gap:10px;margin-top:16px;cursor:pointer;
  font-size:var(--fs-sm);font-weight:600;color:var(--ink);
}
.cfg-metal-check input{width:18px;height:18px;accent-color:var(--forest);cursor:pointer}

/* Building drawing file upload */
.cfg-file-upload{
  margin-top:20px;border:2px dashed var(--silver);border-radius:var(--r-md);
  padding:24px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;
  transition:border-color .2s;
}
.cfg-file-upload:hover{border-color:var(--forest)}
.cfg-file-upload svg{width:34px;height:34px;color:var(--forest);margin-bottom:4px}
.cfg-file-upload strong{font-size:var(--fs-md);color:var(--ink)}
.cfg-file-hint{font-size:var(--fs-xs);color:var(--slate)}
.cfg-file-btn{
  margin-top:8px;padding:9px 22px;border-radius:var(--r-full);cursor:pointer;
  background:var(--ink);color:#fff;font-weight:600;font-size:var(--fs-sm);
  border:none;transition:background .2s;
}
.cfg-file-btn:hover{background:var(--forest);color:var(--ink)}
.cfg-file-name{font-size:var(--fs-sm);color:var(--forest);font-weight:600;word-break:break-all}

/* Help modal */
.cfg-modal-overlay{
  position:fixed;inset:0;z-index:100000;background:rgba(20,20,22,.6);
  display:none;align-items:center;justify-content:center;padding:20px;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.cfg-modal-overlay.open{display:flex}
.cfg-modal{
  position:relative;background:#fff;border-radius:18px;max-width:460px;width:100%;
  padding:32px 28px 26px;box-shadow:0 24px 60px rgba(0,0,0,.3);
}
.cfg-modal-close{
  position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;
  border:none;background:var(--cream);color:var(--ink);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.cfg-modal-close:hover{background:var(--silver)}
.cfg-modal-body h3{font-size:var(--fs-lg);margin:0 0 12px;color:var(--ink);padding-right:30px}
.cfg-modal-body p{font-size:var(--fs-sm);line-height:1.65;color:var(--slate);margin:0}
.cfg-modal-illustration{background:#f4faf0;border:1px solid #dcecd1;border-radius:14px;padding:14px 12px;margin-bottom:18px}
.cfg-modal-illustration svg{width:100%;max-width:300px;height:auto;display:block;margin:0 auto}
.cfg-modal-ok{margin-top:22px;width:100%;justify-content:center}

/* Per-floor customization table */
.cfg-floor-toggle{display:inline-flex;align-items:center;gap:12px;margin-top:16px;padding:9px 9px 9px 20px;border-radius:var(--r-full);border:1.5px solid var(--silver);background:#fff;color:var(--ink);font-weight:600;font-size:var(--fs-sm);cursor:pointer;transition:all .2s}
.cfg-floor-toggle:hover,.cfg-floor-toggle.active{border-color:var(--ember)}
.cfg-floor-toggle-ico{width:28px;height:28px;border-radius:50%;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex:0 0 28px}
.cfg-floor-toggle-ico svg{width:15px;height:15px}
.cfg-floor-toggle.active .cfg-floor-toggle-ico{background:var(--ember);color:var(--ink)}
.cfg-floor-table-wrap{margin-top:16px;overflow-x:auto;border:1px solid var(--silver);border-radius:14px}
.cfg-floor-table{width:100%;border-collapse:collapse;min-width:560px}
.cfg-floor-table th{text-align:left;padding:12px 10px;font-size:var(--fs-xs);font-weight:700;color:var(--forest);border-bottom:1px solid var(--silver);white-space:nowrap}
.cfg-floor-table td{padding:8px 10px;border-bottom:1px solid #f0f0f0}
.cfg-floor-table tr:last-child td{border-bottom:none}
.cfg-floor-num{font-weight:700;color:var(--ink)}
.cfg-floor-input{width:100%;min-width:80px;border:1px solid var(--silver);border-radius:var(--r-full);padding:8px 12px;font:inherit;font-size:var(--fs-sm)}
.cfg-floor-input:focus{border-color:var(--ember);outline:none}
.cfg-blanka{display:inline-flex;align-items:center;gap:9px;margin-top:18px;color:var(--ember-dark);font-weight:700;font-size:var(--fs-sm)}
.cfg-blanka svg{width:20px;height:20px;flex-shrink:0}
.cfg-blanka:hover{color:var(--ink);text-decoration:underline}

/* Wall materials + cross-section diagram */
.cfg-wall-layout{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:880px){.cfg-wall-layout{grid-template-columns:1fr minmax(220px,.8fr);align-items:start}}
.cfg-wall-selects{display:flex;flex-direction:column;gap:16px}
.cfg-wall-diagram{background:var(--cream);border:1px solid #E4F0DC;border-radius:14px;padding:16px;display:flex;align-items:center;justify-content:center}
.cfg-wall-diagram svg{width:100%;max-width:300px;height:auto;display:block}

/* Door options */
.cfg-door-options{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.cfg-door-option{cursor:pointer}
.cfg-door-option input[type="radio"]{display:none}
.cfg-door-card{
  padding:16px 8px;border:2px solid rgba(0,0,0,.08);
  border-radius:var(--r-md);text-align:center;
  transition:all .25s var(--ease);
}
.cfg-door-card:hover{border-color:var(--forest)}
.cfg-door-option input:checked + .cfg-door-card{
  border-color:var(--forest);background:rgba(129,227,81,.06);
}
.cfg-door-icon{
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);margin-bottom:8px;
}
.cfg-door-option input:checked + .cfg-door-card .cfg-door-icon{color:var(--forest)}
.cfg-door-icon svg{width:48px;height:48px}
.cfg-door-icon img{width:52px;height:52px;object-fit:contain;display:block}
.cfg-door-card span{
  font-size:var(--fs-xs);font-weight:600;color:var(--ink);display:block;
}

/* Checkboxes */
.cfg-checks{display:flex;flex-direction:column;gap:8px}
.cfg-check{
  display:flex;align-items:flex-start;gap:14px;cursor:pointer;
  padding:14px;border:1.5px solid rgba(0,0,0,.08);border-radius:var(--r-md);
  transition:all .25s var(--ease);
}
.cfg-check:hover{border-color:var(--forest)}
.cfg-check input[type="checkbox"]{
  width:20px;height:20px;margin:0;accent-color:var(--forest);flex-shrink:0;
}
.cfg-check input[type="checkbox"]:disabled{opacity:.6}
.cfg-check-body{display:flex;flex-direction:column;gap:2px}
.cfg-check-body strong{font-size:var(--fs-base);color:var(--ink);font-weight:700}
.cfg-check-body span{font-size:var(--fs-sm);color:var(--slate);line-height:1.4}

/* RIGHT: Diagram */
.cfg-diagram-wrap{position:sticky;top:calc(var(--header-h) + var(--header-top-h) + 20px)}
.cfg-diagram-card{
  background:var(--white);border:1px solid rgba(0,0,0,.06);
  border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow-md);
}
.cfg-diagram-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.cfg-diagram-header h3{
  font-size:var(--fs-lg);color:var(--ink);margin:0;
}
.cfg-view-toggle{
  display:flex;gap:4px;padding:4px;background:var(--cream);border-radius:var(--r-full);
}
.cfg-view-btn{
  padding:6px 14px;border:none;background:transparent;
  font-size:var(--fs-xs);font-weight:600;color:var(--slate);
  border-radius:var(--r-full);cursor:pointer;transition:all .2s var(--ease);
}
.cfg-view-btn.active{background:var(--forest);color:var(--white)}
.cfg-diagram svg{width:100%;height:auto;display:block}
.cfg-diagram .wall{transition:fill .3s var(--ease),opacity .3s var(--ease)}

/* Summary */
.cfg-summary{
  margin-top:20px;padding-top:20px;border-top:1px solid rgba(0,0,0,.06);
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
.cfg-summary-item{
  display:flex;flex-direction:column;gap:2px;padding:10px 14px;
  background:var(--cream);border-radius:var(--r-md);
}
.cfg-summary-item span{
  font-size:var(--fs-xs);font-weight:600;color:var(--slate);
  text-transform:uppercase;letter-spacing:.04em;
}
.cfg-summary-item strong{font-size:var(--fs-base);color:var(--ink);font-weight:700}

/* Mobile preview toggle + close button */
.cfg-preview-toggle{display:none}
.cfg-diagram-close{display:none}

/* Desktop: schematic on the LEFT (sticky), form on the RIGHT — matches reference */
@media(min-width:1101px){
  .cfg-layout{grid-template-columns:minmax(0,520px) minmax(0,1fr);gap:40px}
  .cfg-diagram-wrap{grid-column:1;grid-row:1}
  .cfg-form-wrap{grid-column:2;grid-row:1}
}

@media(max-width:1100px){
  .cfg-layout{grid-template-columns:minmax(0,1fr);width:100%;max-width:100%;min-width:0}
  .cfg-form-wrap{order:1;width:100%;min-width:0;max-width:100%}

  /* ALL sections, fields, inputs — force within viewport */
  .cfg-section{width:100%;min-width:0;max-width:100%;padding:16px;box-sizing:border-box}
  .cfg-section-header{flex-wrap:wrap}
  .cfg-section-header p{font-size:.8125rem;word-break:break-word}
  .cfg-section-header h3{font-size:1rem}
  .cfg-field{width:100%;min-width:0;max-width:100%}
  .cfg-field label{word-break:break-word}
  .cfg-select,.cfg-input{width:100%;min-width:0;max-width:100%;box-sizing:border-box;font-size:.875rem;padding:10px 12px}
  .cfg-grid-2,.cfg-grid-3{grid-template-columns:minmax(0,1fr)!important;width:100%;min-width:0}
  .cfg-stepper{width:100%;min-width:0}
  .cfg-stepper .cfg-input{flex:1;min-width:0}
  .cfg-door-options{grid-template-columns:repeat(2,minmax(0,1fr));width:100%;min-width:0;gap:10px}
  .cfg-door-option,.cfg-door-card{min-width:0;width:100%;box-sizing:border-box}
  .cfg-door-card span{font-size:.75rem;word-break:break-word;text-align:center}
  .cfg-number{width:36px;height:36px;font-size:.875rem;flex-shrink:0}
  .cfg-calculated{flex-direction:column;gap:4px;text-align:center}
  .cfg-summary{grid-template-columns:repeat(2,minmax(0,1fr));min-width:0}
  .cfg-summary-item{min-width:0}
  .cfg-summary-item strong{word-break:break-word}
  .cfg-checks{width:100%;min-width:0}
  .cfg-check{padding:10px;min-width:0}
  .cfg-check-body{min-width:0;word-break:break-word}
  /* Page hero title tightening */
  .page-hero h1{word-break:break-word;hyphens:auto}

  /* Diagram as fullscreen modal */
  .cfg-diagram-wrap{
    order:2;position:fixed;top:0;left:0;right:0;bottom:0;
    z-index:99999;background:rgba(0,0,0,.6);
    display:none;padding:16px;overflow-y:auto;
  }
  .cfg-diagram-wrap.cfg-diagram-open{display:flex;align-items:flex-start;justify-content:center;padding-top:60px}
  .cfg-diagram-wrap.cfg-diagram-open .cfg-diagram-card{
    max-width:92vw;width:100%;max-height:85vh;overflow-y:auto;border-radius:16px;
  }
  .cfg-diagram-close{
    display:flex;position:fixed;top:12px;right:12px;z-index:100000;
    width:44px;height:44px;border-radius:50%;
    background:white;border:none;cursor:pointer;
    align-items:center;justify-content:center;
    box-shadow:0 2px 12px rgba(0,0,0,.3);
  }
  /* Configurator preview: sticky bottom-left pill so it stays clear of FAB stack */
  .cfg-preview-toggle{
    display:flex;align-items:center;justify-content:center;gap:8px;
    position:fixed;bottom:16px;left:12px;
    z-index:9998;padding:12px 18px;
    background:#81E351;color:white;border:none;border-radius:99px;
    font-size:.875rem;font-weight:700;cursor:pointer;
    box-shadow:0 6px 20px rgba(129,227,81,.45);
    max-width:calc(100vw - 120px);
  }
  .cfg-preview-toggle svg{width:16px;height:16px;flex-shrink:0}
  /* When configurator page open, bump FAB stack up slightly so phone/chat never overlap preview toggle */
  body:has(.cfg-preview-toggle) .floating-buttons{bottom:16px}
}

@media(max-width:480px){
  .cfg-door-options{grid-template-columns:minmax(0,1fr)}
  .cfg-door-card{padding:12px}
  .cfg-summary{grid-template-columns:minmax(0,1fr)}
  .cfg-section-header{gap:10px}
  .cfg-section-header h3{font-size:.95rem}
  .cfg-section-header p{font-size:.75rem}
}

/* ========== PRODUCT/SERVICE LANDING GRID ========== */
.products-landing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.product-landing-card{
  background:var(--white);border-radius:var(--r-xl);
  overflow:hidden;border:1px solid rgba(0,0,0,.06);
  transition:all .4s var(--ease);display:flex;flex-direction:column;
}
.product-landing-card:hover{
  transform:translateY(-6px);box-shadow:var(--shadow-xl);
  border-color:var(--forest);
}
.product-landing-img{overflow:hidden;height:220px}
.product-landing-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease);
}
.product-landing-card:hover .product-landing-img img{transform:scale(1.06)}
.product-landing-body{padding:28px;flex:1;display:flex;flex-direction:column}
.product-landing-icon{
  width:48px;height:48px;border-radius:var(--r-md);
  background:var(--ember-glow);color:var(--ember);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;transition:all .3s var(--ease);
}
.product-landing-icon svg{width:24px;height:24px}
.product-landing-card:hover .product-landing-icon{
  background:var(--forest);color:var(--white);
}
.product-landing-body h3{
  font-size:var(--fs-xl);margin-bottom:8px;color:var(--ink);
}
.product-landing-body p{
  font-size:var(--fs-base);color:var(--slate);line-height:1.7;flex:1;
}
@media(max-width:992px){.products-landing-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.products-landing-grid{grid-template-columns:1fr}}

/* ========== PARTNERS ========== */
.partners-section{padding:32px 0;background:var(--white);border-bottom:1px solid rgba(0,0,0,.05);overflow:hidden}
.partners-marquee{display:flex;gap:80px;animation:marquee 20s linear infinite;align-items:center}
.partners-marquee img{height:36px;opacity:.45;filter:grayscale(1);transition:all .4s var(--ease);flex-shrink:0}
.partners-marquee img:hover{opacity:1;filter:none}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ========== AI CHAT WIDGET ========== */
.chat-widget{
  position:fixed;bottom:90px;right:24px;z-index:9999;
  width:380px;max-height:520px;
  background:var(--white);border-radius:var(--r-xl);
  box-shadow:0 20px 60px rgba(0,0,0,.18);
  border:1px solid rgba(0,0,0,.08);
  display:flex;flex-direction:column;
  transform:translateY(20px) scale(.95);opacity:0;
  visibility:hidden;pointer-events:none;
  transition:all .35s var(--ease);
}
.chat-widget.open{
  transform:translateY(0) scale(1);opacity:1;
  visibility:visible;pointer-events:auto;
}
.chat-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;background:var(--forest);color:var(--white);
  border-radius:var(--r-xl) var(--r-xl) 0 0;flex-shrink:0;
}
.chat-header-info{display:flex;align-items:center;gap:12px}
.chat-avatar{
  width:40px;height:40px;border-radius:var(--r-full);
  background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;
}
.chat-avatar svg{width:22px;height:22px;color:var(--white)}
.chat-header-text h4{font-size:var(--fs-sm);margin:0;font-weight:700;color:var(--white)}
.chat-header-text span{font-size:var(--fs-xs);opacity:.8}
.chat-close{
  background:none;border:none;color:var(--white);cursor:pointer;
  width:32px;height:32px;border-radius:var(--r-full);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.chat-close:hover{background:rgba(255,255,255,.15)}
.chat-close svg{width:18px;height:18px}
.chat-messages{
  flex:1;overflow-y:auto;padding:16px 20px;
  display:flex;flex-direction:column;gap:12px;
  min-height:280px;max-height:340px;
  scroll-behavior:smooth;
}
.chat-msg{
  max-width:85%;padding:12px 16px;border-radius:var(--r-lg);
  font-size:var(--fs-sm);line-height:1.6;
  animation:chatFade .3s var(--ease);
}
@keyframes chatFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.chat-msg.bot{
  background:var(--cream);color:var(--ink);
  align-self:flex-start;border-bottom-left-radius:4px;
}
.chat-msg.user{
  background:var(--forest);color:var(--white);
  align-self:flex-end;border-bottom-right-radius:4px;
}
.chat-msg.typing{
  background:var(--cream);align-self:flex-start;
  border-bottom-left-radius:4px;
}
.typing-dots{display:flex;gap:4px;padding:4px 0}
.typing-dots span{
  width:7px;height:7px;border-radius:50%;background:var(--ash);
  animation:typingBounce 1.4s infinite;
}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}
.chat-input-area{
  display:flex;gap:8px;padding:12px 16px;
  border-top:1px solid rgba(0,0,0,.06);flex-shrink:0;
}
.chat-input{
  flex:1;padding:10px 14px;border:1px solid rgba(0,0,0,.1);
  border-radius:var(--r-full);font-size:var(--fs-sm);
  color:var(--ink);background:var(--white);
  transition:border-color .2s;
}
.chat-input:focus{border-color:var(--forest);outline:none}
.chat-input::placeholder{color:var(--ash)}
.chat-send{
  width:40px;height:40px;border-radius:var(--r-full);
  background:var(--forest);color:var(--white);border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .2s var(--ease);flex-shrink:0;
}
.chat-send:hover{background:var(--forest-light);transform:scale(1.05)}
.chat-send:disabled{opacity:.5;cursor:not-allowed;transform:none}
.chat-send svg{width:18px;height:18px}

/* Chat trigger button */
.float-btn-chat{
  background:var(--forest);position:relative;
}
.float-btn-chat .chat-badge{
  position:absolute;top:-4px;right:-4px;
  width:14px;height:14px;border-radius:50%;
  background:#6BC93F;border:2px solid var(--white);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(91,181,46,.4)}70%{box-shadow:0 0 0 8px rgba(91,181,46,0)}}

@media(max-width:480px){
  .chat-widget{width:calc(100vw - 32px);right:16px;bottom:80px;max-height:70vh}
}

/* ========== RESPONSIVE ========== */
@media(max-width:1200px){
  .bento-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:repeat(2,1fr)}
  .why-us-grid{grid-template-columns:repeat(3,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:992px){
  .top-bar{display:none!important;pointer-events:none!important;height:0!important;overflow:hidden!important}
  .site-header{top:0}
  .hero-content{padding:calc(var(--header-h) + 60px) 0 60px}
  .breadcrumb{margin-top:var(--header-h)}
  .top-bar+.site-header+.breadcrumb{margin-top:var(--header-h)}
  .page-hero{padding:clamp(100px,14vw,160px) 0 clamp(60px,8vw,100px)}
  .counter-grid{grid-template-columns:repeat(2,1fr)}
  .bento-grid{grid-template-columns:repeat(2,1fr)}
  .bento-card{height:320px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-card{border-right:none;border-bottom:1px solid rgba(0,0,0,.06)}
  .about-grid{grid-template-columns:1fr;gap:var(--sp-2xl)}
  .contact-grid{grid-template-columns:1fr}
  .product-detail-grid{grid-template-columns:1fr}
  .service-page-grid{grid-template-columns:1fr}
  .sidebar-menu{display:none}
  .safety-grid{grid-template-columns:repeat(2,1fr)}
  .cta-inner{flex-direction:column;text-align:center;align-items:center}

  .site-header{
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
  }
  .main-nav{display:none!important}
  .main-nav.active{
    display:block!important;
    position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
    background:var(--white);padding:24px;overflow-y:auto;z-index:9999;
  }
  @keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
  .main-nav.active>ul{
    display:flex!important;
    flex-direction:column!important;
    width:100%!important;
    gap:0!important;
    list-style:none!important;
    margin:0!important;
    padding:0!important;
  }
  .main-nav.active>ul>li{
    display:block!important;
    width:100%!important;
  }
  .main-nav.active>ul>li.nav-configurator{
    display:block!important;
  }
  .main-nav.active>ul>li.nav-mobile-only{
    display:block!important;
  }
  .main-nav.active>ul>li>a{
    display:block!important;
    padding:16px 0!important;
    font-size:1.125rem!important;
    font-weight:600!important;
    color:#111827!important;
    border-bottom:1px solid #E5E7EB!important;
    border-radius:0!important;
    text-decoration:none!important;
  }
  .main-nav.active>ul>li>a:hover{
    color:#81E351!important;
  }
  .main-nav.active>ul>li.nav-configurator>a{
    display:inline-block!important;
    margin-top:16px!important;
    padding:14px 32px!important;
    background:#81E351!important;
    color:#fff!important;
    border-radius:12px!important;
    border-bottom:none!important;
    text-align:center!important;
    font-size:1.125rem!important;
    font-weight:700!important;
  }
  .main-nav .dropdown{
    position:static!important;left:auto!important;right:auto!important;top:auto!important;transform:none!important;
    opacity:1!important;visibility:visible!important;pointer-events:auto!important;
    box-shadow:none;border:none;padding:0 0 0 16px;min-width:auto;display:none;border-radius:0;
  }
  /* show only when explicitly opened (kills sticky :hover open on touch) */
  .main-nav .has-dropdown:not(.open) .dropdown{display:none!important}
  .main-nav.active .has-dropdown.open .dropdown{display:block!important}
  .menu-toggle{
    display:flex!important;
    background:rgba(255,255,255,.15)!important;
    border:2px solid rgba(255,255,255,.4)!important;
    min-width:48px;
    min-height:48px;
    position:relative!important;
    z-index:99999!important;
    pointer-events:auto!important;
    cursor:pointer!important;
  }
  .menu-toggle span{
    pointer-events:none;
  }
  .header-actions{
    position:relative;
    z-index:99999;
  }
  .header-phone{display:none}
  .header-job{display:none}
  /* "Заявете оферта" CTA moves out of the header into the mobile nav menu */
  .header-cta{display:none!important}
  .main-nav.active>ul>li.nav-mobile-cta>a{
    display:inline-block!important;
    margin-top:16px!important;
    padding:14px 32px!important;
    background:#81E351!important;
    color:#fff!important;
    border-radius:12px!important;
    border-bottom:none!important;
    text-align:center!important;
    font-size:1.125rem!important;
    font-weight:700!important;
  }
  .header-user{width:38px;height:38px;flex-basis:38px}
  .header-user svg{width:18px;height:18px}
  .header-actions{gap:8px}
}
@media(max-width:768px){
  .hero{min-height:90vh}
  .hero-stats{flex-wrap:wrap;gap:24px}
  .counter-grid{grid-template-columns:repeat(2,1fr)}
  .header-cta{padding:7px 12px;font-size:var(--fs-xs)}
  .hero-buttons{flex-direction:column;width:100%}
  .hero-buttons .btn{width:100%;justify-content:center}
  .bento-grid{grid-template-columns:1fr}
  .bento-card{height:300px}
  .services-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .shop-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .newsletter-form{flex-direction:column}
  .newsletter-form button{width:100%}
  .form-row{grid-template-columns:1fr}
  .parking-types{grid-template-columns:1fr}
  .why-us-grid{grid-template-columns:repeat(2,1fr)}
  .page-hero--with-image .page-hero-image{display:none}
  .page-hero{text-align:center}
  .page-hero p{margin-left:auto;margin-right:auto}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .counter-grid{grid-template-columns:1fr}
  .shop-grid{grid-template-columns:1fr}
  .why-us-grid{grid-template-columns:1fr}
  .safety-grid{grid-template-columns:1fr}
  .hero-visual{display:none!important}
  .header-cta{padding:6px 12px;font-size:.6875rem}
  .site-logo img{height:36px}
  .header-inner{padding:0 12px}
  .menu-toggle{
    width:44px!important;height:44px!important;
    display:flex!important;
    background:rgba(255,255,255,.15)!important;
    border:2px solid rgba(255,255,255,.4)!important;
    position:relative!important;
    z-index:99999!important;
    pointer-events:auto!important;
  }
}

/* ============================================================
   ACCOUNTS / AUTH + JOBS (Работа) module
   ============================================================ */
.auth-section{padding:clamp(40px,6vw,72px) 0;background:#fff}
.auth-card{max-width:780px;margin:0 auto;background:var(--cream);border:1px solid #E4F0DC;border-radius:22px;padding:clamp(24px,4vw,40px)}
.auth-switch{color:var(--slate);font-size:var(--fs-sm);margin:0 0 22px}
.auth-switch a{color:var(--ember-dark);font-weight:700}
/* Switcher tabs */
.auth-switcher{max-width:780px;margin:0 auto 18px;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.auth-tab{display:flex;align-items:center;gap:12px;justify-content:flex-start;padding:16px 20px;border-radius:14px;background:var(--cream);border:1px solid #E4F0DC;font-weight:600;color:var(--slate);cursor:pointer;transition:all .2s}
.auth-tab .auth-tab-box{width:22px;height:22px;border-radius:6px;background:var(--ember);flex:0 0 22px;transition:all .2s}
.auth-tab.active{background:var(--ember);color:var(--ink)}
.auth-tab.active .auth-tab-box{background:#fff}
@media(max-width:560px){.auth-switcher{grid-template-columns:1fr}}
/* Form fields (pill inputs) */
.auth-form{display:flex;flex-direction:column;gap:16px}
.auth-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.auth-grid-2{grid-template-columns:1fr}}
.auth-field{position:relative}
.auth-field input,.auth-field select,.auth-field textarea{
  width:100%;background:#fff;border:1px solid var(--silver);border-radius:var(--r-full);
  padding:15px 22px;font:inherit;font-size:var(--fs-sm);color:var(--ink);transition:border-color .2s;
}
.auth-field textarea{border-radius:18px;resize:vertical;min-height:110px}
.auth-field input:focus,.auth-field select:focus,.auth-field textarea:focus{border-color:var(--ember);outline:none}
.auth-field input::placeholder,.auth-field textarea::placeholder{color:#9aa39a}
.auth-field--pwd input{padding-right:52px}
.auth-eye{position:absolute;right:16px;top:50%;transform:translateY(-50%);width:24px;height:24px;color:var(--slate);background:none;border:none;cursor:pointer}
.auth-eye svg{width:22px;height:22px}
.auth-hint{margin:-8px 0 0 8px;font-size:var(--fs-xs);color:var(--slate)}
.auth-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.auth-check{display:flex;align-items:center;gap:8px;font-size:var(--fs-sm);color:var(--slate);cursor:pointer}
.auth-check input{width:16px;height:16px;accent-color:var(--ember)}
.auth-check a{color:var(--ember-dark);font-weight:700}
.auth-forgot{color:var(--slate);font-size:var(--fs-sm)}
.auth-forgot:hover{color:var(--ember-dark)}
.auth-form .btn{align-self:flex-start;margin-top:4px}
.auth-msg{font-size:var(--fs-sm);font-weight:600}
.auth-msg--err{color:#C0392B}
.auth-msg--ok{color:var(--ember-dark)}
/* File upload card */
.auth-upload{border:1px solid #E4F0DC;background:#fff;border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:6px}
.auth-upload--inline{border-style:dashed}
.auth-upload strong{color:var(--ink);font-size:var(--fs-md)}
.auth-upload strong::after,.auth-upload-hint{color:var(--slate)}
.auth-upload-hint{font-size:var(--fs-xs);color:#C0392B;opacity:.85}
.auth-upload-btn{align-self:flex-start;margin-top:10px;display:inline-flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--ember);color:var(--ink);font-weight:600;border-radius:var(--r-full);padding:9px 9px 9px 22px;cursor:pointer;font-size:var(--fs-sm)}
.auth-upload-ico{width:26px;height:26px;border-radius:50%;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1}
.auth-upload-btn:hover{background:var(--ember)}
.auth-file-names{font-size:var(--fs-xs);color:var(--ember-dark);font-weight:600;word-break:break-all;margin-top:6px}

/* Profile */
.profile-head{max-width:900px;margin:0 auto 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.profile-head h2{margin:0;font-size:var(--fs-2xl)}
.profile-role{margin:4px 0 0;color:var(--slate);font-size:var(--fs-sm)}
.profile-section{max-width:900px;margin:0 auto 22px;background:var(--cream);border:1px solid #E4F0DC;border-radius:18px;padding:24px}
.profile-section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.profile-section-head h3{margin:0;font-size:var(--fs-lg)}
.profile-empty{color:var(--slate);font-size:var(--fs-sm)}
.profile-list{display:flex;flex-direction:column;gap:8px}
.profile-row{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#fff;border:1px solid var(--silver);border-radius:12px;padding:12px 16px}
.profile-tag{margin-left:10px;font-size:var(--fs-xs);background:var(--ember-soft);color:var(--ember-dark);padding:3px 10px;border-radius:var(--r-full);font-weight:600}
.profile-date{color:var(--slate);font-size:var(--fs-xs)}

/* Jobs */
.jobs-section{padding:clamp(36px,5vw,64px) 0;background:#fff}
.jobs-cats{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.jobs-cat{padding:9px 20px;border-radius:var(--r-full);background:var(--cream);border:1px solid var(--silver);color:var(--slate);font-weight:600;font-size:var(--fs-sm);transition:all .2s}
.jobs-cat:hover{border-color:var(--ember)}
.jobs-cat.active{background:var(--ember);color:var(--ink);border-color:var(--ember)}
.jobs-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:26px}
.jobs-filter{display:flex;align-items:center;gap:12px}
.jobs-filter label{font-weight:700;color:var(--ink)}
.jobs-filter select{background:#fff;border:1px solid var(--silver);border-radius:var(--r-full);padding:11px 20px;font:inherit;font-size:var(--fs-sm);min-width:200px}
.jobs-empty{color:var(--ink);font-size:var(--fs-xl);padding:20px 0}
.jobs-locked{max-width:560px;margin:10px auto;text-align:center;background:var(--cream);border:1px solid #E4F0DC;border-radius:20px;padding:clamp(28px,5vw,48px)}
.jobs-locked svg{width:54px;height:54px;color:var(--ember-dark);margin-bottom:8px}
.jobs-locked h3{margin:0 0 10px;font-size:var(--fs-xl);color:var(--ink)}
.jobs-locked p{margin:0 0 22px;color:var(--slate);font-size:var(--fs-sm);line-height:1.6}
.jobs-locked-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.job-card{background:var(--cream);border:1px solid #E4F0DC;border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:10px}
.job-cat-badge{align-self:flex-start;background:var(--ember-soft);color:var(--ember-dark);font-weight:700;font-size:var(--fs-xs);padding:4px 12px;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.03em}
.job-title{margin:2px 0 0;font-size:var(--fs-lg);color:var(--ink)}
.job-meta{display:flex;flex-wrap:wrap;gap:14px;color:var(--slate);font-size:var(--fs-sm)}
.job-meta span{display:inline-flex;align-items:center;gap:6px}
.job-meta svg{width:16px;height:16px;color:var(--ember-dark)}
.job-desc{color:var(--slate);font-size:var(--fs-sm);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.job-files{display:inline-flex;align-items:center;gap:6px;color:var(--ember-dark);font-size:var(--fs-xs);font-weight:600}
.job-files svg{width:14px;height:14px}
.job-card-foot{margin-top:auto;padding-top:8px}
/* Jobs FAQ */
.jobs-faq{padding:clamp(36px,5vw,64px) 0;background:var(--cream)}
.jobs-faq h2{text-align:center;font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:28px}
.jobs-faq .faq-item{max-width:900px;margin:0 auto 12px;background:#fff;border:1px solid var(--silver);border-radius:14px;padding:18px 22px}
.jobs-faq summary{font-weight:700;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.jobs-faq summary::after{content:"⌄";color:var(--ember-dark);font-size:20px}
.jobs-faq .faq-item p{margin:12px 0 0;color:var(--slate);font-size:var(--fs-sm);line-height:1.6}
/* Jobs modals */
.jobs-modal-overlay{position:fixed;inset:0;z-index:100000;background:rgba(20,20,22,.6);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.jobs-modal-overlay.open{display:flex}
.jobs-modal{position:relative;background:var(--cream);border-radius:20px;max-width:620px;width:100%;padding:40px 32px 32px;box-shadow:0 24px 60px rgba(0,0,0,.3)}
.jobs-modal--sm{max-width:460px}
.jobs-modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:#fff;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center}
.jobs-modal-close:hover{background:var(--silver)}
.jobs-modal-title{margin:0 0 4px;font-size:var(--fs-lg);color:var(--ink)}
.jobs-modal-sub{margin:0 0 16px;color:var(--ember-dark);font-weight:600;font-size:var(--fs-sm)}
.btn--ghost-hint{opacity:.92}

/* Contacts — Google Map */
.contact-map-section{padding:0 0 clamp(48px,7vw,90px);background:#fff}
.contact-map{border-radius:20px;overflow:hidden;border:1px solid var(--silver);line-height:0;box-shadow:0 8px 30px rgba(0,0,0,.06)}
.contact-map iframe{width:100%;height:clamp(320px,42vw,480px);border:0;display:block;filter:grayscale(.1)}

/* ===== За нас — services card grid ===== */
.about-services{background:var(--cream)}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:clamp(28px,4vw,46px)}
@media(max-width:1100px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}
.svc-card{display:flex;flex-direction:column;background:#fff;border:1px solid #E8EDE6;border-radius:20px;overflow:hidden;color:var(--ink);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 22px 50px rgba(43,43,43,.13)}
.svc-card-img{position:relative;height:190px;overflow:hidden}
.svc-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s var(--ease)}
.svc-card:hover .svc-card-img img{transform:scale(1.07)}
.svc-card-num{position:absolute;top:14px;left:14px;width:42px;height:42px;border-radius:50%;background:var(--ember);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--ff-heading);font-weight:800;font-size:1rem;box-shadow:0 6px 16px rgba(0,0,0,.18)}
.svc-card-body{padding:22px;display:flex;flex-direction:column;flex:1}
.svc-card-body h3{margin:0 0 10px;font-size:var(--fs-lg);color:var(--ink);line-height:1.25}
.svc-card-body p{margin:0 0 18px;color:var(--slate);font-size:var(--fs-sm);line-height:1.65;flex:1}
.svc-card-link{display:inline-flex;align-items:center;gap:8px;color:var(--ember-dark);font-weight:700;font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.03em;margin-top:auto}
.svc-card-link svg{width:18px;height:18px;transition:transform .25s var(--ease)}
.svc-card:hover .svc-card-link svg{transform:translateX(5px)}

/* ===== За нас — mission / quote / partners (matches reference 2nd section) ===== */
.about-intro{background:#fff}
.about-quote{font-size:clamp(1rem,1.5vw,1.2rem);line-height:1.75;color:var(--ink);margin:0 0 18px}
.about-quote .text-green{color:var(--ember-dark);font-weight:700}
.about-quote-name{margin:0;font-weight:700;color:var(--ink);font-size:var(--fs-md)}
.about-quote-role{margin:2px 0 0;color:var(--ember-dark);font-weight:700}
.about-partners{display:flex;align-items:center;justify-content:center;gap:clamp(28px,5vw,64px);flex-wrap:wrap;
  margin:clamp(28px,4vw,44px) 0;padding-bottom:clamp(28px,4vw,44px);border-bottom:1px solid var(--silver)}
.about-partners img{height:clamp(40px,4vw,54px);width:auto;opacity:.92}
