body,html{height:100%;width:100%}body{margin:0;padding:0;font-family:Quicksand,sans-serif}#map{position:fixed;width:100%;height:100%}.fa-map-marker,.fa-spin,.fa-spinner{background-image:url(../img/locator.png);background-size:28px;width:28px;height:28px;display:block}#loader{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(255,255,255,.8);display:flex;align-items:center;justify-content:center;z-index:1500}#loader.hidden{display:none}.legend{position:fixed;top:10px;right:10px;background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 2px 8px rgb(0 0 0 / .15);width:max-content;font-family:Quicksand,sans-serif;font-weight:600;user-select:none;z-index:1000}.legend-item{display:flex;align-items:center;margin-bottom:10px;cursor:pointer;gap:10px;transition:background-color .3s ease;border-radius:6px;padding:6px 8px}.legend-item.inactive .legend-label>.legend-icon,.legend-item.inactive .legend-label>span:not(:last-child){opacity:.4;user-select:none}.legend-item:last-child{margin-bottom:0}.legend-item:hover{background-color:#e0f7fa}.legend-label{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;flex-grow:1}.legend-icon{width:24px;height:24px;filter:grayscale(60%);transition:filter .3s ease,transform .3s ease;pointer-events:none}.legend-item input[type=checkbox]{display:none}.legend-item input[type=checkbox]:checked+.legend-label .legend-icon{filter:none;transform:scale(1.1)}.checkbox-box{width:18px;height:18px;border:2px solid #555;border-radius:4px;display:flex;align-items:center;justify-content:center;background-color:#fff;position:relative;transition:background-color .3s ease,border-color .3s ease}.checkbox-box::after{content:"✔";color:green;font-size:14px;display:none}.legend-item input[type=checkbox]:checked+.legend-label .checkbox-box::after{display:block}.info-icon{margin-left:auto;font-size:14px;background:#007bff;color:#fff;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:default;position:relative;font-family:sans-serif}.tooltip-box{position:absolute;background:#333;color:#fff;padding:10px 12px;border-radius:6px;font-size:13px;white-space:normal;min-width:220px;max-width:360px;box-shadow:0 2px 6px rgba(0,0,0,.2);opacity:0;transition:opacity .2s ease;z-index:1000;pointer-events:none;word-wrap:break-word;line-height:1.4}.tooltip-box.show{opacity:1}.modal{position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,100,150,.4);display:flex;align-items:center;justify-content:center;box-sizing:border-box}.logo{display:flex;align-items:center;justify-content:center;gap:8px;font-family:Quicksand,sans-serif;font-size:2.5em;font-weight:700;color:#0277bd;margin-bottom:25px}.logo-icon{width:60px;height:60px;display:block}.logo-text{text-transform:uppercase;letter-spacing:1px;margin-top:-6px}@media screen and (max-width:440px){.logo-text{font-size:1.8rem}}.modal-content{background:#fff;padding:30px;max-width:600px;width:calc(100% - 15px);border-radius:12px;position:relative;box-shadow:0 8px 20px rgba(0,0,0,.2);text-align:center;color:#01579b;box-sizing:border-box}.modal-content p{font-size:1.2em;line-height:1.6}.modal-content strong{color:#0277bd}.modal-content p.production{font-size:1rem;color:#176c9e;margin-top:15px;margin-bottom:10px;text-align:center}.production a{color:#1e90ff;text-decoration:none}.production a:hover{text-decoration:underline}.update-date{margin-top:25px;font-size:.9em;color:#4fc3f7}.close-button{position:absolute;top:10px;right:15px;font-size:26px;font-weight:700;color:#01579b;cursor:pointer;transition:color .3s ease}.close-button:hover{color:#0288d1}@media (max-width:480px){.modal-content h1{font-size:1.8em}.modal-content p{font-size:1em}}