/*
Theme Name: Câmara Estrela d'Alva
Theme URI: https://estreladalva.mg.leg.br
Author: Valmy Gomes
Description: Tema institucional para Câmaras Municipais, com layout no padrão portal legislativo (topbar, menu com dropdowns, slider de notícias, carrossel de vereadores, TV Câmara, galeria, banners de transparência e rodapé mega-menu). Totalmente personalizável pelo Customizer: cores, logo, links, redes sociais, banners e vídeo.
Version: 1.0.0
Requires at least: 5.8
Requires PHP: 7.2
License: GPL-3.0-or-later
Text Domain: camara-ed
*/

/* ==========================================================
   Variáveis (sobrescritas pelo Customizer via inline style)
   ========================================================== */
:root{
  --c-primaria:#123a6d;      /* azul escuro institucional */
  --c-secundaria:#1d5aa0;    /* azul médio */
  --c-destaque:#d9a52a;      /* dourado do brasão */
  --c-fundo:#f4f6f9;
  --c-texto:#2b3440;
  --c-branco:#ffffff;
  --c-borda:#dde4ee;
  --sombra:0 2px 10px rgba(18,58,109,.10);
  --raio:6px;
  --fonte:'Segoe UI',Roboto,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{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(--fonte);color:var(--c-texto);background:var(--c-fundo);font-size:1rem;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-secundaria);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 16px}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--c-destaque);color:#222;padding:8px 16px;z-index:9999}
.skip-link:focus{left:8px;top:8px}
a:focus-visible,button:focus-visible{outline:3px solid var(--c-destaque);outline-offset:2px}

