/* ==========================================================================
   NexuAttend — auth utility pages (signup / forgot / reset).
   Self-contained, built on tokens.css only (decoupled from login.css so the
   login redesign can evolve independently). Same brand: orange, Plus Jakarta
   Sans, shared .btn/.input/.field/.alert components from tokens.css.
   ========================================================================== */

.auth-page {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: var(--sp-6);
  background:
    radial-gradient(1100px 520px at 50% -10%, var(--brand-tint) 0%, rgba(255,247,237,0) 60%),
    var(--bg);
}
.auth-card {
  width: 100%; max-width: 440px; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--r-xl); box-shadow: var(--sh-lg);
  padding: var(--sp-8) var(--sp-8) var(--sp-6);
}
.auth-card.wide { max-width: 520px; }

/* brandmark */
.auth-brandmark { display: inline-flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-6); }
.auth-brandmark .mark { width: 34px; height: 34px; display: inline-flex; }
.auth-brandmark .mark img { width: 100%; height: 100%; object-fit: contain; }
.auth-brandmark .wordmark { font-size: var(--fs-lg); font-weight: var(--fw-semibold); letter-spacing: -0.02em; color: var(--text); }
.auth-brandmark .wordmark .thin { color: var(--text-3); font-weight: var(--fw-medium); }

.auth-h { margin-bottom: var(--sp-5); }
.auth-h h1 { font-size: var(--fs-2xl); letter-spacing: -0.02em; }
.auth-h p { color: var(--text-3); margin-top: 4px; font-size: var(--fs-sm); }

/* form layout */
.auth-card .field { margin-bottom: var(--sp-4); }
.auth-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.auth-actions { margin-top: var(--sp-5); }
.auth-foot { margin-top: var(--sp-5); text-align: center; font-size: var(--fs-sm); color: var(--text-3); }
.auth-foot a { font-weight: var(--fw-semibold); }
.auth-row-between { display: flex; align-items: center; justify-content: space-between; }
.auth-back { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--text-3); margin-top: var(--sp-4); }
.auth-back [data-lucide] { width: 15px; height: 15px; }
.auth-back:hover { color: var(--brand); }

/* the error/success alerts use tokens .alert; show toggling via [hidden] */
.auth-card .alert { margin-bottom: var(--sp-4); }

/* success / result panel (after signup or reset request) */
.auth-result { text-align: center; padding: var(--sp-2) 0 0; }
.auth-result .rc-ico { width: 56px; height: 56px; border-radius: var(--r-pill); background: var(--success-tint); border: 1px solid var(--success-border); color: var(--success); display: inline-flex; align-items: center; justify-content: center; margin-bottom: var(--sp-4); }
.auth-result .rc-ico [data-lucide] { width: 28px; height: 28px; }
.auth-result h2 { font-size: var(--fs-xl); margin-bottom: 6px; }
.auth-result p { color: var(--text-3); font-size: var(--fs-sm); margin-bottom: var(--sp-2); }
.auth-result .email-strong { color: var(--text); font-weight: var(--fw-semibold); }

.pw-hint { font-size: var(--fs-xs); color: var(--text-4); margin-top: 4px; }

[hidden] { display: none !important; }

@media (max-width: 480px) { .auth-row2 { grid-template-columns: 1fr; } .auth-card { padding: var(--sp-6) var(--sp-5); } }
