@charset "UTF-8";
/* ==========================================================================
   VYČISTÍM KLÍMU — ALPINE PURITY DESIGN SYSTEM
   Based on Stitch "Glacier Pure" — deep navy, ice white, fresh teal.
   Typography: Inter. Shape: soft, generous radii. Depth: tonal layering.
   ========================================================================== */

/* ===== DESIGN TOKENS ===== */
:root{
  /* Alpine Purity palette */
  --primary:#00324c;
  --primary-container:#1f4965;
  --primary-deep:#001e30;
  --on-primary:#ffffff;
  --on-primary-container:#90b7d8;
  --accent:#2addcd;
  --accent-strong:#00c8b9;
  --accent-deep:#003531;
  --accent-fixed:#57fae9;

  /* Surface hierarchy (no-line rule) */
  --surface:#f6fafb;
  --surface-dim:#d6dbdc;
  --surface-bright:#f6fafb;
  --surface-container-lowest:#ffffff;
  --surface-container-low:#f0f4f5;
  --surface-container:#eaeff0;
  --surface-container-high:#e5e9ea;
  --surface-container-highest:#dfe3e4;

  /* Text */
  --on-surface:#181c1d;
  --on-surface-variant:#40484c;
  --outline:#71787d;
  --outline-variant:#c0c7cd;

  /* State / accent tints */
  --primary-tint-8:rgba(0,50,76,0.08);
  --primary-tint-6:rgba(0,50,76,0.06);
  --primary-tint-4:rgba(0,50,76,0.04);
  --primary-tint-10:rgba(0,50,76,0.10);
  --accent-tint-10:rgba(42,221,205,0.10);
  --accent-tint-20:rgba(42,221,205,0.20);

  /* Ambient shadow (tinted with primary, not black) */
  --shadow-sm:0 4px 16px rgba(0,50,76,0.04);
  --shadow-md:0 12px 32px rgba(0,50,76,0.06);
  --shadow-lg:0 24px 60px rgba(0,50,76,0.08);
  --shadow-xl:0 32px 80px rgba(0,50,76,0.10);

  /* ----- Backward-compatible aliases (keep existing class names working) ----- */
  --bg:var(--surface);
  --bg2:var(--surface-container-lowest);
  --bg3:var(--surface-container);
  --brd:var(--primary-tint-8);
  --sil:#717883;
  --slt:var(--on-surface-variant);
  --ink:var(--on-surface);
  --wht:var(--primary);
  --bl:var(--primary);
  --bl2:var(--primary-container);
  --bls:var(--primary-tint-6);
  --bld:var(--primary-deep);
}

/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--surface);
  color:var(--on-surface);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:'cv11','ss01','ss03';
  letter-spacing:-0.01em;
}
a{text-decoration:none;color:inherit}
::selection{background:var(--accent);color:var(--primary)}

/* ===== NAV (glassmorphism, fixed top) ===== */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.1rem 3rem;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(246,250,251,0.78);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  transition:padding .35s ease, box-shadow .35s ease, background .35s ease;
}
nav.scrolled{padding:.75rem 3rem;box-shadow:0 10px 30px -15px rgba(0,50,76,0.12);background:rgba(246,250,251,0.92)}
.nav-logo{display:flex;align-items:center;gap:.6rem}
.nav-logo span{white-space:nowrap}
.nav-links{display:flex;gap:2.2rem;list-style:none}
.nav-links a{
  color:var(--on-surface-variant);font-size:.78rem;font-weight:700;
  letter-spacing:0.06em;text-transform:uppercase;
  transition:color .4s cubic-bezier(0.2,0.8,0.2,1);
  position:relative;
}
.nav-links a:hover{color:var(--accent-strong)}
.nav-cta{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%) !important;
  color:#fff !important;
  padding:.6rem 1.3rem !important;
  border-radius:0.75rem;
  font-weight:700 !important;
  letter-spacing:0.03em !important;
  text-transform:uppercase;
  font-size:.75rem !important;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1) !important;
  box-shadow:0 8px 20px -8px rgba(0,50,76,0.35);
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(0,50,76,0.5);color:#fff !important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{width:22px;height:2px;background:var(--primary);border-radius:2px;transition:.3s}

/* ===== SHARED ===== */
section{padding:6.5rem 3rem}

.slbl{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.72rem;font-weight:800;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent-strong);margin-bottom:1rem;
}
.slbl::before{content:'';width:28px;height:2px;background:var(--accent);border-radius:2px}

.stl{
  font-family:'Inter',sans-serif;
  font-size:clamp(2.1rem,4vw,3.3rem);
  font-weight:800;
  line-height:1.05;
  max-width:720px;
  color:var(--primary);
  letter-spacing:-0.03em;
}
.sdsc{
  margin-top:1.25rem;
  color:var(--on-surface-variant);
  font-size:1.05rem;
  line-height:1.65;
  max-width:560px;
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.95rem 1.8rem;border-radius:0.75rem;
  font-family:'Inter',sans-serif;font-weight:700;font-size:.88rem;
  letter-spacing:0.02em;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  border:none;cursor:pointer;
}
.btn-p{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  color:#fff;
  box-shadow:0 10px 28px -12px rgba(0,50,76,0.5);
}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(0,50,76,0.6);color:#fff}
.btn-o{background:var(--surface-container-highest);color:var(--primary);border:none}
.btn-o:hover{background:var(--surface-container-high);transform:translateY(-2px);box-shadow:var(--shadow-sm);color:var(--primary)}
.btn-wa{background:#25d366;color:#fff;box-shadow:0 10px 28px -12px rgba(37,211,102,0.5)}
.btn-wa:hover{background:#1fb855;transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(37,211,102,0.6);color:#fff}
.btn-acc{
  background:var(--accent);
  color:var(--primary);
  box-shadow:0 12px 30px -10px rgba(42,221,205,0.55);
}
.btn-acc:hover{background:var(--accent-strong);color:var(--primary);transform:translateY(-2px);box-shadow:0 18px 44px -12px rgba(0,200,185,0.6)}

/* ===== HERO (index) — Asymmetric glass composition ===== */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding:9rem 3rem 5rem;
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--surface) 0%,#e8eff7 45%,var(--surface) 100%);
}
.hero::before{
  content:'';position:absolute;top:-25%;right:-10%;
  width:780px;height:780px;
  background:radial-gradient(circle,rgba(42,221,205,0.14) 0%,transparent 65%);
  pointer-events:none;
  animation:blobDrift1 18s ease-in-out infinite;
  will-change:transform;
}
.hero::after{
  content:'';position:absolute;bottom:-15%;left:-8%;
  width:560px;height:560px;
  background:radial-gradient(circle,rgba(0,50,76,0.08) 0%,transparent 70%);
  pointer-events:none;
  animation:blobDrift2 22s ease-in-out infinite;
  will-change:transform;
}
@keyframes blobDrift1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-40px,30px) scale(1.1)}66%{transform:translate(30px,-20px) scale(.95)}}
@keyframes blobDrift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(50px,-30px) scale(1.15)}}
.hero-badge{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem 1.1rem .5rem .6rem;
  background:rgba(255,255,255,0.7);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:100px;
  font-size:.75rem;font-weight:600;color:var(--primary);
  letter-spacing:0.02em;
  margin-bottom:2rem;width:fit-content;
  opacity:0;transform:translateY(20px);animation:fu .8s .1s cubic-bezier(0.2,0.8,0.2,1) forwards;
  box-shadow:0 6px 20px -10px rgba(0,50,76,0.15);
}
.hero-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-strong);display:inline-block;animation:pulse 2s infinite;box-shadow:0 0 12px rgba(0,200,185,0.6)}
.hero h1{
  font-family:'Inter',sans-serif;
  font-size:clamp(2.8rem,6vw,5.2rem);
  font-weight:900;line-height:0.98;
  max-width:880px;
  color:var(--primary);
  letter-spacing:-0.04em;
  opacity:0;transform:translateY(24px);
  animation:fu .9s .2s cubic-bezier(0.2,0.8,0.2,1) forwards;
}
.hero h1 .blue{color:var(--accent-strong)}
.hero-sub{
  margin-top:1.75rem;
  font-size:1.15rem;color:var(--on-surface-variant);
  max-width:580px;line-height:1.65;
  opacity:0;transform:translateY(16px);animation:fu .9s .4s cubic-bezier(0.2,0.8,0.2,1) forwards;
}
.hero-btns{
  display:flex;gap:.85rem;margin-top:2.75rem;
  opacity:0;transform:translateY(16px);animation:fu .9s .5s cubic-bezier(0.2,0.8,0.2,1) forwards;
}
.hero-stats{
  display:flex;gap:3.5rem;margin-top:4rem;
  opacity:0;transform:translateY(16px);animation:fu .9s .6s cubic-bezier(0.2,0.8,0.2,1) forwards;
}
.hero-stat h3{
  font-family:'Inter',sans-serif;
  font-size:2.6rem;font-weight:900;
  color:var(--primary);letter-spacing:-0.03em;line-height:1;
}
.hero-stat p{
  font-size:.72rem;color:var(--on-surface-variant);
  font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  margin-top:.5rem;
}
.scroll-ind{
  position:absolute;bottom:2.5rem;left:3rem;
  display:flex;align-items:center;gap:.75rem;
  opacity:0;animation:fu .9s .8s forwards;
}
.scroll-line{width:36px;height:2px;background:var(--primary-tint-10);border-radius:2px;position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--accent-strong);border-radius:2px;animation:sp 2.5s infinite}
.scroll-text{font-size:.7rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--on-surface-variant);font-weight:700}

/* ===== TRUST BAR (navy section with 4 stats) ===== */
.trust-bar{
  background:var(--primary);
  color:#fff;
  padding:4rem 3rem;
  position:relative;overflow:hidden;
}
.trust-bar::before{
  content:'';position:absolute;top:-50%;right:-10%;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(42,221,205,0.12) 0%,transparent 70%);
  pointer-events:none;
}
.trust-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  position:relative;z-index:2;
}
.trust-item{text-align:center;padding:0 1rem;position:relative}
.trust-item:not(:first-child)::before{
  content:'';position:absolute;left:0;top:15%;bottom:15%;width:1px;
  background:rgba(255,255,255,0.1);
}
.trust-num{
  font-family:'Inter',sans-serif;
  font-size:2.8rem;font-weight:900;
  color:var(--accent);letter-spacing:-0.03em;line-height:1;
}
.trust-lbl{
  color:var(--on-primary-container);
  font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.14em;
  margin-top:.6rem;
}

