@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200";: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}:root{--color-primary: #0b3d91;--color-primary-light: #1e90ff;--color-background: #ffffff;--color-text: #0b172a;--color-text-secondary: #666666;--color-border: #e5e7eb;--color-error: #dc2626;--font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";--font-size-base: 1rem;--line-height-base: 1.5;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}p{margin:0}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-light)}button{font-family:inherit;font-size:inherit;border:none}button:focus,a:focus,input:focus,textarea:focus,select:focus{outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.layer-tile{display:flex;align-items:center;justify-content:center;width:64px;height:64px;padding:0;margin:0;border:2px solid #d0d0d0;border-radius:4px;background-color:#fff;font-size:12px;font-weight:500;text-align:center;color:#333;cursor:pointer;transition:all .15s ease-in-out;position:relative}.layer-tile:hover{background-color:#f5f5f5;border-color:#999}.layer-tile:focus{outline:none;border-color:#1e90ff;box-shadow:0 0 0 3px #1e90ff33}.layer-tile--active{background-color:#e3f2fd;border-color:#1e90ff}.layer-tile--active:hover{background-color:#bbdefb}.layer-tile--focused{outline:2px solid #1e90ff;outline-offset:-2px}.layer-tile__content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:100%;height:100%;padding:4px}.layer-tile__icon{flex-shrink:0;max-width:32px;max-height:32px}.layer-tile__icon--image{width:32px;height:32px;object-fit:contain}.layer-tile__icon--matsym{font-size:28px;width:28px;height:28px}.layer-tile__label{font-size:11px;line-height:1.2;word-break:break-word;overflow:hidden;text-overflow:ellipsis;max-width:100%}.layer-panel{position:absolute;top:10px;left:10px;background-color:#fffffff2;border:1px solid #cccccc;border-radius:4px;box-shadow:0 2px 8px #00000026;padding:8px;z-index:100;max-height:calc(100% - 20px);overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.layer-panel__main{display:flex;flex-direction:column;gap:8px}.layer-panel__title{font-size:14px;font-weight:600;color:#333;padding:0 4px;text-transform:uppercase;letter-spacing:.5px}.layer-panel__tiles{display:flex;flex-direction:column;gap:6px;max-width:80px}.layer-panel__submenu{display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px solid #e5e7eb;margin-top:8px}.layer-panel__submenu-title{font-size:12px;font-weight:600;color:#666;padding:0 4px;text-transform:uppercase;letter-spacing:.5px}.layer-panel__submenu-tiles{display:flex;flex-direction:row;gap:6px;flex-wrap:wrap;max-width:400px}.layer-panel::-webkit-scrollbar{width:6px}.layer-panel::-webkit-scrollbar-track{background:transparent}.layer-panel::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.layer-panel::-webkit-scrollbar-thumb:hover{background-color:#0006}.app-shell{display:grid;grid-template-rows:auto 1fr auto;height:100vh;height:100dvh;width:100%}.map-wrap{position:relative;height:100%;overflow:hidden}.map{position:absolute;inset:0;width:100%;height:100%}.ol-zoom{top:.5rem;left:.5rem;background-color:transparent!important;border:none!important;box-shadow:none!important}.ol-unselectable.ol-control{background-color:transparent!important;border:none!important}.ol-zoom button{width:36px;height:36px;font-size:2.5rem!important;line-height:1!important;background-color:#fff3!important;border-radius:4px!important;border:1px solid rgba(0,0,0,.1)!important;box-shadow:0 1px 4px #0003!important;color:#000000b3!important;margin:2px!important}.ol-zoom button:hover{background-color:#fff!important}.btn--layers-map{position:absolute;top:13rem;left:.5rem;z-index:100;padding:.375rem;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:#ffffffe6;border:1px solid rgba(0,0,0,.1);box-shadow:0 1px 4px #0003}.btn--layers-map:hover{background-color:#fff}.btn--layers-map:active{background-color:#ffffffd9}.btn--layers-map[aria-pressed=true]{background-color:#00000026}.btn--layers-map .btn--layers__icon{filter:none;opacity:.7}.btn--follow-me{position:absolute;top:9rem;left:.5rem;z-index:100;padding:.375rem;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:4px;box-shadow:0 1px 4px #0003;color:#059669;cursor:pointer;transition:all .15s ease-in-out}.btn--follow-me:hover{background-color:#fff}.btn--follow-me:active{background-color:#ffffffd9}.btn--follow-me--active{background-color:#0596691a;color:#059669}.btn--follow-me--active:hover{background-color:#05966926}.btn--follow-me__icon{stroke:currentColor;fill:none;width:20px;height:20px}.btn{padding:.5rem .75rem;border:none;border-radius:4px;background-color:transparent;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease-in-out;white-space:nowrap}.btn:hover:not(:disabled){background-color:#ffffff26}.btn:active:not(:disabled){background-color:#fff3}.btn:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:-2px}.btn--layers__icon{width:24px;height:24px;filter:brightness(0) invert(1)}.app-header{background:linear-gradient(90deg,#0b3d91,#1e90ff);color:#fff;box-shadow:0 2px 8px #00000026;flex-shrink:0}.header-content{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;max-width:100%}.app-title{font-size:1.25rem;font-weight:600;margin:0;white-space:nowrap}.header-spacer{flex:1}.header-controls{display:flex;gap:.5rem;align-items:center}.app-footer{background-color:#ffffffeb;border-top:1px solid #e5e7eb;box-shadow:0 -2px 8px #00000014;flex-shrink:0;min-height:35px}.footer-content{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;max-width:100%;font-size:1rem}.footer-section{display:flex;align-items:center;gap:.5rem;min-width:0}.footer-section-left{flex:0 0 auto;min-width:40%;display:flex;align-items:flex-end;overflow:hidden}.scale-bar{display:flex;flex-direction:column;align-items:center;gap:.25rem}.scale-bar-line{width:100%;height:3px;background-color:#333;border-left:2px solid #333;border-right:2px solid #333}.scale-bar-label{font-size:.5rem;font-weight:500;color:#0b172a;white-space:nowrap}.footer-section-center{flex:1;justify-content:center;padding:0 1rem;border-left:1px solid #e5e7eb;border-right:1px solid #e5e7eb}.footer-section-right{flex:0 0 auto;min-width:40%;justify-content:flex-end;color:#666}.coordinates-display{display:flex;align-items:center;gap:.75rem;color:#0b172a;font-family:Courier New,monospace;font-weight:500;white-space:nowrap}.zoom-level{display:flex;align-items:center;gap:.25rem}.zoom-level strong{color:#0b3d91}.separator{color:#ccc}.coordinates{color:#0b3d91}.scale-bar-placeholder{color:#999;font-size:.75rem;font-style:italic}.ol-scale-line{position:static!important;background:transparent!important;inset:auto!important}.ol-scale-line-inner{border-color:#0b3d91!important;color:#0b3d91!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif!important;font-size:.75rem!important;text-align:center!important}.attribution{color:#666;font-size:1rem}.attribution a{color:#0b3d91;text-decoration:none;transition:color .2s ease}.attribution a:hover{color:#1e90ff;text-decoration:underline}.btn{padding:.5rem .75rem;background-color:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s ease,border-color .2s ease}.btn:hover:not(:disabled){background-color:#ffffff4d;border-color:#ffffff80}.btn:active:not(:disabled){background-color:#fff6}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus{outline:3px solid #ffbf47;outline-offset:2px}.skip-link{position:absolute;left:.5rem;top:-2.5rem;background-color:#fff;color:#000;padding:.5rem .75rem;border-radius:.375rem;text-decoration:none;font-size:.875rem;font-weight:600;z-index:1000;box-shadow:0 2px 6px #0003}.skip-link:focus{top:.5rem}@media(max-width:768px){.app-title{font-size:1.1rem}.footer-content{padding:.5rem .75rem;gap:.5rem}.footer-section-center{padding:0 .5rem}.coordinates-display{gap:.5rem;font-size:.75rem}}@media(max-width:640px){.app-title{display:none}.header-content{padding:.5rem .75rem}.btn{padding:.375rem .5rem;font-size:.75rem}.footer-content{flex-direction:column;gap:.25rem;padding:.5rem;font-size:.75rem}.footer-section{width:100%;flex-direction:column;align-items:flex-start}.footer-section-center{border:none;padding:0;width:10%;justify-content:flex-start}.coordinates-display{gap:.5rem;font-size:.75rem}}
