/* ================== THEME SCOPED TO .container ================== */
/* Tema padrão (claro) dentro do card */
.container {
  /* cores base do card */
  --card-bg: #ffffff;
  --text: #002d6a;
  --muted: #004080;
  --shadow: 0 4px 15px rgba(0, 45, 106, 0.2);

  /* botões e acentos */
  --accent: #002d6a;
  --accent-2: #004080;
  --btn-bg: var(--accent);
  --btn-bg-hover: var(--accent-2);
  --btn-text: #ffffff;

  /* campos */
  --field-bg: #ffffff;
  --field-tx: #111111;
  --field-border: #002d6a;
  --field-focus: #004080;
  --field-autofill: #e6f7ff;

  /* mensagens */
  --success-bg: #e7f3ff;
  --success-bd: #b3d1ff;
  --success-tx: #002d6a;

  --alert-bg: #ffecec;
  --alert-bd: #e74c3c;
  --alert-tx: #b20000;

  /* footer */
  --footer-tx: #004080;
  --footer-tx-hover: #002d6a;
}

/* Tema ESCURO apenas no card */
.container[data-theme="dark"] {
  --card-bg: #0f1f3a;
  --text: #e7efff;
  --muted: #a5c7ff;
  --shadow: 0 4px 18px rgba(0,0,0,.35);

  --accent: #123e83;
  --accent-2: #0b2f68;
  --btn-bg: var(--accent);
  --btn-bg-hover: var(--accent-2);
  --btn-text: #ffffff;

  --field-bg: #0b1f3f;
  --field-tx: #e7efff;
  --field-border: #2b4f92;
  --field-focus: #3a6ad1;
  --field-autofill: #142a54;

  --success-bg: #0e2a57;
  --success-bd: #1e4a96;
  --success-tx: #dfeaff;

  --alert-bg: #3a1f1f;
  --alert-bd: #e74c3c;
  --alert-tx: #ffd6d6;

  --footer-tx: #a5c7ff;
  --footer-tx-hover: #ffffff;
}

/* ====== Overrides que fazem suas regras existentes usarem as variáveis ====== */
/* card */
.container {
  background: var(--card-bg) !important;
  color: var(--text) !important;
  box-shadow: var(--shadow) !important;
}

/* textos */
.container h1,
.container h2,
.container label,
.container .checkbox-inline,
.container .checkbox-label { color: var(--text) !important; }

.container p,
.container .desc,
.container footer,
.container .footer-links,
.container .footer-links a { color: var(--muted) !important; }

/* botões padrão e especiais */
.container button { 
  background: var(--btn-bg) !important; 
  color: var(--btn-text) !important; 
}
.container button:hover { background: var(--btn-bg-hover) !important; }
.container #toggleForm { background: var(--accent) !important; }
.container #toggleForm:hover { background: var(--accent-2) !important; }

/* botões flutuantes do card (share/theme) */
.container .share-button--card,
.container .theme-button--card {
  background: var(--btn-bg) !important; 
  color: var(--btn-text) !important;
}
.container .share-button--card:hover,
.container .theme-button--card:hover { background: var(--btn-bg-hover) !important; }

/* campos */
.container input[type="text"],
.container input[type="email"],
.container select,
.container textarea {
  background: var(--field-bg) !important;
  color: var(--field-tx) !important;
  border-color: var(--field-border) !important;
}
.container input:focus,
.container select:focus,
.container textarea:focus {
  border-color: var(--field-focus) !important;
  box-shadow: 0 0 5px color-mix(in srgb, var(--field-focus) 30%, transparent) !important;
}
.container input.autofilled { background-color: var(--field-autofill) !important; }

/* mensagens */
.container .sucesso {
  background: var(--success-bg) !important;
  border-color: var(--success-bd) !important;
  color: var(--success-tx) !important;
}
.container .alerta,
.container .alerta-denuncia {
  background: var(--alert-bg) !important;
  border-color: var(--alert-bd) !important;
  color: var(--alert-tx) !important;
}

/* links sociais (mantém a cor de acento do tema) */
.container .social-links a { background: var(--accent) !important; }

/* footer */
.container .footer-links a { color: var(--footer-tx) !important; }
.container .footer-links a:hover { color: var(--footer-tx-hover) !important; }

/* fundo do card com imagem transparente repetindo (opcional) */
.container {
  background:
    url('/img/bg_card.png') top left / 200px 133px repeat,
    var(--card-bg) !important;
}



/* ==========================================================
   🐾 JULINHO CASARES — CADASTRO SOLIDÁRIO
   Estilos revisados e otimizados (v1.4 - theming)
   ========================================================== */