/* ===== SLUZBY (services grid) ===== */
#sluzby{background:var(--surface-container-lowest)}
.cg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}
.cc{
  background:var(--surface-container-low);
  border-radius:1.75rem;
  padding:2.5rem 2rem;
  transition:all .45s cubic-bezier(0.2,0.8,0.2,1);
  position:relative;overflow:hidden;
}
.cc:hover{
  background:#fff;
  transform:translateY(-6px) scale(1.015);
  box-shadow:var(--shadow-lg);
}
.cc.pop{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  color:#fff;
  box-shadow:0 24px 60px -20px rgba(0,50,76,0.45);
}
.cc.pop::before{
  content:'Najob\00013E\0000FAbenej\000161ie';
  position:absolute;top:1.5rem;right:1.5rem;
  background:var(--accent);color:var(--primary);
  padding:.35rem .8rem;border-radius:0.5rem;
  font-size:.66rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;
}
.cc.pop h3,.cc.pop p,.cc.pop .cft li{color:#fff}
.cc.pop .cft li::before{color:var(--accent)}
.cc.pop .ci{background:rgba(255,255,255,0.1)}
.cc.pop .ci svg{color:var(--accent) !important}
.cc.pop .cprice{color:#fff}
.cc.pop .cprice small{color:var(--on-primary-container)}
.cc.pop .ctag{background:var(--accent);color:var(--primary)}
.ci{
  width:54px;height:54px;border-radius:1rem;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin-bottom:1.5rem;
  background:var(--primary-tint-6);
}
.ctag{
  display:inline-block;padding:.3rem .75rem;border-radius:100px;
  font-size:.66rem;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;
  margin-bottom:1rem;background:var(--accent-tint-10);color:var(--accent-strong);
}
.cc h3{
  font-family:'Inter',sans-serif;
  font-size:1.35rem;font-weight:800;
  margin-bottom:.5rem;color:var(--primary);
  letter-spacing:-0.02em;
}
.cprice{
  font-family:'Inter',sans-serif;
  font-size:2.6rem;font-weight:900;
  color:var(--primary);margin:1rem 0;letter-spacing:-0.03em;line-height:1;
}
.cprice small{font-size:.85rem;color:var(--on-surface-variant);font-weight:500;letter-spacing:0}
.cprice-old{font-size:1.4rem;font-weight:600;color:rgba(0,50,76,.45);text-decoration:line-through;text-decoration-color:#ff5e3a;text-decoration-thickness:3px;margin-right:.4rem;letter-spacing:0;display:inline-block;vertical-align:.45rem}
.cc.pop .cprice-old{color:rgba(255,255,255,.55);text-decoration-color:#ff8f6b}
.csale{position:absolute;top:14px;right:14px;background:linear-gradient(135deg,#ff5e3a 0%,#ff2a68 100%);color:#fff;padding:5px 11px;border-radius:6px;font-size:.7rem;font-weight:800;letter-spacing:.06em;box-shadow:0 4px 12px rgba(255,94,58,.4);z-index:2;animation:csaleBob 2.4s ease-in-out infinite;text-transform:uppercase;white-space:nowrap}
.csale-multi{background:linear-gradient(135deg,#2addcd 0%,#1ab8a8 100%);color:#00324c;box-shadow:0 4px 12px rgba(42,221,205,.45)}
@keyframes csaleBob{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-3px) rotate(-2deg)}
}
.cc{position:relative}
.cc p{color:var(--on-surface-variant);font-size:.92rem;line-height:1.65}
.cft{list-style:none;margin:1.5rem 0 1.75rem;display:flex;flex-direction:column;gap:.7rem}
.cft li{display:flex;align-items:center;gap:.7rem;font-size:.9rem;color:var(--on-surface-variant);font-weight:500}
.cft li::before{content:'\2713';color:var(--accent-strong);font-weight:900;font-size:.9rem}
.cbtn{
  display:block;width:100%;text-align:center;
  padding:.9rem;border-radius:0.75rem;
  font-weight:700;font-size:.88rem;
  font-family:'Inter',sans-serif;letter-spacing:0.02em;
  transition:all .3s;
  background:var(--surface-container-highest);color:var(--primary);
  border:none;cursor:pointer;
}
.cbtn:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.cc.pop .cbtn{background:var(--accent);color:var(--primary)}
.cc.pop .cbtn:hover{background:#fff;transform:translateY(-2px)}

/* ===== POSTUP (process) — horizontal timeline ===== */
#postup{background:var(--surface);position:relative;overflow:hidden}
.steps-header{text-align:center;margin-bottom:4.5rem}
.steps-header .stl{max-width:100%;margin:0 auto}
.steps-header .sdsc{margin:1rem auto 0;text-align:center}
.steps-header .slbl{justify-content:center}
.steps-row{display:flex;gap:0;position:relative;counter-reset:step;max-width:1100px;margin:0 auto}
.step{flex:1;text-align:center;padding:0 1.25rem;position:relative}
.step-num{
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.75rem;
  font-family:'Inter',sans-serif;font-size:1.4rem;font-weight:900;
  position:relative;z-index:2;
  transition:all .5s cubic-bezier(0.2,0.8,0.2,1);
  box-shadow:0 12px 30px -10px rgba(0,50,76,0.4);
}
.step:hover .step-num{transform:scale(1.1) rotate(-4deg);box-shadow:0 20px 40px -14px rgba(0,50,76,0.5)}
.step-connector{
  position:absolute;top:32px;left:calc(50% + 32px);right:calc(-50% + 32px);
  height:2px;
  background:linear-gradient(90deg,var(--primary-tint-10),var(--accent-tint-20),var(--primary-tint-10));
  z-index:1;
}
.step:last-child .step-connector{display:none}
.step-icon{font-size:1.6rem;margin-bottom:.85rem;color:var(--accent-strong)}
.step h3{
  font-family:'Inter',sans-serif;
  font-size:1.1rem;font-weight:800;
  color:var(--primary);margin-bottom:.5rem;letter-spacing:-0.01em;
}
.step p{color:var(--on-surface-variant);font-size:.88rem;line-height:1.6;max-width:220px;margin:0 auto}

/* ===== PRECO (bento grid) ===== */
#preco{background:var(--surface-container-lowest);position:relative}
.bento{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:auto;gap:1.5rem;margin-top:3.5rem}
.bento-card{
  background:var(--surface-container-low);
  border-radius:1.75rem;
  padding:2.5rem 2rem;
  transition:all .45s cubic-bezier(0.2,0.8,0.2,1);
  position:relative;overflow:hidden;
}
.bento-card:hover{background:#fff;transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.bento-card.wide{grid-column:span 7}
.bento-card.narrow{grid-column:span 5}
.bento-card.third{grid-column:span 4}
.bento-card.accent{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  color:#fff;box-shadow:0 20px 50px -20px rgba(0,50,76,0.4);
}
.bento-card.accent:hover{background:linear-gradient(135deg,var(--primary-container) 0%,var(--primary) 100%)}
.bento-card.accent h3,.bento-card.accent p,.bento-card.accent .bc-num{color:#fff}
.bento-card.accent .bc-num{color:var(--accent)}
.bento-card.accent .bc-num-label{color:var(--on-primary-container)}
.bento-card.accent .bc-icon{background:rgba(255,255,255,0.08)}
.bento-card.accent .bc-icon svg{color:var(--accent) !important}
.bento-card.accent a{color:var(--accent) !important}
.bc-icon{
  width:52px;height:52px;border-radius:1rem;
  background:var(--primary-tint-6);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:1.5rem;
}
.bento-card h3{
  font-family:'Inter',sans-serif;
  font-size:1.25rem;font-weight:800;
  color:var(--primary);margin-bottom:.6rem;letter-spacing:-0.02em;
}
.bento-card p{color:var(--on-surface-variant);font-size:.92rem;line-height:1.65}
.bc-num{
  font-family:'Inter',sans-serif;
  font-size:3.4rem;font-weight:900;
  color:var(--accent-strong);letter-spacing:-0.04em;line-height:1;margin-bottom:.5rem;
}
.bc-num-label{
  font-size:.72rem;color:var(--on-surface-variant);
  font-weight:700;text-transform:uppercase;letter-spacing:0.12em;
}

/* ===== RECENZIE (testimonials) ===== */
#recenzie{background:var(--surface)}
.reviews-track{
  display:flex;gap:1.5rem;margin-top:3.5rem;
  overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:0.5rem 0 1.5rem;
  scrollbar-width:thin;scrollbar-color:var(--primary) var(--surface-container);
}
.reviews-track::-webkit-scrollbar{height:6px}
.reviews-track::-webkit-scrollbar-track{background:var(--surface-container);border-radius:3px}
.reviews-track::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px}
.review-card{
  min-width:360px;max-width:400px;flex-shrink:0;scroll-snap-align:start;
  background:var(--surface-container-lowest);
  border-radius:1.75rem;
  padding:2.25rem 2rem;
  transition:all .4s cubic-bezier(0.2,0.8,0.2,1);
  position:relative;
}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.review-stars{display:flex;gap:3px;margin-bottom:1.25rem}
.review-stars svg{width:18px;height:18px}
.stars-lg{display:flex;gap:5px;justify-content:center;margin-bottom:1.25rem}
.stars-lg svg{width:32px !important;height:32px !important}
.review-text{color:var(--on-surface);font-size:.98rem;line-height:1.7;margin-bottom:1.75rem;font-weight:400}
.review-author{display:flex;align-items:center;gap:.85rem}
.review-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#fff;font-size:.88rem;flex-shrink:0;
  letter-spacing:0.02em;
}
.review-name{font-weight:700;font-size:.92rem;color:var(--primary)}
.review-role{font-size:.78rem;color:var(--on-surface-variant);margin-top:.15rem}

/* ===== FAQ ===== */
#otazky{background:var(--surface-container-lowest)}
.faq-wrap{max-width:760px;margin:3.5rem auto 0}
.fi{
  background:var(--surface-container-low);
  border-radius:1.25rem;overflow:hidden;
  transition:all .35s ease;
  margin-bottom:.75rem;
}
.fi.act{background:#fff;box-shadow:var(--shadow-md)}
.fq{
  padding:1.3rem 1.5rem;
  display:flex;justify-content:space-between;align-items:center;cursor:pointer;
  font-weight:700;font-size:.98rem;color:var(--primary);
  gap:1rem;transition:color .3s;letter-spacing:-0.01em;
}
.fq:hover{color:var(--accent-strong)}
.fic{
  width:32px;height:32px;border-radius:50%;
  background:var(--surface-container);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  color:var(--on-surface-variant);font-weight:400;
}
.fi.act .fic{background:var(--accent);color:var(--primary);transform:rotate(45deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .45s ease}
.fai{padding:0 1.5rem 1.3rem;color:var(--on-surface-variant);font-size:.95rem;line-height:1.7}

/* ===== CTA BANNER (final call) ===== */
#cta-banner{
  background:linear-gradient(135deg,var(--primary-deep) 0%,var(--primary) 50%,var(--primary-container) 100%);
  padding:6rem 3rem;text-align:center;position:relative;overflow:hidden;
}
#cta-banner::before{
  content:'';position:absolute;top:-40%;left:-15%;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(42,221,205,0.16) 0%,transparent 65%);
  pointer-events:none;
}
#cta-banner::after{
  content:'';position:absolute;bottom:-35%;right:-12%;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(255,255,255,0.05) 0%,transparent 70%);
  pointer-events:none;
}
.cta-inner{position:relative;z-index:2;max-width:720px;margin:0 auto}
.cta-inner h2{
  font-family:'Inter',sans-serif;
  font-size:clamp(2.2rem,5vw,3.5rem);
  font-weight:900;color:#fff;line-height:1.05;letter-spacing:-0.04em;
  margin-bottom:1.25rem;
}
.cta-inner p{color:rgba(255,255,255,0.75);font-size:1.1rem;line-height:1.65;margin-bottom:2.75rem;max-width:540px;margin-left:auto;margin-right:auto}
.cta-inner .btn-p,.cta-inner .btn-acc{
  background:var(--accent);color:var(--primary);
  font-size:1rem;padding:1.15rem 2.5rem;
  box-shadow:0 16px 40px -12px rgba(42,221,205,0.55);
}
.cta-inner .btn-p:hover,.cta-inner .btn-acc:hover{background:#fff;color:var(--primary);transform:translateY(-3px);box-shadow:0 24px 60px -14px rgba(255,255,255,0.4)}

/* ===== KONTAKT ===== */
#kontakt{background:var(--surface)}
.kontakt-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;margin-top:3.5rem;align-items:start}
.kontakt-left h3{font-family:'Inter',sans-serif;font-size:1.6rem;font-weight:800;margin-bottom:1rem;color:var(--primary);letter-spacing:-0.02em}
.kontakt-left>p{color:var(--on-surface-variant);line-height:1.75;font-size:.98rem;margin-bottom:2rem}
.kl{
  display:flex;align-items:center;gap:1rem;
  padding:1.1rem 1.4rem;
  background:var(--surface-container-lowest);
  border-radius:1rem;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  margin-bottom:.75rem;
}
.kl:hover{transform:translateX(4px);box-shadow:var(--shadow-md)}
.kli{
  width:42px;height:42px;border-radius:0.75rem;
  background:var(--accent-tint-10);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.kli svg{color:var(--accent-strong)}
.klt{font-size:.95rem;font-weight:600;color:var(--on-surface)}
.kll{font-size:.68rem;color:var(--on-surface-variant);font-weight:700;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:.2rem}
.kontakt-form{
  background:var(--surface-container-lowest);
  border-radius:1.75rem;
  padding:2.75rem;position:relative;overflow:hidden;
  box-shadow:var(--shadow-md);
}
.kontakt-form::before{
  content:'';position:absolute;top:0;left:2rem;right:2rem;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-strong));
  border-radius:0 0 4px 4px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column;gap:.45rem}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:.72rem;font-weight:700;color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:0.1em}
.form-group input,.form-group textarea,.form-group select{
  font-family:'Inter',sans-serif;font-size:.95rem;
  padding:.85rem 1rem;
  border:none;
  border-radius:0.75rem;
  background:var(--surface-container-low);
  color:var(--on-surface);
  transition:all .3s;
  outline:none;resize:vertical;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  background:#fff;
  box-shadow:0 0 0 2px var(--accent);
}
.form-group textarea{min-height:110px}
.form-submit{
  width:100%;padding:1rem;border:none;
  border-radius:0.75rem;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  color:#fff;
  font-family:'Inter',sans-serif;font-size:.95rem;font-weight:700;
  letter-spacing:0.02em;
  cursor:pointer;transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  margin-top:.5rem;
  box-shadow:0 10px 28px -12px rgba(0,50,76,0.45);
}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(0,50,76,0.6)}
.form-btns{display:flex;gap:.75rem;margin-top:.5rem}
.form-btns .form-submit{flex:1}
.form-submit-wa{
  width:100%;padding:1rem;border:none;
  border-radius:0.75rem;background:#25d366;color:#fff;
  font-family:'Inter',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:0.02em;
  cursor:pointer;transition:all .35s cubic-bezier(0.2,0.8,0.2,1);flex:1;
  box-shadow:0 10px 28px -12px rgba(37,211,102,0.45);
}
.form-submit-wa:hover{background:#1fb855;transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(37,211,102,0.6)}

/* ===== CALCULATOR ===== */
.calc-section{background:var(--surface-container)}
.calc-wrap{
  max-width:640px;margin:0 auto;
  background:var(--surface-container-lowest);
  border-radius:1.75rem;
  padding:2.75rem;position:relative;overflow:hidden;
  box-shadow:var(--shadow-md);
}
.calc-wrap::before{
  content:'';position:absolute;top:-50px;right:-50px;
  width:160px;height:160px;
  background:radial-gradient(circle,var(--accent-tint-10) 0%,transparent 70%);
  pointer-events:none;
}
.calc-row{margin-bottom:1.5rem}
.calc-row label{display:block;font-size:.85rem;font-weight:700;color:var(--primary);margin-bottom:.6rem;letter-spacing:-0.01em}
.calc-row select,.calc-row input[type="number"]{
  width:100%;padding:.9rem 1.1rem;
  border:none;
  border-radius:0.75rem;
  font-family:'Inter',sans-serif;font-size:.95rem;color:var(--on-surface);
  background:var(--surface-container-low);
  transition:all .3s;
  appearance:none;-webkit-appearance:none;
}
.calc-row select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2300324c' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1.1rem center;
}
.calc-row select:focus,.calc-row input:focus{outline:none;background:#fff;box-shadow:0 0 0 2px var(--accent)}
.calc-result{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);
  border-radius:1.25rem;
  padding:1.75rem;text-align:center;margin-top:1rem;color:#fff;
}
.calc-price{font-family:'Inter',sans-serif;font-size:2.6rem;font-weight:900;color:var(--accent);letter-spacing:-0.03em;line-height:1}
.calc-note{font-size:.8rem;color:rgba(255,255,255,0.75);margin-top:.5rem}
.calc-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-top:1.25rem;padding:.85rem 1.75rem;
  background:var(--accent);color:var(--primary);
  border-radius:0.75rem;
  font-weight:700;font-size:.88rem;letter-spacing:0.02em;
  font-family:'Inter',sans-serif;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  border:none;cursor:pointer;
}
.calc-cta:hover{background:#fff;transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(255,255,255,0.3);color:var(--primary)}

/* ===== BREADCRUMBS ===== */
nav.breadcrumbs, .breadcrumbs{
  position:static !important;
  top:auto !important;left:auto !important;right:auto !important;
  max-width:1200px;margin:0 auto !important;
  padding:7rem 2rem 0 !important;
  display:flex !important;
  align-items:center;
  justify-content:flex-start !important;
  gap:.5rem;
  font-size:.85rem;color:var(--on-surface-variant);
  letter-spacing:.01em;
  background:transparent !important;
  backdrop-filter:none !important;
  box-shadow:none !important;
  z-index:auto !important;
  width:auto !important;
  height:auto !important;
}
nav.breadcrumbs a, .breadcrumbs a{
  color:var(--on-surface-variant) !important;text-decoration:none !important;
  transition:color .2s;
  font-weight:500 !important;
  padding:0 !important;
  border-radius:0 !important;
  background:transparent !important;
}
nav.breadcrumbs a:hover, .breadcrumbs a:hover{color:var(--accent-strong) !important;background:transparent !important}
nav.breadcrumbs span[aria-hidden], .breadcrumbs span[aria-hidden]{color:var(--outline-variant);font-weight:400}
nav.breadcrumbs [aria-current], .breadcrumbs [aria-current]{color:var(--primary);font-weight:600}
@media(max-width:640px){
  nav.breadcrumbs, .breadcrumbs{padding:6rem 1.25rem 0 !important;font-size:.8rem}
}

/* ===== PAGE HERO (subpages) ===== */
.page-hero{
  padding:10rem 3rem 5rem;text-align:center;
  background:linear-gradient(160deg,var(--surface) 0%,#e8eff7 50%,var(--surface) 100%);
  position:relative;overflow:hidden;
}
.breadcrumbs + .page-hero{padding-top:2.5rem}
.page-hero::before{
  content:'';position:absolute;top:-25%;right:-10%;
  width:780px;height:780px;
  background:radial-gradient(circle,rgba(42,221,205,0.12) 0%,transparent 65%);
  pointer-events:none;
}
.page-hero h1{
  font-family:'Inter',sans-serif;
  font-size:clamp(2.4rem,5.5vw,4.2rem);
  font-weight:900;line-height:1;
  color:var(--primary);letter-spacing:-0.04em;
  margin-bottom:1.5rem;position:relative;z-index:2;
}
.page-hero h1 .blue{color:var(--accent-strong)}
.page-hero p{font-size:1.15rem;color:var(--on-surface-variant);max-width:640px;margin:0 auto;line-height:1.65;position:relative;z-index:2}

/* ===== STATS BAR ===== */
.stats-bar{
  display:flex;justify-content:center;gap:4rem;
  padding:3rem;
  background:var(--surface-container-lowest);
}
.stat-item{text-align:center}
.stat-item h3{font-family:'Inter',sans-serif;font-size:2.2rem;font-weight:900;color:var(--primary);letter-spacing:-0.03em;line-height:1}
.stat-item p{font-size:.72rem;color:var(--on-surface-variant);font-weight:700;text-transform:uppercase;letter-spacing:0.12em;margin-top:.5rem}

/* ===== REALIZACIE GRID ===== */
.ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:1100px;margin:0 auto}
.ref-card{
  background:var(--surface-container-lowest);
  border-radius:1.75rem;overflow:hidden;
  transition:all .4s cubic-bezier(0.2,0.8,0.2,1);
}
.ref-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.ref-card img{width:100%;height:280px;object-fit:cover;display:block}
.ref-body{padding:2rem}
.ref-body h3{font-family:'Inter',sans-serif;font-size:1.2rem;font-weight:800;color:var(--primary);margin-bottom:.6rem;letter-spacing:-0.02em}
.ref-tags{display:flex;gap:.5rem;margin-bottom:.85rem;flex-wrap:wrap}
.ref-tag{font-size:.66rem;font-weight:800;padding:.3rem .7rem;border-radius:100px;letter-spacing:0.08em;text-transform:uppercase}
.ref-tag.dirty{background:rgba(239,68,68,0.1);color:#dc2626}
.ref-tag.clean{background:var(--accent-tint-10);color:var(--accent-strong)}
.ref-tag.process{background:var(--primary-tint-6);color:var(--primary)}
.ref-tag.type{background:var(--surface-container);color:var(--on-surface-variant)}
.ref-body p{font-size:.92rem;color:var(--on-surface-variant);line-height:1.65}

/* ===== GALLERY ===== */
.gallery-section{background:var(--surface-container-lowest)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1100px;margin:0 auto}
.gallery-grid img{width:100%;height:220px;object-fit:cover;border-radius:1rem;cursor:pointer;transition:all .4s cubic-bezier(0.2,0.8,0.2,1)}
.gallery-grid img:hover{transform:scale(1.03);box-shadow:var(--shadow-lg)}

/* ===== IG CTA ===== */
.ig-cta{
  display:flex;align-items:center;gap:2rem;
  max-width:820px;margin:0 auto;padding:2.75rem;
  background:linear-gradient(135deg,var(--accent-tint-10),var(--primary-tint-4));
  border-radius:1.75rem;
}
.ig-cta-icon{
  width:72px;height:72px;border-radius:1.25rem;
  background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 16px 36px -12px rgba(188,24,136,0.35);
}
.ig-cta-text h3{font-family:'Inter',sans-serif;font-size:1.2rem;font-weight:800;color:var(--primary);margin-bottom:.4rem;letter-spacing:-0.02em}
.ig-cta-text p{font-size:.92rem;color:var(--on-surface-variant);line-height:1.55;margin-bottom:1rem}
.ig-btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.7rem 1.5rem;
  background:var(--primary);color:#fff;
  border-radius:0.75rem;
  font-weight:700;font-size:.85rem;letter-spacing:0.02em;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  box-shadow:0 10px 24px -10px rgba(0,50,76,0.4);
}
.ig-btn:hover{background:var(--primary-container);transform:translateY(-2px);box-shadow:0 14px 32px -10px rgba(0,50,76,0.5);color:#fff}

/* ===== CTA SECTION (landing + realizacie) ===== */
.cta-section{
  text-align:center;padding:5.5rem 3rem;
  background:linear-gradient(160deg,#e8eff7 0%,var(--surface) 100%);
}
.cta-section h2{font-family:'Inter',sans-serif;font-size:clamp(2rem,4.2vw,3rem);font-weight:900;color:var(--primary);margin-bottom:1.25rem;letter-spacing:-0.03em;line-height:1.05}
.cta-section p{font-size:1.08rem;color:var(--on-surface-variant);max-width:560px;margin:0 auto 2.25rem;line-height:1.65}
.cta-btns{display:flex;gap:.85rem;justify-content:center;flex-wrap:wrap}

/* ===== CLIENT GRID ===== */
.client-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;max-width:960px;margin:0 auto}
.client-card{
  background:var(--surface-container-lowest);
  border-radius:1.5rem;
  padding:2rem;text-align:center;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
}
.client-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.client-card .emoji{font-size:2.2rem;margin-bottom:.85rem}
.client-card h3{font-family:'Inter',sans-serif;font-size:1.05rem;font-weight:800;color:var(--primary);margin-bottom:.4rem;letter-spacing:-0.01em}
.client-card p{font-size:.85rem;color:var(--on-surface-variant)}

/* ===== LANDING PAGE SPECIFIC ===== */
.lp-services{background:var(--surface-container-lowest)}
.lp-services .cg{max-width:960px;margin:3.5rem auto 0}
.lp-why{background:var(--surface)}
.lp-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;max-width:960px;margin-left:auto;margin-right:auto}
.lp-why-card{
  background:var(--surface-container-lowest);
  border-radius:1.5rem;
  padding:2.25rem 2rem;text-align:center;
  transition:all .4s cubic-bezier(0.2,0.8,0.2,1);
}
.lp-why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.lp-why-card .bc-icon{margin:0 auto 1.1rem}
.lp-why-card h3{font-family:'Inter',sans-serif;font-size:1.1rem;font-weight:800;color:var(--primary);margin-bottom:.6rem;letter-spacing:-0.01em}
.lp-why-card p{color:var(--on-surface-variant);font-size:.92rem;line-height:1.6}
.lp-faq{background:var(--surface-container-lowest)}
.lp-contact{background:var(--surface)}
.lp-contact-cards{display:flex;gap:1.25rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap}
.lp-contact-card{
  background:var(--surface-container-lowest);
  border-radius:1.25rem;
  padding:1.75rem 2rem;text-align:center;
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  min-width:220px;
}
.lp-contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.lp-contact-card .kli{margin:0 auto .85rem}
.lp-contact-card .kll{margin-bottom:.3rem}

/* ===== FOOTER ===== */
footer{
  padding:3rem;background:var(--primary);color:rgba(255,255,255,0.7);
  font-size:.85rem;
}
footer a{color:var(--accent);transition:color .3s}
footer a:hover{color:#fff}
.footer-cities{display:flex;gap:1.25rem;flex-wrap:wrap;justify-content:center;margin-top:1rem;font-size:.8rem}
.footer-cities a{color:rgba(255,255,255,0.7);transition:color .3s}
.footer-cities a:hover{color:var(--accent)}
.footer-inner{text-align:center;width:100%;max-width:1100px;margin:0 auto}

/* ===== LIGHTBOX ===== */
.lightbox{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,30,48,0.92);z-index:10000;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:12px}
.lightbox-close{
  position:absolute;top:1.5rem;right:1.5rem;
  color:#fff;font-size:2rem;cursor:pointer;
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,0.1);border-radius:50%;
  transition:.3s;backdrop-filter:blur(10px);
}
.lightbox-close:hover{background:rgba(255,255,255,0.2)}

