/* ============================================
   SAMOA ENGENHARIA — CSS Mobile-First
   Breakpoints: base=mobile → 480 → 640 → 1024 → 1380
   W3C / WCAG 2.1 compliant
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;600;700;800;900&family=Barlow:wght@300;400;500;600&family=Bebas+Neue&display=swap');

:root {
  --verde:      #1a7a4a;
  --verde-esc:  #0d4f2e;
  --verde-neon: #2dcd70;
  --cinza-esc:  #111a14;
  --cinza-cla:  #f4f7f5;
  --branco:     #ffffff;
  --texto:      #2c3e2d;
  --texto-cla:  #7a9480;
  --f-disp:     'Bebas Neue', sans-serif;
  --f-cond:     'Barlow Condensed', sans-serif;
  --f-corpo:    'Barlow', sans-serif;
  --radius:     6px;
  --trans:      all .3s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-corpo);color:var(--texto);background:var(--branco);overflow-x:hidden;line-height:1.6;max-width:100vw}
img,svg{max-width:100%;height:auto}
a{color:inherit}
::selection{background:var(--verde-neon);color:var(--cinza-esc)}
:focus-visible{outline:2px solid var(--verde-neon);outline-offset:3px;border-radius:3px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ── SCROLLBAR ── */
@media(min-width:1024px){::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--cinza-esc)}::-webkit-scrollbar-thumb{background:var(--verde);border-radius:3px}}

/* ════ LOADER ════ */
#loader{position:fixed;inset:0;z-index:9999;background:var(--cinza-esc);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.2rem;transition:opacity .6s,visibility .6s}
#loader.hide{opacity:0;visibility:hidden}
#loader svg{width:60px;animation:pulso 1.2s ease-in-out infinite}
#loader-bar{width:150px;height:3px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}
#loader-bar::after{content:'';display:block;height:100%;background:var(--verde-neon);animation:barra 1.4s ease-in-out infinite}
@keyframes barra{0%{width:0;margin-left:0}50%{width:80%;margin-left:10%}100%{width:0;margin-left:100%}}
@keyframes pulso{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}

