/* Google Fonts - Must be at the top */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap');

/**
 * ============================================================================
 * SERYNT DESIGN SYSTEM v1.0
 * Sistema de diseño basado en la identidad visual del logo de Serynt
 * ============================================================================
 *
 * Paleta extraída del logo:
 * - Azul Cielo (#0EA5E9) - Parte superior
 * - Azul Océano (#0284C7) - Transición
 * - Teal/Turquesa (#14B8A6) - Centro
 * - Verde Esmeralda (#10B981) - Parte inferior
 * - Azul Marino (#0F172A) - Texto del logo
 */

/* ============================================================================
   CSS CUSTOM PROPERTIES (Variables)
   ============================================================================ */

:root {
    /* ========== COLORES PRIMARIOS (del logo) ========== */

    /* Azul Cielo - Color principal de marca */
    --serynt-sky-50: #f0f9ff;
    --serynt-sky-100: #e0f2fe;
    --serynt-sky-200: #bae6fd;
    --serynt-sky-300: #7dd3fc;
    --serynt-sky-400: #38bdf8;
    --serynt-sky-500: #0ea5e9;  /* Principal */
    --serynt-sky-600: #0284c7;
    --serynt-sky-700: #0369a1;
    --serynt-sky-800: #075985;
    --serynt-sky-900: #0c4a6e;

    /* Teal - Color secundario */
    --serynt-teal-50: #f0fdfa;
    --serynt-teal-100: #ccfbf1;
    --serynt-teal-200: #99f6e4;
    --serynt-teal-300: #5eead4;
    --serynt-teal-400: #2dd4bf;
    --serynt-teal-500: #14b8a6;  /* Secundario */
    --serynt-teal-600: #0d9488;
    --serynt-teal-700: #0f766e;
    --serynt-teal-800: #115e59;
    --serynt-teal-900: #134e4a;

    /* Verde Esmeralda - Color de acento/éxito */
    --serynt-emerald-50: #ecfdf5;
    --serynt-emerald-100: #d1fae5;
    --serynt-emerald-200: #a7f3d0;
    --serynt-emerald-300: #6ee7b7;
    --serynt-emerald-400: #34d399;
    --serynt-emerald-500: #10b981;  /* Acento */
    --serynt-emerald-600: #059669;
    --serynt-emerald-700: #047857;
    --serynt-emerald-800: #065f46;
    --serynt-emerald-900: #064e3b;

    /* Slate - Escala de grises con tinte azul (para texto y fondos) */
    --serynt-slate-50: #f8fafc;
    --serynt-slate-100: #f1f5f9;
    --serynt-slate-200: #e2e8f0;
    --serynt-slate-300: #cbd5e1;
    --serynt-slate-400: #94a3b8;
    --serynt-slate-500: #64748b;
    --serynt-slate-600: #475569;
    --serynt-slate-700: #334155;
    --serynt-slate-800: #1e293b;
    --serynt-slate-900: #0f172a;  /* Texto principal (del logo) */
    --serynt-slate-950: #020617;

    /* ========== COLORES SEMÁNTICOS ========== */

    /* Primary - Basado en Sky */
    --serynt-primary: var(--serynt-sky-500);
    --serynt-primary-hover: var(--serynt-sky-600);
    --serynt-primary-active: var(--serynt-sky-700);
    --serynt-primary-light: var(--serynt-sky-100);
    --serynt-primary-lighter: var(--serynt-sky-50);

    /* Secondary - Basado en Teal */
    --serynt-secondary: var(--serynt-teal-500);
    --serynt-secondary-hover: var(--serynt-teal-600);
    --serynt-secondary-active: var(--serynt-teal-700);
    --serynt-secondary-light: var(--serynt-teal-100);

    /* Success - Basado en Emerald */
    --serynt-success: var(--serynt-emerald-500);
    --serynt-success-hover: var(--serynt-emerald-600);
    --serynt-success-light: var(--serynt-emerald-100);

    /* Warning - Amber */
    --serynt-warning: #f59e0b;
    --serynt-warning-hover: #d97706;
    --serynt-warning-light: #fef3c7;

    /* Danger - Rose/Red */
    --serynt-danger: #ef4444;
    --serynt-danger-hover: #dc2626;
    --serynt-danger-light: #fee2e2;

    /* Info - Basado en Sky más claro */
    --serynt-info: var(--serynt-sky-400);
    --serynt-info-hover: var(--serynt-sky-500);
    --serynt-info-light: var(--serynt-sky-100);

    /* ========== GRADIENTES DE MARCA ========== */

    /* Gradiente principal del logo (azul → teal → verde) */
    --serynt-gradient-primary: linear-gradient(135deg, var(--serynt-sky-500) 0%, var(--serynt-teal-500) 50%, var(--serynt-emerald-500) 100%);
    --serynt-gradient-primary-vertical: linear-gradient(180deg, var(--serynt-sky-500) 0%, var(--serynt-teal-500) 50%, var(--serynt-emerald-500) 100%);

    /* Gradientes sutiles para fondos */
    --serynt-gradient-subtle: linear-gradient(135deg, var(--serynt-sky-50) 0%, var(--serynt-teal-50) 100%);
    --serynt-gradient-hero: linear-gradient(135deg, var(--serynt-sky-100) 0%, var(--serynt-teal-50) 50%, var(--serynt-emerald-50) 100%);

    /* Gradiente para botones/CTAs */
    --serynt-gradient-button: linear-gradient(135deg, var(--serynt-sky-500) 0%, var(--serynt-teal-500) 100%);
    --serynt-gradient-button-hover: linear-gradient(135deg, var(--serynt-sky-600) 0%, var(--serynt-teal-600) 100%);

    /* ========== TEXTOS ========== */

    --serynt-text-primary: var(--serynt-slate-900);
    --serynt-text-secondary: var(--serynt-slate-600);
    --serynt-text-muted: var(--serynt-slate-500);
    --serynt-text-light: var(--serynt-slate-400);
    --serynt-text-inverse: #ffffff;

    /* ========== FONDOS ========== */

    --serynt-bg-body: var(--serynt-slate-50);
    --serynt-bg-surface: #ffffff;
    --serynt-bg-surface-hover: var(--serynt-slate-50);
    --serynt-bg-surface-active: var(--serynt-slate-100);
    --serynt-bg-muted: var(--serynt-slate-100);
    --serynt-bg-sidebar: var(--serynt-slate-900);

    /* ========== BORDES ========== */

    --serynt-border-color: var(--serynt-slate-200);
    --serynt-border-color-hover: var(--serynt-slate-300);
    --serynt-border-radius-sm: 0.375rem;   /* 6px */
    --serynt-border-radius: 0.5rem;        /* 8px */
    --serynt-border-radius-md: 0.75rem;    /* 12px */
    --serynt-border-radius-lg: 1rem;       /* 16px */
    --serynt-border-radius-xl: 1.5rem;     /* 24px */
    --serynt-border-radius-full: 9999px;

    /* ========== SOMBRAS ========== */

    --serynt-shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --serynt-shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --serynt-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --serynt-shadow-md: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --serynt-shadow-lg: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --serynt-shadow-xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);

    /* Sombras con color de marca */
    --serynt-shadow-primary: 0 4px 14px 0 rgb(14 165 233 / 0.39);
    --serynt-shadow-primary-lg: 0 10px 40px 0 rgb(14 165 233 / 0.3);

    /* ========== TIPOGRAFÍA ========== */

    --serynt-font-sans: 'Plus Jakarta Sans', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --serynt-font-mono: 'JetBrains Mono', 'Fira Code', monospace;

    /* Tamaños de fuente */
    --serynt-text-xs: 0.75rem;     /* 12px */
    --serynt-text-sm: 0.875rem;    /* 14px */
    --serynt-text-base: 1rem;      /* 16px */
    --serynt-text-lg: 1.125rem;    /* 18px */
    --serynt-text-xl: 1.25rem;     /* 20px */
    --serynt-text-2xl: 1.5rem;     /* 24px */
    --serynt-text-3xl: 1.875rem;   /* 30px */
    --serynt-text-4xl: 2.25rem;    /* 36px */
    --serynt-text-5xl: 3rem;       /* 48px */
    --serynt-text-6xl: 3.75rem;    /* 60px */

    /* ========== ESPACIADO ========== */

    --serynt-space-1: 0.25rem;   /* 4px */
    --serynt-space-2: 0.5rem;    /* 8px */
    --serynt-space-3: 0.75rem;   /* 12px */
    --serynt-space-4: 1rem;      /* 16px */
    --serynt-space-5: 1.25rem;   /* 20px */
    --serynt-space-6: 1.5rem;    /* 24px */
    --serynt-space-8: 2rem;      /* 32px */
    --serynt-space-10: 2.5rem;   /* 40px */
    --serynt-space-12: 3rem;     /* 48px */
    --serynt-space-16: 4rem;     /* 64px */

    /* ========== TRANSICIONES ========== */

    --serynt-transition-fast: 150ms ease;
    --serynt-transition-base: 200ms ease;
    --serynt-transition-slow: 300ms ease;
    --serynt-transition-slower: 500ms ease;

    /* ========== Z-INDEX ========== */

    --serynt-z-dropdown: 1000;
    --serynt-z-sticky: 1020;
    --serynt-z-fixed: 1030;
    --serynt-z-modal-backdrop: 1040;
    --serynt-z-modal: 1050;
    --serynt-z-popover: 1060;
    --serynt-z-tooltip: 1070;
}

