.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:#ffffff}.login-background{position:absolute;inset:0;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.login-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 85% 15%,rgba(99,102,241,.03) 0,transparent 50%)}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-20px) rotate(1deg)}66%{transform:translateY(20px) rotate(-1deg)}}.login-container{position:relative;z-index:10;width:100%;max-width:420px;padding:2rem}.login-content{width:100%}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:inline-flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;animation:fadeInDown .6s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.logo-icon-wrapper{width:48px;height:48px;background:#6366f1;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(99,102,241,.2);position:relative;overflow:hidden}.logo-icon-wrapper:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.3) 0,transparent 70%);animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.3}}.logo-icon{width:24px;height:24px;color:white;position:relative;z-index:1}.logo-text{font-size:1.75rem;font-weight:800;color:#1e293b;letter-spacing:-.5px}.login-title{font-size:2rem;font-weight:700;color:#0f172a;margin-bottom:.5rem;letter-spacing:-.02em;animation:fadeIn .8s ease-out .2s both}.login-subtitle{font-size:1rem;color:#64748b;animation:fadeIn .8s ease-out .3s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-card.glass-card{background:#ffffff;border:1px solid #e2e8f0;border-left:4px solid #6366f1;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);border-radius:12px;animation:slideUp .6s ease-out .4s both}[data-theme=dark] .login-card.glass-card{background:rgba(30,41,59,.95);border:1px solid rgba(255,255,255,.1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-input{transition:all .2s ease;border:1px solid #d1d5db;background:white;height:48px;font-size:.95rem;padding:0 1rem}.login-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1);outline:none}.login-input::placeholder{color:#94a3b8}[data-theme=dark] .login-input{background:var(--bg-tertiary);border-color:var(--gray-600)}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);background:transparent;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color var(--transition-base)}.password-toggle:hover{color:var(--text-primary)}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#ef4444;font-size:.875rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .6s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(1turn)}}.login-footer{text-align:center;margin-top:2rem;animation:fadeIn .8s ease-out .6s both}@media (max-width:640px){.login-container{padding:1rem}.login-title{font-size:var(--text-2xl)}.login-subtitle{font-size:var(--text-sm)}.logo-icon-wrapper{width:40px;height:40px}.logo-text{font-size:var(--text-xl)}}.login-card.glass-card:hover{transform:translateY(-1px);box-shadow:0 8px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}:focus-visible{outline:2px solid var(--primary-500)}.login-input:focus-visible{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px rgba(59,130,246,.2)}label{color:#374151;font-weight:500;font-size:.875rem}.login-card{max-width:100%;width:100%;padding:2rem}.space-y-4>*+*{margin-top:1.25rem}.space-y-2>*+*{margin-top:.625rem}:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}