:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--primary-light:#bfdbfe;--primary-bg:#eff6ff;--primary-subtle:#dbeafe;--success-color:#16a34a;--success-bg:#f0fdf4;--danger-color:#dc2626;--danger-hover:#b91c1c;--danger-bg:#fef2f2;--warning-color:#d97706;--warning-bg:#fffbeb;--info-color:#0284c7;--info-bg:#f0f9ff;--accent-purple:#7c3aed;--accent-cyan:#0891b2;--bg-color:#f1f5f9;--bg-subtle:#e2e8f0;--card-bg:#fff;--sidebar-bg:#fff;--input-bg:#fff;--desktop-bg:#cbd5e1;--desktop-shortcut-hover:rgba(255,255,255,.4);--desktop-shortcut-active:rgba(255,255,255,.65);--text-color:#0f172a;--text-primary:#0f172a;--text-muted:#64748b;--text-inverse:#fff;--border-color:#cbd5e1;--border-color-light:#e2e8f0;--shell-bg:#0f172a;--shell-bg-hover:#1e293b;--shell-bg-active:#1d4ed8;--shell-text:#f1f5f9;--shell-text-muted:#94a3b8;--shell-border:#1e293b;--shadow-xs:0 1px 2px rgba(0,0,0,.05);--shadow-sm:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);--shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-md:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--shadow-lg:0 20px 25px -5px rgba(0,0,0,.15),0 10px 10px -5px rgba(0,0,0,.04);--radius-sm:3px;--radius-md:5px;--radius-lg:8px;--radius-xl:12px;--radius-full:9999px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-1:4px;--space-2:8px;--space-3:16px;--space-4:24px;--space-5:28px;--space-6:32px;--space-8:48px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;--font-mono:"SF Mono","Fira Code",monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--window-header-height:38px;--window-border-radius:6px;--taskbar-height:40px;--menubar-height:42px;--window-min-width:300px;--window-min-height:200px;--sidebar-width:260px;--sidebar-header-height:52px;--login-gradient:linear-gradient(135deg,#f0ebe3 0%,#e8dfd5 50%,#ddd5ca 100%);--login-bg-solid:#e8dfd5;--primary:var(--primary-color);--success:var(--success-color);--error:var(--danger-color);--warning:var(--warning-color);--surface-primary:var(--card-bg);--surface-secondary:var(--bg-subtle);--text-secondary:var(--text-muted)}[data-theme=dark]{--primary-color:#3b82f6;--primary-hover:#2563eb;--primary-light:#1e3a5f;--primary-bg:#172554;--primary-subtle:#1e3a5f;--success-color:#22c55e;--success-bg:#052e16;--danger-color:#f87171;--danger-hover:#ef4444;--danger-bg:#450a0a;--warning-color:#fcd34d;--warning-bg:#451a03;--info-color:#38bdf8;--info-bg:#082f49;--accent-purple:#a78bfa;--accent-cyan:#22d3ee;--bg-color:#0f172a;--bg-subtle:#1e293b;--card-bg:#1e293b;--sidebar-bg:#1e293b;--input-bg:#1e293b;--desktop-bg:#0f172a;--desktop-shortcut-hover:rgba(255,255,255,.4);--desktop-shortcut-active:rgba(255,255,255,.65);--shell-bg:#020617;--shell-bg-hover:#0f172a;--shell-bg-active:#2563eb;--shell-text:#e2e8f0;--shell-text-muted:#475569;--shell-border:#0f172a;--text-color:#e2e8f0;--text-primary:#e2e8f0;--text-muted:#94a3b8;--text-inverse:#0f172a;--border-color:#334155;--border-color-light:#1e293b;--shadow-xs:0 1px 2px rgba(0,0,0,.3);--shadow-sm:0 1px 3px rgba(0,0,0,.4);--shadow:0 4px 6px rgba(0,0,0,.4);--shadow-md:0 10px 15px rgba(0,0,0,.4);--shadow-lg:0 20px 25px rgba(0,0,0,.5);--login-gradient:linear-gradient(135deg,#2a2520 0%,#302b25 50%,#3a332b 100%);--login-bg-solid:#302b25;--primary:var(--primary-color);--success:var(--success-color);--error:var(--danger-color);--warning:var(--warning-color);--surface-primary:var(--card-bg);--surface-secondary:var(--bg-subtle);--text-secondary:var(--text-muted)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-color);background-color:var(--bg-color);line-height:1.5;overflow:hidden}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}input,select,textarea{font:inherit;color:inherit}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.desktop-shell{background:var(--desktop-bg);overscroll-behavior:none;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}.desktop-mode{overscroll-behavior:none;touch-action:manipulation;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}.shell-actions{align-items:center;gap:var(--space-xs);display:flex}.shell-nav-button{align-items:center;gap:var(--space-xs);border-radius:var(--radius-md);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast);display:flex}.shell-badge{border-radius:var(--radius-full);background:var(--danger-color);color:#fff;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.shell-action-button{min-width:34px;min-height:34px;padding:0 var(--space-2);justify-content:center}.module-switcher__trigger{padding:0}.shell-dropdown-menu{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:190px;box-shadow:var(--shadow-md);padding:var(--space-xs)0;display:none;overflow:hidden}.shell-dropdown-menu.is-open{display:block}.shell-dropdown-item{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-xs)var(--space-3);font-size:var(--text-sm);color:var(--text-color);text-align:left;transition:background var(--transition-fast),color var(--transition-fast);font-weight:500;display:flex}.shell-dropdown-item:hover{background:var(--bg-subtle)}.shell-dropdown-item.is-active{background:var(--primary-bg);color:var(--primary-color)}.shell-dropdown-divider{background:var(--border-color);height:1px;margin:var(--space-xs)0}.shell-icon-button{border-radius:var(--radius-sm);color:var(--text-muted);transition:background var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast);justify-content:center;align-items:center;display:flex}.shell-icon-button:hover:not(:disabled){background:var(--border-color);color:var(--text-color)}.shell-icon-button:disabled{opacity:.3;cursor:default}.shell-user-button{align-items:center;gap:var(--space-sm);padding:var(--space-xs)var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);display:flex}.desktop-menubar{height:var(--menubar-height);background:var(--card-bg);border-bottom:1px solid var(--border-color);color:var(--text-color);padding:0 var(--space-md);align-items:center;gap:var(--space-xs);z-index:9999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;display:flex}.desktop-menubar .menubar-scroll{align-items:center;gap:var(--space-xs);scrollbar-width:none;flex:0 auto;min-width:0;display:flex;overflow-x:auto;overflow-y:visible}.desktop-menubar .menubar-scroll::-webkit-scrollbar{display:none}.desktop-menubar .menubar-item{font-size:var(--text-sm);color:var(--text-color);white-space:nowrap;padding:4px 10px;font-weight:500;position:relative}.desktop-menubar .menubar-item:hover{background:var(--bg-subtle)}.desktop-menubar .menubar-item.is-active{background:var(--primary-bg);color:var(--primary-color)}.desktop-menubar .menubar-item .menubar-icon{flex-shrink:0;width:16px;height:16px}.desktop-menubar .menubar-item .menubar-badge{position:absolute;top:0;right:2px}.desktop-menubar .menubar-spacer{flex:1}.desktop-menubar .menubar-dropdown{position:relative}.desktop-menubar .menubar-dropdown .dropdown-menu{top:var(--menubar-height);z-index:10000;position:fixed;left:0}.desktop-menubar .menubar-dropdown .dropdown-menu .dropdown-item{text-wrap:nowrap}.desktop-menubar .menubar-user{color:var(--text-muted)}.desktop-menubar .menubar-user:hover{background:var(--bg-subtle);color:var(--text-color)}.desktop-workspace{background-color:var(--desktop-bg);flex:1;position:relative;overflow:hidden}.desktop-shortcuts{align-content:flex-start;gap:var(--space-lg);padding:var(--space-xl);pointer-events:none;flex-wrap:wrap;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.desktop-shortcuts .desktop-shortcut{pointer-events:auto;align-items:center;gap:var(--space-xs);width:88px;padding:var(--space-sm);font:inherit;color:inherit;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background:0 0;border:none;flex-direction:column;display:flex}.desktop-shortcuts .desktop-shortcut:hover{background:var(--desktop-shortcut-hover)}.desktop-shortcuts .desktop-shortcut:active{background:var(--desktop-shortcut-active)}.desktop-shortcuts .desktop-shortcut .shortcut-icon{border-radius:var(--radius-lg);background:var(--card-bg);width:46px;height:46px;box-shadow:var(--shadow-sm);color:var(--primary-color);justify-content:center;align-items:center;display:flex}.desktop-shortcuts .desktop-shortcut .shortcut-icon svg{width:22px;height:22px}.desktop-shortcuts .desktop-shortcut .shortcut-label{font-size:var(--text-xs);color:var(--text-color);text-align:center;word-break:break-word;font-weight:500;line-height:1.2}.desktop-window{background:var(--card-bg);border-radius:var(--window-border-radius);border:1px solid var(--border-color);transition:box-shadow var(--transition-fast),opacity var(--transition-fast);will-change:transform;flex-direction:column;display:flex;position:absolute;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.12)}.desktop-window.is-focused{border-color:var(--primary-color);box-shadow:0 16px 48px rgba(0,0,0,.22)}.desktop-window.is-dragging{opacity:.93;cursor:grabbing;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;transition:none}.desktop-window.is-dragging .window-content{pointer-events:none}.desktop-window.is-resizing{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;transition:none}.desktop-window.is-resizing .window-content{pointer-events:none}.desktop-window.is-minimized{opacity:0;pointer-events:none;transition:transform .2s,opacity .2s;transform:scale(.85)translateY(80px)}.desktop-window.is-maximized{border:none;border-radius:0;width:100%!important;height:100%!important;top:0!important;left:0!important}.desktop-window.is-maximized>.resize-handle{display:none}.desktop-window.is-closing{opacity:0;pointer-events:none;transition:transform .15s,opacity .15s;transform:scale(.96)}.window-header{height:var(--window-header-height);padding:0 var(--space-sm);background:var(--bg-subtle);border-bottom:1px solid var(--border-color);cursor:grab;align-items:center;gap:var(--space-xs);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;display:flex}.window-header:active{cursor:grabbing}.window-header .window-nav{gap:2px}.window-header .window-nav-btn{width:26px;height:26px;font-size:var(--text-sm)}.window-header .window-nav-btn svg{width:13px;height:13px}.window-header .window-title{font-size:var(--text-sm);color:var(--text-color);text-overflow:ellipsis;white-space:nowrap;padding:0 var(--space-sm);pointer-events:none;flex:1;font-weight:600;overflow:hidden}.window-header .window-controls{gap:2px}.window-header .window-control-btn{width:26px;height:26px;font-size:var(--text-sm)}.window-header .window-control-btn.control-close:hover{background:var(--danger-color);color:#fff}.window-header .window-control-btn svg{width:13px;height:13px}.window-content{background:var(--card-bg);flex:1;position:relative;overflow:auto;container:view-shell/inline-size}.window-content .window-loading{background:var(--card-bg);z-index:1;color:var(--text-muted);font-size:var(--text-sm);justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.window-content .window-loading.is-hidden{display:none}.resize-handle{z-index:10;position:absolute}.resize-handle[data-direction=n],.resize-handle[data-direction=s]{height:8px;left:8px;right:8px}.resize-handle[data-direction=e],.resize-handle[data-direction=w]{width:8px;top:8px;bottom:8px}.resize-handle[data-direction=n]{cursor:n-resize;top:-4px}.resize-handle[data-direction=s]{cursor:s-resize;bottom:-4px}.resize-handle[data-direction=e]{cursor:e-resize;right:-4px}.resize-handle[data-direction=w]{cursor:w-resize;left:-4px}.resize-handle[data-direction=ne],.resize-handle[data-direction=se],.resize-handle[data-direction=sw],.resize-handle[data-direction=nw]{width:16px;height:16px}.resize-handle[data-direction=ne]{cursor:ne-resize;top:-4px;right:-4px}.resize-handle[data-direction=se]{cursor:se-resize;bottom:-4px;right:-4px}.resize-handle[data-direction=sw]{cursor:sw-resize;bottom:-4px;left:-4px}.resize-handle[data-direction=nw]{cursor:nw-resize;top:-4px;left:-4px}.desktop-taskbar{height:var(--taskbar-height);background:var(--card-bg);border-top:1px solid var(--border-color);padding:0 var(--space-sm);z-index:9999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:3px;display:flex;overflow-x:auto}.desktop-taskbar::-webkit-scrollbar{display:none}.desktop-taskbar .taskbar-item{padding:4px var(--space-sm);font-size:var(--text-xs);color:var(--text-muted);border-radius:var(--radius-sm);white-space:nowrap;text-overflow:ellipsis;max-width:160px;transition:all var(--transition-fast);background:0 0;border:1px solid transparent;flex-shrink:0;font-weight:500;overflow:hidden}.desktop-taskbar .taskbar-item:hover{background:var(--bg-subtle);color:var(--text-color)}.desktop-taskbar .taskbar-item.is-focused{background:var(--primary-bg);color:var(--primary-color);border-color:var(--primary-light)}.desktop-taskbar .taskbar-item.is-minimized{opacity:.5}.desktop-taskbar .taskbar-item .taskbar-icon{width:var(--text-sm);height:var(--text-sm);flex-shrink:0}[data-theme=dark] .desktop-window.is-focused{box-shadow:0 16px 48px rgba(0,0,0,.6)}[data-theme=dark] .desktop-shortcuts .desktop-shortcut:hover{background:rgba(255,255,255,.08)}[data-theme=dark] .desktop-shortcuts .desktop-shortcut:active{background:rgba(255,255,255,.12)}@media (pointer:coarse){.window-nav-btn,.window-control-btn{width:44px!important;height:44px!important}.taskbar-item{min-height:44px;padding:8px 14px!important}}.sidebar-shell{background:var(--bg-color);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}@media (min-width:768px){.sidebar-shell{flex-direction:row}}.sidebar-topbar{height:var(--sidebar-header-height);padding:0 var(--space-sm);background:var(--card-bg);border-bottom:1px solid var(--border-color);color:var(--text-color);align-items:center;gap:var(--space-sm);z-index:101;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;display:flex}@media (min-width:768px){.sidebar-topbar{display:none}}.sidebar-topbar-actions{margin-left:auto}.sidebar-hamburger{border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-color);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.sidebar-hamburger:hover{background:var(--bg-subtle)}.sidebar-module-button{min-width:40px}.sidebar-module-button__label{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--border-color);z-index:100;transition:transform var(--transition-slow);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-direction:column;flex-shrink:0;display:flex}@media (max-width:767px){.sidebar{top:var(--sidebar-header-height);width:100%;max-width:var(--sidebar-width);box-shadow:var(--shadow-lg);position:fixed;bottom:0;left:0;transform:translate(-100%)}.sidebar.is-open{transform:translate(0)}}.sidebar .sidebar-header{height:var(--sidebar-header-height);padding:0 var(--space-md);background:var(--card-bg);border-bottom:1px solid var(--border-color);align-items:center;gap:var(--space-sm);display:flex}@media (max-width:767px){.sidebar .sidebar-header{display:none}}.sidebar .sidebar-header .sidebar-header-actions{align-items:center;gap:var(--space-xs);margin-left:auto;display:flex}.sidebar .sidebar-nav{padding:var(--space-sm)0;flex:1;overflow-y:auto}.sidebar .sidebar-nav .nav-section{padding:var(--space-sm)var(--space-md);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:700}.sidebar .sidebar-nav .nav-item{gap:var(--space-sm);padding:var(--space-sm)var(--space-md);margin:1px var(--space-xs);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-color);transition:all var(--transition-fast);font-weight:500;display:flex}.sidebar .sidebar-nav .nav-item:hover{background:var(--bg-subtle)}.sidebar .sidebar-nav .nav-item.is-active{background:var(--primary-bg);color:var(--primary-color);font-weight:600}.sidebar .sidebar-nav .nav-item .nav-icon{flex-shrink:0;width:18px;height:18px}.sidebar .sidebar-nav .nav-item .nav-badge{height:20px;padding:0 var(--space-xs);margin-left:auto}.sidebar .sidebar-footer{padding:var(--space-sm)var(--space-md);border-top:1px solid var(--border-color)}.sidebar .sidebar-footer .shell-user-button{justify-content:flex-start;width:100%}.sidebar .sidebar-footer .sidebar-user{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);display:flex}.sidebar .sidebar-footer .sidebar-user .user-name{font-size:var(--text-sm);font-weight:600}.sidebar .sidebar-footer .sidebar-user .user-role{font-size:var(--text-xs);color:var(--text-muted)}.sidebar .sidebar-footer .nav-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-muted);width:100%;transition:all var(--transition-fast);font-weight:500;display:flex}.sidebar .sidebar-footer .nav-item:hover{background:var(--danger-bg);color:var(--danger-color)}.sidebar-overlay{top:var(--sidebar-header-height);z-index:99;background:rgba(0,0,0,.45);position:fixed;bottom:0;left:0;right:0}@media (min-width:768px){.sidebar-overlay{display:none}}.sidebar-module-menu{z-index:200;position:fixed}.sidebar-module-menu__item{text-wrap:nowrap}.sidebar-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.sidebar-main .sidebar-content-area{flex:1;overflow-y:auto;container:view-shell/inline-size}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--text-color);font-weight:500}.form-input{width:100%;padding:var(--space-sm)var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--input-bg);font-size:var(--text-base);color:var(--text-color);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-input::-webkit-input-placeholder{color:var(--text-muted)}.form-input::-ms-input-placeholder{color:var(--text-muted)}.form-input::placeholder{color:var(--text-muted)}.form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:calc(var(--space-xs)*-.5)}.form-error{font-size:var(--text-xs);color:var(--danger-color)}.password-wrapper{align-items:center;display:flex;position:relative}.password-wrapper .form-input{padding-right:2.5rem}.password-wrapper .password-toggle{cursor:pointer;width:2.5rem;color:var(--text-muted);transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;right:0}.password-wrapper .password-toggle:hover{color:var(--text-color)}.btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:var(--text-inverse);border:none}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--bg-subtle);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--border-color)}.btn-danger{background:var(--danger-color);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-ghost{color:var(--text-color);background:0 0;border:none}.btn-ghost:hover:not(:disabled){background:var(--bg-subtle)}.btn-icon{padding:var(--space-sm);width:36px;height:36px}.btn-lg{padding:var(--space-3)var(--space-lg);font-size:var(--text-base)}.btn-sm{padding:var(--space-xs)var(--space-sm);font-size:var(--text-xs)}.login-container{background:var(--login-gradient);min-height:100vh;padding:var(--space-md);justify-content:center;align-items:center;display:flex}.preload-overlay{z-index:9999;background:var(--login-gradient);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.preload-spinner{border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.preload-message{color:rgba(255,255,255,.8);font-size:var(--text-base)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.import-indicator{align-items:center;gap:var(--space-xs);padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-xs);cursor:pointer;background:0 0;border:none;font-weight:600;transition:background .15s;display:flex}.import-indicator:hover{background:var(--surface-hover)}.import-indicator.is-processing{color:var(--info-color)}.import-indicator.is-processing svg{animation:1.5s infinite pulse}.import-indicator.is-completed{color:var(--success-color)}.import-indicator.is-failed{color:var(--error-color)}.btn-success{background:var(--success-color);color:#fff;border:none}.btn-success:hover:not(:disabled){-webkit-filter:brightness(.9);filter:brightness(.9)}.btn-outline{color:var(--primary-color);border:1px solid var(--primary-color);background:0 0}.btn-outline:hover:not(:disabled){background:var(--primary-bg)}.btn-warning{background:var(--warning-color);color:var(--text-inverse);border:none}.btn-warning:hover:not(:disabled){background:color-mix(in srgb,var(--warning-color)85%,black)}.btn-icon-sm{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-muted);transition:background var(--transition-fast),color var(--transition-fast);justify-content:center;align-items:center;padding:0;display:inline-flex}.btn-icon-sm:hover:not(:disabled){background:var(--border-color);color:var(--text-color)}.btn-icon-sm:disabled{opacity:.3;cursor:default}.btn-icon-sm.btn-remove:hover:not(:disabled){background:var(--danger-bg);color:var(--danger-color)}.btn-link{color:var(--primary-color);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.btn-link:hover:not(:disabled){color:var(--primary-hover)}.form-input-sm{padding:var(--space-xs)var(--space-sm);font-size:var(--text-sm)}.table-name{font-weight:500}.table-mono{font-family:var(--font-mono);font-size:var(--text-xs)}.table-actions{white-space:nowrap;text-align:right}.table-actions>*+*{margin-left:var(--space-xs)}.table-row--inactive{opacity:.5}.table-clickable-row:focus-visible{outline:2px solid var(--primary-color);outline-offset:-2px}.management-page{gap:var(--space-sm);height:100%;padding:var(--space-sm)var(--space-md);color:var(--text-color);flex-direction:column;display:flex;overflow:auto}.management-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);flex-wrap:wrap;display:flex}.management-header__body{gap:var(--space-xs);flex-direction:column;display:flex}.management-header__body p{color:var(--text-muted);font-size:var(--text-xs);margin:0}.management-actions{align-items:center;gap:var(--space-xs);flex-wrap:wrap;flex-shrink:0;margin-left:auto;display:flex}.management-toolbar{justify-content:space-between;align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.management-filters{gap:var(--space-sm);flex-wrap:wrap;align-items:flex-end;display:flex}.management-search-field{min-width:180px;max-width:280px}.management-filter-field{min-width:180px}.management-summary{gap:var(--space-xs);flex-wrap:wrap;align-items:center;display:flex}.management-summary__chip{border-radius:var(--radius-full);background:var(--bg-subtle);color:var(--text-muted);font-size:var(--text-xs);white-space:nowrap;padding:2px 10px}.table-clickable-row{cursor:pointer}.form-page{height:100%;padding:var(--space-2)var(--space-3);gap:var(--space-2);flex-direction:column;display:flex;overflow-y:auto}.form-page__header{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.form-page__card{gap:var(--space-md);flex-direction:column;max-width:600px;display:flex}.form-page__actions{gap:var(--space-2);flex-wrap:wrap;justify-content:flex-end;display:flex}.badge{border-radius:var(--radius-sm);font-size:var(--text-xs);white-space:nowrap;padding:2px 8px;font-weight:600;display:inline-block}.badge-success{background:color-mix(in srgb,var(--success-color)15%,transparent);color:var(--success-color)}.badge-danger{background:color-mix(in srgb,var(--danger-color)15%,transparent);color:var(--danger-color)}.badge-warning{background:color-mix(in srgb,var(--warning-color)15%,transparent);color:var(--warning-color)}.badge-info{background:color-mix(in srgb,var(--info-color,var(--primary-color))15%,transparent);color:var(--info-color,var(--primary-color))}.badge-muted{background:var(--bg-subtle);color:var(--text-muted)}.loading-state,.empty-state{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-xl)var(--space-md);text-align:center;color:var(--text-muted);font-size:var(--text-sm);flex-direction:column;display:flex}.loading-spinner{border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.form-error-banner{background:var(--danger-bg);color:var(--danger-color);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);border:1px solid var(--danger-color)}.has-modal-open{overflow:hidden!important}.modal-overlay{z-index:200;background:rgba(0,0,0,.4);justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.modal-panel{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:480px;max-height:90%;overflow-y:auto}.modal-panel--wide{max-width:720px}.modal-panel--lg{width:95%;max-width:900px;max-height:85%}.modal-header{padding:var(--space-3)var(--space-4);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-header h3,.modal-header h4{font-size:var(--text-base);color:var(--text-primary);margin:0;font-weight:600}.modal-body{padding:var(--space-4)}.modal-footer{justify-content:flex-end;gap:var(--space-2);padding:var(--space-3)var(--space-4);border-top:1px solid var(--border-color);display:flex}@media (max-width:480px){.management-page{padding:var(--space-xs);gap:var(--space-xs)}.management-header,.management-toolbar,.management-filters,.form-page__actions,.modal-footer{flex-direction:column;align-items:stretch}.management-search-field,.management-filter-field,.form-page__card{width:100%;min-width:0;max-width:100%}.modal-body,.modal-header,.modal-footer{padding-inline:var(--space-3)}}@container view-shell (width<=480px){.management-page{padding:var(--space-xs);gap:var(--space-xs)}.management-header,.management-toolbar,.management-filters,.form-page__actions,.modal-footer{flex-direction:column;align-items:stretch}.management-search-field,.management-filter-field,.form-page__card{width:100%;min-width:0;max-width:100%}.modal-body,.modal-header,.modal-footer{padding-inline:var(--space-3)}}.form-section-title{color:var(--text-primary,#333);border-bottom:1px solid var(--border-color,#eee);margin:24px 0 8px;padding-bottom:8px;font-size:1rem;font-weight:600}.checkbox-grid{gap:var(--space-md,12px)var(--space-xl,24px);flex-wrap:wrap;display:flex}.checkbox-item{align-items:center;gap:var(--space-xs,4px);cursor:pointer;font-size:var(--text-sm,.85rem);display:flex}.toast-container{top:var(--space-md);right:var(--space-md);z-index:99999;gap:var(--space-sm);pointer-events:none;flex-direction:column;max-width:380px;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);box-shadow:var(--shadow-md);pointer-events:auto;border-left:4px solid;line-height:1.3;animation:.25s ease-out toast-in;display:flex}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.toast-success{background:var(--success-bg);color:var(--success-color);border-left-color:var(--success-color)}.toast-error{background:var(--danger-bg);color:var(--danger-color);border-left-color:var(--danger-color)}.toast-warning{background:var(--warning-bg);color:var(--warning-color);border-left-color:var(--warning-color)}.toast-info{background:var(--info-bg);color:var(--info-color);border-left-color:var(--info-color)}.toast-icon{font-weight:700;font-size:var(--text-base);flex-shrink:0}.toast-message{color:var(--text-primary);flex:1}.toast-close{font-size:var(--text-sm);cursor:pointer;color:inherit;opacity:.5;background:0 0;border:none;flex-shrink:0;padding:0 2px}.toast-close:hover{opacity:1}.connection-indicator.svelte-11nalm8{align-items:center;gap:var(--space-xs);padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;display:inline-flex}.connection-indicator.is-centered.svelte-11nalm8{justify-content:center;width:100%}.connection-indicator[data-state=online].svelte-11nalm8{color:var(--success-color)}.connection-indicator[data-state=online].svelte-11nalm8 .indicator-dot:where(.svelte-11nalm8){background:var(--success-color)}.connection-indicator[data-state=offline].svelte-11nalm8{background:var(--warning-bg);color:var(--warning-color)}.connection-indicator[data-state=offline].svelte-11nalm8 .indicator-dot:where(.svelte-11nalm8){background:var(--warning-color)}.connection-indicator[data-state=connecting].svelte-11nalm8{color:var(--info-color)}.connection-indicator[data-state=connecting].svelte-11nalm8 .indicator-dot:where(.svelte-11nalm8){background:var(--info-color);animation:1.5s infinite svelte-11nalm8-connection-indicator-pulse}.indicator-dot.svelte-11nalm8{width:var(--space-sm);height:var(--space-sm);border-radius:var(--radius-full);flex-shrink:0}.indicator-text.svelte-11nalm8{white-space:nowrap}@media (max-width:767px){.indicator-text.is-mobile-hidden.svelte-11nalm8{display:none}}@keyframes svelte-11nalm8-connection-indicator-pulse{0%,to{opacity:1}50%{opacity:.3}}.login-page.svelte-nqxi0o{min-height:100vh;justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.login-bg-img.svelte-nqxi0o{object-fit:cover;z-index:0;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.login-overlay.svelte-nqxi0o{z-index:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:rgba(0,0,0,.4);position:absolute;top:0;bottom:0;left:0;right:0}.login-content.svelte-nqxi0o{z-index:2;padding:var(--space-4);justify-content:center;align-items:center;width:100%;display:flex;position:relative}.login-card.svelte-nqxi0o{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--radius-xl,16px);width:100%;max-width:400px;padding:var(--space-5,2.5rem)var(--space-4);text-align:center;background:rgba(255,255,255,.92);box-shadow:0 8px 32px rgba(0,0,0,.25)}[data-theme=dark] .login-card.svelte-nqxi0o{background:rgba(30,30,30,.88);box-shadow:0 8px 32px rgba(0,0,0,.5)}.login-logo.svelte-nqxi0o{margin-bottom:var(--space-2);color:var(--primary-color);justify-content:center;display:flex}.login-title.svelte-nqxi0o{font-size:var(--text-xl,1.5rem);color:var(--text-primary);margin:0;font-weight:700}.login-subtitle.svelte-nqxi0o{margin:var(--space-1)0 var(--space-4);font-size:var(--text-sm);color:var(--text-secondary)}.login-submit-btn.svelte-nqxi0o{width:100%;margin-top:var(--space-3)}.help-button.svelte-s8xqfw{border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);cursor:pointer;justify-content:center;align-items:center;display:flex}.help-button.svelte-s8xqfw svg:where(.svelte-s8xqfw){width:16px;height:16px}.help-modal-overlay.svelte-s8xqfw{z-index:9999;background:rgba(0,0,0,.4);justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.help-modal.svelte-s8xqfw{width:90%;max-width:520px}.help-description.svelte-s8xqfw{color:var(--text-muted);font-size:var(--text-sm);margin:0 0 var(--space-md)0}.help-instructions.svelte-s8xqfw h4:where(.svelte-s8xqfw){font-size:var(--text-sm);margin:0 0 var(--space-xs)0;color:var(--text-primary);font-weight:600}.help-instructions.svelte-s8xqfw p:where(.svelte-s8xqfw){font-size:var(--text-sm);color:var(--text-color);margin:0;line-height:1.6}