/* =====================================================================
   Pesquisa de Satisfação — Câmara Municipal de Novo Horizonte do Oeste – RO
   Identidade institucional: azul, branco e dourado.
   ===================================================================== */
:root{
  --azul:#1c4e80;
  --azul-escuro:#143a60;
  --azul-claro:#e8eef5;
  --dourado:#d4af37;
  --dourado-escuro:#b8941f;
  --branco:#ffffff;
  --cinza:#f4f6f9;
  --cinza-borda:#d8dee6;
  --texto:#222b36;
  --texto-suave:#5a6675;
  --verde:#2e7d32;
  --vermelho:#c62828;
  --sombra:0 2px 10px rgba(20,58,96,.10);
  --raio:12px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--cinza);
  color:var(--texto);
  line-height:1.55;
}

/* Acessibilidade --------------------------------------------------- */
.skip-link{
  position:absolute;left:-999px;top:0;background:var(--dourado);color:#000;
  padding:10px 16px;z-index:1000;border-radius:0 0 8px 0;font-weight:bold;
}
.skip-link:focus{left:0;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}
:focus-visible{outline:3px solid var(--dourado);outline-offset:2px;}

/* Layout ----------------------------------------------------------- */
.container{max-width:920px;margin:0 auto;padding:0 16px;}