/* ============ BARRA DE ACESSIBILIDADE ============ */
.acess-bar{display:flex;align-items:center;gap:4px;list-style:none}
.acess-bar button{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;cursor:pointer;font-size:.8125rem;font-weight:700;min-width:30px;height:26px;border-radius:4px;padding:0 6px;font-family:var(--fonte)}
.acess-bar button:hover{background:var(--c-destaque);color:#222;border-color:var(--c-destaque)}
.acess-bar button[aria-pressed="true"]{background:var(--c-destaque);color:#222;border-color:var(--c-destaque)}
.acess-bar .sep{width:1px;height:18px;background:rgba(255,255,255,.3);margin:0 4px}

/* ============ ALTO CONTRASTE ============ */
body.alto-contraste,
body.alto-contraste *:not(img):not(svg):not(path):not(iframe):not(video){background:#000!important;background-image:none!important;color:#fff!important;border-color:#fff!important;box-shadow:none!important;text-shadow:none!important}
body.alto-contraste a:not(.skip-link),body.alto-contraste a:not(.skip-link) *:not(svg):not(path){color:#ff0!important}
body.alto-contraste a:hover,body.alto-contraste a:focus{text-decoration:underline!important}
body.alto-contraste button{color:#ff0!important;border:1px solid #ff0!important}
body.alto-contraste svg{fill:#ff0!important}
body.alto-contraste .news-caption{background:rgba(0,0,0,.85)!important}
body.alto-contraste img{filter:grayscale(40%) contrast(120%)}
body.alto-contraste a:focus-visible,body.alto-contraste button:focus-visible{outline:3px solid #ff0!important}

/* ============ TOPBAR ============ */
.topbar{background:var(--c-primaria);color:#fff;font-size:0.8125rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;min-height:38px;flex-wrap:wrap}
.topbar-social{display:flex;gap:2px;list-style:none}
.topbar-social a{display:flex;align-items:center;justify-content:center;width:32px;height:38px;color:#fff;opacity:.85}
.topbar-social a:hover{opacity:1;background:rgba(255,255,255,.12);text-decoration:none}
.topbar-social svg{width:16px;height:16px;fill:currentColor}
.topbar-menu{display:flex;list-style:none;align-items:stretch}
.topbar-menu>li{position:relative}
.topbar-menu>li>a{display:flex;align-items:center;height:38px;padding:0 12px;color:#fff}
.topbar-menu>li>a:hover{background:rgba(255,255,255,.12);text-decoration:none}
.topbar-menu .sub-menu{display:none;position:absolute;right:0;top:100%;background:#fff;min-width:220px;box-shadow:var(--sombra);list-style:none;z-index:1000;border-radius:0 0 var(--raio) var(--raio);overflow:hidden}
.topbar-menu li:hover>.sub-menu,.topbar-menu li:focus-within>.sub-menu{display:block}
.topbar-menu .sub-menu a{display:block;padding:9px 14px;color:var(--c-texto);font-size:0.8125rem}
.topbar-menu .sub-menu a:hover{background:var(--c-fundo);text-decoration:none}
.topbar-search{display:flex}
.topbar-search input[type=search]{border:0;padding:6px 10px;font-size:0.8125rem;width:160px;border-radius:var(--raio) 0 0 var(--raio)}
.topbar-search button{border:0;background:var(--c-destaque);color:#222;padding:0 12px;cursor:pointer;border-radius:0 var(--raio) var(--raio) 0;font-weight:600}

/* ============ HEADER ============ */
.site-header{background:linear-gradient(135deg,var(--c-primaria) 0%,var(--c-secundaria) 100%);color:#fff;padding:18px 0}
.site-header .container{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.site-branding{display:flex;align-items:center;gap:14px}
.site-branding img{height:74px;width:auto}
.site-title{font-size:1.625rem;font-weight:700;line-height:1.15;letter-spacing:.3px}
.site-title a{color:#fff}
.site-title a:hover{text-decoration:none}
.site-desc{font-size:0.875rem;opacity:.9;font-weight:400}
.header-right{margin-left:auto;text-align:right;font-size:0.875rem}
.header-right .fone{font-size:1.125rem;font-weight:700}

/* ============ MENU PRINCIPAL ============ */
.main-nav{background:var(--c-branco);box-shadow:var(--sombra);position:relative;z-index:900}
.main-nav .container{display:flex;align-items:center}
.menu-toggle{display:none;background:var(--c-primaria);color:#fff;border:0;padding:10px 16px;margin:8px 0;cursor:pointer;border-radius:var(--raio);font-size:0.9375rem}
.nav-menu{display:flex;list-style:none;flex-wrap:wrap}
.nav-menu>li{position:relative}
.nav-menu .sub-menu li{position:relative}
.nav-menu>li>a{display:flex;align-items:center;padding:16px 16px;color:var(--c-primaria);font-weight:600;font-size:0.9375rem;border-bottom:3px solid transparent}
.nav-menu>li>a:hover,.nav-menu>li.current-menu-item>a{border-bottom-color:var(--c-destaque);text-decoration:none;background:var(--c-fundo)}
.nav-menu .menu-item-has-children>a::after{content:"▾";font-size:0.6875rem;margin-left:6px;opacity:.6}
.nav-menu .sub-menu .menu-item-has-children>a{display:flex;justify-content:space-between;align-items:center;gap:8px}
.nav-menu .sub-menu .menu-item-has-children>a::after{content:"▸";margin-left:auto}
.nav-menu .sub-menu{display:none;position:absolute;left:0;top:100%;background:#fff;min-width:260px;box-shadow:var(--sombra);list-style:none;z-index:1000;border-top:3px solid var(--c-destaque);border-radius:0 0 var(--raio) var(--raio)}
.nav-menu li:hover>.sub-menu,.nav-menu li:focus-within>.sub-menu{display:block}
.nav-menu .sub-menu a{display:block;padding:10px 16px;color:var(--c-texto);font-size:0.875rem;border-bottom:1px solid var(--c-borda)}
.nav-menu .sub-menu li:last-child a{border-bottom:0}
.nav-menu .sub-menu a:hover{background:var(--c-fundo);color:var(--c-primaria);text-decoration:none}
.nav-menu .sub-menu .sub-menu{left:100%;top:-3px;border-top:3px solid var(--c-destaque);border-radius:0 var(--raio) var(--raio) var(--raio)} /* ancorado ao item pai; -3px compensa a borda */

/* ============ HERO: NOTÍCIAS + AÇÕES ============ */
.hero{padding:28px 0}
.hero .container{display:grid;grid-template-columns:2fr 1fr;gap:20px}
.news-slider{position:relative;border-radius:var(--raio);overflow:hidden;box-shadow:var(--sombra);background:#fff;min-height:380px}
.news-slide{display:none;position:relative;height:380px}
.news-slide.ativo{display:block}
.news-slide img,.news-slide .sem-foto{width:100%;height:100%;object-fit:cover}
.news-slide .sem-foto{background:linear-gradient(135deg,var(--c-secundaria),var(--c-primaria));display:flex;align-items:center;justify-content:center}
.news-slide .sem-foto svg{width:90px;height:90px;opacity:.35}
.news-caption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(10,25,50,.92));color:#fff;padding:60px 22px 20px}
.news-caption h2{font-size:1.3125rem;line-height:1.3}
.news-caption a{color:#fff}
.news-caption .data{font-size:0.8125rem;color:var(--c-destaque);font-weight:600;display:block;margin-bottom:4px}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);color:#fff;border:0;width:40px;height:40px;font-size:1.25rem;cursor:pointer;z-index:5;border-radius:50%}
.slider-nav:hover{background:var(--c-destaque);color:#222}
.slider-prev{left:12px}.slider-next{right:12px}
.slider-dots{position:absolute;bottom:8px;right:14px;display:flex;gap:6px;z-index:5}
.slider-dots button{width:11px;height:11px;border-radius:50%;border:2px solid #fff;background:transparent;cursor:pointer;padding:0}
.slider-dots button.ativo{background:var(--c-destaque);border-color:var(--c-destaque)}
.hero-acoes{display:flex;flex-direction:column;gap:14px}
.acao-card{flex:1;display:flex;align-items:center;gap:16px;background:#fff;border-radius:var(--raio);box-shadow:var(--sombra);padding:20px 22px;color:var(--c-primaria);font-weight:700;font-size:1.1875rem;border-left:5px solid var(--c-destaque);transition:transform .15s}
.acao-card:hover{transform:translateX(4px);text-decoration:none;background:var(--c-primaria);color:#fff}
.acao-card svg{width:38px;height:38px;fill:currentColor;flex-shrink:0}
.acao-card .acao-img{width:38px;height:38px;object-fit:contain;flex-shrink:0;border-radius:4px}

/* ============ TÍTULOS DE SEÇÃO ============ */
.sec-titulo{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.sec-titulo h2{font-size:1.625rem;color:var(--c-primaria);font-weight:700;white-space:nowrap}
.sec-titulo::after{content:"";flex:1;height:3px;background:linear-gradient(90deg,var(--c-destaque),transparent);order:2}
.sec-titulo .ver-todos{font-size:0.875rem;font-weight:600;background:var(--c-primaria);color:#fff;padding:7px 16px;border-radius:var(--raio);white-space:nowrap;order:3}
.sec-titulo .ver-todos:hover{background:var(--c-destaque);color:#222;text-decoration:none}

/* ============ VEREADORES ============ */
.vereadores{padding:30px 0;background:#fff}
.ver-carrossel{position:relative;overflow:hidden}
.ver-trilho{display:flex;gap:18px;transition:transform .4s ease}
.ver-card{flex:0 0 calc(20% - 15px);background:var(--c-fundo);border:1px solid var(--c-borda);border-radius:var(--raio);overflow:hidden;text-align:center}
.ver-card img,.ver-card .ver-foto-ph{width:100%;aspect-ratio:3/3.4;object-fit:cover;object-position:top}
.ver-foto-ph{background:linear-gradient(160deg,var(--c-borda),#c7d3e6);display:flex;align-items:center;justify-content:center}
.ver-foto-ph svg{width:64px;height:64px;fill:var(--c-secundaria);opacity:.5}
.ver-card .ver-info{padding:12px 8px}
.ver-card h3{font-size:0.9375rem;color:var(--c-primaria)}
.ver-card .partido{font-size:0.7812rem;color:#5b6b80;font-weight:600}
.ver-setas{position:absolute;top:38%;width:100%;display:flex;justify-content:space-between;pointer-events:none}
.ver-setas button{pointer-events:auto;background:var(--c-primaria);color:#fff;border:0;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1.125rem;box-shadow:var(--sombra)}
.ver-setas button:hover{background:var(--c-destaque);color:#222}

/* Overlay de biografia ao passar o mouse */
.ver-card{position:relative}
.ver-bio{position:absolute;inset:0;background:linear-gradient(170deg,rgba(13,32,60,.96),rgba(18,58,109,.96));color:#fff;opacity:0;visibility:hidden;transition:opacity .2s ease;padding:16px 14px;display:flex;flex-direction:column;justify-content:center;gap:6px;text-align:left;font-size:.8125rem;line-height:1.45}
.ver-card:hover .ver-bio,.ver-card:focus .ver-bio,.ver-card:focus-within .ver-bio{opacity:1;visibility:visible}
.ver-bio strong{font-size:.9375rem;color:#fff}
.ver-bio .ver-bio-meta{color:var(--c-destaque);font-weight:700;font-size:.75rem}
.ver-bio p{margin:0;overflow:hidden}
.ver-bio .ver-bio-mais{margin-top:4px;font-weight:700;color:var(--c-destaque);font-size:.75rem}
@media (hover:none){.ver-bio{display:none}} /* em telas de toque, a bio fica na página do vereador */

/* Grade: todos os vereadores de uma vez, sem rolagem */
.ver-grade{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:18px}
.ver-grade .ver-card{flex:none}
@media(max-width:768px){.ver-grade{grid-template-columns:repeat(2,1fr);gap:12px}}

/* Bio em destaque na página individual */
.bio-destaque{background:var(--c-fundo);border-left:4px solid var(--c-destaque);padding:14px 18px;border-radius:var(--raio);margin-bottom:18px}
.bio-destaque p:last-child{margin-bottom:0}

/* ============ TV CÂMARA ============ */
.tv-camara{padding:34px 0;background:var(--c-primaria);color:#fff}
.tv-camara .container{display:grid;grid-template-columns:1fr 1.4fr;gap:26px;align-items:center}
.tv-info h2{font-size:1.875rem;margin-bottom:10px}
.tv-info h2 span{color:var(--c-destaque)}
.tv-info p{opacity:.9;margin-bottom:18px}
.btn-assistir{display:inline-flex;align-items:center;gap:10px;background:var(--c-destaque);color:#222;font-weight:700;padding:12px 26px;border-radius:var(--raio);font-size:1rem}
.btn-assistir:hover{background:#fff;text-decoration:none}
.btn-assistir svg{width:20px;height:20px;fill:currentColor}
.tv-video{position:relative;padding-bottom:56.25%;height:0;border-radius:var(--raio);overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.35)}
.tv-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ============ GALERIA ============ */
.galeria{padding:30px 0}
.galeria-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.galeria-grid a{display:block;border-radius:var(--raio);overflow:hidden;box-shadow:var(--sombra)}
.galeria-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .25s}
.galeria-grid a:hover img{transform:scale(1.06)}

/* ============ BOTÕES RÁPIDOS + CARDS ============ */
.acessos{padding:10px 0 30px}
.botoes-rapidos{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:22px}
.botao-rapido{background:var(--c-secundaria);color:#fff;text-align:center;font-weight:700;padding:16px;border-radius:var(--raio);font-size:1.0625rem;box-shadow:var(--sombra)}
.botao-rapido:hover{background:var(--c-destaque);color:#222;text-decoration:none}
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.card-acesso{background:#fff;border-radius:var(--raio);box-shadow:var(--sombra);padding:22px 18px;border-top:4px solid var(--c-destaque);color:var(--c-texto)}
.card-acesso:hover{text-decoration:none;transform:translateY(-3px);transition:transform .15s}
.card-acesso h3{color:var(--c-primaria);font-size:1.125rem;margin-bottom:6px}
.card-acesso p{font-size:0.8438rem;color:#5b6b80}
.card-acesso svg{width:34px;height:34px;fill:var(--c-secundaria);margin-bottom:10px}

/* ============ BANNERS ============ */
.banners{padding:0 0 36px}
.banners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.banners-grid a{display:block;border-radius:var(--raio);overflow:hidden;box-shadow:var(--sombra)}
.banners-grid img{width:100%}

/* ============ RODAPÉ ============ */
.site-footer{background:var(--c-primaria);color:#fff;padding-top:40px;font-size:0.875rem}
.footer-menus{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.15)}
.footer-col h3{font-size:0.9375rem;color:var(--c-destaque);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:0.875rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:7px}
.footer-col a{color:rgba(255,255,255,.85)}
.footer-col a:hover{color:var(--c-destaque)}
.footer-info{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;padding:28px 0}
.footer-info h3{font-size:0.9375rem;color:var(--c-destaque);margin-bottom:10px;text-transform:uppercase}
.footer-info ul{list-style:none}
.footer-info li{margin-bottom:6px}
.footer-info a{color:rgba(255,255,255,.85)}
.newsletter-form{display:flex;margin-top:10px}
.newsletter-form input[type=email]{flex:1;border:0;padding:10px 12px;border-radius:var(--raio) 0 0 var(--raio);font-size:0.875rem}
.newsletter-form button{border:0;background:var(--c-destaque);color:#222;font-weight:700;padding:0 18px;cursor:pointer;border-radius:0 var(--raio) var(--raio) 0}
.copy-bar{background:rgba(0,0,0,.25);padding:14px 0;font-size:0.8125rem}
.copy-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.copy-bar a{color:var(--c-destaque)}

/* ============ CONTEÚDO INTERNO ============ */
.conteudo{padding:34px 0}
.conteudo-box{background:#fff;border-radius:var(--raio);box-shadow:var(--sombra);padding:30px}
.conteudo-box h1{color:var(--c-primaria);margin-bottom:18px;border-bottom:3px solid var(--c-destaque);padding-bottom:10px;font-size:1.75rem}
.conteudo-box h2,.conteudo-box h3{color:var(--c-primaria);margin:20px 0 10px}
.conteudo-box p,.conteudo-box ul,.conteudo-box ol{margin-bottom:14px}
.conteudo-box ul,.conteudo-box ol{padding-left:24px}
.breadcrumb{font-size:0.8125rem;color:#5b6b80;margin-bottom:16px}
.breadcrumb a{color:var(--c-secundaria)}
.post-meta{font-size:0.8125rem;color:#5b6b80;margin-bottom:16px}
.lista-posts article{background:#fff;border-radius:var(--raio);box-shadow:var(--sombra);padding:22px;margin-bottom:16px}
.lista-posts h2{font-size:1.25rem}
.lista-posts h2 a{color:var(--c-primaria)}
.paginacao{display:flex;gap:8px;justify-content:center;margin-top:20px}
.paginacao .page-numbers{background:#fff;padding:8px 14px;border-radius:var(--raio);box-shadow:var(--sombra);color:var(--c-primaria)}
.paginacao .current{background:var(--c-primaria);color:#fff}

/* ============ RESPONSIVO ============ */
@media(max-width:992px){
  .hero .container{grid-template-columns:1fr}
  .hero-acoes{flex-direction:row}
  .ver-card{flex:0 0 calc(33.33% - 12px)}
  .tv-camara .container{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .galeria-grid{grid-template-columns:repeat(3,1fr)}
  .galeria-grid a:nth-child(n+4){display:none}
  .footer-info{grid-template-columns:1fr}
}
@media(max-width:768px){
  .menu-toggle{display:block}
  .nav-menu{display:none;flex-direction:column;width:100%;padding-bottom:10px}
  .nav-menu.aberto{display:flex}
  .nav-menu>li>a{padding:12px 8px;border-bottom:1px solid var(--c-borda)}
  .nav-menu .sub-menu{position:static;display:none;box-shadow:none;border-top:0;background:var(--c-fundo)}
  .nav-menu li.sub-aberto>.sub-menu{display:block}
  .main-nav .container{flex-direction:column;align-items:stretch}
  .topbar .container{justify-content:center}
  .topbar-menu{display:none}
  .hero-acoes{flex-direction:column}
  .botoes-rapidos,.banners-grid{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .ver-card{flex:0 0 calc(50% - 9px)}
  .site-header .container{justify-content:center;text-align:center}
  .header-right{margin:0 auto;text-align:center}
  .news-slide,.news-slider{min-height:300px;height:300px}
}
