/*
Theme Name: Diretiva Patrimonial
Theme URI:
Author: Grupo Diretiva
Description: Tema institucional da Diretiva Patrimonial — terceirização de mão de obra (setor público e privado).
Version: 0.2.7
Requires at least: 6.5
Tested up to: 7.0
Requires PHP: 8.0
Text Domain: diretiva
*/

/* ============================================================
   Design da Home (extraído do protótipo) — marca Diretiva
   ============================================================ */

/* ====================================================================
   Diretiva Patrimonial — homepage prototype
   Brand: Diretiva (navy + cyan). Layout language: souzalima.com, recolored.
   NO YELLOW anywhere — Souza Lima's yellow → Diretiva cyan.
   ==================================================================== */

:root{
  --navy:#0E4B83; --navy-dark:#000A32; --cyan:#2CADE2;
  --cyan-light:#DFFAFF; --blue-gray:#7794B6; --white:#FFFFFF;
  --ink:#15212E; --max:1180px;
  --font-display:'Montserrat',system-ui,sans-serif;
  --font-body:Tahoma,'Segoe UI',system-ui,sans-serif;
  --navy-grad:linear-gradient(135deg,#0E4B83 0%,#0a3a66 60%,#072c4f 100%);
  --shadow-sm:0 4px 14px rgba(14,75,131,.10);
  --shadow-md:0 14px 40px rgba(14,75,131,.16);
  --shadow-lg:0 28px 70px rgba(0,10,50,.28);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);
  background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:clip; /* clip (não 'hidden') p/ não quebrar o position:sticky do header */
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{font-family:var(--font-display);line-height:1.08;margin:0;color:var(--navy);letter-spacing:-.01em;}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem);font-weight:800;}
h3{font-weight:700;}
p{margin:0;}

.container{max-width:var(--max);margin:0 auto;padding:0 24px;width:100%;}
.section{padding:72px 0;position:relative;}
.section-alt{background:#f4f8fc;}

/* ---- kickers / section heads ---- */
.kicker{
  display:inline-block;font-family:var(--font-display);font-weight:700;
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:14px;position:relative;padding-left:34px;
}
.kicker::before{content:"";position:absolute;left:0;top:50%;width:24px;height:2px;background:var(--cyan);transform:translateY(-50%);}
.kicker-cyan{color:var(--cyan);}
.section-head{max-width:720px;margin:0 0 44px;}
.section-head h2{margin-top:4px;}
.section-lead{margin-top:16px;color:var(--blue-gray);font-size:1.05rem;}
.section-head-light h2,.section-head-light .section-lead{color:var(--white);}
.section-head-light .section-lead{color:#cfe6f7;}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-display);font-weight:700;font-size:.92rem;
  padding:14px 28px;border-radius:4px;border:2px solid transparent;cursor:pointer;
  transition:background .2s,color .2s,border-color .2s,transform .15s,box-shadow .2s;
  letter-spacing:.01em;line-height:1;
}
.btn-primary{background:var(--navy);color:var(--white);}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--cyan);color:var(--navy-dark);transform:translateY(-2px);box-shadow:0 10px 26px rgba(44,173,226,.4);}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--navy);}
.btn-ghost:hover,.btn-ghost:focus-visible{background:var(--navy);color:var(--white);transform:translateY(-2px);}
.btn-lg{padding:17px 36px;font-size:1rem;}
.btn-sm{padding:11px 20px;font-size:.85rem;}
.btn-block{width:100%;}

:focus-visible{outline:3px solid var(--cyan);outline-offset:2px;}

/* ====================================================================
   HEADER
   ==================================================================== */
/* O WP envolve o header num <div class="wp-block-template-part"> de altura
   só do header, o que limita o position:sticky. display:contents "dissolve"
   esse wrapper -> o header vira filho direto do body e o sticky funciona. */
