/* ============================================
   MÓDULOS ESPECÍFICOS - styles-modules.css
   Complemento al styles.css base
   ============================================ */

/* ============================================
   MÓDULO CIVIL - Formulario y Casos
   ============================================ */
.civil-form-container {
    max-width: 1200px;
    margin: 0 auto;
}

.civil-complete-form {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-md);
}

.civil-dashboard {
    max-width: 1400px;
    margin: 0 auto;
}

/* Filtros Civil */
.filters-section {
    background: var(--bg-card);
    padding: var(--space-5);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-5);
    box-shadow: var(--shadow-card);
    border: 1px solid var(--gray-200);
    display: flex;
    gap: var(--space-5);
    align-items: center;
    flex-wrap: wrap;
}

.filter-options {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.filter-options select {
    padding: var(--space-2) var(--space-4);
    border: 2px solid var(--gray-200);
    border-radius: var(--radius-md);
    min-width: 150px;
    background: var(--bg-input);
    color: var(--gray-800);
}

/* Cases Container */
.cases-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: var(--space-5);
}

.case-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-card);
    transition: all 280ms var(--ease-decelerate);
    border-left: 4px solid var(--secondary);
}

.case-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-card-hover);
    border-left-color: var(--secondary-light);
}

.case-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
}

.case-status {
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 600;
}

.case-status.activo {
    background: rgba(16,185,129,0.2);
    color: #34d399;
}

.case-status.cerrado {
    background: rgba(239,68,68,0.2);
    color: #f87171;
}

.case-number {
    font-weight: 600;
    color: var(--gray-500);
    font-size: var(--font-size-sm);
}

.case-content h4 {
    color: var(--secondary);
    margin-bottom: var(--space-3);
    font-size: var(--font-size-lg);
}

.case-details p {
    margin: var(--space-2) 0;
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.case-details strong {
    color: var(--gray-700);
}

.case-progress {
    display: flex;
    gap: var(--space-2);
    margin: var(--space-4) 0;
    flex-wrap: wrap;
}

.progress-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    background: var(--primary-light);
    color: var(--gray-500);
}

.progress-item.completed {
    background: rgba(16,185,129,0.2);
    color: #34d399;
}

.case-actions {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--gray-100);
}

.case-actions button {
    flex: 1;
}

/* Case Details Grid */
.case-details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-5);
}

.detail-section {
    background: var(--primary-light);
    padding: var(--space-5);
    border-radius: var(--radius-lg);
}

.detail-section h4 {
    color: var(--gray-800);
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-2);
    border-bottom: 2px solid var(--secondary);
    font-size: var(--font-size-base);
}

.detail-section p {
    margin: var(--space-2) 0;
    font-size: var(--font-size-sm);
}

.detail-section p strong {
    color: var(--gray-700);
    display: inline-block;
    min-width: 120px;
}

/* Etapas Procesales */
.etapas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: var(--space-3);
    margin-top: var(--space-4);
}

.etapa-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-3);
    background: var(--primary-light);
    border-radius: var(--radius-md);
    text-align: center;
    transition: all var(--transition-fast);
}

.etapa-item.completada {
    background: rgba(16,185,129,0.15);
}

.etapa-item.pendiente {
    background: var(--primary-light);
    opacity: 0.7;
}

.etapa-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-2);
    font-size: var(--font-size-lg);
}

.etapa-item.completada .etapa-icon {
    background: var(--success);
    color: white;
}

.etapa-item.pendiente .etapa-icon {
    background: var(--gray-300);
    color: var(--gray-500);
}

.etapa-name {
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--gray-700);
}

.etapa-label {
    font-size: 10px;
    color: var(--gray-500);
    margin-top: var(--space-1);
}

/* Etapas Detalladas */
.etapas-procesales-detalladas {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    margin-top: var(--space-5);
}

.etapas-procesales-detalladas h3 {
    color: var(--gray-800);
    margin-bottom: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

/* No Cases State */
.no-cases {
    text-align: center;
    padding: var(--space-12) var(--space-6);
    color: var(--gray-500);
}

.no-cases i {
    font-size: 4rem;
    margin-bottom: var(--space-4);
    color: var(--gray-300);
}

.no-cases h3 {
    font-size: var(--font-size-xl);
    margin-bottom: var(--space-2);
    color: var(--gray-600);
}

/* ============================================
   MÓDULO AUDIENCIAS - Calendario
   ============================================ */
.audiencias-container {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-6);
}

.calendar-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-5);
    background: var(--bg-card);
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.calendar-controls h3 {
    font-size: var(--font-size-xl);
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.calendar-nav {
    display: flex;
    gap: var(--space-2);
}

.calendar-grid {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.calendar-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--secondary-dark);
    color: var(--gradient-end);
}

.calendar-day-name {
    padding: var(--space-3);
    text-align: center;
    font-weight: 600;
    font-size: var(--font-size-sm);
}

.calendar-body {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.calendar-day {
    aspect-ratio: 1;
    padding: var(--space-2);
    border: 1px solid var(--gray-200);
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    min-height: 80px;
}

.calendar-day:hover {
    background: var(--primary-light);
}

.calendar-day.empty {
    background: var(--primary-dark);
    cursor: default;
}

.calendar-day.empty:hover {
    background: var(--primary-dark);
}

.calendar-day.today {
    background: var(--accent-15);
}

.calendar-day.selected {
    background: var(--secondary);
    color: var(--gradient-end);
}

.calendar-day.has-events {
    background: rgba(245,158,11,0.15);
}

.calendar-day.has-events.selected {
    background: var(--secondary);
}

.day-number {
    font-weight: 600;
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-1);
}

.events-indicator {
    display: flex;
    gap: 2px;
    flex-wrap: wrap;
    justify-content: center;
}

.events-indicator .dot {
    width: 6px;
    height: 6px;
    border-radius: var(--radius-full);
    background: var(--danger);
}

/* Audiencias List */
.audiencias-list {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
    max-height: calc(100vh - 200px);
    overflow-y: auto;
}

.audiencias-list h3 {
    font-size: var(--font-size-lg);
    color: var(--gray-800);
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--secondary);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.audiencias-cards {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.audiencia-card {
    background: var(--primary-light);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    border-left: 4px solid var(--secondary);
    transition: all var(--transition-fast);
}

.audiencia-card:hover {
    background: var(--bg-card);
    box-shadow: var(--shadow-md);
}

.audiencia-card.urgente {
    border-left-color: var(--danger);
    background: rgba(239,68,68,0.1);
}

.audiencia-card.completada {
    border-left-color: var(--success);
    opacity: 0.7;
}

.audiencia-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--space-3);
}

.audiencia-time {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--gray-800);
}

.audiencia-tipo {
    font-size: var(--font-size-xs);
    padding: var(--space-1) var(--space-2);
    background: var(--gray-200);
    border-radius: var(--radius-full);
    color: var(--gray-600);
}

.audiencia-info h4 {
    font-size: var(--font-size-sm);
    color: var(--gray-800);
    margin-bottom: var(--space-1);
}

.audiencia-info p {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
}

.audiencia-descripcion {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-top: var(--space-2);
    padding-top: var(--space-2);
    border-top: 1px solid var(--gray-200);
}

.audiencia-actions {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

/* Caso details in audiencia */
.caso-details {
    margin-top: var(--space-2);
}

.caso-numero, .caso-cliente, .caso-juzgado, .caso-abogado, .caso-nuc {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
    margin-bottom: var(--space-1);
}

/* Mini audiencias (en vista de caso) */
.audiencias-caso-list {
    margin-top: var(--space-4);
}

.audiencia-card-mini {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    margin-bottom: var(--space-2);
    border-left: 3px solid var(--secondary);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.audiencia-card-mini.tipo-urgente {
    border-left-color: var(--danger);
}

.audiencia-info-mini {
    flex: 1;
}

.audiencia-info-mini strong {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--gray-800);
}

.audiencia-info-mini span {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
}

.audiencia-actions-mini {
    display: flex;
    gap: var(--space-1);
}

.audiencias-resumen {
    background: var(--primary-light);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}

/* ============================================
   MÓDULO ACTUALIZACIÓN PENAL
   ============================================ */
.actualizacion-penal-container {
    max-width: 1400px;
    margin: 0 auto;
}

/* Activity Stats */
.activity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.activity-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
    text-align: center;
}

.activity-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}

.activity-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
}

.activity-stats {
    display: flex;
    justify-content: center;
    gap: var(--space-4);
}

.activity-stat {
    text-align: center;
}

.activity-value {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--gray-800);
}

.activity-label {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
}

/* Analysis Cards */
.analysis-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--space-5);
    margin-bottom: var(--space-6);
}

.analysis-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.analysis-header {
    background: var(--primary);
    color: white;
    padding: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.analysis-content {
    padding: var(--space-5);
}

/* Alerts */
.alerts-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-6);
}

