.login{min-height:100vh;display:grid;place-items:center;padding:var(--s-6);background:var(--bg-app)}.login__card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-lg),var(--edge-top);padding:var(--s-8);display:flex;flex-direction:column;gap:var(--s-5)}.login__brand{display:flex;align-items:center;gap:var(--s-3)}.login__brandmark{width:38px;height:38px;border-radius:var(--r-md);background:linear-gradient(145deg,var(--accent),#5a3ee0);display:grid;place-items:center;box-shadow:var(--sh-accent);flex:none}.login__brandmark svg{width:20px;height:20px;color:#fff}.login__wordmark{font-size:var(--t-lg);font-weight:var(--fw-bold);letter-spacing:-.02em;color:var(--text)}.login__head{display:flex;flex-direction:column;gap:4px}.login__title{font-size:var(--t-xl);font-weight:var(--fw-semi);letter-spacing:-.02em;margin:0}.login__sub{font-size:var(--t-sm);color:var(--text-muted)}.login__form{gap:var(--s-3)}.login__field,.login__form{display:flex;flex-direction:column}.login__field{gap:6px}.login__label{font-size:var(--t-2xs);font-weight:var(--fw-semi);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--text-faint)}.login__input{height:38px;padding:0 var(--s-3);background:var(--bg-sunken);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:var(--t-base);outline:none;transition:border-color var(--dur-1) var(--ease)}.login__input:focus{border-color:var(--line-focus)}.login__input::placeholder{color:var(--text-faint)}.login__submit{height:40px;margin-top:var(--s-2);font-size:var(--t-base);justify-content:center}.login__submit[disabled]{opacity:.6;cursor:default}.login__error{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-3);font-size:var(--t-sm);color:var(--unpaid-text);background:var(--unpaid-soft);border:1px solid hsla(0,91%,71%,.22);border-radius:var(--r-sm)}.login__error svg{width:15px;height:15px;flex:none}.login__foot{font-size:var(--t-xs);color:var(--text-faint);text-align:center}