*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0e1726;--panel:#152133;--panel2:#1b2a40;--border:#26384f;--text:#e6eef7;--muted:#8aa2bd;--accent:#38bdf8;--accent2:#22d3a8;--amber:#f59e0b;--danger:#ef4444}body,html{height:100%;background:var(--bg);color:var(--text);font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}.app{display:grid;grid-template-columns:264px 1fr 280px;grid-template-rows:52px 1fr;grid-template-areas:"topbar topbar topbar" "palette canvas info";height:100vh}.topbar{grid-area:topbar;gap:16px;padding:0 18px;background:var(--panel);border-bottom:1px solid var(--border)}.brand,.topbar{display:flex;align-items:center}.brand{font-weight:800;font-size:16px;letter-spacing:-.3px;gap:9px}.brand .dot{width:11px;height:11px;border-radius:3px;background:linear-gradient(135deg,var(--accent),var(--accent2))}.brand small{font-weight:500;color:var(--muted);font-size:11px;margin-left:2px}.topbar-spacer{flex:1 1}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:7px;border:1px solid var(--border);background:var(--panel2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s,border-color .12s}.btn:hover{background:#243752;border-color:#345a7d}.btn.primary{background:var(--accent);border-color:var(--accent);color:#06243a}.btn.primary:hover{background:#5cccfa}.btn.danger{color:#fca5a5;border-color:#5b2a2a;background:#2a1717}.btn.danger:hover{background:#3a1d1d}.btn:disabled{opacity:.4;cursor:not-allowed}.palette{grid-area:palette;border-right:1px solid var(--border);padding:14px}.info,.palette{background:var(--panel);overflow-y:auto}.info{grid-area:info;border-left:1px solid var(--border);padding:16px}.canvas-wrap{grid-area:canvas;position:relative;overflow:hidden;background:#0a1220}.group-title{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:700;margin:14px 0 8px;display:flex;align-items:center;gap:7px}.group-title:before{content:"";width:9px;height:9px;border-radius:2px;background:currentColor}.group-title:first-child{margin-top:0}.piece-btn{width:100%;text-align:left;display:flex;align-items:center;gap:10px;padding:8px 10px;margin-bottom:5px;border-radius:7px;border:1px solid var(--border);background:var(--panel2);color:var(--text);font-size:12.5px;cursor:pointer;font-family:inherit;transition:background .1s,border-color .1s}.piece-btn:hover{background:#243752;border-color:var(--accent)}.piece-btn .art{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--muted);margin-left:auto}.piece-row{display:flex;align-items:center;gap:6px;margin-bottom:5px}.piece-row .piece-btn{flex:1 1;width:auto;margin-bottom:0;min-width:0}.piece-row .piece-btn .piece-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.piece-price-wrap{display:inline-flex;align-items:center;gap:2px;background:var(--panel2);border:1px solid var(--border);border-radius:6px;padding:0 5px;flex-shrink:0}.piece-price-wrap:focus-within{border-color:var(--accent)}.piece-price-wrap .eur{font-size:11px;color:var(--muted)}.piece-price{width:42px;border:none;background:transparent;color:var(--text);font-size:12px;font-family:JetBrains Mono,monospace;padding:6px 0;outline:none;text-align:right}.piece-price::-webkit-inner-spin-button,.piece-price::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.piece-swatch{width:22px;height:22px;border-radius:5px;flex-shrink:0;display:grid;place-items:center}.info h3{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:12px}.stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--border)}.stat-row .k{font-size:13px;color:var(--muted)}.stat-row .v{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:500}.stat-row .v.big{font-size:17px;color:var(--accent2)}.bom{margin-top:8px}.bom-row{display:flex;align-items:center;gap:9px;padding:6px 0;border-bottom:1px solid var(--border);font-size:12.5px}.bom-row .cnt{font-weight:600;color:var(--accent);min-width:26px}.bom-row .art,.bom-row .cnt{font-family:JetBrains Mono,monospace}.bom-row .art{font-size:10.5px;color:var(--muted);margin-left:auto}.bom-dot{width:9px;height:9px;border-radius:2px;flex-shrink:0}.bom-row .bom-label{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bom-row .bom-label .art{margin-left:0}.bom-head{opacity:.7}.bom-head .cnt{color:var(--muted);font-weight:500}.bom-price-h,.bom-tot-h{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.bom-price,.bom-price-h,.bom-tot-h{width:62px;flex-shrink:0;text-align:right}.bom-price{padding:3px 5px;border-radius:5px;border:1px solid var(--border);background:var(--panel2);color:var(--text);font-size:11.5px;font-family:JetBrains Mono,monospace}.bom-price:focus{border-color:var(--accent);outline:none}.bom-tot{width:62px;flex-shrink:0;text-align:right;font-family:JetBrains Mono,monospace;font-size:11.5px;color:var(--muted)}.bom-total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0 2px;font-size:13px;font-weight:700}.bom-grand{font-family:JetBrains Mono,monospace;color:var(--accent2)}.hint{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);background:rgba(21,33,51,.95);border:1px solid var(--border);border-radius:8px;padding:8px 16px;font-size:12.5px;color:var(--muted);pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.piece-toolbar{position:absolute;transform:translate(-50%,calc(-100% - 16px));display:flex;gap:4px;z-index:20;background:rgba(15,23,38,.97);border:1px solid var(--accent);border-radius:9px;padding:4px;box-shadow:0 6px 20px rgba(0,0,0,.5)}.piece-toolbar button{width:32px;height:32px;border-radius:6px;border:none;background:var(--panel2);color:var(--text);font-size:16px;cursor:pointer;display:grid;place-items:center}.piece-toolbar button:hover{background:#2a3f5c}.piece-toolbar button.del{color:#fca5a5}.piece-toolbar button.del:hover{background:#3a1d1d}.piece-toolbar:after{content:"";position:absolute;left:50%;bottom:-6px;transform:translateX(-50%) rotate(45deg);width:10px;height:10px;background:rgba(15,23,38,.97);border-right:1px solid var(--accent);border-bottom:1px solid var(--accent)}.legend{position:absolute;left:14px;top:14px;pointer-events:none;background:rgba(15,23,38,.92);border:1px solid var(--border);border-radius:10px;padding:10px 13px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;gap:6px;max-width:340px}.legend-row{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}.legend-row b{color:var(--text);font-weight:600}.lg-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}.lg-dot.draw{background:#38bdf8}.lg-dot.sel{background:#22d3a8}.lg-dot.move{background:#f59e0b}.lg-dot.del{background:#ef4444}.zoom-ctl{position:absolute;right:14px;bottom:14px;display:flex;flex-direction:column;gap:6px}.zoom-ctl button{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:rgba(21,33,51,.95);color:var(--text);font-size:17px;cursor:pointer;display:grid;place-items:center}.zoom-ctl button:hover{background:#243752}.empty-note{color:var(--muted);font-size:12.5px;line-height:1.6}svg{display:block}.canvas-svg{cursor:-webkit-grab;cursor:grab}.canvas-svg.panning{cursor:-webkit-grabbing;cursor:grabbing}.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(6,12,22,.72);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center}.modal{width:480px;max-width:92vw;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.5)}.modal h2{font-size:20px;font-weight:800;margin-bottom:8px}.modal-sub{font-size:13.5px;color:var(--muted);line-height:1.6;margin-bottom:22px}.field-row{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px}.field-row label{flex:1 1;font-size:12px;color:var(--muted);font-weight:600;display:flex;flex-direction:column;gap:6px}.field-row .times{color:var(--muted);font-size:18px;padding-bottom:10px}.field-row input{width:100%;padding:11px 13px;border-radius:8px;border:1.5px solid var(--border);background:var(--panel2);color:var(--text);font-size:17px;font-family:JetBrains Mono,monospace;outline:none}.field-row input:focus{border-color:var(--accent)}.presets{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:8px;gap:8px;margin-bottom:24px}.preset{padding:9px 8px;border-radius:7px;border:1px solid var(--border);background:var(--panel2);color:var(--text);font-size:12px;cursor:pointer;font-family:inherit;transition:background .1s,border-color .1s}.preset:hover{background:#243752;border-color:var(--accent)}.preset.active{border-color:var(--accent);background:#1d2c42;color:#fff}.modal-actions{display:flex;align-items:center;gap:10px;margin-top:8px}.modal-wide{width:600px}.seg{display:flex;gap:4px;background:var(--panel2);border:1px solid var(--border);border-radius:9px;padding:4px;margin-bottom:20px}.seg-btn{flex:1 1;padding:8px;border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:600;border-radius:6px;cursor:pointer;font-family:inherit}.seg-btn.active{background:var(--accent);color:#06243a}.lform-grid{display:grid;grid-template-columns:1fr auto;grid-gap:20px;gap:20px;align-items:start;margin-bottom:20px}.lpreview-box{border:1px solid var(--border);border-radius:10px;background:var(--panel2)}.lpreview-box.muted{width:220px;height:160px;display:grid;place-items:center;color:var(--muted);font-size:12px}.draw-hint{font-size:12.5px;color:var(--muted);margin-bottom:10px}.draw-area{border:1px solid var(--border);border-radius:10px;background:#0a1220;cursor:crosshair;display:block}.draw-actions{display:flex;align-items:center;gap:8px;margin-top:12px}.draw-dim{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--muted)}.plan-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:12px;gap:12px;margin-bottom:20px}.plan-card{text-align:left;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--panel2);color:var(--text);cursor:pointer;font-family:inherit;transition:border-color .12s,background .12s}.plan-card:hover{border-color:var(--accent);background:#1d2c42}.plan-thumb{width:100%;height:96px;background:#0a1220;border-radius:7px;display:block;margin-bottom:8px}.plan-name{font-size:13.5px;font-weight:700}.plan-desc{font-size:11.5px;color:var(--muted);line-height:1.4;margin-top:2px}@media (max-width:640px){.plan-grid{grid-template-columns:1fr 1fr}}.ai-box{margin-top:18px;padding:16px;border-radius:12px;border:1px solid var(--accent);background:rgba(56,189,248,.06)}.ai-title{font-size:14px;font-weight:700;color:var(--accent);margin-bottom:10px}.ai-title span{font-weight:400;font-size:11.5px;color:var(--muted);margin-left:6px}.ai-row{display:flex;gap:8px}.ai-row input{flex:1 1;padding:10px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--panel2);color:var(--text);font-size:13.5px;font-family:inherit;outline:none}.ai-row input:focus{border-color:var(--accent)}.ai-error{margin-top:10px;font-size:12.5px;color:#fca5a5}.save-status{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:#6ee7b7;padding:0 6px;white-space:nowrap;opacity:.9}.viewer3d{position:fixed;inset:0;z-index:100;background:#bfe3f5}.viewer3d canvas{display:block;width:100%;height:100%}.v3d-bar{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;gap:10px;padding:12px 16px;background:linear-gradient(transparent,rgba(8,14,24,.72));color:#fff}.v3d-spacer{flex:1 1}.v3d-speed{display:flex;align-items:center;gap:8px;font-size:12.5px;color:#e8f0f8}.v3d-speed input{width:130px}.v3d-note{font-size:12.5px;color:#ffd9a8}