:root{--bg:#0f172a;--card:#111827;--border:#1f2933;--text:#e5e7eb;--muted:#9ca3af;--accent:#3b82f6;--accent-hover:#2563eb;--error:#ef4444}*{box-sizing:border-box;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{min-height:100vh;color:var(--text);background:linear-gradient(135deg,#020617,#0f172a);justify-content:center;align-items:center;margin:0;display:flex}.login-card{background:var(--card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:380px;margin:0 auto;padding:2rem;box-shadow:0 20px 40px #0006}.login-card h1{margin:0 0 .25rem;font-size:1.5rem}.login-card p{color:var(--muted);margin:0 0 1.5rem;font-size:.9rem}.form-group{margin-bottom:1rem}label{color:var(--muted);margin-bottom:.25rem;font-size:.85rem;display:block}input{border:1px solid var(--border);width:100%;color:var(--text);background:#020617;border-radius:8px;outline:none;padding:.6rem .75rem;font-size:.95rem}input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.actions{margin-top:1.25rem}.login-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:.65rem;font-size:.95rem;font-weight:600;transition:background .15s}.login-button:hover{background:var(--accent-hover)}.footer{text-align:center;color:var(--muted);margin-top:1rem;font-size:.85rem}.footer a{color:var(--accent);text-decoration:none}.footer a:hover{text-decoration:underline}.login-container{place-items:center;min-height:100vh;padding:24px;display:grid}