/*
Theme Name:   Câmara Curral de Dentro — Astra Child
Theme URI:    https://camaradecurraldedentro.mg.gov.br
Description:  Tema filho do Astra — Câmara Municipal de Curral de Dentro MG. Projeto Diamante PNTP 2026.
Author:       Câmara Municipal de Curral de Dentro
Author URI:   https://camaradecurraldedentro.mg.gov.br
Template:     astra
Version:      1.0.0
Text Domain:  camara-astra-child
*/

/* ============================================================
   VARIÁVEIS — IDENTIDADE VISUAL CÂMARA CURRAL DE DENTRO
   Paleta extraída do brasão municipal
============================================================ */
:root {
  --c-azul:      #0D2E6E;
  --c-azul-m:    #1249A4;
  --c-azul-c:    #EBF2FD;
  --c-ouro:      #C8941E;
  --c-ouro-v:    #F0B429;
  --c-branco:    #FFFFFF;
  --c-cinza-bg:  #F4F6FB;
  --c-cinza-bd:  #DDE3EF;
  --c-txt:       #131B30;
  --c-txt-m:     #3C4766;
  --c-txt-l:     #6B7A99;
  --c-serif:     'Noto Serif', Georgia, serif;
  --c-sans:      'Inter', 'Segoe UI', system-ui, sans-serif;
  --c-sh:        0 4px 20px rgba(13,46,110,.10);
  --c-r:         10px;
  --c-tr:        all .22s ease;
}

/* ── RESET SUAVE ── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--c-sans); background: var(--c-cinza-bg); color: var(--c-txt); overflow-x: hidden; }
img  { max-width: 100%; height: auto; display: block; }
a    { text-decoration: none; color: inherit; }
ul   { list-style: none; padding: 0; margin: 0; }

/* Sobrescrever Astra */
.ast-container { max-width: 1200px !important; }
body, .ast-single-post .entry-content { font-family: var(--c-sans) !important; }
h1,h2,h3 { font-family: var(--c-serif) !important; letter-spacing: -.02em; }

/* ============================================================
   BARRA DE ACESSIBILIDADE
============================================================ */
.camara-util {
  background: #081B4A;
  color: rgba(255,255,255,.72);
  font-size: 11.5px; font-weight: 500;
  padding: 0 clamp(12px,3vw,40px);
  display: flex; align-items: center;
  justify-content: space-between;
  min-height: 36px; gap: 8px; flex-wrap: wrap;
}
.camara-util a { color: rgba(255,255,255,.7); transition: color .2s; }
.camara-util a:hover { color: var(--c-ouro-v); }
.cu-left  { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.cu-right { display: flex; gap: 6px;  align-items: center; flex-shrink: 0; }
.cu-sep   { width: 1px; height: 13px; background: rgba(255,255,255,.15); }
.btn-ac {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(255,255,255,.09); border: 1px solid rgba(255,255,255,.14);
  border-radius: 5px; padding: 3px 10px;
  font-size: 11px; font-weight: 600; color: rgba(255,255,255,.82);
  transition: var(--c-tr); white-space: nowrap;
  cursor: pointer; font-family: var(--c-sans);
}
.btn-ac:hover, .btn-ac.on { background: rgba(255,255,255,.2); color: #fff; }

/* ============================================================
   HEADER — sobrescreve Astra completamente
============================================================ */
#masthead,
.site-header,
.ast-primary-header-bar { display: none !important; }

.camara-header {
  background: var(--c-azul);
  padding: 0 clamp(12px,3vw,40px);
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 14px; min-height: 80px;
  border-bottom: 3px solid var(--c-ouro);
  flex-wrap: wrap; position: relative;
}
.camara-brand {
  display: flex; align-items: center;
  gap: 14px; flex-shrink: 0;
  padding: 10px 0;
}
.camara-brand img {
  height: 60px; width: 60px;
  object-fit: contain;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.3));
  transition: transform .3s;
  flex-shrink: 0;
}
.camara-brand:hover img { transform: scale(1.05); }
.cb-top  { font-family: var(--c-serif); font-size: 10.5px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--c-ouro); display: block; }
.cb-name { font-family: var(--c-serif); font-size: clamp(16px,2.4vw,22px); font-weight: 700; color: #fff; line-height: 1.1; display: block; }
.cb-sub  { font-size: 10px; color: rgba(255,255,255,.42); letter-spacing: .05em; text-transform: uppercase; display: block; }
.ch-right { display: flex; align-items: center; gap: 10px; }
.camara-search {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.09);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: var(--c-r); padding: 0 13px; height: 40px;
  width: clamp(160px,20vw,250px); transition: var(--c-tr);
}
.camara-search:focus-within {
  background: rgba(255,255,255,.15); border-color: var(--c-ouro);
  box-shadow: 0 0 0 3px rgba(200,148,30,.18);
}
.camara-search input {
  background: none; border: none; outline: none;
  color: #fff; font-family: var(--c-sans); font-size: 13px; width: 100%;
}
.camara-search input::placeholder { color: rgba(255,255,255,.36); }
.ch-ham {
  display: none; background: none; border: none;
  padding: 8px; color: #fff; cursor: pointer; flex-shrink: 0;
}
.ch-ham svg { width: 24px; height: 24px; }