/* ============================================================================
   OVERRIDE DE VARIABLES BOOTSTRAP 5
   ============================================================================ */

:root {
    /* Colores de tema Bootstrap → Paleta Serynt */
    --bs-primary: var(--serynt-primary);
    --bs-primary-rgb: 14, 165, 233;
    --bs-secondary: var(--serynt-secondary);
    --bs-secondary-rgb: 20, 184, 166;
    --bs-success: var(--serynt-success);
    --bs-success-rgb: 16, 185, 129;
    --bs-info: var(--serynt-info);
    --bs-info-rgb: 56, 189, 248;
    --bs-warning: var(--serynt-warning);
    --bs-warning-rgb: 245, 158, 11;
    --bs-danger: var(--serynt-danger);
    --bs-danger-rgb: 239, 68, 68;
    --bs-light: var(--serynt-slate-100);
    --bs-dark: var(--serynt-slate-900);

    /* Tipografía */
    --bs-body-font-family: var(--serynt-font-sans);
    --bs-body-font-size: var(--serynt-text-base);
    --bs-body-color: var(--serynt-text-primary);
    --bs-body-bg: var(--serynt-bg-body);

    /* Links */
    --bs-link-color: var(--serynt-primary);
    --bs-link-hover-color: var(--serynt-primary-hover);

    /* Border radius */
    --bs-border-radius: var(--serynt-border-radius);
    --bs-border-radius-sm: var(--serynt-border-radius-sm);
    --bs-border-radius-lg: var(--serynt-border-radius-md);
    --bs-border-radius-xl: var(--serynt-border-radius-lg);
    --bs-border-radius-2xl: var(--serynt-border-radius-xl);
    --bs-border-radius-pill: var(--serynt-border-radius-full);

    /* Border */
    --bs-border-color: var(--serynt-border-color);
}

