/* ============================================================================
   VARIABLES.CSS - Sistema de Diseño Unificado RQM
   Este archivo contiene TODAS las variables CSS de la aplicación.
   Importar este archivo PRIMERO en cualquier página HTML.
   ============================================================================ */

:root {
    /* === TIPOGRAFÍA - Familia de Fuentes === */
    --font-primary: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-mono: 'Consolas', 'Monaco', 'Courier New', monospace;
    
    /* === TIPOGRAFÍA - Escala de Tamaños === */
    --font-2xs: 0.625rem;   /* 10px - Badges muy pequeños */
    --font-xs: 0.75rem;     /* 12px - Etiquetas, badges */
    --font-sm: 0.875rem;    /* 14px - Texto secundario */
    --font-base: 1rem;      /* 16px - Texto normal */
    --font-md: 1.125rem;    /* 18px - Subtítulos */
    --font-lg: 1.25rem;     /* 20px - Títulos de sección */
    --font-xl: 1.5rem;      /* 24px - Títulos de modal */
    --font-2xl: 1.75rem;    /* 28px - Títulos grandes */
    --font-3xl: 2rem;       /* 32px - Títulos principales */
    --font-4xl: 2.5rem;     /* 40px - Iconos grandes */
    --font-5xl: 3rem;       /* 48px - Iconos muy grandes */
    
    /* === TIPOGRAFÍA - Pesos === */
    --font-normal: 400;
    --font-medium: 500;
    --font-semibold: 600;
    --font-bold: 700;
    
    /* === TIPOGRAFÍA - Altura de línea === */
    --line-tight: 1.25;
    --line-normal: 1.5;
    --line-relaxed: 1.75;
    
    /* === COLORES - Paleta Principal === */
    --color-primary: #3182ce;
    --color-primary-dark: #2c5282;
    --color-primary-light: #63b3ed;
    --color-secondary: #718096;
    --color-success: #38a169;
    --color-success-light: #9ae6b4;
    --color-warning: #d69e2e;
    --color-warning-light: #faf089;
    --color-danger: #e53e3e;
    --color-danger-light: #feb2b2;
    --color-info: #3182ce;
    --color-purple: #7c3aed;
    --color-teal: #059669;
    
    /* === COLORES - Texto === */
    --color-text-primary: #2d3748;
    --color-text-secondary: #718096;
    --color-text-muted: #a0aec0;
    --color-text-inverse: #ffffff;
    
    /* === COLORES - Fondo === */
    --color-bg-primary: #ffffff;
    --color-bg-secondary: #f7fafc;
    --color-bg-tertiary: #edf2f7;
    --color-bg-dark: #2d3748;
    
    /* === COLORES - Bordes === */
    --color-border: #e2e8f0;
    --color-border-dark: #cbd5e0;
    
    /* === ESPACIADO === */
    --spacing-2xs: 0.125rem;  /* 2px */
    --spacing-xs: 0.25rem;    /* 4px */
    --spacing-sm: 0.5rem;     /* 8px */
    --spacing-md: 1rem;       /* 16px */
    --spacing-lg: 1.5rem;     /* 24px */
    --spacing-xl: 2rem;       /* 32px */
    --spacing-2xl: 3rem;      /* 48px */
    
    /* === BORDES === */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 9999px;
    
    /* === SOMBRAS === */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.15);
    
    /* === TRANSICIONES === */
    --transition-fast: 150ms ease;
    --transition-normal: 200ms ease;
    --transition-slow: 300ms ease;
    
    /* === Z-INDEX === */
    --z-dropdown: 100;
    --z-sticky: 200;
    --z-modal-backdrop: 900;
    --z-modal: 1000;
    --z-tooltip: 1100;
}

/* ============================================================================
   CLASES DE UTILIDAD - Tipografía
   ============================================================================ */

/* Tamaños de fuente */
.text-2xs { font-size: var(--font-2xs) !important; }
.text-xs { font-size: var(--font-xs) !important; }
.text-sm { font-size: var(--font-sm) !important; }
.text-base { font-size: var(--font-base) !important; }
.text-md { font-size: var(--font-md) !important; }
.text-lg { font-size: var(--font-lg) !important; }
.text-xl { font-size: var(--font-xl) !important; }
.text-2xl { font-size: var(--font-2xl) !important; }
.text-3xl { font-size: var(--font-3xl) !important; }
.text-4xl { font-size: var(--font-4xl) !important; }
.text-5xl { font-size: var(--font-5xl) !important; }