/* ════ HEADER — MOBILE FIRST ════ */
#header{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(13,22,16,.97);backdrop-filter:blur(10px);border-bottom:1px solid rgba(45,205,112,.1);transition:var(--trans)}
#header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.45)}
.nav-wrap{padding:.75rem 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:.8rem}
.logo-link{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.logo-link svg{width:32px;flex-shrink:0}
.logo-text{font-family:var(--f-cond);font-weight:800;font-size:1.15rem;color:var(--branco);letter-spacing:.05em;line-height:1.1}
.logo-text span{color:var(--verde-neon);display:block;font-size:.6em;font-weight:300;letter-spacing:.16em}

/* Hamburger — visível mobile */
.hamburger{background:none;border:1px solid rgba(255,255,255,.18);border-radius:5px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:.45rem .5rem;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.hamburger span{display:block;width:22px;height:2px;background:var(--branco);border-radius:2px;transition:var(--trans)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0;width:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Nav drawer — mobile */
nav{display:none;position:fixed;top:61px;left:0;right:0;bottom:0;background:rgba(8,15,10,.98);backdrop-filter:blur(16px);overflow-y:auto;flex-direction:column;padding:1.2rem 1.2rem 3rem;gap:.15rem;border-top:1px solid rgba(45,205,112,.1);z-index:899}
nav.open{display:flex}
nav a{font-family:var(--f-cond);font-size:1.25rem;font-weight:600;letter-spacing:.05em;color:rgba(255,255,255,.78);text-decoration:none;padding:.75rem 1rem;border-radius:var(--radius);transition:var(--trans);min-height:48px;display:flex;align-items:center}
nav a:hover,nav a:focus{background:rgba(45,205,112,.1);color:var(--verde-neon)}
nav a.ativo{color:var(--verde-neon)}

/* Dropdown mobile */
.nav-dropdown{display:flex;flex-direction:column}
.nav-dropdown>a{justify-content:space-between}
.nav-dropdown>a::after{content:'▾';font-size:.75rem;opacity:.5}
.dropdown-menu{display:none;flex-direction:column;background:rgba(255,255,255,.04);border-radius:var(--radius);margin:.2rem 0;padding:.3rem}
.dropdown-menu.open{display:flex}
.dropdown-menu a{font-size:1rem;padding:.6rem 1.2rem;color:rgba(255,255,255,.58);min-height:44px;display:flex;align-items:center;gap:.5rem}
.dropdown-menu a:hover{color:var(--verde-neon);background:rgba(45,205,112,.08)}

.nav-cta{background:var(--verde)!important;color:var(--branco)!important;border-radius:30px!important;justify-content:center!important;margin-top:.8rem;font-size:1.1rem!important}
.nav-cta:hover{background:var(--verde-neon)!important;color:var(--cinza-esc)!important}

/* ── Nav Desktop (≥1024px) ── */
@media(min-width:1024px){
  .hamburger{display:none}
  nav{display:flex!important;position:static;background:none;backdrop-filter:none;flex-direction:row;overflow:visible;padding:0;gap:.1rem;border:none;align-items:center;top:auto;bottom:auto}
  nav a{font-size:.9rem;padding:.5rem .8rem;min-height:auto;position:relative}
  nav a::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:2px;background:var(--verde-neon);transition:var(--trans);border-radius:2px}
  nav a:hover{background:none}
  nav a:hover::after,nav a.ativo::after{left:.8rem;right:.8rem}
  .nav-dropdown{flex-direction:row;position:relative}
  .nav-dropdown>a::after{content:'▾';position:static;opacity:1;margin-left:.3rem}
  .dropdown-menu{display:block!important;position:absolute;top:calc(100% + .4rem);left:50%;transform:translateX(-50%) translateY(-8px);background:var(--cinza-esc);border:1px solid rgba(45,205,112,.15);min-width:230px;padding:.4rem;box-shadow:0 20px 40px rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:var(--trans);margin:0;border-radius:var(--radius)}
  .nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .dropdown-menu a{font-size:.87rem;padding:.55rem .9rem;min-height:auto;color:rgba(255,255,255,.62)}
  .nav-cta{font-size:.87rem!important;padding:.48rem 1.2rem!important;margin-top:0}
}
@media(min-width:1380px){.nav-wrap{max-width:1380px;margin:0 auto;padding:.9rem 2rem}}

/* ════ BOTÕES ════ */
.btn-prim,.btn-sec{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.5rem;border-radius:4px;font-family:var(--f-cond);font-size:1rem;font-weight:700;letter-spacing:.07em;text-decoration:none;text-transform:uppercase;transition:var(--trans);cursor:pointer;min-height:48px;border:2px solid transparent}
.btn-prim{background:var(--verde);border-color:var(--verde);color:var(--branco)}
.btn-prim:hover{background:var(--verde-neon);border-color:var(--verde-neon);color:var(--cinza-esc);transform:translateY(-2px);box-shadow:0 6px 16px rgba(45,205,112,.3)}
.btn-sec{background:transparent;border-color:rgba(255,255,255,.28);color:var(--branco)}
.btn-sec:hover{border-color:var(--verde-neon);color:var(--verde-neon);transform:translateY(-2px)}

/* ════ SEÇÕES GENÉRICAS ════ */
section{padding:3.5rem 1.2rem}
@media(min-width:640px){section{padding:5rem 1.6rem}}
@media(min-width:1024px){section{padding:6rem 2rem}}
.container{max-width:1380px;margin:0 auto}
.sec-tag{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--f-cond);font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--verde);margin-bottom:.65rem}
.sec-tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--verde);flex-shrink:0}
.sec-titulo{font-family:var(--f-cond);font-size:clamp(1.8rem,5vw,3rem);font-weight:800;color:var(--cinza-esc);line-height:1.1;margin-bottom:.75rem}
.sec-titulo span{color:var(--verde)}
.sec-sub{font-size:.96rem;color:var(--texto-cla);line-height:1.8;margin-bottom:2.5rem}
.txt-center{text-align:center}
@media(min-width:640px){.txt-center .sec-sub{max-width:560px;margin-left:auto;margin-right:auto}}