/* Cabeçalho público ----------------------------------------------- */
.cabecalho{background:linear-gradient(135deg,var(--azul),var(--azul-escuro));color:#fff;border-bottom:4px solid var(--dourado);}
.cabecalho-conteudo{display:flex;align-items:center;gap:12px;padding:8px 16px;flex-wrap:wrap;}
.brasao{
  width:40px;height:40px;border-radius:50%;background:var(--dourado);color:var(--azul-escuro);
  display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:16px;flex:0 0 auto;
  border:2px solid #fff;
}
.brasao.pequeno{width:32px;height:32px;font-size:12px;}
.logo-img{height:40px;width:auto;max-width:200px;display:block;flex:0 0 auto;background:#fff;padding:2px 5px;border-radius:8px;border:2px solid #fff;}
.logo-img.pequeno{height:32px;max-width:150px;}
.login-cabecalho .logo-img{margin:0 auto 10px;}
.banner-link{display:block;}
.banner-img{display:block;width:100%;height:auto;border-radius:12px;margin:18px 0 6px;box-shadow:var(--sombra);transition:transform .2s,box-shadow .2s;}
.banner-link:hover .banner-img{transform:translateY(-3px);box-shadow:0 8px 22px rgba(20,58,96,.28);}
.cabecalho-texto{display:flex;flex-direction:column;line-height:1.2;}
.cabecalho-titulo{font-weight:700;font-size:1.15rem;}
.cabecalho-sub{font-size:.85rem;opacity:.9;}
.cabecalho .btn-voltar{margin-left:auto;}

/* Botões ----------------------------------------------------------- */
.btn{
  display:inline-block;padding:11px 20px;border-radius:8px;font-weight:600;text-decoration:none;
  border:2px solid transparent;cursor:pointer;font-size:1rem;line-height:1.2;transition:.15s;margin:4px 4px 4px 0;
}
.btn-primario{background:var(--azul);color:#fff;}
.btn-primario:hover{background:var(--azul-escuro);}
.btn-secundario{background:#fff;color:var(--azul);border-color:var(--azul);}
.btn-secundario:hover{background:var(--azul-claro);}
.btn-voltar{background:var(--dourado);color:var(--azul-escuro);border-color:var(--dourado-escuro);}
.btn-voltar:hover{background:var(--dourado-escuro);color:#fff;}
.btn-perigo{background:var(--vermelho);color:#fff;}
.btn-perigo:hover{filter:brightness(.9);}
.btn-grande{padding:14px 28px;font-size:1.08rem;}
.btn-pequeno{padding:6px 12px;font-size:.85rem;}

/* Cartões ---------------------------------------------------------- */
.cartao{background:#fff;border:1px solid var(--cinza-borda);border-radius:var(--raio);padding:22px;margin:18px 0;box-shadow:var(--sombra);}
.cartao h1,.cartao h2{color:var(--azul);margin-top:0;}
.destaque{border-top:4px solid var(--dourado);}
.centralizado{text-align:center;}
main h1.titulo-pagina{color:var(--azul);margin:24px 0 6px;}
.intro{color:var(--texto-suave);font-size:1.02rem;}
.dica{color:var(--texto-suave);font-size:.92rem;}
.aviso{color:var(--vermelho);font-weight:600;}

/* Formulário ------------------------------------------------------- */
.formulario{display:block;}
fieldset.cartao{border:1px solid var(--cinza-borda);}
legend{font-weight:700;color:var(--azul);padding:0 6px;font-size:1.05rem;}
.pergunta legend .num{color:var(--dourado-escuro);}
.obrig{color:var(--vermelho);}
.opcao{display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:8px;cursor:pointer;}
.opcao:hover{background:var(--azul-claro);}
.opcao input{width:20px;height:20px;accent-color:var(--azul);flex:0 0 auto;}
.bloco-lgpd{border-left:5px solid var(--dourado);background:#fffdf5;}
.aviso-lgpd{color:var(--vermelho);font-weight:600;}
.campo{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.campo > span{font-weight:600;color:var(--texto);}
.campo input,.campo select,.campo textarea,.campo-texto{
  padding:11px 12px;border:1px solid var(--cinza-borda);border-radius:8px;font-size:1rem;font-family:inherit;width:100%;background:#fff;
}
.campo input:focus,.campo textarea:focus,.campo select:focus{border-color:var(--azul);}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:0 18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:0 18px;}
.acoes-form{margin-top:16px;display:flex;flex-wrap:wrap;gap:6px;}
.form-inline{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0;}
.form-inline .campo{margin-bottom:0;}
.filtros .campo{flex-direction:column;}

/* Alertas ---------------------------------------------------------- */
.alerta{padding:14px 16px;border-radius:8px;margin:16px 0;border:1px solid;}
.alerta-erro{background:#fdecea;border-color:#f5c6c2;color:#a31515;}
.alerta-sucesso{background:#e8f5e9;border-color:#b7dfba;color:#1b5e20;}
.alerta ul{margin:8px 0 0;padding-left:20px;}

/* Resultados / cards ---------------------------------------------- */
.cards-resumo{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:18px 0;}
.card-num{background:#fff;border:1px solid var(--cinza-borda);border-top:4px solid var(--azul);border-radius:var(--raio);padding:18px;text-align:center;box-shadow:var(--sombra);}
.card-num .numero{display:block;font-size:2.1rem;font-weight:800;color:var(--azul);}
.card-num .rotulo{color:var(--texto-suave);font-size:.9rem;}
.grafico-wrap{max-width:560px;margin:10px auto;}
.tabela-resultado,.tabela{width:100%;border-collapse:collapse;margin-top:12px;}
.tabela-resultado th,.tabela-resultado td,.tabela th,.tabela td{border:1px solid var(--cinza-borda);padding:9px 10px;text-align:left;font-size:.95rem;}
.tabela-resultado th,.tabela th{background:var(--azul);color:#fff;}
.tabela tr:nth-child(even),.tabela-resultado tr:nth-child(even){background:#fafbfd;}
.nowrap{white-space:nowrap;}
.lista-dados{list-style:none;padding:0;}
.lista-dados li{padding:6px 0;border-bottom:1px solid var(--cinza-borda);}

/* Rodapé ----------------------------------------------------------- */
.rodape{background:var(--azul-escuro);color:#fff;margin-top:30px;border-top:4px solid var(--dourado);}
.rodape .container{padding:10px 16px;text-align:center;font-size:.85rem;}
.rodape-acoes{margin:24px 0;text-align:center;}
.icone-ok{width:80px;height:80px;border-radius:50%;background:var(--verde);color:#fff;font-size:46px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}

/* ----- Login ------------------------------------------------------ */
.tela-login{background:linear-gradient(135deg,var(--azul),var(--azul-escuro));min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}
.login-box{background:#fff;border-radius:16px;max-width:400px;width:100%;padding:30px;box-shadow:0 10px 40px rgba(0,0,0,.3);border-top:5px solid var(--dourado);}
.login-cabecalho{text-align:center;margin-bottom:18px;}
.login-cabecalho .brasao{margin:0 auto 10px;}
.login-cabecalho h1{color:var(--azul);margin:6px 0 0;font-size:1.3rem;}
.login-cabecalho p{margin:2px 0;color:var(--texto-suave);font-size:.9rem;}
.login-sub{font-weight:600;color:var(--dourado-escuro)!important;}
.login-voltar{text-align:center;margin-top:14px;}
.login-voltar a{color:var(--azul);}

/* ----- Admin ------------------------------------------------------ */
.admin{background:var(--cinza);}
.admin-topo{background:linear-gradient(135deg,var(--azul),var(--azul-escuro));color:#fff;border-bottom:4px solid var(--dourado);}
.admin-topo-conteudo{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:7px 20px;flex-wrap:wrap;}
.admin-marca{display:flex;align-items:center;gap:10px;font-size:1.02rem;padding-right:14px;border-right:1px solid rgba(255,255,255,.22);}
.admin-marca strong{font-weight:700;}
.admin-usuario span{background:rgba(255,255,255,.12);padding:6px 12px;border-radius:999px;}
.admin-conteudo{max-width:1180px;}
.admin-menu{display:flex;gap:6px;flex-wrap:wrap;margin-left:12px;}
.admin-menu a{
  color:rgba(255,255,255,.92);text-decoration:none;padding:9px 16px;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.2px;position:relative;
  transition:background .18s,color .18s,transform .12s,box-shadow .18s;
}
.admin-menu a:hover{background:rgba(255,255,255,.16);color:#fff;transform:translateY(-1px);}
.admin-menu a.ativo{
  background:linear-gradient(135deg,var(--dourado),var(--dourado-escuro));
  color:var(--azul-escuro);box-shadow:0 3px 10px rgba(212,175,55,.45);
}
.admin-menu a.ativo:hover{transform:none;}
.admin-usuario{margin-left:auto;display:flex;align-items:center;gap:10px;font-size:.9rem;}
.admin-conteudo{max-width:1100px;margin:0 auto;padding:20px 16px;}
.admin-rodape{max-width:1100px;margin:20px auto;padding:0 16px 30px;color:var(--texto-suave);text-align:center;}
.painel-cabecalho{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
.status-pesquisa{font-weight:700;padding:6px 12px;border-radius:20px;font-size:.85rem;}
.status-pesquisa.on{background:#e8f5e9;color:var(--verde);}
.status-pesquisa.off{background:#fdecea;color:var(--vermelho);}
hr{border:none;border-top:1px solid var(--cinza-borda);margin:22px 0;}

/* Responsivo ------------------------------------------------------- */
@media (max-width:680px){
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .cabecalho .btn-voltar{margin-left:0;width:100%;text-align:center;}
  .admin-usuario{margin-left:0;width:100%;justify-content:space-between;}
  .admin-menu{margin-left:0;}
}

/* VLibras não deve sobrepor o conteúdo no mobile */
[vw]{z-index:9999;}

/* =====================================================================
   ANIMAÇÕES
   ===================================================================== */
@keyframes fadeInUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes slideDown{from{opacity:0;transform:translateY(-16px);}to{opacity:1;transform:translateY(0);}}
@keyframes brilho{0%{background-position:-200% 0;}100%{background-position:200% 0;}}
@keyframes flutuar{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
@keyframes pulsar{0%{box-shadow:0 0 0 0 rgba(212,175,55,.55);}70%{box-shadow:0 0 0 14px rgba(212,175,55,0);}100%{box-shadow:0 0 0 0 rgba(212,175,55,0);}}
@keyframes girar{from{transform:rotate(0);}to{transform:rotate(360deg);}}
@keyframes checkPop{0%{transform:scale(0);}60%{transform:scale(1.15);}100%{transform:scale(1);}}

/* Cabeçalho com leve gradiente em movimento + brasão flutuando */
.cabecalho,.admin-topo,.tela-login{
  background-size:200% 200%;
  animation:gradiente 14s ease infinite;
}
@keyframes gradiente{0%{background-position:0% 50%;}50%{background-position:100% 50%;}100%{background-position:0% 50%;}}
.cabecalho-conteudo{animation:slideDown .6s ease both;}
.cabecalho .brasao,.login-cabecalho .brasao{animation:flutuar 4s ease-in-out infinite;}

/* Entrada dos blocos (efeito escalonado) */
.cartao,fieldset.cartao{animation:fadeInUp .55s ease both;}
.cartao:nth-of-type(1){animation-delay:.02s;}
.cartao:nth-of-type(2){animation-delay:.10s;}
.cartao:nth-of-type(3){animation-delay:.18s;}
.cartao:nth-of-type(4){animation-delay:.26s;}
.cartao:nth-of-type(5){animation-delay:.34s;}
.cartao:nth-of-type(6){animation-delay:.42s;}
.cartao:nth-of-type(7){animation-delay:.50s;}
.cartao:nth-of-type(n+8){animation-delay:.56s;}

/* Cards de número entram e o número "respira" */
.card-num{animation:fadeInUp .6s ease both;}
.card-num:hover{transform:translateY(-4px);transition:.2s;}
.card-num .numero{transition:.2s;}
.card-num:hover .numero{color:var(--dourado-escuro);}

/* Botões: elevação + brilho ao passar o mouse */
.btn{position:relative;overflow:hidden;transition:transform .15s,background .15s,box-shadow .15s;}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(20,58,96,.25);}
.btn:active{transform:translateY(0);}
.btn-primario,.btn-voltar{
  background-image:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  background-size:200% 100%;background-repeat:no-repeat;background-position:-200% 0;
}
.btn-primario:hover,.btn-voltar:hover{animation:brilho 1s ease;}
.btn-grande{animation:pulsar 2.4s infinite;}

/* Opções: realce suave ao selecionar/passar */
.opcao{transition:background .15s,transform .12s,box-shadow .15s;}
.opcao:hover{transform:translateX(4px);}
.opcao input:checked + span{font-weight:600;color:var(--azul);}

/* Campos com foco animado */
.campo input,.campo select,.campo textarea,.campo-texto{transition:border-color .2s,box-shadow .2s;}
.campo input:focus,.campo select:focus,.campo textarea:focus,.campo-texto:focus{
  box-shadow:0 0 0 3px rgba(28,78,128,.15);
}

/* Ícone de sucesso animado */
.icone-ok{animation:checkPop .5s ease both,pulsar 2s 1s infinite;}

/* Barra de progresso do formulário */
.barra-progresso{
  position:sticky;top:0;z-index:50;height:8px;background:var(--azul-claro);
  border-radius:0 0 6px 6px;overflow:hidden;margin:-2px 0 14px;
}
.barra-progresso > span{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg,var(--azul),var(--dourado));
  transition:width .4s ease;
}
.barra-progresso-rotulo{font-size:.82rem;color:var(--texto-suave);text-align:right;margin:-8px 0 12px;}

/* Linha de apoio para leitores de tela já existe (.sr-only) */

/* Respeita quem prefere menos movimento (acessibilidade) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;}
}

/* =====================================================================
   CABEÇALHO E RODAPÉ FIXOS
   ===================================================================== */
body{display:flex;flex-direction:column;min-height:100vh;}
body.tela-login{display:flex;}   /* login mantém centralização */

/* Cabeçalho fixo no topo */
.cabecalho,.admin-topo{
  position:sticky;top:0;z-index:900;
  box-shadow:0 3px 10px rgba(20,58,96,.25);
}

/* Conteúdo ocupa o espaço disponível, empurrando o rodapé para baixo */
main,.admin-conteudo{flex:1 0 auto;}

/* Rodapé fixo na parte inferior */
.rodape,.admin-rodape{
  position:sticky;bottom:0;z-index:800;margin-top:auto;
  box-shadow:0 -3px 10px rgba(20,58,96,.25);
}
.admin-rodape{background:var(--azul-escuro);color:#fff;padding:8px 16px;border-top:3px solid var(--dourado);max-width:none;}
.admin-rodape small{color:#fff;}

/* Barra de progresso fica logo abaixo do cabeçalho fixo */
.barra-progresso{top:64px;}

