body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center;height:100%;width:100%}.map-container{height:100vh;width:100%}.clicked-coord-label{position:absolute;right:0;bottom:0;background:#fff;border-radius:5px}.clicked-coord-label p{margin:10px}.search-box{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:1000;width:400px}.search-input-container{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:12px 16px;font-size:14px;border:2px solid #ddd;border-radius:25px;outline:none;background:#fff;box-shadow:0 2px 10px #0000001a;transition:all .2s ease}.search-input:focus{border-color:#007bff;box-shadow:0 2px 15px #007bff33}.search-loading{position:absolute;right:16px;display:flex;align-items:center}.spinner{width:16px;height:16px;border:2px solid #ddd;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 8px 8px;max-height:300px;overflow-y:auto;box-shadow:0 4px 15px #0000001a;z-index:1001}.suggestion-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .15s ease}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background-color:#f8f9fa}.suggestion-text{font-size:14px;color:#333;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-info-label{position:absolute;left:10px;bottom:10px;background:#ffffffe6;border-radius:5px;padding:8px 12px;font-size:12px;color:#333;box-shadow:0 2px 5px #0000001a;border:1px solid #ddd;z-index:1000}.map-info-label p{margin:2px 0;line-height:1.3;text-align:left}.measurement-toggle{position:absolute;top:140px;left:10px;z-index:1000}.layers-toggle,.overlay-toggle{position:absolute;top:200px;left:10px;z-index:1000}.extract-toggle{position:absolute;top:260px;left:10px;z-index:1000}.measurement-toggle-button{padding:10px 12px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:18px;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.measurement-toggle-button:hover{border-color:#007bff;background:#f8f9fa}.measurement-toggle-button.active{background:#007bff;color:#fff;border-color:#007bff}.layers-toggle-button{padding:10px 12px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:18px;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.layers-toggle-button:hover{border-color:#17a2b8;background:#f8f9fa}.layers-toggle-button.active{background:#17a2b8;color:#fff;border-color:#17a2b8}.overlay-toggle-button{padding:10px 12px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:18px;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.overlay-toggle-button:hover{border-color:#28a745;background:#f8f9fa}.overlay-toggle-button.active{background:#28a745;color:#fff;border-color:#28a745}.extract-toggle-button{padding:10px 12px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:18px;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.extract-toggle-button:hover{border-color:#ff6b6b;background:#f8f9fa}.extract-toggle-button.active{background:#ff6b6b;color:#fff;border-color:#ff6b6b}.measurement-control{position:absolute;top:180px;right:20px;width:280px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;border:1px solid #ddd;z-index:1001;overflow:hidden}.measurement-control .panel-header{display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;padding:12px 16px;margin:0;border-bottom:1px solid #dee2e6}.measurement-control .panel-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.measurement-control .close-button{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.measurement-control .close-button:hover{background:#e9ecef;color:#333}.measurement-buttons{display:flex;gap:8px;margin:16px 16px 12px;flex-wrap:wrap}.measurement-button{padding:8px 12px;border:2px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s ease;min-width:38px;display:flex;align-items:center;justify-content:center}.measurement-button:hover{border-color:#007bff;background:#f8f9fa}.measurement-button.active{background:#007bff;color:#fff;border-color:#007bff}.measurement-button.clear-button{background:#dc3545;color:#fff;border-color:#dc3545}.measurement-button.clear-button:hover{background:#c82333;border-color:#bd2130}.measurement-options{display:flex;flex-direction:column;gap:6px;margin:0 16px 16px}.measurement-option{display:flex;align-items:center;font-size:12px;cursor:pointer}.measurement-option input{margin-right:6px}.measurement-result{margin:6px 6px 6px 16px;padding:2px;border-radius:4px;font-size:12px;text-align:left}.overlay-layer-control{position:absolute;top:80px;left:20px;width:320px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;border:1px solid #ddd;z-index:1001;overflow:hidden}.overlay-layer-control .panel-header{display:flex;justify-content:space-between;align-items:center;background:#28a745;padding:12px 16px;margin:0;color:#fff}.overlay-layer-control .panel-header h3{margin:0;font-size:16px;font-weight:600;color:#fff}.overlay-layer-control .close-button{background:none;border:none;font-size:20px;cursor:pointer;color:#fff;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.overlay-layer-control .close-button:hover{background:#fff3;color:#fff}.overlay-content{max-height:500px;overflow-y:auto}.available-layers h4{margin:16px 16px 8px;font-size:14px;color:#333;font-weight:600}.layer-item{border-bottom:1px solid #f0f0f0;padding:12px 16px}.layer-item:last-child{border-bottom:none}.layer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.layer-toggle{display:flex;align-items:center;cursor:pointer;font-size:14px;flex:1}.layer-toggle input{margin-right:8px}.layer-name{font-weight:500;color:#333}.layer-actions{display:flex;gap:4px}.add-feature-button,.zoom-to-layer-button,.remove-layer-button{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;border-radius:4px}.add-feature-button{color:#28a745;font-size:20px;font-weight:700}.add-feature-button:hover{background:#e8f5e9}.zoom-to-layer-button{color:#007bff}.zoom-to-layer-button:hover{background:#e7f3ff}.remove-layer-button{color:#dc3545}.remove-layer-button:hover{background:#fff5f5}.layer-controls{margin-top:8px;padding-top:8px;border-top:1px solid #f0f0f0}.opacity-control{display:flex;flex-direction:column;font-size:12px;color:#666}.opacity-slider{margin-top:4px;width:100%}.overlay-actions{padding:16px;border-top:1px solid #f0f0f0;background:#f8f9fa}.clear-all-button{width:100%;padding:8px 16px;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s ease}.clear-all-button:hover{background:#c82333}.base-layer-control{position:absolute;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:5px}.layer-button{padding:8px 16px;font-size:12px;font-weight:500;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;cursor:pointer;transition:all .2s ease;min-width:80px;text-align:center;box-shadow:0 2px 4px #0000001a}.layer-button:hover{background:#f8f9fa;border-color:#007bff}.layer-button.active{background:#007bff;color:#fff;border-color:#007bff}.layer-button.active:hover{background:#0056b3;border-color:#0056b3}.reverse-geocode-panel{position:absolute;top:80px;right:20px;width:350px;max-height:500px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;border:1px solid #ddd;z-index:1001;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #ddd}.panel-header .title-container{display:flex;align-items:center;gap:8px}.panel-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.coordinate-action-button{background:none;border:none;font-size:18px;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.coordinate-action-button:hover{background-color:#0000000d}.edit-action-button{background:none;border:none;font-size:18px;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.edit-action-button:hover{background-color:#0000000d}.delete-action-button{background:none;border:none;font-size:18px;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.delete-action-button:hover{background-color:#0000000d}.close-button{background:none;border:none;font-size:20px;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.close-button:hover{background:#e9ecef;color:#333}.loading-container{padding:20px;text-align:center}.loading-container .spinner{width:24px;height:24px;margin:0 auto 10px}.loading-container p{margin:0;color:#666;font-size:14px}.error-container{padding:20px;text-align:center}.error-container p{margin:0;color:#dc3545;font-size:14px}.results-container{padding:0;max-height:400px;overflow-y:auto}.results-table{width:100%;border-collapse:collapse;font-size:14px}.results-table td{padding:8px 16px;border-bottom:1px solid #f0f0f0;vertical-align:top}.results-table td.label{font-weight:600;color:#495057;background:#f8f9fa;width:30%;min-width:100px}.results-table td.value{color:#333;word-break:break-word}.results-table tr:last-child td{border-bottom:none}.toggle-4d-control{position:fixed;bottom:20px;right:20px;display:flex;align-items:center;gap:12px;z-index:1000;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:25px;box-shadow:0 2px 8px #00000026;border:1px solid rgba(255,255,255,.8)}.toggle-4d-label{color:#333;font-size:16px;font-weight:500;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px rgba(255,255,255,.8);min-width:20px}.toggle-4d-switch{width:60px;height:30px;border-radius:15px;cursor:pointer;display:flex;align-items:center;padding:3px;transition:all .3s ease;box-shadow:inset 0 1px 3px #0003;position:relative}.toggle-4d-switch.off{background-color:#28a745}.toggle-4d-switch.on{background-color:#dc3545}.toggle-4d-circle{width:24px;height:24px;background-color:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px #0003}.toggle-4d-circle.off{transform:translate(30px)}.toggle-4d-circle.on{transform:translate(0)}.toggle-4d-text{position:absolute;font-size:10px;font-weight:700;color:#fff;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px rgba(0,0,0,.3);pointer-events:none}.toggle-4d-text.off{left:8px}.toggle-4d-text.on{left:38px}.extraction-progress-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.extraction-progress-dialog{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;width:600px;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.extraction-progress-dialog h3{margin:0;padding:20px;font-size:20px;font-weight:600;color:#333;border-bottom:2px solid #e9ecef;background:#f8f9fa}.progress-steps{padding:20px;flex:1;overflow-y:auto}.progress-step{display:flex;gap:16px;padding:16px;border-radius:8px;margin-bottom:12px;background:#f8f9fa;transition:all .3s ease}.progress-step.active{background:#e7f3ff;border-left:4px solid #007bff;padding-left:12px}.progress-step.completed{background:#d4edda;opacity:.8}.progress-step.error{background:#f8d7da;border-left:4px solid #dc3545;padding-left:12px}.progress-step.pending{opacity:.5}.step-indicator{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;background:#fff;border:2px solid #dee2e6}.progress-step.active .step-indicator{border-color:#007bff;background:#007bff;color:#fff}.progress-step.completed .step-indicator{border-color:#28a745;background:#28a745;color:#fff}.progress-step.error .step-indicator{border-color:#dc3545;background:#dc3545;color:#fff}.step-icon{font-size:24px}.step-spinner{font-size:24px;animation:spin 1s linear infinite}.step-number{font-size:18px;color:#6c757d}.step-content{flex:1;display:flex;flex-direction:column;gap:4px}.step-name{font-size:16px;font-weight:600;color:#333}.step-description{font-size:14px;color:#6c757d}.step-details{font-size:13px;color:#495057;margin-top:4px;padding:6px 10px;background:#fff9;border-radius:4px}.step-error{font-size:13px;color:#dc3545;margin-top:4px;padding:6px 10px;background:#fffc;border-radius:4px}.extraction-error{margin:0 20px 16px;padding:12px 16px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:14px}.extraction-success{margin:0 20px 16px;padding:12px 16px;background:#d4edda;border:1px solid #c3e6cb;border-radius:6px;color:#155724;font-size:14px;font-weight:500}.dialog-actions{padding:16px 20px;border-top:2px solid #e9ecef;background:#f8f9fa;display:flex;justify-content:flex-end}.close-dialog-button{padding:10px 24px;background:#6c757d;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease}.close-dialog-button:hover{background:#5a6268}.step-progress{margin-top:8px}.progress-bar-container{width:100%;height:20px;background:#e9ecef;border-radius:10px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease;border-radius:10px}.progress-text{margin-top:4px;font-size:12px;color:#495057;text-align:center;font-weight:500}.feature-control{position:absolute;top:80px;left:690px;width:350px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;border:1px solid #ddd;z-index:1002;overflow:hidden}.feature-control .panel-header{display:flex;justify-content:space-between;align-items:center;background:#28a745;padding:12px 16px;margin:0;color:#fff}.feature-control .panel-header h3{margin:0;font-size:16px;font-weight:600;color:#fff}.feature-control .close-button{background:none;border:none;font-size:20px;cursor:pointer;color:#fff;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.feature-control .close-button:hover{background:#fff3;color:#fff}.feature-content{padding:16px}.catalog-selector{margin-bottom:16px;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.catalog-selector label{display:block;margin-bottom:8px;font-size:14px;color:#333}.catalog-selector select{width:100%;padding:8px 12px;font-size:14px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;transition:border-color .2s}.catalog-selector select:focus{outline:none;border-color:#28a745;box-shadow:0 0 0 2px #28a7451a}.catalog-selector select:hover{border-color:#999}.feature-info{background:#f8f9fa;padding:12px;border-radius:6px;margin-bottom:16px;border:1px solid #e0e0e0}.feature-info p{margin:6px 0;font-size:14px;color:#333}.feature-info p strong{color:#666;font-weight:600}.feature-instructions{background:#e7f3ff;padding:12px;border-radius:6px;margin-bottom:16px;border:1px solid #b3d9ff}.feature-instructions p{margin:8px 0;font-size:14px;color:#004085;line-height:1.5}.feature-instructions .instruction-detail{margin-top:8px;font-style:italic;color:#005a9e}.feature-instructions .capturing-notice{font-weight:600;color:#28a745}.feature-actions{display:flex;justify-content:center;gap:10px}.start-capture-button,.cancel-capture-button{padding:10px 20px;font-size:14px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.start-capture-button{background:#28a745;color:#fff}.start-capture-button:hover{background:#218838;transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.cancel-capture-button{background:#dc3545;color:#fff}.cancel-capture-button:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px #dc35454d}.success-message{color:#28a745;font-weight:600;margin:8px 0}.attribute-form{background:#f8f9fa;padding:16px;border-radius:6px;margin-bottom:16px;border:1px solid #e0e0e0;max-height:400px;overflow-y:auto}.attribute-form h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.form-field{margin-bottom:12px}.form-field label{display:block;font-size:13px;font-weight:500;color:#555;margin-bottom:4px}.form-field input[type=text],.form-field input[type=number],.form-field select{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;font-size:13px;font-family:inherit;box-sizing:border-box}.form-field input[type=text]:focus,.form-field input[type=number]:focus,.form-field select:focus{outline:none;border-color:#28a745;box-shadow:0 0 0 2px #28a7451a}.form-field input:disabled,.form-field select:disabled{background-color:#e9ecef;cursor:not-allowed}.form-field-checkbox{display:flex;align-items:center}.form-field-checkbox label{display:flex;align-items:center;cursor:pointer;margin-bottom:0}.form-field-checkbox input[type=checkbox]{margin-right:8px;cursor:pointer;width:auto}.submit-button{padding:10px 20px;font-size:14px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#28a745;color:#fff;margin-right:10px}.submit-button:hover{background:#218838;transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.cancel-button{padding:10px 20px;font-size:14px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#6c757d;color:#fff}.cancel-button:hover{background:#5a6268;transform:translateY(-1px);box-shadow:0 2px 8px #6c757d4d}: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}.error-notification{position:fixed;top:20px;right:20px;z-index:9999;min-width:300px;max-width:500px;opacity:0;transform:translate(400px);transition:all .3s ease-in-out;pointer-events:none}.error-notification.visible{opacity:1;transform:translate(0);pointer-events:all}.error-content{display:flex;align-items:center;gap:12px;padding:16px;background-color:#fee;border:1px solid #fcc;border-left:4px solid #f44;border-radius:4px;box-shadow:0 4px 12px #00000026}.error-icon{font-size:20px;flex-shrink:0}.error-message{flex:1;color:#c33;font-size:14px;line-height:1.4}.error-dismiss{background:none;border:none;color:#c33;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity .2s}.error-dismiss:hover{opacity:1}.error-dismiss:focus{outline:2px solid #f44;outline-offset:2px}