/* ============================================================================
   UTILIDADES DE GRADIENTE
   ============================================================================ */

.serynt-gradient {
    background: var(--serynt-gradient-primary) !important;
}

.serynt-gradient-vertical {
    background: var(--serynt-gradient-primary-vertical) !important;
}

.serynt-gradient-subtle {
    background: var(--serynt-gradient-subtle) !important;
}

.serynt-gradient-hero {
    background: var(--serynt-gradient-hero) !important;
}

.serynt-gradient-text {
    background: var(--serynt-gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ============================================================================
   BOTONES PERSONALIZADOS SERYNT
   ============================================================================ */

.btn-serynt {
    background: var(--serynt-gradient-button);
    border: none;
    color: white;
    font-weight: 600;
    padding: 0.625rem 1.5rem;
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-base);
    box-shadow: var(--serynt-shadow-sm);
}

.btn-serynt:hover {
    background: var(--serynt-gradient-button-hover);
    color: white;
    transform: translateY(-1px);
    box-shadow: var(--serynt-shadow-primary);
}

.btn-serynt:active {
    transform: translateY(0);
}

.btn-serynt-outline {
    background: transparent;
    border: 2px solid var(--serynt-primary);
    color: var(--serynt-primary);
    font-weight: 600;
    padding: 0.5rem 1.5rem;
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-base);
}

.btn-serynt-outline:hover {
    background: var(--serynt-primary);
    color: white;
}

/* Tamaños de botones */
.btn-serynt-sm {
    padding: 0.375rem 1rem;
    font-size: var(--serynt-text-sm);
}

.btn-serynt-lg {
    padding: 0.875rem 2rem;
    font-size: var(--serynt-text-lg);
}

/* Variantes de botones */
.btn-serynt-primary {
    background: var(--serynt-gradient-button);
    border: none;
    color: white;
    font-weight: 600;
    padding: 0.625rem 1.5rem;
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-base);
    box-shadow: var(--serynt-shadow-sm);
}

.btn-serynt-primary:hover {
    background: var(--serynt-gradient-button-hover);
    color: white;
    transform: translateY(-1px);
    box-shadow: var(--serynt-shadow-primary);
}

.btn-serynt-secondary {
    background: var(--serynt-slate-200);
    border: none;
    color: var(--serynt-slate-700);
    font-weight: 600;
    padding: 0.625rem 1.5rem;
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-base);
}

.btn-serynt-secondary:hover {
    background: var(--serynt-slate-300);
    color: var(--serynt-slate-800);
}

.btn-serynt-secondary:disabled {
    background: var(--serynt-slate-100);
    color: var(--serynt-slate-400);
    cursor: not-allowed;
}

.btn-serynt-outline-secondary {
    background: transparent;
    border: 2px solid var(--serynt-slate-300);
    color: var(--serynt-slate-700);
    font-weight: 600;
    padding: 0.5rem 1.5rem;
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-base);
}

.btn-serynt-outline-secondary:hover {
    background: var(--serynt-slate-100);
    border-color: var(--serynt-slate-400);
    color: var(--serynt-slate-800);
}

/* ============================================================================
   ALERTAS SERYNT
   ============================================================================ */

.serynt-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-radius: var(--serynt-border-radius);
    border-left: 4px solid;
    margin-bottom: 1rem;
}