.wp-block-template-part{display:contents;}
.site-header{
  position:sticky;top:0;z-index:60;background:var(--white);
  box-shadow:0 2px 18px rgba(14,75,131,.08);
}
.header-inner{display:flex;align-items:center;gap:24px;height:78px;}
.brand-logo{height:46px;width:auto;}
.main-nav{margin-left:auto;}
.nav-list{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0;}
.nav-list > li > a,.nav-toggle{
  font-family:var(--font-display);font-weight:600;font-size:.86rem;color:var(--navy);
  padding:10px 13px;display:inline-flex;align-items:center;gap:5px;border-radius:4px;
  background:none;border:none;cursor:pointer;position:relative;transition:color .18s;
}
.nav-list > li > a::after{
  content:"";position:absolute;left:13px;right:13px;bottom:4px;height:2px;
  background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .2s;
}
.nav-list > li > a:hover::after,.nav-list > li > a:focus-visible::after{transform:scaleX(1);}
.nav-list > li > a:hover,.nav-toggle:hover{color:var(--cyan);}
.caret{font-size:.6rem;transition:transform .2s;}

.has-dropdown{position:relative;}
.dropdown{
  position:absolute;top:calc(100% + 6px);left:0;min-width:270px;background:var(--white);
  list-style:none;margin:0;padding:8px;border-radius:8px;box-shadow:var(--shadow-md);
  border-top:3px solid var(--cyan);opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s,transform .18s,visibility .18s;z-index:70;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown,
.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.has-dropdown:hover .caret,.has-dropdown.open .caret{transform:rotate(180deg);}
.dropdown a{
  display:block;padding:10px 14px;border-radius:5px;font-size:.86rem;font-weight:600;
  font-family:var(--font-display);color:var(--navy);transition:background .15s,color .15s,padding-left .15s;
}
.dropdown a:hover,.dropdown a:focus-visible{background:var(--cyan-light);color:var(--navy-dark);padding-left:18px;}

.header-actions{display:flex;align-items:center;gap:14px;}
.hamburger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;
  align-items:center;justify-content:center;background:var(--navy);border:none;border-radius:6px;cursor:pointer;}
.hamburger span{width:20px;height:2px;background:#fff;transition:.25s;}
.site-header.nav-open .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.site-header.nav-open .hamburger span:nth-child(2){opacity:0;}
.site-header.nav-open .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ====================================================================
   HERO  (bold navy+cyan diagonals — Souza Lima energy, recolored)
   ==================================================================== */
/* Hero CLEAN: fundo branco, título navy, blocos diagonais chapados navy+ciano */
.hero{position:relative;overflow:hidden;background:#fff;color:var(--ink);isolation:isolate;}
.hero-bg{position:absolute;inset:0;z-index:-1;background:#fff;}
.hero-diag{position:absolute;}
/* bloco navy chapado, sangrando até a borda direita */
.hero-diag-1{
  top:-2%;right:0;width:47%;height:104%;background:var(--navy);
  clip-path:polygon(26% 0,100% 0,100% 100%,2% 100%);
}
/* acento ciano fino paralelo, à esquerda do navy */
.hero-diag-2{
  top:-2%;right:40%;width:16%;height:104%;background:var(--cyan);
  clip-path:polygon(52% 0,74% 0,30% 100%,8% 100%);
}
/* triângulo ciano pequeno no canto inferior esquerdo */
.hero-grid{
  left:0;bottom:0;width:148px;height:104px;background:var(--cyan);
  clip-path:polygon(0 0,0 100%,100% 100%);opacity:.92;
}
.hero-inner{
  position:relative;display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:center;
  padding:104px 24px 116px;
}
.hero-copy{max-width:600px;}
.eyebrow{
  display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--navy);margin-bottom:24px;
  padding:0;border:none;background:none;animation:fadeUp .6s .05s both;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:2px;background:var(--cyan);vertical-align:middle;margin-right:12px;}
.hero h1{
  color:var(--navy);font-size:clamp(2.3rem,5.6vw,4.1rem);font-weight:900;letter-spacing:-.025em;
  line-height:1.04;margin-bottom:22px;animation:fadeUp .6s .12s both;
}
.hero-sub{font-size:1.1rem;color:#46586a;max-width:500px;margin-bottom:32px;animation:fadeUp .6s .2s both;}
.hero-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px;animation:fadeUp .6s .28s both;}
.tab-pill{
  font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--navy);cursor:pointer;
  padding:11px 22px;border-radius:40px;border:1.5px solid #cfe0ee;background:#fff;transition:.2s;
}
.tab-pill:hover{border-color:var(--cyan);color:var(--cyan);}
.tab-pill.is-active{background:var(--navy);color:#fff;border-color:var(--navy);}
.hero-copy .btn{animation:fadeUp .6s .36s both;}

/* números limpos sobre o bloco navy (sem card de vidro) */
.hero-card{
  position:relative;z-index:1;justify-self:end;max-width:280px;
  background:transparent;border:none;box-shadow:none;padding:0;animation:fadeUp .7s .4s both;
}
.hero-card-row{display:flex;align-items:baseline;gap:16px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.2);}
.hero-card-row:last-child{border-bottom:none;}
.hcr-num{font-family:var(--font-display);font-weight:900;font-size:2.4rem;color:var(--cyan);line-height:1;min-width:92px;}
.hcr-label{color:rgba(255,255,255,.85);font-size:.92rem;}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;}}

