.profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;width:240px;z-index:1000;overflow:hidden}.profile-header{padding:16px;background:linear-gradient(135deg,#f60,#00a8ff);color:#fff}.profile-fullname{font-size:16px;font-weight:700;margin-bottom:6px}.profile-name{font-size:13px;opacity:.95}.dropdown-divider{height:1px;background:#e0e0e0}.dropdown-menu{padding:0}.dropdown-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;cursor:pointer;font-size:14px;font-weight:500;color:#333;transition:all .2s;text-align:left}.dropdown-item:hover{background:linear-gradient(135deg,#00a8ff1a,#00a8ff0d);color:#00a8ff;padding-left:20px}.dropdown-item.logout:hover{background:#fee;color:#c33}.item-icon{font-size:18px;display:inline-flex;align-items:center;justify-content:center}.item-icon svg{width:16px;height:16px}.projects-page{min-height:100vh;background:#f9fafb;display:flex;flex-direction:column}.projects-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:0 var(--spacing-lg);height:60px;display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:18px;font-weight:700;height:40px}.logo-brand{font-size:20px;font-weight:700;color:#f60;letter-spacing:-.3px}.logo-divider{color:#d1d5db;font-weight:300;font-size:20px}.logo-title{color:#333;font-weight:600;font-size:20px;letter-spacing:-.3px}.new-project-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f60;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #f603}.new-project-button:hover{background:#f50;transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.button-icon{font-size:16px}.button-text{font-size:14px}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.profile-button-extended{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f60;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:600;box-shadow:0 2px 4px #f603}.profile-button-extended:hover{background:#f50;transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.projects-container{flex:1;padding:40px;max-width:1400px;margin:0 auto;width:100%;position:relative}.page-title{font-size:32px;font-weight:700;color:#333;margin:0 0 32px;text-align:left}.projects-layout{display:flex;gap:24px;height:100%}.folders-sidebar{width:250px;background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;height:fit-content}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sidebar-header h3{margin:0;font-size:16px;color:#333}.add-folder-button{width:28px;height:28px;background:#00a8ff;color:#fff;border:none;border-radius:6px;font-size:18px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.add-folder-button:hover{background:#0090dd;transform:scale(1.05)}.folder-form{margin-bottom:12px;padding:8px;background:#f9f9f9;border-radius:6px}.folder-form input{width:100%;padding:6px;border:1px solid #ddd;border-radius:4px;font-size:13px;margin-bottom:6px;transition:all .2s}.folder-form input:focus{outline:none;border-color:#00a8ff;box-shadow:0 0 0 3px #00a8ff1a}.folder-form-actions{display:flex;gap:6px}.folder-form-actions button{flex:1;padding:6px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.folder-form-actions button[type=submit]{background:#00a8ff;color:#fff}.folder-form-actions button[type=button]{background:#e0e0e0;color:#666}.folders-list{display:flex;flex-direction:column;gap:4px}.folder-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:all .2s;position:relative}.folder-item-root{font-weight:600}.folder-item-sub{padding-left:28px;position:relative}.folder-item-sub:before{content:"";position:absolute;left:12px;top:50%;width:8px;height:1px;background:#ddd}.folder-item:hover{background:#f5f5f5}.folder-item.active{background:#00a8ff;color:#fff}.folder-item.active .folder-icon{filter:brightness(2)}.folder-item.active .folder-count{color:#fffc}.folder-item.active.folder-item-sub:before{background:#ffffff80}.folder-main{display:flex;align-items:center;gap:8px;flex:1}.folder-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center}.folder-icon svg{width:16px;height:16px}.folder-name{flex:1;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-count{font-size:12px;color:#999}.folder-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.folder-item:hover .folder-actions{opacity:1}.folder-actions button{background:#e0e0e0;border:none;border-radius:3px;width:24px;height:24px;cursor:pointer;font-size:12px;color:#666;display:flex;align-items:center;justify-content:center}.folder-actions button svg{width:14px;height:14px}.folder-actions button:hover{background:#d0d0d0}.folder-edit-input{width:100%;padding:6px;border:2px solid #00A8FF;border-radius:4px;font-size:13px;transition:all .2s}.folder-edit-input:focus{outline:none;box-shadow:0 0 0 3px #00a8ff1a}.projects-main{flex:1}.breadcrumb{font-size:14px;color:#666;margin-bottom:8px}.breadcrumb-link{color:#00a8ff;cursor:pointer;text-decoration:underline}.breadcrumb-separator{margin:0 8px;color:#ccc}.error-message{background:#fee;color:#c33;padding:16px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-message button{padding:6px 12px;background:#c33;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.projects-actions{margin-bottom:30px}.create-project-button{padding:12px 24px;background:#f60;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #f603}.create-project-button:hover{background:#f50;transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.create-project-form{display:flex;gap:10px;background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 12px #0000001a;border:1px solid #e5e7eb}.create-project-form input{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s}.create-project-form input:focus{outline:none;border-color:#00a8ff;box-shadow:0 0 0 3px #00a8ff1a}.create-project-form button{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.create-project-form button[type=submit]{background:#f60;color:#fff;box-shadow:0 2px 4px #f603}.create-project-form button[type=submit]:hover{background:#f50;transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.create-project-form button[type=button]{background:#9ca3af;color:#fff;box-shadow:0 2px 4px #9ca3af33}.create-project-form button[type=button]:hover{background:#6b7280;transform:translateY(-1px)}.loading{text-align:center;padding:60px 20px;color:#999;font-size:16px}.empty-state{text-align:center;padding:80px 20px;color:#999}.empty-state p{margin:0 0 8px;font-size:18px}.empty-hint{font-size:14px!important;color:#bbb!important}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.project-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border:2px solid transparent;position:relative;transition:all .2s;display:flex;flex-direction:column;overflow:visible;z-index:1}.project-card:has(.move-dialog){z-index:1001}.project-card:hover{box-shadow:0 6px 20px #00a8ff33;transform:translateY(-4px);border-color:#00a8ff}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.project-header h3{margin:0;font-size:18px;color:#333;cursor:pointer;flex:1;word-break:break-word}.project-header h3:hover{color:#00a8ff}.project-actions{display:flex;gap:8px;position:relative}.project-actions button{background:#f0f0f0;border:none;border-radius:4px;width:28px;height:28px;cursor:pointer;font-size:14px;color:#666;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.project-actions button svg{width:14px;height:14px}.project-actions button:hover{background:#e0e0e0}.project-actions button.delete-button:hover{background:#fee;color:#c33}.project-edit input{width:100%;padding:8px;border:2px solid #00A8FF;border-radius:6px;font-size:16px;font-weight:600;transition:all .2s}.project-edit input:focus{outline:none;box-shadow:0 0 0 3px #00a8ff1a}.project-meta{display:flex;justify-content:space-between;font-size:13px;color:#999;margin-bottom:16px}.open-button{padding:12px;background:#00a8ff;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:auto;box-shadow:0 2px 4px #00a8ff33}.open-button:hover{background:#0090dd;transform:translateY(-2px);box-shadow:0 4px 12px #00a8ff66}.public-badge{margin-left:8px;font-size:14px;display:inline-flex;align-items:center;justify-content:center;color:#00a8ff}.public-badge svg{width:16px;height:16px}.move-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:transparent;cursor:default}.move-dialog{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:2px solid #00A8FF;border-radius:12px;padding:0;box-shadow:0 8px 24px #00a8ff40;z-index:1000;min-width:220px;display:flex;flex-direction:column;gap:0;white-space:nowrap;overflow:hidden}.move-dialog p{margin:0;padding:14px 16px;font-size:14px;font-weight:600;color:#fff;background:#00a8ff;border-bottom:1px solid rgba(0,0,0,.1)}.move-dialog button{padding:12px 16px;border:none;border-bottom:1px solid #f0f0f0;background:#fff;cursor:pointer;font-size:13px;text-align:left;transition:all .2s;color:#333;display:flex;align-items:center;gap:6px}.move-dialog button svg{width:14px;height:14px;flex-shrink:0}.move-dialog button:last-of-type{border-bottom:none}.move-dialog button:hover:not(:disabled){background:#00a8ff1a;color:#00a8ff;font-weight:600}.move-dialog button:disabled{opacity:.5;cursor:not-allowed;background:#f9f9f9}.move-dialog button.add-folder-inline{background:#00a8ff1a;color:#00a8ff;font-weight:600;margin-top:8px;border:1px solid #00A8FF;border-radius:6px}.move-dialog button.add-folder-inline:hover{background:#00a8ff;color:#fff;transform:translateY(-1px)}.move-dialog button.cancel{background:#9ca3af;color:#fff;font-weight:600;margin-top:4px;border:none}.move-dialog button.cancel:hover{background:#6b7280}.login-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;width:320px;z-index:1000;overflow:hidden}.dropdown-tabs{display:flex;background:#f5f5f5;border-bottom:1px solid #e0e0e0}.dropdown-tabs button{flex:1;padding:12px;background:transparent;border:none;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .2s;border-bottom:2px solid transparent}.dropdown-tabs button.active{color:#00a8ff;border-bottom-color:#00a8ff;background:#fff}.dropdown-form{padding:20px;display:flex;flex-direction:column;gap:12px}.dropdown-error{background:#fee;color:#c33;padding:10px;border-radius:6px;font-size:13px;border:1px solid #fcc}.form-field input{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-field input:focus{outline:none;border-color:#00a8ff}.dropdown-submit{padding:12px;background:#f60;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px;box-shadow:0 2px 4px #f603}.dropdown-submit:hover:not(:disabled){background:#f50;transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.dropdown-submit:disabled{opacity:.6;cursor:not-allowed}.share-button{padding:10px 18px;background:#00a8ff;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #00a8ff33;display:inline-flex;align-items:center;gap:6px}.share-button svg{width:16px;height:16px}.share-button:hover{background:#0090dd;transform:translateY(-1px);box-shadow:0 4px 8px #00a8ff4d}.share-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}.share-dialog{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:500px;box-shadow:0 8px 24px #0003}.share-dialog h3{margin:0 0 20px;font-size:20px;color:#333}.share-toggle{margin-bottom:20px;padding:16px;background:#f9f9f9;border-radius:8px}.share-toggle label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:16px;font-weight:600;color:#333}.share-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer}.share-toggle-hint{margin:8px 0 0 32px;font-size:13px;color:#666}.share-link-section{margin-bottom:20px}.share-link-section label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#333}.share-link-input{display:flex;gap:8px}.share-link-input input{flex:1;padding:10px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:monospace;color:#00a8ff}.share-link-input input:focus{outline:none;border-color:#00a8ff}.share-link-input button{padding:10px 20px;background:#00a8ff;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-width:85px}.share-link-input button:hover{background:#0090dd;transform:translateY(-1px);box-shadow:0 4px 8px #00a8ff4d}.share-link-input button.copied{background:#4caf50;animation:copySuccess .5s ease;cursor:default}.share-link-input button:disabled{cursor:default}@keyframes copySuccess{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.share-dialog-actions{display:flex;justify-content:flex-end}.share-dialog-actions button{padding:10px 24px;background:#f0f0f0;color:#666;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.share-dialog-actions button:hover{background:#e0e0e0}/**
 * 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-container{display:flex;flex-direction:column;height:100%;background:#1e1e1e;border-radius:0 0 8px 8px;overflow:hidden;margin:0 8px 8px}.terminal-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:#252526;border-bottom:1px solid #3e3e42}.terminal-title{font-size:13px;font-weight:600;color:#fff;display:flex;align-items:center;gap:6px}.terminal-status{font-size:11px;color:#4ec9b0;padding:2px 8px;background:#4ec9b01a;border-radius:4px}.terminal-content{flex:1;padding:8px;overflow:hidden}.terminal-content .xterm{height:100%}.terminal-content .xterm-viewport{overflow-y:auto!important}.terminal-content .xterm-viewport::-webkit-scrollbar{width:10px}.terminal-content .xterm-viewport::-webkit-scrollbar-track{background:#1e1e1e}.terminal-content .xterm-viewport::-webkit-scrollbar-thumb{background:#424242;border-radius:5px}.terminal-content .xterm-viewport::-webkit-scrollbar-thumb:hover{background:#4e4e4e}.canvas-panel{display:flex;flex-direction:column;height:100%;background:#1e1e1e;border-radius:8px 8px 0 0;overflow:hidden;margin:0 8px}.canvas-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;text-align:center;padding:2rem}.canvas-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.canvas-placeholder p{margin:0;font-size:.9rem}.canvas-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:#252526;border-bottom:1px solid #3e3e42}.canvas-title{font-size:13px;font-weight:600;color:#fff;display:flex;align-items:center;gap:6px}.canvas-header-right{display:flex;align-items:center;gap:.75rem}.canvas-status{display:flex;align-items:center;gap:.5rem;color:#4caf50;font-size:.85rem}.drawing-indicator{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.canvas-content{flex:1;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;background:#1a1a1a;position:relative;width:100%;height:100%}.canvas-placeholder-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;color:#666;text-align:center;pointer-events:none;z-index:1}.canvas-placeholder-overlay .canvas-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.canvas-placeholder-overlay p{margin:0;font-size:.9rem}.turtle-canvas{background:#fff;z-index:2;max-width:100%;max-height:100%;object-fit:contain;display:block}.canvas-toggle-btn{background:transparent;border:1px solid #3e3e42;color:#fff;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:28px;height:24px}.canvas-toggle-btn:hover{background:#3e3e42;border-color:#555}.canvas-toggle-btn:active{background:#4e4e4e}.canvas-panel.collapsed{flex:0 0 auto;height:auto;min-height:0;max-height:44px;overflow:hidden}.canvas-panel.collapsed .canvas-content{display:none;height:0}.canvas-panel.collapsed .canvas-header{border-bottom:none}.canvas-panel:not(.collapsed){flex:0 1 auto;min-height:200px;max-height:60vh}:root{--color-primary: #00A8FF;--color-primary-hover: #0090DD;--color-primary-light: #33BBFF;--color-secondary: #FF6600;--color-secondary-hover: #FF5500;--color-success: #10b981;--color-error: #ef4444;--color-warning: #FF6600;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-border: #e5e7eb;--color-text: #111827;--color-text-secondary: #6b7280;--color-text-light: #9ca3af;--color-console-bg: #1e1e1e;--color-console-text: #d4d4d4;--color-console-system: #858585;--color-console-error: #f48771;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--border-radius: 6px;--border-radius-sm: 4px;--header-height: 60px;--font-mono: "Fira Code", "Cascadia Code", Consolas, monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background:var(--color-bg)}.ide-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.ide-main{flex:1;overflow:hidden;position:relative}.ide-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:var(--color-text-secondary)}.splash-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:#00a8ff;color:#fff}.splash-powered{font-size:14px;opacity:.9;margin-top:var(--spacing-xs);font-weight:500;letter-spacing:.5px}.splash-content{text-align:center;max-width:400px;padding:var(--spacing-xl)}.splash-logo{margin-bottom:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.splash-logo-image{height:80px;width:auto}.python-logo{font-size:60px;margin-top:var(--spacing-sm)}.splash-logo h1{font-size:36px;font-weight:700;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.2)}.splash-brand{color:#ff6b35}.splash-divider{color:#ffffff80;font-weight:300}.splash-title{color:#fff}.splash-spinner{margin:var(--spacing-lg) 0}.spinner{width:50px;height:50px;margin:0 auto;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.splash-message{font-size:18px;font-weight:600;margin-bottom:var(--spacing-sm)}.splash-message.error{color:#fecaca}.splash-hint{font-size:14px;opacity:.9;margin-top:var(--spacing-sm)}.splash-error{font-size:60px;margin:var(--spacing-lg) 0}.splash-retry-button{margin-top:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-lg);background:#fff;color:var(--color-primary);border:none;border-radius:var(--border-radius);font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.splash-retry-button:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.ide-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--spacing-md);background:#fff;border-bottom:1px solid #e5e7eb;gap:var(--spacing-md)}.header-left,.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:18px;font-weight:700;height:40px;transition:opacity .2s;cursor:pointer}.header-logo:hover{opacity:.8}.logo-image{height:40px;width:auto;object-fit:contain;margin-top:-12px}.logo-brand{font-size:20px;font-weight:700;color:var(--color-secondary);letter-spacing:-.3px}.file-menu-container{position:relative;margin-left:var(--spacing-md)}.file-menu-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#9ca3af;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#fff;box-shadow:0 2px 4px #9ca3af33}.file-menu-button:hover{background:#6b7280;transform:translateY(-1px);box-shadow:0 4px 8px #9ca3af4d}.file-menu-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center}.file-menu-icon svg{width:16px;height:16px}.file-menu-dropdown{position:absolute;top:100%;left:0;margin-top:8px;background:#fff;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;z-index:1000;overflow:hidden}.file-menu-dropdown button{width:100%;padding:12px 16px;background:#fff;border:none;border-bottom:1px solid #f0f0f0;text-align:left;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:12px;color:var(--color-text)}.file-menu-dropdown button:last-child{border-bottom:none}.file-menu-dropdown button:hover{background:linear-gradient(135deg,#00a8ff1a,#00a8ff0d);color:var(--color-primary);padding-left:20px}.menu-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center}.menu-icon svg{width:16px;height:16px}.project-name-container{margin-left:var(--spacing-md);display:flex;align-items:center;min-width:250px;max-width:250px}.project-name-editable{padding:8px 16px;background:linear-gradient(135deg,#00a8ff1a,#00a8ff0d);border:2px solid var(--color-primary);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.project-name-editable.untitled{color:#ef4444;background:linear-gradient(135deg,#ef44441a,#ef44440d);border-color:#ef4444}.project-name-editable.untitled:hover{border-color:#dc2626;background:linear-gradient(135deg,#ef444426,#ef444414)}.project-name-editable:hover{border-color:var(--color-primary-hover);background:linear-gradient(135deg,#00a8ff26,#00a8ff14);transform:translateY(-1px)}.project-name-input{padding:8px 16px;border:2px solid var(--color-primary);border-radius:8px;font-size:14px;font-weight:600;width:100%;color:var(--color-text)}.project-name-input:focus{outline:none;border-color:var(--color-primary-hover);box-shadow:0 0 0 3px #00a8ff1a}.profile-button-extended{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-secondary);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:600;box-shadow:0 2px 4px #f603}.profile-button-extended:hover{background:var(--color-secondary-hover);transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.profile-username{font-size:14px;font-weight:600}.run-controls{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.run-control-button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.run-control-button .button-icon{font-size:14px}.run-control-button .button-text{font-size:14px;color:#fff}.run-control-button.run-button{background:var(--color-secondary)}.run-control-button.run-button:hover:not(:disabled){background:var(--color-secondary-hover);transform:translateY(-1px);box-shadow:0 2px 6px #ff66004d}.run-control-button.clear-button{background:#9ca3af}.run-control-button.clear-button:hover:not(:disabled){background:#6b7280;transform:translateY(-1px);box-shadow:0 2px 6px #9ca3af4d}.run-control-button:disabled{opacity:.5;cursor:not-allowed}.run-control-status{display:flex;align-items:center;gap:var(--spacing-xs);margin-left:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg);border-radius:var(--border-radius-sm);font-size:13px;color:var(--color-text-secondary)}.right-panel-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.right-panel-container>.run-controls{flex-shrink:0}.right-panel-container>.panels-group{flex:1;overflow:hidden}.resize-handle-vertical{height:2px;background:#333;cursor:row-resize;margin:0 8px;transition:background .2s;position:relative;z-index:10}.resize-handle-vertical:hover{background:#00a8ff;height:3px}.logo-divider{color:#d1d5db;margin:0 12px;font-weight:300;font-size:20px}.logo-title{font-size:20px;font-weight:600;color:#333;letter-spacing:-.3px}.header-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.header-button:focus,.header-button:active{outline:none}.header-button:hover:not(:disabled):not(.header-gradient-button){background:var(--color-bg-secondary);border-color:var(--color-primary)}.header-button:disabled{opacity:.5;cursor:not-allowed}.run-button{background:var(--color-secondary);color:#fff;border-color:var(--color-secondary);font-weight:600}.run-button:hover:not(:disabled){background:var(--color-secondary-hover);border-color:var(--color-secondary-hover);transform:translateY(-1px);box-shadow:0 4px 8px #ff6b354d}.run-button:focus,.run-button:active{outline:none;box-shadow:none}.clear-button{background:var(--color-bg-tertiary);color:var(--color-text);border-color:var(--color-border);font-weight:600}.clear-button:hover:not(:disabled){background:var(--color-bg-secondary);border-color:var(--color-primary)}.clear-button:disabled{opacity:.5;cursor:not-allowed}.header-gradient-button{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;border:none;font-weight:600;box-shadow:0 2px 8px #00a8ff33;transition:all .2s ease}.header-gradient-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #00a8ff80;filter:brightness(1.1)}.header-gradient-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #00a8ff4d}.help-button{width:36px;height:36px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.login-button{padding:8px 16px;background:var(--color-secondary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #f603}.login-button:hover{background:var(--color-secondary-hover);transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.profile-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-secondary);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:600;box-shadow:0 2px 4px #f603}.profile-button:hover{background:var(--color-secondary-hover);transform:translateY(-1px);box-shadow:0 4px 8px #ff66004d}.profile-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center}.profile-icon svg{width:16px;height:16px}.button-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center}.button-icon svg{width:16px;height:16px}.header-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:14px;color:var(--color-text-secondary)}.status-spinner{animation:spin 1s linear infinite}.file-panel{height:100%;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column}.file-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.file-panel-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.file-create-button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-secondary);color:#fff;border:none;border-radius:var(--border-radius-sm);font-size:20px;cursor:pointer;transition:all .2s}.file-create-button:hover{background:var(--color-secondary-hover);transform:scale(1.1)}.file-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.file-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);cursor:pointer;transition:background .2s;margin-bottom:2px}.file-item:hover{background:var(--color-bg-tertiary)}.file-item.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff}.file-name{display:flex;align-items:center;gap:var(--spacing-xs);flex:1}.file-icon{font-size:16px}.file-actions{display:none;gap:var(--spacing-xs)}.file-item:hover .file-actions{display:flex}.file-action-button{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--border-radius-sm);cursor:pointer;font-size:14px;transition:background .2s}.file-action-button:hover{background:#0000001a}.file-action-button.delete:hover{background:var(--color-error);color:#fff}.file-edit-input{width:100%;padding:var(--spacing-xs);border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);font-size:14px;font-family:inherit}.file-panel-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-secondary)}.editor-container{height:100%;display:flex;flex-direction:column;background:var(--color-bg)}.editor-tabs{display:flex;gap:2px;padding:var(--spacing-sm) var(--spacing-sm) 0;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.editor-tab{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-bottom:none;border-radius:var(--border-radius-sm) var(--border-radius-sm) 0 0;cursor:pointer;transition:background .2s}.editor-tab.active{background:var(--color-bg)}.editor{flex:1;overflow:hidden}.error-line-highlight{background:#ef44441a!important;border-left:3px solid var(--color-error)}.error-line-glyph{background:var(--color-error);width:4px!important}.error-column-highlight{background:#ef44444d!important;border-bottom:2px solid var(--color-error)}.console-container{height:100%;display:flex;flex-direction:column;background:var(--color-console-bg)}.console-tabs{display:flex;gap:0;background:#2d2d2d;border-bottom:1px solid #1e1e1e}.console-tab{position:relative;padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:#858585;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.console-tab:hover{color:#d4d4d4;background:#ffffff0d}.console-tab.active{color:#d4d4d4;border-bottom:2px solid var(--color-primary)}.console-tab.has-error{color:var(--color-error)}.tab-badge{margin-left:var(--spacing-xs);padding:2px 6px;background:#ffffff1a;border-radius:10px;font-size:11px}.tab-badge.error{background:var(--color-error);color:#fff}.console-tab-content{flex:1;overflow:hidden}.console{height:100%;display:flex;flex-direction:column;background:var(--color-console-bg);color:var(--color-console-text);overflow:hidden}.console-body{flex:1;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.console-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:#2d2d2d;border-bottom:1px solid #1e1e1e}.console-turtle-container{border-bottom:1px solid #1e1e1e;background:#1e1e1e;display:flex;justify-content:center;align-items:center;padding:var(--spacing-sm);flex-shrink:0}.console-title{font-size:14px;font-weight:600;color:#858585}.console-clear-button{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;color:#858585;border:1px solid #3e3e3e;border-radius:var(--border-radius-sm);font-size:12px;cursor:pointer;transition:all .2s}.console-clear-button:hover{background:#ffffff0d;color:#d4d4d4}.console-content{flex:1;min-height:0;padding:var(--spacing-sm)}.console-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-console-system)}.console-logs{font-family:var(--font-mono);font-size:13px;line-height:1.6}.console-log{padding:2px var(--spacing-sm);margin-bottom:1px;word-wrap:break-word;white-space:pre-wrap}.console-log-input-prompt{color:gold;font-weight:600;background:#ffd7001a;padding:4px var(--spacing-sm);margin:2px 0;border-left:3px solid #ffd700}.console-log-input-response{color:#4ec9b0;font-weight:600;padding:4px var(--spacing-sm);padding-left:calc(var(--spacing-sm) + 16px);margin:2px 0;position:relative}.console-log-input-response:before{content:"▶";position:absolute;left:var(--spacing-sm);color:#4ec9b0;font-weight:700}.console-log-stdout{color:var(--color-console-text)}.console-log-stderr{color:var(--color-console-error)}.console-log-system{color:var(--color-console-system);font-style:italic}.console-timestamp{margin-right:var(--spacing-sm);color:#666}.console-input-container{border-top:2px solid #ffd700;background:#2d2d2d;padding:var(--spacing-sm) var(--spacing-md)}.console-input-form{display:flex;flex-direction:column;gap:var(--spacing-xs)}.console-input-prompt-text{color:gold;font-family:var(--font-mono);font-size:13px;font-weight:600;display:block;margin-bottom:var(--spacing-xs)}.console-input-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);background:#1e1e1e;border:1px solid #3e3e3e;border-radius:4px;padding:var(--spacing-xs) var(--spacing-sm);transition:border-color .2s}.console-input-wrapper:focus-within{border-color:#4ec9b0;box-shadow:0 0 0 1px #4ec9b0}.console-input-arrow{color:#4ec9b0;font-family:var(--font-mono);font-size:14px;font-weight:600;flex-shrink:0}.console-input-field{flex:1;background:transparent;border:none;color:#d4d4d4;font-family:var(--font-mono);font-size:13px;outline:none;padding:0}.console-input-field:disabled{opacity:.5;cursor:not-allowed}.console-input-field::placeholder{color:#666;font-style:italic}.error-panel{height:100%;display:flex;flex-direction:column;background:var(--color-bg)}.error-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.error-panel-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.error-confidence{font-size:12px;font-weight:700}.error-panel-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.error-panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-text-secondary)}.error-success-icon{font-size:48px;color:var(--color-success);margin-bottom:var(--spacing-md)}.error-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-lg)}.error-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.error-icon{font-size:24px}.error-title{font-size:18px;font-weight:600;color:var(--color-error)}.error-section{margin-bottom:var(--spacing-lg)}.error-section-title{font-size:14px;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text)}.error-explanation{font-size:15px;line-height:1.6;color:var(--color-text)}.error-location{font-size:14px}.error-snippet{margin-top:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-console-bg);border-left:3px solid var(--color-error);border-radius:var(--border-radius-sm);overflow-x:auto}.error-snippet code{font-family:var(--font-mono);color:var(--color-console-text);font-size:13px}.error-pointer{color:var(--color-error);font-weight:700}.error-fix-steps{list-style:none;padding:0}.error-fix-steps li{padding:var(--spacing-sm);margin-bottom:var(--spacing-xs);background:var(--color-bg-secondary);border-left:3px solid var(--color-primary);border-radius:var(--border-radius-sm)}.error-original-toggle{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.error-toggle-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;font-size:14px;transition:all .2s}.error-toggle-button:hover{background:var(--color-bg-secondary)}.error-original{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--color-console-bg);border-radius:var(--border-radius-sm);overflow-x:auto;font-family:var(--font-mono);font-size:12px;color:var(--color-console-text)}.instruction-panel{height:100%;display:flex;flex-direction:column;background:var(--color-bg-secondary);border-left:1px solid var(--color-border)}.instruction-panel-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.instruction-panel-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.instruction-panel-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.instruction-empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.instruction-section{margin-bottom:var(--spacing-lg)}.instruction-task-title{font-size:20px;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text)}.instruction-description{font-size:15px;line-height:1.6;color:var(--color-text)}.instruction-subtitle{font-size:14px;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.instruction-example{margin-top:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--border-radius);border:1px solid var(--color-border)}.instruction-example pre{margin-top:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--border-radius-sm);overflow-x:auto}.instruction-example code{font-family:var(--font-mono);font-size:13px}.instruction-requirements{list-style:none;padding:0}.requirement{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);margin-bottom:var(--spacing-xs);background:var(--color-bg);border-radius:var(--border-radius-sm);border:1px solid var(--color-border)}.requirement.requirement-passed{border-color:var(--color-success);background:#10b9811a}.requirement.requirement-failed{border-color:var(--color-error);background:#ef44441a}.requirement-icon{font-size:16px;font-weight:700}.requirement-passed .requirement-icon{color:var(--color-success)}.requirement-failed .requirement-icon{color:var(--color-error)}.requirement-pending .requirement-icon{color:var(--color-text-light)}.instruction-feedback{padding:var(--spacing-md);border-radius:var(--border-radius);font-weight:500;text-align:center}.instruction-feedback.success{background:#10b9811a;color:var(--color-success);border:1px solid var(--color-success)}.instruction-feedback.partial{background:#f59e0b1a;color:var(--color-warning);border:1px solid var(--color-warning)}.instruction-hints{display:flex;flex-direction:column;gap:var(--spacing-sm)}.instruction-hint{padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--border-radius);border:1px solid var(--color-border)}.hint-reveal-button{width:100%;padding:var(--spacing-sm);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;border:none;border-radius:var(--border-radius-sm);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.hint-reveal-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0066ff4d}.hint-revealed{font-size:14px;line-height:1.6}.resize-handle{position:relative;background:transparent}.panel-toggle{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:80px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:100;font-size:16px;transition:all .2s;box-shadow:2px 0 4px #0000001a}.panel-toggle:hover{background:var(--color-primary);color:#fff;box-shadow:2px 0 8px #00000026}.panel-toggle-left{left:0;border-left:none;border-radius:0 8px 8px 0}.panel-toggle-right{right:0;border-right:none;border-radius:var(--border-radius-sm) 0 0 var(--border-radius-sm)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#0000004d}.console-content::-webkit-scrollbar-thumb{background:#fff3}.console-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.turtle-canvas-container{height:100%;display:flex;flex-direction:column;background:var(--color-bg)}.turtle-canvas-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.turtle-canvas-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.turtle-clear-button{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:12px;cursor:pointer;transition:all .2s}.turtle-clear-button:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.turtle-canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);overflow:auto;background:var(--color-bg-tertiary)}.turtle-canvas{border:2px solid var(--color-border);border-radius:var(--border-radius);background:#fff;box-shadow:0 4px 6px #0000001a;max-width:100%;height:auto;display:block}@media (max-width: 1024px){.header-button .button-text{display:none}}@media (max-width: 768px){.ide-main{flex-direction:column}.panel-toggle{display:none}.header-right .header-button:not(.help-button){display:none}}.backend-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#fee2e2;border-bottom:2px solid #ef4444;color:#991b1b;font-size:13px}.error-icon{font-size:18px}.error-message{flex:1;font-weight:500}.connection-status{position:fixed;bottom:20px;right:20px;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#000c;color:#fff;border-radius:var(--border-radius);font-size:13px;box-shadow:0 4px 12px #0000004d;z-index:1000}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shared-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:#999}.shared-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.shared-error p{color:#c33;font-size:18px}.shared-error button{padding:10px 20px;background:#00a8ff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;box-shadow:0 2px 4px #00a8ff33}.shared-error button:hover{background:#0090dd;transform:translateY(-1px);box-shadow:0 4px 8px #00a8ff4d}.shared-banner{background:linear-gradient(135deg,#f60,#00a8ff);color:#fff;padding:14px 24px;box-shadow:0 2px 8px #0000001a}.banner-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.banner-content span{display:inline-flex;align-items:center}.banner-content span svg{margin-right:8px;flex-shrink:0}.fork-banner-button{padding:10px 20px;background:#fff;color:#f60;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #fff3;display:inline-flex;align-items:center;gap:8px}.fork-banner-button svg{width:18px;height:18px;flex-shrink:0}.fork-banner-button:hover{transform:translateY(-2px);box-shadow:0 4px 16px #fff6;background:#fffaf5}.fork-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}.fork-dialog{background:#fff;border-radius:16px;padding:32px;width:90%;max-width:450px;box-shadow:0 12px 40px #0000004d;border:2px solid #00A8FF}.fork-dialog h3{margin:0 0 12px;font-size:22px;font-weight:700;color:#333;background:linear-gradient(135deg,#f60,#00a8ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fork-dialog p{margin:0 0 24px;color:#666;font-size:14px;line-height:1.6}.fork-dialog input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;margin-bottom:20px;box-sizing:border-box;transition:all .2s}.fork-dialog input:focus{outline:none;border-color:#00a8ff;box-shadow:0 0 0 3px #00a8ff1a}.fork-dialog-actions{display:flex;gap:12px}.fork-dialog-actions button{flex:1;padding:14px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.fork-dialog-actions button:first-child{background:#f60;color:#fff;box-shadow:0 2px 4px #f603}.fork-dialog-actions button:first-child:hover:not(:disabled){background:#f50;transform:translateY(-1px);box-shadow:0 4px 12px #f606}.fork-dialog-actions button:first-child:disabled{opacity:.6;cursor:not-allowed}.fork-dialog-actions button.cancel{background:#9ca3af;color:#fff;box-shadow:0 2px 4px #9ca3af33}.fork-dialog-actions button.cancel:hover{background:#6b7280;transform:translateY(-1px)}.fork-hint{margin:16px 0 0;padding:14px 16px;background:linear-gradient(135deg,#ff66001a,#00a8ff1a);border:1px solid #00A8FF;border-radius:8px;font-size:13px;color:#666;line-height:1.5}
