﻿:root{
  --bg:#f6faf6;
  --bg-soft:#edf6ee;
  --panel:#ffffff;
  --panel-2:#f4faf5;
  --line:#d6e6d8;
  --text:#163322;
  --muted:#617564;
  --orange:#2f8f46;
  --orange-2:#4eaf67;
  --green:#2f8f46;
  --green-2:#246f36;
  --shadow:0 18px 40px rgba(22,51,34,.10);
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
  }
}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

section[id]{
  scroll-margin-top:118px;
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.container{
  width:min(calc(100% - 48px),var(--container));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:40;
  backdrop-filter:blur(14px);
  background:rgba(255,255,255,.9);
  border-bottom:1px solid rgba(47,143,70,.12);
}
.header-inner{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  flex-shrink:0;
}
.brand-logo{
  width:clamp(220px,24vw,320px);
  height:auto;
  max-width:100%;
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.18));
}
.nav{
  display:flex;
  align-items:center;
  gap:28px;
}
.nav a{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 2px;
  color:#425845;
  font-weight:600;
  font-size:.96rem;
  transition:color .22s ease, transform .22s ease;
}
.nav a::before{
  content:"";
  position:absolute;
  left:50%;
  top:-10px;
  transform:translate(-50%, 8px);
  width:0;
  height:0;
  border-left:8px solid transparent;
  border-right:8px solid transparent;
  border-top:10px solid #7aca74;
  opacity:0;
  transition:opacity .22s ease, transform .22s ease;
  filter:drop-shadow(0 6px 10px rgba(47,143,70,.14));
}
.nav a:hover,
.nav a:focus-visible{
  color:var(--green);
  transform:translateY(-1px);
}
.nav a:hover::before,
.nav a:focus-visible::before{
  opacity:1;
  transform:translate(-50%, 0);
}
:where(.btn, .nav a, .service-body a, .footer a, .contact-link, .floating-whatsapp):focus-visible{
  outline:2px solid var(--green);
  outline-offset:3px;
}