.serynt-alert i {
    font-size: 1.25rem;
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.serynt-alert-success {
    background: var(--serynt-emerald-50);
    border-left-color: var(--serynt-success);
    color: var(--serynt-emerald-800);
}

.serynt-alert-success i {
    color: var(--serynt-success);
}

.serynt-alert-danger {
    background: var(--serynt-danger-light);
    border-left-color: var(--serynt-danger);
    color: #991b1b;
}

.serynt-alert-danger i {
    color: var(--serynt-danger);
}

.serynt-alert-warning {
    background: var(--serynt-warning-light);
    border-left-color: var(--serynt-warning);
    color: #92400e;
}

.serynt-alert-warning i {
    color: var(--serynt-warning);
}

.serynt-alert-info {
    background: var(--serynt-sky-50);
    border-left-color: var(--serynt-info);
    color: var(--serynt-sky-800);
}

.serynt-alert-info i {
    color: var(--serynt-info);
}

/* Gradiente para success */
:root {
    --serynt-gradient-success: linear-gradient(135deg, var(--serynt-emerald-500) 0%, var(--serynt-teal-500) 100%);
    --serynt-gradient-warning: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

/* ============================================================================
   BADGES SERYNT
   ============================================================================ */

.serynt-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: var(--serynt-border-radius-full);
    line-height: 1.4;
}

.serynt-badge i {
    font-size: 0.875rem;
}

.serynt-badge-success {
    background: var(--serynt-emerald-100);
    color: var(--serynt-emerald-700);
}

.serynt-badge-danger {
    background: var(--serynt-danger-light);
    color: #b91c1c;
}

.serynt-badge-warning {
    background: var(--serynt-warning-light);
    color: #b45309;
}

.serynt-badge-info {
    background: var(--serynt-sky-100);
    color: var(--serynt-sky-700);
}

.serynt-badge-primary {
    background: var(--serynt-sky-100);
    color: var(--serynt-sky-700);
}

.serynt-badge-secondary {
    background: var(--serynt-slate-100);
    color: var(--serynt-slate-700);
}

/* ============================================================================
   TARJETAS SERYNT
   ============================================================================ */

.card-serynt {
    background: var(--serynt-bg-surface);
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius-md);
    box-shadow: var(--serynt-shadow-sm);
    transition: all var(--serynt-transition-base);
}

.card-serynt:hover {
    box-shadow: var(--serynt-shadow-md);
    border-color: var(--serynt-border-color-hover);
}

.card-serynt-header {
    padding: var(--serynt-space-4) var(--serynt-space-6);
    border-bottom: 1px solid var(--serynt-border-color);
    background: var(--serynt-bg-surface);
    border-radius: var(--serynt-border-radius-md) var(--serynt-border-radius-md) 0 0;
}

.card-serynt-body {
    padding: var(--serynt-space-6);
}

.card-serynt-footer {
    padding: var(--serynt-space-4) var(--serynt-space-6);
    border-top: 1px solid var(--serynt-border-color);
    background: var(--serynt-slate-50);
    border-radius: 0 0 var(--serynt-border-radius-md) var(--serynt-border-radius-md);
}

/* Variante destacada */
.card-serynt-featured {
    border: 2px solid var(--serynt-primary);
    box-shadow: var(--serynt-shadow-primary);
}

/* ============================================================================
   INPUTS Y FORMULARIOS
   ============================================================================ */

.form-control-serynt {
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius);
    padding: 0.625rem 1rem;
    font-size: var(--serynt-text-base);
    transition: all var(--serynt-transition-fast);
    background: var(--serynt-bg-surface);
}

.form-control-serynt:focus {
    border-color: var(--serynt-primary);
    box-shadow: 0 0 0 3px rgb(14 165 233 / 0.15);
    outline: none;
}

.form-control-serynt:hover:not(:focus) {
    border-color: var(--serynt-border-color-hover);
}

.form-label-serynt {
    font-weight: 500;
    color: var(--serynt-text-primary);
    margin-bottom: var(--serynt-space-2);
    font-size: var(--serynt-text-sm);
}

/* ============================================================================
   BADGES Y ETIQUETAS
   ============================================================================ */

.badge-serynt {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    font-size: var(--serynt-text-xs);
    font-weight: 600;
    border-radius: var(--serynt-border-radius-full);
}

.badge-serynt-primary {
    background: var(--serynt-primary-light);
    color: var(--serynt-sky-700);
}

.badge-serynt-success {
    background: var(--serynt-success-light);
    color: var(--serynt-emerald-700);
}

.badge-serynt-warning {
    background: var(--serynt-warning-light);
    color: #92400e;
}

.badge-serynt-danger {
    background: var(--serynt-danger-light);
    color: #b91c1c;
}

.badge-serynt-info {
    background: var(--serynt-info-light);
    color: var(--serynt-sky-700);
}

/* ============================================================================
   ALERTAS
   ============================================================================ */

.alert-serynt {
    border: none;
    border-radius: var(--serynt-border-radius);
    padding: var(--serynt-space-4);
    border-left: 4px solid;
}

.alert-serynt-success {
    background: var(--serynt-success-light);
    border-left-color: var(--serynt-success);
    color: var(--serynt-emerald-800);
}

.alert-serynt-warning {
    background: var(--serynt-warning-light);
    border-left-color: var(--serynt-warning);
    color: #92400e;
}

.alert-serynt-danger {
    background: var(--serynt-danger-light);
    border-left-color: var(--serynt-danger);
    color: #991b1b;
}

.alert-serynt-info {
    background: var(--serynt-info-light);
    border-left-color: var(--serynt-info);
    color: var(--serynt-sky-800);
}