/* ===== WHATSAPP FLOATING ===== */
.wa-btn{
  position:fixed;bottom:1.75rem;right:1.75rem;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,0.4);
  z-index:90;transition:all .35s cubic-bezier(0.2,0.8,0.2,1);cursor:pointer;
}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 12px 36px rgba(37,211,102,0.55)}
.wa-btn svg{width:30px;height:30px;fill:#fff}
.wa-tooltip{
  position:fixed;bottom:2.2rem;right:5.25rem;
  background:#fff;color:var(--primary);
  font-size:.82rem;font-weight:600;
  padding:.7rem 1.1rem;border-radius:0.75rem;
  box-shadow:var(--shadow-md);
  z-index:90;opacity:0;transform:translateX(10px);
  transition:all .35s cubic-bezier(0.2,0.8,0.2,1);
  pointer-events:none;white-space:nowrap;
}
.wa-btn:hover+.wa-tooltip,.wa-tooltip:hover{opacity:1;transform:translateX(0)}

/* ===== ANIMATIONS ===== */
@keyframes menuIn{from{opacity:0}to{opacity:1}}
@keyframes fu{to{opacity:1;transform:translateY(0)}}
@keyframes sp{0%{left:-100%}50%{left:100%}100%{left:100%}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s cubic-bezier(0.2,0.8,0.2,1),transform .75s cubic-bezier(0.2,0.8,0.2,1)}
.reveal.active{opacity:1;transform:translateY(0)}

/* ===== HERO IMAGE (asymmetric glass card) ===== */
.hero-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center;max-width:1320px;margin:0 auto;position:relative;z-index:2}
.hero-visual{position:relative}
.hero-glow{
  position:absolute;top:-4rem;right:-4rem;width:24rem;height:24rem;
  background:radial-gradient(circle,rgba(42,221,205,0.25) 0%,transparent 65%);
  filter:blur(40px);pointer-events:none;
}
.hero-card{
  position:relative;z-index:2;
  background:rgba(255,255,255,0.55);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  padding:2rem;border-radius:2rem;
  box-shadow:0 32px 80px -24px rgba(0,50,76,0.25);
}
.hero-card img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center;border-radius:1.25rem;margin-bottom:1.5rem;display:block}
.hero-card-meta{display:flex;justify-content:space-between;align-items:flex-end}
.hero-card-meta .lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--on-surface-variant);font-weight:700;margin-bottom:.35rem}
.hero-card-meta .val{font-family:'Inter',sans-serif;font-size:1.2rem;font-weight:900;letter-spacing:-0.02em;color:var(--primary)}
.hero-card-meta .val.teal{color:var(--accent-strong)}

