/* Fontes hospedadas localmente (sem dependência do Google Fonts) */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/inter-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/inter-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/inter-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Archivo';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/archivo-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/archivo-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/archivo-latin-700-normal.woff2') format('woff2')}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/archivo-latin-800-normal.woff2') format('woff2')}

:root{
  --green:#02A742; --green-d:#02853a; --blue:#0A4F8A; --blue-d:#0a3d6b;
  --orange:#F6821F; --ink:#16202a; --muted:#5a6b78; --line:#e6ebef;
  --bg:#ffffff; --bg-alt:#f5f8fa; --white:#fff; --radius:14px;
  --shadow:0 6px 24px rgba(16,32,42,.08); --shadow-lg:0 18px 48px rgba(16,32,42,.16);
  --maxw:1160px; --display:'Archivo',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);line-height:1.12;margin:0 0 .4em;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.5vw,3.3rem);font-weight:800}
h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700}
h3{font-size:1.18rem;font-weight:700}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:780px}
.center{text-align:center}
.eyebrow{display:inline-block;font-family:var(--display);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);margin-bottom:.5rem}
.center .eyebrow{margin-bottom:.7rem}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:600;font-size:.98rem;
  padding:.8rem 1.5rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:#e0700f;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-light{background:#fff;color:var(--blue-d)}
.btn-light:hover{transform:translateY(-2px)}
.btn-wa{background:var(--green);color:#fff}
.btn-wa:hover{background:var(--green-d)}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:1.2rem;height:118px;transition:height .25s}
.site-header.shrink .header-inner{height:78px}
.logo img{height:96px;width:auto;transition:height .25s}
.site-header.shrink .logo img{height:62px}
.mainnav{margin-left:auto}
.mainnav ul{display:flex;gap:.3rem;list-style:none;margin:0;padding:0}
.navlink{display:block;padding:.55rem .8rem;font-family:var(--display);font-weight:600;font-size:.95rem;color:var(--ink);border-radius:8px}
.navlink:hover,.navlink.active{color:var(--green)}
.caret{font-size:.7em;opacity:.6;margin-left:.2rem}
.has-sub{position:relative}
.submenu{position:absolute;top:100%;left:0;min-width:250px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:.4rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:.6rem .8rem;border-radius:8px;color:var(--ink);font-size:.93rem;font-weight:500}
.submenu a:hover{background:var(--bg-alt);color:var(--green)}
.header-cta{padding:.6rem 1.15rem;font-size:.9rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.2s}

/* hero */
.hero{position:relative;color:#fff;background-color:var(--blue-d);display:flex;align-items:center;min-height:clamp(460px,44vw,760px)}
.hero-inner{position:relative;padding:5.5rem 22px;max-width:var(--maxw);margin:0 auto}
.hero h1{color:#fff;max-width:18ch}
.hero-sub{font-size:1.15rem;max-width:60ch;color:rgba(255,255,255,.92);margin-bottom:1.6rem}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.center-actions{justify-content:center}
.breadcrumb{font-size:.85rem;color:rgba(255,255,255,.8);margin-bottom:1rem;display:flex;gap:.5rem;align-items:center}
.breadcrumb a{color:rgba(255,255,255,.9)}
.breadcrumb span{opacity:.7}

/* sections */
.section{padding:4.5rem 0}
.section-alt{background:var(--bg-alt)}
.section .center h2{margin-bottom:2.2rem}
.lead-cta{font-family:var(--display);font-weight:600;font-size:1.18rem;color:var(--blue-d);border-left:4px solid var(--orange);padding-left:1rem;margin:1.5rem 0}

/* grids */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.6rem;box-shadow:var(--shadow)}
.section-alt .feature{background:#fff}
.feature-icon{width:46px;height:46px;border-radius:12px;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.3rem;margin-bottom:1rem}
.feature p{color:var(--muted);margin:0;font-size:.97rem}

/* cards */
.cards .card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.2s}
.cards .card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.card-img{aspect-ratio:16/10;background:var(--bg-alt) center/cover no-repeat}
.card-body{padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.card-body h3{margin:0;color:var(--ink)}
.card-body p{font-size:.9rem;color:var(--muted);margin:0}
.card-link{margin-top:auto;font-family:var(--display);font-weight:700;color:var(--green);font-size:.92rem}

/* two-col */
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.col-text .btn{margin-top:.6rem}
.col-img img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;object-fit:cover}
.contact-list{list-style:none;padding:0;margin:1.2rem 0}
.contact-list li{padding:.5rem 0;border-bottom:1px solid var(--line)}

/* form */
.col-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem}
.contact-form{display:flex;flex-direction:column;gap:.9rem}
.contact-form label{display:flex;flex-direction:column;gap:.35rem;font-family:var(--display);font-weight:600;font-size:.9rem;color:var(--blue-d)}
.contact-form input,.contact-form textarea{font-family:var(--body);font-size:1rem;padding:.7rem .85rem;border:1.5px solid var(--line);border-radius:10px;background:var(--bg-alt)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--green);background:#fff}
.contact-form .btn{margin-top:.4rem;justify-content:center}
.hp{position:absolute!important;left:-9999px!important;height:0;width:0;opacity:0}