/* ============================================================================
   NAVEGACIÓN / SIDEBAR
   ============================================================================ */

.sidebar-serynt {
    background: var(--serynt-bg-sidebar);
}

.sidebar-serynt .nav-link {
    color: var(--serynt-slate-400);
    padding: var(--serynt-space-3) var(--serynt-space-4);
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-fast);
    margin: var(--serynt-space-1) 0;
}

.sidebar-serynt .nav-link:hover {
    color: white;
    background: rgba(255, 255, 255, 0.1);
}

.sidebar-serynt .nav-link.active {
    color: white;
    background: var(--serynt-gradient-button);
}

/* ============================================================================
   ANIMACIONES Y TRANSICIONES
   ============================================================================ */

@keyframes serynt-fade-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes serynt-slide-in {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes serynt-scale-in {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes serynt-pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

@keyframes serynt-gradient-shift {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

.animate-fade-in {
    animation: serynt-fade-in var(--serynt-transition-slow) ease-out;
}

.animate-slide-in {
    animation: serynt-slide-in var(--serynt-transition-slow) ease-out;
}

.animate-scale-in {
    animation: serynt-scale-in var(--serynt-transition-base) ease-out;
}

.animate-pulse {
    animation: serynt-pulse 2s ease-in-out infinite;
}

/* Gradiente animado */
.animate-gradient {
    background-size: 200% 200%;
    animation: serynt-gradient-shift 3s ease infinite;
}

/* ============================================================================
   UTILIDADES
   ============================================================================ */

/* Texto */
.text-serynt-primary { color: var(--serynt-primary) !important; }
.text-serynt-secondary { color: var(--serynt-secondary) !important; }
.text-serynt-success { color: var(--serynt-success) !important; }
.text-serynt-warning { color: var(--serynt-warning) !important; }
.text-serynt-danger { color: var(--serynt-danger) !important; }
.text-serynt-muted { color: var(--serynt-text-muted) !important; }

/* Fondos */
.bg-serynt-primary { background-color: var(--serynt-primary) !important; }
.bg-serynt-secondary { background-color: var(--serynt-secondary) !important; }
.bg-serynt-success { background-color: var(--serynt-success) !important; }
.bg-serynt-light { background-color: var(--serynt-primary-light) !important; }
.bg-serynt-body { background-color: var(--serynt-bg-body) !important; }
.bg-serynt-surface { background-color: var(--serynt-bg-surface) !important; }

/* Bordes */
.border-serynt { border-color: var(--serynt-border-color) !important; }
.border-serynt-primary { border-color: var(--serynt-primary) !important; }

/* Sombras */
.shadow-serynt-sm { box-shadow: var(--serynt-shadow-sm) !important; }
.shadow-serynt { box-shadow: var(--serynt-shadow) !important; }
.shadow-serynt-md { box-shadow: var(--serynt-shadow-md) !important; }
.shadow-serynt-lg { box-shadow: var(--serynt-shadow-lg) !important; }
.shadow-serynt-primary { box-shadow: var(--serynt-shadow-primary) !important; }

/* Hover effects */
.hover-lift {
    transition: transform var(--serynt-transition-base), box-shadow var(--serynt-transition-base);
}

.hover-lift:hover {
    transform: translateY(-2px);
    box-shadow: var(--serynt-shadow-md);
}

.hover-scale {
    transition: transform var(--serynt-transition-base);
}

.hover-scale:hover {
    transform: scale(1.02);
}

/* ============================================================================
   RESPONSIVIDAD
   ============================================================================ */

/* Mobile-first breakpoints */
@media (max-width: 767.98px) {
    :root {
        --serynt-text-5xl: 2.25rem;
        --serynt-text-6xl: 2.75rem;
    }

    .card-serynt-body {
        padding: var(--serynt-space-4);
    }
}

/* ============================================================================
   DARK MODE (preparado para futuro)
   ============================================================================ */

@media (prefers-color-scheme: dark) {
    .dark-mode {
        --serynt-bg-body: var(--serynt-slate-950);
        --serynt-bg-surface: var(--serynt-slate-900);
        --serynt-bg-surface-hover: var(--serynt-slate-800);
        --serynt-text-primary: var(--serynt-slate-100);
        --serynt-text-secondary: var(--serynt-slate-300);
        --serynt-border-color: var(--serynt-slate-700);
    }
}

/* ============================================================================
   APP SIDEBAR - NAVEGACIÓN PRINCIPAL
   ============================================================================ */

.left-sidebar {
    background: linear-gradient(180deg, var(--serynt-slate-900) 0%, var(--serynt-slate-950) 100%);
    border-right: 1px solid rgba(255, 255, 255, 0.05);
}

/* Brand Logo Area */
.left-sidebar .brand-logo {
    padding: var(--serynt-space-4);
    border-bottom: none;
    background: white;
    margin: var(--serynt-space-3);
    margin-bottom: 0;
    border-radius: var(--serynt-border-radius-md) var(--serynt-border-radius-md) 0 0;
    text-align: center;
}

.left-sidebar .brand-logo a {
    display: block;
    text-align: center;
}

.left-sidebar .brand-logo img {
    height: auto;
    width: 80%;
    max-width: 150px;
    margin: 0 auto;
    display: block;
    transition: all var(--serynt-transition-fast);
}

.left-sidebar .brand-logo:hover img {
    transform: scale(1.02);
}

/* Home Link below logo */
.left-sidebar .sidebar-home-link {
    background: var(--serynt-slate-100);
    margin: 0 var(--serynt-space-3) var(--serynt-space-3);
    border-radius: 0 0 var(--serynt-border-radius-md) var(--serynt-border-radius-md);
    border-top: 1px solid var(--serynt-border-color);
}

.left-sidebar .sidebar-home-link a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--serynt-space-2);
    padding: var(--serynt-space-3);
    color: var(--serynt-primary);
    font-weight: 600;
    font-size: var(--serynt-text-sm);
    text-decoration: none;
    transition: all var(--serynt-transition-fast);
}

.left-sidebar .sidebar-home-link a:hover {
    background: var(--serynt-primary-light);
    color: var(--serynt-primary-hover);
}

.left-sidebar .sidebar-home-link a i {
    font-size: 1.1rem;
}

.left-sidebar .brand-logo h1 {
    display: none; /* Ocultar el texto "Inicio" */
}

/* Sidebar Navigation */
.left-sidebar .sidebar-nav {
    padding: var(--serynt-space-4) var(--serynt-space-3);
}

/* Section Headers */
.left-sidebar .nav-small-cap {
    padding: var(--serynt-space-4) var(--serynt-space-4) var(--serynt-space-2);
    margin-top: var(--serynt-space-2);
}

.left-sidebar .nav-small-cap .hide-menu {
    color: var(--serynt-sky-300) !important;
    font-size: var(--serynt-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.left-sidebar .nav-small-cap i {
    display: none; /* Ocultar icono de puntos */
}

/* Navigation Items */
.left-sidebar .sidebar-item {
    margin: var(--serynt-space-1) 0;
}

.left-sidebar .sidebar-link {
    display: flex;
    align-items: center;
    gap: var(--serynt-space-3);
    padding: var(--serynt-space-3) var(--serynt-space-4);
    color: rgba(255, 255, 255, 0.85) !important;
    font-size: var(--serynt-text-sm);
    font-weight: 500;
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-fast);
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

.left-sidebar .sidebar-link span:first-child {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
}

.left-sidebar .sidebar-link i {
    font-size: 1.25rem;
    transition: transform var(--serynt-transition-fast);
}

/* Hover State */
.left-sidebar .sidebar-link:hover {
    color: white !important;
    background: rgba(255, 255, 255, 0.15);
}

.left-sidebar .sidebar-link:hover i {
    transform: scale(1.1);
    color: var(--serynt-sky-300) !important;
}

/* Icons default color */
.left-sidebar .sidebar-link i {
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 1.25rem;
}

/* Active State */
.left-sidebar .sidebar-item.selected > .sidebar-link,
.left-sidebar .sidebar-link.active {
    color: white;
    background: var(--serynt-gradient-button);
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.3);
}

.left-sidebar .sidebar-item.selected > .sidebar-link i,
.left-sidebar .sidebar-link.active i {
    color: white;
}

/* Active indicator line */
.left-sidebar .sidebar-item.selected > .sidebar-link::before,
.left-sidebar .sidebar-link.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 60%;
    background: white;
    border-radius: 0 2px 2px 0;
}

/* Scrollbar Styling */
.left-sidebar .scroll-sidebar::-webkit-scrollbar {
    width: 6px;
}

.left-sidebar .scroll-sidebar::-webkit-scrollbar-track {
    background: transparent;
}

.left-sidebar .scroll-sidebar::-webkit-scrollbar-thumb {
    background: var(--serynt-slate-700);
    border-radius: 3px;
}

.left-sidebar .scroll-sidebar::-webkit-scrollbar-thumb:hover {
    background: var(--serynt-slate-600);
}

/* ============================================================================
   APP HEADER - BARRA SUPERIOR
   ============================================================================ */

.app-header {
    background: var(--serynt-bg-surface);
    border-bottom: 1px solid var(--serynt-border-color);
    box-shadow: var(--serynt-shadow-sm);
    position: sticky;
    top: 0;
    z-index: var(--serynt-z-sticky);
}

.app-header .navbar {
    padding: var(--serynt-space-3) var(--serynt-space-5);
}

/* Sidebar Toggle Button */
.app-header .sidebartoggler {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--serynt-border-radius);
    color: var(--serynt-text-secondary);
    transition: all var(--serynt-transition-fast);
}

