/* ═══════════════════════════════════════════════════════════════════════
   style.css — SAAE Portal Institucional
   Filosofia visual: "Porcelana Institucional"
   ─────────────────────────────────────────────────────────────────────
   Paleta:
     Azul suave    #2D5FA0  (COR_PRIMARY) — dessaturado, elegante
     Azul profundo #1B3A6A  (COR_DARK)   — rodapé, topbar
     Azul-gelo     #EDF2FA  (COR_LIGHT)  — fundos alternados
     Verde-teal    #2E7D5E  (COR_ACTION) — ações e confirmações
     Âmbar-mel     #C2780A  (COR_ACCENT) — destaques pontuais
     Vermelho      #BF3527  (COR_DANGER) — urgência

   Princípios:
     · Dessaturação intencional = sofisticação
     · Sombras com tint azul-ardósia (quase imperceptíveis)
     · Bordas arredondadas generosas (12-22px)
     · Muito espaço branco e respiro entre elementos
     · Hierarquia tipográfica clara sem peso visual excessivo

   Tipografia: Sora (corpo/UI) + Lora (títulos editoriais)
   ═══════════════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────────────────────────────
   01 · TOKENS — sistema de design completo
   Cores principais chegam via <style> injetado pelo PHP no header.php
────────────────────────────────────────────────────────────────────── */
:root {
  /* Escala azul — derivada de COR_PRIMARY #2D5FA0 */
  --blue-900: #0E1E3C;
  --blue-800: #152E58;
  --blue-700: #1B3A6A;  /* COR_DARK */
  --blue-600: #244A88;
  --blue-500: #2D5FA0;  /* COR_PRIMARY */
  --blue-450: #3A6EB2;
  --blue-400: #5085C4;
  --blue-300: #7BA8D8;
  --blue-200: #AECAEC;
  --blue-150: #C5D9F0;
  --blue-100: #D8E8F6;
  --blue-50:  #EAF2FB;
  --blue-25:  #EDF2FA;  /* COR_LIGHT */

  /* Verde-teal — COR_ACTION #2E7D5E */
  --teal-700: #1E6049;
  --teal-600: #267354;
  --teal-500: #2E7D5E;
  --teal-400: #3C9872;
  --teal-300: #68B89A;
  --teal-100: #BAE2D2;
  --teal-50:  #E4F3EC;

  /* Âmbar-mel — COR_ACCENT #C2780A */
  --amber-700: #9B5E08;
  --amber-600: #B06B09;
  --amber-500: #C2780A;
  --amber-400: #DA9830;
  --amber-300: #EFBB68;
  --amber-100: #F9E0B2;
  --amber-50:  #FDF3DC;

  /* Vermelho — COR_DANGER #BF3527 */
  --red-700:  #922018;
  --red-600:  #A82D22;
  --red-500:  #BF3527;
  --red-100:  #F8D6D2;
  --red-50:   #FDF0EE;

  /* Neutros / slate */
  --slate-900: #141C2A;
  --slate-800: #1E2A3C;
  --slate-700: #2C3A50;
  --slate-600: #445264;
  --slate-500: #617082;
  --slate-400: #8C9BAF;
  --slate-300: #B6C3D2;
  --slate-200: #D6DFE8;
  --slate-150: #E2EAF0;
  --slate-100: #EDF1F7;
  --slate-50:  #F4F7FA;
  --white:     #FFFFFF;

  /* Semânticas */
  --text-primary:   var(--slate-900);
  --text-secondary: var(--slate-600);
  --text-muted:     var(--slate-500);
  --border:         var(--slate-200);
  --border-lt:      var(--slate-150);
  --bg-page:        var(--white);
  --bg-tinted:      var(--slate-50);
  --bg-blue:        var(--blue-25);

  /* Tipografia */
  --font-display: 'Lora', Georgia, serif;
  --font-body:    'Sora', system-ui, sans-serif;
  --base-fs: 16px;

  /* Border-radius */
  --r-xs: 4px;   --r-sm: 8px;   --r-md: 12px;
  --r-lg: 16px;  --r-xl: 22px;  --r-2xl: 30px;
  --r-pill: 9999px;

  /* Sombras suaves — tint azul-ardósia dessaturado */
  --sh-xs: 0 1px 3px rgba(18,38,78,.05);
  --sh-sm: 0 2px 8px rgba(18,38,78,.07), 0 1px 2px rgba(18,38,78,.04);
  --sh-md: 0 4px 16px rgba(18,38,78,.08), 0 2px 4px rgba(18,38,78,.05);
  --sh-lg: 0 8px 24px rgba(18,38,78,.10), 0 4px 8px rgba(18,38,78,.06);
  --sh-xl: 0 16px 40px rgba(18,38,78,.12), 0 6px 14px rgba(18,38,78,.07);
  --sh-primary: 0 4px 16px rgba(45,95,160,.26);

  /* Transições */
  --ease:   cubic-bezier(.4, 0, .2, 1);
  --t-fast: .14s var(--ease);
  --t-base: .22s var(--ease);
  --t-slow: .38s var(--ease);

  /* Espaçamento base 8pt */
  --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px;
  --s8:32px; --s10:40px; --s12:48px; --s16:64px; --s20:80px; --s24:96px;
}

