/* ============================================
   DCCAE - Estilos globales
============================================ */

.dccae-wrapper * { box-sizing: border-box; }
.dccae-wrapper form { margin: 0 !important; padding: 0 !important; }

/* --- Caja formulario --- */
.crud-box-dccae {
    max-width: 700px;
    margin: 30px auto;
    padding: 30px;
    background: #ffffff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
.crud-box-dccae h2 { margin: 0 0 8px 0; color: #333; font-size: 22px; font-weight: 600; }
.crud-box-dccae .subtitulo { color: #888; font-size: 14px; margin: 0 0 24px 0; }

/* --- Campos --- */
.dccae-wrapper .campo { margin-bottom: 18px; }
.dccae-wrapper label { display: block; margin-bottom: 6px; font-weight: 600; color: #444; font-size: 14px; }

.dccae-wrapper input[type="text"],
.dccae-wrapper input[type="number"],
.dccae-wrapper input[type="date"],
.dccae-wrapper select {
    width: 100%; padding: 10px 14px; border: 2px solid #ddd;
    border-radius: 6px; font-size: 14px; background: #fff; transition: border-color 0.2s;
}
.dccae-wrapper input:focus,
.dccae-wrapper select:focus {
    outline: none; border-color: #4CAF50; box-shadow: 0 0 0 3px rgba(76,175,80,0.1);
}
.dccae-wrapper input[readonly] { background-color: #f5f5f5; cursor: not-allowed; color: #666; }

/* --- Botones --- */
.btn-primario-dccae {
    background-color: #4CAF50 !important; color: white !important;
    padding: 12px 28px !important; border: none !important; border-radius: 6px !important;
    cursor: pointer !important; font-size: 15px !important; font-weight: 600 !important;
    width: 100% !important; transition: background-color 0.3s ease !important; margin-top: 10px !important;
}
.btn-primario-dccae:hover { background-color: #45a049 !important; }

.btn-secundario-dccae {
    background-color: #6c757d !important; color: white !important;
    padding: 10px 24px !important; border: none !important; border-radius: 6px !important;
    cursor: pointer !important; font-size: 14px !important; font-weight: 500 !important;
    width: 100% !important; transition: background-color 0.3s ease !important; margin-top: 8px !important;
}
.btn-secundario-dccae:hover { background-color: #5a6268 !important; }

.btn-pdf-dccae {
    background-color: #4CAF50 !important; color: white !important;
    padding: 10px 24px !important; border: none !important; border-radius: 6px !important;
    cursor: pointer !important; font-size: 14px !important; font-weight: 600 !important;
    width: 100% !important; transition: background-color 0.3s ease !important; margin-top: 8px !important;
}
.btn-pdf-dccae:hover { background-color: #45a049 !important; }
.btn-pdf-dccae:disabled { background-color: #cccccc !important; cursor: not-allowed !important; }

/* --- Mensajes resultado --- */
.resultado-dccae {
    padding: 12px 16px; border-radius: 6px; font-size: 14px;
    font-weight: 500; margin-bottom: 16px; display: none;
}
.resultado-dccae.ok  { background: #d7ffd7; border: 2px solid #4caf50; color: #2e7d32; display: block; }
.resultado-dccae.error { background: #ffd7d7; border: 2px solid #f44336; color: #c62828; display: block; }

/* --- Info boxes --- */
.info-box-dccae { padding: 12px 15px; border-radius: 4px; font-size: 14px; margin-bottom: 20px; }
.info-box-dccae.verde { background: #e8f5e9; border-left: 4px solid #4CAF50; color: #2e7d32; }
.info-box-dccae.azul  { background: #e3f2fd; border-left: 4px solid #2196F3; color: #1565c0; }

/* ============================================
   LISTADO
============================================ */
.listado-dccae-wrapper {
    max-width: 100% !important; width: 100% !important;
    margin: 20px auto !important; padding: 0 15px !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    overflow-x: hidden !important;
}
.listado-dccae-wrapper h2 {
    color: #333 !important; font-size: 22px !important; font-weight: 600 !important;
    margin: 0 0 20px 0 !important; padding: 0 0 14px 0 !important;
    border-bottom: 3px solid #4CAF50 !important;
}

/* Filtros */
.filtros-dccae {
    display: flex !important; flex-wrap: wrap !important; gap: 12px !important;
    align-items: flex-end !important; margin-bottom: 20px !important;
    background: #f9f9f9 !important; padding: 16px !important;
    border-radius: 8px !important; border: 1px solid #e0e0e0 !important;
}
.filtros-dccae .campo {
    display: flex !important; flex-direction: column !important;
    min-width: 160px !important; flex: 1 !important; margin-bottom: 0 !important;
}
.filtros-dccae label { font-size: 12px !important; font-weight: 600 !important; color: #555 !important; margin-bottom: 4px !important; }
.filtros-dccae input { padding: 9px 12px !important; border: 2px solid #ddd !important; border-radius: 6px !important; font-size: 13px !important; height: 40px !important; }
.filtros-dccae .acciones { display: flex !important; gap: 8px !important; align-items: flex-end !important; flex-wrap: wrap !important; }

.btn-buscar-dccae {
    background-color: #9C27B0 !important; color: white !important; padding: 0 20px !important;
    border: none !important; border-radius: 6px !important; cursor: pointer !important;
    font-size: 13px !important; font-weight: 600 !important; height: 40px !important;
    white-space: nowrap !important; transition: background-color 0.3s !important;
}
.btn-buscar-dccae:hover { background-color: #7B1FA2 !important; }

.btn-exportar-dccae {
    background-color: #2196F3 !important; color: white !important; padding: 0 20px !important;
    border: none !important; border-radius: 6px !important; cursor: pointer !important;
    font-size: 13px !important; font-weight: 600 !important; height: 40px !important;
    white-space: nowrap !important; transition: background-color 0.3s !important;
    text-decoration: none !important; display: inline-flex !important; align-items: center !important;
}
.btn-exportar-dccae:hover { background-color: #0b7dda !important; color: white !important; }

.btn-limpiar-dccae {
    background-color: #757575 !important; color: white !important; padding: 0 16px !important;
    border: none !important; border-radius: 6px !important; cursor: pointer !important;
    font-size: 13px !important; font-weight: 600 !important; height: 40px !important;
    white-space: nowrap !important; transition: background-color 0.3s !important;
    text-decoration: none !important; display: inline-flex !important; align-items: center !important;
}
.btn-limpiar-dccae:hover { background-color: #616161 !important; color: white !important; }

/* Tabla */
.tabla-dccae-wrapper {
    overflow-x: auto !important; background: #ffffff !important;
    border-radius: 8px !important; box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    margin-bottom: 16px !important; -webkit-overflow-scrolling: touch !important;
}
.tabla-dccae { width: 100% !important; border-collapse: collapse !important; font-size: 13px !important; margin: 0 !important; }
.tabla-dccae thead th {
    background-color: #4CAF50 !important; color: white !important; font-weight: 600 !important;
    padding: 12px 10px !important; text-align: center !important; white-space: nowrap !important; font-size: 13px !important;
}
.tabla-dccae tbody td {
    padding: 10px !important; border-bottom: 1px solid #e0e0e0 !important;
    vertical-align: middle !important; text-align: center !important; font-size: 13px !important;
}
.tabla-dccae tbody tr:nth-child(even) { background-color: #f9f9f9 !important; }
.tabla-dccae tbody tr:hover { background-color: #e8f5e9 !important; }

.sin-registros-dccae { text-align: center !important; padding: 40px 20px !important; color: #888 !important; font-size: 15px !important; }

/* Acciones */
.acciones-dccae { display: flex !important; gap: 6px !important; align-items: center !important; justify-content: center !important; }
.btn-icono-dccae {
    background-color: #ff9800 !important; color: white !important; padding: 6px 10px !important;
    border-radius: 5px !important; display: inline-flex !important; align-items: center !important;
    justify-content: center !important; border: none !important; cursor: pointer !important;
    font-size: 15px !important; min-width: 34px !important; height: 34px !important;
    margin: 0 !important; transition: background-color 0.3s !important;
}
.btn-icono-dccae:hover { background-color: #e68900 !important; }
.btn-icono-dccae.pdf  { background-color: #4CAF50 !important; }
.btn-icono-dccae.pdf:hover { background-color: #45a049 !important; }
.btn-icono-dccae:disabled { background-color: #ccc !important; cursor: not-allowed !important; }

/* Paginación */
.paginacion-dccae {
    display: flex !important; justify-content: center !important; align-items: center !important;
    gap: 6px !important; margin-top: 16px !important; flex-wrap: wrap !important;
}
.paginacion-dccae button {
    padding: 8px 14px !important; border: 2px solid #4CAF50 !important; border-radius: 6px !important;
    background: white !important; color: #4CAF50 !important; font-weight: 600 !important;
    font-size: 13px !important; cursor: pointer !important; transition: all 0.2s !important;
}
.paginacion-dccae button:hover,
.paginacion-dccae button.activo { background-color: #4CAF50 !important; color: white !important; }

/* Formulario edición inline */
#form-edicion-dccae { max-width: 700px; margin: 20px auto 0; }

/* ============================================
   RESPONSIVE
============================================ */
@media (max-width: 768px) {
    .filtros-dccae { flex-direction: column !important; }
    .filtros-dccae .campo { min-width: 100% !important; }
    .filtros-dccae .acciones { width: 100% !important; }
    .btn-buscar-dccae, .btn-exportar-dccae, .btn-limpiar-dccae { width: 100% !important; justify-content: center !important; }
    .tabla-dccae thead th, .tabla-dccae tbody td { padding: 7px 5px !important; font-size: 11px !important; }
    .btn-icono-dccae { min-width: 30px !important; height: 30px !important; font-size: 13px !important; }
    .crud-box-dccae { padding: 20px 16px !important; }
}
@media (max-width: 480px) {
    .tabla-dccae thead th, .tabla-dccae tbody td { padding: 5px 3px !important; font-size: 10px !important; }
}
