:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}:root{--bg: #EEF2F1;--panel: #FFFFFF;--brand: #2F6A53;--text: #0F172A;--muted: #6B7280;--border: #E5E7EB;--primary: #2F6A53;--primary-600: #275c48;--shadow: 0 4px 12px rgba(2,8,23,.06);--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,Segoe UI,system-ui,Arial,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.app-bar{height:64px;display:flex;align-items:center;gap:16px;background:var(--brand);color:#fff;padding:0 24px;flex-shrink:0}.app-logo{height:50px;object-fit:contain}.app-title{flex:1;text-align:center;font-weight:700;font-size:22px;color:#fff}.app-bar-spacer{width:50px}.app-grid{display:flex;height:calc(100vh - 64px);gap:20px;padding:20px;overflow:hidden}.panel-sidebar{width:360px;min-width:360px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;padding-right:5px}.main-content{flex:1;display:flex;flex-direction:column;gap:20px;overflow-y:auto;min-width:0}.panel-map{flex:1;min-height:450px;position:relative}.panel-bottom-container{display:grid;grid-template-columns:1fr 1fr;gap:20px;flex-shrink:0}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel-section{padding:20px}.panel-section+.panel-section{border-top:1px solid var(--border)}.panel-content{padding:20px}.map-wrap{position:relative;overflow:hidden;height:100%;width:100%;border-radius:var(--radius)}#map{width:100%;height:100%}.map-overlay{position:absolute;top:14px;right:14px;z-index:1000;width:240px;background:#fffffff2;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);font-size:13px;padding:12px}.ov-group{margin-bottom:10px}.ov-title{font-size:11px;font-weight:700;color:var(--muted);margin:5px 0 8px;text-transform:uppercase}.ov-check,.ov-radio{display:flex;align-items:center;gap:8px;padding:6px 8px;margin-bottom:6px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}.ov-check:hover,.ov-radio:hover{background:#f9fafb}.section-title{font-size:18px;font-weight:700;margin:0 0 10px}.subtle{color:var(--muted);font-size:13px;margin-bottom:12px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.label{font-weight:600;font-size:13px}.input{height:38px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:#fff;outline:none;font-size:14px}.input[readonly]{background:#f9fafb;color:#374151}.row{display:flex;gap:8px;align-items:center}.row .input{flex:1}.btn{height:38px;padding:0 14px;border-radius:8px;border:0;cursor:pointer;background:var(--primary);color:#fff;font-weight:600;font-size:13px}.btn.secondary{background:var(--primary);color:#fff;width:100%}.helper{font-size:11px;color:var(--muted)}.leyenda-container{display:flex;flex-direction:column;gap:0}.leyenda-item{display:flex;align-items:flex-start;gap:6px;font-size:11px;line-height:1.3;margin-bottom:4px}.leyenda-item .color-box{width:10px;height:10px;border:1px solid rgba(0,0,0,.1);border-radius:2px;flex-shrink:0;margin-top:3px}.block-title{font-size:16px;font-weight:700;margin:0 0 10px}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:10px}.card{border:1px solid var(--border);border-radius:10px;padding:10px;background:#fff}.card-title{font-weight:600;margin-bottom:4px;font-size:12px;color:var(--text)}.muted{color:var(--muted);font-size:10px}.value{height:30px;border-radius:6px;display:flex;align-items:center;padding:0 8px;font-weight:700;font-size:14px;margin-top:6px}.desc-sub{font-size:13px;font-weight:700;margin:10px 0 4px}.desc-p{margin:0 0 8px;font-size:12px;color:var(--muted);line-height:1.4;text-align:justify}@media (max-width: 1024px){.app-grid{flex-direction:column;overflow-y:auto;height:auto}.panel-sidebar{width:100%;min-width:0;overflow:visible}.main-content{overflow:visible}.panel-map{height:50vh;min-height:350px}.panel-bottom-container{grid-template-columns:1fr}}
