/* ── Canal de Denúncias COPLAC — Folha de Estilos ──────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --verde-escuro:  #1B4332;
  --verde-medio:   #2D6A4F;
  --verde-claro:   #52B788;
  --verde-tenue:   #D8F3DC;
  --cinza-fundo:   #F8F9FA;
  --cinza-borda:   #E2E8F0;
  --cinza-texto:   #64748B;
  --texto:         #1A202C;
  --branco:        #FFFFFF;
  --erro:          #DC2626;
  --erro-fundo:    #FEF2F2;
  --radius:        10px;
  --radius-lg:     16px;
  --sombra:        0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
}

/* ── Reset ── */
html { font-size: 16px; }
body.coplac-canal-body {
  font-family: 'DM Sans', system-ui, sans-serif;
  background: var(--cinza-fundo);
  color: var(--texto);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── Layout ── */
.cc-page { min-height: 100vh; display: flex; flex-direction: column; }
.cc-container { width: 100%; max-width: 780px; margin: 0 auto; padding: 0 1.5rem; }
.cc-container--estreito { max-width: 560px; }
.cc-main { flex: 1; padding: 2.5rem 0 4rem; }

/* ── Header ── */
.cc-header {
  background: var(--branco);
  border-bottom: 1px solid var(--cinza-borda);
  padding: .875rem 0;
  position: sticky; top: 0; z-index: 10;
}
.cc-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.cc-header__marca { display: flex; align-items: center; gap: .75rem; }
.cc-header__escudo {
  width: 40px; height: 40px;
  background: var(--verde-tenue);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
}
.cc-header__empresa { display: block; font-weight: 600; font-size: 15px; line-height: 1.1; }
.cc-header__canal { display: block; font-size: 12px; color: var(--cinza-texto); }

/* ── Hero ── */
.cc-hero { text-align: center; padding: 2rem 0 2.5rem; }
.cc-hero--sm { padding: 1.5rem 0 2rem; }
.cc-hero__titulo {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  color: var(--verde-escuro);
  line-height: 1.2;
  margin-bottom: .875rem;
}
.cc-hero__subtitulo {
  font-size: 1rem; color: var(--cinza-texto);
  max-width: 560px; margin: 0 auto 1.5rem;
}

/* ── Garantias ── */
.cc-garantias {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: .625rem; margin-top: 1.25rem;
}
.cc-garantia {
  display: flex; align-items: center; gap: .5rem;
  background: var(--verde-tenue);
  border-radius: 99px;
  padding: .375rem 1rem;
  font-size: .8125rem; font-weight: 500; color: var(--verde-escuro);
}

/* ── Formulário ── */
.cc-form {
  background: var(--branco);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius-lg);
  box-shadow: var(--sombra);
  overflow: hidden;
}
.cc-form--consulta {
  background: var(--branco);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--sombra);
}
.cc-form__secao { padding: 1.75rem 2rem; border-bottom: 1px solid var(--cinza-borda); }
.cc-form__secao:last-child { border-bottom: none; }
.cc-form__secao-titulo {
  font-size: .9375rem; font-weight: 600;
  color: var(--verde-escuro);
  margin-bottom: 1.25rem;
}
.cc-form__secao-opc { font-weight: 400; color: var(--cinza-texto); font-size: .8125rem; }
.cc-form__secao--politica { background: #F0FDF4; }
.cc-form__rodape {
  padding: 1.5rem 2rem;
  background: var(--cinza-fundo);
  text-align: center;
  border-top: 1px solid var(--cinza-borda);
}
.cc-form__aviso-envio { font-size: .8125rem; color: var(--cinza-texto); margin-top: .875rem; }

/* ── Campos ── */
.cc-campo { margin-bottom: 1.125rem; }
.cc-campo:last-child { margin-bottom: 0; }
.cc-campo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.cc-campo--row { display: flex; gap: .75rem; }
.cc-label {
  display: block; font-size: .875rem; font-weight: 500;
  color: var(--texto); margin-bottom: .425rem;
}
.cc-label__req { color: var(--verde-claro); }
.cc-label__dica { display: block; font-size: .78125rem; font-weight: 400; color: var(--cinza-texto); margin-top: 1px; }

.cc-input, .cc-select, .cc-textarea {
  width: 100%;
  padding: .625rem .875rem;
  border: 1.5px solid var(--cinza-borda);
  border-radius: var(--radius);
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: .9375rem;
  color: var(--texto);
  background: var(--branco);
  transition: border-color .15s, box-shadow .15s;
  appearance: none;
}
.cc-input:focus, .cc-select:focus, .cc-textarea:focus {
  outline: none;
  border-color: var(--verde-claro);
  box-shadow: 0 0 0 3px rgba(82,183,136,.15);
}
.cc-select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .875rem center; padding-right: 2.5rem; }
.cc-textarea { resize: vertical; min-height: 100px; }
.cc-textarea--sm { min-height: 70px; }
.cc-input--protocolo { font-family: monospace; letter-spacing: .05em; font-size: 1rem; flex: 1; }
.cc-contador { display: block; font-size: .75rem; color: var(--cinza-texto); margin-top: .3rem; text-align: right; }

