/* ========================================
   TGR CSS CUSTOM PROPERTIES
   Sistema de diseño escalable y mantenible
   
   NOTA: Se mantiene el color primario rojo (#f93048) como identidad
   empresarial de TGR. El sistema de variables CSS solo mejora la
   mantenibilidad sin alterar la identidad visual.
   ======================================== */

:root {
    /* ========================================
       COLORES PRINCIPALES
       ======================================== */
    
    /* Colores base de marca TGR */
    --tgr-red-base: #f93048;                    /* Color rojo corporativo principal */
    --tgr-red-light: #ff5a6e;                   /* Versión más clara del rojo */
    --tgr-red-dark: #d61f33;                    /* Versión más oscura del rojo */
    --tgr-red-lighter: #ff8a9a;                 /* Versión aún más clara para dark theme */
    
    /* Colores de marca TGR */
    --tgr-primary: var(--tgr-red-base);
    --tgr-primary-light: var(--tgr-red-light);
    --tgr-primary-dark: var(--tgr-red-dark);
    --tgr-primary-contrast: #ffffff;
    
    /* Sobrescribir variable primaria de Tabler */
    --tblr-primary: var(--tgr-red-base);
    
    --tgr-secondary: #206bc4;
    --tgr-secondary-light: #4a8fd8;
    --tgr-secondary-dark: #1a5aa3;
    --tgr-secondary-contrast: #ffffff;
    
    /* Color azul oscuro TGR */
    --tgr-dark-blue: #18183D;
    --tgr-dark-blue-light: #2a2a5a;
    --tgr-dark-blue-dark: #0f0f25;
    
    /* Colores complementarios para el esquema rojo */
    --tgr-primary-50: #fef2f2;
    --tgr-primary-100: #fee2e2;
    --tgr-primary-200: #fecaca;
    --tgr-primary-300: #fca5a5;
    --tgr-primary-400: #f87171;
    --tgr-primary-500: #ef4444;
    --tgr-primary-600: #dc2626;
    --tgr-primary-700: #b91c1c;
    --tgr-primary-800: #991b1b;
    --tgr-primary-900: #7f1d1d;
    
    /* Colores de acento */
    --tgr-accent: #ffc107;
    --tgr-accent-light: #ffd54f;
    --tgr-accent-dark: #ff8f00;
    --tgr-accent-contrast: #212529;
    
    /* Colores de estado */
    --tgr-success: #28a745;
    --tgr-warning: #ffc107;
    --tgr-danger: #dc3545;
    --tgr-info: #17a2b8;
    
    /* ========================================
       TIPOGRAFÍA
       ======================================== */
    
    /* Familias de fuentes */
    --tgr-font-family-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --tgr-font-family-secondary: 'Lexend', 'Inter', sans-serif;
    --tgr-font-family-mono: 'JetBrains Mono', 'Fira Code', monospace;
    
    /* Tamaños de fuente base */
    --tgr-font-size-xs: 0.75rem;    /* 12px */
    --tgr-font-size-sm: 0.875rem;   /* 14px */
    --tgr-font-size-base: 1rem;     /* 16px */
    --tgr-font-size-lg: 1.125rem;   /* 18px */
    --tgr-font-size-xl: 1.25rem;    /* 20px */
    --tgr-font-size-2xl: 1.5rem;    /* 24px */
    --tgr-font-size-3xl: 1.875rem;  /* 30px */
    --tgr-font-size-4xl: 2.25rem;   /* 36px */
    --tgr-font-size-5xl: 3rem;      /* 48px */
    --tgr-font-size-6xl: 3.75rem;   /* 60px */
    
    /* Pesos de fuente */
    --tgr-font-weight-light: 300;
    --tgr-font-weight-normal: 400;
    --tgr-font-weight-medium: 500;
    --tgr-font-weight-semibold: 600;
    --tgr-font-weight-bold: 700;
    --tgr-font-weight-extrabold: 800;
    --tgr-font-weight-black: 900;
    
    /* Alturas de línea */
    --tgr-line-height-tight: 1.25;
    --tgr-line-height-snug: 1.375;
    --tgr-line-height-normal: 1.5;
    --tgr-line-height-relaxed: 1.625;
    --tgr-line-height-loose: 2;
    
    /* ========================================
       ESPACIADO
       ======================================== */
    
    /* Sistema de espaciado basado en 4px */
    --tgr-space-0: 0;
    --tgr-space-1: 0.25rem;   /* 4px */
    --tgr-space-2: 0.5rem;    /* 8px */
    --tgr-space-3: 0.75rem;   /* 12px */
    --tgr-space-4: 1rem;      /* 16px */
    --tgr-space-5: 1.25rem;   /* 20px */
    --tgr-space-6: 1.5rem;    /* 24px */
    --tgr-space-8: 2rem;      /* 32px */
    --tgr-space-10: 2.5rem;   /* 40px */
    --tgr-space-12: 3rem;     /* 48px */
    --tgr-space-16: 4rem;     /* 64px */
    --tgr-space-20: 5rem;     /* 80px */
    --tgr-space-24: 6rem;     /* 96px */
    --tgr-space-32: 8rem;     /* 128px */
    
    /* ========================================
       BORDES Y RADIOS
       ======================================== */
    
    /* Bordes */
    --tgr-border-width: 1px;
    --tgr-border-width-2: 2px;
    --tgr-border-width-4: 4px;
    --tgr-border-width-8: 8px;
    
    /* Radios de borde */
    --tgr-border-radius: 0.375rem;   /* 6px */
    --tgr-border-radius-sm: 0.25rem; /* 4px */
    --tgr-border-radius-md: 0.5rem;  /* 8px */
    --tgr-border-radius-lg: 0.75rem; /* 12px */
    --tgr-border-radius-xl: 1rem;    /* 16px */
    --tgr-border-radius-2xl: 1.5rem; /* 24px */
    --tgr-border-radius-full: 9999px;
    
    /* ========================================
       SOMBRAS
       ======================================== */
    
    /* Sombras base */
    --tgr-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --tgr-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
    --tgr-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --tgr-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --tgr-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    --tgr-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    
    /* Sombras personalizadas para etiquetas */
    --tgr-shadow-tag-light: 0 8px 16px rgba(0, 0, 0, 0.1);
    --tgr-shadow-tag-medium: 0 10px 20px rgba(0, 0, 0, 0.15);
    --tgr-shadow-tag-heavy: 0 12px 24px rgba(0, 0, 0, 0.2);
    
    /* ========================================
       TRANSICIONES
       ======================================== */
    
    /* Duración de transiciones */
    --tgr-transition-fast: 150ms;
    --tgr-transition-normal: 300ms;
    --tgr-transition-slow: 500ms;
    
    /* Funciones de timing */
    --tgr-ease-linear: linear;
    --tgr-ease-in: cubic-bezier(0.4, 0, 1, 1);
    --tgr-ease-out: cubic-bezier(0, 0, 0.2, 1);
    --tgr-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --tgr-ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
    
    /* ========================================
       BREAKPOINTS
       ======================================== */
    
    /* Breakpoints para media queries */
    --tgr-breakpoint-xs: 360px;
    --tgr-breakpoint-sm: 480px;
    --tgr-breakpoint-md: 576px;
    --tgr-breakpoint-lg: 768px;
    --tgr-breakpoint-xl: 992px;
    --tgr-breakpoint-2xl: 1200px;
    
    /* ========================================
       Z-INDEX
       ======================================== */
    
    /* Sistema de capas */
    --tgr-z-dropdown: 1000;
    --tgr-z-sticky: 1020;
    --tgr-z-fixed: 1030;
    --tgr-z-modal-backdrop: 1040;
    --tgr-z-modal: 1050;
    --tgr-z-popover: 1060;
    --tgr-z-tooltip: 1070;
    --tgr-z-tag-base: 1;
    --tgr-z-tag-hover: 10;
    
    /* ========================================
       LAYOUT
       ======================================== */
    
    /* Contenedores */
    --tgr-container-max-width: 1200px;
    --tgr-container-padding: var(--tgr-space-4);
    
    /* Grid */
    --tgr-grid-columns: 12;
    --tgr-grid-gutter: var(--tgr-space-6);
    
    /* ========================================
       COMPONENTES ESPECÍFICOS
       ======================================== */
    
    /* Etiquetas del título */
    --tgr-title-tag-padding: var(--tgr-space-5) var(--tgr-space-9);
    --tgr-title-tag-border-radius: var(--tgr-border-radius-2xl);
    --tgr-title-tag-font-size: var(--tgr-font-size-5xl);
    --tgr-title-tag-font-weight: var(--tgr-font-weight-extrabold);
    
    /* Colores específicos para etiquetas del título */
    --tgr-title-tag-bg: var(--tgr-dark-blue);           /* Azul exacto en modo claro */
    --tgr-title-tag-color: #ffffff;                      /* Blanco en modo claro */
    --tgr-title-tag-border: 2px solid var(--tgr-dark-blue);
    --tgr-title-tag-bg-hover: var(--tgr-dark-blue-light); /* Azul más claro para hover en modo claro */
    
    /* SVG containers */
    --tgr-svg-container-min-height: 200px;
    --tgr-svg-container-min-height-tablet: 150px;
    --tgr-svg-container-min-height-mobile: 120px;
    
    /* Columnas de imagen */
    --tgr-img-column-width: 200px;
    --tgr-img-column-width-tablet: 150px;
    --tgr-img-column-width-mobile: 120px;
    
    /* Gradientes para el esquema rojo */
    --tgr-gradient-primary: linear-gradient(135deg, var(--tgr-primary-400) 0%, var(--tgr-primary-600) 100%);
    --tgr-gradient-primary-light: linear-gradient(135deg, var(--tgr-primary-100) 0%, var(--tgr-primary-300) 100%);
    --tgr-gradient-primary-dark: linear-gradient(135deg, var(--tgr-primary-700) 0%, var(--tgr-primary-900) 100%);
    
    /* Estados interactivos para el esquema rojo */
    --tgr-primary-hover: var(--tgr-primary-600);
    --tgr-primary-active: var(--tgr-primary-700);
    --tgr-primary-focus: var(--tgr-primary-400);
    
    /* Estados de enlaces */
    --tgr-link-color: var(--tgr-dark-blue);              /* Azul empresarial en modo claro */
    --tgr-link-hover: var(--tgr-dark-blue-light);        /* Azul más claro para hover en modo claro */
    --tgr-link-active: var(--tgr-dark-blue-dark);        /* Azul más oscuro para active en modo claro */
    
    /* Variables específicas para botón demo-request */
    --tgr-demo-btn-bg: var(--tgr-dark-blue);             /* Azul empresarial en modo claro */
    --tgr-demo-btn-hover: var(--tgr-dark-blue-light);    /* Azul más claro para hover en modo claro */
    --tgr-demo-btn-active: var(--tgr-dark-blue-dark);    /* Azul más oscuro para active en modo claro */
    --tgr-demo-btn-text: #ffffff;                        /* Texto blanco */
}