.alerts-header {
    background: var(--danger);
    color: white;
    padding: var(--space-4);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.alerts-list {
    padding: var(--space-4);
}

.alert-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-2);
}

.alert-item.alert-danger {
    background: rgba(239,68,68,0.15);
    color: #f87171;
}

.alert-item.alert-warning {
    background: rgba(245,158,11,0.15);
    color: #fbbf24;
}

.alert-item.alert-success {
    background: rgba(16,185,129,0.15);
    color: #34d399;
}

/* Advanced Filters */
.advanced-filters-panel {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    margin-bottom: var(--space-5);
    box-shadow: var(--shadow-sm);
}

.advanced-filters-section {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-4);
}

.active-filters {
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--gray-200);
}

.active-filters-list {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.active-filters-list .badge {
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.active-filters-list .badge button {
    background: none;
    border: none;
    padding: 0;
    margin-left: var(--space-1);
    cursor: pointer;
    opacity: 0.7;
}

.active-filters-list .badge button:hover {
    opacity: 1;
}

/* Bar Charts */
.bar-container {
    margin-bottom: var(--space-3);
}

.bar-label {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--space-1);
}

.bar-fill {
    height: 24px;
    background: var(--secondary);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    padding-left: var(--space-2);
    color: white;
    font-size: var(--font-size-xs);
    font-weight: 600;
    transition: width var(--transition-slow);
}

.bar-value {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
    text-align: right;
    margin-top: var(--space-1);
}

/* Case Badge */
.case-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: 500;
}

/* Audiencias Card in Actualizacion */
.audiencias-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.audiencias-header {
    background: var(--primary);
    color: white;
    padding: var(--space-4);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.audiencias-placeholder {
    padding: var(--space-8);
    text-align: center;
    color: var(--gray-400);
}

/* ============================================
   MÓDULO REPORTES
   ============================================ */
.report-controls {
    display: flex;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
    flex-wrap: wrap;
    align-items: flex-end;
}

.report-controls .form-group {
    margin-bottom: 0;
}

.report-chart {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-6);
}

.report-chart h3 {
    font-size: var(--font-size-lg);
    color: var(--gray-800);
    margin-bottom: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.report-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.report-summary-item {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    text-align: center;
    box-shadow: var(--shadow-sm);
    border-top: 4px solid var(--secondary);
}

.report-summary-value {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    color: var(--gray-800);
}

.report-summary-label {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
    margin-top: var(--space-1);
}

/* Lawyer Report */
.lawyer-report-content {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
}

.report-generator-modal {
    background: var(--primary-light);
    padding: var(--space-6);
    border-radius: var(--radius-lg);
}

.report-generator-modal h3 {
    color: var(--gray-800);
    margin-bottom: var(--space-4);
}

/* ============================================
   MÓDULO PETICIONES
   ============================================ */
.peticiones-container {
    max-width: 1200px;
    margin: 0 auto;
}

.peticiones-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-6);
    flex-wrap: wrap;
    gap: var(--space-4);
}

.peticiones-stats {
    display: flex;
    gap: var(--space-4);
}

.peticion-stat {
    background: var(--bg-card);
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-lg);
    text-align: center;
    box-shadow: var(--shadow-sm);
    min-width: 100px;
}

.peticion-stat-value {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--gray-800);
}

.peticion-stat-label {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
    text-transform: uppercase;
}

.peticiones-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.peticion-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    border-left: 4px solid var(--secondary);
}

.peticion-card.pendiente {
    border-left-color: var(--warning);
}

.peticion-card.aprobada {
    border-left-color: var(--success);
}

.peticion-card.rechazada {
    border-left-color: var(--danger);
}

.peticion-card-header {
    padding: var(--space-4) var(--space-5);
    background: var(--primary-light);
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--gray-100);
}

.peticion-card-header h4 {
    font-size: var(--font-size-base);
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.peticion-card-body {
    padding: var(--space-5);
}

.peticion-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-4);
}

.peticion-info-item {
    display: flex;
    flex-direction: column;
}

.peticion-info-label {
    font-size: var(--font-size-xs);
    color: var(--gray-500);
    text-transform: uppercase;
    margin-bottom: var(--space-1);
}

.peticion-info-value {
    font-size: var(--font-size-sm);
    color: var(--gray-800);
    font-weight: 500;
}

.peticion-description {
    margin-top: var(--space-4);
    padding: var(--space-4);
    background: var(--primary-light);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: var(--gray-700);
}

.peticion-card-footer {
    padding: var(--space-4) var(--space-5);
    background: var(--primary-light);
    border-top: 1px solid var(--gray-100);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.peticion-timeline {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--font-size-xs);
    color: var(--gray-500);
}

.peticion-timeline-step {
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.peticion-timeline-step.completed {
    color: var(--success);
}

.peticion-timeline-step.current {
    color: var(--secondary);
    font-weight: 600;
}

/* Solicitar Documentos */
.documento-selector {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-3);
    margin: var(--space-4) 0;
}

.documento-selector label {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3);
    background: var(--primary-light);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    border: 2px solid transparent;
}

.documento-selector label:hover {
    background: var(--bg-card);
}

.documento-selector input:checked + label,
.documento-selector label:has(input:checked) {
    background: var(--accent-15);
    border-color: var(--secondary);
}

.documentos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--space-3);
}

.documentos-badge {
    position: absolute;
    top: var(--space-2);
    right: var(--space-2);
    background: var(--warning);
    color: white;
    font-size: var(--font-size-xs);
    padding: 2px 6px;
    border-radius: var(--radius-full);
}

.documento-destacado {
    background: rgba(245,158,11,0.15);
    border: 2px solid var(--warning);
}

/* ============================================
   MÓDULO ADMIN
   ============================================ */
.admin-container {
    max-width: 1400px;
    margin: 0 auto;
}

.admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: var(--space-6);
}

.admin-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.admin-card-header {
    background: var(--primary);
    color: white;
    padding: var(--space-4) var(--space-5);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.admin-card-header h3 {
    font-size: var(--font-size-lg);
    font-weight: 600;
}

.admin-card-body {
    padding: var(--space-5);
}

/* Users List */
.users-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.user-item {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4);
    background: var(--primary-light);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
}

.user-item:hover {
    background: var(--bg-card);
}

.user-avatar {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-full);
    background: linear-gradient(135deg, var(--secondary) 0%, var(--secondary-dark) 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
    font-weight: 600;
    flex-shrink: 0;
}

.user-info {
    flex: 1;
    min-width: 0;
}

.user-info h4 {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--gray-800);
    margin-bottom: var(--space-1);
}

.user-info p {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

.user-actions {
    display: flex;
    gap: var(--space-2);
}

/* Overview Stats */
.overview-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

.overview-stat {
    background: var(--primary-light);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    text-align: center;
}

.overview-stat-value {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--gray-800);
}

.overview-stat-label {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

/* ============================================
   MÓDULO CALCULADORA MORA
   ============================================ */
.calculadora-container {
    max-width: 900px;
    margin: 0 auto;
}

.calculadora-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-6);
}

.calculadora-card h3 {
    color: var(--gray-800);
    margin-bottom: var(--space-5);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.calculadora-result {
    background: linear-gradient(135deg, var(--gradient-start) 0%, var(--secondary-dark) 100%);
    color: white;
    padding: var(--space-8);
    border-radius: var(--radius-lg);
    text-align: center;
    margin-top: var(--space-6);
}

.calculadora-result h3 {
    color: rgba(255,255,255,0.9);
    font-size: var(--font-size-lg);
    margin-bottom: var(--space-2);
}

.calculadora-result .amount {
    font-size: var(--font-size-3xl);
    font-weight: 700;
}

.calculadora-result .detail {
    font-size: var(--font-size-sm);
    opacity: 0.8;
    margin-top: var(--space-2);
}

/* ============================================
   MÓDULO FECHAS IMPORTANTES
   ============================================ */
.fechas-container {
    max-width: 1200px;
    margin: 0 auto;
}

.fechas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--space-5);
}

.fecha-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
    border-left: 4px solid var(--secondary);
    transition: all var(--transition-normal);
}

.fecha-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.fecha-card.urgente {
    border-left-color: var(--danger);
    background: rgba(239,68,68,0.1);
}

.fecha-card.proximo {
    border-left-color: var(--warning);
    background: rgba(245,158,11,0.1);
}

.fecha-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--space-3);
}

.fecha-date {
    background: var(--secondary-dark);
    color: var(--gradient-end);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    text-align: center;
    min-width: 60px;
}

.fecha-date .day {
    font-size: var(--font-size-xl);
    font-weight: 700;
    line-height: 1;
}

.fecha-date .month {
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    opacity: 0.9;
}

.fecha-content h4 {
    font-size: var(--font-size-base);
    color: var(--gray-800);
    margin-bottom: var(--space-2);
}

.fecha-content p {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
}

.fecha-meta {
    display: flex;
    gap: var(--space-4);
    margin-top: var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid var(--gray-100);
    font-size: var(--font-size-xs);
    color: var(--gray-500);
}

