@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");:root{--bg-color:#0f111a;--panel-bg:hsla(0,0%,100%,.03);--panel-border:hsla(0,0%,100%,.08);--text-primary:#f8fafc;--text-secondary:#94a3b8;--accent:#3b82f6;--accent-hover:#2563eb;--accent-glow:rgba(59,130,246,.5);--danger:#ef4444;--success:#10b981}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);background-image:radial-gradient(circle at 15% 50%,rgba(59,130,246,.15),transparent 25%),radial-gradient(circle at 85% 30%,rgba(16,185,129,.1),transparent 25%);color:var(--text-primary);font-family:Inter,sans-serif;min-height:100vh;display:flex;flex-direction:column}.glass-panel{background:var(--panel-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--panel-border);border-radius:16px;box-shadow:0 8px 32px 0 rgba(0,0,0,.3);padding:2rem}input{width:100%;padding:.75rem 1rem;background:rgba(0,0,0,.2);border:1px solid var(--panel-border);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all .3s ease;outline:none}input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}input::placeholder{color:var(--text-secondary)}.btn-primary{width:100%;padding:.75rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px 0 var(--accent-glow)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.title{font-size:1.875rem;font-weight:700;margin-bottom:.5rem;text-align:center;background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{font-size:.9375rem;color:var(--text-secondary);text-align:center;margin-bottom:2rem}.spinner{display:inline-block;width:20px;height:20px;border-radius:50%;border:3px solid hsla(0,0%,100%,.3);border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(1turn)}}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;margin-bottom:.5rem;color:var(--text-secondary)}.error-text{color:var(--danger)}.error-text,.success-text{font-size:.875rem;margin-top:.5rem;text-align:center}.success-text{color:var(--success)}