/* ============================================================
   NAVBAR DESKTOP
============================================================ */
#ast-fixed-header,
.ast-above-header-wrap,
.ast-below-header-wrap { display: none !important; }

.camara-navbar {
  background: #fff; border-bottom: 2px solid var(--c-cinza-bd);
  padding: 0 clamp(12px,3vw,40px);
  display: flex; align-items: stretch; height: 50px;
  position: sticky; top: 0; z-index: 200;
  box-shadow: 0 2px 10px rgba(13,46,110,.07);
}
.cn-list { display: flex; align-items: stretch; list-style: none; width: 100%; margin: 0; padding: 0; }
.cn-item { position: relative; display: flex; align-items: stretch; }
.cn-link {
  display: flex; align-items: center; gap: 4px;
  padding: 0 14px; font-size: 12px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: var(--c-txt-m); border-bottom: 3px solid transparent;
  transition: var(--c-tr); white-space: nowrap;
  cursor: pointer; background: none;
  border-top: none; border-left: none; border-right: none;
}
.cn-link:hover, .cn-link.on { color: var(--c-azul-m); border-bottom-color: var(--c-ouro); }
.cn-chv { font-size: 9px; opacity: .45; transition: transform .2s; }
.cn-item:hover > .cn-link .cn-chv { transform: rotate(180deg); }
.cn-drop {
  display: none; position: absolute; top: 100%; left: 0;
  background: #fff; border: 1.5px solid var(--c-cinza-bd);
  border-top: 3px solid var(--c-azul);
  border-radius: 0 0 10px 10px;
  box-shadow: 0 8px 28px rgba(13,46,110,.12);
  min-width: 228px; z-index: 300; padding: 8px 0;
}
.cn-item:hover > .cn-drop { display: block; }
.cn-drop a {
  display: block; padding: 10px 20px;
  font-size: 12.5px; color: var(--c-txt-m);
  transition: var(--c-tr); border-left: 3px solid transparent;
}
.cn-drop a:hover {
  background: var(--c-azul-c); color: var(--c-azul-m);
  border-left-color: var(--c-ouro); padding-left: 24px;
}

/* ============================================================
   MENU MOBILE
============================================================ */
.camara-mob {
  display: none; position: fixed; inset: 0; z-index: 500;
  background: rgba(8,27,74,.97);
  flex-direction: column; overflow-y: auto;
  padding: 20px 20px 48px;
}
.camara-mob.open { display: flex; }
.mob-close {
  align-self: flex-end; background: none; border: none;
  color: #fff; font-size: 28px; line-height: 1;
  margin-bottom: 16px; cursor: pointer;
}
.mob-h   { display: block; padding: 13px 0; border-bottom: 1px solid rgba(255,255,255,.1); font-size: 14px; font-weight: 700; color: rgba(255,255,255,.9); text-transform: uppercase; letter-spacing: .04em; }
.mob-sub { display: block; padding: 10px 0 10px 16px; border-bottom: 1px solid rgba(255,255,255,.06); font-size: 13px; font-weight: 500; color: rgba(255,255,255,.55); }