/* ============================================
   MÓDULO COPIAS
   ============================================ */
.copias-container {
    max-width: 1200px;
    margin: 0 auto;
}

.copias-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--space-4);
}

.copia-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
}

.copia-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
}

.copia-status {
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 600;
}

.copia-status.pendiente {
    background: rgba(245,158,11,0.2);
    color: #fbbf24;
}

.copia-status.completada {
    background: rgba(16,185,129,0.2);
    color: #34d399;
}

/* ============================================
   MÓDULO KARINA
   ============================================ */
.karina-container {
    max-width: 1200px;
    margin: 0 auto;
}

.solicitud-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-4);
    border-left: 4px solid var(--secondary);
}

.solicitud-card.pendiente {
    border-left-color: var(--warning);
}

.solicitud-card.completada {
    border-left-color: var(--success);
}

.solicitud-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--space-4);
}

.solicitud-content h4 {
    font-size: var(--font-size-base);
    color: var(--gray-800);
    margin-bottom: var(--space-2);
}

.solicitud-meta {
    display: flex;
    gap: var(--space-4);
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

/* ============================================
   MÓDULO PENAL
   ============================================ */
.penal-container {
    max-width: 1400px;
    margin: 0 auto;
}

.proceso-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-4);
}

.proceso-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--gray-100);
}

.proceso-title h4 {
    font-size: var(--font-size-lg);
    color: var(--gray-800);
}

.proceso-nuc {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

/* ============================================
   RESPONSIVE PARA MÓDULOS
   ============================================ */
@media (max-width: 991px) {
    .audiencias-container {
        grid-template-columns: 1fr;
    }

    .audiencias-list {
        max-height: none;
    }

    .analysis-grid {
        grid-template-columns: 1fr;
    }

    .admin-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .cases-container {
        grid-template-columns: 1fr;
    }

    .calendar-day {
        min-height: 60px;
        padding: var(--space-1);
    }

    .day-number {
        font-size: var(--font-size-xs);
    }

    .calendar-day-name {
        font-size: var(--font-size-xs);
        padding: var(--space-2);
    }

    .peticiones-stats {
        flex-wrap: wrap;
        justify-content: center;
    }

    .peticion-stat {
        flex: 1;
        min-width: 80px;
    }

    .report-controls {
        flex-direction: column;
    }

    .report-controls .form-group {
        width: 100%;
    }

    .etapas-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .case-actions {
        flex-direction: column;
    }

    .filters-section {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-options {
        flex-direction: column;
    }
}

@media (max-width: 575px) {
    .etapas-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .activity-grid {
        grid-template-columns: 1fr;
    }

    .overview-stats {
        grid-template-columns: 1fr;
    }

    .peticion-info-grid {
        grid-template-columns: 1fr;
    }

    .peticion-card-footer {
        flex-direction: column;
        gap: var(--space-3);
    }

    .audiencia-card {
        padding: var(--space-3);
    }
}

/* ============================================
   ESTILOS ADICIONALES Y UTILIDADES
   ============================================ */

/* Connection Error */
.connection-error {
    background: rgba(239,68,68,0.15);
    border: 1px solid rgba(239,68,68,0.3);
    color: #f87171;
    padding: var(--space-6);
    border-radius: var(--radius-lg);
    text-align: center;
    margin: var(--space-6) 0;
}

.connection-error i {
    font-size: 3rem;
    margin-bottom: var(--space-4);
    display: block;
}

.connection-error h3 {
    font-size: var(--font-size-xl);
    margin-bottom: var(--space-2);
}

.connection-error p {
    margin-bottom: var(--space-4);
}

/* Error Container */
.error-container {
    background: rgba(239,68,68,0.1);
    border: 1px solid rgba(239,68,68,0.3);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    text-align: center;
    color: #f87171;
}

.error-msg {
    background: rgba(239,68,68,0.15);
    color: #f87171;
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
}

/* Success Message */
.success-msg {
    background: rgba(16,185,129,0.15);
    color: #34d399;
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
}

/* Big Number for Reports */
.big-number {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    color: var(--gray-800);
}

/* Date Badge */
.date-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    background: var(--primary-light);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    color: var(--gray-600);
}

/* Days Badge */
.days-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 600;
}

.days-badge.urgente {
    background: rgba(239,68,68,0.2);
    color: #f87171;
}

.days-badge.proximo {
    background: rgba(245,158,11,0.2);
    color: #fbbf24;
}

.days-badge.normal {
    background: rgba(16,185,129,0.2);
    color: #34d399;
}

/* Filter Group */
.filter-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.filter-group label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--gray-700);
}

/* Case Type Summary */
.case-type-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--space-4);
    margin-bottom: var(--space-5);
}

.case-type-item {
    background: var(--primary-light);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    text-align: center;
}

.case-type-item .count {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--gray-800);
}

.case-type-item .label {
    font-size: var(--font-size-sm);
    color: var(--gray-500);
}

/* Cases Table Container */
.cases-table-container {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

/* Detailed Report */
.detailed-report {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-6);
}

.detailed-report-header {
    background: var(--primary);
    color: white;
    padding: var(--space-4) var(--space-5);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.detailed-report-content {
    padding: var(--space-5);
}

/* PDF Button */
.btn-pdf-special {
    background: #dc2626;
    color: white;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 500;
    transition: all var(--transition-fast);
}

.btn-pdf-special:hover {
    background: #b91c1c;
}

/* Completed Status */
.completed {
    color: var(--success);
}

/* Editar Audiencia Modal */
.editar-audiencia-modal {
    max-width: 600px;
}

/* Emplazados Detalle */
.emplazados-detalle {
    background: var(--primary-light);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    margin-top: var(--space-3);
}

.emplazados-detalle h5 {
    font-size: var(--font-size-sm);
    color: var(--gray-700);
    margin-bottom: var(--space-2);
}

.emplazados-detalle ul {
    list-style: disc;
    padding-left: var(--space-5);
}

.emplazados-detalle li {
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    margin-bottom: var(--space-1);
}

/* Delete Buttons */
.btn-delete,
.btn-delete-peticion {
    background: transparent;
    color: var(--danger);
    border: 1px solid var(--danger);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    transition: all var(--transition-fast);
}

.btn-delete:hover,
.btn-delete-peticion:hover {
    background: var(--danger);
    color: white;
}

/* Edit Button */
.btn-edit {
    background: transparent;
    color: var(--secondary);
    border: 1px solid var(--secondary);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    transition: all var(--transition-fast);
}

.btn-edit:hover {
    background: var(--secondary);
    color: white;
}

/* Clear Button */
.btn-clear {
    background: transparent;
    color: var(--gray-500);
    border: 1px solid var(--gray-300);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    transition: all var(--transition-fast);
}

.btn-clear:hover {
    background: var(--gray-100);
    border-color: var(--gray-400);
}

/* Icon Button */
.btn-icon {
    width: 36px;
    height: 36px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    background: var(--primary-light);
    color: var(--gray-600);
    transition: all var(--transition-fast);
}

.btn-icon:hover {
    background: var(--bg-card);
    color: var(--gray-800);
}

/* Coming Soon */
.coming-soon {
    text-align: center;
    padding: var(--space-12) var(--space-6);
    color: var(--gray-400);
}

.coming-soon i {
    font-size: 5rem;
    margin-bottom: var(--space-4);
}

.coming-soon h3 {
    font-size: var(--font-size-2xl);
    color: var(--gray-600);
    margin-bottom: var(--space-2);
}

.coming-soon p {
    font-size: var(--font-size-base);
}

/* Form Grid */
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-4);
}

/* Tables inside modules */
.module table {
    width: 100%;
    border-collapse: collapse;
}

.module table th {
    background: var(--primary-light);
    padding: var(--space-3) var(--space-4);
    text-align: left;
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: var(--gray-600);
    border-bottom: 2px solid var(--gray-200);
}

.module table td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--gray-100);
    font-size: var(--font-size-sm);
}

.module table tbody tr:hover {
    background: var(--primary-light);
}

/* Readonly state */
.audiencia-readonly {
    opacity: 0.6;
    pointer-events: none;
}

/* Google Drive Button */
.btn-drive {
    background: #4285f4;
    color: white;
}

.btn-drive:hover {
    background: #3367d6;
}

/* Print Styles for Modules */
@media print {
    .module {
        background: white !important;
        box-shadow: none !important;
    }

    .case-card,
    .audiencia-card,
    .peticion-card {
        break-inside: avoid;
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }

    .btn,
    .case-actions,
    .audiencia-actions,
    .user-actions {
        display: none !important;
    }
}

/* ============================================
   MÓDULO: ÚLTIMOS ACUERDOS
   ============================================ */

.acuerdos-container {
    padding: 0;
    max-width: 100%;
}

