/* ═══════════════════════════════════════════════════════════════════════
   CajonDeslizante.css  –  Diseño industrial / técnico refinado
   Paleta: slate oscuro + acento ámbar/naranja + blancos limpios
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────────────────── */
:root {
    --cd-bg:          #f1f5f9;
    --cd-surface:     #ffffff;
    --cd-surface-2:   #f8fafc;
    --cd-border:      #e2e8f0;
    --cd-border-dark: #cbd5e1;

    --cd-text-primary:   #0f172a;
    --cd-text-secondary: #475569;
    --cd-text-muted:     #94a3b8;

    --cd-accent:      #f59e0b;
    --cd-accent-2:    #3b82f6;
    --cd-accent-dark: #b45309;

    --cd-success:  #10b981;
    --cd-danger:   #ef4444;
    --cd-info:     #3b82f6;

    --cd-head-bg:  #1e293b;
    --cd-head-txt: #e2e8f0;
    --cd-foot-bg:  #1e293b;
    --cd-foot-txt: #f1f5f9;

    --cd-edit-bg:  #fffbeb;
    --cd-row-odd:  #f8fafc;
    --cd-row-even: #ffffff;
    --cd-row-hover:#fef3c7;

    --cd-row-h: 40px;
    --cd-radius: 8px;
    --cd-shadow: 0 4px 24px rgba(15,23,42,.08);
    --cd-shadow-sm: 0 1px 4px rgba(15,23,42,.06);

    /* Ancho columnas – ajustar según necesidad */
    --w-fecha:    150px;
    --w-turno:    120px;
    --w-zona:     120px;
    --w-num:      90px;
    --w-cajon:    110px;
    --w-datetime: 150px;
    --w-actions:  150px;
}

/* ── Reset / base ──────────────────────────────────────────────────── */
.cd-page * { box-sizing: border-box; }
.cd-page {
    font-family: 'IBM Plex Sans', 'Segoe UI', system-ui, sans-serif;
    font-size: 13px;
    color: var(--cd-text-primary);
    background: var(--cd-bg);
    min-height: 100vh;
    padding: 0 0 48px;
}

/* ── Header ────────────────────────────────────────────────────────── */
.cd-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--cd-head-bg);
    color: var(--cd-head-txt);
    padding: 18px 28px;
    border-bottom: 3px solid var(--cd-accent);
    gap: 16px;
}

.cd-header__left   { display: flex; align-items: center; gap: 16px; }
.cd-header__icon   {
    font-size: 2rem;
    color: var(--cd-accent);
    line-height: 1;
    filter: drop-shadow(0 0 8px rgba(245,158,11,.4));
}
.cd-header__title  { font-size: 1.3rem; font-weight: 700; margin: 0; letter-spacing: -.5px; }
.cd-header__subtitle { font-size: .85rem; color: var(--cd-text-muted); margin: 0; margin-top: 2px; }

.cd-header__actions { display: flex; gap: 10px; flex-wrap: wrap; }

.cd-btn-primary {
    background: var(--cd-accent) !important;
    color: #1e293b !important;
    font-weight: 600 !important;
    border: none !important;
    border-radius: var(--cd-radius) !important;
}
.cd-btn-secondary {
    background: rgba(255,255,255,.1) !important;
    color: var(--cd-head-txt) !important;
    border: 1px solid rgba(255,255,255,.2) !important;
    border-radius: var(--cd-radius) !important;
}

/* ── Sección tabla ─────────────────────────────────────────────────── */
.cd-table-section {
    padding: 24px 28px 0;
}

.cd-table-wrapper {
    background: var(--cd-surface);
    border-radius: var(--cd-radius);
    box-shadow: var(--cd-shadow);
    overflow-x: auto;
    border: 1px solid var(--cd-border);
}

/* ── Fila genérica (cabeceras, filas, footer) ──────────────────────── */
.cd-table-head,
.cd-row,
.cd-table-foot {
    display: flex;
    align-items: stretch;
    min-width: fit-content;
}

/* ── Cabeceras ─────────────────────────────────────────────────────── */
.cd-table-head {
    background: var(--cd-head-bg);
    border-bottom: 2px solid var(--cd-accent);
    position: sticky;
    top: 0;
    z-index: 10;
}

.cd-th {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 10px 8px;
    color: var(--cd-head-txt);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .6px;
    white-space: nowrap;
    border-right: 1px solid rgba(255,255,255,.07);
    user-select: none;
}

.cd-th__calc-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--cd-accent);
    color: #1e293b;
    border-radius: 3px;
    font-size: 10px;
    width: 14px;
    height: 14px;
    font-weight: 700;
    flex-shrink: 0;
}

/* ── Filas de datos ────────────────────────────────────────────────── */
.cd-row {
    min-height: var(--cd-row-h);
    border-bottom: 1px solid var(--cd-border);
    transition: background .15s;
    cursor: pointer;
}
.cd-row:nth-child(even) { background: var(--cd-row-even); }
.cd-row:nth-child(odd)  { background: var(--cd-row-odd); }
.cd-row:hover           { background: var(--cd-row-hover); }
.cd-row--editing        { background: var(--cd-edit-bg) !important; cursor: default; box-shadow: inset 3px 0 0 var(--cd-accent); }
.cd-row--error          { box-shadow: inset 3px 0 0 var(--cd-danger) !important; }

.cd-row-error-msg {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px 4px 16px;
    background: #fef2f2;
    color: var(--cd-danger);
    font-size: 11.5px;
    border-bottom: 1px solid #fecaca;
    border-left: 3px solid var(--cd-danger);
}

/* ── Celdas ────────────────────────────────────────────────────────── */
.cd-cell {
    display: flex;
    align-items: center;
    padding: 4px 8px;
    border-right: 1px solid var(--cd-border);
    overflow: hidden;
}

