:root {
  /* Tomamos como base el primario del tema si existe */
  --primary-color: var(--app-primary, #0083c7);
  --secondary-color: #667eea;
  --success-color: #28a745;
  --danger-color: #dc3545;
  --warning-color: #ffc107;
  --info-color: #17a2b8;
  --light-bg: #f8f9fa;
  /* Texto oscuro por defecto, pero respetando el tema si está definido */
  --dark-text: var(--app-text, #333);
}

/* Solo tipografía, el color/fondo los controla theme.css (.app-body) */
body {
  font-family: "Heebo", sans-serif;
}

/* Botones y colores básicos, usando el primario del tema */
.btn-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}

.btn-primary:hover {
  /* pequeño oscurecimiento, sin fijar un color concreto */
  filter: brightness(0.9);
}

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

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

/* Tarjetas */
.card {
  transition: all 0.3s ease;
}

/* Que la tarjeta de login respete el color del tema (claro/oscuro) */
.auth-card {
  animation: fadeIn 0.5s ease;
  background-color: var(--app-card-bg, #ffffff) !important;
  color: var(--app-text, var(--dark-text));
}

/* Hover suave (solo desktop) */
@media (min-width: 992px) {
  .card:hover {
    transform: translateY(-2px);
  }
}

/* Sombra estándar */
.shadow {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

.shadow-sm {
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

.shadow-lg {
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

/* Inputs */
.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 0.2rem rgba(0, 131, 199, 0.25);
}

.input-group-text {
  background-color: var(--primary-color);
  color: #fff;
  border-color: var(--primary-color);
}

/* Bordes redondeados */
.rounded-4 {
  border-radius: 1rem !important;
}

/* Animación de entrada SOLO para la tarjeta de login/registro */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Responsive login */
@media (max-width: 768px) {
  /* Ya no tocamos el body (tema lo maneja).
     Sólo ajustamos márgenes/tamaños de la tarjeta. */
  .auth-card {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
  }

  .col-lg-4,
  .col-lg-8 {
    min-height: auto !important;
  }
}
/* Iconos sociales del login */
.login-social a {
  color: #1f2937;              /* gris oscuro para tema claro */
  transition: color 0.2s ease;
}

/* Tema oscuro: iconos claros */
html[data-theme="dark"] .login-social a {
  color: #f9fafb;              /* casi blanco */
}

/* Hover en tema oscuro: un toque dorado */
html[data-theme="dark"] .login-social a:hover {
  color: #facc15;
}
