.theme-toggle{display:flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;padding:4px;border-radius:50px}.toggle-track{position:relative;width:52px;height:28px;background:var(--glass-bg, rgba(255, 255, 255, .05));border:1px solid var(--border-default, rgba(255, 255, 255, .1));border-radius:50px;transition:all .3s ease}.theme-toggle:hover .toggle-track{border-color:var(--accent, #a78bfa);box-shadow:0 0 0 3px var(--accent-glow, rgba(167, 139, 250, .2))}.toggle-thumb{position:absolute;top:3px;width:20px;height:20px;background:var(--accent, #a78bfa);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 2px 8px var(--accent-glow, rgba(167, 139, 250, .3))}.toggle-thumb.dark{left:3px}.toggle-thumb.light{left:calc(100% - 23px)}.toggle-icons{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 6px;pointer-events:none}.icon-sun{color:#fbbf24;opacity:.4}.icon-moon{color:#818cf8;opacity:.4}.toggle-label{font-size:12px;font-weight:500;color:var(--text-secondary, #94a3b8)}[data-theme=light] .toggle-track{background:#e2e8f0;border-color:#cbd5e1}[data-theme=light] .theme-toggle:hover .toggle-track{border-color:var(--accent, #a78bfa);background:#ddd6fe}.theme-toggle--sm .toggle-track{width:40px;height:22px}.theme-toggle--sm .toggle-thumb{width:16px;height:16px;top:2px}.theme-toggle--sm .toggle-thumb.dark{left:2px}.theme-toggle--sm .toggle-thumb.light{left:calc(100% - 19px)}.theme-toggle--lg .toggle-track{width:64px;height:34px}.theme-toggle--lg .toggle-thumb{width:26px;height:26px;top:3px}.theme-toggle--lg .toggle-thumb.dark{left:3px}.theme-toggle--lg .toggle-thumb.light{left:calc(100% - 30px)}.floating-chat-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:500;box-shadow:0 4px 16px #6366f166;transition:transform .2s,box-shadow .2s}.floating-chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #6366f180}.floating-chat-fab-badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center;line-height:1.4}.floating-chat-minimized{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:8px;padding:10px 12px 10px 16px;background:var(--accent);color:#fff;border-radius:24px;cursor:pointer;z-index:500;box-shadow:0 4px 16px #6366f166;font-size:13px;font-weight:500;transition:transform .2s;border:none}.floating-chat-minimized:hover{transform:scale(1.03)}.floating-chat-minimized-badge{background:var(--danger);color:#fff;font-size:10px;padding:1px 6px;border-radius:8px;min-width:16px;text-align:center}.floating-chat-minimized .floating-chat-control-btn{width:24px;height:24px;color:#ffffffb3;margin-left:4px}.floating-chat-minimized .floating-chat-control-btn:hover{color:#fff;background:#fff3}.floating-chat-window{position:fixed;bottom:24px;right:24px;width:380px;height:520px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);z-index:500;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #00000040;animation:fcOpen .25s ease}@keyframes fcOpen{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-chat-window.maximized{bottom:0;right:0;top:0;left:var(--sidebar-width);width:auto;height:auto;border-radius:0;border:none;box-shadow:none;animation:none}.floating-chat-titlebar{display:flex;align-items:center;justify-content:space-between;padding-right:4px;border-bottom:1px solid var(--border);background:var(--bg-tertiary);min-height:40px;flex-shrink:0}.floating-chat-tabs{display:flex;flex:1;min-width:0}.floating-chat-tab{display:flex;align-items:center;gap:6px;padding:10px 14px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.floating-chat-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.floating-chat-tab:hover:not(.active){color:var(--text-secondary)}.floating-chat-tab-badge{background:var(--danger);color:#fff;font-size:10px;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center;line-height:1.4}.floating-chat-controls{display:flex;gap:2px;flex-shrink:0}.floating-chat-control-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;transition:all .15s}.floating-chat-control-btn:hover{background:var(--bg-hover);color:var(--text)}.floating-chat-control-btn.close:hover{background:var(--danger);color:#fff}.floating-chat-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.fc-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.fc-search{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-muted);flex-shrink:0}.fc-search input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:13px}.fc-search input::-moz-placeholder{color:var(--text-muted)}.fc-search input::placeholder{color:var(--text-muted)}.fc-convo-list{flex:1;overflow-y:auto}.fc-convo-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}.fc-convo-item:hover{background:var(--bg-hover)}.fc-convo-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;flex-shrink:0}.fc-convo-info{flex:1;min-width:0}.fc-convo-name{font-weight:600;font-size:13px;color:var(--text)}.fc-convo-last{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.fc-convo-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.fc-convo-time{font-size:10px;color:var(--text-muted);white-space:nowrap}.fc-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.fc-chat-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.fc-chat-header-info{flex:1;min-width:0}.fc-chat-header-name{font-weight:600;font-size:13px;color:var(--text)}.fc-chat-header-platform{font-size:11px;color:var(--text-muted);text-transform:capitalize}.fc-messages{flex:1;overflow-y:auto;padding:12px;background:var(--bg-tertiary);display:flex;flex-direction:column;gap:8px}.fc-message{display:flex}.fc-message.customer{justify-content:flex-start}.fc-message.agent{justify-content:flex-end}.fc-message-bubble{max-width:80%;padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.4}.fc-message.customer .fc-message-bubble{background:var(--bg-secondary);color:var(--text);border-bottom-left-radius:4px}.fc-message.agent .fc-message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.fc-message-time{font-size:10px;opacity:.6;margin-top:4px;display:flex;align-items:center;gap:4px}.fc-message.agent .fc-message-time{justify-content:flex-end}.fc-quick-replies{display:flex;gap:6px;padding:8px 12px;overflow-x:auto;border-top:1px solid var(--border);flex-shrink:0}.fc-quick-btn{padding:4px 10px;font-size:11px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .15s}.fc-quick-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.fc-input-area{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0}.fc-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;color:var(--text);outline:none;transition:border-color .2s}.fc-input:focus{border-color:var(--accent)}.fc-input::-moz-placeholder{color:var(--text-muted)}.fc-input::placeholder{color:var(--text-muted)}.fc-send-btn{width:34px;height:34px;border-radius:8px;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;flex-shrink:0}.fc-send-btn:hover{opacity:.85}.fc-section-header{display:flex;align-items:center;gap:6px;padding:10px 14px 6px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.fc-channel-list{display:flex;flex-direction:column}.fc-channel-item{display:flex;align-items:center;gap:8px;padding:8px 14px;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:all .15s}.fc-channel-item:hover{background:var(--bg-hover);color:var(--text)}.fc-channel-badge{background:var(--danger);color:#fff;font-size:10px;padding:1px 6px;border-radius:8px;margin-left:auto}.fc-dm-list{display:flex;flex-direction:column}.fc-dm-item{display:flex;align-items:center;gap:8px;padding:6px 14px;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:background .15s}.fc-dm-item:hover{background:var(--bg-hover)}.fc-dm-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:10px;position:relative;flex-shrink:0}.fc-status-dot{position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;border-radius:50%;border:2px solid var(--bg-secondary)}.fc-status-dot.online{background:#34d399}.fc-status-dot.away{background:#fbbf24}.fc-status-dot.offline{background:#6b7280}.fc-team-message{display:flex;gap:8px;padding:2px 0}.fc-team-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:10px;flex-shrink:0;margin-top:2px}.fc-team-msg-content{flex:1;min-width:0}.fc-team-msg-header{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}.fc-team-msg-header span:first-child{font-size:12px}.fc-team-msg-time{font-size:10px;color:var(--text-muted)}.fc-team-msg-text{font-size:13px;color:var(--text);line-height:1.4;word-wrap:break-word}.fc-scrollable{flex:1;overflow-y:auto}.main.collapsed~.floating-chat-window.maximized{left:var(--sidebar-collapsed)}@media(max-width:1024px){.floating-chat-window.maximized{left:var(--sidebar-collapsed)}}@media(max-width:768px){.floating-chat-window{inset:0;width:100%;height:100%;border-radius:0}.floating-chat-window.maximized{left:0}.floating-chat-fab{bottom:16px;right:16px;width:48px;height:48px}.floating-chat-minimized{bottom:16px;right:16px}}.login-theme-toggle{position:fixed;top:24px;right:24px;z-index:100}.login-page{--bg-deepest: #030305;--bg-deep: #07070d;--bg-base: #0c0c14;--bg-surface: #12121c;--bg-elevated: #181824;--glass-bg: rgba(255, 255, 255, .015);--glass-border: rgba(255, 255, 255, .05);--glass-border-hover: rgba(255, 255, 255, .1);--accent: #a78bfa;--accent-glow: rgba(167, 139, 250, .35);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:var(--bg-deepest);position:relative;overflow-x:hidden;overflow-y:auto}.login-bg{position:fixed;inset:0;z-index:0;pointer-events:none}.bg-gradient-1{position:absolute;top:-40%;left:-20%;width:80%;height:80%;background:radial-gradient(circle,rgba(167,139,250,.06) 0%,transparent 60%);animation:float1 35s ease-in-out infinite}.bg-gradient-2{position:absolute;bottom:-30%;right:-20%;width:70%;height:70%;background:radial-gradient(circle,rgba(99,102,241,.04) 0%,transparent 60%);animation:float2 40s ease-in-out infinite}.bg-gradient-3{position:absolute;top:50%;left:50%;width:60%;height:60%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(167,139,250,.03) 0%,transparent 50%);animation:pulse 12s ease-in-out infinite}.bg-mouse-follow{position:absolute;width:600px;height:600px;left:0;top:0;background:radial-gradient(circle,rgba(167,139,250,.06) 0%,transparent 50%);pointer-events:none;will-change:transform;transition:transform .3s ease-out}.bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%);mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%)}.bg-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.03;mix-blend-mode:overlay}@keyframes float1{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(5deg)}66%{transform:translate(-20px,20px) rotate(-3deg)}}@keyframes float2{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(-40px,-20px) rotate(-5deg)}}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.5;transform:translate(-50%,-50%) scale(1.1)}}.login-page .login-container{position:relative;z-index:1;display:flex;width:100%;max-width:1200px;min-height:-moz-min-content;min-height:min-content;margin:40px auto;border-radius:32px;overflow:hidden;background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:0 0 0 1px #ffffff05 inset,0 50px 100px -20px #00000080,0 30px 60px -30px #0009}.login-page .login-branding{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:60px;background:linear-gradient(135deg,var(--bg-deep) 0%,var(--bg-base) 100%);position:relative;overflow:hidden}.login-page .login-branding:before{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(to bottom,transparent,rgba(167,139,250,.3),rgba(167,139,250,.1),transparent)}.branding-content{flex:1;display:flex;flex-direction:column;justify-content:center}.brand-logo{position:relative;width:100px;height:100px;margin-bottom:40px}.logo-glow{position:absolute;inset:-20px;background:var(--accent);opacity:.15;filter:blur(30px);border-radius:50%;animation:logoGlow 3s ease-in-out infinite}@keyframes logoGlow{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.25;transform:scale(1.1)}}.logo-icon{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a78bfa,#818cf8);border-radius:24px;color:#fff;border:1px solid rgba(167,139,250,.3);box-shadow:0 0 20px #a78bfa4d,0 0 40px #a78bfa33,0 0 60px #a78bfa1a,0 8px 32px #0006,0 0 0 1px #ffffff1a inset;transition:all .3s ease;animation:neonPulse 3s ease-in-out infinite}.logo-icon:hover{box-shadow:0 0 30px #a78bfa80,0 0 60px #a78bfa4d,0 0 90px #a78bfa33,0 12px 40px #00000080,0 0 0 1px #ffffff1a inset;transform:translateY(-4px);animation:none}.login-page .brand-title{font-size:48px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:16px}.title-indo{color:var(--text-primary)}.title-company{color:var(--accent);display:block}.brand-divider{display:flex;align-items:center;gap:16px;margin-bottom:8px}.brand-divider .divider-line{flex:0 0 40px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}.divider-icon{color:var(--accent);animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.5;transform:scale(.8) rotate(180deg)}}.login-page .brand-tagline{font-size:14px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:48px}.login-page .brand-quote{font-size:18px;font-style:italic;color:var(--text-muted);line-height:1.7;max-width:360px;margin-bottom:48px;position:relative;border:none;padding:0;background:transparent}.quote-mark{color:var(--accent);font-size:24px;opacity:.5}.brand-features{display:flex;flex-direction:column;gap:12px}.feature-item{display:flex;align-items:center;gap:12px;color:var(--text-secondary);font-size:14px;padding:14px 16px;background:#ffffff05;border:1px solid rgba(167,139,250,.3);border-radius:14px;transition:all .3s ease;box-shadow:0 0 15px #a78bfa33,0 0 30px #a78bfa1a,0 4px 20px #0000004d}.feature-item:hover{background:#ffffff0a;border-color:#a78bfa80;transform:translateY(-4px);box-shadow:0 0 30px #a78bfa80,0 0 60px #a78bfa4d,0 0 90px #a78bfa33,0 12px 40px #00000080}.feature-check{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:6px;color:#34d399;font-size:10px}.feature-emoji{font-size:18px;min-width:26px;text-align:center;line-height:1;flex-shrink:0}.login-page .brand-copyright{color:var(--text-muted);font-size:12px}.login-form-section{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:40px;background:var(--bg-base);overflow-y:auto}.login-card{position:relative;width:100%;max-width:540px;transition:all .3s ease}.card-glass{position:absolute;inset:0;background:var(--glass-bg);border-radius:24px;backdrop-filter:blur(16px) saturate(1.2);box-shadow:0 0 20px #a78bfa4d,0 0 40px #a78bfa33,0 0 60px #a78bfa1a,0 8px 32px #0006;transition:all .3s ease;animation:neonPulse 3s ease-in-out infinite}.card-border{position:absolute;inset:0;border-radius:24px;border:1px solid rgba(167,139,250,.3);pointer-events:none;transition:all .3s ease}.login-card:hover .card-glass{box-shadow:0 0 30px #a78bfa80,0 0 60px #a78bfa4d,0 0 90px #a78bfa33,0 12px 40px #00000080;animation:none}.login-card:hover .card-border{border-color:#a78bfa80}.card-content{position:relative;padding:32px}.login-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-subtitle{font-size:14px;color:var(--text-secondary)}.user-cards-grouped{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;max-height:380px;overflow-y:auto;padding-right:6px}.user-cards-grouped::-webkit-scrollbar{width:4px}.user-cards-grouped::-webkit-scrollbar-track{background:#ffffff05;border-radius:2px}.user-cards-grouped::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px;opacity:.5}.user-group{display:flex;flex-direction:column;gap:6px}.user-group-header{display:flex;align-items:baseline;gap:8px;padding:0 2px}.user-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent, #818cf8)}.user-group-hint{font-size:9px;color:#94a3b899;font-weight:400}.user-group .user-cards{margin-bottom:0;max-height:none;overflow:visible;padding-right:0}.user-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;max-height:280px;overflow-y:auto;padding-right:8px}.user-cards::-webkit-scrollbar{width:4px}.user-cards::-webkit-scrollbar-track{background:#ffffff05;border-radius:2px}.user-cards::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px;opacity:.5}.user-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:none;overflow:hidden;padding-right:0}.user-cards-grid .card-inner{padding:10px;gap:8px;overflow:hidden}.user-cards-grid .user-icon{width:32px;height:32px;border-radius:9px;flex-shrink:0}.user-cards-grid .user-info{min-width:0;flex:1}.user-cards-grid .user-role{font-size:11px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-cards-grid .user-email{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-cards-grid .user-description{font-size:9px}.user-cards-grid .user-arrow{display:none}.user-cards-grid .user-card{min-width:0}.user-card{position:relative;display:flex;align-items:center;width:100%;padding:0;background:transparent;border:none;cursor:pointer;text-align:left;animation:cardSlideIn .4s ease-out backwards;animation-delay:var(--animation-delay);transition:all .3s ease}@keyframes cardSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.card-glow{position:absolute;inset:0;background:var(--card-gradient);opacity:0;filter:blur(20px);border-radius:14px;transition:opacity .3s ease}.user-card:hover .card-glow{opacity:.15}.user-card.selected .card-glow{opacity:.25}.card-inner{position:relative;display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;background:#ffffff05;border:1px solid rgba(167,139,250,.3);border-radius:14px;transition:all .3s ease;box-shadow:0 0 15px #a78bfa33,0 0 30px #a78bfa1a,0 4px 20px #0000004d}.user-card:hover .card-inner{background:#ffffff0a;border-color:#a78bfa80;transform:translateY(-4px);box-shadow:0 0 30px #a78bfa80,0 0 60px #a78bfa4d,0 0 90px #a78bfa33,0 12px 40px #00000080}.user-card.selected .card-inner{background:#ffffff0f;border-color:var(--card-color)}.user-card:disabled{cursor:not-allowed}.user-card:disabled:not(.selected){opacity:.5}.user-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--card-gradient);border-radius:10px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #0003}.user-info{flex:1;min-width:0}.user-role{display:block;font-size:13px;font-weight:600;color:var(--card-color);margin-bottom:2px}.user-email{display:block;font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-description{display:block;font-size:10px;color:var(--text-muted);opacity:.7;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-arrow{color:var(--text-muted);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.user-card:hover .user-arrow{color:var(--card-color);transform:translate(4px)}.mini-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--card-color);border-radius:50%;animation:spin .8s linear infinite}.form-divider{display:flex;align-items:center;gap:16px;margin-bottom:24px}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--glass-border),transparent)}.divider-text{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.login-form{display:flex;flex-direction:column;gap:16px}.input-group{display:flex;flex-direction:column;gap:8px}.input-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-secondary)}.input-wrapper{position:relative}.input-field{width:100%;padding:14px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;color:var(--text-primary);font-size:14px;transition:all .2s ease}.input-field:focus{outline:none;background:#ffffff0d;border-color:var(--accent);box-shadow:0 0 0 3px #a78bfa1a}.input-field::-moz-placeholder{color:var(--text-muted)}.input-field::placeholder{color:var(--text-muted)}.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;transition:color .2s;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--text-secondary)}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:10px;color:#f87171;font-size:13px}.submit-button{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;background:linear-gradient(135deg,#a78bfa,#818cf8);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.submit-button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 50%);opacity:0;transition:opacity .3s}.submit-button:hover{transform:translateY(-2px);box-shadow:0 12px 24px #a78bfa59}.submit-button:hover:before{opacity:1}.submit-button:active{transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.button-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes neonPulse{0%,to{box-shadow:0 0 20px #a78bfa4d,0 0 40px #a78bfa33,0 0 60px #a78bfa1a,0 8px 32px #0006}50%{box-shadow:0 0 25px #a78bfa66,0 0 50px #a78bfa40,0 0 75px #a78bfa26,0 8px 32px #0006}}@keyframes neonPulseCard{0%,to{box-shadow:0 0 20px #a78bfa4d,0 0 40px #a78bfa33,0 0 60px #a78bfa1a,0 8px 32px #0006}50%{box-shadow:0 0 22px #a78bfa59,0 0 44px #a78bfa38,0 0 66px #a78bfa1f,0 8px 32px #0006}}.credentials-info{margin-top:24px;padding:16px;background:#a78bfa08;border:1px solid rgba(167,139,250,.1);border-radius:14px}.credentials-header{font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:12px}.credentials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.credential-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px 8px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:10px;text-align:center;min-height:80px}.credential-role{font-size:11px;font-weight:600;line-height:1.3;min-height:28px;display:flex;align-items:center;justify-content:center}.credential-pass{font-size:11px;font-family:JetBrains Mono,Fira Code,monospace;color:var(--accent);background:#a78bfa26;padding:6px 12px;border-radius:6px;white-space:nowrap}@media(max-width:1100px)and (min-width:1025px){.card-content{padding:24px}.login-card{max-width:480px}}@media(max-width:1024px){.login-page .login-container{flex-direction:column;margin:16px;min-height:auto;border-radius:24px}.login-page .login-branding{padding:20px 24px;display:flex}.login-page .login-branding:before{display:none}.branding-content{align-items:center;text-align:center}.brand-logo{width:56px;height:56px;margin-bottom:12px}.logo-icon{border-radius:14px}.login-page .brand-title{font-size:24px;text-align:center;margin-bottom:8px}.title-company{display:inline}.brand-divider{justify-content:center;margin-bottom:4px}.brand-divider .divider-line{flex:0 0 24px}.divider-icon{width:12px;height:12px}.login-page .brand-tagline{margin-bottom:12px;text-align:center;font-size:10px;letter-spacing:2px}.login-page .brand-quote{display:none}.brand-features{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:6px}.feature-item{padding:6px 10px;font-size:10px;flex:0 0 auto;border-radius:8px}.feature-check{width:14px;height:14px;font-size:8px;border-radius:4px}.login-page .brand-copyright{display:none}.login-form-section{padding:16px}.card-content{padding:20px}.login-header{margin-bottom:20px}.login-title{font-size:22px}.login-subtitle{font-size:12px}.user-cards-grouped{max-height:320px;gap:10px}.user-cards{gap:6px;max-height:240px}.card-inner{padding:10px 12px;gap:10px;border-radius:10px}.user-icon{width:32px;height:32px;border-radius:8px}.user-role{font-size:11px}.user-email,.user-description{font-size:9px}.form-divider{margin-bottom:16px}.divider-text{font-size:9px}.login-form{gap:12px}.input-label{font-size:10px;gap:4px}.input-field{padding:10px 12px;font-size:13px;border-radius:8px}.submit-button{padding:12px 16px;font-size:13px;border-radius:10px}}@media(max-width:480px){.login-page .login-container{margin:8px;border-radius:16px}.login-page .login-branding{padding:16px}.brand-logo{width:48px;height:48px;margin-bottom:10px}.logo-icon{border-radius:12px;box-shadow:0 0 12px #a78bfa40,0 0 24px #a78bfa26,0 4px 16px #00000059}.logo-icon svg{width:24px;height:24px}.login-page .brand-title{font-size:20px;margin-bottom:6px}.brand-divider{gap:8px}.brand-divider .divider-line{flex:0 0 20px}.divider-icon{width:10px;height:10px}.login-page .brand-tagline{font-size:9px;letter-spacing:1px;margin-bottom:10px}.brand-features{gap:4px}.feature-item{padding:5px 8px;font-size:9px;gap:6px;border-radius:6px;box-shadow:0 0 10px #a78bfa33,0 0 20px #a78bfa1a,0 2px 10px #0003}.feature-check{width:12px;height:12px;font-size:6px;border-radius:3px}.login-form-section{padding:12px}.card-content{padding:14px}.login-header{margin-bottom:16px}.login-title{font-size:18px}.login-subtitle{font-size:11px}.user-cards-grouped{max-height:280px;gap:8px}.user-group-hint{display:none}.user-cards{max-height:180px;gap:4px}.user-cards-grid{grid-template-columns:1fr;gap:4px}.user-cards-grid .user-arrow{display:flex}.card-inner{padding:8px 10px;gap:8px;border-radius:8px;box-shadow:0 0 10px #a78bfa33,0 0 20px #a78bfa1a,0 4px 16px #0000004d}.user-icon{width:28px;height:28px;border-radius:6px}.user-icon svg{width:14px;height:14px}.user-role{font-size:10px}.user-email,.user-description{font-size:8px}.user-arrow svg{width:14px;height:14px}.form-divider{margin-bottom:12px}.divider-text{font-size:8px}.input-label{font-size:9px}.input-field{padding:10px 12px;font-size:12px;border-radius:8px}.submit-button{padding:10px 16px;font-size:12px;border-radius:8px}.credentials-grid{grid-template-columns:repeat(2,1fr)}}[data-theme=light] .login-page{--bg-deepest: #f0f4f8;--bg-deep: #f8fafc;--bg-base: #ffffff;--bg-surface: #ffffff;--bg-elevated: #ffffff;--glass-bg: rgba(0, 0, 0, .02);--glass-border: rgba(0, 0, 0, .08);--glass-border-hover: rgba(0, 0, 0, .15);--accent: #7c3aed;--accent-glow: rgba(124, 58, 237, .2);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8}[data-theme=light] .login-branding{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}[data-theme=light] .login-branding:before{background:linear-gradient(to bottom,transparent,rgba(124,58,237,.2),rgba(124,58,237,.1),transparent)}[data-theme=light] .login-form-section{background:#f8fafc}[data-theme=light] .bg-gradient-1,[data-theme=light] .bg-gradient-2,[data-theme=light] .bg-gradient-3{opacity:.5}[data-theme=light] .bg-grid{background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px)}[data-theme=light] .bg-mouse-follow{background:radial-gradient(circle,rgba(124,58,237,.08) 0%,transparent 50%)}[data-theme=light] .card-inner{background:#00000005;border-color:#00000014;box-shadow:0 2px 8px #00000014;animation:none}[data-theme=light] .user-card:hover .card-inner{background:#0000000a;border-color:#7c3aed4d;box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}[data-theme=light] .card-glass{box-shadow:0 4px 20px #00000014;animation:none}[data-theme=light] .card-border{border-color:#00000014}[data-theme=light] .login-card:hover .card-glass{box-shadow:0 8px 30px #0000001f}[data-theme=light] .login-card:hover .card-border{border-color:#7c3aed33}[data-theme=light] .logo-icon{border-color:transparent;box-shadow:0 8px 24px #7c3aed40;animation:none}[data-theme=light] .logo-icon:hover{box-shadow:0 12px 32px #7c3aed59;transform:translateY(-2px)}[data-theme=light] .feature-item{background:#00000005;border-color:#00000014;box-shadow:0 2px 8px #0000000f;animation:none}[data-theme=light] .feature-item:hover{background:#0000000a;border-color:#7c3aed4d;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}[data-theme=light] .input-field{background:#00000005;border-color:#0000001a;color:var(--text-primary)}[data-theme=light] .input-field:focus{background:#fff}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root,[data-theme=light]{--shadcn-background: 0 0% 100%;--shadcn-foreground: 222.2 84% 4.9%;--shadcn-card: 0 0% 100%;--shadcn-card-foreground: 222.2 84% 4.9%;--shadcn-popover: 0 0% 100%;--shadcn-popover-foreground: 222.2 84% 4.9%;--shadcn-primary: 239 84% 67%;--shadcn-primary-foreground: 210 40% 98%;--shadcn-secondary: 210 40% 96%;--shadcn-secondary-foreground: 222.2 47.4% 11.2%;--shadcn-muted: 210 40% 96%;--shadcn-muted-foreground: 215.4 16.3% 46.9%;--shadcn-accent: 210 40% 96%;--shadcn-accent-foreground: 222.2 47.4% 11.2%;--shadcn-destructive: 0 84.2% 60.2%;--shadcn-destructive-foreground: 210 40% 98%;--shadcn-border: 214.3 31.8% 91.4%;--shadcn-input: 214.3 31.8% 91.4%;--shadcn-ring: 239 84% 67%;--shadcn-radius: .5rem}[data-theme=dark]{--shadcn-background: 240 10% 3.9%;--shadcn-foreground: 0 0% 98%;--shadcn-card: 240 6% 10%;--shadcn-card-foreground: 0 0% 98%;--shadcn-popover: 240 6% 10%;--shadcn-popover-foreground: 0 0% 98%;--shadcn-primary: 239 84% 67%;--shadcn-primary-foreground: 0 0% 98%;--shadcn-secondary: 240 3.7% 15.9%;--shadcn-secondary-foreground: 0 0% 98%;--shadcn-muted: 240 3.7% 15.9%;--shadcn-muted-foreground: 240 5% 64.9%;--shadcn-accent: 240 3.7% 15.9%;--shadcn-accent-foreground: 0 0% 98%;--shadcn-destructive: 0 62.8% 30.6%;--shadcn-destructive-foreground: 0 0% 98%;--shadcn-border: 240 3.7% 15.9%;--shadcn-input: 240 3.7% 15.9%;--shadcn-ring: 239 84% 67%}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media(min-width:1400px){.container{max-width:1400px}}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.left-2{left:.5rem}.left-3{left:.75rem}.top-1\/2{top:50%}.z-50{z-index:50}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-5{margin-bottom:1.25rem}.ml-auto{margin-left:auto}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.list-item{display:list-item}.hidden{display:none}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-2{height:.5rem}.h-20{height:5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-px{height:1px}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.w-10{width:2.5rem}.w-12{width:3rem}.w-2{width:.5rem}.w-20{width:5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-64{width:16rem}.w-8{width:2rem}.w-\[150px\]{width:150px}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.caption-bottom{caption-side:bottom}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--shadcn-radius)}.rounded-md{border-radius:calc(var(--shadcn-radius) - 2px)}.rounded-sm{border-radius:calc(var(--shadcn-radius) - 4px)}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-amber-500\/20{border-color:#f59e0b33}.border-emerald-500\/20{border-color:#10b98133}.border-indigo-500\/20{border-color:#6366f133}.border-input{border-color:hsl(var(--shadcn-input))}.border-red-500\/20{border-color:#ef444433}.border-transparent{border-color:transparent}.border-white\/\[0\.04\]{border-color:#ffffff0a}.border-white\/\[0\.06\]{border-color:#ffffff0f}.bg-amber-500\/15{background-color:#f59e0b26}.bg-background{background-color:hsl(var(--shadcn-background))}.bg-card{background-color:hsl(var(--shadcn-card))}.bg-destructive{background-color:hsl(var(--shadcn-destructive))}.bg-emerald-500\/15{background-color:#10b98126}.bg-indigo-500\/10{background-color:#6366f11a}.bg-muted{background-color:hsl(var(--shadcn-muted))}.bg-muted\/50{background-color:hsl(var(--shadcn-muted) / .5)}.bg-popover{background-color:hsl(var(--shadcn-popover))}.bg-primary{background-color:hsl(var(--shadcn-primary))}.bg-red-500\/15{background-color:#ef444426}.bg-secondary{background-color:hsl(var(--shadcn-secondary))}.bg-white\/\[0\.02\]{background-color:#ffffff05}.bg-white\/\[0\.04\]{background-color:#ffffff0a}.bg-white\/\[0\.06\]{background-color:#ffffff0f}.fill-current{fill:currentColor}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pl-8{padding-left:2rem}.pl-9{padding-left:2.25rem}.pr-2{padding-right:.5rem}.pt-2{padding-top:.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[11px\]{font-size:11px}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.tracking-tight{letter-spacing:-.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-destructive-foreground{color:hsl(var(--shadcn-destructive-foreground))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-foreground{color:hsl(var(--shadcn-foreground))}.text-indigo-400{--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity, 1))}.text-muted{color:hsl(var(--shadcn-muted))}.text-muted-foreground{color:hsl(var(--shadcn-muted-foreground))}.text-popover-foreground{color:hsl(var(--shadcn-popover-foreground))}.text-primary{color:hsl(var(--shadcn-primary))}.text-primary-foreground{color:hsl(var(--shadcn-primary-foreground))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-secondary{color:hsl(var(--shadcn-secondary))}.text-secondary-foreground{color:hsl(var(--shadcn-secondary-foreground))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-offset-background{--tw-ring-offset-color: hsl(var(--shadcn-background))}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.fade-in-0{--tw-enter-opacity: 0}.zoom-in-95{--tw-enter-scale: .95}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{animation-timing-function:cubic-bezier(0,0,.2,1)}.paused{animation-play-state:paused}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{color:hsl(var(--shadcn-foreground))}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--shadcn-muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--shadcn-muted-foreground))}.hover\:border-white\/\[0\.1\]:hover{border-color:#ffffff1a}.hover\:bg-accent:hover{background-color:hsl(var(--shadcn-accent))}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--shadcn-destructive) / .8)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--shadcn-destructive) / .9)}.hover\:bg-muted\/50:hover{background-color:hsl(var(--shadcn-muted) / .5)}.hover\:bg-primary\/80:hover{background-color:hsl(var(--shadcn-primary) / .8)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--shadcn-primary) / .9)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--shadcn-secondary) / .8)}.hover\:bg-transparent:hover{background-color:transparent}.hover\:bg-white\/\[0\.03\]:hover{background-color:#ffffff08}.hover\:bg-white\/\[0\.06\]:hover{background-color:#ffffff0f}.hover\:text-accent-foreground:hover{color:hsl(var(--shadcn-accent-foreground))}.hover\:text-foreground:hover{color:hsl(var(--shadcn-foreground))}.hover\:underline:hover{text-decoration-line:underline}.focus\:bg-accent:focus{background-color:hsl(var(--shadcn-accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--shadcn-accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--shadcn-ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--shadcn-ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--shadcn-accent))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:hsl(var(--shadcn-muted))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:hsl(var(--shadcn-muted-foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y: -.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x: .5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x: -.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y: .5rem}@media(min-width:640px){.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}}@media(min-width:768px){.md\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0px}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0px}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}html.theme-transitioning,html.theme-transitioning *,html.theme-transitioning *:before,html.theme-transitioning *:after{transition:background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease,fill .3s ease,stroke .3s ease!important}*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-card: rgba(255, 255, 255, .03);--bg-hover: rgba(255, 255, 255, .04);--bg-elevated: rgba(255, 255, 255, .05);--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--accent: #6366f1;--accent-light: rgba(99, 102, 241, .12);--success: #10b981;--success-light: rgba(16, 185, 129, .12);--warning: #f59e0b;--warning-light: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-light: rgba(239, 68, 68, .12);--info: #06b6d4;--info-light: rgba(6, 182, 212, .12);--purple: #8b5cf6;--purple-light: rgba(139, 92, 246, .12);--pink: #ec4899;--pink-light: rgba(236, 72, 153, .12);--accent-bright: #818cf8;--success-bright: #34d399;--warning-bright: #fbbf24;--danger-bright: #f87171;--info-bright: #22d3ee;--purple-bright: #a78bfa;--pink-bright: #f472b6;--accent-deep: #4f46e5;--success-deep: #059669;--warning-deep: #d97706;--danger-deep: #dc2626;--info-deep: #0891b2;--purple-deep: #7c3aed;--pink-deep: #db2777;--blue-deep: #2563eb;--text: #ffffff;--text-secondary: #a1a1aa;--text-muted: #8a8a95;--sidebar-width: 260px;--sidebar-collapsed: 72px;--radius: 12px;--radius-sm: 8px;--font: "Inter", system-ui, -apple-system, sans-serif}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-hover: #f1f5f9;--bg-elevated: #edf2f7;--border: #e2e8f0;--border-hover: #cbd5e1;--accent: #6366f1;--accent-light: #eef2ff;--success: #10b981;--success-light: #ecfdf5;--warning: #f59e0b;--warning-light: #fffbeb;--danger: #ef4444;--danger-light: #fef2f2;--info: #06b6d4;--info-light: #ecfeff;--purple: #8b5cf6;--purple-light: #f5f3ff;--pink: #ec4899;--pink-light: #fdf2f8;--accent-bright: #818cf8;--success-bright: #34d399;--warning-bright: #fbbf24;--danger-bright: #f87171;--info-bright: #22d3ee;--purple-bright: #a78bfa;--pink-bright: #f472b6;--accent-deep: #4338ca;--success-deep: #047857;--warning-deep: #b45309;--danger-deep: #b91c1c;--info-deep: #0e7490;--purple-deep: #6d28d9;--pink-deep: #be185d;--blue-deep: #1d4ed8;--text: #0f172a;--text-secondary: #334155;--text-muted: #64748b}[data-theme=light] body{background:var(--bg-primary);color:var(--text)}[data-theme=light] .sidebar{background:var(--bg-secondary);border-right-color:var(--border)}[data-theme=light] .card,[data-theme=light] .kpi-card{background:var(--bg-secondary);border-color:var(--border)}[data-theme=light] .btn-secondary{background:var(--bg-tertiary);color:var(--text)}[data-theme=light] .nav-item:hover{background:var(--bg-tertiary)}[data-theme=light] .badge-success{background:#f0faf5;color:#047857}[data-theme=light] .badge-warning{background:#fef9ee;color:#92400e}[data-theme=light] .badge-danger{background:#fef2f2;color:#b91c1c}[data-theme=light] .badge-info{background:#f0f9ff;color:#0e7490}[data-theme=light] .badge-purple{background:#f5f3ff;color:#6d28d9}[data-theme=light] .badge-accent{background:#eef2ff;color:#4338ca}[data-theme=light] .nav-item.active{background:var(--accent-light)}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg-primary);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;min-height:100vh}.main{position:relative;flex:1;margin-left:var(--sidebar-width);padding:24px 32px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);overflow-x:hidden;min-height:100vh}.main.collapsed{margin-left:var(--sidebar-collapsed)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar-mouse-glow{position:absolute;pointer-events:none;z-index:0;width:300px;height:300px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(167,139,250,.06) 0%,transparent 50%);transition:left .3s ease-out,top .3s ease-out}[data-theme=light] .sidebar-mouse-glow{background:radial-gradient(circle,rgba(124,58,237,.08) 0%,transparent 50%)}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-overlay,.mobile-menu-btn,.sidebar-close{display:none}.desktop-only{display:flex}.mobile-only{display:none}.sidebar-header{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.sidebar-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.sidebar-brand{overflow:hidden;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed .sidebar-brand{opacity:0;width:0}.sidebar-brand h1{font-size:18px;font-weight:700;background:linear-gradient(90deg,var(--accent),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.sidebar-brand span{font-size:11px;color:var(--text-muted)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:8px}.nav-title-btn{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:8px 12px;margin-bottom:4px;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.nav-title-btn:hover{background:var(--bg-card);color:var(--text-secondary)}.nav-title-text{text-align:left}.nav-chevron{transition:transform .3s ease;opacity:.6}.nav-chevron.open{transform:rotate(180deg)}.nav-items{max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .25s ease,padding .3s ease;padding:0}.nav-items.open{max-height:500px;opacity:1;padding-bottom:8px}.sidebar.collapsed .nav-title-btn{opacity:0;height:0;padding:0;margin:0;overflow:hidden}.sidebar.collapsed .nav-items{max-height:500px;opacity:1;padding:0}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;transition:all .2s;margin-bottom:2px;position:relative}.nav-item:hover{background:var(--bg-elevated);color:var(--text)}.nav-item.active{background:var(--accent-light);color:var(--accent);border-left:3px solid var(--accent);padding-left:9px}.nav-icon{width:20px;height:20px;flex-shrink:0}.nav-label{font-size:14px;font-weight:500;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;transition:all .3s}.nav-item.locked{opacity:.5;cursor:not-allowed;pointer-events:none}.nav-item.locked:hover{background:transparent;color:var(--text-secondary)}.nav-lock-icon{margin-left:auto;color:var(--text-muted);opacity:.7}.sidebar.collapsed .nav-lock-icon{display:none}.sidebar.collapsed .nav-badge{position:absolute;top:4px;right:4px;padding:1px 4px;font-size:9px;margin:0}.ai-assistant-link{background:linear-gradient(135deg,#8b5cf61a,#6366f11a);border:1px solid rgba(139,92,246,.2)}.ai-assistant-link:hover{background:linear-gradient(135deg,#8b5cf633,#6366f133);border-color:#8b5cf666}.ai-assistant-link.active{background:linear-gradient(135deg,#8b5cf640,#6366f140);border-color:var(--accent)}.ai-live-dot{width:8px;height:8px;background:#34d399;border-radius:50%;margin-left:auto;animation:ai-live-pulse 2s infinite;box-shadow:0 0 8px #5eac8a99}@keyframes ai-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.85)}}.sidebar.collapsed .ai-live-dot{position:absolute;top:4px;right:4px;margin:0;width:6px;height:6px}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.topbar{position:sticky;top:0;display:flex;align-items:center;gap:12px;padding:16px 32px;z-index:10}.topbar-title{font-size:18px;font-weight:700;color:var(--text);margin:0 auto 0 0;white-space:nowrap}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--bg-elevated);border:1px solid var(--border-light, rgba(255,255,255,.15));border-radius:10px;padding:0 12px;height:36px;min-width:180px;color:var(--text-secondary);transition:all .2s}.topbar-search input{border:none;background:transparent;color:var(--text);font-size:13px;outline:none;width:100%}.topbar-search input::-moz-placeholder{color:var(--text-muted)}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.topbar-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all .2s}.topbar-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.topbar-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;border-radius:8px;background:var(--danger, #f87171);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px}.topbar-clock{display:flex;align-items:center;gap:6px;padding:0 12px;height:36px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);font-size:13px;white-space:nowrap}.clock-time{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);font-family:SF Mono,Fira Code,monospace;letter-spacing:.5px}.clock-date{font-size:11px;color:var(--text-muted);padding-left:6px;border-left:1px solid var(--border)}.topbar-notif-wrapper{position:relative}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0000004d;z-index:100;overflow:hidden;animation:notifSlideIn .15s ease-out}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.notif-title{font-weight:700;font-size:14px;color:var(--text)}.notif-mark-all{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .2s}.notif-mark-all:hover{background:var(--accent-light)}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{padding:32px 16px;text-align:center;color:var(--text-muted);font-size:13px}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;position:relative}.notif-item:not(:last-child){border-bottom:1px solid var(--border)}.notif-item:hover{background:var(--bg-tertiary)}.notif-item.unread{background:#6366f10d}.notif-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-icon--order{background:#6366f126;color:var(--accent)}.notif-icon--stock{background:#f59e0b26;color:var(--warning)}.notif-icon--chat{background:#10b98126;color:var(--success)}.notif-content{flex:1;min-width:0}.notif-item-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}.notif-desc{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time{font-size:11px;color:var(--text-muted);margin-top:4px}.notif-close{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;opacity:0;transition:all .15s}.notif-item:hover .notif-close{opacity:1}.notif-close:hover{color:var(--danger);background:#ef44441a}.sidebar-user{display:flex;align-items:center;gap:12px;padding:8px;border-radius:var(--radius-sm);transition:background .2s}.sidebar-user:hover{background:var(--bg-elevated)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--purple));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}.user-info{overflow:hidden;flex:1;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed .user-info{opacity:0;width:0}.user-name{font-size:13px;font-weight:600}.user-role{font-size:11px;color:var(--text-muted)}.logout-btn{padding:6px;margin-left:auto;transition:all .3s}.sidebar.collapsed .logout-btn{display:none}.sidebar-toggle{position:absolute;top:24px;right:-12px;width:24px;height:24px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s;z-index:10}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.page-title{font-size:24px;font-weight:700;margin-bottom:4px}.page-subtitle{font-size:14px;color:var(--text-secondary)}.page-actions{display:flex;gap:12px;flex-wrap:wrap}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}.card:hover{border-color:var(--border-hover)}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px}.card-title{font-size:15px;font-weight:600}.card-body{padding:20px}.card-body.flush{padding:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.stat-card{padding:20px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .2s}.kpi-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.kpi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.kpi-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.kpi-trend{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:4px 8px;border-radius:20px}.kpi-trend.up{background:var(--success-light);color:var(--success)}.kpi-trend.down{background:var(--danger-light);color:var(--danger)}.kpi-value{font-size:28px;font-weight:700;margin-bottom:4px}.kpi-label{font-size:13px;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(.9)}.btn-secondary{background:var(--bg-tertiary);color:var(--text)}.btn-secondary:hover{background:var(--bg-elevated)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.9)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(.9)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text)}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{padding:6px;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary)}.table td{font-size:13px;color:var(--text-secondary)}.table tbody tr:hover{background:var(--bg-hover)}.table tbody tr:last-child td{border-bottom:none}.table-sticky-col th:first-child,.table-sticky-col td:first-child{position:sticky;left:0;z-index:2;background:var(--bg-secondary)}.table-sticky-col th:first-child{background:var(--bg-tertiary);z-index:3}.table-sticky-col td:first-child:after,.table-sticky-col th:first-child:after{content:"";position:absolute;top:0;right:-4px;bottom:0;width:4px;background:linear-gradient(to right,rgba(0,0,0,.06),transparent);pointer-events:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;border-radius:20px;white-space:nowrap}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-purple{background:var(--purple-light);color:var(--purple)}.badge-accent{background:var(--accent-light);color:var(--accent)}.badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:var(--text-muted)}.input{width:100%;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;transition:all .2s}.input-group .input{padding-left:40px}.input:focus{outline:none;border-color:var(--accent);background:var(--bg-tertiary)}.input::-moz-placeholder{color:var(--text-muted)}.input::placeholder{color:var(--text-muted)}.select{padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;cursor:pointer}.select:focus{outline:none;border-color:var(--accent)}.select option{background:var(--bg-card);color:var(--text)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.warehouse-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.account-layout{display:grid;grid-template-columns:240px 1fr;gap:24px}.chat-layout{display:grid;grid-template-columns:320px 1fr;height:100%}.mobile-only{display:none!important}.social-icon{transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;flex-shrink:0}.social-icon:hover{transform:scale(1.15) translateY(-2px)}.social-icon:active{transform:scale(.95)}.social-icon.facebook:hover{filter:drop-shadow(0 4px 12px rgba(24,119,242,.5))}.social-icon.instagram:hover{filter:drop-shadow(0 4px 12px rgba(225,48,108,.5))}.social-icon.tiktok:hover{filter:drop-shadow(0 4px 12px rgba(254,44,85,.5))}.social-icon.whatsapp:hover{filter:drop-shadow(0 4px 12px rgba(37,211,102,.5))}.social-icon.twitter-x:hover{filter:drop-shadow(0 4px 12px rgba(255,255,255,.3))}.social-icon.shopee:hover{filter:drop-shadow(0 4px 12px rgba(238,77,45,.5))}.social-icon.tokopedia:hover{filter:drop-shadow(0 4px 12px rgba(66,181,73,.5))}.social-icon.lazada:hover{filter:drop-shadow(0 4px 12px rgba(15,22,137,.5))}.social-icon.bukalapak:hover{filter:drop-shadow(0 4px 12px rgba(227,30,82,.5))}@keyframes icon-pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.social-icon.has-notification{animation:icon-pulse 2s ease-in-out infinite}.social-icon-wrapper{position:relative;display:inline-flex;cursor:pointer}.logo-indocompany{transition:all .3s ease}.logo-indocompany:hover{transform:scale(1.05);filter:drop-shadow(0 4px 12px rgba(139,92,246,.4))}.logo-indocompany:hover .flow-arrow{animation:flow-pulse .6s ease infinite}@keyframes flow-pulse{0%,to{transform:translate(0);opacity:1}50%{transform:translate(3px);opacity:.7}}.list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);transition:background .2s}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--bg-hover)}.chart-container{width:100%;height:300px}.tabs{display:flex;gap:4px;padding:4px;background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:20px;width:-moz-fit-content;width:fit-content;flex-wrap:wrap}.tab{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap}.tab:hover{color:var(--text);background:var(--bg-hover)}.tab.active{background:var(--bg-secondary);color:var(--text)}.tab-count{margin-left:6px;background:var(--danger);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px}.avatar{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.product-img{width:48px;height:48px;border-radius:var(--radius-sm);-o-object-fit:cover;object-fit:cover;background:var(--bg-tertiary)}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes flashPulse{0%{opacity:0}15%{opacity:1}40%{opacity:.6}70%{opacity:.9}to{opacity:0}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.modal-close:hover{background:#ffffff1a;color:var(--text)}.modal-body{padding:20px;overflow-y:auto}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:1100}.toast-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000004d;animation:slideInRight .3s ease;min-width:280px}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-message{flex:1;font-size:13px;color:var(--text)}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{animation:shimmer 1.5s infinite linear}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#2a2a36}.toggle{position:relative;display:inline-block;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--text-muted);transition:.3s;border-radius:50%}.toggle input:checked+.toggle-slider{background-color:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(20px);background-color:#fff}@media(max-width:1024px){:root{--sidebar-width: 72px}.sidebar{width:var(--sidebar-collapsed)}.sidebar .sidebar-brand,.sidebar .nav-label,.sidebar .nav-title-btn,.sidebar .nav-title-text,.sidebar .nav-chevron,.sidebar .user-info,.sidebar .logout-btn{opacity:0;width:0;overflow:hidden;height:0;padding:0;margin:0}.sidebar .nav-items{max-height:500px;opacity:1}.sidebar .nav-badge{position:absolute;top:4px;right:4px;padding:1px 4px;font-size:9px;margin:0}.sidebar-toggle{display:none}.main{margin-left:var(--sidebar-collapsed);padding:20px}.main.collapsed{margin-left:var(--sidebar-collapsed)}.kpi-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.warehouse-grid{grid-template-columns:1fr}.account-layout{grid-template-columns:200px 1fr;gap:20px}.chat-layout{grid-template-columns:280px 1fr}.page-header{flex-direction:column;align-items:flex-start;padding-right:0}.page-actions{width:100%}.topbar{position:static;margin-bottom:16px;justify-content:flex-end}}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;transform:translate(-100%);z-index:200}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open .sidebar-brand,.sidebar.mobile-open .nav-label,.sidebar.mobile-open .nav-title-btn,.sidebar.mobile-open .nav-title-text,.sidebar.mobile-open .nav-chevron,.sidebar.mobile-open .user-info,.sidebar.mobile-open .logout-btn{opacity:1;width:auto;height:auto}.sidebar.mobile-open .nav-title-btn{display:flex;padding:8px 12px;margin-bottom:4px}.sidebar.mobile-open .nav-items{max-height:0;opacity:0}.sidebar.mobile-open .nav-items.open{max-height:500px;opacity:1}.sidebar.mobile-open .nav-badge{position:static;margin-left:auto;padding:2px 6px;font-size:10px}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0009;z-index:150;animation:fadeIn .2s ease}.mobile-menu-btn{display:flex;position:fixed;top:16px;left:16px;z-index:50;width:44px;height:44px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;justify-content:center;cursor:pointer;color:var(--text)}.sidebar-close{display:flex;position:absolute;top:20px;right:16px;width:32px;height:32px;background:none;border:none;color:var(--text-muted);cursor:pointer;align-items:center;justify-content:center;border-radius:6px}.sidebar-close:hover{background:#ffffff1a;color:var(--text)}.desktop-only{display:none}.mobile-only{display:flex}.main{margin-left:0;padding:70px 16px 16px}.main.collapsed{margin-left:0}.kpi-grid,.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.kpi-card{padding:16px}.kpi-value{font-size:22px}.kpi-icon{width:40px;height:40px}.grid-2,.grid-3,.warehouse-grid,.account-layout{grid-template-columns:1fr;gap:16px}.chat-layout{grid-template-columns:1fr}.chat-layout>*:last-child{display:none}.chat-layout.show-chat>*:first-child{display:none}.chat-layout.show-chat>*:last-child{display:flex}.mobile-only{display:flex!important}.page-title{font-size:20px}.topbar-search{min-width:120px}.topbar-clock,.clock-date{display:none}.notif-dropdown{width:calc(100vw - 32px);right:-8px}.page-actions{width:100%;flex-wrap:wrap}.page-actions .btn{flex:1;min-width:120px}.tabs{width:100%;overflow-x:auto;flex-wrap:nowrap}.card-header{flex-direction:column;align-items:flex-start}.table{font-size:12px}.table th,.table td{padding:10px 12px}.modal-overlay{padding:12px}.modal-content{max-height:95vh}.toast-container{bottom:16px;right:16px;left:16px}.toast-item{min-width:auto}.chart-container{height:250px}}@media(max-width:480px){.kpi-grid,.stats-grid{grid-template-columns:1fr}.page-actions .btn{width:100%;flex:none}.kpi-value{font-size:20px}}.login-container{display:flex;min-height:100vh;background:#0a0a0f}.login-branding{flex:1;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f0f23);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px;position:relative;overflow:hidden}.branding-bg-decoration{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 70%,rgba(139,92,246,.1) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(99,102,241,.1) 0%,transparent 50%);animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(-20px,-20px) rotate(5deg)}}.brand-logo{width:120px;height:120px;background:linear-gradient(135deg,#a78bfa,#818cf8);border-radius:24px;display:flex;align-items:center;justify-content:center;margin-bottom:32px;box-shadow:0 20px 40px #8b5cf64d;position:relative;z-index:1}.brand-icon{color:#fff}.brand-title{font-size:42px;font-weight:700;color:#fff;letter-spacing:-.5px;margin-bottom:8px;position:relative;z-index:1}.brand-tagline{font-size:16px;font-weight:600;color:#a78bfa;letter-spacing:4px;text-transform:uppercase;margin-bottom:32px;position:relative;z-index:1}.brand-divider{width:60px;height:3px;background:linear-gradient(90deg,#a78bfa,#818cf8);border-radius:2px;margin-bottom:32px}.brand-quote{font-size:18px;font-style:italic;color:#a1a1aa;text-align:center;max-width:380px;line-height:1.7;margin-bottom:48px;position:relative;z-index:1}.brand-features{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}.feature-item{display:flex;align-items:center;gap:12px;color:#a1a1aa;font-size:14px}.feature-icon{color:#34d399}.brand-copyright{position:absolute;bottom:32px;color:#71717a;font-size:13px}.login-form-panel{flex:1;display:flex;justify-content:center;align-items:center;padding:40px;background:#0f0f14}.login-card{width:100%;max-width:420px;padding:48px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:20px;backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:32px}.form-title{font-size:28px;font-weight:600;color:#fff;margin-bottom:8px}.form-subtitle{color:#a1a1aa;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.login-form-group{display:flex;flex-direction:column;gap:8px}.login-form-label{display:flex;align-items:center;gap:8px;color:#a1a1aa;font-size:13px;font-weight:500}.login-input-wrapper{position:relative}.login-form-input{width:100%;padding:14px 16px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px;transition:all .2s ease}.login-form-input:focus{outline:none;background:#ffffff14;border-color:#a78bfa;box-shadow:0 0 0 3px #8b5cf626}.login-form-input::-moz-placeholder{color:#71717a}.login-form-input::placeholder{color:#71717a}.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:#71717a;cursor:pointer;padding:4px;transition:color .2s}.password-toggle:hover{color:#a1a1aa}.login-form-options{display:flex;justify-content:space-between;align-items:center}.login-checkbox-wrapper{display:flex;align-items:center;gap:8px;color:#a1a1aa;font-size:13px;cursor:pointer}.login-checkbox-wrapper input{width:16px;height:16px;accent-color:#a78bfa}.forgot-link{color:#a78bfa;font-size:13px;text-decoration:none;transition:color .2s}.forgot-link:hover{color:#a78bfa}.login-error-message{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:13px;text-align:center}.login-button{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;background:linear-gradient(135deg,#a78bfa,#818cf8);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px}.login-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b5cf666}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:loginSpin .8s linear infinite}@keyframes loginSpin{to{transform:rotate(360deg)}}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.login-divider span{color:#71717a;font-size:12px}.social-login{display:flex;gap:12px}.social-button{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#a1a1aa;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.social-button:hover{background:#ffffff14;border-color:#fff3}.default-credentials{margin-top:24px;padding:16px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px}.credentials-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.credentials-header span{color:#a1a1aa;font-size:13px;font-weight:500}.fill-button{padding:6px 12px;background:#8b5cf633;border:none;border-radius:6px;color:#a78bfa;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.fill-button:hover{background:#8b5cf64d}.credentials-info{display:flex;flex-direction:column;gap:8px}.credential-item{display:flex;align-items:center;gap:8px;font-size:12px}.credential-label{color:#71717a;min-width:70px}.credential-item code{background:var(--bg-elevated);padding:4px 8px;border-radius:4px;color:#a78bfa;font-family:monospace;font-size:12px}.online-dot{display:inline-block;width:8px;height:8px;background:#34d399;border-radius:50%;margin-right:2px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes glow{0%,to{box-shadow:0 0 8px #818cf866,0 0 24px #818cf826,inset 0 0 8px #818cf80d}50%{box-shadow:0 0 20px #818cf899,0 0 48px #818cf840,inset 0 0 16px #818cf814}}.ai-cc-glow{animation:glow 2s ease-in-out infinite;overflow:visible!important;border-color:#818cf84d!important}@media(max-width:1024px){.login-branding{display:none}.login-form-panel{padding:24px}.login-card{padding:32px}}@media(max-width:480px){.login-card{padding:24px;border-radius:16px}.form-title{font-size:24px}.social-login{flex-direction:column}}.user-cards-container{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;max-height:320px;overflow-y:auto;padding-right:8px}.user-cards-container::-webkit-scrollbar{width:4px}.user-cards-container::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:2px}.user-cards-container::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:2px}.user-login-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--user-bg);border:1px solid var(--user-border);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.user-login-card:hover{background:var(--user-border);transform:translate(4px);border-color:var(--user-color)}.user-login-card:active{transform:translate(2px)}.user-login-card:disabled{opacity:.6;cursor:not-allowed;transform:none}.user-login-card.loading{opacity:.8}.user-login-card-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:10px}.user-login-card-info{flex:1;display:flex;flex-direction:column;gap:2px}.user-login-card-role{font-size:13px;font-weight:600;color:var(--user-color);letter-spacing:.5px}.user-login-card-email{font-size:12px;color:#71717a}.user-login-card-arrow{color:#4a4a5a;transition:transform .2s}.user-login-card:hover .user-login-card-arrow{transform:translate(4px);color:var(--user-color)}.user-card-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--user-color);border-radius:50%;animation:loginSpin .8s linear infinite}.show-manual-login-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#a1a1aa;font-size:13px;cursor:pointer;transition:all .2s}.show-manual-login-btn:hover{background:#ffffff14;color:#fff}.manual-login-form{display:flex;flex-direction:column;gap:16px}.back-to-cards-btn{background:none;border:none;color:#71717a;font-size:13px;cursor:pointer;padding:8px;transition:color .2s;text-align:center}.back-to-cards-btn:hover{color:#a1a1aa}.credentials-table{margin-top:24px;border:1px solid var(--purple-light);border-radius:12px;overflow:hidden}.credentials-table-header{padding:12px 16px;background:var(--purple-light);font-size:13px;font-weight:500;color:var(--text-secondary)}.credentials-table table{width:100%;border-collapse:collapse;font-size:11px}.credentials-table th{padding:10px 12px;text-align:left;color:var(--text-muted);font-weight:500;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.credentials-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.credentials-table tr:last-child td{border-bottom:none}.credentials-table code{background:var(--bg-hover);padding:2px 6px;border-radius:4px;color:var(--purple);font-family:JetBrains Mono,Courier New,monospace;font-size:10px}.cred-role-badge{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:500}@media(max-width:1024px){.user-cards-container{max-height:280px}.credentials-table{display:none}}.main.full-width{margin-left:0;padding:0}.launcher{min-height:100vh;padding:40px;background:var(--bg)}.launcher-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px}.launcher-brand{display:flex;align-items:center;gap:12px}.launcher-brand-text{font-size:18px;font-weight:700;color:var(--text)}.launcher-topbar-actions{display:flex;align-items:center;gap:8px}.launcher-header{text-align:center;margin-bottom:48px}.launcher-title{font-size:28px;font-weight:700;color:var(--text);margin-bottom:8px}.launcher-subtitle{font-size:15px;color:var(--text-secondary)}.launcher-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;max-width:1160px;margin:0 auto}.module-card{display:flex;flex-direction:column;padding:24px 22px 18px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);text-align:left;color:inherit;font-family:inherit;position:relative;overflow:hidden}.module-card:before{content:"";position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .35s ease;background:linear-gradient(135deg,var(--card-accent, #818cf8) 0%,transparent 60%);pointer-events:none}.module-card:hover:before{opacity:.04}.module-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px -12px #0000001f,0 0 0 1px var(--card-accent, var(--accent)),0 0 30px -8px var(--card-glow, rgba(99,102,241,.15));border-color:var(--card-accent, var(--accent))}.module-card:active{transform:translateY(-2px);transition-duration:.1s}.module-card-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;position:relative;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease}.module-card:hover .module-card-icon{transform:scale(1.08);box-shadow:0 8px 24px -4px var(--card-glow, rgba(99,102,241,.35))}.module-card-body{flex:1;margin-bottom:14px}.module-card-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px;letter-spacing:-.01em}.module-card-desc{font-size:13px;color:var(--text-secondary);line-height:1.45;margin:0}.module-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}.module-card-count{font-size:12px;color:var(--text-muted);font-weight:500}.module-card-arrow{color:var(--text-muted);transition:all .3s cubic-bezier(.4,0,.2,1)}.module-card:hover .module-card-arrow{transform:translate(4px);color:var(--card-accent, var(--accent))}.sidebar-module-header{gap:10px}.sidebar-back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm, 8px);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all .2s}.sidebar-back-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.sidebar-module-info{display:flex;align-items:center;gap:8px;overflow:hidden;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar-module-name{font-size:16px;font-weight:700;color:var(--text)}.sidebar.collapsed .sidebar-module-info{opacity:0;width:0;overflow:hidden}@media(max-width:768px){.launcher{padding:20px}.launcher-title{font-size:22px}.launcher-grid{grid-template-columns:repeat(2,1fr);gap:12px}.module-card{padding:16px;border-radius:16px}.module-card-icon{width:42px;height:42px;border-radius:12px;margin-bottom:12px}.module-card-title{font-size:14px}.module-card-desc{font-size:11px}}@media(max-width:480px){.launcher-grid{grid-template-columns:1fr}}.flow-node{display:flex;flex-direction:column;align-items:center;border-radius:10px;padding:6px 12px;cursor:default;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;position:relative}.flow-node--clickable{cursor:pointer;animation:flowNodePulse 3s ease-in-out infinite}.flow-node--clickable:hover{transform:scale(1.1);z-index:2;filter:brightness(1.15)}@keyframes flowNodePulse{0%,to{box-shadow:0 0 0 transparent}50%{box-shadow:0 0 14px var(--flow-node-color, rgba(99,102,241,.25))}}.flow-arrow{display:inline-flex;align-items:center;justify-content:center;position:relative;width:28px;height:16px;color:var(--text-muted);font-size:16px;font-weight:300}.flow-arrow:before{content:"";position:absolute;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:0;animation:flowArrowDot 2s ease-in-out infinite}.flow-arrow:after{content:"→"}@keyframes flowArrowDot{0%{left:2px;opacity:0}15%{opacity:.7}85%{opacity:.7}to{left:20px;opacity:0}}.flow-branch{color:var(--text-muted);font-size:16px;font-weight:300;animation:flowBranchPulse 2.5s ease-in-out infinite}@keyframes flowBranchPulse{0%,to{opacity:.4}50%{opacity:1}}.rack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.rack-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm, 8px);padding:12px;transition:border-color .2s,background .2s}.rack-card:hover{border-color:var(--border-hover);background:var(--bg-hover)}.rack-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-size:12px;font-weight:700}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-state-icon{width:64px;height:64px;border-radius:16px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:16px}.empty-state-title{font-size:15px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.empty-state-desc{font-size:13px;color:var(--text-muted);max-width:320px}
