/* ===========================
   layout_index.css
   Pantalla de Login – Versionado con tokens
   Requiere: styles_variables.css
   =========================== */

/* Reinicio básico + tipografía por token */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: var(--font-family);
  scrollbar-width: thin;
  scrollbar-color: var(--color-muted) var(--color-surface);
  list-style: none;
  text-decoration: none;
}

html, body { height: 100%; }

body {
  background-color: var(--color-bg);
  color: var(--color-text);
  overflow-x: hidden;
}

/* Enlaces */
a {
  color: var(--color-primary);
  text-decoration: none;
}
a:visited { color: var(--color-primary); }

/* ===========================
   Layout del login
   =========================== */
.login-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100dvh;               /* mejor manejo en móviles */
  background-color: var(--color-bg);
  padding: var(--space-6);
  box-sizing: border-box;
}

/* Tarjeta de login */
.login-form {
  background: var(--color-surface);
  color: var(--color-text);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
  width: 100%;
  max-width: 640px;
  box-sizing: border-box;
  border: 1px solid var(--color-border);
}

/* Título */
.form-title {
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--color-text);
  text-align: center;
  margin-bottom: var(--space-4);
}

/* Grupos de campos */
.form-group {
  margin-bottom: var(--space-4);
}

.form-label {
  font-size: var(--fs-sm);
  color: var(--color-text-2);
  margin-bottom: var(--space-1);
  display: block;
}

/* Inputs */
.form-input {
  display: block;
  width: 100%;
  height: var(--h-input);
  padding: 0 var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-text);
  background-color: var(--field-bg);
  border: 1px solid var(--field-border);
  border-radius: var(--radius-sm);
  box-sizing: border-box;
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-input::placeholder {
  color: var(--color-muted);
}

.form-input:focus {
  border-color: var(--field-border-focus);
  box-shadow: 0 0 0 3px var(--field-outline-focus);
}

/* Acciones */
.form-actions {
  text-align: center;
  margin-top: var(--space-4);
}

/* Botón primario */
.form-button {
  width: 100%;
  height: var(--h-input);
  padding: 0 var(--space-3);
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--color-on-primary);
  background-color: var(--btn-primary-bg);
  border: 1px solid var(--btn-primary-bd);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.form-button:hover {
  background-color: var(--btn-primary-bg-h);
}

.form-button:active {
  transform: translateY(1px);
}

/* Branding / Logo */
.login-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.logo-container { display: flex; justify-content: center; }

.login-logo {
  width: 120px;
  height: auto;
  object-fit: contain;
  filter: none; /* el tema se maneja por tokens, no por filtro */
}

/* ===========================
   Responsivo
   =========================== */
@media (max-width: var(--bp-md)) {
  .login-form {
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-2);
    width: 100%;
    max-width: 98vw;
    margin-top: 0;
    font-size: var(--fs-xs);
  }

  .form-title {
    font-size: var(--fs-base);
  }

  .form-input, .form-button {
    font-size: var(--fs-xs);
    height: calc(var(--h-input) - 6px);
    padding: 0 var(--space-2);
  }

  .login-logo {
    max-width: 100px;
    width: 50%;
  }

  .login-container {
    padding: var(--space-2);
  }
}

@media (min-width: var(--bp-xl)) {
  .login-form {
    padding: var(--space-7);
    border-radius: var(--radius-lg);
  }
}
