:root{--bg: #131317;--panel: #1c1c20;--panel-2: #232328;--border: #2c2c33;--text: #e6e6ea;--muted: #9a9aa3;--accent: #2978ff;--accent-2: #4c8eff}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{background:var(--bg);color:var(--text);font:13px/1.4 system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.layout{display:grid;grid-template-columns:44px 240px 1fr 280px;grid-template-rows:48px 1fr 220px 24px;grid-template-areas:"tb tb tb tb" "tr lp ch rp" "tr lp ch rb" "sb sb sb sb";height:100vh;width:100vw}.topbar{grid-area:tb;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;padding:0 10px;overflow-x:auto}.tools-rail{grid-area:tr;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0}.left-panel{grid-area:lp;background:var(--panel);border-right:1px solid var(--border);padding:10px;overflow-y:auto}.right-panel{grid-area:rp;background:var(--panel);border-left:1px solid var(--border);padding:10px;overflow-y:auto}.right-bottom{grid-area:rb;background:var(--panel);border-left:1px solid var(--border);border-top:1px solid var(--border);padding:10px;overflow-y:auto}.statusbar{grid-area:sb;background:var(--panel-2);border-top:1px solid var(--border);color:var(--muted);padding:0 10px;line-height:24px;font-size:12px}.canvas-host{grid-area:ch;position:relative;background:#1f1f24;overflow:hidden}canvas#canvas{position:absolute;left:22px;top:22px;width:calc(100% - 22px);height:calc(100% - 22px);display:block;outline:none}body.no-rulers canvas#canvas{left:0;top:0;width:100%;height:100%}body.no-rulers .ruler,body.no-rulers .ruler-corner{display:none}.ruler{position:absolute;pointer-events:none}.ruler-corner{position:absolute;left:0;top:0;background:#1c1c1f;border-right:1px solid #3a3a40;border-bottom:1px solid #3a3a40}.tb-group{display:flex;align-items:center;gap:6px;padding:0 6px;border-right:1px solid var(--border);height:32px}.tb-group:last-child{border-right:none}.tb-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-right:4px}.topbar.topbar-v2{gap:6px;padding:0 12px;overflow:visible}.topbar.topbar-v2 .tb-brand{font-weight:700;font-size:13px;letter-spacing:.04em;color:var(--text);padding-right:10px;margin-right:4px;border-right:1px solid var(--border);height:32px;display:flex;align-items:center}.topbar.topbar-v2 .tb-spacer{flex:1}.tb-menu-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--text);border:1px solid transparent;border-radius:5px;padding:5px 10px;height:30px;font-size:12px;cursor:pointer;max-width:220px}.tb-menu-btn:hover,.tb-menu-btn.open{background:var(--panel-2);border-color:var(--border)}.tb-menu-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.tb-menu-caret{color:var(--muted);font-size:10px}.tb-cluster{display:inline-flex;align-items:center;gap:2px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:2px}.tb-iconbtn{background:transparent;color:var(--text);border:none;border-radius:4px;padding:4px 8px;min-width:28px;height:24px;font-size:11px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.tb-iconbtn:hover{background:#2c2c33}.tb-iconbtn:disabled{opacity:.3;pointer-events:none}.tb-iconbtn.toggle.on{background:var(--accent);color:#fff}.tb-iconbtn.toggle.on:hover{background:var(--accent-2)}.tb-iconbtn.with-icon{padding:4px 6px;min-width:26px}.tb-iconbtn svg{display:block}.tb-saved{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);padding:0 8px;user-select:none}.tb-saved-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 4px #4ade8099;transition:background .12s}.tb-saved.dirty .tb-saved-dot{background:#fbbf24;box-shadow:0 0 4px #fbbf2499}.tb-popover{position:fixed;z-index:1500;background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:8px;box-shadow:0 12px 40px #0000008c;min-width:240px;max-width:360px;padding:6px;animation:pop-in .1s ease-out}@keyframes pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.menu-list{display:flex;flex-direction:column;gap:1px;max-height:320px;overflow-y:auto}.menu-row{display:grid;grid-template-columns:1fr auto;align-items:center;border-radius:5px}.menu-row:hover{background:var(--panel-2)}.menu-row.active{background:#1f3052}.menu-row.active:hover{background:#25396a}.menu-row-main{display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:transparent;border:none;color:inherit;padding:7px 10px;font:inherit;cursor:pointer;text-align:left;min-width:0;width:100%}.menu-row-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.menu-row-time{font-size:10px;color:var(--muted)}.menu-row-actions{display:inline-flex;gap:1px;padding-right:4px;opacity:0;transition:opacity 80ms}.menu-row:hover .menu-row-actions,.menu-row.active .menu-row-actions{opacity:1}.menu-icon-btn{background:transparent;border:none;color:var(--muted);width:22px;height:22px;border-radius:4px;cursor:pointer;font-size:12px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.menu-icon-btn:hover{background:#2c2c33;color:var(--text)}.menu-icon-btn.danger:hover{background:#4a1f1f;color:#ff8a8a}.menu-item{display:block;width:100%;text-align:left;background:transparent;color:var(--text);border:none;border-radius:5px;padding:7px 10px;font:inherit;font-size:12px;cursor:pointer}.menu-item:hover{background:var(--panel-2)}.menu-sep{height:1px;background:var(--border);margin:4px 2px}.menu-toggle{display:grid;grid-template-columns:16px 1fr;column-gap:8px;row-gap:2px;align-items:center}.menu-toggle .menu-check{color:var(--accent);font-weight:700;visibility:hidden;text-align:center}.menu-toggle.on .menu-check{visibility:visible}.menu-toggle .menu-toggle-label{font-size:12px}.menu-toggle .menu-hint{grid-column:2 / 3;color:var(--muted);font-size:11px;line-height:1.3}.preview-banner{position:fixed;left:50%;bottom:36px;transform:translate(-50%);z-index:50;display:inline-flex;align-items:center;gap:14px;background:#141418eb;color:var(--text);border:1px solid var(--border);border-radius:999px;padding:8px 14px;font-size:12px;box-shadow:0 6px 24px #00000073;backdrop-filter:blur(6px)}.preview-banner kbd{font:inherit;background:var(--panel-2);border:1px solid var(--border);border-radius:3px;padding:0 5px;font-size:10.5px}body.preview-mode .left-panel,body.preview-mode .right-panel,body.preview-mode .right-bottom,body.preview-mode .tools-rail,body.preview-mode .ruler,body.preview-mode .ruler-corner{opacity:.35;pointer-events:none;filter:saturate(.6)}body.preview-mode .canvas-host{background:#2a2a30}.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:6px 4px}.menu-field{display:flex;flex-direction:column;gap:3px;font-size:11px;color:var(--muted)}.menu-field>span{font-size:10px;text-transform:uppercase;letter-spacing:.05em}.menu-field .select,.menu-field .num{width:100%}.menu-apply{width:100%;margin-top:8px}.btn{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:5px 10px;font-size:12px;cursor:pointer}.btn:hover{background:#2c2c33}.btn:disabled{opacity:.5;cursor:default}.btn.small{padding:3px 7px;font-size:11px}.btn.icon{padding:3px 7px;min-width:24px}.btn.toggle.on{background:var(--accent);border-color:var(--accent);color:#fff}.select,.num,input[type=text],input[type=number],textarea{background:#15151a;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font:inherit;width:100%}.select.wide{width:100%}input[type=color]{width:100%;height:26px;padding:1px;background:transparent;border:1px solid var(--border);border-radius:4px}.lc{display:flex;flex-direction:column;gap:1px;font-size:10px;color:var(--muted)}.lc>span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.lc input.num{width:64px}.lc select.select{width:auto;min-width:80px}.panel-header{display:flex;align-items:center;justify-content:space-between;margin:8px 0 6px}.panel-header h3{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.empty{color:var(--muted);font-size:12px;padding:8px;background:var(--panel-2);border-radius:4px;border:1px dashed var(--border)}.page-list{display:flex;flex-direction:column;gap:4px}.page-item{display:grid;grid-template-columns:32px 1fr auto;gap:6px;align-items:center;padding:6px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;cursor:pointer}.page-item.active{border-color:var(--accent);background:#233a5e}.page-item .thumb{width:32px;height:42px;background:#fff;color:#333;display:grid;place-items:center;font-size:12px;font-weight:600;border-radius:2px}.page-item .meta{min-width:0}.page-item .meta input{width:100%;padding:2px 4px;font-size:12px}.page-item .sub{color:var(--muted);font-size:10px;margin-top:2px}.page-item .actions{display:flex;flex-direction:column;gap:2px}.page-item .actions .btn{padding:1px 5px;font-size:11px}.tpl-list{display:flex;flex-direction:column;gap:4px}.tpl-item{display:flex;gap:4px;align-items:center;padding:5px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px}.tpl-item span{flex:1;font-size:12px}.section-title{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:6px}.field{display:flex;flex-direction:column;gap:2px;font-size:11px;color:var(--muted)}.field>span{font-size:10px;text-transform:uppercase;letter-spacing:.04em}.field>.text-area{width:100%;resize:vertical;min-height:60px;font-family:inherit}.btn-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}.fill-page-btn{display:block;width:100%;margin-top:6px}.full-row{margin-top:6px}.full-row>.field{width:100%}.wh-row{grid-column:1 / -1;display:grid;grid-template-columns:1fr auto 1fr;gap:6px;align-items:end}.ar-lock{display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);cursor:pointer;padding:0 6px;height:26px;align-self:end;transition:color .12s,border-color .12s,background .12s}.ar-lock:hover{background:var(--panel-2);color:var(--fg)}.ar-lock.on{color:var(--accent);border-color:var(--accent)}.ar-lock.on:hover{background:color-mix(in srgb,var(--accent) 12%,transparent)}.ar-lock svg{display:block}.readout{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;padding:5px 8px;font-size:12px;color:var(--muted);margin-top:4px}.readout.small{font-size:11px;padding:3px 6px}.modal-overlay{position:fixed;inset:0;background:#0009;display:grid;place-items:center;z-index:1000;animation:fade-in .12s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 12px 50px #00000080;width:min(520px,92vw);max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--text)}.modal-body{padding:12px 16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:6px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:10px 16px;border-top:1px solid var(--border)}.modal-section-title{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;margin-top:8px;margin-bottom:2px}.modal-radio-group{display:flex;flex-wrap:wrap;gap:4px}.modal-radio,.modal-checkbox{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;font-size:12px;cursor:pointer;user-select:none}.modal-radio input,.modal-checkbox input{margin:0}.modal-radio:has(input:checked){background:var(--accent);border-color:var(--accent);color:#fff}.modal-checkbox input:disabled+span,.modal-radio input:disabled+span{opacity:.4}.modal-checkbox:has(input:disabled),.modal-radio:has(input:disabled){opacity:.6;cursor:not-allowed}.modal-row{display:flex;gap:8px;align-items:center}.modal-row input[type=color]{width:60px}.modal-quality{display:grid;grid-template-columns:auto 1fr 70px;gap:8px;align-items:center}.modal-quality label{font-size:11px;color:var(--muted)}.modal-quality input[type=range]{width:100%}.modal-quality input:disabled{opacity:.4}.modal-summary{margin-top:12px;padding:8px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;font-size:12px;color:var(--muted)}.modal-summary strong{color:var(--text)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-2)}.storage-modal{width:min(640px,94vw)}.storage-summary{display:flex;flex-direction:column;gap:6px}.storage-bar{width:100%;height:10px;background:var(--panel-2);border:1px solid var(--border);border-radius:5px;overflow:hidden}.storage-bar-fill{height:100%;background:var(--accent);transition:width .2s ease-out}.storage-bar-fill.warn{background:#d4a017}.storage-bar-fill.bad{background:#c83737}.storage-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--text)}.storage-meta .muted{color:var(--muted)}.storage-note{margin:6px 0 4px;padding:8px 10px;font-size:11px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;color:var(--muted);line-height:1.5}.storage-note b{color:var(--text)}.storage-controls{display:flex;align-items:center;gap:6px;margin-top:4px}.storage-controls-label{font-size:11px;color:var(--muted);margin-right:4px}.storage-sort-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.storage-list{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto;border:1px solid var(--border);border-radius:4px;padding:4px;background:var(--panel-2)}.storage-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:6px 8px;background:var(--panel);border:1px solid var(--border);border-radius:3px}.storage-row-info{min-width:0;display:flex;flex-direction:column;gap:2px}.storage-row-name{font-size:12px;color:var(--text)}.storage-row-sub{font-size:10px;color:var(--muted)}.storage-row-sub code{background:var(--panel-2);padding:1px 4px;border-radius:2px;font-size:10px}.storage-row-size{font-size:12px;color:var(--text);font-variant-numeric:tabular-nums;min-width:70px;text-align:right}.storage-del{color:#d27575}.storage-del:hover{background:#3a2222;border-color:#5a3030}.storage-empty{padding:14px;text-align:center;color:var(--muted);font-size:12px}.storage-tag{display:inline-block;font-size:9px;text-transform:uppercase;letter-spacing:.05em;padding:1px 5px;border-radius:2px;background:var(--accent);color:#fff;vertical-align:middle}.storage-tag.warn{background:#6b5419;color:#ffd97a}.assets-modal{width:min(720px,94vw)}.assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;max-height:60vh;overflow-y:auto;padding:4px;border:1px solid var(--border);border-radius:4px;background:var(--panel-2)}.asset-card{display:flex;flex-direction:column;gap:6px;padding:8px;background:var(--panel);border:1px solid var(--border);border-radius:4px}.asset-thumb{width:100%;aspect-ratio:4 / 3;background:repeating-conic-gradient(#2a2a30 0% 25%,#1f1f24 0% 50%) 50% / 16px 16px;border:1px solid var(--border);border-radius:3px;display:grid;place-items:center;overflow:hidden}.asset-thumb img{width:100%;height:100%;object-fit:contain;display:block}.asset-thumb.missing{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em}.asset-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.asset-name{font-size:11px;color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-sub{font-size:10px;color:var(--muted)}.asset-actions{display:flex;gap:6px}.asset-actions .btn{flex:1}.rail-btn{width:32px;height:32px;display:grid;place-items:center;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:16px;line-height:1;padding:0}.rail-btn:hover{background:#2c2c33;border-color:#3a3a40}.rail-btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.layer-list{display:flex;flex-direction:column;gap:2px}.layer-item{display:grid;grid-template-columns:18px 1fr auto auto;gap:6px;align-items:center;padding:4px 6px;background:var(--panel-2);border:1px solid var(--border);border-radius:3px;cursor:pointer;font-size:12px;position:relative;user-select:none}.layer-item.active{border-color:var(--accent);background:#233a5e}.layer-item.hidden .layer-name,.layer-item.hidden .layer-icon{opacity:.4;font-style:italic}.layer-item.dragging{opacity:.5}.layer-item.drop-before:before,.layer-item.drop-after:after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--accent)}.layer-item.drop-before:before{top:-1px}.layer-item.drop-after:after{bottom:-1px}.layer-icon{width:18px;height:18px;display:grid;place-items:center;font-size:11px;color:var(--muted)}.layer-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layer-icon-btn{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:3px;line-height:0;border-radius:3px;display:inline-flex;align-items:center;justify-content:center}.layer-icon-btn svg{display:block}.layer-icon-btn:hover{background:#2c2c33;color:var(--text)}.layer-icon-btn.active{color:var(--accent)}.layer-icon svg{display:block}.layer-group{display:flex;align-items:center;gap:3px;padding:4px 6px;margin-top:8px;background:var(--panel);border:1px solid var(--border);border-radius:3px;font-size:12px}.layer-group.active-layer{border-color:var(--accent)}.layer-active-dot{flex:0 0 auto;width:12px;height:12px;border-radius:50%;border:1px solid var(--border);cursor:pointer;padding:0}.layer-group-name{flex:1 1 auto;min-width:0;background:transparent;border:1px solid transparent;color:var(--text);font:inherit;font-weight:600;padding:2px 4px;border-radius:3px}.layer-group-name:hover,.layer-group-name:focus{border-color:var(--border);background:var(--panel-2);outline:none}.layer-group+.layer-item,.layer-group~.layer-item{margin-left:10px}.inline-text-edit{position:absolute;margin:0;padding:0;border:1px dashed var(--accent);outline:none;background:#ffffff0a;resize:none;overflow:hidden;white-space:pre-wrap;word-wrap:break-word;box-sizing:border-box;z-index:5;caret-color:var(--accent)}.dpi-readout{font-variant-numeric:tabular-nums;font-weight:600}.dpi-readout.ok{color:#4ade80}.dpi-readout.warn{color:#facc15}.dpi-readout.bad{color:#f87171}.align-section .align-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-top:4px}.align-section .align-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px 0;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer}.align-section .align-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.align-section .align-btn:disabled{opacity:.35;cursor:not-allowed}.find-modal{width:min(420px,92vw)}.find-modal .row{display:grid;grid-template-columns:90px 1fr;gap:6px;align-items:center}.find-modal .row input[type=text]{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:5px 7px;font:inherit}.find-modal .find-opts{display:flex;gap:12px;margin-top:4px;grid-template-columns:none}.find-modal .find-opts label{display:inline-flex;align-items:center;gap:4px;cursor:pointer}.find-modal .find-status{font-size:12px;color:var(--muted);margin-top:4px;min-height:1.2em}.guides-overlay{pointer-events:none}.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.swatch-card{display:flex;align-items:center;gap:8px;padding:6px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px}.swatch-chip{flex:0 0 auto;width:34px;height:34px;border-radius:4px;border:1px solid var(--border);cursor:pointer}.swatch-meta{flex:1 1 auto;min-width:0}.swatch-name{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swatch-spec{font-size:10px;color:var(--muted)}.swatch-actions{display:flex;flex-wrap:wrap;gap:3px}.swatch-editor-host:empty{display:none}.swatch-editor{margin-top:12px;padding:10px;border:1px solid var(--border);border-radius:4px;background:var(--panel-2)}.swatch-preview{height:36px;border-radius:4px;border:1px solid var(--border);margin-bottom:8px}.style-list{display:flex;flex-direction:column;gap:6px}.style-row{display:flex;align-items:center;gap:8px;padding:6px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px}.style-name{flex:1 1 auto;min-width:0}.style-spec{font-size:10px;color:var(--muted);white-space:nowrap}.style-actions{display:flex;gap:3px}
