:root{--bg:#eef6f4;--surface:#fff;--surface-muted:#f6faf9;--line:#d8e5e1;--text:#18332f;--muted:#647873;--primary:#0f8f83;--primary-strong:#0b766c;--accent:#f97316;--danger:#c2410c;--warn:#a16207;--success:#047857;--shadow:0 18px 45px #18332f1f;color:var(--text);background:linear-gradient(90deg, #0f8f8314 1px, transparent 1px), linear-gradient(#0f8f8312 1px, transparent 1px), var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-size:36px 36px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}button:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #f973165c}#app{min-height:100svh}.workspace{grid-template-rows:auto 1fr;gap:0;height:100vh;padding:0;display:grid;overflow:hidden}.topbar{border:1px solid var(--line);width:min(1720px,100%);min-height:72px;box-shadow:var(--shadow);background:#ffffffdb;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;padding:12px 14px;display:flex}.brand{align-items:center;gap:12px;min-width:0;display:flex}.brand-mark{color:#fff;background:linear-gradient(135deg, var(--primary), #164e63);border-radius:8px;flex:none;place-items:center;width:48px;height:48px;font-size:13px;font-weight:800;display:grid}h1,h2,p{margin:0}h1{letter-spacing:0;font-size:20px;line-height:1.2}.brand p,.muted,.section-title span,.result-list span{color:var(--muted)}.brand p{margin-top:4px;font-size:13px}.file-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.button,.icon-button,.tool-button{border:1px solid var(--line);background:var(--surface);color:var(--text);transition:background-color .18s,border-color .18s,color .18s,transform .18s}.button{border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-weight:700;display:inline-flex}.button.primary{color:#fff;background:var(--primary);border-color:var(--primary)}.button.primary:hover:not(:disabled){background:var(--primary-strong)}.icon-button{border-radius:8px;place-items:center;width:42px;height:42px;display:inline-grid}.icon-button:hover:not(:disabled),.tool-button:hover:not(:disabled){border-color:#0f8f8373;transform:translateY(-1px)}.status-row{border:0;border-bottom:1px solid var(--line);background:#ffffffe6;border-radius:0;align-items:center;gap:10px;width:100%;min-height:44px;padding:10px 16px;font-size:14px;display:flex}.tone-info{color:var(--muted)}.tone-success{color:var(--success);border-color:#04785747}.tone-warn{color:var(--warn);border-color:#a162074d}.tone-error{color:var(--danger);border-color:#c2410c4d}.shell{grid-template-columns:80px minmax(0,1fr) 360px;gap:0;width:100%;height:100%;min-height:0;display:grid}.toolrail,.sidepanel,.viewer-zone{background:#ffffffe6}.toolrail{border:0;border-right:1px solid var(--line);border-radius:0;flex-direction:column;align-items:stretch;gap:8px;height:100%;min-height:0;padding:10px;display:flex}.tool-button{border-radius:8px;place-items:center;gap:4px;min-height:58px;font-size:12px;font-weight:700;display:grid}.tool-button.active{color:#fff;background:var(--primary);border-color:var(--primary)}.tool-separator{background:var(--line);height:1px;margin:4px 0}.rail-action{width:100%}.viewer-zone{background:radial-gradient(circle at 20% 15%,#f973161f,#0000 28%),linear-gradient(90deg,#0f8f8314 1px,#0000 1px) 0 0/28px 28px,linear-gradient(#0f8f8314 1px,#0000 1px) 0 0/28px 28px,#f8fbfa;border:0;border-radius:0;height:100%;position:relative;overflow:hidden}.viewer-zone.dragging{outline-offset:-6px;outline:3px solid #f9731673}.viewer-host{width:100%;height:100%;display:block;position:absolute;inset:0}.viewer-host canvas{inset:0;width:100%!important;height:100%!important}.measure-overlay{z-index:4;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.working-line,.result-line{fill:none;stroke-linecap:round;stroke-linejoin:round}.working-line{stroke:var(--accent);stroke-width:2.5px;stroke-dasharray:6 5}.result-line{stroke:#0f766e;stroke-width:2px}.working-area,.result-area{stroke-linejoin:round}.working-area{fill:#f9731624;stroke:var(--accent);stroke-width:2px;stroke-dasharray:6 5}.working-area.faint{opacity:.2}.result-area{fill:#0f8f8321;stroke:#0f766e;stroke-width:2px}.point-handle{fill:#fff;stroke:var(--accent);stroke-width:2px}.hover-handle{fill:#f9731629;stroke:var(--accent);stroke-width:2.5px}.base-station-range{fill:#3b82f61a;stroke:#3b82f666;stroke-width:1.5px;stroke-dasharray:4 4}.base-station-marker{fill:#3b82f6;stroke:#fff;stroke-width:2px}.beacon-marker{fill:#8b5cf6;stroke:#fff;stroke-width:2px}.measure-readout{z-index:5;pointer-events:none;color:#7c2d12;white-space:nowrap;background:#fff7edf0;border:1px solid #c2410c3d;border-radius:8px;max-width:220px;padding:7px 9px;font-size:13px;font-weight:800;position:absolute;transform:translate(12px,-38px);box-shadow:0 10px 24px #7c2d1224}.empty-state,.loading-mask{z-index:3;text-align:center;align-content:center;place-items:center;gap:14px;padding:24px;display:grid;position:absolute;inset:0}.empty-state h2{letter-spacing:0;font-size:24px}.empty-state p{max-width:520px;color:var(--muted)}.empty-blueprint{width:96px;height:96px;color:var(--primary);border:1px solid var(--line);background-color:#ffffffc7;background-image:linear-gradient(90deg,#0f8f832e 1px,#0000 1px),linear-gradient(#0f8f832e 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:12px 12px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border-radius:8px;place-items:center;display:grid}.loading-mask{color:var(--primary-strong);background:#f8fbfac2}.spinner{border:4px solid #0f8f8333;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.sidepanel{border:0;border-left:1px solid var(--line);border-radius:0;height:100%;min-height:0;padding:12px;overflow-y:auto}.panel-section{border-bottom:1px solid var(--line);padding:12px 0}.panel-section:first-child{padding-top:0}.panel-section:last-child{border-bottom:0}.section-title{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:10px;display:flex}.section-title h2{letter-spacing:0;font-size:15px}.section-title span{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;overflow:hidden}.meta-grid,.stats{grid-template-columns:1fr 1fr;gap:8px;display:grid}.meta-grid{margin:0}.meta-grid div,.stats div,.result-list li{border:1px solid var(--line);background:var(--surface-muted);border-radius:8px}.meta-grid div,.stats div{padding:10px}dt{color:var(--muted);font-size:12px}dd{margin:4px 0 0;font-weight:700}select{border:1px solid var(--line);background:var(--surface);width:100%;min-height:34px;color:var(--text);border-radius:6px}.stats span{color:var(--muted);font-size:12px;display:block}.stats strong{overflow-wrap:anywhere;margin-top:6px;font-size:14px;display:block}.layer-list,.result-list{gap:8px;display:grid}.layer-row{border:1px solid var(--line);background:var(--surface-muted);width:100%;min-height:42px;color:var(--text);text-align:left;border-radius:8px;grid-template-columns:18px 16px minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px;display:grid}.swatch{border:1px solid #0000001f;border-radius:3px;width:14px;height:14px}.layer-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.result-list{margin:0;padding:0;list-style:none}.result-list li{padding:10px}.result-list div{justify-content:space-between;align-items:center;gap:8px;display:flex}.result-list strong,.result-list p{overflow-wrap:anywhere}.result-list p{color:var(--primary-strong);margin-top:8px;font-weight:800}.muted{font-size:13px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (width<=1120px){.shell{grid-template-columns:76px minmax(0,1fr)}.sidepanel{grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 16px;display:grid}.viewer-zone{min-height:62svh}}@media (width<=720px){.workspace{padding:10px}.topbar{flex-direction:column;align-items:stretch}.file-actions{justify-content:stretch}.file-actions .button{flex:auto}.shell{grid-template-columns:1fr}.toolrail{flex-direction:row;min-height:74px;overflow-x:auto}.tool-button{min-width:76px}.tool-separator{width:1px;height:auto;margin:0 2px}.rail-action{flex:none;width:46px}.viewer-zone{min-height:58svh}.sidepanel,.meta-grid,.stats{grid-template-columns:1fr}.brand-mark{width:44px;height:44px}h1{font-size:18px}}.result-header{align-items:center;gap:8px;width:100%;display:flex}.result-index{color:var(--muted);background:var(--line);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:12px;font-weight:700}.result-name-input{min-width:0;color:var(--text);background:0 0;border:1px solid #0000;border-radius:4px;flex:1;padding:2px 4px;font-size:14px;font-weight:700;transition:all .18s}.result-name-input:hover{border-color:var(--line);background:#0f8f830d}.result-name-input:focus{background:var(--surface);border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #0f8f8326}.result-time{color:var(--muted);flex-shrink:0;font-size:11px}.result-details{border-top:1px dashed var(--line);width:100%;margin-top:6px;padding-top:6px}.result-detail-row{justify-content:space-between;align-items:center;width:100%;display:flex}.rect-details{flex-direction:column;gap:4px;display:flex}.rect-dims{grid-template-columns:1fr 1fr;gap:12px;width:100%;margin-top:2px;display:grid}.rect-dims>div{background:0 0;border:0;justify-content:space-between;align-items:center;padding:0;display:flex}.detail-label{color:var(--muted);font-size:11px}.detail-value{color:var(--primary-strong);font-size:13px;font-weight:800}.results-actions{align-items:center;gap:8px;display:flex}.mini-action-btn{width:28px;height:28px;color:var(--primary-strong);border-color:var(--line);border-radius:6px;place-items:center;padding:0;display:grid}.mini-action-btn:hover{border-color:var(--primary);background:#0f8f8314}.floor-row{justify-content:space-between;align-items:center;width:100%;margin-top:4px;display:flex}.floor-input{border:1px solid var(--line);text-align:right;width:60px;height:24px;color:var(--text);background:var(--surface);border-radius:4px;padding:0 4px;font-size:12px;font-weight:700}.floor-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #0f8f8326}
