/* ==================================================
   SISTEMA DE DISEÑO UNIFICADO - SGTP-TV
   Base CSS: Variables globales y estilos compartidos
   ================================================== */

/* ==================================================
   NORMALIZACIÓN ENTRE NAVEGADORES
   Garantiza renderizado idéntico en Chrome, Edge, Firefox, Safari
   ================================================== */

/* Establece tamaño base consistente en todos los navegadores */
html {
    /* 16px base - todos los rem se calculan desde aquí */
    /* !important para sobrescribir estilos de Bootstrap */
    font-size: 16px !important;
    
    /* Mejora renderizado de fuentes */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    
    /* Asegura que el scroll sea suave */
    scroll-behavior: smooth;
    
    /* Evita zoom en inputs en iOS */
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* Box-sizing universal - incluye padding y border en el tamaño */
*, *::before, *::after {
    box-sizing: border-box;
}

/* Reset de márgenes y padding del body */
body {
    margin: 0;
    padding: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 1rem; /* 16px */
    line-height: 1.5;
    color: var(--color-text-primary);
    background-color: #fff;
}

/* Reset de elementos comunes */
h1, h2, h3, h4, h5, h6, p, ul, ol {
    margin: 0;
    padding: 0;
}

/* ==================================================
   VARIABLES CSS GLOBALES
   ================================================== */

:root {
    /* === ESCALA TIPOGRÁFICA UNIFICADA === */
    /* Basada en análisis de valores más usados en el proyecto */
    --font-xs: 0.75rem;      /* 12px - Textos auxiliares, labels pequeños */
    --font-sm: 0.875rem;     /* 14px - Textos secundarios, menús, tablas */
    --font-base: 1rem;       /* 16px - Texto base del proyecto */
    --font-md: 1.125rem;     /* 18px - Subtítulos, nombres de usuario */
    --font-lg: 1.25rem;      /* 20px - Títulos secundarios */
    --font-xl: 1.5rem;       /* 24px - Títulos principales, iconos grandes */
    --font-2xl: 2rem;        /* 32px - Headers, títulos hero */
    
    /* === ESCALA DE ESPACIADO UNIFICADA === */
    /* Sistema de espaciado consistente para padding y margin */
    --space-1: 0.25rem;      /* 4px */
    --space-2: 0.5rem;       /* 8px */
    --space-3: 0.75rem;      /* 12px */
    --space-4: 1rem;         /* 16px */
    --space-5: 1.25rem;      /* 20px */
    --space-6: 1.5rem;       /* 24px */
    --space-8: 2rem;         /* 32px */
    --space-10: 2.5rem;      /* 40px */
    
    /* === BORDER RADIUS UNIFICADO === */
    --radius-sm: 0.25rem;    /* 4px - Elementos pequeños */
    --radius-md: 0.5rem;     /* 8px - Botones, inputs */
    --radius-lg: 0.75rem;    /* 12px - Cards, modals */
    --radius-xl: 1rem;       /* 16px - Contenedores grandes */
    --radius-round: 50%;     /* Círculos perfectos */
    
    /* === COLORES DEL PROYECTO === */
    /* Colores principales SENA */
    --sena-green-primary: #39A900;
    --sena-green-secondary: #2E8B00;
    --sena-green-light: #4CBB17;
    --sena-green-dark: #1F5F00;
    --sena-green-bg: #F0F8E8;
    
    /* Colores de sistema (mantener compatibilidad) */
    --color-sena-green: #28a745;
    --color-sena-green-dark: #218838;
    --color-sena-green-light: #39a900;
    --color-text-primary: #212529;
    --color-text-secondary: #6c757d;
    --color-text-muted: #999;
    --color-border: #ddd;
    --color-bg-light: #f9f9f9;
    
    /* Escala de grises */
    --white: #ffffff;
    --gray-50: #f9fafb;
    --gray-100: #f3f4f6;
    --gray-200: #e5e7eb;
    --gray-300: #d1d5db;
    --gray-600: #4b5563;
    --gray-700: #374151;
    --gray-800: #1f2937;
    
    /* === SOMBRAS === */
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}

/* ==================================================
   ESTILOS GLOBALES DEL SIDEBAR
   ================================================== */

/* === CONTENEDOR PRINCIPAL DEL SIDEBAR === */
.sidebar {
    font-size: var(--font-sm);
}

/* === PERFIL DE USUARIO EN SIDEBAR === */
.sidebar-profile {
    padding: var(--space-6) var(--space-5);
}

.sidebar-avatar-container {
    width: 60px;
    height: 60px;
    margin: 0 auto var(--space-4);
    border-radius: var(--radius-round);
    overflow: hidden;
}

.sidebar-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sidebar-avatar-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-xl);
    background: rgba(255, 255, 255, 0.2);
}

.sidebar-user-info {
    text-align: center;
}

.sidebar-user-label {
    margin: 0 0 var(--space-1) 0;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.7;
}

.sidebar-user-name {
    margin: var(--space-1) 0;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.3;
}

.sidebar-user-email {
    margin: var(--space-1) 0;
    font-size: var(--font-xs);
    opacity: 0.85;
    line-height: 1.4;
}

/* === NAVEGACIÓN DEL SIDEBAR === */
.sidebar-nav {
    padding: var(--space-5) var(--space-4);
}

.sidebar-menu-item {
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-sm);
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
}

.sidebar-menu-item .menu-icon {
    font-size: var(--font-base);
    min-width: 20px;
}

.sidebar-submenu-item {
    padding: 0.625rem var(--space-3);
    font-size: var(--font-sm);
}

/* === LOGO DEL SIDEBAR === */
.sidebar-logo-container {
    padding: var(--space-6) 0;
    text-align: center;
}

.sidebar-logo-img {
    width: 80px;
    height: auto;
}

.sidebar-logo-icon {
    width: 36px;
    height: 36px;
}

/* === FOOTER DEL SIDEBAR === */
.sidebar-footer {
    padding: var(--space-5) var(--space-4);
}

/* ==================================================
   UTILIDAD: CLASES GLOBALES
   ================================================== */

/* Tipografía */
.text-xs { font-size: var(--font-xs); }
.text-sm { font-size: var(--font-sm); }
.text-base { font-size: var(--font-base); }
.text-md { font-size: var(--font-md); }
.text-lg { font-size: var(--font-lg); }
.text-xl { font-size: var(--font-xl); }
.text-2xl { font-size: var(--font-2xl); }

/* Espaciado */
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-5 { padding: var(--space-5); }
.p-6 { padding: var(--space-6); }

.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-3 { margin: var(--space-3); }
.m-4 { margin: var(--space-4); }
.m-5 { margin: var(--space-5); }
.m-6 { margin: var(--space-6); }

/* Border Radius */
.rounded-sm { border-radius: var(--radius-sm); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: var(--radius-round); }

/* Dropdown container */
.dropdown-container {
    position: relative;
    margin: 6px 0;
}

.dropdown-trigger {
    cursor: pointer;
    justify-content: space-between;
    position: relative;
}

.dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, var(--sena-green-primary) 0%, var(--sena-green-dark) 100%);
    border-radius: 12px;
    margin-top: 4px;
    padding: 6px 0;
    z-index: 100;
    box-shadow: 0 8px 20px rgba(0,0,0,0.2);
    animation: fadeIn 0.2s ease;
}

.dropdown-menu .btn {
    margin: 2px 8px;
    padding: 10px 12px;
    background: rgba(255,255,255,0.1);
    border-radius: 8px;
}

.dropdown-menu .btn:hover {
    background: rgba(255,255,255,0.25);
    transform: translateX(3px);
}

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