.main-toolbar{display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 20px;background:#222228;border-bottom:1px solid #27272a;gap:16px}.toolbar-left .app-title{font-size:16px;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;letter-spacing:-.02em}.toolbar-center{display:flex;align-items:center;gap:8px;background:#2a2a32;padding:6px 10px;border-radius:12px;border:1px solid #27272a}.toolbar-center .tool-group{display:flex;gap:4px}.toolbar-center .divider{width:1px;height:24px;background:#3f3f46;margin:0 4px}.toolbar-right{display:flex;gap:8px}.toolbar-right .btn{display:flex;align-items:center;gap:6px;padding:8px 14px}.btn-delete:not(:disabled):hover,.btn-clear:not(:disabled):hover{color:#ef4444;border-color:#ef4444;background:#ef44441a}@media(max-width:768px){.main-toolbar .app-title,.main-toolbar .toolbar-right{display:none}}.left-sidebar{width:280px;background:#222228;border-right:1px solid #27272a;overflow-y:auto;padding:20px}@media(max-width:1024px){.left-sidebar{width:240px}}.section-title{font-size:15px;font-weight:600;color:#71717a;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.section-hint{font-size:11px;color:#71717a;margin-bottom:12px}.material-list,.router-list{display:flex;flex-direction:column;gap:8px}.material-item,.router-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid #27272a;border-radius:8px;background:#2a2a32;cursor:pointer;transition:all .2s ease;text-align:left}.material-item:hover,.router-item:hover{border-color:#6366f1;background:#3a3a44}.material-item.active,.router-item.active{border-color:#6366f1;background:#6366f126;box-shadow:0 0 20px #6366f14d}.material-color{width:18px;height:18px;border-radius:4px;flex-shrink:0;box-shadow:0 0 0 1px #ffffff1a}.material-name,.router-name{flex:1;font-size:13px;font-weight:500;color:#f4f4f5}.material-attenuation,.router-info{font-size:11px;color:#71717a;font-family:JetBrains Mono,monospace}.right-sidebar{width:280px;background:#222228;border-left:1px solid #27272a;overflow-y:auto;padding:20px}@media(max-width:1024px){.right-sidebar{width:240px}}.sidebar-section{margin-bottom:28px}.section-title{font-size:15px;font-weight:600;color:#71717a;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px}.control-row,.property-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.control-row label,.property-row label{font-size:13px;color:#a1a1aa}.control-row .slider,.property-row .slider{flex:1}.control-row .value,.property-row .value{min-width:44px;text-align:right;font-size:13px;color:#a1a1aa;font-family:JetBrains Mono,monospace}.control-row select,.property-row select{min-width:110px}.btn-danger{width:100%;margin-top:12px;background:transparent;border:1px solid #ef4444;color:#ef4444;padding:10px}.btn-danger:hover{background:#ef444426}.signal-legend .legend-bar{height:20px;border-radius:6px;background:linear-gradient(to right,#ef4444,#f97316,#eab308,#84cc16,#22c55e);margin-bottom:10px;box-shadow:0 0 20px #22c55e33}.signal-legend .legend-labels{display:flex;justify-content:space-between;font-size:11px;color:#71717a;margin-bottom:4px}.signal-legend .legend-labels:last-child{margin-bottom:0}.mobile-toolbar{position:fixed;bottom:0;left:0;right:0;background:#222228;border-top:1px solid #27272a;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tool-tabs{display:flex;justify-content:space-around;padding:10px 8px;padding-bottom:max(10px,env(safe-area-inset-bottom))}.tool-tabs .tab-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 18px;border:none;border-radius:8px;background:transparent;color:#a1a1aa;font-size:11px;font-weight:500;transition:all .2s ease}.tool-tabs .tab-btn svg{transition:transform .2s ease}.tool-tabs .tab-btn:active{transform:scale(.95)}.tool-tabs .tab-btn.active{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);box-shadow:0 0 20px #6366f14d}.tool-tabs .tab-btn.active svg{transform:scale(1.1)}.tool-panel{max-height:45vh;overflow-y:auto;padding:20px;border-top:1px solid #27272a;background:#2a2a32}.panel-content .material-grid,.panel-content .router-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.panel-content .material-btn,.panel-content .router-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 12px;border:1px solid #27272a;border-radius:8px;background:#222228;color:#f4f4f5;transition:all .2s ease}.panel-content .material-btn:active,.panel-content .router-btn:active{transform:scale(.97)}.panel-content .material-btn.active,.panel-content .router-btn.active{border-color:#6366f1;background:#6366f126;box-shadow:0 0 20px #6366f14d}.panel-content .material-btn .color,.panel-content .router-btn .color{width:28px;height:28px;border-radius:6px;box-shadow:0 0 0 1px #ffffff1a}.panel-content .material-btn .name,.panel-content .router-btn .name{font-size:13px;font-weight:500}.panel-content .material-btn .info,.panel-content .router-btn .info{font-size:11px;color:#71717a;font-family:JetBrains Mono,monospace}.panel-content .control-row{display:flex;align-items:center;gap:14px;margin-bottom:16px}.panel-content .control-row label{min-width:60px;font-size:13px;color:#a1a1aa}.panel-content .control-row input[type=range],.panel-content .control-row select{flex:1}.panel-content .btn{width:100%;margin-bottom:10px;padding:12px;font-weight:500}.panel-content .btn:last-child{margin-bottom:0}.slide-up-enter-active,.slide-up-leave-active{transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease}.slide-up-enter-from,.slide-up-leave-to{transform:translateY(100%);opacity:0}.canvas-ruler{position:absolute;z-index:10}.canvas-ruler.top{top:0;left:30px;height:30px}.canvas-ruler.left{top:30px;left:0;width:30px}.canvas-grid{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.canvas-controls{position:absolute;bottom:20px;left:20px;display:flex;flex-direction:column;gap:6px;z-index:50}.canvas-controls .btn{background:#32323a;border:1px solid #27272a;box-shadow:0 4px 12px #00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.canvas-controls .btn:hover{background:#3a3a44;border-color:#6366f1}.canvas-controls .btn.active{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-color:transparent;color:#fff;box-shadow:0 0 20px #6366f14d}.canvas-controls .scale-info{padding:6px 10px;background:#32323a;border:1px solid #27272a;border-radius:8px;box-shadow:0 4px 12px #00000080;font-size:11px;text-align:center;color:#a1a1aa;font-family:JetBrains Mono,monospace;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.wall-renderer{cursor:pointer}.wall-renderer.selected line{filter:drop-shadow(0 0 4px rgba(139,92,246,.6))}.wall-renderer .wall-length{font-size:.4px;fill:#fff;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 0 2px rgba(0,0,0,.8)}.router-renderer{cursor:move}.router-renderer.selected circle:first-child{filter:drop-shadow(0 0 6px rgba(139,92,246,.6))}.router-renderer .router-label{font-size:.25px;fill:#fff;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 0 2px rgba(0,0,0,.8)}.heatmap-renderer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.heatmap-renderer canvas{width:100%;height:100%}.canvas-container{position:relative;flex:1;overflow:hidden;background:#1a1a1f;cursor:crosshair}.canvas-container.is-pan-tool,.canvas-container.is-pan-ready{cursor:grab}.canvas-container.is-panning{cursor:grabbing}.ruler-corner{position:absolute;top:0;left:0;width:30px;height:30px;background:#222228;border-right:1px solid #27272a;border-bottom:1px solid #27272a;z-index:20}.canvas-viewport{position:absolute;top:30px;left:30px;right:0;bottom:0;overflow:hidden}.canvas-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.canvas-svg g{pointer-events:auto}.canvas-svg .drawing-length{font-size:.4px;fill:#fff;font-weight:600;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 0 3px rgba(0,0,0,.8)}.canvas-svg .drawing-length.length-matched,.canvas-svg .drawing-length .length-match-indicator{fill:#4ade80}.canvas-svg .alignment-guides{pointer-events:none}.canvas-svg .alignment-guides .guide-line{stroke-width:.03;stroke-dasharray:.1,.05;fill:none}.canvas-svg .alignment-guides .guide-line.guide-horizontal{stroke:#f472b6}.canvas-svg .alignment-guides .guide-line.guide-vertical{stroke:#60a5fa}.canvas-svg .alignment-guides .guide-line.guide-parallel{stroke:#fbbf24;stroke-width:.05;stroke-dasharray:.15,.08}.canvas-svg .alignment-guides .guide-point.guide-horizontal{fill:#f472b6}.canvas-svg .alignment-guides .guide-point.guide-vertical{fill:#60a5fa}.canvas-svg .alignment-guides .guide-distance{font-size:.28px;fill:#fbbf24;font-weight:500;text-shadow:0 0 2px rgba(0,0,0,.8)}.canvas-svg .length-match-highlight{stroke:#4ade80;stroke-width:.2;fill:none;stroke-dasharray:.15,.1;animation:pulse .8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.snap-indicator{position:absolute;width:14px;height:14px;margin-left:-7px;margin-top:-7px;border:2px solid #22d3ee;border-radius:50%;background:#22d3ee33;box-shadow:0 0 20px #22d3ee4d;pointer-events:none;z-index:100}.snap-indicator.on-wall-line{border-color:#f59e0b;background:#f59e0b4d;box-shadow:0 0 12px #f59e0b80}.wall-line-distances{position:absolute;pointer-events:none;z-index:101}.wall-line-distances .distance-label{position:absolute;padding:3px 6px;background:#f59e0be6;border-radius:4px;color:#000;font-size:11px;font-weight:600;font-family:JetBrains Mono,monospace;white-space:nowrap;box-shadow:0 2px 4px #0000004d}.wall-line-distances .distance-label.start{transform:translate(-100%,-50%);margin-left:-12px}.wall-line-distances .distance-label.end{transform:translateY(-50%);margin-left:12px}.cursor-info{position:absolute;bottom:12px;right:12px;padding:6px 10px;background:#32323a;border:1px solid #27272a;color:#a1a1aa;font-size:11px;border-radius:8px;pointer-events:none;font-family:JetBrains Mono,monospace;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app{display:flex;flex-direction:column;width:100%;height:100%;background:#222228}.main-content{display:flex;flex:1;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;color:#f4f4f5;background:#1a1a1f;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;height:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 16px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn{background:#32323a;border:1px solid #27272a;color:#f4f4f5;border-radius:8px;font-weight:500;transition:all .2s ease}.btn:hover:not(:disabled){background:#3a3a44;border-color:#3f3f46;transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border:none;color:#fff;box-shadow:0 0 20px #6366f14d}.btn.btn-primary:hover:not(:disabled){box-shadow:0 0 30px #6366f180;transform:translateY(-1px)}.btn.btn-icon{padding:8px;min-width:36px;min-height:36px}.btn.btn-tool{display:flex;flex-direction:row;align-items:center;gap:6px;padding:8px 14px;font-size:13px;background:transparent;border:1px solid transparent}.btn.btn-tool:hover:not(:disabled):not(.active){background:#3a3a44;border-color:#27272a}.btn.btn-tool svg{flex-shrink:0}.btn.btn-tool .tool-label{line-height:1}.btn.active{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-color:transparent;color:#fff;box-shadow:0 0 20px #6366f14d}.input{padding:10px 14px;background:#2a2a32;border:1px solid #27272a;border-radius:8px;font-size:14px;color:#f4f4f5;outline:none;transition:all .2s ease}.input::placeholder{color:#71717a}.input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.slider{-webkit-appearance:none;width:100%;height:6px;background:#2a2a32;border-radius:3px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-radius:50%;cursor:pointer;box-shadow:0 0 20px #6366f14d;transition:transform .15s ease}.slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider::-moz-range-thumb{width:18px;height:18px;background:#6366f1;border-radius:50%;cursor:pointer;border:none}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 10px;background:#32323a;color:#f4f4f5;font-size:12px;white-space:nowrap;border-radius:6px;border:1px solid #27272a;opacity:0;pointer-events:none;transition:opacity .15s ease;box-shadow:0 4px 12px #00000080}.tooltip:hover:after{opacity:1}select{padding:10px 36px 10px 14px;background:#2a2a32 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23a1a1aa' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right 12px center;border:1px solid #27272a;border-radius:8px;font-size:14px;color:#f4f4f5;cursor:pointer;outline:none;-webkit-appearance:none;-moz-appearance:none;transition:all .2s ease}select:hover{border-color:#3f3f46}select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}select option{background:#2a2a32;color:#f4f4f5}.card{background:#222228;border:1px solid #27272a;border-radius:12px;padding:16px}.divider{width:1px;height:24px;background:#27272a;margin:0 8px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#222228}::-webkit-scrollbar-thumb{background:#3a3a44;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3f3f46}