/* Alto contraste (acessibilidade) */
[data-hc="1"] {
  --c-primary:#1040A0; --c-dark:#082060; --blue-500:#1040A0;
  --blue-25:#C0D8FF; --slate-900:#000; --slate-600:#111;
  --slate-200:#777; --slate-50:#FFF; --border:#444; --bg-tinted:#EEE;
}

/* ──────────────────────────────────────────────────────────────────────
   02 · RESET E BASE
────────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:var(--base-fs);scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
body{font-family:var(--font-body);font-size:1rem;line-height:1.7;
  color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-primary,var(--blue-500));text-decoration:none}
a:hover{color:var(--c-dark,var(--blue-700))}
:focus-visible{outline:2.5px solid var(--c-primary,var(--blue-400));outline-offset:3px;border-radius:var(--r-sm)}

.skip-link{position:absolute;top:-200%;left:16px;z-index:9999;
  background:var(--c-primary,var(--blue-500));color:#fff;
  font-size:14px;font-weight:600;padding:10px 20px;
  border-radius:0 0 var(--r-md) var(--r-md);transition:top var(--t-fast)}
.skip-link:focus{top:0}

[data-reveal]{opacity:0;transform:translateY(18px);
  transition:opacity .5s var(--ease),transform .5s var(--ease)}
[data-reveal].visible{opacity:1;transform:none}

.empty-state{text-align:center;padding:var(--s16) var(--s4);color:var(--text-muted)}
.empty-state i{font-size:48px;display:block;margin-bottom:14px;color:var(--slate-300)}
.container-xl{max-width:1280px}

/* ──────────────────────────────────────────────────────────────────────
   03 · TOPBAR
────────────────────────────────────────────────────────────────────── */
.topbar{background:var(--c-dark,var(--blue-700));padding:7px 0}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.topbar-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.tb-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;
  color:rgba(255,255,255,.5);text-decoration:none;transition:color var(--t-fast)}
.tb-item:hover{color:rgba(255,255,255,.88)}
.tb-item--static{pointer-events:none}
.tb-item i{opacity:.7;font-size:11px}
.tb-sep{width:1px;height:12px;background:rgba(255,255,255,.12)}
.topbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tb-link{font-size:11.5px;color:rgba(255,255,255,.46);text-decoration:none;
  padding:3px 9px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);
  transition:all var(--t-fast);white-space:nowrap}
.tb-link:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.88)}
.a11y-group{display:flex;align-items:center;gap:3px}
.a11y-btn{background:transparent;border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.36);font-family:var(--font-body);font-size:11px;font-weight:700;
  padding:2px 6px;border-radius:var(--r-xs);cursor:pointer;
  transition:all var(--t-fast);display:inline-flex;align-items:center}
