:root{--bg:#f5f6f8;--panel:#fff;--ink:#16181d;--ink-2:#5b616e;--ink-3:#878d99;--line:#e7e9ee;--line-2:#eef0f3;--accent:#5b5bd6;--accent-soft:#ececfb;--accent-ink:#4a4ac4;--green:#1f9d6b;--danger:#d6455b;--radius:9px;--radius-sm:6px;--shadow-sm:0 1px 2px #10121d0a, 0 1px 3px #10121d0d;--shadow-md:0 4px 14px #10121d12;--shadow-lg:0 12px 40px #10121d29}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;letter-spacing:-.01em;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:13px;line-height:1.45}button{font-family:inherit}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.topbar{background:var(--panel);border-bottom:1px solid var(--line);flex:0 0 56px;align-items:center;gap:14px;height:56px;padding:0 16px;display:flex}.brand{letter-spacing:-.02em;align-items:center;gap:9px;font-size:14px;font-weight:600;display:flex}.brand .glyph{background:var(--accent);color:#fff;border-radius:7px;place-items:center;width:26px;height:26px;display:grid;box-shadow:0 1px 3px #5b5bd666}.brand .glyph svg{width:15px;height:15px}.divider{background:var(--line);width:1px;height:22px}.project{color:var(--ink-2);align-items:center;gap:8px;font-weight:450;display:flex}.project input{color:var(--ink);letter-spacing:-.01em;background:0 0;border:1px solid #0000;border-radius:6px;width:150px;padding:4px 8px;font-family:inherit;font-size:13px;font-weight:500}.project input:hover{background:var(--bg)}.project input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--panel);outline:none}.chip{background:var(--line-2);color:var(--ink-2);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:500}.proj-btn{border:1px solid var(--line);background:var(--panel);cursor:pointer;width:32px;height:32px;color:var(--ink-2);border-radius:8px;place-items:center;display:grid}.proj-btn:hover{background:var(--bg);color:var(--accent);border-color:var(--accent)}.proj-btn svg{width:16px;height:16px}.save-status{color:var(--ink-3);align-items:center;gap:4px;min-width:56px;font-size:11px;display:inline-flex}.save-status .save-check{width:12px;height:12px;color:var(--green)}.save-status.saving{color:var(--ink-3)}.spacer{flex:1}.seg{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:2px;display:flex}.seg button{cursor:pointer;width:30px;height:26px;color:var(--ink-3);background:0 0;border:0;border-radius:6px;place-items:center;display:grid}.seg button.active{background:var(--panel);color:var(--accent);box-shadow:var(--shadow-sm)}.seg button svg{width:15px;height:15px}.zoom{font-variant-numeric:tabular-nums;color:var(--ink-2);padding:0 6px;font-weight:500}.btn{border:1px solid var(--line);background:var(--panel);height:34px;color:var(--ink);cursor:pointer;border-radius:8px;align-items:center;gap:7px;padding:0 14px;font-size:13px;font-weight:500;display:inline-flex}.btn:hover{background:#fafbfc}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 3px #5b5bd659}.btn.primary:hover{background:var(--accent-ink)}.btn svg{width:15px;height:15px}.avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c7cf0,#5b5bd6);border:0;border-radius:50%;flex:none;place-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:grid}.auth-wrap{position:relative}.menu-backdrop{z-index:40;position:fixed;inset:0}.account-menu{z-index:41;background:var(--panel);border:1px solid var(--line);width:220px;box-shadow:var(--shadow-lg);border-radius:10px;padding:12px;position:absolute;top:40px;right:0}.account-email{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.account-sub{color:var(--green);margin-top:2px;font-size:11px}.body{flex:1;min-height:0;display:flex}.panel{background:var(--panel);flex-direction:column;min-height:0;display:flex}.panel.left{border-right:1px solid var(--line);flex:0 0 264px;width:264px}.panel.right{border-left:1px solid var(--line);flex:0 0 288px;width:288px}.panel-scroll{padding:4px 0;overflow-y:auto}.section{border-bottom:1px solid var(--line-2);padding:16px 18px}.section h3{letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:6px;margin-bottom:14px;font-size:11px;font-weight:600;display:flex}.empty-note{color:var(--ink-3);font-size:12px;line-height:1.5}.field{margin-bottom:14px}.field:last-child{margin-bottom:0}.field label{color:var(--ink-2);justify-content:space-between;align-items:center;margin-bottom:7px;font-weight:500;display:flex}.field label .val{color:var(--ink);font-variant-numeric:tabular-nums}.stepper{border:1px solid var(--line);border-radius:var(--radius-sm);align-items:center;height:32px;display:flex;overflow:hidden}.stepper button{background:var(--panel);cursor:pointer;width:32px;height:100%;color:var(--ink-2);border:0;place-items:center;font-size:15px;display:grid}.stepper button:hover{background:var(--bg)}.stepper button:disabled{color:var(--line);cursor:not-allowed}.stepper .num{text-align:center;font-variant-numeric:tabular-nums;border-left:1px solid var(--line);border-right:1px solid var(--line);flex:1;font-weight:500}.slider-input{appearance:none;background:var(--line);cursor:pointer;border-radius:4px;outline:none;width:100%;height:4px;margin:13px 0}.slider-input::-webkit-slider-thumb{appearance:none;background:var(--panel);border:1px solid var(--line);width:15px;height:15px;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:50%}.slider-input::-moz-range-thumb{background:var(--panel);border:1px solid var(--line);width:15px;height:15px;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:50%}.input{border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;height:32px;color:var(--ink);background:var(--panel);padding:0 10px;font-family:JetBrains Mono,monospace;font-size:12px}.input.sans{font-family:Inter,sans-serif;font-size:13px}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.toggle-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.toggle-row .lab{color:var(--ink);font-weight:500}.toggle-row .sub{color:var(--ink-3);margin-top:2px;font-size:11px}.toggle{background:var(--line);cursor:pointer;border:0;border-radius:20px;flex:none;width:38px;height:22px;transition:background .15s;position:relative}.toggle.on{background:var(--accent)}.toggle .dot{width:18px;height:18px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:left .15s;position:absolute;top:2px;left:2px}.toggle.on .dot{left:18px}.tpl-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.tpl{border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;background:var(--panel);text-align:left;padding:8px}.tpl:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.tpl.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.tpl .mini{gap:3px;height:42px;margin-bottom:6px;display:grid}.tpl .mini span{background:var(--accent-soft);border-radius:2px}.tpl .name{color:var(--ink-2);font-size:11px;font-weight:500}.item-row{border-radius:var(--radius-sm);cursor:pointer;color:var(--ink-2);align-items:center;gap:8px;padding:7px 9px;font-weight:450;display:flex}.item-row:hover{background:var(--bg)}.item-row.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:500}.item-row .dot{border-radius:2px;flex:none;width:7px;height:7px}.item-row .lab{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.add-btn{border:1px dashed var(--line);border-radius:var(--radius-sm);background:var(--panel);width:100%;height:34px;color:var(--accent);cursor:pointer;justify-content:center;align-items:center;gap:6px;margin-top:4px;font-weight:500;display:flex}.add-btn:hover{border-color:var(--accent);background:var(--accent-soft)}.add-btn svg{width:14px;height:14px}.upload-btn{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel);width:100%;height:34px;color:var(--ink);cursor:pointer;justify-content:center;align-items:center;gap:7px;margin-bottom:14px;font-size:13px;font-weight:500;display:flex}.upload-btn:hover{background:var(--bg);border-color:var(--accent);color:var(--accent-ink)}.btn-danger{border-radius:var(--radius-sm);width:100%;height:34px;color:var(--danger);cursor:pointer;background:#fdf2f4;border:1px solid #f1c6cd;justify-content:center;align-items:center;gap:7px;margin-top:4px;font-weight:500;display:flex}.btn-danger:hover{background:#fbe7ea}.btn-danger svg{width:14px;height:14px}.canvas-wrap{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex}.canvas-toolbar{border-bottom:1px solid var(--line);height:42px;color:var(--ink-3);background:#fff9;flex:0 0 42px;align-items:center;gap:8px;padding:0 16px;font-size:12px;display:flex}.canvas-toolbar .crumb{color:var(--ink-2)}.canvas{flex:1;justify-content:center;padding:34px;display:flex;overflow:auto}.frame{background:var(--panel);border:1px solid var(--line);width:100%;box-shadow:var(--shadow-md);border-radius:14px;height:max-content;padding:22px;transition:max-width .2s}.gallery{gap:14px;display:grid}.gallery.masonry{column-gap:14px;display:block}.gallery.masonry .tile{break-inside:avoid;margin-bottom:14px}.tile{border:1px solid var(--line-2);background:var(--line-2);cursor:pointer;border-radius:10px;position:relative;overflow:hidden}.gallery:not(.masonry) .tile{min-height:0}.tile img,.tile .thumb-fallback{object-fit:cover;width:100%;display:block}.thumb-fallback{place-items:center;display:grid}.thumb-fallback svg{opacity:.7;width:28px;height:28px}.gallery.masonry .tile .thumb-fallback{height:180px}.insp-thumb .thumb-fallback{height:120px}.gallery:not(.masonry) .tile img{height:100%;position:absolute;inset:0}.tile .cap{color:#fff;z-index:2;background:linear-gradient(#0000,#080a0f9e);padding:18px 12px 10px;font-size:12px;font-weight:500;position:absolute;bottom:0;left:0;right:0}.tile.sel{outline:2px solid var(--accent);outline-offset:2px}.tile.drop{outline:2px dashed var(--accent);outline-offset:2px}.tile .drop-hint{z-index:4;color:#fff;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#5b5bd652;place-items:center;font-size:12px;font-weight:600;display:grid;position:absolute;inset:0}.frame.frame-drop{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft), var(--shadow-md)}.tile .badge{background:var(--accent);color:#fff;z-index:3;border-radius:5px;padding:2px 7px;font-size:10px;font-weight:600;position:absolute;top:8px;left:8px}.handle{border:1.5px solid var(--accent);z-index:3;background:#fff;border-radius:2px;width:9px;height:9px;position:absolute}.handle.tl{top:-5px;left:-5px}.handle.tr{top:-5px;right:-5px}.handle.bl{bottom:-5px;left:-5px}.handle.br{bottom:-5px;right:-5px}.insp-thumb{border:1px solid var(--line);border-radius:8px;margin-bottom:14px;overflow:hidden}.insp-thumb img{object-fit:cover;width:100%;height:120px;display:block}.row2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.note{color:var(--ink-3);background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 10px;font-size:11px;line-height:1.5}.align-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.align-grid button{border:1px solid var(--line);background:var(--panel);cursor:pointer;height:30px;color:var(--ink-3);border-radius:6px;place-items:center;display:grid}.align-grid button.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.align-grid button svg{width:14px;height:14px}.overlay{z-index:50;background:#10121d59;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal{background:var(--panel);width:640px;max-width:100%;max-height:86vh;box-shadow:var(--shadow-lg);border-radius:14px;flex-direction:column;display:flex;overflow:hidden}.modal-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.modal-head h2{font-size:15px;font-weight:600}.icon-btn{cursor:pointer;width:30px;height:30px;color:var(--ink-3);background:0 0;border:0;border-radius:7px;place-items:center;display:grid}.icon-btn:hover{background:var(--bg);color:var(--ink)}.icon-btn svg{width:16px;height:16px}.modal-body{padding:16px 18px;overflow-y:auto}.code-tabs{background:var(--bg);border:1px solid var(--line);border-radius:8px;gap:2px;margin-bottom:14px;padding:3px;display:flex}.code-tabs button{height:30px;color:var(--ink-2);cursor:pointer;background:0 0;border:0;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.code-tabs button.active{background:var(--panel);color:var(--ink);box-shadow:var(--shadow-sm)}.code-tabs button .lock{width:11px;height:11px;color:var(--ink-3)}.code-wrap{position:relative}.code-wrap .copy{border:1px solid var(--line);background:var(--panel);height:28px;color:var(--ink-2);cursor:pointer;border-radius:6px;align-items:center;gap:5px;padding:0 10px;font-size:11px;font-weight:500;display:flex;position:absolute;top:10px;right:10px}.code-wrap .copy:hover{background:var(--bg)}.code-wrap .copy svg{width:12px;height:12px}.code{border:1px solid var(--line);color:#3a3f4a;white-space:pre;background:#fbfbfd;border-radius:8px;max-height:360px;padding:14px;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.7;overflow:auto}.pro-hint{background:var(--accent-soft);border:1px solid #dcdcf7;border-radius:8px;align-items:flex-start;gap:10px;margin-top:14px;padding:12px 13px;display:flex}.pro-hint .ico{color:var(--accent);flex:none}.pro-hint .ico svg{width:16px;height:16px}.pro-hint .txt{color:var(--accent-ink);font-size:12px;font-weight:450;line-height:1.5}.pro-hint .txt b{font-weight:600}.proj-list{flex-direction:column;gap:6px;display:flex}.proj-row{border:1px solid var(--line);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.proj-row:hover{background:var(--bg);border-color:var(--accent)}.proj-row.current{border-color:var(--accent);background:var(--accent-soft)}.proj-meta{flex:1;min-width:0}.proj-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.proj-sub{color:var(--ink-3);margin-top:2px;font-size:11px;display:block}.empty-canvas{border:1.5px dashed var(--line);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;display:flex}.empty-canvas .ec-title{color:var(--ink);font-size:15px;font-weight:600}.empty-canvas .ec-sub{color:var(--ink-3);max-width:280px;margin-bottom:8px;font-size:12px}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{border:2px solid var(--panel);background:#d7dae0;border-radius:9px}