/* ---------- Variáveis (tema claro • padrão) ---------- */
:root {
  --bg-body: #002d6a;
  --text: #002d6a;
  --muted: #004080;

  --card-bg: #ffffff;
  --shadow: 0 4px 15px rgba(0, 45, 106, 0.2);

  --accent: #002d6a;
  --accent-2: #004080;

  --field-border: #002d6a;
  --field-focus: #004080;
  --field-autofill: #e6f7ff;

  --btn-bg: #002d6a;
  --btn-bg-hover: #004080;
  --btn-text: #ffffff;

  --success-bg: #e7f3ff;
  --success-bd: #b3d1ff;
  --success-tx: #002d6a;

  --alert-bg: #ffecec;
  --alert-bd: #e74c3c;
  --alert-tx: #b20000;

  --footer-tx: #004080;
  --footer-tx-hover: #002d6a;
}

/* ---------- Tema invertido (escuro) ---------- */
html[data-theme="dark"] {
  /* invertendo a lógica: corpo claro e card escuro */
  --bg-body: #e7efff;           /* fundo geral claro */
  --text: #0f1f3a;              /* texto principal escuro */
  --muted: #123e83;

  --card-bg: #0f1f3a;           /* card escuro */
  --shadow: 0 4px 18px rgba(0, 0, 0, 0.35);

  --accent: #123e83;            /* botões escuros */
  --accent-2: #0b2f68;

  --field-border: #2b4f92;
  --field-focus: #3a6ad1;
  --field-autofill: #142a54;

  --btn-bg: #123e83;
  --btn-bg-hover: #0b2f68;
  --btn-text: #ffffff;

  --success-bg: #0e2a57;
  --success-bd: #1e4a96;
  --success-tx: #cfe2ff;

  --alert-bg: #3a1f1f;
  --alert-bd: #e74c3c;
  --alert-tx: #ffd6d6;

  --footer-tx: #a5c7ff;
  --footer-tx-hover: #ffffff;
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }

html {
  min-height: 100%;
}

body {
  font-family: 'Poppins', sans-serif;
  background: var(--bg-body);
  color: var(--text);
  margin: 0;
  padding: 40px 0; /* adiciona espaçamento no topo e base */
  display: flex;
  justify-content: center;
  align-items: flex-start; /* o card começa do topo e cresce */
  min-height: 100vh; /* altura mínima igual à tela, mas cresce */
}


/* Evita que o card “grude” no topo em telas muito baixas */
@media (max-height: 700px) {
  body { align-items: flex-start; padding-top: 28px; }
}

.container {
  position: relative;
  max-width: 750px;
  width: calc(100% - 40px);
  background: var(--card-bg);
  padding: 35px;
  border-radius: 20px;
  box-shadow: var(--shadow);
}

/* Fundo do card opcional (se quiser usar imagem acima do branco) */
/*
.container {
  background:
    url('/img/bg_card.png') top left / 200px 133px repeat,
    var(--card-bg);
}
*/

/* -------- Cabeçalhos e descrições -------- */
h1 {
  text-align: center;
  color: var(--text);
  margin-bottom: 10px;
  font-size: 1.9rem;
}

p.desc {
  text-align: center;
  color: var(--muted);
  margin-bottom: 25px;
  font-size: 1rem;
}

/* -------- Campos de formulário -------- */
form label {
  display: block;
  margin-top: 12px;
  font-weight: 600;
  color: var(--text);
  transition: opacity 0.3s ease;
}

form input[type="text"],
form input[type="email"],
form select,
form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--field-border);
  border-radius: 10px;
  margin-top: 5px;
  font-size: 15px;
  transition: all 0.3s ease;
  background: #fff;
  color: #111;
}

/* campos em tema escuro dentro do card */
html[data-theme="dark"] form input[type="text"],
html[data-theme="dark"] form input[type="email"],
html[data-theme="dark"] form select,
html[data-theme="dark"] form textarea {
  background: #0b1f3f;
  color: #e7efff;
}

form select:focus,
form textarea:focus,
form input:focus {
  outline: none;
  border-color: var(--field-focus);
  box-shadow: 0 0 5px color-mix(in srgb, var(--field-focus) 30%, transparent);
}

form textarea {
  resize: vertical;
  min-height: 80px;
}

/* -------- Checkboxes -------- */
form .checkbox-label {
  display: flex;
  align-items: center;
  margin-top: 12px;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  transition: opacity 0.3s ease;
}

form .checkbox-label input[type="checkbox"] { margin-right: 10px; }

/* -------- Botões -------- */
button {
  display: block;
  width: 100%;
  background: var(--btn-bg);
  color: var(--btn-text);
  padding: 15px;
  border: none;
  border-radius: 10px;
  font-size: 18px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 20px;
  transition: background 0.3s, transform 0.2s ease;
}

button:hover {
  background: var(--btn-bg-hover);
  transform: translateY(-1px);
}