.a11y-btn:hover{background:rgba(255,255,255,.09);color:#fff}
@media(max-width:640px){.topbar-right .tb-link:not(:first-child):not(:last-child){display:none}}

/* ──────────────────────────────────────────────────────────────────────
   04 · HEADER / NAVBAR
────────────────────────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:500;background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--blue-100);transition:box-shadow var(--t-base)}
.site-header.scrolled{box-shadow:0 2px 18px rgba(18,38,78,.08)}
.site-header .container-xl{padding:0 24px}
.header-nav{display:flex;align-items:center;height:66px;gap:14px;justify-content:space-between}

/* Marca */
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.brand-gem{width:42px;height:42px;border-radius:11px;
  background:linear-gradient(140deg,var(--c-primary,var(--blue-500)),var(--blue-400));
  display:flex;align-items:center;justify-content:center;font-size:19px;color:#fff;
  box-shadow:var(--sh-primary);flex-shrink:0;transition:transform var(--t-base)}
.brand:hover .brand-gem{transform:scale(1.05) rotate(-4deg)}
.brand-gem--sm{width:36px;height:36px;font-size:16px;border-radius:9px}
.brand-gem--footer{width:40px;height:40px;font-size:18px;border-radius:10px;
  background:rgba(255,255,255,.1);box-shadow:none}
.brand-txt{display:flex;flex-direction:column;line-height:1.2}
.brand-sigla{font-size:17px;font-weight:700;color:var(--c-dark,var(--blue-700));letter-spacing:-.02em}
.brand-muni{font-size:10px;color:var(--text-muted);font-weight:400}

/* Menu desktop */
.desktop-nav{display:none;list-style:none;gap:2px;align-items:center;margin:0;padding:0}
@media(min-width:1200px){.desktop-nav{display:flex}}
.d-nav-link{font-size:13px;font-weight:500;color:var(--text-secondary)!important;
  padding:7px 10px!important;border-radius:var(--r-sm)!important;text-decoration:none;
  white-space:nowrap;position:relative;transition:all var(--t-fast)!important}
.d-nav-link::after{content:'';position:absolute;bottom:3px;left:10px;right:10px;height:2px;
  border-radius:1px;background:var(--c-primary,var(--blue-500));
  transform:scaleX(0);transition:transform var(--t-base)}
.d-nav-link:hover,.d-nav-link--on{color:var(--c-primary,var(--blue-500))!important;background:var(--blue-25)!important}
.d-nav-link--on::after,.d-nav-link:hover::after{transform:scaleX(1)}

.header-ctas{display:flex;align-items:center;gap:8px}
.btn-2via{display:inline-flex;align-items:center;gap:7px;
  background:var(--c-primary,var(--blue-500));color:#fff!important;
  font-family:var(--font-body);font-size:13px;font-weight:700;
  padding:9px 17px;border-radius:var(--r-md);text-decoration:none;white-space:nowrap;
  box-shadow:var(--sh-primary);transition:all var(--t-base)}
.btn-2via:hover{background:var(--c-dark,var(--blue-700));color:#fff!important;
  transform:translateY(-1px);box-shadow:var(--sh-lg)}
.btn-2via--full{width:100%;justify-content:center}
.btn-emerg{display:inline-flex;align-items:center;gap:7px;
  background:var(--c-danger,var(--red-500));color:#fff!important;
  font-family:var(--font-body);font-size:13px;font-weight:700;
  padding:9px 15px;border-radius:var(--r-md);text-decoration:none;white-space:nowrap;
  transition:background var(--t-fast)}
.btn-emerg:hover{background:var(--red-700);color:#fff!important}
.btn-emerg--full{width:100%;justify-content:center}
.btn-wpp{display:flex;align-items:center;justify-content:center;gap:7px;
  background:#25D366;color:#fff!important;font-family:var(--font-body);
  font-size:14px;font-weight:700;padding:10px;border-radius:var(--r-md);
  text-decoration:none;transition:background var(--t-fast)}
.btn-wpp:hover{background:#1DAA55}
.btn-wpp--full{width:100%}

/* Hamburger */
.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;padding:8px;background:transparent;
  border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;
  transition:border-color var(--t-fast)}
@media(min-width:1200px){.hamburger{display:none}}
.hamburger:hover{border-color:var(--c-primary,var(--blue-400))}
.hbar{display:block;width:100%;height:1.5px;background:var(--slate-600);
  border-radius:2px;transition:transform var(--t-base),opacity var(--t-fast)}
.hamburger[aria-expanded="true"] .hbar:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger[aria-expanded="true"] .hbar:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] .hbar:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile overlay + drawer */
.m-overlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(8,18,45,.52);backdrop-filter:blur(4px)}
.m-overlay.open{display:block;animation:fadeIn .2s ease}
.m-drawer{position:fixed;top:0;right:0;bottom:0;z-index:700;width:min(340px,93vw);
  background:#fff;display:flex;flex-direction:column;overflow-y:auto;
  padding:var(--s5) var(--s6) var(--s10);gap:var(--s5);
  box-shadow:var(--sh-xl);animation:slideRight .24s var(--ease)}
.m-drawer[hidden]{display:none}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideRight{from{transform:translateX(100%)}to{transform:none}}
.drawer-top{display:flex;align-items:center;justify-content:space-between;
  padding-bottom:16px;border-bottom:1px solid var(--border)}
.drawer-close{width:36px;height:36px;border-radius:var(--r-sm);background:transparent;
  border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;font-size:14px;
  display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.drawer-close:hover{border-color:var(--red-500);color:var(--red-500)}
.drawer-nav{list-style:none;display:flex;flex-direction:column;gap:2px}
.drawer-link{display:flex;align-items:center;padding:12px 13px;border-radius:var(--r-md);
  font-size:15px;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all var(--t-fast)}
.drawer-link:hover,.drawer-link--on{background:var(--blue-25);color:var(--c-primary,var(--blue-500))}
.drawer-link--on{font-weight:700}
.drawer-ctas{display:flex;flex-direction:column;gap:8px}
.drawer-footer{display:flex;flex-direction:column;gap:8px;padding-top:16px;border-top:1px solid var(--border)}
.drawer-footer a{display:flex;align-items:center;gap:8px;font-size:13px;
  color:var(--text-secondary);text-decoration:none;transition:color var(--t-fast)}
.drawer-footer a i{color:var(--c-primary,var(--blue-500))}
.drawer-footer a:hover{color:var(--c-primary,var(--blue-500))}

/* ──────────────────────────────────────────────────────────────────────
   05 · SEÇÕES — base compartilhada
────────────────────────────────────────────────────────────────────── */
.section{padding:var(--s20) 0}
.section--tinted{background:var(--bg-blue)}
.section--white{background:#fff}

.sec-header{margin-bottom:var(--s12);text-align:center}
.sec-header--split{display:flex;align-items:flex-end;justify-content:space-between;
  flex-wrap:wrap;gap:16px;text-align:left;margin-bottom:var(--s10)}
.sec-header--split .sec-title{margin-bottom:0}

/* Eyebrow com linha decorativa */
.sec-eyebrow{display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-primary,var(--blue-500));margin-bottom:10px}
.sec-eyebrow::before{content:'';display:inline-block;width:22px;height:2px;
  background:currentColor;border-radius:1px;flex-shrink:0}
.sec-eyebrow--light{color:rgba(185,215,255,.82)}
.sec-eyebrow--light::before{opacity:.6}

.sec-title{font-family:var(--font-display);font-size:clamp(22px,2.8vw,32px);
  font-weight:600;color:var(--slate-900);line-height:1.22;letter-spacing:-.01em;margin-bottom:10px}
.sec-title--light{color:#fff}
.sec-lead{font-size:16px;color:var(--text-secondary);line-height:1.75;max-width:520px;margin:0 auto}
.btn-ver-mais{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:700;
  color:var(--c-primary,var(--blue-500));text-decoration:none;white-space:nowrap;
  transition:gap var(--t-fast),color var(--t-fast)}
.btn-ver-mais:hover{gap:9px;color:var(--c-dark,var(--blue-700))}

/* ──────────────────────────────────────────────────────────────────────
   06 · HERO — imagem institucional + card branco sobreposto
────────────────────────────────────────────────────────────────────── */
.hero{position:relative;min-height:560px;display:flex;align-items:center;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,var(--c-dark,var(--blue-700)) 0%,var(--c-primary,var(--blue-500)) 100%)}
.hero-bg{position:absolute;inset:0;z-index:0}
/* saturate(.68) = menos vibrante, mais sofisticado */
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center;
  filter:brightness(.50) saturate(.68);transition:transform 8s ease}
