/* Scoped login styles only - do not affect global styles
   All rules are scoped under the .login-section wrapper */

.login-section,
.login-section * {
  box-sizing: border-box;
}

.login-section {
  --background: #ffffff;
  --foreground: #475569;
  --card: #f1f5f9;
  --card-foreground: #374151;
  --primary: #059669;
  --primary-foreground: #ffffff;
  --secondary: #f1f5f9;
  --secondary-foreground: #374151;
  --muted: #f1f5f9;
  --muted-foreground: #475569;
  --accent: #10b981;
  --accent-foreground: #ffffff;
  --destructive: #dc2626;
  --destructive-foreground: #ffffff;
  --border: #e5e7eb;
  --input: #ffffff;
  --ring: rgba(5, 150, 105, 0.12);
  --radius: 0.5rem;
  font-family: "Source Sans Pro", sans-serif;
  color: var(--foreground);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* Mobile-first: single-column, touch-friendly sizing; width 95% on small screens */
.login-section {
  /* normal document flow: allow the login container to expand and push content
     instead of being centered with flex and scrolling internally */
  display: block;
  padding: 1rem 0.9rem;
}

.login-section .login-container {
  background: var(--input);
  border-radius: calc(var(--radius) * 2);
  box-shadow: 0 10px 20px rgba(16, 24, 40, 0.06);
  padding: 1.25rem 1rem;
  width: 95%;
  max-width: 420px;
  margin: 0 auto;
  border: 1px solid var(--border);
  animation: slideUp 420ms ease-out;
  /* allow the card to grow and push content below it */
}

.login-section .login-header {
  text-align: center;
  margin-bottom: 1.25rem;
}

.login-section .login-title {
  font-family: "Playfair Display", serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--foreground);
  margin-bottom: 0.25rem;
}

.login-section .login-subtitle {
  color: var(--muted-foreground);
  font-size: 0.95rem;
  font-weight: 400;
}

/* Form Layout - simplified for login (no multi-column layout needed) */
.login-section .form-group {
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem;
}

.login-section .form-label {
  font-weight: 500;
  color: var(--foreground);
  margin-bottom: 0.4rem;
  font-size: 0.875rem;
}

.login-section .form-input {
  width: 100%;
  padding: 0.8rem 0.9rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  background: var(--input);
  color: var(--foreground);
  font-size: 1rem;
  transition: box-shadow 160ms ease, border-color 160ms ease;
  outline: none;
  font-family: inherit;
  min-height: 44px; /* touch target */
}

.login-section .form-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 4px var(--ring);
}

.login-section .form-input:hover {
  border-color: #c7e9dd;
}

.login-section .form-input.error {
  border-color: var(--destructive);
  box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.06);
}

.login-section .error-message {
  color: var(--destructive);
  font-size: 0.875rem;
  margin-top: 0.45rem;
  font-weight: 500;
  min-height: 1.25rem;
}

.login-section .submit-button {
  width: 100%;
  background: var(--primary);
  color: var(--primary-foreground);
  border: none;
  padding: 0.9rem 1rem;
  border-radius: calc(var(--radius) * 1.05);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease;
  letter-spacing: 0.01em;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.5rem;
}

.login-section .submit-button:hover:not(:disabled) {
  background: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(5, 150, 105, 0.12);
}

.login-section .submit-button:disabled {
  background: var(--muted);
  color: var(--muted-foreground);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.login-section .submit-button .loading-spinner {
  display: none;
  width: 18px;
  height: 18px;
  border: 2px solid transparent;
  border-top: 2px solid currentColor;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: 0.5rem;
}

.login-section .submit-button.loading .loading-spinner {
  display: inline-block;
}

@keyframes spin { to { transform: rotate(360deg); } }

.login-section .message {
  margin-top: 1rem;
  padding: 0.875rem 1rem;
  border-radius: var(--radius);
  font-weight: 500;
  text-align: center;
}

.login-section .message.success {
  background: rgba(16, 185, 129, 0.08);
  color: var(--accent);
  border: 1px solid rgba(16, 185, 129, 0.12);
}

.login-section .message.error {
  background: rgba(220, 38, 38, 0.06);
  color: var(--destructive);
  border: 1px solid rgba(220, 38, 38, 0.12);
}

.login-section .signup-link {
  text-align: center;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}

.login-section .signup-link a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}

.login-section .signup-link a:hover {
  text-decoration: underline;
}

/* Additional login-specific styles */
.login-section .forgot-password {
  text-align: right;
  margin-top: 0.5rem;
  margin-bottom: 1rem;
}

.login-section .forgot-password a {
  color: var(--primary);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
}

.login-section .forgot-password a:hover {
  text-decoration: underline;
}

/* Tablet (min-width: 600px) - slightly wider form */
@media (min-width: 600px) {
  .login-section .login-container {
    padding: 2rem;
    max-width: 480px;
  }

  .login-section .login-title { font-size: 1.9rem; }

  .login-section .form-input { padding: 0.9rem 1rem; }
}

/* Desktop (min-width: 900px) - increase horizontal breathing room and typography */
@media (min-width: 900px) {
  .login-section .login-container {
    padding: 2.25rem 2.25rem;
    max-width: 520px;
  }

  .login-section .login-header { margin-bottom: 2rem; }

  .login-section .login-title { font-size: 2.25rem; }
}

/* Large screens (min-width: 1200px) - comfortable wide layout */
@media (min-width: 1200px) {
  .login-section .login-container {
    max-width: 600px;
    padding: 2.5rem 3rem;
  }

  .login-section .login-title { font-size: 2.5rem; }
}

/* Focus visible for accessibility (scoped) */
.login-section .form-input:focus-visible,
.login-section .submit-button:focus-visible { 
  outline: 2px solid var(--primary); 
  outline-offset: 2px; 
}

/* Animation for form appearance (scoped) */
@keyframes slideUp { 
  from { opacity: 0; transform: translateY(18px); } 
  to { opacity: 1; transform: translateY(0); } 
}

/* High contrast mode support (scoped) */
@media (prefers-contrast: high) {
  .login-section .form-input { border-width: 3px; }
  .login-section .submit-button { border: 2px solid var(--primary); }
}

/* Reduced motion support (scoped) */
@media (prefers-reduced-motion: reduce) {
  .login-section .login-container { animation: none; }
  .login-section .form-input, .login-section .submit-button { transition: none; }
}