/* Botão ativo (acordeão aberto) */
button.active {
  background: var(--accent-2);
  box-shadow: 0 0 10px color-mix(in srgb, var(--accent-2) 25%, transparent);
}

/* -------- Mensagens de sucesso e alerta -------- */
.sucesso {
  background: var(--success-bg);
  border: 1px solid var(--success-bd);
  color: var(--success-tx);
  padding: 15px;
  border-radius: 10px;
  margin-bottom: 20px;
  text-align: center;
  font-weight: 500;
}

.alerta {
  background: var(--alert-bg);
  border: 1px solid var(--alert-bd);
  color: var(--alert-tx);
  padding: 12px 15px;
  border-radius: 10px;
  margin-bottom: 15px;
  text-align: center;
  font-weight: 600;
}

/* -------- Bio e redes sociais -------- */
.bio-section {
  text-align: center;
  margin-bottom: 30px;

  /* permite posicionar botões flutuantes */
  position: relative;
  padding-top: 8px;
}

.bio-section img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
  border: 0;
  margin-bottom: 10px;
}

.bio-section h2 {
  margin: 0;
  font-size: 1.4rem;
  color: var(--text);
}

.bio-section p {
  color: var(--muted);
  margin-top: 5px;
  font-size: 0.95rem;
}

/* Selo verificado (mantido) */
.verificado {
  background: #0095F6;
  color: #fff;
  border-radius: 50%;
  font-size: 0.9rem;
  font-weight: bold;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  line-height: 1;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.15);
}

/* -------- Redes sociais -------- */
.social-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 15px;
  margin-top: 15px;
}

.social-links a {
  text-decoration: none;
  color: #fff;
  background: var(--accent);
  padding: 8px 14px;
  border-radius: 8px;
  font-weight: 500;
  font-size: 0.9rem;
  transition: all 0.3s ease;
}
.social-links a:hover { filter: brightness(1.2); transform: translateY(-1px); }
.social-links a[href*="facebook"],
.social-links a[href*="instagram"],
.social-links a[href*="threads"],
.social-links a[href*="tiktok"],
.social-links a[href*="youtube"] { background: var(--accent); }

/* -------- Campos dinâmicos -------- */
.denuncia-extra,
.alerta-denuncia,
.endereco-section {
  display: none;
  opacity: 0;
  visibility: hidden;
  max-height: 0;
  transition: all 0.5s ease;
}
.denuncia-extra.show,
.alerta-denuncia.show,
.endereco-section.show {
  display: block;
  opacity: 1;
  visibility: visible;
  max-height: 3000px;
  margin-top: 15px;
}

.alerta-denuncia {
  background: var(--alert-bg);
  border: 1px solid var(--alert-bd);
  color: var(--alert-tx);
  padding: 15px;
  border-radius: 10px;
  margin-top: 15px;
  font-size: 0.9rem;
  font-weight: 500;
}

