/* ==============================
   Auth layout
   ============================== */

.auth-layout {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 1.5rem;
  background: var(--bg-base);
}

.auth-form-card {
  width: 100%;
  max-width: 420px;
  padding: 2.25rem 2rem;
  &:hover { transform: none; box-shadow: var(--shadow-sm); }
}

.auth-form-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--accent);
  margin-bottom: 2rem;
}

.auth-form-header {
  margin-bottom: 1.75rem;

  h1 {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    margin-bottom: .375rem;
  }

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

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: .375rem;

  & > label {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--text-primary);
  }
}

.form-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;

  a {
    font-size: var(--text-xs);
  }
}

.input-password-wrap {
  position: relative;

  .input { padding-right: 2.75rem; }

  .password-toggle {
    position: absolute;
    right: .875rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    cursor: pointer;
    line-height: 1;
    transition: color .15s;

    &:hover { color: var(--text-primary); }
  }

  input[type="password"] ~ .password-toggle .fa-eye-slash { display: none; }
  input[type="text"]     ~ .password-toggle .fa-eye       { display: none; }
}

.checkbox-wrap {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;

  input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--accent);
    cursor: pointer;
    flex-shrink: 0;
  }

  span {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    user-select: none;
  }
}

.auth-form-row {
  display: flex;
  align-items: center;
  justify-content: space-between;

  a { font-size: var(--text-xs); }
}

.btn-auth {
  width: 100%;
  height: 42px;
  margin-top: .25rem;
}
