/* ============================================
   RentingOS Design System
   CSS Variables & Theme Configuration
   ============================================ */

:root {
  /* ============================================
     PALETA DE COLORES - AZUL (Confianza)
     ============================================ */
  --color-blue-50: #E6F1FB;
  --color-blue-100: #B5D4F4;
  --color-blue-200: #85B7EB;
  --color-blue-300: #5898E8;
  --color-blue-400: #378ADD;
  --color-blue-500: #2575BE;
  --color-blue-600: #185FA5;
  --color-blue-700: #0F4A82;
  --color-blue-800: #0C447C;
  --color-blue-900: #042C53;

  /* ============================================
     PALETA DE COLORES - VERDE (Crecimiento)
     ============================================ */
  --color-green-50: #EAF3DE;
  --color-green-100: #C0DD97;
  --color-green-200: #97C459;
  --color-green-300: #7AB840;
  --color-green-400: #639922;
  --color-green-500: #518119;
  --color-green-600: #0F6E56;
  --color-green-700: #0E5F4A;
  --color-green-800: #27500A;
  --color-green-900: #173404;

  /* ============================================
     PALETA DE COLORES - GRIS (Solidez)
     ============================================ */
  --color-gray-50: #F1EFE8;
  --color-gray-100: #D3D1C7;
  --color-gray-200: #B4B2A9;
  --color-gray-300: #9E9C93;
  --color-gray-400: #888780;
  --color-gray-500: #6F6E6A;
  --color-gray-600: #5F5E5A;
  --color-gray-700: #4F4E4A;
  --color-gray-800: #444441;
  --color-gray-900: #2C2C2A;

  /* ============================================
     PALETA DE COLORES - ORO (Atención)
     ============================================ */
  --color-gold-50: #FAEEDA;
  --color-gold-100: #FAC775;
  --color-gold-200: #EF9F27;
  --color-gold-300: #DA8B1A;
  --color-gold-400: #BA7517;
  --color-gold-500: #A46813;
  --color-gold-600: #854F0B;
  --color-gold-700: #6B4008;
  --color-gold-800: #633806;
  --color-gold-900: #412402;

  /* ============================================
     COLORES SEMÁNTICOS
     ============================================ */
  --color-success: #0F6E56;
  --color-success-light: #EAF3DE;
  --color-warning: #BA7517;
  --color-warning-light: #FAEEDA;
  --color-error: #E24B4A;
  --color-error-light: #FCEBEB;
  --color-info: #185FA5;
  --color-info-light: #E6F1FB;

  /* ============================================
     COLORES NEUTROS
     ============================================ */
  --color-white: #FFFFFF;
  --color-black: #000000;
  --color-text-primary: #2C2C2A;
  --color-text-secondary: #5F5E5A;
  --color-text-tertiary: #888780;
  --color-text-muted: #B4B2A9;
  --color-background-primary: #FFFFFF;
  --color-background-secondary: #F1EFE8;
  --color-background-tertiary: #E6F1FB;
  --color-border-light: #D3D1C7;
  --color-border-medium: #B4B2A9;
  --color-border-dark: #5F5E5A;

  /* ============================================
     TIPOGRAFÍA
     ============================================ */
  --font-family-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto',
    'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans',
    'Helvetica Neue', sans-serif;
  --font-family-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono',
    Consolas, 'Courier New', monospace;

  /* Font Weights */
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* Font Sizes */
  --font-size-xs: 12px;
  --font-size-sm: 14px;
  --font-size-base: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 28px;
  --font-size-4xl: 32px;

  /* Line Heights */
  --line-height-tight: 1.2;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.75;
  --line-height-loose: 2;

  /* ============================================
     ESPACIADO (Base 8px)
     ============================================ */
  --spacing-0: 0;
  --spacing-1: 4px;
  --spacing-2: 8px;
  --spacing-3: 12px;
  --spacing-4: 16px;
  --spacing-5: 20px;
  --spacing-6: 24px;
  --spacing-8: 32px;
  --spacing-10: 40px;
  --spacing-12: 48px;
  --spacing-16: 64px;

  /* ============================================
     BORDER RADIUS
     ============================================ */
  --radius-none: 0;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 20px;
  --radius-full: 9999px;

  /* ============================================
     SOMBRAS (Flat Design - Mínimas)
     ============================================ */
  --shadow-none: none;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.15);
  --shadow-focus: 0 0 0 3px var(--color-blue-100);

  /* ============================================
     TRANSICIONES
     ============================================ */
  --transition-fast: 150ms ease-in-out;
  --transition-base: 250ms ease-in-out;
  --transition-slow: 350ms ease-in-out;

  /* ============================================
     Z-INDEX SCALE
     ============================================ */
  --z-hide: -1;
  --z-base: 0;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-fixed: 300;
  --z-modal-backdrop: 400;
  --z-modal: 500;
  --z-tooltip: 600;
  --z-notification: 700;
}