/* ====================================================================
   3. TRUST BAR
   ==================================================================== */
.trust{background:var(--cyan-light);}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:26px 24px;}
.trust-item{display:flex;align-items:center;gap:16px;padding:6px 20px;position:relative;}
.trust-item:not(:last-child)::after{content:"";position:absolute;right:0;top:14%;bottom:14%;width:1px;background:rgba(14,75,131,.18);}
.trust-ic{
  flex:none;width:52px;height:52px;border-radius:12px;background:var(--navy);color:var(--cyan);
  display:grid;place-items:center;font-family:var(--font-display);font-weight:900;font-size:1.05rem;
}
.trust-item p{font-family:var(--font-display);font-weight:600;font-size:.95rem;color:var(--navy);line-height:1.25;}

/* ====================================================================
   4. QUEM SOMOS
   ==================================================================== */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.qs-text p{color:#3a4a5a;font-size:1.05rem;margin:18px 0 28px;}
.qs-media{position:relative;}
.qs-img-placeholder{
  position:relative;aspect-ratio:4/3;border-radius:16px;overflow:hidden;
  background:linear-gradient(180deg,transparent 45%,rgba(0,10,50,.55)),url('assets/img/quem-somos.jpg');
  background-size:cover;background-position:center;box-shadow:var(--shadow-md);
  display:grid;place-items:end start;
}
.qs-img-placeholder::after{
  content:"";position:absolute;right:-30px;top:-30px;width:150px;height:150px;border-radius:50%;
  border:2px dashed rgba(44,173,226,.45);
}
.qs-badge{
  position:relative;z-index:2;margin:0 0 18px 20px;
  font-family:var(--font-display);font-weight:900;font-size:3.2rem;color:#fff;line-height:.8;
  text-shadow:0 2px 14px rgba(0,10,50,.6);
}
.qs-badge::after{content:" anos";display:block;font-size:.9rem;font-weight:600;letter-spacing:.1em;color:var(--cyan);text-transform:uppercase;}
.qs-img-note{display:none;}

/* ====================================================================
   5. SERVIÇOS + generic cards grid
   ==================================================================== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.svc-card{
  background:#fff;border:1px solid #e6eef6;border-radius:14px;padding:32px 28px;
  display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .22s,box-shadow .22s,border-color .22s;
}
.svc-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .25s;}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent;}
.svc-card:hover::before{transform:scaleX(1);}
.svc-ic{
  width:58px;height:58px;border-radius:14px;background:var(--cyan-light);color:var(--navy);
  display:grid;place-items:center;font-size:1.6rem;margin-bottom:20px;transition:.22s;
}
.svc-card:hover .svc-ic{background:var(--cyan);color:#fff;}
.svc-card h3{font-size:1.18rem;margin-bottom:10px;}
.svc-card p{color:#5a6b7a;font-size:.95rem;flex:1;margin-bottom:20px;}
.card-link{font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--navy);display:inline-flex;gap:7px;align-items:center;transition:gap .2s,color .2s;}
.card-link:hover{color:var(--cyan);gap:12px;}

/* ====================================================================
   6. POR QUE ESCOLHER
   ==================================================================== */
.reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px 36px;}
.reason{display:flex;flex-direction:column;padding:26px;border-radius:12px;background:#fff;border:1px solid #e6eef6;transition:transform .2s,box-shadow .2s;}
.reason:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);}
.reason-ic{width:48px;height:48px;border-radius:50%;background:var(--navy);color:var(--cyan);display:grid;place-items:center;font-size:1.3rem;margin-bottom:16px;}
.reason h3{font-size:1.05rem;margin-bottom:8px;}
.reason p{color:#5a6b7a;font-size:.92rem;}

/* ====================================================================
   7. ATUAÇÃO EM CONTRATOS PÚBLICOS — DESTAQUE (navy band + diagonal)
   ==================================================================== */
.publicos{background:var(--navy-dark);color:#fff;overflow:hidden;}
.publicos-bg{position:absolute;inset:0;z-index:0;}
.pub-diag{position:absolute;top:0;right:0;width:48%;height:100%;background:var(--navy);clip-path:polygon(22% 0,100% 0,100% 100%,0 100%);opacity:.6;}
.publicos .container{position:relative;z-index:1;}
.pills-grid{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;}
.org-pill{
  font-family:var(--font-display);font-weight:600;font-size:.9rem;color:#eaf4fc;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);
  padding:14px 22px;border-radius:8px;transition:.2s;
}
.org-pill:hover{background:var(--cyan);color:var(--navy-dark);border-color:var(--cyan);transform:translateY(-3px);}
.pub-cta{margin-top:40px;}

/* ====================================================================
   8. PROCESSO — timeline
   ==================================================================== */
.timeline{
  list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative;
}
.timeline::before{content:"";position:absolute;top:28px;left:6%;right:6%;height:2px;background:linear-gradient(90deg,var(--cyan),rgba(44,173,226,.25));z-index:0;}
.step{position:relative;text-align:center;padding:0 6px;}
.step-num{
  position:relative;z-index:1;width:56px;height:56px;margin:0 auto 18px;border-radius:50%;
  background:var(--cyan);color:var(--navy-dark);display:grid;place-items:center;
  font-family:var(--font-display);font-weight:900;font-size:1.4rem;box-shadow:0 8px 22px rgba(44,173,226,.4);border:4px solid #fff;
}
.step h3{font-size:1rem;margin-bottom:8px;}
.step p{color:#5a6b7a;font-size:.88rem;}

/* ====================================================================
   9. GESTÃO DE RISCOS — DARK
   ==================================================================== */
.riscos{background:var(--navy-dark);color:#fff;overflow:hidden;}
.riscos-bg{position:absolute;inset:0;z-index:0;}
.risco-diag{position:absolute;bottom:-20%;left:-10%;width:60%;height:140%;background:var(--navy);clip-path:polygon(0 0,78% 0,100% 100%,0 100%);opacity:.45;}
.riscos .container{position:relative;z-index:1;}
.riscos .two-col{align-items:flex-start;}
.risco-text p{color:#cfe0ee;font-size:1.05rem;margin-top:18px;}
.risco-text h2{color:#fff;}
.risco-badges{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.risco-badges li{
  display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:600;font-size:.95rem;color:#fff;
  background:rgba(255,255,255,.05);border:1px solid rgba(44,173,226,.35);border-radius:10px;padding:18px 18px;
}
.risco-badges span{width:26px;height:26px;flex:none;border-radius:50%;background:var(--cyan);color:var(--navy-dark);display:grid;place-items:center;font-weight:900;font-size:.85rem;}

/* ====================================================================
   10. BLOG
   ==================================================================== */
.blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid #e6eef6;border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s;}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.blog-thumb{position:relative;display:block;aspect-ratio:16/9;overflow:hidden;background:#e7eff7;}
.blog-thumb-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease;}
.blog-card:hover .blog-thumb-img{transform:scale(1.05);}
.blog-tag{align-self:flex-start;margin:18px 24px 0;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.09em;text-transform:uppercase;color:var(--cyan);}
.blog-card h3{font-size:1.12rem;line-height:1.32;font-weight:800;padding:8px 24px 0;color:var(--navy);}
.blog-card h3 a{color:inherit;text-decoration:none;}
.blog-card h3 a:hover{color:var(--cyan);}
.blog-card p{color:#5a6b7a;font-size:.92rem;line-height:1.6;padding:10px 24px 16px;margin:0;}
.blog-link{margin:auto 24px 22px;align-self:flex-start;font-family:var(--font-display);font-weight:700;font-size:.86rem;color:var(--navy);text-decoration:none;transition:color .2s;}
.blog-link:hover{color:var(--cyan);}
/* placeholder "Em breve" (fallback quando não há posts) */
.blog-card:not(.has-thumb) .blog-thumb{background:var(--navy-grad);}
.soon-tag{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-weight:700;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--navy-dark);background:var(--cyan);padding:7px 16px;border-radius:30px;}

/* ====================================================================
   11. CTA FINAL — diagonal banner
   ==================================================================== */
.cta-final{position:relative;overflow:hidden;background:var(--navy);color:#fff;padding:84px 0;isolation:isolate;}
.cta-bg{position:absolute;inset:0;z-index:-1;background:linear-gradient(118deg,rgba(0,10,50,.93),rgba(14,75,131,.7)),url('assets/img/cta-bg.jpg');background-size:cover;background-position:center;}
.cta-diag{position:absolute;top:0;right:0;width:55%;height:100%;background:var(--cyan);clip-path:polygon(30% 0,100% 0,100% 100%,8% 100%);opacity:.9;}
.cta-bg::after{content:"";position:absolute;top:0;right:0;width:55%;height:100%;background:var(--navy);clip-path:polygon(42% 0,100% 0,100% 100%,18% 100%);opacity:.4;}
.cta-inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.cta-final h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:900;max-width:620px;}

/* ====================================================================
   FOOTER
   ==================================================================== */
.site-footer{background:var(--navy);color:#cfe0ee;padding-top:64px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.1fr 1fr 1.1fr;gap:36px;padding-bottom:48px;}
.footer-logo{height:54px;width:auto;margin-bottom:18px;}
.footer-tag{font-size:.92rem;color:#a9c4dd;max-width:300px;margin-bottom:22px;}
.footer-social{display:flex;flex-wrap:wrap;gap:10px;}
.soc{font-family:var(--font-display);font-weight:600;font-size:.78rem;color:#fff;border:1px solid rgba(255,255,255,.25);padding:8px 14px;border-radius:30px;transition:.2s;}
.soc:hover{background:var(--cyan);color:var(--navy-dark);border-color:var(--cyan);}
.footer-col h3{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:16px;}
.footer-col-second{margin-top:24px;}
.footer-col ul{list-style:none;margin:0;padding:0;}
.footer-col li{margin-bottom:10px;}
.footer-col a{font-size:.9rem;color:#bfd6ea;transition:color .18s,padding-left .18s;}
.footer-col a:hover{color:var(--cyan);padding-left:4px;}
.footer-contact address{font-style:normal;font-size:.9rem;line-height:1.9;color:#bfd6ea;}
.footer-contact a{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;}
.footer-bottom p{font-size:.82rem;color:#9bb6d2;}

/* ====================================================================
   FLOATING WHATSAPP + MODAL
   ==================================================================== */
.wa-fab{
  position:fixed;right:24px;bottom:24px;z-index:80;width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;
  background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 12px 30px rgba(37,211,102,.45);
  transition:transform .2s,box-shadow .2s;
}
.wa-fab:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 16px 38px rgba(37,211,102,.6);}
.wa-fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25D366;animation:waPulse 2.2s infinite;}
@keyframes waPulse{0%{transform:scale(1);opacity:.7;}100%{transform:scale(1.5);opacity:0;}}

.wa-modal{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:20px;}
.wa-modal[hidden]{display:none;}
.wa-modal-backdrop{position:absolute;inset:0;background:rgba(0,10,50,.6);backdrop-filter:blur(3px);}
.wa-modal-box{
  position:relative;background:#fff;border-radius:16px;max-width:440px;width:100%;padding:34px 32px;
  box-shadow:var(--shadow-lg);border-top:5px solid var(--cyan);animation:fadeUp .3s both;
}
.wa-modal-close{position:absolute;top:14px;right:16px;width:34px;height:34px;border:none;background:#eef4f9;border-radius:50%;font-size:1.4rem;line-height:1;color:var(--navy);cursor:pointer;transition:.2s;}
.wa-modal-close:hover{background:var(--cyan);color:#fff;}
.wa-modal h2{font-size:1.5rem;}
.wa-modal-sub{color:#5a6b7a;font-size:.92rem;margin:8px 0 22px;}
.wa-form{display:flex;flex-direction:column;gap:14px;}
.wa-form label{display:flex;flex-direction:column;gap:6px;font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--navy);}
.wa-form input,.wa-form select{
  font-family:var(--font-body);font-size:.95rem;padding:12px 14px;border:1.5px solid #d4e1ee;border-radius:8px;color:var(--ink);transition:border-color .2s;
}
.wa-form input:focus,.wa-form select:focus{outline:none;border-color:var(--cyan);}
.wa-form .btn{margin-top:8px;}

/* ====================================================================
   RESPONSIVE
   ==================================================================== */
@media (max-width:1080px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr;}
  .footer-brand{grid-column:1 / -1;}
}
@media (max-width:980px){
  .header-cta{display:none;}
  .hamburger{display:flex;}
  .main-nav{
    position:absolute;top:78px;left:0;right:0;background:#fff;box-shadow:var(--shadow-md);
    max-height:0;overflow:hidden;transition:max-height .3s ease;margin-left:0;
  }
  .site-header.nav-open .main-nav{max-height:80vh;overflow-y:auto;}
  .nav-list{flex-direction:column;align-items:stretch;gap:0;padding:8px 14px 18px;}
  .nav-list > li > a,.nav-toggle{width:100%;justify-content:space-between;padding:14px 12px;font-size:1rem;border-bottom:1px solid #eef3f8;}
  .nav-list > li > a::after{display:none;}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border-top:none;
    min-width:0;max-height:0;overflow:hidden;padding:0;transition:max-height .25s;}
  .has-dropdown.open .dropdown{max-height:500px;padding:4px 0 10px;}
  .dropdown a{padding-left:24px;}
}
@media (max-width:820px){
  .hero-inner{grid-template-columns:1fr;padding:64px 24px 72px;}
  .hero-diag-1,.hero-diag-2,.hero-grid{display:none;}
  .hero-card{justify-self:stretch;max-width:none;margin-top:6px;background:var(--navy);border-radius:14px;padding:6px 22px;}
  .two-col{grid-template-columns:1fr;gap:36px;}
  .cards-grid,.reasons-grid{grid-template-columns:1fr 1fr;}
  .trust-inner{grid-template-columns:1fr 1fr;gap:18px;}
  .trust-item:nth-child(2)::after{display:none;}
  .timeline{grid-template-columns:1fr;gap:0;}
  .timeline::before{top:0;bottom:0;left:27px;right:auto;width:2px;height:auto;background:linear-gradient(180deg,var(--cyan),rgba(44,173,226,.25));}
  .step{display:grid;grid-template-columns:56px 1fr;gap:18px;text-align:left;padding:14px 0;align-items:start;}
  .step-num{margin:0;}
  .risco-badges{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .section{padding:54px 0;}
  .cards-grid,.reasons-grid,.footer-grid{grid-template-columns:1fr;}
  .trust-inner{grid-template-columns:1fr;}
  .trust-item::after{display:none!important;}
  .hcr-num{font-size:1.9rem;min-width:72px;}
  .cta-inner{flex-direction:column;align-items:flex-start;}
  .org-pill{font-size:.82rem;padding:11px 16px;}
}

/* ======================================================================
   MOVIMENTO VIVO — reveal ao rolar + header inteligente (trazido da InterligaMed)
   ====================================================================== */
.site-header{transition:transform .35s ease;}
body.hdr-hidden .site-header{transform:translateY(-100%);}
.r-anim{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1);will-change:opacity,transform;}
.r-fade{opacity:0;transition:opacity .7s ease;will-change:opacity;}
.r-anim.in-view,.r-fade.in-view{opacity:1;transform:none;}
.cards-grid > .r-fade:nth-child(2){transition-delay:.07s;}
.cards-grid > .r-fade:nth-child(3){transition-delay:.14s;}
.cards-grid > .r-fade:nth-child(4){transition-delay:.21s;}
.cards-grid > .r-fade:nth-child(5){transition-delay:.28s;}
.cards-grid > .r-fade:nth-child(6){transition-delay:.35s;}
@media (prefers-reduced-motion: reduce){
  .r-anim,.r-fade{opacity:1 !important;transform:none !important;}
  .site-header{transition:none;}
  body.hdr-hidden .site-header{transform:none;}
}
