:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Fira Code", monospace;--color-bg-primary: #f2f5f8;--color-bg-secondary: #ffffff;--color-bg-tertiary: #e4e8eb99;--color-border: #9893a557;--color-border-active: #3b82f6;--color-bg-tab-primary: #f2f5f8c9;--color-bg-tab-secondary: #ffffff;--color-text-primary: #111827;--color-text-secondary: #4b5563;--color-text-dim: #9ca3af;--color-text-output: #182634;--color-icon: #4b5563;--color-icon-active: #000000;--header-height: 36px;--header-height-mobile: 44px;--sidebar-width: 20vw;--output-area-width: 20vw;--gutter-size: 8px;--editor-font-size: 14px;--scrollbar-thumb: rgba(121, 121, 121, .4);--scrollbar-thumb-hover: rgba(100, 100, 100, .7)}body.dark{--color-bg-primary: #222222;--color-bg-secondary: #2a2a2b;--color-bg-tertiary: #3737378a;--color-border: #4a4a4ad4;--color-border-active: #1a8ad8;--color-bg-tab-primary: #3737378a;--color-bg-tab-secondary: #2a2a2b;--color-text-primary: #dedddd;--color-text-secondary: #a6a6a6;--color-text-dim: #737373;--color-text-output: #dedddd;--color-icon: #a6a6a6;--color-icon-active: #dedddd;--scrollbar-thumb: rgba(140, 140, 140, .45);--scrollbar-thumb-hover: rgba(200, 200, 200, .55)}.monaco-editor,.monaco-diff-editor,.monaco-component{--vscode-editor-background: var(--color-bg-secondary) !important}.margin{--vscode-editorGutter-background: var(--color-bg-secondary) !important}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb);border-radius:4px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover)}::-webkit-scrollbar-button{display:none;width:0;height:0}::-webkit-scrollbar-corner{background:transparent}@supports (-moz-appearance: none){*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent}}.monaco-scrollable-element>.scrollbar>.slider{background:var(--scrollbar-thumb)!important;border-radius:4px!important;border:2px solid transparent!important;background-clip:content-box!important}.monaco-scrollable-element>.scrollbar>.slider:hover{background:var(--scrollbar-thumb-hover)!important;border-radius:4px!important;border:2px solid transparent!important;background-clip:content-box!important}.monaco-scrollable-element>.shadow{display:none!important}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100vh;height:100dvh;width:100vw;font-family:var(--font-sans);font-size:14px;background-color:var(--color-bg-primary);color:var(--color-text-primary);overflow:hidden;transition:background-color .2s linear,color .2s linear;display:flex;flex-direction:column}.form-group a:link,.form-group a:visited,.form-group a:hover,.form-group a:active{color:#00e}body.dark .form-group a:link,body.dark .form-group a:visited,body.dark .form-group a:hover,body.dark .form-group a:active{color:#6a7ae5}input{background-color:var(--color-bg-tab-primary)}input:focus{box-shadow:0 0 0 2px #3b82f63d}body.dark input:focus{box-shadow:0 0 0 2px #3bf6c430;background-color:transparent}option{background-color:var(--color-bg-tab-primary)}body.dark option{background-color:#333}button{border:none;background:none;cursor:pointer;padding:0;font-family:inherit}.action-btn{display:flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:4px;border:1px solid transparent;font-weight:500;gap:6px}.action-btn#run-btn{color:#fff;background-color:#16a34a;border:1px solid #16a34a;overflow:hidden;white-space:nowrap;transition:max-width .2s ease-in-out,background-color .1s ease,border-color .1s ease;width:65px;display:flex;justify-content:center;align-items:baseline;padding:5px 12px!important}.action-btn#run-btn:hover{background-color:#15803d}.action-btn#share-btn{color:var(--color-text-primary);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border)}.action-btn#share-btn:hover{background-color:#e2e8f0}body.dark .action-btn#share-btn:hover{background-color:#3f3f46}.action-btn#signin-btn{color:var(--color-text-primary);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);margin-left:2px}.action-btn#signin-btn:hover{background-color:#e2e8f0}body.dark .action-btn#signin-btn:hover{background-color:#3f3f46}.action-btn#signin-btn.logged-in{border-radius:20px;padding:3px 8px 3px 3px;gap:6px;background-color:transparent;border:1px solid transparent}.action-btn#signin-btn.logged-in:hover{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border)}.action-btn#signin-btn.logged-in:focus{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border)}.action-btn#signin-btn.logged-in:hover .user-menu-chevron{color:var(--color-text-primary)}.action-btn#sidebar-toggle-btn,.action-btn#theme-toggle-btn{background-color:transparent}.action-btn#theme-toggle-btn{background-color:var(--color-bg-tertiary);color:var(--color-icon-active)}body.dark .action-btn#theme-toggle-btn i:before{content:""}body:not(.dark) .action-btn#theme-toggle-btn i:before{content:""}.action-btn.active{filter:brightness(1.15);transform:scale(.98);transition:filter .1s,transform .1s}.header-action-btn{background-color:transparent;color:var(--color-icon);padding:5px 7px;margin:2px 0;border-radius:4px;font-size:14px;line-height:1}.header-action-btn:hover{color:var(--color-icon-active)}.ide-header{display:flex;justify-content:space-between;align-items:center;height:var(--header-height);padding:8px 10px 0;-webkit-user-select:none;user-select:none}.header-group{display:flex;align-items:center;gap:8px}.header-group.left,.header-group.right{flex:0 1 auto}.header-group.center{flex:1 0 auto;justify-content:center}.header-group.right{gap:2px}.logo{display:grid;place-items:center}.brand-title{font-weight:600;font-size:18px;color:var(--color-text-primary)}.header-icon-btn{background-color:transparent;color:var(--color-icon);padding:6px;border-radius:4px;font-size:16px;line-height:1;margin-top:1px}.header-icon-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-icon-active)}#main-menu-btn:focus{background-color:var(--color-bg-tertiary);color:var(--color-icon-active)}.header-separator{width:1px;height:16px;background-color:var(--color-border);margin:0 4px}.user-avatar,.user-avatar-placeholder{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-avatar-placeholder{background-color:var(--color-border-active);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px;line-height:1}.user-menu-chevron{font-size:10px;color:var(--color-text-secondary);margin-right:2px}.ide-container{display:grid;flex-grow:1;width:100vw;grid-template-rows:1fr auto;grid-template-columns:var(--sidebar-width) var(--gutter-size) 1fr;transition:grid-template-columns .2s ease-in-out;padding:8px}.ide-container.sidebar-hidden{grid-template-columns:0px 0px 1fr}.sidebar{grid-column:1 / 2;grid-row:1 / 3;display:flex;flex-direction:column;border-radius:6px;border:1px solid var(--color-border);overflow:hidden;background-color:var(--color-bg-secondary);margin-bottom:22px;transition:border .3s ease-in-out}.ide-container.sidebar-hidden .sidebar{border-color:var(--color-bg-primary)!important}.sidebar-sections-container{display:flex;flex-direction:column;height:100%}.sidebar-section{display:flex;flex-direction:column}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 12px;font-size:11px;font-weight:600;color:var(--color-text-primary);letter-spacing:.5px;-webkit-user-select:none;user-select:none;cursor:pointer;background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.sidebar-section-header:hover{background-color:var(--color-bg-tertiary)}.sidebar-section.active{flex-grow:1;min-height:0}.sidebar-section.active+.sidebar-section{margin-top:auto;border-top:1px solid var(--color-border)}.sidebar-section.active~.sidebar-section:last-child>.sidebar-section-header{border-bottom:none}.sidebar-section.active .sidebar-section-header{border-bottom:none;cursor:auto;background-color:transparent}.sidebar-section-header .fa-chevron-right,.sidebar-section-header .fa-chevron-down{transition:transform .2s ease-in-out}.sidebar-section-header.active .fa-chevron-down{transform:rotate(0)}.sidebar-section-header:not(.active) .fa-chevron-down{transform:rotate(-90deg)}.header-title-group{display:flex;align-items:center;gap:6px}.sidebar-section-content{display:none}.sidebar-section-content.active{display:flex;flex-grow:1;overflow:hidden;flex-direction:column}.pane-group{display:flex;flex-direction:column;height:100%;border-radius:6px;border:1px solid var(--color-border);overflow:hidden;background-color:var(--color-bg-secondary)}.split-container>.pane-group{min-width:150px;min-height:100px}.tab-content-wrapper{flex-grow:1;overflow:hidden;position:relative}.main-content{grid-column:3 / 4;grid-row:1 / 2;overflow:hidden;position:relative;display:flex;flex-direction:column}body.is-dragging-a-tab .tab-content-wrapper{pointer-events:none}.workbench{display:flex;flex-direction:column;overflow:hidden;flex-grow:1;min-height:0;padding:0;position:relative}#monaco-editor-container{width:100%;height:100%;flex-grow:1}.monaco-editor-instance{width:100%;height:100%}.tabs-container{display:flex;align-items:flex-start;list-style:none;margin:0;padding:5px 0 0 2px;height:46px;background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);position:relative;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;flex-shrink:0}.tab-content-panel{display:none;background-color:var(--color-bg-secondary);position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;padding:0}.tabs-container::-webkit-scrollbar{height:2px}.tabs-container::-webkit-scrollbar-thumb{border:0}.tabs-container::-webkit-scrollbar-button{display:none}.tab{display:flex;align-items:baseline;gap:8px;padding:7px 10px;cursor:pointer;background-color:var(--color-bg-tab-secondary);color:var(--color-text-secondary);border-radius:4px;margin-left:4px;border:1px solid transparent;flex-shrink:0;height:34px}.tab:hover{background-color:var(--color-bg-tab-primary)}.tab.active{color:var(--color-text-primary);border-color:var(--color-border)}.pane-group.is-focused .tab.active{border-color:var(--color-border);background-color:var(--color-bg-tab-primary)}.new-tab-btn{padding:8px 12px;color:var(--color-icon);font-size:14px;border-radius:4px}.new-tab-btn:hover,.new-tab-btn:active{background-color:var(--color-bg-tertiary);color:var(--color-icon-active)}.python-icon{color:#306998}.close-icon{font-size:11px;padding:4px;border-radius:4px}.close-icon:hover{background-color:var(--color-bg-tertiary)}.close-icon.is-dirty:before{content:"";font-family:"Font Awesome 6 Free";font-weight:900;font-size:.76em;vertical-align:middle}.close-icon.is-dirty:hover:before{content:"";font-size:12px}.tab.active .close-icon:hover{background-color:var(--color-bg-tertiary)}.gutter-col{grid-row:1 / 3;grid-column:2 / 3;cursor:col-resize;width:var(--gutter-size);background-color:transparent;margin-top:8px;margin-bottom:22px;transition:background-color .1s ease-in-out;border-radius:3px}.gutter-col:hover,.gutter-row:hover,.gutter.is-dragging,.gutter-col.is-dragging{background-color:var(--color-border-active)}.ide-container.is-resizing{transition:none}.ide-container.is-resizing iframe,body.is-resizing-panes iframe{pointer-events:none}#explorer-panel,#search-panel,#packages-panel,#settings-panel{padding:0;position:relative}.explorer-container,.search-container,.packages-container,.settings-container{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column}.explorer-tree{flex-grow:1;overflow-y:auto;padding:0 0 0 8px;display:flex;flex-direction:column;border-top:solid 1px #8080802e}.ide-container.sidebar-hidden .explorer-tree,.ide-container.sidebar-hidden .search-results-container,.ide-container.sidebar-hidden .packages-list{overflow-x:hidden}.explorer-item{display:flex;align-items:center;gap:6px;padding:4px 12px 4px 4px;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--color-text-secondary);border-radius:2px;box-shadow:none}.explorer-item>span:last-of-type{white-space:nowrap;overflow:hidden}.explorer-item:hover{background-color:var(--color-bg-tab-primary)}.explorer-item i{width:18px;text-align:center;color:var(--color-icon);flex-shrink:0}.explorer-item.folder>.fa-folder{color:var(--color-icon)}.explorer-item.folder.open>span{color:var(--color-text-primary)}.explorer-item.context-menu-active{background-color:var(--color-bg-tab-primary)}.explorer-item .fa-python,.tab .fa-python{color:#00758f}.explorer-item .fa-js-square,.tab .fa-js-square{color:#f7df1e}.explorer-item .fa-html5,.tab .fa-html5{color:#e34f26}.explorer-item .fa-css3-alt,.tab .fa-css3-alt{color:#1572b6}.explorer-item .fa-sass,.tab .fa-sass{color:#c69}.explorer-item .fa-npm,.tab .fa-npm{color:#cb3837}.explorer-item .fa-bolt,.tab .fa-bolt{color:#646cff}.explorer-item .fa-file-image,.tab .fa-file-image{color:#815ac0}.explorer-item .fa-database,.tab .fa-database{color:#00758f}.explorer-item .fa-markdown,.tab .fa-markdown{color:#09f}.explorer-item .fa-file-archive,.tab .fa-file-archive{color:#c87a02}.explorer-item .fa-file-pdf,.tab .fa-file-pdf{color:#d94b3c}.explorer-item .fa-file-csv,.tab .fa-file-csv{color:#207245}.explorer-folder-children{margin-left:12px;border-left:1px solid var(--color-bg-tertiary);padding-left:8px;position:relative}body.dark .explorer-folder-children{border-left-color:var(--color-border)}.explorer-item.folder:not(.open)+.explorer-folder-children{display:none}.explorer-item.active{background-color:var(--color-bg-tab-primary);color:var(--color-text-primary);font-weight:500}#explorer-actions{visibility:hidden;display:flex;gap:4px}#terminal-container,#console-container{height:100%;overflow:hidden}#terminal-container .terminal{height:100%;padding:10px;font-size:var(--editor-font-size)}#console-container{padding:10px;font-family:var(--font-mono);font-size:14px;color:var(--color-text-secondary);line-height:1.6;overflow-y:auto}#explorer-more-actions-btn:hover{background-color:var(--color-bg-tertiary)}#import-project-wrapper{visibility:hidden}.sidebar-section-header.active #import-project-wrapper,.sidebar-section-header.active #explorer-actions{visibility:visible}.context-menu{position:fixed;z-index:1000;display:none;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;box-shadow:0 4px 12px #0000001a;min-width:120px;padding:0}body.dark .context-menu{box-shadow:0 4px 12px #0003}.context-menu-item{display:flex;align-items:center;gap:10px;padding:6px 8px;font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none}.context-menu-item:hover{background-color:var(--color-bg-tertiary)}.context-menu-item i{width:16px;text-align:center;color:var(--color-icon)}.context-menu-separator{height:1px;background-color:var(--color-border);margin:0}.explorer-item-input{width:100%;padding:2px 4px;border:1px solid var(--color-border-active);background-color:var(--color-bg-primary);color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none!important;box-shadow:none!important}body.dark .explorer-item-input{background-color:var(--color-bg-secondary)}.explorer-item.is-dragging{opacity:.5}.explorer-item.folder.drop-target{background-color:#3b82f64d;color:#fff;box-shadow:inset 0 0 0 1px #3b82f6cc}.explorer-item.folder.drop-target i{color:#fff}.explorer-root-drop-zone{flex-grow:1;min-height:10px;margin-right:12px;border-radius:4px;margin-top:4px;background-color:transparent;transition:background-color .1s ease-in-out}.explorer-root-drop-zone.drop-target{background-color:#3b82f64d;border:1px solid rgba(59,130,246,.8)}.search-form-container{padding:4px 12px 8px;border-bottom:1px solid var(--color-border);flex-shrink:0}.search-input-wrapper{position:relative}#search-input,#replace-input{width:100%;padding:6px 90px 6px 8px;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none}.search-options{position:absolute;right:5px;top:50%;transform:translateY(-50%);display:flex;gap:2px}.search-option-btn{width:22px;height:22px;border-radius:4px;color:var(--color-icon);background-color:transparent;border:1px solid transparent;display:grid;place-items:center;font-size:12px}.search-option-btn:hover{background-color:var(--color-bg-secondary);border-color:var(--color-border)}.search-option-btn.active{background-color:var(--color-border-active);color:#fff;border-color:var(--color-border-active)}body.dark .search-option-btn.active{color:var(--color-icon-active)}.search-results-container{flex-grow:1;overflow-y:auto;padding:8px 0}.search-result-group{margin-bottom:2px}.search-result-file{display:flex;align-items:center;gap:8px;padding:4px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:var(--color-bg-secondary)}.search-result-file:hover{background-color:var(--color-bg-tertiary)}.search-result-file i{width:16px;text-align:center;color:var(--color-icon)}.search-result-file-path{font-weight:500;color:var(--color-text-primary)}.search-result-count{font-size:12px;padding:1px 6px;border-radius:8px;background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);margin-left:auto}body.dark .search-result-count{background-color:var(--color-bg-primary)}.search-result-matches{display:block}.search-result-line{display:flex;align-items:start;padding:2px 12px 2px 36px;font-family:var(--font-mono);font-size:13px;color:var(--color-text-secondary);cursor:pointer;white-space:pre;overflow:hidden;text-overflow:ellipsis}.search-result-line:hover{background-color:var(--color-bg-tertiary)}.search-result-line-number{color:var(--color-text-dim);width:40px;flex-shrink:0;text-align:right;margin-right:10px}.search-result-line-content mark{background-color:#fde047;color:#111827;border-radius:2px;box-shadow:0 0 0 1px #fde047}.search-results-empty{padding:4px 12px;color:var(--color-text-secondary);font-size:13px;margin:0 0 10px;line-height:1.4}body.dark .search-result-line-content mark{background-color:#a16207;color:#f0f0f0;box-shadow:0 0 0 1px #a16207}.packages-container{display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.packages-search-wrapper{padding:4px 12px 8px;flex-shrink:0;border-bottom:1px solid var(--color-border)}#packages-search-input{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none}.packages-info-text{font-size:13px;color:var(--color-text-secondary);margin:0 0 10px;line-height:1.4}.packages-list{flex-grow:1;overflow-y:auto}.packages-list-empty{padding:10px 12px;color:var(--color-text-secondary)}.package-item{display:flex;flex-direction:column;padding:10px 12px;cursor:default;border-bottom:1px solid var(--color-border);min-height:66px}.package-item-header{display:flex;align-items:center;gap:8px;min-width:0}.package-item-name{font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-shrink:1}.package-item-version,.package-item-actions{flex-shrink:0}.package-item-version{font-size:12px;color:var(--color-text-secondary)}.package-item-description{font-size:13px;color:var(--color-text-secondary);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.package-item-actions{margin-left:auto}.package-action-btn{padding:4px 10px;font-size:12px;border-radius:4px;border:1px solid var(--color-border);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-width:75px}.package-action-btn:hover{background-color:var(--color-bg-tertiary)}body.dark .package-action-btn{background-color:var(--color-bg-secondary)}body.dark .package-action-btn:hover{background-color:var(--color-bg-tertiary)}.action-btn.primary{background-color:#16a34a;color:#fff;border-color:#16a34a}.action-btn.primary:hover{background-color:#128f40}body.dark .action-btn.primary:hover{background-color:#128f40!important}.action-btn.icon-only{width:32px;padding:8px 12px;justify-content:center;color:var(--color-text-secondary);border-color:transparent;background:transparent}.action-btn.icon-only:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.action-btn.success{background-color:#16a34a!important;color:#fff!important;border-color:#16a34a!important}.action-btn.error{background-color:#dc2626!important;color:#fff!important;border-color:#dc2626!important}.action-btn.secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-border);padding:8px 12px;align-items:center}.action-btn.secondary:hover{background-color:#dadfe7}body.dark .action-btn.secondary:hover{background-color:#414141}.action-btn.danger{background-color:#ef5350;color:#fff}.action-btn.danger:hover{background-color:#dc2626;color:#fff}body.dark .action-btn.danger{background-color:#ef5350;color:#fff}body.dark .action-btn.danger:hover{background-color:#dc2626;color:#fff}.action-btn.stop-mode{background-color:#dc2626!important;border-color:#dc2626!important;color:#fff!important}.action-btn.stop-mode:hover{background-color:#b91c1c!important}.ide-status-bar{grid-row:2 / 3;grid-column:3 / 4;display:flex;justify-content:space-between;align-items:center;height:22px;padding:4px 2px 0;font-size:12px;color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.status-bar-left,.status-bar-right{display:flex;align-items:center;gap:6px}.status-bar-item{display:flex;align-items:center;gap:6px;padding:2px 8px;border-radius:4px;cursor:default;height:100%;transition:background-color .15s ease;white-space:nowrap}#cursor-position-status,#language-mode-status,#python-version-status{min-width:60px;justify-content:center}.status-bar-item i{font-size:13px;color:var(--color-icon)}.status-bar-separator{width:1px;height:14px;background-color:var(--color-border);margin:0}#cursor-position-status{position:relative;margin-right:8px}#cursor-position-status:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:1px;height:14px;background-color:var(--color-border)}.tab.dragging{opacity:.5;background-color:var(--color-bg-tertiary);pointer-events:none}.tab-reorder-indicator{position:absolute;display:none;width:2px;background-color:var(--color-border-active);z-index:200;pointer-events:none;top:0;left:-1px;will-change:transform}.tabs-container.is-dragging .tab *{pointer-events:none}.new-tab-btn-container{margin-left:4px}.new-tab-btn-container.drag-over{border-left:2px solid var(--color-border-active)}.split-layout{display:flex;width:100%;height:100%;min-width:0;min-height:0}.split-layout>*:not(.gutter){min-width:150px;min-height:100px;position:relative}.gutter{background-color:transparent;transition:background-color .1s ease-in-out;flex-shrink:0;border-radius:3px}.gutter:hover{background-color:var(--color-border-active)}.split-layout[style*="flex-direction: row"]>.gutter{width:var(--gutter-size);cursor:col-resize}.split-layout[style*="flex-direction: column"]>.gutter{height:var(--gutter-size);cursor:row-resize}.dynamic-drop-zone{position:absolute;background-color:#3b82f64d;border:1px solid rgba(59,130,246,.8);z-index:100;display:none;pointer-events:none;transition:all .05s ease-in-out;border-radius:6px}.main-content.is-splitting .dynamic-drop-zone{display:block}.edge-drop-zone{position:absolute;background-color:#3b82f64d;border:1px solid rgba(59,130,246,.8);z-index:101;display:none;pointer-events:none;border-radius:6px}#edge-drop-zone-top{top:0;left:0;right:0;height:18px}#edge-drop-zone-bottom{bottom:0;left:0;right:0;height:18px}#edge-drop-zone-left{top:0;left:0;bottom:0;width:40px}#edge-drop-zone-right{top:0;right:0;bottom:0;width:40px}body.is-dragging-a-tab iframe{pointer-events:none}.tabs-container.drop-target{background-color:#3b82f64d;box-shadow:inset 0 0 0 1px #3b82f6cc;border-radius:5px}#output-wrapper,#repl-wrapper{width:100%;height:100%;overflow:hidden;margin:0;padding:0;font-family:var(--font-mono);font-size:var(--editor-font-size)}#interactive-console{height:100%;width:100%;box-sizing:border-box;outline:none}#output-wrapper h1,#output-wrapper h2{font-size:1.5em;font-weight:600;padding-bottom:.3em}#output-wrapper h3{font-size:1.2em;font-weight:600}#output-wrapper p,#output-wrapper ul{color:var(--color-text-output);line-height:1.7}#output-wrapper ul{padding-left:20px}#output-wrapper li{margin-bottom:8px}#output-wrapper a{color:var(--color-border-active);text-decoration:none}#output-wrapper a:hover{text-decoration:underline}.sampleCode{background-color:var(--color-bg-primary);border:1px solid var(--color-border);color:var(--color-text-output);padding:6px 12px;border-radius:4px;font-weight:500}#sampleCode:hover,body.dark #sampleCode{background-color:var(--color-bg-tertiary)}body.dark #sampleCode:hover{background-color:#3f3f46}.shortcut-list{display:flex;flex-direction:column;gap:16px;margin-top:1em}.shortcut-item{display:flex;align-items:center;gap:20px}.shortcut-keys{display:flex;gap:6px;align-items:center}.shortcut-keys span{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;padding:4px 8px;font-family:var(--font-mono);font-size:13px}.timeline{position:relative;padding-left:28px;border-left:2px solid var(--color-border);margin:1em}.timeline-item{position:relative;margin-top:20px}.timeline-item:before{content:"";position:absolute;left:-37px;width:12px;height:12px;border-radius:50%;background-color:var(--color-bg-primary);border:2px solid var(--color-border)}.timeline-date{font-weight:600;color:var(--color-text-output);margin-bottom:8px}.timeline-content{padding:10px 20px;background:var(--color-bg-tab-primary);border-radius:8px}body.dark .timeline-item:before{background-color:var(--color-bg-secondary)}.static-content-target{max-width:650px;margin:0 auto}.static-content-target form{margin-top:1em;max-width:600px}.static-content-target label{display:block;margin-bottom:5px;font-size:16px;font-weight:700}.static-content-target input{width:-webkit-fill-available;max-width:350px}.static-content-target input[type=text],.static-content-target input[type=email],.static-content-target textarea{width:100%;padding:6px;margin-bottom:15px;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-output);font-family:inherit;font-size:14px;outline:none}.static-content-target textarea{min-height:120px;resize:vertical}.form-bottom{display:flex;justify-content:space-between;align-items:center}.form-bottom button[type=submit]{color:#fff;background-color:#16a34a;padding:8px 16px;border-radius:4px;font-weight:500}.form-bottom button[type=submit]:hover{background-color:#15803d}.form-bottom label{display:flex;align-items:center;gap:6px;white-space:nowrap}#settings-panel{padding:0;position:relative}.settings-container{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column}.settings-filter-tabs{display:flex;padding:0 12px;gap:15px;border-bottom:1px solid var(--color-border);-webkit-user-select:none;user-select:none;flex-shrink:0}.settings-filter-btn{padding:8px 4px;font-size:14px;font-weight:500;color:var(--color-text-secondary);border-bottom:2px solid transparent;background:none;border-radius:0}.settings-filter-btn.active{color:var(--color-text-primary);border-bottom-color:var(--color-border-active)}.settings-content{flex-grow:1;overflow-y:auto;padding:16px}.settings-section{display:none}.settings-section.active{display:block}.settings-section h3{margin-top:24px;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:1.1em}.settings-section>*:first-child{margin-top:0}.setting-item{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:20px;gap:8px}.setting-label{flex-grow:1}.setting-label label{font-weight:500;font-size:14px;color:var(--color-text-primary)}.setting-label p{font-size:13px;color:var(--color-text-secondary);margin:4px 0 0;line-height:1.5}.setting-control{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px}.setting-control input,.setting-control select{justify-content:flex-start}.setting-control input[type=text],.setting-control input[type=number],.setting-control select{width:100%;padding:2px 8px;background-color:var(--color-bg-tab-primary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none}.setting-control select:focus{box-shadow:none!important}.setting-control input[type=range]{flex-grow:1}.setting-control .range-value{min-width:40px;text-align:right}.toggle-switch{position:relative;display:inline-block;width:32px;height:18px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);transition:.4s;border-radius:18px}.toggle-switch .slider:before{position:absolute;content:"";height:12px;width:12px;left:2px;bottom:2px;background-color:var(--color-text-secondary);transition:.4s;border-radius:50%}.toggle-switch input:checked+.slider{background-color:var(--color-border-active);border-color:var(--color-border-active)}.toggle-switch input:checked+.slider:before{transform:translate(14px);background-color:#fff}#problems-wrapper{padding:0;font-size:13px;-webkit-user-select:none;user-select:none;overflow-y:auto}.problems-container{padding-bottom:20px}.problem-group{border-bottom:1px solid var(--color-border)}.problem-file-header{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;background-color:var(--color-bg-tertiary)}.problem-file-header .fa-chevron-down{transition:transform .15s ease-in-out}.problem-group.collapsed .problem-file-header .fa-chevron-down{transform:rotate(-90deg)}.problem-file-path{font-weight:500}.problem-count{font-size:12px;padding:1px 6px;border-radius:8px;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);margin-left:auto}body.dark .problem-count{background-color:var(--color-bg-primary)}.problem-items-container{display:block}.problem-group.collapsed .problem-items-container{display:none}.problem-item{display:flex;align-items:flex-start;gap:8px;padding:4px 12px 4px 28px;cursor:pointer;align-items:center}.problem-item:hover{background-color:var(--color-bg-tertiary)}.problem-severity-icon.error{color:#d94b3c}.problem-severity-icon.warning{color:#f2bb30}.problem-severity-icon.info{color:#3b82f6}.problem-message{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.problem-details{flex-shrink:0;color:var(--color-text-secondary)}.problem-code{text-transform:uppercase;cursor:help}#problems-status{cursor:pointer;display:flex;gap:10px;padding:3px 10px}.problems-count-item{display:flex;align-items:center;gap:4px}.problems-count-item.errors .fas.fa-times-circle{color:#d94b3c}.problems-count-item.warnings .fas.fa-exclamation-triangle{color:#f2bb30}#problems-status{position:relative;margin-right:10px}#problems-status:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:1px;height:14px;background-color:var(--color-border)}#problems-status:hover{background-color:var(--color-bg-tertiary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000005e;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background-color:var(--color-bg-secondary);border:none;border-radius:8px;box-shadow:0 15px 30px #0000001f;overflow:hidden;padding:25px;min-width:500px;max-width:600px}body.dark .modal-content{box-shadow:0 15px 30px #0006}.modal-content.modal-flush{padding:0!important;max-width:fit-content!important;background-color:transparent;border:none;box-shadow:none}.auth-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:20px}.auth-tab-btn{padding:10px 16px;font-size:16px;font-weight:500;color:var(--color-text-secondary);border-bottom:2px solid transparent}.auth-tab-btn.active{color:var(--color-text-primary);border-bottom-color:var(--color-border-active)}.auth-form{display:none}.auth-form.active{display:block}.form-group label{display:block;margin-bottom:8px;font-weight:500}.form-group input{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none}.auth-submit-btn{width:100%;padding:10px;font-size:16px;font-weight:500;border-radius:4px;color:#fff;background-color:#16a34a;margin-top:10px}.auth-submit-btn:hover{background-color:#15803d}.auth-error-message{color:#d94b3c;font-size:13px;min-height:18px;margin:-5px 0 10px}#reset-email,#update-password{width:100%!important}#reset-password-form,#update-password-form{width:350px!important;margin:0 auto}#auth-success-message{text-align:center;padding:20px 0}#auth-success-message .success-icon{font-size:48px;color:#16a34a;margin-bottom:16px}#auth-success-message h3{margin-top:0;margin-bottom:12px;font-size:1.2em;color:var(--color-text-primary)}#auth-success-message p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:0}.google-signin-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:10px;font-size:15px;font-weight:500;border-radius:4px;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);margin-bottom:16px}.google-signin-btn:hover{background-color:var(--color-bg-tertiary)}.google-signin-btn svg{width:18px;height:18px}.auth-separator{display:flex;align-items:center;text-align:center;color:var(--color-text-secondary);margin-bottom:16px;font-size:12px}.auth-separator:before,.auth-separator:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.auth-separator:not(:empty):before{margin-right:.5em}.auth-separator:not(:empty):after{margin-left:.5em}.form-description{font-size:13px;color:var(--color-text-secondary);margin:4px 0 10px;line-height:1.5}.form-extra{display:flex;justify-content:flex-end;margin-top:-8px;margin-bottom:12px}.link-btn{font-size:13px;color:var(--color-border-active);text-decoration:none;background:none;border:none;padding:4px;cursor:pointer}.link-btn:hover{text-decoration:underline}#reset-password-form .form-extra{justify-content:center;margin-top:16px}#interactive-console{height:100%;width:100%;font-family:var(--font-mono);font-size:var(--editor-font-size);color:var(--color-text-output);outline:none;cursor:text;overflow:hidden;background-color:transparent;display:block;white-space:pre-wrap;word-break:break-all}.interactive-console .xterm-viewport,.interactive-console .xterm-screen,.repl-terminal-element .xterm-viewport,.repl-terminal-element .xterm-screen{background-color:transparent!important}.interactive-console .xterm-rows{color:var(--color-text-output)!important}.interactive-console:not(.input-active) .xterm-cursor-block,.interactive-console:not(.input-active) .xterm-cursor-bar,.interactive-console:not(.input-active) .xterm-cursor-underline,.interactive-console:not(.input-active) .xterm-cursor-outline{background-color:transparent!important;border-color:transparent!important;outline:none!important;display:none!important}.interactive-console.input-active .xterm-cursor-block{background-color:var(--color-text-output)!important;color:var(--color-bg-secondary)!important}.interactive-console.input-active .xterm-cursor-bar,.interactive-console.input-active .xterm-cursor-underline{border-color:var(--color-text-output)!important}#console-content>span:first-child{margin-top:0;padding-top:0}#console-content{margin:0;padding:0;display:inline}.console-cursor{display:inline-block;width:8px;height:1.1em;background-color:var(--color-text-output);vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.console-plot-iframe{width:100%;max-width:100%;border:solid 1px var(--color-border);background:#fff;border-radius:4px}.console-plot-wrapper{margin:10px 0;width:100%;overflow-x:auto;display:block}.console-plot-preview{max-height:300px;max-width:100%;border:1px solid var(--color-border);border-radius:4px;margin:8px 0;cursor:pointer;transition:opacity .2s;background-color:#fff}.console-plot-preview:hover{opacity:.9;box-shadow:0 0 0 2px var(--color-border-active)}.console-plot-link{display:inline-block}.ansi-black-fg{color:#3e424d}.ansi-red-fg{color:#e75c58}.ansi-green-fg{color:#9ec400}.ansi-yellow-fg{color:#e7c547}.ansi-blue-fg{color:#7aa6da}.ansi-magenta-fg{color:#b77ee0}.ansi-cyan-fg{color:#54ced6}.ansi-white-fg{color:#d7d7d5}.ansi-bright-black-fg{color:#666}.ansi-bright-red-fg{color:#f33}.ansi-bright-green-fg{color:#3f3}body.dark .ansi-black-fg{color:#c5c8c6}.console-text-system{color:var(--color-text-secondary);font-style:italic;display:block;margin-top:8px;padding-top:4px}.console-user-input{color:var(--color-text-primary)}.error-summary{padding:4px 0}details.error-traceback{margin-top:4px;color:var(--color-text-secondary)}details.error-traceback summary{outline:none;-webkit-user-select:none;user-select:none;margin-bottom:4px;color:var(--color-text-dim)}details.error-traceback summary:hover{color:var(--color-text-primary)}details.error-traceback pre{background-color:var(--color-bg-tertiary);padding:8px;border-radius:4px;overflow-x:auto;margin:0;font-family:var(--font-mono);white-space:pre}.project-selector-btn{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;background:transparent;border:1px solid var(--color-border);font-size:14px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background-color .1s,border-color .1s;max-width:250px}.project-selector-btn:not([disabled]):hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.project-selector-btn:not([disabled]):active{background-color:var(--color-bg-secondary)}.project-selector-btn span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-selector-btn i{font-size:10px;color:var(--color-text-secondary);margin-top:2px}.image-preview-container{height:100%;width:100%;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-tertiary);overflow:hidden;position:relative;-webkit-user-select:none;user-select:none}.image-preview-container.bg-checkered{background-image:linear-gradient(45deg,#e5e7eb 25%,transparent 25%),linear-gradient(-45deg,#e5e7eb 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e5e7eb 75%),linear-gradient(-45deg,transparent 75%,#e5e7eb 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}body.dark .image-preview-container.bg-checkered{background-image:linear-gradient(45deg,#252526 25%,transparent 25%),linear-gradient(-45deg,#252526 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#252526 75%),linear-gradient(-45deg,transparent 75%,#252526 75%)}.image-preview-container.bg-black{background:#000!important}.image-preview-container.bg-white{background:#fff!important}.preview-image{position:absolute;box-shadow:0 4px 12px #00000026;background-color:transparent;will-change:transform,opacity;transition:transform .05s ease-out,opacity .2s ease-in;cursor:grab;max-width:none;max-height:none;opacity:0}.preview-image:active{cursor:grabbing}.image-hud{position:absolute;bottom:20px;right:20px;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;padding:6px 12px;border-radius:6px;font-family:var(--font-mono);font-size:11px;display:flex;gap:15px;pointer-events:none;z-index:30;border:1px solid rgba(255,255,255,.1)}.hud-item span{color:#9ca3af;margin-right:4px}.image-msg{color:var(--color-text-secondary);font-size:14px;background:var(--color-bg-secondary);padding:10px 20px;border-radius:6px;box-shadow:0 2px 4px #0000001a}.image-msg.error{color:#ef4444}.dashboard-container{display:flex;width:850px;height:600px;max-height:85vh;max-width:95vw;background-color:var(--color-bg-secondary);border-radius:8px;box-shadow:0 15px 30px #0000001f;overflow:hidden}.dashboard-sidebar{width:220px;background-color:var(--color-bg-primary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:20px;flex-shrink:0}body.dark .dashboard-sidebar{background-color:var(--color-bg-tertiary)}.dash-content{overflow-y:auto;scrollbar-width:thin;padding:0 30px 30px}.dashboard-user-profile{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--color-border)}.dashboard-avatar{width:32px;height:32px;border-radius:6px;background-color:var(--color-border-active);color:#fff;display:grid;place-items:center;font-weight:600;font-size:16px}.dashboard-user-info{display:flex;flex-direction:column;overflow:hidden}.dashboard-name{font-weight:600;font-size:13px;color:var(--color-text-primary)}.dashboard-email{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-nav{display:flex;flex-direction:column;gap:4px;flex-grow:1}.dash-tab-btn{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid transparent;border-radius:6px;color:var(--color-text-secondary);text-align:left;font-size:13px;font-weight:500;transition:all .1s}.dash-tab-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.dash-tab-btn.active{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}body.dark .dash-tab-btn.active{background-color:#ffffff0d;color:var(--color-text-primary);border:1px solid var(--color-border)}body.dark .dash-tab-btn:hover{background-color:#ffffff0d}.dashboard-footer{margin-top:auto;padding-top:15px;border-top:1px solid var(--color-border)}.dash-footer-btn{width:100%;display:flex;align-items:center;gap:10px;padding:8px;color:var(--color-text-secondary);font-size:13px;border-radius:4px;transition:color .1s;border:solid 1px transparent;white-space:nowrap}.dash-footer-btn:hover{color:#ef4444;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border)}body.dark .dash-footer-btn:hover{color:#ef4444;background-color:#ffffff0d;border:1px solid var(--color-border)}.dashboard-main{flex-grow:1;padding:0;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:rgb(157 157 157) transparent}.dash-pane{display:none;flex-direction:column;height:100%}.dash-pane.active{display:flex}.pm-header{display:flex;justify-content:space-between;align-items:center;padding:30px 30px 20px;height:80px}.pm-header-left{display:flex;align-items:center;gap:8px;flex-grow:1}.pm-header-right{display:flex;align-items:center;justify-content:flex-end}.pm-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap}.dash-section-header{margin-bottom:20px;display:flex;height:32px;align-items:center}.dash-section-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.pm-search-wrapper,.pm-create-wrapper{display:flex;align-items:center}.pm-input-container{display:flex;align-items:center;gap:6px;position:relative}@keyframes expandWidth{0%{opacity:0;transform:scaleX(.9)}to{opacity:1;transform:scaleX(1)}}.pm-input-animated{height:32px;padding:0 10px;border:1px solid var(--color-border);border-radius:6px;background-color:var(--color-bg-primary);color:var(--color-text-primary);font-size:13px;outline:none;width:200px;font-family:inherit;transition:box-shadow .1s,border-color .1s}#pm-search-input{padding-right:24px}#pm-search-clear{position:absolute;right:12px;color:var(--color-text-dim);cursor:pointer;font-size:12px;display:none}#pm-search-clear:hover{color:var(--color-text-primary)}#pm-new-name{width:160px}#pm-create-btn,#task-create-toggle,#support-create-toggle{padding:6px 8px;margin-left:2px;font-size:15px}#pm-confirm-create{padding:7px 12px;margin-left:2px}#task-create-btn{padding:6px 8px;margin-left:2px;font-size:15px}.pm-rename-input{border:1px solid var(--color-border-active)!important;outline:none!important;background-color:var(--color-bg-secondary)!important;color:var(--color-text-primary)!important;box-shadow:none!important}.project-list{display:flex;flex-direction:column;gap:12px}.project-card{display:flex;align-items:center;padding:12px 16px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;transition:background-color .1s}.project-card:hover{background-color:var(--color-bg-primary)}body.dark .project-card:hover{background-color:var(--color-bg-tertiary)}.project-card.active-project{background-color:var(--color-bg-primary);cursor:default}body.dark .project-card.active-project{background-color:var(--color-bg-tertiary);cursor:default}.project-icon{font-size:18px;color:var(--color-text-secondary);margin-right:12px;display:flex;justify-content:center}.project-card.active-project .project-icon{color:#3b82f6}.project-info{flex-grow:1;padding:0;display:flex;flex-direction:column;justify-content:center;min-width:0}.project-size-col{display:flex;flex-direction:column;justify-content:center;min-width:80px;padding:0 10px;border-left:1px solid var(--color-bg-tertiary);border-right:1px solid var(--color-bg-tertiary);margin-right:10px}body.dark .project-size-col{border-left-color:var(--color-border);border-right-color:var(--color-border)}.size-label{font-size:11px;color:var(--color-text-dim);font-weight:600;letter-spacing:.5px}.size-value{font-size:13px;font-weight:500;color:var(--color-text-secondary);margin-top:2px}.project-title-row{display:flex;align-items:center;gap:8px}.project-name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.current-badge{font-size:10px;padding:2px 6px;background-color:#16a34a;border:1px solid #16a34a;border-radius:4px;color:#fff;text-transform:uppercase;font-weight:600}.project-meta{font-size:12px;color:var(--color-text-dim);margin-top:2px}.project-actions{display:flex;gap:5px;opacity:1;transition:opacity .2s}.card-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--color-text-secondary);background:transparent;border:solid 1px var(--color-border)}.card-btn:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}body.dark .card-btn:hover{background-color:#4141416b;color:var(--color-text-primary)}.card-btn.delete:hover{color:#ef4444!important}.dash-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:20px}.dash-card h3{margin:0 0 15px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.account-profile-row{display:flex;gap:20px;align-items:flex-start}.account-avatar-large{width:48px;height:48px;border-radius:50%;background-color:var(--color-border-active);color:#fff;font-size:24px;font-weight:600;display:grid;place-items:center;flex-shrink:0}.account-details{flex-grow:1;display:flex;flex-direction:column;gap:15px}.input-with-copy{display:flex;gap:8px}.settings-row{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-bg-tertiary)}.settings-row:last-child{border-bottom:none}.settings-label{display:block;margin:0 0 10px;font-weight:600;font-size:14px;color:var(--color-text-primary)}.settings-desc{font-size:12px;color:var(--color-text-secondary);margin:2px 0 0}.dash-card.danger-zone{border-color:#fca5a5;background-color:#fff9f9}body.dark .dash-card.danger-zone{border-color:#7f1d1d;background-color:#450a0a33}.editor-skeleton{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-bg-secondary);font-family:var(--font-mono);font-size:14px;padding-top:16px}.skeleton-row{display:flex;align-items:center;height:19px;margin-bottom:2px}.skeleton-linenumber{width:65px;padding-right:23px;text-align:right;color:var(--color-text-dim);flex-shrink:0;-webkit-user-select:none;user-select:none;opacity:.7}.skeleton-code{height:16px;border-radius:4px;background:linear-gradient(90deg,transparent 33%,rgba(0,0,0,.06) 50%,transparent 66%) var(--color-bg-tertiary);background-size:300% 100%;animation:skeleton-shimmer 2s infinite linear}body.dark .skeleton-code{background:linear-gradient(90deg,transparent 33%,rgba(255,255,255,.05) 50%,transparent 66%) var(--color-bg-tertiary);background-size:300% 100%}@keyframes skeleton-shimmer{0%{background-position:right}}.header-status{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--color-text-secondary);opacity:0;transition:opacity .2s ease-in-out;pointer-events:none}.header-status.visible{opacity:1}.header-status.success{color:#16a34a}.header-status .fa-spin{animation-duration:1.5s}.modal-header h2{margin:0 0 15px;font-size:18px;color:var(--color-text-primary)}.modal-input{width:100%;padding:8px 10px;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.form-hint{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.progress-label-row{display:flex;justify-content:space-between;font-size:13px;color:var(--color-text-primary);margin-bottom:5px}.progress-track{width:100%;height:8px;background-color:var(--color-bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:#16a34a;width:0%;transition:width .1s linear}.modal-overlay.is-locked{cursor:not-allowed}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.modal-content.shake{animation:shake .3s ease-in-out}.notification-layout{display:flex;gap:30px;align-items:flex-start;padding:10px 0}.notification-icon{font-size:32px;flex-shrink:0;margin-top:2px}.notification-icon .info{color:var(--color-border-active)}.notification-icon .success{color:#16a34a}.notification-icon .error{color:#d94b3c}.notification-icon .warning{color:#f2bb30}.notification-icon .promo{color:#8b5cf6}.notification-content{flex-grow:1;display:flex;gap:20px;flex-direction:column}.notification-title{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.notification-message{margin:0;font-size:14px;line-height:1.8}.usage-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:20px}.usage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.usage-title{font-weight:600;color:var(--color-text-primary);font-size:14px}.usage-stats{font-size:13px;color:var(--color-text-secondary);font-family:var(--font-mono)}.usage-track{width:100%;height:12px;background-color:var(--color-bg-tertiary);border-radius:6px;overflow:hidden;position:relative}.usage-fill{height:100%;background-color:#16a34a;width:0%;transition:width .5s ease-out,background-color .3s}.usage-fill.warning{background-color:#f59e0b}.usage-fill.danger{background-color:#ef4444}.plan-hero{background:linear-gradient(135deg,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 100%);border:1px solid var(--color-border);border-radius:8px;padding:24px;display:flex;align-items:center;gap:20px}.plan-hero.pro-tier{background:linear-gradient(135deg,#1e293b,#0f172a);border-color:#334155;color:#fff}.plan-hero.pro-tier h3,.plan-hero.pro-tier p{color:#fff}.plan-badge{font-size:11px;font-weight:700;text-transform:uppercase;padding:4px 8px;border-radius:4px;letter-spacing:.5px}.plan-badge.free{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.plan-badge.pro{background-color:#fbbf24;color:#92400e;border:1px solid #f59e0b}.plan-info h3{margin:0 0 4px;font-size:18px}.plan-info p{margin:0;font-size:13px;color:var(--color-text-secondary)}.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin:20px 0}.feature-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-text-secondary);text-align:left}.feature-item i{color:#16a34a;width:16px;text-align:center}.feature-item.locked i{color:var(--color-text-dim)}.upgrade-card{border:1px solid rgba(22,163,74,.25);background-color:#d1f7d169;border-radius:8px;padding:24px;text-align:center}body.dark .upgrade-card{background-color:#16a34a1a;border-color:#16a34a40}.upgrade-price{font-size:28px;font-weight:700;color:var(--color-text-primary);margin:10px 0}.upgrade-period{font-size:14px;font-weight:400;color:var(--color-text-secondary)}.plans-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px}.plan-card-header{margin-bottom:15px;border-bottom:1px solid var(--color-border);padding-bottom:15px}.plan-card-header h3{margin:0;font-size:22px;color:var(--color-text-primary);padding-bottom:3px}.plan-card-price{font-size:14px;color:var(--color-text-secondary);margin-top:10px}.free-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:24px;display:flex;flex-direction:column;text-align:center}.upgrade-card{display:flex;flex-direction:column}.features-list-vertical{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;flex-grow:1}.feature-item.muted{color:var(--color-text-dim)}#repl-wrapper .xterm-viewport,#repl-wrapper .xterm-screen,#output-wrapper .xterm-viewport,#output-wrapper .xterm-screen{background-color:transparent!important}#repl-wrapper .xterm-rows,#output-wrapper .xterm-rows{color:var(--color-text-output)!important}#output-wrapper,#repl-wrapper{width:100%;height:100%;margin:0;padding:0;font-family:var(--font-mono);font-size:var(--editor-font-size);overflow:hidden}#output-wrapper.static-mode{overflow-y:auto}#interactive-console{height:100%;width:100%;margin:0;box-sizing:border-box;outline:none}#output-wrapper h1,#output-wrapper h2,#output-wrapper h3{color:var(--color-text-output);margin-top:.5em;margin-bottom:.5em}.console-progress-bar{position:absolute;top:0;left:0;right:0;height:4px;background-color:transparent;overflow:hidden;z-index:10;opacity:0;transition:opacity .2s;pointer-events:none}.console-progress-bar.active{opacity:1}.console-progress-bar:after{content:"";position:absolute;top:0;left:0;bottom:0;width:30%;background-color:var(--color-border-active);animation:indeterminate 1.5s infinite linear;transform:translate(-100%)}@keyframes indeterminate{0%{transform:translate(-100%);width:30%}50%{width:50%}to{transform:translate(350%);width:30%}}.static-close-btn{position:sticky;top:15px;right:15px;float:right;z-index:50;width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background-color:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background-color .2s,color .2s}.static-close-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.auth-form .form-group{margin-bottom:15px}.project-skeleton{width:80px;height:16px;border-radius:4px;background-color:var(--color-bg-tertiary);background:linear-gradient(90deg,transparent 33%,rgba(0,0,0,.06) 50%,transparent 66%) var(--color-bg-tertiary);background-size:300% 100%;animation:skeleton-shimmer 2s infinite linear}body.dark .project-skeleton{background:linear-gradient(90deg,transparent 33%,rgba(255,255,255,.05) 50%,transparent 66%) var(--color-bg-tertiary);background-size:300% 100%}.project-selector-btn .project-skeleton{margin:1px 0}.editor-toolbar{position:absolute;top:10px;right:20px;z-index:25;display:flex;align-items:center;gap:4px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;padding:3px;opacity:0;transition:opacity .3s ease-in-out;box-shadow:0 1px 2px #0000001a}.pane-group:hover .editor-toolbar{opacity:.8}.editor-toolbar:hover{opacity:1!important}.editor-toolbar-btn{width:24px;height:24px;display:grid;place-items:center;color:var(--color-text-secondary);border-radius:4px;font-size:13px;cursor:pointer}.editor-toolbar-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.editor-toolbar.toolbar-intro{opacity:1!important}.pane-controls-container{margin-left:auto;display:flex;align-items:center;padding:0 0 0 5px;position:sticky;right:0;background-color:var(--color-bg-secondary);z-index:5;height:34px}body.dark .pane-controls-container{background-color:var(--color-bg-secondary)}.pane-control-btn{padding:6px;margin-right:5px;color:var(--color-icon);border-radius:4px;font-size:14px;cursor:pointer;display:grid;place-items:center;width:28px;height:28px;transition:all .2s}.pane-control-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.pane-control-btn.active{color:var(--color-icon);font-size:13px}.pane-control-btn.active:hover{color:var(--color-text-primary);font-size:13px}.terminal-wrapper{display:flex;flex-direction:column;width:100%;height:100%;overflow:hidden}.terminal-top-spacer{height:18px;width:100%;flex-shrink:0;background:transparent}.terminal-layout{display:flex;flex-direction:row;flex-grow:1;width:100%;overflow:hidden}.terminal-spacer{width:16px;flex-shrink:0;background:transparent}.terminal-target{flex-grow:1;height:100%;overflow:hidden;position:relative}.xterm-viewport{z-index:5!important;cursor:default}.xterm-screen{z-index:1!important;box-sizing:border-box;padding:0!important}#output-log-container{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;padding:16px 10px 10px 18px;font-family:var(--font-mono);font-size:var(--editor-font-size);color:var(--color-text-output);line-height:1.5;background-color:transparent;display:block}.log-line{white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere;min-height:1.5em;display:block}.log-line.system{color:var(--color-text-secondary);font-style:italic;margin-bottom:4px}.log-span{display:inline}.log-input{display:inline;outline:none;background:transparent;color:var(--color-text-primary);font-family:inherit;font-size:inherit;white-space:pre-wrap;word-break:break-all;min-width:1px;display:inline-block;vertical-align:baseline;padding-right:1px}.log-input:focus{caret-color:var(--color-text-primary)}.log-input:hover{cursor:text}.log-input:focus{box-shadow:none!important}.log-plot-container{margin:10px 0;max-width:100%;border:1px solid var(--color-border);border-radius:4px;overflow:hidden;background-color:#fff}.log-plot-container iframe{border:none;width:100%;height:500px;display:block}.tasks-table{width:100%;border-collapse:collapse;font-size:13px}.tasks-table th{text-align:left;padding:10px 5px;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);font-weight:600}.tasks-table td{padding:10px 5px;border-bottom:1px solid var(--color-bg-tertiary);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.tasks-table .mono-text{font-family:var(--font-mono)}.status-badge{padding:4px 6px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.status-badge.success{background-color:#d1fae5;color:#065f46}.status-badge.error{background-color:#fee2e2;color:#991b1b}.status-badge.pending,.status-badge.running{background-color:#f3f4f6;color:#4b5563;padding:6px 10px;font-size:12px!important}.actions-cell{display:flex;gap:4px;justify-content:flex-end}.modal-body{margin-bottom:30px}.form-group{margin-bottom:20px}.task-log-viewer{background-color:var(--color-bg-tertiary);color:var(--color-text-output);padding:12px;border-radius:4px;border:1px solid var(--color-border);font-family:var(--font-mono);font-size:12px;line-height:1.5;overflow-y:auto;max-height:300px;white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere}.notification-confirm-btn{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-border);padding:8px 12px;align-items:center;min-width:70px}.notification-confirm-btn:hover{background-color:#dadfe7}body.dark .notification-confirm-btn:hover{background-color:#414141c2}.hosting-status-row{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-bg-primary);padding:15px;border-radius:6px;margin-bottom:15px}.status-indicator-wrapper{display:flex;align-items:center;gap:10px}.status-dot{width:12px;height:12px;border-radius:50%;background-color:#9ca3af}.status-dot.active{background-color:#16a34a;box-shadow:0 0 0 4px #dcfce7}.hosting-url{font-family:var(--font-mono);color:#3b82f6;text-decoration:none;font-size:13px}.hosting-url:hover{text-decoration:underline}.hosting-actions{display:flex;gap:10px}.hosting-card .project-actions{gap:4px}.create-card{flex-direction:column;align-items:stretch;cursor:default;background-color:var(--color-bg-secondary);padding:12px 16px;border:1px solid var(--color-border);border-radius:4px;transition:background-color .1s}.create-card-title{margin:0 0 15px;font-size:14px;font-weight:600;color:var(--color-text-primary);border-bottom:1px solid var(--color-bg-tertiary);padding-bottom:10px}.create-form-grid{display:flex;flex-direction:column}.create-actions{display:flex;justify-content:flex-end;gap:10px}.input-group-suffix{padding:6px 10px;font-family:Fira Code;font-size:14px;color:var(--color-text-primary)}.dash-input{width:100%;padding:8px;background-color:var(--color-bg-tab-primary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:13px;outline:none}.hosting-card-cockpit{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s;cursor:default}.cockpit-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-bg-tertiary)}.cockpit-identity{display:flex;align-items:baseline;gap:10px;flex-direction:row}.cockpit-identity h3{margin:0;font-size:16px;font-weight:500;color:var(--color-text-primary)}.production-tag,.legacy-tag{font-size:10px;text-transform:uppercase;font-weight:600;color:var(--color-text-secondary);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:3px 6px;border-radius:4px;letter-spacing:.5px}.cockpit-badge{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:20px;background-color:var(--color-bg-tertiary);font-size:13px;font-weight:500;color:var(--color-text-secondary);transition:all .3s ease}.status-indicator{width:10px;height:10px;border-radius:50%;background-color:#9ca3af}.cockpit-badge.active{background-color:#dcfce7;color:#166534}.cockpit-badge.active .status-indicator{background-color:#16a34a;box-shadow:0 0 #16a34ab3;animation:pulse-green 2s infinite}.cockpit-badge.deploying{background-color:#dbeafe;color:#1e40af}.cockpit-badge.deploying .status-indicator{background-color:#3b82f6;animation:pulse-blue 2s infinite}.cockpit-badge.failed{background-color:#fee2e2;color:#991b1b}.cockpit-badge.failed .status-indicator{background-color:#ef4444}@keyframes pulse-green{0%{transform:scale(.95);box-shadow:0 0 #16a34ab3}70%{transform:scale(1);box-shadow:0 0 0 4px #16a34a00}to{transform:scale(.95);box-shadow:0 0 #16a34a00}}@keyframes pulse-blue{0%{transform:scale(.95);box-shadow:0 0 #3b82f6b3}70%{transform:scale(1);box-shadow:0 0 0 4px #3b82f600}to{transform:scale(.95);box-shadow:0 0 #3b82f600}}body.dark .cockpit-badge.active{background-color:#14532d;color:#dcfce7}body.dark .cockpit-badge.deploying{background-color:#1e3a8a;color:#dbeafe}body.dark .cockpit-badge.failed{background-color:#7f1d1d;color:#fee2e2}.cockpit-stage{padding:20px;background-color:#f2f5f882;border-bottom:1px solid var(--color-bg-tertiary)}body.dark .cockpit-stage{background-color:#2121217a}.cockpit-stage label{display:block;margin-bottom:8px}.cockpit-url-bar{display:flex;align-items:center;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;margin-bottom:12px;transition:border-color .2s,box-shadow .2s}.project-pill{color:var(--color-text-secondary);border-right:1px solid var(--color-border);padding:2px 8px;font-size:12px;font-weight:500;margin-right:2px;max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;line-height:22px;height:24px;vertical-align:middle;-webkit-user-select:none;user-select:none}.url-text{flex-grow:1;font-family:var(--font-mono);font-size:13px;color:var(--color-text-primary);padding:8px 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:none;background:transparent}code.url-text{display:block;cursor:text}.url-actions{display:flex;gap:4px}.url-action-btn{width:28px;height:28px;display:grid;place-items:center;border-radius:4px;color:var(--color-text-secondary);background-color:transparent;cursor:pointer;transition:all .1s;text-decoration:none;border:none;margin:4px}.url-action-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.cockpit-controls{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background-color:var(--color-bg-secondary)}.controls-group{display:flex;gap:8px}.cockpit-url-bar.editing{background-color:var(--color-bg-primary);padding:0}.cockpit-url-bar.disabled{background-color:var(--color-bg-primary);cursor:default}.url-input{width:100%;border:none;padding:8px 12px;font-size:14px;color:var(--color-text-primary);outline:none;border-radius:6px}.url-input.monospace{font-family:var(--font-mono);font-size:13px}.url-text.locked{-webkit-user-select:none;user-select:none;font-size:13px}.empty-state-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;border:1px dashed var(--color-border);border-radius:8px;background-color:var(--color-bg-primary);text-align:center;min-height:300px}body.dark .empty-state-card{background-color:var(--color-bg-tertiary)}.empty-state-icon{font-size:48px;color:var(--color-text-secondary);margin-bottom:20px;opacity:.5}.empty-state-card h3{margin:0 0 10px;color:var(--color-text-primary);font-size:18px;font-weight:600}.empty-state-card p{color:var(--color-text-secondary);margin-bottom:25px;font-size:14px;max-width:300px;line-height:1.5}.task-path-display{flex-grow:1;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;padding:6px 12px;margin:0 15px;display:flex;align-items:center;gap:8px;min-width:0}.task-path-display i{color:var(--color-text-dim);font-size:12px}.task-path-display span{font-family:var(--font-mono);font-size:12px;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-card .project-info{flex:0 0 180px;min-width:180px}.task-card-cockpit{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s;cursor:default;margin-bottom:20px}.task-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.task-meta-item{display:flex;flex-direction:column;gap:6px}.task-meta-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px}.task-meta-value{font-size:14px;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.task-meta-value i{color:var(--color-text-dim)}.stage-label-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.stage-label-row label{margin-bottom:0}.last-run-text{font-size:11px;color:var(--color-text-secondary);font-weight:500}.task-body-flex{display:flex;gap:12px;align-items:flex-end}.task-main-col{flex-grow:1;min-width:0}.task-card-cockpit .cockpit-stage{border-bottom:none}.account-grid-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.dash-card .form-group:last-child{margin-bottom:0}.input-overlay-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;padding:4px;font-size:13px;transition:color .2s;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:4px}.input-overlay-btn:hover{color:var(--color-text-primary);border:1px solid var(--color-border)}.editor-toolbar-btn.disabled{opacity:.3;pointer-events:none;cursor:not-allowed}.action-btn#run-btn[disabled]{background-color:var(--color-bg-tertiary);color:var(--color-text-dim);border-color:var(--color-border);cursor:not-allowed}#terminal-wrapper{width:100%;height:100%;margin:0;padding:0;font-family:var(--font-mono);font-size:var(--editor-font-size);overflow:hidden}#terminal-wrapper .xterm-viewport,#terminal-wrapper .xterm-screen{background-color:transparent!important}#terminal-wrapper .xterm-rows{color:var(--color-text-output)!important}.ticket-card-cockpit{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;display:flex;flex-direction:column;overflow:hidden;transition:background-color .2s,box-shadow .2s;cursor:pointer;margin-bottom:12px}body.dark .ticket-card-cockpit{background-color:var(--color-bg-tertiary)}.ticket-status-badge{font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.ticket-category-badge{font-size:12px;font-weight:700;padding:2px 6px;border-radius:4px;background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.ticket-status-badge.open{background-color:#fef4e2;color:#99771b;border:1px solid #c5ae7e}.ticket-status-badge.answered{background-color:#dbeafe;color:#4660b2;border:1px solid #93c5fd}.ticket-status-badge.resolved{background-color:#dcfce7;color:#166534;border:1px solid #86efac}body.dark .ticket-status-badge.open{background-color:#443e2e;color:#e5d1ad;border-color:#716547}body.dark .ticket-status-badge.answered{background-color:#2c3547;color:#accaec;border-color:#445cab}body.dark .ticket-status-badge.resolved{background-color:#124727;color:#a7e5bd;border-color:#1d783f}.ticket-thread-view{display:flex;flex-direction:column;height:100%;min-height:400px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.ticket-thread-header{padding:15px 20px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;background:var(--color-bg-primary)}.ticket-thread-messages{flex-grow:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px;background:var(--color-bg-primary)}.chat-message{max-width:85%;display:flex;flex-direction:column}.chat-message.user{align-self:flex-end;align-items:flex-end}.chat-message.admin{align-self:flex-start;align-items:flex-start}.chat-bubble{padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.chat-message.user .chat-bubble{background-color:#3b82f6;color:#fff;border-bottom-right-radius:2px}.chat-message.admin .chat-bubble{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);border-bottom-left-radius:2px}.chat-meta{font-size:11px;color:var(--color-text-dim);margin-top:6px}.ticket-reply-box{padding:15px 20px;background:var(--color-bg-secondary);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:10px}.ticket-reply-box textarea{width:100%;min-height:80px;resize:vertical;padding:10px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-tab-primary);color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none}.ticket-reply-box textarea:focus{border-color:var(--color-border-active)}.thread-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000005e;z-index:2100;display:flex;align-items:center;justify-content:center;padding:40px}.thread-modal{background:var(--color-bg-secondary);width:100%;max-width:800px;height:85vh;border-radius:12px;display:flex;flex-direction:column;border:1px solid var(--color-border);overflow:hidden;box-shadow:0 5px 15px #0000004d;background-color:transparent}.thread-modal-header{padding:20px 20px 15px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:flex-start;background:var(--color-bg-primary)}.thread-modal-content{flex-grow:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px;background:var(--color-bg-secondary)}.thread-modal-footer{padding:20px;background:var(--color-bg-primary);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:10px}.thread-reply-input{width:100%;min-height:80px;padding:12px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-primary);font-family:inherit;font-size:14px;outline:none;resize:vertical}.thread-reply-input:focus{border-color:var(--color-border-active);box-shadow:0 0 0 2px var(--color-border-active-dim)}.chat-message.user .chat-bubble{background-color:#3b82f6;color:#fff}.chat-message.admin .chat-bubble{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}@media (max-width: 768px){.ide-container{display:flex!important;flex-direction:column!important;padding:8px 0!important}.gutter-col{display:none!important}.sidebar{position:fixed;top:var(--header-height-mobile);left:0;bottom:30px;width:85vw;max-width:320px;z-index:1000;margin:0!important;border-radius:0!important;border:none!important;border-top:1px solid var(--color-border)!important;border-right:1px solid var(--color-border)!important;border-bottom:1px solid var(--color-border)!important;transform:translate(0);transition:transform .3s ease-in-out,box-shadow .3s ease-in-out}.ide-container.sidebar-hidden .sidebar{transform:translate(-110%);box-shadow:none}.ide-container:before{content:"";position:fixed;top:var(--header-height-mobile);left:0;right:0;bottom:30px;background:#0000005e;z-index:999;opacity:1;transition:opacity .3s ease-in-out;pointer-events:auto}.ide-container.sidebar-hidden:before{opacity:0;pointer-events:none}.main-content{margin-top:0!important;flex-grow:1;width:100vw}.pane-group{border-radius:0;border-left:none;border-right:none}.brand-title{display:none!important}.project-selector-btn{max-width:100px!important}.ide-header{padding:8px 5px 0!important}#python-version-status,#python-version-separator{display:none!important}.split-layout{flex-direction:column!important}.split-layout>.gutter{width:100%!important;height:var(--gutter-size)!important;cursor:row-resize!important}.pane-group:focus-within .editor-toolbar,.pane-group.is-focused .editor-toolbar{opacity:.8!important}.editor-toolbar:active{opacity:1!important}.modal-content{min-width:0!important;width:100%!important;border:none!important;padding:15px!important;display:flex;flex-direction:column;overflow-y:auto;margin:0 20px}#auth-modal-content .modal-content{height:auto!important;max-height:90vh!important;border-radius:8px!important;margin:20px}.dashboard-container{flex-direction:column!important;width:90vw!important;height:85vh!important;height:85dvh!important;max-width:none!important;max-height:none!important;margin:auto}.dashboard-sidebar{width:100%!important;flex-direction:row!important;padding:10px!important;border-right:none!important;border-bottom:1px solid var(--color-border)!important;overflow-x:auto!important;align-items:center!important}.dashboard-sidebar::-webkit-scrollbar{display:none}.dashboard-user-profile{margin-bottom:0!important;padding-bottom:0!important;border-bottom:none!important;padding-right:10px!important;border-right:1px solid var(--color-border)!important;margin-right:10px!important}.dashboard-user-info{display:none!important}.dashboard-nav{flex-direction:row!important;gap:5px!important}.dash-tab-btn{white-space:nowrap!important;padding:6px 12px!important}.dashboard-footer{margin-top:0!important;padding-top:0!important;border-top:none!important;border-left:1px solid var(--color-border)!important;padding-left:10px!important;margin-left:10px!important}.dash-pane{padding:0!important}.pm-header{flex-direction:row!important;align-items:flex-start!important;height:auto!important;gap:15px!important;padding:15px 20px!important}.pm-header-right,.pm-search-wrapper,.pm-create-wrapper{justify-content:flex-start!important}.pm-input-animated{width:100%!important}.account-grid-row,.plans-comparison,.features-grid,.create-form-grid,.task-meta-grid{grid-template-columns:1fr!important}.form-group input,.form-group select{width:100%!important}.hosting-card-cockpit .cockpit-controls{flex-direction:row!important;gap:10px!important}#manage-toggle-btn{min-width:115px!important}.controls-group{justify-content:center!important}.dash-content{padding:0 20px 20px}.pm-header h2{margin:5px 0}.project-card{flex-wrap:wrap!important;gap:10px!important;padding:15px!important}.project-info{min-width:60%!important}.project-title-row{flex-wrap:wrap}.project-size-col{border-left:none!important;border-right:none!important;padding:0!important;margin:0!important;flex-direction:row!important;align-items:center!important;gap:8px!important;width:100%!important}.project-card .project-actions{width:100%!important;justify-content:center!important;padding-top:12px!important;border-top:1px solid var(--color-border)!important;margin-top:5px!important}.cockpit-header{align-items:flex-start!important;gap:12px!important}.cockpit-identity{flex-direction:column!important}.cockpit-badge{align-self:flex-start!important}.task-body-flex{flex-direction:column!important;align-items:stretch!important}.task-body-flex .project-actions{justify-content:center!important;padding-top:15px!important;border-top:1px solid var(--color-border)!important;margin-top:5px!important}.settings-row{flex-direction:column!important;align-items:flex-start!important;gap:15px!important}.settings-row button{width:100%!important;justify-content:center!important}.ticket-card-cockpit .cockpit-header{flex-direction:column;align-items:flex-start!important;gap:12px!important}.thread-modal-overlay{padding:0!important}.thread-modal{width:100vw!important;height:100dvh!important;max-width:none!important;max-height:none!important;border-radius:0!important;border:none!important}.chat-message{max-width:95%!important}.plan-hero{flex-direction:column!important;text-align:center!important;align-items:center!important}.modal-footer{flex-wrap:wrap!important}.project-size-col{display:none}.modal-content.modal-flush{padding:0!important;margin:0!important}.dashboard-main,.dash-pane,.dash-content{min-height:0!important}.dash-content{flex-grow:1!important;overflow-y:auto!important}}/**
* 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}