/* ===== RESPONSIVE - Tablet ===== */
@media(max-width:1024px){
  nav{padding:1rem 2rem}
  nav.scrolled{padding:.7rem 2rem}
  section{padding:5rem 2rem}
  .hero{padding:7rem 2rem 4rem}
  .hero-wrap{grid-template-columns:1fr;gap:3rem}
  .hero-visual{max-width:480px;margin:0 auto}
  .hero h1{font-size:clamp(2.4rem,5.5vw,3.8rem)}
  .cg{grid-template-columns:1fr;max-width:500px;margin-left:auto;margin-right:auto}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-card.wide,.bento-card.narrow,.bento-card.third{grid-column:span 1}
  .kontakt-grid{grid-template-columns:1fr;gap:2.5rem}
  .steps-row{flex-wrap:wrap;justify-content:center}
  .step{flex:0 0 48%;margin-bottom:2rem}
  .step-connector{display:none}
  .hero-stats{gap:2rem}
  .review-card{min-width:320px}
  .page-hero{padding:8rem 2rem 3.5rem}
  .stats-bar{gap:2.5rem;padding:2.5rem}
  .ref-grid{grid-template-columns:1fr;max-width:600px}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .ig-cta{flex-direction:column;text-align:center}
  .lp-why-grid{grid-template-columns:1fr;max-width:500px}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:3rem}
  .trust-item:nth-child(3)::before{display:none}
}

/* ===== RESPONSIVE - Mobile ===== */
@media(max-width:768px){
  nav{padding:.9rem 1.25rem}
  nav.scrolled{padding:.7rem 1.25rem}
  .nav-links{display:flex;position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;min-height:100vh;min-height:100dvh;background:linear-gradient(160deg,#ffffff 0%,#eefbfa 100%);flex-direction:column;padding:6rem 2rem 2rem;gap:1.4rem;z-index:9999;align-items:center;justify-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch;clip-path:circle(0% at calc(100% - 38px) 38px);-webkit-clip-path:circle(0% at calc(100% - 38px) 38px);visibility:hidden;transition:clip-path .7s cubic-bezier(.77,0,.175,1),-webkit-clip-path .7s cubic-bezier(.77,0,.175,1),visibility 0s linear .7s}
  .nav-links.open{clip-path:circle(160% at calc(100% - 38px) 38px);-webkit-clip-path:circle(160% at calc(100% - 38px) 38px);visibility:visible;animation:none;transition:clip-path .7s cubic-bezier(.77,0,.175,1),-webkit-clip-path .7s cubic-bezier(.77,0,.175,1),visibility 0s linear 0s}
  .nav-links::before{content:'';position:absolute;top:-30%;right:-25%;width:90vw;height:90vw;background:radial-gradient(circle,rgba(42,221,205,.18) 0%,rgba(42,221,205,.05) 40%,transparent 65%);opacity:0;transition:opacity .8s ease .25s;pointer-events:none;border-radius:50%}
  .nav-links.open::before{opacity:1}
  .nav-links::after{content:'';position:absolute;bottom:-20%;left:-20%;width:70vw;height:70vw;background:radial-gradient(circle,rgba(0,50,76,.08) 0%,transparent 60%);opacity:0;transition:opacity 1s ease .35s;pointer-events:none;border-radius:50%}
  .nav-links.open::after{opacity:1}
  .nav-links li{opacity:0;transform:translateY(28px) scale(.94);transition:opacity .55s cubic-bezier(.2,.8,.2,1),transform .55s cubic-bezier(.2,.8,.2,1);position:relative;z-index:1}
  .nav-links.open li{opacity:1;transform:translateY(0) scale(1)}
  .nav-links.open li:nth-child(1){transition-delay:.32s}
  .nav-links.open li:nth-child(2){transition-delay:.38s}
  .nav-links.open li:nth-child(3){transition-delay:.44s}
  .nav-links.open li:nth-child(4){transition-delay:.5s}
  .nav-links.open li:nth-child(5){transition-delay:.56s}
  .nav-links.open li:nth-child(6){transition-delay:.62s}
  .nav-links.open li:nth-child(7){transition-delay:.68s}
  .nav-links.open li:nth-child(8){transition-delay:.74s}
  .nav-links.open li:nth-child(9){transition-delay:.8s}
  .nav-links a{transition:color .25s ease,transform .3s cubic-bezier(.2,.8,.2,1)}
  .nav-links a:active{transform:scale(.95)}
  .nav-links li{list-style:none}
  .nav-links a{font-size:1.25rem;font-weight:700;color:var(--primary);letter-spacing:0;text-transform:none}
  .nav-cta{padding:1rem 2.5rem !important;font-size:1rem !important}
  .hamburger{display:flex;z-index:10000;position:relative}
  /* Removed blanket *{animation-duration:.3s !important} — caused all animations to blink fast on mobile.
     Problematic animations have explicit overrides in the second @media block below (.hero-card, .marquee-track, .wave-divider, etc.) */
  .hero::before,.hero::after{display:none}
  section{padding:4rem 1.5rem}
  .slbl{font-size:.7rem;letter-spacing:0.14em}
  .stl{font-size:clamp(1.9rem,7vw,2.6rem)}
  .sdsc{font-size:1.02rem}
  .hero{padding:6.5rem 1.5rem 3rem;min-height:auto}
  .hero-wrap{grid-template-columns:1fr;gap:2.5rem}
  .hero h1{font-size:clamp(2.2rem,8vw,3rem);max-width:100%}
  .hero-sub{font-size:1.05rem;max-width:100%;line-height:1.6}
  .hero-btns{flex-direction:column;gap:.85rem}
  .hero-btns .btn{width:100%;justify-content:center;padding:1.05rem 1.5rem;font-size:1rem}
  .hero-stats{flex-direction:row;gap:0;justify-content:space-between;margin-top:2.75rem;padding-top:2rem;border-top:1px solid var(--primary-tint-8)}
  .hero-stat{text-align:center;flex:1}
  .hero-stat h3{font-size:1.9rem}
  .hero-stat p{font-size:.7rem}
  .scroll-ind{display:none}
  .hero-glow{display:none}
  .hero-card{padding:1.25rem;border-radius:1.5rem}
  .trust-bar{padding:3rem 1.5rem}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:2.25rem}
  .trust-num{font-size:2.1rem}
  .trust-item::before{display:none}
  .cg{grid-template-columns:1fr;max-width:100%;gap:1.25rem}
  .cc{padding:2.1rem 1.6rem;border-radius:1.5rem}
  .ci{width:48px;height:48px;border-radius:0.85rem}
  .cc h3{font-size:1.3rem}
  .cprice{font-size:2.3rem;margin:.9rem 0}
  .cft li{font-size:.95rem}
  .cbtn{padding:1rem;font-size:1rem}
  .cc.pop::before{font-size:.6rem}
  .steps-row{flex-direction:column;align-items:stretch;gap:0;max-width:560px;margin:0 auto}
  .step{width:100%;max-width:100%;padding:0 0 2rem 0;display:flex;flex-direction:row;align-items:flex-start;gap:1.25rem;text-align:left}
  .step-num{width:54px;height:54px;min-width:54px;font-size:1.2rem;margin:0}
  .step-connector,.step-icon{display:none}
  .step h3{font-size:1.1rem;margin-bottom:.35rem}
  .step p{font-size:.95rem;max-width:100%;margin:0;line-height:1.55}
  .step>div:last-child{flex:1}
  .bento{grid-template-columns:1fr;gap:1.25rem}
  .bento-card.wide,.bento-card.narrow,.bento-card.third{grid-column:span 1}
  .bento-card{padding:2rem 1.5rem;border-radius:1.5rem}
  .bc-icon{width:48px;height:48px;border-radius:0.85rem;margin-bottom:1.1rem}
  .bento-card h3{font-size:1.2rem}
  .bento-card p{font-size:.95rem}
  .bc-num{font-size:2.8rem}
  .reviews-track{gap:1rem;padding-bottom:1rem;scroll-padding-left:1.5rem}
  .review-card{min-width:300px;max-width:340px;padding:2rem 1.75rem;border-radius:1.5rem}
  .review-text{font-size:.96rem;line-height:1.65}
  .faq-wrap{margin-top:2.5rem}
  .fi{border-radius:1rem}
  .fq{padding:1.2rem 1.3rem;font-size:1rem}
  .fic{width:30px;height:30px;font-size:1.1rem}
  .fai{padding:0 1.3rem 1.2rem;font-size:.95rem;line-height:1.65}
  #cta-banner{padding:4rem 1.5rem}
  .cta-inner h2{font-size:clamp(2rem,7.5vw,2.6rem)}
  .cta-inner p{font-size:1rem;margin-bottom:2rem}
  .cta-inner .btn-p,.cta-inner .btn-acc{width:100%;justify-content:center;padding:1.1rem 2rem;font-size:1rem}
  .kontakt-left h3{font-size:1.4rem}
  .kontakt-left>p{font-size:1rem}
  .kl{padding:1rem 1.15rem;border-radius:0.85rem}
  .kli{width:40px;height:40px;border-radius:0.75rem}
  .klt{font-size:.96rem}
  .kontakt-form{padding:2rem 1.5rem;border-radius:1.5rem}
  .form-row{grid-template-columns:1fr;gap:.85rem;margin-bottom:.85rem}
  .form-group label{font-size:.7rem}
  .form-group input,.form-group textarea,.form-group select{font-size:16px;padding:.95rem 1rem;border-radius:0.75rem}
  .form-group textarea{min-height:100px}
  .form-submit,.form-submit-wa{padding:1.1rem;border-radius:0.75rem;font-size:1rem}
  .form-btns{flex-direction:column}
  footer{padding:2.5rem 1.5rem;font-size:.82rem}
  .footer-cities{gap:.85rem}
  .page-hero{padding:7.5rem 1.5rem 3rem}
  .page-hero h1{font-size:clamp(2rem,8vw,3rem)}
  .page-hero p{font-size:1.02rem}
  .stats-bar{flex-wrap:wrap;gap:2rem 1.5rem;padding:2.5rem 1.5rem;justify-content:space-around}
  .stat-item h3{font-size:1.8rem}
  .ref-grid{grid-template-columns:1fr;gap:1.5rem}
  .ref-card img{height:220px}
  .ref-body{padding:1.75rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .gallery-grid img{height:160px;border-radius:0.85rem}
  .ig-cta{padding:2rem;flex-direction:column;text-align:center}
  .cta-section{padding:4rem 1.5rem}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-btns .btn{width:100%;justify-content:center}
  .lp-why-grid{grid-template-columns:1fr}
  .lp-contact-cards{flex-direction:column;align-items:center}
  .calc-wrap{padding:2rem 1.5rem;border-radius:1.5rem}
  .calc-price{font-size:2.2rem}
  .predpo-wrap{grid-template-columns:1fr !important;gap:1.25rem !important}
  .predpo-wrap img{height:280px !important}
}

/* ===== RESPONSIVE - Small phones ===== */
@media(max-width:400px){
  section{padding:3.5rem 1.25rem}
  .hero{padding:6rem 1.25rem 2.5rem}
  .hero h1{font-size:clamp(1.95rem,9vw,2.4rem)}
  .hero-stat h3{font-size:1.7rem}
  .hero-stat p{font-size:.65rem;letter-spacing:0.06em}
  nav{padding:.85rem 1rem}
  .stl{font-size:clamp(1.7rem,7.5vw,2.1rem)}
  .cc{padding:1.9rem 1.4rem}
  .cprice{font-size:2rem}
  .bento-card{padding:1.9rem 1.4rem}
  .review-card{min-width:280px;max-width:310px;padding:1.75rem}
  #cta-banner{padding:3.5rem 1.25rem}
  .kontakt-form{padding:1.9rem 1.4rem}
  .page-hero{padding:7rem 1.25rem 2.5rem}
  .gallery-grid img{height:130px}
  .trust-num{font-size:1.8rem}
}

/* ==========================================================================
   ANIMATIONS v2 — LIVE & COOL
   ========================================================================== */

/* ===== 1) SCROLL PROGRESS BAR (top gradient strip) ===== */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:1000;
  background:linear-gradient(90deg,var(--accent-strong) 0%,var(--accent-fixed) 50%,var(--accent-strong) 100%);
  background-size:200% 100%;
  box-shadow:0 2px 10px rgba(0,200,185,0.5);
  transition:width .1s linear;
  animation:shimmerSlide 3s linear infinite;
  pointer-events:none;
}
@keyframes shimmerSlide{0%{background-position:0% 0}100%{background-position:200% 0}}

/* ===== 2) CURSOR SPOTLIGHT (radial glow follows cursor — desktop only) ===== */
.cursor-spotlight{
  position:fixed;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:1;opacity:0;
  background:radial-gradient(600px circle at var(--mx,-100%) var(--my,-100%),rgba(42,221,205,0.08),transparent 40%);
  transition:opacity .4s ease;
  mix-blend-mode:screen;
}
@media(hover:hover) and (pointer:fine){.cursor-spotlight{opacity:1}}

/* ===== 3) FLOATING BUBBLES (cleaning theme — hero decoration) ===== */
.bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.bubble{
  position:absolute;bottom:-60px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,0.9),rgba(42,221,205,0.3) 60%,rgba(0,200,185,0.15));
  box-shadow:inset 0 0 20px rgba(255,255,255,0.4),0 0 20px rgba(42,221,205,0.2);
  animation:bubbleRise var(--dur,14s) var(--del,0s) linear infinite;
  opacity:0;
}
@keyframes bubbleRise{
  0%{transform:translateY(0) translateX(0) scale(0.4);opacity:0}
  10%{opacity:.6}
  50%{transform:translateY(-50vh) translateX(var(--sway,20px)) scale(1)}
  90%{opacity:.4}
  100%{transform:translateY(-110vh) translateX(calc(var(--sway,20px) * -1)) scale(1.2);opacity:0}
}