.acuerdos-header {
    background: linear-gradient(135deg, var(--gradient-start) 0%, var(--gradient-mid) 50%, var(--gradient-end) 100%);
    color: white;
    padding: 24px 30px;
    border-radius: 12px;
    margin-bottom: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}

.acuerdos-header-content h2 {
    margin: 0 0 4px 0;
    font-size: 1.5rem;
    font-weight: 600;
    color: white;
}

.acuerdos-header-content p {
    margin: 0;
    opacity: 0.85;
    font-size: 0.9rem;
}

.acuerdos-stats {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.acuerdos-stat-card {
    background: rgba(255,255,255,0.15);
    border-radius: 8px;
    padding: 10px 18px;
    text-align: center;
    min-width: 80px;
    backdrop-filter: blur(4px);
}

.acuerdos-stat-card.accent {
    background: rgba(255,152,0,0.3);
    border: 1px solid rgba(255,152,0,0.5);
}

.acuerdos-stat-card .stat-number {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
}

.acuerdos-stat-card .stat-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    opacity: 0.9;
}

.acuerdos-stats {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

@keyframes pulseRed {
    0%, 100% { box-shadow: 0 0 0 0 rgba(192,57,43,.5); }
    50%       { box-shadow: 0 0 0 6px rgba(192,57,43,0); }
}

.td-vence {
    white-space: nowrap;
    font-size: 12px;
    text-align: center;
}

/* Tabs */
.acuerdos-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 16px;
    border-bottom: 2px solid var(--gray-200);
    padding-bottom: 0;
}

.acuerdos-tab {
    padding: 10px 20px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--gray-500);
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 6px;
}

.acuerdos-tab:hover {
    color: var(--secondary);
}

.acuerdos-tab.active {
    color: var(--secondary);
    border-bottom-color: var(--secondary);
    font-weight: 600;
}

.acuerdos-tab-content {
    display: none;
}

.acuerdos-tab-content.active {
    display: block;
}

/* Filtros */
.acuerdos-filtros {
    background: var(--primary-light);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 16px;
}

.filtro-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: flex-end;
    margin-bottom: 10px;
}

.filtro-row:last-child {
    margin-bottom: 0;
}

.filtro-group {
    flex: 1;
    min-width: 140px;
}

.filtro-group.filtro-busqueda {
    flex: 3;
    min-width: 250px;
}

.filtro-group label {
    display: block;
    font-size: 0.75rem;
    color: var(--gray-500);
    margin-bottom: 4px;
    font-weight: 500;
}

.filtro-input,
.filtro-select {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    font-size: 0.9rem;
    transition: border-color 0.2s;
    background: var(--bg-input);
    color: var(--gray-800);
}

.filtro-input:focus,
.filtro-select:focus {
    border-color: var(--secondary);
    outline: none;
    box-shadow: 0 0 0 2px var(--glow-gold);
}

/* Tabla */
.acuerdos-tabla-container {
    overflow-x: auto;
}

