*{margin:0;padding:0}html{overflow:hidden;font-family:Arial,Helvetica,sans-serif;-webkit-user-select:none;user-select:none}body{overflow:hidden;margin:0}footer{position:fixed;bottom:0;left:0;width:100%;background-color:transparent;color:#000;font-size:.75rem;padding:.5rem;text-align:center;z-index:1000;pointer-events:none}.webgl{position:fixed;top:0;left:0;outline:none}canvas{image-rendering:pixelated;outline:none}#VRButton{background-color:#ff0!important;color:#000!important;width:250px!important;height:50px!important;position:absolute!important;bottom:20px!important;left:50%!important;transform:translate(-50%,-50%)!important}#ARButton{background-color:#ff0!important;color:#000!important;width:250px!important;height:50px!important;position:absolute!important;bottom:90px!important;left:50%!important;transform:translate(-50%,-50%)!important}.genericButton{display:contents}.lil-gui.autoPlace{top:0;right:0}.lil-gui{width:275px!important}.hidden-gui{display:none!important}.show-gui{display:visible!important}#layer-gui-container{position:absolute;right:0;top:0;display:flex;flex-direction:column;gap:0px;z-index:1000}#about{color:#000;font-family:monospace;position:absolute;line-height:1.5em;bottom:10px;right:10px;padding:2px;height:18px;width:30px;border-radius:5px;background-color:#a7a2a2cc;text-align:center}#statusLoad{position:fixed;bottom:0;left:5px;width:100px;background-color:transparent;color:#000;font-size:.75rem;z-index:1000;pointer-events:none}#info{color:#fff;font-family:monospace;position:absolute;white-space:pre;line-height:1.5em;padding:10px;height:100px;width:300px;background-color:#ff0}#world{left:10px;top:10px;width:150px;padding:10px;border-radius:5px;background-color:#ff0;z-index:100;position:absolute;text-align:center}#world ul{margin:0;padding-left:20px}#menu{position:absolute;left:2%;top:310px;width:300px;max-height:300px;padding:10px;border-radius:5px;background-color:#a7a2a280;line-height:2em;z-index:100}.viewerDiv{width:200px;height:100px;background:#add8e6;border:1px solid black;display:flex;justify-content:center;align-items:center}#messageBoardContainer{display:none;background-color:#fff;width:200px;height:200px;border:1px solid red;margin:100px;padding:0;position:static;top:100px;left:100px}.searchContent{position:absolute;width:400px;top:10px;left:50%;background-color:#a7a2a280;color:#000;border-radius:5px;padding:3px;left:calc(50% - 200px);max-height:350px;overflow-y:auto;text-align:center}#log-output{position:fixed;bottom:20px;left:20px;width:300px;height:200px;background-color:#222;color:#0f0;padding:10px;overflow:auto;font-family:monospace;white-space:pre;z-index:100;border-radius:8px;cursor:move;display:none}.addresSearch{width:80%;margin-bottom:4px;margin-top:10px;padding:2px}#addressContainer{padding:5px}#resultsContainer{padding:0}#currentLocation{vertical-align:middle}#currentLocationImage{width:16px;height:16px;vertical-align:middle;margin-right:5px}#progress-container{position:fixed;top:40%;left:50%;transform:translate(-50%,-50%);width:300px;text-align:center;background:#000c;color:#fff;padding:20px;border-radius:10px;display:none}#progress-bar{width:100%;height:20px;background:gray;border-radius:5px;overflow:hidden;margin-top:10px}#progress-bar-fill{width:0%;height:100%;background:#32cd32;transition:width .3s ease-in-out}#knop{bottom:100px}.netwerkLog{position:absolute;font-family:monospace;white-space:pre-wrap;background:#111;color:#0f0;padding:10px;height:100px;overflow-y:auto;left:5%;bottom:20px;width:90%}#menuContainer{position:fixed;top:10px;left:10px;pointer-events:all;display:flex;flex-direction:column;gap:10px}.close-btn{position:absolute;background:none;color:#fff;border:none;font-size:24px;cursor:pointer}.menuIconBlack{width:32px;height:32px;fill:#000;stroke-width:14;stroke:#fff;stroke-linejoin:round}.menuIconWhite{width:32px;height:32px;fill:#fff;stroke:#000}.menuIconBlack.active{fill:#fff!important;stroke:#000!important}#toggleMenu{position:fixed;top:1rem;left:1rem;z-index:1000}#sidebar{position:fixed;top:0;left:0;height:100%;width:270px;background-color:#333;color:#fff;transform:translate(-100%);transition:transform .3s ease;padding-top:60px;padding-left:10px;z-index:1000}#sidebarHeader{height:30px;top:10px;position:absolute}#sidebar ul{list-style-type:none;padding:0}#sidebar ul li{padding:15px}#sidebar ul li a{color:#fff;text-decoration:none}#sidebar.open{transform:translate(0)}.sidebarCategoryName{font-weight:700;color:#fff;background-color:#333;border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none;outline:none}details[open]>.sidebarCategoryName{background-color:#444}.sidebarCategoryName::marker{font-size:1.1em;color:#87cefa}.environmentLayerSection,.menuLayerSection{height:calc(100dvh - 200px);padding-right:10px;padding-bottom:calc(80px + env(safe-area-inset-bottom));line-height:25px;font-size:small;-webkit-overflow-scrolling:touch;overflow:auto}.layerGroup{margin-bottom:10px;white-space:wrap;overflow-x:auto;height:fit-content}#features{margin-bottom:100px}.layerGroup h2{text-align:center;margin:4px}#layerGroup3DLayers{padding-bottom:100px}#addLayerButton{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 14px;font-size:14px;background-color:#e6f5ea;color:#2a6f37;border:none;border-radius:4px;cursor:pointer;font-family:sans-serif;width:100%}#addLayerButton svg{width:20px;height:20px;stroke:green;stroke-width:3}.layerTree{font-family:sans-serif;font-size:13px}.layerTree ul{list-style:none;padding-left:16px}.layerTree li{margin:2px 0}.tree-toggle{cursor:pointer;margin-right:4px}.layer-checkbox{margin-right:6px}.catalog-tree{font-family:sans-serif;font-size:13px;max-height:200px;display:inline-block;overflow:auto;width:100%}.catalog-tree .tree-toggle:before{content:"▶";display:inline-block;transform:rotate(0);transition:transform .2s}.catalog-tree ul{list-style:none;margin:0;padding-left:18px}.catalog-tree li{line-height:1.6;position:relative}.catalog-tree li span{cursor:pointer}.catalog-tree li:hover{background:#89c5ed}.catalog-tree li:before{content:"";position:absolute;top:0;left:-10px;border-left:1px solid #ccc;height:100%}.catalog-tree li:after{content:"";position:absolute;top:12px;left:-10px;width:10px;border-top:1px solid #ccc}.catalog-tree>ul>li:before{border-left:none}.catalog-tree input[type=checkbox]{margin-right:6px}.pdokSearch{width:100%;padding:4px;margin-bottom:6px}#pdokResults ul{list-style:none;padding-left:0}#pdokResults li{padding:3px 6px}#pdokResults li:hover{background:#89c5ed}.sidebarSourceHeader{margin-top:6px;font-size:12px;opacity:.75;text-transform:uppercase;letter-spacing:.04em}.functionGroup{position:sticky;top:10px;background:#fff;padding:0;border-top:1px solid #ddd;z-index:10;margin-bottom:20px}.mode-tile{display:inline-block;width:100px;margin:8px;border:2px solid transparent;border-radius:24px;overflow:hidden;cursor:pointer;text-align:center;transition:border-color .2s;background-color:#222}.mode-tile.selected{border-color:#a855f7}.mode-tile img{width:100%;height:auto;display:block;border-radius:0;clip-path:inset(0 0 15px 0)}.mode-tile span{display:block;margin-top:-10px;font-weight:700;color:#fff}.switch-container{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:8px 0}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0;position:absolute}.switch .slider{position:absolute;inset:0;cursor:pointer;background:#888;border-radius:24px;transition:.2s}.switch .slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}.switch input:checked+.slider{background:#4caf50}.switch input:checked+.slider:before{transform:translate(20px)}.reset-buildings{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin-left:10px;border:1px solid #888;border-radius:4px;background:#2c2c2c;color:#fff;cursor:pointer;transition:all .2s ease}.reset-buildings:hover{background:#444;border-color:#aaa;transform:rotate(45deg)}#toast-container{margin-top:8px;display:flex;flex-direction:column;gap:6px}.toast{background:#282828e6;color:#fff;padding:8px 12px;border-radius:6px;font-size:13px;opacity:0;transform:translateY(-6px);transition:opacity .25s ease,transform .25s ease}.toast.show{opacity:1;transform:translateY(0)}.hint{text-align:center;border-radius:5px;display:inline-block;background:#fff;opacity:.9;position:absolute;left:calc(50% - 15px);top:45%;width:70%;transform:translate(-45%,-45%);z-index:1100;visibility:hidden;padding:.4em 1.2em .8em;line-height:1.1em}.hint img{width:100%;max-width:100px;height:auto;padding:.2em 0}.hint h1{font-size:1.6rem;padding:.2em 0 .4em;line-height:normal}.hintText{padding-bottom:10px;font-size:.8rem}.hintTextAttention{padding-bottom:10px;font-size:.8rem;font-style:italic}.begrepen{padding:10px 0}.btn{border:none;border-radius:5px;color:#fff!important;cursor:pointer;display:inline-block;font-family:inherit;font-weight:600;height:39px;line-height:39px;margin:0;outline:none;padding:0 1.2em;text-align:center;text-decoration:none}.btn.blue{background-color:#009ee3;text-shadow:1px 1px #07a}.btn.navy{background-color:#005e9e;text-shadow:1px 1px #004777}.preferredArea{text-align:center;border-radius:5px;display:inline-block;background:#fff;opacity:.9;position:absolute;left:calc(50% - 15px);top:45%;width:60%;transform:translate(-45%,-45%);z-index:1000;visibility:hidden;padding:.4em 1.2em .8em;line-height:1.1em}.preferredArea h1{font-size:1.6rem;padding:.2em 0 .4em;line-height:normal}.preferredAreaText{font-size:.8rem;margin-top:4px;line-height:1.2em}.btnPreferredAreaContent{display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.2em;width:100%;height:100%;box-sizing:border-box;text-align:center;font-size:clamp(1rem,1.4vw,.9rem);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btnPreferredArea{border-radius:5px;opacity:1;cursor:pointer;display:block;font-family:inherit;font-weight:600;margin:6px auto;outline:none;text-align:center;text-decoration:none;width:auto;white-space:nowrap;border:#005e9e 1px solid;height:70px}.btnLink{text-decoration:none;color:#000!important}.loader{border:16px solid #009ee3;border-radius:50%;border-top:16px solid #07a;width:60px;height:60px;-webkit-animation:spin 2s linear infinite;animation:spin 2s linear infinite;position:fixed;top:50%;left:50%;margin-top:-60px;margin-left:-60px;z-index:1000;visibility:hidden}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#layerBox{position:fixed;top:20px;left:50%;transform:translate(-50%);width:500px;padding:15px;background-color:#ffffffe6;border-radius:8px;box-shadow:0 0 10px #0000001a;font-family:sans-serif;z-index:1000;max-height:600px;overflow:auto}@media(max-width:600px){#layerBox{width:90%;left:50%;transform:translate(-50%);max-height:400px}}#layerBox input,#layerBox select{width:100%;padding:6px;margin-bottom:8px;box-sizing:border-box}#layerBox label{font-size:.9em;margin-top:5px;display:block}#layerBox input[type=checkbox]{width:auto;margin:2px 8px 2px 0}#layerBox button{margin-right:5px;padding:6px 12px;cursor:pointer}#layerFields{max-height:300px;overflow-y:auto;margin-bottom:10px}#layerFields::-webkit-scrollbar{width:6px}#layerFields::-webkit-scrollbar-thumb{background-color:#0003;border-radius:4px}.layer-item{background:#f4f4f4;padding:6px;margin-bottom:6px;border-radius:4px;display:flex;justify-content:space-between;font-size:.9em}.layerTypeBadge{margin-left:6px;vertical-align:middle}#shadowSlider{display:none}#timeDial{position:absolute;right:20px;top:20px;width:220px;height:220px;z-index:1000;border-radius:50%;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);touch-action:none}@media(max-width:768px){#timeDial{width:200px;height:200px;right:16px;bottom:16px}}.ring{fill:none}.ringLabel{font-size:12px;letter-spacing:2px;text-transform:uppercase;pointer-events:none;fill:#ffffffbf}.ring.active{stroke-width:18}.ringHighlight{fill:none;stroke-width:30;pointer-events:none;stroke:#ffffffb3;filter:blur(3px);opacity:0;transition:opacity .15s ease}.monthLabel{fill:#4da3ff}.dayLabel{fill:#6edc8c}.timeLabel{fill:#ffb74d}ß .ringTick{pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none}.ringTick.selected{fill:#fff;paint-order:stroke;stroke:#0000008c;stroke-width:3;font-weight:700}.separator{fill:none;stroke:#96969659;stroke-width:3;pointer-events:none}.month{stroke:#4da3ff}.day{stroke:#6edc8c}.time{stroke:#ffb74d}#timeLabel{fill:#fff;font-size:14px;font-weight:500;pointer-events:none}#timeLabel tspan:last-child{font-size:16px;font-weight:600}.timeTick,.dayTick{font-size:12px;font-weight:500;fill:#111}.monthTick{font-size:14px;font-weight:500;fill:#111}#timeDialMobile{position:absolute;right:10px;top:10px;width:120px;height:120px;z-index:1000;border-radius:50%;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:none;touch-action:none}#timeDialMobile svg{width:100%;height:100%}.mobileRing{fill:none;stroke:#4d97ff;stroke-width:36}#mobileTimeLabel{fill:#fff;font-size:20px;font-weight:500}@media(max-width:600px){.searchContent{width:60%;left:50%;transform:translate(-50%);position:absolute}#progress-container{width:80%;left:50%;transform:translate(-50%);position:absolute}#log-output{width:90%;left:50%;transform:translate(-50%)}}