/* ===== 4) GRADIENT TEXT ANIMATION (on accent headings) ===== */
.gradient-text{
  background:linear-gradient(90deg,var(--accent-strong) 0%,#2addcd 25%,var(--primary) 50%,#2addcd 75%,var(--accent-strong) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:gradientFlow 6s ease infinite;
}
@keyframes gradientFlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Shimmer sweep on blue accent word — uses masked gradient overlay */
.hero h1 .blue{position:relative;display:inline-block;color:var(--accent-strong)}
@supports((-webkit-background-clip:text) or (background-clip:text)){
  .hero h1 .blue{
    background:linear-gradient(90deg,var(--accent-strong) 0%,#2addcd 45%,#57fae9 50%,#2addcd 55%,var(--accent-strong) 100%);
    background-size:250% 100%;
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    animation:shinePass 5s ease-in-out 1s infinite;
  }
}
@keyframes shinePass{0%{background-position:200% 0}50%{background-position:-100% 0}100%{background-position:-200% 0}}

/* ===== 5) MAGNETIC BUTTON EFFECT (JS-driven; CSS spring) ===== */
.btn-p,.btn-o,.btn-acc,.btn-wa,.nav-cta,.cbtn,.form-submit,.form-submit-wa{
  position:relative;overflow:hidden;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .35s cubic-bezier(.2,.8,.2,1),background .35s cubic-bezier(.2,.8,.2,1),color .35s cubic-bezier(.2,.8,.2,1) !important;
}

/* Ripple (inserted via JS) */
.ripple-wave{
  position:absolute;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(255,255,255,0.55) 0%,rgba(255,255,255,0) 70%);
  transform:translate(-50%,-50%) scale(0);
  animation:rippleExpand .75s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes rippleExpand{to{transform:translate(-50%,-50%) scale(4);opacity:0}}

/* ===== 6) PULSE AURA on primary CTA ===== */
.btn-p::before,.btn-acc::before{
  content:'';position:absolute;inset:-3px;border-radius:inherit;
  background:linear-gradient(90deg,var(--accent-strong),var(--accent-fixed),var(--accent-strong));
  background-size:200% 100%;
  opacity:0;z-index:-1;
  filter:blur(12px);
  animation:auraPulse 4s ease-in-out infinite,shimmerSlide 3s linear infinite;
}
.btn-p:hover::before,.btn-acc:hover::before{opacity:.7}
@keyframes auraPulse{0%,100%{opacity:0}50%{opacity:.35}}

/* ===== 7) 3D TILT on service cards (JS-driven) ===== */
.cc{
  transform-style:preserve-3d;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .45s cubic-bezier(.2,.8,.2,1) !important;
  will-change:transform;
}
.cc>*{transform:translateZ(20px);transform-style:preserve-3d}
.cc .ci{transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.cc:hover .ci{transform:translateZ(50px) scale(1.08) rotate(-6deg)}

/* Glowing gradient border on cards */
.cc::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  padding:2px;
  background:conic-gradient(from var(--ang,0deg),transparent 0deg,var(--accent-strong) 60deg,transparent 120deg,transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .4s;
  animation:spinBorder 4s linear infinite;
}
.cc:hover::after{opacity:1}
@keyframes spinBorder{to{--ang:360deg}}
@property --ang{syntax:'<angle>';initial-value:0deg;inherits:false}

/* ===== 8) HERO IMAGE FLOAT + PARALLAX ===== */
.hero-card{animation:heroFloat 6s ease-in-out infinite;will-change:transform}
@keyframes heroFloat{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(.3deg)}}
.hero-glow{animation:glowBreathe 4s ease-in-out infinite;will-change:transform,opacity}
@keyframes glowBreathe{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.15);opacity:1}}

/* Shimmer on hero card image */
.hero-card::before{
  content:'';position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:inherit;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,0.35) 50%,transparent 70%);
  background-size:200% 100%;
  animation:shinePass 4s ease-in-out 2s infinite;
}

/* ===== 9) ANIMATED COUNTER (scale-in) ===== */
.hero-stat h3,.trust-num,.cprice{transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.counting{display:inline-block;transform-origin:center}
.counting.flash{animation:countFlash .6s ease}
@keyframes countFlash{0%{transform:scale(1)}50%{transform:scale(1.15);color:var(--accent-strong)}100%{transform:scale(1)}}

/* ===== 10) ENHANCED REVEAL (stagger, rotate, blur) ===== */
.reveal{
  opacity:0;transform:translateY(30px) scale(.98);filter:blur(4px);
  transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1),filter .9s cubic-bezier(.2,.8,.2,1);
}
.reveal.active{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}

.reveal-left{transform:translateX(-40px) scale(.98)}
.reveal-left.active{transform:translateX(0) scale(1)}
.reveal-right{transform:translateX(40px) scale(.98)}
.reveal-right.active{transform:translateX(0) scale(1)}

/* ===== 11) WAVE DIVIDER (between sections) ===== */
.wave-divider{
  position:relative;width:100%;height:80px;margin-top:-80px;pointer-events:none;z-index:2;overflow:hidden;
}
.wave-divider svg{position:absolute;bottom:0;left:0;width:200%;height:100%;animation:waveSlide 120s linear infinite}
@keyframes waveSlide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== 12) SCROLL INDICATOR BREATHING ===== */
.scroll-ind{animation:scrollBreathe 2.5s ease-in-out infinite}
@keyframes scrollBreathe{0%,100%{transform:translateY(0);opacity:.9}50%{transform:translateY(6px);opacity:1}}

/* ===== 13) BADGE PULSING RING (hero badge) ===== */
.hero-badge{position:relative}
.hero-badge::after{
  content:'';position:absolute;inset:-2px;border-radius:100px;
  border:2px solid var(--accent-strong);opacity:0;
  animation:badgeRing 2.5s ease-out infinite;
}
@keyframes badgeRing{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.15);opacity:0}}

/* ===== 14) NAV LINKS UNDERLINE ANIMATION ===== */
.nav-links a:not(.nav-cta){position:relative}
.nav-links a:not(.nav-cta)::after{
  content:'';position:absolute;left:50%;bottom:-6px;
  width:0;height:2px;background:var(--accent-strong);border-radius:2px;
  transform:translateX(-50%);
  transition:width .35s cubic-bezier(.2,.8,.2,1);
}
.nav-links a:not(.nav-cta):hover::after{width:80%}