/* cta band */
.cta-band{background:linear-gradient(120deg,var(--blue-d),var(--green-d));color:#fff}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:2.6rem 22px;flex-wrap:wrap}
.cta-inner p{font-family:var(--display);font-weight:700;font-size:1.3rem;margin:0;max-width:60ch}

/* thank you */
.thankyou{padding:6rem 0}
.check{width:80px;height:80px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-size:2.6rem;margin:0 auto 1.5rem}

/* footer */
.site-footer{background:#10202c;color:#c3d0da}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;padding:3.5rem 22px 2.5rem}
.fcol h4{color:#fff;font-size:1rem;margin-bottom:1rem}
.fcol a{display:block;color:#aebcc7;padding:.28rem 0;font-size:.94rem}
.fcol a:hover{color:var(--green)}
.fbrand img{margin-bottom:1rem}
.fbrand p{color:#94a6b2;font-size:.94rem}
.fcontact a{color:var(--green);font-weight:600}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08)}
.footer-bottom .container{display:flex;justify-content:space-between;gap:1rem;padding:1.3rem 22px;font-size:.85rem;color:#7e909d;flex-wrap:wrap}

/* whatsapp float */
.wa-float{position:fixed;right:20px;bottom:20px;width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-lg);z-index:60;transition:.2s}
.wa-float:hover{transform:scale(1.08)}

/* responsive */
@media(max-width:900px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr;gap:2rem}
  .col-img{order:-1}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .burger{display:flex}
  .header-cta{display:none}
  .mainnav{position:fixed;inset:118px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);max-height:0;overflow:hidden;transition:.25s;margin:0}
  .mainnav.open{max-height:85vh;overflow:auto}
  .mainnav ul{flex-direction:column;padding:.6rem}
  .navlink{padding:.85rem .6rem;border-bottom:1px solid var(--line)}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0 0 .5rem 1rem;display:none}
  .has-sub.open .submenu{display:block}
  .cta-inner{flex-direction:column;text-align:center}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:520px){.grid-3,.grid-4{grid-template-columns:1fr}.hero-inner{padding:3.5rem 22px}}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}

/* ===================== ANIMAÇÕES ===================== */
/* Hero: leve zoom contínuo (ken burns) + entrada do conteúdo */
.hero{overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(10,40,70,.62),rgba(10,40,70,.62)),var(--hero) var(--hero-pos,center 40%)/cover no-repeat;background-color:var(--blue-d);transform:scale(1.0);animation:kenburns 24s ease-in-out infinite alternate;z-index:0}
.hero-overlay{display:none}
.hero-inner{z-index:1}
@keyframes kenburns{from{transform:scale(1.0) translateY(0)}to{transform:scale(1.04) translateY(-4px)}}
.hero h1{opacity:0;transform:translateY(18px);animation:heroUp .7s .15s ease forwards}
.hero-sub{opacity:0;transform:translateY(18px);animation:heroUp .7s .32s ease forwards}
.hero-actions{opacity:0;transform:translateY(18px);animation:heroUp .7s .5s ease forwards}
.breadcrumb{opacity:0;animation:fadeIn .6s .1s ease forwards}
@keyframes heroUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}

/* Reveal ao rolar (controlado por JS via .in) */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* Cabeçalho com sombra ao rolar */
.site-header{transition:box-shadow .25s,background .25s}
.site-header.shrink{box-shadow:0 6px 24px rgba(16,32,42,.08)}

/* Cards: brilho/elevação + zoom na imagem */
.cards .card{position:relative}
.cards .card .card-img{transition:transform .5s ease}
.cards .card:hover .card-img{transform:scale(1.07)}
.cards .card::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.cards .card:hover::after{transform:scaleX(1)}
.card-link{transition:gap .25s;display:inline-flex;gap:.15rem}
.cards .card:hover .card-link{gap:.5rem;color:var(--green-d)}