/* ════ HERO ════ */
.hero{min-height:100svh;position:relative;display:flex;align-items:center;overflow:hidden;background:var(--cinza-esc)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,rgba(13,79,46,.9) 0%,rgba(13,22,16,.97) 65%),url('../images/hero-bg.jpg') center/cover no-repeat}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(45,205,112,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(45,205,112,.04) 1px,transparent 1px);background-size:44px 44px;animation:gridMove 20s linear infinite}
@keyframes gridMove{0%{background-position:0 0}100%{background-position:44px 44px}}
.hero-particles{position:absolute;inset:0;pointer-events:none}
.particle{position:absolute;border-radius:50%;background:var(--verde-neon);opacity:0;animation:float-up var(--dur,8s) ease-in-out infinite var(--delay,0s)}
@keyframes float-up{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:.5}90%{opacity:.2}100%{transform:translateY(-10vh) scale(1);opacity:0}}

/* Mobile: coluna única */
.hero-content{position:relative;z-index:2;width:100%;padding:7rem 1.2rem 4rem;display:flex;flex-direction:column;gap:2rem}
.hero-tag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(45,205,112,.12);border:1px solid rgba(45,205,112,.28);padding:.33rem .85rem;border-radius:30px;font-family:var(--f-cond);font-size:.74rem;font-weight:700;letter-spacing:.12em;color:var(--verde-neon);text-transform:uppercase;margin-bottom:.9rem;width:fit-content}
.hero-tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--verde-neon);animation:blink 1.4s ease-in-out infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero-titulo{font-family:var(--f-disp);font-size:clamp(3rem,12vw,7rem);color:var(--branco);line-height:.9;margin-bottom:1.1rem;letter-spacing:.02em}
.hero-titulo em{color:var(--verde-neon);font-style:normal;display:block}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.7);margin-bottom:1.8rem;line-height:1.8}
.hero-btns{display:flex;flex-direction:column;gap:.75rem}

/* Números — 2×2 mobile */
.hero-numeros{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(45,205,112,.08);border:1px solid rgba(255,255,255,.07);border-radius:10px;overflow:hidden}
.num-item{background:rgba(255,255,255,.03);padding:1.1rem .8rem;text-align:center}
.num-val{font-family:var(--f-disp);font-size:2.6rem;color:var(--verde-neon);line-height:1;display:block}
.num-label{font-family:var(--f-cond);font-size:.7rem;letter-spacing:.1em;color:rgba(255,255,255,.42);text-transform:uppercase;margin-top:.25rem}
.hero-scroll{position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.35rem;z-index:2;animation:bounce 2s ease-in-out infinite}
.hero-scroll span{font-family:var(--f-cond);font-size:.63rem;letter-spacing:.15em;color:rgba(255,255,255,.33);text-transform:uppercase}
.hero-scroll svg{color:var(--verde-neon)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* Desktop hero: duas colunas */
@media(min-width:1024px){
  .hero-content{flex-direction:row;align-items:center;max-width:1380px;margin:0 auto;padding:8rem 2rem 4rem;gap:4rem}
  .hero-texto{flex:1}
  .hero-numeros{flex:0 0 380px}
  .hero-btns{flex-direction:row}
}

/* ════ SERVIÇOS ════ */
.servicos-section{background:var(--cinza-cla)}
.servicos-grid{display:grid;grid-template-columns:1fr;gap:1.1rem}
@media(min-width:520px){.servicos-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.servicos-grid{grid-template-columns:repeat(3,1fr)}}
.servico-card{background:var(--branco);border-radius:10px;overflow:hidden;text-decoration:none;transition:var(--trans);border:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;position:relative}
.servico-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--verde);transform:scaleX(0);transform-origin:left;transition:var(--trans)}
.servico-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.1)}
.servico-card:hover::before{transform:scaleX(1)}
.card-icone{height:130px;display:flex;align-items:center;justify-content:center;font-size:3.2rem;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--verde-esc),var(--verde))}
.card-num{position:absolute;top:.7rem;right:.8rem;font-family:var(--f-disp);font-size:2.2rem;color:rgba(255,255,255,.07);line-height:1}
.card-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.card-titulo{font-family:var(--f-cond);font-size:1.1rem;font-weight:800;color:var(--cinza-esc);margin-bottom:.45rem;text-transform:uppercase;letter-spacing:.03em}
.card-desc{font-size:.88rem;color:var(--texto-cla);line-height:1.7;flex:1}
.card-link{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--f-cond);font-size:.8rem;font-weight:700;letter-spacing:.07em;color:var(--verde);text-transform:uppercase;margin-top:.9rem;transition:var(--trans)}
.card-link svg{transition:var(--trans)}
.servico-card:hover .card-link svg{transform:translateX(4px)}

