.login-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg, #f8fafc);transition:background .3s ease}.login-page.dark{background:linear-gradient(135deg,#0f1115,#1a1f2e)}.login-page.light{background:linear-gradient(135deg,#f0f4f8,#d9e2ec)}.login-header{padding:20px 24px;background:var(--primary, #3b82f6);box-shadow:0 2px 12px #00000026}.login-brand{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.login-logo{width:42px;height:42px;border-radius:10px;object-fit:contain}.login-brand-text h1{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.login-brand-text span{font-size:.8rem;color:#fffc}.login-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}.login-card{width:100%;max-width:420px;background:var(--bg-elev, #ffffff);border-radius:16px;box-shadow:0 10px 40px #0000001a;padding:40px;transition:all .3s ease}.dark .login-card{background:#151922f2;border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 40px #0006}.login-card-header{text-align:center;margin-bottom:32px}.login-card-header h2{margin:0 0 8px;font-size:1.75rem;font-weight:700;color:var(--text, #1e293b)}.dark .login-card-header h2{color:#f1f5f9}.login-card-header p{margin:0;font-size:.95rem;color:var(--muted, #64748b)}.dark .login-card-header p{color:#94a3b8}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{font-size:.875rem;font-weight:500;color:var(--text, #334155)}.dark .login-field label{color:#cbd5e1}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input-wrapper svg{position:absolute;left:14px;width:20px;height:20px;color:var(--muted, #94a3b8);pointer-events:none}.login-input-wrapper input{width:100%;padding:14px 14px 14px 46px;font-size:1rem;border:2px solid var(--border, #e2e8f0);border-radius:10px;background:var(--bg, #ffffff);color:var(--text, #1e293b);transition:all .2s ease;outline:none}.dark .login-input-wrapper input{background:#0f172a99;border-color:#ffffff1a;color:#f1f5f9}.login-input-wrapper input::placeholder{color:var(--muted, #94a3b8)}.login-input-wrapper input:focus{border-color:var(--primary, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.dark .login-input-wrapper input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f640}.login-button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-forgot-link{background:none;border:none;color:var(--primary, #3b82f6);font-size:.9rem;cursor:pointer;padding:8px;margin-top:4px;transition:color .2s ease}.login-forgot-link:hover{color:#1d4ed8;text-decoration:underline}.login-error{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#dc2626;font-size:.9rem}.dark .login-error{background:#ef444426;border-color:#ef444466;color:#f87171}.login-error svg{width:20px;height:20px;flex-shrink:0}.login-message{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:8px;font-size:.9rem}.login-message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#16a34a}.dark .login-message.success{background:#22c55e26;border-color:#22c55e66;color:#4ade80}.login-message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#dc2626}.login-footer{padding:16px 24px;text-align:center;color:var(--muted, #64748b);font-size:.85rem}.dark .login-footer{color:#64748b}.login-footer p{margin:0}.login-success-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f1115,#1a1f2e);animation:fadeIn .3s ease-out}.light .login-success-overlay{background:linear-gradient(135deg,#f0f4f8,#d9e2ec)}.login-success-content{display:flex;flex-direction:column;align-items:center;gap:20px;animation:scaleIn .4s ease-out .1s both}.login-success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px #22c55e66;animation:pulse 1s ease-in-out infinite}.login-success-icon svg{width:40px;height:40px;color:#fff;animation:checkmark .4s ease-out .3s both}.login-success-content span{font-size:1.5rem;font-weight:600;color:#f1f5f9;animation:fadeInUp .4s ease-out .4s both}.light .login-success-content span{color:#1e293b}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes checkmark{0%{opacity:0;stroke-dashoffset:30}to{opacity:1;stroke-dashoffset:0}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 10px 40px #22c55e66}50%{transform:scale(1.05);box-shadow:0 15px 50px #22c55e80}}@media (max-width: 480px){.login-card{padding:30px 24px;margin:0 10px}.login-card-header h2{font-size:1.5rem}.login-input-wrapper input{padding:12px 12px 12px 42px}.login-button{padding:12px 20px}}