.btn{
  min-height:54px;
  padding:0 24px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  transition:.25s ease;
  border:1px solid transparent;
}
.btn:hover{transform:translateY(-2px)}
.btn-header{
  min-height:50px;
  padding:0 20px;
  border-radius:999px;
  font-size:.96rem;
  letter-spacing:-.01em;
}
.btn-whatsapp{
  gap:10px;
  color:#28c85e;
  background:linear-gradient(180deg,#effcf3 0%, #e2f8ea 100%);
  border-color:rgba(40,200,94,.22);
  box-shadow:0 10px 24px rgba(40,200,94,.12);
}
.btn-whatsapp:hover{
  color:#22bb55;
  background:linear-gradient(180deg,#f5fef7 0%, #e8fbef 100%);
  box-shadow:0 14px 28px rgba(40,200,94,.16);
}
.btn-whatsapp__icon{
  width:28px;
  height:28px;
  border-radius:50%;
  background:rgba(40,200,94,.10);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  box-shadow:inset 0 0 0 1px rgba(40,200,94,.08);
}
.btn-whatsapp__icon::before{
  content:"";
  width:15px;
  height:15px;
  background:#28c85e;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath fill='black' d='M19.11 17.21c-.29-.15-1.69-.83-1.95-.93-.26-.09-.45-.14-.64.15s-.74.93-.9 1.12c-.17.2-.33.22-.62.08-.29-.15-1.22-.45-2.32-1.43-.86-.77-1.45-1.72-1.62-2.01-.17-.29-.02-.45.13-.59.13-.13.29-.33.43-.5.14-.16.19-.28.29-.47.09-.2.05-.36-.02-.5-.07-.15-.64-1.55-.88-2.12-.23-.55-.47-.48-.64-.49h-.55c-.19 0-.5.07-.76.36-.26.29-1 1-.97 2.44.02 1.43 1.02 2.81 1.16 3.01.14.2 2 3.07 4.83 4.3.67.29 1.2.46 1.61.59.67.21 1.28.18 1.76.11.54-.08 1.69-.69 1.93-1.35.24-.66.24-1.22.17-1.34-.07-.12-.26-.19-.55-.33ZM16.01 3.2c-7.06 0-12.8 5.7-12.8 12.7 0 2.24.59 4.43 1.72 6.35L3.1 29.5l7.42-1.93c1.82.98 3.86 1.49 5.92 1.5h.01c7.05 0 12.79-5.7 12.79-12.7 0-3.39-1.33-6.58-3.74-8.97A12.73 12.73 0 0 0 16.01 3.2Zm.43 23.23h-.01a10.8 10.8 0 0 1-5.5-1.49l-.39-.23-4.4 1.14 1.17-4.28-.25-.44a10.66 10.66 0 0 1-1.64-5.65c0-5.92 4.85-10.74 10.81-10.74 2.88 0 5.58 1.11 7.61 3.13a10.64 10.64 0 0 1 3.16 7.61c0 5.92-4.85 10.75-10.8 10.75Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath fill='black' d='M19.11 17.21c-.29-.15-1.69-.83-1.95-.93-.26-.09-.45-.14-.64.15s-.74.93-.9 1.12c-.17.2-.33.22-.62.08-.29-.15-1.22-.45-2.32-1.43-.86-.77-1.45-1.72-1.62-2.01-.17-.29-.02-.45.13-.59.13-.13.29-.33.43-.5.14-.16.19-.28.29-.47.09-.2.05-.36-.02-.5-.07-.15-.64-1.55-.88-2.12-.23-.55-.47-.48-.64-.49h-.55c-.19 0-.5.07-.76.36-.26.29-1 1-.97 2.44.02 1.43 1.02 2.81 1.16 3.01.14.2 2 3.07 4.83 4.3.67.29 1.2.46 1.61.59.67.21 1.28.18 1.76.11.54-.08 1.69-.69 1.93-1.35.24-.66.24-1.22.17-1.34-.07-.12-.26-.19-.55-.33ZM16.01 3.2c-7.06 0-12.8 5.7-12.8 12.7 0 2.24.59 4.43 1.72 6.35L3.1 29.5l7.42-1.93c1.82.98 3.86 1.49 5.92 1.5h.01c7.05 0 12.79-5.7 12.79-12.7 0-3.39-1.33-6.58-3.74-8.97A12.73 12.73 0 0 0 16.01 3.2Zm.43 23.23h-.01a10.8 10.8 0 0 1-5.5-1.49l-.39-.23-4.4 1.14 1.17-4.28-.25-.44a10.66 10.66 0 0 1-1.64-5.65c0-5.92 4.85-10.74 10.81-10.74 2.88 0 5.58 1.11 7.61 3.13a10.64 10.64 0 0 1 3.16 7.61c0 5.92-4.85 10.75-10.8 10.75Z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.btn-primary{
  background:linear-gradient(180deg,var(--green),var(--green-2));
  color:#fff;
  box-shadow:0 12px 28px rgba(47,143,70,.22);
}
.btn-outline{
  border-color:rgba(47,143,70,.18);
  color:var(--text);
  background:rgba(255,255,255,.82);
}
.btn-outline-green{
  color:var(--green);
  border-color:rgba(47,143,70,.56);
  background:rgba(47,143,70,.05);
}
.btn-green{
  background:linear-gradient(180deg,var(--green),var(--green-2));
  color:#fff;
  box-shadow:0 12px 28px rgba(47,143,70,.2);
}
.btn-outline-orange{
  color:var(--green);
  border-color:rgba(47,143,70,.56);
  background:rgba(47,143,70,.05);
}

.hero{
  position:relative;
  min-height:710px;
  display:flex;
  align-items:center;
  background-image:
    linear-gradient(90deg, rgba(248,252,248,.77) 0%, rgba(248,252,248,.74) 30%, rgba(248,252,248,.61) 52%, rgba(248,252,248,.22) 76%, rgba(248,252,248,.06) 100%),
    url("Imagens/hero-principal.jpg"),
    url("https://images.unsplash.com/photo-1621905252507-b35492cc74b4?auto=format&fit=crop&w=1600&q=80");
  background-position:center, center, center;
  background-size:auto, cover, cover;
  background-repeat:no-repeat, no-repeat, no-repeat;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 15% 50%, rgba(47,143,70,.10), transparent 32%),
    radial-gradient(circle at 80% 10%, rgba(47,143,70,.08), transparent 25%);
  pointer-events:none;
}
.hero-content{
  position:relative;
  z-index:2;
  padding:clamp(90px,10vw,120px) 0 clamp(58px,7vw,70px);
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(320px,430px);
  gap:clamp(24px,3vw,34px);
  align-items:center;
}
.hero-copy{
  max-width:720px;
}
.badge-row{margin-bottom:26px}
.top-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid rgba(47,143,70,.25);
  background:rgba(47,143,70,.08);
  color:var(--green);
  font-weight:700;
}
.dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--green);
  display:inline-block;
}
.hero h1{
  margin:0;
  font-size:clamp(3rem,6vw,5.2rem);
  line-height:.97;
  letter-spacing:-.05em;
  max-width:720px;
  text-wrap:balance;
}
.hero-title__desktop,
.hero-title__mobile{
  display:block;
}
.hero-title__mobile{
  display:none;
}
.hero-title__line{
  display:block;
}
.hero-title__line--keep{
  white-space:nowrap;
}
.hero-title__accent{
  color:var(--green);
}
.hero-text{
  margin:26px 0 38px;
  max-width:660px;
  font-size:1.1rem;
  line-height:1.7;
  color:#4f6254;
  font-weight:700;
  text-wrap:pretty;
}
.hero-actions{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
.hero-actions .btn{
  min-width:220px;
}
.hero-stats{
  margin-top:42px;
  display:flex;
  gap:44px;
  flex-wrap:wrap;
}
.stat{
  min-width:170px;
  padding:14px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.38);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 14px 30px rgba(31,74,39,.08);
  backdrop-filter:blur(6px);
}
.hero-media{
  display:flex;
  justify-content:flex-end;
  width:100%;
}
.hero-slider{
  width:100%;
  max-width:430px;
  padding:18px;
  border-radius:28px;
  border:1px solid rgba(47,143,70,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(244,250,245,.8));
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);
}
.hero-slider__viewport{
  position:relative;
  min-height:clamp(340px,46vw,540px);
  border-radius:22px;
  overflow:hidden;
}
.hero-slide{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding:24px;
  background-size:cover;
  background-position:center;
  opacity:0;
  transform:translateX(18px) scale(.985);
  transition:opacity .45s ease, transform .45s ease;
}
.hero-slide::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.005), rgba(22,51,34,.02)),
    linear-gradient(135deg, rgba(47,143,70,.02), transparent 42%);
}
.hero-slide.is-active{
  opacity:1;
  transform:translateX(0) scale(1);
}
.hero-slide--1{background-image:url("Imagens/slide-1.jpg"), url("https://images.unsplash.com/photo-1621905252507-b35492cc74b4?auto=format&fit=crop&w=1200&q=80")}
.hero-slide--2{background-image:url("Imagens/slide-2.jpg"), url("https://images.unsplash.com/photo-1621905251918-48416bd8575a?auto=format&fit=crop&w=1200&q=80")}
.hero-slide--3{background-image:url("Imagens/slide-3.jpg"), url("https://images.unsplash.com/photo-1581092580497-e0d23cbdf1dc?auto=format&fit=crop&w=1200&q=80")}
.hero-slide--4{background-image:url("Imagens/slide-4.jpg"), url("https://images.unsplash.com/photo-1541888946425-d81bb19240f5?auto=format&fit=crop&w=1200&q=80")}
.hero-slide__body{
  position:relative;
  z-index:1;
  width:min(100%, 340px);
  padding:18px;
  margin-left:-10px;
  border-radius:20px;
  background:transparent;
  border:0;
  backdrop-filter:none;
}
.hero-slide__label{
  position:absolute;
  top:18px;
  left:18px;
  z-index:1;
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(33, 92, 49, .72);
  border:1px solid rgba(155, 226, 116, .36);
  color:#e6ffd8;
  box-shadow:0 8px 18px rgba(6, 24, 12, .18);
  font-size:.92rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.hero-slide h3{
  margin:14px 0 10px;
  font-size:1.4rem;
  line-height:1.56;
  color:#e6ffd8;
  font-weight:900;
}
.hero-slide h3 span,
.hero-slide p span{
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
  border-radius:8px;
  text-shadow:0 1px 6px rgba(5,22,9,.2);
}
.hero-slide h3 span{
  display:inline;
  padding:.08em .3em .12em;
  background:rgba(18, 64, 30, .62);
}
.hero-slide p{
  margin:0;
  color:#d4f1c8;
  line-height:1.82;
  font-weight:800;
}
.hero-slide p span{
  display:inline;
  padding:.14em .28em;
  background:rgba(18, 64, 30, .52);
}
.hero-slider__controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:18px;
}
.hero-slider__button{
  width:50px;
  height:50px;
  border-radius:50%;
  border:1px solid rgba(47,143,70,.18);
  background:rgba(255,255,255,.82);
  color:var(--green);
  font-size:1.15rem;
  cursor:pointer;
  transition:.25s ease;
}
.hero-slider__button:hover{
  background:rgba(47,143,70,.12);
  border-color:rgba(47,143,70,.34);
}
.hero-slider__button:focus-visible,
.hero-slider__dot:focus-visible{
  outline:2px solid var(--green);
  outline-offset:2px;
}
.hero-slider__dots{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.hero-slider__dot{
  width:11px;
  height:11px;
  border:0;
  border-radius:999px;
  background:rgba(47,143,70,.22);
  cursor:pointer;
  transition:.25s ease;
}
.hero-slider__dot.is-active{
  width:30px;
  background:var(--orange);
}
.stat strong{
  display:block;
  font-size:1.6rem;
  color:var(--green);
  font-weight:900;
  margin-bottom:6px;
}
.stat span{
  color:var(--muted);
  font-size:1rem;
  font-weight:700;
}

.section{
  padding:clamp(72px,8vw,86px) 0;
}
.section-dark{
  background:linear-gradient(180deg,#fbfdfb 0%, #f0f7f1 100%);
}
.section-head{
  max-width:820px;
  margin:0 auto 40px;
}
.section-head.center{text-align:center}
.section-kicker{
  display:block;
  color:var(--green);
  font-size:.95rem;
  font-weight:900;
  letter-spacing:.12em;
  margin-bottom:14px;
}
.section-kicker.green{color:var(--green)}
.section-kicker.left{text-align:left}
.section-head h2,
.about-content h2,
.cta-inner h2{
  margin:0 0 16px;
  font-size:clamp(2.15rem,4vw,3.4rem);
  line-height:1.08;
  letter-spacing:-.04em;
  text-wrap:balance;
}
.section-head p,
.about-content p{
  margin:0;
  color:var(--muted);
  font-size:1.07rem;
  line-height:1.7;
  text-wrap:pretty;
}

.grid{
  display:grid;
  gap:24px;
}
.grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.info-card{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
  transition:.22s ease;
  height:100%;
}
.info-card:hover{
  transform:translateY(-5px);
  border-color:rgba(47,143,70,.36);
}
.highlight-top{
  position:relative;
}
.highlight-top::before{
  content:"";
  position:absolute;
  top:-1px;
  left:18px;
  width:40px;
  height:3px;
  border-radius:4px;
  background:var(--orange);
}
.icon-box{
  width:48px;
  height:48px;
  border-radius:14px;
  display:grid;
  place-items:center;
  font-size:1.35rem;
  background:rgba(47,143,70,.12);
  color:var(--green);
  margin-bottom:18px;
}
.info-card h3,
.contact-card h3,
.service-body h3{
  margin:0 0 12px;
  font-size:1.05rem;
  line-height:1.4;
}
.info-card p,
.contact-card p,
.service-body p{
  margin:0;
  color:var(--muted);
  line-height:1.7;
  font-size:.99rem;
}

.cards-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(16px,2.2vw,18px);
}
.service-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%, #f5faf6 100%);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;
  height:100%;
}
.service-card:hover{
  transform:translateY(-5px);
  border-color:rgba(47,143,70,.34);
  box-shadow:0 20px 42px rgba(22,51,34,.14);
}
.service-image{
  height:clamp(200px,22vw,210px);
  background-size:cover;
  background-position:center;
}
.image-1{
  background-image:url("Imagens/foto-01.jpg"), url("Imagens/foto 01.jpg");
  background-position:center 64%;
}
.image-2{
  background-image:url("Imagens/foto-02.jpg"), url("Imagens/foto 02.jpg");
  background-position:center 62%;
}
.image-3{background-image:url("Imagens/foto-03.jpg"), url("Imagens/foto 03.jpg")}
.image-4{
  background-image:url("Imagens/foto-04.jpg"), url("Imagens/foto 04.jpg");
  background-position:center 68%;
}
.image-5{background-image:url("Imagens/foto-05.jpg"), url("Imagens/foto 05.jpg")}
.image-6{background-image:url("Imagens/foto-06.jpeg"), url("Imagens/foto 06.jpeg")}
.service-body{
  display:flex;
  flex:1;
  flex-direction:column;
  padding:24px 20px 22px;
}
.service-body a{
  display:inline-block;
  margin-top:auto;
  padding-top:16px;
  color:var(--green);
  font-weight:800;
}
.service-body a:hover{
  color:var(--green-2);
}

