/* Eng. Fábio Junior Martins — Estrutural | Premium stylesheet */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-feature-settings:"ss01","cv11"}
body{margin:0;font-family:'Inter',system-ui,sans-serif;font-weight:400;line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;font-feature-settings:"cv11","ss01","ss03"}
::selection{background:rgba(234,88,12,.18);color:var(--ink)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-soft)}
::-webkit-scrollbar-thumb{background:var(--steel-2);border-radius:10px;border:2px solid var(--bg-soft)}
::-webkit-scrollbar-thumb:hover{background:var(--ink)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
:root{
  --bg:#ffffff;
  --bg-soft:#f5f7fa;
  --bg-card:#f8fafc;
  --bg-deep:#0a0e1a;
  --ink:#0a0e1a;
  --ink-soft:#1e293b;
  --steel:#334155;
  --steel-2:#475569;
  --muted:#64748b;
  --line:#e2e8f0;
  --line-soft:#eef1f5;
  --accent:#ea580c;
  --accent-2:#f97316;
  --accent-3:#fb923c;
  --accent-soft:#fff7ed;
  --warn:#facc15;
  --r:14px;--rs:10px;
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow-sm:0 1px 2px rgba(15,23,42,.04);
  --shadow:0 1px 3px rgba(15,23,42,.06),0 12px 32px -12px rgba(15,23,42,.12);
  --shadow-lg:0 4px 8px rgba(15,23,42,.08),0 32px 64px -16px rgba(15,23,42,.16);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
button{font:inherit;cursor:pointer;border:0;background:0}
h1,h2,h3,h4{font-family:'Space Grotesk',Inter,sans-serif;font-weight:600;letter-spacing:-.022em;line-height:1.1;margin:0 0 .55em;color:var(--ink);text-wrap:balance}
h1{font-size:clamp(2.5rem,6.2vw,4.6rem);font-weight:700;letter-spacing:-.04em;line-height:1.02}
h2{font-size:clamp(1.85rem,3.6vw,2.8rem);font-weight:600;letter-spacing:-.028em;line-height:1.08}
h3{font-size:clamp(1.22rem,2.2vw,1.5rem);font-weight:600;letter-spacing:-.018em}
h4{font-weight:600;letter-spacing:-.015em}
p{margin:0 0 1em;text-wrap:pretty}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:'Inter';font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:1.4rem;padding:.4rem .85rem;background:var(--accent-soft);border:1px solid rgba(234,88,12,.15);border-radius:999px}
.eyebrow::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px rgba(234,88,12,.18)}
.container{width:min(1180px,92%);margin:0 auto}
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:1rem 1.8rem;border-radius:10px;font-weight:600;font-size:.94rem;letter-spacing:-.008em;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s var(--ease),background .25s var(--ease);position:relative;overflow:hidden}
.btn-primary{background:linear-gradient(180deg,var(--accent-2) 0%,var(--accent) 100%);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 1px 2px rgba(15,23,42,.08),0 8px 24px rgba(234,88,12,.32);animation:btnPulse 2.4s ease-in-out infinite}
.btn-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 4px 8px rgba(15,23,42,.1),0 16px 36px rgba(234,88,12,.5);animation-play-state:paused}
.btn-primary:active{transform:translateY(0) scale(.98);box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 1px 2px rgba(15,23,42,.08),0 4px 12px rgba(234,88,12,.28);animation-play-state:paused}
@keyframes btnPulse{
  0%,100%{box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 1px 2px rgba(15,23,42,.08),0 8px 24px rgba(234,88,12,.32),0 0 0 0 rgba(234,88,12,.55)}
  50%{box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 4px 12px rgba(15,23,42,.12),0 14px 32px rgba(234,88,12,.45),0 0 0 12px rgba(234,88,12,0)}
}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:0 1px 2px rgba(15,23,42,.04)}
.btn-ghost:hover{background:var(--bg-soft);border-color:var(--ink);transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.08)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);background:rgba(255,255,255,.78);border-bottom:1px solid transparent;transition:border-color .3s var(--ease),background .3s var(--ease)}
.nav.scrolled{background:rgba(255,255,255,.94);border-bottom-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.95rem 0}
.brand{display:flex;align-items:center;gap:.7rem;font-family:'Space Grotesk';font-weight:700;font-size:1.05rem;letter-spacing:-.015em}
.brand-mark{width:38px;height:38px;border-radius:9px;background:var(--ink);position:relative;display:grid;place-items:center;color:#fff;font-weight:700;font-family:'Space Grotesk';font-size:.95rem;letter-spacing:-.02em;overflow:hidden}
.brand-mark::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-3))}
.brand strong{color:var(--ink);display:block;line-height:1.1}
.brand small{display:block;font-family:'Inter';font-weight:500;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.15rem}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--steel-2);position:relative;padding:.4rem 0;transition:color .2s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{padding:.6rem 1.2rem;background:var(--ink);color:#fff;border-radius:8px;font-size:.88rem}
.nav-cta:hover{background:var(--accent);color:#fff}
.nav-toggle{display:none;width:42px;height:42px;border-radius:8px;background:var(--bg-soft);align-items:center;justify-content:center;position:relative}
.nav-toggle span,.nav-toggle::before,.nav-toggle::after{content:"";display:block;width:18px;height:2px;background:var(--ink);position:absolute;transition:transform .3s var(--ease)}
.nav-toggle::before{transform:translateY(-6px)}
.nav-toggle::after{transform:translateY(6px)}
@media (max-width:880px){
  .nav-links{position:fixed;inset:64px 0 0 0;flex-direction:column;background:#fff;padding:2.5rem 2rem;gap:1.5rem;transform:translateX(100%);transition:transform .35s var(--ease);align-items:flex-start;border-top:1px solid var(--line)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.15rem}
  .nav-toggle{display:flex}
}

/* CITY HERO — premium */
.city-hero{padding:160px 0 100px;background:linear-gradient(180deg,#fff 0%,#fafbfd 100%);position:relative;overflow:hidden}
.city-hero::before{content:"";position:absolute;top:-300px;right:-200px;width:900px;height:900px;background:radial-gradient(circle,rgba(234,88,12,.08) 0%,transparent 60%);filter:blur(40px);z-index:0}
.city-hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(15,23,42,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.035) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 70% 55% at 50% 30%,#000 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 70% 55% at 50% 30%,#000 30%,transparent 80%);z-index:0;pointer-events:none}
.city-hero .container{position:relative;z-index:1;max-width:880px}
.city-hero h1{margin:.4em 0;letter-spacing:-.045em}
.city-hero h1 em{font-style:normal;color:var(--accent);position:relative;display:inline-block;background:linear-gradient(180deg,var(--accent-2),var(--accent));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.city-hero h1 em::after{content:"";position:absolute;bottom:.04em;left:0;right:0;height:.16em;background:var(--accent);opacity:.16;z-index:-1;border-radius:3px}
.city-sub{font-size:clamp(1.08rem,1.7vw,1.24rem);color:var(--steel);max-width:720px;margin:1.5rem 0 2.6rem;line-height:1.65}
.city-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:3.2rem}
.city-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1.8rem;padding-top:2.2rem;border-top:1px solid var(--line)}
@media (max-width:600px){.city-trust{grid-template-columns:repeat(2,1fr);gap:1.6rem}}
.ct-item{position:relative;padding-left:0}
.ct-item strong{display:block;font-family:'Space Grotesk';font-size:1.18rem;font-weight:700;color:var(--ink);line-height:1.1;letter-spacing:-.018em}
.ct-item span{color:var(--muted);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;margin-top:.4rem;display:block;font-weight:600}
.breadcrumb{font-size:.82rem;color:var(--muted);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb strong{color:var(--ink);font-weight:500}
.breadcrumb span{color:var(--line)}

/* CITY PHOTO BLOCK */
.city-photo{padding:80px 0;background:#fff}
.city-photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1100px;margin:0 auto}
@media (max-width:880px){.city-photo-grid{grid-template-columns:1fr;gap:2.5rem}}
.city-photo-img{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:5/4;box-shadow:0 24px 48px -12px rgba(15,23,42,.18),0 4px 8px rgba(15,23,42,.06)}
.city-photo-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.city-photo-img:hover img{transform:scale(1.04)}
.city-photo-tag{position:absolute;bottom:1rem;left:1rem;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);padding:.55rem 1rem;border-radius:999px;font-family:'Space Grotesk';font-size:.85rem;font-weight:600;color:var(--ink);letter-spacing:-.01em;box-shadow:0 4px 12px rgba(15,23,42,.12)}
.city-photo h2{margin-bottom:1.2rem}
.city-photo p{color:var(--steel-2);font-size:1rem;margin-bottom:1.8rem;line-height:1.7}

/* SECTIONS */
section{padding:90px 0;position:relative}
.s-head{text-align:center;max-width:760px;margin:0 auto 4rem}
.s-head p{color:var(--steel-2);font-size:1.05rem;margin-top:.6rem;line-height:1.65}

/* SERVICOS — premium */
.serv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
@media (max-width:780px){.serv-grid{grid-template-columns:1fr}}
.serv-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:2.6rem 2.4rem;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s var(--ease),border-color .4s var(--ease);position:relative;overflow:hidden;isolation:isolate}
.serv-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 0% 0%,rgba(234,88,12,.04) 0%,transparent 50%);opacity:0;transition:opacity .4s var(--ease);pointer-events:none;z-index:-1}
.serv-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px -12px rgba(15,23,42,.16),0 8px 16px -8px rgba(15,23,42,.08);border-color:rgba(234,88,12,.4)}
.serv-card:hover::after{opacity:1}
.serv-card.featured{background:linear-gradient(135deg,#fff7ed 0%,#fff 70%);border-color:var(--accent);grid-column:span 2;box-shadow:0 1px 2px rgba(234,88,12,.05),0 12px 32px -8px rgba(234,88,12,.12)}
@media (max-width:780px){.serv-card.featured{grid-column:span 1}}
.serv-card.featured::before{content:"ESPECIALIDADE";position:absolute;top:1.6rem;right:1.6rem;font-size:.66rem;font-weight:700;letter-spacing:.16em;color:#fff;background:linear-gradient(180deg,var(--accent-2),var(--accent));padding:.4rem .9rem;border-radius:999px;box-shadow:0 4px 12px rgba(234,88,12,.35)}
.serv-icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--bg-soft) 0%,#fff 100%);border:1px solid var(--line);display:grid;place-items:center;margin-bottom:1.7rem;color:var(--accent);transition:all .35s var(--ease);box-shadow:inset 0 1px 0 #fff,0 2px 6px rgba(15,23,42,.04)}
.serv-card:hover .serv-icon{transform:scale(1.05);background:linear-gradient(135deg,#fff7ed 0%,#fff 100%);border-color:rgba(234,88,12,.3)}
.serv-card.featured .serv-icon{background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#fff;border-color:transparent;box-shadow:0 6px 16px rgba(234,88,12,.32)}
.serv-card h3{margin-bottom:.7rem;letter-spacing:-.015em}
.serv-card p{color:var(--steel-2);font-size:.95rem;margin-bottom:1.4rem;line-height:1.65}
.serv-card ul{list-style:none;padding:0;margin:0 0 1.6rem}
.serv-card li{padding:.45rem 0 .45rem 1.7rem;position:relative;font-size:.92rem;color:var(--steel-2)}
.serv-card li::before{content:"";position:absolute;left:0;top:.85rem;width:8px;height:8px;border:2px solid var(--accent);border-top:0;border-left:0;transform:rotate(45deg)}
.serv-link{font-weight:600;color:var(--accent);font-size:.92rem;display:inline-flex;align-items:center;gap:.45rem}
.serv-link::after{content:"\2192";transition:transform .25s var(--ease)}
.serv-link:hover::after{transform:translateX(5px)}

/* WHY CITY */
.why-city{background:var(--bg-soft)}
.why-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center}
@media (max-width:880px){.why-grid{grid-template-columns:1fr}}
.why-bullets{list-style:none;padding:0;margin:2rem 0 0;display:grid;gap:1rem}
.why-bullets li{padding:1.1rem 1.3rem;background:#fff;border:1px solid var(--line);border-radius:var(--rs);font-size:.94rem;color:var(--steel-2);line-height:1.65}
.why-bullets strong{color:var(--ink);font-weight:600}
.why-img{border-radius:var(--r);overflow:hidden;aspect-ratio:5/4;box-shadow:var(--shadow-lg)}
.why-img img{width:100%;height:100%;object-fit:cover}

/* PROC — premium timeline */
.proc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.4rem;counter-reset:step;position:relative}
.proc-grid::before{content:"";position:absolute;top:48px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,transparent 0%,var(--accent) 15%,var(--accent) 85%,transparent 100%);opacity:.25;z-index:0}
@media (max-width:980px){.proc-grid{grid-template-columns:repeat(2,1fr)}.proc-grid::before{display:none}}
@media (max-width:520px){.proc-grid{grid-template-columns:1fr}}
.proc-step{padding:2rem 1.7rem;background:#fff;border:1px solid var(--line);border-radius:16px;position:relative;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s var(--ease),border-color .35s var(--ease);z-index:1}
.proc-step:hover{transform:translateY(-6px);box-shadow:0 20px 40px -12px rgba(15,23,42,.15);border-color:var(--accent)}
.proc-step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:'Space Grotesk';font-size:.85rem;font-weight:700;color:var(--accent);line-height:1;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:#fff;border:2px solid var(--accent);border-radius:50%;margin-bottom:1.1rem;letter-spacing:0;box-shadow:0 4px 10px rgba(234,88,12,.2)}
.proc-step:hover::before{background:var(--accent);color:#fff;transform:scale(1.1);transition:all .3s var(--ease)}
.proc-step h4{font-family:'Space Grotesk';font-size:1.08rem;font-weight:600;margin:0 0 .55rem;letter-spacing:-.015em}
.proc-step p{font-size:.88rem;color:var(--steel-2);margin:0;line-height:1.65}

/* FAQ */
.faq-section{background:#fff}
.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);padding:1.5rem 0;cursor:pointer}
.faq-item summary{list-style:none;display:flex;justify-content:space-between;align-items:center;font-family:'Space Grotesk';font-size:1.15rem;font-weight:500;color:var(--ink);gap:1rem;letter-spacing:-.01em}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.7rem;color:var(--accent);font-weight:300;transition:transform .3s var(--ease);line-height:1;flex-shrink:0}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{color:var(--accent)}
.faq-item p{margin-top:1rem;color:var(--steel-2);font-size:.95rem;line-height:1.7}

/* CTA FINAL */
.cta-final{background:var(--bg-deep);color:#fff;padding:90px 0;text-align:center;position:relative;overflow:hidden}
.cta-final::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 50%,rgba(234,88,12,.18) 0%,transparent 70%)}
.cta-final h2{color:#fff;max-width:720px;margin:0 auto 1rem}
.cta-final p{color:rgba(255,255,255,.72);max-width:560px;margin:0 auto 2.5rem;font-size:1.05rem;line-height:1.65}
.cta-final .eyebrow{color:var(--accent-3)}
.cta-final .eyebrow::before{background:var(--accent-3)}
.cta-final .btn-primary{font-size:1rem;padding:1.1rem 2.2rem}

/* FOOTER */
footer{background:var(--bg-deep);color:rgba(255,255,255,.72);padding:80px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
footer .brand strong{color:#fff}
footer .brand small{color:rgba(255,255,255,.5)}
.foot-col h5{font-family:'Inter';font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin:0 0 1.3rem}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.7rem}
.foot-col a{font-size:.92rem;color:rgba(255,255,255,.65)}
.foot-col a:hover{color:var(--accent-3)}
.foot-about p{font-size:.92rem;color:rgba(255,255,255,.65);margin-top:1rem;line-height:1.7}
.foot-crea{display:inline-block;margin-top:1rem;padding:.55rem 1.1rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:.82rem;font-weight:600;color:#fff}
.foot-bottom{padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:rgba(255,255,255,.5)}
.foot-bottom a{color:rgba(255,255,255,.5)}
.foot-bottom a:hover{color:var(--accent-3)}

/* === ANIMAÇÕES PREMIUM === */

/* Reveal scroll stagger refinado */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.25,.46,.45,.94),transform .9s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.reveal[data-delay="5"]{transition-delay:.4s}

/* Reveal scale variation */
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .8s var(--ease),transform .8s cubic-bezier(.34,1.56,.64,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* Reveal slide left/right */
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* Floating elements gentle motion */
@keyframes floatGentle{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.float-gentle{animation:floatGentle 5s ease-in-out infinite}

/* Glow pulse pra eyebrows */
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 3px rgba(234,88,12,.18)}50%{box-shadow:0 0 0 6px rgba(234,88,12,.06)}}
.eyebrow::before{animation:glowPulse 2.5s ease-in-out infinite}

/* Number count-up base style */
.count-up{display:inline-block;font-variant-numeric:tabular-nums}

/* Marquee refinado pra trust bar */
.norms-grid > .norm-card{animation:cardEnter .8s cubic-bezier(.34,1.56,.64,1) backwards}
.norms-grid > .norm-card:nth-child(1){animation-delay:.05s}
.norms-grid > .norm-card:nth-child(2){animation-delay:.1s}
.norms-grid > .norm-card:nth-child(3){animation-delay:.15s}
.norms-grid > .norm-card:nth-child(4){animation-delay:.2s}
.norms-grid > .norm-card:nth-child(5){animation-delay:.25s}
.norms-grid > .norm-card:nth-child(6){animation-delay:.3s}
.norms-grid > .norm-card:nth-child(7){animation-delay:.35s}
.norms-grid > .norm-card:nth-child(8){animation-delay:.4s}
@keyframes cardEnter{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Card 3D tilt hover sutil */
.serv-card,.proc-step,.port-card,.blog-card,.search-col{transform-style:preserve-3d;perspective:1000px;will-change:transform}
.serv-card:hover{transform:translateY(-8px) rotateX(2deg) rotateY(-1deg)}
.blog-card:hover{transform:translateY(-8px) rotateX(2deg)}

/* Port card overlay shimmer */
.port-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);opacity:0;transform:translateX(-100%);transition:opacity .3s,transform .9s var(--ease);z-index:3;pointer-events:none}
.port-card:hover::before{opacity:1;transform:translateX(100%)}

/* Hero h1 gradient shift animation */
.hero h1 em,.city-hero h1 em{background-size:200% 100%;animation:gradientShift 6s ease-in-out infinite}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Smooth scroll snap suave */
@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}

/* Button hover ripple */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}
.btn-primary:hover::before{width:300px;height:300px}
.btn-primary > *{position:relative;z-index:1}

/* Subtle text gradient on h2 */
h2.gradient{background:linear-gradient(135deg,var(--ink) 0%,var(--steel) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* === WA FLOAT — Match referência: círculo verde + halo branco === */
.wa-float{
  position:fixed;
  bottom:28px;
  right:28px;
  width:58px;
  height:58px;
  border-radius:50%;
  background:#25D366;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  text-decoration:none;
  box-shadow:0 4px 14px rgba(15,23,42,.18),0 2px 6px rgba(15,23,42,.1);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;
}
/* Halo branco translúcido ao redor — pulsando */
.wa-float::before{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius:50%;
  background:rgba(255,255,255,.45);
  z-index:-1;
  pointer-events:none;
  animation:waHaloPulse 2.2s ease-in-out infinite;
}
/* Anel verde se expandindo */
.wa-float::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:rgba(37,211,102,.55);
  z-index:-2;
  pointer-events:none;
  animation:waRingExpand 2.2s ease-out infinite;
}
@keyframes waHaloPulse{
  0%,100%{transform:scale(1);opacity:.6}
  50%{transform:scale(1.15);opacity:.85}
}
@keyframes waRingExpand{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(2);opacity:0}
}
.wa-float:hover{
  transform:scale(1.08) translateY(-2px);
  box-shadow:0 6px 18px rgba(15,23,42,.22),0 4px 10px rgba(15,23,42,.12);
}
.wa-float:active{transform:scale(.96)}
.wa-float img{
  width:38px;
  height:38px;
  position:relative;
  z-index:2;
}
.wa-float .wa-tip,.wa-float .wa-badge{display:none}
@media (max-width:580px){
  .wa-float{width:52px;height:52px;bottom:18px;right:18px}
  .wa-float img{width:34px;height:34px}
  .wa-float::before{inset:-8px}
}
@media (max-width:580px){
  .wa-float{bottom:16px;right:16px;width:48px;height:48px}
  .wa-float img{width:48px;height:48px}
  .wa-float::before{width:48px;height:48px}
  .wa-float .wa-tip{display:none}
}

/* BLOG */
.blog-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;max-width:1200px;margin:0 auto}
@media (max-width:880px){.blog-list{grid-template-columns:1fr}}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);display:block}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.blog-card-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-card)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.blog-card:hover .blog-card-img img{transform:scale(1.08)}
.blog-card-body{padding:1.7rem 1.5rem 1.9rem}
.blog-tag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.7rem}
.blog-card h3{font-size:1.18rem;line-height:1.3;margin-bottom:.6rem;letter-spacing:-.015em}
.blog-card p{font-size:.88rem;color:var(--steel-2);margin:0 0 1rem}
.blog-card-meta{font-size:.78rem;color:var(--muted);display:flex;gap:1rem;align-items:center}