/* Pesos de fuente */
.font-normal { font-weight: var(--font-normal) !important; }
.font-medium { font-weight: var(--font-medium) !important; }
.font-semibold { font-weight: var(--font-semibold) !important; }
.font-bold { font-weight: var(--font-bold) !important; }

/* Familia de fuente */
.font-mono { font-family: var(--font-mono) !important; }

/* Colores de texto */
.text-primary { color: var(--color-text-primary) !important; }
.text-secondary { color: var(--color-text-secondary) !important; }
.text-muted { color: var(--color-text-muted) !important; }
.text-success { color: var(--color-success) !important; }
.text-warning { color: var(--color-warning) !important; }
.text-danger { color: var(--color-danger) !important; }
.text-info { color: var(--color-info) !important; }
.text-purple { color: var(--color-purple) !important; }
.text-teal { color: var(--color-teal) !important; }

/* Alineación de texto */
.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }

/* ============================================================================
   COMPONENTES REUTILIZABLES
   ============================================================================ */

/* Títulos de modal */
.modal-title {
    font-size: var(--font-xl);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-md);
}

.modal-subtitle {
    font-size: var(--font-md);
    font-weight: var(--font-medium);
    color: var(--color-text-secondary);
}

/* Iconos en modales */
.modal-icon {
    font-size: var(--font-4xl);
    margin-bottom: var(--spacing-sm);
}

.modal-icon-lg {
    font-size: var(--font-5xl);
    margin-bottom: var(--spacing-md);
}

/* Texto en modales */
.modal-text {
    font-size: var(--font-base);
    color: var(--color-text-primary);
    line-height: var(--line-normal);
}

.modal-text-sm {
    font-size: var(--font-sm);
    color: var(--color-text-secondary);
}

/* Labels en formularios */
.form-label {
    font-size: var(--font-sm);
    font-weight: var(--font-medium);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    display: block;
}

/* Inputs */
.form-input {
    font-size: var(--font-base);
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    width: 100%;
    transition: border-color var(--transition-fast);
}

.form-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(49, 130, 206, 0.1);
}

/* Tablas */
.table-header {
    font-size: var(--font-xs);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    color: var(--color-text-secondary);
    letter-spacing: 0.05em;
}

.table-cell {
    font-size: var(--font-sm);
    color: var(--color-text-primary);
}

.table-cell-meta {
    font-size: var(--font-xs);
    color: var(--color-text-muted);
}

/* Badges */
.badge {
    font-size: var(--font-xs);
    font-weight: var(--font-medium);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-full);
    display: inline-block;
}

/* Estadísticas */
.stat-value {
    font-size: var(--font-2xl);
    font-weight: var(--font-bold);
    color: var(--color-text-primary);
}

.stat-label {
    font-size: var(--font-xs);
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.stat-icon {
    font-size: var(--font-xl);
}

/* Metadatos (proyecto, partida, etc.) */
.meta-proyecto {
    font-size: var(--font-xs);
    color: var(--color-purple);
}

.meta-partida {
    font-size: var(--font-xs);
    color: var(--color-teal);
}

.meta-aprobador {
    font-size: var(--font-xs);
    color: var(--color-primary);
}

/* ============================================================================
   ICONOS FONTAWESOME - Reglas Globales para Asegurar Renderizado
   ============================================================================ */

/* Asegurar que todos los iconos FontAwesome se rendericen correctamente */
button i.fas,
button i.far,
button i.fab,
a i.fas,
a i.far,
a i.fab,
.btn i.fas,
.btn i.far,
.btn i.fab {
    font-family: 'Font Awesome 6 Free', 'Font Awesome 6 Brands', sans-serif !important;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: inline-block;
    line-height: 1;
}

/* Iconos sólidos (fas) requieren font-weight 900 */
button i.fas,
a i.fas,
.btn i.fas {
    font-weight: 900 !important;
}

/* Iconos regular (far) requieren font-weight 400 */
button i.far,
a i.far,
.btn i.far {
    font-weight: 400 !important;
}

/* Iconos de brands (fab) */
button i.fab,
a i.fab,
.btn i.fab {
    font-family: 'Font Awesome 6 Brands' !important;
    font-weight: 400 !important;
}
