body{margin:0;overflow:hidden;background-color:var(--bg-color)}.login-wrapper{display:flex;height:100vh;width:100vw}.login-banner{flex:1.2;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;padding:60px;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.login-logo{display:flex;align-items:center;gap:16px;margin-bottom:60px;z-index:2;position:relative}.logo-icon{width:56px;height:56px;background-image:url(/logo.png);background-size:cover;background-position:center;border-radius:16px;box-shadow:0 10px 20px #00000026}.login-logo h2{font-size:24px;font-weight:700;letter-spacing:1px}.banner-text{z-index:2;position:relative;max-width:80%}.banner-text h1{font-size:48px;font-weight:800;line-height:1.3;margin-bottom:24px;text-shadow:0 4px 12px rgba(0,0,0,.15)}.banner-text p{font-size:18px;opacity:.9;line-height:1.6}.glow{position:absolute;border-radius:50%;filter:blur(80px);z-index:1}.glow-1{width:400px;height:400px;background:#ff9a8b66;top:-100px;right:-100px}.glow-2{width:600px;height:600px;background:#ff5a8d4d;bottom:-200px;left:-200px}.floating-mockup{position:absolute;right:40px;bottom:60px;width:380px;height:220px;background:#ffffff1a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);z-index:2;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;animation:float 6s ease-in-out infinite}.mockup-header{height:32px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;padding:0 16px;gap:6px}.dot{width:10px;height:10px;border-radius:50%;background:#fff6}.mockup-body{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;font-size:18px;font-weight:500}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.login-panel{flex:1;background:var(--bg-color);display:flex;align-items:center;justify-content:center;position:relative}.login-box{width:100%;max-width:420px;background:#fff;padding:48px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transform:translateY(0)}.login-header{text-align:center;margin-bottom:32px}.login-header h2{font-size:28px;color:var(--text-main);margin-bottom:8px}.login-header p{color:var(--text-muted);font-size:14px}.login-tabs{display:flex;position:relative;border-bottom:2px solid var(--border-color);margin-bottom:32px}.tab-item{flex:1;text-align:center;padding:12px 0;font-size:16px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:color .3s}.tab-item.active{color:var(--primary)}.tab-indicator{position:absolute;bottom:-2px;left:0;width:50%;height:2px;background-color:var(--primary);transition:transform .3s cubic-bezier(.25,.8,.25,1)}.tab-content{display:none;animation:fadeIn .4s ease forwards;opacity:0}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:20px}.input-icon-wrapper{position:relative;display:flex;align-items:center}.input-icon-wrapper i{position:absolute;left:16px;color:#9ca3af;font-size:20px;transition:color .3s}.input-icon-wrapper input{width:100%;padding:16px 16px 16px 44px;border:1px solid var(--border-color);border-radius:12px;font-size:15px;color:var(--text-main);transition:all .3s;background:#f9fafb;outline:none}.input-icon-wrapper input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #ff5a8d1a}.input-icon-wrapper input:focus+i,.input-icon-wrapper input:not(:placeholder-shown)+i{color:var(--primary)}.verification-wrapper input{padding-right:120px}.btn-send-code{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--primary);font-size:14px;font-weight:600;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background .2s}.btn-send-code:hover{background:#ff5a8d1a}.btn-send-code:disabled{color:#9ca3af;cursor:not-allowed;background:transparent}.btn-submit{width:100%;padding:16px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;transition:all .3s;box-shadow:0 4px 12px #ff5a8d4d}.btn-submit:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #ff5a8d66}.btn-submit i{transition:transform .3s}.btn-submit:hover i{transform:translate(4px)}.btn-submit:active{transform:translateY(0)}.btn-submit.loading{opacity:.8;cursor:not-allowed}.qrcode-wrapper{display:flex;flex-direction:column;align-items:center;padding:20px 0}.qrcode-box{width:220px;height:220px;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:10px;background:#fff;box-shadow:var(--shadow-sm);position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.qrcode-box img{width:100%;height:100%;object-fit:contain;border-radius:8px}.qr-tip{font-size:14px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.qr-tip i{color:#07c160;font-size:18px}.qr-placeholder,.qr-expired{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-md);z-index:2;gap:12px;color:var(--text-main);font-weight:500}.qr-expired{display:none;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spin-icon{font-size:32px;color:var(--primary);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-refresh{padding:8px 24px;border:none;background:var(--primary);color:#fff;border-radius:20px;cursor:pointer;font-weight:500;transition:background .2s}.btn-refresh:hover{background:var(--primary-hover)}.custom-toast{position:fixed;top:32px;left:50%;transform:translate(-50%) translateY(-20px);background:#000000d9;color:#fff;padding:12px 24px;border-radius:30px;display:flex;align-items:center;gap:10px;font-size:14px;z-index:9999;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #00000026}.custom-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast-success i{color:#10b981}.toast-error i{color:#ef4444}.toast-warning i{color:#f59e0b}.custom-toast i{font-size:18px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182799;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999;opacity:0;visibility:hidden;transition:all .3s ease}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{background:#fff;width:400px;border-radius:var(--radius-md);padding:32px;transform:translateY(20px);transition:all .3s cubic-bezier(.25,.8,.25,1);box-shadow:0 20px 25px -5px #0000001a}.modal-overlay.active .modal-content{transform:translateY(0)}.modal-header h3{font-size:20px;color:var(--text-main);margin-bottom:8px}.bind-tip{font-size:14px;color:var(--text-muted);line-height:1.5}@media (max-width: 992px){.login-banner{display:none}.login-box{box-shadow:none;max-width:100%;padding:32px}}
