.window{background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 12px #00000026;overflow:hidden;-webkit-user-select:none;user-select:none}.window-titlebar{background:#f0f0f0;border-bottom:1px solid #ccc;padding:4px 8px;display:flex;align-items:center;justify-content:space-between;height:32px;flex-shrink:0}.window-title{flex:1;font-weight:500;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.window-controls{display:flex;gap:4px;margin-left:8px}.window-control{width:24px;height:24px;border:none;background:transparent;cursor:pointer;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;padding:0}.window-control:hover{background:#0000001a}.window-control.close:hover{background:#e81123;color:#fff}.window-content{background:#fff;overflow:auto}.resize-handle{position:absolute;background:transparent}.resize-n{top:0;left:4px;right:4px;height:4px;cursor:ns-resize}.resize-s{bottom:0;left:4px;right:4px;height:4px;cursor:ns-resize}.resize-e{top:4px;right:0;bottom:4px;width:4px;cursor:ew-resize}.resize-w{top:4px;left:0;bottom:4px;width:4px;cursor:ew-resize}.resize-ne{top:0;right:0;width:8px;height:8px;cursor:nesw-resize}.resize-nw{top:0;left:0;width:8px;height:8px;cursor:nwse-resize}.resize-se{bottom:0;right:0;width:8px;height:8px;cursor:nwse-resize}.resize-sw{bottom:0;left:0;width:8px;height:8px;cursor:nesw-resize}.workspace{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;background:#f5f5f5}.workspace-overview{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.workspace-overview-content{background:#fff;border-radius:8px;padding:24px;max-width:90vw;max-height:90vh;overflow:auto;box-shadow:0 8px 32px #0000004d}.workspace-overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.workspace-overview-header h2{margin:0;font-size:24px}.workspace-overview-close{width:32px;height:32px;border:none;background:transparent;font-size:24px;cursor:pointer;border-radius:4px}.workspace-overview-close:hover{background:#0000001a}.workspace-overview-grid{display:grid;gap:16px;min-width:600px;min-height:400px}.workspace-overview-item{background:#f5f5f5;border:2px solid #ddd;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}.workspace-overview-item:hover{border-color:#0078d4;transform:scale(1.02)}.workspace-overview-item.active{border-color:#0078d4;background:#e3f2fd}.workspace-overview-item-label{font-weight:600;margin-bottom:8px;font-size:16px}.workspace-overview-item-preview{flex:1;display:flex;align-items:center;justify-content:center;min-height:120px}.workspace-overview-empty{color:#999;font-style:italic}.workspace-overview-windows{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;width:100%}.workspace-overview-window-thumbnail{background:#fff;border:1px solid #ddd;border-radius:4px;padding:8px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace-overview-more{grid-column:1 / -1;text-align:center;color:#666;font-size:12px;padding:4px}.shortcut-context-menu{background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 8px #00000026;min-width:200px;max-width:300px;max-height:400px;overflow-y:auto;z-index:99999!important;font-size:14px;pointer-events:auto;visibility:visible;opacity:1}.shortcut-context-menu-header{padding:8px 12px;font-weight:700;border-bottom:1px solid #eee;background:#f5f5f5}.shortcut-context-menu-section{padding:4px 0}.shortcut-context-menu-section-title{padding:4px 12px;font-size:11px;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:.5px}.shortcut-context-menu-item{display:flex;align-items:center;width:100%;padding:6px 12px;border:none;background:none;text-align:left;cursor:pointer;font-size:14px;color:#333}.shortcut-context-menu-item:hover{background:#e8f4f8}.shortcut-context-menu-item-icon{margin-right:8px;width:16px;text-align:center}.shortcut-context-menu-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shortcut-context-menu-divider{height:1px;background:#eee;margin:4px 0}.taskbar-shortcuts{display:flex;align-items:center;gap:4px;padding:0 8px}.taskbar-shortcut{width:40px;height:40px;border:none;background:transparent;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.taskbar-shortcut:hover{background:#ffffff1a}.taskbar-shortcut-icon{width:24px;height:24px}.taskbar-shortcut-icon-placeholder{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#0078d4;color:#fff;border-radius:4px;font-size:12px;font-weight:600}.taskbar-search{position:relative;flex:1;max-width:400px;margin:0 16px}.taskbar-search-input{width:100%;padding:8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#ffffff1a;color:#fff;font-size:14px;outline:none}.taskbar-search-input::placeholder{color:#fff9}.taskbar-search-input:focus{background:#ffffff26;border-color:#ffffff4d}.taskbar-search-results{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:400px;overflow-y:auto;z-index:1000}.taskbar-search-result{display:flex;align-items:center;gap:12px;padding:12px;border:none;background:transparent;cursor:pointer;width:100%;text-align:left;transition:background .2s}.taskbar-search-result:hover{background:#f5f5f5}.taskbar-search-result-icon{width:32px;height:32px;flex-shrink:0}.taskbar-search-result-info{flex:1;min-width:0}.taskbar-search-result-name{font-weight:500;font-size:14px;margin-bottom:2px}.taskbar-search-result-desc{font-size:12px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.taskbar-button{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;background:transparent;cursor:pointer;border-radius:4px;min-width:120px;max-width:200px;transition:background .2s}.taskbar-button:hover{background:#ffffff1a}.taskbar-button.focused{background:#fff3;border-bottom:2px solid #0078d4}.taskbar-button.minimized{opacity:.6}.taskbar-button-icon{width:20px;height:20px;flex-shrink:0;border-radius:4px;object-fit:contain;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;transition:transform .15s ease,filter .15s ease;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.taskbar-button:hover .taskbar-button-icon{transform:scale(1.05);filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.taskbar-button.focused .taskbar-button-icon{transform:scale(1.08);filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}.taskbar-button.minimized .taskbar-button-icon{opacity:.7;filter:grayscale(.3) drop-shadow(0 1px 2px rgba(0,0,0,.1))}.taskbar-button-icon-placeholder{width:20px;height:20px;min-width:20px;min-height:20px;display:flex;align-items:center;justify-content:center;color:#fff;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0;box-shadow:0 1px 3px #0003,inset 0 1px #fff3;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:transform .15s ease,box-shadow .15s ease}.taskbar-button:hover .taskbar-button-icon-placeholder{transform:scale(1.05);box-shadow:0 2px 4px #00000040,inset 0 1px #ffffff4d}.taskbar-button.focused .taskbar-button-icon-placeholder{box-shadow:0 2px 6px #0000004d,inset 0 1px #ffffff4d;transform:scale(1.08)}.taskbar-button.minimized .taskbar-button-icon-placeholder{opacity:.7;filter:grayscale(.2)}.taskbar-button-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.workspace-overview-button{width:40px;height:40px;border:none;background:transparent;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s;padding:0}.workspace-overview-button:hover{background:#ffffff1a}.workspace-overview-button-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:2px;width:20px;height:20px}.workspace-overview-button-dot{width:4px;height:4px;background:#fffc;border-radius:50%}.workspace-overview-button:hover .workspace-overview-button-dot{background:#fff}.notification-item{display:flex;gap:12px;padding:12px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:8px}.notification-item:hover{background:#f5f5f5;box-shadow:0 2px 4px #0000001a}.notification-item-priority-low{border-left:3px solid #2196f3}.notification-item-priority-normal{border-left:3px solid #4caf50}.notification-item-priority-high{border-left:3px solid #ff9800}.notification-item-priority-urgent{border-left:3px solid #f44336}.notification-item-status-read{opacity:.7}.notification-item-status-dismissed{display:none}.notification-item-icon{flex-shrink:0;width:40px;height:40px;border-radius:8px;overflow:hidden;background:#f0f0f0}.notification-item-icon img{width:100%;height:100%;object-fit:cover}.notification-item-content{flex:1;min-width:0}.notification-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}.notification-item-title{font-weight:600;font-size:14px;color:#333;margin-right:8px}.notification-item-dismiss{flex-shrink:0;background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.notification-item-dismiss:hover{background:#e0e0e0;color:#333}.notification-item-message{font-size:13px;color:#666;margin-bottom:8px;line-height:1.4}.notification-item-footer{display:flex;justify-content:space-between;align-items:center;gap:8px}.notification-item-timestamp{font-size:11px;color:#999}.notification-item-actions{display:flex;gap:4px}.notification-item-action-button{padding:4px 12px;font-size:12px;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.notification-item-action-button:hover{background:#1976d2}.notification-center{position:fixed;top:0;right:0;width:400px;max-width:90vw;height:100vh;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:-4px 0 16px #0003;display:flex;flex-direction:column;z-index:10002;overflow:hidden;animation:notification-center-slide-in .35s cubic-bezier(.16,1,.3,1);border-left:1px solid rgba(255,255,255,.2)}@keyframes notification-center-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-center-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.notification-center-title{font-size:20px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.notification-center-unread-count{background:#f44336;color:#fff;font-size:12px;font-weight:600;padding:2px 8px;border-radius:12px;min-width:20px;text-align:center}.notification-center-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.notification-center-close:hover{background:#f0f0f0;color:#333}.notification-center-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid #e0e0e0;gap:12px;flex-shrink:0}.notification-center-filters{display:flex;gap:4px}.notification-center-filter{padding:6px 12px;font-size:13px;background:#f5f5f5;color:#666;border:none;border-radius:6px;cursor:pointer;transition:all .2s;position:relative}.notification-center-filter:hover{background:#e0e0e0}.notification-center-filter.active{background:#2196f3;color:#fff}.notification-center-filter-badge{margin-left:4px;background:#ffffff4d;padding:1px 6px;border-radius:10px;font-size:11px}.notification-center-actions{display:flex;gap:8px}.notification-center-action-button{padding:6px 12px;font-size:12px;background:#f5f5f5;color:#333;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.notification-center-action-button:hover{background:#e0e0e0}.notification-center-search{padding:12px 20px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.notification-center-search-input{width:100%;padding:8px 12px;font-size:14px;border:1px solid #e0e0e0;border-radius:6px;outline:none;transition:border-color .2s}.notification-center-search-input:focus{border-color:#2196f3}.notification-center-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 20px;min-height:0}.notification-center-list{display:flex;flex-direction:column}.notification-center-empty{text-align:center;padding:40px 20px;color:#999;font-size:14px}.notification-center-content::-webkit-scrollbar{width:8px}.notification-center-content::-webkit-scrollbar-track{background:#f5f5f5}.notification-center-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.notification-center-content::-webkit-scrollbar-thumb:hover{background:#999}.notification-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.notification-badge-count{min-width:18px;height:18px;padding:0 6px;background:#f44336;color:#fff;font-size:11px;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center;animation:notification-badge-pulse .3s ease-out}.notification-badge-dot{width:8px;height:8px;background:#f44336;border-radius:50%;animation:notification-badge-pulse .3s ease-out}@keyframes notification-badge-pulse{0%{transform:scale(.8);opacity:.8}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.notification-toast-container{position:fixed;z-index:10001;display:flex;flex-direction:column;gap:8px;pointer-events:none}.notification-toast-top-right{top:16px;right:16px;align-items:flex-end}.notification-toast-top-left{top:16px;left:16px;align-items:flex-start}.notification-toast-bottom-right{bottom:80px;right:16px;align-items:flex-end;flex-direction:column-reverse}.notification-toast-bottom-left{bottom:80px;left:16px;align-items:flex-start;flex-direction:column-reverse}.notification-toast-item{pointer-events:auto;max-width:400px;min-width:300px}@keyframes notification-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-toast-top-left .notification-toast-item{animation-name:notification-toast-slide-in-left}@keyframes notification-toast-slide-in-left{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-toast-bottom-right .notification-toast-item,.notification-toast-bottom-left .notification-toast-item{animation-name:notification-toast-slide-in-bottom}@keyframes notification-toast-slide-in-bottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.notification-settings{background:#fff;border-radius:8px;padding:20px;max-width:500px}.notification-settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.notification-settings-title{font-size:20px;font-weight:600;color:#333;margin:0}.notification-settings-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.notification-settings-close:hover{background:#f0f0f0;color:#333}.notification-settings-content{display:flex;flex-direction:column;gap:24px}.notification-settings-section{display:flex;flex-direction:column;gap:12px}.notification-settings-section-title{font-size:16px;font-weight:600;color:#333;margin:0}.notification-settings-item{display:flex;flex-direction:column;gap:4px}.notification-settings-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.notification-settings-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.notification-settings-select,.notification-settings-input{padding:6px 12px;font-size:14px;border:1px solid #e0e0e0;border-radius:4px;outline:none;transition:border-color .2s}.notification-settings-select:focus,.notification-settings-input:focus{border-color:#2196f3}.notification-settings-input{width:100px}.taskbar-notification-button{position:relative;width:40px;height:40px;background:transparent;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s;margin-left:4px}.taskbar-notification-button:hover{background:#ffffff1a}.taskbar-notification-icon{width:16px;height:16px;color:#ffffffe6;flex-shrink:0}.taskbar-notification-button .notification-badge{position:absolute;top:6px;right:6px}.taskbar{position:fixed;bottom:0;left:0;right:0;height:48px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;padding:0 8px;z-index:1000;border-top:1px solid rgba(255,255,255,.1)}.taskbar-windows{display:flex;align-items:center;gap:4px;flex:1;overflow-x:auto;overflow-y:hidden}.taskbar-windows::-webkit-scrollbar{height:2px}.taskbar-windows::-webkit-scrollbar-track{background:transparent}.taskbar-windows::-webkit-scrollbar-thumb{background:#fff3;border-radius:1px}.browser{display:flex;flex-direction:column;width:100%;height:100%;background:#f5f5f5}.browser-toolbar{display:flex;align-items:center;gap:8px;padding:8px;background:#fff;border-bottom:1px solid #ddd;flex-shrink:0}.browser-nav-buttons{display:flex;gap:4px}.browser-nav-button{width:32px;height:32px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;padding:0}.browser-nav-button:hover:not(:disabled){background:#f0f0f0}.browser-nav-button:disabled{opacity:.5;cursor:not-allowed}.browser-url-bar{flex:1;display:flex;gap:4px}.browser-url-input{flex:1;padding:6px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;outline:none}.browser-url-input:focus{border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.browser-go-button{padding:6px 16px;border:1px solid #0066cc;background:#06c;color:#fff;border-radius:4px;cursor:pointer;font-size:14px}.browser-go-button:hover{background:#0052a3}.browser-content{flex:1;overflow:hidden;position:relative}.browser-iframe{width:100%;height:100%;border:none;background:#fff}.browser-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:#666}.browser-loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #0066cc;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.browser-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:48px 32px;text-align:center;background:linear-gradient(135deg,#f5f7fa,#fff);color:#333}.browser-error-icon{margin-bottom:24px;color:#ff6b6b;opacity:.9}.browser-error-icon svg{filter:drop-shadow(0 2px 4px rgba(255,107,107,.2))}.browser-error-title{margin:0 0 16px;font-size:28px;font-weight:600;color:#2d3748;letter-spacing:-.5px}.browser-error-message{margin:0 0 32px;max-width:560px;font-size:15px;line-height:1.6;color:#4a5568}.browser-error-suggestion{display:flex;align-items:flex-start;gap:12px;margin-bottom:32px;padding:16px 20px;background:#fff9e6;border:1px solid #ffe066;border-radius:8px;max-width:560px;text-align:left;color:#856404}.browser-error-suggestion svg{flex-shrink:0;margin-top:2px;color:#f59e0b}.browser-error-suggestion strong{display:block;margin-bottom:4px;color:#92400e;font-weight:600}.browser-error-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.browser-open-external,.browser-retry-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.browser-open-external{background:linear-gradient(135deg,#06c,#0052a3);color:#fff}.browser-open-external:hover{background:linear-gradient(135deg,#0052a3,#003d7a);box-shadow:0 4px 8px #0066cc4d;transform:translateY(-1px)}.browser-open-external:active{transform:translateY(0);box-shadow:0 2px 4px #06c3}.browser-retry-button{background:#fff;color:#4a5568;border:1px solid #e2e8f0}.browser-retry-button:hover{background:#f7fafc;border-color:#cbd5e0;box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.browser-retry-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000000d}.browser-open-external svg,.browser-retry-button svg{flex-shrink:0}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{-webkit-user-select:text;user-select:text;white-space:pre}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.terminal{width:100%;height:100%;padding:8px;background:#1e1e1e}.terminal .xterm{width:100%;height:100%}.terminal .xterm-viewport,.terminal .xterm-screen{background-color:#1e1e1e}.dialog-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;min-width:500px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.menubar{display:flex;align-items:center;background:#f0f0f0;border-bottom:1px solid #d0d0d0;padding:0;height:28px;font-size:13px;-webkit-user-select:none;user-select:none}.menubar-button{background:none;border:none;padding:4px 12px;cursor:pointer;font-size:13px;color:#333;height:28px;display:flex;align-items:center;transition:background-color .15s}.menubar-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #c0c0c0;box-shadow:0 2px 8px #00000026;min-width:180px;z-index:1000;padding:4px 0}.menubar-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 20px;background:none;border:none;text-align:left;cursor:pointer;font-size:13px;color:#333;transition:background-color .15s}.menubar-menu-item:hover{background:#e8f4fd}.menubar-menu-item:disabled{color:#999;cursor:not-allowed}.menubar-menu-item:disabled:hover{background:none}.menubar-shortcut{color:#999;font-size:11px;margin-left:20px}.notepad{display:flex;flex-direction:column;width:100%;height:100%;background:#fff;overflow:hidden}.notepad-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#666}.notepad-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.notepad-textarea{flex:1;width:100%;border:none;outline:none;padding:12px;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.6;resize:none;color:#333;background:#fff;overflow-y:auto;white-space:pre;overflow-x:auto}.notepad-textarea-wrap{white-space:pre-wrap;word-wrap:break-word;overflow-x:hidden}.notepad-textarea::placeholder{color:#999}.notepad-textarea:focus{outline:none}.file-dialog{display:flex;flex-direction:column;min-height:400px;max-height:600px}.file-dialog-browser{flex:1;display:flex;flex-direction:column;border:1px solid #d0d0d0;border-radius:4px;overflow:hidden;margin-bottom:16px}.file-dialog-path{display:flex;align-items:center;padding:8px 12px;background:#f5f5f5;border-bottom:1px solid #d0d0d0;gap:8px}.file-dialog-nav{background:#fff;border:1px solid #c0c0c0;border-radius:3px;padding:4px 8px;cursor:pointer;font-size:12px;color:#333;transition:background-color .15s}.file-dialog-nav:hover:not(:disabled){background:#e8f4fd}.file-dialog-nav:disabled{opacity:.5;cursor:not-allowed}.file-dialog-current-path{flex:1;font-size:12px;color:#666;font-family:monospace}.file-dialog-list{flex:1;overflow-y:auto;padding:4px;background:#fff}.file-dialog-loading,.file-dialog-empty{padding:20px;text-align:center;color:#999;font-size:14px}.file-dialog-item{display:flex;align-items:center;padding:6px 8px;cursor:pointer;border-radius:3px;transition:background-color .15s;gap:8px}.file-dialog-item:hover{background:#f0f0f0}.file-dialog-item.selected{background:#e8f4fd;color:#06c}.file-dialog-item.directory{font-weight:500}.file-dialog-icon{font-size:16px;width:20px;text-align:center}.file-dialog-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-dialog-input{margin-bottom:12px}.file-dialog-input label{display:block;margin-bottom:4px;font-size:13px;color:#333;font-weight:500}.file-dialog-input input{width:100%;padding:6px 8px;border:1px solid #c0c0c0;border-radius:3px;font-size:13px;font-family:monospace}.file-dialog-input input:focus{outline:none;border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.file-dialog-error{padding:8px 12px;background:#fee;border:1px solid #fcc;border-radius:3px;color:#c00;font-size:12px;margin-bottom:12px}.file-dialog-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:12px;border-top:1px solid #e0e0e0}.file-dialog-actions button{padding:6px 16px;border:1px solid #c0c0c0;border-radius:3px;background:#fff;cursor:pointer;font-size:13px;color:#333;transition:background-color .15s}.file-dialog-actions button:hover:not(:disabled){background:#f5f5f5}.file-dialog-actions button.primary{background:#06c;color:#fff;border-color:#06c}.file-dialog-actions button.primary:hover:not(:disabled){background:#0052a3}.file-dialog-actions button:disabled{opacity:.5;cursor:not-allowed}.file-browser-toolbar{display:flex;align-items:center;gap:8px;padding:8px;background:#f5f5f5;border-bottom:1px solid #d0d0d0;flex-shrink:0}.toolbar-nav-buttons{display:flex;gap:4px}.toolbar-button{width:32px;height:32px;border:1px solid #c0c0c0;background:#fff;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;padding:0;transition:background-color .15s}.toolbar-button:hover:not(:disabled){background:#e8f4fd}.toolbar-button:disabled{opacity:.5;cursor:not-allowed}.toolbar-path{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.toolbar-breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:2px;font-size:13px;overflow:hidden}.toolbar-breadcrumb{background:none;border:none;padding:4px 6px;cursor:pointer;color:#06c;font-size:13px;border-radius:3px;transition:background-color .15s;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toolbar-breadcrumb:hover{background:#e8f4fd}.toolbar-separator{color:#999;margin:0 2px}.toolbar-path-input{flex:1;padding:6px 8px;border:1px solid #c0c0c0;border-radius:4px;font-size:13px;font-family:monospace;min-width:0}.toolbar-path-input:focus{outline:none;border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.toolbar-actions{display:flex;align-items:center;gap:8px}.toolbar-search{padding:6px 8px;border:1px solid #c0c0c0;border-radius:4px;font-size:13px;width:200px}.toolbar-search:focus{outline:none;border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.toolbar-view-controls{display:flex;align-items:center;gap:8px}.toolbar-view-toggle{display:flex;gap:0;border:1px solid #c0c0c0;border-radius:4px;overflow:hidden;background:#fff}.toolbar-view-button{width:32px;height:32px;border:none;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;padding:0;transition:background-color .15s;border-right:1px solid #c0c0c0}.toolbar-view-button:last-child{border-right:none}.toolbar-view-button:hover{background:#e8f4fd}.toolbar-view-button.active{background:#06c;color:#fff}.toolbar-scale-control{display:flex;align-items:center;gap:6px}.toolbar-scale-label{font-size:12px;color:#666}.toolbar-scale-slider{width:100px;height:4px}.toolbar-scale-value{font-size:12px;color:#666;min-width:35px;text-align:right}.file-list{flex:1;overflow-y:auto;background:#fff}.file-list.list-view{padding:8px}.file-list-item{display:flex;align-items:center;padding:8px;cursor:pointer;border-radius:4px;gap:8px;transition:background-color .15s}.file-list-item:hover{background:#f0f0f0}.file-list-item.selected{background:#e8f4fd;color:#06c}.file-list-icon{font-size:20px;width:24px;text-align:center}.file-list-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-list-table{width:100%;border-collapse:collapse;font-size:13px}.file-list-header{padding:8px 12px;text-align:left;background:#f5f5f5;border-bottom:2px solid #d0d0d0;font-weight:600;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none;position:sticky;top:0;z-index:10;transition:background-color .15s}.file-list-header:hover{background:#e8e8e8}.file-list-header.active{background:#e0e0e0;color:#06c}.sort-indicator{margin-left:4px;font-size:12px}.file-list-row{cursor:pointer;transition:background-color .15s}.file-list-row:hover{background:#f5f5f5}.file-list-row.selected{background:#e8f4fd}.file-list-row.selected .file-list-name{color:#06c;font-weight:500}.file-list-cell{padding:8px 12px;border-bottom:1px solid #e8e8e8}.file-list-cell.name{display:flex;align-items:center;gap:8px;min-width:200px}.file-list-cell.size{width:100px;text-align:right;font-family:monospace;color:#666}.file-list-cell.modified{width:180px;color:#666}.file-list-cell.type{width:120px;color:#666}.file-list.tile-view{position:relative;padding:16px;min-height:100%}.file-list-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;border:2px solid transparent;border-radius:8px;background:#fff;cursor:move;transition:all .2s;-webkit-user-select:none;user-select:none}.file-list-tile:hover{background:#f5f5f5;border-color:silver}.file-list-tile.selected{background:#e8f4fd;border-color:#06c}.file-list-tile.dragging{opacity:.8;box-shadow:0 4px 12px #0003}.file-list-tile-icon{font-size:32px;margin-bottom:4px;text-align:center}.file-list-tile-name{font-size:11px;text-align:center;word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;line-height:1.2}.context-menu{position:fixed;background:#fff;border:1px solid #c0c0c0;box-shadow:0 2px 8px #00000026;border-radius:4px;padding:4px 0;min-width:180px;z-index:10001}.context-menu-item{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;cursor:pointer;font-size:13px;color:#333;transition:background-color .15s}.context-menu-item:hover{background:#e8f4fd}.context-menu-item:disabled{color:#999;cursor:not-allowed}.context-menu-item:disabled:hover{background:none}.context-menu-separator{height:1px;background:#e0e0e0;margin:4px 0}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.dialog-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;min-width:400px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0;background:#f5f5f5}.dialog-title{margin:0;font-size:18px;font-weight:600;color:#333}.dialog-close{background:none;border:none;font-size:24px;line-height:1;color:#666;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.dialog-close:hover{background:#e0e0e0;color:#333}.dialog-content{padding:20px;overflow-y:auto;flex:1}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:1px solid #e0e0e0;margin-top:16px}.dialog-actions button{padding:8px 16px;border:1px solid #c0c0c0;border-radius:4px;background:#fff;cursor:pointer;font-size:13px;color:#333;transition:background-color .15s}.dialog-actions button:hover:not(:disabled){background:#f5f5f5}.dialog-actions button.primary{background:#06c;color:#fff;border-color:#06c}.dialog-actions button.primary:hover:not(:disabled){background:#0052a3}.dialog-actions button:disabled{opacity:.5;cursor:not-allowed}.dialog-input{margin-bottom:16px}.dialog-input label{display:block;margin-bottom:4px;font-size:13px;color:#333;font-weight:500}.dialog-input input{width:100%;padding:8px;border:1px solid #c0c0c0;border-radius:4px;font-size:13px}.dialog-input input:focus{outline:none;border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.dialog-message{margin-bottom:16px;color:#333;font-size:14px}.dialog-error{padding:8px 12px;background:#fee;border:1px solid #fcc;border-radius:4px;color:#c00;font-size:12px;margin-bottom:16px}.file-browser{display:flex;flex-direction:column;width:100%;height:100%;background:#fff;overflow:hidden}.file-browser-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#666}.file-browser-loading-content{display:flex;align-items:center;justify-content:center;padding:40px;color:#666}.file-browser-error{padding:12px 16px;background:#fee;border-bottom:1px solid #fcc;color:#c00;font-size:13px}.settings-sidebar{width:200px;background:#f5f5f5;border-right:1px solid #d0d0d0;display:flex;flex-direction:column;flex-shrink:0}.settings-sidebar-header{padding:16px;border-bottom:1px solid #d0d0d0}.settings-sidebar-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.settings-sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.settings-sidebar-item{display:flex;align-items:center;width:100%;padding:12px 16px;background:none;border:none;text-align:left;cursor:pointer;color:#333;font-size:14px;transition:background-color .15s;gap:12px}.settings-sidebar-item:hover{background:#e8e8e8}.settings-sidebar-item.active{background:#e8f4fd;color:#06c;font-weight:500}.settings-sidebar-icon{font-size:18px;width:24px;text-align:center}.settings-sidebar-label{flex:1}.settings{display:flex;height:100%;width:100%;overflow:hidden}.settings-loading{display:flex;align-items:center;justify-content:center;height:100%;width:100%;font-size:16px;color:#666}.settings-content{flex:1;overflow-y:auto;padding:24px;background:#fff}.settings-error{background:#fee;border:1px solid #fcc;color:#c00;padding:12px;border-radius:4px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.settings-panel{max-width:800px}.settings-panel-title{margin:0 0 24px;font-size:24px;font-weight:600;color:#333}.settings-panel-loading{padding:40px;text-align:center;color:#666}.settings-form{display:flex;flex-direction:column;gap:16px}.settings-form-group{display:flex;flex-direction:column;gap:8px}.settings-form-group label{font-weight:500;color:#333;font-size:14px}.settings-form-group input,.settings-form-group select,.settings-form-group textarea{padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;font-family:inherit}.settings-form-group input:focus,.settings-form-group select:focus,.settings-form-group textarea:focus{outline:none;border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.settings-form-group textarea{resize:vertical;min-height:80px}.settings-form-hint{font-size:12px;color:#666;margin-top:-4px}.settings-form-error{background:#fee;border:1px solid #fcc;color:#c00;padding:12px;border-radius:4px;font-size:14px}.settings-form-success{background:#efe;border:1px solid #cfc;color:#0c0;padding:12px;border-radius:4px;font-size:14px}.settings-form-actions{display:flex;gap:8px;margin-top:8px}.settings-button{padding:8px 16px;border:1px solid #ccc;border-radius:4px;background:#fff;color:#333;font-size:14px;cursor:pointer;transition:all .15s}.settings-button:hover:not(:disabled){background:#f5f5f5;border-color:#999}.settings-button:disabled{opacity:.5;cursor:not-allowed}.settings-button.primary{background:#06c;color:#fff;border-color:#06c}.settings-button.primary:hover:not(:disabled){background:#0052a3;border-color:#0052a3}.settings-button-small{padding:4px 8px;border:1px solid #ccc;border-radius:3px;background:#fff;color:#333;font-size:12px;cursor:pointer;transition:all .15s;margin-right:4px}.settings-button-small:hover:not(:disabled){background:#f5f5f5;border-color:#999}.settings-button-small:disabled{opacity:.5;cursor:not-allowed}.users-table,.mounts-table,.apps-table{width:100%;border-collapse:collapse;margin-top:16px}.users-table th,.mounts-table th,.apps-table th{background:#f5f5f5;padding:12px;text-align:left;font-weight:600;font-size:14px;border-bottom:2px solid #ddd}.users-table td,.mounts-table td,.apps-table td{padding:12px;border-bottom:1px solid #eee;font-size:14px}.users-table tr:hover,.mounts-table tr:hover,.apps-table tr:hover{background:#f9f9f9}.users-table code,.mounts-table code{font-family:monospace;font-size:12px;background:#f5f5f5;padding:2px 6px;border-radius:3px}.users-list,.mounts-list,.apps-list{margin-top:16px}.users-list-header,.mounts-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.users-list-header h4,.mounts-list-header h4{margin:0;font-size:18px;font-weight:600}.users-list-empty,.mounts-list-empty,.apps-list-empty{padding:40px;text-align:center;color:#666;font-style:italic}.user-form,.mount-form{background:#f9f9f9;padding:20px;border-radius:4px;border:1px solid #ddd}.user-form h4,.mount-form h4{margin:0 0 16px;font-size:18px;font-weight:600}.json-editor{display:flex;flex-direction:column;gap:8px}.json-editor-toolbar{display:flex;gap:8px}.json-editor-textarea{width:100%;min-height:300px;padding:12px;border:1px solid #ccc;border-radius:4px;font-family:Courier New,monospace;font-size:13px;line-height:1.5;resize:vertical}.json-editor-textarea.error{border-color:#c00;background:#fee}.json-editor-textarea:focus{outline:none;border-color:#06c;box-shadow:0 0 0 2px #0066cc1a}.json-editor-error{background:#fee;border:1px solid #fcc;color:#c00;padding:8px 12px;border-radius:4px;font-size:13px;font-family:monospace}.other-settings{display:flex;gap:16px;height:calc(100vh - 200px)}.other-settings-browser{width:300px;border:1px solid #ddd;border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.other-settings-path{padding:12px;background:#f5f5f5;border-bottom:1px solid #ddd;display:flex;align-items:center;gap:8px}.other-settings-current-path{flex:1;font-family:monospace;font-size:13px;color:#333}.other-settings-list{flex:1;overflow-y:auto}.other-settings-loading,.other-settings-empty{padding:40px;text-align:center;color:#666}.other-settings-item{display:flex;align-items:center;padding:10px 12px;cursor:pointer;border-bottom:1px solid #eee;gap:8px;transition:background-color .15s}.other-settings-item:hover{background:#f5f5f5}.other-settings-item.selected{background:#e8f4fd;color:#06c}.other-settings-icon{font-size:18px}.other-settings-name{flex:1;font-size:14px}.other-settings-editor{flex:1;display:flex;flex-direction:column;border:1px solid #ddd;border-radius:4px;overflow:hidden}.other-settings-file-header{padding:12px;background:#f5f5f5;border-bottom:1px solid #ddd}.other-settings-file-name{font-family:monospace;font-size:13px;color:#333}.other-settings-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:#999;font-style:italic}.draw-toolbar{position:absolute;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:16px 12px;display:flex;gap:20px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;z-index:100;border:1px solid rgba(255,255,255,.8)}.draw-toolbar-left{left:20px;top:20px;bottom:20px;width:80px;max-height:calc(100vh - 40px);flex-direction:column;overflow-y:auto;overflow-x:hidden}.draw-toolbar-right{right:20px;top:20px;bottom:20px;width:80px;max-height:calc(100vh - 40px);flex-direction:column;overflow-y:auto;overflow-x:hidden}.draw-toolbar-bottom{left:20px;right:20px;bottom:20px;height:80px;max-width:calc(100vw - 40px);flex-direction:row;align-items:center;overflow-x:auto;overflow-y:hidden}.draw-toolbar-section{display:flex;gap:12px;flex-shrink:0}.draw-toolbar-left .draw-toolbar-section,.draw-toolbar-right .draw-toolbar-section{flex-direction:column}.draw-toolbar-bottom .draw-toolbar-section{flex-direction:row;align-items:center}.draw-toolbar-title{display:none}.draw-toolbar-tools{display:flex;gap:8px}.draw-toolbar-left .draw-toolbar-tools,.draw-toolbar-right .draw-toolbar-tools{flex-direction:column}.draw-toolbar-bottom .draw-toolbar-tools{flex-direction:row}.draw-toolbar-tool{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:#fffc;border:2px solid rgba(0,0,0,.08);border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;padding:0}.draw-toolbar-tool:hover{background:#0000000a;border-color:#0000001f;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.draw-toolbar-tool.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 4px 16px #667eea66;transform:translateY(-2px) scale(1.05)}.draw-toolbar-tool.active:hover{box-shadow:0 6px 20px #667eea80}.draw-toolbar-icon{font-size:24px;line-height:1}.draw-toolbar-label{display:none}.draw-toolbar-color-wrapper{display:flex;gap:8px;align-items:center}.draw-toolbar-left .draw-toolbar-color-wrapper,.draw-toolbar-right .draw-toolbar-color-wrapper{flex-direction:column}.draw-toolbar-bottom .draw-toolbar-color-wrapper{flex-direction:row}.draw-toolbar-color-swatch{width:56px;height:56px;border-radius:12px;cursor:pointer;border:3px solid rgba(0,0,0,.1);box-shadow:0 2px 8px #0000001a;transition:all .2s}.draw-toolbar-color-swatch:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.draw-toolbar-color-text{padding:8px;border:2px solid rgba(0,0,0,.08);border-radius:8px;font-family:Monaco,Menlo,monospace;font-size:11px;text-align:center;background:#fffc;transition:all .2s}.draw-toolbar-left .draw-toolbar-color-text,.draw-toolbar-right .draw-toolbar-color-text{width:100%}.draw-toolbar-bottom .draw-toolbar-color-text{width:80px}.draw-toolbar-color-text:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.draw-toolbar-brush-size{display:flex;gap:10px;align-items:center}.draw-toolbar-left .draw-toolbar-brush-size,.draw-toolbar-right .draw-toolbar-brush-size{flex-direction:column}.draw-toolbar-bottom .draw-toolbar-brush-size{flex-direction:row}.draw-toolbar-brush-preview{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:#fffc;border-radius:12px;border:2px solid rgba(0,0,0,.08)}.draw-toolbar-brush-circle{border-radius:50%;transition:all .2s;box-shadow:0 2px 4px #0003}.draw-toolbar-brush-slider{height:6px;border-radius:3px;background:linear-gradient(to right,#e0e0e0,#667eea);outline:none;-webkit-appearance:none;cursor:pointer}.draw-toolbar-left .draw-toolbar-brush-slider,.draw-toolbar-right .draw-toolbar-brush-slider{width:100%}.draw-toolbar-bottom .draw-toolbar-brush-slider{width:100px}.draw-toolbar-brush-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;box-shadow:0 2px 6px #667eea66;transition:all .2s}.draw-toolbar-brush-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #667eea99}.draw-toolbar-brush-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border:none;box-shadow:0 2px 6px #667eea66;transition:all .2s}.draw-toolbar-brush-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #667eea99}.draw-toolbar-brush-input{padding:6px;border:2px solid rgba(0,0,0,.08);border-radius:8px;font-size:12px;text-align:center;background:#fffc;transition:all .2s}.draw-toolbar-left .draw-toolbar-brush-input,.draw-toolbar-right .draw-toolbar-brush-input{width:100%}.draw-toolbar-bottom .draw-toolbar-brush-input{width:60px}.draw-toolbar-brush-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.draw-toolbar-button{padding:12px;background:#fffc;border:2px solid rgba(0,0,0,.08);border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.draw-toolbar-left .draw-toolbar-button,.draw-toolbar-right .draw-toolbar-button{width:100%}.draw-toolbar-bottom .draw-toolbar-button{padding:12px 20px}.draw-toolbar-button:hover{background:#0000000a;border-color:#0000001f;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.draw-toolbar-button.clear{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border-color:#ff6b6b;color:#fff;box-shadow:0 2px 8px #ff6b6b4d}.draw-toolbar-button.clear:hover{background:linear-gradient(135deg,#ff5252,#e53935);box-shadow:0 4px 12px #ff6b6b66;transform:translateY(-2px)}.draw-toolbar-left::-webkit-scrollbar,.draw-toolbar-right::-webkit-scrollbar{width:6px}.draw-toolbar-bottom::-webkit-scrollbar{height:6px}.draw-toolbar-left::-webkit-scrollbar-track,.draw-toolbar-right::-webkit-scrollbar-track,.draw-toolbar-bottom::-webkit-scrollbar-track{background:transparent}.draw-toolbar-left::-webkit-scrollbar-thumb,.draw-toolbar-right::-webkit-scrollbar-thumb,.draw-toolbar-bottom::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.draw-toolbar-left::-webkit-scrollbar-thumb:hover,.draw-toolbar-right::-webkit-scrollbar-thumb:hover,.draw-toolbar-bottom::-webkit-scrollbar-thumb:hover{background:#0000004d}.konva-canvas-container{flex:1;position:relative;background:#e0e0e0;overflow:hidden;width:100%;height:100%}.konva-canvas-container canvas{background:#fff}.menubar{display:flex;background:#f0f0f0;border-bottom:1px solid #d0d0d0;padding:0;z-index:100}.menubar-item{position:relative}.menubar-button{padding:8px 16px;background:none;border:none;cursor:pointer;font-size:14px;color:#333;transition:background-color .15s}.menubar-button:hover{background:#e0e0e0}.menubar-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #d0d0d0;border-radius:4px;box-shadow:0 2px 8px #00000026;min-width:200px;z-index:1000;padding:4px 0}.menubar-menu-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 16px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:#333;transition:background-color .15s}.menubar-menu-item:hover{background:#f0f0f0}.menubar-menu-item-checked{background:#e8f4fd;font-weight:500}.menubar-shortcut{color:#999;font-size:12px;margin-left:16px}.menubar-menu-separator{height:1px;background:#e0e0e0;margin:4px 0}.draw{display:flex;flex-direction:column;width:100%;height:100%;background:#fff;overflow:hidden}.draw-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#666}.draw-content{flex:1;display:flex;overflow:hidden;position:relative}.desktop-context-menu{position:fixed;background:#fff;border:1px solid #c0c0c0;box-shadow:0 2px 8px #00000026;border-radius:4px;padding:4px 0;min-width:200px;z-index:10000;font-size:13px}.desktop-context-menu-section{padding:0}.desktop-context-menu-section-title{padding:6px 16px 4px;font-size:11px;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:.5px}.desktop-context-menu-item{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;cursor:pointer;font-size:13px;color:#333;transition:background-color .15s}.desktop-context-menu-item:hover{background:#e8f4fd}.desktop-context-menu-item:disabled{color:#999;cursor:not-allowed}.desktop-context-menu-item:disabled:hover{background:none}.desktop-context-menu-separator{height:1px;background:#e0e0e0;margin:4px 0}.os-desktop{width:100%;height:100%;position:relative;overflow:hidden}.os-desktop-background{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,red,#ff7f00,#ff0,#0f0 42%,#00f 57%,indigo,#9400d3 85%,red);background-size:400% 400%;background-position:center;animation:rainbow-gradient 40s ease infinite;overflow:hidden}.os-desktop-background:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#cc4a6b,#cc7a4a,#ccaa4a,#4acc7a 42%,#4a7acc 57%,#7a4acc,#aa4acc 85%,#cc4a6b);opacity:0;animation:chromatic-overlay 30s ease infinite}@keyframes rainbow-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes chromatic-overlay{0%,85%{opacity:0}87%{opacity:.5}89%{opacity:.7}91%{opacity:.4}93%{opacity:0}to{opacity:0}}.os-desktop-branding{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:20px;z-index:2;pointer-events:none}.os-desktop-icon{width:80px;height:80px;filter:drop-shadow(0 0 20px rgba(255,255,255,.5));animation:icon-pulse 6s ease-in-out infinite,icon-chromatic 25s ease-in-out infinite}@keyframes icon-pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.05);opacity:1}}@keyframes icon-chromatic{0%,85%{filter:drop-shadow(0 0 20px rgba(255,255,255,.5))}87%{filter:drop-shadow(-2px 0 15px rgba(255,100,150,.7)) drop-shadow(2px 0 15px rgba(100,200,255,.7))}89%{filter:drop-shadow(2px 0 15px rgba(255,150,100,.7)) drop-shadow(-2px 0 15px rgba(150,255,200,.7))}91%{filter:drop-shadow(0 0 20px rgba(255,255,255,.5))}to{filter:drop-shadow(0 0 20px rgba(255,255,255,.5))}}.os-desktop-title{font-size:48px;font-weight:700;color:#fff;text-shadow:0 0 10px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5);letter-spacing:4px;animation:title-glow 8s ease-in-out infinite,title-chromatic 28s ease-in-out infinite}@keyframes title-glow{0%,to{text-shadow:0 0 10px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}50%{text-shadow:0 0 15px rgba(255,255,255,1),0 0 30px rgba(255,255,255,.8),0 0 45px rgba(255,255,255,.6),2px 2px 4px rgba(0,0,0,.5)}}@keyframes title-chromatic{0%,83%{text-shadow:0 0 10px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}85%{text-shadow:-2px 0 8px rgba(255,120,150,.8),2px 0 8px rgba(120,200,255,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}87%{text-shadow:2px 0 8px rgba(255,180,120,.8),-2px 0 8px rgba(150,255,200,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}89%{text-shadow:-1px 0 6px rgba(255,100,180,.7),1px 0 6px rgba(100,220,255,.7),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}91%{text-shadow:0 0 10px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}to{text-shadow:0 0 10px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.6),0 0 30px rgba(255,255,255,.4),2px 2px 4px rgba(0,0,0,.5)}}.os-desktop-blurstorm{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;overflow:hidden}.blur-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.6;mix-blend-mode:screen}.blob-1{width:300px;height:300px;background:linear-gradient(135deg,#ff0080,#ff8000);top:10%;left:10%;animation:blob-move-1 50s ease-in-out infinite}.blob-2{width:400px;height:400px;background:linear-gradient(135deg,#8000ff,#0080ff);top:60%;right:10%;animation:blob-move-2 60s ease-in-out infinite}.blob-3{width:350px;height:350px;background:linear-gradient(135deg,#00ff80,#80ff00);bottom:10%;left:30%;animation:blob-move-3 45s ease-in-out infinite}.blob-4{width:250px;height:250px;background:linear-gradient(135deg,#ff0080,#f0f);top:30%;left:50%;animation:blob-move-4 55s ease-in-out infinite,blob-chromatic-4 32s ease-in-out infinite}.blob-5{width:320px;height:320px;background:linear-gradient(135deg,#0080ff,#0ff);top:70%;left:20%;animation:blob-move-5 58s ease-in-out infinite}.blob-6{width:280px;height:280px;background:linear-gradient(135deg,#ff8000,#ff0);top:20%;right:30%;animation:blob-move-6 48s ease-in-out infinite,blob-chromatic-6 35s ease-in-out infinite}@keyframes blob-move-1{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,30px) scale(.95)}75%{transform:translate(25px,15px) scale(1.02)}}@keyframes blob-move-2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-35px,-25px) scale(1.08)}66%{transform:translate(25px,35px) scale(.92)}}@keyframes blob-move-3{0%,to{transform:translate(0) scale(1)}25%{transform:translate(40px,-30px) scale(1.1)}50%{transform:translate(-30px,-40px) scale(.9)}75%{transform:translate(20px,25px) scale(1.05)}}@keyframes blob-move-4{0%,to{transform:translate(0) scale(1)}30%{transform:translate(-25px,30px) scale(1.05)}60%{transform:translate(30px,-25px) scale(.95)}90%{transform:translate(-15px,-20px) scale(1.02)}}@keyframes blob-chromatic-4{0%,82%{background:linear-gradient(135deg,#ff0080,#f0f)}84%{background:linear-gradient(135deg,#cc4a9a,#cc6baa)}86%{background:linear-gradient(135deg,#aa5b9a,#bb7baa)}88%{background:linear-gradient(135deg,#ff0080,#f0f)}to{background:linear-gradient(135deg,#ff0080,#f0f)}}@keyframes blob-move-5{0%,to{transform:translate(0) scale(1)}20%{transform:translate(35px,20px) scale(1.08)}40%{transform:translate(-20px,35px) scale(.92)}60%{transform:translate(25px,-30px) scale(1.05)}80%{transform:translate(-30px,15px) scale(.97)}}@keyframes blob-move-6{0%,to{transform:translate(0) scale(1)}25%{transform:translate(-40px,25px) scale(1.1)}50%{transform:translate(30px,40px) scale(.9)}75%{transform:translate(-25px,-20px) scale(1.05)}}@keyframes blob-chromatic-6{0%,80%{background:linear-gradient(135deg,#ff8000,#ff0)}82%{background:linear-gradient(135deg,#ccaa4a,#ddbb5a)}84%{background:linear-gradient(135deg,#bb9b6a,#ccab7a)}86%{background:linear-gradient(135deg,#ff8000,#ff0)}to{background:linear-gradient(135deg,#ff8000,#ff0)}}.os-desktop-content{position:relative;z-index:1;width:100%;height:100%}.os-loading{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;font-size:18px;color:#666}.os{width:100vw;height:100vh;overflow:hidden;position:relative}