.pill-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.pill-card{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:60px;
  padding:14px 16px;
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:14px;
  font-weight:700;
  box-shadow:var(--shadow);
  transition:transform .2s ease, border-color .2s ease;
}
.pill-card:hover{
  transform:translateY(-3px);
  border-color:rgba(47,143,70,.28);
}
.pill-card span{
  width:38px;
  height:38px;
  border-radius:12px;
  display:grid;
  place-items:center;
  color:var(--green);
  background:rgba(47,143,70,.08);
  font-size:1.15rem;
}

.about-section{
  padding-top:64px;
}
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:42px;
  align-items:center;
}
.about-visual{
  position:relative;
}
.about-photo{
  min-height:clamp(360px,42vw,500px);
  border-radius:22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(22,51,34,.12)),
    url("Imagens/sobre-nos.png"),
    url("Imagens/sobre nos.png");
  background-position:center, center, center;
  background-size:auto, cover, cover;
  background-repeat:no-repeat, no-repeat, no-repeat;
  border:1px solid var(--line);
}
.experience-box{
  position:absolute;
  right:-18px;
  bottom:-18px;
  width:134px;
  height:118px;
  border-radius:16px;
  background:linear-gradient(180deg,var(--green),var(--green-2));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  box-shadow:0 20px 40px rgba(47,143,70,.22);
}
.experience-box strong{
  font-size:2.2rem;
  font-weight:900;
}
.experience-box span{
  font-size:1rem;
}
.about-content p{
  margin-bottom:18px;
}
.check-list{
  list-style:none;
  padding:0;
  margin:26px 0 0;
  display:grid;
  gap:12px;
}
.check-list li{
  position:relative;
  padding-left:28px;
  color:var(--text);
  font-weight:600;
}
.check-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--green);
  font-weight:900;
}