.app-header .sidebartoggler:hover {
    background: var(--serynt-primary-light);
    color: var(--serynt-primary);
}

.app-header .sidebartoggler i {
    font-size: 1.5rem;
}

/* Notifications Bell */
.app-header .nav-icon-hover {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--serynt-border-radius);
    color: var(--serynt-text-secondary);
    transition: all var(--serynt-transition-fast);
    position: relative;
}

.app-header .nav-icon-hover:hover {
    background: var(--serynt-primary-light);
    color: var(--serynt-primary);
}

.app-header .nav-icon-hover i {
    font-size: 1.25rem;
}

/* Notification Badge */
.app-header .notification-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 10px;
    font-weight: 600;
    line-height: 18px;
    text-align: center;
    background: var(--serynt-danger);
    border-radius: var(--serynt-border-radius-full);
    color: white;
    animation: serynt-pulse 2s ease-in-out infinite;
}

/* Branch/User Info */
.app-header .text-muted {
    color: var(--serynt-text-muted) !important;
    font-size: var(--serynt-text-sm);
}

.app-header .text-primary {
    color: var(--serynt-primary) !important;
    font-weight: 600;
}

/* User Dropdown */
.app-header .dropdown-menu {
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius-md);
    box-shadow: var(--serynt-shadow-lg);
    padding: var(--serynt-space-2);
    min-width: 200px;
}