.hero:hover .hero-img{transform:scale(1.025)}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(108deg,rgba(9,20,55,.80) 0%,rgba(28,62,126,.46) 55%,rgba(9,20,55,.25) 100%)}
.hero .container-xl{position:relative;z-index:1;padding:var(--s12) 24px}
.hero-layout{display:grid;grid-template-columns:1fr;gap:var(--s10);align-items:end}
@media(min-width:992px){.hero-layout{grid-template-columns:1.1fr 1fr;gap:var(--s12);align-items:center}}

/* Card institucional — elemento central do hero */
.hero-card{background:rgba(255,255,255,.97);border-radius:var(--r-xl);padding:var(--s8);
  box-shadow:var(--sh-xl);
  /* Borda esquerda tricolor = identidade visual de produto */
  border-left:5px solid transparent;
  background-image:linear-gradient(rgba(255,255,255,.97),rgba(255,255,255,.97)),
    linear-gradient(180deg,var(--c-primary,#2D5FA0),var(--c-action,#2E7D5E),var(--c-accent,#C2780A));
  background-origin:border-box;background-clip:padding-box,border-box;
  max-width:560px;backdrop-filter:blur(8px)}
@media(min-width:640px){.hero-card{padding:var(--s10)}}

.hero-card-eyebrow{display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--c-primary,var(--blue-500));margin-bottom:var(--s4)}
.hero-card-title{font-family:var(--font-display);font-size:clamp(24px,3.5vw,38px);
  font-weight:700;color:var(--slate-900);line-height:1.12;letter-spacing:-.02em;margin-bottom:var(--s4)}
.hero-card-title em{color:var(--c-primary,var(--blue-500));font-style:normal}
.hero-card-sub{font-size:15.5px;color:var(--text-secondary);line-height:1.7;margin-bottom:var(--s6)}

.hero-ctas{display:flex;flex-wrap:wrap;gap:var(--s3);margin-bottom:var(--s5)}
.hero-btn-primary{display:inline-flex;align-items:center;gap:8px;
  background:var(--c-primary,var(--blue-500));color:#fff!important;
  font-family:var(--font-body);font-size:14.5px;font-weight:700;
  padding:12px 22px;border-radius:var(--r-md);text-decoration:none;white-space:nowrap;
  box-shadow:var(--sh-primary);transition:all var(--t-base)}
.hero-btn-primary:hover{background:var(--c-dark,var(--blue-700));color:#fff!important;
  transform:translateY(-1px);box-shadow:var(--sh-lg)}
.hero-btn-ghost{display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:#fff!important;
  font-family:var(--font-body);font-size:14.5px;font-weight:600;
  padding:12px 22px;border-radius:var(--r-md);
  border:1.5px solid rgba(255,255,255,.42);text-decoration:none;white-space:nowrap;
  transition:all var(--t-base)}
.hero-btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.72);color:#fff!important}

.hero-status{display:flex;align-items:center;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text-muted)}
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.status-dot--ok{background:var(--teal-500);box-shadow:0 0 0 3px rgba(46,125,94,.2)}
.status-link{font-weight:700;color:var(--c-primary,var(--blue-500));text-decoration:underline}
.status-link:hover{color:var(--c-dark,var(--blue-700))}

.hero-stats{display:flex;align-items:center;flex-wrap:wrap;gap:var(--s6);padding:var(--s6) 0 var(--s4)}
@media(min-width:992px){.hero-stats{flex-direction:column;align-items:flex-start;gap:var(--s5)}}
.hstat{display:flex;flex-direction:column}
.hstat-num{font-family:var(--font-body);font-size:34px;font-weight:800;color:#fff;line-height:1;letter-spacing:-.03em}
.hstat-unit{font-size:19px;color:rgba(255,255,255,.85);font-weight:700}
.hstat-label{font-size:11.5px;color:rgba(255,255,255,.5);margin-top:3px}
.hstat-sep{width:30px;height:1px;background:rgba(255,255,255,.15);flex-shrink:0}
@media(min-width:992px){.hstat-sep{width:100%}}

/* ──────────────────────────────────────────────────────────────────────
   07 · SERVIÇOS — portais externos encaminhados pelo portal
   Integração: link/iframe/api via SAAE_SISTEMAS em config.php
────────────────────────────────────────────────────────────────────── */
.srv-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:576px){.srv-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.srv-grid{grid-template-columns:repeat(3,1fr)}}

