/*
 * ZFIP Design System — zfip-tema.css
 * Carga después de adminlte.min.css; no rompe estilos existentes.
 */

/* ─── Variables globales ─────────────────────────────────────────────────── */
:root {
  --zfip-primary:        #213e49;
  --zfip-primary-light:  #0586b0;
  --zfip-secondary:      #1e95b9;
  --zfip-success:        #9dc066;
  --zfip-warning:        #D4AC0D;
  --zfip-danger:         #C0392B;
  --zfip-info:           #1e95b9;
  --zfip-muted:          #6C757D;

  --zfip-bg:             #F0F2F5;
  --zfip-card-bg:        #FFFFFF;
  --zfip-border:         #DEE2E6;
  --zfip-shadow-sm:      0 1px 4px rgba(0,0,0,.10);
  --zfip-shadow-md:      0 4px 14px rgba(0,0,0,.12);
  --zfip-shadow-lg:      0 8px 28px rgba(0,0,0,.16);

  --zfip-radius-sm:      6px;
  --zfip-radius-md:      10px;
  --zfip-radius-lg:      16px;

  --zfip-font:           'Manrope', 'Segoe UI', sans-serif;
}

/* Modo oscuro */
.dark-mode {
  --zfip-bg:        #181C24;
  --zfip-card-bg:   #242A35;
  --zfip-border:    #343A46;
}

/* ─── KPI Cards ──────────────────────────────────────────────────────────── */
.zfip-kpi-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--zfip-radius-md);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
  transition: box-shadow .2s, transform .2s, background .2s;
  position: relative;
  overflow: hidden;
  height: 100%;
}
.zfip-kpi-card:hover {
  background: rgba(255,255,255,.10);
  box-shadow: 0 4px 16px rgba(0,0,0,.35);
  transform: translateY(-2px);
}
.zfip-kpi-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px;
  height: 100%;
  background: var(--zfip-kpi-color, var(--zfip-primary));
}
.zfip-kpi-icon {
  width: 48px; height: 48px;
  border-radius: var(--zfip-radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  background: rgba(255,255,255,.08);
  color: var(--zfip-kpi-color, #74b3f0);
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.10);
}
.zfip-kpi-body { flex: 1; min-width: 0; }
.zfip-kpi-label {
  font-size: 10px; font-weight: 700; letter-spacing: .7px;
  text-transform: uppercase; color: rgba(255,255,255,.50);
  margin-bottom: 2px;
}
.zfip-kpi-value {
  font-size: 26px; font-weight: 800; line-height: 1;
  color: #fff;
}
.zfip-kpi-sub {
  font-size: 11px; color: rgba(255,255,255,.45); margin-top: 5px;
}
.zfip-kpi-sub a { color: #74b3f0 !important; }
.zfip-kpi-badge {
  font-size: 11px; font-weight: 600; padding: 3px 8px;
  border-radius: 20px;
}

/* Colores semánticos para KPI */
.zfip-kpi--primary  { --zfip-kpi-color: var(--zfip-primary);   }
.zfip-kpi--success  { --zfip-kpi-color: var(--zfip-success);   }
.zfip-kpi--danger   { --zfip-kpi-color: var(--zfip-danger);    }
.zfip-kpi--warning  { --zfip-kpi-color: var(--zfip-warning);   }
.zfip-kpi--info     { --zfip-kpi-color: var(--zfip-info);      }
.zfip-kpi--muted    { --zfip-kpi-color: var(--zfip-muted);     }

/* ─── Section cards ──────────────────────────────────────────────────────── */
.zfip-section-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--zfip-radius-md);
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
  overflow: hidden;
}
.zfip-section-card .zfip-card-header {
  padding: 13px 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,.04);
}
.zfip-section-card .zfip-card-header .zfip-card-title {
  font-size: 13px; font-weight: 700; letter-spacing: .3px;
  color: rgba(255,255,255,.85); margin: 0;
}
.zfip-section-card .zfip-card-body { padding: 18px 20px; }