/* ========================================
   DARK THEME SUPPORT
   ======================================== */

[data-bs-theme="dark"] {
    /* Colores adaptados para dark theme con esquema rojo */
    --tgr-primary: var(--tgr-red-light);
    --tgr-primary-light: var(--tgr-red-lighter);
    --tgr-primary-dark: var(--tgr-red-base);
    
    /* Sobrescribir variable primaria de Tabler para modo oscuro */
    --tblr-primary: var(--tgr-red-base);
    
    /* Sombras adaptadas para dark theme */
    --tgr-shadow-tag-light: 0 8px 16px rgba(255, 90, 110, 0.15);
    --tgr-shadow-tag-medium: 0 10px 20px rgba(255, 90, 110, 0.2);
    --tgr-shadow-tag-heavy: 0 12px 24px rgba(255, 90, 110, 0.25);
    
    /* Colores complementarios para dark theme */
    --tgr-primary-50: #7f1d1d;
    --tgr-primary-100: #991b1b;
    --tgr-primary-200: #b91c1c;
    --tgr-primary-300: #dc2626;
    --tgr-primary-400: #ef4444;
    --tgr-primary-500: var(--tgr-red-light);
    --tgr-primary-600: var(--tgr-red-lighter);
    --tgr-primary-700: #fecaca;
    --tgr-primary-800: #fee2e2;
    --tgr-primary-900: #fef2f2;
    
    /* Colores de etiquetas del título para dark theme */
    --tgr-title-tag-bg: var(--tgr-primary);           /* Rojo en modo oscuro */
    --tgr-title-tag-color: var(--tgr-primary-contrast); /* Blanco en modo oscuro */
    --tgr-title-tag-border: 2px solid var(--tgr-primary);
    --tgr-title-tag-bg-hover: var(--tgr-primary-light); /* Rojo más claro para hover en modo oscuro */
    
    /* Estados de enlaces para modo oscuro */
    --tgr-link-color: var(--tgr-red-base);               /* Rojo oscuro empresarial en modo oscuro */
    --tgr-link-hover: var(--tgr-link-color);             /* Usa el mismo color que el normal para hover en modo oscuro */
    --tgr-link-active: var(--tgr-red-dark);              /* Rojo más oscuro para active en modo oscuro */
    
    /* Variables específicas para botón demo-request en modo oscuro */
    --tgr-demo-btn-bg: var(--tgr-red-base);              /* Rojo empresarial en modo oscuro */
    --tgr-demo-btn-hover: var(--tgr-red-light);          /* Rojo más claro para hover en modo oscuro */
    --tgr-demo-btn-active: var(--tgr-red-dark);          /* Rojo más oscuro para active en modo oscuro */
    --tgr-demo-btn-text: #ffffff;                        /* Texto blanco */
}

/* ========================================
   RESPONSIVE UTILITIES
   ======================================== */

/* Utilidades para breakpoints específicos */
@media (max-width: 768px) {
    :root {
        --tgr-title-tag-font-size: var(--tgr-font-size-4xl);
        --tgr-title-tag-padding: var(--tgr-space-4) var(--tgr-space-6);
    }
}

@media (max-width: 576px) {
    :root {
        --tgr-title-tag-font-size: var(--tgr-font-size-3xl);
        --tgr-title-tag-padding: var(--tgr-space-3) var(--tgr-space-5);
    }
}

@media (max-width: 480px) {
    :root {
        --tgr-title-tag-font-size: var(--tgr-font-size-2xl);
        --tgr-title-tag-padding: var(--tgr-space-2) var(--tgr-space-4);
    }
}

@media (max-width: 360px) {
    :root {
        --tgr-title-tag-font-size: var(--tgr-font-size-xl);
        --tgr-title-tag-padding: var(--tgr-space-1) var(--tgr-space-3);
    }
}
