/* IL_PUBLICA (v3) – UI layer
   Objetivo: visual moderno/clean sem brigar com Bootstrap.
   IMPORTANT: este arquivo NÃO sobrescreve classes Bootstrap (.btn, .card, etc).
*/

/* Layout */
.page{
  max-width: 1100px;
  margin: 0 auto;
  padding: 18px 14px;
}

.page-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.stack{ display:flex; flex-direction:column; gap:12px; }
.stack-sm{ display:flex; flex-direction:column; gap:8px; }

.grid-2{ display:grid; gap:14px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3{ display:grid; gap:14px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4{ display:grid; gap:14px; grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (max-width: 992px){
  .grid-4{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px){
  .grid-3, .grid-2{ grid-template-columns: repeat(1, minmax(0, 1fr)); }
}

/* Cards */
.card-shadow{
  border: 1px solid rgba(10,31,68,.08);
  box-shadow: 0 10px 30px rgba(10,31,68,.06);
  border-radius: 16px;
}

.kpi-value{
  font-size: 28px;
  font-weight: 900;
  letter-spacing: .2px;
}

.kpi-label{ font-size: 12px; color: rgba(68,68,68,.75); }

/* Lists */
.list-cards{ display:flex; flex-direction:column; gap:12px; }

.mini-card{
  padding: 12px;
  border-radius: 14px;
}

/* Images grid */
.preview-grid{ display:grid; gap:10px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.preview-grid img{ width:100%; height:150px; object-fit:cover; border-radius: 12px; border:1px solid rgba(10,31,68,.10); }
@media (max-width: 860px){
  .preview-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Timeline */
.timeline{ display:flex; flex-direction:column; gap:10px; }
.tl-item{ padding:10px 12px; border-radius: 14px; border:1px solid rgba(10,31,68,.08); background: rgba(255,255,255,.6); }

/* Status badges (Bootstrap-friendly) */
.badge-status{ font-weight:700; border:1px solid rgba(0,0,0,.06); }
.badge-ABERTO{ background: rgba(0,180,255,.16); color:#001018; }
.badge-EM_ATENDIMENTO{ background: rgba(255,193,7,.18); color:#3a2c00; }
.badge-ENCERRADO{ background: rgba(25,135,84,.18); color:#052b15; }

/* Tables */
.table thead th{ font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: rgba(68,68,68,.75); }

/* Form helpers */
.help{ font-size: 12px; color: rgba(68,68,68,.75); }

/* Back-compat (para JS e alguns templates) */
.muted{ color: rgba(108,117,125,1); }
.preview{ display:grid; gap:10px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.preview-item{ padding:10px; border:1px solid rgba(10,31,68,.10); border-radius: 14px; background: rgba(255,255,255,.7); }
.preview-item img{ width:100%; height:150px; object-fit:cover; border-radius: 12px; }
@media (max-width: 860px){
  .preview{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