/* Anchos de columna */
.cd-cell--fecha    { width: var(--w-fecha);    min-width: var(--w-fecha);    }
.cd-cell--turno    { width: var(--w-turno);    min-width: var(--w-turno);    }
.cd-cell--zona     { width: var(--w-zona);     min-width: var(--w-zona);     }
.cd-cell--num      { width: var(--w-num);      min-width: var(--w-num);      justify-content: flex-end; }
.cd-cell--cajon    { width: var(--w-cajon);    min-width: var(--w-cajon);    }
.cd-cell--datetime { width: var(--w-datetime); min-width: var(--w-datetime); }
.cd-cell--actions  { width: var(--w-actions);  min-width: var(--w-actions);  justify-content: center; gap: 4px; }

/* Celdas calculadas */
.cd-cell--calc {
    background: rgba(241,245,249,.6);
    color: var(--cd-text-secondary);
    font-style: italic;
}
.cd-row--editing .cd-cell--calc { background: rgba(241,245,249,.4); }

/* Valores negativos */
.cd-cell--negative { color: var(--cd-danger) !important; }

/* ── Badges turno / zona ───────────────────────────────────────────── */
.cd-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .3px;
    white-space: nowrap;
}

.cd-badge--turno { background: #dbeafe; color: #1d4ed8; }
.cd-badge--mañana{ background: #fef9c3; color: #854d0e; }
.cd-badge--tarde { background: #ffedd5; color: #9a3412; }
.cd-badge--noche { background: #1e1b4b; color: #a5b4fc; }
.cd-badge--dia   { background: #dcfce7; color: #166534; }

.cd-badge--zona   { background: #f0fdf4; color: #166534; }
.cd-badge--zapata { background: #fef9c3; color: #713f12; }
.cd-badge--fuste  { background: #e0f2fe; color: #075985; }

/* ── Inputs en edición ─────────────────────────────────────────────── */
.cd-input.rz-inputtext,
.cd-input .rz-inputtext,
.cd-input.rz-dropdown,
.cd-input .rz-dropdown,
.cd-input.rz-numeric,
.cd-input .rz-numeric {
    font-size: 12px !important;
    height: 30px !important;
    padding: 2px 6px !important;
    border-radius: 4px !important;
    border: 1px solid var(--cd-border-dark) !important;
    background: #fff !important;
    width: 100% !important;
}

.cd-input.rz-datepicker input,
.cd-input .rz-datepicker input {
    font-size: 12px !important;
    height: 30px !important;
}

/* ── Botones acción ────────────────────────────────────────────────── */
.cd-btn-action.rz-button {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    padding: 0 !important;
    border-radius: 6px !important;
}

/* ── Footer ────────────────────────────────────────────────────────── */
.cd-table-foot {
    background: var(--cd-foot-bg);
    border-top: 2px solid var(--cd-accent);
    position: sticky;
    bottom: 0;
}

.cd-tf {
    display: flex;
    align-items: center;
    padding: 8px 8px;
    color: var(--cd-foot-txt);
    font-weight: 700;
    font-size: 12px;
    border-right: 1px solid rgba(255,255,255,.07);
}

.cd-tf.cd-cell--num { justify-content: flex-end; }

.cd-tf__label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--cd-accent);
    color: #1e293b;
    border-radius: 4px;
    width: 20px;
    height: 20px;
    font-size: 13px;
    font-weight: 800;
}

/* ── Estado vacío ──────────────────────────────────────────────────── */
.cd-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    color: var(--cd-text-muted);
    gap: 12px;
}
.cd-empty-state__icon { font-size: 2.5rem; opacity: .4; }

/* ── Secciones inferiores ──────────────────────────────────────────── */
.cd-chart-section,
.cd-summary-section {
    padding: 28px 28px 0;
}

.cd-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--cd-text-primary);
    margin: 0 0 16px;
    letter-spacing: -.3px;
}
.cd-section-title__icon { font-size: 1.1rem; }

.cd-chart-container {
    background: var(--cd-surface);
    border: 1px solid var(--cd-border);
    border-radius: var(--cd-radius);
    box-shadow: var(--cd-shadow-sm);
    padding: 16px;
    min-height: 320px;
}

.cd-chart-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 240px;
    color: var(--cd-text-muted);
    font-size: .9rem;
}

/* ── Tarjetas resumen ──────────────────────────────────────────────── */
.cd-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
    margin-bottom: 8px;
}

.cd-summary-card {
    background: var(--cd-surface);
    border: 1px solid var(--cd-border);
    border-radius: var(--cd-radius);
    box-shadow: var(--cd-shadow-sm);
    overflow: hidden;
}

.cd-summary-card__header {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--cd-head-bg);
    color: var(--cd-head-txt);
    padding: 10px 16px;
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .5px;
    border-bottom: 2px solid var(--cd-accent);
}

.cd-summary-card__body { padding: 12px 16px; }

.cd-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
    border-bottom: 1px solid var(--cd-border);
    gap: 16px;
}
.cd-summary-row:last-child { border-bottom: none; }
.cd-summary-row--total .cd-summary-key { font-weight: 700; }

.cd-summary-key { color: var(--cd-text-secondary); font-size: 12px; white-space: nowrap; }
.cd-summary-val { font-size: 13px; font-weight: 500; color: var(--cd-text-primary); text-align: right; }
.cd-summary-val--highlight {
    font-size: 16px;
    font-weight: 700;
    color: var(--cd-accent-dark);
    font-variant-numeric: tabular-nums;
}

/* ── Responsive ────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .cd-header { padding: 14px 16px; flex-wrap: wrap; }
    .cd-table-section,
    .cd-chart-section,
    .cd-summary-section { padding-left: 12px; padding-right: 12px; }
}