/* ============================================
   RESETEO Y BASE
   ============================================ */

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: var(--font-size-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-family-sans);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  background-color: var(--color-background-primary);
}

/* ============================================
   TIPOGRAFÍA - HEADINGS
   ============================================ */

h1 {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-4);
}

h2 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-3);
}

h3 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-3);
}

h4 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-2);
}

h5 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-2);
}

h6 {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-2);
}

/* ============================================
   TIPOGRAFÍA - BODY TEXT
   ============================================ */

p {
  margin-bottom: var(--spacing-4);
  line-height: var(--line-height-relaxed);
}

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

a {
  color: var(--color-blue-600);
  text-decoration: none;
  cursor: pointer;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-blue-800);
}

a:active {
  color: var(--color-blue-900);
}

/* ============================================
   BOTONES
   ============================================ */

button,
input[type='button'],
input[type='submit'] {
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  border-radius: var(--radius-md);
  padding: var(--spacing-2) var(--spacing-4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
}

/* Botón Primario */
.btn-primary {
  background-color: var(--color-blue-600);
  color: white;
  border: 1px solid var(--color-blue-600);
}

.btn-primary:hover {
  background-color: var(--color-blue-800);
  border-color: var(--color-blue-800);
}

.btn-primary:active {
  transform: scale(0.98);
}

.btn-primary:disabled {
  background-color: var(--color-gray-400);
  border-color: var(--color-gray-400);
  cursor: not-allowed;
  opacity: 0.6;
}

/* Botón Secundario */
.btn-secondary {
  background-color: transparent;
  color: var(--color-blue-600);
  border: 1px solid var(--color-blue-600);
}

.btn-secondary:hover {
  background-color: var(--color-blue-50);
  border-color: var(--color-blue-800);
  color: var(--color-blue-800);
}

.btn-secondary:active {
  background-color: var(--color-blue-100);
  transform: scale(0.98);
}

.btn-secondary:disabled {
  color: var(--color-gray-400);
  border-color: var(--color-gray-400);
  cursor: not-allowed;
}

/* Botón Tertiary */
.btn-tertiary {
  background-color: transparent;
  color: var(--color-blue-600);
  border: none;
  padding: var(--spacing-1) var(--spacing-2);
  text-decoration: underline;
}

.btn-tertiary:hover {
  color: var(--color-blue-800);
  text-decoration-thickness: 2px;
}

.btn-tertiary:disabled {
  color: var(--color-gray-400);
  cursor: not-allowed;
}

/* Botón Peligroso */
.btn-danger {
  background-color: var(--color-error);
  color: white;
  border: 1px solid var(--color-error);
}

.btn-danger:hover {
  background-color: #c73939;
  border-color: #c73939;
}

.btn-danger:active {
  transform: scale(0.98);
}

/* ============================================
   INPUTS & FORM ELEMENTS
   ============================================ */

input,
select,
textarea {
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
  padding: var(--spacing-2) var(--spacing-3);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  background-color: var(--color-background-primary);
  color: var(--color-text-primary);
  transition: border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--color-blue-600);
  box-shadow: var(--shadow-focus);
}

input:disabled,
select:disabled,
textarea:disabled {
  background-color: var(--color-background-secondary);
  color: var(--color-text-muted);
  cursor: not-allowed;
}

label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-1);
}

/* ============================================
   ALERTAS
   ============================================ */

.alert {
  padding: var(--spacing-3) var(--spacing-4);
  border-radius: var(--radius-md);
  border-left: 4px solid;
  margin-bottom: var(--spacing-4);
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-3);
}

.alert-icon {
  font-size: var(--font-size-lg);
  flex-shrink: 0;
}

.alert-content {
  flex: 1;
}

.alert-title {
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-1);
}

.alert-description {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-normal);
}

/* Alert Success */
.alert-success {
  background-color: var(--color-success-light);
  border-color: var(--color-success);
  color: var(--color-success);
}

.alert-success .alert-title {
  color: var(--color-green-800);
}

/* Alert Warning */
.alert-warning {
  background-color: var(--color-warning-light);
  border-color: var(--color-warning);
  color: var(--color-warning);
}