/* ── Política ── */
.cc-politica__titulo { font-size: .9375rem; font-weight: 600; color: var(--verde-escuro); margin-bottom: .75rem; }
.cc-politica p { font-size: .875rem; color: var(--cinza-texto); margin-bottom: .625rem; }
.cc-politica p:last-child { margin-bottom: 0; }

/* ── Botões ── */
.cc-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .625rem 1.25rem;
  border-radius: var(--radius);
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: .9375rem; font-weight: 500;
  cursor: pointer; border: none; text-decoration: none;
  transition: all .15s; white-space: nowrap;
}
.cc-btn--primario {
  background: var(--verde-escuro); color: var(--branco);
}
.cc-btn--primario:hover { background: var(--verde-medio); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(27,67,50,.25); }
.cc-btn--secundario {
  background: var(--verde-tenue); color: var(--verde-escuro); border: 1.5px solid var(--verde-claro);
}
.cc-btn--secundario:hover { background: #c6ead0; }
.cc-btn--ghost {
  background: transparent; color: var(--cinza-texto); border: 1.5px solid var(--cinza-borda);
}
.cc-btn--ghost:hover { background: var(--cinza-fundo); border-color: #CBD5E1; color: var(--texto); }
.cc-btn--lg { padding: .875rem 2rem; font-size: 1rem; border-radius: 12px; }
.cc-btn--sm { padding: .4375rem .875rem; font-size: .8125rem; }

/* ── Confirmação ── */
.cc-page--confirmacao { background: var(--branco); align-items: center; justify-content: center; min-height: 100vh; }
.cc-confirm-card {
  max-width: 520px; margin: 3rem auto;
  background: var(--branco); border: 1px solid var(--cinza-borda);
  border-radius: var(--radius-lg); padding: 2.5rem 2rem; text-align: center;
  box-shadow: var(--sombra);
}
.cc-confirm-icon { margin-bottom: 1.25rem; }
.cc-confirm-titulo {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 1.625rem; color: var(--verde-escuro); margin-bottom: .875rem;
}
.cc-confirm-texto { font-size: .9375rem; color: var(--cinza-texto); margin-bottom: 1.75rem; }
.cc-protocolo-box {
  background: var(--verde-tenue);
  border: 1.5px solid var(--verde-claro);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.5rem;
  display: flex; flex-direction: column; align-items: center; gap: .625rem;
}
.cc-protocolo-label { font-size: .8125rem; font-weight: 500; color: var(--cinza-texto); text-transform: uppercase; letter-spacing: .05em; }
.cc-protocolo-codigo {
  font-family: 'DM Mono', 'Fira Code', monospace;
  font-size: 1.5rem; font-weight: 600;
  color: var(--verde-escuro);
  letter-spacing: .08em;
}
.cc-btn-copiar {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--verde-escuro); color: var(--branco);
  border: none; border-radius: 6px;
  padding: .375rem .875rem; font-size: .8125rem; font-weight: 500;
  cursor: pointer; transition: background .15s;
}
.cc-btn-copiar:hover { background: var(--verde-medio); }
.cc-confirm-acoes { display: flex; gap: .75rem; justify-content: center; margin-top: 1.5rem; flex-wrap: wrap; }

/* ── Alertas ── */
.cc-alerta {
  display: flex; align-items: center; gap: .75rem;
  padding: .875rem 1rem;
  border-radius: var(--radius);
  font-size: .9rem;
  margin-bottom: 1.5rem;
}
.cc-alerta--erro { background: var(--erro-fundo); color: var(--erro); border: 1px solid #FECACA; }
.cc-aviso-anonimato {
  display: flex; align-items: flex-start; gap: .625rem;
  background: #EFF6FF; border: 1px solid #BFDBFE;
  border-radius: var(--radius); padding: .875rem 1rem;
  font-size: .8125rem; color: #1D4ED8;
  text-align: left;
}

/* ── Resultado de consulta ── */
.cc-resultado {
  background: var(--branco); border: 1px solid var(--cinza-borda);
  border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--sombra);
}
.cc-resultado__header {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--cinza-borda);
  display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem;
}
.cc-resultado__protocolo { font-family: monospace; font-size: 1rem; font-weight: 600; color: var(--texto); }
.cc-resultado__categoria { font-size: .875rem; color: var(--cinza-texto); margin-top: .25rem; }
.cc-status-badge { padding: .35rem .875rem; border-radius: 99px; font-size: .8125rem; font-weight: 600; white-space: nowrap; }
.cc-resultado__datas {
  padding: .875rem 1.5rem;
  border-bottom: 1px solid var(--cinza-borda);
  display: flex; gap: 2rem; flex-wrap: wrap;
  font-size: .8125rem; color: var(--cinza-texto);
}
.cc-resultado__resposta { padding: 1.25rem 1.5rem; }
.cc-resultado__resposta-titulo { font-weight: 600; font-size: .875rem; margin-bottom: .625rem; color: var(--verde-escuro); }
.cc-resultado__aguardando {
  padding: 1.25rem 1.5rem;
  display: flex; align-items: center; gap: .625rem;
  font-size: .875rem; color: var(--cinza-texto);
}