.srv-card{border-radius:var(--r-xl);border:1.5px solid var(--border);background:#fff;
  box-shadow:var(--sh-sm);overflow:hidden;transition:all var(--t-base)}
.srv-card::before{content:'';display:block;height:3px}
.srv-card--blue::before{background:var(--c-primary,var(--blue-500))}
.srv-card--green::before{background:var(--c-action,var(--teal-500))}
.srv-card--amber::before{background:var(--c-accent,var(--amber-500))}
.srv-card--slate::before{background:var(--slate-300)}
.srv-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px);border-color:var(--blue-150)}

.srv-link{display:flex;align-items:center;gap:16px;padding:20px 22px;text-decoration:none;color:inherit}
.srv-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:21px;
  transition:transform var(--t-base)}
.srv-card:hover .srv-icon{transform:scale(1.08) rotate(-3deg)}
.srv-icon--blue{background:var(--blue-25);border:1.5px solid var(--blue-150);color:var(--c-primary,var(--blue-500))}
.srv-icon--green{background:var(--teal-50);border:1.5px solid var(--teal-100);color:var(--teal-600)}
.srv-icon--amber{background:var(--amber-50);border:1.5px solid var(--amber-100);color:var(--amber-600)}
.srv-icon--slate{background:var(--slate-100);border:1.5px solid var(--slate-200);color:var(--slate-500)}
.srv-info{flex:1}
.srv-name{font-size:14.5px;font-weight:700;color:var(--slate-900);margin-bottom:3px}
.srv-desc{font-size:12.5px;color:var(--text-muted);line-height:1.45}
.srv-arrow{font-size:18px;color:var(--slate-300);flex-shrink:0;transition:all var(--t-fast)}
.srv-card:hover .srv-arrow{color:var(--c-primary,var(--blue-500));transform:translateX(3px)}

/* ──────────────────────────────────────────────────────────────────────
   08 · COMUNICADOS
────────────────────────────────────────────────────────────────────── */
.com-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:768px){.com-grid{grid-template-columns:repeat(2,1fr)}}

.com-card{border-radius:var(--r-lg);padding:18px 20px;
  display:flex;align-items:flex-start;gap:14px;border:1.5px solid;
  transition:transform var(--t-base),box-shadow var(--t-base)}
.com-card:hover{transform:translateX(4px);box-shadow:var(--sh-sm)}
.com-card--urgente{background:var(--red-50);border-color:var(--red-100)}
.com-card--manutencao{background:var(--blue-25);border-color:var(--blue-100)}
.com-card--campanha{background:var(--teal-50);border-color:var(--teal-100)}
.com-card--aviso{background:var(--amber-50);border-color:var(--amber-100)}
.com-icon{width:42px;height:42px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:19px}
.com-card--urgente .com-icon{background:var(--red-100);color:var(--red-700)}
.com-card--manutencao .com-icon{background:var(--blue-100);color:var(--c-primary,var(--blue-600))}
.com-card--campanha .com-icon{background:var(--teal-100);color:var(--teal-700)}
.com-card--aviso .com-icon{background:var(--amber-100);color:var(--amber-700)}
.com-meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:7px}
.com-pin{font-size:12px;color:var(--c-primary,var(--blue-500))}
.com-badge{font-size:9.5px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  padding:2px 8px;border-radius:var(--r-pill)}
.com-badge--urgente{background:var(--red-100);color:var(--red-700)}
.com-badge--manutencao{background:var(--blue-100);color:var(--c-primary,var(--blue-600))}
.com-badge--campanha{background:var(--teal-100);color:var(--teal-700)}
.com-badge--aviso{background:var(--amber-100);color:var(--amber-700)}
.com-date{font-size:12px;color:var(--text-muted)}
.com-body{flex:1}
.com-title{font-size:14.5px;font-weight:700;color:var(--slate-900);line-height:1.35;margin-bottom:7px}
.com-txt{font-size:13px;color:var(--text-secondary);line-height:1.6}
.com-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;
  color:inherit;text-decoration:underline;margin-top:8px;transition:gap var(--t-fast)}
.com-link:hover{gap:8px}

/* ──────────────────────────────────────────────────────────────────────
   09 · NOTÍCIAS
────────────────────────────────────────────────────────────────────── */
.news-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:576px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){
  .news-grid{grid-template-columns:repeat(3,1fr)}
  .news-card--featured{grid-column:span 2}
  .news-card--featured .news-thumb{height:280px}
}
.news-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);
  overflow:hidden;box-shadow:var(--sh-sm);display:flex;flex-direction:column;transition:all var(--t-base)}
.news-card:hover{box-shadow:var(--sh-xl);transform:translateY(-4px);border-color:var(--blue-150)}
.news-thumb{position:relative;height:210px;overflow:hidden;background:var(--blue-25);
  display:flex;align-items:center;justify-content:center}
