/* ========================================
   Filament Soft Theme - Colores Suaves y Claros
   ======================================== */

/* Variables CSS para colores suaves */
:root {
    --soft-primary: #0ea5e9;      /* Azul cielo */
    --soft-primary-light: #bae6fd; /* Azul muy claro */
    --soft-background: #fafafa;    /* Gris casi blanco */
    --soft-surface: #ffffff;       /* Blanco puro */
    --soft-border: #e5e7eb;        /* Gris muy suave */
    --soft-text: #374151;          /* Gris oscuro suave */
    --soft-text-light: #6b7280;    /* Gris medio */
    --soft-success: #10b981;       /* Verde menta */
    --soft-warning: #f59e0b;       /* Amarillo dorado */
    --soft-danger: #ef4444;        /* Rosa/Rojo suave */
    --soft-info: #8b5cf6;          /* Violeta suave */
    --soft-shadow: rgba(0, 0, 0, 0.05); /* Sombra muy suave */

    /* Override Filament variables */
    --primary-50: 240, 249, 255 !important;
    --primary-100: 224, 242, 254 !important;
    --primary-200: 186, 230, 253 !important;
    --primary-300: 125, 211, 252 !important;
    --primary-400: 56, 189, 248 !important;
    --primary-500: 14, 165, 233 !important;
    --primary-600: 2, 132, 199 !important;
    --primary-700: 3, 105, 161 !important;
    --primary-800: 7, 89, 133 !important;
    --primary-900: 12, 74, 110 !important;
}

/* ==========================================
   ESTILOS GENERALES
   ========================================== */

/* Fondo general más claro */
.fi-layout {
    background: linear-gradient(135deg, #f0f9ff 0%, #fafafa 100%) !important;
    min-height: 100vh;
}

/* Contenido principal con fondo blanco */
.fi-main {
    background-color: var(--soft-surface) !important;
    border-radius: 16px;
    margin: 1rem;
    box-shadow: 0 1px 3px var(--soft-shadow);
}

/* ==========================================
   SIDEBAR - Diseño Minimalista Claro
   ========================================== */

/* Sidebar con fondo claro */
.fi-sidebar {
    background: linear-gradient(180deg, #ffffff 0%, #f9fafb 100%) !important;
    border-right: 1px solid var(--soft-border) !important;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.03) !important;
}

/* Logo área */
.fi-sidebar-header {
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--soft-border) !important;
    padding: 1.25rem !important;
}

/* Items de navegación */
.fi-sidebar-nav {
    padding: 1rem 0.75rem !important;
}

.fi-sidebar-item {
    margin-bottom: 0.25rem !important;
}

.fi-sidebar-item a {
    color: var(--soft-text) !important;
    background: transparent !important;
    border-radius: 12px !important;
    transition: all 0.2s ease !important;
    padding: 0.625rem 1rem !important;
    font-weight: 500 !important;
}

.fi-sidebar-item a:hover {
    background: var(--soft-primary-light) !important;
    color: var(--soft-primary) !important;
    transform: translateX(2px);
}

.fi-sidebar-item-active > a {
    background: linear-gradient(135deg, #dbeafe 0%, #bae6fd 100%) !important;
    color: var(--soft-primary) !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(14, 165, 233, 0.15) !important;
}

/* Grupos de navegación */
.fi-sidebar-group {
    margin-bottom: 1.5rem !important;
}

.fi-sidebar-group-label {
    color: var(--soft-text-light) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    padding: 0.5rem 1rem !important;
    opacity: 0.7;
}

/* ==========================================
   TOPBAR - Diseño Limpio
   ========================================== */

.fi-topbar {
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    border-bottom: 1px solid var(--soft-border) !important;
    box-shadow: 0 1px 3px var(--soft-shadow) !important;
    padding: 0.75rem 1.5rem !important;
}

/* Búsqueda global */
.fi-global-search-field {
    background: var(--soft-background) !important;
    border: 1px solid var(--soft-border) !important;
    border-radius: 10px !important;
}

.fi-global-search-field:focus {
    border-color: var(--soft-primary-light) !important;
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1) !important;
}

/* ==========================================
   CARDS Y WIDGETS - Estilo Suave
   ========================================== */

.fi-widget {
    background: var(--soft-surface) !important;
    border: 1px solid var(--soft-border) !important;
    border-radius: 16px !important;
    box-shadow: 0 1px 3px var(--soft-shadow) !important;
    transition: all 0.3s ease !important;
}

.fi-widget:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
    transform: translateY(-2px);
}