/* ── Footer ── */
.cc-footer {
  background: var(--branco);
  border-top: 1px solid var(--cinza-borda);
  padding: 1rem 0;
}
.cc-footer__inner {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
  gap: .5rem; font-size: .78125rem; color: var(--cinza-texto);
}
.cc-footer__anonimato { display: flex; align-items: center; gap: .35rem; }

/* ── Responsivo ── */
@media (max-width: 600px) {
  .cc-form__secao { padding: 1.25rem 1rem; }
  .cc-campo-grid { grid-template-columns: 1fr; }
  .cc-garantias { flex-direction: column; align-items: center; }
  .cc-campo--row { flex-direction: column; }
  .cc-confirm-card { margin: 1.5rem 1rem; padding: 1.5rem 1rem; }
  .cc-protocolo-codigo { font-size: 1.125rem; }
  .cc-resultado__header { flex-direction: column; }
  .cc-resultado__datas { flex-direction: column; gap: .375rem; }
}

/* ── Confirmação simplificada (sem protocolo) ── */
.cc-confirm-mensagem {
  display: flex; align-items: flex-start; gap: 1rem;
  background: var(--verde-tenue);
  border: 1.5px solid var(--verde-claro);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.5rem;
  margin: 1.5rem 0;
  text-align: left;
}
.cc-confirm-mensagem strong { display: block; color: var(--verde-escuro); font-size: .9375rem; margin-bottom: .35rem; }
.cc-confirm-mensagem p { font-size: .875rem; color: var(--cinza-texto); margin: 0; }

.cc-confirm-compromisso {
  display: flex; flex-direction: column; gap: .625rem;
  background: var(--cinza-fundo);
  border-radius: var(--radius);
  padding: 1.125rem 1.375rem;
  text-align: left;
}
.cc-compromisso-item {
  display: flex; align-items: center; gap: .625rem;
  font-size: .875rem; color: var(--cinza-texto);
}
