:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;width:100vw;height:100vh;overflow:hidden}#root{width:100%;height:100%}.grecaptcha-badge{visibility:hidden}:root{--accent-color: #669C32;--accent-color-dark: #3A682F;--header-background: #222;--sidebar-background: #444;--font-color-dark: #333;--mobile-header-height: 50px;--desktop-header-height: 60px;--mobile-left-toolbar-width: 50px;--dev-toolbar-height-minimal: 12px;--dev-toolbar-height-active: 30px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body,html,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow:hidden}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:#f0f2f5}.app-header{height:50px;background-color:var(--header-background);color:#fff;display:flex;gap:15px;align-items:center;justify-content:space-between;padding:0 10px;box-shadow:0 2px 4px #0000001a;z-index:1001;flex-shrink:0;box-sizing:border-box;width:100%}body.dev-environment .app-header{margin-top:var(--dev-toolbar-height-minimal)}body.dev-environment .app-container{height:calc(100vh - var(--dev-toolbar-height-minimal))}body.dev-mode-enabled .app-header{margin-top:var(--dev-toolbar-height-active)}body.dev-mode-enabled .app-container{height:calc(100vh - var(--dev-toolbar-height-active))}.current-site-container{display:flex;align-items:center;overflow:hidden;flex-shrink:1;cursor:pointer;padding:5px 10px;border-radius:4px;transition:background-color .2s ease-in-out}.current-site-container:hover{background-color:#ffffff1a}.current-site-name{font-size:1.5em;font-weight:700;color:#fff;margin-right:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.current-site-name.placeholder{font-style:italic;opacity:.7}.edit-site-icon{width:16px;height:16px;vertical-align:middle}.site-dropdown{position:absolute;top:60px;background-color:var(--sidebar-background);border:1px solid #555;border-radius:4px;z-index:1001;box-shadow:0 4px 8px #0003}.site-dropdown-item{padding:10px 15px;color:#fff;cursor:pointer;border-bottom:1px solid #444}.site-dropdown-item:last-child{border-bottom:none}.site-dropdown-item:hover,.site-dropdown-item.active{background-color:#555}.header-left{display:flex;align-items:center}.app-logo{height:35px;margin-right:10px}.app-header h1{margin:0;font-size:1.5em}.header-right{display:flex;align-items:center;flex-shrink:0}.user-profile-button{background:none;border:none;cursor:pointer;padding:0;border-radius:50%}.user-profile-button img{height:30px;width:30px;filter:brightness(0) invert(1);display:block}.user-profile-button:hover{background-color:#ffffff1a}.main-layout{display:flex;flex-grow:1;overflow:hidden}.left-toolbar{width:60px;background-color:var(--sidebar-background);color:#fff;padding:10px 0;display:flex;flex-direction:column;align-items:center;gap:15px;align-self:stretch;flex-shrink:0;box-shadow:2px 0 5px #0000001a}.toolbar-button{background:none;border:none;color:#fff;cursor:pointer;padding:10px;width:100%;text-align:center;font-size:1.8em}.toolbar-button:hover{background-color:var(--accent-color-dark)}.toolbar-section-button{background:none;border:none;color:#fff;cursor:pointer;padding:12px 10px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:background-color .2s ease}.toolbar-section-button img{width:28px;height:28px;filter:brightness(0) invert(1)}.toolbar-section-button span{font-size:.65em;display:block;margin-top:2px}.left-drawer{width:350px;background-color:#ecf0f1;border-right:1px solid #bdc3c7;flex-shrink:0;color:var(--font-color-dark);transition:width .3s ease,padding .3s ease,transform .3s ease;display:flex;flex-direction:column;overflow:hidden;height:100vh}.left-drawer.closed{width:0;padding-left:0;padding-right:0;overflow:hidden;border-right:none}.drawer-navigation{display:flex;.mobile-drawer .drawer-navigation{flex-direction:row;gap:8px;padding:10px 15px;border-bottom:1px solid #bdc3c7;flex-shrink:0;overflow-x:auto}}.mobile-drawer .drawer-nav-button{display:flex;align-items:center;gap:12px;padding:10px 15px;border:1px solid transparent;background-color:transparent;color:var(--font-color-dark);text-align:left;font-size:.95em;border-radius:4px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.drawer-nav-button:hover{background-color:#dde4e6}.drawer-nav-button.active{background-color:#d1d8da;border-color:#a2adb1;font-weight:600}.map-view-container{flex-grow:1;position:relative;height:100%}.drawer-section-content{overflow-y:auto;padding:0;flex-grow:1;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.drawer-controls .subsection{padding:15px;background-color:#f0f4f7;border-radius:4px;margin-bottom:15px;border:1px solid #dde2e6}.drawer-controls .subsection h3{margin-top:0;margin-bottom:12px;font-size:1.1em}.drawer-controls{display:flex;flex-direction:column;gap:2px}.drawer-controls div{display:flex;flex-direction:column;gap:6px}.drawer-controls label{font-weight:700;font-size:.9em;color:#34495e}.drawer-controls h2{color:var(--font-color-dark);margin-top:0}.drawer-controls h4{color:var(--font-color-dark)}.drawer-controls select,.drawer-controls input[type=file]{padding:10px;border:1px solid #bdc3c7;border-radius:4px;font-size:.95em;color:var(--font-color-dark);background-color:#fff}.drawer-controls input[type=checkbox]{margin-right:8px;vertical-align:middle}.drawer-controls div>label[for=styleToggle]{display:flex;align-items:center;font-weight:400}.drawer-controls input[type=text],.drawer-controls input[type=number],.drawer-controls select{background-color:#fff;color:var(--font-color-dark);border:1px solid #cccccc;padding:8px 10px;border-radius:4px;margin-top:4px;margin-bottom:12px;width:calc(100% - 22px);box-sizing:border-box;font-size:1em}.drawer-controls input[type=text]:focus,.drawer-controls input[type=number]:focus,.drawer-controls select:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 .2rem #007bff40}.button-primary{background-color:var(--accent-color);color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;font-size:1em}.button-primary:hover{background-color:var(--accent-color-dark)}.drawer-controls button:not(.button-primary){background-color:#6c757d;color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;font-size:1em}.drawer-controls button:not(.button-primary):hover{background-color:#545b62}.app-header.mobile-header{position:fixed;top:0;left:0;width:100%;z-index:1000;height:var(--mobile-header-height);padding:0 10px;display:flex;align-items:center;justify-content:space-between}.app-header.mobile-header .header-left{display:flex;align-items:center;flex-grow:1;min-width:0;overflow:hidden;gap:0px}.app-header.mobile-header .current-site-name{font-size:1.1em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100vw - 150px)}.app-header.mobile-header .app-logo.mobile-logo{height:30px;flex-shrink:0}.app-header.mobile-header .current-site-container{display:flex;align-items:center;overflow:hidden;flex-shrink:1;min-width:0}.app-header.mobile-header .edit-site-icon{width:14px;height:14px;top:var(--mobile-header-height)}.mobile-left-toolbar{position:fixed;left:0;top:0;bottom:0;width:var(--mobile-left-toolbar-width);background-color:#2c2c2c;padding-top:var(--mobile-header-height);display:flex;flex-direction:column;align-items:center;padding:10px 0;padding-top:calc(var(--mobile-header-height) + 10px);gap:10px;z-index:999;box-shadow:2px 0 5px #0003}.mobile-left-toolbar .toolbar-section-button{width:calc(var(--mobile-left-toolbar-width) - 16px);height:auto;padding:8px 0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:background-color .2s ease-in-out}.mobile-left-toolbar .toolbar-section-button img{width:24px;height:24px;filter:brightness(0) invert(1)}.left-toolbar .toolbar-section-button:hover,.mobile-left-toolbar .toolbar-section-button:hover{background-color:var(--accent-color-dark)}.left-toolbar .toolbar-section-button.active,.mobile-left-toolbar .toolbar-section-button.active{background-color:var(--accent-color);border-color:var(--accent-color-dark)}.site-dropdown.mobile-site-dropdown{min-width:280px;left:50%;transform:translate(-50%);top:calc(100% + 5px);max-height:60vh;overflow-y:auto}.mobile-controls-fab{position:fixed;bottom:20px;right:20px;z-index:1002}.mobile-drawer{position:fixed;left:0;top:var(--mobile-header-height);bottom:0;width:80%;max-width:350px;background-color:#ecf0f1;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1010;padding:0;overflow:hidden;box-shadow:2px 0 15px #00000080;color:var(--font-color-dark);display:flex;flex-direction:column}.mobile-drawer.open{transform:translate(0)}.mobile-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #dddddd;flex-shrink:0}.mobile-drawer-title{font-size:1.2em;font-weight:700;color:#333;margin:0;padding:0;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-drawer-backdrop{position:fixed;inset:0;background-color:#00000080;z-index:1009}.mobile-drawer>div:first-child{padding:0 10px}.mobile-drawer-close-btn{background:#ffffff1a;border:none;font-size:2.5em;font-weight:700;cursor:pointer;padding:8px;color:#555;line-height:1;transition:color .2s ease-in-out,background-color .2s ease-in-out;position:absolute;top:10px;right:10px;width:48px;height:48px;display:flex;justify-content:center;align-items:center;border-radius:50%}.mobile-drawer-close-btn:hover{color:#fff;background-color:#fff3}.map-tools-container{position:absolute;top:50%;right:0;transform:translateY(-50%);z-index:999;background-color:#282828d9;padding:8px;border-radius:8px 0 0 8px;box-shadow:-2px 0 5px #0000004d;display:flex;flex-direction:column;gap:8px}.map-draw-polygon-button{background:transparent;border:1px solid rgba(255,255,255,.3);padding:8px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;width:48px;height:48px;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.map-draw-polygon-button:hover{background:var(--accent-color-dark);border-color:var(--accent-color-dark)}.map-draw-polygon-button.drawing{background:var(--accent-color-dark);border:2px solid var(--accent-color)}.map-draw-polygon-button img{width:24px;height:24px;filter:brightness(0) invert(1)}@media(max-width:768px){.map-draw-polygon-button{width:40px;height:40px;padding:6px}.map-draw-polygon-button img{width:20px;height:20px}.point-batch-tile,.polygon-list .point-batch-tile{padding:6px 8px;margin:0;border-radius:4px;box-sizing:border-box}.batch-main-content{margin-right:4px;flex:1;min-width:0}.batch-meta-and-actions{min-width:45px;flex-shrink:0}.batch-actions-row{gap:4px;align-items:center}.batch-action-btn{width:26px;height:26px;padding:3px;flex-shrink:0}.batch-action-btn img{width:14px;height:14px}.batch-point-count{font-size:.8em;flex-shrink:0}.batch-utility-type{flex:1;min-width:0}.batch-utility-type span{font-size:.8em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.batch-subtype-notes{font-size:.75em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-import-date{font-size:.7em;text-align:right}.drawer-section-content{padding:0;box-sizing:border-box;overflow-x:hidden}.point-inventory-container,.polygon-inventory-container{padding:0;width:100%;box-sizing:border-box;overflow-x:hidden}.point-batch-list,.polygon-list{gap:3px;overflow-x:hidden}.point-inventory-filters,.polygon-inventory-filters{margin-bottom:8px;padding:6px;box-sizing:border-box}.batch-header{align-items:center;gap:6px;min-width:0}}.dialog-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1050}.dialog-content{background-color:#f0f2f5;padding:20px;border-radius:8px;box-shadow:0 5px 15px #0000004d;width:90%;max-width:500px;position:relative;color:#333}.dialog-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #dddddd;padding-bottom:10px;margin-bottom:15px}.dialog-header h2{margin:0;font-size:1.5em;color:#333}.dialog-close-btn{background:none;border:none;font-size:2em;font-weight:700;cursor:pointer;padding:0;color:#555;line-height:1}.dialog-close-btn:hover{color:#000}.dialog-body input[type=text],.dialog-body input[type=number],.dialog-body input[type=file],.dialog-body select{background-color:#fff;color:#333;border:1px solid #cccccc}.dialog-body label{color:#444}.point-inventory-container{padding:0;height:100%;display:flex;flex-direction:column}.point-inventory-filters{margin-bottom:15px;padding:5px;border:1px dashed #ccc}.point-inventory-filters p{margin:0;color:#777;text-align:center}.point-batch-list{padding:0;margin:0;display:flex;flex-direction:column;gap:5px;flex:1;min-height:0}.point-batch-tile{display:flex;justify-content:space-between;align-items:flex-start;background-color:#fff;border:1px solid #e0e0e0;border-left:8px solid transparent;border-radius:6px;padding:10px 12px;font-size:.9em;box-shadow:0 2px 4px #0000000f;transition:background-color .3s ease,opacity .3s ease,border-color .3s ease,box-shadow .3s ease,border-left-color .2s ease}.point-batch-tile.batch-hidden{background-color:#f5f5f5;opacity:.7}.batch-main-content{flex-grow:1;display:flex;flex-direction:column;margin-right:8px;min-width:0}.batch-header{display:flex;align-items:center;margin-bottom:4px}.batch-point-count{font-size:1.3em;font-weight:700;color:#4a90e2;margin-right:8px;line-height:1;flex-shrink:0}.batch-utility-type{font-weight:700;font-size:1.05em;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batch-subtype-notes{font-size:.9em;color:#666;font-style:italic;padding-left:2px;word-break:break-word;line-height:1.3}.batch-meta-and-actions{display:flex;flex-direction:column;align-items:flex-end;min-width:60px;flex-shrink:0}.batch-import-date{font-size:.85em;color:#777;margin-bottom:5px;white-space:nowrap}.batch-actions-row{display:flex;align-items:center}.batch-action-btn{background:none;border:none;padding:5px;cursor:pointer;line-height:0;margin-left:4px}.batch-action-btn:first-child{margin-left:0}.batch-action-btn img{width:24px;height:24px;display:block;opacity:.75;transition:opacity .2s ease-in-out}.batch-action-btn:hover img{opacity:1}.batch-options-menu-container{position:relative;display:inline-block}.batch-options-popup{position:absolute;right:0;top:100%;margin-top:2px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 10px #00000026;z-index:100;min-width:120px;padding:5px 0}.batch-options-popup button{display:block;width:100%;padding:8px 12px;text-align:left;background:none;border:none;cursor:pointer;font-size:.9em;color:#333;white-space:nowrap}.batch-options-popup button:hover{background-color:#f5f5f5}.point-batch-tile:not(.batch-hidden):hover{border-color:#b0b0b0;box-shadow:0 3px 7px #0000001a}.polygon-inventory-container{padding:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.polygon-list{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0}.polygon-tile{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 1px 3px #0000000d;transition:background-color .2s ease-in-out}.polygon-tile:hover{background-color:#f0f0f0}.polygon-hidden{opacity:.6;background-color:#e9e9e9}.polygon-hidden .polygon-name{text-decoration:line-through}.polygon-main-content{display:flex;flex-direction:column;gap:5px}.polygon-header{display:flex;justify-content:space-between;align-items:center;font-weight:700}.polygon-name{font-size:1.1em;color:#333}.polygon-vertex-count{font-size:.9em;color:#555;background-color:#e7e7e7;padding:2px 6px;border-radius:4px}.polygon-notes{font-size:.85em;color:#666;font-style:italic}.polygon-meta-and-actions{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px;border-top:1px solid #eee}.polygon-creation-date{font-size:.8em;color:#777}.polygon-actions-row{display:flex;gap:8px;align-items:center}.polygon-action-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.polygon-action-btn img{width:20px;height:20px}.polygon-action-btn:hover{background-color:#e0e0e0}.polygon-options-menu-container{position:relative}.polygon-options-popup{position:absolute;right:0;top:calc(100% + 5px);background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 10px #0000001a;z-index:100;padding:5px 0;min-width:120px}.polygon-options-popup button{display:block;width:100%;padding:8px 12px;text-align:left;background:none;border:none;cursor:pointer;font-size:.9em;color:#333}.polygon-options-popup button:hover{background-color:#f0f0f0}.point-inventory-container,.polygon-inventory-container,.site-config-container{padding:0!important;margin:0;display:flex;flex-direction:column;height:100%;box-sizing:border-box}.drawer-title-bar{background-color:#e0e0e0;border-bottom:1px solid #ccc;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;width:100%;margin:0;box-sizing:border-box;box-shadow:0 2px 4px #0000001a;flex-shrink:0;border-radius:0;order:-1;min-height:45px;position:relative}.drawer-title-handle{position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background-color:#999;border-radius:2px;cursor:grab;z-index:1}.drawer-title-bar:has(.drawer-title-handle){padding-top:16px}.drawer-title-handle{z-index:1}.drawer-title-text{font-size:1.1em;font-weight:600;color:#333;margin:0;flex:1;line-height:1.2;display:flex;align-items:center}.drawer-title-actions{display:flex;gap:8px;align-items:center}.drawer-title-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:4px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0}.drawer-title-btn:hover{background-color:#0000001a}.drawer-title-btn img{width:18px;height:18px;filter:brightness(.4)}.drawer-title-btn:hover img{filter:brightness(.2)}@media(max-width:768px){.left-drawer{overflow:hidden!important;height:100vh!important}.site-config-container{height:100%!important;overflow:hidden!important}.site-config-container>:not(.drawer-title-bar){overflow:hidden!important}.drawer-title-bar{padding:10px 16px;border-top-left-radius:12px;border-top-right-radius:12px;margin:0;width:100%;min-height:42px}.drawer-title-bar:has(.drawer-title-handle){padding-top:14px}.drawer-title-text{font-size:1em}.drawer-title-btn{width:32px;height:32px;padding:6px}.drawer-title-btn img{width:18px;height:18px}.drawer-title-actions{gap:6px}}.inventory-content{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column}.site-config-container .drawer-controls{padding:0}.site-config-container .scrollable-form-content{padding:16px}.point-inventory-container>:not(.drawer-title-bar),.polygon-inventory-container>:not(.drawer-title-bar){flex:1;overflow-y:auto}.site-config-container>:not(.drawer-title-bar){flex:1;overflow:hidden}@media(max-width:768px){.inventory-content{padding:8px 12px}}: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}.ol-overviewmap .ol-viewport:hover{cursor:pointer}.drawer-controls{display:flex;flex-direction:column;flex:1;overflow:hidden}.scrollable-form{display:flex;flex-direction:column;height:100%;overflow:hidden}.scrollable-form-content{flex:1;overflow-y:auto}.drawer-title{font-size:1.4em;color:var(--text-color-dark);margin-bottom:15px;text-align:center}.form-group{display:flex;flex-direction:column;gap:3px}.form-label{font-size:.85em;color:var(--text-color-light);font-weight:500}.form-input,.form-select{padding:7px 9px;border:1px solid var(--border-color);border-radius:4px;font-size:.95em;color:var(--text-color-dark);background-color:var(--background-color-light);transition:border-color .2s ease-in-out}.form-input:focus,.form-select:focus{border-color:var(--accent-color);outline:none}.form-select{appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23000000%22%20d%3D%22M287%2C197.3L159.3%2C69.7c-3.2-3.2-8.4-3.2-11.6%2C0L5.4%2C197.3c-3.2%2C3.2-3.2%2C8.4%2C0%2C11.6l11.6%2C11.6c3.2%2C3.2%2C8.4%2C3.2%2C11.6%2C0l124.4-124.3l124.4%2C124.3c3.2%2C3.2%2C8.4%2C3.2%2C11.6%2C0l11.6-11.6C290.2%2C205.7%2C290.2%2C200.5%2C287%2C197.3z%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right 8px top 50%;background-size:12px auto;padding-right:30px}.section-title{font-size:1.05em;color:var(--text-color-dark);margin-top:15px;margin-bottom:8px;border-bottom:1px solid var(--border-color);padding-bottom:4px}.form-section{display:flex;flex-direction:column;gap:8px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:.9em;color:var(--text-color-dark);cursor:pointer}.form-checkbox{width:15px;height:15px;accent-color:var(--accent-color)}.info-box{background-color:var(--background-color-light);border:1px solid var(--border-color);border-radius:4px;padding:8px;display:flex;flex-direction:column;gap:3px}.info-text{font-size:.8em;color:var(--text-color-light);margin:0}.info-text.bold{font-weight:600;color:var(--text-color-dark)}.info-text.italic{font-style:italic}.status-text{font-weight:600;color:var(--accent-color)}.debug-button-container{margin-top:8px}.debug-button{padding:5px 10px;font-size:.75em;background-color:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s ease-in-out}.debug-button:hover{background-color:var(--accent-color-dark)}.form-divider{border:none;border-top:1px solid var(--border-color);margin:15px 0}.form-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px;background-color:#fff;border-top:1px solid var(--border-color);flex-shrink:0}.button-primary{background-color:var(--primary-button-background);color:var(--primary-button-text);padding:9px 14px;border:none;border-radius:4px;cursor:pointer;font-size:.95em;font-weight:600;transition:background-color .2s ease-in-out}.button-primary:hover{background-color:var(--primary-button-background-hover)}button[type=button]{background-color:var(--secondary-button-background);color:var(--secondary-button-text);padding:9px 14px;border:1px solid var(--secondary-button-border);border-radius:4px;cursor:pointer;font-size:.95em;font-weight:500;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}button[type=button]:hover{background-color:var(--secondary-button-background-hover);border-color:var(--secondary-button-border-hover)}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#4caf50}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 1px #4caf50}:root{--text-color-dark: #333;--text-color-light: #666;--border-color: #ddd;--background-color-light: #f9f9f9;--accent-color: #4CAF50;--accent-color-dark: #45a049;--primary-button-background: #4CAF50;--primary-button-text: white;--primary-button-background-hover: #45a049;--secondary-button-background: #f0f0f0;--secondary-button-text: #333;--secondary-button-border: #ccc;--secondary-button-background-hover: #e0e0e0;--secondary-button-border-hover: #bbb}@media(max-width:768px){.drawer-controls{gap:0;padding:0!important}.scrollable-form-content{overflow-y:auto!important;-webkit-overflow-scrolling:touch}.drawer-title{font-size:1.2em;margin-bottom:12px}.section-title{font-size:1em;margin-top:12px;margin-bottom:6px}.form-group{gap:2px}.form-label{font-size:.8em}.form-input,.form-select{padding:6px 8px;font-size:.9em}.checkbox-label{gap:4px;font-size:.85em}.info-box{padding:6px;gap:2px}.info-text{font-size:.75em}.form-actions{gap:6px;margin-top:12px}.button-primary,button[type=button]{padding:8px 12px;font-size:.9em}.form-section{gap:6px}input[style*=monospace]{font-size:11px!important;word-break:break-all}}
