/* people_space — auth pages stylesheet.
   Imports the Clearspace design-system tokens (so --cs-* + the Suisse font
   resolve), then the auth-page styles from the add-auth skill. */
@import url("colors_and_type.css");

/* ──────────────────────────────────────────────────────────────────
   Auth pages — Clearspace Design System
     · Login: split-screen — dark brand panel + white sign-in card
     · Callback / Reset / Denied / 403 (Centered Minimal)
   ────────────────────────────────────────────────────────────────── */

.auth-body {
  margin: 0;
  min-height: 100vh;
  background: var(--cs-dark-blue, #323D4C);
  color: var(--cs-charcoal, #16191A);
  font-family: var(--font-primary, 'Suisse Intl', 'Suisse Int\'l', 'DM Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.auth-body *, .auth-body *::before, .auth-body *::after { box-sizing: border-box; }

.login-body {
  margin: 0;
  min-height: 100vh;
  color: var(--cs-charcoal, #16191A);
  font-family: var(--font-primary, 'Suisse Intl', 'Suisse Int\'l', 'DM Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.login-body *, .login-body *::before, .login-body *::after { box-sizing: border-box; }

.login-split { display: grid; grid-template-columns: 1fr 1fr; min-height: 100vh; }

.login-brand {
  position: relative; display: flex; flex-direction: column; justify-content: center;
  gap: 28px; padding: 56px 60px; background: var(--cs-dark-blue, #323D4C); color: #fff; overflow: hidden;
}
.login-hero-logo { height: 64px; width: auto; max-width: 100%; align-self: flex-start; flex-shrink: 0; display: block; }
.login-lede { max-width: 420px; margin: 0; font-size: 18px; line-height: 1.6; color: rgba(255,255,255,0.62); }
.login-foot {
  position: absolute; left: 60px; right: 60px; bottom: 40px; display: flex; gap: 26px;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.34);
}

.login-signin { display: flex; align-items: center; justify-content: center; padding: 48px; background: #fff; }
.login-card {
  width: 100%; max-width: 400px; border: 1px solid var(--cs-n-200, #E5E7EB);
  border-radius: var(--radius-xl, 14px); padding: 36px; box-shadow: var(--shadow-card, 0 1px 4px rgba(22,25,26,0.06));
}
.login-card-title { font-size: 24px; font-weight: 600; letter-spacing: -0.02em; margin: 0 0 6px; color: var(--cs-charcoal, #16191A); }
.login-card-sub { font-size: 14px; line-height: 1.5; color: var(--cs-n-500, #6B7280); margin: 0 0 26px; }

.login-btn-ms {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; height: var(--btn-h-lg, 44px); padding: 0 16px;
  font-family: inherit; font-size: 15px; font-weight: 500;
  color: #1E293B; background: #fff; border: 1px solid var(--cs-n-300, #D1D5DB); border-radius: var(--radius-md, 8px);
  text-decoration: none; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease;
}
.login-btn-ms:hover { background: var(--cs-n-50, #F9FAFB); border-color: var(--cs-n-400, #9CA3AF); }
.login-btn-ms:focus-visible {
  outline: none; border-color: var(--cs-light-blue, #3BABFF);
  box-shadow: 0 0 0 3px rgba(59, 171, 255, 0.10);
}
.login-btn-ms svg { width: 18px; height: 18px; flex-shrink: 0; }

.login-note { margin: 22px 0 0; font-size: 13px; line-height: 1.5; color: var(--cs-n-400, #9CA3AF); }

@media (max-width: 767.98px) {
  .login-split { grid-template-columns: 1fr; }
  .login-brand { padding: 40px 28px; gap: 16px; min-height: 38vh; justify-content: flex-end; }
  .login-hero-logo { height: 44px; }
  .login-lede { font-size: 16px; }
  .login-foot { display: none; }
  .login-signin { padding: 28px 24px; align-items: flex-start; }
}

.auth-flash {
  margin: 0 0 16px 0; font-family: inherit; font-size: 14px; font-weight: 400;
  line-height: 1.4; letter-spacing: -0.005em;
}
.auth-flash--error   { color: var(--cs-light-red, #F05A5A); }
.auth-flash--success { color: var(--cs-dark-green, #3F4D32); }

.auth-center {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh; padding: 64px 32px; background: #FFFFFF;
}
.auth-stack { width: 100%; max-width: 440px; display: flex; flex-direction: column; align-items: flex-start; }
.auth-stack-mark { height: 26px; width: auto; display: block; margin-bottom: 48px; }
.auth-stack-product {
  font-family: inherit; font-weight: 300; font-size: 48px; line-height: 1.0;
  letter-spacing: -0.03em; color: var(--cs-charcoal, #16191A); margin: 0;
}
.auth-stack-subtitle {
  font-family: inherit; font-weight: 300; font-size: 16px; line-height: 1.45;
  color: var(--cs-n-500, #6B7280); margin: 16px 0 0; max-width: 38ch;
}
.auth-stack .auth-flash { margin-bottom: 24px; }

.auth-form-fields { width: 100%; margin-top: 28px; display: flex; flex-direction: column; gap: 14px; }
.auth-field { display: flex; flex-direction: column; gap: 6px; }
.auth-field label {
  font-family: inherit; font-size: 13px; font-weight: 400;
  color: var(--cs-n-700, #374151); letter-spacing: -0.005em;
}
.auth-field input {
  width: 100%; padding: 11px 14px; font-family: inherit; font-size: 15px; font-weight: 300;
  color: var(--cs-charcoal, #16191A); background: #FFFFFF;
  border: 1px solid var(--cs-n-300, #D1D5DB); border-radius: 8px; outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.auth-field input::placeholder { color: var(--cs-n-400, #9CA3AF); font-weight: 300; }
.auth-field input:focus {
  border-color: var(--cs-light-blue, #3BABFF); box-shadow: 0 0 0 3px rgba(59, 171, 255, 0.10);
}

.auth-btn {
  display: inline-flex; align-items: center; justify-content: center; width: 100%;
  margin-top: 4px; padding: 12px 18px; border: 1px solid var(--cs-light-blue, #3BABFF);
  border-radius: 8px; background: var(--cs-light-blue, #3BABFF); color: #FFFFFF;
  font-family: inherit; font-size: 15px; font-weight: 500; letter-spacing: -0.01em;
  text-decoration: none; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease;
}
.auth-btn:hover { background: var(--cs-dark-blue, #323D4C); border-color: var(--cs-dark-blue, #323D4C); }
.auth-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(59, 171, 255, 0.20); }
.auth-btn--link { text-align: center; margin-top: 28px; }
