/* Login Page Styles - Bitsite Design System */

@layer login {
  .login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: var(--bg-page);
    position: relative;
  }

  .login-container {
    width: 100%;
    max-width: 400px;
    padding: var(--spacing-md);
    position: relative;
  }

  .login-header {
    position: absolute;
    top: -100px;
    left: 0;
    right: 0;
    text-align: center;
  }

  .login-header h1 {
    font-size: 2rem;
    font-weight: var(--font-weight-light);
    color: var(--primary-dark);
    letter-spacing: 0.03em;
    margin-bottom: var(--spacing-sm);
  }

  .login-header p {
    font-size: 0.875rem;
    color: var(--text-color-light);
  }

  .login-main {
    background: var(--bg-color);
    border-radius: var(--radius-card);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-md);
  }

  .errornote {
    background-color: var(--error-color);
    color: var(--bg-color);
    padding: var(--spacing-md);
    border-radius: var(--radius-sm);
    margin-bottom: var(--spacing-lg);
    font-size: 0.875rem;
  }

  #login-form > * + * {
    margin-top: var(--spacing-lg);
  }

  .form-row {
    display: flex;
    flex-direction: column;
  }

  .form-row label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-color);
    margin-bottom: var(--spacing-sm);
  }

  /* Etalon input styles matching password forms */
  .form-row input[type="text"],
  .form-row input[type="password"] {
    width: 100%;
    font-size: 0.9375rem;
    font-family: var(--font-family);
    border: 2px solid var(--border-light);
    border-radius: var(--radius-card);
    transition: all 0.2s ease;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0.625rem 0.75rem;
  }

  .form-row input[type="text"]:focus,
  .form-row input[type="password"]:focus {
    outline: none !important;
    -webkit-tap-highlight-color: transparent !important;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(1, 173, 221, 0.1);
  }

  .submit-row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    align-items: stretch;
  }

  .submit-row input[type="submit"] {
    width: 100%;
    height: var(--button-height);
    line-height: var(--button-height);
    padding: 0 var(--spacing-xl);
    background-color: var(--button-bg);
    color: var(--text-color-white);
    border: none;
    border-radius: var(--radius-button);
    font-size: 0.875rem;
    font-weight: var(--font-weight-normal);
    text-transform: uppercase;
    letter-spacing: var(--button-letter-spacing);
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
  }

  .submit-row input[type="submit"]:hover {
    background-color: var(--button-hover-bg);
    box-shadow: var(--shadow-md);
  }

  .submit-row input[type="submit"]:active {
    transform: translateY(1px);
  }

  .submit-row input[type="submit"]:disabled {
    background-color: var(--button-disabled-bg);
    color: var(--button-disabled-color);
    box-shadow: none;
    cursor: default;
  }

  .submit-row a {
    text-align: center;
    font-size: 0.875rem;
    color: var(--link-color);
    text-decoration: none;
    transition: color 0.2s ease;
  }

  .submit-row a:hover {
    color: var(--link-hover-color);
    text-decoration: underline;
  }
}

/* Mobile responsive */
@media (max-width: 767px) {
  @layer login {
    .login-container {
      max-width: 100%;
      padding: var(--spacing-sm);
    }

    .login-main {
      padding: var(--spacing-lg);
    }

    .login-header h1 {
      font-size: 1.5rem;
    }
  }
}
