*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}body{height:100vh;background:#0f172a;display:flex;justify-content:center;align-items:center;color:#e2e8f0}.container{width:100%;max-width:400px;padding:40px;background:#1e293b;border-radius:12px;box-shadow:0 20px 40px #0006}.title{font-size:22px;font-weight:600;text-align:center;margin-bottom:8px}.subtitle{font-size:14px;text-align:center;color:#94a3b8;margin-bottom:30px}input{width:100%;padding:12px 14px;margin-bottom:16px;background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:14px;transition:all .2s ease}input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}button{width:100%;padding:12px;background:#3b82f6;border:none;border-radius:8px;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:background .2s ease,opacity .2s ease}button:hover:not(:disabled){background:#2563eb}button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top:2px solid white;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error{margin-top:16px;font-size:13px;color:#f87171;text-align:center}.shake{animation:shake .3s ease}@keyframes shake{0%{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-6px)}to{transform:translate(0)}}.footer-text{margin-top:20px;font-size:11px;color:#64748b;text-align:center}
