﻿@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600&family=Poppins:wght@600;700&display=swap');

:root{
  --blue:#1A9BEF;
  --blue-dark:#003A6E;
  --aqua:#58D1B4;
  --bg-light:#F2F7FA;
  --text:#222222;
  --white:#FFFFFF;
  --shadow:0 6px 18px rgba(0,0,0,.06);
  --radius:12px;
  --radius-btn:10px;
  --maxw:1200px;
  --wave-h:46px;
}

/* Reset / Normalize */
*{box-sizing:border-box}
*::before,*::after{box-sizing:inherit}
html,body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,ul,ol,dl{margin:0}
img{max-width:100%;display:block;height:auto}
button,input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;padding:0}

/* Base Typography */
html,body{height:100%;overflow-x:hidden}
body{
  font-family:'Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-size:clamp(1rem,0.4vw+0.85rem,1.125rem);
  line-height:1.65;
  color:var(--text);
  background:var(--white);
}
h1,h2,h3{font-family:'Poppins','Open Sans',Arial,Helvetica,sans-serif;color:var(--blue-dark);letter-spacing:.2px}
h1{font-size:clamp(2rem, 2.5vw + 1rem, 3.25rem);line-height:1.1;font-weight:700}
h2{font-size:clamp(1.5rem, 1.4vw + 0.9rem, 2.25rem);line-height:1.2;font-weight:700}
h3{font-size:clamp(1.25rem, 0.9vw + 0.8rem, 1.5rem);line-height:1.25;font-weight:600}
p{max-width:72ch}

/* Utilities */
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
@media (min-width: 768px){.container{padding:8px 20px !important}}
.section{position:relative;padding:56px 0}
/* Per-section background alternation */
#about{--section-bg:var(--white)}
#services{--section-bg:var(--bg-light)}
#why{--section-bg:var(--white)}
#testimonials{--section-bg:var(--bg-light)}
#areas{--section-bg:var(--white)}
#gallery{--section-bg:var(--bg-light)}
#contact{--section-bg:var(--white)}
.section{background:var(--section-bg,var(--white))}
/* Ensure anchor navigation accounts for fixed bars */
.section{scroll-margin-top:var(--anchor-offset, 0px)}



/* Hero special background with radial mesh, floating blobs and photo */
#home{--section-bg:var(--white);position:relative;isolation:isolate;
    min-height: 80vh; /* garante Ã¡rea visÃ­vel */
  background-image:
    linear-gradient(0deg, rgba(0,58,110,.42), rgba(0,58,110,.42)),
    radial-gradient(1200px 600px at 10% 10%, rgba(26,155,239,.12), transparent 60%),
    radial-gradient(800px 500px at 90% 20%, rgba(88,209,180,.10), transparent 60%),
    radial-gradient(900px 700px at 50% 120%, rgba(0,58,110,.08), transparent 60%),
    url('/assets/coffee-shop-small-business.webp'),
    linear-gradient(180deg, #ffffff 0%, #f8fcff 100%);
  background-size: 100% 100%, auto, auto, auto, cover, 100% 100%;
  background-position: center, center, center, center, center calc(50% + var(--hero-bg-offset, 0px)), center;
  background-repeat: no-repeat;
  display: flex;
}

/* Hero overlay removed per request */

.hero__inner{position:relative;z-index:1}
.hero__content{max-width:70ch;text-align:center;margin-inline:auto;position:relative;background:rgba(0,58,110,.42);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:16px;padding:20px 24px;box-shadow:0 10px 28px rgba(0,0,0,.18)}
.hero__title{color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.25);margin-bottom:clamp(8px,1.2vw,12px)}
.hero__subtitle{color:#eaf6ff;text-shadow:0 1px 8px rgba(0,0,0,.22);margin-bottom:clamp(8px,1.2vw,12px)}
.hero__desc{color:#f5fbff;opacity:.95;margin-bottom:clamp(10px,1.6vw,16px)}

/* BotÃµes na hero com contraste adequado */
#home .btn-outline,#home .btn--outline{background:rgba(255,255,255,.92);color:var(--blue-dark);border-color:transparent}
#home .btn-outline:hover,#home .btn--outline:hover{background:var(--blue);color:#fff}
.hero__actions{justify-content:center}

/* Subtle fade-up for hero content (no HTML changes) */
.is-ready #home .hero__title{animation:fadeUp .6s cubic-bezier(.22,.61,.36,1) .0s both}
.is-ready #home .hero__subtitle{animation:fadeUp .6s cubic-bezier(.22,.61,.36,1) .05s both}
.is-ready #home .hero__desc{animation:fadeUp .6s cubic-bezier(.22,.61,.36,1) .1s both}
.is-ready #home .hero__actions{animation:fadeUp .6s cubic-bezier(.22,.61,.36,1) .15s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* Extra highlight for primary CTA within hero */
#home .btn--primary{box-shadow:0 14px 36px rgba(26,155,239,.42)}
#home .btn--primary:hover{box-shadow:0 18px 44px rgba(26,155,239,.5)}

/* Page-load fade-up animation for hero */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
#home .hero__title,#home .hero__subtitle,#home .hero__desc,#home .hero__actions{opacity:0;transform:translateY(18px)}
html.is-ready #home .hero__title{animation:fadeUp .55s ease-out .05s both}
html.is-ready #home .hero__subtitle{animation:fadeUp .55s ease-out .15s both}
html.is-ready #home .hero__desc{animation:fadeUp .55s ease-out .25s both}
html.is-ready #home .hero__actions{animation:fadeUp .55s ease-out .35s both}
html.is-ready #home .hero__media{display:none}

@media (prefers-reduced-motion: reduce){
  #home .hero__title,#home .hero__subtitle,#home .hero__desc,#home .hero__actions{opacity:1 !important;transform:none !important}
}

/* Header / Nav */
.header{position:relative;margin-top:var(--announce-h,0px);z-index:40;background:rgba(255,255,255,.85);backdrop-filter:blur(8px) saturate(140%);box-shadow:var(--shadow);border-bottom:1px solid rgba(0,0,0,.04)}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0}

.header__logo{height:100px;width:auto;max-width:100%}

/* Desktop Navigation */
.nav--desktop{position:relative}
.nav__list{display:flex;align-items:center;gap:clamp(20px,2.2vw,28px)}
.nav__link{position:relative;padding:10px 2px;background-image:linear-gradient(var(--blue),var(--blue));background-size:0% 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .25s ease}
.nav__link:hover{background-size:100% 2px}
.nav__link[aria-current="page"]{background-size:100% 2px}

/* Mobile Menu Toggle Button */
.mobile-menu-toggle{display:none;position:relative;width:44px;height:44px;padding:0;border:none;background:transparent;cursor:pointer;z-index:45}
.mobile-menu-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:8px}
.mobile-menu-toggle__icon{position:relative;display:block;width:26px;height:2px;background:var(--blue-dark);border-radius:2px;transition:background-color 0.3s ease}
.mobile-menu-toggle__icon::before,
.mobile-menu-toggle__icon::after{content:'';position:absolute;left:0;width:100%;height:2px;background:var(--blue-dark);border-radius:2px;transition:transform 0.3s ease, top 0.3s ease, bottom 0.3s ease}
.mobile-menu-toggle__icon::before{top:-8px}
.mobile-menu-toggle__icon::after{bottom:-8px}