/* Botões: leve brilho ao passar */
.btn{position:relative;overflow:hidden}
.btn::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);transition:left .6s}
.btn:hover::before{left:130%}

/* Ícone de diferencial: pop */
.feature{transition:transform .3s ease,box-shadow .3s ease}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature-icon{transition:transform .3s ease}
.feature:hover .feature-icon{transform:rotate(-8deg) scale(1.08)}

/* Imagem em coluna: revela com leve clip */
.col-img img{transition:transform .5s ease,box-shadow .3s ease}
.col-img:hover img{transform:translateY(-4px) scale(1.01)}

/* Links de navegação: sublinhado animado */
.navlink{position:relative}
.navlink::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.3rem;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.navlink:hover::after,.navlink.active::after{transform:scaleX(1)}

/* WhatsApp flutuante: pulso suave */
.wa-float{animation:wapulse 2.6s ease-in-out infinite}
@keyframes wapulse{0%,100%{box-shadow:var(--shadow-lg),0 0 0 0 rgba(37,211,102,.5)}50%{box-shadow:var(--shadow-lg),0 0 0 14px rgba(37,211,102,0)}}

/* Banda CTA: brilho sutil em movimento */
.cta-band{position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;top:-50%;left:-30%;width:50%;height:200%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.08),transparent);transform:skewX(-18deg);animation:ctaSheen 6s linear infinite}
@keyframes ctaSheen{0%{left:-40%}60%,100%{left:130%}}

@media(prefers-reduced-motion:reduce){
  .hero::before{animation:none;transform:scale(1.0)}
  .hero h1,.hero-sub,.hero-actions,.breadcrumb{animation:none;opacity:1;transform:none}
  .reveal{opacity:1;transform:none;transition:none}
  .wa-float,.cta-band::after,.btn::before{animation:none}
}

/* logo no rodapé sobre chip branco para contraste */
.fbrand img{height:100px;width:auto;background:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 4px 14px rgba(0,0,0,.18)}

/* galeria de fotos reais */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gal-item{display:block;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--bg-alt)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gal-item:hover img{transform:scale(1.08)}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.gallery{grid-template-columns:1fr}}

/* ===== Lightbox ===== */
.gal-item{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(10,20,28,.92);
  display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;
  transition:opacity .25s ease;padding:3vw}
.lightbox.open{opacity:1;visibility:visible}
.lb-figure{margin:0;max-width:92vw;max-height:88vh;display:flex}
.lb-img{max-width:92vw;max-height:88vh;width:auto;height:auto;border-radius:10px;
  box-shadow:0 24px 60px rgba(0,0,0,.5);transform:scale(.96);transition:transform .25s ease}
.lightbox.open .lb-img{transform:scale(1)}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.12);border:0;color:#fff;
  cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:background .2s}
.lb-close:hover,.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-close{top:18px;right:22px;width:46px;height:46px;font-size:1.9rem;line-height:1}
.lb-nav{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:1.5rem}
.lb-prev{left:18px}.lb-next{right:18px}
@media(max-width:560px){.lb-nav{width:42px;height:42px}.lb-prev{left:8px}.lb-next{right:8px}.lb-close{top:10px;right:12px}}

/* texto introdutório das páginas com galeria + espaçamento da galeria */
.narrow-text{max-width:880px}
.gallery-section{padding-top:0}

/* rodapé: 4 colunas (marca + Contato + Navegue + Funcionamento) */
.footer-grid{grid-template-columns:1.4fr 1.3fr .8fr 1fr}
.faddr{color:#94a6b2;font-size:.9rem;margin-top:.5rem;line-height:1.5}
.fhours{color:#aebcc7;font-size:.92rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* mensagens e nota do formulário */
.form-msg{margin:.4rem 0 0;font-size:.92rem;font-weight:600}
.form-msg.error{color:#c0392b}
.form-msg.ok{color:var(--green-d)}
.form-note{margin:.6rem 0 0;font-size:.8rem;color:var(--muted);font-weight:400}

/* crédito de desenvolvimento (rodapé) */
.dev-credit{display:inline-flex;align-items:center;gap:.5rem;color:#7e909d;font-size:.82rem;transition:color .2s}
.dev-credit span{color:#7e909d}
.dev-credit img{height:26px;width:auto;opacity:.9;transition:opacity .2s}
.dev-credit:hover{color:#aebcc7}
.dev-credit:hover img{opacity:1}

/* selo do reCAPTCHA v3 acima do botao flutuante do WhatsApp (canto inferior direito) */
.grecaptcha-badge{ bottom:90px !important; }
