.auth-wrap{min-height:calc(100vh - 140px);display:flex;align-items:center;justify-content:center;padding:48px 20px}.auth-card{width:100%;max-width:430px;background:var(--surface,#fff);border:1px solid var(--border);border-radius:var(--r-xl,20px);box-shadow:var(--shadow-md,0 10px 40px rgba(16,24,40,.08));padding:34px 32px}.auth-head{text-align:center;margin-bottom:26px}.auth-head h1{font-size:26px;font-weight:800;letter-spacing:-.5px}.auth-head p{color:var(--text-3);margin-top:8px;font-size:14.5px}.auth-form .field{margin-bottom:16px}.auth-form .field label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:6px}.auth-row-between{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.auth-link{color:var(--brand,#4f7bf0);font-size:13.5px;font-weight:600}.auth-alert{border-radius:10px;padding:11px 14px;font-size:13.5px;margin-bottom:18px;line-height:1.5}.auth-alert.error{background:color-mix(in srgb,oklch(.6 .2 25) 12%,transparent);color:oklch(.55 .2 25)}.auth-alert.success{background:color-mix(in srgb,oklch(.6 .16 150) 14%,transparent);color:oklch(.48 .16 150)}.auth-alert.info{background:var(--accent-soft,#eef2ff);color:var(--brand,#4f7bf0)}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-faint);font-size:12.5px}.auth-divider:after,.auth-divider:before{content:"";flex:1;height:1px;background:var(--border)}.auth-oauth{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px;border:1.5px solid var(--border);border-radius:11px;background:var(--surface,#fff);font-weight:600;font-size:14.5px;color:var(--text-1);cursor:pointer}.auth-oauth:hover{background:var(--surface-2,#f4f5fb)}.auth-foot{text-align:center;margin-top:22px;font-size:14px;color:var(--text-3)}.auth-foot a{color:var(--brand,#4f7bf0);font-weight:600}.auth-pw-hint{font-size:12px;color:var(--text-faint);margin-top:-8px;margin-bottom:16px}.auth-state{text-align:center}.auth-state .si{width:56px;height:56px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;background:var(--accent-soft,#eef2ff);color:var(--brand,#4f7bf0)}.auth-state .si svg{width:28px;height:28px}