
@font-face{font-family:GropledBold;src: url('/assets/fonts/Gropled-Bold.woff2') format('woff2');font-weight:bold;font-style:normal;font-display:swap}
:root{--light:#b3ddf6;--med:#2c7397;--dark:#002c3f;--white:#ffffff;--muted:#e6f3fb;--space:40px}
*{box-sizing:border-box}
.sr-only{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
body{font-family:Arial, Helvetica, sans-serif;color:var(--dark);margin:0}
.site-link{display:inline-block}
.site-link, a{color:var(--med);text-decoration:none;transition:background 180ms ease,color 180ms ease}
a:hover,a:focus{background:var(--light);color:var(--dark);border-radius:6px}
.site-header{position:fixed;top:0;left:0;right:0;height:auto;background:#002c3f;display:flex;align-items:center;justify-content:center;padding:0 16px;border-bottom:1px solid rgba(255,255,255,0.04);z-index:50}
.site-header .brand{font-family:GropledBold,Arial;font-weight:700;color:var(--med);font-size:24px}
/* Контейнер .container — общий макет для хедера и контента
  Используется для центрирования контента и ограничений ширины */
.container{margin:0 auto;padding:0 12px;display:flex;align-items:center}
.header-inner{width:100%;display:flex;align-items:center;gap:12px;justify-content:space-between;position:relative}
/* Header blocks: top/middle/bottom — provide explicit flex containers to control layout
  - .header-top holds logo/brand and hamburger
  - .header-middle holds navigation
  - .header-bottom holds contact controls (phone/telegram/lang)
  This separation makes responsive reflow predictable. */
.header-top{display:flex;align-items:center;gap:8px;flex:0 0 auto;justify-content:flex-start;padding-left:12px}
.header-middle{display:flex;flex:1 1 50%;justify-content:center}
.header-bottom{display:flex;flex:0 0 auto;align-items:center;gap:10px;justify-content:flex-end;padding-right:12px}
.header-top .logo{display:flex;align-items:center;gap:10px}
/* spacing for contact controls in header-bottom */
.header-bottom .header-cta > *{margin-left:12px}
.header-bottom .phone{color:#fff;font-weight:600}
.header-bottom .telegram{color:#fff;background:transparent;text-decoration:none}

/* main nav styles: make links high-contrast and span available width */
.main-nav{display:flex;gap:8px;flex:1;justify-content:center}
  .main-nav{display:flex;gap:8px;flex:1;justify-content:center}
  /* Navigation links: centered with 2px separators and press/hover visual
    - separators implemented via left border on links (except first)
    - on hover/active the link appears pressed via translateY and inset shadow */
  .main-nav a{color:#ffffff;text-decoration:none;padding:10px 18px;display:inline-block;font-weight:600;border-radius:6px;border-left:2px solid rgba(255,255,255,0.06);transition:background 140ms ease, transform 120ms ease, border-color 140ms ease}
  .main-nav a:first-child{border-left:0}
  .main-nav a:hover,.main-nav a:focus{background:rgba(255,255,255,0.06);outline:none;border-color:rgba(255,255,255,0.18);transform:translateY(1px);box-shadow:inset 0 3px 8px rgba(0,0,0,0.12)}

/* enable native smooth scrolling as a fallback; JS handles header offset */
html{scroll-behavior:smooth}

/* mobile/tablet breakpoint: menu takes full width and links span across */
@media (max-width:1330px) and (min-width:601px) {
  /* Tablet/large-mobile breakpoint (601px - 1330px):
     - keep logo (left) and contacts (right) on a single header row
     - hide the inline center nav (we use the hamburger to open the collapsible panel)
     - the collapsible panel (.main-nav) is positioned under the header when opened */
  .main-nav{
    position:absolute;display:flex;top:100%;left:0;right:auto;background:#002c3f;padding:6px 12px;flex-direction:column;
    max-height:0;overflow:hidden;opacity:0;transform:translateY(-6px);
    transition:max-height 320ms ease, opacity 220ms ease, transform 220ms ease;
    box-shadow:0 12px 30px rgba(0,0,0,0.12);
    z-index:110; /* keep nav panel under header controls */
    width:min(90vw, 360px);
    border-radius:10px;
    pointer-events:none;
    visibility:hidden;
  }
  .main-nav.open{max-height:480px;opacity:1;transform:none;pointer-events:auto;visibility:visible}
  .main-nav a{display:block;padding:12px 16px;width:100%;text-align:left;border-bottom:1px solid rgba(255,255,255,0.03)}

  .header-inner{flex-direction:row;align-items:center;gap:8px;padding:8px 0;position:relative}
  .header-top{order:0;width:auto;padding:6px 12px}
  /* keep inline container visible so panel can open; nav itself is collapsible via classes */
  .header-middle{order:2;width:auto;display:block;position:relative}
  .header-bottom{order:0;margin-left:auto;padding:6px 12px;display:flex;justify-content:flex-end}
  .logo .brand{font-size:20px}
}

/* Extra-small screens: keep brand + contact controls on one line up to 600px
   - header-top (logo) stays left, header-bottom (contacts) moves to the right on the same row
   - main navigation becomes the next row below (order:2) */
@media (max-width:600px){
  /* Small screens: stack header into two rows
     - first row: logo (top)
     - second row: contacts (phone/telegram/lang)
     - navigation panel follows below when opened */
  .header-inner{flex-direction:column;align-items:stretch;gap:6px;padding:6px 0}
  .header-top{order:0;width:100%;padding:6px 12px}
  .header-bottom{order:1;width:100%;padding:6px 12px;display:flex;justify-content:flex-end;gap:8px}
  .header-middle{order:2;width:100%;display:block;position:relative}
  .logo .brand{font-size:18px}
  /* ensure nav panel is full-width under header when opened */
  .main-nav{position:absolute;top:100%;left:0;right:0;width:100%;border-radius:0}
}
/* mobile nav */
.main-nav{display:flex;gap:12px}
.nav-toggle{display:none;background:none;border:0;font-size:20px}
.logo{display:flex;align-items:center;gap:8px}

/* Ensure brand text stays on one line and flex items can shrink properly
  - .brand: nowrap + ellipsis to avoid wrapping and overflow
  - nav-toggle stays visible (no shrinking) and is above other inline content */
.logo .brand{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0}
.nav-toggle{flex:0 0 auto;z-index:80}

/* Allow direct children of header-inner and container to shrink when space is tight
  prevents long words or large elements from overflowing their flex parents */
.header-inner > *, .container > *{min-width:0}
.hero{padding:calc(var(--space) * 3) 16px 60px;background:linear-gradient(180deg,#fff,#f7fbff)}
.hero h1{font-family:GropledBold,Arial;font-size:28px;color:var(--dark);margin:0 0 8px}
.btn{display:inline-block;padding:10px 18px;border-radius:6px;text-decoration:none}
.btn.primary{background:var(--med);color:#fff}
.advantages{
  padding:var(--space) 16px;
  /* subtle pale background that fits the site's palette */
  background: linear-gradient(180deg, #f6fbfd, var(--light));
}
.advantages .container{max-width:1200px;margin:0 auto}
.advantages h2{margin:0 0 18px;color:var(--dark);font-family:GropledBold,Arial;font-size:22px;text-align:center}
.advantages .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;align-items:start}
.advantages .card{background:#fff;padding:18px;border-radius:12px;display:flex;flex-direction:column;gap:8px;align-items:flex-start;box-shadow:0 10px 30px rgba(2,23,31,0.06);border:1px solid rgba(44,115,151,0.04);width:100%}
/* первый элемент (эмодзи-иконка) — крупнее и сверху */
.advantages .card > :first-child{font-size:28px;line-height:1;display:inline-block}
.advantages .card .icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(180deg,var(--med),#1f6b80);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.advantages .card h3{margin:2px 0 6px;font-family:GropledBold,Arial;font-size:16px;color:var(--dark);display:flex;align-items:center;gap:8px}
.advantages .card p{margin:0;color:#55696f;word-break:break-word;overflow-wrap:break-word;max-width:100%}

/* Hover / focus animation: subtle lift and highlight */
.advantages .card{
  transition: transform 220ms cubic-bezier(.2,.9,.2,1), box-shadow 220ms ease, border-color 220ms ease;
}
@media (hover: hover) and (pointer: fine) {
  .advantages .card:hover, .advantages .card:focus-within {
    transform: translateY(-8px);
    box-shadow: 0 18px 40px rgba(2,23,31,0.12);
    border-color: rgba(44,115,151,0.12);
  }
  .advantages .card:active{ transform: translateY(-3px); }
}
.advantages .card:focus-within{ outline: 2px solid rgba(44,115,151,0.08); outline-offset:6px }
.services{padding:calc(var(--space) - 8px) 16px}
.service-card{background:#fff;padding:12px;border-radius:12px;display:flex;gap:18px;align-items:stretch;box-shadow:0 6px 18px rgba(7,28,36,0.06)}
.service-card .service-media{flex:0 0 58%;max-width:58%}
.service-card .service-content{flex:1 1 42%;padding:14px;display:flex;flex-direction:column;justify-content:center}
.service-card h3{margin-top:0;margin-bottom:8px;font-family:GropledBold,Arial}
.service-card p{margin:0 0 10px;color:var(--dark)}
.service-card .price{font-weight:700;color:var(--med)}
.calculator{padding:calc(var(--space) - 10px) 16px;background:#f6fbfd}
.calc-wrap{display:flex;gap:16px;align-items:flex-start}
.calc-inputs label{display:block;margin-bottom:8px}
.total{font-weight:700;margin-top:10px}
.timeline{padding:0 16px}
.reviews{padding:var(--space) 30px}
.faq{padding:var(--space) 16px;background:var(--dark);color:#fff}
.faq h2{color:#fff;margin-bottom:16px}

/* Accordion styles themed like header */
.faq .accordion{max-width:900px;margin:0 auto;display:block;gap:12px}
.faq .accordion .item{border-bottom:1px solid rgba(255,255,255,0.04);padding:8px 0}
.faq .accordion .item button{background:transparent;border:0;color:#fff;font-weight:700;padding:14px 12px;width:100%;text-align:left;font-size:16px;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:space-between}
.faq .accordion .item button:focus{outline:2px solid rgba(255,255,255,0.08)}
.faq .accordion .item button .arrow{display:inline-block;transform:rotate(0);transition:transform 220ms ease}
.faq .accordion .item button[aria-expanded="true"] .arrow{transform:rotate(180deg)}
.faq .accordion .item .panel{max-height:0;overflow:hidden;transition:max-height 320ms ease,padding 220ms ease;color:#f3f7f8;background:rgba(255,255,255,0.02);padding:0 12px;border-radius:6px;margin-top:8px}
.faq .accordion .item .panel.open{padding:12px;border-radius:6px}
.faq .accordion .item .panel p{margin:0;color:#e7f0f2}
.contact{padding:var(--space) 16px;background:linear-gradient(180deg,var(--med),#1f6b80);color:#fff}
.contact h2{color:#fff}
.contact .container{max-width:900px;margin:0 auto}
.contact form{background:rgba(255,255,255,0.06);padding:18px;border-radius:10px;display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
.contact form label{display:block;color:#fff}
.contact form input,.contact form textarea,.contact form select{width:100%;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.03);color:#fff}
.contact form textarea{grid-column:1 / -1;min-height:100px}
.contact .btn.primary{background:#fff;color:var(--dark);grid-column:1 / -1;padding:12px 16px}
.contact .map{margin-top:12px;color:#e6f8fb}
.site-footer{background:var(--dark);color:#fff;padding:14px;align-items:center;display:flex;justify-content:center}
/* center footer brand and snippet */
.site-footer .container.footer-center{display:flex;flex-direction:column;align-items:center;gap:6px}
.site-footer .footer-brand{font-weight:700}
@media(max-width:700px){.hero h1{font-size:20px}.calc-wrap{flex-direction:column}}

/* Mobile nav consolidated rules */
@media(max-width:1330px){
  /* Duplicate mobile rules adjusted for consistent behaviour across file
     Ensure nav-toggle becomes visible on small screens. */
  .main-nav{
    display:flex;position:fixed;top:60px;left:0;right:auto;background:#002c3f;padding:6px 12px;flex-direction:column;
    max-height:0;overflow:hidden;opacity:0;transform:translateY(-6px);
    transition:max-height 320ms ease, opacity 220ms ease, transform 220ms ease;
    box-shadow:0 12px 30px rgba(0,0,0,0.12);
    z-index:10; /* ensure panel sits under header controls */
    width:min(90vw, 360px);
    border-radius:10px;
  }
  .main-nav.open{max-height:480px;opacity:1;transform:none}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.08);font-size:22px;width:44px;height:44px;border-radius:8px;cursor:pointer;padding:4px;box-shadow:0 2px 6px rgba(0,0,0,0.18)}
  .nav-toggle:focus{outline:2px solid rgba(255,255,255,0.2);outline-offset:3px}
  /* keep logo, phone and language above the sliding nav panel */
  .logo, .header-cta, .nav-toggle{position:relative;z-index:120}
  .logo .brand{position:relative;z-index:120}
  body.nav-open{overflow:hidden}
  .main-nav a{display:block;padding:12px 16px;width:100%;text-align:left;border-bottom:1px solid rgba(255,255,255,0.03)}
}
/* Modal for calculator */
.modal{position:fixed;inset:0;background:rgba(0,0,0,0.5);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;pointer-events:none;transition:opacity 240ms ease}
.modal.active{opacity:1;pointer-events:auto}
.modal .modal-body{background:#fff;border-radius:10px;padding:18px;max-width:900px;width:95%;max-height:90vh;overflow:auto;box-shadow:0 10px 40px rgba(0,0,0,0.3)}
.modal .modal-close{position:absolute;top:12px;right:18px;background:#fff;border:0;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}

/* Privacy modal tweaks to match calculator layout and improve readability */
.modal .privacy{max-width:840px;margin:0 auto;padding:12px 12px 18px;color:var(--dark);font-size:14px;line-height:1.6}
.modal .privacy h1{margin-top:0;font-size:20px}
.modal .privacy p, .modal .privacy li{color:var(--dark);line-height:1.6;margin-bottom:10px}
.modal .privacy ul{margin-left:18px;margin-bottom:12px}
.modal .privacy a{color:var(--med)}
.modal .privacy .note{font-size:13px;color:#6b7980;margin-top:6px}

/* Standalone privacy page (when opened at ?section=privacy) */
.privacy{max-width:920px;margin:0 auto;padding:32px 16px 48px;color:var(--dark);font-size:16px;line-height:1.7;font-family:Arial,Helvetica,sans-serif}
.privacy h1{margin-top:0;margin-bottom:16px;font-size:26px;font-weight:700;color:var(--dark)}
.privacy h2{margin:18px 0 10px;font-size:20px;color:var(--dark)}
.privacy p,.privacy li{margin:0 0 12px;color:var(--dark);line-height:1.7}
.privacy ul{margin:0 0 14px 20px;padding:0}
.privacy a{color:var(--med);text-decoration:underline}
.privacy .note{font-size:13px;color:#6b7980;margin-top:10px}
.privacy.container{display:block;max-width:920px;padding:32px 16px 48px;align-items:unset}

/* Cookie/consent banner */
.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:420px;margin:0 auto;background:rgba(7,62,73,0.95);color:#e9f5f8;padding:14px 14px 12px;border-radius:14px;box-shadow:0 8px 28px rgba(0,0,0,0.24);z-index:3000;display:none;gap:10px;flex-direction:column;font-size:14px;line-height:1.5}
.cookie-banner.show{display:flex}
.cookie-banner__title{font-weight:700;margin:0;color:#fff}
.cookie-banner__text{margin:4px 0 8px;color:#dcebf0}
.cookie-banner__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-start}
.cookie-banner__btn{border:none;border-radius:10px;padding:10px 14px;font-weight:700;cursor:pointer;font-size:14px}
.cookie-banner__btn.primary{background:#3fb3ce;color:#05313d}
.cookie-banner__btn.secondary{background:transparent;color:#dcebf0;border:1px solid rgba(255,255,255,0.35)}
@media(max-width:520px){.cookie-banner{left:12px;right:12px;padding:12px 12px 10px}.cookie-banner__actions{flex-direction:column;align-items:stretch}}

/* simple pop-in animations */
.animate-in{opacity:0;transform:translateY(12px);transition:opacity 420ms ease, transform 420ms ease}
.animate-in.in-view{opacity:1;transform:none}

/* Calculator modal styles */
.calc-root{max-width:880px;margin:8px auto 0;font-family:Arial,Helvetica,sans-serif}
.calc-root h3{margin:0 0 12px;font-family:GropledBold,Arial;color:var(--dark);font-size:20px}
.calc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px}
.calc-grid label{display:flex;flex-direction:column;font-weight:600;color:var(--dark);background:transparent}
.calc-grid input[type="number"],.calc-grid select{padding:10px;border-radius:8px;border:1px solid #e6eef5;background:#fbfdff}
.calc-grid input[type="text"],.calc-grid input[type="tel"],.calc-grid textarea{padding:10px;border-radius:8px;border:1px solid #e6eef5;background:#fbfdff}
.calc-grid textarea{min-height:80px;resize:vertical}
.calc-result{background:linear-gradient(90deg, rgba(44,115,151,0.06), rgba(179,221,246,0.02));padding:12px;border-radius:8px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.calc-result strong{font-size:20px;color:var(--med)}
.calc-actions{display:flex;gap:10px}
.calc-actions .btn{padding:10px 14px;border-radius:8px}
.calc-actions .btn.primary{background:var(--med)}
.calc-actions .btn{border:none;cursor:pointer}
.calc-root .muted{color:#6b7980;font-size:13px;margin-top:8px}

/* small screens: stack fields */
@media(max-width:700px){
	.calc-grid{grid-template-columns:1fr}
	.modal .modal-body{padding:12px}
}

/* Reviews layout improvements */
.carousel{position:relative;overflow:visible;min-height:420px}
.carousel .slide{position:absolute;left:0;top:0;width:100%;opacity:0;transform:translateX(18px);transition:opacity 600ms cubic-bezier(.2,.9,.2,1), transform 600ms cubic-bezier(.2,.9,.2,1);pointer-events:none;display:block;padding:6px 0}
.carousel .slide.active{opacity:1;transform:none;pointer-events:auto}

.slide-media{display:flex;align-items:stretch;gap:18px;max-width:1100px;margin:0 auto}
.rev-img{flex:0 0 58%;max-width:58%}
.rev-img img{width:100%;height:100%;max-height:420px;object-fit:cover;border-radius:8px;display:block}
.rev-overlay{flex:1 1 42%;display:flex;flex-direction:column;justify-content:center;padding:18px;background:linear-gradient(90deg, rgba(0,44,63,0.06), rgba(44,115,151,0.02));border-radius:8px}
.rev-overlay p{margin:0 0 12px;color:var(--dark);line-height:1.35;font-size:16px}
.rev-overlay .rev-author{color:var(--dark);font-weight:600;margin-top:6px}
.rev-stars{color:#f5b301;margin-bottom:10px;font-size:18px}

/* ===== BEFORE / AFTER SLIDER (FIXED) ===== */

.ba-slider{
  position:relative;
  width:100%;
  height:420px;
  overflow:hidden;
  border-radius:10px;
  touch-action:none;
}

.ba-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  user-select:none;
  pointer-events:none;
}

.ba-before{
  z-index:1;
}

.ba-after{
  z-index:2;
  clip-path: inset(0 50% 0 0);
}

.ba-handle{
  position:absolute;
  top:0;
  bottom:0;
  left:50%;
  width:4px;
  background:rgba(255,255,255,.7);
  transform:translateX(-50%);
  cursor:ew-resize;
  z-index:3;
  touch-action:none;
}

.ba-handle::after{
  content:'';
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:20px;
  height:20px;
  border-radius:50%;
  background:var(--med);
  box-shadow:0 4px 12px rgba(0,0,0,.2);
}

/* Performance & animation improvements */
/* Allow slides to flow so text and images can size correctly */
.carousel{padding-bottom:10px}
/* Image styles */
/* Service / general site images stay large and full-bleed */
.service-card img{width:100%;height:300px;object-fit:cover;display:block;border-radius:6px}

/* Legacy thumbnail rule removed to allow flexible review images (see .rev-img img) */

/* Hint to browser that these will be animated - helps with rendering smoother */
.carousel .slide, .hero h1, .btn{will-change:opacity,transform}

/* Responsive: stack service cards on small screens */
@media(max-width:1330px){
	.service-card{flex-direction:column}
	.service-card .service-media,.service-card .service-content{flex:1 1 auto;max-width:100%}
	.ba-slider{height:300px}
}

/* Reduce layout thrashing on inputs */
input,textarea,select{transition:box-shadow 150ms linear}

/* Full-width calculator section */
.calc-full-section{width:100%;padding:48px 12px;background:linear-gradient(180deg,#fff,#f6fbfd)}
.calc-full{max-width:1400px;margin:0 auto;padding:0 12px;width:100%}
.calc-card{width:100%;background:#fff;padding:28px;border-radius:12px;box-shadow:0 8px 30px rgba(15,40,55,0.06);display:flex;flex-direction:column;gap:14px}
.calc-title{margin:0;font-family:GropledBold,Arial;font-size:22px;color:var(--dark)}
.calc-sub{margin:0;color:#55696f}
.calc-inputs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.calc-inputs label{display:flex;flex-direction:column}
.calc-inputs input[type="number"],.calc-inputs select{padding:10px;border-radius:8px;border:1px solid #e6eef5;background:#fbfdff}
.calc-inputs .full-row{grid-column:1 / -1;display:flex;align-items:center;gap:8px}
.calc-actions-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.total{font-weight:800;font-size:18px}
.calc-buttons{display:flex;gap:10px}
.calc-note{font-size:13px;color:#6b7980;margin-top:6px}

@media(max-width:900px){
	.calc-inputs{grid-template-columns:1fr}
	.calc-actions-row{flex-direction:column;align-items:stretch}
	.calc-buttons{justify-content:stretch}
}

/* Process / How we work styles */
.process{padding:var(--space) 12px;background:linear-gradient(180deg,#fbfdff,#f6fbfd)}
.process h2{margin-bottom:18px;color:var(--dark)}
.process-steps{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.process-steps .step{background:#fff;border-radius:12px;padding:18px;display:flex;gap:14px;align-items:flex-start;box-shadow:0 10px 30px rgba(2,23,31,0.06);border:1px solid rgba(44,115,151,0.04)}
.process-steps .step-num{width:44px;height:44px;border-radius:10px;background:linear-gradient(180deg,var(--med),#1f6b80);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:GropledBold;font-size:18px}
.process-steps .step-body h4{margin:0;font-size:16px;color:var(--dark)}
.process-steps .step-body p{margin:8px 0 0;color:#55696f}

@media(max-width:900px){
	.process-steps{grid-template-columns:1fr}
	.process{padding:30px 12px}
}
/* animate-in for process steps: staggered entrance */
.process-steps .step.animate-in{opacity:0;transform:translateY(14px);transition:opacity 420ms ease, transform 420ms ease}
.process-steps .step.animate-in.in-view{opacity:1;transform:none}
.process-steps .step:nth-child(1){transition-delay:0ms}
.process-steps .step:nth-child(2){transition-delay:80ms}
.process-steps .step:nth-child(3){transition-delay:160ms}
.process-steps .step:nth-child(4){transition-delay:240ms}
.process-steps .step:nth-child(5){transition-delay:320ms}
.process-steps .step:nth-child(6){transition-delay:400ms}

.step-icon{width:20px;height:20px;margin-right:8px;flex-shrink:0;display:inline-block}
.process-steps .step-body{display:flex;align-items:center;gap:10px}

/* Placeholder slide media styling (removed inline styles) */
.slide-media.placeholder{background:#f0f4f6;padding:18px;border-radius:10px;display:flex;align-items:center;gap:16px}

/* Honeypot hidden field */
.hp-field{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* Service cards alternate layout: even cards flip media/content */
.services .grid{display:flex;flex-direction:column;gap:18px}
.service-card{display:flex;gap:18px;align-items:stretch}
.service-card .service-media{flex:0 0 58%;max-width:58%}
.service-card .service-content{flex:1 1 42%;padding:14px;display:flex;flex-direction:column;justify-content:center}
.service-card:nth-child(even){flex-direction:row-reverse}

/* Design tuned colors and shadow — consistent with site palette */
.card, .calc-card, .service-card{box-shadow:0 10px 30px rgba(2,23,31,0.06);border:1px solid rgba(44,115,151,0.04)}
.btn.primary{background:var(--med);color:#fff;box-shadow:0 6px 18px rgba(44,115,151,0.12)}
.btn{border-radius:8px;padding:10px 14px}

@media(max-width:900px){
	.service-card{flex-direction:column}
	.service-card .service-media,.service-card .service-content{flex:1 1 auto;max-width:100%}
}

/* Coverage map styles */
.coverage{padding:var(--space) 12px;background:linear-gradient(180deg,#fff,#f8fbfd)}
.coverage h2{margin-bottom:12px;color:var(--dark)}
.coverage-inner{max-width:1200px;margin:0 auto}
.coverage-map{width:100%;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px rgba(2,23,31,0.06);border:1px solid rgba(44,115,151,0.04)}
.coverage-contacts{margin-top:12px;color:#2c4f57;display:flex;gap:18px;align-items:center}
.coverage-contacts a{color:var(--med)}

@media(max-width:700px){
	.coverage-map{height:360px}
	.coverage-contacts{flex-direction:column;align-items:flex-start}
}

@media(min-width:1200px){
  .ba-slider{
    height:250px;
  }
}


