.auth-wrap { display: flex; align-items: center; justify-content: center; min-height: calc(100vh - 80px); padding: 24px 16px; }
.auth-card { width: 100%; max-width: 440px; background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 32px; box-shadow: 0 1px 2px rgba(15,23,42,.04); }
.auth-card h1 { margin: 0 0 6px; font-size: 22px; color: #0f172a; }
.auth-sub { color: #64748b; margin: 0 0 22px; font-size: 14px; }
.auth-card label { display: block; font-size: 13.5px; color: #334155; font-weight: 500; margin: 14px 0 6px; }
.auth-card input { width: 100%; height: 44px; padding: 0 14px; border: 1px solid #cbd5e1; border-radius: 10px; font-size: 14.5px; background: #fff; color: #0f172a; transition: border-color .15s, box-shadow .15s; }
.auth-card input:focus { outline: 0; border-color: #2563eb; box-shadow: 0 0 0 3px rgba(37,99,235,.15); }
.auth-card .auth-cta { width: 100%; margin-top: 20px; background: #2563eb; color: #fff; border: 0; border-radius: 10px; padding: 13px 16px; font-size: 15px; font-weight: 600; cursor: pointer; transition: background .15s; }
.auth-card .auth-cta:hover { background: #1d4ed8; }
.auth-card .auth-cta:disabled { background: #94a3b8; cursor: not-allowed; }
.auth-card .auth-foot { text-align: center; margin: 18px 0 0; color: #64748b; font-size: 13.5px; }
.auth-card .auth-foot a { color: #2563eb; font-weight: 500; }
.auth-msg { margin-top: 14px; padding: 10px 12px; border-radius: 8px; font-size: 13.5px; line-height: 1.5; }
.auth-msg.error { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; }
.auth-msg.success { background: #ecfdf5; border: 1px solid #a7f3d0; color: #047857; }
.auth-msg.info { background: #eff6ff; border: 1px solid #bfdbfe; color: #1d4ed8; }
.auth-hint { color: #64748b; font-size: 12.5px; margin: 6px 0 0; }
.auth-back { display: inline-flex; align-items: center; gap: 6px; color: #475569; font-size: 13.5px; margin-bottom: 18px; }
.auth-back:hover { color: #2563eb; text-decoration: none; }
.verified-icon { width: 56px; height: 56px; margin: 0 auto 16px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.verified-icon.ok { background: #d1fae5; color: #047857; }
.verified-icon.bad { background: #fee2e2; color: #b91c1c; }
.text-center { text-align: center; }
@media (max-width: 480px) { .auth-card { padding: 24px 18px; } .auth-card input { height: 46px; font-size: 16px; } }