.cta-banner{
  padding:84px 0;
  background:
    radial-gradient(circle at 50% 20%, rgba(92,170,110,.12), transparent 28%),
    radial-gradient(circle at 50% 60%, rgba(47,143,70,.18), transparent 35%),
    linear-gradient(90deg,#2f8f46 0%,#246f36 100%);
  text-align:center;
}
.cta-inner{
  max-width:860px;
  color:#fff;
}
.cta-inner h2 span{
  color:#dff7e5;
}
.cta-inner p{
  max-width:700px;
  margin:0 auto 28px;
  color:rgba(255,255,255,.88);
  font-size:1.07rem;
  line-height:1.7;
}
.center-actions{
  justify-content:center;
}
.cta-banner .center-actions{
  gap:18px;
}
.cta-banner .center-actions .btn{
  min-width:240px;
  background:linear-gradient(180deg,#c8f0cb 0%, #a8dfae 100%);
  color:#184728;
  border:1px solid rgba(255,255,255,.28);
  box-shadow:0 14px 30px rgba(20,79,34,.16);
}
.cta-banner .center-actions .btn:hover{
  background:linear-gradient(180deg,#d3f4d5 0%, #b3e6b8 100%);
  border-color:rgba(255,255,255,.38);
}

.contact-section{
  padding-top:66px;
}
.contact-cards{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(16px,2vw,20px);
}
.contact-card{
  background:rgba(255,255,255,.95);
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  text-align:center;
  box-shadow:var(--shadow);
  height:100%;
  transition:transform .22s ease, border-color .22s ease;
}
.contact-card:hover{
  transform:translateY(-4px);
  border-color:rgba(47,143,70,.3);
}
.contact-card .icon-box{
  margin:0 auto 18px;
}
.contact-card p,
.footer li{
  overflow-wrap:anywhere;
}
.contact-link{
  color:var(--text);
  font-weight:700;
  transition:color .2s ease;
}
.contact-link:hover{
  color:var(--green);
}

.footer{
  padding:42px 0;
  background:#ffffff;
  border-top:1px solid rgba(47,143,70,.12);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.15fr .8fr .8fr 1fr;
  gap:34px;
}
.footer-brand{
  margin-bottom:18px;
}
.footer-logo{
  width:min(240px,100%);
  height:auto;
  filter:none;
}
.footer-desc{
  color:var(--muted);
  line-height:1.8;
  max-width:320px;
}
.footer h4{
  margin:0 0 16px;
  font-size:1rem;
  letter-spacing:.04em;
}
.footer ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:12px;
  color:var(--muted);
}
.footer li,
.footer a{
  color:var(--muted);
  line-height:1.6;
}
.footer a:hover{
  color:var(--green);
}
.floating-whatsapp{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:90;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:min(108px, 18vw);
  padding:6px;
  border-radius:999px;
  background:rgba(255,255,255,.44);
  border:1px solid rgba(255,255,255,.72);
  backdrop-filter:blur(4px);
  box-shadow:0 10px 22px rgba(18,76,38,.08);
  transition:transform .24s ease, filter .24s ease;
}
.floating-whatsapp:hover{
  transform:translateY(-3px) scale(1.02);
  filter:drop-shadow(0 18px 26px rgba(34,152,74,.24));
}
.floating-whatsapp__image{
  width:100%;
  height:auto;
  display:block;
  filter:
    drop-shadow(0 0 1px rgba(255,255,255,.95))
    drop-shadow(0 0 8px rgba(255,255,255,.5))
    drop-shadow(0 16px 26px rgba(18,76,38,.16));
}

@media (max-width: 1100px){
  .hero-grid{
    grid-template-columns:1fr;
    gap:28px;
  }
  .hero-copy{
    max-width:none;
  }
  .hero-media{
    max-width:680px;
    width:100%;
    justify-content:center;
  }
  .hero-slider{
    max-width:680px;
    margin:0 auto;
  }
  .hero-slider__viewport{
    min-height:420px;
  }
  .grid-3,
  .cards-grid,
  .pill-grid,
  .contact-cards,
  .footer-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .about-grid{
    grid-template-columns:1fr;
  }
  .about-photo{
    min-height:420px;
  }
  .experience-box{
    right:18px;
    bottom:18px;
  }
}

@media (max-width: 980px){
  .header-inner{
    min-height:auto;
    padding:14px 0;
    flex-wrap:wrap;
    justify-content:center;
    gap:14px 22px;
  }
  .brand{
    width:100%;
    justify-content:center;
  }
  .nav{
    width:100%;
    justify-content:center;
    gap:12px 22px;
    flex-wrap:wrap;
  }
  .btn-header{
    order:3;
  }
  .hero-content{
    padding:92px 0 58px;
  }
  .hero-stats{
    gap:16px;
  }
  .about-grid{
    gap:30px;
  }
}

@media (max-width: 760px){
  .container{
    width:min(calc(100% - 28px),var(--container));
  }
  .header-inner{
    padding:10px 0;
    gap:12px;
  }
  .brand{
    width:100%;
    justify-content:center;
  }
  .brand-logo{
    width:min(250px,72vw);
    height:auto;
  }
  .nav{
    order:2;
    width:100%;
    justify-content:center;
    gap:8px 18px;
    flex-wrap:wrap;
  }
  .nav a{
    padding:8px 0;
    font-size:.93rem;
  }
  .nav a::before{
    display:none;
  }
  .btn-header{
    display:none;
  }
  .hero{
    min-height:auto;
  }
  .hero-content{
    padding:84px 0 56px;
  }
  .hero-grid{
    gap:24px;
  }
  .hero h1{
    font-size:clamp(2rem,10.2vw,3.8rem);
    max-width:none;
  }
  .hero-title__desktop{
    display:none;
  }
  .hero-title__mobile{
    display:block;
  }
  .hero-text{
    margin:22px 0 30px;
    font-size:1rem;
  }
  .hero-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .hero-actions .btn{
    width:100%;
    min-width:0;
  }
  .hero-stats{
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
  }
  .stat{
    min-width:0;
  }
  .hero-slider{
    padding:12px;
  }
  .hero-slider__viewport{
    min-height:320px;
  }
  .hero-slide{
    padding:16px;
  }
  .hero-slide__label{
    top:14px;
    left:14px;
    font-size:.86rem;
  }
  .hero-slide__body{
    width:100%;
    padding:10px 0 0;
    margin-left:0;
  }
  .hero-slide h3{
    font-size:1.16rem;
  }
  .hero-slide p{
    font-size:.95rem;
    line-height:1.7;
  }
  .hero-slider__controls{
    margin-top:14px;
    flex-wrap:wrap;
    justify-content:center;
  }
  .hero-slider__dots{
    order:2;
    width:100%;
  }
  .hero-slider__button{
    width:44px;
    height:44px;
  }
  .grid-3,
  .cards-grid,
  .pill-grid,
  .contact-cards,
  .footer-grid{
    grid-template-columns:1fr;
  }
  .service-image{
    height:200px;
  }
  .about-photo{
    min-height:340px;
  }
  .experience-box{
    right:14px;
    bottom:14px;
    width:116px;
    height:100px;
  }
  .cta-banner .center-actions .btn{
    min-width:0;
    width:100%;
  }
  .floating-whatsapp{
    right:16px;
    bottom:16px;
    width:min(92px, 24vw);
  }
  .section{
    padding:72px 0;
  }
}

@media (max-width: 540px){
  .container{
    width:min(calc(100% - 22px),var(--container));
  }
  .top-badge{
    padding:10px 14px;
    font-size:.9rem;
  }
  .hero h1{
    font-size:clamp(1.82rem,12vw,3rem);
    line-height:1.01;
  }
  .hero-content{
    padding:74px 0 48px;
  }
  .hero-slider{
    padding:10px;
    border-radius:22px;
  }
  .hero-slider__viewport{
    min-height:280px;
    border-radius:18px;
  }
  .hero-slide{
    padding:14px;
  }
  .hero-slide__label{
    top:12px;
    left:12px;
    min-height:30px;
    padding:0 11px;
    font-size:.78rem;
    letter-spacing:.05em;
  }
  .hero-slide h3{
    font-size:1.02rem;
  }
  .hero-slide p{
    font-size:.9rem;
  }
  .hero-slider__button{
    width:42px;
    height:42px;
  }
  .section-head{
    margin-bottom:30px;
  }
  .section-head h2,
  .about-content h2,
  .cta-inner h2{
    font-size:clamp(1.8rem,9vw,2.4rem);
  }
  .info-card,
  .contact-card,
  .service-body{
    padding:20px 18px;
  }
  .service-image{
    height:190px;
  }
  .about-photo{
    min-height:300px;
  }
  .experience-box{
    width:102px;
    height:88px;
  }
  .experience-box strong{
    font-size:1.8rem;
  }
  .experience-box span{
    font-size:.88rem;
  }
  .floating-whatsapp{
    right:12px;
    bottom:12px;
    width:min(82px,26vw);
    padding:5px;
  }
}

