.viecon-map-container{--primary-color:red;--col--entrance:#950606;--col--bicycle:#ffac1c;--col--surrounding:#909090;--col--parking:#039;--col--underground:#a862a4;--col--hotel:#21888f;--col--gastro:#ff8da1;--col--elevator:#7f00ff;--col--specialneeds:#212121;--col--delivery:#6f3250;--col--hotelgreen:#00a949;--col--disabledP:#039;--col--green-location:#87ae73;--col--shuttle:#f7b731;--col--taxi:#f7b731;--map-width:100%;--map-max-width:100%;--map-height:auto;--map-aspect-ratio:16/9;--map-max-height:671px;--map-mobile-aspect-ratio:1/1;--map-mobile-max-height:80vh;font-family:NunitoSans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;*{box-sizing:border-box;margin:0;padding:0}.map-wrapper{aspect-ratio:var(--map-aspect-ratio,7/4);background-color:#e8e8e8;flex-shrink:0;height:var(--map-height,auto);margin:0 auto;max-height:var(--map-max-height,800px);max-width:var(--map-max-width,1200px);position:relative;width:var(--map-width,100%);@media screen and (max-width:768px){aspect-ratio:var(--map-mobile-aspect-ratio,1/1);height:auto;max-height:var(--map-mobile-max-height,500px)}h3{font-size:1.17rem;font-weight:700}h3,p{margin:0 0 .5rem}p+a{margin-top:1rem}}#panzoomContainer{align-items:center;border:1px solid #ddd;display:flex;height:100%;justify-content:center;outline:none;overflow:hidden;position:relative;width:100%}#panzoomContainer:focus{outline:3px solid #fdc32a}.map-bg,.map-overlay{backface-visibility:hidden;height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;left:0;position:absolute;top:0;transform:translateZ(0);user-select:none;width:100%}.map-bg{background-color:#fff;height:100%;object-fit:contain;object-position:center;pointer-events:none;position:relative;width:100%;&:not([src]),&[src=""]{visibility:hidden}&:before{background-color:rgba(0,0,0,.1);content:"";height:100%;position:absolute;width:100%;z-index:1}}.map-overlay{pointer-events:auto;z-index:2}.map-overlay svg{height:100%;image-rendering:pixelated;shape-rendering:crispEdges;width:100%}.map-overlay g:not(.svg-extra),.map-overlay path:not(.svg-extra),.map-overlay polygon:not(.svg-extra){transform:translate(-3px,-3px)}.map-overlay .svg-extra,.map-overlay .svg-extra g,.map-overlay .svg-extra path,.map-overlay .svg-extra polygon{transform:translate(-1px,-1.5px)!important}.map-overlay>:not(.svg-extra) circle,.map-overlay>:not(.svg-extra) path,.map-overlay>:not(.svg-extra) polygon{cursor:pointer;fill:rgba(255,0,0,.4);pointer-events:auto;stroke:red;stroke-width:0;vector-effect:non-scaling-stroke;&.no-bg{fill:rgba(255,0,0,.001)}}.map-overlay>:not(.svg-extra) circle:hover,.map-overlay>:not(.svg-extra) path:hover,.map-overlay>:not(.svg-extra) polygon:hover{fill:rgba(255,0,0,.65)!important}.building-title-bg{pointer-events:none}.zoom-controls{display:flex;flex-direction:column;gap:8px;position:absolute;right:20px;top:20px;z-index:1000}.zoom-controls button{align-items:center;background:#fff;border:2px solid #333;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.2);cursor:pointer;display:flex;font-size:18px;font-weight:700;height:40px;justify-content:center;width:40px}.zoom-controls button:hover{background:#f0f0f0}.zoom-controls button:disabled{cursor:not-allowed;opacity:.5}.filters{background:#f9f9f9;border-top:1px solid #ddd;display:flex;flex-wrap:wrap;gap:1rem;padding:1rem calc(50% - 750px);@media screen and (max-width:1520px){gap:.5rem;padding-bottom:1rem;padding-left:28px;padding-right:28px;padding-top:1rem}@media screen and (max-width:768px){padding-bottom:1rem;padding-left:20px;padding-right:20px;padding-top:1rem}}.filters fieldset{border:1px solid #ccc;border-radius:4px;margin:0;padding:.5rem}.filters legend{font-weight:700;padding:0 .5rem}.filters button{align-items:center;background:#fff;border:0;border-radius:25px;cursor:pointer;display:flex;flex-direction:row;margin:.2rem;padding:4px 1rem 4px 4px;transition:transform .2s ease;&:hover{transform:scale(1.05)}.icon{border-radius:100%;height:26px;margin-right:8px;width:26px}span:last-child{color:#000;font-size:18px}&[data-layer=parking]{border:1px solid var(--col--parking);.icon{background-color:var(--col--parking)}}&[data-layer=underground]{border:1px solid var(--col--underground);.icon{background-color:var(--col--underground);background-image:url(assets/underground.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=hotel],&[data-layer=hotelgreen]{border:1px solid var(--col--hotel);.icon{background-color:var(--col--hotel);background-image:url(assets/hotel.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=elevator]{border:1px solid var(--col--elevator);.icon{background-color:var(--col--elevator);background-image:url(assets/elevator.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=delivery]{border:1px solid var(--col--delivery);.icon{background-color:var(--col--delivery);background-image:url(assets/delivery.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=disabledP],&[data-layer=parking]{border:1px solid var(--col--parking);.icon{background-color:var(--col--parking);background-image:url(assets/parking.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer*=gastro-],&[data-layer=gastro]{border:1px solid var(--col--gastro);.icon{background-color:var(--col--gastro);background-image:url(assets/gastro.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=specialneeds]{border:1px solid var(--col--specialneeds);.icon{background-color:var(--col--specialneeds);background-image:url(assets/specialneeds.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=hotelgreen]{border:1px solid var(--col--hotelgreen);.icon{background-color:var(--col--hotelgreen)}}&[data-layer=taxi]{border:1px solid var(--col--taxi);.icon{background-color:var(--col--taxi);background-image:url(assets/taxi.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=shuttle]{border:1px solid var(--col--shuttle);.icon{background-color:var(--col--shuttle)}}&[data-layer=green-location]{border:1px solid var(--col--green-location);.icon{background-color:var(--col--green-location);background-image:url(assets/green-location.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer*=entrances],&[data-layer*=zones-overlay],&[data-layer=buildings],&[data-layer=spaces]{border:1px solid red;.icon{background-color:red}}&[data-layer=anfahrt],&[data-layer=entrance]{border:1px solid var(--col--delivery);.icon{background-color:var(--col--delivery);background-image:url(assets/entrance.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=bicycle]{border:1px solid var(--col--bicycle);.icon{background-color:var(--col--bicycle);background-image:url(assets/bicycle.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}&[data-layer=kindergarten],&[data-layer=surrounding]{border:1px solid var(--col--surrounding);.icon{background-color:var(--col--surrounding);background-image:url(assets/surrounding.svg);background-position:50%;background-repeat:no-repeat;background-size:16px}}}.filters button[aria-pressed=true]{color:#000;opacity:1}.filters button:not([aria-pressed=true]){background:transparent;border-color:gray;color:gray!important;opacity:.6;.icon{background-color:gray}&:hover{opacity:1}}.modal{align-items:flex-end;background:rgba(0,0,0,.6);display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .3s;visibility:hidden;z-index:2000}.modal[aria-hidden=false]{opacity:1;visibility:visible}.modal-content{background:#fff;border-top-left-radius:12px;border-top-right-radius:12px;max-height:50vh;overflow-y:auto;padding:1rem;width:100%;width:1500px}.close-btn{background:none;border:none;cursor:pointer;float:right;font-size:1.5rem}.poi-container{pointer-events:none;position:absolute;z-index:10;button{background:none;border:none;cursor:pointer}}.poi-icon{cursor:pointer;pointer-events:auto;position:absolute;z-index:100}.poi-icon:hover{z-index:200!important}.poi-icon-wrapper{align-items:center;background:hsla(0,0%,100%,.9);border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.2);display:flex;flex-direction:row;gap:5px;padding:1px 2px;transition:transform .2s ease;white-space:nowrap}.poi-icon-wrapper.alignment-right{flex-direction:row-reverse;justify-content:flex-end;overflow:hidden}.poi-icon:hover .poi-icon-wrapper.has-infobox{background:#fff;transform:scale(1.1)}.poi-image{height:24px;object-fit:contain;width:24px}.poi-image-bg{align-items:center;border-radius:50%;display:inline-flex;height:9px;justify-content:center;padding:1px 2px;width:9px;&.parking{background-color:var(--col--parking)}&.kindergarten,&.surrounding{background-color:var(--col--surrounding)}&.green-location{background-color:var(--col--green-location)}&.taxi{background-color:var(--col--taxi)}&.bicycle{background-color:var(--col--bicycle)}&.anfahrt,&.entrance{background-color:var(--col--delivery)}&.underground{background-color:var(--col--underground)}&.shuttle{background-color:var(--col--shuttle)}&.hotel{background-color:var(--col--hotel)}&.hotelgreen{background-color:var(--col--hotelgreen)}&.gastro,&[class*=gastro-]{background-color:var(--col--gastro)}&.disabledP{background-color:var(--col--disabledP)}&.delivery{background-color:var(--col--delivery)}&.specialneeds{background-color:var(--col--specialneeds)}&.elevator{background-color:var(--col--elevator)}&.spaces{background-color:red}}.poi-label{color:#333;font-size:7px;font-weight:700;line-height:10px;padding-right:6px;text-align:center;white-space:nowrap}.poi-icon-wrapper.alignment-right .poi-label{padding-left:6px;padding-right:0;text-align:right}.map-controls-top-left{align-items:stretch;display:flex;flex-direction:column;gap:.6rem;left:20px;position:absolute;top:20px;z-index:1001}.floor-navigation{backdrop-filter:blur(10px);background:hsla(0,0%,100%,.95);border:2px solid #fff;border:1px solid hsla(0,0%,100%,.2);border-radius:4px;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;justify-content:center;padding:.55rem .75rem;position:relative}.floor-info{align-items:center;display:flex;gap:10px}#currentFloorName{color:#333;font-weight:700}.nav-link{margin:.3rem}.map-btn{background:var(--primary-color);border:0;border-radius:8px;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;padding:.55rem 1rem;text-decoration:none;transition:all .15s ease-out;&:hover{background:#b30000}&.small{font-size:12px}&.secondary{background-color:#000;&:hover{background-color:#505050;transition:all .15s ease-out}}}.related-floor-btn{align-items:center;background-color:#fff;border:2px solid #000;color:#000;display:flex;gap:8px;justify-content:center;transition:transform .2s ease-out;&:hover{background-color:#fff;color:#000;transform:scale(1.05)}.btn-icon{display:block;height:1em;object-fit:contain;width:1em}}.close-btn:focus,button.poi-icon:focus,button[role=button]:focus,path[role=button]:focus{outline:3px solid #06c;outline-offset:2px}.visually-hidden{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0 0 0 0);border:0;white-space:nowrap}.svg-extra{pointer-events:none}.building-title-label{fill:#222;font-family:Arial,sans-serif;font-size:48px;font-weight:700;pointer-events:none;text-shadow:0 2px 8px #fff}.no-stroke{stroke:none!important}#imageOverlay{background:linear-gradient(90deg,#fff,hsla(0,0%,91%,0) 10%,hsla(0,0%,91%,0) 90%,#fff);border-radius:0;pointer-events:none;@media screen and (max-width:768px){display:none}}.map-navigation-dropdown{font-family:inherit;position:absolute;z-index:1002}.map-navigation-dropdown.bottom-right{bottom:20px;right:20px}.map-navigation-dropdown.top-right{right:20px;top:20px}.map-navigation-dropdown.bottom-left{bottom:20px;left:20px}.map-navigation-dropdown.top-left{left:20px;top:20px}.map-nav-toggle-btn{align-items:center;background:#fff;border:2px solid #000;border-radius:4px;box-shadow:0 4px 12px rgba(0,0,0,.15);cursor:pointer;display:flex;font-size:16px;font-weight:700;gap:10px;justify-content:space-between;min-width:150px;padding:.55rem .75rem;position:relative}.map-nav-toggle-btn:hover{background:#f9f9f9}.map-nav-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;color:transparent;display:inline-block;height:12px;transition:transform .3s ease;width:12px}.map-nav-toggle-btn[aria-expanded=true] .map-nav-icon{transform:rotate(180deg)}.map-nav-menu{background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 10px rgba(0,0,0,.15);display:none;list-style:none;margin:0;max-height:230px;max-width:250px;min-width:100%;overflow-y:auto;padding:0;position:absolute;width:max-content}.map-nav-menu.open{display:block}.map-nav-menu.up{bottom:100%;margin-bottom:5px;right:0}.map-nav-menu.down{margin-top:5px;right:0;top:100%}.map-nav-menu li:last-child{border-bottom:none}.map-nav-link{color:#333;display:block;font-size:14px;padding:10px 15px;text-decoration:none;transition:background .2s}.map-nav-link:hover{background:#f0f0f0}.map-nav-link.active{background:#e6f7ff;font-weight:700}}