.news-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .45s var(--ease);
  background:linear-gradient(90deg,var(--slate-150) 25%,var(--slate-100) 50%,var(--slate-150) 75%);
  background-size:200% 100%}
.news-img.loaded{background:none;animation:none}
.news-img:not(.loaded){animation:shimmer 1.6s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.news-card:hover .news-img{transform:scale(1.04)}
.news-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:46px;color:var(--slate-300)}
.news-cat{position:absolute;top:12px;right:12px;font-size:10px;font-weight:800;
  letter-spacing:.07em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-pill)}
.news-cat--obras{background:var(--c-primary,var(--blue-500));color:#fff}
.news-cat--qualidade{background:var(--teal-600);color:#fff}
.news-cat--social{background:var(--c-accent,var(--amber-500));color:#fff}
.news-cat--institucional{background:var(--slate-600);color:#fff}
.news-date{position:absolute;bottom:12px;left:12px;font-size:11px;font-weight:600;
  background:rgba(0,0,0,.48);color:#fff;padding:3px 9px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.news-body{padding:20px;flex:1;display:flex;flex-direction:column;gap:8px}
.news-title{font-family:var(--font-display);font-size:16.5px;font-weight:600;
  color:var(--slate-900);line-height:1.35}
.news-title a{color:inherit;text-decoration:none;transition:color var(--t-fast)}
.news-title a:hover{color:var(--c-primary,var(--blue-500))}
.news-lead{font-size:13.5px;color:var(--text-secondary);line-height:1.65;flex:1}
.news-more{display:inline-flex;align-items:center;gap:5px;font-size:13.5px;font-weight:700;
  color:var(--c-primary,var(--blue-500));text-decoration:none;margin-top:8px;transition:gap var(--t-fast)}
.news-more:hover{gap:9px}

/* ──────────────────────────────────────────────────────────────────────
   10 · DIÁRIO OFICIAL (módulo externo — encaminhamento)
────────────────────────────────────────────────────────────────────── */
.do-panel{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-sm)}
.do-list{display:flex;flex-direction:column}
.do-row{display:grid;grid-template-columns:1fr;gap:10px;padding:17px 22px;
  border-bottom:1px solid var(--border-lt);transition:background var(--t-fast)}
.do-row:last-child{border-bottom:none}
.do-row:hover{background:var(--blue-25)}
@media(min-width:768px){.do-row{grid-template-columns:auto 1fr auto;align-items:center}}
.do-meta{display:flex;align-items:center;flex-wrap:wrap;gap:7px}
.do-badge{font-size:9.5px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;padding:3px 9px;border-radius:var(--r-pill)}
.do-badge--portaria{background:var(--blue-25);color:var(--c-primary,var(--blue-500))}
.do-badge--licitacao{background:var(--amber-50);color:var(--amber-700)}
.do-badge--resolucao{background:var(--teal-50);color:var(--teal-700)}
.do-badge--contrato{background:var(--slate-100);color:var(--slate-600)}
.do-badge--decreto{background:var(--red-50);color:var(--red-700)}
.do-badge--edital{background:var(--blue-25);color:var(--c-primary,var(--blue-500))}
.do-date{font-size:12px;color:var(--text-muted);white-space:nowrap}
.do-num{font-size:12px;color:var(--text-muted)}
.do-title{font-size:14px;font-weight:500;color:var(--slate-800);line-height:1.4}
.do-pdf{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;
  background:var(--c-primary,var(--blue-500));color:#fff!important;
  padding:7px 13px;border-radius:var(--r-sm);text-decoration:none;white-space:nowrap;transition:background var(--t-fast)}
.do-pdf:hover{background:var(--c-dark,var(--blue-700))}

/* ──────────────────────────────────────────────────────────────────────
   11 · TRANSPARÊNCIA (portais externos — encaminhamento e acesso)
────────────────────────────────────────────────────────────────────── */
.tp-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:var(--s10)}
@media(min-width:576px){.tp-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.tp-grid{grid-template-columns:repeat(4,1fr)}}

.tp-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);
  padding:24px 20px 20px;display:flex;flex-direction:column;gap:10px;
  text-decoration:none;color:inherit;box-shadow:var(--sh-xs);
  position:relative;overflow:hidden;transition:all var(--t-base)}
.tp-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--c-primary,var(--blue-500));transition:height var(--t-base)}
.tp-card--green::after{background:var(--c-action,var(--teal-500))}
.tp-card--amber::after{background:var(--c-accent,var(--amber-500))}
.tp-card--slate::after{background:var(--slate-300)}
.tp-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px)}
.tp-card:hover::after{height:4px}
.tp-icon{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;
  justify-content:center;font-size:21px;transition:transform var(--t-base)}