/* ===== 15) STEP NUMBER ANIMATED GRADIENT ===== */
.step-num{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 50%,var(--accent-deep) 100%)!important;
  background-size:200% 200%!important;
  animation:gradShift 5s ease infinite;
}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ===== 16) REVIEW CARDS ENTRANCE ===== */
.review-card{animation:none}
.reviews-track.active .review-card{animation:reviewPop .7s cubic-bezier(.2,.8,.2,1) backwards}
.reviews-track.active .review-card:nth-child(1){animation-delay:.1s}
.reviews-track.active .review-card:nth-child(2){animation-delay:.2s}
.reviews-track.active .review-card:nth-child(3){animation-delay:.3s}
.reviews-track.active .review-card:nth-child(4){animation-delay:.4s}
.reviews-track.active .review-card:nth-child(5){animation-delay:.5s}
@keyframes reviewPop{from{opacity:0;transform:translateY(40px) rotate(-2deg) scale(.95)}to{opacity:1;transform:translateY(0) rotate(0) scale(1)}}

/* ===== 17) SECTION TITLE LETTER STAGGER (optional hook) ===== */
.stl .word{display:inline-block;opacity:0;transform:translateY(20px) rotate(3deg);transition:all .7s cubic-bezier(.2,.8,.2,1)}
.reveal.active .stl .word,.stl.active .word{opacity:1;transform:translateY(0) rotate(0)}
.stl .word:nth-child(1){transition-delay:.05s}
.stl .word:nth-child(2){transition-delay:.12s}
.stl .word:nth-child(3){transition-delay:.19s}
.stl .word:nth-child(4){transition-delay:.26s}
.stl .word:nth-child(5){transition-delay:.33s}
.stl .word:nth-child(6){transition-delay:.4s}
.stl .word:nth-child(7){transition-delay:.47s}

/* ===== 18) GALLERY IMAGE SHINE on hover ===== */
.gallery-grid a,.ref-card{position:relative;overflow:hidden}
.gallery-grid a::after,.ref-card::after{
  content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;
  background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,0.45) 50%,transparent 100%);
  transition:left .8s cubic-bezier(.2,.8,.2,1);pointer-events:none;z-index:2;
}
.gallery-grid a:hover::after,.ref-card:hover::after{left:150%}

/* ===== 19) WHATSAPP FAB pulse ===== */
.wa-btn{animation:waBreath 3s ease-in-out infinite}
.wa-btn::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(37,211,102,.6);
  animation:waRing 2.2s ease-out infinite;
}
@keyframes waBreath{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes waRing{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.6);opacity:0}}

/* ===== 20) FAQ HOVER SLIDE ===== */
.fi{transition:transform .35s cubic-bezier(.2,.8,.2,1),background .35s}
.fi:hover{transform:translateX(6px)}

/* ===== 21) ICON SVG DRAWING (service icons) ===== */
.cc:hover .ci svg *{
  animation:drawStroke 1.2s cubic-bezier(.2,.8,.2,1) forwards;
  stroke-dasharray:200;stroke-dashoffset:200;
}
@keyframes drawStroke{to{stroke-dashoffset:0}}

/* ===== 22) HERO VISUAL DEPTH (parallax hook) ===== */
.hero-visual{will-change:transform}

/* ===== 23) ENTRY STAGGER for service cards ===== */
.cg .cc.reveal{transition-delay:calc(var(--i,0) * 100ms)}

/* ===== 24) SCROLLBAR STYLING ===== */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--surface-container-low)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--accent-strong),var(--primary));border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--accent-fixed),var(--primary-container))}

/* ==========================================================================
   ANIMATIONS v3 — NEXT LEVEL
   ========================================================================== */

/* ===== 26) PARTICLE CANVAS (hero background) ===== */
.particle-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:1;opacity:.6;
}

/* ===== 27) HERO H1 LETTER SPLIT ===== */
.hero h1 .char{
  display:inline-block;opacity:0;
  transform:translateY(40px) rotateX(-60deg) scale(.85);
  transform-origin:50% 100%;
  animation:charDrop .9s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay:calc(var(--ci,0) * 30ms + .2s);
}
@keyframes charDrop{to{opacity:1;transform:translateY(0) rotateX(0) scale(1)}}
.hero h1 .char.space{min-width:.25em}

/* ===== 28) GOOEY FILTER on bubbles — merge effect ===== */
.bubbles{filter:url(#gooey);}
.bubble{mix-blend-mode:screen}

/* ===== 29) FLOATING DECORATIVE ICONS (snowflakes / sparkles) ===== */
.deco-floats{position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.deco-float{
  position:absolute;font-size:var(--sz,1.5rem);
  animation:decoFloat var(--dur,12s) var(--del,0s) ease-in-out infinite,decoSpin var(--spin,8s) linear infinite;
  opacity:var(--op,.4);filter:drop-shadow(0 4px 12px rgba(0,200,185,0.25));
  will-change:transform;
}
@keyframes decoFloat{
  0%,100%{transform:translate(0,0)}
  25%{transform:translate(20px,-30px)}
  50%{transform:translate(-15px,15px)}
  75%{transform:translate(25px,20px)}
}
@keyframes decoSpin{to{rotate:360deg}}

/* ===== 30) MARQUEE INFINITE BAND ===== */
.marquee{
  overflow:hidden;position:relative;
  background:var(--primary);color:#fff;
  padding:1.25rem 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.marquee::before,.marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,var(--primary),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--primary),transparent)}
.marquee-track{
  display:flex;gap:3rem;white-space:nowrap;width:max-content;
  animation:marqueeSlide 30s linear infinite;
  will-change:transform;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{
  display:inline-flex;align-items:center;gap:.75rem;
  font-size:1.05rem;font-weight:700;letter-spacing:-.01em;
  color:rgba(255,255,255,.85);
}
.marquee-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent-strong);
  box-shadow:0 0 14px rgba(42,221,205,.7);
}
@keyframes marqueeSlide{to{transform:translateX(-50%)}}

/* ===== 31) KEN BURNS on hero-card & gallery images ===== */
.hero-card img,.gallery-grid img,.ref-card img{
  transition:transform 12s ease-out;
  will-change:transform;
}
.hero-card img{animation:kenBurns 20s ease-in-out infinite alternate}
.gallery-grid a:hover img,.ref-card:hover img{transform:scale(1.08)}
@keyframes kenBurns{
  0%{transform:scale(1) translate(0,0)}
  50%{transform:scale(1.08) translate(-1%,-1%)}
  100%{transform:scale(1.04) translate(1%,1%)}
}

/* ===== 32) CLIP-PATH REVEAL on images (diagonal wipe) ===== */
.clip-reveal{
  clip-path:polygon(0 0,0 0,0 100%,0 100%);
  transition:clip-path 1.1s cubic-bezier(.2,.8,.2,1);
}
.clip-reveal.active{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}

/* ===== 33) GLITCH TEXT EFFECT on nav logo hover ===== */
.nav-logo{position:relative;transition:filter .2s}
.nav-logo:hover{filter:hue-rotate(0deg)}
.nav-logo:hover::before,.nav-logo:hover::after{
  content:attr(data-text);position:absolute;left:0;top:0;width:100%;
  pointer-events:none;
}
.nav-logo:hover::before{
  color:rgba(255,0,80,.7);animation:glitch1 .6s cubic-bezier(.25,.46,.45,.94) both;
  clip-path:polygon(0 0,100% 0,100% 45%,0 45%);
}
.nav-logo:hover::after{
  color:rgba(0,200,185,.8);animation:glitch2 .6s cubic-bezier(.25,.46,.45,.94) both;
  clip-path:polygon(0 55%,100% 55%,100% 100%,0 100%);
}
@keyframes glitch1{0%,100%{transform:translate(0)}20%{transform:translate(-2px,-1px)}40%{transform:translate(-1px,1px)}60%{transform:translate(1px,-1px)}80%{transform:translate(2px,1px)}}
@keyframes glitch2{0%,100%{transform:translate(0)}20%{transform:translate(2px,1px)}40%{transform:translate(1px,-1px)}60%{transform:translate(-1px,1px)}80%{transform:translate(-2px,-1px)}}

/* ===== 34) SPRING SQUISH on card click ===== */
.cc.squish,.bento-card.squish,.review-card.squish,.ref-card.squish{
  animation:squishPop .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes squishPop{
  0%{transform:scale(1)}
  30%{transform:scale(.94,1.06)}
  60%{transform:scale(1.04,.96)}
  100%{transform:scale(1)}
}

/* ===== 35) ANIMATED GRADIENT MESH on CTA banner ===== */
#cta-banner{position:relative;overflow:hidden;isolation:isolate}
#cta-banner::before{
  content:'';position:absolute;inset:-50%;z-index:-1;
  background:
    radial-gradient(circle at 20% 30%,rgba(42,221,205,.35) 0%,transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(87,250,233,.3) 0%,transparent 45%),
    radial-gradient(circle at 50% 50%,rgba(0,200,185,.25) 0%,transparent 50%);
  animation:meshRotate 20s linear infinite;
  will-change:transform;
}
@keyframes meshRotate{to{transform:rotate(360deg)}}

/* ===== 36) SPARKLE BURST on card hover entry ===== */
@keyframes sparkleOut{
  0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:1}
  100%{transform:translate(calc(-50% + var(--dx,40px)),calc(-50% + var(--dy,-30px))) scale(1.2) rotate(180deg);opacity:0}
}
.sparkle{
  position:absolute;pointer-events:none;z-index:10;
  width:10px;height:10px;
  background:radial-gradient(circle,#fff 0%,var(--accent-strong) 40%,transparent 70%);
  border-radius:50%;top:50%;left:50%;
  animation:sparkleOut .9s cubic-bezier(.2,.8,.2,1) forwards;
}

/* ===== 37) CONFETTI CANVAS ===== */
.confetti-canvas{
  position:fixed;inset:0;pointer-events:none;z-index:9999;
}

/* ===== 38) BUTTON ICON ROTATE on hover ===== */
.btn-p,.btn-o,.btn-acc{display:inline-flex;align-items:center;gap:.5rem}
.btn-p:hover,.btn-acc:hover{letter-spacing:.01em}

/* ===== 39) SCROLL-DRIVEN WIGGLE on fast scroll ===== */
body.scrolling-fast .cc,body.scrolling-fast .bento-card{
  animation:wiggle .3s ease;
}
@keyframes wiggle{0%,100%{transform:rotate(0)}25%{transform:rotate(.5deg)}75%{transform:rotate(-.5deg)}}

/* ===== 40) FORM FIELD FOCUS GLOW ===== */
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  box-shadow:0 0 0 4px rgba(42,221,205,.18),0 8px 28px -12px rgba(0,50,76,.25)!important;
  transform:translateY(-1px);
}

/* ===== 41) PRICE ODOMETER (digit roll) ===== */
.odometer{display:inline-flex;overflow:hidden;vertical-align:baseline}
.odometer-digit{
  display:inline-block;position:relative;
  transition:transform .8s cubic-bezier(.2,.8,.2,1);
}

/* ===== 42) DOT PATTERN BACKGROUND (drifting) ===== */
#preco,.stats-grid,.cta-inner{position:relative}
.dot-grid{
  position:absolute;inset:0;pointer-events:none;opacity:.4;z-index:0;
  background-image:radial-gradient(rgba(0,50,76,.15) 1px,transparent 1px);
  background-size:24px 24px;
  animation:dotDrift 30s linear infinite;
}
@keyframes dotDrift{to{background-position:48px 48px}}

/* ===== 43) SCROLL-SNAPPING scroll hint (hero) ===== */
.scroll-ind .scroll-line{position:relative;overflow:hidden}
.scroll-ind .scroll-line::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent,var(--accent-strong),transparent);
  animation:scrollDrop 2s ease-in-out infinite;
}
@keyframes scrollDrop{0%{transform:translateY(-100%)}100%{transform:translateY(100%)}}

