*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--panel-width: 220px;--left-panel-width: var(--panel-width);--right-panel-width: var(--panel-width);--font-stack: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--text: #0f172a;--text-dark: #334155;--text-muted: #64748b;--text-soft: #94a3b8;--text-on-dark: #fef3c7;--text-on-dark-accent: #fcd34d;--bg: #f8fafc;--panel: #ffffff;--panel-soft: #f8fafc;--border: #e4e7ec;--border-soft: #eef2f6;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-bg: #eff6ff;--danger: #b91c1c;--danger-dark: #991b1b;--danger-bg: #fef2f2;--danger-border: #fca5a5;--group-mode: #0891b2;--group-mode-hover: #0e7490;--group-mode-on: #ecfeff}html,body{width:100%;height:100%;overflow:hidden;font-family:var(--font-stack);color:var(--text);background:var(--bg);touch-action:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;user-select:none;-webkit-user-select:none}input,textarea,[contenteditable]{user-select:text;-webkit-user-select:text}.angle-readout,.hall-parts-value,.hall-label,.count-info,.stat-value,.stat-label,.popup-stepper .val,.selected-variant-stepper .val,.export-tile-hint,.export-size-hint,.device-detail-popup,.selected-info{font-variant-numeric:tabular-nums}#app{display:flex;flex-direction:column;width:100vw;height:100vh;height:100dvh}header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--panel);border-bottom:1px solid var(--border);box-shadow:0 1px 2px #0000000a;flex-shrink:0}.logo{display:flex;align-items:center;gap:10px}.logo-mark{width:30px;height:30px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center}.logo-mark svg{width:30px;height:30px;display:block}.logo-text h1{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.logo-text p{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:1px}.help-btn{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--panel);cursor:pointer;font-family:inherit;color:var(--text);border-radius:4px;transition:background .1s,border-color .1s,color .1s}.help-btn:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.help-btn svg{width:18px;height:18px;display:block;pointer-events:none}.export-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;font-size:12px;font-weight:500;letter-spacing:.2px;border:1px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;font-family:inherit;margin-right:6px;border-radius:4px;transition:background .1s,border-color .1s}.export-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.export-btn svg{width:15px;height:15px;display:block;pointer-events:none}.toolbar-btn{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--panel);cursor:pointer;font-family:inherit;color:var(--text);margin-right:4px;border-radius:4px;transition:background .1s,border-color .1s,color .1s}.toolbar-btn:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.toolbar-btn.danger:hover{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger)}.toolbar-btn svg{width:18px;height:18px;display:block;pointer-events:none}.mode-toggle{height:32px;padding:0 14px;display:inline-flex;align-items:center;font-size:12px;font-weight:500;letter-spacing:.2px;border:1px solid var(--border);background:var(--panel);cursor:pointer;font-family:inherit;color:var(--text-muted);margin-right:8px;border-radius:4px;transition:background .15s,border-color .15s,color .15s}.mode-toggle:hover{border-color:var(--text-soft);color:var(--text)}body.advanced .mode-toggle{background:var(--text);border-color:var(--text);color:var(--text-on-dark)}.tilt-row{display:flex;gap:6px}.tilt-row .action-btn{flex:1}.advanced-only{display:none}body.advanced .advanced-only{display:block}.toast{position:absolute;z-index:30;top:64px;left:50%;transform:translate(-50%) translateY(-10px);background:#0f172aeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:9px 18px;font-size:12px;font-weight:500;letter-spacing:.1px;border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 24px #0f172a38;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease,transform .2s ease}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}#fileInput{display:none}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s;pointer-events:none}.confirm-backdrop.visible{opacity:1;pointer-events:auto}.confirm-dialog{background:var(--panel);border:1px solid var(--border);box-shadow:0 20px 48px #0f172a2e;padding:0;min-width:280px;max-width:360px;border-radius:10px;overflow:hidden;transform:translateY(6px);transition:transform .12s}.confirm-backdrop.visible .confirm-dialog{transform:translateY(0)}.confirm-dialog-header{padding:12px 16px;background:var(--panel-soft);border-bottom:1px solid var(--border-soft)}.confirm-dialog-header h2{font-size:15px;font-weight:600;letter-spacing:-.1px}.confirm-dialog-body{padding:14px 16px;font-size:11px;line-height:1.5;color:var(--text-dark)}.confirm-dialog-footer{padding:10px 16px;background:var(--panel-soft);border-top:1px solid var(--border-soft);display:flex;justify-content:flex-end;gap:8px}.confirm-btn{padding:8px 14px;font-size:12px;font-weight:500;letter-spacing:.2px;border:1px solid var(--border);background:var(--panel);cursor:pointer;font-family:inherit;color:var(--text);border-radius:6px;transition:background .1s,border-color .1s}.confirm-btn:hover:not(.primary):not(.danger-primary){background:var(--panel-soft);border-color:var(--text-soft)}.confirm-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.confirm-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.confirm-btn.danger-primary{background:var(--danger);color:#fff;border-color:var(--danger)}.confirm-btn.danger-primary:hover{background:var(--danger-dark);border-color:var(--danger-dark)}.export-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;pointer-events:none}.export-dialog-backdrop.visible{opacity:1;pointer-events:auto}.export-dialog{background:var(--panel);border:1px solid var(--border);box-shadow:0 20px 48px #0f172a2e;min-width:340px;max-width:420px;width:100%;border-radius:10px;overflow:hidden;transform:translateY(8px);transition:transform .15s}.export-dialog-backdrop.visible .export-dialog{transform:translateY(0)}.export-dialog-header{padding:12px 16px;background:var(--panel-soft);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.export-dialog-header h2{font-size:15px;font-weight:600;letter-spacing:-.1px}.export-dialog-close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--text-muted);padding:0;font-family:inherit;line-height:1}.export-dialog-body{padding:16px;display:flex;flex-direction:column;gap:14px}.export-section-label{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-soft);margin-bottom:6px;font-weight:600}.export-quality-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.export-opt-btn{border:1px solid var(--border);background:var(--panel-soft);padding:8px 6px;font-family:inherit;cursor:pointer;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dark);transition:all .1s;text-align:center}.export-opt-btn:hover{border-color:var(--accent);background:var(--accent-bg)}.export-opt-btn.selected{border-color:var(--text);background:var(--text);color:var(--text-on-dark)}.export-fmt-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.export-toggle-row{display:flex;align-items:center;gap:8px;font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dark);cursor:pointer;-webkit-user-select:none;user-select:none}.export-toggle-row input[type=checkbox]{margin:0;cursor:pointer}.export-toggle-row+.export-toggle-row{margin-top:6px}.export-toggle-row.disabled{color:var(--border);cursor:not-allowed}.export-toggle-row.disabled input[type=checkbox]{cursor:not-allowed}.export-radio-row{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.export-radio-row label{display:flex;align-items:center;gap:8px;font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dark);cursor:pointer;-webkit-user-select:none;user-select:none}.export-radio-row input[type=radio]{margin:0;cursor:pointer}.export-select-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dark);cursor:pointer;-webkit-user-select:none;user-select:none}.export-select-row+.export-select-row{margin-top:6px}.export-select-row select{border:1px solid var(--border);background:var(--panel);padding:5px 8px;font-family:inherit;font-size:11px;color:var(--text);outline:none;cursor:pointer;min-width:160px}.export-select-row select:focus{border-color:var(--accent)}.export-tile-hint{margin-top:8px;font-size:10px;color:var(--text-muted);text-align:right;letter-spacing:.4px}.export-filename-input{width:100%;border:1px solid var(--border);background:var(--panel);padding:7px 10px;font-family:inherit;font-size:11px;color:var(--text);outline:none}.export-filename-input:focus{border-color:var(--accent)}.export-dialog-footer{padding:12px 16px;background:var(--panel-soft);border-top:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;gap:12px}.export-size-hint{font-size:9px;color:var(--text-muted);line-height:1.4}.export-size-hint strong{color:var(--text)}.export-go-btn{padding:9px 20px;font-size:12px;font-weight:500;letter-spacing:.2px;border:none;background:var(--accent);color:#fff;cursor:pointer;font-family:inherit;white-space:nowrap;border-radius:6px;transition:background .1s}.export-go-btn:hover{background:var(--accent-hover)}.export-pdf-note{font-size:9px;color:var(--text-soft);font-style:italic}.design-btn{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--panel);cursor:pointer;font-family:inherit;color:var(--text);margin-right:6px;border-radius:4px;transition:background .1s,border-color .1s,color .1s}.design-btn:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.design-btn svg{width:18px;height:18px;display:block;pointer-events:none}.design-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;pointer-events:none}.design-dialog-backdrop.visible{opacity:1;pointer-events:auto}.design-dialog{background:var(--panel);border:1px solid var(--border);box-shadow:0 20px 48px #0f172a2e;min-width:340px;max-width:480px;width:100%;border-radius:10px;overflow:hidden;transform:translateY(8px);transition:transform .15s}.design-dialog-backdrop.visible .design-dialog{transform:translateY(0)}.design-dialog-header{padding:12px 16px;background:var(--panel-soft);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.design-dialog-header h2{font-size:15px;font-weight:600;letter-spacing:-.1px}.design-dialog-close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--text-muted);padding:0;font-family:inherit;line-height:1}.design-dialog-body{padding:16px}.design-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.design-toggle-row{display:flex;align-items:center;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border-soft);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;color:var(--text)}.design-toggle-row input[type=checkbox]{cursor:pointer;margin:0}.design-toggle-label{line-height:1}.hall-parts-control{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border-soft);font-size:12px;color:var(--text);-webkit-user-select:none;user-select:none}.hall-parts-label{line-height:1}.hall-parts-buttons{display:flex;align-items:center;gap:4px}.hall-parts-btn{width:24px;height:24px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text-dark);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;padding:0;line-height:1;transition:all .1s}.hall-parts-btn:hover:not(:disabled){border-color:var(--accent);background:var(--accent-bg)}.hall-parts-btn:disabled{opacity:.35;cursor:not-allowed}.hall-parts-value{min-width:22px;text-align:center;font-size:12px;font-weight:600;color:var(--text)}.field-lines-section{margin-top:14px;padding-top:12px;border-top:1px solid var(--border-soft)}.field-lines-heading{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;color:var(--text);margin-bottom:10px}.field-lines-sport{margin-bottom:12px}.field-lines-sport:last-child{margin-bottom:0}.field-lines-sport-heading{font-size:11px;font-weight:600;color:#57534e;margin-bottom:4px;letter-spacing:.3px}.field-line-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.field-line-row.disabled{opacity:.4;cursor:not-allowed}.field-line-name{flex:1;line-height:1.2}.field-line-controls{display:flex;align-items:center;gap:4px}.field-line-row input[type=checkbox]{cursor:pointer;margin:0}.field-line-row.disabled input[type=checkbox]{cursor:not-allowed}.field-line-swatch{width:12px;height:12px;border:1px solid var(--border);flex-shrink:0}.part-toggles{display:flex;gap:3px}.part-toggle{width:22px;height:22px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;padding:0;transition:all .1s}.part-toggle:hover{border-color:var(--accent);background:var(--accent-bg)}.part-toggle.active{border-color:var(--text);background:var(--text);color:var(--panel)}.field-line-row.disabled .part-toggle{cursor:not-allowed}.design-card{position:relative;border:1px solid var(--border);background:var(--panel-soft);padding:10px 8px 8px;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .1s,background .1s}.design-card:hover{border-color:var(--accent);background:var(--accent-bg)}.design-card.selected{border-color:var(--text);border-width:2px;padding:9px 7px 7px;background:var(--panel)}.design-card.selected:after{content:"✓";position:absolute;top:4px;right:6px;font-size:11px;color:var(--text);font-weight:700;line-height:1}.design-preview{width:80px;height:50px;border:1px solid var(--border);background:linear-gradient(to bottom,var(--top) 0%,var(--socle) 60%,var(--floor) 60%,var(--floor) 100%)}.design-label{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dark);font-weight:600}main{flex:1;display:flex;min-height:0;position:relative}aside{background:var(--panel);display:flex;flex-direction:column;flex-shrink:0}aside.left{width:var(--left-panel-width);border-right:1px solid var(--border);transition:width .26s cubic-bezier(.4,0,.2,1)}aside.right{width:var(--right-panel-width);border-left:1px solid var(--border);transition:width .26s cubic-bezier(.4,0,.2,1);overflow:hidden}main.panel-collapsed aside.right{width:0;border-left:none}.panel-toggle{position:absolute;right:var(--right-panel-width);top:50%;transform:translateY(-50%);width:18px;height:52px;background:var(--panel);border:1px solid var(--border);border-right:none;border-radius:4px 0 0 4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);z-index:10;padding:0;font-family:inherit;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:-1px 0 4px #0000000a;transition:right .26s cubic-bezier(.4,0,.2,1),left .26s cubic-bezier(.4,0,.2,1),background .1s,color .1s}.panel-toggle:hover{background:var(--panel-soft);color:var(--text)}main.panel-collapsed .panel-toggle:not(.panel-toggle-left){right:0}.panel-toggle.panel-toggle-left{right:auto;left:var(--left-panel-width);border-left:none;border-right:1px solid var(--border);border-radius:0 4px 4px 0;box-shadow:1px 0 4px #0000000a}.panel-title{padding:12px 14px;background:var(--panel);border-bottom:1px solid var(--border-soft);font-size:13px;font-weight:600;letter-spacing:-.1px;color:var(--text);display:flex;justify-content:space-between;align-items:center}.panel-title .badge{font-size:10px;font-weight:600;background:var(--panel-soft);color:var(--text-muted);padding:2px 8px;border-radius:10px;letter-spacing:0}.group-mode-action.active{background:var(--group-mode)!important;border-color:var(--group-mode)!important;color:var(--group-mode-on)!important}.group-mode-action.active:hover{background:var(--group-mode-hover)!important;border-color:var(--group-mode-hover)!important}body.group-mode-active #canvas{cursor:crosshair}.panel-content{flex:1;overflow-y:auto;padding:8px;position:relative}.panel-footer{padding:10px 14px;background:var(--panel-soft);border-top:1px solid var(--border-soft);font-size:11px;color:var(--text-muted);line-height:1.5}.device-search{display:flex;align-items:center;gap:7px;margin:8px 10px 4px;padding:5px 9px;background:var(--panel-soft);border:1px solid var(--border);border-radius:6px;transition:border-color .12s,background .12s}.device-search:focus-within{border-color:var(--accent);background:var(--panel)}.device-search-icon{width:13px;height:13px;color:var(--text-muted);flex-shrink:0;pointer-events:none}.device-search-input{flex:1;min-width:0;border:none;background:transparent;padding:2px 0;font-size:12px;font-family:inherit;color:var(--text);outline:none}.device-search-input::placeholder{color:var(--text-muted)}.device-search-clear{width:16px;height:16px;display:none;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:0;border-radius:3px;flex-shrink:0}.device-search-clear svg{width:11px;height:11px}.device-search-clear:hover{background:var(--border);color:var(--text)}.device-search.has-content .device-search-clear{display:flex}.device-search-empty{padding:24px 14px;text-align:center;font-size:11px;color:var(--text-muted);line-height:1.6}.category-group{margin-bottom:14px}.category-label{font-size:11px;font-weight:600;color:var(--text-muted);padding:8px 6px;letter-spacing:-.05px}.device-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}body.cols-3 .device-grid{grid-template-columns:1fr 1fr 1fr}body.cols-3{--left-panel-width: 290px}.device-card{position:relative;border:1px solid var(--border-soft);background:var(--border-soft);cursor:grab;font-family:inherit;aspect-ratio:1;padding:0;border-radius:6px;overflow:hidden;transition:border-color .12s,background .12s,box-shadow .12s;user-select:none;-webkit-user-select:none;touch-action:none}.device-card:active{cursor:grabbing}.device-card:hover,.device-card.dragging{border-color:var(--accent);background:var(--accent-bg)}.device-card.dragging{opacity:.5}.device-card>*{pointer-events:none}.device-icon-big{position:absolute;top:4px;left:4px;width:calc(100% - 8px);height:calc(100% - 8px);display:flex;align-items:center;justify-content:center;color:var(--panel);font-size:28px;border-radius:4px}.device-thumb{position:absolute;top:4px;left:4px;width:calc(100% - 8px);height:calc(100% - 8px);object-fit:contain;display:block;image-rendering:-webkit-optimize-contrast}.device-shortname{position:absolute;left:0;right:0;bottom:0;padding:2px 4px 4px;font-size:10px;font-weight:600;color:var(--text-dark);text-align:center;line-height:1.15;letter-spacing:-.05px;pointer-events:none;z-index:1}.device-detail-popup{position:absolute;z-index:50;background:var(--text);color:var(--text-on-dark);border:1px solid rgba(255,255,255,.1);padding:10px 12px;box-shadow:0 10px 24px #0f172a4d;border-radius:8px;pointer-events:auto;min-width:170px;max-width:220px;opacity:0;transition:opacity .12s}.device-detail-popup.visible{opacity:1}.device-detail-popup h4{font-size:12px;font-weight:600;letter-spacing:-.05px;margin-bottom:4px;color:#fff}.device-detail-popup .desc{font-size:11px;color:var(--text-on-dark-accent);margin-bottom:8px;line-height:1.4}.popup-stepper-row{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:11px}.popup-stepper-row+.popup-stepper-row{margin-top:5px}.popup-stepper{display:inline-flex;align-items:center;gap:6px}.popup-stepper .val{font-size:11px;font-weight:600;min-width:60px;text-align:right;color:#fff}.popup-stepper-vert{display:inline-flex;flex-direction:column;border:1px solid rgba(255,255,255,.16);border-radius:4px;overflow:hidden}.popup-stepper-vert button{width:20px;height:17px;border:none;background:transparent;color:#fff;font-family:inherit;font-size:10px;cursor:pointer;padding:0;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .1s}.popup-stepper-vert button:first-child{border-bottom:1px solid rgba(255,255,255,.14)}.popup-stepper-vert button:hover:not(:disabled){background:#ffffff1a}.popup-stepper-vert button:disabled{color:var(--text-muted);cursor:not-allowed}.popup-stepper-vert button:active:not(:disabled){background:#fff3}.selected-variant-row{font-size:11px;color:var(--text-muted);margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;gap:8px}.selected-variant-stepper{display:inline-flex;border:1px solid var(--border);background:var(--panel);border-radius:6px;overflow:hidden}.selected-variant-stepper button{width:26px;height:26px;border:none;background:transparent;font-family:inherit;font-size:14px;cursor:pointer;padding:0;color:var(--text-dark);transition:background .1s,color .1s}.selected-variant-stepper button:hover:not(:disabled){background:var(--accent-bg);color:var(--accent)}.selected-variant-stepper button:disabled{color:var(--border);cursor:not-allowed}.selected-variant-stepper button:active:not(:disabled){background:var(--accent-bg)}.selected-variant-stepper .val{padding:0 10px;font-size:12px;font-weight:600;line-height:26px;min-width:70px;text-align:center;color:var(--text)}.canvas-wrap{flex:1;position:relative;background:linear-gradient(to bottom,var(--border-soft),var(--border));min-width:0;overflow:hidden}#canvas{width:100%;height:100%;display:block;touch-action:none}.overlay{position:absolute;z-index:10;background:#fffffff0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);box-shadow:0 4px 14px #0f172a14;border-radius:8px}.undo-toolbar{top:14px;left:14px;display:flex;padding:4px;gap:2px}.undo-btn{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;font-family:inherit;color:var(--text-dark);border-radius:4px}.undo-btn:hover:not(:disabled){background:var(--accent-bg);color:var(--accent)}.undo-btn:disabled{color:var(--border);cursor:not-allowed}.undo-btn svg{width:16px;height:16px;display:block;pointer-events:none}.views-toolbar{top:14px;left:50%;transform:translate(-50%);display:flex;padding:4px;gap:2px}.view-btn{padding:7px 14px;font-size:12px;font-weight:500;letter-spacing:.1px;border:none;background:transparent;cursor:pointer;font-family:inherit;color:var(--text-muted);border-radius:5px;transition:background .12s,color .12s}.view-btn:hover:not(.active){color:var(--text);background:var(--accent-bg)}.view-btn.active{background:var(--accent);color:#fff}.hall-info{top:14px;right:14px;padding:8px 14px;font-size:12px;font-weight:500;color:var(--text);display:flex;align-items:center;gap:4px;cursor:default;transition:padding .15s}.hall-info:hover{padding:8px}.hall-label{padding:0 6px;white-space:nowrap}.hall-btn{width:24px;height:24px;border:none;background:none;cursor:pointer;font-size:16px;line-height:1;color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-family:inherit;padding:0;border-radius:5px;opacity:0;transition:opacity .15s,background .1s,color .1s;flex-shrink:0}.hall-info:hover .hall-btn{opacity:1}.hall-btn:hover{background:var(--accent-bg);color:var(--accent)}@media (hover: none){.hall-btn{opacity:1}}.hall-info.parts-1 .hall-btn-minus,.hall-info.parts-3 .hall-btn-plus{visibility:hidden;pointer-events:none}.count-info{bottom:14px;left:14px;padding:8px 14px;font-size:12px;font-weight:500;color:var(--text-muted)}.source-link{position:absolute;bottom:14px;right:14px;z-index:20;display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border-radius:6px;font-size:11px;font-weight:500;color:var(--text-soft);text-decoration:none;background:#ffffff9e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border-soft);transition:color .12s,background .12s,border-color .12s}.source-link:hover{color:var(--accent);background:var(--panel);border-color:var(--border)}.source-link svg{width:13px;height:13px;display:block}.help-panel{position:absolute;top:0;right:0;bottom:0;width:300px;background:var(--panel);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:40;transform:translate(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:-4px 0 16px #00000012}.help-panel.open{transform:translate(0)}.help-btn.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.help-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-soft);flex-shrink:0;background:var(--panel)}.help-panel-title{font-size:13px;font-weight:600;color:var(--text)}.help-panel-close{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--panel);border-radius:4px;cursor:pointer;color:var(--text-muted);font-family:inherit;padding:0;transition:background .1s,color .1s}.help-panel-close:hover{background:var(--panel-soft);color:var(--text)}.help-panel-close svg{width:14px;height:14px;display:block;pointer-events:none}.help-panel-body{flex:1;overflow-y:auto;overscroll-behavior:contain}.help-section{border-bottom:1px solid var(--border-soft)}.help-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-dark);text-align:left;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .1s}.help-section-header:hover{background:var(--panel-soft)}.help-chevron{width:14px;height:14px;flex-shrink:0;color:var(--text-muted);transition:transform .22s ease}.help-section.open .help-chevron{transform:rotate(180deg)}.help-section-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .22s ease}.help-section.open .help-section-body{grid-template-rows:1fr}.help-section-content{overflow:hidden;padding:0 14px;font-size:11px;line-height:1.55;color:var(--text-dark)}.help-section.open .help-section-content{padding-bottom:14px}.help-sub{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin:10px 0 4px}.help-sub:first-child{margin-top:6px}kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:1px 4px;font-size:9px;font-family:inherit;font-weight:600;background:var(--panel-soft);border:1px solid var(--border);border-bottom-width:2px;border-radius:3px;color:var(--text);white-space:nowrap;line-height:1.4}.help-table{width:100%;border-collapse:collapse;margin-bottom:2px}.help-table td{padding:2px 0;vertical-align:middle;font-size:11px}.help-table td:first-child{width:1%;white-space:nowrap;padding-right:10px;color:var(--text)}.help-table td:last-child{color:var(--text-muted)}.help-keyboard-note{display:flex;align-items:center;gap:6px;padding:5px 8px;margin-top:4px;margin-bottom:6px;background:var(--accent-bg);border:1px solid #bfdbfe;border-radius:4px;font-size:10px;font-weight:600;color:var(--accent)}.help-keyboard-note:before{content:"⌨"}.help-intro-list{list-style:none;margin-top:6px}.help-intro-list li{padding:2px 0 2px 14px;position:relative;font-size:11px;color:var(--text-muted)}.help-intro-list li:before{content:"·";position:absolute;left:4px;color:var(--text-soft)}.help-intro-list li strong{color:var(--text-dark)}.help-feature-list{list-style:none;margin-bottom:2px}.help-feature-list li{padding:2px 0 2px 16px;position:relative;font-size:11px;color:var(--text-muted)}.help-feature-list li:before{content:"✓";position:absolute;left:0;font-size:9px;color:var(--text-soft);line-height:1.7}.help-feature-list.plus li:before{content:"+";color:var(--accent);font-weight:700}.help-feature-list.plus li{color:var(--text-dark)}.floating-actions{position:absolute;z-index:25;background:#0f172ac7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;gap:0;padding:0;opacity:0;transition:opacity .18s;will-change:transform;box-shadow:0 8px 20px #0f172a38;pointer-events:none;overflow:hidden}.floating-actions.visible{opacity:1;pointer-events:auto}.floating-actions button{background:transparent;border:none;color:#fff;width:32px;height:32px;font-size:14px;line-height:1;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;padding:0;transition:background .1s}.floating-actions button svg{width:16px;height:16px;display:block;pointer-events:none}.floating-actions button:hover{background:#ffffff1f}.floating-actions button:active{background:#fff3}.floating-actions button.danger:hover{background:#ef444447}.floating-actions .divider{width:1px;background:#ffffff1f;margin:6px 0}.drag-ghost{position:fixed;z-index:1000;pointer-events:none;background:var(--panel);border:1px solid var(--accent);padding:7px 12px;font-size:12px;font-weight:500;letter-spacing:.1px;color:var(--text);font-family:inherit;box-shadow:0 8px 20px #0f172a2e;border-radius:6px;display:none;align-items:center;gap:7px;opacity:1;transform-origin:0 0;will-change:transform,opacity}.drag-ghost.visible{display:flex}.drag-ghost.dissolving{transition:opacity .25s ease-out,transform .25s ease-out;opacity:0}.drag-ghost .di{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--panel);font-size:12px}.angle-readout{position:absolute;z-index:20;background:#0f172af2;color:#fff;padding:8px 16px;font-size:18px;font-weight:600;letter-spacing:-.2px;font-family:inherit;pointer-events:none;opacity:0;transition:opacity .1s;border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 8px 20px #0f172a40;will-change:transform}.angle-readout.visible{opacity:1}.selected-info{padding:4px}.selected-info>div{margin-bottom:14px}.label-tiny{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:-.05px}.label-bold{font-size:14px;font-weight:600;margin-top:4px;letter-spacing:-.1px;color:var(--text)}.desc-text{font-size:11px;color:var(--text-muted);margin-top:4px;line-height:1.45}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.stat-box{border:1px solid var(--border-soft);padding:8px 10px;border-radius:6px;background:var(--panel-soft)}.stat-label{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:-.05px}.stat-value{font-size:13px;font-weight:600;margin-top:3px;color:var(--text)}.action-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 12px;font-size:12px;font-weight:500;letter-spacing:.2px;cursor:pointer;font-family:inherit;margin-bottom:6px;border-radius:6px;border:none;transition:background .1s,border-color .1s}.action-btn.secondary{background:var(--panel);color:var(--text);border:1px solid var(--border)}.action-btn.secondary:hover:not(:disabled){background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.action-btn.secondary:active{background:var(--border-soft)}.action-btn.secondary:disabled{color:var(--border);border-color:var(--border-soft);cursor:not-allowed}.action-btn.danger{background:var(--panel);color:var(--danger);border:1px solid var(--danger-border)}.action-btn.danger:hover,.action-btn.danger:active{background:var(--danger-bg)}.action-btn.icon-btn{width:28px;height:28px;padding:0;margin-bottom:0;flex-shrink:0}.empty-state{text-align:center;padding:36px 18px;color:var(--text-muted);font-size:12px;line-height:1.55}.empty-state svg{width:28px;height:28px;margin:0 auto 14px;padding:14px;background:var(--accent-bg);color:var(--accent);border-radius:10px;box-sizing:content-box;opacity:1;display:block}.schema-info{font-size:9px;color:var(--text-muted);margin-top:8px;padding:6px;background:var(--panel-soft);border:1px solid var(--border-soft);line-height:1.4}.schema-info strong{color:var(--text)}.schema-info code{font-family:inherit;background:var(--panel);padding:0 3px;border:1px solid var(--border-soft)}@media (max-width: 900px){:root{--panel-width: 175px}.device-icon-big{font-size:28px}.panel-toggle-left{display:none}body.cols-3{--left-panel-width: var(--panel-width)}body.cols-3 .device-grid{grid-template-columns:1fr 1fr}}@media (max-width: 900px){.help-panel{width:min(300px,65vw)}}@media (max-width: 640px){:root{--panel-width: 130px}.help-panel{width:min(300px,80vw)}}@media (max-width: 480px){.help-panel{width:100%;border-left:none}}@media (max-width: 500px),(max-height: 500px){.device-grid,body.cols-3 .device-grid{grid-template-columns:1fr}.logo-text p,.help-btn{display:none}.export-btn{padding:6px 8px;font-size:9px;margin-right:4px}.toolbar-btn{padding:6px 8px;font-size:12px;margin-right:2px}}