.tp-card:hover .tp-icon{transform:scale(1.08) rotate(-3deg)}
.tp-card--blue .tp-icon{background:var(--blue-25);border:1.5px solid var(--blue-150);color:var(--c-primary,var(--blue-500))}
.tp-card--green .tp-icon{background:var(--teal-50);border:1.5px solid var(--teal-100);color:var(--teal-600)}
.tp-card--amber .tp-icon{background:var(--amber-50);border:1.5px solid var(--amber-100);color:var(--amber-600)}
.tp-card--slate .tp-icon{background:var(--slate-100);border:1.5px solid var(--slate-200);color:var(--slate-500)}
.tp-name{font-size:15.5px;font-weight:700;color:var(--slate-900)}
.tp-desc{font-size:13px;color:var(--text-secondary);line-height:1.55;flex:1}
.tp-arrow{font-size:17px;color:var(--slate-300);margin-top:auto;transition:all var(--t-fast)}
.tp-card:hover .tp-arrow{color:var(--c-primary,var(--blue-500));transform:translateX(3px)}

.tp-metrics{background:var(--c-dark,var(--blue-700));border-radius:var(--r-xl);
  padding:var(--s10) var(--s8);display:flex;flex-wrap:wrap;justify-content:space-around;gap:var(--s6)}
.tpm{display:flex;flex-direction:column;align-items:center;text-align:center}
.tpm-num{font-family:var(--font-body);font-size:40px;font-weight:800;color:#fff;line-height:1}
.tpm-unit{font-size:22px;color:rgba(255,255,255,.75);font-weight:700}
.tpm-label{font-size:11.5px;color:rgba(255,255,255,.48);margin-top:5px}
.tpm-sep{width:1px;height:54px;background:rgba(255,255,255,.12);align-self:center}
@media(max-width:576px){.tpm-sep{display:none}}

/* ──────────────────────────────────────────────────────────────────────
   12 · APLICATIVO
────────────────────────────────────────────────────────────────────── */
.section-app{background:linear-gradient(135deg,var(--c-dark,var(--blue-700)) 0%,var(--c-primary,var(--blue-500)) 100%);padding:var(--s20) 0}
.app-layout{display:flex;align-items:center;gap:var(--s16);flex-wrap:wrap}
.app-phone{flex-shrink:0}
.phone-shell{width:108px;height:206px;border-radius:22px;
  border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 20px 48px rgba(0,0,0,.22);animation:phoneFloat 4.5s ease-in-out infinite}
@keyframes phoneFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.phone-screen{display:flex;flex-direction:column;align-items:center;gap:7px}
.phone-ico{font-size:30px;color:rgba(255,255,255,.72)}
.phone-screen span{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.42)}
.app-content{flex:1;min-width:260px}
.app-desc{font-size:15.5px;color:rgba(255,255,255,.58);line-height:1.75;margin-bottom:var(--s6)}
.app-stores{display:flex;flex-wrap:wrap;gap:var(--s3)}
.store-btn{display:flex;align-items:center;gap:10px;padding:11px 17px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--r-md);text-decoration:none;transition:all var(--t-fast)}
.store-btn:hover{background:rgba(255,255,255,.15)}
.store-btn i{font-size:20px;color:rgba(255,255,255,.72)}
.store-btn div{display:flex;flex-direction:column}
.store-btn div span:first-child{font-size:9px;color:rgba(255,255,255,.42);text-transform:uppercase;letter-spacing:.05em}
.store-btn div span:last-child{font-size:13.5px;font-weight:700;color:#fff}

/* ──────────────────────────────────────────────────────────────────────
   13 · CONTATO
────────────────────────────────────────────────────────────────────── */
.ct-layout{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:900px){.ct-layout{grid-template-columns:1fr 1.45fr}}
.ct-info{display:flex;flex-direction:column;gap:12px}
.ct-card{display:flex;align-items:flex-start;gap:14px;padding:17px 20px;background:#fff;
  border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-xs);transition:all var(--t-fast)}
.ct-card:hover{border-color:var(--blue-150);box-shadow:var(--sh-sm)}
.ct-card i{font-size:21px;color:var(--c-primary,var(--blue-500));flex-shrink:0;margin-top:2px}
.ct-card strong{display:block;font-size:13px;font-weight:700;color:var(--slate-900);margin-bottom:4px}
.ct-card span,.ct-card a{display:block;font-size:13.5px;color:var(--text-secondary);text-decoration:none}
.ct-card a:hover{color:var(--c-primary,var(--blue-500))}
.emerg-label{color:var(--teal-600)!important;font-weight:600}
.ct-map{border-radius:var(--r-xl);overflow:hidden;min-height:360px;position:relative;
  border:1.5px solid var(--border);box-shadow:var(--sh-sm)}
.ct-map-btn{position:absolute;bottom:16px;left:16px}
.btn-map{display:inline-flex;align-items:center;gap:7px;background:#fff;
  color:var(--c-primary,var(--blue-600));font-size:13px;font-weight:700;
  padding:9px 14px;border-radius:var(--r-md);text-decoration:none;
  box-shadow:var(--sh-md);transition:all var(--t-fast)}
