:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Pretendard,system-ui,Apple SD Gothic Neo,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{color:#1f2330;background:#f4f5f7}.app{flex-direction:column;height:100vh;display:flex}.gate{z-index:1000;background:linear-gradient(135deg,#1b2030,#2d3450);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gate-card{text-align:center;background:#fff;border-radius:16px;width:320px;max-width:90vw;padding:36px 32px;box-shadow:0 20px 60px #00000059}.gate-logo{margin-bottom:6px;font-size:22px;font-weight:800}.gate-desc{color:#666;margin:0 0 18px;font-size:13px}.gate-input{text-align:center;border:1px solid #d6d9e3;border-radius:10px;width:100%;margin-bottom:10px;padding:12px 14px;font-size:15px}.gate-input:focus{border-color:#2d7bff;outline:none}.gate-btn{color:#fff;cursor:pointer;background:#2d7bff;border:none;border-radius:10px;width:100%;padding:12px;font-size:15px;font-weight:700}.gate-btn:hover{background:#1b66e0}.gate-btn:disabled{opacity:.6;cursor:default}.gate-err{color:#c0392b;margin:10px 0 0;font-size:12px}.toolbar{z-index:20;background:#fff;border-bottom:1px solid #e5e7ee;flex-shrink:0;align-items:center;gap:12px;padding:10px 16px;display:flex;position:relative}.toolbar .brand{font-size:16px;font-weight:800}.toolbar .tag{color:#fff;vertical-align:middle;background:#2d7bff;border-radius:6px;margin-left:6px;padding:2px 6px;font-size:11px}.toolbar .spacer{flex:1}.tb{color:#555;align-items:center;gap:6px;font-size:13px;display:flex}.tb select{background:#fff;border:1px solid #d6d9e3;border-radius:8px;padding:6px 8px;font-size:13px}.tb-btn{cursor:pointer;background:#fff;border:1px solid #d6d9e3;border-radius:8px;padding:7px 12px;font-size:13px}.tb-btn:hover{background:#f3f5fb}.tb-btn.primary{color:#fff;background:#2d7bff;border-color:#2d7bff}.tb-btn.primary:hover{background:#1b66e0}.dropdown{position:relative}.dropdown:hover .hovermenu{display:flex}.menu{z-index:50;background:#fff;border:1px solid #e0e3ee;border-radius:10px;flex-direction:column;gap:2px;min-width:200px;padding:6px;display:flex;position:absolute;top:110%;right:0;box-shadow:0 8px 30px #0000001f}.hovermenu{display:none}.menu-open{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 10px;font-size:13px}.menu-open:hover{background:#eef3ff}.menu-row{align-items:center;display:flex}.menu-row .menu-open{flex:1}.menu-del{color:#c0392b;cursor:pointer;background:0 0;border:none;padding:4px 8px}.menu-empty{color:#999;padding:10px;font-size:13px}.modal-overlay{z-index:900;background:#14182880;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;flex-direction:column;max-height:88vh;display:flex;box-shadow:0 24px 70px #0000004d}.fmt-modal{width:860px;max-width:96vw;padding:18px 20px 16px}.modal-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-head h2{margin:0;font-size:18px}.modal-x{cursor:pointer;background:#eef0f5;border:none;border-radius:50%;width:30px;height:30px;font-size:13px}.modal-x:hover{background:#e2e6f0}.fmt-actions{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.fmt-actions .btn{width:auto;margin:0}.fmt-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;padding:2px;display:grid;overflow-y:auto}.fmt-card{background:#fff;border:1px solid #e2e6f0;border-radius:12px;position:relative;overflow:hidden}.fmt-card.current{border-color:#2d7bff;outline:2px solid #2d7bff}.fmt-pick{cursor:pointer;text-align:left;background:0 0;border:none;width:100%;padding:0}.fmt-thumb-wrap{aspect-ratio:1;background:repeating-conic-gradient(#f0f0f0 0% 25%,#fff 0% 50%) 50%/18px 18px;border-bottom:1px solid #eef0f5;justify-content:center;align-items:center;width:100%;display:flex}.fmt-thumb{width:100%;height:100%}.fmt-name{white-space:nowrap;text-overflow:ellipsis;padding:8px 10px 2px;font-size:13px;font-weight:700;overflow:hidden}.fmt-cur{color:#2d7bff}.fmt-size{color:#8a90a0;padding:0 10px 8px;font-size:11px}.fmt-card-actions{opacity:0;gap:4px;transition:opacity .12s;display:flex;position:absolute;top:6px;right:6px}.fmt-card:hover .fmt-card-actions{opacity:1}.fmt-card-actions button{cursor:pointer;background:#ffffffeb;border:none;border-radius:7px;width:26px;height:26px;font-size:12px;box-shadow:0 1px 4px #0003}.fmt-card-actions button:hover{background:#eef3ff}.fmt-card-actions button.del:hover{background:#ffe0e0}.help-banner{background:#eef3ff;border-bottom:1px solid #d6e0ff;flex-wrap:wrap;align-items:stretch;gap:8px;padding:12px 44px 12px 16px;display:flex;position:relative}.help-title{color:#1b4ea8;width:100%;margin-bottom:2px;font-size:13px;font-weight:800}.help-steps{flex-wrap:wrap;flex:1;gap:8px;display:flex}.help-step{background:#fff;border:1px solid #dbe4f7;border-radius:9px;flex:1;align-items:flex-start;gap:7px;min-width:150px;padding:7px 10px;display:flex}.help-num{color:#fff;background:#2d7bff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;font-size:12px;font-weight:800;display:flex}.help-step-t{color:#222;font-size:12px;font-weight:700}.help-step-d{color:#667;font-size:11px;line-height:1.3}.help-close{color:#1b4ea8;cursor:pointer;background:#d6e0ff;border:none;border-radius:50%;width:24px;height:24px;font-size:12px;position:absolute;top:10px;right:12px}.help-close:hover{background:#c3d3fb}.body{flex:1;min-height:0;display:flex}.left{background:#fff;border-right:1px solid #e5e7ee;width:300px;overflow-y:auto}.right{background:#fff;border-left:1px solid #e5e7ee;width:300px;overflow-y:auto}.center{background:#eceef3;flex:1;justify-content:center;align-items:center;padding:24px;display:flex;overflow:hidden}.right-section{border-bottom:1px solid #eef0f5;padding:14px}.right-section h3,.assets h3{color:#333;margin:0 0 10px;font-size:13px;font-weight:800}.assets section{border-bottom:1px solid #eef0f5;padding:14px}.assets small{color:#999;font-weight:500}.hint{color:#8a8f9e;margin:8px 0 0;font-size:11px;line-height:1.5}.btn{cursor:pointer;background:#f7f9fc;border:1px solid #d6d9e3;border-radius:8px;width:100%;margin-bottom:8px;padding:9px;font-size:13px;display:block}.btn:hover{background:#eef3ff}.btn:disabled{opacity:.5;cursor:default}.btn.primary{color:#fff;background:#2d7bff;border-color:#2d7bff}.btn.primary:hover{background:#1b66e0}.ai-prompt{resize:vertical;border:1px solid #d6d9e3;border-radius:8px;width:100%;margin-bottom:8px;padding:8px 10px;font-family:inherit;font-size:13px}.hint.err{color:#c0392b}.hint code{background:#eef0f5;border-radius:4px;padding:1px 5px;font-size:11px}.thumb{background:repeating-conic-gradient(#e8e8e8 0% 25%,#fff 0% 50%) 50%/16px 16px;border-radius:8px;width:100%;margin-top:6px}.ref-row{margin-bottom:6px}.ref-add{margin-bottom:0!important}.ref-thumb-wrap{display:inline-block;position:relative}.ref-thumb{border:1px solid #d6d9e3;border-radius:8px;max-height:90px;display:block}.ref-del{color:#fff;cursor:pointer;background:#c0392b;border:none;border-radius:50%;width:22px;height:22px;font-size:12px;position:absolute;top:-8px;right:-8px}.ref-del:hover{background:#a93226}.row{align-items:center;gap:8px;margin-bottom:8px;font-size:12px;display:flex}.row-label{color:#666;flex-shrink:0;width:80px}.row-field{flex:1}.row input,.row select,.row textarea{border:1px solid #d6d9e3;border-radius:7px;width:100%;padding:6px 8px;font-family:inherit;font-size:13px}.row input[type=color]{height:32px;padding:2px}.row input[type=range],.row input[type=checkbox]{width:auto}.row-divider{background:#eef0f5;height:1px;margin:12px 0}.seg{gap:4px;margin-bottom:10px;display:flex}.seg button{cursor:pointer;background:#fff;border:1px solid #d6d9e3;border-radius:7px;flex:1;padding:7px 4px;font-size:12px}.seg button.on{color:#fff;background:#2d7bff;border-color:#2d7bff}.qrow{cursor:text;flex-direction:column;gap:3px;margin-bottom:9px;display:flex}.qlabel{color:#888;font-size:11px}.qrow input{border:1px solid #d6d9e3;border-radius:7px;padding:7px 9px;font-family:inherit;font-size:13px}.panel-empty{color:#9aa0ac;text-align:center;padding:16px;font-size:12px}.layerlist{flex-direction:column;gap:3px;display:flex}.layer-item{cursor:pointer;border-radius:7px;align-items:center;gap:2px;padding:5px 6px;font-size:12px;display:flex}.layer-item:hover{background:#f3f5fb}.layer-item.selected{background:#e7f0ff;outline:1px solid #2d7bff}.layer-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.layer-type{color:#aaa;text-align:center;width:18px}.ic{cursor:pointer;background:0 0;border:none;border-radius:5px;padding:2px 4px;font-size:12px}.ic:hover{background:#e2e6f0}.ic.danger:hover{background:#ffe0e0}.comp-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.comp-item{position:relative}.comp-insert{cursor:pointer;background:#fafbfe;border:1px solid #e0e3ee;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;min-height:78px;padding:10px 6px;display:flex}.comp-insert:hover{background:#eef3ff;border-color:#2d7bff}.comp-name{color:#555;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:11px;overflow:hidden}.comp-thumb{object-fit:contain;background:repeating-conic-gradient(#e8e8e8 0% 25%,#fff 0% 50%) 50%/10px 10px;border-radius:6px;width:46px;height:46px}.comp-swatch{border:1px solid #d6d9e3;border-radius:6px;width:46px;height:28px;display:inline-block}.comp-textchip{text-overflow:ellipsis;white-space:nowrap;border-radius:8px;max-width:100%;padding:6px 10px;font-size:13px;font-weight:700;overflow:hidden}.comp-del{color:#fff;cursor:pointer;background:#c0392b;border:none;border-radius:50%;width:20px;height:20px;font-size:11px;line-height:1;position:absolute;top:-6px;right:-6px}.comp-del:hover{background:#a93226}