/* ============================================================
   HERO
============================================================ */
.camara-hero {
  background: linear-gradient(140deg,#0D2E6E 0%,#1249A4 55%,#1761C5 100%);
  padding: clamp(40px,6vw,76px) clamp(12px,3vw,40px);
  position: relative; overflow: hidden;
}
.ch-pat {
  position: absolute; inset: 0; opacity: .024; pointer-events: none;
  background-image: linear-gradient(45deg,#fff 1px,transparent 1px),linear-gradient(-45deg,#fff 1px,transparent 1px);
  background-size: 40px 40px;
}
.ch-glow {
  position: absolute; top: -100px; right: -100px;
  width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(circle,rgba(200,148,30,.13) 0%,transparent 70%);
  pointer-events: none;
}
.ch-inner {
  max-width: 1200px; margin: 0 auto; position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr minmax(280px,370px);
  gap: clamp(20px,4vw,52px); align-items: center;
}
.ch-badge {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(200,148,30,.18); border: 1.5px solid rgba(200,148,30,.4);
  border-radius: 20px; padding: 5px 14px;
  font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--c-ouro-v); margin-bottom: 16px;
}
.ch-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--c-ouro-v); animation: pd 1.8s infinite; }
@keyframes pd { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.7)} }
.ch-content h1 { font-family: var(--c-serif) !important; font-size: clamp(26px,4vw,46px) !important; font-weight: 700; color: #fff !important; line-height: 1.12; margin-bottom: 14px; }
.ch-content h1 em { font-style: normal; color: var(--c-ouro-v); }
.ch-desc { font-size: clamp(13.5px,1.6vw,15.5px); color: rgba(255,255,255,.7); line-height: 1.7; margin-bottom: 26px; max-width: 490px; }
.ch-ctas { display: flex; gap: 11px; flex-wrap: wrap; }
.btn-p {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--c-ouro); color: var(--c-azul);
  padding: 11px 22px; border-radius: var(--c-r);
  font-size: 13px; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase; transition: var(--c-tr); border: none;
  box-shadow: 0 4px 14px rgba(200,148,30,.4); cursor: pointer;
}
.btn-p:hover { background: var(--c-ouro-v); transform: translateY(-2px); box-shadow: 0 6px 18px rgba(200,148,30,.5); color: var(--c-azul); }
.btn-s {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(255,255,255,.1); color: #fff;
  padding: 11px 22px; border-radius: var(--c-r);
  border: 1.5px solid rgba(255,255,255,.25);
  font-size: 13px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .03em; transition: var(--c-tr); cursor: pointer;
}
.btn-s:hover { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.5); }
.ch-card {
  background: rgba(255,255,255,.07); border: 1.5px solid rgba(255,255,255,.15);
  border-radius: 16px; padding: clamp(14px,2.5vw,24px); backdrop-filter: blur(8px);
}
.ch-card-lbl { font-size: 10.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--c-ouro); margin-bottom: 14px; }
.ch-prox { background: rgba(200,148,30,.12); border: 1.5px solid rgba(200,148,30,.3); border-radius: 10px; padding: 13px 15px; margin-bottom: 12px; }
.ch-prox-tag  { font-size: 9.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--c-ouro-v); margin-bottom: 4px; }
.ch-prox-data { font-family: var(--c-serif); font-size: 18px; font-weight: 700; color: #fff; line-height: 1.2; }
.ch-prox-hora { font-size: 12px; color: rgba(255,255,255,.52); margin-top: 2px; }
.ch-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 7px; }
.ch-stat { text-align: center; padding: 11px 5px; background: rgba(255,255,255,.05); border-radius: 8px; }
.ch-stat-n { font-family: var(--c-serif); font-size: 25px; font-weight: 700; color: #fff; line-height: 1; }
.ch-stat-l { font-size: 9px; color: rgba(255,255,255,.43); text-transform: uppercase; letter-spacing: .07em; margin-top: 2px; font-weight: 600; }

/* ============================================================
   SEÇÕES GENÉRICAS
============================================================ */
.sec { padding: clamp(32px,5vw,52px) clamp(12px,3vw,40px); }
.sec-w { background: #fff; }
.sec-c { background: var(--c-cinza-bg); }
.sec-b { background: var(--c-azul); }
.sec-in { max-width: 1200px; margin: 0 auto; }
.sec-ey { font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--c-ouro); margin-bottom: 4px; }
.sec-ey-w { color: var(--c-ouro-v); }
.sec-ti { font-family: var(--c-serif) !important; font-size: clamp(19px,2.6vw,27px) !important; font-weight: 700; color: var(--c-txt); }
.sec-ti-w { color: #fff !important; }
.sec-hd { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 26px; gap: 12px; flex-wrap: wrap; }
.btn-lk {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12px; font-weight: 700; color: var(--c-azul-m);
  border: 1.5px solid var(--c-azul-c); border-radius: 7px;
  padding: 6px 14px; transition: var(--c-tr); white-space: nowrap;
}
.btn-lk:hover { background: var(--c-azul-c); color: var(--c-azul-m); }

/* Acesso Rápido */
.q-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 12px; }
.q-card {
  background: var(--c-cinza-bg); border: 1.5px solid var(--c-cinza-bd);
  border-radius: 12px; padding: 20px 10px 16px;
  text-align: center; display: flex; flex-direction: column;
  align-items: center; gap: 9px; transition: var(--c-tr);
  position: relative; overflow: hidden; cursor: pointer;
}
.q-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--c-ouro); transform: scaleX(0); transition: transform .22s; }
.q-card:hover { background: #fff; border-color: var(--c-azul-m); transform: translateY(-4px); box-shadow: var(--c-sh); }
.q-card:hover::after { transform: scaleX(1); }
.q-ic { width: 46px; height: 46px; border-radius: 11px; display: flex; align-items: center; justify-content: center; font-size: 20px; background: var(--c-azul-c); color: var(--c-azul-m); transition: var(--c-tr); }
.q-card:hover .q-ic { background: var(--c-azul); color: #fff; }
.q-lb { font-size: 11px; font-weight: 700; color: var(--c-txt-m); text-transform: uppercase; letter-spacing: .04em; line-height: 1.3; }

/* Notícias */
.n-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 22px; }
.n-dest { background: #fff; border: 1.5px solid var(--c-cinza-bd); border-radius: 14px; overflow: hidden; transition: var(--c-tr); }
.n-dest:hover { box-shadow: var(--c-sh); transform: translateY(-3px); }
.n-img { width: 100%; height: 195px; object-fit: cover; background: linear-gradient(135deg,var(--c-azul-c),#c5d5ef); display: flex; align-items: center; justify-content: center; font-size: 46px; overflow: hidden; }
.n-body { padding: 18px; }
.n-tag { display: inline-block; background: var(--c-azul-c); color: var(--c-azul-m); padding: 2px 9px; border-radius: 4px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 8px; }
.n-ti { font-family: var(--c-serif) !important; font-size: 16px !important; font-weight: 700; color: var(--c-txt); line-height: 1.35; margin-bottom: 7px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.n-meta { font-size: 11px; color: var(--c-txt-l); }
.n-list { display: flex; flex-direction: column; gap: 11px; }
.n-mini { background: #fff; border: 1.5px solid var(--c-cinza-bd); border-radius: 10px; padding: 13px 15px; display: flex; gap: 13px; align-items: flex-start; transition: var(--c-tr); }
.n-mini:hover { border-color: var(--c-azul-m); transform: translateX(3px); }
.n-date { flex-shrink: 0; width: 44px; height: 50px; background: var(--c-azul); border-radius: 8px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; text-align: center; }
.nd-d { font-family: var(--c-serif); font-size: 20px; font-weight: 700; line-height: 1; }
.nd-m { font-size: 8.5px; text-transform: uppercase; letter-spacing: .06em; opacity: .72; }
.n-mini-ti { font-size: 13px; font-weight: 600; color: var(--c-txt); line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* Sessões */
.s-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.s-card { background: #fff; border: 1.5px solid var(--c-cinza-bd); border-radius: 14px; overflow: hidden; transition: var(--c-tr); }
.s-card:hover { box-shadow: var(--c-sh); transform: translateY(-3px); }
.s-hd { background: var(--c-azul); padding: 13px 19px; display: flex; align-items: center; justify-content: space-between; }
.s-tipo { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--c-ouro); }
.s-badge { display: inline-flex; align-items: center; gap: 5px; background: rgba(200,148,30,.2); border: 1px solid rgba(200,148,30,.4); border-radius: 20px; padding: 3px 9px; font-size: 9.5px; font-weight: 700; color: var(--c-ouro-v); text-transform: uppercase; }
.s-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--c-ouro-v); }
.s-body { padding: 19px; }
.s-num { font-family: var(--c-serif); font-size: 42px; font-weight: 700; color: var(--c-azul); line-height: 1; }
.s-mes { font-size: 13px; font-weight: 600; color: var(--c-txt-l); text-transform: uppercase; letter-spacing: .08em; margin-top: 2px; }
.s-hora { display: inline-flex; align-items: center; gap: 6px; margin: 9px 0; font-size: 14.5px; font-weight: 600; color: var(--c-txt-m); }
.s-local { font-size: 12px; color: var(--c-txt-l); line-height: 1.5; margin-bottom: 14px; }
.s-btns { display: flex; gap: 7px; flex-wrap: wrap; }
.btn-sm { display: inline-flex; align-items: center; gap: 5px; padding: 7px 13px; border-radius: 7px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; transition: var(--c-tr); cursor: pointer; border: none; }
.btn-sm-a { background: var(--c-azul-c); color: var(--c-azul); }
.btn-sm-a:hover { background: var(--c-azul); color: #fff; }
.btn-sm-o { background: rgba(200,148,30,.12); color: var(--c-azul); border: 1px solid rgba(200,148,30,.3) !important; }
.btn-sm-o:hover { background: var(--c-ouro); color: var(--c-azul); }

/* Vereadores */
.v-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 18px; }
.v-card { border: 1.5px solid var(--c-cinza-bd); border-radius: 13px; overflow: hidden; background: var(--c-cinza-bg); transition: var(--c-tr); display: block; }
.v-card:hover { box-shadow: 0 8px 24px rgba(13,46,110,.12); transform: translateY(-4px); border-color: var(--c-azul-m); }
.v-foto { position: relative; width: 100%; height: 240px; overflow: hidden; background: linear-gradient(180deg,#e8f0fb,#c5d5ef); }
.v-foto img { width: 100% !important; height: 240px !important; object-fit: cover !important; object-position: top center !important; display: block !important; border-radius: 0 !important; margin: 0 !important; padding: 0 !important; }
.v-card:hover .v-foto img { transform: scale(1.05); }
.v-par { position: absolute; top: 8px; right: 8px; background: var(--c-azul); color: var(--c-ouro); font-size: 9px; font-weight: 700; padding: 3px 7px; border-radius: 5px; letter-spacing: .05em; }
.v-info { padding: 11px 13px 13px; }
.v-nome { font-family: var(--c-serif) !important; font-size: 13.5px !important; font-weight: 700; color: var(--c-txt); line-height: 1.25; margin-bottom: 3px; }
.v-cargo { font-size: 10.5px; color: var(--c-txt-l); text-transform: uppercase; letter-spacing: .07em; font-weight: 600; }

/* Documentos */
.d-tabs { display: flex; gap: 4px; background: #fff; border: 1.5px solid var(--c-cinza-bd); border-radius: 10px; padding: 5px; margin-bottom: 22px; flex-wrap: wrap; }
.d-tab { padding: 7px 15px; border-radius: 7px; font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--c-txt-l); cursor: pointer; border: none; background: none; transition: var(--c-tr); }
.d-tab.on { background: var(--c-azul); color: #fff; }
.d-tab:hover:not(.on) { background: var(--c-azul-c); color: var(--c-azul-m); }
.d-list { display: flex; flex-direction: column; gap: 9px; }
.d-row { background: #fff; border: 1.5px solid var(--c-cinza-bd); border-radius: 10px; padding: 13px 17px; display: flex; align-items: center; gap: 13px; transition: var(--c-tr); cursor: pointer; }
.d-row:hover { border-color: var(--c-azul-m); box-shadow: 0 3px 14px rgba(13,46,110,.07); transform: translateX(3px); }
.d-ic { width: 38px; height: 38px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 10.5px; font-weight: 700; flex-shrink: 0; }
.d-info { flex: 1; min-width: 0; }
.d-nome { font-size: 13px; font-weight: 600; color: var(--c-txt); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.d-meta { display: flex; gap: 11px; font-size: 10.5px; color: var(--c-txt-l); flex-wrap: wrap; }
.d-tp { display: inline-block; padding: 1.5px 7px; border-radius: 4px; font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.d-acts { display: flex; gap: 5px; flex-shrink: 0; opacity: 1 !important; visibility: visible !important; }
.btn-ico { width: 32px; height: 32px; border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: 13px; transition: var(--c-tr); cursor: pointer; border: none; opacity: 1 !important; visibility: visible !important; }
.btn-ico-v { background: var(--c-azul-c); color: var(--c-azul-m); }
.btn-ico-v:hover { background: var(--c-azul); color: #fff; }
.btn-ico-d { background: #e8f5e9; color: #2e7d32; }
.btn-ico-d:hover { background: #2e7d32; color: #fff; }

/* Transparência */
.t-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 15px; }
.t-card { background: rgba(255,255,255,.07); border: 1.5px solid rgba(255,255,255,.13); border-radius: 12px; padding: 20px 18px; display: flex; flex-direction: column; gap: 9px; transition: var(--c-tr); position: relative; overflow: hidden; }
.t-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--c-ouro); transform: scaleX(0); transition: transform .22s; transform-origin: left; }
.t-card:hover { background: rgba(255,255,255,.13); border-color: rgba(200,148,30,.35); transform: translateY(-3px); }
.t-card:hover::after { transform: scaleX(1); }
.t-ic { font-size: 26px; width: 50px; height: 50px; border-radius: 12px; background: rgba(200,148,30,.15); border: 1px solid rgba(200,148,30,.25); display: flex; align-items: center; justify-content: center; }
.t-lbl { font-size: 14px; font-weight: 700; color: #fff; line-height: 1.3; }
.t-desc { font-size: 11.5px; color: rgba(255,255,255,.46); line-height: 1.5; }
.t-lk { font-size: 9.5px; color: var(--c-ouro); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }

/* ============================================================
   MODAIS
============================================================ */
.camara-modal { display: none; position: fixed; inset: 0; z-index: 9999; background: rgba(5,15,40,.88); align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(4px); }
.camara-modal.open { display: flex; }
.cm-box { background: #0D2E6E; border: 1.5px solid rgba(200,148,30,.35); border-radius: 16px; width: 100%; max-width: 960px; overflow: hidden; box-shadow: 0 24px 80px rgba(0,0,0,.7); animation: cmOpen .3s ease; }
.cm-box-pdf { background: #1a2340; max-width: 880px; }
@keyframes cmOpen { from{opacity:0;transform:translateY(20px) scale(.97)} to{opacity:1;transform:none} }
.cm-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 22px; border-bottom: 1px solid rgba(200,148,30,.25); background: rgba(255,255,255,.05); }
.cm-titulo { font-family: var(--c-serif); font-size: 15px; font-weight: 700; color: #fff; }
.cm-fechar { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); border-radius: 7px; color: #fff; font-size: 20px; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; transition: var(--c-tr); cursor: pointer; }
.cm-fechar:hover { background: rgba(255,255,255,.22); }
.yt-wrap { position: relative; width: 100%; padding-bottom: 56.25%; background: #000; }
.yt-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.pdf-view { width: 100%; height: 70vh; border: none; background: #2a3555; }
.cm-foot { display: flex; align-items: center; justify-content: space-between; padding: 12px 22px; background: rgba(255,255,255,.04); border-top: 1px solid rgba(255,255,255,.08); gap: 10px; flex-wrap: wrap; }
.cm-foot-info { font-size: 12px; color: rgba(255,255,255,.5); }

/* ============================================================
   FOOTER
============================================================ */
.site-footer, #colophon { display: none !important; }
.camara-footer { background: #081428; padding: clamp(32px,5vw,52px) clamp(12px,3vw,40px) 0; color: rgba(255,255,255,.58); }
.cf-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: clamp(20px,4vw,40px); padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,.08); }
.cf-brand { display: flex; flex-direction: column; gap: 13px; }
.cf-logo { display: flex; align-items: center; gap: 12px; }
.cf-logo img { height: 50px; width: 50px; object-fit: contain; opacity: 1; image-rendering: -webkit-optimize-contrast; image-rendering: crisp-edges; }
.cf-logo-nm { font-family: var(--c-serif); font-size: 14px; font-weight: 700; color: rgba(255,255,255,.85); line-height: 1.3; }
.cf-desc { font-size: 12px; line-height: 1.7; color: rgba(255,255,255,.38); }
.cf-cont { font-size: 12px; line-height: 2; color: rgba(255,255,255,.46); }
.cf-cont strong { color: rgba(255,255,255,.74); font-weight: 600; }
.cf-col h4 { font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--c-ouro); margin-bottom: 13px; }
.cf-col a { display: block; font-size: 12px; color: rgba(255,255,255,.43); margin-bottom: 7px; transition: color .2s; }
.cf-col a:hover { color: rgba(255,255,255,.9); }
.cf-bot { max-width: 1200px; margin: 0 auto; padding: 14px 0; display: flex; align-items: center; justify-content: space-between; font-size: 11px; color: rgba(255,255,255,.26); flex-wrap: wrap; gap: 8px; }
.cf-bot a { color: rgba(255,255,255,.32); }
.cf-bot a:hover { color: var(--c-ouro); }

/* ============================================================
   ALTO CONTRASTE
============================================================ */
body.alto-contraste { background: #000 !important; color: #fff !important; }
body.alto-contraste * { background-color: #000 !important; color: #fff !important; border-color: #ffd700 !important; }
body.alto-contraste h1,body.alto-contraste h2,body.alto-contraste h3,body.alto-contraste h4 { color: #ffd700 !important; }
body.alto-contraste a { color: #0ff !important; }
body.alto-contraste img { filter: grayscale(100%) contrast(110%) !important; }

/* ============================================================
   RESPONSIVIDADE
============================================================ */
@media (max-width:1024px){
  .q-grid { grid-template-columns: repeat(3,1fr); }
  .t-grid { grid-template-columns: repeat(2,1fr); }
  .v-grid { grid-template-columns: repeat(3,1fr); }
  .cf-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width:768px){
  .camara-navbar .cn-list { display: none; }
  .ch-ham { display: flex !important; margin-left: auto; }
  .camara-brand img { height: 50px; }
  .cb-name { font-size: 16px !important; }
  .cb-sub  { display: none; }
  .camara-search { display: none; }
  .ch-inner { grid-template-columns: 1fr; }
  .ch-card  { display: none; }
  .q-grid   { grid-template-columns: repeat(3,1fr); gap: 9px; }
  .n-grid   { grid-template-columns: 1fr; }
  .s-grid   { grid-template-columns: 1fr; }
  .v-grid   { grid-template-columns: repeat(2,1fr); }
  .t-grid   { grid-template-columns: 1fr 1fr; }
  .cf-grid  { grid-template-columns: 1fr; }
  .cu-left  { display: none; }
}
@media (max-width:480px){
  .q-grid { grid-template-columns: repeat(2,1fr); }
  .v-grid { grid-template-columns: repeat(2,1fr); }
  .t-grid { grid-template-columns: 1fr; }
}

/* ── OCULTAR FOOTER E CONTAINER VAZIO DO ASTRA ─────────────── */
.site-footer,
#colophon,
.ast-footer-overlay,
.footer-widget-area,
.ast-small-footer,
.ast-small-footer-wrap,
.ast-footer-widget-area,
footer.site-footer,
.hfb-footer { display: none !important; }

/* Largura total — remover container do Astra */
.ast-container,
#content .ast-container,
.site-content,
#content,
.entry-content p,
.ast-article-post,
.ast-page-builder-template .entry-content,
.page-template-default .entry-content,
.single-page .entry-content { 
  max-width: 100% !important; 
  padding-left: 0 !important; 
  padding-right: 0 !important; 
  margin-left: 0 !important; 
  margin-right: 0 !important; 
  width: 100% !important;
}


/* ── REMOVE FOOTER DUPLICADO SEM CLASSE (Elementor legado) ── */
body > footer:not(.camara-footer),
.elementor-section footer:not(.camara-footer),
footer[style*="background"]:not(.camara-footer) { 
  display: none !important; 
}
/* ================================================================
   CORREÇÕES GLOBAIS — replicam o CSS inline da home para todas
   as páginas. A home tinha isso no bloco HTML, agora fica global.
   ================================================================ */

/* 1. Torna entry-content, container Astra full-width */
.ast-container,
.entry-content,
.ast-article-single,
.ast-article-post,
.ast-page-builder-template,
.ast-page-builder-template .entry-content {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}

/* 2. Remove padding do site-content */
.site-content,
.ast-single-post .site-content,
.ast-page-builder-template .site-content {
  padding: 0 !important;
}

/* 3. Esconde título da página (entry-header) em todas as páginas */
.entry-header,
.ast-entry-header,
.ast-page-header-wrap,
.page-header {
  display: none !important;
}

/* 4. Esconde breadcrumb do Astra */
.ast-breadcrumbs-wrapper,
.ast-breadcrumbs {
  display: none !important;
}

/* 5. Remove padding do #content */
#content {
  padding: 0 !important;
}

/* 6. Esconde sidebar e força #primary full-width */
#secondary,
.secondary,
.ast-secondary-sidebar,
.widget-area {
  display: none !important;
}
#primary.content-area,
#primary {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 7. Remove meta (data, autor) de páginas */
.entry-meta,
.ast-post-meta,
.posted-on,
.byline {
  display: none !important;
}

/* ================================================================
   CSS GLOBAL — migrado do bloco inline da home page
   Antes ficava só na home. Agora aplica em TODAS as páginas.
   Qualquer nova página criada herda automaticamente esses estilos.
   ================================================================ */

/* Navbar — botões quadrados sem arredondamento (padrão do projeto) */
.camara-navbar .cn-link,
.camara-navbar button.cn-link {
  border-radius: 0 !important;
  background: none !important;
  box-shadow: none !important;
}

/* Botões de documento (VER / BAIXAR) */
.doc-btn-ver,
.doc-btn-baixar {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 32px;
  padding: 0 12px;
  border-radius: 7px;
  font-size: 11px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  font-family: Inter, sans-serif;
  letter-spacing: .03em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  opacity: 1 !important;
  visibility: visible !important;
}
.doc-btn-ver            { background: #EBF2FD; color: #1249A4; }
.doc-btn-ver:hover      { background: #1249A4; color: #fff; }
.doc-btn-baixar         { background: #e8f5e9; color: #2e7d32; }
.doc-btn-baixar:hover   { background: #2e7d32; color: #fff; }
.doc-item               { opacity: 1 !important; visibility: visible !important; }
.doc-acoes              { display: flex; gap: 6px; flex-shrink: 0; opacity: 1 !important; }

/* ================================================================
   CORREÇÕES CONV08 — Heroes das páginas internas
   ================================================================ */

/* FIX 1 — h1/h2/h3 brancos nos heroes das páginas novas
   O Astra define color no h1 sem !important mas com alta especificidade.
   Forçamos branco em qualquer hero com fundo azul do projeto. */
.sic-hero h1,
.ouv-hero h1,
.faq-hero h1,
.cs-hero h1,
.lg-hero h1,
.mp-hero h1,
.fc-hero h1 {
  color: #fff !important;
  font-family: 'Noto Serif', Georgia, serif !important;
}

/* FIX 2 — Badge PNTP: vira tooltip discreto ao hover
   Remove o destaque visual permanente e mostra só ao passar o mouse. */
.sic-badge,
.ouv-badge,
.faq-badge,
.cs-badge,
.lg-badge,
.mp-badge,
.fc-badge {
  /* Estado padrão: quase invisível, texto transparente */
  background: rgba(200,148,30,.06) !important;
  border-color: rgba(200,148,30,.15) !important;
  color: transparent !important;
  cursor: default;
  user-select: none;
  transition: background .25s, border-color .25s, color .25s, opacity .25s;
  position: relative;
}
/* Ao hover: aparece suave */
.sic-hero:hover .sic-badge,
.ouv-hero:hover .ouv-badge,
.faq-hero:hover .faq-badge,
.cs-hero:hover .cs-badge,
.lg-hero:hover .lg-badge,
.mp-hero:hover .mp-badge,
.fc-hero:hover .fc-badge {
  background: rgba(200,148,30,.18) !important;
  border-color: rgba(200,148,30,.4) !important;
  color: #F0B429 !important;
}

/* FIX 3 — Home: corrige deslocamento lateral causado por margin:0 global
   O reset zera margin:0 no .entry-content, mas os containers internos
   da home usam margin:0 auto para centralizar. Garantimos que #camara-main
   e seus filhos diretos com max-width possam centralizar normalmente. */
#camara-main {
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100% !important;
}
#camara-main > section > div[style*="max-width"] {
  margin-left: auto;
  margin-right: auto;
}