/* ════ DIFERENCIAIS ════ */
.diferenciais-section{background:var(--cinza-esc)}
.diferenciais-section .sec-titulo{color:var(--branco)}
.diferenciais-grid{display:grid;grid-template-columns:1fr;gap:.9rem}
@media(min-width:480px){.diferenciais-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.diferenciais-grid{grid-template-columns:repeat(3,1fr)}}
.dif-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:1.4rem;transition:var(--trans)}
.dif-card:hover{background:rgba(45,205,112,.07);border-color:rgba(45,205,112,.22);transform:translateY(-3px)}
.dif-icone{font-size:1.75rem;margin-bottom:.75rem}
.dif-titulo{font-family:var(--f-cond);font-size:1.05rem;font-weight:700;color:var(--branco);margin-bottom:.4rem}
.dif-texto{font-size:.87rem;color:rgba(255,255,255,.44);line-height:1.7}

/* ════ PROCESSO ════ */
.processo-section{background:var(--branco)}
/* Mobile: lista vertical */
.processo-steps{display:flex;flex-direction:column;gap:1.8rem}
.step{display:flex;gap:1.1rem;align-items:flex-start}
.step-num{width:3.4rem;height:3.4rem;flex-shrink:0;background:var(--verde);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--f-disp);font-size:1.25rem;color:var(--branco);box-shadow:0 0 0 4px var(--branco),0 0 0 6px rgba(26,122,74,.18);transition:var(--trans)}
.step:hover .step-num{background:var(--verde-neon);color:var(--cinza-esc)}
.step-content{padding-top:.2rem}
.step-titulo{font-family:var(--f-cond);font-size:.98rem;font-weight:700;margin-bottom:.3rem}
.step-desc{font-size:.84rem;color:var(--texto-cla);line-height:1.6}
/* Tablet+: grid com linha */
@media(min-width:768px){
  .processo-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative;text-align:center}
  .processo-steps::before{content:'';position:absolute;top:2.2rem;left:2rem;right:2rem;height:2px;background:linear-gradient(90deg,var(--verde),var(--verde-neon));z-index:0}
  .step{flex-direction:column;align-items:center;gap:0}
  .step-num{margin:0 auto 1rem;width:4.5rem;height:4.5rem;font-size:1.6rem}
  .step-content{text-align:center}
}
@media(min-width:1024px){.processo-steps{grid-template-columns:repeat(6,1fr)}}

/* ════ SOBRE ════ */
.sobre-section{background:var(--cinza-cla)}
.sobre-grid{display:flex;flex-direction:column;gap:2.5rem}
@media(min-width:1024px){.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}}
.sobre-img{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:linear-gradient(135deg,var(--verde-esc),var(--verde));display:flex;align-items:center;justify-content:center;font-size:6rem;min-height:200px}
.sobre-img::after{content:'';position:absolute;bottom:-1rem;right:-1rem;width:45%;height:45%;border-right:3px solid var(--verde);border-bottom:3px solid var(--verde);border-radius:0 0 12px 0}
.sobre-img::before{content:'';position:absolute;top:-1rem;left:-1rem;width:32%;height:32%;border-left:3px solid var(--verde-neon);border-top:3px solid var(--verde-neon);border-radius:12px 0 0 0;z-index:1}
.cert-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--branco);border:1px solid rgba(26,122,74,.2);padding:.38rem .85rem;border-radius:30px;font-family:var(--f-cond);font-size:.78rem;font-weight:700;letter-spacing:.05em;color:var(--verde)}

