/**
 * Variables CSS Globales - Sistema de Diseño SecureShop
 * Consolida variables de app.css y checkout.css
 */

:root {
  /* ===== COLORES PRIMARIOS ===== */
  --primary: #0ea5e9;
  --primary-dark: #0284c7;
  --primary-rgb: 14, 165, 233;

  --secondary: #64748b;
  --secondary-dark: #475569;
  --secondary-rgb: 100, 116, 139;

  /* Alias para compatibilidad con código existente */
  --brand: var(--primary);
  --brand-dark: var(--primary-dark);

  /* ===== COLORES SEMÁNTICOS ===== */
  --success: #22c55e;
  --success-dark: #16a34a;
  --success-rgb: 34, 197, 94;

  --warning: #f59e0b;
  --warning-dark: #d97706;
  --warning-rgb: 245, 158, 11;

  --danger: #ef4444;
  --danger-dark: #dc2626;
  --danger-rgb: 239, 68, 68;

  --info: #3b82f6;
  --info-dark: #2563eb;
  --info-rgb: 59, 130, 246;

  /* Alias para compatibilidad con checkout.css */
  --accent: var(--warning);

  /* ===== GRISES (INK SYSTEM) ===== */
  --ink: #0f172a;           /* Slate 900 - Texto principal */
  --ink-soft: #1e293b;      /* Slate 800 - Texto secundario */
  --ink-muted: #475569;     /* Slate 600 - Texto terciario */
  --ink-lighter: #64748b;   /* Slate 500 - Texto deshabilitado */

  /* ===== SUPERFICIES ===== */
  --surface: #ffffff;
  --surface-soft: #f8fafc;    /* Slate 50 - Fondos secundarios */
  --surface-hover: #f1f5f9;   /* Slate 100 - Hover en filas */
  --surface-dark: #e2e8f0;    /* Slate 200 - Bordes sutiles */

  /* ===== BORDES ===== */
  --border: rgba(15, 23, 42, 0.08);
  --border-light: rgba(15, 23, 42, 0.05);
  --border-medium: rgba(15, 23, 42, 0.12);
  --border-strong: rgba(15, 23, 42, 0.2);

  /* ===== SOMBRAS ===== */
  --shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.05);
  --shadow-sm: 0 2px 4px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 4px 6px rgba(15, 23, 42, 0.07);
  --shadow-lg: 0 10px 15px rgba(15, 23, 42, 0.1);
  --shadow-xl: 0 20px 25px rgba(15, 23, 42, 0.1);
  --shadow-2xl: 0 24px 60px rgba(15, 23, 42, 0.12);

  /* Alias para compatibilidad */
  --shadow: var(--shadow-2xl);

  /* ===== TIPOGRAFÍA ===== */
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', 'SF Mono', Consolas, 'Liberation Mono', Menlo, monospace;

  /* Escala tipográfica */
  --text-xs: 0.75rem;     /* 12px */
  --text-sm: 0.875rem;    /* 14px */
  --text-base: 1rem;      /* 16px */
  --text-lg: 1.125rem;    /* 18px */
  --text-xl: 1.25rem;     /* 20px */
  --text-2xl: 1.5rem;     /* 24px */
  --text-3xl: 1.875rem;   /* 30px */
  --text-4xl: 2.25rem;    /* 36px */
  --text-5xl: 3rem;       /* 48px */

  /* Pesos */
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;

  /* Line heights */
  --leading-none: 1;
  --leading-tight: 1.25;
  --leading-normal: 1.5;
  --leading-relaxed: 1.75;

  /* ===== ESPACIADO ===== */
  --space-0: 0;
  --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 */
  --space-12: 3rem;     /* 48px */
  --space-16: 4rem;     /* 64px */
  --space-20: 5rem;     /* 80px */
  --space-24: 6rem;     /* 96px */

  /* ===== BORDER RADIUS ===== */
  --radius-sm: 0.25rem;   /* 4px */
  --radius-md: 0.5rem;    /* 8px */
  --radius-lg: 0.75rem;   /* 12px */
  --radius-xl: 1rem;      /* 16px */
  --radius-2xl: 1.5rem;   /* 24px */
  --radius-full: 9999px;  /* Completamente redondo */

  /* ===== Z-INDEX SCALE ===== */
  --z-0: 0;
  --z-10: 10;
  --z-20: 20;
  --z-30: 30;
  --z-40: 40;
  --z-50: 50;
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;
  --z-toast: 1080;

  /* ===== TRANSITIONS ===== */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slower: 500ms cubic-bezier(0.4, 0, 0.2, 1);

  /* ===== BREAKPOINTS (para uso en JS) ===== */
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --breakpoint-xxl: 1400px;
}

/* ===== MODO OSCURO ===== */
:root.dark {
  --ink: #f8fafc;
  --ink-soft: #e2e8f0;
  --ink-muted: #cbd5e1;
  --ink-lighter: #94a3b8;

  --surface: #1e293b;
  --surface-soft: #334155;
  --surface-hover: #475569;
  --surface-dark: #64748b;

  --border: rgba(241, 245, 249, 0.1);
  --border-light: rgba(241, 245, 249, 0.05);
  --border-medium: rgba(241, 245, 249, 0.15);
  --border-strong: rgba(241, 245, 249, 0.25);

  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.4);
  --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.5);
  --shadow-2xl: 0 24px 60px rgba(0, 0, 0, 0.6);
}

/* Aplicar modo oscuro a componentes Bootstrap */
:root.dark .bg-light {
  background-color: var(--surface-soft) !important;
  color: var(--ink) !important;
}

:root.dark .bg-white {
  background-color: var(--surface) !important;
  color: var(--ink) !important;
}

:root.dark .text-dark {
  color: var(--ink) !important;
}

:root.dark .text-muted {
  color: var(--ink-muted) !important;
}

:root.dark .card {
  background-color: var(--surface);
  border-color: var(--border);
  color: var(--ink);
}

:root.dark .table {
  --bs-table-bg: var(--surface);
  --bs-table-color: var(--ink);
  --bs-table-striped-bg: var(--surface-hover);
  --bs-table-hover-bg: var(--surface-hover);
}

:root.dark .navbar-light {
  background-color: var(--surface) !important;
  border-color: var(--border) !important;
}

:root.dark .form-control,
:root.dark .form-select {
  background-color: var(--surface-soft);
  border-color: var(--border);
  color: var(--ink);
}

:root.dark .form-control:focus,
:root.dark .form-select:focus {
  background-color: var(--surface);
  border-color: var(--primary);
  color: var(--ink);
}

/* ===== UTILIDADES GLOBALES ===== */

/* Body defaults */
body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--ink);
  background-color: var(--surface-soft);
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--font-semibold);
  line-height: var(--leading-tight);
  color: var(--ink);
  margin-bottom: var(--space-4);
}

/* Links */
a {
  color: var(--primary);
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--primary-dark);
}

/* Code */
code, pre {
  font-family: var(--font-mono);
}

/* Selection */
::selection {
  background-color: rgba(var(--primary-rgb), 0.2);
  color: var(--ink);
}

/* Smooth scrolling */
html {
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