.denuncia-extra {
  margin-top: 20px;
  padding: 15px;
  background: color-mix(in srgb, var(--alert-bg) 20%, #fff);
  border: 1px solid color-mix(in srgb, var(--alert-bd) 70%, transparent);
  border-radius: 10px;
}

/* -------- Checkbox e grupos -------- */
.checkbox-group {
  display: flex;
  gap: 20px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.checkbox-inline {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  color: var(--text);
}

/* -------- Campos com erro -------- */
input:invalid,
input.error,
select.error,
textarea.error {
  border-color: #e74c3c !important;
  background-color: #ffecec;
  box-shadow: 0 0 5px rgba(231, 76, 60, 0.4);
}

/* Mensagens de erro */
.error-message {
  color: #e74c3c;
  font-size: 0.85rem;
  margin-top: 4px;
  font-weight: 500;
  display: none;
}
input.error + .error-message,
select.error + .error-message,
textarea.error + .error-message { display: block; }

/* -------- Acordeão -------- */
.acordeon {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.6s ease, opacity 0.5s ease;
}
.acordeon.show { max-height: 3000px; opacity: 1; }

/* -------- Botões especiais -------- */
#toggleForm { background: var(--accent); }
#toggleForm:hover { background: var(--accent-2); }

/* -------- Footer -------- */
footer {
  text-align: center;
  margin-top: 25px;
  color: var(--muted);
  font-size: 14px;
}

/* -------- Responsividade -------- */
@media (max-width: 600px) {
  .container { padding: 25px; }
  h1 { font-size: 1.6rem; }
  button { font-size: 16px; }
}

/* 💫 Destaque suave ao preencher automaticamente via CEP */
input.autofilled {
  background-color: var(--field-autofill);
  box-shadow: 0 0 4px color-mix(in srgb, var(--field-focus) 30%, transparent);
  transition: background-color 1.2s ease;
}
input.autofilled:focus { background-color: #ffffff; }

/* -------- Rodapé: links legais -------- */
.footer-links {
  text-align: center;
  font-size: 0.75rem;
  margin-top: 30px;
  color: var(--footer-tx);
}
.footer-links a {
  color: var(--footer-tx);
  text-decoration: none;
  margin: 0 6px;
  transition: color 0.3s ease;
}
.footer-links a:hover { color: var(--footer-tx-hover); text-decoration: underline; }
.footer-links span { color: #777; margin: 0 4px; }

/* -------- Botões flutuantes no card -------- */
.share-button--card,
.theme-button--card {
  position: absolute;
  top: 8px;
  z-index: 5;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--accent);
  color: #fff;
  border: none;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0, 45, 106, .3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .15s ease, background .2s ease, box-shadow .2s ease;
}
.share-button--card { right: 8px; }
.theme-button--card { left: 8px; }

.share-button--card i,
.theme-button--card i { font-size: 18px; line-height: 1; }
.share-button--card:hover,
.theme-button--card:hover { background: var(--accent-2); transform: translateY(-1px); }

@media (max-width: 480px) {
  .share-button--card,
  .theme-button--card {
    width: 40px; height: 40px; top: 6px; border-radius: 10px;
  }
  .share-button--card { right: 6px; }
  .theme-button--card { left: 6px; }
}

/* -------- Modal (compartilhamento) -------- */
.modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:999; align-items:center; justify-content:center; }
.modal.show { display:flex; }
.modal-content {
  background: var(--card-bg);
  color: var(--text);
  border-radius: 16px;
  max-width: 420px; width: 92%;
  padding: 22px 24px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  position: relative;
}
.close-modal { position:absolute; top:12px; right:16px; font-size:24px; background:none; border:none; color:#666; cursor:pointer; }
.share-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(92px, 1fr)); gap:12px; margin-top:14px; }
.share-item { display:flex; flex-direction:column; align-items:center; text-decoration:none; color:var(--text); font-size:.8rem; }
.share-item i { font-size:1.6rem; margin-bottom:6px; }

/* ==========================================================
   🍪 LGPD - Banner discreto fixo no rodapé
   ========================================================== */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: var(--card-bg, #fff);
  color: var(--text, #002d6a);
  border-top: 1px solid rgba(0,0,0,0.1);
  box-shadow: 0 -3px 12px rgba(0,0,0,0.1);
  padding: 12px 20px;
  display: none;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  z-index: 9999;
  animation: slideUp 0.5s ease;
}

.cookie-banner.show {
  display: flex;
}

.cookie-banner-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 12px;
  flex-wrap: wrap;
}

.cookie-banner-content p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.4;
  flex: 1;
}

.cookie-banner-buttons {
  display: flex;
  gap: 10px;
}

.cookie-banner-buttons button {
  border: none;
  border-radius: 8px;
  font-weight: 600;
  padding: 8px 14px;
  cursor: pointer;
  transition: background 0.3s ease;
  font-size: 0.9rem;
}

.cookie-banner-buttons #acceptAllCookies {
  background: var(--accent, #002d6a);
  color: #fff;
}
.cookie-banner-buttons #acceptAllCookies:hover {
  background: var(--accent-2, #004080);
}
.cookie-banner-buttons .secondary {
  background: #e9edf5;
  color: var(--text, #002d6a);
}
.cookie-banner-buttons .secondary:hover {
  background: #d8e2f3;
}

/* 🔧 Modal de personalização (mesmo estilo anterior, mais limpo) */
.cookie-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  align-items: center;
  justify-content: center;
  z-index: 10000;
}
.cookie-modal.show { display: flex; }

.cookie-modal-content {
  background: var(--card-bg, #fff);
  color: var(--text, #002d6a);
  border-radius: 14px;
  padding: 24px 26px;
  width: 90%;
  max-width: 420px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
  animation: fadeIn 0.4s ease;
}

/* Transições */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(15px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes slideUp {
  from { transform: translateY(100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

/* Tema escuro */
.container[data-theme="dark"] .cookie-banner {
  background: #0f1f3a;
  color: #e7efff;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.container[data-theme="dark"] .cookie-banner .secondary {
  background: #1e2f55;
  color: #e7efff;
}
.container[data-theme="dark"] .cookie-modal-content {
  background: #0f1f3a;
  color: #e7efff;
}
/* style.css */
input.error, select.error, textarea.error { border-color:#e74c3c !important; background:#fff5f5; }
.error-message { color:#e74c3c; font-size:.85rem; margin-top:4px; }
.alerta { margin-top:10px; padding:10px 12px; background:#fff8e1; border:1px solid #ffecb3; border-radius:6px; }