.acuerdos-tabla {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.acuerdos-tabla thead th {
    background: var(--primary-light);
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
    color: var(--gray-700);
    border-bottom: 2px solid var(--gray-300);
    white-space: nowrap;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.acuerdos-tabla tbody tr {
    border-bottom: 1px solid var(--gray-200);
    transition: background 0.15s;
}

.acuerdos-tabla tbody tr:hover {
    background: var(--primary-light);
}

.acuerdos-tabla tbody tr:nth-child(even) {
    background: rgba(35,35,54,0.5);
}

.acuerdos-tabla tbody tr:nth-child(even):hover {
    background: var(--primary-light);
}

.acuerdos-tabla td {
    padding: 10px 12px;
    vertical-align: middle;
}

.acuerdos-tabla .td-fecha {
    white-space: nowrap;
    font-size: 0.85rem;
    color: var(--gray-600);
}

.acuerdos-tabla .td-caso strong {
    color: var(--secondary);
}

.acuerdos-tabla .td-caso small {
    color: var(--gray-500);
}

.acuerdos-tabla .td-desc {
    max-width: 280px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.85rem;
    color: var(--gray-600);
}

.acuerdos-tabla .td-acciones {
    display: flex;
    gap: 4px;
    white-space: nowrap;
}

/* Badges */
.badge {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 10px;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* Etapa inicial - Azul */
.badge-audiencia { background: rgba(21,101,192,0.2); color: #42a5f5; }
.badge-prevencion { background: rgba(21,101,192,0.2); color: #42a5f5; }
.badge-radicacion { background: rgba(21,101,192,0.2); color: #42a5f5; }
.badge-desechamiento { background: rgba(198,40,40,0.2); color: #ef5350; }
.badge-medidas-cautelares { background: rgba(13,71,161,0.2); color: #42a5f5; }

/* Emplazamiento - Púrpura */
.badge-emplazamiento { background: rgba(123,31,162,0.2); color: #ce93d8; }
.badge-emplazamiento-ok { background: rgba(46,125,50,0.2); color: #66bb6a; }
.badge-emplazamiento-no { background: rgba(198,40,40,0.2); color: #ef5350; }

/* Contestación - Verde */
.badge-admision { background: rgba(46,125,50,0.2); color: #66bb6a; }
.badge-contestacion { background: rgba(46,125,50,0.2); color: #66bb6a; }
.badge-rebeldia { background: rgba(198,40,40,0.2); color: #ef5350; }
.badge-reconvencion { background: rgba(0,105,92,0.2); color: #4db6ac; }

/* Vista - Gris azulado */
.badge-vista { background: rgba(84,110,122,0.2); color: #90a4ae; }

/* Pruebas - Naranja */
.badge-requerimiento { background: rgba(230,81,0,0.2); color: #ff8a65; }
.badge-pruebas { background: rgba(230,81,0,0.2); color: #ff8a65; }
.badge-desecho { background: rgba(211,47,47,0.2); color: #ef5350; }
.badge-informe { background: rgba(2,136,209,0.2); color: #4fc3f7; }

/* Multi-tipo: bloques apilados de campos condicionales */
.multi-tipo-bloque {
    border-left: 3px solid var(--secondary, #d4a853);
    padding-left: 12px;
    margin-bottom: 12px;
}
.multi-tipo-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--secondary, #d4a853);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.multi-tipo-bloque + .multi-tipo-bloque {
    margin-top: 8px;
    border-left-color: var(--secondary-light, #e8c87a);
}

/* Multi-badges en tabla */
.td-tipo {
    max-width: 220px;
}
.td-tipo .badge + .badge {
    margin-left: 2px;
    margin-top: 2px;
}

/* ============================================
   PANEL DE TIPOS - Selector categorizado con checkboxes
   ============================================ */
.tipo-panel-wrapper {
    position: relative;
}
.tipo-panel-toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
    border: 2px solid var(--gray-200, #3a3a50);
    border-radius: var(--radius-md, 8px);
    background: var(--bg-input, #1e1e30);
    cursor: pointer;
    min-height: 38px;
    transition: border-color 0.2s;
}
.tipo-panel-toggle:hover {
    border-color: var(--secondary, #d4a853);
}
.tipo-panel-count {
    color: var(--gray-400, #888);
    font-size: 0.88rem;
}
.tipo-panel-count.has-selection {
    color: var(--secondary, #d4a853);
    font-weight: 600;
}
.tipo-panel-arrow {
    color: var(--gray-400, #888);
    font-size: 0.75rem;
    transition: transform 0.2s;
}

/* Badges de seleccionados */
.tipo-panel-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    padding: 4px 0;
}
.tipo-badge-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--secondary-dark, #b8912e);
    color: #fff;
    font-size: 0.68rem;
    padding: 2px 7px;
    border-radius: 10px;
    cursor: default;
    line-height: 1.4;
}
.tipo-badge-x {
    cursor: pointer;
    font-size: 0.58rem;
    opacity: 0.7;
    transition: opacity 0.15s;
}
.tipo-badge-x:hover {
    opacity: 1;
}
.tipo-oficio-detalle {
    border: 1px solid var(--accent-40) !important;
    border-radius: 4px !important;
    background: rgba(0,0,0,0.25) !important;
    color: #f0f0f5 !important;
    font-size: 11px !important;
    padding: 1px 6px !important;
    max-width: 170px;
}
.tipo-oficio-detalle::placeholder {
    color: rgba(240,240,245,0.45);
}
.tipo-add-oficio-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: transparent;
    border: 1px dashed var(--accent-40);
    color: var(--secondary, #d4a853);
    font-size: 0.65rem;
    padding: 2px 7px;
    border-radius: 10px;
    cursor: pointer;
    transition: background 0.15s;
}
.tipo-add-oficio-btn:hover {
    background: var(--accent-10);
}

/* Panel desplegable */
.tipo-panel-dropdown {
    border: 2px solid var(--gray-200, #3a3a50);
    border-radius: var(--radius-md, 8px);
    background: var(--bg-card, #2a2a3d);
    margin-top: 4px;
    box-shadow: var(--shadow-lg, 0 8px 32px rgba(0,0,0,0.3));
    max-height: 58vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.tipo-panel-search-wrap {
    display: flex;
    align-items: center;
    padding: 8px 12px;
    border-bottom: 1px solid var(--gray-200, #3a3a50);
    gap: 8px;
    flex-shrink: 0;
}
.tipo-panel-search-wrap i {
    color: var(--gray-400, #888);
    font-size: 0.85rem;
}
.tipo-panel-search {
    border: none;
    background: transparent;
    color: var(--gray-800, #e0e0e0);
    font-size: 0.88rem;
    width: 100%;
    outline: none;
}
.tipo-panel-search::placeholder {
    color: var(--gray-400, #888);
}

/* Grid de categorías — 2 columnas con CSS columns */
.tipo-panel-grid {
    overflow-y: auto;
    padding: 8px 10px;
    columns: 2;
    column-gap: 16px;
    flex: 1;
}
.tipo-cat {
    break-inside: avoid;
    margin-bottom: 10px;
}
.tipo-cat-title {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--secondary, #d4a853);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 4px 0 3px;
    border-bottom: 1px solid var(--gray-200, #3a3a50);
    margin-bottom: 2px;
}
.tipo-cat-options {
    display: flex;
    flex-direction: column;
}
.tipo-cat-option {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 4px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.8rem;
    color: var(--gray-700, #ccc);
    transition: background 0.12s;
    margin: 0;
}
.tipo-cat-option:hover {
    background: var(--glow-gold, var(--accent-15));
}
.tipo-cat-option input[type="checkbox"] {
    accent-color: var(--secondary, #d4a853);
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    cursor: pointer;
}
.tipo-cat-option input[type="checkbox"]:checked + span {
    color: var(--secondary-light, #e8c87a);
    font-weight: 600;
}
.tipo-cat-option span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Responsive: 1 columna en pantallas chicas */
@media (max-width: 768px) {
    .tipo-panel-grid {
        columns: 1;
    }
    .tipo-panel-dropdown {
        max-height: 50vh;
    }
}

.badge-dictamen { background: rgba(0,131,143,0.2); color: #4dd0e1; }
.badge-cierre { background: rgba(69,39,160,0.2); color: #b39ddb; }

/* Alegatos/Sentencia - Rojo */
.badge-alegatos { background: rgba(69,39,160,0.2); color: #b39ddb; }
.badge-sentencia { background: rgba(198,40,40,0.2); color: #ef5350; }
.badge-sentencia-int { background: rgba(191,54,12,0.2); color: #ff8a65; }
.badge-convenio { background: rgba(27,94,32,0.2); color: #66bb6a; }
.badge-depuracion { background: rgba(106,27,154,0.2); color: #ce93d8; }

/* Recursos - Verde azulado */
.badge-apelacion { background: rgba(0,105,92,0.2); color: #4db6ac; }
.badge-apelacion-no { background: rgba(198,40,40,0.2); color: #ef5350; }
.badge-amparo { background: rgba(85,139,47,0.2); color: #aed581; }

/* Ejecución - Rojo oscuro */
.badge-embargo { background: rgba(183,28,28,0.2); color: #ef5350; }

/* Incidentes - Ámbar */
.badge-incidente { background: rgba(245,127,23,0.2); color: #ffca28; }

/* Trámite - Gris */
.badge-exhorto { background: rgba(173,20,87,0.2); color: #f48fb1; }
.badge-tramite { background: rgba(84,110,122,0.2); color: #90a4ae; }
.badge-apercibimiento { background: rgba(230,81,0,0.2); color: #ff8a65; }
.badge-diferimiento { background: rgba(245,127,23,0.2); color: #ffca28; }
.badge-otro { background: rgba(84,110,122,0.2); color: #90a4ae; }

/* Etapas CNPP Penal - Púrpura */
.badge-penal           { background: rgba(142,68,173,0.2); color: #ce93d8; }
.badge-penal-sentencia { background: rgba(74,35,90,0.3);   color: #e1bee7; font-weight:700; }
.badge-penal-salida    { background: rgba(26,188,156,0.2); color: #80cbc4; }

/* Estado de acción */
.badge-accion-si { background: rgba(230,81,0,0.2); color: #ff8a65; }
.badge-accion-no { background: rgba(80,80,80,0.2); color: #888; }

/* Botones xs */
.btn-xs {
    padding: 4px 8px;
    font-size: 0.78rem;
    border-radius: 4px;
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--gray-300);
    color: var(--gray-600);
    cursor: pointer;
    transition: all 0.2s;
}

.btn-outline:hover {
    border-color: var(--secondary);
    color: var(--secondary);
}

.btn-danger-outline {
    background: transparent;
    border: 1px solid rgba(239,68,68,0.5);
    color: #f87171;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-danger-outline:hover {
    background: rgba(239,68,68,0.15);
    border-color: #ef4444;
    color: #ef4444;
}

/* Paginación */
.acuerdos-paginacion {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    flex-wrap: wrap;
    gap: 8px;
}

.pag-info {
    font-size: 0.85rem;
    color: var(--gray-500);
}

.pag-buttons {
    display: flex;
    gap: 4px;
}

.pag-btn {
    padding: 6px 12px;
    border: 1px solid var(--gray-200);
    background: var(--bg-card);
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: all 0.2s;
    color: var(--gray-600);
}

.pag-btn:hover {
    border-color: var(--secondary);
    color: var(--secondary);
}

.pag-btn.active {
    background: var(--secondary);
    color: var(--gradient-end);
    border-color: var(--secondary);
}

/* Empty state */
.acuerdos-empty {
    text-align: center;
    padding: 40px;
    color: var(--gray-500);
}

.acuerdos-empty i {
    font-size: 3rem;
    margin-bottom: 12px;
    display: block;
}

.acuerdos-loading {
    text-align: center;
    padding: 30px;
    color: var(--gray-500);
}

/* Nuevo Acuerdo Layout */
.acuerdos-nuevo-layout {
    display: flex;
    gap: 24px;
    align-items: flex-start;
}

.acuerdos-form-col {
    flex: 1;
    min-width: 0;
    position: relative;
}

.acuerdos-visor-col {
    flex: 1;
    min-width: 0;
    display: none;
    flex-direction: column;
    gap: 16px;
    position: sticky;
    top: 20px;
}

/* Form sections */
.form-section {
    background: var(--bg-card);
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 16px;
}

.form-section-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--secondary);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--gray-200);
}

.form-section-hint {
    font-weight: 400;
    font-size: 0.78rem;
    color: var(--gray-400);
    margin-left: auto;
}

/* Form */
.acuerdos-form .form-group {
    margin-bottom: 14px;
}

.acuerdos-form .form-group:last-child {
    margin-bottom: 0;
}

.acuerdos-form .form-group label {
    display: block;
    font-weight: 500;
    margin-bottom: 5px;
    font-size: 0.85rem;
    color: var(--gray-600);
}

.acuerdos-form .required {
    color: #f87171;
}

.acuerdos-form .form-row {
    display: flex;
    gap: 12px;
}

.acuerdos-form .form-row-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 12px;
}

.acuerdos-form .form-row .form-group {
    flex: 1;
}

.acuerdos-form .form-control {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    font-size: 0.9rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    background: var(--bg-input);
    color: var(--gray-800);
}

.acuerdos-form .form-control:focus {
    border-color: var(--secondary);
    outline: none;
    box-shadow: 0 0 0 3px var(--glow-gold);
}

.acuerdos-form select.form-control {
    cursor: pointer;
}

.acuerdos-form select.form-control optgroup {
    font-weight: 600;
    color: var(--secondary);
}

.acuerdos-form textarea.form-control {
    resize: vertical;
    min-height: 70px;
}

.form-actions {
    display: flex;
    gap: 10px;
    margin-top: 8px;
}

.form-actions .btn-lg {
    padding: 12px 28px;
    font-size: 1rem;
}

/* Campos condicionales */
.campos-condicionales {
    background: var(--accent-08);
    border: 1px solid var(--border-gold);
    border-radius: 8px;
    padding: 14px;
    margin-bottom: 14px;
}

.campos-condicionales h4 {
    margin: 0 0 10px 0;
    font-size: 0.9rem;
    color: var(--secondary);
}

/* Upload Zone */
.acuerdos-upload-zone {
    border: 2px dashed var(--gray-300);
    border-radius: 10px;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    background: var(--primary-light);
}

.acuerdos-upload-zone:hover,
.acuerdos-upload-zone.dragover {
    border-color: var(--secondary);
    background: var(--accent-08);
}

.acuerdos-upload-zone i {
    font-size: 1.8rem;
    color: var(--gray-400);
    margin-bottom: 6px;
}

.acuerdos-upload-zone p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--gray-500);
}

.upload-link {
    color: var(--secondary);
    text-decoration: underline;
    cursor: pointer;
}

.upload-filename {
    margin-top: 8px;
    padding: 6px 12px;
    background: rgba(16,185,129,0.15);
    border-radius: 6px;
    font-size: 0.83rem;
    color: #34d399;
    display: inline-block;
}

/* Visor wrapper & toolbar */
.visor-wrapper {
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    overflow: hidden;
    background: var(--bg-card);
}

.visor-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    background: var(--primary-light);
    border-bottom: 1px solid var(--gray-200);
}

.visor-toolbar-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--gray-700);
    display: flex;
    align-items: center;
    gap: 6px;
}

.visor-toolbar-title i {
    color: #ef4444;
}

.visor-size-controls {
    display: flex;
    align-items: center;
    gap: 4px;
}

.visor-size-btn {
    width: 28px;
    height: 28px;
    border: 1px solid var(--gray-200);
    background: var(--bg-card);
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: var(--gray-500);
    transition: all 0.15s;
}

.visor-size-btn:hover {
    background: var(--primary-light);
    border-color: var(--gray-300);
    color: var(--gray-800);
}

.visor-size-label {
    font-size: 0.72rem;
    color: var(--gray-400);
    min-width: 40px;
    text-align: center;
}

/* Visor PDF */
.acuerdos-visor-pdf {
    overflow: hidden;
    height: 500px;
    background: var(--primary-dark);
    transition: height 0.3s ease;
}

.visor-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #9ca3af;
}

.visor-placeholder i {
    font-size: 2.5rem;
    margin-bottom: 10px;
}

.visor-placeholder p {
    font-size: 0.85rem;
}

/* Verificación OCR */
.acuerdos-verificacion {
    background: rgba(245,158,11,0.1);
    border: 1px solid rgba(245,158,11,0.3);
    border-radius: 12px;
    padding: 16px;
}

.acuerdos-verificacion h4 {
    margin: 0 0 10px 0;
    color: #fbbf24;
    font-size: 0.92rem;
    display: flex;
    align-items: center;
    gap: 6px;
}

.verificacion-status {
    margin-bottom: 10px;
    font-size: 0.85rem;
}

.ocr-resultados {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ocr-campo {
    font-size: 0.83rem;
    padding: 4px 0;
}

.ocr-campo strong {
    color: var(--gray-800);
}

.ocr-raw-text {
    margin-top: 8px;
    padding: 10px;
    background: var(--primary-light);
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    font-size: 0.78rem;
    color: var(--gray-600);
    max-height: 200px;
    overflow-y: auto;
    white-space: pre-wrap;
    word-break: break-word;
}

.acuerdos-confianza-alta { font-size: 0.72rem; }
.acuerdos-confianza-media { font-size: 0.72rem; }
.acuerdos-confianza-baja { font-size: 0.72rem; }

/* Responsive */
@media (max-width: 900px) {
    .acuerdos-header {
        flex-direction: column;
        text-align: center;
    }

    .acuerdos-stats {
        justify-content: center;
    }

    .acuerdos-nuevo-layout {
        flex-direction: column;
    }

    .acuerdos-visor-col {
        position: static;
    }

    .acuerdos-form .form-row,
    .acuerdos-form .form-row-3 {
        grid-template-columns: 1fr;
        flex-direction: column;
    }

    .filtro-row {
        flex-direction: column;
    }

    .filtro-group {
        min-width: 100%;
    }
}

/* ============================================
   OCR PANEL — UltimosAcuerdos
   ============================================ */
.visor-ocr-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    background: var(--accent-15);
    border: 1px solid var(--accent-40);
    border-radius: var(--radius-sm, 6px);
    color: var(--secondary, #d4a853);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
    white-space: nowrap;
}
.visor-ocr-btn:hover {
    background: var(--accent-30);
    border-color: var(--accent-40);
}

.ocr-panel {
    background: var(--bg-card, #2a2a3d);
    border-radius: var(--radius-lg, 10px);
    padding: var(--space-4, 16px);
    margin-top: var(--space-3, 12px);
    border: 1px solid var(--accent-20);
}

.ocr-panel-header {
    display: flex;
    align-items: center;
    gap: var(--space-3, 12px);
    margin-bottom: var(--space-3, 12px);
    color: var(--secondary, #d4a853);
    font-weight: 600;
    font-size: 14px;
}
.ocr-panel-header button {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--text-muted, #888);
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
    transition: color 0.2s;
}
.ocr-panel-header button:hover {
    color: var(--text-primary, #f0f0f5);
}

.ocr-campo-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: var(--space-3, 12px);
    background: var(--primary-dark, #12121f);
    border-radius: var(--radius-md, 8px);
    margin-bottom: var(--space-2, 8px);
    border-left: 3px solid transparent;
}
.ocr-confianza-alta { border-left-color: #4caf50; }
.ocr-confianza-media { border-left-color: var(--secondary, #d4a853); }
.ocr-confianza-baja { border-left-color: #666; }

.ocr-campo-label {
    font-size: 11px;
    color: var(--text-muted, #888);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}
.ocr-campo-valor {
    font-weight: 600;
    color: var(--text-primary, #f0f0f5);
    font-size: 14px;
    white-space: pre-wrap;
    word-break: break-word;
}
.ocr-campo-nota {
    font-size: 11px;
    color: var(--text-muted, #888);
}

.ocr-confianza-alta .ocr-campo-valor { color: #4caf50; }
.ocr-confianza-media .ocr-campo-valor { color: var(--secondary, #d4a853); }
.ocr-confianza-baja .ocr-campo-valor { color: var(--text-muted, #888); font-style: italic; }

.ocr-panel-footer {
    margin-top: var(--space-4, 16px);
    display: flex;
    gap: var(--space-3, 12px);
}

.ocr-fuente-groq {
    margin-bottom: 10px;
    padding: 6px 10px;
    background: var(--accent-10);
    border-radius: 6px;
    font-size: 12px;
    color: var(--secondary, #d4a853);
    display: flex;
    align-items: center;
    gap: 6px;
}

.ocr-fuente-local {
    margin-bottom: 10px;
    padding: 6px 10px;
    background: rgba(100, 100, 130, 0.15);
    border-radius: 6px;
    font-size: 12px;
    color: var(--text-muted, #888);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Caso preview card bajo el selector de caso */
.acuerdo-caso-preview { margin-top: 8px; }

.caso-preview-card {
    background: var(--accent-08);
    border: 1px solid var(--accent-20);
    border-radius: 8px;
    padding: 10px 14px;
}

.caso-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 6px 16px;
}

.caso-preview-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.caso-preview-label {
    font-size: 0.72rem;
    color: var(--text-muted, #888);
    display: flex;
    align-items: center;
    gap: 4px;
}

.caso-preview-label i { font-size: 0.68rem; color: var(--secondary, #d4a853); }

.caso-preview-val {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-primary, #f0f0f5);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Emplazamiento multi-parte */
.empl-partes-container {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 8px;
}

.empl-parte-row {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    padding: 8px;
    background: rgba(255,255,255,0.03);
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.06);
}

.empl-parte-row .form-group { flex: 1; margin-bottom: 0; }

.empl-remove-btn {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border: 1px solid rgba(239,68,68,0.3);
    background: rgba(239,68,68,0.08);
    color: #ef4444;
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    transition: all 0.15s;
    margin-bottom: 2px;
}

.empl-remove-btn:hover { background: rgba(239,68,68,0.18); border-color: #ef4444; }

.btn-agregar-parte {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: var(--accent-10);
    border: 1px dashed var(--accent-40);
    border-radius: 6px;
    color: var(--secondary, #d4a853);
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 0.15s;
    width: 100%;
    justify-content: center;
    margin-top: 4px;
}

.btn-agregar-parte:hover { background: var(--accent-20); border-color: var(--secondary, #d4a853); }

.empl-info-tag {
    font-size: 0.7rem;
    font-weight: 400;
    color: var(--text-muted, #888);
    margin-left: 8px;
}
}

/* ============================================================
   PORTAL CLIENTES — Módulo de administración
   ============================================================ */

.portal-clientes-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 12px;
}

.portal-clientes-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 28px;
}

@media (max-width: 767px) {
    .portal-clientes-stats { grid-template-columns: repeat(2, 1fr); }
}

.portal-stat-card {
    background: var(--bg-card, #2a2a3d);
    border: 1px solid var(--accent-15);
    border-radius: 10px;
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.portal-stat-card .stat-label {
    font-size: 0.75rem;
    color: var(--text-muted, #888);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.portal-stat-card .stat-value {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--secondary, #d4a853);
    line-height: 1;
}

.portal-generar-card {
    background: var(--bg-card, #2a2a3d);
    border: 1px solid var(--accent-20);
    border-radius: 10px;
    padding: 20px 24px;
    margin-bottom: 28px;
}

.portal-generar-card h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary, #f0f0f5);
    margin: 0 0 14px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.portal-generar-card h3 i { color: var(--secondary, #d4a853); }

.portal-generar-row {
    display: flex;
    gap: 10px;
    align-items: flex-end;
    flex-wrap: wrap;
}

.portal-generar-row .portal-caso-select-wrap {
    flex: 1;
    min-width: 220px;
}

.portal-generar-row label {
    display: block;
    font-size: 0.78rem;
    color: var(--text-muted, #888);
    margin-bottom: 4px;
}

.portal-generar-row select,
.portal-generar-row input[type="text"] {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg-input, #1e1e30);
    border: 1px solid var(--accent-20);
    border-radius: 6px;
    color: var(--text-primary, #f0f0f5);
    font-size: 0.88rem;
}

.portal-generar-row select:focus,
.portal-generar-row input[type="text"]:focus {
    outline: none;
    border-color: var(--secondary, #d4a853);
}

.btn-portal-generar {
    padding: 8px 20px;
    background: var(--secondary, #d4a853);
    color: var(--gradient-start);
    border: none;
    border-radius: 6px;
    font-weight: 600;
    font-size: 0.88rem;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
}

.btn-portal-generar:hover { background: var(--secondary-light, #e8c87a); }
.btn-portal-generar:disabled { opacity: 0.55; cursor: not-allowed; }

.portal-links-table-wrap {
    background: var(--bg-card, #2a2a3d);
    border: 1px solid var(--accent-15);
    border-radius: 10px;
    overflow: hidden;
}

.portal-links-table-wrap h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary, #f0f0f5);
    margin: 0;
    padding: 16px 20px;
    border-bottom: 1px solid var(--accent-10);
    display: flex;
    align-items: center;
    gap: 8px;
}

.portal-links-table-wrap h3 i { color: var(--secondary, #d4a853); }

.portal-links-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.87rem;
}

.portal-links-table th {
    padding: 10px 16px;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-muted, #888);
    background: rgba(0,0,0,0.15);
    border-bottom: 1px solid var(--accent-10);
}

.portal-links-table td {
    padding: 11px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    color: var(--text-primary, #f0f0f5);
    vertical-align: middle;
}

.portal-links-table tr:last-child td { border-bottom: none; }

.portal-links-table tr:hover td { background: var(--bg-hover); }

.portal-link-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.73rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.portal-link-badge.activo {
    background: rgba(34,197,94,0.15);
    color: #22c55e;
    border: 1px solid rgba(34,197,94,0.3);
}

.portal-link-badge.inactivo {
    background: rgba(239,68,68,0.12);
    color: #ef4444;
    border: 1px solid rgba(239,68,68,0.25);
}

.portal-actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.portal-copy-btn,
.portal-preview-btn,
.portal-toggle-btn,
.portal-delete-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 0.78rem;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    transition: all 0.15s;
    background: transparent;
}

.portal-copy-btn {
    border-color: var(--accent-30);
    color: var(--secondary, #d4a853);
}
.portal-copy-btn:hover { background: var(--accent-10); }

.portal-preview-btn {
    border-color: rgba(99,179,237,0.35);
    color: #63b3ed;
}
.portal-preview-btn:hover { background: rgba(99,179,237,0.1); }

.portal-toggle-btn {
    border-color: rgba(167,243,208,0.3);
    color: #6ee7b7;
}
.portal-toggle-btn:hover { background: rgba(110,231,183,0.1); }
.portal-toggle-btn.desactivar { border-color: rgba(252,211,77,0.3); color: #fcd34d; }
.portal-toggle-btn.desactivar:hover { background: rgba(252,211,77,0.1); }

.portal-delete-btn {
    border-color: rgba(239,68,68,0.3);
    color: #ef4444;
}
.portal-delete-btn:hover { background: rgba(239,68,68,0.1); }

.portal-empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-muted, #888);
    font-size: 0.9rem;
}

.portal-empty-state i {
    font-size: 2.5rem;
    color: var(--accent-30);
    display: block;
    margin-bottom: 12px;
}

/* ============================================================
   REPORTES — Cards uniformes con tema dark-dorado
   ============================================================ */

.rpt-card {
    background: var(--bg-card, #2a2a3d) !important;
    border: 1px solid var(--accent-15) !important;
    border-radius: 10px !important;
    padding: 0 !important;
    overflow: hidden;
    margin-bottom: 16px !important;
    background-image: none !important;
}

.rpt-card-header {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--accent-10);
}

.rpt-card-icon {
    width: 40px; height: 40px;
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.rpt-card-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-primary, #f0f0f5);
    margin-bottom: 4px;
}

.rpt-card-desc {
    font-size: 0.82rem;
    color: var(--text-muted, #8888aa);
    line-height: 1.5;
}

.rpt-card-body {
    padding: 18px 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Botón principal dorado */
.btn-rpt-gold {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: var(--secondary, #d4a853);
    color: var(--gradient-start);
    border: none;
    border-radius: 7px;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
}
.btn-rpt-gold:hover { background: var(--secondary-light, #e8c87a); }
.btn-rpt-gold:disabled { opacity: 0.5; cursor: not-allowed; }

/* Botón outline */
.btn-rpt-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: transparent;
    color: var(--secondary, #d4a853);
    border: 1px solid var(--accent-40);
    border-radius: 7px;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}
.btn-rpt-outline:hover { background: var(--accent-08); border-color: var(--secondary, #d4a853); }

/* Fila de botones */
.rpt-btn-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* Barra de progreso */
.rpt-progress {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 12px 14px;
    background: var(--accent-08);
    border: 1px solid var(--accent-15);
    border-radius: 7px;
    font-size: 0.85rem;
    color: var(--text-muted, #8888aa);
}

.rpt-progress-bar-wrap {
    flex: 1;
    min-width: 120px;
    height: 6px;
    background: var(--accent-15);
    border-radius: 3px;
    overflow: hidden;
}

.rpt-progress-bar {
    height: 100%;
    background: var(--secondary, #d4a853);
    border-radius: 3px;
    transition: width 0.3s;
}

/* Filtros en línea */
.rpt-filters-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 4px;
}

.rpt-filter-group {
    flex: 1;
    min-width: 180px;
}

.rpt-filter-group label {
    display: block;
    font-size: 0.78rem;
    color: var(--text-muted, #8888aa);
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.rpt-select {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg-input, #1e1e30);
    border: 1px solid var(--accent-20);
    border-radius: 6px;
    color: var(--text-primary, #f0f0f5);
    font-size: 0.87rem;
}
.rpt-select:focus { outline: none; border-color: var(--secondary, #d4a853); }

/* Grid LEGO */
.rpt-lego-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

@media (max-width: 600px) {
    .rpt-lego-grid { grid-template-columns: 1fr; }
    .rpt-btn-row { flex-direction: column; }
}

.rpt-lego-item {
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--accent-10);
    border-radius: 8px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.rpt-lego-label {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--text-primary, #f0f0f5);
    display: flex;
    align-items: center;
    gap: 7px;
}

.rpt-lego-desc {
    font-size: 0.78rem;
    color: var(--text-muted, #8888aa);
    margin-bottom: 8px;
}

/* =============================================================
   OVERRIDES TEMA CLARO — corrige selectores con text hardcodeado
   ============================================================= */

/* Títulos y encabezados principales */
[data-theme="light"] .detail-section h4,
[data-theme="light"] .calendar-controls h3,
[data-theme="light"] .audiencias-list h3,
[data-theme="light"] .case-view-title h2,
[data-theme="light"] .audiencia-info h4,
[data-theme="light"] .timeline-content h4,
[data-theme="light"] .peticion-card-header h4,
[data-theme="light"] .report-summary h2,
[data-theme="light"] .report-chart h3 {
    color: var(--text-heading);
}

/* Valores y texto de cuerpo */
[data-theme="light"] .case-detail-value,
[data-theme="light"] .peticion-info-value {
    color: var(--text-body);
}

/* Inputs globales: texto visible en ambos temas */
[data-theme="light"] input:not([type="checkbox"]):not([type="radio"]):not([type="range"]),
[data-theme="light"] select,
[data-theme="light"] textarea {
    color: var(--text-body);
    background-color: var(--bg-input);
}
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder {
    color: var(--text-muted);
    opacity: 1;
}

/* Tablas de módulos */
[data-theme="light"] .ap-audiencias-table td,
[data-theme="light"] .data-table td {
    color: var(--text-body);
}
[data-theme="light"] .ap-audiencias-table th {
    color: #ffffff;
}

/* Badges de estado */
[data-theme="light"] .badge-penal,
[data-theme="light"] .badge-penal-sentencia,
[data-theme="light"] .badge-penal-salida {
    color: #ffffff;
}

/* =============================================================
   GENERADOR DE DEMANDA CIVIL — estilos .dem-*
   ============================================================= */

.dem-subseccion {
    background: var(--bg-input);
    border-radius: 10px;
    padding: 16px 20px;
    margin-bottom: 18px;
    border-left: 4px solid #8e44ad;
}

.dem-subseccion h4 {
    font-size: 13px;
    font-weight: 700;
    color: #8e44ad;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0 0 14px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.dem-array-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr auto;
    gap: 8px;
    align-items: end;
    margin-bottom: 8px;
}

.dem-array-row input,
.dem-array-row select {
    width: 100%;
}

.dem-array-row button {
    background: #e74c3c;
    color: white;
    border: none;
    border-radius: 6px;
    padding: 6px 10px;
    cursor: pointer;
    white-space: nowrap;
}

.dem-array-row button:hover {
    background: #c0392b;
}

.dem-add-btn {
    background: none;
    border: 1px dashed #8e44ad;
    color: #8e44ad;
    border-radius: 6px;
    padding: 6px 14px;
    cursor: pointer;
    font-size: 12px;
    margin-top: 4px;
    transition: background 0.2s;
}

.dem-add-btn:hover {
    background: rgba(142, 68, 173, 0.08);
}

/* =============================================================
   INVENTARIO DE EQUIPOS
   ============================================================= */

.inv-container {
    padding: 24px;
    max-width: 1400px;
}

/* Tabs de inventario */
.inv-tab-bar {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid rgba(255,255,255,0.08);
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.inv-tab-btn {
    padding: 10px 22px;
    border: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    background: transparent;
    color: #888;
    cursor: pointer;
    font-size: .9rem;
    font-weight: 600;
    transition: color .2s, border-color .2s;
    border-radius: 6px 6px 0 0;
}
.inv-tab-btn:hover { color: #d4a853; background: rgba(212,168,83,.06); }
.inv-tab-active    { color: #d4a853 !important; border-bottom-color: #d4a853 !important; }

/* Header */
.inv-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 12px;
}

.inv-title {
    font-size: 1.6rem;
    color: var(--primary, #1a1a2e);
    margin: 0;
}

.inv-subtitle {
    color: #666;
    margin: 4px 0 0;
    font-size: 0.9rem;
}

/* Buttons */
.inv-btn-primary {
    background: var(--secondary, #d4a853);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 9px 18px;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    transition: opacity 0.15s;
}
.inv-btn-primary:hover { opacity: 0.88; }

.inv-btn-secondary {
    background: #fff;
    color: var(--primary, #1a1a2e);
    border: 1px solid #ccc;
    border-radius: 8px;
    padding: 9px 18px;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    transition: background 0.15s;
}
.inv-btn-secondary:hover { background: #f5f5f5; }

/* Stats */
.inv-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}

.inv-stat-card {
    background: #fff;
    border-radius: 10px;
    padding: 16px 12px;
    text-align: center;
    border: 1px solid #eee;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.inv-stat-ico {
    font-size: 1.3rem;
    color: #aaa;
    margin-bottom: 6px;
    display: block;
}

.inv-stat-num {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--primary, #1a1a2e);
    line-height: 1;
}

.inv-stat-lbl {
    font-size: 0.72rem;
    color: #888;
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

/* Filtros */
.inv-filtros {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 10px;
    padding: 14px 18px;
    margin-bottom: 16px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.inv-input,
.inv-select {
    border: 1px solid #ddd;
    border-radius: 7px;
    padding: 8px 12px;
    font-size: 0.9rem;
    background: #fafafa;
    transition: border-color 0.15s;
}

.inv-filtros .inv-input  { flex: 2; min-width: 200px; }
.inv-filtros .inv-select { flex: 1; min-width: 140px; }

.inv-input:focus,
.inv-select:focus {
    outline: none;
    border-color: var(--secondary, #d4a853);
    background: #fff;
}

/* Resultado count */
.inv-resultado {
    font-size: 0.82rem;
    color: #888;
    margin-bottom: 10px;
}

/* Table */
.inv-table-wrapper {
    background: #fff;
    border-radius: 10px;
    border: 1px solid #eee;
    overflow: hidden;
    overflow-x: auto;
}

.inv-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.inv-table thead th {
    background: var(--primary, #1a1a2e);
    color: #fff;
    padding: 11px 14px;
    text-align: left;
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
}

.inv-table tbody tr {
    border-bottom: 1px solid #f0f0f0;
    transition: background 0.15s;
}

.inv-table tbody tr:hover { background: #fafbff; }

.inv-table td {
    padding: 10px 14px;
    vertical-align: middle;
}

.inv-tipo-cell {
    display: flex;
    align-items: center;
    gap: 7px;
}

.inv-tipo-ico {
    font-size: 1rem;
    color: #888;
}

.inv-serie {
    font-family: monospace;
    font-size: 0.82rem;
    background: #f4f4f4;
    padding: 2px 6px;
    border-radius: 4px;
    color: #555;
}

.inv-row-actions {
    display: flex;
    gap: 6px;
}

.inv-btn-icon {
    background: none;
    border: 1px solid #ddd;
    border-radius: 6px;
    padding: 5px 9px;
    cursor: pointer;
    color: #555;
    font-size: 0.85rem;
    transition: background 0.15s, color 0.15s;
}
.inv-btn-icon:hover { background: #f0f4ff; color: var(--primary, #1a1a2e); border-color: #aac; }

.inv-btn-icon-del { border-color: #fcc; color: #c0392b; }
.inv-btn-icon-del:hover { background: #fff0f0; border-color: #e74c3c; color: #e74c3c; }

/* Empty state */
.inv-empty {
    text-align: center;
    padding: 48px 24px;
    color: #aaa;
}

.inv-empty i {
    font-size: 2.5rem;
    display: block;
    margin-bottom: 12px;
}

/* Badges */
.inv-badge {
    display: inline-block;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 0.73rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.inv-badge-activo  { background: #dcfce7; color: #166534; }
.inv-badge-mant    { background: #fef3c7; color: #92400e; }
.inv-badge-ret     { background: #fee2e2; color: #991b1b; }

/* Form */
.inv-form-card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 10px;
    padding: 28px;
    max-width: 780px;
}

.inv-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.inv-fg {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.inv-fg-full {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.inv-fg label,
.inv-fg-full label {
    font-size: 0.8rem;
    font-weight: 600;
    color: #555;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.inv-req { color: #e74c3c; margin-left: 2px; }

.inv-fg .inv-input,
.inv-fg .inv-select,
.inv-fg-full .inv-input,
.inv-fg-full .inv-select,
.inv-textarea {
    border: 1px solid #ddd;
    border-radius: 7px;
    padding: 9px 12px;
    font-size: 0.9rem;
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.15s;
    background: #fafafa;
}

.inv-fg .inv-input:focus,
.inv-fg .inv-select:focus,
.inv-fg-full .inv-input:focus,
.inv-fg-full .inv-select:focus,
.inv-textarea:focus {
    outline: none;
    border-color: var(--secondary, #d4a853);
    background: #fff;
}

.inv-textarea {
    resize: vertical;
    min-height: 80px;
}

.inv-form-actions {
    display: flex;
    gap: 10px;
    margin-top: 24px;
}

@media (max-width: 600px) {
    .inv-form-grid  { grid-template-columns: 1fr; }
    .inv-stats      { grid-template-columns: repeat(3, 1fr); }
    .inv-filtros    { flex-direction: column; }
    .inv-filtros .inv-input,
    .inv-filtros .inv-select { width: 100%; }
}

/* ============================================
   PERICIALES — Detalle expandible de audiencia
   ============================================ */

.pericial-detalle-contenido {
    padding: 10px 4px;
    font-size: 13px;
    color: var(--gray-700);
}

.detalle-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.detalle-row b {
    white-space: nowrap;
    min-width: 60px;
    color: var(--gray-800);
}

.partes-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.parte-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 14px;
    font-size: 12px;
    font-weight: 600;
}

.parte-badge.actor {
    background: #d4efdf;
    color: #1e8449;
}

.parte-badge.demandado {
    background: #fadbd8;
    color: #922b21;
}

.parte-badge.vehiculo {
    background: #d6eaf8;
    color: #1a5276;
}

.peritos-para-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.perito-para-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 14px;
    font-size: 12px;
    font-weight: 600;
    background: var(--accent-15);
    color: var(--gray-700);
}

.perito-para-badge em {
    font-style: normal;
    font-size: 11px;
    opacity: 0.8;
}

.perito-para-badge.ratificar {
    background: #fef9e7;
    color: #b7950b;
}

.perito-para-badge.pericial {
    background: #eaf4fb;
    color: #1f618d;
}

.cuestionarios-section {
    flex-direction: column;
    align-items: flex-start;
}

.cuestionario-perito-bloque {
    margin-top: 6px;
    padding: 8px 12px;
    background: var(--bg-input, #f4f6f7);
    border-radius: 6px;
    width: 100%;
}

.cuest-perito-titulo {
    font-weight: 700;
    font-size: 12px;
    color: var(--gray-800);
    margin-bottom: 4px;
}

.cuest-preguntas-lista {
    margin: 0;
    padding-left: 18px;
    font-size: 12px;
    color: var(--gray-700);
}

.cuest-preguntas-lista li {
    margin-bottom: 3px;
}
