/* ===== Maxx Pav — estilos compartilhados (HTML/CSS puro, sem build) ===== */
:root{
  --red:#8b0000;
  --red-hi:#b31217;
  --asphalt:#161514;
  --asphalt-2:#211f1d;
  --graphite:#3a3835;
  --concrete:#6b6a66;
  --concrete-lo:#d8d5cd;
  --sand:#f4f1ea;
  --sand-2:#efece5;
  --white:#ffffff;
  --disp:'Archivo',sans-serif;
  --body:'Barlow',sans-serif;
  --cond:'Barlow Semi Condensed',sans-serif;
  --maxw:1160px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-nav:cubic-bezier(.4,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --r-sm:10px;
  --r:16px;
  --r-lg:22px;
  --shadow:0 16px 38px -16px rgba(22,21,20,.32);
  --shadow-sm:0 8px 20px -12px rgba(22,21,20,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--body);color:var(--asphalt);background:var(--sand);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.disp{font-family:var(--disp);font-weight:800;line-height:1.04;letter-spacing:-.01em;text-wrap:balance}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--cond);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.82rem}
.kicker{color:var(--red);display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
.kicker::before{content:"";width:30px;height:3px;background:var(--red)}
.section{padding:72px 0}
.section-head{max-width:640px;margin-bottom:40px}
.section-head h2{font-size:clamp(1.8rem,4vw,2.7rem);font-weight:800;margin-bottom:12px}
.section-head p{color:var(--concrete);font-size:1.06rem}
.muted{color:var(--concrete)}

/* faixa "sinalização" — assinatura (vermelho/asfalto) */
.hazard{height:7px;background:repeating-linear-gradient(-45deg,var(--red) 0 20px,var(--asphalt) 20px 40px);background-size:56.57px 56.57px;animation:hazard-move 2.6s linear infinite}
@keyframes hazard-move{to{background-position:56.57px 0}}

/* ===== botões ===== */
.btn{font-family:var(--cond);font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:.95rem;padding:15px 28px;border:2px solid transparent;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .15s var(--ease),background .2s,border-color .2s,color .2s,box-shadow .2s;line-height:1}
.btn-red{background:var(--red);color:#fff;position:relative;overflow:hidden;isolation:isolate;box-shadow:0 10px 24px -12px rgba(139,0,0,.7);animation:btn-halo 3.4s ease-in-out infinite}
.btn-red::after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);animation:btn-sheen 4.6s ease-in-out 1s infinite;pointer-events:none}
.btn-red:hover{background:var(--red-hi);transform:translateY(-3px) scale(1.02);animation-play-state:paused;transition:transform .3s var(--ease-spring),background .2s}
.btn-red:active{transform:translateY(-1px) scale(.99);transition:transform .1s}
@keyframes btn-halo{0%,100%{box-shadow:0 10px 24px -12px rgba(139,0,0,.7),0 0 0 0 rgba(179,18,23,.5)}50%{box-shadow:0 12px 30px -10px rgba(179,18,23,.85),0 0 0 7px rgba(179,18,23,0)}}
@keyframes btn-sheen{0%{left:-120%}22%,100%{left:130%}}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-3px);transition:transform .18s var(--ease),border-color .3s,background .3s}
.btn-dark{background:var(--asphalt);color:#fff}
.btn-dark:hover{background:var(--graphite);transform:translateY(-2px)}
.btn-lg{padding:18px 34px;font-size:1rem}

/* ===== header ===== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(22,21,20,.96);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:74px}
.brand{display:flex;flex-direction:column;line-height:1;color:#fff}
.brand .bwm{font-family:var(--disp);font-weight:900;font-size:1.5rem;letter-spacing:.02em}
.brand .bwm span{color:var(--red-hi)}
.brand small{font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:rgba(255,255,255,.55);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;color:rgba(255,255,255,.82);padding:6px 0;position:relative;display:inline-block;transition:color .5s var(--ease-nav),transform .5s var(--ease-nav)}
.nav-links a:hover{color:#fff;transform:translateY(-1px);text-shadow:0 0 12px rgba(179,18,23,.5)}
.nav-links a::after{content:"";position:absolute;left:50%;right:50%;bottom:-2px;height:2px;background:var(--red-hi);transition:left .5s var(--ease-nav),right .5s var(--ease-nav)}
.nav-links a:hover::after{left:0;right:0}
.site-header{transition:background .5s var(--ease-nav),box-shadow .5s var(--ease-nav)}
.nav{transition:height .5s var(--ease-nav)}
.site-header.scrolled{box-shadow:0 8px 26px -14px rgba(0,0,0,.7);border-bottom-color:rgba(179,18,23,.45)}
.site-header.scrolled .nav{height:60px}
.brand .bwm{transition:font-size .5s var(--ease-nav)}
.site-header.scrolled .brand .bwm{font-size:1.3rem}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-phone{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--cond);font-weight:700;font-size:1rem;white-space:nowrap}
.nav-phone svg{width:18px;height:18px;color:var(--red-hi)}
.hamb{display:none;background:none;border:0;width:44px;height:44px;flex:none;cursor:pointer;flex-direction:column;justify-content:center;gap:6px;padding:10px}
.brand{flex:none}
.hamb span{height:2px;background:#fff;display:block;transition:.25s var(--ease)}

/* menu mobile */
.mobile-menu{position:fixed;inset:74px 0 0;background:var(--asphalt);z-index:99;transform:translateX(100%);transition:transform .4s var(--ease-out);display:flex;flex-direction:column;padding:24px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{color:#fff;font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:1.15rem;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1);opacity:0;transform:translateX(24px);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out)}
.mobile-menu.open a{opacity:1;transform:none}
.mobile-menu.open a:nth-child(1){transition-delay:.06s}
.mobile-menu.open a:nth-child(2){transition-delay:.12s}
.mobile-menu.open a:nth-child(3){transition-delay:.18s}
.mobile-menu.open a:nth-child(4){transition-delay:.24s}
.mobile-menu.open a:nth-child(5){transition-delay:.30s}
.mobile-menu.open a:nth-child(6){transition-delay:.36s}
.mobile-menu.open a:nth-child(7){transition-delay:.42s}
.mobile-menu.open a:nth-child(8){transition-delay:.48s}
.mobile-menu .btn{margin-top:22px}
.hamb.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamb.active span:nth-child(2){opacity:0}
.hamb.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===== hero ===== */
.hero{position:relative;background:#0d0c0b;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 42%;filter:grayscale(.12) contrast(1.05)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;z-index:0;pointer-events:none}
.hero-bg::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(13,12,11,.95) 0%,rgba(13,12,11,.8) 45%,rgba(13,12,11,.4) 100%),linear-gradient(0deg,rgba(139,0,0,.25),transparent 55%)}
.hero-in{position:relative;z-index:2;padding:100px 0 90px;max-width:760px}
.hero .eyebrow{color:#fff;display:inline-flex;align-items:center;gap:12px;margin-bottom:22px;opacity:.9}
.hero .eyebrow::before{content:"";width:34px;height:3px;background:var(--red-hi)}
.hero h1{font-size:clamp(2.5rem,6vw,4.6rem);font-weight:900;margin-bottom:20px}
.hero h1 em{font-style:normal;color:#ff5a56}
.hero .sub{font-size:clamp(1.05rem,2vw,1.28rem);color:rgba(255,255,255,.82);max-width:560px;margin-bottom:32px;font-weight:400}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.hero-strip{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:22px 46px;padding:22px 0 0;border-top:1px solid rgba(255,255,255,.14);margin-top:44px}
.hs{display:flex;align-items:baseline;gap:10px}
.hs b{font-family:var(--disp);font-weight:800;font-size:1.7rem;color:#fff;font-variant-numeric:tabular-nums}
.hs span{font-family:var(--cond);text-transform:uppercase;letter-spacing:.07em;font-size:.76rem;color:rgba(255,255,255,.6);line-height:1.15}

/* ===== trust bar ===== */
.trust{background:var(--asphalt);color:#fff}
.trust-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.trust-item{background:var(--asphalt-2);border:1px solid rgba(255,255,255,.09);border-radius:var(--r);padding:24px 22px;display:flex;gap:14px;align-items:flex-start;transition:transform .2s var(--ease),border-color .2s}
.trust-item:hover{transform:translateY(-4px);border-color:rgba(179,18,23,.5)}
.trust-item svg{width:30px;height:30px;color:var(--red-hi);flex:none}
.trust-item b{font-family:var(--disp);font-weight:700;font-size:1.02rem;display:block;margin-bottom:3px}
.trust-item span{color:rgba(255,255,255,.6);font-size:.9rem}

/* ===== serviços (blocos alternados) ===== */
.svc-block{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:#fff;border:1px solid #e7e3d9;border-radius:var(--r-lg);margin-bottom:24px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s;position:relative}
.svc-block:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.svc-block .svc-ph{background-size:cover;background-position:center;min-height:320px;transition:transform .6s var(--ease);border-radius:inherit;overflow:hidden}
.svc-block:hover .svc-ph{transform:scale(1.06)}

/* bordas brilhantes coloridas — anel giratório (fotos/blocos de serviço) */
.glow{position:relative;isolation:isolate}
.glow::before{
  content:"";position:absolute;inset:-2px;border-radius:inherit;padding:2px;z-index:0;pointer-events:none;
  background:conic-gradient(from var(--glow-angle),transparent 0deg,var(--c1) 70deg,var(--c2) 160deg,transparent 250deg,var(--c1) 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:glow-spin 8s linear infinite,glow-breathe 3.4s ease-in-out infinite;will-change:--glow-angle;
}
.glow:hover::before{filter:drop-shadow(0 0 7px var(--c1))}
.glow > *{position:relative;z-index:1}
@keyframes glow-spin{to{--glow-angle:360deg}}
@keyframes glow-breathe{0%,100%{opacity:.65}50%{opacity:1}}
.svc-block:nth-of-type(1).glow::before{animation-delay:0s,0s}
.svc-block:nth-of-type(2).glow::before{animation-delay:-2s,-.8s}
.svc-block:nth-of-type(3).glow::before{animation-delay:-4s,-1.6s}
.svc-block:nth-of-type(4).glow::before{animation-delay:-6s,-2.4s}
/* dessincroniza os anéis das fotos/cards (galeria, trust, etapas, regiões) */
.glow:nth-child(2)::before{animation-delay:-1.1s,-.5s}
.glow:nth-child(3)::before{animation-delay:-2.2s,-1s}
.glow:nth-child(4)::before{animation-delay:-3.3s,-1.5s}
.glow:nth-child(5)::before{animation-delay:-4.4s,-2s}
.glow:nth-child(6)::before{animation-delay:-5.5s,-2.6s}
.glow:nth-child(7)::before{animation-delay:-6.6s,-3.1s}
.glow:nth-child(8)::before{animation-delay:-7.7s,-3.6s}
@supports not (background:conic-gradient(from 0deg,red,blue)){
  .glow::before{background:none;box-shadow:0 0 0 2px var(--c1),0 0 16px -2px var(--c1);animation:glow-breathe 3.4s ease-in-out infinite}
}
.svc-block .svc-txt{padding:40px}
.svc-block:nth-child(even) .svc-ph{order:2}
.svc-block .svc-num{font-family:var(--disp);font-weight:900;font-size:1.1rem;color:var(--red);letter-spacing:.05em}
.svc-block h3{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;margin:6px 0 14px}
.svc-block p{color:var(--concrete);margin-bottom:18px}
.svc-block ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px 18px;margin-bottom:22px}
.svc-block li{font-family:var(--cond);font-weight:600;font-size:.92rem;color:var(--graphite);display:flex;align-items:center;gap:8px}
.svc-block li::before{content:"";width:8px;height:8px;background:var(--red);transform:rotate(45deg);flex:none}
.svc-block a.more{font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--red);font-size:.92rem;display:inline-flex;align-items:center;gap:8px}
.svc-block a.more:hover{color:var(--red-hi)}

/* ===== prova social (prefeituras) ===== */
.social{background:var(--sand-2);border-top:1px solid #e4e0d6;border-bottom:1px solid #e4e0d6}
.social .lbl{text-align:center;color:var(--concrete);font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;margin-bottom:26px}
.logo-track{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap;background:#fff;border:1px solid #e7e3d9;border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:30px 28px}
.logo-track img{height:56px;width:auto;filter:grayscale(1);opacity:.7;transition:.25s}
.logo-track img:hover{filter:grayscale(0);opacity:1}

/* ===== diferenciais ===== */
.why{background:var(--asphalt);color:#fff}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.why-card{background:var(--asphalt-2);border:1px solid rgba(255,255,255,.08);border-top:3px solid var(--red);border-radius:var(--r-lg);padding:32px 30px;position:relative;transition:transform .22s var(--ease),border-color .22s}
.why-card:hover{transform:translateY(-5px);border-color:rgba(179,18,23,.45)}
.why-card svg{width:32px;height:32px;color:var(--red-hi);margin-bottom:16px}
.why-card h3{font-size:1.2rem;font-weight:700;margin-bottom:8px}
.why-card p{color:rgba(255,255,255,.65);font-size:.96rem}

/* ===== galeria ===== */
.gallery{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.gallery a{position:relative;overflow:hidden;aspect-ratio:4/3;background:#ddd;border-radius:var(--r);box-shadow:var(--shadow-sm);transition:box-shadow .25s,transform .25s var(--ease)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery a:hover{transform:translateY(-4px);box-shadow:0 0 0 3px var(--red),var(--shadow)}
.gallery a:hover img{transform:scale(1.08)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(139,0,0,.4),transparent 55%);opacity:0;transition:.3s}
.gallery a:hover::after{opacity:1}
.gallery a.glow::before{inset:0;z-index:2;padding:2.5px}   /* anel giratório colorido na borda da foto (acima da imagem) */

/* ===== áreas teaser ===== */
.areas{background:var(--red);color:#fff;text-align:center}
.areas h2{font-size:clamp(1.7rem,4vw,2.5rem);margin-bottom:12px}
.areas p{color:rgba(255,255,255,.85);max-width:640px;margin:0 auto 26px;font-size:1.06rem}
.areas .chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:820px;margin:0 auto 30px}
.areas .chips span{font-family:var(--cond);font-weight:600;font-size:.88rem;border:1px solid rgba(255,255,255,.4);padding:8px 16px;border-radius:999px;transition:transform .25s var(--ease),background .2s;white-space:nowrap}
.areas .chips span:hover{transform:translateY(-3px) scale(1.04);background:rgba(255,255,255,.18)}
/* esteira infinita de cidades (igual VCL) */
.areas .chips.marquee{display:block;max-width:1000px;margin:0 auto 30px;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.areas .chips.marquee .mq-track{display:flex;flex-wrap:nowrap;gap:10px;width:max-content;animation:areas-mq 30s linear infinite}
.areas .chips.marquee:hover .mq-track{animation-play-state:paused}
@keyframes areas-mq{to{transform:translateX(-50%)}}

/* ===== orçamento / form ===== */
.quote{background:var(--sand-2)}
.quote-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.quote-info h2{font-size:clamp(1.7rem,3.5vw,2.4rem);margin-bottom:14px}
.quote-info p{color:var(--concrete);margin-bottom:22px}
.quote-info .contact-line{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-size:1.05rem}
.quote-info .contact-line svg{width:22px;height:22px;color:var(--red);flex:none}
.quote-info .contact-line b{font-family:var(--cond)}
form.quote-form{background:#fff;border:1px solid #e7e3d9;border-top:4px solid var(--red);border-radius:var(--r-lg);padding:34px 30px;box-shadow:var(--shadow)}
form.quote-form .frow{margin-bottom:16px}
form.quote-form label{display:block;font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;color:var(--graphite);margin-bottom:6px}
form.quote-form input,form.quote-form select,form.quote-form textarea{width:100%;padding:13px 15px;border:1px solid #d4d0c6;border-radius:var(--r-sm);background:var(--sand);font-family:var(--body);font-size:1rem;color:var(--asphalt);transition:border-color .2s,box-shadow .2s}
form.quote-form input:focus,form.quote-form select:focus,form.quote-form textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(139,0,0,.12)}
form.quote-form textarea{resize:vertical;min-height:96px}
form.quote-form .btn{width:100%;margin-top:6px}
.form-note{font-size:.82rem;color:var(--concrete);margin-top:12px;text-align:center}

/* ===== footer ===== */
.site-footer{background:#0e0d0c;color:rgba(255,255,255,.7);padding:56px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px}
.foot-brand .bwm{font-family:var(--disp);font-weight:900;font-size:1.5rem;color:#fff}
.foot-brand .bwm span{color:var(--red-hi)}
.foot-brand p{margin-top:14px;font-size:.94rem;max-width:36ch}
.foot-col h4{font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;color:#fff;margin-bottom:16px}
.foot-col a,.foot-col p{display:block;font-size:.94rem;margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-social{display:flex;gap:12px;margin-top:6px}
.foot-social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.2s}
.foot-social a:hover{background:var(--red);border-color:var(--red)}
.foot-social svg{width:18px;height:18px;color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;color:rgba(255,255,255,.5)}

/* ===== whatsapp float ===== */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:120;width:60px;height:60px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(37,211,102,.4);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px;color:#fff}

/* ===== reveal ===== */
.reveal{opacity:0;transform:translateY(34px) scale(.98);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out);will-change:transform,opacity}
.reveal.in{opacity:1;transform:none}
.reveal-l{transform:translateX(-42px)}
.reveal-r{transform:translateX(42px)}
.reveal-l.in,.reveal-r.in{transform:none}

/* barra de progresso de scroll */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;z-index:200;transform:scaleX(0);transform-origin:0 50%;background:linear-gradient(90deg,var(--red),var(--red-hi),#ff7a18);box-shadow:0 0 10px rgba(179,18,23,.6);pointer-events:none;will-change:transform}
/* parallax do hero/subhero (elemento maior que o container) */
.hero-bg,.subhero .sub-bg{top:-8%;bottom:auto;height:116%;will-change:transform}
/* ping do WhatsApp */
.wa-float::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25d366;z-index:-1;animation:wa-ping 2.8s ease-out infinite}
@keyframes wa-ping{0%{transform:scale(1);opacity:.55}70%,100%{transform:scale(1.9);opacity:0}}

/* ===== responsivo ===== */
@media(max-width:960px){
  .nav-links,.nav-cta{display:none}
  .hamb{display:flex}
  .trust-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .why-grid{grid-template-columns:1fr}
  .quote-grid{grid-template-columns:1fr;gap:32px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:720px){
  .svc-block{grid-template-columns:1fr}
  .svc-block .svc-ph{min-height:220px;order:0!important}
  .svc-block .svc-txt{padding:28px}
  .hero-in{padding:70px 0 60px}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .foot-grid{grid-template-columns:1fr}
  .section{padding:52px 0}
  .btn{width:100%}
  .cta-row .btn{width:auto;flex:1}
}

/* ===== páginas internas ===== */
.subhero{position:relative;background:#0d0c0b;color:#fff;overflow:hidden}
.subhero .sub-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(.12) contrast(1.05)}
.subhero .sub-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,12,11,.95),rgba(13,12,11,.72) 60%,rgba(13,12,11,.45)),linear-gradient(0deg,rgba(139,0,0,.22),transparent 60%)}
.subhero-in{position:relative;z-index:2;padding:66px 0 58px;max-width:760px}
.breadcrumb{font-family:var(--cond);font-weight:600;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:16px}
.breadcrumb a{color:rgba(255,255,255,.75)}
.breadcrumb a:hover{color:#fff}
.breadcrumb b{color:#ff6b67;font-weight:600}
.subhero h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:900;margin-bottom:14px}
.subhero p{color:rgba(255,255,255,.82);max-width:560px;margin-bottom:24px;font-size:clamp(1rem,2vw,1.15rem)}

.content-2col{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.content-2col.rev .c-media{order:-1}
.c-media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background-size:cover;background-position:center;border:1px solid #e7e3d9}
.c-body h2{font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:14px}
.c-body p{color:var(--concrete);margin-bottom:14px}
.feat-list{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 22px;margin-top:20px}
.feat-list li{display:flex;gap:10px;align-items:flex-start;color:var(--graphite);font-weight:500}
.feat-list li svg{width:20px;height:20px;color:var(--red);flex:none;margin-top:3px}

.proc{background:var(--sand-2);border-top:1px solid #e7e3d9;border-bottom:1px solid #e7e3d9}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;margin-top:36px}
.step-card{background:#fff;border:1px solid #e7e3d9;border-radius:var(--r);padding:26px 24px;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s}
.step-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step-card .sn{font-family:var(--disp);font-weight:900;font-size:2rem;color:transparent;-webkit-text-stroke:1.5px var(--red);line-height:1;display:block;margin-bottom:12px}
.step-card h3{font-size:1.1rem;margin-bottom:6px}
.step-card p{color:var(--concrete);font-size:.93rem}

.cta-band{background:var(--red);color:#fff;text-align:center}
.cta-band h2{font-size:clamp(1.6rem,3.6vw,2.4rem);margin-bottom:12px;color:#fff}
.cta-band p{color:rgba(255,255,255,.88);max-width:580px;margin:0 auto 26px;font-size:1.05rem}

.region{background:#fff;border:1px solid #e7e3d9;border-left:4px solid var(--red);border-radius:var(--r-lg);padding:28px 30px;box-shadow:var(--shadow-sm);margin-bottom:20px}
.region h3{font-size:1.25rem;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.region h3 svg{width:22px;height:22px;color:var(--red)}
.region .cities{display:flex;flex-wrap:wrap;gap:8px}
.region .cities span{font-family:var(--cond);font-weight:600;font-size:.9rem;background:var(--sand-2);border:1px solid #e0dccf;padding:7px 14px;border-radius:999px;color:var(--graphite)}

.map-embed{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid #e7e3d9;line-height:0;margin-top:26px}
.map-embed iframe{width:100%;height:360px;border:0;display:block}

@media(max-width:820px){
  .content-2col{grid-template-columns:1fr;gap:28px}
  .content-2col .c-media{order:-1}
  .feat-list{grid-template-columns:1fr}
}

/* ===== motor de animação: @property + acessibilidade + economia ===== */
@property --glow-angle{ syntax:'<angle>'; inherits:false; initial-value:0deg; }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
  }
  .reveal,.reveal-l,.reveal-r{opacity:1!important;transform:none!important}
  .scroll-progress{display:none!important}
  .hero-bg,.subhero .sub-bg{transform:none!important}
  .glow::before{animation:none!important;opacity:.55}
}
/* aba oculta: pausa as animações infinitas (economia de CPU, sem "pulo" ao voltar) */
.tab-hidden .glow::before,.tab-hidden .gallery a.glow,.tab-hidden .hazard,
.tab-hidden .btn-red,.tab-hidden .btn-red::after,.tab-hidden .wa-float::before,
.tab-hidden .nav-links a{animation-play-state:paused!important}
