/* ============================================================
   Câmara Ouvidoria — Estilos Frontend
   Design profissional para portal público de câmaras municipais
   ============================================================ */

:root {
    --ouv-primary:    #1a3a6b;
    --ouv-secondary:  #2c7be5;
    --ouv-accent:     #00b894;
    --ouv-danger:     #e74c3c;
    --ouv-warning:    #f39c12;
    --ouv-success:    #27ae60;
    --ouv-gray-100:   #f8f9fa;
    --ouv-gray-200:   #e9ecef;
    --ouv-gray-600:   #6c757d;
    --ouv-gray-900:   #212529;
    --ouv-radius:     10px;
    --ouv-shadow:     0 2px 12px rgba(0,0,0,.08);
}

/* Wrapper geral */
.camara-ouv-wrap {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 16px;
    color: var(--ouv-gray-900);
}

/* Header da seção */
.camara-ouv-header {
    background: linear-gradient(135deg, var(--ouv-primary) 0%, var(--ouv-secondary) 100%);
    color: #fff;
    padding: 32px 36px;
    border-radius: var(--ouv-radius);
    margin-bottom: 28px;
}
.camara-ouv-header h2 { margin: 0 0 8px; font-size: 1.6rem; }
.camara-ouv-header p  { margin: 0; opacity: .85; }

/* ---- Seletor de tipos ---- */
.camara-ouv-tipos {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 14px;
    margin-bottom: 28px;
}

