*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:PingFang TC,Noto Sans TC,system-ui,sans-serif}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.toolbar{color:#f4ede0;z-index:2;background:#3b3228;border-bottom:1px solid #00000040;flex:none;align-items:center;gap:12px;padding:8px 14px;display:flex;position:relative;box-shadow:0 1px 6px #3b32282e}.brand{letter-spacing:.5px;margin-right:4px;font-weight:700}.tool-group+.tool-group,.tool-group+.project-name,.project-name+.tool-group{border-left:1px solid #ffffff1f;padding-left:12px}.project-name{color:#f4ede0;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;width:150px;padding:4px 8px;font-size:13px}.project-select{color:#f4ede0;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;max-width:150px;padding:4px 6px;font-size:13px}.project-select option{color:#4a4038;background:#fffdf8}.tool-group{gap:4px;display:flex}.toolbar button{color:#f4ede0;cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:6px;align-items:center;gap:5px;padding:5px 10px;font-size:13px;display:inline-flex}.toolbar button svg{flex:none}.toolbar button:hover{background:#d4af7c80}.toolbar button:disabled{opacity:.35;cursor:default;pointer-events:none}.save-status{color:#f4ede0bf;white-space:nowrap;font-size:12px}.toolbar button.active{background:#c9863b;border-color:#c9863b;box-shadow:inset 0 -2px #f0c78e,inset 0 1px 2px #0003}.spacer{flex:1}.main{flex:1;min-height:0;display:flex}.left{background:#f4efe5;border-right:1px solid #e0d6c2;width:208px;overflow-y:auto}.right{background:#f4efe5;border-left:1px solid #e0d6c2;width:230px;overflow-y:auto}.canvas{flex:1;position:relative}.catalog{padding:10px}.cat-title{color:#8a7a63;margin:10px 4px 6px;font-size:12px;font-weight:600}.cat-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.cat-card{cursor:grab;color:#5d5040;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #e0d6c2;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;font-size:12px;display:flex}.cat-card:hover{border-color:#c9863b;box-shadow:0 1px 4px #a0783c33}.cat-thumb{color:#a8895d;background:#efe6d3;border-radius:6px;place-items:center;width:44px;height:44px;font-size:18px;display:grid}.panel{padding:14px}.panel h3{color:#4a4038;margin:4px 0 12px;font-size:15px}.field{color:#5d5040;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;display:flex}.field input[type=number]{border:1px solid #d8cdb8;border-radius:6px;width:90px;padding:4px 6px}.btn-row{gap:6px;margin:4px 0 8px;display:flex}.btn-row button{color:#5d5040;cursor:pointer;background:#fff;border:1px solid #d8cdb8;border-radius:6px;flex:1;padding:5px 4px;font-size:12px}.btn-row button:hover{color:#4a4038;border-color:#c9863b}.panel button.danger{color:#b3452e;cursor:pointer;background:#fff;border:1px solid #d9a08e;border-radius:6px;width:100%;margin-top:10px;padding:6px}.panel button.danger:hover{background:#fbeae5}.hint{color:#8a7a63;font-size:12px;line-height:1.7}.hint p{margin:0 0 10px}.hint b{color:#5d5040}img.cat-thumb{object-fit:contain;background:#f7f2e8}.webgl-fallback{text-align:center;color:#5d5040;background:#faf6ee;place-items:center;padding:24px;display:grid;position:absolute;inset:0}.webgl-fallback h3{color:#4a4038;margin:0 0 10px}.webgl-fallback p{color:#8a7a63;margin:4px 0;font-size:13px}.snapshot-btn{color:#f4ede0;cursor:pointer;background:#3b3228d9;border:1px solid #fff3;border-radius:8px;padding:7px 14px;font-size:13px;position:absolute;bottom:12px;right:14px}.snapshot-btn:hover{background:#c9863b;border-color:#c9863b}.tool-hint{color:#f4ede0;pointer-events:none;z-index:3;white-space:nowrap;background:#3b3228e0;border-radius:8px;padding:6px 14px;font-size:12.5px;position:absolute;top:10px;left:50%;transform:translate(-50%)}.scale-bar{pointer-events:none;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex;position:absolute;bottom:12px;left:14px}.scale-bar-line{border-bottom:2px solid #8a7a63;height:0;position:relative}.scale-bar-line:before,.scale-bar-line:after{content:"";background:#8a7a63;width:2px;height:8px;position:absolute;bottom:-3px}.scale-bar-line:before{left:0}.scale-bar-line:after{right:0}.scale-bar span{color:#8a7a63;font-size:11px}.empty-state{pointer-events:none;place-items:center;display:grid;position:absolute;inset:0}.empty-card{pointer-events:auto;background:#fffdf8;border:1px solid #e0d6c2;border-radius:14px;width:380px;padding:26px 30px;box-shadow:0 8px 30px #5a46281f}.empty-card h2{color:#4a4038;margin:0 0 6px;font-size:18px}.empty-card>p{color:#8a7a63;margin:0 0 16px;font-size:13px}.empty-actions{flex-direction:column;gap:8px;display:flex}.empty-actions button{cursor:pointer;text-align:left;background:#faf6ee;border:1px solid #e0d6c2;border-radius:10px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px;display:flex}.empty-actions button:hover{background:#fdf8ef;border-color:#c9863b}.empty-actions button b{color:#4a4038;font-size:14px}.empty-actions button span{color:#8a7a63;font-size:12px}.mobile-banner{color:#fff;background:#c9863b;flex:none;align-items:center;gap:8px;padding:6px 12px;font-size:12.5px;display:none}.mobile-banner button{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:4px;margin-left:auto;padding:2px 8px}@media (width<=880px){.mobile-banner{display:flex}.toolbar{scrollbar-width:none;overflow-x:auto}.toolbar::-webkit-scrollbar{display:none}.toolbar button{white-space:nowrap;flex:none}.project-name{flex:none;width:90px}.project-select{flex:none;max-width:90px}.save-status{display:none}.left{width:132px}.right{display:none}.empty-card{width:calc(100vw - 60px);padding:18px 20px}}@media (width<=560px){.left{display:none}}