/* ===== 44) TRUST BAR ITEM REVEAL ===== */
.trust-item{opacity:0;transform:translateY(20px);transition:all .7s cubic-bezier(.2,.8,.2,1)}
.trust-bar.active .trust-item{opacity:1;transform:translateY(0)}
.trust-bar.active .trust-item:nth-child(1){transition-delay:.05s}
.trust-bar.active .trust-item:nth-child(2){transition-delay:.15s}
.trust-bar.active .trust-item:nth-child(3){transition-delay:.25s}
.trust-bar.active .trust-item:nth-child(4){transition-delay:.35s}

/* ===== 45) AVATAR PULSE on reviews ===== */
.review-avatar{position:relative}
.review-card:hover .review-avatar{animation:avatarBeat 1s cubic-bezier(.34,1.56,.64,1)}
@keyframes avatarBeat{0%,100%{transform:scale(1)}30%{transform:scale(1.2)}60%{transform:scale(.95)}}

/* ===== 46) FAQ CHEVRON SPIN ===== */
.fic{transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.fi.act .fic{transform:rotate(135deg) scale(1.1)}

/* ===== 47) HAMBURGER MORPH to X (preserves original display logic) ===== */
.hamburger span{transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .25s}
.nav-links.open~.hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-links.open~.hamburger span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-links.open~.hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== 48) PAGE LOADER (brief fade-in) ===== */
body.loading{opacity:0}
body{opacity:1;transition:opacity .6s ease}

/* ===== 49) EMOJI BOUNCE on stat flash ===== */
.hero-stat h3,.trust-num{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}

/* ===== 50) MOBILE: lighten animations (calm down the chaos) ===== */
@media(max-width:768px){
  .cursor-spotlight,.particle-canvas,.deco-floats{display:none}
  .bubbles{display:none} /* bubliny zbytočne kradnú výkon na mobile */
  /* Hero card už nepláva — bolo to príliš nepokojné */
  .hero-card{animation:none!important}
  .hero-card img{animation:none!important}
  .hero-glow{animation:glowBreathe 6s ease-in-out infinite} /* len jemné dýchanie */
  /* Marquee 3x pomalšie — čitateľné */
  .marquee-track{animation-duration:70s!important}
  /* Conic border animácia na kartách — zbytočná na mobile */
  .cc::after{display:none}
  /* Blob drift pomalšie */
  .hero::before{animation-duration:28s}
  .hero::after{animation-duration:34s}
  /* WhatsApp ring — menej agresívne */
  .wa-btn::before{animation-duration:3.5s}
  /* Gradient mesh na CTA — vypnúť (zbytočný blur na mobile) */
  #cta-banner::before{animation:none}
  /* Shimmer na blue texte — vypnúť, je to rušivé */
  .hero h1 .blue{animation:none}
  /* Wave divider — úplne stopnutý, bol to najrušivejší element na mobile */
  .wave-divider svg{animation:none!important}
  /* Na mobile wave nesmie prekrývať hero-card obsah */
  .wave-divider{margin-top:0!important;height:50px!important}
  .hero{padding-bottom:2rem}
}

/* ===== REDUCED MOTION — accessibility ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .bubbles,.cursor-spotlight,.hero-card::before,.particle-canvas,.deco-floats,.marquee{display:none!important}
  .reveal,.hero h1 .char{opacity:1!important;transform:none!important;filter:none!important}
}

/* ============================================
   QUALITY SECTION (top firma + chémia)
   ============================================ */