.fi-stats-overview-stat {
    background: linear-gradient(135deg, #ffffff 0%, #f9fafb 100%) !important;
    border: 1px solid var(--soft-border) !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
}

.fi-stats-overview-stat-value {
    color: var(--soft-primary) !important;
    font-size: 2rem !important;
    font-weight: 700 !important;
}

.fi-stats-overview-stat-label {
    color: var(--soft-text-light) !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
}

/* ==========================================
   TABLAS - Diseño Minimalista
   ========================================== */

.fi-ta-table {
    background: var(--soft-surface) !important;
    border: 1px solid var(--soft-border) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

.fi-ta-table thead {
    background: linear-gradient(180deg, #f9fafb 0%, #f3f4f6 100%) !important;
    border-bottom: 2px solid var(--soft-border) !important;
}

.fi-ta-table th {
    color: var(--soft-text) !important;
    font-weight: 600 !important;
    font-size: 0.875rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.025em !important;
    padding: 1rem !important;
}

.fi-ta-table tbody tr {
    border-bottom: 1px solid var(--soft-border) !important;
    transition: all 0.2s ease !important;
}

.fi-ta-table tbody tr:hover {
    background: var(--soft-background) !important;
}

.fi-ta-table td {
    color: var(--soft-text) !important;
    padding: 1rem !important;
    font-size: 0.875rem !important;
}

/* ==========================================
   BOTONES - Estilo Suave
   ========================================== */

.fi-btn {
    border-radius: 10px !important;
    font-weight: 600 !important;
    transition: all 0.2s ease !important;
    text-transform: none !important;
    box-shadow: 0 1px 2px var(--soft-shadow) !important;
}

.fi-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1) !important;
}

/* Botón primario */
.fi-btn-primary,
.fi-ac-btn-action {
    background: linear-gradient(135deg, #3b82f6 0%, #0ea5e9 100%) !important;
    border: none !important;
    color: white !important;
}

.fi-btn-primary:hover,
.fi-ac-btn-action:hover {
    background: linear-gradient(135deg, #2563eb 0%, #0284c7 100%) !important;
}

/* Botón secundario */
.fi-btn-secondary {
    background: var(--soft-background) !important;
    border: 1px solid var(--soft-border) !important;
    color: var(--soft-text) !important;
}

.fi-btn-secondary:hover {
    background: var(--soft-border) !important;
}

/* ==========================================
   FORMULARIOS - Inputs Suaves
   ========================================== */

.fi-input,
.fi-select-input,
.fi-textarea {
    background: var(--soft-surface) !important;
    border: 1.5px solid var(--soft-border) !important;
    border-radius: 10px !important;
    color: var(--soft-text) !important;
    transition: all 0.2s ease !important;
    font-size: 0.875rem !important;
}

.fi-input:focus,
.fi-select-input:focus,
.fi-textarea:focus {
    border-color: var(--soft-primary) !important;
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1) !important;
    outline: none !important;
}

/* Labels */
.fi-fo-field-wrp-label {
    color: var(--soft-text) !important;
    font-weight: 600 !important;
    font-size: 0.875rem !important;
    margin-bottom: 0.5rem !important;
}

/* ==========================================
   MODALES - Diseño Limpio
   ========================================== */

.fi-modal {
    background: var(--soft-surface) !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15) !important;
}

.fi-modal-header {
    background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%) !important;
    border-bottom: 1px solid var(--soft-border) !important;
    padding: 1.5rem !important;
    border-radius: 16px 16px 0 0 !important;
}

.fi-modal-heading {
    color: var(--soft-primary) !important;
    font-weight: 700 !important;
    font-size: 1.25rem !important;
}

/* ==========================================
   NOTIFICACIONES - Estilo Suave
   ========================================== */

