/* ===== expedientes.css =====
   Solo columnas de tabla, modal extra-ancho y componentes exclusivos.
   Hero, KPI cards y shell viven en assets/css/module-patterns.css
   ========================================================= */

/* Tabla de expedientes */
.ui-div-table-expedientes .ui-div-row {
    grid-template-columns: 2fr 1fr 1fr 1.3fr .8fr .9fr;
}

/* Filtros */
.expedientes-filters-grid {
    grid-template-columns: 2fr 1fr 1fr 1.4fr;
}

/* Modal de detalle — ancho extra */
.expedientes-modal-backdrop .is-xl {
    max-width: 1120px;
    width: min(1120px, calc(100vw - 28px));
}

/* Layout interior del expediente: sidebar + contenido */
.exp-grid {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 18px;
}

/* Paneles del expediente */
.exp-panel {
    background: rgba(255,255,255,.04);
    border: 1px solid var(--stroke);
    border-radius: var(--radius-md);
    padding: 18px;
}

.exp-panel h3 {
    margin: 0 0 14px;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--text-muted);
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(255,255,255,.06);
}

/* Definición de datos */
.exp-dl {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 8px 12px;
    margin: 0 0 18px;
}

/* Variante compacta: filas más apretadas, sin margen inferior extra */
.exp-dl--compact {
    gap: 5px 12px;
    margin-bottom: 14px;
}

.exp-dl--compact dt {
    font-size: 11.5px;
}

.exp-dl--compact dd {
    font-size: 12.5px;
}

.exp-dl dt {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-muted);
    align-self: start;
    padding-top: 1px;
}

.exp-dl dd {
    margin: 0;
    font-size: 13px;
    color: var(--text);
    line-height: 1.4;
    word-break: break-word;
}

/* Título de sección inline (reemplaza el h3 suelto) */
.exp-section-title {
    margin: 10px 0 6px;
    font-size: 11.5px;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--text-muted);
}

/* Mensaje/nota */
.exp-message-box {
    font-size: 12.5px;
    line-height: 1.55;
    color: var(--text-soft);
    white-space: pre-wrap;
    margin: 0;
}

/* Footer del panel de seguimiento — botón guardar integrado arriba */
.exp-seguimiento-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.exp-seguimiento-form .exp-form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.exp-seguimiento-form label {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
}

.exp-seguimiento-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

/* Pestañas del expediente */
.exp-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.exp-tabs button {
    border: 1px solid var(--stroke);
    background: rgba(255,255,255,.04);
    color: var(--text-soft);
    border-radius: 999px;
    padding: 7px 14px;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.exp-tabs button:hover {
    background: rgba(255,255,255,.08);
    border-color: var(--stroke-strong);
    color: var(--text);
}

.exp-tabs button.is-active {
    background: linear-gradient(135deg, var(--azul), var(--cielo));
    border-color: rgba(91,170,224,.42);
    color: #fff;
    box-shadow: 0 8px 18px rgba(26,111,191,.18);
}

.exp-tab { display: none; }
.exp-tab.is-active { display: block; }

/* Tarjeta de cita */
.exp-cita-card {
    border: 1px solid var(--stroke);
    border-radius: var(--radius-sm);
    padding: 14px;
    margin-bottom: 12px;
    background: rgba(255,255,255,.035);
    transition: background var(--transition);
}

.exp-cita-card:hover { background: rgba(255,255,255,.055); }

.exp-cita-card > div {
    display: flex;
    gap: 10px;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 8px;
}

.exp-cita-card span {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 700;
}

.exp-cita-card p {
    margin: 8px 0 0;
    font-size: 13px;
    line-height: 1.5;
    white-space: pre-wrap;
    color: var(--text-soft);
}

/* Línea de tiempo */
.exp-timeline { display: grid; gap: 14px; }

.exp-timeline-item {
    position: relative;
    border-left: 3px solid var(--azul);
    padding: 2px 0 14px 16px;
}

.exp-timeline-item::before {
    content: "";
    position: absolute;
    left: -6px;
    top: 4px;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--azul);
    border: 2px solid var(--bg-2);
}

.exp-timeline-item strong {
    display: block;
    font-size: 14px;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 2px;
}

.exp-timeline-item span {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 700;
}

.exp-timeline-item p {
    margin: 6px 0 0;
    font-size: 13px;
    line-height: 1.45;
    color: var(--text-soft);
    white-space: pre-wrap;
}

/* ===== Responsive ===== */

@media (max-width: 900px) {
    .expedientes-filters-grid,
    .exp-grid {
        grid-template-columns: 1fr;
    }

    .exp-dl { grid-template-columns: 1fr; }
    .exp-dl dt { margin-bottom: -4px; }
}

/* ===== Light mode ===== */

body.light .exp-panel {
    background: rgba(255,255,255,.72);
    border-color: var(--stroke);
}

body.light .exp-panel h3 {
    border-bottom-color: rgba(13,72,130,.10);
}

body.light .exp-tabs button {
    background: rgba(255,255,255,.55);
    border-color: var(--stroke);
}

body.light .exp-tabs button:hover {
    background: rgba(255,255,255,.88);
}

body.light .exp-cita-card {
    background: rgba(255,255,255,.55);
    border-color: var(--stroke);
}

body.light .exp-cita-card:hover {
    background: rgba(255,255,255,.82);
}

@media (max-width: 940px) {
    .ui-div-table-expedientes .ui-div-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .expedientes-filters-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 560px) {
    .ui-div-table-expedientes .ui-div-row,
    .expedientes-filters-grid {
        grid-template-columns: 1fr;
    }
}