.alert-warning .alert-title {
  color: var(--color-gold-800);
}

/* Alert Error */
.alert-error {
  background-color: var(--color-error-light);
  border-color: var(--color-error);
  color: var(--color-error);
}

.alert-error .alert-title {
  color: #a23939;
}

/* Alert Info */
.alert-info {
  background-color: var(--color-info-light);
  border-color: var(--color-info);
  color: var(--color-info);
}

.alert-info .alert-title {
  color: var(--color-blue-800);
}

/* ============================================
   CARDS
   ============================================ */

.card {
  background-color: var(--color-background-primary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  padding: var(--spacing-4);
  transition: border-color var(--transition-base),
    box-shadow var(--transition-base);
}

.card:hover {
  border-color: var(--color-border-medium);
  box-shadow: var(--shadow-md);
}

.card-header {
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: var(--spacing-3);
  margin-bottom: var(--spacing-3);
}

.card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

.card-subtitle {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-top: var(--spacing-1);
}

.card-body {
  margin-bottom: var(--spacing-3);
}

.card-footer {
  border-top: 1px solid var(--color-border-light);
  padding-top: var(--spacing-3);
  margin-top: var(--spacing-3);
  display: flex;
  gap: var(--spacing-2);
}

/* ============================================
   BADGES
   ============================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--spacing-1) var(--spacing-2);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}

.badge-primary {
  background-color: var(--color-blue-100);
  color: var(--color-blue-800);
}

.badge-success {
  background-color: var(--color-green-50);
  color: var(--color-green-800);
}

.badge-warning {
  background-color: var(--color-gold-50);
  color: var(--color-gold-800);
}

.badge-error {
  background-color: var(--color-error-light);
  color: #a23939;
}

.badge-neutral {
  background-color: var(--color-gray-100);
  color: var(--color-gray-800);
}

/* ============================================
   TABLAS
   ============================================ */

table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

thead {
  background-color: var(--color-background-secondary);
  border-bottom: 1px solid var(--color-border-light);
}

th {
  padding: var(--spacing-3) var(--spacing-4);
  text-align: left;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

td {
  padding: var(--spacing-3) var(--spacing-4);
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text-secondary);
}

tbody tr:hover {
  background-color: var(--color-background-secondary);
}

/* ============================================
   UTILIDADES
   ============================================ */

.text-primary {
  color: var(--color-text-primary);
}

.text-secondary {
  color: var(--color-text-secondary);
}

.text-tertiary {
  color: var(--color-text-tertiary);
}

.text-blue {
  color: var(--color-blue-600);
}

.text-green {
  color: var(--color-green-600);
}

.text-gold {
  color: var(--color-gold-400);
}

.text-success {
  color: var(--color-success);
}

.text-error {
  color: var(--color-error);
}

.bg-primary {
  background-color: var(--color-background-primary);
}

.bg-secondary {
  background-color: var(--color-background-secondary);
}

.bg-blue-light {
  background-color: var(--color-blue-50);
}

.bg-green-light {
  background-color: var(--color-green-50);
}

.border-light {
  border: 1px solid var(--color-border-light);
}

.border-medium {
  border: 1px solid var(--color-border-medium);
}

.rounded-sm {
  border-radius: var(--radius-sm);
}

.rounded-md {
  border-radius: var(--radius-md);
}

.rounded-lg {
  border-radius: var(--radius-lg);
}

.shadow-sm {
  box-shadow: var(--shadow-sm);
}

.shadow-md {
  box-shadow: var(--shadow-md);
}

/* Espaciado rápido */
.mt-1 {
  margin-top: var(--spacing-1);
}
.mt-2 {
  margin-top: var(--spacing-2);
}
.mt-3 {
  margin-top: var(--spacing-3);
}
.mt-4 {
  margin-top: var(--spacing-4);
}

.mb-1 {
  margin-bottom: var(--spacing-1);
}
.mb-2 {
  margin-bottom: var(--spacing-2);
}
.mb-3 {
  margin-bottom: var(--spacing-3);
}
.mb-4 {
  margin-bottom: var(--spacing-4);
}

.p-2 {
  padding: var(--spacing-2);
}
.p-3 {
  padding: var(--spacing-3);
}
.p-4 {
  padding: var(--spacing-4);
}

.gap-2 {
  gap: var(--spacing-2);
}
.gap-3 {
  gap: var(--spacing-3);
}
.gap-4 {
  gap: var(--spacing-4);
}