/* Animate to X when open */
.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon{background:transparent}
.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon::before{top:0;transform:rotate(45deg)}
.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon::after{bottom:0;transform:rotate(-45deg)}

/* Mobile Menu Drawer */
.mobile-menu{position:fixed;inset:0;z-index:100;pointer-events:none;visibility:hidden}
.mobile-menu.is-open{pointer-events:auto;visibility:visible}

/* Backdrop */
.mobile-menu__backdrop{position:absolute;inset:0;background:rgba(0,58,110,0.4);opacity:0;transition:opacity 0.3s ease;backdrop-filter:blur(0px)}
.mobile-menu.is-open .mobile-menu__backdrop{opacity:1;backdrop-filter:blur(2px)}

@media (prefers-reduced-motion: reduce){
  .mobile-menu__backdrop{transition:opacity 0.1s ease}
}

/* Drawer Panel */
.mobile-menu__drawer{position:absolute;top:0;right:0;bottom:0;width:min(320px, 85vw);background:#ffffff;box-shadow:-4px 0 24px rgba(0,0,0,0.15);display:flex;flex-direction:column;transform:translateX(100%);transition:transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-menu.is-open .mobile-menu__drawer{transform:translateX(0)}

@media (prefers-reduced-motion: reduce){
  .mobile-menu__drawer{transition:transform 0.1s ease}
}

/* Drawer Header */
.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #eef3f7;flex-shrink:0}
.mobile-menu__logo{height:50px;width:auto}
.mobile-menu__close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:none;background:transparent;color:var(--blue-dark);cursor:pointer;border-radius:8px;transition:background-color 0.2s ease, color 0.2s ease}
.mobile-menu__close:hover{background:var(--bg-light);color:var(--blue)}
.mobile-menu__close:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* Navigation List */
.mobile-menu__nav{flex:1;padding:24px 0;overflow-y:auto}
.mobile-menu__list{display:flex;flex-direction:column;gap:4px;padding:0 20px}
.mobile-menu__link{display:block;padding:14px 16px;font-family:'Open Sans',sans-serif;font-size:1.0625rem;font-weight:600;color:var(--blue-dark);border-radius:10px;transition:background-color 0.2s ease, color 0.2s ease, transform 0.1s ease}
.mobile-menu__link:hover{background:var(--bg-light);color:var(--blue);transform:translateX(4px)}
.mobile-menu__link:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
.mobile-menu__link:active{transform:translateX(2px)}

