/**
 * CSS PERSONALIZADO - INTRANET ECIJA MÉXICO
 * Archivo: css/custom.css
 * Todo el CSS personalizado separado del HTML
 */

/* ==============================================
   VARIABLES TIPOGRÁFICAS
   ============================================== */
:root {
  --font-family-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
  
  /* Pesos de fuente Inter */
  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;
  --font-weight-black: 900;
  
  /* Espaciado optimizado para Inter */
  --letter-spacing-tight: -0.02em;
  --letter-spacing-normal: -0.003em;
  --letter-spacing-wide: 0.005em;
}

/* ==============================================
   TIPOGRAFÍA INTER - REEMPLAZO DE JOSEFIN SANS
   ============================================== */
body,
.qrt-app,
.qrt-preloader,
.qrt-top-bar,
.qrt-left-bar,
.qrt-content,
h1, h2, h3, h4, h5, h6,
p, span, div, button, input, textarea, select,
.qrt-btn,
.qrt-title,
.qrt-text,
.qrt-info,
.qrt-table,
.qrt-current-page-title,
.qrt-leng {
  font-family: var(--font-family-primary) !important;
}

/* PRESERVAR ICONOS DE FONTAWESOME */
.fas, .far, .fab, .fal, .fad,
[class^="fa-"], [class*=" fa-"],
.fa::before, .fas::before, .far::before, .fab::before {
  font-family: "Font Awesome 5 Free", "Font Awesome 5 Brands", "Font Awesome 5 Pro" !important;
}

/* OPTIMIZACIONES DE RENDERIZADO */
body {
  font-feature-settings: 'cv02', 'cv03', 'cv04', 'cv11';
  font-variant-numeric: oldstyle-nums;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-normal);
}

/* ==============================================
   JERARQUÍA TIPOGRÁFICA
   ============================================== */
h1, .h1 {
  font-weight: var(--font-weight-bold) !important;
  letter-spacing: var(--letter-spacing-tight);
  line-height: 1.2;
}

h2, .h2 {
  font-weight: var(--font-weight-semibold) !important;
  letter-spacing: var(--letter-spacing-tight);
  line-height: 1.3;
}

h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  font-weight: var(--font-weight-semibold) !important;
  line-height: 1.4;
}

p, .qrt-text {
  font-weight: var(--font-weight-regular) !important;
  line-height: 1.6;
  letter-spacing: var(--letter-spacing-normal);
}

/* ==============================================
   COMPONENTES ESPECÍFICOS
   ============================================== */

/* Navegación */
.qrt-current-page-title a {
  font-weight: var(--font-weight-semibold) !important;
  letter-spacing: var(--letter-spacing-tight);
}

/* Botones */
.qrt-btn {
  font-weight: var(--font-weight-medium) !important;
  letter-spacing: var(--letter-spacing-wide);
}

.qrt-btn-sm { font-size: 14px; }
.qrt-btn-md { font-size: 16px; }
.qrt-btn-lg { 
  font-size: 18px; 
  font-weight: var(--font-weight-semibold) !important;
}

/* Toggle de tema */
.qrt-leng {
  font-weight: var(--font-weight-medium) !important;
  font-size: 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  padding: 0 !important;
}

.qrt-leng i {
  font-size: 14px;
}

/* ==============================================
   CAMPOS EDITABLES - EXPEDIENTE
   ============================================== */
.rfix {
  position: fixed;
  top: 90px;
  right: 10px;
  width: 340px;
  height: calc(100vh - 100px);
}

.qrt-editable {
  border-left: 3px solid #FF392A !important;
  position: relative;
}

.qrt-field-modified {
  animation: fieldHighlight 0.3s ease;
  background-color: rgba(255, 57, 42, 0.05) !important;
  border-color: #FF392A !important;
  box-shadow: 0 0 0 2px rgba(255, 57, 42, 0.1) !important;
}

@keyframes fieldHighlight {
  0% { background-color: rgba(255, 57, 42, 0.1); }
  100% { background-color: rgba(255, 57, 42, 0.05); }
}

.qrt-edit-indicator {
  color: #FF392A;
  font-size: 12px;
  margin-left: 5px;
  opacity: 0.8;
}

.qrt-editable:focus {
  border-left-color: #FF392A !important;
  box-shadow: 0 0 0 2px rgba(255, 57, 42, 0.1) !important;
}

/* Campos readonly */
.qrt-form-field input[readonly] {
  background-color: rgba(0, 0, 0, 0.05);
  border-color: rgba(0, 0, 0, 0.1);
  cursor: not-allowed;
}

/* ==============================================
   ALERTAS PERSONALIZADAS
   ============================================== */
.qrt-alert {
  padding: 20px;
  border-radius: 8px;
  margin-bottom: 30px;
  border-left: 4px solid;
  display: flex;
  align-items: center;
  gap: 15px;
}

.qrt-alert i {
  font-size: 24px;
  flex-shrink: 0;
}

.qrt-alert-success {
  background-color: rgba(40, 167, 69, 0.1);
  border-left-color: #28a745;
  color: #155724;
}

.qrt-alert-error {
  background-color: rgba(220, 53, 69, 0.1);
  border-left-color: #dc3545;
  color: #721c24;
}

.qrt-alert-info {
  background-color: rgba(23, 162, 184, 0.1);
  border-left-color: #17a2b8;
  color: #0c5460;
}

/* ==============================================
   UTILIDADES
   ============================================== */
.qrt-p-0-40 { padding: 0 40px; }
.qrt-mr-10 { margin-right: 10px; }
.qrt-mr-15 { margin-right: 15px; }

/* ==============================================
   TRANSICIONES SUAVES
   ============================================== */
body,
.qrt-app,
.qrt-left-bar,
.qrt-top-bar,
.qrt-content,
.qrt-preloader {
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* ==============================================
   RESPONSIVE
   ============================================== */
@media (max-width: 1200px) {
  .qrt-p-0-40 {
    padding: 0 20px;
  }
  
  .qrt-alert {
    flex-direction: column;
    text-align: center;
  }
}

@media (max-width: 768px) {
  h1, .h1 {
    font-weight: var(--font-weight-semibold) !important;
  }
  
  h2, .h2 {
    font-weight: var(--font-weight-medium) !important;
  }
  
  .qrt-btn {
    font-weight: var(--font-weight-medium) !important;
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

#qrt-fixed-panel.show {
  display: block !important;
  animation: slideInRight 5s ease-out forwards;
}