/* ═══════════════════════════════════════════════════════════════════════════
   CLAJAMA AUTH SYSTEM — Login, Register, Forgot/Reset Password
   
   Consolidated from template-styles.css (auth sections) into a single
   global file loaded via base.html for all auth pages.
   
   Auth pages: login.html, forgot_password.html, reset_password.html
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Auth Page Shell ── */
.auth-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 24px;
}

/* ── Auth Card ── */
.auth-card {
  max-width: 440px;
  margin: 0 auto;
  text-align: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 56px 40px;
  position: relative;
  overflow: hidden;
}

.auth-card.compact {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 48px;
  max-width: 420px;
  margin: 80px auto;
  text-align: center;
}

.auth-card.compact label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  text-transform: uppercase;
  display: block;
  margin-bottom: 6px;
  text-align: left;
}

.auth-card.compact input {
  width: 100%;
  background: var(--raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-size: 15px;
  color: var(--text-primary);
  outline: none;
  font-family: inherit;
}

.auth-card.compact input:focus {
  border-color: var(--accent);
}

@media (max-width: 639px) {
  .auth-card { padding: 32px 16px; }
  .auth-card.compact { padding: 32px 16px; margin: 20px 12px; }
}

/* ── Auth Section Wrapper (forgot_password) ── */
.auth-section-wrapper {
  padding: 80px 16px;
}

@media (max-width: 639px) {
  .auth-section-wrapper { padding: 32px 12px; }
}

/* ── Auth Footer ── */
.auth-footer {
  margin-top: 24px;
  text-align: center;
}

.auth-footer a {
  font-size: 12px;
  opacity: 0.6;
  color: var(--text-muted);
  text-decoration: none;
}

.auth-footer a:hover {
  opacity: 1;
  color: var(--accent);
}

/* ── Auth Logo ── */
.auth-card .logo {
  margin-bottom: 28px;
  text-align: center;
}

.auth-card .logo-text {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
}

.auth-card .logo-text .accent {
  color: var(--accent);
}

/* ── Tab Bar (Login / Register toggle) ── */
.tab-bar {
  display: flex;
  gap: 0;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--border);
}

.tab-bar .tab {
  flex: 1;
  padding: 12px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-muted);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
}

.tab-bar .tab.active {
  color: var(--text-primary);
  border-bottom-color: var(--accent);
}

.tab-bar .tab:hover {
  color: var(--text-secondary);
}

/* ── Form Groups ── */
.form-group {
  margin-bottom: 18px;
  text-align: left;
}

.form-group label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 6px;
  letter-spacing: 0.03em;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="password"] {
  width: 100%;
  background: var(--raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  font-size: 14px;
  color: var(--text-primary);
  outline: none;
  font-family: inherit;
  transition: border-color 0.2s ease;
}

.form-group input:focus {
  border-color: var(--accent);
}

.form-actions {
  grid-column: 1 / -1;
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

/* ── Remember Me ── */
.remember-row {
  margin-bottom: 8px !important;
}

.remember-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-muted);
  cursor: pointer;
  user-select: none;
}

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

/* ── Terms of Service Checkbox ── */
.tos-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
  cursor: pointer;
}

.tos-checkbox input[type="checkbox"] {
  margin-top: 2px;
  accent-color: var(--accent);
  flex-shrink: 0;
}

.tos-checkbox a {
  color: var(--accent);
  text-decoration: underline;
}

/* ── Flash Messages ── */
.flash-message {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  margin-bottom: 16px;
  text-align: center;
}

.flash-message.error {
  background: rgba(231, 76, 60, 0.1);
  color: #e74c3c;
  border: 1px solid rgba(231, 76, 60, 0.2);
}

.flash-message.success {
  background: rgba(46, 204, 113, 0.1);
  color: #2ecc71;
  border: 1px solid rgba(46, 204, 113, 0.2);
}

/* ── Nav Public (used on auth pages) ── */
.nav-public .nav-logo {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}

.nav-public .nav-logo-mark {
  width: 32px;
  height: 32px;
  background: var(--accent);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 18px;
  color: #fff;
}

.nav-public .nav-logo-text {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
}