.app-header .dropdown-item {
    padding: var(--serynt-space-2) var(--serynt-space-3);
    border-radius: var(--serynt-border-radius-sm);
    color: var(--serynt-text-secondary);
    font-size: var(--serynt-text-sm);
    transition: all var(--serynt-transition-fast);
}

.app-header .dropdown-item:hover {
    background: var(--serynt-primary-light);
    color: var(--serynt-primary);
}

.app-header .dropdown-item i {
    color: var(--serynt-text-muted);
    transition: color var(--serynt-transition-fast);
}

.app-header .dropdown-item:hover i {
    color: var(--serynt-primary);
}

/* User Avatar */
.app-header .rounded-circle {
    border: 2px solid var(--serynt-border-color);
    transition: all var(--serynt-transition-fast);
}

.app-header .rounded-circle:hover {
    border-color: var(--serynt-primary);
    box-shadow: 0 0 0 3px var(--serynt-primary-light);
}

/* Notifications Dropdown */
#notificationsDropdown .dropdown-menu {
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius-md);
    box-shadow: var(--serynt-shadow-xl);
    overflow: hidden;
}

#notificationsDropdown .bg-light {
    background: var(--serynt-slate-50) !important;
}

#notificationsDropdown .notification-item {
    transition: background-color var(--serynt-transition-fast);
}

#notificationsDropdown .notification-item:hover {
    background-color: var(--serynt-slate-100) !important;
}

#notificationsDropdown .notification-item.bg-light {
    background: var(--serynt-primary-lighter) !important;
    border-left: 3px solid var(--serynt-primary);
}

/* Change Branch Button */
.app-header .btn-outline-secondary {
    border-color: var(--serynt-border-color);
    color: var(--serynt-text-muted);
    border-radius: var(--serynt-border-radius-sm);
    padding: 0.25rem 0.5rem;
    transition: all var(--serynt-transition-fast);
}

.app-header .btn-outline-secondary:hover {
    background: var(--serynt-primary-light);
    border-color: var(--serynt-primary);
    color: var(--serynt-primary);
}

/* ============================================================================
   PAGE WRAPPER - CONTENEDOR PRINCIPAL
   ============================================================================ */

.page-wrapper {
    background: var(--serynt-bg-body);
    min-height: 100vh;
}

.body-wrapper {
    background: var(--serynt-bg-body);
    min-height: 100vh;
}

/* Container Fluid */
.container-fluid {
    padding: var(--serynt-space-5);
}

/* ============================================================================
   CARDS Y CONTENEDORES COMUNES
   ============================================================================ */

.card {
    background: var(--serynt-bg-surface);
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius-md);
    box-shadow: var(--serynt-shadow-sm);
}

.card-header {
    background: var(--serynt-bg-surface);
    border-bottom: 1px solid var(--serynt-border-color);
    padding: var(--serynt-space-4) var(--serynt-space-5);
}

.card-body {
    padding: var(--serynt-space-5);
}

.card-footer {
    background: var(--serynt-slate-50);
    border-top: 1px solid var(--serynt-border-color);
    padding: var(--serynt-space-4) var(--serynt-space-5);
}

/* Card Title */
.card-title {
    color: var(--serynt-text-primary);
    font-weight: 600;
    font-size: var(--serynt-text-lg);
    margin-bottom: 0;
}

/* ============================================================================
   TABLAS
   ============================================================================ */

.table {
    color: var(--serynt-text-primary);
}

.table thead th {
    background: var(--serynt-slate-50);
    color: var(--serynt-text-secondary);
    font-weight: 600;
    font-size: var(--serynt-text-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--serynt-border-color);
    padding: var(--serynt-space-3) var(--serynt-space-4);
}

.table tbody td {
    padding: var(--serynt-space-3) var(--serynt-space-4);
    border-bottom: 1px solid var(--serynt-border-color);
    vertical-align: middle;
}

.table tbody tr:hover {
    background: var(--serynt-slate-50);
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: var(--serynt-slate-50);
}

/* ============================================================================
   BOTONES BOOTSTRAP OVERRIDE
   ============================================================================ */