/* BLOG POST */
.post-hero{padding:140px 0 60px;background:#fff;border-bottom:1px solid var(--line)}
.post-hero .container{max-width:780px}
.post-hero h1{font-size:clamp(2rem,4.5vw,3.4rem);letter-spacing:-.03em;margin-bottom:1rem}
.post-meta{display:flex;gap:1rem;align-items:center;color:var(--muted);font-size:.85rem;margin:1rem 0 1.5rem;flex-wrap:wrap}
.post-meta strong{color:var(--ink);font-weight:600}
.post-cover{aspect-ratio:16/8;border-radius:var(--r);overflow:hidden;margin-top:2rem}
.post-cover img{width:100%;height:100%;object-fit:cover}
.post-body{padding:60px 0 100px;background:#fff}
.post-body .container{max-width:780px;font-size:1.05rem;line-height:1.8;color:var(--ink-soft)}
.post-body h2{margin:2.5rem 0 1rem;font-size:1.7rem;color:var(--ink)}
.post-body h3{margin:2rem 0 .8rem;font-size:1.3rem;color:var(--ink)}
.post-body p{margin:0 0 1.2em}
.post-body ul,.post-body ol{padding-left:1.5rem;margin:0 0 1.5em}
.post-body li{margin-bottom:.5em}
.post-body blockquote{border-left:3px solid var(--accent);padding:.5rem 0 .5rem 1.5rem;margin:1.8rem 0;color:var(--steel-2);font-style:italic}
.post-body a{color:var(--accent);font-weight:500;border-bottom:1px solid rgba(234,88,12,.3)}
.post-body a:hover{border-color:var(--accent)}
.post-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.95rem}
.post-body th,.post-body td{padding:.8rem 1rem;border:1px solid var(--line);text-align:left}
.post-body th{background:var(--bg-soft);font-weight:600;color:var(--ink)}
.post-body code{background:var(--bg-soft);padding:.15em .4em;border-radius:4px;font-size:.92em;color:var(--accent)}
.post-cta{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--r);padding:2rem;margin:2.5rem 0;text-align:center}
.post-cta h3{margin:0 0 .5rem;color:var(--ink)}
.post-cta p{margin:0 0 1.2rem;color:var(--steel-2)}