.quality-section{background:linear-gradient(180deg,#f7fafb 0%,#eaf6f5 100%);position:relative;overflow:hidden}
.quality-section::before{content:'';position:absolute;top:-100px;right:-150px;width:400px;height:400px;background:radial-gradient(circle,rgba(42,221,205,.12) 0%,transparent 65%);pointer-events:none;border-radius:50%;animation:qDrift 20s ease-in-out infinite}
.quality-section::after{content:'';position:absolute;bottom:-100px;left:-150px;width:400px;height:400px;background:radial-gradient(circle,rgba(0,50,76,.06) 0%,transparent 65%);pointer-events:none;border-radius:50%}
@keyframes qDrift{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,20px)}}
.quality-section .stl strong{color:#2addcd}
.quality-section .sdsc strong{color:#00324c;font-weight:700}
.quality-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;margin:3rem auto 2.5rem;max-width:1200px;position:relative;z-index:1}
.qc{background:#fff;border-radius:18px;padding:1.8rem 1.5rem 1.5rem;border:1px solid rgba(0,50,76,.06);position:relative;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s;overflow:hidden}
.qc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#2addcd 0%,#00324c 100%);transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.2,.8,.2,1)}
.qc:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,50,76,.12);border-color:rgba(42,221,205,.4)}
.qc:hover::before{transform:scaleX(1)}
.qc-num{position:absolute;top:14px;right:18px;font-family:'Inter',sans-serif;font-size:3.4rem;font-weight:900;color:rgba(0,50,76,.06);line-height:.8;letter-spacing:-0.04em;pointer-events:none;transition:color .35s}
.qc:hover .qc-num{color:rgba(42,221,205,.18)}
.qc-icon{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#eafffd 0%,#d4f7f4 100%);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;color:#00324c;transition:transform .35s cubic-bezier(.34,1.56,.64,1),background .35s}
.qc:hover .qc-icon{transform:rotate(-6deg) scale(1.06);background:linear-gradient(135deg,#2addcd 0%,#1ab8a8 100%);color:#fff}
.qc h4{margin:0 0 .55rem;font-size:1.08rem;color:#00324c;letter-spacing:-0.01em;font-weight:700}
.qc p{margin:0;color:rgba(0,50,76,.7);font-size:.92rem;line-height:1.55}
.quality-trust{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;max-width:900px;margin:2rem auto 0;background:rgba(255,255,255,.7);backdrop-filter:blur(6px);border:1px solid rgba(42,221,205,.25);border-radius:18px;padding:1.5rem 1.5rem;position:relative;z-index:1;box-shadow:0 8px 24px rgba(0,50,76,.06)}
.qt-item{text-align:center;padding:.5rem .25rem;border-right:1px solid rgba(0,50,76,.08)}
.qt-item:last-child{border-right:none}
.qt-item strong{display:block;font-family:'Inter',sans-serif;font-size:1.85rem;font-weight:900;color:#2addcd;letter-spacing:-0.02em;line-height:1;margin-bottom:.4rem}
.qt-item span{display:block;font-size:.78rem;color:rgba(0,50,76,.7);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
@media(max-width:768px){
  .quality-grid{grid-template-columns:1fr;gap:1rem;margin:2rem auto 2rem}
  .qc{padding:1.5rem 1.25rem 1.25rem}
  .qc-num{font-size:2.6rem}
  .quality-trust{grid-template-columns:repeat(2,1fr);padding:1.2rem 1rem}
  .qt-item{border-right:none;border-bottom:1px solid rgba(0,50,76,.08);padding:.7rem .25rem}
  .qt-item:nth-child(odd){border-right:1px solid rgba(0,50,76,.08)}
  .qt-item:nth-last-child(-n+2){border-bottom:none}
  .qt-item strong{font-size:1.5rem}
}

/* ============================================
   PROMO BANNER (top of page)
   ============================================ */
.vk-promo-banner{position:fixed;top:0;left:0;right:0;z-index:200;background:linear-gradient(90deg,#00324c 0%,#0a4663 50%,#00324c 100%);background-size:200% 100%;animation:vkPromoShine 8s ease-in-out infinite;color:#fff;overflow:hidden;border-bottom:2px solid #2addcd;box-shadow:0 4px 16px rgba(0,50,76,.18);max-height:120px;transition:max-height .45s ease,opacity .45s ease,transform .45s ease}
/* Push the fixed nav and body content down when promo is visible */
body.vk-has-promo nav{top:46px}
body.vk-has-promo{padding-top:46px}
@media(max-width:768px){
  body.vk-has-promo nav{top:64px}
  body.vk-has-promo{padding-top:64px}
}
.vk-promo-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(42,221,205,.18) 0%,transparent 60%);pointer-events:none}
.vk-promo-banner.vk-dismissed{max-height:0;opacity:0;transform:translateY(-100%);border-bottom-width:0}
.vk-promo-inner{position:relative;display:flex;align-items:center;justify-content:center;gap:14px;padding:11px 50px 11px 16px;font-size:.92rem;font-weight:600;flex-wrap:wrap;max-width:1280px;margin:0 auto}
.vk-promo-badge{background:linear-gradient(135deg,#ff5e3a 0%,#ff2a68 100%);color:#fff;padding:4px 11px;border-radius:5px;font-size:.7rem;font-weight:800;letter-spacing:.09em;box-shadow:0 3px 10px rgba(255,94,58,.45);animation:vkPromoBadgePulse 1.6s cubic-bezier(.4,0,.2,1) infinite;flex-shrink:0;text-transform:uppercase;white-space:nowrap}
.vk-promo-text{color:#fff;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:1.4}
.vk-promo-text strong{color:#2addcd;font-weight:800;font-size:1.04em}
.vk-promo-old{text-decoration:line-through;text-decoration-color:rgba(255,94,58,.85);text-decoration-thickness:2px;opacity:.65;font-weight:500;font-size:.94em}
.vk-promo-sep{opacity:.4}
.vk-promo-extra{opacity:.95;font-weight:500}
.vk-promo-cta{background:#2addcd;color:#00324c;padding:7px 16px;border-radius:22px;font-weight:800;text-decoration:none;font-size:.85rem;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,background .25s;box-shadow:0 4px 12px rgba(42,221,205,.3);white-space:nowrap;letter-spacing:.01em}
.vk-promo-cta:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 6px 18px rgba(42,221,205,.45);background:#3ee6d6}
.vk-promo-close{position:absolute;top:50%;right:10px;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.85);width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,transform .35s,color .25s;padding:0}
.vk-promo-close svg{width:14px;height:14px}
.vk-promo-close:hover{background:rgba(255,255,255,.22);color:#fff;transform:translateY(-50%) rotate(90deg)}
@keyframes vkPromoShine{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
@keyframes vkPromoBadgePulse{
  0%,100%{transform:scale(1);box-shadow:0 3px 10px rgba(255,94,58,.45)}
  50%{transform:scale(1.06);box-shadow:0 4px 16px rgba(255,94,58,.65)}
}

/* Mobile: stack and shrink */
@media(max-width:768px){
  .vk-promo-inner{padding:9px 42px 9px 12px;gap:8px;font-size:.78rem}
  .vk-promo-badge{font-size:.62rem;padding:3px 8px}
  .vk-promo-text{gap:6px;font-size:.8rem}
  .vk-promo-text strong{font-size:1em}
  .vk-promo-cta{padding:6px 12px;font-size:.76rem}
  .vk-promo-sep{display:none}
  .vk-promo-extra{font-size:.78rem;width:100%;text-align:center;opacity:.85}
}
@media(max-width:480px){
  .vk-promo-extra{display:none}
}

/* Push the chat teaser & button down a bit when promo is visible (so they don't crowd) */
body.vk-has-promo .vk-chat-btn{bottom:24px}

/* ============================================
   CHATBOT WIDGET
   ============================================ */
.vk-chat-btn{position:fixed;bottom:24px;left:24px;width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,#00324c 0%,#004d6b 100%);color:#fff;border:none;cursor:pointer;z-index:9998;box-shadow:0 8px 28px rgba(0,50,76,.35),0 0 0 0 rgba(42,221,205,.5);display:flex;align-items:center;justify-content:center;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease;animation:vkChatPulse 2.6s ease-in-out infinite}
.vk-chat-btn:hover{transform:scale(1.08) rotate(-6deg)}
.vk-chat-btn:active{transform:scale(.95)}
.vk-chat-btn svg{width:28px;height:28px;transition:transform .3s}
.vk-chat-btn[data-open="1"]{transform:rotate(180deg) scale(.9);background:linear-gradient(135deg,#00324c 0%,#001f30 100%)}
.vk-chat-btn[data-open="1"]:hover{transform:rotate(180deg) scale(1)}
.vk-chat-badge{position:absolute;top:-2px;right:-2px;width:18px;height:18px;background:#ff4757;color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff;animation:vkChatBadgePop .5s cubic-bezier(.34,1.56,.64,1)}
.vk-chat-btn[data-open="1"] .vk-chat-badge{display:none}
@keyframes vkChatPulse{
  0%,100%{box-shadow:0 8px 28px rgba(0,50,76,.35),0 0 0 0 rgba(42,221,205,.55)}
  50%{box-shadow:0 8px 28px rgba(0,50,76,.35),0 0 0 14px rgba(42,221,205,0)}
}
@keyframes vkChatBadgePop{
  0%{transform:scale(0)}
  60%{transform:scale(1.25)}
  100%{transform:scale(1)}
}
.vk-chat-panel{position:fixed;bottom:100px;left:24px;width:380px;max-width:calc(100vw - 32px);height:580px;max-height:calc(100vh - 130px);background:#fff;border-radius:20px;box-shadow:0 24px 60px rgba(0,50,76,.25),0 4px 16px rgba(0,50,76,.12);display:flex;flex-direction:column;overflow:hidden;z-index:9999;transform-origin:bottom left;transform:scale(.4) translate(-30%,30%);opacity:0;pointer-events:none;visibility:hidden;transition:transform .45s cubic-bezier(.34,1.56,.64,1),opacity .35s ease,visibility 0s linear .45s}
.vk-chat-panel.open{transform:scale(1) translate(0,0);opacity:1;pointer-events:auto;visibility:visible;transition:transform .45s cubic-bezier(.34,1.56,.64,1),opacity .35s ease,visibility 0s linear 0s}
.vk-chat-head{background:linear-gradient(135deg,#00324c 0%,#003e5e 100%);color:#fff;padding:18px 20px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;flex-shrink:0}
.vk-chat-head::before{content:'';position:absolute;top:-50%;right:-20%;width:200px;height:200px;background:radial-gradient(circle,rgba(42,221,205,.25) 0%,transparent 60%);pointer-events:none}
.vk-chat-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#2addcd 0%,#1ab8a8 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(42,221,205,.4)}
.vk-chat-avatar svg{width:22px;height:22px;color:#00324c}
.vk-chat-info{flex:1;min-width:0;position:relative;z-index:1}
.vk-chat-info h4{margin:0;font-size:.97rem;font-weight:700;letter-spacing:.01em}
.vk-chat-info p{margin:2px 0 0;font-size:.78rem;opacity:.85;display:flex;align-items:center;gap:6px}
.vk-chat-status-dot{width:7px;height:7px;background:#2addcd;border-radius:50%;display:inline-block;box-shadow:0 0 0 0 rgba(42,221,205,.7);animation:vkOnlinePulse 2s ease-in-out infinite}
@keyframes vkOnlinePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(42,221,205,.6)}
  50%{box-shadow:0 0 0 5px rgba(42,221,205,0)}
}
.vk-chat-close,.vk-chat-reset{background:rgba(255,255,255,.12);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,transform .35s;position:relative;z-index:1}
.vk-chat-close:hover{background:rgba(255,255,255,.22);transform:rotate(90deg)}
.vk-chat-reset:hover{background:rgba(255,255,255,.22);transform:rotate(-180deg)}
.vk-chat-close svg,.vk-chat-reset svg{width:16px;height:16px}
.vk-chat-body{flex:1;overflow-y:auto;padding:18px 16px;background:linear-gradient(180deg,#f7fafb 0%,#ffffff 100%);display:flex;flex-direction:column;gap:10px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}
.vk-chat-body::-webkit-scrollbar{width:6px}
.vk-chat-body::-webkit-scrollbar-thumb{background:rgba(0,50,76,.15);border-radius:3px}
.vk-msg{max-width:85%;padding:11px 14px;border-radius:16px;font-size:.92rem;line-height:1.45;animation:vkMsgIn .4s cubic-bezier(.2,.8,.2,1) backwards;word-wrap:break-word;white-space:pre-line}
.vk-msg-bot{align-self:flex-start;background:#fff;color:#00324c;border:1px solid rgba(0,50,76,.08);border-bottom-left-radius:4px;box-shadow:0 2px 8px rgba(0,50,76,.05)}
.vk-msg-user{align-self:flex-end;background:linear-gradient(135deg,#2addcd 0%,#1fc4b5 100%);color:#00324c;border-bottom-right-radius:4px;font-weight:600;box-shadow:0 4px 14px rgba(42,221,205,.3)}
@keyframes vkMsgIn{
  from{opacity:0;transform:translateY(8px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.vk-typing{display:flex;gap:4px;padding:14px 16px;background:#fff;border:1px solid rgba(0,50,76,.08);border-radius:16px;border-bottom-left-radius:4px;align-self:flex-start;animation:vkMsgIn .35s ease backwards}
.vk-typing span{width:7px;height:7px;background:rgba(0,50,76,.4);border-radius:50%;animation:vkTypingDot 1.3s ease-in-out infinite}
.vk-typing span:nth-child(2){animation-delay:.2s}
.vk-typing span:nth-child(3){animation-delay:.4s}
@keyframes vkTypingDot{
  0%,60%,100%{transform:translateY(0);opacity:.4}
  30%{transform:translateY(-5px);opacity:1}
}
.vk-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 4px;animation:vkMsgIn .4s ease backwards;animation-delay:.15s}
.vk-chip{background:#fff;color:#00324c;border:1.5px solid rgba(42,221,205,.5);padding:8px 14px;border-radius:20px;font-size:.84rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.2,.8,.2,1);font-family:inherit;line-height:1.3}
.vk-chip:hover{background:#2addcd;color:#00324c;transform:translateY(-2px);box-shadow:0 6px 14px rgba(42,221,205,.35);border-color:#2addcd}
.vk-chip:active{transform:translateY(0) scale(.96)}
.vk-form{background:#fff;border:1px solid rgba(0,50,76,.1);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:9px;animation:vkMsgIn .45s cubic-bezier(.2,.8,.2,1) backwards}
.vk-form input,.vk-form select{width:100%;padding:10px 12px;border:1.5px solid rgba(0,50,76,.15);border-radius:10px;font-size:.9rem;font-family:inherit;color:#00324c;background:#fafbfc;transition:border .2s,background .2s;box-sizing:border-box}
.vk-form input:focus,.vk-form select:focus{outline:none;border-color:#2addcd;background:#fff}
.vk-form-row{display:flex;flex-direction:column;gap:4px}
.vk-form-row label{font-size:.74rem;font-weight:600;color:rgba(0,50,76,.7);text-transform:uppercase;letter-spacing:.04em;padding-left:2px}
.vk-form-actions{display:flex;flex-direction:column;gap:7px;margin-top:4px}
.vk-form-btn{padding:11px 14px;border:none;border-radius:10px;font-size:.88rem;font-weight:700;cursor:pointer;transition:transform .25s,box-shadow .25s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px}
.vk-form-btn svg{width:16px;height:16px;flex-shrink:0}
.vk-form-btn-quote{background:linear-gradient(135deg,#2addcd 0%,#1ab8a8 100%);color:#00324c;box-shadow:0 6px 18px rgba(42,221,205,.45);font-weight:800;font-size:.95rem;padding:13px 14px;letter-spacing:.01em;animation:vkQuotePulse 2.4s ease-in-out infinite}
.vk-form-btn-quote:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(42,221,205,.55);animation:none}
@keyframes vkQuotePulse{0%,100%{box-shadow:0 6px 18px rgba(42,221,205,.45)}50%{box-shadow:0 6px 24px rgba(42,221,205,.7)}}
.vk-form-btn-wa{background:#25D366;color:#fff;box-shadow:0 4px 12px rgba(37,211,102,.35)}
.vk-form-btn-wa:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(37,211,102,.45)}
.vk-form-btn-mail{background:#00324c;color:#fff;box-shadow:0 4px 12px rgba(0,50,76,.3)}
.vk-form-btn-mail:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,50,76,.4)}
.vk-form-btn-tel{background:#fff;color:#00324c;border:1.5px solid rgba(0,50,76,.2)}
.vk-form-btn-tel:hover{background:#f0fafa;border-color:#2addcd;transform:translateY(-2px)}
.vk-chat-foot{padding:10px 16px;background:#fafbfc;border-top:1px solid rgba(0,50,76,.06);font-size:.72rem;color:rgba(0,50,76,.55);text-align:center;flex-shrink:0}
.vk-chat-foot a{color:#00324c;font-weight:600;text-decoration:none}
.vk-chat-foot a:hover{color:#2addcd}

/* Mobile chatbot */
@media(max-width:768px){
  .vk-chat-btn{bottom:16px;left:16px;width:54px;height:54px}
  .vk-chat-btn svg{width:24px;height:24px}
  .vk-chat-panel{bottom:82px;left:12px;right:12px;width:auto;max-width:none;height:calc(100vh - 100px);height:calc(100dvh - 100px);max-height:none;border-radius:18px}
  .vk-msg{font-size:.9rem}
  .vk-chip{font-size:.82rem;padding:8px 12px}
  .vk-chat-head{padding:14px 16px}
  .vk-chat-body{padding:14px 12px}
}

/* Don't conflict with WhatsApp button on small screens */
@media(max-width:380px){
  .vk-chat-btn{width:50px;height:50px}
  .vk-chat-btn svg{width:22px;height:22px}
}

/* Teaser auto-popup bubble */
.vk-chat-teaser{position:fixed;bottom:34px;left:96px;max-width:260px;background:#fff;color:#00324c;padding:14px 38px 14px 14px;border-radius:16px;border-bottom-left-radius:4px;box-shadow:0 12px 32px rgba(0,50,76,.18),0 2px 8px rgba(0,50,76,.08);font-size:.88rem;line-height:1.4;z-index:9997;display:flex;align-items:flex-start;gap:10px;cursor:pointer;opacity:0;transform:translateY(8px) scale(.9);transform-origin:bottom left;visibility:hidden;transition:opacity .35s ease,transform .45s cubic-bezier(.34,1.56,.64,1),visibility 0s linear .45s;border:1px solid rgba(0,50,76,.06)}
.vk-chat-teaser.show{opacity:1;transform:translateY(0) scale(1);visibility:visible;transition:opacity .35s ease,transform .45s cubic-bezier(.34,1.56,.64,1),visibility 0s linear 0s;animation:vkTeaserBounce 1.8s ease-in-out 1.2s 2}
.vk-chat-teaser::before{content:'';position:absolute;bottom:6px;left:-7px;width:14px;height:14px;background:#fff;border-left:1px solid rgba(0,50,76,.06);border-bottom:1px solid rgba(0,50,76,.06);transform:rotate(45deg);border-bottom-left-radius:3px}
.vk-chat-teaser:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 16px 40px rgba(0,50,76,.22),0 2px 8px rgba(0,50,76,.08)}
.vk-teaser-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#2addcd 0%,#1ab8a8 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#00324c;box-shadow:0 2px 8px rgba(42,221,205,.35)}
.vk-teaser-avatar svg{width:18px;height:18px}
.vk-teaser-text{flex:1;padding-top:1px;color:#00324c}
.vk-teaser-text strong{display:block;font-weight:700;font-size:.92rem;margin-bottom:1px;color:#00324c}
.vk-teaser-close{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:rgba(0,50,76,.07);border:none;color:rgba(0,50,76,.6);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,transform .25s}
.vk-teaser-close svg{width:11px;height:11px}
.vk-teaser-close:hover{background:rgba(0,50,76,.15);color:#00324c;transform:rotate(90deg)}
@keyframes vkTeaserBounce{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-4px) scale(1.01)}
}
@media(max-width:768px){
  .vk-chat-teaser{bottom:28px;left:80px;max-width:220px;font-size:.82rem;padding:11px 32px 11px 11px}
  .vk-teaser-avatar{width:30px;height:30px}
  .vk-teaser-avatar svg{width:16px;height:16px}
}
@media(max-width:480px){
  .vk-chat-teaser{max-width:calc(100vw - 100px)}
}