.btn-map:hover{background:var(--c-primary,var(--blue-500));color:#fff}

/* ──────────────────────────────────────────────────────────────────────
   14 · RODAPÉ
────────────────────────────────────────────────────────────────────── */
.footer-sos{background:var(--c-danger,var(--red-600));padding:10px 0}
.footer-sos-inner{display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;font-size:13.5px;color:rgba(255,255,255,.88);font-weight:500}
.footer-sos-inner>*{display:flex;align-items:center;gap:8px}
.sos-pulse{width:7px;height:7px;border-radius:50%;background:#fff;
  animation:sosPulse 1.6s ease-in-out infinite;flex-shrink:0}
@keyframes sosPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(1.5)}}
.sos-wa{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.18);color:#fff;
  font-size:12.5px;font-weight:700;padding:6px 13px;border-radius:var(--r-pill);
  text-decoration:none;transition:background var(--t-fast)}
.sos-wa:hover{background:rgba(255,255,255,.3);color:#fff}

.footer-body{background:var(--c-dark,var(--blue-700));padding:56px 0 40px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:38px}
@media(min-width:576px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1.3fr}}
.fcol--brand{display:flex;flex-direction:column;gap:18px}
.footer-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.footer-brand .brand-sigla{color:#fff}
.footer-brand .brand-muni{color:rgba(255,255,255,.38)}
.footer-sobre{font-size:13.5px;color:rgba(255,255,255,.42);line-height:1.75}
.footer-social{display:flex;gap:8px}
.soc-btn{width:34px;height:34px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);color:rgba(255,255,255,.42);
  display:flex;align-items:center;justify-content:center;font-size:15px;
  text-decoration:none;transition:all var(--t-fast)}
.soc-btn:hover{background:rgba(255,255,255,.15);color:#fff}
.fcol-title{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.28);margin-bottom:15px}
.footer-link{display:block;font-size:13.5px;color:rgba(255,255,255,.48);text-decoration:none;
  margin-bottom:9px;transition:color var(--t-fast),padding-left var(--t-fast)}
.footer-link:hover{color:rgba(255,255,255,.88);padding-left:4px}
.footer-address{font-style:normal;display:flex;flex-direction:column;gap:11px}
.fa-row{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:rgba(255,255,255,.48)}
.fa-row i{color:var(--blue-300);flex-shrink:0;margin-top:2px}
.fa-row a{color:rgba(255,255,255,.48);text-decoration:none;display:block;transition:color var(--t-fast)}
.fa-row a:hover{color:rgba(255,255,255,.88)}
.fa-row small{font-size:11px;opacity:.55}
.fa-row span{display:block}
.footer-base{background:#07101E;padding:16px 0}
.footer-base-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-base-row p{font-size:12px;color:rgba(255,255,255,.26)}
.footer-base-row nav{display:flex;flex-wrap:wrap;gap:14px}
.footer-base-row a{font-size:12px;color:rgba(255,255,255,.28);text-decoration:none;transition:color var(--t-fast)}
.footer-base-row a:hover{color:rgba(255,255,255,.62)}

/* ──────────────────────────────────────────────────────────────────────
   15 · FLUTUANTES — FAB WhatsApp, botão topo, cookie LGPD
────────────────────────────────────────────────────────────────────── */
.fab-wpp{position:fixed;bottom:28px;right:28px;z-index:400;display:flex;align-items:center;gap:8px;
  background:#25D366;color:#fff;font-family:var(--font-body);font-size:13.5px;font-weight:700;
  padding:11px 17px;border-radius:var(--r-pill);text-decoration:none;
  box-shadow:0 4px 16px rgba(37,211,102,.32);animation:fabFloat 3.5s ease-in-out infinite;
  transition:all var(--t-base)}
.fab-wpp i{font-size:21px}
@keyframes fabFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.fab-wpp:hover{background:#1DAA55;color:#fff;transform:scale(1.05)!important;animation:none}
@media(max-width:480px){.fab-wpp{padding:14px;border-radius:50%}.fab-label{display:none}}

.btn-top{position:fixed;bottom:28px;left:28px;z-index:400;width:42px;height:42px;border-radius:50%;
  background:var(--c-primary,var(--blue-500));color:#fff;border:none;cursor:pointer;font-size:20px;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-md);
  transition:all var(--t-base);opacity:0;pointer-events:none}
.btn-top:not([hidden]){opacity:1;pointer-events:auto}
.btn-top:hover{background:var(--c-dark,var(--blue-700));transform:translateY(-2px)}

.cookie-bar{position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:var(--c-dark,var(--blue-700));border-top:2px solid var(--blue-400);
  animation:slideUp .3s var(--ease)}
.cookie-bar[hidden]{display:none}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
.cookie-inner{display:flex;align-items:center;flex-wrap:wrap;gap:16px;
  padding:15px 0;justify-content:space-between}
.cookie-inner p{font-size:13px;color:rgba(255,255,255,.62);flex:1;min-width:200px}
.cookie-inner a{color:var(--blue-200)}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie-btn-reject,.cookie-btn-accept{font-family:var(--font-body);font-size:13px;font-weight:700;
  padding:8px 18px;border-radius:var(--r-md);border:none;cursor:pointer;transition:all var(--t-fast)}
.cookie-btn-reject{background:rgba(255,255,255,.08);color:rgba(255,255,255,.62)}
.cookie-btn-reject:hover{background:rgba(255,255,255,.15)}
.cookie-btn-accept{background:var(--c-primary,var(--blue-500));color:#fff}
.cookie-btn-accept:hover{background:var(--blue-450)}
