/* ==========================================================================
   VOLTARGY DESIGN SYSTEM - SISTEMA DE VARIABLES CSS
   ==========================================================================
   Sistema de diseno para la marca Voltargy en la plataforma Servicon.
   Este archivo define todas las variables CSS para colores, tipografia,
   espaciado, sombras y otros tokens de diseno.
   ========================================================================== */

/* ==========================================================================
   COLORES DE MARCA VOLTARGY
   ========================================================================== */

:root {
  /* Colores principales de la marca */
  --voltargy-primary: #124B8E;
  --voltargy-secondary: #06B258;
  --voltargy-text: #000000;
  --voltargy-background: #FFFFFF;

  /* Variantes de colores primarios - tonos mas claros y oscuros */
  --voltargy-primary-light: #1A6BC4;
  --voltargy-primary-lighter: #3D8DE0;
  --voltargy-primary-lightest: #E8F0F9;
  --voltargy-primary-dark: #0D3562;
  --voltargy-primary-darker: #082440;

  /* Variantes de colores secundarios */
  --voltargy-secondary-light: #08D96E;
  --voltargy-secondary-lighter: #3FE38D;
  --voltargy-secondary-lightest: #E6F9EF;
  --voltargy-secondary-dark: #058944;
  --voltargy-secondary-darker: #036230;
}

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

:root {
  /* Colores principales de Bootstrap usando colores Voltargy */
  --bs-primary: #124B8E;
  --bs-primary-rgb: 18, 75, 142;
  --bs-primary-text-emphasis: #0D3562;
  --bs-primary-bg-subtle: #E8F0F9;
  --bs-primary-border-subtle: #3D8DE0;

  --bs-success: #06B258;
  --bs-success-rgb: 6, 178, 88;
  --bs-success-text-emphasis: #036230;
  --bs-success-bg-subtle: #E6F9EF;
  --bs-success-border-subtle: #3FE38D;

  --bs-secondary: #6C757D;
  --bs-secondary-rgb: 108, 117, 125;
  --bs-secondary-text-emphasis: #2B2F32;
  --bs-secondary-bg-subtle: #E2E3E5;
  --bs-secondary-border-subtle: #A6ACAF;

  --bs-danger: #DC3545;
  --bs-danger-rgb: 220, 53, 69;
  --bs-danger-text-emphasis: #A02834;
  --bs-danger-bg-subtle: #F8D7DA;
  --bs-danger-border-subtle: #E87D85;

  --bs-warning: #FFC107;
  --bs-warning-rgb: 255, 193, 7;
  --bs-warning-text-emphasis: #997404;
  --bs-warning-bg-subtle: #FFF3CD;
  --bs-warning-border-subtle: #FFD966;

  --bs-info: #0DCAF0;
  --bs-info-rgb: 13, 202, 240;
  --bs-info-text-emphasis: #087990;
  --bs-info-bg-subtle: #CFF4FC;
  --bs-info-border-subtle: #6EDFF6;

  --bs-light: #F8F9FA;
  --bs-light-rgb: 248, 249, 250;
  --bs-light-text-emphasis: #6C757D;
  --bs-light-bg-subtle: #FCFCFD;
  --bs-light-border-subtle: #E9ECEF;

  --bs-dark: #212529;
  --bs-dark-rgb: 33, 37, 41;
  --bs-dark-text-emphasis: #212529;
  --bs-dark-bg-subtle: #CED4DA;
  --bs-dark-border-subtle: #868E96;

  /* Color de cuerpo */
  --bs-body-color: #000000;
  --bs-body-color-rgb: 0, 0, 0;
  --bs-body-bg: #FFFFFF;
  --bs-body-bg-rgb: 255, 255, 255;

  /* Colores de enlaces */
  --bs-link-color: #124B8E;
  --bs-link-color-rgb: 18, 75, 142;
  --bs-link-hover-color: #0D3562;
  --bs-link-hover-color-rgb: 13, 53, 98;

  /* Colores de bordes */
  --bs-border-color: #DEE2E6;
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
}

/* ==========================================================================
   VARIABLES SEMANTICAS
   ========================================================================== */

:root {
  /* Estados de validacion */
  --color-success: #06B258;
  --color-success-light: #E6F9EF;
  --color-success-dark: #036230;

  --color-danger: #DC3545;
  --color-danger-light: #F8D7DA;
  --color-danger-dark: #A02834;

  --color-warning: #FFC107;
  --color-warning-light: #FFF3CD;
  --color-warning-dark: #997404;

  --color-info: #0DCAF0;
  --color-info-light: #CFF4FC;
  --color-info-dark: #087990;

  /* Estados de elementos interactivos */
  --color-hover: rgba(18, 75, 142, 0.08);
  --color-active: rgba(18, 75, 142, 0.16);
  --color-focus: rgba(18, 75, 142, 0.24);
  --color-disabled: #E9ECEF;
  --color-disabled-text: #ADB5BD;

  /* Grises neutrales */
  --color-gray-50: #F8F9FA;
  --color-gray-100: #F1F3F5;
  --color-gray-200: #E9ECEF;
  --color-gray-300: #DEE2E6;
  --color-gray-400: #CED4DA;
  --color-gray-500: #ADB5BD;
  --color-gray-600: #6C757D;
  --color-gray-700: #495057;
  --color-gray-800: #343A40;
  --color-gray-900: #212529;
}

/* ==========================================================================
   TIPOGRAFIA
   ========================================================================== */