/* ─── Alert strip ────────────────────────────────────────────────────────── */
.zfip-alert-row {
  display: flex; flex-direction: column; gap: 8px;
}
.zfip-alert-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border-radius: var(--zfip-radius-sm);
  font-size: 13px;
  background: rgba(245,158,11,.12);
  border-left: 3px solid #F59E0B;
  color: #FDE68A;
  text-decoration: none;
  transition: background .15s;
}
.zfip-alert-item:hover { background: rgba(245,158,11,.20); color: #FEF3C7; }
.zfip-alert-item.danger {
  background: rgba(239,68,68,.12);
  border-color: #EF4444;
  color: #FCA5A5;
}
.zfip-alert-item.danger:hover { background: rgba(239,68,68,.22); color: #FEE2E2; }
.zfip-alert-item.info {
  background: rgba(59,130,246,.12);
  border-color: #60A5FA;
  color: #BFDBFE;
}
.zfip-alert-item.info:hover { background: rgba(59,130,246,.22); color: #DBEAFE; }

/* ─── Sidebar group header ───────────────────────────────────────────────── */
.zfip-nav-group-label {
  font-size: 10px; font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  padding: 14px 16px 4px;
  display: block;
}

/* ─── Quick-actions bar ──────────────────────────────────────────────────── */
.zfip-quick-bar {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 20px;
}
.zfip-quick-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px;
  border-radius: var(--zfip-radius-sm);
  font-size: 13px; font-weight: 600;
  border: 1.5px solid transparent;
  cursor: pointer; transition: all .18s;
  text-decoration: none;
}
.zfip-quick-btn.primary {
  background: var(--zfip-primary); color: #fff;
  border-color: var(--zfip-primary);
}
.zfip-quick-btn.primary:hover {
  background: var(--zfip-primary-light); color: #fff;
}
.zfip-quick-btn.outline {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.88);
  border-color: rgba(255,255,255,.30);
}
.zfip-quick-btn.outline:hover {
  background: var(--zfip-primary);
  color: #fff;
  border-color: var(--zfip-primary);
}
/* Modo claro (si aplica) */
@media (prefers-color-scheme: light) {
  .zfip-quick-btn.outline {
    background: transparent;
    color: var(--zfip-primary);
    border-color: var(--zfip-primary);
  }
}

/* ─── Breadcrumb override ────────────────────────────────────────────────── */
.zfip-breadcrumb {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; color: rgba(255,255,255,.55);
  margin-bottom: 14px; flex-wrap: wrap;
}
.zfip-breadcrumb a { color: #74b3f0; text-decoration: none; }
.zfip-breadcrumb a:hover { color: #fff; text-decoration: underline; }
.zfip-breadcrumb .sep { color: rgba(255,255,255,.25); }
.zfip-breadcrumb .current { color: rgba(255,255,255,.9); font-weight: 700; }

/* ─── Progress bar slim ──────────────────────────────────────────────────── */
.zfip-progress {
  height: 6px; border-radius: 3px;
  background: var(--zfip-border);
  overflow: hidden; margin-top: 6px;
}
.zfip-progress-bar {
  height: 100%; border-radius: 3px;
  background: var(--zfip-kpi-color, var(--zfip-primary));
  transition: width .4s ease;
}

/* ─── Estado badge ───────────────────────────────────────────────────────── */
.zfip-badge {
  display: inline-block;
  padding: 3px 10px; border-radius: 20px;
  font-size: 11px; font-weight: 700; letter-spacing: .3px;
}
.zfip-badge.activo        { background:rgba(34,197,94,.2);   color:#86EFAC; border:1px solid rgba(34,197,94,.35); }
.zfip-badge.inactivo      { background:rgba(239,68,68,.2);   color:#FCA5A5; border:1px solid rgba(239,68,68,.35); }
.zfip-badge.pendiente     { background:rgba(245,158,11,.2);  color:#FDE68A; border:1px solid rgba(245,158,11,.35); }
.zfip-badge.aprobado      { background:rgba(34,197,94,.2);   color:#86EFAC; border:1px solid rgba(34,197,94,.35); }
.zfip-badge.rechazado     { background:rgba(239,68,68,.2);   color:#FCA5A5; border:1px solid rgba(239,68,68,.35); }
.zfip-badge.ejecutado     { background:rgba(96,165,250,.2);  color:#BFDBFE; border:1px solid rgba(96,165,250,.35); }
.zfip-badge.mantenimiento { background:rgba(168,85,247,.2);  color:#D8B4FE; border:1px solid rgba(168,85,247,.35); }

/* ─── Chart wrapper ──────────────────────────────────────────────────────── */
.zfip-chart-wrap {
  position: relative; width: 100%; min-height: 200px;
}

/* ─── Utilities ──────────────────────────────────────────────────────────── */
.zfip-gap-sm { gap: 8px !important; }
.zfip-gap-md { gap: 16px !important; }
.zfip-text-primary { color: var(--zfip-primary) !important; }
.zfip-text-muted   { color: var(--zfip-muted)   !important; }
.zfip-fw-800       { font-weight: 800 !important; }
