:root{--bg: #0e1116;--surface: #161b22;--surface-2: #1c232c;--surface-3: #232c37;--border: #21262d;--border-2: #30363d;--text: #e6edf3;--text-2: #8b949e;--text-dim: #6e7681;--accent: #f0883e;--accent-soft: rgba(240, 136, 62, .12);--accent-line: rgba(240, 136, 62, .35);--success: #3fb950;--danger: #da3633;--info: #58a6ff;--mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sans: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--sidebar-w: 240px;--editor-w: 480px}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--sans);font-size:13px;line-height:1.5;overflow:hidden;-webkit-font-smoothing:antialiased}body:focus{outline:none}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}#app{display:grid;grid-template-rows:auto auto 1fr;height:100vh}.project-switcher{position:relative;display:flex;align-items:center;gap:10px;margin-right:14px;padding-left:14px;border-left:1px solid var(--border)}.project-switcher-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:5px;color:var(--text);cursor:pointer;font-size:12px;font-family:var(--mono);letter-spacing:.01em;max-width:280px;min-width:160px}.project-switcher-btn:hover{border-color:var(--text-dim)}.project-switcher-btn .project-icon{color:var(--accent)}.project-switcher-btn .project-name{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-switcher-btn .caret{color:var(--text-dim);font-size:10px}.project-menu{position:absolute;top:calc(100% + 4px);left:14px;min-width:320px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:6px;padding:4px;display:none;flex-direction:column;gap:1px;box-shadow:0 8px 24px #00000080;z-index:50;max-height:70vh;overflow-y:auto}.project-menu.open{display:flex}.project-menu-section{padding:6px 10px 4px;font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-weight:600}.project-menu-divider{height:1px;background:var(--border);margin:4px 0}.project-menu-item{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:7px 10px;background:transparent;border:none;border-radius:4px;color:var(--text);cursor:pointer;font-size:12px;text-align:left;font-family:var(--sans)}.project-menu-item:hover{background:var(--surface-3)}.project-menu-item.active{background:var(--accent-soft);color:var(--accent)}.project-menu-item .item-name{display:flex;flex-direction:column;gap:1px;min-width:0}.project-menu-item .item-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.project-menu-item .item-meta{font-family:var(--mono);font-size:9.5px;color:var(--text-dim);letter-spacing:.04em}.project-menu-item .item-actions{display:flex;gap:1px;opacity:0}.project-menu-item:hover .item-actions{opacity:1}.project-menu-item .item-actions button{width:22px;height:22px;background:transparent;border:none;color:var(--text-dim);cursor:pointer;border-radius:3px;font-family:var(--mono);font-size:11px;padding:0;display:grid;place-items:center}.project-menu-item .item-actions button:hover{color:var(--text);background:#ffffff0f}.project-menu-item .item-actions button.danger:hover{color:var(--danger)}.project-menu-action{display:flex;align-items:center;gap:8px;padding:7px 10px;background:transparent;border:none;border-radius:4px;color:var(--text);cursor:pointer;font-size:12px;text-align:left;font-family:var(--mono);letter-spacing:.02em;width:100%}.project-menu-action:hover{background:var(--surface-3)}.project-menu-action.danger{color:#ff8a85}.project-menu-action.danger:hover{background:#da36331f}.save-indicator{font-family:var(--mono);font-size:10.5px;color:var(--text-dim);letter-spacing:.04em;display:flex;align-items:center;gap:5px;min-width:90px}.save-indicator .save-dot{width:6px;height:6px;border-radius:50%;background:var(--text-dim);transition:background .2s}.save-indicator.saving .save-dot{background:var(--accent);animation:pulse .8s ease-in-out infinite}.save-indicator.saved .save-dot{background:var(--success)}.save-indicator.error .save-dot{background:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:6px;row-gap:6px;min-height:48px;padding:6px 14px;background:var(--surface);border-bottom:1px solid var(--border)}.toolbar-brand{display:flex;align-items:center;gap:8px;margin-right:18px;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.04em}.toolbar-brand .brand-mark{width:22px;height:22px;border:1.5px solid var(--accent);border-radius:3px;display:grid;place-items:center;font-size:10px;font-weight:700;color:var(--accent);font-family:var(--mono)}.toolbar-spacer{flex:1}.theme-control{position:relative;display:inline-flex;align-items:center;gap:6px;margin-right:10px;padding-right:10px;border-right:1px solid var(--border)}.theme-control .theme-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:600}#theme-select{background:var(--surface-2);border:1px solid var(--border-2);border-radius:5px;color:var(--text);padding:4px 8px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;cursor:pointer;outline:none;min-width:130px}#theme-select:hover{border-color:var(--text-dim)}#theme-select:focus{border-color:var(--accent)}.theme-edit{width:26px;height:26px;padding:0;background:transparent;border:1px solid var(--border-2);border-radius:4px;cursor:pointer;display:grid;place-items:center;font-size:13px;line-height:1}.theme-edit:hover{border-color:var(--accent-line);background:var(--accent-soft)}.theme-popover{position:absolute;top:calc(100% + 6px);right:0;min-width:280px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:6px;padding:10px 12px 12px;box-shadow:0 10px 28px #0000008c;z-index:60;display:flex;flex-direction:column;gap:8px}.theme-popover[hidden]{display:none}.theme-popover-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-weight:600;margin-bottom:2px}.theme-popover .theme-row{display:grid;grid-template-columns:1fr 32px 100px;align-items:center;gap:8px}.theme-popover .theme-row label{font-size:12px;color:var(--text)}.theme-popover .theme-row code{font-family:var(--mono);font-size:9.5px;color:var(--text-dim);letter-spacing:.04em;text-align:right}.theme-popover .theme-row input[type=color]{width:32px;height:24px;padding:0;border:1px solid var(--border-2);border-radius:4px;background:transparent;cursor:pointer}.theme-popover-actions{display:flex;justify-content:flex-end;margin-top:4px}.theme-popover-actions button{background:transparent;border:1px dashed var(--border-2);color:var(--text-2);border-radius:4px;padding:5px 10px;font-family:var(--mono);font-size:11px;cursor:pointer;transition:all .1s}.theme-popover-actions button:hover{border-color:var(--accent-line);color:var(--accent);border-style:solid}.locale-toggle{display:inline-flex;border:1px solid var(--border-2);border-radius:5px;overflow:hidden;margin-right:6px}.locale-toggle button{padding:5px 10px;background:transparent;border:none;color:var(--text-2);cursor:pointer;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.06em;transition:background .12s ease,color .12s ease}.locale-toggle button+button{border-left:1px solid var(--border-2)}.locale-toggle button:hover{color:var(--text);background:var(--surface-2)}.locale-toggle button.active{background:var(--accent-soft);color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--border-2);border-radius:5px;color:var(--text);cursor:pointer;font-size:12px;font-weight:500;transition:background .12s ease,border-color .12s ease;font-family:var(--mono);letter-spacing:.01em}.btn:hover{background:var(--surface-2);border-color:var(--text-dim)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#1c1c1c;font-weight:600}.btn-primary:hover{background:#ff9248;border-color:#ff9248}.btn-ghost{border-color:transparent;color:var(--text-2)}.btn-ghost:hover{color:var(--text);background:var(--surface-2)}.btn-icon{width:26px;height:26px;padding:0;display:grid;place-items:center}.workspace{display:grid;grid-template-columns:var(--sidebar-w) 5px var(--editor-w) 5px minmax(0,1fr);min-height:0;position:relative}.panel{background:var(--surface);overflow-y:auto;display:flex;flex-direction:column;min-width:0}.panel:last-child{border-right:none}.resizer{background:var(--border);cursor:col-resize;position:relative;z-index:5;transition:background .12s;user-select:none;touch-action:none}.resizer:before{content:"";position:absolute;inset:0 -3px}.resizer:hover,.resizer:focus-visible,.resizer.dragging{background:var(--accent);outline:none}body.is-resizing{cursor:col-resize!important;user-select:none}body.is-resizing iframe{pointer-events:none}.workspace-tabs{display:none;background:var(--surface);border-bottom:1px solid var(--border)}.workspace-tabs button{flex:1 1 0;background:transparent;border:none;color:var(--text-2);padding:10px 8px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:color .1s,border-color .1s}.workspace-tabs button:hover{color:var(--text)}.workspace-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}@media (max-width: 900px){.workspace-tabs{display:flex}.workspace{grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr)}.resizer{display:none}.workspace>.panel,.workspace>.preview-wrap{display:none}.workspace>.panel.is-active{display:flex}.workspace>.preview-wrap.is-active{display:flex}}@media (max-width: 600px){.toolbar-spacer{display:none}.toolbar-brand{margin-right:8px}.project-switcher{margin-right:6px;padding-left:8px}.theme-control{margin-right:4px;padding-right:6px}.project-switcher-btn{min-width:120px;max-width:200px}}.panel-header{padding:12px 14px 8px;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.section-list{padding:6px 0;display:flex;flex-direction:column;gap:1px}.section-row{display:grid;grid-template-columns:26px 1fr auto;align-items:center;padding:8px 12px;cursor:pointer;border-left:2px solid transparent;font-size:12.5px;gap:8px;user-select:none;transition:background .1s}.section-row:hover{background:var(--surface-2)}.section-row.active{background:var(--accent-soft);border-left-color:var(--accent)}.section-row.active .section-row-label{color:var(--text)}.section-row.fixed{font-weight:500}.section-row-icon{display:grid;place-items:center;width:22px;height:22px;border-radius:4px;background:var(--surface-3);color:var(--text-2);font-family:var(--mono);font-size:10px;font-weight:600}.section-row.active .section-row-icon{background:var(--accent);color:#1c1c1c}.section-row-label{color:var(--text-2);display:flex;flex-direction:column;gap:1px;min-width:0}.section-row-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section-row-type{font-family:var(--mono);font-size:9.5px;color:var(--text-dim);letter-spacing:.05em}.section-row-controls{display:flex;gap:1px;opacity:0;transition:opacity .1s}.section-row:hover .section-row-controls,.section-row.active .section-row-controls{opacity:1}.section-row-controls button{width:22px;height:22px;padding:0;background:transparent;border:none;color:var(--text-dim);cursor:pointer;border-radius:3px;display:grid;place-items:center;font-family:var(--mono);font-size:11px}.section-row-controls button:hover{background:var(--surface-3);color:var(--text)}.section-row-controls button.danger:hover{color:var(--danger)}.section-divider{height:1px;background:var(--border);margin:6px 0}.section-row[draggable=true]{cursor:grab}.section-row[draggable=true]:active{cursor:grabbing}.section-row.dragging{opacity:.4}.section-row.drag-over-above{box-shadow:inset 0 2px 0 0 var(--accent)}.section-row.drag-over-below{box-shadow:inset 0 -2px 0 0 var(--accent)}.add-section-wrap{padding:10px 12px;border-top:1px solid var(--border);position:relative}.add-section-menu{position:absolute;bottom:calc(100% + 4px);left:12px;right:12px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:6px;padding:4px;display:none;flex-direction:column;gap:1px;box-shadow:0 8px 24px #0006;z-index:10}.add-section-menu.open{display:flex}.add-section-menu button{text-align:left;padding:7px 10px;background:transparent;border:none;border-radius:4px;color:var(--text);cursor:pointer;font-size:12px;display:flex;flex-direction:column;gap:1px}.add-section-menu button:hover{background:var(--surface-3)}.add-section-menu button .menu-type{font-family:var(--mono);font-size:9.5px;color:var(--text-dim);letter-spacing:.05em}.editor-body{padding:14px 16px 80px;overflow-y:auto;flex:1}.editor-empty{padding:60px 30px;color:var(--text-dim);text-align:center;font-family:var(--mono);font-size:12px;line-height:1.7}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.field-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:600;display:flex;align-items:center;justify-content:space-between}.field-label .field-hint{font-family:var(--mono);font-size:9.5px;text-transform:none;letter-spacing:0;color:var(--text-dim);font-weight:400;font-style:italic}.editor-body input[type=text],.editor-body textarea,.editor-body select{background:var(--bg);border:1px solid var(--border-2);border-radius:5px;padding:8px 10px;color:var(--text);outline:none;width:100%;resize:vertical;font-size:12.5px;transition:border-color .1s}.editor-body input[type=text]:focus,.editor-body textarea:focus,.editor-body select:focus{border-color:var(--accent)}.editor-body textarea{font-family:var(--sans);line-height:1.5;min-height:60px}.editor-body textarea.svg-input{font-family:var(--mono);font-size:11px;min-height:100px;line-height:1.4}.editor-body textarea.code-input{font-family:var(--mono);font-size:11.5px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.subcard{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:10px 12px 4px;margin-bottom:8px;position:relative}.subcard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border)}.subcard-title{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);font-weight:600}.subcard-controls{display:flex;gap:2px}.subcard-controls button{width:22px;height:22px;padding:0;background:transparent;border:none;color:var(--text-dim);cursor:pointer;border-radius:3px;font-family:var(--mono);font-size:11px}.subcard-controls button:hover{color:var(--text);background:var(--surface-3)}.subcard-controls button.danger:hover{color:var(--danger)}.add-item-btn{width:100%;padding:7px 10px;background:transparent;border:1px dashed var(--border-2);border-radius:5px;color:var(--text-2);cursor:pointer;font-size:12px;margin-top:4px;font-family:var(--mono);letter-spacing:.02em;transition:all .1s}.add-item-btn:hover{border-color:var(--accent-line);color:var(--accent);border-style:solid}.editor-section-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px;display:flex;align-items:center;gap:8px}.editor-section-title .type-badge{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:2px 6px;border-radius:3px;font-weight:600}.editor-section-meta{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin-bottom:14px}.subgroup{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}.subgroup:last-child{border-bottom:none}.subgroup-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px}.subgroup-title:before{content:"";width:12px;height:1px;background:var(--accent)}.chart-editor{border:1px solid var(--border);border-radius:6px;background:var(--surface-2);margin-bottom:14px;padding:12px}.chart-type-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.chart-type-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:600;flex-shrink:0}.chart-type-select{flex:1 1 auto;background:var(--bg);border:1px solid var(--border-2);border-radius:4px;padding:6px 8px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none}.chart-type-select:focus{border-color:var(--accent)}.chart-preset-desc{font-family:var(--mono);font-size:10.5px;color:var(--text-2);margin-bottom:10px;line-height:1.5}.chart-data-table{overflow-x:auto;border:1px solid var(--border);border-radius:4px;background:var(--bg);margin-bottom:8px}.chart-data-table table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11px}.chart-data-table th,.chart-data-table td{border:1px solid var(--border);padding:0;background:var(--bg)}.chart-data-table th{background:var(--surface);padding:5px 8px;color:var(--text-2);font-weight:600;letter-spacing:.04em;text-align:left;white-space:nowrap}.chart-data-table th .col-header-inner{display:flex;align-items:center;gap:6px}.chart-data-table .col-label-input{flex:1 1 auto;min-width:60px;border:1px solid transparent;background:transparent;padding:2px 4px;color:var(--text);font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.04em;outline:none;border-radius:3px}.chart-data-table .col-label-input:hover{border-color:var(--border-2)}.chart-data-table .col-label-input:focus{background:var(--bg);border-color:var(--accent)}.chart-data-table .col-type{flex-shrink:0;font-size:9px;color:var(--text-dim);background:var(--surface-2);padding:1px 4px;border-radius:2px}.chart-data-table .row-del-cell{width:22px}.chart-data-table .row-del{width:100%;height:100%;min-height:22px;border:none;background:transparent;color:var(--text-dim);cursor:pointer;font-size:10px}.chart-data-table .row-del:hover{color:var(--danger);background:#da36331f}.chart-data-table input[type=text]{width:100%;border:none;background:transparent;padding:4px 6px;color:var(--text);font-family:var(--mono);font-size:11px;outline:none}.chart-data-table input[type=text]:focus{background:var(--surface-3);box-shadow:inset 0 0 0 1px var(--accent)}.chart-data-empty{text-align:center;color:var(--text-dim);font-style:italic;padding:16px}.chart-data-actions{margin-bottom:10px}.chart-data-actions .add-item-btn{width:100%;margin-top:0}.chart-advanced{margin-top:10px;border-top:1px solid var(--border);padding-top:10px}.chart-advanced>summary{list-style:none;cursor:pointer;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:600;padding:4px 0;user-select:none}.chart-advanced>summary::-webkit-details-marker{display:none}.chart-advanced>summary:before{content:"▸";display:inline-block;margin-right:6px;transition:transform .12s}.chart-advanced[open]>summary:before{transform:rotate(90deg)}.chart-advanced>summary:hover{color:var(--text-2)}.chart-advanced-body{display:flex;flex-direction:column;gap:6px;margin-top:8px}.advanced-action{text-align:left;padding:8px 10px;background:var(--bg);border:1px solid var(--border-2);border-radius:4px;color:var(--text);cursor:pointer;display:flex;flex-direction:column;gap:2px;transition:border-color .12s,background .12s}.advanced-action:hover{border-color:var(--accent-line);background:var(--surface-3)}.advanced-action-title{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--text)}.advanced-action-desc{font-family:var(--mono);font-size:10px;color:var(--text-dim);line-height:1.4}.chart-mode-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:4px;margin-bottom:10px}.chart-mode-banner .banner-text{font-family:var(--mono);font-size:11px;color:var(--text);flex:1 1 auto}.chart-mode-banner .banner-btn{flex-shrink:0;background:var(--surface-2);border:1px solid var(--border-2);border-radius:3px;padding:4px 8px;color:var(--text);cursor:pointer;font-family:var(--mono);font-size:10px;letter-spacing:.04em}.chart-mode-banner .banner-btn:hover{border-color:var(--accent);color:var(--accent)}.chart-spec-input.invalid{border-color:var(--danger)!important;box-shadow:0 0 0 1px var(--danger)}.preview-wrap{background:#2a2f37;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.03) 1px,transparent 0);background-size:24px 24px;overflow:hidden;display:flex;flex-direction:column;position:relative;min-height:0}.preview-scroll{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:30px;min-height:0}.preview-frame{width:841mm;height:1189mm;flex-shrink:0;transform-origin:top center;transform:scale(var(--preview-scale, .32));background:#fff;box-shadow:0 8px 30px #0009}.preview-frame iframe{width:100%;height:100%;border:none;display:block}.logo-card{transition:border-color .12s,background .12s}.logo-card.drag-over{border-color:var(--accent);background:var(--accent-soft)}.logo-preview{background:linear-gradient(45deg,var(--surface-2) 25%,transparent 25%) 0 0 / 12px 12px,linear-gradient(-45deg,var(--surface-2) 25%,transparent 25%) 0 6px / 12px 12px,linear-gradient(45deg,transparent 75%,var(--surface-2) 75%) 6px -6px / 12px 12px,linear-gradient(-45deg,transparent 75%,var(--surface-2) 75%) 6px 0 / 12px 12px,var(--surface);border:1px solid var(--border);border-radius:4px;padding:6px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;max-height:90px}.logo-preview img{max-width:100%;max-height:76px;object-fit:contain;display:block}.logo-embedded-note{font-family:var(--mono);font-size:10px;color:var(--text-dim);letter-spacing:.04em;padding:6px 8px;background:var(--surface-3);border-radius:3px;margin-bottom:14px}.logo-drop-hint{border:1px dashed var(--border-2);border-radius:4px;padding:14px 10px;text-align:center;font-family:var(--mono);font-size:10.5px;color:var(--text-dim);margin-bottom:8px;letter-spacing:.02em}.logo-card.drag-over .logo-drop-hint{border-color:var(--accent);color:var(--accent)}.overflow-banner{position:absolute;bottom:0;left:0;right:0;padding:10px 18px;background:#da3633eb;color:#fff;font-family:var(--mono);font-size:11.5px;text-align:center;letter-spacing:.02em;z-index:6;pointer-events:none;transform:translateY(100%);opacity:0;transition:transform .18s ease,opacity .18s ease;backdrop-filter:blur(6px)}.overflow-banner.visible{transform:translateY(0);opacity:1}.preview-overlay{position:absolute;top:14px;right:18px;font-family:var(--mono);font-size:10.5px;color:var(--text-dim);background:#0e1116d9;padding:5px 10px;border-radius:4px;border:1px solid var(--border-2);display:flex;gap:12px;align-items:center;z-index:5;backdrop-filter:blur(4px)}.zoom-controls{display:flex;gap:2px}.zoom-controls button{width:22px;height:22px;padding:0;background:transparent;border:1px solid var(--border-2);color:var(--text-2);cursor:pointer;border-radius:3px;font-family:var(--mono)}.zoom-controls button:hover{color:var(--text);border-color:var(--text-dim)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--surface-3);color:var(--text);padding:10px 18px;border-radius:6px;border:1px solid var(--border-2);font-family:var(--mono);font-size:12px;z-index:100;box-shadow:0 8px 24px #00000080;opacity:0;transition:opacity .2s,transform .2s}.toast.show{opacity:1;transform:translate(-50%) translateY(-4px)}.toast.error{border-color:var(--danger);color:#ffb4b0}.toast.success{border-color:var(--success);color:#b3e6b8}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:5px;border:2px solid var(--surface)}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.preview-scroll::-webkit-scrollbar-thumb{border-color:#2a2f37}