/* ════ DEPOIMENTOS ════ */
.depoimentos-section{background:var(--branco)}
.dep-grid{display:grid;grid-template-columns:1fr;gap:1.1rem}
@media(min-width:600px){.dep-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.dep-grid{grid-template-columns:repeat(3,1fr)}}
.dep-card{background:var(--cinza-cla);border-radius:10px;padding:1.4rem;border-left:4px solid var(--verde);position:relative}
.dep-card::before{content:'"';font-size:4.5rem;line-height:.8;font-family:Georgia,serif;color:var(--verde);opacity:.12;position:absolute;top:.4rem;left:.7rem}
.dep-texto{font-size:.9rem;color:var(--texto);line-height:1.8;margin-bottom:.9rem;position:relative;z-index:1}
.dep-autor{display:flex;align-items:center;gap:.65rem}
.dep-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--verde);color:var(--branco);display:flex;align-items:center;justify-content:center;font-family:var(--f-cond);font-weight:800;font-size:.95rem}
.dep-nome{font-family:var(--f-cond);font-weight:700;font-size:.9rem}
.dep-cargo{font-size:.76rem;color:var(--texto-cla)}

/* ════ CONTATO ════ */
.contato-section{background:var(--cinza-esc)}
.contato-section .sec-titulo{color:var(--branco)}
.contato-grid{display:flex;flex-direction:column;gap:2.5rem}
@media(min-width:1024px){.contato-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start}}
.contato-info{color:rgba(255,255,255,.7)}
.contato-info>p{line-height:1.8;margin-bottom:1.8rem;font-size:.92rem}
.info-item{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.1rem}
.info-icone{width:42px;height:42px;flex-shrink:0;background:rgba(45,205,112,.1);border:1px solid rgba(45,205,112,.17);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.95rem}
.info-texto strong{display:block;color:var(--branco);font-family:var(--f-cond);font-size:.87rem;margin-bottom:.14rem;letter-spacing:.04em}
.info-texto span,.info-texto a{font-size:.84rem;color:rgba(255,255,255,.52);text-decoration:none}
.info-texto a:hover{color:var(--verde-neon)}
.sociais{display:flex;gap:.65rem;margin-top:1.7rem;flex-wrap:wrap}
.social-btn{width:42px;height:42px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.52);font-size:1rem;text-decoration:none;transition:var(--trans)}
.social-btn:hover{background:var(--verde);border-color:var(--verde);color:var(--branco);transform:translateY(-2px)}

