:root{--bg:#f4f6f9;--surface:#fff;--text:#111827;--muted:#667085;--line:#d0d5dd;--brand:#111827;--brand-hover:#000;--danger:#b42318}*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f8fafc 0,#eef2f7 100%);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--text)}.wrap{width:min(440px,92vw)}.box{background:var(--surface);border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 18px 50px rgba(15,23,42,.08);overflow:hidden}.head{padding:28px 30px 22px;border-bottom:1px solid #eef2f6;text-align:center}.logo{width:48px;height:48px;border-radius:12px;background:#111827;color:#fff;display:grid;place-items:center;font-weight:900;margin:0 auto 14px;letter-spacing:-.04em}.head h1{font-size:24px;line-height:1.2;margin:0;color:#101828}.head p{color:var(--muted);margin:7px 0 0;font-size:14px}.body{padding:26px 30px 30px}.field{margin-bottom:16px}label{display:block;font-size:13px;font-weight:800;color:#344054;margin-bottom:7px}input{width:100%;padding:12px 13px;border-radius:10px;border:1px solid var(--line);background:#fff;color:#111827;font-size:15px}input:focus{outline:2px solid rgba(37,99,235,.14);border-color:#2563eb}.btn{width:100%;border:0;border-radius:10px;padding:12px 14px;background:var(--brand);color:white;font-weight:800;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;gap:9px}.btn:hover{background:var(--brand-hover)}.btn:disabled{opacity:.78;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.38);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}html[data-theme="dark"]{--bg:#0b1120;--surface:#111827;--text:#f1f5f9;--muted:#b6c2d2;--line:rgba(148,163,184,.28);--brand:#60a5fa;--brand-hover:#3b82f6;--danger:#f87171}html[data-theme="dark"] body{background:radial-gradient(circle at top left,rgba(96,165,250,.12),transparent 34%),linear-gradient(180deg,#0b1120 0,#020617 100%);color:var(--text)}html[data-theme="dark"] .box{background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012)),var(--surface);border-color:rgba(148,163,184,.22);box-shadow:0 24px 70px rgba(0,0,0,.45)}html[data-theme="dark"] .head{border-bottom-color:rgba(148,163,184,.14)}html[data-theme="dark"] .head h1,html[data-theme="dark"] label{color:#f8fafc}html[data-theme="dark"] input{background:#0f172a;border-color:rgba(148,163,184,.30);color:#f8fafc}html[data-theme="dark"] input::placeholder{color:#94a3b8}html[data-theme="dark"] .logo{background:#e5e7eb;color:#020617}html[data-theme="dark"] .badge{background:rgba(148,163,184,.10);border-color:rgba(148,163,184,.20);color:#cbd5e1}html[data-theme="dark"] .err{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.28);color:#fca5a5}.err{background:#fef3f2;color:var(--danger);padding:11px 12px;border-radius:10px;margin-bottom:16px;border:1px solid #fecaca;font-size:14px}.hint{text-align:center;font-size:12px;color:#98a2b3;margin-top:16px}.security{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:16px}.badge{font-size:11px;color:#475467;background:#f9fafb;border:1px solid #eaecf0;border-radius:999px;padding:5px 9px}
