.auth-root{--canvas:#f8f7fb;--surface:#fff;--ink:#211f30;--ink-soft:#46435c;--muted:#8a889b;--faint:#a9a7b8;--line:#e9e7f0;--line-soft:#f1f0f6;--brand:#8281b1;--brand-deep:#5e5c8a;--brand-deeper:#4c4a73;--brand-tint:#eeedf6;--brand-tint-2:#e2e0ee;--grad:linear-gradient(150deg,#9a99c9,#8281b1 42%,#5e5c8a);--good-bg:#e7f4ec;--good-fg:#2c7a4b;--bad-bg:#fbe7e7;--bad-fg:#b23b3b;--shadow-md:0 2px 6px #211f300d,0 8px 24px #211f3012;background:var(--canvas);min-height:100dvh;color:var(--ink);font-family:var(--font-sans),"Hanken Grotesk",sans-serif;-webkit-font-smoothing:antialiased;font-size:15px}.auth-root,.auth-root *{box-sizing:border-box;margin:0;padding:0}.auth-root svg{stroke-linecap:round;stroke-linejoin:round}.auth-root button,.auth-root input{font-family:inherit}.auth-root a{text-decoration:none}.auth-shell{grid-template-columns:1.05fr 1fr;min-height:100dvh;display:grid}.auth-brand{background:var(--grad);color:#fff;flex-direction:column;justify-content:space-between;padding:50px 52px;display:flex;position:relative;overflow:hidden}.auth-brand-top{z-index:2;color:inherit;align-items:center;gap:12px;display:flex;position:relative}.auth-mark{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff29;border:1px solid #ffffff40;border-radius:11px;place-items:center;width:38px;height:38px;display:grid}.auth-mark svg{color:#fff;width:20px;height:20px}.auth-wordmark{font-family:var(--font-display),"Bricolage Grotesque",sans-serif;letter-spacing:-.02em;font-size:21px;font-weight:700}.auth-brand-copy{z-index:2;max-width:440px;position:relative}.auth-hero{font-family:var(--font-display),"Bricolage Grotesque",sans-serif;letter-spacing:-.02em;font-size:38px;font-weight:600;line-height:1.12}.auth-subline{color:#ffffffd1;margin-top:18px;font-size:15.5px;line-height:1.6}.auth-brand-foot{z-index:2;color:#fff9;font-size:12.5px;position:relative}.auth-deco-glow{z-index:1;background:radial-gradient(circle at 30% 30%,#ffffff2e,#0000 60%);border-radius:50%;width:520px;height:520px;position:absolute;bottom:-120px;right:-120px}.auth-bars{z-index:1;opacity:.5;align-items:flex-end;gap:10px;display:flex;position:absolute;bottom:54px;right:54px}.auth-bars .bar{background:#ffffff8c;border-radius:6px 6px 0 0;width:14px}.auth-bars .bar-a{height:60px}.auth-bars .bar-b{height:110px}.auth-bars .bar-c{height:82px}.auth-bars .bar-d{height:140px}.auth-bars .bar-e{height:100px}.auth-stage{background:var(--canvas);place-items:center;padding:48px 40px;display:grid}.auth-card{width:100%;max-width:392px}.auth-card-title{font-family:var(--font-display),"Bricolage Grotesque",sans-serif;letter-spacing:-.02em;color:var(--ink);font-size:26px;font-weight:600}.auth-card-subtitle{color:var(--muted);margin-top:8px;font-size:14px;line-height:1.5}.auth-card-kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:18px;font-size:11px;font-weight:600}.auth-form{flex-direction:column;gap:16px;margin-top:28px;display:flex}.auth-field{flex-direction:column;gap:7px;display:flex}.auth-row{justify-content:space-between;align-items:center;display:flex}.auth-label{color:var(--ink-soft);font-size:12.5px;font-weight:600}.auth-link{color:var(--brand-deep);cursor:pointer;background:0 0;border:0;padding:0;font-size:12.5px;font-weight:600}.auth-link:hover{text-decoration:underline}.auth-input-wrap{position:relative}.auth-input{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);border-radius:10px;padding:11px 13px;font-size:14px;transition:all .14s}.auth-input::placeholder{color:var(--faint)}.auth-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint);outline:none}.auth-input.with-toggle{padding-right:42px}.auth-toggle{width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:7px;place-items:center;display:grid;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.auth-toggle:hover{color:var(--ink-soft);background:var(--line-soft)}.auth-toggle svg{width:17px;height:17px}.auth-submit{background:var(--brand-deep);color:#fff;cursor:pointer;border:0;border-radius:10px;width:100%;padding:12px;font-size:14.5px;font-weight:600;transition:all .14s;box-shadow:0 2px 6px #5e5c8a4d}.auth-submit:hover{background:var(--brand-deeper)}.auth-submit:disabled{opacity:.55;cursor:not-allowed}.auth-banner{border-radius:10px;align-items:flex-start;gap:9px;padding:10px 12px;font-size:13px;font-weight:500;display:flex}.auth-banner svg{flex:none;width:16px;height:16px}.auth-banner.error{background:var(--bad-bg);color:var(--bad-fg)}.auth-banner.success{background:var(--good-bg);color:var(--good-fg);border-radius:12px;gap:11px;padding:14px;font-size:13.5px;line-height:1.5}.auth-banner.success svg{width:18px;height:18px;margin-top:1px}.auth-inline-error{color:var(--bad-fg);font-size:12.5px}.auth-foot{margin-top:22px}.auth-backlink{color:var(--muted);align-items:center;gap:6px;font-size:13px;font-weight:600;display:inline-flex}.auth-backlink:hover{color:var(--brand-deep)}.auth-backlink svg{width:14px;height:14px}@media (max-width:980px){.auth-shell{grid-template-columns:1fr}.auth-brand{min-height:360px;padding:38px 34px}.auth-stage{padding:34px 24px}}@media (max-width:640px){.auth-brand{min-height:320px;padding:28px 22px}.auth-hero{font-size:31px}.auth-subline{font-size:14px}.auth-stage{padding:28px 20px}}