/* Formulário */
.form-contato{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.4rem;backdrop-filter:blur(8px)}
@media(min-width:640px){.form-contato{padding:2rem}}
/* Mobile: 1 col; tablet+: 2 col */
.form-row{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:520px){.form-row{grid-template-columns:1fr 1fr;gap:1rem}}
.form-group{margin-bottom:.9rem}
.form-group label{display:block;font-family:var(--f-cond);font-size:.76rem;font-weight:700;letter-spacing:.1em;color:rgba(255,255,255,.52);text-transform:uppercase;margin-bottom:.32rem}
.form-group input,.form-group select,.form-group textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:.78rem 1rem;color:var(--branco);font-family:var(--f-corpo);font-size:1rem;transition:var(--trans);outline:none;min-height:48px}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.22)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--verde-neon);background:rgba(45,205,112,.06);box-shadow:0 0 0 3px rgba(45,205,112,.1)}
.form-group select{-webkit-appearance:none;cursor:pointer}
.form-group select option{background:var(--cinza-esc)}
.form-group textarea{resize:vertical;min-height:110px}
.form-msg{padding:.85rem 1rem;border-radius:var(--radius);font-family:var(--f-cond);font-size:.9rem;font-weight:600;margin-bottom:.75rem;display:none}
.form-msg.sucesso{background:rgba(45,205,112,.12);border:1px solid rgba(45,205,112,.28);color:var(--verde-neon);display:block}
.form-msg.erro{background:rgba(220,50,50,.12);border:1px solid rgba(220,50,50,.28);color:#ff6b6b;display:block}
.btn-submit{width:100%;padding:1rem;background:var(--verde);border:2px solid var(--verde);border-radius:var(--radius);cursor:pointer;font-family:var(--f-cond);font-size:1.05rem;font-weight:700;letter-spacing:.09em;color:var(--branco);text-transform:uppercase;transition:var(--trans);display:flex;align-items:center;justify-content:center;gap:.55rem;min-height:52px}
.btn-submit:hover{background:var(--verde-neon);border-color:var(--verde-neon);color:var(--cinza-esc)}
.btn-submit:active{transform:scale(.98)}
.btn-submit.loading{pointer-events:none;opacity:.7}
.spinner{width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite;display:none;flex-shrink:0}
.btn-submit.loading .spinner{display:block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ════ MAPA ════ */
.mapa-section{padding:0}
.mapa-wrap{height:260px;background:#1e2d23;position:relative}
@media(min-width:640px){.mapa-wrap{height:350px}}
.mapa-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(.4) contrast(1.05)}
.mapa-overlay{position:absolute;top:1rem;left:1rem;background:rgba(13,22,16,.92);border:1px solid rgba(45,205,112,.2);border-radius:8px;padding:.85rem 1.1rem;color:var(--branco);max-width:calc(100% - 2rem)}
@media(min-width:480px){.mapa-overlay{max-width:270px}}
.mapa-overlay strong{font-family:var(--f-cond);font-size:.92rem;display:block;color:var(--verde-neon);margin-bottom:.22rem}
.mapa-overlay span{font-size:.8rem;color:rgba(255,255,255,.52)}

/* ════ FOOTER ════ */
footer{background:#080f0a;padding:2.8rem 1.2rem 1.2rem;color:rgba(255,255,255,.42)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:1380px;margin:0 auto;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.07)}
@media(min-width:600px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand p{font-size:.87rem;line-height:1.8;margin-top:.75rem}
.footer-col h4{font-family:var(--f-cond);font-size:.8rem;font-weight:700;letter-spacing:.12em;color:var(--branco);text-transform:uppercase;margin-bottom:.9rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.45rem}
.footer-col a{text-decoration:none;font-size:.84rem;color:rgba(255,255,255,.38);transition:var(--trans)}
.footer-col a:hover{color:var(--verde-neon);padding-left:4px}
.footer-bottom{max-width:1380px;margin:1.1rem auto 0;display:flex;flex-direction:column;gap:.7rem;font-size:.77rem;text-align:center}
@media(min-width:640px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center;text-align:left}}
.footer-links{display:flex;gap:1.1rem;justify-content:center}
.footer-bottom a{color:rgba(255,255,255,.26);text-decoration:none}
.footer-bottom a:hover{color:var(--verde-neon)}

/* ════ FLOATS ════ */
.whatsapp-float{position:fixed;bottom:1.2rem;right:1.2rem;z-index:800;width:52px;height:52px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);text-decoration:none;transition:var(--trans);animation:wa-pulse 3s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.1)}
.whatsapp-float svg{width:27px;height:27px;color:white}
@keyframes wa-pulse{0%,100%{box-shadow:0 4px 16px rgba(37,211,102,.4)}50%{box-shadow:0 4px 28px rgba(37,211,102,.65),0 0 0 10px rgba(37,211,102,.07)}}
#back-top{position:fixed;bottom:4.6rem;right:1.2rem;z-index:800;width:42px;height:42px;background:rgba(13,22,16,.85);border:1px solid rgba(45,205,112,.24);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--verde-neon);transition:var(--trans);opacity:0;pointer-events:none;backdrop-filter:blur(6px)}
#back-top.visible{opacity:1;pointer-events:all}
#back-top:hover{background:var(--verde);border-color:var(--verde);color:var(--branco);transform:translateY(-2px)}

/* ════ HERO INTERNO ════ */
.hero-interno{background:linear-gradient(145deg,var(--verde-esc),var(--cinza-esc));padding:6.5rem 1.2rem 3rem;text-align:center;position:relative;overflow:hidden}
@media(min-width:640px){.hero-interno{padding:8rem 2rem 4rem}}
.hero-interno .hero-grid{position:absolute;inset:0}
.hero-interno h1{font-family:var(--f-disp);font-size:clamp(2.4rem,8vw,5rem);color:var(--branco);position:relative;z-index:1;margin-bottom:.65rem}
.hero-interno h1 em{color:var(--verde-neon);font-style:normal}
.hero-interno>p{color:rgba(255,255,255,.6);font-size:.95rem;max-width:560px;margin:0 auto;position:relative;z-index:1;line-height:1.8}
.breadcrumb{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.4rem;font-family:var(--f-cond);font-size:.76rem;letter-spacing:.07em;color:rgba(255,255,255,.36);margin-bottom:.75rem;position:relative;z-index:1}
.breadcrumb a{color:var(--verde-neon);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

/* ════ CONTEÚDO SERVIÇO ════ */
.servico-detalhe{background:var(--branco);padding:3.5rem 1.2rem}
@media(min-width:640px){.servico-detalhe{padding:4.5rem 1.6rem}}
@media(min-width:1024px){.servico-detalhe{padding:5rem 2rem}}
.servico-detalhe-grid{display:flex;flex-direction:column;gap:2.5rem}
@media(min-width:1024px){.servico-detalhe-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}}
.servico-detalhe h2{font-family:var(--f-cond);font-size:clamp(1.4rem,3vw,2rem);font-weight:800;color:var(--cinza-esc);margin-bottom:.7rem}
.servico-detalhe p{font-size:.92rem;color:var(--texto-cla);line-height:1.85;margin-bottom:1rem}
.feature-list{list-style:none;margin-top:1.1rem}
.feature-list li{display:flex;gap:.65rem;align-items:flex-start;padding:.6rem 0;border-bottom:1px solid rgba(0,0,0,.06);font-size:.9rem;color:var(--texto)}
.feature-list li::before{content:'✓';width:20px;height:20px;flex-shrink:0;background:rgba(26,122,74,.1);color:var(--verde);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700}
.servico-visual{background:linear-gradient(135deg,var(--verde-esc),var(--verde));border-radius:12px;height:260px;display:flex;align-items:center;justify-content:center;font-size:7rem;position:relative;overflow:hidden}
@media(min-width:640px){.servico-visual{height:360px;font-size:9rem}}
.specs-table{width:100%;border-collapse:collapse;margin-top:1.4rem}
.specs-table th,.specs-table td{padding:.7rem .85rem;text-align:left;border-bottom:1px solid rgba(0,0,0,.07);font-size:.87rem}
.specs-table th{font-family:var(--f-cond);font-weight:700;color:var(--verde);font-size:.76rem;letter-spacing:.07em;text-transform:uppercase;background:var(--cinza-cla)}
.specs-table tr:hover td{background:rgba(26,122,74,.03)}

/* ════ CTA STRIP ════ */
.cta-strip{background:var(--verde);padding:3.2rem 1.2rem;text-align:center}
@media(min-width:640px){.cta-strip{padding:4rem 2rem}}
.cta-strip h2{font-family:var(--f-disp);font-size:clamp(1.7rem,5vw,3.5rem);color:var(--branco);margin-bottom:.65rem}
.cta-strip p{color:rgba(255,255,255,.8);margin-bottom:1.7rem;font-size:.95rem;line-height:1.7}
.cta-strip .btn-prim{background:var(--branco);border-color:var(--branco);color:var(--verde);display:inline-flex}
.cta-strip .btn-prim:hover{background:var(--cinza-esc);border-color:var(--cinza-esc);color:var(--branco)}

/* ════ REVEAL ANIMATIONS ════ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .65s ease,transform .65s ease}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visivel,.reveal-left.visivel,.reveal-right.visivel{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important}}