@media (max-width:580px){
  section{padding:60px 0}
  .city-hero{padding:120px 0 50px}
  .post-hero{padding:110px 0 40px}
  .post-body{padding:40px 0 70px}
}

/* === NORMS BAR (estática, profissional) === */
.norms{padding:70px 0;background:var(--bg-deep);color:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.norms-header{text-align:center;max-width:680px;margin:0 auto 2.5rem}
.norms-header .eyebrow{color:var(--accent-3)}
.norms-header .eyebrow::before{background:var(--accent-3)}
.norms-header p{color:rgba(255,255,255,.7);font-size:1rem;margin:0;line-height:1.6}
.norms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1100px;margin:0 auto}
@media (max-width:880px){.norms-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.norms-grid{grid-template-columns:1fr}}
.norm-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:1.3rem 1.4rem;transition:border-color .25s var(--ease),background .25s var(--ease)}
.norm-card:hover{border-color:var(--accent);background:rgba(234,88,12,.08)}
.norm-card strong{display:block;font-family:'Space Grotesk';font-size:1.05rem;font-weight:700;color:#fff;letter-spacing:-.01em;margin-bottom:.25rem}
.norm-card span{display:block;font-size:.78rem;color:rgba(255,255,255,.65);line-height:1.4}
.norm-card.alt strong{color:var(--accent-3)}

/* === SERVICE ICONS SVG === */
.serv-icon svg{width:28px;height:28px;stroke-width:1.8}
.serv-card.featured .serv-icon svg{stroke:#fff}

/* === FAQ TABS === */
.faq-tabs{display:flex;justify-content:center;gap:.6rem;margin-bottom:2.5rem;flex-wrap:wrap}
.faq-tab{padding:.7rem 1.4rem;background:#fff;border:1px solid var(--line);border-radius:8px;font-size:.9rem;font-weight:500;color:var(--steel-2);cursor:pointer;transition:all .25s var(--ease)}
.faq-tab:hover{background:var(--bg-soft);color:var(--ink)}
.faq-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px rgba(234,88,12,.25)}

/* === PESQUISAS RELACIONADAS === */
.searches{background:var(--bg-soft);padding:90px 0}
.search-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:1240px;margin:0 auto}
@media (max-width:1024px){.search-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:580px){.search-grid{grid-template-columns:1fr}}
.search-col{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.6rem;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.search-col:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.search-col h3{font-family:'Space Grotesk';font-size:1.05rem;font-weight:700;color:var(--ink);margin:0 0 1.2rem;padding-bottom:.9rem;border-bottom:2px solid var(--accent);display:inline-block}
.search-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}
.search-col li{font-size:.85rem;color:var(--steel-2);padding-left:1.1rem;position:relative;line-height:1.5}
.search-col li::before{content:"";position:absolute;left:0;top:.55rem;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.5}
