.graphviz-page{overflow:hidden;height:100vh}.svg-topbar{flex-shrink:0;z-index:1002;height:49px}.topbar-actions{display:flex;align-items:center;gap:var(--space-xs)}.toast-container{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}.toast{background:var(--text-main);color:#fff;padding:10px 18px;border-radius:var(--radius);font-size:var(--font-size-sm);font-weight:500;box-shadow:0 4px 12px rgba(0,0,0,.2);pointer-events:auto;animation:gv-toast-in .25s ease-out;display:flex;align-items:center;gap:var(--space-xs)}.toast.toast-success{background:var(--success)}.toast.toast-error{background:var(--danger)}.toast.toast-out{animation:gv-toast-out .2s ease-in forwards}@keyframes gv-toast-in{from{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes gv-toast-out{from{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(10px)scale(.96)}}.ide-layout{display:flex;height:calc(100vh - 49px);overflow:hidden}.ide-editor-panel{width:45%;min-width:280px;max-width:80%;display:flex;flex-direction:column;background:#1e1e1e;overflow:hidden}.ide-preview-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-color);min-width:250px}.ide-resize-handle{width:5px;cursor:col-resize;background:var(--border-color);position:relative;flex-shrink:0;z-index:10;transition:background .15s}.ide-resize-handle:hover,.ide-resize-handle.active{background:var(--primary)}.resize-handle-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:3px;height:30px;border-radius:2px;opacity:0;transition:opacity .15s}.ide-resize-handle:hover .resize-handle-grip{opacity:1}.editor-header{display:flex;align-items:center;justify-content:space-between;background:#252526;border-bottom:1px solid #3c3c3c;padding:0 var(--space-sm);height:36px;flex-shrink:0}.editor-tab{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:#ccc;padding:6px 10px;border-bottom:2px solid transparent;font-weight:500}.editor-tab.active{border-bottom-color:var(--primary);color:#fff}.editor-file-size{font-size:var(--font-size-xs);color:gray;font-family:sf mono,fira code,cascadia code,Consolas,monospace}.monaco-container{flex:1;overflow:hidden}.preview-toolbar{display:flex;align-items:center;justify-content:space-between;padding:4px var(--space-sm);background:var(--panel-bg);border-bottom:1px solid var(--border-color);height:40px;flex-shrink:0;gap:var(--space-sm)}.toolbar-group{display:flex;align-items:center;gap:4px}.zoom-level{font-size:var(--font-size-xs);color:var(--text-muted);min-width:42px;text-align:center;font-family:sf mono,fira code,Consolas,monospace;font-weight:500}.toggle-label{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--border-color);border-radius:var(--radius);padding:5px 8px;color:var(--text-muted);transition:all .15s}.toggle-label input[type=checkbox]{display:none}.toggle-label:has(input:checked){color:var(--primary);border-color:var(--primary);background:var(--primary-light)}.toggle-label:hover{border-color:var(--border-strong);color:var(--text-main)}.preview-canvas-wrapper{flex:1;overflow:hidden;position:relative}.preview-canvas{width:100%;height:100%;overflow:hidden;position:relative;cursor:grab}.preview-canvas:active{cursor:grabbing}.preview-canvas.checkered{background-color:#fff;background-image:linear-gradient(45deg,#f0f0f0 25%,transparent 25%),linear-gradient(-45deg,#f0f0f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f0 75%),linear-gradient(-45deg,transparent 75%,#f0f0f0 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0}.preview-canvas.dark-canvas{background-color:#1e1e1e}.preview-canvas.dark-canvas.checkered{background-image:linear-gradient(45deg,#2a2a2a 25%,transparent 25%),linear-gradient(-45deg,#2a2a2a 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#2a2a2a 75%),linear-gradient(-45deg,transparent 75%,#2a2a2a 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0}.gv-boundary{position:absolute;top:0;left:0;pointer-events:none;border:1.5px dashed rgba(49,130,206,.5);box-shadow:0 0 0 1px rgba(49,130,206,.12);z-index:5;box-sizing:border-box;display:none}.preview-svg-container{position:absolute;top:0;left:0;transform-origin:0 0;transform:translate(0,0);transition:none}.preview-svg-container svg{display:block;max-width:none}.preview-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);color:var(--text-light);padding:var(--space-xl);text-align:center;user-select:none}.preview-placeholder p{font-size:var(--font-size-sm);margin:0}.tools-panel{flex-shrink:0;background:var(--panel-bg);border-top:1px solid var(--border-color);display:flex;flex-direction:column;max-height:280px;min-height:40px;transition:max-height .2s ease}.tools-panel.collapsed{max-height:40px;overflow:hidden}.tools-tabs{display:flex;align-items:center;padding:0 var(--space-xs);border-bottom:1px solid var(--border-color);flex-shrink:0;height:38px;gap:0}.tools-tab{display:flex;align-items:center;gap:5px;font-size:var(--font-size-sm);color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid transparent;padding:8px 12px;cursor:pointer;font-weight:500;white-space:nowrap;transition:color .15s}.tools-tab:hover{color:var(--text-main)}.tools-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tools-tabs-spacer{flex:1}.tools-content{display:none;padding:var(--space-sm)var(--space-md);overflow-y:auto;flex:1}.tools-content.active{display:block}.drag-overlay{position:fixed;inset:0;background:rgba(49,130,206,.12);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center}.drag-overlay[hidden]{display:none}.drag-overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl);background:var(--panel-bg);border:2px dashed var(--primary);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15)}.drag-overlay-icon{color:var(--primary)}.drag-overlay-text{font-size:var(--font-size-md);font-weight:600;color:var(--text-main)}.gv-settings-row{display:flex;gap:var(--space-md);align-items:flex-end;flex-wrap:wrap}.gv-setting{display:flex;flex-direction:column;gap:4px}.gv-setting label{font-size:var(--font-size-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.gv-setting select{font-size:var(--font-size-sm);padding:5px 8px;border-radius:var(--radius);border:1px solid var(--border-color);background:var(--bg-color);color:var(--text-main);cursor:pointer;min-width:140px}.gv-setting select:hover{border-color:var(--border-strong)}.gv-setting select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(49,130,206,.15)}.gv-examples-grid{display:flex;flex-wrap:wrap;gap:6px}.gv-example-btn{padding:5px 14px;font-size:var(--font-size-xs);font-weight:600;background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;color:var(--text-muted);transition:all .15s}.gv-example-btn:hover{color:var(--text-main);border-color:var(--border-strong);background:var(--panel-bg)}.gv-example-btn:active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.gv-error-output{margin:0;padding:var(--space-sm);font-size:var(--font-size-xs);font-family:sf mono,fira code,cascadia code,Consolas,monospace;line-height:1.5;color:var(--text-muted);background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius);max-height:160px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.drag-overlay{position:fixed;inset:0;background:rgba(49,130,206,.12);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center}.drag-overlay[hidden]{display:none}.drag-overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl);background:var(--panel-bg);border:2px dashed var(--primary);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15)}.drag-overlay-icon{color:var(--primary)}.drag-overlay-text{font-size:var(--font-size-md);font-weight:600;color:var(--text-main)}.toast-container{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}.toast{background:var(--text-main);color:#fff;padding:10px 18px;border-radius:var(--radius);font-size:var(--font-size-sm);font-weight:500;box-shadow:0 4px 12px rgba(0,0,0,.2);pointer-events:auto;animation:gv-toast-in .25s ease-out}.toast.toast-success{background:var(--success)}.toast.toast-error{background:var(--danger)}.toast.toast-out{animation:gv-toast-out .2s ease-in forwards}@keyframes gv-toast-in{from{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes gv-toast-out{from{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(10px)scale(.96)}}@media(max-width:700px){.ide-layout{flex-direction:column}.ide-editor-panel{width:100%!important;max-width:100%;height:40vh;min-height:200px}.ide-resize-handle{width:100%;height:5px;cursor:row-resize}.ide-preview-panel{min-width:0}.gv-settings-row{flex-direction:column;gap:var(--space-sm)}.gv-setting select{min-width:100%}}