@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700;9..40,800&display=swap";:root{--c-bg: #F5F5F7;--c-surface: #ffffff;--c-surface2: rgba(0,0,0,.04);--c-surface3: rgba(0,0,0,.07);--c-border: rgba(0,0,0,.07);--c-border2: rgba(0,0,0,.12);--c-border3: rgba(0,0,0,.18);--c-text: #0F0F1A;--c-text2: #374151;--c-text3: #6B7280;--c-blue: #7C3AED;--c-blue-dim: rgba(124,58,237,.08);--c-blue-glow: rgba(124,58,237,.3);--c-green: #16A34A;--c-green-dim: rgba(22,163,74,.1);--c-orange: #D97706;--c-orange-dim: rgba(217,119,6,.1);--c-red: #DC2626;--c-red-dim: rgba(220,38,38,.1);--c-purple: #7C3AED;--c-purple-dim: rgba(124,58,237,.08);--c-yellow: #CA8A04;--c-teal: #0D9488;--r-sm: 10px;--r-md: 14px;--r-lg: 16px;--r-xl: 20px;--font: "DM Sans", sans-serif;--font-mono: "SF Mono","Fira Code",monospace}*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}body{background:var(--c-bg);color:var(--c-text);font-family:var(--font);font-size:13px;height:100vh;display:flex;flex-direction:column;overflow:hidden;line-height:1.75}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}::-webkit-scrollbar-track{background:transparent}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.acc-body{animation:fadeSlideUp .28s cubic-bezier(.4,0,.2,1)}.modal{animation:fadeSlideUp .32s cubic-bezier(.4,0,.2,1)}#topbar{transition:box-shadow .2s ease}.tb{transition:background .15s ease,color .15s ease}.lbtn,.exp-btn{transition:all .18s ease}.tb-action-primary{transition:all .2s cubic-bezier(.4,0,.2,1)}.tb-action-primary:hover{transform:translateY(-1px)}#topbar{display:flex;flex-direction:column;background:#f5f5f7eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,.07);position:sticky;top:0;flex-shrink:0;z-index:10}#topbar-row1{display:flex;align-items:center;gap:6px;height:46px;padding:0 12px;border-bottom:1px solid rgba(0,0,0,.04)}#topbar-row2{display:flex;align-items:center;gap:6px;height:52px;padding:0 12px}#topbar-logo{display:flex;align-items:center;gap:9px;flex-shrink:0;margin-right:4px}.topbar-tools{display:flex;align-items:center;gap:2px;flex-shrink:0}.topbar-exports{display:flex;align-items:center;gap:6px;flex-shrink:0}.logo-name{font-size:16px;font-weight:400;color:#0f0f1a;letter-spacing:-.04em;white-space:nowrap}.logo-name span{color:#7c3aed;font-weight:700}.tag-pill{font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px;letter-spacing:.04em;background:#7c3aed14;color:#7c3aed;border:1px solid rgba(124,58,237,.2)}.vdiv{width:1px;height:24px;background:#00000012;flex-shrink:0;margin:0 4px}.tb-group{display:flex;gap:1px;background:#0000000a;border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:3px;flex-shrink:0;margin:0 1px}.tb{padding:5px 7px 4px;font-size:0;border-radius:7px;border:none;background:transparent;color:#374151;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;line-height:1;flex-shrink:0}.tb:hover{background:#0000000e;color:#0f0f1a}.tb.act{background:#0f0f1a;color:#fff;font-weight:600}.tb.act-blue{background:#7c3aed;color:#fff;border:none}.tb.act-green{background:#16a34a26;color:#16a34a;border:1px solid rgba(22,163,74,.35)}.tb.act-orange{background:#d9770626;color:#d97706;border:1px solid rgba(217,119,6,.35)}.tb.act-red{background:#dc26261f;color:#dc2626;border:1px solid rgba(220,38,38,.3)}.tb.act-purple{background:#7c3aed1f;color:#7c3aed;border:1px solid rgba(124,58,237,.3)}.tb.act-yellow{background:#ca8a041f;color:#ca8a04;border:1px solid rgba(202,138,4,.3)}.tb svg{width:15px;height:15px;flex-shrink:0;opacity:.8}.tb-label{font-size:9px;font-weight:500;letter-spacing:.01em;white-space:nowrap;opacity:.7;font-family:var(--font)}.tb-action{padding:5px 10px;font-size:11px;font-weight:600;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;gap:5px;white-space:nowrap;flex-shrink:0;letter-spacing:-.1px}.tb-action-primary{background:#7c3aed;color:#fff;box-shadow:0 4px 20px #7c3aed4d}.tb-action-primary:hover{box-shadow:0 6px 24px #7c3aed66}.tb-action-ghost{background:#0000000a;border:1px solid rgba(0,0,0,.09);color:#374151}.tb-action-ghost:hover{background:#00000014;color:#0f0f1a}.status-pill{font-size:11px;color:#7c3aed;padding:4px 11px;background:#7c3aed12;border:1px solid rgba(124,58,237,.18);border-radius:20px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.exp-btn{padding:5px 10px;font-size:11px;font-weight:500;border-radius:10px;border:1px solid rgba(0,0,0,.09);background:#0000000a;color:#374151;cursor:pointer;flex-shrink:0}.exp-btn:hover{background:#00000014;color:#0f0f1a;border-color:#00000021}#main{display:flex;flex:1;overflow:hidden}#left{width:248px;flex-shrink:0;background:#fff;border-right:1px solid rgba(0,0,0,.07);box-shadow:2px 0 12px #0000000a;display:flex;flex-direction:column;overflow:hidden}.lscroll{overflow-y:auto;flex:1}.lscroll::-webkit-scrollbar{width:5px}.lscroll::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}.acc-group{border-bottom:1px solid rgba(0,0,0,.06)}.acc-hdr{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:none;border:none;cursor:pointer;transition:background .12s;text-align:left}.acc-hdr:hover{background:#00000009}.acc-ico{font-size:13px;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#7c3aed14;border-radius:8px}.acc-title{font-size:12px;font-weight:600;color:#0f0f1a;flex:1;letter-spacing:-.1px}.acc-arrow{font-size:10px;color:var(--c-text3);transition:transform .15s;flex-shrink:0}.acc-body{padding:4px 12px 12px}.lfield{margin-bottom:7px}.lfield label{display:block;font-size:10.5px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.09em;margin-bottom:3px}.lfield input,.lfield select{width:100%;padding:6px 8px;font-size:12px;background:#0000000a;border:1px solid rgba(0,0,0,.09);color:#0f0f1a;border-radius:10px;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;font-family:var(--font)}.lfield input:focus,.lfield select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.lfield select option{background:#fff;color:#0f0f1a}.lrow{display:flex;gap:6px;margin-bottom:0}.lrow>.lfield{flex:1;margin-bottom:7px}.lhint{font-size:10px;color:#6b7280;line-height:1.4;margin-top:2px}.lsep{height:1px;background:#0000000f;margin:8px 0}.lcap{font-size:10.5px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.09em;margin-bottom:5px}.lbtn{display:flex;align-items:center;gap:7px;width:100%;padding:7px 10px;font-size:12px;font-weight:500;background:#0000000a;border:1px solid rgba(0,0,0,.08);color:#374151;border-radius:10px;cursor:pointer;margin-bottom:4px;text-align:left;font-family:var(--font)}.lbtn:hover{background:#00000012;color:#0f0f1a;border-color:#0000001f}.lbtn-ico{font-size:13px;flex-shrink:0}.lbtn-primary{background:#7c3aed;border-color:#7c3aed;color:#fff;box-shadow:0 4px 20px #7c3aed4d}.lbtn-primary:hover{box-shadow:0 6px 24px #7c3aed66;color:#fff;border-color:#7c3aed;background:#7c3aed}.lbtn-success{background:#16a34a14;border-color:#16a34a33;color:#16a34a}.lbtn-success:hover{background:#16a34a26;color:#16a34a}.zone-item{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-radius:var(--r-sm);background:var(--c-surface2);border:1px solid var(--c-border);margin-bottom:4px}.zone-item-active{background:var(--c-blue-dim);border-color:#7c3aed4d}.zone-item-name{font-size:11px;font-weight:600;color:var(--c-text2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zone-item-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.zone-item-lbl{font-size:10px;color:var(--c-text3)}.zone-item-input{width:48px;padding:2px 5px;font-size:11px;border:1px solid var(--c-border2);border-radius:5px;background:var(--c-surface);color:var(--c-text);font-family:var(--font)}.zone-item-del{background:none;border:none;color:var(--c-text3);cursor:pointer;font-size:10px;padding:2px 5px;border-radius:4px;line-height:1}.zone-item-del:hover{background:var(--c-red-dim);color:var(--c-red)}.scale-badge{width:100%;padding:6px 9px;border-radius:10px;background:#7c3aed12;border:1px solid rgba(124,58,237,.18);color:#7c3aed;font-size:11px;font-weight:500;font-family:var(--font-mono)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.toggle-row label{font-size:12px;color:#374151;font-weight:500}.toggle{position:relative;width:36px;height:20px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--c-surface3);border-radius:20px;border:1px solid var(--c-border2);transition:.2s;cursor:pointer}.toggle input:checked+.toggle-track{background:#7c3aed;border-color:#7c3aed}.toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:.2s;pointer-events:none}.toggle input:checked~.toggle-thumb{left:18px}.psec{padding:14px 14px 10px;border-bottom:1px solid var(--c-border)}.psec-h{font-size:10.5px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.09em;margin-bottom:10px}.f{margin-bottom:8px}.f label{display:block;font-size:11px;color:#374151;margin-bottom:4px;font-weight:500}.f input,.f select{width:100%;padding:6px 9px;font-size:12px;background:#0000000a;border:1px solid rgba(0,0,0,.09);color:#0f0f1a;border-radius:10px;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;font-family:var(--font)}.f input:focus,.f select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.f select option{background:#fff;color:#0f0f1a}.f .row{display:flex;gap:6px}.f .row>div{flex:1}.f .hint{font-size:10px;color:#6b7280;margin-top:3px;line-height:1.4}#canvas-area{flex:1;position:relative;overflow:hidden;background:#050508}canvas{display:block;cursor:crosshair}#legend{position:absolute;top:12px;left:12px;display:flex;flex-direction:row;align-items:center;gap:10px;flex-wrap:wrap;pointer-events:none;background:#ffffffeb;padding:5px 10px;border-radius:20px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 8px #00000012}.li{display:flex;align-items:center;gap:5px;font-size:9px;font-weight:500;color:#374151;white-space:nowrap}.ld{width:14px;height:2px;border-radius:1px;flex-shrink:0}#zinfo{position:absolute;bottom:12px;right:12px;font-size:10px;color:#374151;background:#ffffffe6;padding:4px 10px;border-radius:20px;border:1px solid rgba(0,0,0,.09);box-shadow:0 2px 8px #0000000f}#coord-hud{position:absolute;bottom:12px;left:50%;transform:translate(-50%);font-size:11px;color:#374151;background:#ffffffe6;padding:3px 12px;border-radius:20px;border:1px solid rgba(0,0,0,.09);font-family:var(--font-mono);pointer-events:none;box-shadow:0 2px 8px #0000000f}#table-preview{position:absolute;top:12px;right:12px;background:#fffffff2;border:1px solid rgba(0,0,0,.09);border-radius:12px;padding:10px;box-shadow:0 2px 12px #00000014}#ruler-label{color:#fff9}.resize-handle-left{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:10;background:transparent;transition:background .15s}.resize-handle-left:hover,.resize-handle-left:active{background:#7c3aed40}#right{width:100%;flex-shrink:0;background:#fff;border-left:1px solid rgba(0,0,0,.07);box-shadow:-2px 0 12px #0000000a;display:flex;flex-direction:column;overflow:hidden}.tabs{display:flex;border-bottom:1px solid var(--c-border);padding:0;gap:0}.tab{flex:1;text-align:center;padding:10px 4px;font-size:9.5px;font-weight:600;cursor:pointer;color:#6b7280;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;text-transform:uppercase;letter-spacing:.07em;overflow:hidden;text-overflow:ellipsis}.tab:hover{color:#374151}.tab.act{color:#7c3aed;border-bottom-color:#7c3aed}.tc{display:none;overflow-y:auto;flex:1;padding:10px}.tc::-webkit-scrollbar{width:5px}.tc::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}.tc.act{display:block}.mg{display:grid;grid-template-columns:1fr 1fr;gap:6px}.mc{background:#00000008;border-radius:12px;padding:10px 11px;border:1px solid rgba(0,0,0,.07);transition:border-color .15s}.mc:hover{border-color:#0000001f}.mc .v{font-size:20px;font-weight:700;letter-spacing:-.5px;color:#0f0f1a}.mc .v.b{color:#7c3aed}.mc .v.g{color:var(--c-green)}.mc .v.y{color:var(--c-yellow)}.mc .v.r{color:var(--c-red)}.mc .v.o{color:var(--c-orange)}.mc .v.t{color:var(--c-teal)}.mc .l{font-size:10px;color:#6b7280;margin-top:2px;font-weight:500}.mc.fw{grid-column:1/-1}.ei{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;margin-bottom:4px;background:#fff;border:1px solid rgba(0,0,0,.07);cursor:pointer;transition:all .15s}.ei:hover{border-color:#0000001f;background:#00000009}.ei.sel{border-color:#7c3aed40;background:#7c3aed0f}.ei-ico{width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.ei-ico.inv{background:#7c3aed14;border:1px solid rgba(124,58,237,.2)}.ei-ico.sub{background:var(--c-orange-dim);border:1px solid rgba(217,119,6,.25)}.ei-ico.tr{background:var(--c-purple-dim);border:1px solid rgba(124,58,237,.2)}.ei-ico.dc{background:var(--c-blue-dim);border:1px solid rgba(124,58,237,.2)}.ei-info{flex:1;min-width:0}.ei-name{font-weight:600;font-size:12px;color:#0f0f1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ei-det{font-size:10px;color:#6b7280;margin-top:1px}.ei-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:20px;flex-shrink:0}.ei-badge.g{background:var(--c-green-dim);color:var(--c-green)}.ei-badge.o{background:var(--c-orange-dim);color:var(--c-orange)}.ei-badge.b{background:var(--c-blue-dim);color:#7c3aed}.ei-badge.p{background:var(--c-purple-dim);color:var(--c-purple)}.ei-badge.r{background:var(--c-red-dim);color:var(--c-red)}.ei-del{width:22px;height:22px;border-radius:var(--r-sm);background:none;border:none;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;transition:all .15s}.ei-del:hover{background:var(--c-red-dim);color:var(--c-red)}.stbl{width:100%;border-collapse:collapse;font-size:11px}.stbl th{padding:5px 6px;text-align:left;color:#6b7280;font-weight:600;border-bottom:1px solid var(--c-border);font-size:10px;background:#0000000a}.stbl td{padding:4px 6px;border-bottom:1px solid var(--c-border);color:#374151}.stbl tr:hover td{background:var(--c-surface2)}.stbl select{font-size:10px;background:#0000000a;color:#0f0f1a;border:1px solid rgba(0,0,0,.09);border-radius:6px;padding:2px 4px;width:100%;font-family:var(--font)}.str-row:hover{background:var(--c-blue-dim)!important}.str-row:hover td{background:transparent!important}.str-row[draggable=true]:active{opacity:.7}.ei[draggable=true]:active{opacity:.75;transform:scale(.98)}#bottombar{display:flex;align-items:center;gap:12px;padding:5px 16px;height:34px;background:#f5f5f7f2;border-top:1px solid var(--c-border);flex-shrink:0;font-size:11px;color:#6b7280;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bbs{display:flex;align-items:center;gap:5px}.bbd{width:6px;height:6px;border-radius:50%;flex-shrink:0}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f1a73;z-index:200;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:20px;padding:28px;min-width:340px;max-width:500px;width:92%;box-shadow:0 24px 64px #00000024,0 8px 24px #00000014}.modal-hdr{display:flex;align-items:center;gap:10px;margin-bottom:16px}.modal-hdr-ico{width:32px;height:32px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.modal h2{font-size:15px;font-weight:700;color:#0f0f1a;letter-spacing:-.04em}.modal .f{margin-bottom:9px}.modal .f label{font-size:11px;font-weight:600;color:#374151;margin-bottom:4px;display:block}.modal .f input,.modal .f select{width:100%;padding:7px 10px;font-size:12px;background:#0000000a;border:1px solid rgba(0,0,0,.09);color:#0f0f1a;border-radius:10px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:var(--font)}.modal .f input:focus,.modal .f select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.modal .f .row{display:flex;gap:8px}.modal .f .row>div{flex:1}.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:14px;border-top:1px solid var(--c-border)}.modal-footer button{padding:7px 16px;border-radius:10px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--font)}.btn-cancel{background:#0000000d;border:1px solid rgba(0,0,0,.1);color:#374151}.btn-cancel:hover{background:#00000017;color:#0f0f1a}.btn-ok{background:#7c3aed;border:1px solid #7C3AED;color:#fff;box-shadow:0 4px 20px #7c3aed59}.btn-ok:hover{box-shadow:0 6px 24px #7c3aed73}.modal-note{font-size:11px;color:#6b7280;background:#0000000a;border:1px solid rgba(0,0,0,.07);border-radius:10px;padding:8px 10px;margin-top:6px;line-height:1.5}#drag-ghost{position:fixed;pointer-events:none;z-index:300;display:none;font-size:20px;transform:translate(-50%,-50%)}.sec-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sec-count{font-size:10px;font-weight:600;padding:2px 6px;border-radius:20px;background:#0000000f;color:#6b7280}#map-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:none;flex-direction:column;background:var(--c-bg)}#map-modal.open{display:flex}#map-address{flex:1;padding:7px 12px;font-size:13px;background:#0000000d;border:1px solid rgba(0,0,0,.12);border-radius:10px;color:#0f0f1a;outline:none;font-family:var(--font)}#map-address:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}#map-address::placeholder{color:#0f0f1a59}.map-btn{padding:7px 14px;font-size:12px;font-weight:600;border-radius:10px;border:none;cursor:pointer;transition:all .12s;font-family:var(--font)}.map-btn-primary{background:#7c3aed;color:#fff;box-shadow:0 4px 20px #7c3aed4d}.map-btn-primary:hover{box-shadow:0 6px 24px #7c3aed66}.map-btn-ghost{background:#0000000d;color:#374151;border:1px solid rgba(0,0,0,.1)}.map-btn-ghost:hover{background:#00000017;color:#0f0f1a}.map-btn-danger{background:#dc26261a;color:var(--c-red);border:1px solid rgba(220,38,38,.25)}.map-btn-danger:hover{background:#dc26262e}#map-container{flex:1;position:relative}#map-leaflet{width:100%;height:100%}#map-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:400}#map-crosshair:before,#map-crosshair:after{content:"";position:absolute;background:#dc2626e6}#map-crosshair:before{width:2px;height:32px;top:-16px;left:-1px}#map-crosshair:after{width:32px;height:2px;left:-16px;top:-1px}#map-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;border:2px solid rgba(220,38,38,.9);background:#dc26264d;pointer-events:none;z-index:401}#map-status{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#ffffffeb;border:1px solid rgba(0,0,0,.1);border-radius:20px;padding:6px 16px;font-size:11px;color:#374151;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;white-space:nowrap}#map-capture-btn{position:absolute;bottom:52px;right:16px;z-index:402}#map-zoom-info{position:absolute;top:12px;right:12px;background:#ffffffeb;border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:6px 10px;font-size:10px;color:#374151;font-family:var(--font-mono)}html,body{height:100%;width:100%;margin:0;padding:0;overflow:hidden;overscroll-behavior:none;-webkit-user-select:none;user-select:none;touch-action:pan-x pan-y}#mobile-toolbar{display:none;position:fixed;bottom:0;left:0;right:0;height:56px;z-index:200;background:#f5f5f7f5;border-top:1px solid rgba(0,0,0,.08);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:0 4px;align-items:center;justify-content:space-around;gap:0}.mob-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 10px;border:none;background:none;color:#6b7280;cursor:pointer;font-size:9px;font-weight:600;letter-spacing:.02em;border-radius:10px;transition:all .12s;text-transform:uppercase;flex:1;border-top:2px solid transparent}.mob-btn svg{width:20px;height:20px}.mob-btn.act{color:#7c3aed;border-top-color:#7c3aed}.mob-btn:active{background:#0000000d}.mob-tool{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px 8px;border:none;background:#0000000a;border-radius:10px;cursor:pointer;color:#374151;font-size:9px;font-weight:600;letter-spacing:.01em;transition:all .12s;border:1px solid transparent}.mob-tool svg{width:18px;height:18px;opacity:.8;flex-shrink:0}.mob-tool:active{background:#00000014}.mob-tool.act{background:#0f0f1a;color:#fff;border-color:transparent}.mob-tool.act-blue{background:#7c3aed;color:#fff;border-color:transparent}.mob-tool.act-green{background:#16a34a26;color:#16a34a;border-color:#16a34a59}.mob-tool.act-orange{background:#d9770626;color:#d97706;border-color:#d9770659}.mob-tool.act-red{background:#dc26261f;color:#dc2626;border-color:#dc26264d}.mob-tool.act-purple{background:#7c3aed1f;color:#7c3aed;border-color:#7c3aed4d}.mob-tool.act-yellow{background:#ca8a041f;color:#ca8a04;border-color:#ca8a044d}.mob-tool svg{opacity:.8}.mob-tool.act svg,.mob-tool.act-blue svg{opacity:1}#mobile-drawer{display:none;position:fixed;bottom:56px;left:0;right:0;max-height:55vh;background:#fff;border-top:1px solid rgba(0,0,0,.08);border-radius:20px 20px 0 0;z-index:199;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateY(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);box-shadow:0 -8px 32px #0000001a;padding-bottom:env(safe-area-inset-bottom)}#mobile-drawer.open{transform:translateY(0)}.drawer-handle{width:36px;height:4px;border-radius:2px;background:#00000026;margin:10px auto 12px}canvas{touch-action:none}@media (max-width:1279px){#left,#right,#topbar-row2{display:none!important}#topbar-row1{height:48px;padding:0 10px;gap:6px}#topbar-logo .logo-name{display:none}#topbar-logo{margin-right:0}#main{flex-direction:column}#canvas-area{flex:1;min-height:0;padding-bottom:56px}#mobile-toolbar{display:flex}#mobile-drawer{display:block}#coord-hud{font-size:9px;padding:2px 8px;bottom:64px}#zinfo{bottom:64px}#scale-ruler{bottom:68px}#legend{top:8px;left:8px;padding:4px 10px;gap:8px;border-radius:14px}.li{font-size:8px;gap:4px}.ld{width:10px}.modal{min-width:0;width:94%;border-radius:16px}.map-btn{font-size:11px;padding:6px 10px}}@media (max-height:500px) and (max-width:1279px){#topbar-row1{height:38px}#mobile-toolbar{height:46px}#mobile-drawer{max-height:70vh;bottom:46px}#canvas-area{padding-bottom:46px}#coord-hud{bottom:52px}}