.camara-ouv-tipo-card {
    background: #fff;
    border: 2px solid var(--ouv-gray-200);
    border-radius: var(--ouv-radius);
    padding: 18px 12px;
    text-align: center;
    cursor: pointer;
    transition: all .2s;
    box-shadow: var(--ouv-shadow);
}
.camara-ouv-tipo-card:hover,
.camara-ouv-tipo-card:focus { border-color: var(--ouv-secondary); transform: translateY(-2px); }
.camara-ouv-tipo-card.ativo  { border-color: var(--ouv-primary); background: #eef3fb; }

.ouv-tipo-icon  { display: block; font-size: 2rem; margin-bottom: 6px; }
.ouv-tipo-label { display: block; font-weight: 700; font-size: .95rem; }
.ouv-tipo-desc  { display: none; }

/* ---- Formulário ---- */
.camara-ouv-form { background: #fff; border-radius: var(--ouv-radius); box-shadow: var(--ouv-shadow); overflow: hidden; }

.ouv-form-section {
    padding: 28px 32px;
    border-bottom: 1px solid var(--ouv-gray-200);
}
.ouv-form-section:last-child { border-bottom: none; }
.ouv-form-section h3 { margin: 0 0 20px; color: var(--ouv-primary); font-size: 1.1rem; }

.ouv-field { margin-bottom: 18px; }
.ouv-field label { display: block; font-weight: 600; margin-bottom: 6px; font-size: .9rem; }
.ouv-field input,
.ouv-field select,
.ouv-field textarea {
    width: 100%; padding: 10px 14px; border: 1.5px solid var(--ouv-gray-200);
    border-radius: 7px; font-size: .95rem; transition: border-color .2s; box-sizing: border-box;
}
.ouv-field input:focus, .ouv-field select:focus, .ouv-field textarea:focus {
    outline: none; border-color: var(--ouv-secondary); box-shadow: 0 0 0 3px rgba(44,123,229,.15);
}
.ouv-field small { display: block; color: var(--ouv-gray-600); font-size: .82rem; margin-top: 4px; }
.req { color: var(--ouv-danger); }

.ouv-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .ouv-field-row { grid-template-columns: 1fr; } }

/* Identificação */
.ouv-identificacao-opts { margin-bottom: 20px; }
.ouv-radio-opt {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 16px; margin-bottom: 8px;
    border: 1.5px solid var(--ouv-gray-200); border-radius: 8px; cursor: pointer;
}
.ouv-radio-opt:has(input:checked) { border-color: var(--ouv-secondary); background: #eef3fb; }
.ouv-radio-opt input { width: auto; }

/* LGPD box */
.ouv-lgpd-box {
    background: #fff8e1; border: 1.5px solid #ffe082; border-radius: 8px;
    padding: 14px 16px; margin-top: 16px;
}
.ouv-lgpd-box label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-weight: normal; }
.ouv-lgpd-box input { width: auto; margin-top: 2px; flex-shrink: 0; }

/* Botões */
.ouv-form-actions { padding: 24px 32px; display: flex; gap: 12px; background: var(--ouv-gray-100); }
.ouv-btn-enviar {
    background: var(--ouv-primary); color: #fff; border: none; border-radius: 8px;
    padding: 12px 28px; font-size: 1rem; font-weight: 700; cursor: pointer; transition: background .2s;
}
.ouv-btn-enviar:hover { background: var(--ouv-secondary); }
.ouv-btn-cancelar {
    background: none; border: 1.5px solid var(--ouv-gray-200); border-radius: 8px;
    padding: 12px 20px; cursor: pointer; color: var(--ouv-gray-600);
}

/* Alert */
.ouv-alert { padding: 14px 18px; border-radius: 8px; margin: 0 32px 20px; font-weight: 600; }
.ouv-alert.erro    { background: #fdecea; color: var(--ouv-danger); border: 1px solid #f5c6cb; }
.ouv-alert.sucesso { background: #d4edda; color: var(--ouv-success); border: 1px solid #c3e6cb; }

/* Sucesso */
.ouv-sucesso-box {
    background: #fff; border-radius: var(--ouv-radius); box-shadow: var(--ouv-shadow);
    padding: 40px; text-align: center;
}
.ouv-sucesso-icon { font-size: 3.5rem; margin-bottom: 12px; }
.ouv-sucesso-box h3 { color: var(--ouv-success); font-size: 1.4rem; margin-bottom: 12px; }
.ouv-protocolo-destaque {
    display: inline-block; background: var(--ouv-primary); color: #fff;
    padding: 14px 28px; border-radius: 8px; font-size: 1.3rem; font-weight: 700;
    letter-spacing: 1px; margin: 16px 0;
}
.ouv-lgpd-aviso { font-size: .85rem; color: var(--ouv-gray-600); margin-top: 16px; }
.ouv-btn-nova {
    background: var(--ouv-secondary); color: #fff; border: none; border-radius: 8px;
    padding: 12px 24px; cursor: pointer; font-size: .95rem; margin-top: 12px;
}

/* ---- Consulta ---- */
#camara-ouv-consulta { margin-top: 32px; }
.ouv-consulta-form { margin-bottom: 24px; }
.ouv-consulta-input-row { display: flex; gap: 10px; }
.ouv-consulta-input-row input {
    flex: 1; padding: 12px 16px; border: 2px solid var(--ouv-gray-200);
    border-radius: 8px; font-size: 1rem;
}
.ouv-btn-consultar {
    background: var(--ouv-primary); color: #fff; border: none; border-radius: 8px;
    padding: 12px 24px; font-size: 1rem; font-weight: 700; cursor: pointer;
}

/* Resultado da consulta */
.ouv-resultado-card {
    background: #fff; border-radius: var(--ouv-radius); box-shadow: var(--ouv-shadow); overflow: hidden;
}
.ouv-resultado-header {
    padding: 20px 24px; display: flex; justify-content: space-between; align-items: center;
    border-bottom: 1px solid var(--ouv-gray-200);
}
.ouv-resultado-body { padding: 24px; }
.ouv-status-pill {
    display: inline-block; padding: 5px 14px; border-radius: 20px; color: #fff; font-size: .85rem; font-weight: 700;
}
.ouv-info-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
.ouv-info-item label { display: block; font-size: .8rem; color: var(--ouv-gray-600); margin-bottom: 4px; }
.ouv-info-item span { font-weight: 600; }
.ouv-atrasada-badge { color: var(--ouv-danger); font-weight: 700; }
.ouv-resposta-bloco {
    background: #f0f7ee; border-left: 4px solid var(--ouv-success);
    padding: 16px 20px; border-radius: 0 8px 8px 0; margin-top: 16px;
}

/* Timeline */
.ouv-timeline { position: relative; padding-left: 24px; }
.ouv-timeline::before { content: ''; position: absolute; left: 7px; top: 0; bottom: 0; width: 2px; background: var(--ouv-gray-200); }
.ouv-tl-item { position: relative; padding: 10px 0 10px 20px; }
.ouv-tl-dot {
    position: absolute; left: -21px; top: 14px; width: 12px; height: 12px;
    background: var(--ouv-secondary); border-radius: 50%; border: 2px solid #fff;
}
.ouv-tl-acao { font-weight: 700; font-size: .9rem; }
.ouv-tl-data { font-size: .8rem; color: var(--ouv-gray-600); }

/* ---- Relatório ---- */
#camara-ouv-relatorio { margin-top: 32px; }
.ouv-filtros-box {
    background: #fff; border-radius: var(--ouv-radius); box-shadow: var(--ouv-shadow);
    padding: 20px 24px; margin-bottom: 24px;
}
.ouv-filtros-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; }
.ouv-filtros-row .ouv-field { margin: 0; min-width: 130px; }
.ouv-filtros-row label { font-size: .82rem; }
.ouv-btn-filtrar {
    background: var(--ouv-primary); color: #fff; border: none; border-radius: 8px;
    padding: 10px 20px; cursor: pointer; font-weight: 700;
}

/* Cards de totais */
.ouv-rel-totais { display: grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap: 16px; margin-bottom: 24px; }
.ouv-rel-card {
    background: #fff; border-radius: var(--ouv-radius); box-shadow: var(--ouv-shadow);
    padding: 20px 16px; text-align: center; border-top: 4px solid var(--ouv-secondary);
}
.ouv-rel-card.danger { border-top-color: var(--ouv-danger); }
.ouv-rel-card.success{ border-top-color: var(--ouv-success); }
.ouv-rel-num   { display: block; font-size: 2.2rem; font-weight: 800; color: var(--ouv-primary); }
.ouv-rel-label { display: block; font-size: .82rem; color: var(--ouv-gray-600); margin-top: 4px; }

/* Tabelas de relatório */
.ouv-rel-table { width: 100%; border-collapse: collapse; }
.ouv-rel-table th, .ouv-rel-table td { padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--ouv-gray-200); font-size: .9rem; }
.ouv-rel-table th { background: var(--ouv-gray-100); font-weight: 700; }
.ouv-rel-bar { height: 8px; background: var(--ouv-secondary); border-radius: 4px; display: inline-block; margin-left: 8px; min-width: 2px; }

/* Exportar */
.ouv-exportar-box { margin-top: 20px; padding: 16px 24px; background: var(--ouv-gray-100); border-radius: var(--ouv-radius); display: flex; align-items: center; gap: 12px; }
.ouv-btn-exportar {
    background: #fff; border: 1.5px solid var(--ouv-gray-200); border-radius: 7px;
    padding: 8px 16px; text-decoration: none; color: var(--ouv-primary); font-weight: 600; font-size: .9rem;
}

/* Loading */
.ouv-loading { text-align: center; padding: 32px; color: var(--ouv-gray-600); }

@media (max-width: 600px) {
    .camara-ouv-tipos { grid-template-columns: repeat(2,1fr); }
    .ouv-info-row { grid-template-columns: 1fr; }
    .ouv-filtros-row { flex-direction: column; }
    .ouv-consulta-input-row { flex-direction: column; }
}