:root {
  /* Familia de fuentes - Inter de Google Fonts */
  --font-family-base: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
  --font-family-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
  --font-family-mono: 'Courier New', Courier, monospace;

  /* Tamanos de fuente */
  --font-size-xs: 0.75rem;      /* 12px */
  --font-size-sm: 0.875rem;     /* 14px */
  --font-size-base: 1rem;       /* 16px */
  --font-size-md: 1.125rem;     /* 18px */
  --font-size-lg: 1.25rem;      /* 20px */
  --font-size-xl: 1.5rem;       /* 24px */
  --font-size-2xl: 1.875rem;    /* 30px */
  --font-size-3xl: 2.25rem;     /* 36px */
  --font-size-4xl: 3rem;        /* 48px */

  /* Pesos de fuente */
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;

  /* Altura de linea */
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;

  /* Espaciado de letras */
  --letter-spacing-tight: -0.025em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.025em;
  --letter-spacing-wider: 0.05em;
}

/* ==========================================================================
   SISTEMA DE ESPACIADO
   ========================================================================== */

:root {
  /* Espaciado base (basado en 4px) */
  --spacing-0: 0;
  --spacing-1: 0.25rem;   /* 4px */
  --spacing-2: 0.5rem;    /* 8px */
  --spacing-3: 0.75rem;   /* 12px */
  --spacing-4: 1rem;      /* 16px */
  --spacing-5: 1.25rem;   /* 20px */
  --spacing-6: 1.5rem;    /* 24px */
  --spacing-8: 2rem;      /* 32px */
  --spacing-10: 2.5rem;   /* 40px */
  --spacing-12: 3rem;     /* 48px */
  --spacing-16: 4rem;     /* 64px */
  --spacing-20: 5rem;     /* 80px */
  --spacing-24: 6rem;     /* 96px */

  /* Espaciado semantico */
  --spacing-xs: var(--spacing-2);   /* 8px */
  --spacing-sm: var(--spacing-3);   /* 12px */
  --spacing-md: var(--spacing-4);   /* 16px */
  --spacing-lg: var(--spacing-6);   /* 24px */
  --spacing-xl: var(--spacing-8);   /* 32px */
  --spacing-2xl: var(--spacing-12); /* 48px */
}

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

:root {
  /* Sombras de elevacion */
  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.05);
  --shadow-none: none;

  /* Sombras especificas para componentes */
  --shadow-card: var(--shadow-sm);
  --shadow-card-hover: var(--shadow-md);
  --shadow-modal: var(--shadow-xl);
  --shadow-dropdown: var(--shadow-lg);
  --shadow-focus: 0 0 0 3px rgba(18, 75, 142, 0.24);
}

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

:root {
  /* Anchos de borde */
  --border-width-0: 0;
  --border-width-1: 1px;
  --border-width-2: 2px;
  --border-width-4: 4px;

  /* Radios de borde */
  --border-radius-none: 0;
  --border-radius-sm: 0.125rem;   /* 2px */
  --border-radius-base: 0.25rem;  /* 4px */
  --border-radius-md: 0.375rem;   /* 6px */
  --border-radius-lg: 0.5rem;     /* 8px */
  --border-radius-xl: 0.75rem;    /* 12px */
  --border-radius-2xl: 1rem;      /* 16px */
  --border-radius-3xl: 1.5rem;    /* 24px */
  --border-radius-full: 9999px;

  /* Colores de borde */
  --border-color-light: var(--color-gray-200);
  --border-color-base: var(--color-gray-300);
  --border-color-dark: var(--color-gray-400);
  --border-color-primary: var(--voltargy-primary);
  --border-color-secondary: var(--voltargy-secondary);
  --border-color-danger: var(--color-danger);
  --border-color-success: var(--color-success);
  --border-color-warning: var(--color-warning);
  --border-color-info: var(--color-info);
}

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

:root {
  /* Duraciones */
  --transition-fast: 150ms;
  --transition-base: 250ms;
  --transition-slow: 350ms;
  --transition-slower: 500ms;

  /* Funciones de tiempo */
  --transition-ease: ease;
  --transition-ease-in: ease-in;
  --transition-ease-out: ease-out;
  --transition-ease-in-out: ease-in-out;

  /* Transiciones completas */
  --transition-all: all var(--transition-base) var(--transition-ease-in-out);
  --transition-color: color var(--transition-fast) var(--transition-ease-in-out),
                      background-color var(--transition-fast) var(--transition-ease-in-out),
                      border-color var(--transition-fast) var(--transition-ease-in-out);
  --transition-transform: transform var(--transition-base) var(--transition-ease-out);
  --transition-opacity: opacity var(--transition-base) var(--transition-ease-in-out);
}

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

:root {
  --z-index-dropdown: 1000;
  --z-index-sticky: 1020;
  --z-index-fixed: 1030;
  --z-index-modal-backdrop: 1040;
  --z-index-modal: 1050;
  --z-index-popover: 1060;
  --z-index-tooltip: 1070;
  --z-index-toast: 1080;
}

/* ==========================================================================
   ANCHOS MAXIMOS Y CONTENEDORES
   ========================================================================== */

:root {
  /* Anchos maximos para contenido */
  --max-width-xs: 20rem;      /* 320px */
  --max-width-sm: 24rem;      /* 384px */
  --max-width-md: 28rem;      /* 448px */
  --max-width-lg: 32rem;      /* 512px */
  --max-width-xl: 36rem;      /* 576px */
  --max-width-2xl: 42rem;     /* 672px */
  --max-width-3xl: 48rem;     /* 768px */
  --max-width-4xl: 56rem;     /* 896px */
  --max-width-5xl: 64rem;     /* 1024px */
  --max-width-6xl: 72rem;     /* 1152px */
  --max-width-7xl: 80rem;     /* 1280px */
  --max-width-full: 100%;
}

/* ==========================================================================
   BREAKPOINTS (Para referencia en JavaScript)
   ========================================================================== */

:root {
  --breakpoint-xs: 0px;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --breakpoint-xxl: 1400px;
}