.btn-primary {
    background: var(--serynt-gradient-button);
    border: none;
    color: white;
    font-weight: 600;
    transition: all var(--serynt-transition-base);
}

.btn-primary:hover {
    background: var(--serynt-gradient-button-hover);
    box-shadow: var(--serynt-shadow-primary);
    transform: translateY(-1px);
}

.btn-primary:active,
.btn-primary:focus {
    background: var(--serynt-gradient-button-hover);
    box-shadow: 0 0 0 3px var(--serynt-primary-light);
}

.btn-success {
    background: var(--serynt-success);
    border-color: var(--serynt-success);
}

.btn-success:hover {
    background: var(--serynt-success-hover);
    border-color: var(--serynt-success-hover);
}

.btn-danger {
    background: var(--serynt-danger);
    border-color: var(--serynt-danger);
}

.btn-danger:hover {
    background: var(--serynt-danger-hover);
    border-color: var(--serynt-danger-hover);
}

.btn-warning {
    background: var(--serynt-warning);
    border-color: var(--serynt-warning);
}

.btn-warning:hover {
    background: var(--serynt-warning-hover);
    border-color: var(--serynt-warning-hover);
}

.btn-outline-primary {
    color: var(--serynt-primary);
    border-color: var(--serynt-primary);
}

.btn-outline-primary:hover {
    background: var(--serynt-primary);
    border-color: var(--serynt-primary);
    color: white;
}

/* ============================================================================
   FORMULARIOS BOOTSTRAP OVERRIDE
   ============================================================================ */

.form-control {
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius);
    padding: var(--serynt-space-2) var(--serynt-space-3);
    transition: all var(--serynt-transition-fast);
}

.form-control:focus {
    border-color: var(--serynt-primary);
    box-shadow: 0 0 0 3px var(--serynt-primary-light);
}

.form-label {
    color: var(--serynt-text-primary);
    font-weight: 500;
    font-size: var(--serynt-text-sm);
    margin-bottom: var(--serynt-space-2);
}

.form-select {
    border: 1px solid var(--serynt-border-color);
    border-radius: var(--serynt-border-radius);
    transition: all var(--serynt-transition-fast);
}

.form-select:focus {
    border-color: var(--serynt-primary);
    box-shadow: 0 0 0 3px var(--serynt-primary-light);
}

/* ============================================================================
   BADGES BOOTSTRAP OVERRIDE
   ============================================================================ */

.badge.bg-primary {
    background: var(--serynt-primary) !important;
}

.badge.bg-success {
    background: var(--serynt-success) !important;
}

.badge.bg-warning {
    background: var(--serynt-warning) !important;
    color: var(--serynt-slate-900) !important;
}

.badge.bg-danger {
    background: var(--serynt-danger) !important;
}

.badge.bg-info {
    background: var(--serynt-info) !important;
}

/* ============================================================================
   ALERTAS BOOTSTRAP OVERRIDE
   ============================================================================ */

.alert-success {
    background: var(--serynt-success-light);
    border-color: var(--serynt-success);
    color: var(--serynt-emerald-800);
}

.alert-warning {
    background: var(--serynt-warning-light);
    border-color: var(--serynt-warning);
    color: #92400e;
}

.alert-danger {
    background: var(--serynt-danger-light);
    border-color: var(--serynt-danger);
    color: #991b1b;
}

.alert-info {
    background: var(--serynt-info-light);
    border-color: var(--serynt-info);
    color: var(--serynt-sky-800);
}

/* ============================================================================
   MODAL OVERRIDE
   ============================================================================ */

.modal-content {
    border: none;
    border-radius: var(--serynt-border-radius-lg);
    box-shadow: var(--serynt-shadow-xl);
}

.modal-header {
    border-bottom: 1px solid var(--serynt-border-color);
    padding: var(--serynt-space-4) var(--serynt-space-5);
}

.modal-body {
    padding: var(--serynt-space-5);
}

.modal-footer {
    border-top: 1px solid var(--serynt-border-color);
    padding: var(--serynt-space-4) var(--serynt-space-5);
}

.modal-title {
    font-weight: 600;
    color: var(--serynt-text-primary);
}

/* ============================================================================
   PAGINATION OVERRIDE
   ============================================================================ */

.pagination .page-link {
    color: var(--serynt-primary);
    border-color: var(--serynt-border-color);
    transition: all var(--serynt-transition-fast);
}

.pagination .page-link:hover {
    background: var(--serynt-primary-light);
    border-color: var(--serynt-primary);
    color: var(--serynt-primary);
}

.pagination .page-item.active .page-link {
    background: var(--serynt-primary);
    border-color: var(--serynt-primary);
}

/* ============================================================================
   BREADCRUMB
   ============================================================================ */

.breadcrumb {
    background: transparent;
    padding: 0;
    margin-bottom: var(--serynt-space-4);
}

.breadcrumb-item a {
    color: var(--serynt-primary);
    text-decoration: none;
}

.breadcrumb-item a:hover {
    color: var(--serynt-primary-hover);
    text-decoration: underline;
}

.breadcrumb-item.active {
    color: var(--serynt-text-muted);
}