/* Actions Area */
.mobile-menu__actions{padding:20px;border-top:1px solid #eef3f7;display:flex;flex-direction:column;gap:12px;flex-shrink:0}
.mobile-menu__cta{display:flex;align-items:center;justify-content:center;min-height:48px;padding:14px 24px;background:var(--blue);color:#ffffff;font-family:'Poppins',sans-serif;font-size:1.0625rem;font-weight:600;border-radius:10px;text-align:center;box-shadow:0 4px 12px rgba(26,155,239,0.3);transition:background-color 0.2s ease, transform 0.1s ease, box-shadow 0.2s ease}
.mobile-menu__cta:hover{background:var(--aqua);color:var(--blue-dark);transform:translateY(-1px);box-shadow:0 6px 16px rgba(26,155,239,0.35)}
.mobile-menu__cta:active{transform:translateY(0);box-shadow:0 2px 8px rgba(26,155,239,0.25)}
.mobile-menu__cta:focus-visible{outline:2px solid var(--blue-dark);outline-offset:2px}

.mobile-menu__phone{display:flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:12px 24px;background:var(--bg-light);color:var(--blue-dark);font-weight:600;border-radius:10px;border:2px solid #e0eaf2;transition:background-color 0.2s ease, border-color 0.2s ease}
.mobile-menu__phone:hover{background:#ffffff;border-color:var(--blue)}
.mobile-menu__phone:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* Prevent body scroll when menu is open */
body.mobile-menu-open{overflow:hidden;position:fixed;width:100%;height:100%}

/* Responsive Behavior */
@media (max-width: 1023px){
  .mobile-menu-toggle{display:flex;align-items:center;justify-content:center}
  .nav--desktop{display:none}
  .header__cta--desktop{display:none}
  .header .header__cta{display:none}
  .header__logo{height:64px}
}

@media (max-width: 767px){
  .header__logo{height:56px}
  .header__inner{padding:10px 20px !important;}
  .announce__inner{padding:10px 20px !important;}
}

@media (max-width: 480px){
  .header__logo{height:50px}
  .header__inner{padding:8px 0;gap:12px}
  .mobile-menu-toggle{width:40px;height:40px}
  .hero__socialproof {flex-direction:column;gap:4px}
  
  }


@media (min-width: 1024px){
  .mobile-menu{display:none}
}

/* Buttons */
.btn{inline-size:fit-content;display:inline-flex;align-items:center;justify-content:center;gap:12px;font-weight:600;letter-spacing:.3px;border-radius:var(--radius-btn);transition:transform .2s ease, box-shadow .2s ease, background-color .2s ease,color .2s ease;border:1px solid transparent;cursor:pointer;text-decoration:none;line-height:1.1}
.btn{font-size:clamp(1rem,0.6vw+0.85rem,1.125rem);padding:18px 30px}

/* Support both modifier syntaxes */
.btn-primary,.btn--primary{background:var(--blue);color:#fff;box-shadow:0 8px 20px rgba(26,155,239,.28);background-image:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0))}
.btn-primary:hover,.btn--primary:hover{background:var(--aqua);color:var(--blue-dark);transform:translateY(-1px) scale(1.01);box-shadow:0 12px 28px rgba(26,155,239,.32)}
.btn-primary:active,.btn--primary:active{transform:none;box-shadow:0 4px 12px rgba(26,155,239,.2)}
.btn-outline,.btn--outline{background:linear-gradient(180deg,#ffffff 0%,#f9fcff 100%);color:var(--blue-dark);border:2px solid var(--blue);box-shadow:0 4px 12px rgba(0,0,0,.05)}
.btn-outline:hover,.btn--outline:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 10px 24px rgba(26,155,239,.22)}
.btn:focus-visible{box-shadow:0 0 0 4px rgba(26,155,239,.25)}

/* Announcement Bar */
.announce{position:fixed;left:0;right:0;top:0;z-index:50;background:var(--blue-dark);color:#fff}
.announce__inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}
.announce__text{margin:0;font-weight:700;font-size:clamp(0.875rem, 2vw, 1rem)}
.announce__sms{color:#fff;text-decoration:underline;white-space:nowrap;font-size:clamp(0.875rem, 2vw, 1rem)}
.phone-announcment{display:flex;flex-direction:row;align-items:center;gap:8px}
.phone-announcment img{height:18px}

@media (max-width: 480px){
  .announce__inner{gap:8px}
  .announce__text{font-size:0.8125rem}
  .announce__sms{font-size:0.8125rem}
  .phone-announcment img{height:16px}
}

/* ===== HERO layout ===== */
.hero{position:relative;padding:0;min-height: 80vh}
.hero .container{position:relative;z-index:2;min-height: 80vh;display:grid;place-items:center}
.hero__media{display:none}
.hero__media picture,.hero__media img{width:100%;height:100%;display:block}
.hero__media img{object-fit:cover;object-position:65% 35%;filter:saturate(1.05)}

.hero__panel{max-width:780px;margin:0 auto;background:rgba(255,255,255,.16);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.28);border-radius:18px;padding:clamp(18px,3.2vw,28px);color:#fff;box-shadow:0 20px 60px rgba(0,0,0,.25);text-align:center;display:flex;flex-direction:column;align-items:center}
.hero__panel .hero__content{background:transparent;box-shadow:none;padding:0;-webkit-backdrop-filter:none;backdrop-filter:none}
.hero__panel .hero__title{color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.35);font-size:clamp(2rem,2.6vw + 1rem,3.2rem);line-height:1.1;margin:8px 0 6px}
.hero__sub{opacity:.95;margin:4px 0}
.hero__micro{opacity:.9;margin-bottom:clamp(10px,1.5vw,16px)}
.hero__trust{display:flex;flex-wrap:wrap;gap:8px 10px;margin-bottom:8px}
.pill{font:600 .9rem/1 'Poppins',sans-serif;color:#003A6E;background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.9);border-radius:999px;padding:6px 10px}
.hero__ctas{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.hero__trust,.hero__ctas,.hero__socialproof{justify-content:center}
.hero__call{border-color:#fff;color:#fff}
.hero__call:hover{background:#fff;color:#003A6E}
.hero__socialproof{display:flex;align-items:center;gap:10px;margin-top:12px}
.hero__socialproof .stars{display:inline-flex;gap:4px;align-items:center}
.hero__socialproof .stars .star{width:18px;height:18px;display:inline-block}
.hero__socialproof .label{color:#fff;opacity:.95}
.hero__badge{position:absolute;top:18px;left:18px;z-index:1;background:rgba(255,255,255,.9);color:#003A6E;font-weight:700;border-radius:999px;padding:8px 12px;border:1px solid rgba(0,0,0,.06);box-shadow:0 10px 20px rgba(0,0,0,.08)}

@media (max-width:768px){
  .hero{padding:40px 0}
  .hero .container{min-height:auto}
  .hero__panel{margin-top:0;padding:20px 16px;border-radius:14px;width:100%}
  .hero__content{text-align:center}
  .hero__title{font-size:clamp(1.75rem, 5vw, 2.25rem)}
  .hero__subtitle{font-size:clamp(1rem, 3vw, 1.125rem)}
  .hero__desc{font-size:clamp(0.9rem, 2.5vw, 1rem)}
  .pill{font-size:.85rem;padding:5px 9px}
  .hero__ctas{flex-direction:column;gap:8px;width:100%}
  .hero__cta{width:100%;justify-content:center}
}

/* Hero background is handled on #home with image + gradients */

/* About */

.about .container{display:grid;gap:clamp(16px,2vw,24px);grid-template-columns:1fr}
@media(min-width:1024px){.about .container{grid-template-columns:1.05fr .95fr}}
.about .container>*{grid-column:1}
/* Override for dedicated about-us grid: 2 columns on desktop */
.about .container.about-us{display:grid;gap:clamp(16px,2vw,24px);grid-template-columns:1fr}
@media(min-width:1024px){.about .container.about-us{grid-template-columns:1fr 1fr}}
.about .container.about-us > *{grid-column:auto}

/* Image positioning for responsive */
.about__image-tablet{display:none}
.about__image-tablet img{width:100%;height:auto;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.08)}

/* Mobile: hide tablet image, show grid-2 at bottom */
@media(max-width:766px){
  .about__image-tablet{display:none}
  .about .container.about-us .grid-2{display:block}
}

/* Tablet: show image between badges and CTA, hide grid-2 */
@media(min-width:768px) and (max-width:1023px){
  .about__image-tablet{display:block;margin:20px auto;max-width:450px}
  .about__image-tablet img{width:100%;height:auto}
  .about .container.about-us .grid-2{display:none}
}

/* Desktop: hide tablet image, show grid-2 in column */
@media(min-width:1024px){
  .about__image-tablet{display:none}
  .about .container.about-us .grid-2{display:block}
}
.about__badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;margin-bottom:32px}
/* Highlighted badges with icons */
.about__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
  color:var(--blue-dark);
  border:1px solid #e6edf3;border-radius:999px;
  padding:10px 14px;font-weight:600;
  box-shadow:0 8px 18px rgba(0,0,0,.06)
}
.about__badge:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(0,0,0,.08)}
.about__badge::before{
  content:"";display:inline-block;width:18px;height:18px;flex:0 0 18px;
  background:linear-gradient(90deg,var(--aqua),var(--blue));
  -webkit-mask:center/contain no-repeat;mask:center/contain no-repeat
}
/* Map each badge to its SVG icon by order */
.about__badges .about__badge:nth-child(1)::before{ -webkit-mask-image:url("./Licensed%20%26%20Insured.svg"); mask-image:url("./Licensed%20%26%20Insured.svg"); }
.about__badges .about__badge:nth-child(2)::before{ -webkit-mask-image:url("./Eco-Friendly.svg"); mask-image:url("./Eco-Friendly.svg"); }
.about__badges .about__badge:nth-child(3)::before{ -webkit-mask-image:url("./Pet%20Friendly.svg"); mask-image:url("./Pet%20Friendly.svg"); }
.about__badges .about__badge:nth-child(4)::before{ -webkit-mask-image:url("./Satisfaction%20Guaranteed.svg"); mask-image:url("./Satisfaction%20Guaranteed.svg"); }
.about__title{margin-bottom:clamp(10px,1.6vw,16px)}
.about__content{display:grid;gap:clamp(10px,1.2vw,14px); text-align: start;}
/* Centered tagline inside About */
.about__tagline{ text-align:start; margin-inline:auto }

.about-us {
  display: flex;
}

/* Services */
.services__grid{display:grid;gap:20px}
@media(min-width:640px){.services__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services__grid{grid-template-columns:repeat(3,1fr)}}
.service{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);border-radius:14px;box-shadow:0 0px 5px rgba(0,0,0,.06);padding:24px;border:1px solid rgba(0,0,0,.05);transition:box-shadow .2s ease, transform .2s ease;min-height:360px;display:flex;flex-direction:column}
.service:hover{box-shadow:0 0px 13px rgba(0,0,0,.08);transform:translateY(-2px)}
.service .service__title{position:relative;padding-left:36px}
.service .service__title::before{content:"";position:absolute;left:0;top:2px;width:24px;height:24px;background:linear-gradient(180deg,var(--aqua),var(--blue));}
/* Service card image */
.service__img{width:100%;height:180px;object-fit:cover;border-radius:10px;margin-bottom:12px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}

.services__title {
  text-align: center;
}
/* Services carousel (horizontal) */
.services__slider{margin-top:12px;position:relative}
.services__viewport{overflow:hidden;position:relative; padding: 12px 0px;}
.services__track{display:flex;gap:var(--svc-gap,16px);align-items:stretch;scroll-behavior:smooth;position:relative;flex-wrap:nowrap}
.services__track{will-change:transform}
.services__slide{flex:0 0 100%;width:100%}
@media(min-width:768px){.services__slide{flex-basis:calc((100% - var(--svc-gap,16px)) / 2);width:calc((100% - var(--svc-gap,16px)) / 2)}}
@media(min-width:1024px){.services__slide{flex-basis:calc((100% - (2 * var(--svc-gap,16px))) / 3);width:calc((100% - (2 * var(--svc-gap,16px))) / 3)}
.services__btn--next {
  margin-right: -10px;
}
}
.services__controls{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;gap:10px;pointer-events:none;z-index:2}
.services__btn{background:var(--blue-dark);color:#fff;border:0;border-radius:999px;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(26,155,239,.25);cursor:pointer;pointer-events:auto}
.services__btn:hover{background:var(--aqua);color:var(--blue-dark)}
.services__btn--prev{margin-left:-20px}
.services__btn--next{margin-right:-20px}
.services__btn[disabled]{opacity:.45;cursor:not-allowed;background:#cfe7f7;color:#fff;box-shadow:none}
.services__btn[disabled]:hover{background:#cfe7f7;color:#fff}

/* Progress bar for mobile/tablet */
.services__progress{display:none;width:100%;height:4px;background:#E5F4FB;border-radius:999px;margin-top:20px;overflow:hidden}
.services__progress-bar{height:100%;background:var(--blue);border-radius:999px;transition:width 0.3s ease;width:0}

/* Show progress bar and hide nav buttons on mobile/tablet */
@media(max-width:1023px){
  .services__progress{display:block}
  .services__controls{display:none}
}

/* Service icons via mask-image per item */
.services__item:nth-child(1) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 3l9 8h-3v9h-5v-6H11v6H6v-9H3l9-8z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 3l9 8h-3v9h-5v-6H11v6H6v-9H3l9-8z'/></svg>") center/contain no-repeat; }
.services__item:nth-child(2) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M20 8h-3V4H7v4H4l-1 2v10h18V10l-1-2zM9 6h6v2H9V6zm10 12H5v-6h14v6z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M20 8h-3V4H7v4H4l-1 2v10h18V10l-1-2zM9 6h6v2H9V6zm10 12H5v-6h14v6z'/></svg>") center/contain no-repeat; }
.services__item:nth-child(3) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M16 11V5h-2v6h-2l3 4 3-4h-2zM6 19h12v2H6v-2zM4 3h16v2H4V3z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M16 11V5h-2v6h-2l3 4 3-4h-2zM6 19h12v2H6v-2zM4 3h16v2H4V3z'/></svg>") center/contain no-repeat; }
.services__item:nth-child(4) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 5h16v14H4zM6 7v10h12V7H6zm3 2h6v2H9V9z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 5h16v14H4zM6 7v10h12V7H6zm3 2h6v2H9V9z'/></svg>") center/contain no-repeat; }
.services__item:nth-child(5) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M3 5h18v2H3V5zm0 6h18v2H3v-2zm0 6h18v2H3v-2z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M3 5h18v2H3V5zm0 6h18v2H3v-2zm0 6h18v2H3v-2z'/></svg>") center/contain no-repeat; }
.services__item:nth-child(6) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 7h16v10H4V7zm2 2v6h12V9H6z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M4 7h16v10H4V7zm2 2v6h12V9H6z'/></svg>") center/contain no-repeat; }
.services__item:nth-child(7) .service__title::before{ -webkit-mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 6a6 6 0 100 12 6 6 0 000-12zM2 12h4m12 0h4M12 2v4m0 12v4'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 6a6 6 0 100 12 6 6 0 000-12zM2 12h4m12 0h4M12 2v4m0 12v4'/></svg>") center/contain no-repeat; }

/* Service header: icon above title (replaces pseudo icons) */
.service__head{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin:6px 0}
.service__icon{width:40px;height:40px;object-fit:cover;border-radius:8px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.service .service__title{padding-left:0}
.service .service__title::before{content:none}

/* Why */
.why__grid{display:grid;gap:20px;justify-items:center}
@media(min-width:768px){.why__grid{grid-template-columns:repeat(3,1fr)}}
.why__item{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.06);padding:24px;border:1px solid rgba(0,0,0,.05);transition:box-shadow .2s ease, transform .2s ease;text-align:center;color:var(--text)}
.why__item:hover{box-shadow:0 16px 36px rgba(0,0,0,.08);transform:translateY(-2px)}
.why__item-title{position:relative;padding-left:0}
.why__item-title::before{display:none;content:"";position:absolute;left:0;top:4px;width:18px;height:18px;background:var(--aqua);
  -webkit-mask: radial-gradient(circle at 50% 50%, #000 60%, transparent 61%);
  mask: radial-gradient(circle at 50% 50%, #000 60%, transparent 61%);border-radius:50%;}
.why__highlight{margin-top:16px;font-style:italic; color: #fff; text-align: center;}
/* Section background image + darker overlay for contrast (similar to hero) */
#why{position:relative;background-image:linear-gradient(180deg, rgba(0,58,110,.82), rgba(0,58,110,.68) 55%, rgba(0,58,110,.5)), url("./what%20make%20us%20different.webp");background-position:center;background-size:cover;background-repeat:no-repeat}
/* Bigger vertical padding */
#why.section{padding:clamp(140px,10vw,200px) 0}
/* Center title/subtitle + light text */
.why__title{ text-align:center; color:#ffffff }
.why__subtitle,.why__desc{ text-align:center; margin-inline:auto; color:#eaf6ff }
.why-content {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Testimonials */
.testimonials__list{display:grid;gap:16px}
/* Make each review card equal height */
.testimonials__item{display:flex}
@media(min-width:768px){.testimonials__list{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1200px){.testimonials__list{grid-template-columns:repeat(3,1fr)}}
.testimonial{position:relative;background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.06);padding:24px;border:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;flex:1}
.testimonial__quote{margin-top:auto}
.testimonial::before{content:'\201C';position:absolute;top:8px;right:16px;font-size:72px;line-height:1;color:#000;opacity:.06;pointer-events:none}
.testimonial__stars{background:linear-gradient(90deg,var(--aqua),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.1em;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace}
.testimonial__meta{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.testimonial__stars{display:inline-flex;gap:4px;align-items:center;background:none;color:inherit;-webkit-background-clip:initial;background-clip:initial}
.testimonial__stars .star{width:16px;height:16px;display:inline-block}
.testimonial{transition:transform .2s ease, box-shadow .2s ease}
.testimonial:hover,.testimonial.is-hover{box-shadow:0 16px 36px rgba(0,0,0,.08);transform:translateY(-2px)}
.testimonials__more .link{position:relative;padding-right:18px}
.testimonials__more .link::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:12px;height:12px;background:currentColor;opacity:.9;
  -webkit-mask: url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M10 17l5-5-5-5v10z'/></svg>") center/contain no-repeat;
  mask: url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M10 17l5-5-5-5v10z'/></svg>") center/contain no-repeat;}

/* Areas */
#service-map {
  z-index: 1;
}
.areas__map{margin-top:12px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.areas__img{width:100%;aspect-ratio:16/9;object-fit:cover}
.areas__cap{text-align:center;font-size:.95em;padding:8px;color:#4a4a4a;background:#fff}
.areas__leaflet{margin-top:16px;height:420px;border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
@media (min-width:1024px){.areas__leaflet{height:520px}}
.area-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
} 

@media (max-width: 1024px) {
  .area-content {
    grid-template-columns: 1fr;
  }
}
/* Hide visible caption below the map; keep img alt for SEO */
#areas .areas__cap{display:none}
/* Align and space content in Areas section */
.area-grid-2{display:flex;flex-direction:column;align-items:start;text-align:center; justify-content: center;}
.areas__title{text-align:center;margin-bottom:8px}
.areas__desc{text-align:center;margin:6px 0 14px;max-width:60ch}
#areas .contact__list{display:flex;flex-direction:column;align-items:start;gap:10px;margin-top:12px}
#areas .contact__item{padding-left:0;text-align:center}
#areas .contact__item::before{display:none}
#areas .areas__cta{margin-top:8px}
.area-grid-2 h2, .area-grid-2 p {
  text-align: start;
}
.contact__list li {
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
}
.contact__list li img {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}
.contact__list li a{
  text-decoration: none;

}

/* Contact */
/* Light background to separate the section */
#contact{background:
  radial-gradient(800px 400px at 15% -10%, rgba(26,155,239,.08), transparent 60%),
  radial-gradient(700px 350px at 90% 110%, rgba(88,209,180,.08), transparent 60%),
  #F9FBFE}

/* ===== Contact grid ===== */
.contact__grid{display:grid;gap:clamp(20px,3vw,32px);grid-template-columns:1fr;align-items:start}
@media (min-width:1024px){.contact__grid{grid-template-columns:minmax(0,0.6fr) minmax(0,0.4fr)}}
.contact__left > * + *{margin-top:clamp(12px,1.2vw,16px)}
.form__field{display:flex;flex-direction:column;gap:6px}
.form__field--check {
  display: flex;
  flex-direction: row;
}
.form__label{font-weight:600}
/* ===== Steps card (dark) ===== */
.contact__steps{position:relative;background:linear-gradient(180deg,#0C2F54 0%,#003A6E 100%);color:#fff;border-radius:16px;box-shadow:0 16px 40px rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.08);padding:clamp(16px,2vw,24px)}
.contact__steps-title{margin:0 0 clamp(10px,1.2vw,14px);font-weight:700;color:#fff;font-size:clamp(1.25rem,0.9vw + 0.8rem,1.5rem)}
.contact__steps-list{position:relative;counter-reset:step;display:grid;gap:12px;margin:0 0 clamp(14px,1.5vw,18px);padding:0;list-style:none}
/* timeline connector */
.contact__steps-list::before{content:"";position:absolute;left:22px;top:6px;bottom:6px;width:2px;background:rgba(255,255,255,.25)}
.contact__step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding-left:8px}
.contact__step-badge{position:relative;z-index:1;width:32px;height:32px;display:inline-grid;place-items:center;border-radius:50%;background:#58D1B4;color:#0C2F54;font-weight:700;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.contact__step-content strong{display:block;color:#fff}
.contact__step-content p{margin:2px 0 0 0;color:rgba(255,255,255,.92);font-size:clamp(.95rem,.3vw + .85rem,1rem);line-height:1.55}
.contact__steps-cta{margin-top:8px;width:fit-content;border:2px solid #58D1B4;color:#58D1B4;background:transparent}
.contact__steps-cta:hover{background:#58D1B4;color:#003A6E}
/* focus styles for accessibility */
.contact__steps a:focus-visible,.contact__steps button:focus-visible{outline:3px solid #58D1B4;outline-offset:2px}
/* ===== Photo collage ===== */
.contact__shots{position:relative;margin:clamp(14px,1.6vw,20px) 0 0;min-height:160px}
.contact__shot{border-radius:12px;display:block;width:72%;box-shadow:var(--shadow);object-fit:cover;border:4px solid rgba(255,255,255,.9)}
.contact__shot--main{aspect-ratio:4/3}
.contact__shot--secondary{position:absolute;right:0;bottom:-6%;width:55%;aspect-ratio:4/3;transform:translateY(0)}
@media (min-width:1024px){.contact__steps{position:sticky;top:96px}}

/* Subtle vertical divider between columns (desktop only) */
@media (min-width:1024px){
  .contact__grid{position:relative}
  
}

/* Optional trust badges (if present in markup) */
.contact__trust{display:flex;flex-wrap:wrap;gap:10px 14px;margin-top:12px;color:rgba(255,255,255,.92);font-size:.95rem}
.contact__trust-item{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}
.contact__trust-dot{width:8px;height:8px;border-radius:50%;background:#58D1B4}
/* Layout for contact form fields */
.contact__form{display:grid;gap:16px}
@media(min-width:768px){
  .contact__form{grid-template-columns:repeat(10,1fr);column-gap:16px}
  /* Default: full width */
  .contact__form .form__field{grid-column:1/-1}
  /* 1) First/Last Name -> 50% each */
  .contact__form .form__field:has(#firstName){grid-column:1/span 5}
  .contact__form .form__field:has(#lastName){grid-column:6/span 5}
  /* 2) Email 60% + Phone 40% */
  .contact__form .form__field:has(#email){grid-column:1/span 6}
  .contact__form .form__field:has(#phone){grid-column:7/span 4}
  /* 3) Type of Cleaning + Date -> 50% each */
  .contact__form .form__field:has(#service){grid-column:1/span 5}
  .contact__form .form__field:has(#date){grid-column:6/span 5}
  /* 4) Details (message) and consent/actions full width */
  .contact__form .form__field:has(#message),
  .contact__form .form__field--check,
  .contact__form .form__actions{grid-column:1/-1}
}
/* Map .form__control to existing inputs/selects/textarea */
.form__control,
.form__input,
.form__select,
.form__textarea{padding:14px;border:1px solid #e6edf3;border-radius:10px;background:#fff;box-shadow:var(--shadow)}
.form__control:focus,.form__input:focus,.form__select:focus,.form__textarea:focus{outline:3px solid var(--aqua);border-color:transparent;box-shadow:0 0 0 4px rgba(26,155,239,.25)}

/* Date input - show placeholder text on mobile */
.form__input[type="date"]{color:#1f2937}
.form__input[type="date"]::-webkit-datetime-edit{color:#6b7280}
.form__input[type="date"]:focus::-webkit-datetime-edit{color:#1f2937}

.form__row{display:grid;gap:16px}
@media(min-width:768px){.form__row{grid-template-columns:repeat(2,1fr)}}
.field-error{color:#b00020;font-size:.9em;margin-top:6px;display:none}
.form__success{position:relative;background:#e9f9f3;color:#116a4a;border:1px solid #b7efdb;padding:12px 12px 12px 36px;border-radius:10px;display:none;margin-bottom:12px}
.form__success::before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;background:#16a085;
  -webkit-mask: url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>") center/contain no-repeat;
  mask: url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>") center/contain no-repeat;}
.contact__details{background:#fff;border:1px solid #eef3f7;border-radius:12px;box-shadow:var(--shadow);padding:24px}
.contact__item{position:relative;padding-left:22px}
.contact__item::before{content:"";position:absolute;left:0;top:.6em;width:10px;height:10px;border-radius:50%;background:linear-gradient(180deg,var(--aqua),var(--blue))}
.form__actions{margin-top:16px;display:flex;gap:14px;flex-wrap:wrap}

/* Gallery */
.gallery__viewport{overflow-x:auto;overflow-y:hidden;position:relative;-webkit-overflow-scrolling:touch;-ms-overflow-style:none;scrollbar-width:none}
.gallery__track{display:flex;gap:16px;scroll-behavior:smooth}
.gallery__slide{min-width:80%;max-width:80%;border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.05)}
@media(min-width:768px){.gallery__slide{min-width:48%;max-width:48%}}
@media(min-width:1024px){.gallery__slide{min-width:32%;max-width:32%}}
.gallery__img{width:100%;height:100%;object-fit:cover;display:block;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.gallery__video{width:100%;height:auto;display:block;background:#000}
.gallery__controls{display:flex;gap:10px;justify-content:center;margin-top:12px}
.gallery__btn{background:var(--blue);color:#fff;border:0;border-radius:999px;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(26,155,239,.25)}
.gallery__btn:hover{background:var(--aqua);color:var(--blue-dark)}

/* Progress bar for mobile/tablet */
.gallery__progress{display:none;width:100%;max-width:400px;height:4px;background:#E5F4FB;border-radius:999px;margin:16px auto 0;overflow:hidden}
.gallery__progress-bar{height:100%;background:var(--blue);border-radius:999px;transition:width 0.3s ease;width:0}

/* Show progress bar and hide nav buttons on mobile/tablet */
@media(max-width:1023px){
  .gallery__progress{display:block}
  .gallery__controls{display:none}
}

.gallery-content{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}
.gallery__title,.gallery__desc{text-align:center;margin-top:12px}
/* Hide native horizontal scrollbar while preserving scroll */
.gallery__viewport{scrollbar-width:none}
.gallery__viewport::-webkit-scrollbar{height:0}
.gallery__viewport::-webkit-scrollbar-track{background:#e6edf3;border-radius:999px}
.gallery__viewport::-webkit-scrollbar-thumb{background:var(--blue);border-radius:999px}
/* Captions for slides */
.gallery__cap{
  font-size:0.875rem;
  line-height:1.4;
  padding:12px 16px;
  color:#5a6c7d;
  text-align:center;
  background:#f8fafb;
  border-top:1px solid #e8eef3;
  font-family:'Open Sans',sans-serif;
  font-weight:400;
}
@media(max-width:767px){
  .gallery__cap{font-size:0.8125rem;padding:10px 12px}
}

/* Gallery: Before/After Compare (optional) */
.gallery__compare{position:relative}
.gallery__compare-img{display:block;width:100%;height:auto}
.gallery__compare-after{position:absolute;inset:0;overflow:hidden}
.gallery__compare-after img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gallery__compare-range{position:absolute;left:12px;right:12px;bottom:12px}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.8);display:none;align-items:center;justify-content:center;z-index:100}
.lightbox{backdrop-filter:blur(6px)}
.lightbox.is-open{display:flex; flex-direction: column;}
.lightbox__img{max-width:90vw;max-height:80vh;border-radius:var(--radius);box-shadow:0 8px 28px rgba(0,0,0,.45)}
.lightbox__video{max-width:90vw;max-height:80vh;border-radius:var(--radius);box-shadow:0 8px 28px rgba(0,0,0,.45);background:#000}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(255,255,255,.92);border:0;border-radius:10px;padding:8px 12px;cursor:pointer;font-size:1.25rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;transition:all 0.2s ease}
.lightbox__close:hover,.lightbox__nav:hover{background:rgba(255,255,255,1);transform:scale(1.05)}
.lightbox__close{top:16px;right:16px;font-weight:700}
.lightbox__nav--prev{left:16px}
.lightbox__nav--next{right:16px}
.lightbox__cap{color:#fff;margin-top:12px;text-align:center;opacity:.9;font-size:.95em}

/* Footer */
.footer{background:linear-gradient(180deg,#0b2f54,#003A6E);color:#fff;position:relative}
.footer::before{content:"";position:absolute;left:0;right:0;top:-1px;height:var(--wave-h);background:
  url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'>\
    <path fill='%23003A6E' d='M0,0 C240,96 480,0 720,64 C960,128 1200,32 1440,96 L1440,0 L0,0 Z'/>\
  </svg>") center/100% 100% no-repeat}
.footer__inner{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;padding:20px 0}
.footer a{color:#fff;text-decoration:underline}
.footer a:hover{color:var(--aqua)}
.footer__list{display:flex;gap:12px;flex-wrap:wrap}
.footer__logo{height:60px;width:auto}
.footer-content {
  display: flex;
  justify-content: space-between;
}

/* Accessibility */
:focus-visible{outline:3px solid var(--aqua);outline-offset:2px}
.link{text-decoration:underline}

/* Back-to-top button (created dynamically) */
.to-top{position:fixed;right:20px;bottom:24px;width:44px;height:44px;border-radius:999px;border:0;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.18);opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .2s ease, transform .2s ease;z-index:90}
.to-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.to-top:hover{background:var(--aqua);color:var(--blue-dark)}
.to-top:focus-visible{box-shadow:0 0 0 4px rgba(26,155,239,.25)}

/* Motion preferences */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
}

/* Global spacing refinements */
.section > .container > h2{margin-bottom:clamp(12px,2vw,20px)}
.services__actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:clamp(14px,1.8vw,24px); justify-content: center;}
.testimonials__more{margin-top:clamp(8px,1.2vw,12px)}

/* Subtle reveal-on-scroll effect */
.will-reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease, transform .5s ease}
.is-revealed{opacity:1;transform:none}

/* ===== Footer ===== */
.site-footer{background:#F2F7FA;margin-top:clamp(32px,6vw,72px);color:var(--text)}
/* Top band */
.site-footer__top{background:linear-gradient(180deg, rgba(0,58,110,.92) 0%, rgba(0,58,110,.88) 100%), linear-gradient(180deg,#2F8C8A 0%, #2F8C8A 100%);color:#fff;padding:clamp(28px,4vw,48px) 0}
/* Footer container - max 1024px centered */
.site-footer .container{max-width:1200px !important;margin:0 auto;padding:0 20px}
@media(min-width:768px){
  .site-footer .container{padding:0 32px}
}
.site-footer__grid{display:grid;gap:clamp(20px,3vw,36px);grid-template-columns:1fr;justify-items:center;text-align:center}
@media(min-width:900px){.site-footer__grid{grid-template-columns:1.2fr 1fr 1fr;align-items:start;justify-items:start;text-align:left}}
.site-footer__brand{display:flex;flex-direction:column;justify-content:center;align-items:center}
@media(min-width:900px){.site-footer__brand{align-items:flex-start}}
.site-footer__logo{max-height:100px;width:auto;display:block;margin:0 0 10px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}
.site-footer__note{opacity:.95;margin:6px 0 0}
.site-footer__title{font-weight:700;margin:0 0 10px;color:#fff;font-size:clamp(1rem,.4vw + .95rem,1.1rem)}
.site-footer__links{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.site-footer__links a{color:rgba(255,255,255,.95);text-decoration:none}
.site-footer__links a:hover,.site-footer__links a:focus-visible{color:#58D1B4;text-decoration:underline;outline:none}
.site-footer__contact-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.site-footer__contact-list a{color:rgba(255,255,255,.95);text-decoration:none}
.site-footer__contact-list a:hover,.site-footer__contact-list a:focus-visible{color:#58D1B4;text-decoration:underline}
.ico{display:inline-block;width:14px;height:14px;margin-right:8px;vertical-align:-2px;background:#58D1B4}
.ico-pin{-webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="black" d="M12 2a7 7 0 0 0-7 7c0 5.25 7 13 7 13s7-7.75 7-13a7 7 0 0 0-7-7Zm0 9.5A2.5 2.5 0 1 1 12 6a2.5 2.5 0 0 1 0 5.5Z"/></svg>') no-repeat center/contain;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="black" d="M12 2a7 7 0 0 0-7 7c0 5.25 7 13 7 13s7-7.75 7-13a7 7 0 0 0-7-7Zm0 9.5A2.5 2.5 0 1 1 12 6a2.5 2.5 0 0 1 0 5.5Z"/></svg>') no-repeat center/contain}
.ico-mail{-webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="black" d="M20 4H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2Zm-1 4-7 4.5L5 8V6l7 4.5L19 6v2Z"/></svg>') no-repeat center/contain;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="black" d="M20 4H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2Zm-1 4-7 4.5L5 8V6l7 4.5L19 6v2Z"/></svg>') no-repeat center/contain}
.ico-phone{-webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="black" d="M6.6 10.8a15.1 15.1 0 0 0 6.6 6.6l2.2-2.2c.3-.3.7-.4 1.1-.3 1.2.4 2.6.6 4 .6.6 0 1 .4 1 1V20c0 .6-.4 1-1 1C10.1 21 3 13.9 3 5c0-.6.4-1 1-1h3.5c.6 0 1 .4 1 1 0 1.4.2 2.8.6 4 .1.4 0 .8-.3 1.1L6.6 10.8Z"/></svg>') no-repeat center/contain;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="black" d="M6.6 10.8a15.1 15.1 0 0 0 6.6 6.6l2.2-2.2c.3-.3.7-.4 1.1-.3 1.2.4 2.6.6 4 .6.6 0 1 .4 1 1V20c0 .6-.4 1-1 1C10.1 21 3 13.9 3 5c0-.6.4-1 1-1h3.5c.6 0 1 .4 1 1 0 1.4.2 2.8.6 4 .1.4 0 .8-.3 1.1L6.6 10.8Z"/></svg>') no-repeat center/contain}
/* Bottom bar */
.site-footer__bottom{background:#fff;color:var(--text);padding:12px 0;border-top:1px solid #e6edf3}
.site-footer__bottom-grid{display:grid;gap:10px;grid-template-columns:1fr;align-items:center;justify-items:center;max-width:1024px;margin:0 auto;padding:0 20px;text-align:center}
@media(min-width:768px){.site-footer__bottom-grid{padding:0 32px}}
.site-footer__legal{display:flex;justify-self:center;gap:8px;flex-wrap:wrap;justify-content:center}
@media(min-width:900px){.site-footer__bottom-grid{grid-template-columns:1fr auto 1fr;justify-items:stretch;text-align:left}.site-footer__legal{justify-self:start}.site-footer__copy{justify-self:center;text-align:center}.site-footer__credit{justify-self:end;text-align:right}}
.site-footer__legal a{color:var(--blue-dark);text-decoration:none}
.site-footer__legal a:hover,.site-footer__legal a:focus-visible{text-decoration:underline;color:var(--blue)}
.site-footer__credit a{color:var(--blue-dark);text-decoration:underline}
.site-footer .sep{margin:0 8px;color:#9aa8b5}

/* ===== Legal Pages ===== */
.legal-page{background:#fff;min-height:70vh}
.legal-content{max-width:900px;margin:0 auto;padding:clamp(40px,6vw,80px) 20px}
.legal-title{font-size:clamp(2rem,4vw,2.75rem);color:var(--blue-dark);margin-bottom:8px;text-align:center}
.legal-updated{text-align:center;color:#6b7280;font-size:0.95rem;margin-bottom:40px;font-style:italic}
.legal-intro{font-size:1.125rem;line-height:1.7;color:var(--text);margin-bottom:32px;padding:20px;background:#f8fafb;border-left:4px solid var(--blue);border-radius:8px}
.legal-body{line-height:1.8;color:var(--text)}
.legal-body h2{font-size:clamp(1.25rem,2vw,1.75rem);color:var(--blue-dark);margin-top:40px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--aqua)}
.legal-body p{margin-bottom:16px}
.legal-body ul{margin:16px 0 24px 24px;list-style:disc}
.legal-body ul li{margin-bottom:12px;padding-left:8px}
.legal-body strong{color:var(--blue-dark);font-weight:600}
.legal-body a{color:var(--blue);text-decoration:underline}
.legal-body a:hover{color:var(--aqua)}
.contact-info{list-style:none !important;margin-left:0 !important;padding:20px;background:#f8fafb;border-radius:8px}
.contact-info li{margin-bottom:12px;padding-left:0 !important}
.legal-cta{margin-top:48px;padding:32px;background:linear-gradient(135deg,#1A9BEF,#58D1B4);border-radius:12px;text-align:center;color:#fff}
.legal-cta p{color:#fff;font-size:1.25rem;font-weight:600;margin-bottom:20px}
.legal-cta .btn{background:#fff;color:var(--blue-dark);border:none}
.legal-cta .btn:hover{background:var(--blue-dark);color:#fff;transform:translateY(-2px)}
@media(max-width:767px){
  .legal-content{padding:32px 16px}
  .legal-body h2{margin-top:32px}
  .legal-cta{padding:24px 20px}
}




