/* ═══════════════════════════════════════════════════════
   CNDC 2026 — Dashboard Gerencial
   ═══════════════════════════════════════════════════════ */

/* ── Encabezado ───────────────────────────────────────── */
.cndc-dash__header {
    background: linear-gradient(90deg, var(--primary), var(--primary-light));
    color: var(--white);
    padding: 1.5rem 0;
}
.cndc-dash__header h1 { font-size: 1.4rem; font-weight: 700; }
.cndc-dash__header p  { color: rgba(255,255,255,0.7); font-size: 0.85rem; margin-top: 0.25rem; }
.cndc-dash__meta {
    margin-left: auto;
    text-align: right;
    font-size: 0.8rem;
    color: rgba(255,255,255,0.65);
}

/* ── KPIs ─────────────────────────────────────────────── */
.cndc-kpi-row {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
    padding: 1.5rem 0;
}
.cndc-kpi-card {
    background: var(--white);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--shadow);
    border-top: 4px solid var(--primary-light);
    text-align: center;
}
.cndc-kpi-card--green  { border-top-color: #27ae60; }
.cndc-kpi-card--orange { border-top-color: #e67e22; }
.cndc-kpi-card--red    { border-top-color: #c0392b; }

.cndc-kpi__val {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--primary);
}
.cndc-kpi-card--green  .cndc-kpi__val { color: #27ae60; }
.cndc-kpi-card--orange .cndc-kpi__val { color: #e67e22; }
.cndc-kpi-card--red    .cndc-kpi__val { color: #c0392b; }

.cndc-kpi__lbl {
    font-size: 0.7rem;
    color: var(--neutral-mid);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-top: 0.25rem;
}
.cndc-kpi__sub {
    font-size: 0.75rem;
    color: #27ae60;
    margin-top: 0.2rem;
}

/* ── Grids de gráficas ────────────────────────────────── */
.cndc-charts-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    margin-bottom: 1.25rem;
}

.cndc-chart-card {
    background: var(--white);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--shadow);
}
.cndc-chart-card h3 {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 0.2rem;
}
.cndc-chart-card p {
    font-size: 0.75rem;
    color: var(--neutral-mid);
    margin-bottom: 0.75rem;
}

.cndc-hchart      { min-height: 280px; }
.cndc-hchart--tall{ min-height: 340px; }

/* ── Planificación side-by-side: matched chart cards ──── */
#do-row-planificacion {
    align-items: stretch;
}
#do-row-planificacion > .cndc-chart-card {
    display: flex;
    flex-direction: column;
    padding: 0;
}
#do-row-planificacion > .cndc-chart-card > h3 {
    min-height: 3.95rem;
    padding: 1.25rem 1.25rem 0.5rem;
    margin: 0;
}
#do-row-planificacion > .cndc-chart-card > .do-chart {
    flex: 0 0 340px;
    height: 340px;
    min-height: 340px;
    overflow: hidden;
    padding: 0 0.5rem;
    box-sizing: border-box;
}
#do-row-planificacion > .cndc-chart-card > p {
    margin-top: auto;
    padding: 0.25rem 1.25rem 1rem;
    margin-bottom: 0;
}

@media (max-width: 640px) {
    #do-row-planificacion > .cndc-chart-card > h3 {
        min-height: 0;
    }
}

/* ── Tabla de datos ───────────────────────────────────── */
.cndc-table-wrap {
    background: var(--white);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}
.cndc-table-header {
    background: var(--primary);
    color: var(--white);
    padding: 0.75rem 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.cndc-table-header h4 { font-size: 0.9rem; font-weight: 600; }
.cndc-table-header span { font-size: 0.75rem; color: rgba(255,255,255,0.65); }

.cndc-data-tbl { width: 100%; border-collapse: collapse; font-size: 0.8rem; }
.cndc-data-tbl th {
    background: #f0f4f8;
    padding: 0.6rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--primary);
    text-align: left;
    border-bottom: 1px solid #dee2e6;
    white-space: nowrap;
}
.cndc-data-tbl td {
    padding: 0.55rem 0.75rem;
    border-bottom: 1px solid #f0f0f0;
    color: #444;
}
.cndc-data-tbl tr:hover td { background: #fafcff; }
.cndc-data-tbl td.num   { text-align: right; font-family: monospace; font-weight: 600; color: var(--primary); }
.cndc-data-tbl td.total { font-weight: 700; }

/* ── Responsive ───────────────────────────────────────── */
@media (max-width: 900px) {
    .cndc-kpi-row        { grid-template-columns: repeat(2, 1fr); }
    .cndc-charts-grid-2  { grid-template-columns: 1fr; }
    .cndc-dash__header .cndc-container { flex-direction: column; gap: 0.5rem; }
    .cndc-dash__meta { text-align: left; margin-left: 0; }
}
@media (max-width: 480px) {
    .cndc-kpi-row { grid-template-columns: 1fr; }
}
