*{margin:0;padding:0;box-sizing:border-box}body{font-family:Sarabun,sans-serif;background:#0f1c30;color:#fff;overflow:hidden;height:100vh;height:100dvh}.editor-layout{display:flex;flex-direction:column;height:100vh;height:100dvh}.editor-toolbar{height:48px;background:#12203a;border-bottom:1px solid #1e3a55;display:flex;align-items:center;padding:0 12px;gap:6px;flex-shrink:0}.editor-body{display:flex;flex:1;overflow:hidden}.editor-sidebar{width:280px;background:#34495e;border-right:1px solid #1e3a55;display:flex;flex-shrink:0;overflow:hidden}.editor-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;background:#152235 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Crect width='8' height='8' fill='%23192a40'/%3E%3Crect x='8' y='8' width='8' height='8' fill='%23192a40'/%3E%3C/svg%3E");overflow:hidden;position:relative}.editor-props{width:280px;background:#34495e;border-left:1px solid #1e3a55;overflow-y:auto;flex-shrink:0}.editor-bottom{height:56px;background:#12203a;border-top:1px solid #1e3a55;display:flex;align-items:center;padding:0 16px;gap:8px;flex-shrink:0}.tb-group{display:flex;align-items:center;gap:1px;background:#2c3e50;border-radius:6px;padding:2px}.tb-btn{background:none;border:none;color:#94b4c1;padding:7px;font-size:12px;cursor:pointer;border-radius:4px;font-family:Sarabun,sans-serif;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;min-width:30px;min-height:30px;position:relative}.tb-btn:hover{background:#2d4a66;color:#fff}.tb-btn.active{background:#4a7c8f;color:#111}.tb-btn svg{width:16px;height:16px;flex-shrink:0}.tb-btn[title]:hover:after{content:attr(title);position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#0f1c30;color:#ccc;font-size:10px;padding:4px 10px;border-radius:5px;white-space:nowrap;z-index:100;pointer-events:none;border:1px solid #2d4a66;animation:tooltipIn .15s ease}.tb-btn[title]:hover:before{content:"";position:absolute;top:calc(100% + 3px);left:50%;transform:translate(-50%);border:4px solid transparent;border-bottom-color:#2d4a66;z-index:101;pointer-events:none;animation:tooltipIn .15s ease}@keyframes tooltipIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tb-sep{display:none}.tb-brand{font-size:14px;font-weight:600;margin-right:8px;text-decoration:none;letter-spacing:.05em;background:linear-gradient(110deg,#3d6b7e,#4a7c8f,#a3c4cf,#4a7c8f,#3d6b7e);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s linear infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.tb-spacer{flex:1}.sb-tabs{width:72px;background:#101d35;border-right:1px solid #222;display:flex;flex-direction:column;align-items:center;padding:6px 0;gap:1px;flex-shrink:0}.sb-tab{width:64px;height:52px;background:none;border:none;color:#5a7e95;cursor:pointer;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:all .15s;border-left:3px solid transparent}.sb-tab:hover{color:#ccc;background:#2c3e50}.sb-tab.active{color:#4a7c8f;background:#4a7c8f0f;border-left-color:#4a7c8f}.sb-tab svg{width:18px;height:18px;flex-shrink:0}.sb-tab span{font-size:9px;line-height:1;white-space:nowrap}.sb-panels{flex:1;overflow-y:auto;overflow-x:hidden}.sb-panel{display:none;opacity:0;transition:opacity .2s ease}.sb-section{padding:14px;border-bottom:1px solid #1e3a55}.sb-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#6a8fa0;margin-bottom:10px;font-weight:500}.sb-btn{display:flex;align-items:center;gap:8px;width:100%;background:#1a3050;border:1px solid #1e3a55;color:#bbb;padding:10px 12px;font-size:12px;cursor:pointer;border-radius:6px;font-family:Sarabun,sans-serif;margin-bottom:6px;transition:all .15s}.sb-btn:hover{background:#3d5a6e;color:#fff;border-color:#345570}.sb-btn svg{width:16px;height:16px;flex-shrink:0}.cat-filter{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.cat-btn{background:#1a3050;border:1px solid #1e3a55;color:#8ab0c0;padding:5px 10px;font-size:11px;cursor:pointer;border-radius:20px;font-family:Sarabun,sans-serif;transition:all .15s;white-space:nowrap}.cat-btn:hover{background:#3d5a6e;color:#fff}.cat-btn.active{background:#4a7c8f;color:#111;border-color:#4a7c8f;font-weight:500}.bg-cat-filter{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:8px}.bg-cat-filter .cat-btn{padding:3px 8px;font-size:10px}.bg-page-btn{background:#1a3050;border:1px solid #1e3a55;color:#8ab0c0;width:28px;height:28px;font-size:11px;cursor:pointer;border-radius:4px;font-family:Sarabun,sans-serif;transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.bg-page-btn:hover{background:#3d5a6e;color:#fff;border-color:#3d5e7a}.bg-page-btn.active{background:#4a7c8f;color:#111;border-color:#4a7c8f;font-weight:600}.bg-gallery-item{aspect-ratio:3/2;border-radius:6px;cursor:pointer;overflow:hidden;border:2px solid transparent;transition:all .2s;position:relative}.bg-gallery-item:hover{border-color:#4a7c8f;transform:scale(1.03);box-shadow:0 4px 12px #4a7c8f33}.bg-gallery-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.bg-gallery-item .bg-overlay{position:absolute;inset:0;background:linear-gradient(transparent 50%,#000000b3);opacity:0;transition:opacity .2s;display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px}.bg-gallery-item:hover .bg-overlay{opacity:1}.bg-gallery-item .bg-label{color:#fff;font-size:9px;text-shadow:0 1px 3px rgba(0,0,0,.8)}.stock-suggest{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:8px}.suggest-btn{background:#1a3050;border:1px solid #1e3a55;color:#94b4c1;padding:4px 8px;font-size:10px;cursor:pointer;border-radius:20px;font-family:Sarabun,sans-serif;transition:all .15s}.suggest-btn:hover{background:#3d5a6e;color:#4a7c8f;border-color:#4a7c8f}.stock-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;max-height:280px;overflow-y:auto}.stock-item{aspect-ratio:3/2;border-radius:4px;cursor:pointer;overflow:hidden;border:2px solid transparent;transition:all .15s;position:relative}.stock-item:hover{border-color:#4a7c8f;transform:scale(1.02)}.stock-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.stock-item .stock-use{position:absolute;bottom:0;left:0;right:0;background:#000c;color:#4a7c8f;font-size:9px;text-align:center;padding:3px;opacity:0;transition:opacity .15s}.stock-item:hover .stock-use{opacity:1}.stock-loading{grid-column:1/-1;text-align:center;color:#6a8fa0;font-size:11px;padding:20px 0}.template-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;max-height:500px;overflow-y:auto;padding-right:4px}.template-card{aspect-ratio:4/3;background:#2c3e50;border:2px solid transparent;border-radius:6px;cursor:pointer;overflow:hidden;transition:all .2s;position:relative}.template-card:hover{border-color:#4a7c8f;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.template-card img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.template-card.active{border-color:#4a7c8f}.tpl-mini{width:100%;height:100%}.prop-group{padding:14px 16px;border-bottom:1px solid #1e3a55}.prop-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#6a8fa0;margin-bottom:8px;font-weight:500}.prop-input{width:100%;background:#1a3050;border:1px solid #2d4a66;color:#eee;padding:8px 10px;font-size:12px;border-radius:6px;font-family:Sarabun,sans-serif;transition:border-color .15s}.prop-input:focus{outline:none;border-color:#4a7c8f;box-shadow:0 0 0 2px #4a7c8f1f}.prop-row{display:flex;gap:6px;margin-bottom:6px}.prop-row .prop-input{flex:1}.prop-color{width:36px;height:36px;border:2px solid #2d4a66;border-radius:6px;cursor:pointer;padding:0;transition:border-color .15s}.prop-color:hover{border-color:#4a7c8f}.font-select{width:100%;background:#1a3050;border:1px solid #2d4a66;color:#eee;padding:8px 10px;font-size:13px;border-radius:6px;cursor:pointer;transition:border-color .15s}.font-select:focus{outline:none;border-color:#4a7c8f;box-shadow:0 0 0 2px #4a7c8f1f}.bottom-price{font-size:14px;color:#4a7c8f;font-weight:600}.bottom-btn{padding:8px 24px;font-size:13px;font-weight:600;border:none;border-radius:6px;cursor:pointer;font-family:Sarabun,sans-serif;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.bottom-export-group{display:flex;gap:1px;background:#2d4a66;border-radius:6px;overflow:hidden}.btn-export{padding:8px 16px;font-size:11px;font-weight:500;background:#2c3e50;border:none;color:#94b4c1;cursor:pointer;font-family:Sarabun,sans-serif;transition:all .15s}.btn-export:hover{background:#2d4a66;color:#fff}.bottom-divider{width:1px;height:24px;background:#2d4a66;margin:0 4px}.btn-save{background:#2c3e50;color:#ccc;border:1px solid #345570}.btn-save:hover{background:#2d4a66;color:#fff}.btn-cart{background:#4a7c8f;color:#111}.btn-cart:hover{background:#d4b97e;transform:translateY(-1px);box-shadow:0 2px 10px #4a7c8f4d}.no-selection{padding:40px 16px;text-align:center;color:#5a7e95;font-size:13px}#canvas-container{position:relative;box-shadow:0 8px 32px #0009,0 0 0 1px #ffffff0a;border-radius:2px}.color-swatches{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.color-swatch{width:22px;height:22px;border-radius:4px;border:2px solid #2d4a66;cursor:pointer;transition:all .15s}.color-swatch:hover{transform:scale(1.15);border-color:#4a7c8f}.modal-overlay{display:none;position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);z-index:100;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal-box{background:#34495e;border:1px solid #1e3a55;border-radius:12px;padding:24px;width:420px;max-width:92vw;max-height:80vh;overflow-y:auto;box-shadow:0 12px 48px #00000080}.modal-title{font-size:18px;font-weight:600;color:#4a7c8f;margin-bottom:20px}.size-preset{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid #1e3a55;border-radius:8px;cursor:pointer;margin-bottom:6px;transition:all .15s}.size-preset:hover{border-color:#4a7c8f;background:#2c3e50}.size-preset-name{color:#ddd;font-size:13px;font-weight:500}.size-preset-dim{color:#7ea0b0;font-size:11px}.editor-loading{position:fixed;inset:0;background:linear-gradient(135deg,#0f1c30,#34495e,#2c3e50);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;gap:16px}.editor-loading span{font-size:16px;font-weight:500;letter-spacing:.12em;background:linear-gradient(110deg,#3d6b7e,#4a7c8f,#a3c4cf,#4a7c8f,#3d6b7e);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s linear infinite}.sb-panels::-webkit-scrollbar,.editor-props::-webkit-scrollbar,.stock-grid::-webkit-scrollbar,.template-grid::-webkit-scrollbar,.drawer-content::-webkit-scrollbar{width:4px}.sb-panels::-webkit-scrollbar-thumb,.editor-props::-webkit-scrollbar-thumb,.stock-grid::-webkit-scrollbar-thumb,.template-grid::-webkit-scrollbar-thumb,.drawer-content::-webkit-scrollbar-thumb{background:#345570;border-radius:2px}.sb-panels::-webkit-scrollbar-thumb:hover,.editor-props::-webkit-scrollbar-thumb:hover{background:#555}.mobile-toolbar,.mobile-drawer,.drawer-overlay,.tablet-props-fab,.mobile-fab-actions{display:none}@media(min-width:769px)and (max-width:1024px){.editor-sidebar{width:260px}.sb-tabs{width:56px}.sb-tab{width:48px;height:44px}.sb-tab span{font-size:8px}#floating-toolbar{display:none!important}.editor-props{position:fixed;right:0;top:50px;bottom:56px;width:280px;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:85;box-shadow:-4px 0 20px #0006}.editor-props.tablet-open{transform:translate(0)}.tablet-props-fab{display:flex;position:fixed;right:16px;bottom:72px;width:48px;height:48px;background:#4a7c8f;color:#111;border:none;border-radius:50%;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px #0006;z-index:80;transition:all .15s}.tablet-props-fab:hover{transform:scale(1.08);box-shadow:0 4px 20px #4a7c8f4d}.tablet-props-fab svg{width:20px;height:20px}.editor-toolbar{padding:0 8px;gap:4px}.tb-group{padding:1px}.tb-btn{padding:5px;min-width:28px;min-height:28px}.btn-export{padding:6px 12px;font-size:10px}}@media(max-width:768px){.editor-sidebar,.editor-props{display:none}#floating-toolbar{display:none!important}.editor-toolbar{height:44px;gap:2px;padding:0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.editor-toolbar::-webkit-scrollbar{display:none}.tb-btn{padding:6px;min-width:34px;min-height:34px;font-size:11px;flex-shrink:0}.tb-group{padding:1px;flex-shrink:0}.tb-group-layers,.tb-group-grouping,.tb-group-marks,.tb-btn#btn-save{display:none}.mobile-toolbar{display:flex;height:auto;min-height:60px;background:#12203a;border-top:1px solid #1e3a55;align-items:center;justify-content:space-around;flex-shrink:0;padding:4px 4px calc(4px + env(safe-area-inset-bottom,20px))}.mob-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:#7ea0b0;font-size:10px;font-family:Sarabun,sans-serif;cursor:pointer;padding:6px 4px;border-radius:8px;transition:all .15s;min-width:48px;min-height:44px}.mob-btn:hover,.mob-btn.active{color:#4a7c8f;background:#2c3e50}.mob-btn svg{width:22px;height:22px;stroke:currentColor}.mobile-drawer{position:fixed;bottom:0;left:0;right:0;height:60vh;max-height:calc(100vh - 104px);background:#34495e;border-radius:16px 16px 0 0;z-index:90;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:0 -8px 32px #00000080}.mobile-drawer.open{transform:translateY(0)}.mobile-drawer:before{content:"";display:block;width:36px;height:4px;background:#3d5e7a;border-radius:2px;margin:8px auto 0;flex-shrink:0}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 12px;border-bottom:1px solid #1e3a55;font-size:15px;color:#4a7c8f;font-weight:600}.drawer-content{flex:1;overflow-y:auto;padding:12px 16px;-webkit-overflow-scrolling:touch}.drawer-content .sb-btn{padding:12px 14px;font-size:14px;min-height:44px;border-radius:8px;margin-bottom:8px}.drawer-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(2px);z-index:89}.drawer-overlay.open{display:block}.editor-bottom{display:none}.mobile-fab-actions{display:flex;position:absolute;right:8px;top:8px;z-index:40;gap:6px}.mobile-fab-actions .fab-save{width:42px;height:42px;border-radius:50%;border:none;background:#162640e6;color:#ccc;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:all .15s}.mobile-fab-actions .fab-save:active{background:#213551e6;transform:scale(.9)}.mobile-fab-actions .fab-cart{width:42px;height:42px;border-radius:50%;border:none;background:#4a7c8fe6;color:#111;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #4a7c8f4d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:all .15s;padding:0}.mobile-fab-actions .fab-cart:active{background:#b89a5ef2;transform:scale(.9)}.tablet-props-fab{display:none!important}}.ai-section{background:linear-gradient(135deg,#34495e,#2c3e50);border:1px solid #4A7C8F22;border-radius:6px}.ai-btn{display:flex;align-items:center;gap:8px;width:100%;background:linear-gradient(135deg,#2c3e50,#34495e);border:1px solid #4A7C8F44;color:#4a7c8f;padding:8px 10px;font-size:12px;cursor:pointer;border-radius:4px;font-family:Sarabun,sans-serif;margin-bottom:6px;transition:all .2s}.ai-btn:hover{background:linear-gradient(135deg,#3d5a6e,#2c3e50);border-color:#4a7c8f}.ai-btn:disabled{opacity:.5;cursor:not-allowed}.ai-btn svg{width:16px;height:16px;flex-shrink:0}.ai-prompt-input{width:100%;background:#2c3e50;border:1px solid #4A7C8F44;color:#fff;padding:8px;font-size:11px;border-radius:4px;font-family:Sarabun,sans-serif;resize:vertical;min-height:60px;box-sizing:border-box}.ai-prompt-input:focus{outline:none;border-color:#4a7c8f}.ai-prompt-input::-moz-placeholder{color:#6a8fa0}.ai-prompt-input::placeholder{color:#6a8fa0}.ai-suggest{display:flex;flex-wrap:wrap;gap:3px;margin:6px 0}.ai-suggest-btn{background:#1a3050;border:1px solid #4A7C8F33;color:#4a7c8f99;padding:3px 6px;font-size:9px;cursor:pointer;border-radius:3px;font-family:Sarabun,sans-serif;transition:all .2s}.ai-suggest-btn:hover{background:#3d5a6e;color:#4a7c8f;border-color:#4a7c8f}#ai-loading-spinner{display:none;align-items:center;justify-content:center;gap:8px;padding:12px;color:#4a7c8f;font-size:11px}.ai-spinner{width:16px;height:16px;border:2px solid #4A7C8F33;border-top-color:#4a7c8f;border-radius:50%;animation:aispin .8s linear infinite}@keyframes aispin{to{transform:rotate(360deg)}}.shape-visual-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.shape-visual-btn{display:flex;flex-direction:column;align-items:center;gap:4px;background:#1a3050;border:1px solid #1e3a55;border-radius:8px;padding:10px 4px 8px;cursor:pointer;transition:all .2s;font-family:Sarabun,sans-serif;color:#94b4c1}.shape-visual-btn:hover{background:#3d5a6e;border-color:#4a7c8f55;transform:scale(1.05);box-shadow:0 2px 8px #4a7c8f1a}.shape-visual-btn svg{width:36px;height:36px;flex-shrink:0}.shape-visual-btn span{font-size:9px;line-height:1.2;white-space:nowrap}.shape-visual-btn:active{transform:scale(.95)}.text-preset-btn{transition:all .2s!important}.text-preset-btn:hover{border-color:#4a7c8f55!important;transform:translateY(-1px);box-shadow:0 2px 8px #4a7c8f14}.text-preset-btn:active{transform:translateY(0) scale(.98)}.layer-header{display:flex;align-items:center;justify-content:space-between;padding:0 2px 10px;border-bottom:1px solid #4A7C8F22;margin-bottom:6px}.layer-header .layer-count{font-size:10px;color:#666;background:#1e1e1e;padding:2px 8px;border-radius:10px}.layer-item{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:2px;border-radius:8px;cursor:pointer;transition:all .2s;color:#999;border-left:3px solid transparent;background:#1a1a1a}.layer-item:hover{background:#222;color:#ccc;box-shadow:0 2px 8px #0003}.layer-item.active{background:#4a7c8f0f;color:#ddd;border-left-color:#4a7c8f;box-shadow:0 2px 12px #4a7c8f14}.layer-thumb{width:44px;height:34px;min-width:44px;background:#252525;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid #2d4a66;transition:border-color .2s}.layer-item:hover .layer-thumb,.layer-item.active .layer-thumb{border-color:#4a7c8f44}.layer-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.layer-thumb svg{width:20px;height:20px}.layer-thumb-text{font-size:9px;color:#bbb;padding:2px 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;text-align:center;font-family:Sarabun,sans-serif}.layer-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.layer-type-badge{font-size:8px;color:#666;text-transform:uppercase;letter-spacing:.5px}.layer-item.active .layer-type-badge{color:#4a7c8f88}.layer-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:18px;font-weight:400}.layer-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .2s}.layer-item:hover .layer-actions,.layer-item.active .layer-actions{opacity:1}.layer-btn{background:none;border:1px solid transparent;color:#666;cursor:pointer;padding:3px;border-radius:4px;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px}.layer-btn:hover{color:#4a7c8f;background:#4a7c8f14;border-color:#4a7c8f33}.layer-btn.off{opacity:.3}.layer-btn.off:hover{opacity:.7}.layer-btn svg{width:12px;height:12px;min-width:12px;max-width:12px;display:block}.layer-item.dragging{opacity:.3;transform:scale(.97)}.layer-item.drag-over{box-shadow:0 -2px #4a7c8f}.layer-item:active{transform:scale(.98)}.layer-divider{height:1px;background:linear-gradient(90deg,transparent,#2d4a66,transparent);margin:4px 8px}.layer-empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 16px;color:#555;font-size:11px;text-align:center}.layer-empty-state svg{opacity:.3}#floating-toolbar{position:absolute;left:50%;transform:translate(-50%);background:#1a1a1a;border:1px solid #2d4a66;border-radius:10px;padding:4px 8px;display:none;z-index:50;box-shadow:0 4px 20px #0009;align-items:center;gap:3px}#floating-toolbar.visible{display:flex}.ft-sep{width:1px;height:24px;background:#2d4a66;margin:0 2px;flex-shrink:0}.ft-btn{background:none;border:none;color:#999;padding:5px;font-size:12px;cursor:pointer;border-radius:5px;font-family:Sarabun,sans-serif;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;min-width:28px;min-height:28px}.ft-btn:hover{background:#2d4a66;color:#fff}.ft-btn.active{background:#4a7c8f;color:#111}.ft-btn svg{width:14px;height:14px}.ft-input{background:#252525;border:1px solid #2d4a66;color:#eee;padding:4px 6px;font-size:11px;border-radius:5px;font-family:Sarabun,sans-serif;width:50px;text-align:center}.ft-input:focus{outline:none;border-color:#4a7c8f}.ft-select{background:#252525;border:1px solid #2d4a66;color:#eee;padding:4px 6px;font-size:11px;border-radius:5px;font-family:Sarabun,sans-serif;max-width:110px;cursor:pointer}.ft-select:focus{outline:none;border-color:#4a7c8f}.ft-color{width:24px;height:24px;border:2px solid #3d5e7a;border-radius:4px;cursor:pointer;padding:0;transition:border-color .15s}.ft-color:hover{border-color:#4a7c8f}.prop-range{width:100%;height:6px;-webkit-appearance:none;background:#1e3a55;border-radius:3px;outline:none}.prop-range::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#4a7c8f;border-radius:50%;cursor:pointer;box-shadow:0 1px 4px #0006}.range-row{display:flex;align-items:center;gap:8px}.range-val{color:#7ea0b0;font-size:11px;min-width:32px;text-align:right;font-variant-numeric:tabular-nums}.transform-btns{display:flex;gap:3px}.transform-btns button{flex:1;background:#1a3050;border:1px solid #2d4a66;color:#bbb;padding:6px;font-size:11px;cursor:pointer;border-radius:4px;font-family:Sarabun,sans-serif;transition:all .15s}.transform-btns button:hover{border-color:#4a7c8f;color:#4a7c8f;background:#2c3e50}.shadow-controls{margin-top:4px}.shadow-controls label{display:flex;align-items:center;gap:8px;color:#bbb;font-size:12px;cursor:pointer;margin-bottom:6px}.shadow-controls input[type=checkbox]{accent-color:#4A7C8F;width:16px;height:16px}.editor-loading .loading-ring{width:56px;height:56px;border-radius:50%;position:relative;border:2px solid rgba(74,124,143,.15)}.editor-loading .loading-ring:before{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid transparent;border-top-color:#4a7c8f;border-right-color:#a3c4cf;animation:aispin .8s linear infinite}.editor-loading .loading-ring:after{content:"";position:absolute;inset:4px;border-radius:50%;border:1px solid transparent;border-bottom-color:#3d6b7e;animation:aispin 1.2s linear infinite reverse}.editor-loading .loading-ring .ring-dot{position:absolute;top:50%;left:50%;width:8px;height:8px;margin:-4px 0 0 -4px;background:#4a7c8f;border-radius:50%;animation:loadPulse 1.5s ease-in-out infinite}@keyframes loadPulse{0%,to{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1}}.editor-loading .loading-tip{font-size:11px;color:#7ea0b0;letter-spacing:.05em;min-height:16px;transition:opacity .4s ease}.editor-loading.fade-out{opacity:0;transition:opacity .5s ease;pointer-events:none}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.editor-toast{position:fixed;right:16px;z-index:300;display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;font-size:13px;font-family:Prompt,sans-serif;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d;animation:toastSlideIn .35s cubic-bezier(.34,1.56,.64,1);transition:transform .3s ease,opacity .3s ease;max-width:360px}.editor-toast.removing{animation:toastSlideOut .3s ease forwards}.editor-toast .toast-icon{width:20px;height:20px;flex-shrink:0}.editor-toast .toast-msg{flex:1;line-height:1.4}.editor-toast.toast-success{background:#166534d9;color:#dcfce7;border:1px solid rgba(34,197,94,.3)}.editor-toast.toast-error{background:#991b1bd9;color:#fecaca;border:1px solid rgba(239,68,68,.3)}.editor-toast.toast-info{background:#1e3a5fe6;color:#bfdbfe;border:1px solid rgba(59,130,246,.3)}.tb-btn{overflow:hidden}.ripple-effect{position:absolute;border-radius:50%;background:#4a7c8f59;transform:scale(0);animation:rippleAnim .5s ease-out forwards;pointer-events:none}@keyframes rippleAnim{to{transform:scale(2.5);opacity:0}}.canvas-empty-state{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:none;z-index:5;animation:emptyPulse 3s ease-in-out infinite}@keyframes emptyPulse{0%,to{opacity:.7}50%{opacity:1}}.canvas-empty-state svg{opacity:.4}.canvas-empty-state .empty-title{font-size:16px;font-weight:500;color:#94b4c1;letter-spacing:.02em}.canvas-empty-state .empty-sub{font-size:12px;color:#5a7e95;max-width:260px;text-align:center;line-height:1.5}.canvas-empty-state .empty-keys{display:flex;gap:8px;margin-top:4px}.canvas-empty-state .key-hint{font-size:10px;color:#5a7e95;background:#1e3a5580;padding:3px 8px;border-radius:4px;border:1px solid #2d4a66}.editor-canvas-area.drag-over .canvas-empty-state{opacity:1!important;animation:none}.editor-canvas-area.drag-over:after{content:"";position:absolute;inset:16px;border:2px dashed #4A7C8F;border-radius:12px;z-index:4;pointer-events:none;animation:dashPulse 1s ease-in-out infinite}@keyframes dashPulse{0%,to{opacity:.4}50%{opacity:.8}}.sb-panel{display:none;opacity:0;transition:opacity .25s ease}.sb-panel.active{display:block;opacity:1}.sb-tab.active{position:relative}.sb-tab.active:after{content:"";position:absolute;top:50%;right:-1px;width:3px;height:20px;background:#4a7c8f;border-radius:2px 0 0 2px;transform:translateY(-50%);box-shadow:0 0 8px #4a7c8f66}
