/* ==========================================================================
   Login page styles. Loaded only on /login. Presentational only; the page does
   not authenticate. Mobile-first: single column with a slim brand strip; the
   split-screen brand panel appears at >= 54em.
   ========================================================================== */

.login { display: grid; grid-template-columns: 1fr; min-height: 100vh; background: var(--bg); color: var(--charcoal); }

/* brand panel (dark) */
.login__brand { position: relative; overflow: hidden; background: var(--dark-band); color: var(--ink); padding: 48px 56px; display: none; flex-direction: column; justify-content: space-between; }
.login__glow { position: absolute; pointer-events: none; }
.login__glow--a { bottom: -160px; left: -120px; width: 520px; height: 480px; background: radial-gradient(55% 55% at 50% 50%, rgba(126, 199, 212, .30) 0%, rgba(10, 26, 34, 0) 70%); }
.login__glow--b { top: -140px; right: -140px; width: 440px; height: 420px; background: radial-gradient(55% 55% at 50% 50%, rgba(191, 221, 228, .16) 0%, rgba(10, 26, 34, 0) 70%); }
.login__brand-logo { position: relative; z-index: 1; display: flex; align-items: center; gap: 9px; width: fit-content; }
.login__brand-logo img { height: 26px; width: auto; filter: brightness(0) invert(1); }
.login__brand-wordmark { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; color: var(--ink); }
.login__brand-copy { position: relative; z-index: 1; max-width: 400px; }
.login__brand-line { font-size: clamp(30px, 3vw, 42px); font-weight: 600; line-height: 1.1; letter-spacing: -0.03em; margin: 0 0 18px; }
.login__brand-sub { font-size: 16px; line-height: 1.6; color: var(--ink-60); margin: 0; }
.login__brand-foot { position: relative; z-index: 1; font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 12px; letter-spacing: 0.03em; color: rgba(244, 241, 234, 0.4); }

/* form column */
.login__form-col { position: relative; display: flex; flex-direction: column; padding: 32px 40px; }
.login__strip { display: flex; align-items: center; gap: 9px; margin-bottom: 24px; }
.login__strip img { height: 24px; width: auto; }
.login__strip-wordmark { font-size: 19px; font-weight: 600; letter-spacing: -0.02em; color: var(--charcoal); }
.login__center { flex: 1; display: flex; flex-direction: column; justify-content: center; align-items: center; }
.login__box { width: 100%; max-width: 380px; }
.login__context { font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 12px; font-weight: 500; letter-spacing: 0.16em; color: var(--teal-text); margin-bottom: 20px; }
.login__title { font-size: 30px; font-weight: 600; letter-spacing: -0.025em; margin: 0 0 8px; }
.login__subtitle { font-size: 16px; line-height: 1.5; color: var(--charcoal-55); margin: 0 0 32px; }

.login__label { display: block; font-size: 13.5px; font-weight: 500; color: var(--charcoal); margin-bottom: 8px; }
.login__input { width: 100%; font-family: inherit; font-size: 15px; color: var(--charcoal); background: #fff; border: 1px solid rgba(31, 45, 54, 0.2); border-radius: var(--radius); padding: 12px 14px; min-height: 44px; transition: border-color .14s ease, box-shadow .14s ease; }
.login__input:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px rgba(42, 143, 164, 0.18); }
.login__input[aria-invalid="true"] { border-color: #b4443a; }
.login__field-error { font-size: 13px; color: #b4443a; margin: 8px 0 0; }

.login__pw-head { display: flex; align-items: baseline; justify-content: space-between; margin: 22px 0 8px; }
.login__forgot { font-size: 13px; font-weight: 500; color: var(--teal-text); }
.login__pw-wrap { position: relative; }
.login__pw-input { padding-right: 52px; }
.login__pw-toggle { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); background: transparent; border: 0; cursor: pointer; padding: 10px; color: rgba(31, 45, 54, 0.6); font-size: 12px; font-family: "JetBrains Mono", ui-monospace, monospace; letter-spacing: 0.04em; }

.login__cred-error { font-size: 13.5px; line-height: 1.45; color: #b4443a; background: rgba(180, 68, 58, 0.07); border: 1px solid rgba(180, 68, 58, 0.24); border-radius: var(--radius); padding: 10px 12px; margin: 22px 0 0; }
.login__remember { display: flex; align-items: center; gap: 9px; margin: 20px 0 0; cursor: pointer; user-select: none; }
.login__remember input { width: 15px; height: 15px; accent-color: var(--teal); cursor: pointer; }
.login__remember span { font-size: 13.5px; color: var(--charcoal-66); }

.login__submit { width: 100%; margin-top: 24px; font-family: inherit; font-size: 15px; font-weight: 600; color: #fff; background: var(--charcoal); border: 0; border-radius: var(--radius); padding: 13px 16px; min-height: 48px; cursor: pointer; transition: background .14s ease; }
.login__submit:hover, .login__submit.is-loading { background: var(--ink-dark); }
.login__submit.is-loading { cursor: default; }

.login__divider { display: flex; align-items: center; gap: 14px; margin: 26px 0; }
.login__divider-line { flex: 1; height: 1px; background: rgba(31, 45, 54, 0.14); }
.login__divider-text { font-size: 13px; color: var(--charcoal-45); }

.login__oauth { width: 100%; font-family: inherit; font-size: 15px; font-weight: 500; color: var(--charcoal); background: transparent; border: 1px solid rgba(31, 45, 54, 0.24); border-radius: var(--radius); padding: 12px 16px; min-height: 44px; cursor: pointer; transition: border-color .14s ease; }
.login__oauth:hover { border-color: var(--charcoal); }
.login__oauth--spaced { margin-bottom: 10px; }

.login__sent-mark { width: 44px; height: 44px; border-radius: 999px; background: var(--teal-text); display: flex; align-items: center; justify-content: center; margin-bottom: 22px; color: #fff; font-size: 20px; line-height: 1; }
.login__sent-email { font-weight: 600; color: var(--charcoal); }
.login__back { font-family: inherit; font-size: 15px; font-weight: 500; color: var(--teal-text); background: transparent; border: 0; padding: 0; cursor: pointer; }

.login__foot { margin-top: 34px; padding-top: 22px; border-top: 1px solid var(--line); }
.login__foot-primary { font-size: 14.5px; color: var(--charcoal-64); margin: 0 0 16px; }
.login__foot-link { font-weight: 500; color: var(--teal-text); }
.login__fineprint { font-size: 12.5px; line-height: 1.5; color: var(--charcoal-45); margin: 0; }
.login__fineprint a { color: var(--charcoal-55); text-decoration: underline; }

@media (min-width: 54em) {
  .login { grid-template-columns: 1fr 1fr; }
  .login__brand { display: flex; }
  .login__strip { display: none; }
}
