*{box-sizing:border-box}html,body{color:#0f172a;background:#f1f5f9;height:100%;margin:0;padding:0;font-family:-apple-system,PingFang SC,Microsoft YaHei,Segoe UI,sans-serif;font-size:14px;overflow:hidden}body{flex-direction:column;height:100vh;display:flex}button{cursor:pointer;font-family:inherit}.topbar{z-index:10;background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border-bottom:1px solid #e2e8f0;flex-shrink:0;align-items:center;gap:16px;padding:10px 18px;display:flex;box-shadow:0 1px 4px #0f172a0a}.brand{border-right:1px solid #e2e8f0;align-items:center;gap:10px;padding-right:12px;display:flex}.brand-logo{gap:2px;display:flex}.brand-logo span{border-radius:3px;width:16px;height:16px;display:inline-block;position:relative}.brand-logo .brick-red{background:#e11d48}.brand-logo .brick-yellow{background:#facc15}.brand-logo .brick-blue{background:#3b82f6}.brand-logo .brick-green{background:#22c55e}.brand-text h1{letter-spacing:.3px;margin:0;font-size:16px;font-weight:700}.brand-text small{color:#64748b;font-size:11px}.topbar-actions{flex-wrap:wrap;align-items:center;gap:6px;margin-left:auto;display:flex}.divider-v{background:#e2e8f0;width:1px;height:22px;margin:0 6px}.btn{color:#334155;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:7px 13px;font-size:13px;font-weight:500;transition:all .15s}.btn:hover{color:#0d9488;background:#f0fdfa;border-color:#0d9488}.btn:active{transform:translateY(1px)}.btn-primary{color:#fff;background:linear-gradient(135deg,#0d9488,#14b8a6);border-color:#0d9488}.btn-primary:hover{color:#fff;background:linear-gradient(135deg,#0f766e,#0d9488)}.btn-amber{color:#fff;background:linear-gradient(135deg,#f59e0b,#fbbf24);border-color:#f59e0b}.btn-amber:hover{color:#fff;background:linear-gradient(135deg,#d97706,#f59e0b)}.btn-teal{color:#fff;background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:#2563eb}.btn-teal:hover{color:#fff;background:linear-gradient(135deg,#1d4ed8,#2563eb)}.btn-ghost{color:#475569;background:0 0;border-color:#0000}.btn-ghost:hover{color:#0d9488;background:#f1f5f9;border-color:#0000}.btn-sm{padding:5px 10px;font-size:12px}.btn-block{width:100%}.workspace{flex:1;min-height:0;display:flex;overflow:hidden}.panel-left{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:280px;display:flex}.panel-tabs{gap:4px;padding:8px 8px 0;display:flex}.panel-tab{color:#475569;background:#f8fafc;border:1px solid #0000;border-bottom-color:#e2e8f0;border-radius:8px 8px 0 0;flex:1;padding:9px 10px;font-size:13px;font-weight:500}.panel-tab.active{color:#0d9488;background:#fff;border-color:#e2e8f0 #e2e8f0 #0000;font-weight:600}.panel-search{padding:10px;position:relative}.panel-search input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");background-position:12px;background-repeat:no-repeat;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:8px 12px 8px 34px;font-size:13px}.panel-search input:focus{background-color:#f0fdfa;border-color:#0d9488}.main-color-bar{border-bottom:1px dashed #e2e8f0;flex-wrap:wrap;gap:4px;padding:4px 10px 20px;display:flex;position:relative}.main-color-bar:before{content:"主颜色";color:#94a3b8;width:100%;margin-bottom:2px;font-size:11px;font-weight:500;display:block}.main-color-bar.collapsed .color-dot:nth-child(n+17){display:none}.color-expand-toggle{color:#0d9488;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2px 10px;font-size:11px;transition:all .15s;position:absolute;bottom:-1px;right:12px;transform:translateY(50%)}.color-expand-toggle:hover{background:#f0fdfa;border-color:#0d9488}.color-dot{border:2px solid #0000;border-radius:50%;width:16px;height:16px;padding:0;transition:all .15s;box-shadow:inset 0 1px 2px #0000001a}.color-dot:hover{transform:scale(1.15)}.color-dot.active{border-color:#0d9488;transform:scale(1.15);box-shadow:0 0 0 2px #5eead4,inset 0 1px 2px #0000001a}.panel-body{flex-direction:column;flex:1;min-height:0;display:flex}.panel-body.hidden{display:none}#panel-custom{overflow:auto}.category-list{flex-wrap:wrap;gap:6px;padding:10px 10px 4px;display:flex}.cat-btn{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;align-items:center;gap:4px;padding:6px 10px;font-size:12px;display:inline-flex}.cat-btn:hover{color:#0d9488;background:#f0fdfa;border-color:#0d9488}.cat-btn.active{color:#fff;background:linear-gradient(135deg,#0d9488,#14b8a6);border-color:#0d9488}.cat-icon{font-size:13px}.cat-badge{color:#0d9488;text-align:center;background:#0d948826;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.parts-grid-wrap{flex:1;min-height:0;overflow:auto}.parts-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:10px;display:grid}.part-card{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:8px 6px;transition:all .15s;position:relative}.part-card:hover{background:#f0fdfa;border-color:#0d9488;transform:translateY(-1px);box-shadow:0 4px 12px #0d94881f}.part-card:active{transform:translateY(0)}.part-thumb{width:100%;max-width:100px;height:auto;margin:0 auto;display:block}.part-info{margin-top:4px}.part-name{color:#0f172a;font-size:12px;font-weight:600}.part-code{color:#94a3b8;font-size:10px}.del-custom{color:#ef4444;background:#ef44441a;border:none;border-radius:50%;width:20px;height:20px;font-size:14px;line-height:1;position:absolute;top:4px;right:4px}.del-custom:hover{color:#fff;background:#ef4444}.custom-form{flex-direction:column;gap:12px;padding:14px;display:flex}.form-row{flex-direction:column;gap:6px;display:flex}.form-row label{color:#64748b;font-size:12px;font-weight:500}.form-row input[type=number],.form-row input[type=text],.form-row textarea{border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px}.form-row input:focus,.form-row textarea:focus{background:#f0fdfa;border-color:#0d9488}.num-pair{align-items:center;gap:8px;display:flex}.num-pair input{width:80px}.num-pair span{color:#94a3b8;font-weight:500}.shape-picker{gap:8px;display:flex}.shape-opt{background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;flex:1;padding:10px;font-size:18px;transition:all .15s}.shape-opt:hover{border-color:#0d9488}.shape-opt.active{background:#f0fdfa;border-color:#0d9488}#custom-color{flex-wrap:wrap;gap:6px;display:flex}.custom-preview{background:linear-gradient(135deg,#f8fafc,#eef2f7);border:1px dashed #cbd5e1;border-radius:10px;justify-content:center;align-items:center;min-height:180px;padding:10px;display:flex}.preview-placeholder{color:#94a3b8;font-size:12px}.custom-thumb{width:100%;max-width:220px;height:auto}.custom-list-title{color:#475569;border-top:1px dashed #e2e8f0;padding-top:8px;font-size:12px;font-weight:600}.canvas-area{background:radial-gradient(circle at 50% 40%,#fff,#e2e8f0);flex:1;min-width:0;position:relative;overflow:visible}#three-canvas{width:100%;height:100%;display:block}.canvas-hint{color:#fff;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172abf;border-radius:20px;padding:7px 16px;font-size:12px;animation:6s ease-in-out forwards fadeInOut;position:absolute;top:18px;left:50%;transform:translate(-50%)}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%)translateY(-10px)}10%{opacity:1;transform:translate(-50%)translateY(0)}70%{opacity:1}to{opacity:0}}.canvas-toolbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:4px;padding:8px;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0f172a1a}.tool-btn{color:#475569;background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;font-size:11px;transition:all .15s;display:flex}.tool-btn span{font-size:18px}.tool-btn:hover{color:#0d9488;background:#f1f5f9}.tool-btn.active{color:#fff;background:linear-gradient(135deg,#0d9488,#14b8a6)}.tool-btn.danger:hover{color:#ef4444;background:#fef2f2}.kb-hint{color:#475569;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;background:#fffffff2;border:1px solid #e2e8f0;border-radius:20px;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:4px;max-width:50%;padding:6px 14px;font-size:11px;display:flex;position:absolute;top:18px;right:20px;box-shadow:0 2px 8px #0f172a0f}.kb-hint strong{color:#0d9488;font-weight:700}.kb-hint span{white-space:nowrap}.tpl-meta{color:#0d9488;padding:0 12px 8px;font-size:11px;font-weight:600}.selection-info{background:#fffffff7;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:10px;min-width:260px;padding:12px 16px;font-size:13px;display:flex;position:absolute;top:70px;right:20px;box-shadow:0 4px 16px #0f172a1a}.selection-info.hidden{display:none}.sel-swatch{border-radius:5px;flex-shrink:0;width:20px;height:20px;box-shadow:inset 0 0 0 1px #0000001f}.sel-detail{color:#0f172a;font-weight:700}.sel-meta{color:#64748b;font-size:11px}.sel-rotator{cursor:pointer;color:#475569;background:#f1f5f9;border-radius:6px;padding:5px 10px;font-size:12px;transition:all .15s}.sel-rotator:hover{color:#fff;background:#0d9488}.sel-rotator.danger:hover{color:#fff;background:#ef4444}.statusbar{color:#64748b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;border-top:1px solid #e2e8f0;justify-content:space-between;padding:6px 14px;font-size:12px;display:flex;position:absolute;bottom:0;left:0;right:0}.status-right strong{color:#0d9488}.modal{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal.open{animation:.2s modalFadeIn;display:flex}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;flex-direction:column;width:min(480px,92vw);height:auto;min-height:200px;max-height:85vh;animation:.25s ease-out modalSlideIn;display:flex;overflow:hidden;box-shadow:0 20px 60px #0f172a40}.modal-content.modal-wide{width:min(780px,94vw)}.modal-content.modal-large{width:min(1000px,96vw);min-height:600px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,#f8fafc,#fff);border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{margin:0;font-size:16px;font-weight:700}.modal-close{color:#475569;background:#f1f5f9;border:none;border-radius:50%;width:28px;height:28px;font-size:14px}.modal-close:hover{color:#fff;background:#ef4444}.modal-body{flex:1;min-height:0;padding:20px;overflow:auto}.parts-summary{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.summary-item{text-align:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;padding:14px}.summary-num{color:#0d9488;font-size:26px;font-weight:800;line-height:1}.summary-label{color:#64748b;margin-top:4px;font-size:11px}.parts-list-toolbar{gap:10px;margin-bottom:12px;display:flex}.parts-list-toolbar input{border:1px solid #e2e8f0;border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px}.parts-list-toolbar input:focus{background:#f0fdfa;border-color:#0d9488}.parts-table-wrap{border:1px solid #e2e8f0;border-radius:10px;max-height:55vh;overflow:auto}.parts-table{border-collapse:collapse;width:100%;font-size:13px}.parts-table thead{z-index:1;background:#f8fafc;position:sticky;top:0}.parts-table th{text-align:left;color:#475569;border-bottom:2px solid #e2e8f0;padding:10px 12px;font-size:12px;font-weight:600}.parts-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:8px 12px}.parts-table tr:hover td{background:#f0fdfa}.list-thumb{width:40px;height:40px;display:block}.color-swatch{vertical-align:middle;border-radius:4px;width:14px;height:14px;display:inline-block;box-shadow:inset 0 0 0 1px #0000001a}.modal-xlarge{width:92vw;max-width:1200px;height:88vh;max-height:820px}.steps-header{background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-bottom:2px solid #e2e8f0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.steps-header-left{align-items:center;gap:12px;display:flex}.steps-icon{background:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:28px;display:flex;box-shadow:0 2px 8px #0000000f}.steps-header h2{color:#0f172a;margin:0;font-size:18px;font-weight:700}.steps-subtitle{color:#64748b;margin-top:2px;font-size:12px}.steps-header-right{align-items:center;gap:16px;display:flex}.steps-progress-wrap{flex-direction:column;align-items:flex-end;gap:4px;min-width:200px;display:flex}.steps-progress-bar{background:#e2e8f0;border-radius:3px;width:100%;height:6px;overflow:hidden}.steps-progress-fill{background:linear-gradient(90deg,#0d9488,#14b8a6);border-radius:3px;width:0%;height:100%;transition:width .3s}.steps-progress-text{color:#475569;font-size:12px;font-weight:500}.steps-progress-text strong{color:#0d9488;font-size:14px;font-weight:700}.steps-body{flex:1;gap:0;padding:0;display:flex;overflow:hidden}.steps-sidebar{background:#f8fafc;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;gap:4px;width:220px;padding:14px 12px;display:flex;overflow-y:auto}.step-item{cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:10px 12px;transition:all .2s;position:relative}.step-item:hover{border-color:#0d9488;transform:translate(2px);box-shadow:0 2px 8px #0d94881a}.step-item.active{color:#fff;background:linear-gradient(135deg,#0d9488,#14b8a6);border-color:#0d9488;box-shadow:0 4px 12px #0d948840}.step-item.done:before{content:"✓";color:#fff;background:#10b981;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:flex;position:absolute;top:8px;right:10px}.step-item.active.done:before{color:#0d9488;background:#fff}.step-num{font-size:13px;font-weight:700;display:block}.step-meta{opacity:.8;align-items:center;gap:4px;margin-top:3px;font-size:11px;display:flex}.step-item.active .step-meta{opacity:.9}.steps-main{background:#fff;flex-direction:column;flex:1;min-width:0;display:flex}.steps-canvas-wrap{background:radial-gradient(at 50% 30%,#fff 0%,#f1f5f9 50%,#e2e8f0 100%);border-bottom:1px solid #e2e8f0;flex:1;min-height:380px;position:relative;overflow:hidden}#steps-canvas{width:100%;height:100%;min-height:380px;position:relative}.steps-badge-corner{z-index:10;pointer-events:none;position:absolute;top:20px;left:20px}.step-page-badge{color:#fff;text-align:center;background:#f59e0b;border-radius:8px;flex-direction:column;align-items:center;padding:10px 16px;font-weight:900;line-height:1;display:flex;box-shadow:0 4px 12px #f59e0b66}.badge-step-label{letter-spacing:2px;opacity:.9;font-size:10px;font-weight:700}.badge-step-num{margin-top:2px;font-size:28px;font-weight:900}.steps-new-parts-hint{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#0f172acc;border-radius:20px;align-items:center;gap:8px;padding:8px 14px;font-size:12px;display:flex;position:absolute;bottom:16px;right:20px}.hint-dot{background:#f59e0b;border-radius:50%;width:10px;height:10px;animation:1.5s ease-in-out infinite hint-pulse;box-shadow:0 0 8px #f59e0b}@keyframes hint-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.steps-info-bar{background:#fff;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.step-info-title{color:#0f172a;font-size:15px;font-weight:700}.step-info-count{color:#475569;align-items:center;gap:6px;font-size:13px;display:flex}.step-info-count strong{color:#0d9488;font-size:15px;font-weight:700}.count-icon{font-size:14px}.step-parts{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;gap:8px;max-height:120px;padding:12px 20px;display:flex;overflow-y:auto}.step-part{color:#475569;background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;transition:all .15s;display:inline-flex}.step-part:hover{border-color:#0d9488;transform:translateY(-1px)}.step-part .sp-name{color:#0f172a;font-weight:600}.step-part .sp-code{color:#94a3b8;font-size:11px}.step-part .sp-count{color:#0d9488;background:#ccfbf1;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}.steps-nav{background:#fff;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex}.steps-nav .btn{justify-content:center;align-items:center;gap:8px;min-width:120px;padding:10px 20px;font-weight:600;display:flex}.nav-arrow{font-size:14px;font-weight:700}.btn-ghost{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0}.btn-ghost:hover{color:#0f172a;background:#e2e8f0}.steps-dots{flex-wrap:wrap;justify-content:center;gap:6px;max-width:50%;display:flex}.step-dot{cursor:pointer;background:#e2e8f0;border-radius:50%;width:10px;height:10px;transition:all .2s}.step-dot:hover{background:#94a3b8;transform:scale(1.2)}.step-dot.active{background:#0d9488;transform:scale(1.3);box-shadow:0 0 0 3px #0d948833}.step-dot.done{background:#10b981}.projects-grid,.templates-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.proj-card,.tpl-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;transition:all .15s;display:flex;overflow:hidden}.proj-card:hover,.tpl-card:hover{border-color:#0d9488;transform:translateY(-2px);box-shadow:0 6px 18px #0d94881f}.proj-thumb{aspect-ratio:4/3;object-fit:cover;background:#f8fafc;width:100%}.tpl-emoji{aspect-ratio:4/3;background:linear-gradient(135deg,#fef3c7,#fde68a);justify-content:center;align-items:center;width:100%;font-size:64px;display:flex}.proj-body{flex:1;padding:12px}.proj-name{color:#0f172a;font-size:14px;font-weight:600}.proj-desc{color:#64748b;min-height:32px;margin-top:4px;font-size:12px}.proj-meta{color:#94a3b8;margin-top:6px;font-size:11px}.tpl-name{padding:10px 12px 0;font-size:14px;font-weight:600}.tpl-desc{color:#64748b;flex:1;padding:4px 12px 12px;font-size:12px}.proj-actions{border-top:1px solid #f1f5f9;gap:8px;padding:10px 12px 12px;display:flex}.tpl-card button{margin:0 12px 12px}.empty-hint{text-align:center;color:#94a3b8;grid-column:1/-1;padding:30px;font-size:13px}.hidden{display:none!important}.toast{color:#fff;opacity:0;pointer-events:none;z-index:200;background:#0f172af5;border-radius:24px;align-items:center;gap:10px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:72px;left:50%;transform:translate(-50%)translateY(30px);box-shadow:0 8px 28px #00000047}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast.toast-err{background:#b91c1cf5}.toast.toast-ok{background:#065f46f5}.modal-medium{width:90%;max-width:480px;height:auto;max-height:70vh}.history-summary{color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;display:flex}.history-list{max-height:55vh;overflow-y:auto}.history-item{cursor:pointer;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:12px 14px;transition:all .15s;display:flex}.history-item:hover{background:#f0fdfa}.history-item.current{background:#ccfbf1;border-left:3px solid #0d9488}.history-item.future{opacity:.5;background:#f8fafc}.history-item-content{flex:1}.history-item-desc{color:#0f172a;font-size:13px;font-weight:600}.history-item-time{color:#94a3b8;margin-top:2px;font-size:11px}.history-item-index{color:#94a3b8;text-align:center;min-width:28px;margin-right:10px;font-size:12px;font-weight:700}.history-item.current .history-item-index{color:#0d9488}.history-item.current .history-item-desc:after{content:" ← 当前";color:#0d9488;font-size:11px;font-weight:400}.history-empty{text-align:center;color:#94a3b8;padding:40px 20px;font-size:14px}.library-color-bar{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 12px;display:flex}.library-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:22px;height:22px;transition:all .15s;box-shadow:0 1px 3px #00000026}.library-color-dot:hover{transform:scale(1.15)}.library-color-dot.active{border-color:#0f172a;transform:scale(1.2);box-shadow:0 2px 6px #00000040}.library-color-label{color:#64748b;margin-right:8px;font-size:12px}.view-presets{z-index:10;gap:4px;display:flex;position:absolute;top:12px;right:12px}.view-preset-btn{color:#475569;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe6;border:1px solid #e2e8f0;border-radius:6px;padding:6px 10px;font-size:11px;font-weight:600;transition:all .15s}.view-preset-btn:hover{color:#0d9488;background:#fff;border-color:#0d9488}.view-preset-btn.active{color:#fff;background:#0d9488;border-color:#0d9488}.tool-btn-wrap{display:inline-flex;position:relative}.view-menu{z-index:9999;opacity:0;pointer-events:none;background:#fff;border:1px solid #e2e8f0;border-radius:12px;min-width:150px;padding:8px;transition:all .2s cubic-bezier(.4,0,.2,1);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%)translateY(8px);box-shadow:0 -8px 30px #0f172a1f,0 4px 12px #0f172a0f}.view-menu.open{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.view-menu:after{content:"";background:#fff;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;width:12px;height:12px;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)rotate(45deg)}.view-menu-item{color:#334155;cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:9px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.view-menu-item:hover{color:#0d9488;background:#f0fdfa;transform:translate(2px)}.view-menu-item.active{color:#0f766e;background:linear-gradient(135deg,#ccfbf1,#99f6e4);font-weight:600}.view-menu-item.active:before{content:"✓";color:#0d9488;font-size:14px;font-weight:700}.view-menu-divider{background:#f1f5f9;height:1px;margin:6px 4px}.toast.toast-warn{background:#78350ff5}.toast span{font-size:17px}@media (width<=900px){.panel-left{width:240px}.brand-text{display:none}}@media (width<=720px){.panel-left{width:200px}.parts-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap}.topbar-actions{width:100%}.canvas-hint{padding:6px 12px;font-size:11px}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dropdown-wrapper{position:relative}.dropdown-toggle{align-items:center;gap:4px;display:flex}.dropdown-toggle:after{content:"▾";margin-left:2px;font-size:10px}.dropdown-menu{opacity:0;visibility:hidden;z-index:1000;background:#fff;border-radius:8px;min-width:140px;margin-top:4px;transition:all .2s;position:absolute;top:100%;overflow:hidden;transform:translateY(-8px);box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d}.dropdown-menu.dropdown-down{top:100%;transform:translateY(-8px)}.dropdown-menu.show{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{text-align:left;color:#334155;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 14px;font-size:13px;transition:background .15s;display:block}.dropdown-item:hover{color:#1e293b;background:#f1f5f9}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}
