
:root{
  --navy:#0c1b2a;
  --blue:#113f67;
  --blue-2:#1c5d99;
  --slate:#5b6573;
  --gray:#e8edf3;
  --black:#0a0a0a;
  --white:#ffffff;
  --green:#0f8a5f;
  --shadow:0 18px 50px rgba(8,18,31,.12);
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-md:14px;
  --container:min(1180px, 92vw);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--navy);
  background:#dee0e2;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:var(--container);margin:0 auto}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  min-height:48px;padding:0 22px;border-radius:999px;border:1px solid transparent;
  font-weight:700;transition:.25s ease;cursor:pointer
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue-2));color:#fff;box-shadow:var(--shadow)}
.btn-outline{border-color:#c8d2de;background:#fff}
.btn-dark{background:var(--navy);color:#fff}
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(12px);
  background:rgba(255,255,255,.82);
  border-bottom:1px solid rgba(17,63,103,.08)
}
.site-header .row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:20px}
.brand{
  display:flex;align-items:center;gap:14px;font-weight:800;letter-spacing:.2px
}
.brand-mark{
  width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg,var(--navy),var(--blue-2));
  color:#fff;display:grid;place-items:center;font-size:18px;box-shadow:var(--shadow)
}
.nav{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.nav a{padding:10px 12px;border-radius:12px;color:#304154;font-weight:600}
.nav a:hover,.nav a.active{background:#eef3f8;color:var(--navy)}
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(circle at top right, rgba(28,93,153,.18), transparent 30%),
    linear-gradient(135deg,#09131d 0%,#10283f 55%,#113f67 100%);
  color:#fff;
}
.hero .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding:88px 0 72px}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);font-size:13px
}
.hero h1{font-size:clamp(2.5rem,5vw,4.8rem);line-height:1.03;margin:18px 0 18px}
.hero p{font-size:1.08rem;line-height:1.7;color:rgba(255,255,255,.88);max-width:720px}
.hero-card{
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow);border-radius:var(--radius-xl);padding:26px
}
.hero-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px}
.kpi{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:20px;border-radius:18px
}
.kpi strong{display:block;font-size:1.7rem;margin-bottom:4px}
.section{padding:50px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:26px}
.section h2{font-size:clamp(2rem,4vw,3rem);margin:0}
.muted{color:var(--slate);line-height:1.75}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.card{
  background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);border:1px solid #edf1f5
}
.icon-badge{
  width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,#e6eef7,#f5f9fd);
  display:grid;place-items:center;font-weight:800;color:var(--blue)
}
.service-card h3,.portfolio-card h3,.doc-card h3{margin:16px 0 8px}
.portfolio-card img{aspect-ratio:16/10;object-fit:cover;border-radius:16px}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.filter-chip{
  padding:10px 14px;border-radius:999px;background:#fff;border:1px solid #d6dfe8;font-weight:600;cursor:pointer
}
.filter-chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.banner-compliance{
  background:linear-gradient(135deg,#0f8a5f,#0d6b4b);
  color:#fff;border-radius:var(--radius-xl);padding:28px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  box-shadow:var(--shadow)
}
.forms-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
form.card{padding:26px}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.field label{font-weight:700;font-size:.95rem}
.field input,.field select,.field textarea{
  width:100%;min-height:50px;padding:14px 16px;border-radius:14px;border:1px solid #d7e0ea;background:#fff;
  font:inherit;color:var(--navy)
}
.field textarea{min-height:140px;resize:vertical}
.help{font-size:.88rem;color:#6d7682}
.alert{padding:16px 18px;border-radius:16px;margin-bottom:16px}
.alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert-error{background:#fff1f2;color:#9f1239;border:1px solid #fecdd3}
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px
}
.stat{
  background:#fff;border-radius:18px;padding:24px;box-shadow:var(--shadow);border:1px solid #edf1f5
}
.stat strong{display:block;font-size:2rem}
.footer{
  background:#09131d;color:#dbe4ef;margin-top:70px
}
.footer .grid{display:grid;grid-template-columns:1.3fr .7fr .9fr;gap:26px;padding:52px 0}
.footer a{color:#dbe4ef}
.hero-actions,.inline-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.compliance-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.tab-btn{
  padding:12px 16px;border-radius:14px;border:1px solid #d5dde6;background:#fff;font-weight:700;cursor:pointer
}
.tab-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.radio-group{display:flex;gap:10px;flex-wrap:wrap}
.radio-tile{
  flex:1;min-width:150px;border:1px solid #d5dde6;padding:14px;border-radius:14px;background:#fff
}
.radio-tile input{margin-right:8px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden}
th,td{padding:14px 16px;border-bottom:1px solid #edf1f5;text-align:left;vertical-align:top}
th{background:#f5f8fb}
.badge{
  display:inline-flex;padding:8px 12px;border-radius:999px;font-size:.82rem;font-weight:800
}
.badge-recebido{background:#e0f2fe;color:#075985}
.badge-analise{background:#fef3c7;color:#92400e}
.badge-investigacao{background:#ede9fe;color:#5b21b6}
.badge-finalizado{background:#dcfce7;color:#166534}
.timeline{display:flex;flex-direction:column;gap:16px}
.timeline-item{
  padding:18px;border-left:4px solid var(--blue-2);background:#fff;border-radius:14px;box-shadow:var(--shadow)
}
.page-hero{
  padding:72px 0 32px;
  background:linear-gradient(180deg,#eef4fb 0%, rgba(238,244,251,0) 100%);
}
.metric-line{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px}
.metric-pill{
  background:#fff;border:1px solid #dbe5ef;border-radius:999px;padding:12px 16px;font-weight:700
}
.admin-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.sidebar{background:#09131d;color:#dbe4ef;padding:28px}
.sidebar nav{display:flex;flex-direction:column;gap:8px;margin-top:20px}
.sidebar nav a{padding:12px 14px;border-radius:12px}
.sidebar nav a:hover,.sidebar nav a.active{background:rgba(255,255,255,.08)}
.admin-main{padding:28px;background:#f7f9fc}
.admin-top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px}
.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#09131d,#113f67)}
.login-card{width:min(520px,100%);background:#fff;padding:32px;border-radius:24px;box-shadow:var(--shadow)}
small.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f4f6f8;padding:4px 8px;border-radius:10px}
@media (max-width: 1024px){
  .hero .grid,.forms-grid,.grid-3,.grid-2,.footer .grid,.stats-strip,.admin-layout{grid-template-columns:1fr}
  .hero-kpis{grid-template-columns:1fr}
  .banner-compliance{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .nav{display:none}
  .form-row{grid-template-columns:1fr}
  .site-header .row{padding:14px 0}
  .hero .grid{padding:64px 0 58px}
  .section{padding:60px 0}
}

/* =========================================================
   FORMULÁRIO PREMIUM - COMPLIANCE / DENÚNCIAS
========================================================= */

.compliance-form-wrap{
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 22px;
    padding: 28px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.compliance-form-title{
    margin: 0 0 8px;
    font-size: 28px;
    line-height: 1.15;
    color: #0f172a;
    font-weight: 800;
}

.compliance-form-subtitle{
    margin: 0 0 24px;
    color: #64748b;
    font-size: 15px;
    line-height: 1.7;
}

.form-grid{
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 18px;
}

.col-12{ grid-column: span 12; }
.col-6{ grid-column: span 6; }
.col-4{ grid-column: span 4; }

@media (max-width: 860px){
    .col-6,
    .col-4{
        grid-column: span 12;
    }
}

.form-group{
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.form-label{
    font-size: 14px;
    font-weight: 700;
    color: #1e293b;
    letter-spacing: .01em;
}

.form-label .required{
    color: #dc2626;
}

.form-help{
    margin-top: -2px;
    font-size: 12px;
    color: #64748b;
}

/* Campos */
.input,
.select,
.textarea,
.file-input{
    width: 100%;
    border: 1px solid #dbe4ee;
    background: #fff;
    color: #0f172a;
    border-radius: 14px;
    padding: 14px 16px;
    font-size: 15px;
    line-height: 1.4;
    outline: none;
    transition:
        border-color .22s ease,
        box-shadow .22s ease,
        transform .22s ease,
        background-color .22s ease;
}

.input::placeholder,
.textarea::placeholder{
    color: #94a3b8;
}

.input:hover,
.select:hover,
.textarea:hover,
.file-input:hover{
    border-color: #bfd0e3;
}

.input:focus,
.select:focus,
.textarea:focus,
.file-input:focus{
    border-color: #1f5f98;
    box-shadow: 0 0 0 4px rgba(31, 95, 152, 0.12);
    transform: translateY(-1px);
}

.textarea{
    min-height: 150px;
    resize: vertical;
}

/* Tipo de denúncia */
.complaint-types{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

@media (max-width: 680px){
    .complaint-types{
        grid-template-columns: 1fr;
    }
}

.complaint-choice{
    position: relative;
}

.complaint-choice input{
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.complaint-card{
    min-height: 108px;
    border: 1px solid #d8e2ec;
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 12px;
    cursor: pointer;
    transition:
        transform .22s ease,
        box-shadow .22s ease,
        border-color .22s ease,
        background-color .22s ease;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
}

.complaint-card:hover{
    transform: translateY(-3px);
    border-color: #b8c9db;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
}

.complaint-card-icon{
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 2px solid #64748b;
    position: relative;
    transition: all .22s ease;
}

.complaint-card-text{
    font-size: 14px;
    font-weight: 700;
    color: #1e293b;
    line-height: 1.2;
}

.complaint-choice input:checked + .complaint-card{
    border-color: #1f5f98;
    background: linear-gradient(180deg, #f7fbff 0%, #edf5fc 100%);
    box-shadow: 0 16px 34px rgba(31, 95, 152, 0.12);
}

.complaint-choice input:checked + .complaint-card .complaint-card-icon{
    border-color: #1f5f98;
    background: #fff;
}

.complaint-choice input:checked + .complaint-card .complaint-card-icon::after{
    content: "";
    position: absolute;
    inset: 7px;
    border-radius: 999px;
    background: #1f5f98;
}

.complaint-choice input:checked + .complaint-card .complaint-card-text{
    color: #0b2d4d;
}

/* Chips informativos */
.inline-note{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #475569;
    background: #eff6ff;
    border: 1px solid #dbeafe;
    border-radius: 999px;
    padding: 8px 12px;
}

.inline-note strong{
    color: #0f172a;
}

/* Campos condicionais */
.conditional-fields{
    display: none;
    margin-top: 4px;
    padding-top: 6px;
}

.conditional-fields.is-visible{
    display: block;
    animation: fadeSlide .28s ease;
}

@keyframes fadeSlide{
    from{
        opacity: 0;
        transform: translateY(6px);
    }
    to{
        opacity: 1;
        transform: translateY(0);
    }
}

/* Upload */
.file-box{
    border: 1px dashed #b8c9db;
    border-radius: 16px;
    background: #f8fbfe;
    padding: 16px;
    transition: border-color .22s ease, background-color .22s ease, transform .22s ease;
}

.file-box:hover{
    border-color: #1f5f98;
    background: #f5faff;
    transform: translateY(-1px);
}

.file-box small{
    display: block;
    margin-top: 8px;
    color: #64748b;
    line-height: 1.5;
}

/* Botões */
.form-actions{
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
}

.btn{
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 20px;
    border-radius: 999px;
    border: 1px solid transparent;
    text-decoration: none;
    font-size: 15px;
    font-weight: 700;
    transition:
        transform .22s ease,
        box-shadow .22s ease,
        background-color .22s ease,
        color .22s ease,
        border-color .22s ease;
    cursor: pointer;
}

.btn:hover{
    transform: translateY(-2px);
}

.btn-primary{
    background: linear-gradient(135deg, #0f4c81 0%, #1f5f98 100%);
    color: #fff;
    box-shadow: 0 14px 30px rgba(15, 76, 129, 0.24);
}

.btn-primary:hover{
    box-shadow: 0 18px 36px rgba(15, 76, 129, 0.30);
}

.btn-light{
    background: #fff;
    color: #0f172a;
    border-color: #dbe4ee;
}

.btn-light:hover{
    border-color: #c6d4e1;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

/* Alertas */
.form-alert{
    border-radius: 14px;
    padding: 14px 16px;
    font-size: 14px;
    line-height: 1.5;
    border: 1px solid transparent;
}

.form-alert-success{
    background: #ecfdf5;
    border-color: #bbf7d0;
    color: #166534;
}

.form-alert-error{
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

/* Espaçamento mais elegante */
.form-section-divider{
    height: 1px;
    margin: 8px 0 2px;
    background: linear-gradient(90deg, transparent, rgba(15,23,42,.10), transparent);
}

/* =========================
   MODAL DE PROTOCOLO
========================= */
.protocol-modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 99999;
}

.protocol-modal.is-open {
  display: block;
}

.protocol-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 23, 0.58);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}

.protocol-modal__dialog {
  position: relative;
  width: min(520px, calc(100% - 32px));
  margin: 8vh auto 0;
  background: #ffffff;
  border-radius: 22px;
  padding: 28px;
  box-shadow: 0 28px 70px rgba(2, 6, 23, 0.28);
  animation: protocolModalIn .22s ease;
  z-index: 2;
}

@keyframes protocolModalIn {
  from {
    opacity: 0;
    transform: translateY(14px) scale(.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.protocol-modal__close {
  position: absolute;
  top: 12px;
  right: 14px;
  border: 0;
  background: transparent;
  font-size: 30px;
  line-height: 1;
  color: #475569;
  cursor: pointer;
}

.protocol-modal__icon {
  width: 62px;
  height: 62px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ecfdf5;
  color: #166534;
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 16px;
}

.protocol-modal__dialog h3 {
  margin: 0 0 10px;
  font-size: 28px;
  line-height: 1.15;
  color: #0f172a;
}

.protocol-modal__text {
  margin: 0 0 18px;
  color: #64748b;
  line-height: 1.7;
}

.protocol-modal__protocol {
  display: inline-block;
  padding: 14px 18px;
  border-radius: 14px;
  background: #eff6ff;
  color: #0b3b66;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: .03em;
  margin-bottom: 10px;
}

.protocol-modal__meta {
  color: #475569;
  margin-bottom: 22px;
}

.protocol-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

/* garante que o modal não apareça como bloco comum */
#protocol-modal[aria-hidden="true"] {
  display: none !important;
}

#protocol-modal[aria-hidden="false"] {
  display: block !important;
}