.fi-notification {
    background: var(--soft-surface) !important;
    border: 1px solid var(--soft-border) !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

.fi-notification-success {
    border-left: 4px solid var(--soft-success) !important;
    background: linear-gradient(90deg, #ecfdf5 0%, #ffffff 100%) !important;
}

.fi-notification-warning {
    border-left: 4px solid var(--soft-warning) !important;
    background: linear-gradient(90deg, #fffbeb 0%, #ffffff 100%) !important;
}

.fi-notification-danger {
    border-left: 4px solid var(--soft-danger) !important;
    background: linear-gradient(90deg, #fef2f2 0%, #ffffff 100%) !important;
}

.fi-notification-info {
    border-left: 4px solid var(--soft-info) !important;
    background: linear-gradient(90deg, #f5f3ff 0%, #ffffff 100%) !important;
}

/* ==========================================
   BADGES - Estilo Minimalista
   ========================================== */

.fi-badge {
    border-radius: 20px !important;
    padding: 0.25rem 0.75rem !important;
    font-weight: 600 !important;
    font-size: 0.75rem !important;
}

.fi-badge-primary {
    background: rgba(14, 165, 233, 0.1) !important;
    color: var(--soft-primary) !important;
    border: 1px solid rgba(14, 165, 233, 0.2) !important;
}

.fi-badge-success {
    background: rgba(16, 185, 129, 0.1) !important;
    color: var(--soft-success) !important;
    border: 1px solid rgba(16, 185, 129, 0.2) !important;
}

.fi-badge-warning {
    background: rgba(245, 158, 11, 0.1) !important;
    color: var(--soft-warning) !important;
    border: 1px solid rgba(245, 158, 11, 0.2) !important;
}

.fi-badge-danger {
    background: rgba(239, 68, 68, 0.1) !important;
    color: var(--soft-danger) !important;
    border: 1px solid rgba(239, 68, 68, 0.2) !important;
}

/* ==========================================
   SCROLLBAR - Personalizada
   ========================================== */

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--soft-background);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb {
    background: var(--soft-border);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--soft-text-light);
}

/* ==========================================
   ANIMACIONES SUAVES
   ========================================== */

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fi-page-header,
.fi-widget,
.fi-ta-table {
    animation: fadeIn 0.3s ease-out;
}

/* ==========================================
   RESPONSIVE AJUSTES
   ========================================== */

@media (max-width: 1024px) {
    .fi-sidebar {
        background: rgba(255, 255, 255, 0.98) !important;
    }
}

@media (max-width: 768px) {
    .fi-main {
        margin: 0.5rem;
        border-radius: 12px;
    }

    .fi-widget {
        border-radius: 12px !important;
    }
}

/* ==========================================
   EFECTOS HOVER ADICIONALES
   ========================================== */

/* Efecto glow suave en focus */
*:focus-visible {
    outline: 2px solid var(--soft-primary-light) !important;
    outline-offset: 2px !important;
}

/* Links con transición suave */
a {
    transition: color 0.2s ease !important;
}

a:hover {
    color: var(--soft-primary) !important;
}

/* ==========================================
   BREADCRUMBS - Estilo Minimalista
   ========================================== */

.fi-breadcrumbs {
    background: var(--soft-background) !important;
    padding: 0.75rem 1rem !important;
    border-radius: 8px !important;
    margin-bottom: 1rem !important;
}

.fi-breadcrumbs-item {
    color: var(--soft-text-light) !important;
}

.fi-breadcrumbs-item-active {
    color: var(--soft-primary) !important;
    font-weight: 600 !important;
}

/* ==========================================
   SECCIONES Y PANELES
   ========================================== */

.fi-section {
    background: var(--soft-surface) !important;
    border: 1px solid var(--soft-border) !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}

.fi-section-heading {
    color: var(--soft-text) !important;
    font-weight: 700 !important;
    font-size: 1.125rem !important;
    margin-bottom: 1rem !important;
}

/* ==========================================
   TOPBAR PERSONALIZADO - Integración con tema suave
   ========================================== */

/* El topbar usa el componente por defecto de Filament con estilos personalizados */

/* El topbar ahora está completamente integrado en el componente por defecto de Filament */

/* ==========================================
   AJUSTES ADICIONALES FILAMENT
   ========================================== */

/* Panel de login más suave */
.fi-login-panel {
    background: linear-gradient(135deg, #f0f9ff 0%, #ffffff 100%) !important;
    box-shadow: 0 10px 40px rgba(14, 165, 233, 0.05) !important;
}

/* Dashboard widgets con bordes suaves */
.fi-wi-stats-overview-card {
    border: 1px solid rgba(14, 165, 233, 0.1) !important;
    background: linear-gradient(135deg, #ffffff 0%, #f0f9ff 100%) !important;
}

/* Mejora en los tooltips */
.fi-tooltip {
    background: rgba(255, 255, 255, 0.95) !important;
    color: var(--soft-text) !important;
    border: 1px solid var(--soft-border) !important;
    backdrop-filter: blur(10px) !important;
}

/* Tabs más elegantes */
.fi-tabs-item {
    color: var(--soft-text-light) !important;
    border-bottom: 2px solid transparent !important;
    transition: all 0.3s ease !important;
}

.fi-tabs-item:hover {
    color: var(--soft-primary) !important;
    background: var(--soft-background) !important;
}

.fi-tabs-item-active {
    color: var(--soft-primary) !important;
    border-bottom-color: var(--soft-primary) !important;
}

/* Dropdowns más suaves */
.fi-dropdown-panel {
    background: rgba(255, 255, 255, 0.98) !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid var(--soft-border) !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08) !important;
}

/* Avatares con borde suave */
.fi-avatar {
    border: 2px solid var(--soft-border) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
}

/* Mejora en los iconos */
.fi-icon {
    transition: transform 0.2s ease !important;
}

.fi-icon:hover {
    transform: scale(1.1);
}

/* Loading states más elegantes */
.fi-loading-indicator {
    color: var(--soft-primary) !important;
}

/* Breadcrumbs mejorados */
.fi-breadcrumbs-item-separator {
    color: var(--soft-border) !important;
}

/* Mejora en paginación */
.fi-pagination-item {
    border: 1px solid var(--soft-border) !important;
    transition: all 0.2s ease !important;
}

.fi-pagination-item:hover {
    background: var(--soft-primary-light) !important;
    border-color: var(--soft-primary) !important;
}

.fi-pagination-item-active {
    background: var(--soft-primary) !important;
    color: white !important;
    border-color: var(--soft-primary) !important;
}

/* ==========================================
   FIN DEL TEMA SOFT
   ========================================== */