.mapboxgl-map{font:12px/20px Helvetica Neue,Arial,Helvetica,sans-serif;overflow:hidden;position:relative;-webkit-tap-highlight-color:rgb(0 0 0/0)}.mapboxgl-canvas{left:0;position:absolute;top:0}.mapboxgl-map:-webkit-full-screen{height:100%;width:100%}.mapboxgl-canary{background-color:salmon}.mapboxgl-canvas-container.mapboxgl-interactive,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass{cursor:grab;-webkit-user-select:none;user-select:none}.mapboxgl-canvas-container.mapboxgl-interactive.mapboxgl-track-pointer{cursor:pointer}.mapboxgl-canvas-container.mapboxgl-interactive:active,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass:active{cursor:grabbing}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-canvas-container.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:pinch-zoom}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:none}.mapboxgl-ctrl-bottom,.mapboxgl-ctrl-bottom-left,.mapboxgl-ctrl-bottom-right,.mapboxgl-ctrl-left,.mapboxgl-ctrl-right,.mapboxgl-ctrl-top,.mapboxgl-ctrl-top-left,.mapboxgl-ctrl-top-right{pointer-events:none;position:absolute;z-index:2}.mapboxgl-ctrl-top-left{left:0;top:0}.mapboxgl-ctrl-top{left:50%;top:0;transform:translate(-50%)}.mapboxgl-ctrl-top-right{right:0;top:0}.mapboxgl-ctrl-right{right:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl-bottom-right{bottom:0;right:0}.mapboxgl-ctrl-bottom{bottom:0;left:50%;transform:translate(-50%)}.mapboxgl-ctrl-bottom-left{bottom:0;left:0}.mapboxgl-ctrl-left{left:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl{clear:both;pointer-events:auto;transform:translate(0)}.mapboxgl-ctrl-top-left .mapboxgl-ctrl{float:left;margin:10px 0 0 10px}.mapboxgl-ctrl-top .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-top-right .mapboxgl-ctrl{float:right;margin:10px 10px 0 0}.mapboxgl-ctrl-bottom-right .mapboxgl-ctrl,.mapboxgl-ctrl-right .mapboxgl-ctrl{float:right;margin:0 10px 10px 0}.mapboxgl-ctrl-bottom .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl,.mapboxgl-ctrl-left .mapboxgl-ctrl{float:left;margin:0 0 10px 10px}.mapboxgl-ctrl-group{background:#fff;border-radius:4px}.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px #0000001a}@media (-ms-high-contrast:active){.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px ButtonText}}.mapboxgl-ctrl-group button{background-color:initial;border:0;box-sizing:border-box;cursor:pointer;display:block;height:29px;outline:none;overflow:hidden;padding:0;width:29px}.mapboxgl-ctrl-group button+button{border-top:1px solid #ddd}.mapboxgl-ctrl button .mapboxgl-ctrl-icon{background-position:50%;background-repeat:no-repeat;display:block;height:100%;width:100%}@media (-ms-high-contrast:active){.mapboxgl-ctrl-icon{background-color:initial}.mapboxgl-ctrl-group button+button{border-top:1px solid ButtonText}}.mapboxgl-ctrl-attrib-button:focus,.mapboxgl-ctrl-group button:focus{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl button:disabled{cursor:not-allowed}.mapboxgl-ctrl button:disabled .mapboxgl-ctrl-icon{opacity:.25}.mapboxgl-ctrl-group button:first-child{border-radius:4px 4px 0 0}.mapboxgl-ctrl-group button:last-child{border-radius:0 0 4px 4px}.mapboxgl-ctrl-group button:only-child{border-radius:inherit}.mapboxgl-ctrl button:not(:disabled):hover{background-color:#0000000d}.mapboxgl-ctrl-group button:focus:focus-visible{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl-group button:focus:not(:focus-visible){box-shadow:none}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23999'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23333'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23aaa'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-waiting .mapboxgl-ctrl-icon{animation:mapboxgl-spin 2s linear infinite}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23999'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23000'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23666'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}}@keyframes mapboxgl-spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='0.3' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='0.9' fill='%23fff'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;cursor:pointer;display:block;height:23px;margin:0 0 -4px -4px;overflow:hidden;width:88px}a.mapboxgl-ctrl-logo.mapboxgl-compact{width:23px}@media (-ms-high-contrast:active){a.mapboxgl-ctrl-logo{background-color:initial;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='1' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='1' fill='%23fff'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='1' stroke='%23fff' stroke-width='3' fill='%23fff'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='1' fill='%23000'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E")}}.mapboxgl-ctrl.mapboxgl-ctrl-attrib{background-color:#ffffff80;margin:0;padding:0 5px}@media screen{.mapboxgl-ctrl-attrib.mapboxgl-compact{background-color:#fff;border-radius:12px;box-sizing:initial;margin:10px;min-height:20px;padding:2px 24px 2px 0;position:relative}.mapboxgl-ctrl-attrib.mapboxgl-compact-show{padding:2px 28px 2px 8px;visibility:visible}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show{border-radius:12px;padding:2px 8px 2px 28px}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner{display:none}.mapboxgl-ctrl-attrib-button{background-color:#ffffff80;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E");border:0;border-radius:12px;box-sizing:border-box;cursor:pointer;display:none;height:24px;outline:none;position:absolute;right:0;top:0;width:24px}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-top-left .mapboxgl-ctrl-attrib-button{left:0}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-inner{display:block}.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-button{background-color:#0000000d}.mapboxgl-ctrl-bottom-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;right:0}.mapboxgl-ctrl-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0}.mapboxgl-ctrl-top-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0;top:0}.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0;top:0}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;left:0}.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0}}@media screen and (-ms-high-contrast:active){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd' fill='%23fff'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}@media screen and (-ms-high-contrast:black-on-white){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}.mapboxgl-ctrl-attrib a{color:#000000bf;text-decoration:none}.mapboxgl-ctrl-attrib a:hover{color:inherit;text-decoration:underline}.mapboxgl-ctrl-attrib .mapbox-improve-map{font-weight:700;margin-left:2px}.mapboxgl-attrib-empty{display:none}.mapboxgl-ctrl-scale{background-color:#ffffffbf;border:2px solid #333;border-top:#333;box-sizing:border-box;color:#333;font-size:10px;padding:0 5px;white-space:nowrap}.mapboxgl-popup{display:flex;left:0;pointer-events:none;position:absolute;top:0;will-change:transform}.mapboxgl-popup-anchor-top,.mapboxgl-popup-anchor-top-left,.mapboxgl-popup-anchor-top-right{flex-direction:column}.mapboxgl-popup-anchor-bottom,.mapboxgl-popup-anchor-bottom-left,.mapboxgl-popup-anchor-bottom-right{flex-direction:column-reverse}.mapboxgl-popup-anchor-left{flex-direction:row}.mapboxgl-popup-anchor-right{flex-direction:row-reverse}.mapboxgl-popup-tip{border:10px solid #0000;height:0;width:0;z-index:1}.mapboxgl-popup-anchor-top .mapboxgl-popup-tip{align-self:center;border-bottom-color:#fff;border-top:none}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom-color:#fff;border-left:none;border-top:none}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom-color:#fff;border-right:none;border-top:none}.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip{align-self:center;border-bottom:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom:none;border-left:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom:none;border-right:none;border-top-color:#fff}.mapboxgl-popup-anchor-left .mapboxgl-popup-tip{align-self:center;border-left:none;border-right-color:#fff}.mapboxgl-popup-anchor-right .mapboxgl-popup-tip{align-self:center;border-left-color:#fff;border-right:none}.mapboxgl-popup-close-button{background-color:initial;border:0;border-radius:0 3px 0 0;cursor:pointer;position:absolute;right:0;top:0}.mapboxgl-popup-close-button:hover{background-color:#0000000d}.mapboxgl-popup-content{background:#fff;border-radius:3px;box-shadow:0 1px 2px #0000001a;padding:10px 10px 15px;pointer-events:auto;position:relative}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-content{border-top-left-radius:0}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-content{border-top-right-radius:0}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-content{border-bottom-left-radius:0}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-content{border-bottom-right-radius:0}.mapboxgl-popup-track-pointer{display:none}.mapboxgl-popup-track-pointer *{pointer-events:none;-webkit-user-select:none;user-select:none}.mapboxgl-map:hover .mapboxgl-popup-track-pointer{display:flex}.mapboxgl-map:active .mapboxgl-popup-track-pointer{display:none}.mapboxgl-marker{left:0;opacity:1;position:absolute;top:0;transition:opacity .2s;will-change:transform}.mapboxgl-user-location-dot,.mapboxgl-user-location-dot:before{background-color:#1da1f2;border-radius:50%;height:15px;width:15px}.mapboxgl-user-location-dot:before{animation:mapboxgl-user-location-dot-pulse 2s infinite;content:"";position:absolute}.mapboxgl-user-location-dot:after{border:2px solid #fff;border-radius:50%;box-shadow:0 0 3px #00000059;box-sizing:border-box;content:"";height:19px;left:-2px;position:absolute;top:-2px;width:19px}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading{height:0;width:0}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after,.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-bottom:7.5px solid #4aa1eb;content:"";position:absolute}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-left:7.5px solid #0000;transform:translateY(-28px) skewY(-20deg)}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after{border-right:7.5px solid #0000;transform:translate(7.5px,-28px) skewY(20deg)}@keyframes mapboxgl-user-location-dot-pulse{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(3)}to{opacity:0;transform:scale(1)}}.mapboxgl-user-location-dot-stale{background-color:#aaa}.mapboxgl-user-location-dot-stale:after{display:none}.mapboxgl-user-location-accuracy-circle{background-color:#1da1f233;border-radius:100%;height:1px;width:1px}.mapboxgl-crosshair,.mapboxgl-crosshair .mapboxgl-interactive,.mapboxgl-crosshair .mapboxgl-interactive:active{cursor:crosshair}.mapboxgl-boxzoom{background:#fff;border:2px dotted #202020;height:0;left:0;opacity:.5;position:absolute;top:0;width:0}@media print{.mapbox-improve-map{display:none}}.mapboxgl-scroll-zoom-blocker,.mapboxgl-touch-pan-blocker{align-items:center;background:#000000b3;color:#fff;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;height:100%;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;text-align:center;top:0;transition:opacity .75s ease-in-out;transition-delay:1s;width:100%}.mapboxgl-scroll-zoom-blocker-show,.mapboxgl-touch-pan-blocker-show{opacity:1;transition:opacity .1s ease-in-out}.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page,.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-ctrl-separator{background-color:#e0e0e0;height:1px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button{color:#333;font-size:18px;font-weight:700;height:44px;width:44px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:hover{background-color:#f5f5f5}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button-selected{background-color:#4a5568;color:#fff}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button-selected:hover{background-color:#2d3748}.stats-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.stats-modal{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d}.stats-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:#79a9f5 0%;color:#fff}.stats-modal-title{display:flex;align-items:center;gap:12px}.stats-modal-title h2{margin:0;font-size:20px;font-weight:600}.stats-subtitle{display:block;font-size:13px;opacity:.9;margin-top:2px}.stats-modal-close{background:#fff3;border:none;border-radius:8px;padding:8px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s}.stats-modal-close:hover{background:#ffffff4d}.stats-modal-tabs{display:flex;gap:4px;padding:12px 24px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.stats-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;background:none;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.stats-tab:hover{background:#e2e8f0;color:#334155}.stats-tab.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.stats-modal-content{flex:1;overflow-y:auto;padding:24px}.stats-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-card{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.summary-card.highlight{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.summary-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff;border-radius:10px;color:#3b82f6;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.summary-card.highlight .summary-icon{background:#22c55e;color:#fff}.summary-info{flex:1}.summary-label{display:block;font-size:16px;color:#2a394e;margin-bottom:4px}.summary-value{display:block;font-size:20px;font-weight:700;color:#1e293b}.summary-detail{display:block;font-size:12px;color:#22c55e;margin-top:2px}.chart-section{margin-bottom:32px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chart-header h3{margin:0;font-size:16px;font-weight:600;color:#1e293b}.chart-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:4px}.chart-toggle button{padding:6px 16px;background:none;border:none;border-radius:6px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.chart-toggle button.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.chart-container{background:#f8fafc;border-radius:12px;padding:20px;min-height:300px}.no-data{display:flex;align-items:center;justify-content:center;height:200px;color:#94a3b8;font-size:14px}.stats-chart-tooltip{background:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;border:1px solid #e2e8f0}.tooltip-name{font-weight:600;color:#1e293b;margin:0 0 4px}.tooltip-value{font-size:18px;font-weight:700;color:#3b82f6;margin:0}.tooltip-area{font-size:12px;color:#64748b;margin:4px 0 0}.stats-chart-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:16px}.legend-item{display:flex;align-items:center;gap:6px;font-size:13px}.legend-color{width:12px;height:12px;border-radius:3px}.legend-label{color:#334155}.legend-percent{color:#64748b;font-weight:500}.top-varieties{margin-bottom:16px}.top-varieties h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#1e293b}.top-varieties-list{display:flex;flex-direction:column;gap:12px}.top-variety-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.variety-rank{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.variety-details{flex:1;min-width:0}.variety-details .variety-name{display:block;font-weight:500;color:#1e293b;margin-bottom:6px}.variety-bar-container{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.variety-bar{height:100%;border-radius:3px;transition:width .3s ease}.variety-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.variety-area{font-size:13px;color:#64748b}.variety-percent{font-size:15px;font-weight:700;color:#1e293b}.varieties-table-section{overflow:hidden}.table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.table-header h3{margin:0;font-size:16px;font-weight:600;color:#1e293b}.varieties-table-wrapper{overflow-x:auto;border:1px solid #e2e8f0;border-radius:12px}.varieties-table{width:100%;border-collapse:collapse;font-size:14px}.varieties-table th{padding:12px 16px;text-align:left;font-weight:600;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}.varieties-table th.text-right{text-align:right}.varieties-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#334155}.varieties-table td.text-right{text-align:right;font-variant-numeric:tabular-nums}.varieties-table tbody tr:hover{background:#f8fafc}.varieties-table tbody tr:last-child td{border-bottom:none}.varieties-table tfoot{background:#f8fafc}.varieties-table tfoot td{padding:12px 16px;border-top:2px solid #e2e8f0;border-bottom:none}.rank-cell{width:50px}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;color:#fff;font-weight:600;font-size:12px}.variety-cell{font-weight:500}.percent-cell{display:flex;align-items:center;gap:12px;justify-content:flex-end}.percent-bar-container{width:80px;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.percent-bar{height:100%;border-radius:3px}.stats-modal-footer{padding:12px 24px;background:#f8fafc;border-top:1px solid #e2e8f0;text-align:center}.stats-source{font-size:12px;color:#94a3b8}@media (max-width: 768px){.stats-modal-overlay{padding:0}.stats-modal{max-width:100%;max-height:100vh;border-radius:0}.stats-modal-header{padding:16px}.stats-modal-title h2{font-size:18px}.stats-modal-tabs{padding:8px 16px;overflow-x:auto}.stats-tab{padding:8px 16px;white-space:nowrap}.stats-modal-content{padding:16px}.stats-summary-grid{grid-template-columns:1fr}.chart-header{flex-direction:column;align-items:flex-start;gap:12px}.top-variety-item{flex-wrap:wrap}.variety-details{width:100%;order:2}.variety-stats{flex-direction:row;gap:12px}.percent-cell{flex-direction:column;align-items:flex-end;gap:4px}.percent-bar-container{width:60px}}@media (max-width: 480px){.stats-modal-title{flex-direction:column;align-items:flex-start;gap:4px}.stats-modal-title svg{display:none}.summary-card{padding:12px}.summary-value{font-size:18px}}.map-canvas{width:100%;height:100%}.query-loading{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#fff;padding:12px 24px;border-radius:8px;box-shadow:0 2px 8px #00000026;display:flex;align-items:center;gap:12px;z-index:10;animation:slideDown .3s ease}.loading-spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#22c55e;border-radius:50%;animation:spin .6s linear infinite}.query-error{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#fef2f2;color:#dc2626;padding:12px 24px;border-radius:8px;border:1px solid #fecaca;display:flex;align-items:center;gap:12px;z-index:10;animation:slideDown .3s ease;max-width:400px}.query-error button{background:none;border:none;color:#dc2626;font-size:20px;cursor:pointer;padding:0;margin-left:auto}.map-auth-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:24px 32px;border-radius:12px;box-shadow:0 4px 16px #0000001a;text-align:center;z-index:5;max-width:400px}.auth-message h3{margin:0 0 8px;color:#1f2937;font-size:18px}.auth-message p{margin:0;color:#6b7280;font-size:14px}.map-sidebar{position:absolute;top:20px;left:20px;width:280px;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;z-index:10;transition:transform .3s ease}.map-sidebar.collapsed{transform:translate(-100%)}.sidebar-toggle{position:absolute;top:16px;right:-40px;background:#fff;border:none;border-radius:0 8px 8px 0;padding:12px 8px;cursor:pointer;box-shadow:2px 0 8px #0000001a;transition:background .2s}.sidebar-toggle:hover{background:#f9fafb}.sidebar-content{padding:16px;max-height:500px;overflow-y:auto}.sidebar-section{margin-bottom:12px;border-bottom:1px solid #e5e7eb;padding-bottom:12px}.sidebar-section:last-child{border-bottom:none;margin-bottom:0}.section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px;background:none;border:none;cursor:pointer;border-radius:6px;transition:background .2s}.section-header:hover{background:#f9fafb}.section-title{display:flex;align-items:center;gap:8px;font-weight:600;color:#1f2937;font-size:14px}.section-title svg{color:#22c55e}.chevron{transition:transform .2s;color:#9ca3af}.chevron.rotated{transform:rotate(90deg)}.section-content{padding:12px 8px;animation:slideDown .2s ease}.style-options{display:flex;flex-direction:column;gap:8px}.style-btn{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px}.style-btn:hover{border-color:#22c55e;background:#f0fdf4}.style-btn.active{border-color:#22c55e;background:#dcfce7;font-weight:600}.style-icon{font-size:18px}.style-name{flex:1;text-align:left}.layer-item{padding:8px 0;border-bottom:1px solid #f3f4f6}.layer-item:last-child{border-bottom:none}.layer-item.disabled{opacity:.5;pointer-events:none}.layer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.layer-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#374151}.layer-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#22c55e}.coming-soon{font-size:11px;color:#9ca3af;font-style:italic}.opacity-control{margin-top:8px;padding-left:24px}.opacity-control label{font-size:12px;color:#6b7280;display:block;margin-bottom:6px}.opacity-slider{width:100%;height:4px;border-radius:2px;background:#e5e7eb;outline:none;cursor:pointer}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#22c55e;cursor:pointer;transition:transform .2s}.opacity-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.opacity-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#22c55e;border:none;cursor:pointer;transition:transform .2s}.opacity-slider::-moz-range-thumb:hover{transform:scale(1.2)}.regions-list{display:flex;flex-direction:column;gap:6px}.region-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151;text-align:left}.region-btn:hover{border-color:#22c55e;background:#f0fdf4;color:#22c55e}.region-btn svg{flex-shrink:0}.legend-content{font-size:13px}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:8px}.legend-color{width:20px;height:20px;border-radius:4px;border:1px solid #e5e7eb;flex-shrink:0}.legend-note{font-size:12px;color:#6b7280;font-style:italic;margin:8px 0 0}.sidebar-collapsed-buttons{position:absolute;top:20px;left:20px;display:flex;flex-direction:column;gap:8px;z-index:10}.collapsed-btn{background:#fff;border:none;border-radius:8px;padding:12px;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .2s}.collapsed-btn:hover{background:#f0fdf4;transform:scale(1.05)}.collapsed-btn svg{color:#22c55e}.block-popup-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease}.block-popup{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;max-width:450px;width:90%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;border-bottom:1px solid #e5e7eb;background:linear-gradient(to bottom,#f9fafb,#fff)}.popup-header h3{margin:0;font-size:20px;color:#1f2937;font-weight:700}.popup-close-btn{background:#f3f4f6;border:none;color:#1f2937;padding:4px;border-radius:4px;transition:all .2s}.popup-close-btn:hover{background:#f3f4f6;color:#1f2937}.popup-content{padding:20px 24px;overflow-y:auto;flex:1}.popup-row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid #f3f4f6}.popup-row:last-child{border-bottom:none}.popup-icon{color:#22c55e;flex-shrink:0;margin-top:2px}.popup-details{flex:1;display:flex;flex-direction:column;gap:4px}.popup-label{font-size:12px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.popup-value{font-size:15px;color:#1f2937;font-weight:500}.popup-badges{padding:12px 0;display:flex;flex-direction:column;gap:8px}.badge-list{display:flex;flex-wrap:wrap;gap:8px}.sustainability-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1.5px solid;border-radius:20px;font-size:13px;font-weight:500;background:#fff}.popup-footer{padding:16px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.report-issue-btn{width:100%;padding:10px 16px;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.report-issue-btn:hover{border-color:#22c55e;color:#22c55e;background:#f0fdf4}.report-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}.report-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:500px;max-height:calc(100vh - 40px);display:flex;flex-direction:column;animation:modalSlideUp .3s ease}@keyframes modalSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.report-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.report-modal-header h3{margin:0;font-size:20px;font-weight:700;color:#1f2937}.report-modal-close{background:#f3f4f6;border:none;border-radius:8px;padding:8px;cursor:pointer;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center}.report-modal-close:hover{background:#e5e7eb;color:#1f2937}.report-modal-context{padding:12px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:14px;flex-shrink:0}.context-label{font-weight:600;color:#6b7280}.context-value{color:#1f2937}.context-separator{color:#d1d5db}.report-modal-body{padding:24px;overflow-y:auto;flex:1;min-height:0}.report-modal-body .report-issue-form h4{display:none}@media (max-width: 768px){.report-modal-overlay{padding:0;align-items:flex-end}.report-modal{max-width:100%;max-height:90vh;border-radius:20px 20px 0 0;animation:modalSlideUpMobile .3s ease}@keyframes modalSlideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.report-modal-header{padding:16px 20px}.report-modal-header h3{font-size:18px}.report-modal-close{width:40px;height:40px}.report-modal-context{padding:10px 20px;font-size:13px}.report-modal-body{padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom))}}@media (max-width: 480px){.report-modal{max-height:95vh}.report-modal-header{padding:14px 16px}.report-modal-header h3{font-size:17px}.report-modal-context{padding:10px 16px;font-size:12px}.report-modal-body{padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom))}}.report-issue-form{animation:slideDown .3s ease;padding:8px 0}.report-issue-form h4{margin:0 0 16px;font-size:16px;color:#1f2937}.form-group{margin-bottom:10px}.label-hint{display:block;font-size:11px;font-weight:400;color:#6b7280;margin-top:2px;font-style:italic}.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 3px #22c55e1a}.form-group textarea{resize:vertical;min-height:80px}.form-error{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px;margin-bottom:16px}.form-actions{display:flex;gap:8px;margin-top:16px}.btn-secondary,.btn-primary{flex:1;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-primary{background:#22c55e;color:#fff}.btn-primary:hover:not(:disabled){background:#16a34a}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.form-note{font-size:11px;color:#6b7280;margin:12px 0 0;line-height:1.4}.report-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;text-align:center}.success-icon{color:#22c55e}.report-success p{margin:0;color:#374151;font-size:14px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.regional-map-container{height:500px}.map-sidebar{width:240px}.block-popup{width:95%;max-height:90vh}.popup-header,.popup-content{padding:16px 20px}.popup-footer{padding:12px 20px}}@media (max-width: 480px){.regional-map-container{height:400px;border-radius:8px}.map-sidebar{width:200px}.sidebar-content{max-height:350px}.block-popup{border-radius:12px 12px 0 0;max-height:85vh}.popup-header h3{font-size:18px}.form-actions{flex-direction:column}}.layer-toggle-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f1f5f9;border:none;border-radius:6px;cursor:pointer;color:#64748b;transition:all .2s;flex-shrink:0}.layer-toggle-btn:hover{background:#e2e8f0;color:#334155}.layer-icon-grape{color:#22c55e;flex-shrink:0}.layer-icon-region{color:#3b82f6;flex-shrink:0}.layer-icon-gi{color:#8b5cf6;flex-shrink:0}.region-area{font-size:10px;font-weight:500;color:#64748b;background:#e2e8f0;padding:2px 8px;border-radius:10px;margin-left:auto}.region-btn{display:flex;align-items:center;gap:8px;width:100%}.region-btn .region-name{flex:1;text-align:left}.loading-regions{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;color:#64748b;font-size:13px}.loading-spinner.small{width:16px;height:16px}.region-popup,.gi-popup{position:absolute;top:5;right:0;bottom:0;left:5;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;width:320px;max-width:calc(100vw - 32px);overflow:hidden;z-index:100;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.popup-close-btn{background:#fff3;border:none;border-radius:6px;padding:4px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s}.popup-close-btn:hover{background:#ffffff4d}.popup-loading,.popup-error{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px;color:#64748b}.popup-error{color:#ef4444}.popup-footer{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:#f8fafc;border-top:1px solid #e2e8f0;font-size:11px;color:#94a3b8}.region-popup-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.region-popup-title{display:flex;align-items:center;gap:8px}.region-popup-title h3{margin:0;font-size:16px;font-weight:600}.region-popup-content{padding:16px}.region-summary{margin:0 0 16px;font-size:13px;line-height:1.5;color:#475569}.region-stats{display:flex;gap:12px;margin-bottom:16px;padding:12px;background:#f8fafc;border-radius:8px}.stat-item{flex:1;text-align:center}.stat-label{display:block;font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{display:block;font-size:18px;font-weight:600;color:#1e293b}.region-varieties{margin-bottom:16px}.region-varieties h4{display:flex;align-items:center;gap:6px;margin:0 0 8px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.variety-list{display:flex;flex-direction:column;gap:6px}.variety-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#f1f5f9;border-radius:6px;font-size:13px}.variety-name{color:#334155;font-weight:500}.variety-percent{color:#3b82f6;font-weight:600}.region-climate{margin-bottom:16px}.region-climate h4{margin:0 0 6px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.region-climate p{margin:0;font-size:13px;line-height:1.4;color:#475569}.region-action-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.region-action-btn:hover{background:#2563eb}.gi-popup-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.gi-popup-title{display:flex;align-items:center;gap:8px}.gi-popup-title h3{margin:0;font-size:16px;font-weight:600}.gi-popup-content{padding:16px}.gi-status-row{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.gi-status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.gi-status-badge.status-registered{background:#dcfce7;color:#166534}.gi-status-badge.status-pending{background:#fef3c7;color:#92400e}.gi-status-badge.status-expired{background:#fee2e2;color:#991b1b}.gi-region-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#f1f5f9;border-radius:20px;font-size:12px;color:#64748b}.gi-info{margin-bottom:16px}.gi-info h4{margin:0 0 12px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.gi-info-grid{display:grid;gap:8px}.gi-info-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8fafc;border-radius:6px}.gi-info-label{font-size:12px;color:#64748b}.gi-info-value{font-size:13px;font-weight:600;color:#1e293b}.gi-notes{margin-bottom:16px;padding:12px;background:#fefce8;border-radius:8px;border-left:3px solid #eab308}.gi-notes p{margin:0;font-size:13px;line-height:1.4;color:#713f12}.gi-link-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;background:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;text-decoration:none;cursor:pointer;transition:background .2s}.gi-link-btn:hover{background:#7c3aed;color:#fff}@media (max-width: 640px){.region-popup,.gi-popup{top:auto;bottom:16px;right:16px;left:16px;width:auto}}.mobile-sidebar-overlay{display:none;position:absolute;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:15}.map-sidebar-mobile{display:none;position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;z-index:20;transition:transform .3s ease}.map-sidebar-mobile:not(.expanded){transform:translateY(0)}.map-sidebar-mobile.expanded{max-height:50%}.mobile-sidebar-header{display:flex;flex-direction:column;align-items:center;width:100%;padding:10px 16px 14px;background:#fff;border:none;border-radius:16px 16px 0 0;cursor:pointer;touch-action:manipulation}.mobile-drag-handle{width:40px;height:4px;background:#d1d5db;border-radius:2px;margin-bottom:10px}.mobile-header-content{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#1f2937;width:100%;justify-content:center}.mobile-header-content svg:first-child{color:#22c55e}.mobile-header-content svg:last-child{color:#6b7280}.mobile-sidebar-content{max-height:calc(50vh - 60px);overflow-y:auto;border-top:1px solid #e5e7eb}.mobile-sidebar-content .sidebar-content{max-height:none;padding:12px 16px 20px}.map-sidebar-mobile .sidebar-section{margin-bottom:8px;padding-bottom:8px}.map-sidebar-mobile .section-header{padding:10px 8px}.map-sidebar-mobile .section-title{font-size:13px}.map-sidebar-mobile .style-options{display:flex;gap:8px}.map-sidebar-mobile .style-btn{flex:1;min-width:0;padding:10px 8px}.map-sidebar-mobile .style-name{font-size:12px}.map-sidebar-mobile .regions-list{display:grid;grid-template-columns:1fr 1fr;gap:6px}.map-sidebar-mobile .region-btn{padding:10px;font-size:12px}.map-sidebar-mobile .region-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-sidebar-mobile .region-area{display:none}.map-sidebar-mobile .layer-item{padding:6px 0}.map-sidebar-mobile .layer-label{font-size:13px}.map-sidebar-mobile .opacity-control label{font-size:11px}.map-sidebar-mobile .legend-content{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.map-sidebar-mobile .legend-item{font-size:11px}.map-sidebar-mobile .legend-note{width:100%;font-size:11px;margin-top:6px}@media (max-width: 768px){.map-sidebar,.sidebar-collapsed-buttons{display:none!important}.mobile-sidebar-overlay,.map-sidebar-mobile{display:block}.regional-map-container{height:500px}}@media (max-width: 480px){.regional-map-container{height:400px;border-radius:8px}.map-sidebar-mobile .regions-list{grid-template-columns:1fr}.map-sidebar-mobile .style-options{flex-direction:column}.map-sidebar-mobile .style-btn{width:100%}}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-sidebar-content{padding-bottom:env(safe-area-inset-bottom)}}@media (max-width: 768px){.region-popup{position:absolute;top:auto!important;right:12px!important;bottom:70px!important;left:12px!important;width:auto!important;max-width:none!important;max-height:280px!important;overflow:hidden;border-radius:12px}.region-popup-header{padding:10px 14px}.region-popup-title h3{font-size:15px}.region-popup-title svg{width:16px;height:16px}.region-popup-content{padding:12px 14px;max-height:180px;overflow-y:auto}.region-summary{font-size:13px;line-height:1.4;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.region-stats{padding:8px 10px;margin-bottom:10px}.region-stats .stat-item{padding:6px 0}.region-stats .stat-label{font-size:11px}.region-stats .stat-value{font-size:14px}.region-varieties{margin-bottom:10px}.region-varieties h4{font-size:12px;margin-bottom:6px}.variety-list{gap:4px}.variety-item{padding:5px 8px;font-size:12px}.region-climate{display:none}.region-action-btn{padding:10px 14px;font-size:13px}.region-popup .popup-footer{padding:6px 14px;font-size:10px}}@media (max-width: 480px){.region-popup{right:8px!important;left:8px!important;bottom:65px!important;max-height:250px!important}.region-popup-header{padding:8px 12px}.region-popup-title h3{font-size:14px}.region-popup-content{padding:10px 12px;max-height:160px}.variety-item:nth-child(n+3){display:none}}.regional-map-container{position:relative;width:100%;height:700px;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}@media (max-width: 768px){.regional-map-container{height:calc(100dvh - 180px);min-height:450px;max-height:600px;border-radius:8px}}@media (max-width: 480px){.regional-map-container{height:calc(100dvh - 140px);min-height:400px;max-height:none;border-radius:0;margin-left:-16px;margin-right:-16px;width:calc(100% + 32px);box-shadow:none}}@media (max-width: 375px){.regional-map-container{height:calc(100dvh - 120px);min-height:350px}}@media (max-width: 768px) and (orientation: landscape){.regional-map-container{height:calc(100dvh - 80px);min-height:280px;max-height:none}}@media (max-width: 768px){.block-popup-overlay{padding:16px;align-items:flex-end}.block-popup{max-width:100%;width:100%;max-height:85vh;border-radius:16px 16px 0 0;margin-bottom:0;animation:slideUpMobile .3s ease;display:flex;flex-direction:column}.popup-header{padding:12px 16px;position:sticky;top:0;z-index:1;background:#fff;flex-shrink:0}.popup-header h3{font-size:18px;padding-right:40px}.popup-close-btn{position:absolute;top:8px;right:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f3f4f6}.popup-content{padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;min-height:0}.popup-row{padding:10px 0}.popup-label{font-size:11px}.popup-value{font-size:14px}.popup-footer{padding:12px 16px;position:sticky;bottom:0;background:#f9fafb}}@media (max-width: 480px){.block-popup-overlay{padding:0}.block-popup{max-height:90vh;border-radius:20px 20px 0 0}.popup-header{padding:16px 16px 12px}.popup-header h3{font-size:16px}.popup-content{padding:12px 16px}.popup-row{padding:8px 0;gap:10px}.popup-icon svg{width:16px;height:16px}.badge-list{gap:6px}.sustainability-badge{padding:5px 10px;font-size:12px}.popup-footer{padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom))}.report-issue-btn{padding:12px 16px;font-size:14px;min-height:44px}}@media (max-width: 375px){.block-popup{max-height:80vh}.popup-header h3{font-size:15px}.popup-value{font-size:13px}.sustainability-badge{padding:4px 8px;font-size:11px}}@media (max-width: 768px){.report-issue-form h4{font-size:15px;margin-bottom:12px}.form-group{margin-bottom:12px}.form-group label{font-size:12px}.label-hint{font-size:10px}.form-group select,.form-group textarea{padding:12px;font-size:16px;border-radius:10px}.form-group textarea{min-height:70px}.form-actions{flex-direction:column-reverse;gap:10px}.btn-secondary,.btn-primary{min-height:48px;font-size:15px;border-radius:10px}.form-note{font-size:11px;text-align:center;margin-top:12px}}@media (max-width: 480px){.form-group select,.form-group textarea{padding:14px 12px}.btn-secondary,.btn-primary{min-height:50px}}@media (max-width: 768px){.query-loading,.blocks-loading,.query-error{top:12px;padding:10px 16px;font-size:13px;max-width:calc(100% - 24px)}}@media (max-width: 480px){.query-loading,.blocks-loading,.query-error{top:8px;left:8px;right:8px;transform:none;border-radius:8px}}@media (max-width: 768px){.map-auth-overlay{bottom:80px;padding:16px 20px;left:12px;right:12px;transform:none;width:auto;max-width:none}.auth-message h3{font-size:16px}.auth-message p{font-size:13px}}@media (max-width: 480px){.map-auth-overlay{bottom:70px;left:8px;right:8px;padding:14px 16px;border-radius:10px}.auth-message h3{font-size:15px}.auth-message p{font-size:12px}}.popup-drag-handle{display:none}@media (max-width: 768px){.popup-drag-handle{display:flex;justify-content:center;padding:12px 0 4px;cursor:grab}.drag-handle-bar{width:36px;height:4px;background:#d1d5db;border-radius:2px}.block-popup .popup-header{padding-top:8px}}@keyframes slideUpMobile{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.popup-close-btn,.report-issue-btn,.btn-primary,.btn-secondary,.region-btn,.style-btn,.layer-toggle-btn{min-height:44px;min-width:44px}button{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.popup-close-btn:active,.report-issue-btn:active,.btn-primary:active,.btn-secondary:active{transform:scale(.97);opacity:.9}}.layer-toggle-btn{background:none;border:none;padding:4px;cursor:pointer;color:#22c55e;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.layer-toggle-btn:hover{background:#f0fdf4}.layer-icon-grape{color:#22c55e}.layer-icon-region{color:#3b82f6}.layer-icon-gi{color:#961111}@media (max-width: 768px){.layer-toggle-btn{padding:10px;margin:-6px 2px -6px -6px}}.report-issue-form{animation:slideDown .3s ease;width:100%;box-sizing:border-box}.report-issue-form h4{margin:0 0 16px;font-size:16px;color:#1f2937;font-weight:600}.form-group{margin-bottom:16px}.form-group:last-of-type{margin-bottom:12px}.form-group label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.label-hint{display:block;font-size:12px;font-weight:400;color:#6b7280;margin-top:4px;font-style:italic;line-height:1.4;background:#f9fafb;padding:6px 8px;border-radius:6px;border-left:3px solid #22c55e}.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1.5px solid #d1d5db;border-radius:10px;font-size:15px;font-family:inherit;transition:border-color .2s,box-shadow .2s;background-color:#fff;box-sizing:border-box}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 3px #22c55e26}.form-group textarea{resize:vertical;min-height:100px;line-height:1.5}.form-error{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;font-size:13px;margin-bottom:16px;line-height:1.4}.form-error svg{flex-shrink:0;margin-top:1px}.form-actions{display:flex;gap:12px;margin-top:20px}.btn-secondary,.btn-primary{flex:1;padding:12px 18px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;min-height:48px}.btn-secondary{background:#f3f4f6;color:#374151;border:1.5px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb;border-color:#d1d5db}.btn-primary{background:#22c55e;color:#fff;box-shadow:0 2px 4px #22c55e33}.btn-primary:hover:not(:disabled){background:#16a34a;box-shadow:0 4px 8px #22c55e4d}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.form-note{font-size:12px;color:#6b7280;margin:16px 0 0;line-height:1.5;text-align:center;padding:0 8px}.report-success{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;text-align:center;animation:fadeIn .3s ease}.success-icon{color:#22c55e;width:48px;height:48px}.report-success p{margin:0;color:#374151;font-size:15px;font-weight:500}@media (max-width: 768px){.report-issue-form{padding:4px 0}.report-issue-form h4{font-size:17px;margin-bottom:16px;text-align:center}.form-group{margin-bottom:18px}.form-group label{font-size:14px;margin-bottom:8px}.label-hint{font-size:12px;padding:8px 10px;margin-top:6px;margin-bottom:4px}.form-group select,.form-group textarea{font-size:16px;padding:14px 16px;border-radius:12px}.form-group select{padding-right:44px;background-position:right 14px center}.form-group textarea{min-height:90px}.form-error{padding:12px 14px;font-size:14px;border-radius:12px}.form-actions{flex-direction:column-reverse;gap:10px;margin-top:24px}.btn-secondary,.btn-primary{width:100%;min-height:52px;font-size:16px;border-radius:12px}.form-note{font-size:12px;margin-top:16px;padding:0 4px}.report-success{padding:28px 20px}.success-icon{width:44px;height:44px}.report-success p{font-size:15px}}@media (max-width: 480px){.report-issue-form h4{font-size:16px;margin-bottom:14px}.form-group{margin-bottom:16px}.form-group label{font-size:13px}.label-hint{font-size:11px;padding:8px}.form-group select,.form-group textarea{padding:14px;border-radius:10px}.form-group textarea{min-height:80px}.form-error{padding:10px 12px;font-size:13px;gap:8px}.form-actions{gap:8px;margin-top:20px}.btn-secondary,.btn-primary{min-height:50px;font-size:15px;border-radius:10px}.form-note{font-size:11px;margin-top:14px;line-height:1.4}.report-success{padding:24px 16px;gap:12px}.success-icon{width:40px;height:40px}.report-success p{font-size:14px}}@media (max-width: 375px){.report-issue-form h4{font-size:15px}.form-group label{font-size:12px}.label-hint{font-size:10px;padding:6px 8px}.form-group select,.form-group textarea{padding:12px;font-size:16px}.form-group textarea{min-height:70px}.btn-secondary,.btn-primary{min-height:48px;font-size:14px}.form-note{font-size:10px}}@media (max-width: 768px) and (orientation: landscape){.report-issue-form{padding:0}.report-issue-form h4{font-size:15px;margin-bottom:12px}.form-group{margin-bottom:12px}.form-group label{font-size:12px;margin-bottom:4px}.label-hint{font-size:10px;padding:6px 8px;margin-top:4px}.form-group select,.form-group textarea{padding:10px 12px;font-size:14px;border-radius:8px}.form-group textarea{min-height:60px}.form-actions{flex-direction:row;gap:10px;margin-top:16px}.btn-secondary,.btn-primary{min-height:44px;font-size:14px}.form-note{font-size:10px;margin-top:10px}.report-success{padding:20px 16px;flex-direction:row;gap:16px;text-align:left}.success-icon{width:32px;height:32px}}@media (max-width: 768px){.form-group select,.form-group textarea,.btn-secondary,.btn-primary{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn-secondary:active:not(:disabled),.btn-primary:active:not(:disabled){transform:scale(.98);transition:transform .1s}.form-group select:active{background-color:#f9fafb}}@media (prefers-reduced-motion: reduce){.report-issue-form,.report-success,.spinner{animation:none}.btn-secondary,.btn-primary,.form-group select,.form-group textarea{transition:none}}@supports (padding: env(safe-area-inset-bottom)){@media (max-width: 768px){.report-issue-form{padding-bottom:env(safe-area-inset-bottom)}}}@media (prefers-contrast: high){.form-group select,.form-group textarea{border-width:2px}.btn-secondary{border-width:2px;border-color:#374151}.label-hint{border-left-width:4px;background:#f3f4f6}}.landing-page{min-height:100vh;background:#fff}.landing-header{position:sticky;top:0;z-index:1000;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d}.header-brand{display:flex;align-items:center;gap:12px}.section-header{text-align:center;margin-bottom:42px;display:flex;flex-direction:column;gap:.25rem}.section-header h2{font-size:24pt;font-weight:500;color:#2f2f2f;margin:0 0 12px}.section-header p{font-size:14pt;color:#505050;margin:0}.map-section{max-width:1400px;margin:0 auto;padding:40px 24px}.map-container-wrapper{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 16px #00000014;border:1px solid #e0e0e0;margin-bottom:32px;min-height:700px}.featured-regions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:32px}.featured-region-card{background:#fdf6e3;border:1px solid rgba(91,104,48,.25);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s}.featured-region-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#d1583b}.region-icon{width:48px;height:48px;background:linear-gradient(135deg,#446145,#5b6830);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.region-info h3{margin:0 0 4px;font-size:16pt;color:#2f2f2f}.region-info p{margin:0;font-size:12pt;color:#505050}.view-all-regions{text-align:center}.view-all-btn{display:inline-block;padding:12px 32px;background:#5b6830;color:#fff;text-decoration:none;font-size:14pt;font-weight:600;border-radius:8px;transition:all .2s}.view-all-btn:hover{background:#446145;transform:translateY(-2px);box-shadow:0 4px 12px #5b68304d}.weather-section{background:#f8f9fa;padding:60px 24px}.weather-wrapper{max-width:800px;margin:0 auto}.insights-section{max-width:1400px;margin:0 auto;padding:40px 24px}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:1px}.insight-card{background:#fff;border:2px solid rgba(91,104,48,.25);border-radius:12px;padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;transition:all .3s ease;text-align:center}.insight-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #5b683033;border-color:#5b6830}.insight-card.active{background:linear-gradient(135deg,#f8fbff,#e8f4ff);border-color:#5b6830;box-shadow:0 8px 24px #5b68304d}.insight-icon{width:64px;height:64px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#5b6830;transition:all .3s}.insight-card:hover .insight-icon{transform:scale(1.1);background:#5b6830;color:#fff}.insight-card.active .insight-icon{background:#5b6830;color:#fff}.insight-label{font-size:14pt;font-weight:600;color:#2f2f2f}.active-insight-container{background:#fff;border:2px solid #5B6830;border-radius:16px;padding:32px;margin-top:32px;box-shadow:0 8px 32px #5b683026;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.insight-content-wrapper{width:100%}.insight-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e0e0e0}.insight-header h3{margin:0;font-size:20pt;font-weight:700;color:#2f2f2f}.close-insight-btn{background:none;border:none;color:#505050;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-insight-btn:hover{background:#f5f5f5;color:#d1583b}.insight-placeholder{padding:60px 20px;text-align:center;background:#f8f9fa;border-radius:12px;color:#505050}.insight-placeholder p{font-size:14pt;margin:0}.latest-articles-section{max-width:1400px;margin:0 auto;padding:40px 24px}.articles-carousel{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#d1d5db transparent;margin:0 -8px;padding:4px 8px 16px}.articles-carousel::-webkit-scrollbar{height:6px}.articles-carousel::-webkit-scrollbar-track{background:transparent}.articles-carousel::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.articles-carousel-track{display:flex;gap:20px;min-width:min-content}.carousel-article-card{flex:0 0 320px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .25s ease;display:flex;flex-direction:column}.carousel-article-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#5b6830}.carousel-card-image{width:100%;height:180px;overflow:hidden;background:#f3f4f6}.carousel-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.carousel-article-card:hover .carousel-card-image img{transform:scale(1.05)}.carousel-card-body{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}.carousel-card-tags{display:flex;gap:6px;flex-wrap:wrap}.carousel-tag{padding:2px 8px;background:#5b68301a;color:#5b6830;border-radius:12px;font-size:11px;font-weight:600;text-transform:lowercase}.carousel-card-title{margin:0;font-size:15px;font-weight:700;color:#1f2937;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.carousel-card-excerpt{margin:0;font-size:13px;color:#6b7280;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.carousel-card-date{font-size:12px;color:#9ca3af;margin-top:auto}.articles-carousel-footer{text-align:center;margin-top:24px}.view-all-articles-btn{display:inline-block;padding:10px 28px;background:#fff;color:#5b6830;border:2px solid #5B6830;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s}.view-all-articles-btn:hover{background:#5b6830;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #5b68304d}@media (max-width: 768px){.latest-articles-section{padding:40px 16px}.carousel-article-card{flex:0 0 260px}.carousel-card-image{height:150px}}@media (max-width: 480px){.carousel-article-card{flex:0 0 240px}.carousel-card-image{height:130px}.carousel-card-body{padding:12px}}.about-cta-section{background:#f8f9fa;padding:40px 24px}.about-content{max-width:1000px;margin:0 auto;text-align:center}.about-content h2{font-size:28pt;font-weight:700;color:#2f2f2f;margin:0 0 24px}.about-content p{font-size:14pt;color:#505050;line-height:1.8;margin:0 0 16px}.premium-cta{background:#fdf6e3;border:2px solid rgba(91,104,48,.25);border-radius:16px;padding:48px;margin-top:48px}.premium-cta h3{font-size:20pt;font-weight:700;color:#5b6830;margin:0 0 16px}.premium-cta p{margin-bottom:32px}.premium-btn{display:inline-block;padding:16px 40px;background:#d1583b;color:#fff;text-decoration:none;font-size:16pt;font-weight:700;border-radius:8px;transition:all .2s}.premium-btn:hover{background:#b84a2e;transform:translateY(-2px);box-shadow:0 8px 24px #d1583b66}.landing-footer{background:#2f2f2f;color:#fff;padding:28px 24px 24px}.footer-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.footer-brand{display:flex;align-items:center;gap:16px}.footer-logo{height:46px;width:auto}.footer-brand p{margin:0;font-size:14pt;font-weight:600}.footer-links{display:flex;gap:32px;flex-wrap:wrap}.footer-links a{color:#fffc;text-decoration:none;font-size:12pt;transition:color .2s}.footer-links a:hover{color:#fff}.footer-copyright{color:#fff9;font-size:11pt;padding-top:18px;border-top:1px solid rgba(255,255,255,.1)}@media (max-width: 1024px){.hero-title{font-size:28pt}.hero-subtitle{font-size:14pt}.section-header h2{font-size:24pt}.map-container-wrapper{min-height:400px}.insights-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width: 768px){.header-container{flex-direction:column;gap:16px;padding:12px 16px}.header-logo{height:40px}.header-title-block h1{font-size:14pt}.header-title-block p{font-size:10pt}.header-nav{width:100%;justify-content:space-around;gap:12px}.header-nav a{font-size:11pt}.header-nav .nav-cta{padding:6px 12px}.hero-section{padding:40px 16px}.hero-title{font-size:22pt}.hero-subtitle{font-size:12pt;margin-bottom:32px}.hero-stats{grid-template-columns:repeat(2,1fr);gap:16px}.stat-number{font-size:24pt}.stat-text{font-size:10pt}.map-section,.insights-section{padding:40px 16px}.section-header h2{font-size:20pt}.section-header p{font-size:12pt}.map-container-wrapper{padding:16px;min-height:300px}.featured-regions-grid{grid-template-columns:1fr}.insights-grid{grid-template-columns:repeat(2,1fr);gap:12px}.insight-card{padding:20px 16px}.insight-icon{width:48px;height:48px}.insight-label{font-size:11pt}.active-insight-container{padding:20px}.insight-header h3{font-size:16pt}.about-cta-section{padding:40px 16px}.about-content h2{font-size:20pt}.about-content p{font-size:12pt}.premium-cta{padding:32px 20px}.premium-cta h3{font-size:16pt}.premium-btn{padding:12px 32px;font-size:13pt}.footer-links{flex-direction:column;gap:16px}}@media (max-width: 480px){.hero-stats,.insights-grid{grid-template-columns:1fr}}.public-cta{margin:32px 0;padding:32px;background:linear-gradient(135deg,#f8fbff,#e8f4ff);border:2px solid #5B6830;border-radius:12px;text-align:center}.public-cta h3{margin:0 0 12px;font-size:22px;color:#2f2f2f}.public-cta p{margin:0 0 24px;color:#505050;font-size:15px;line-height:1.6}.cta-btn{padding:14px 32px;background:#d1583b;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #d1583b4d}.cta-btn:hover{background:#b84a2e;transform:translateY(-2px);box-shadow:0 6px 16px #d1583b66}@media (max-width: 768px){.user-menu-trigger span{display:none}.user-dropdown{right:-8px}.public-cta{padding:24px 20px}.public-cta h3{font-size:18px}.cta-btn{width:100%}}.auth-hint{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#d1583b1a;border:1px solid rgba(209,88,59,.3);border-radius:20px;font-size:13px;color:#d1583b;font-weight:500;margin-left:16px}.insight-card.locked{position:relative;opacity:.7;cursor:pointer}.insight-card.locked:hover{opacity:1;transform:translateY(-4px);border-color:#d1583b}.card-lock-overlay{position:absolute;top:8px;right:8px;width:32px;height:32px;background:#d1583be6;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.map-container-wrapper.locked{position:relative;min-height:600px;overflow:hidden;border-radius:12px}.map-locked-overlay{position:relative;width:100%;height:600px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:12px;overflow:hidden}.map-lock-content{position:relative;z-index:2;text-align:center;padding:40px;background:#fffffff2;border-radius:16px;box-shadow:0 8px 32px #00000026;max-width:400px}.map-lock-content svg{color:#5b6830;margin-bottom:20px}.map-lock-content h3{margin:0 0 12px;font-size:24px;color:#2f2f2f}.map-lock-content p{margin:0 0 24px;color:#666;font-size:15px;line-height:1.5}.unlock-btn{padding:12px 32px;background:#d1583b;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.unlock-btn:hover{background:#b84a2e;transform:translateY(-2px);box-shadow:0 4px 12px #d1583b4d}.map-preview-blur{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;filter:blur(8px);opacity:.4;pointer-events:none}.section-header{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:32px}@media (max-width: 768px){.auth-hint{font-size:12px;padding:4px 10px;margin-left:0;margin-top:8px}.section-header{flex-direction:column}.map-lock-content{padding:32px 24px;max-width:90%}.map-lock-content h3{font-size:20px}.map-lock-content svg{width:40px;height:40px}.card-lock-overlay{width:28px;height:28px}.card-lock-overlay svg{width:16px;height:16px}}@media (max-width: 480px){.map-locked-overlay{height:500px}.unlock-btn{width:100%}}.admin-header-link{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;transition:all .2s ease;box-shadow:0 2px 3px #0000001a;color:#5b6830;text-decoration:none;font-size:14pt;font-weight:600;transition:color .2s}@media (max-width: 768px){.mobile-menu-btn{display:flex}.desktop-nav{display:none!important}.header-container{padding:12px 16px}.header-logo{height:50px}.header-title-block h1{font-size:16pt}.header-title-block p{font-size:11pt}}@media (max-width: 480px){.header-logo{height:40px}.header-title-block h1{font-size:14pt}.header-title-block p{font-size:10pt}.mobile-nav{width:100%;max-width:100%}}@media (max-width: 360px){.header-title-block{display:none}}.landing-header{position:sticky;top:0;z-index:1000;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d;transition:transform .3s ease;will-change:transform}.landing-header.header-hidden{transform:translateY(-100%);box-shadow:none}@media (max-width: 768px){.header-container{padding:10px 16px}.header-logo{height:44px}.header-title-block h1{font-size:15pt}.header-title-block p{font-size:10pt}}@media (max-width: 480px){.header-container{padding:8px 12px}.header-logo{height:38px}.header-title-block h1{font-size:14pt}.header-title-block p{font-size:9pt}}@media (prefers-reduced-motion: reduce){.landing-header{transition:none}.landing-header.header-hidden{transform:none;opacity:.7;padding:4px 0}}@media (max-width: 768px){.mobile-menu-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-menu-btn:active{transform:scale(.95);background:#f0f0f0}}.insight-card.demo{position:relative;cursor:pointer}.card-demo-badge{position:absolute;top:8px;right:8px;padding:3px 10px;background:#5b6830d9;color:#fff;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.demo-hint{background:#5b68301a!important;color:#5b6830!important}.demo-hint-btn{background:none;border:none;color:#d1583b;font-weight:700;cursor:pointer;padding:0;font-size:inherit;text-decoration:underline;transition:color .2s}.demo-hint-btn:hover{color:#b84a2e}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.auth-modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px #0003}.preferences-modal{max-width:600px}.auth-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#666;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.auth-modal-close:hover{background:#f5f5f5;color:#2f2f2f}.auth-modal-header{padding:40px 40px 24px;background:#fff 100%;color:#fff;border-radius:12px 12px 0 0;border:2px solid #e5e7eb}.auth-modal-header h2{margin:0 0 8px;color:#000;font-size:26px;font-weight:700}.auth-modal-header p{margin:0;opacity:.9;color:#000;font-size:16px}.auth-modal-body{padding:32px 40px 40px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;margin-top:8px;font-weight:600;color:#2f2f2f}.form-group input,.form-group select{padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#5b6830}.form-group small{font-size:12px;color:#666}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-footer{text-align:right;margin-top:-10px}.auth-submit-btn{padding:14px;margin-top:15px;background:#d1583b;color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.auth-submit-btn:hover{background:#b84a2e;transform:translateY(-1px)}.auth-submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.auth-back-btn{padding:14px;margin-top:15px;background:#f5f5f5;color:#2f2f2f;border:1px solid #ddd;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.auth-back-btn:hover{background:#e8e8e8}.link-button{background:none;border:none;color:#5b6830;font-size:16px;font-weight:600;cursor:pointer;text-decoration:none;padding:0}.link-button:hover{color:#d1583b;text-decoration:underline}.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-error{padding:12px;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px}.auth-success{padding:12px;background:#efe;border:1px solid #cfc;border-radius:6px;color:#3c3;font-size:14px}.auth-switch{text-align:center;font-size:16px;color:#666;padding-top:12px;border-top:1px solid #eee}.signup-progress{display:flex;align-items:center;justify-content:center;margin-bottom:32px}.progress-step{width:32px;height:32px;border-radius:50%;background:#f5f5f5;border:2px solid #ddd;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#999;transition:all .3s}.progress-step.active{background:#5b6830;border-color:#5b6830;color:#fff}.progress-line{width:60px;height:2px;background:#ddd;transition:background .3s}.progress-line.active{background:#5b6830}.signup-step h3{margin:0 0 8px;font-size:18px;color:#2f2f2f}.step-description{margin:0 0 24px;color:#666;font-size:14px}.checkbox-group{display:flex;flex-direction:column;gap:16px}.checkbox-label{display:flex;gap:12px;padding:16px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.checkbox-label:hover{background:#fff;border-color:#5b6830}.checkbox-label input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer;flex-shrink:0}.checkbox-content{display:flex;flex-direction:column;gap:4px}.checkbox-content strong{font-size:14px;color:#2f2f2f}.checkbox-content small{font-size:13px;color:#666}.preferences-tabs{display:flex;border-bottom:1px solid #e0e0e0}.preferences-tabs .tab{flex:1;padding:16px;background:none;border:none;border-bottom:2px solid transparent;font-size:15px;font-weight:600;color:#666;cursor:pointer;transition:all .2s}.preferences-tabs .tab:hover{color:#2f2f2f}.preferences-tabs .tab.active{color:#5b6830;border-bottom-color:#5b6830}.preferences-content{padding-top:24px}@media (max-width: 640px){.auth-modal-content{max-width:100%;border-radius:0;max-height:100vh}.auth-modal-header{padding:32px 24px 20px}.auth-modal-body{padding:24px}.form-row{grid-template-columns:1fr}.signup-progress{margin-bottom:24px}.progress-line{width:40px}.form-actions{grid-template-columns:1fr}}.verification-status{text-align:center;padding:40px 20px}.spinner{border:4px solid #f3f4f6;border-top:4px solid #5B6830;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}.verification-status p{color:#666;font-size:16px;margin:0}.verification-success{text-align:center;padding:40px 20px}.success-icon{width:80px;height:80px;border-radius:50%;background-color:#10b981;color:#fff;font-size:48px;line-height:80px;margin:0 auto 20px;animation:scaleIn .3s ease-out}.verification-success h3{color:#10b981;margin:0 0 10px;font-size:22px}.verification-success p{color:#2f2f2f;margin:0 0 8px;font-size:16px}.redirect-message{color:#6b7280;font-size:14px;margin-top:12px;font-style:italic}.verification-error{text-align:center;padding:40px 20px}.error-icon{width:80px;height:80px;border-radius:50%;background-color:#ef4444;color:#fff;font-size:48px;line-height:80px;margin:0 auto 20px;animation:shake .5s ease-out}.verification-error h3{color:#ef4444;margin:0 0 10px;font-size:22px}.verification-error p{color:#6b7280;margin:0 0 20px;font-size:16px}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:44px}.password-toggle{position:absolute;right:8px;background:none;border:none;padding:8px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle:hover{color:#5b6830}.password-match{color:#22c55e!important;font-weight:500}.password-mismatch{color:#ef4444!important;font-weight:500}.reset-success{text-align:center;padding:40px 20px}.reset-success .success-icon{color:#22c55e;margin-bottom:20px}.reset-success p{color:#374151;font-size:1.1rem;margin-bottom:8px}.reset-success .success-hint{color:#6b7280;font-size:.9rem}.auth-error{display:flex;align-items:center;gap:8px;background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.public-climate-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #00000014;max-width:1200px;margin:0 auto}.climate-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e9ecef}.header-title{display:flex;align-items:center;gap:16px}.header-title h2{margin:0;font-size:24px;font-weight:700;color:#1a1a1a}.about-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;font-size:13px;color:#666;cursor:pointer;transition:all .2s}.about-btn:hover{background:#e9ecef;color:#333}.close-btn{background:none;border:none;padding:8px;cursor:pointer;color:#666;border-radius:50%;transition:all .2s}.close-btn:hover{background:#f5f5f5;color:#333}.view-toggle-container{display:flex;justify-content:center;margin-bottom:24px}.view-toggle{display:flex;gap:4px;background:#f1f3f4;border-radius:8px;padding:4px}.view-toggle-btn{padding:12px 24px;border:none;background:transparent;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.view-toggle-btn:hover{background:#ffffff80}.view-toggle-btn.active{background:#fff;color:#06c;box-shadow:0 2px 8px #0000001a}.zone-selector{margin-bottom:24px}.zone-selector-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.zone-dropdown-container{position:relative}.zone-dropdown-trigger{display:flex;justify-content:space-between;align-items:center;width:100%;min-width:250px;padding:0 1rem;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s;height:44px;box-sizing:border-box}.zone-dropdown-trigger:hover{border-color:#06c}.zone-dropdown-trigger.open{border-color:#06c;box-shadow:0 0 0 3px #0066cc1a}.zone-dropdown-trigger:disabled{background:#f5f5f5;cursor:not-allowed}.zone-dropdown-text{color:#333}.dropdown-chevron{transition:transform .2s}.dropdown-chevron.rotated{transform:rotate(180deg)}.zone-dropdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.zone-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;width:100%;max-width:400px;max-height:400px;overflow-y:auto;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 8px 24px #00000026;z-index:100}.zone-region-group{border-bottom:1px solid #eee}.zone-region-group:last-child{border-bottom:none}.zone-region-header{padding:10px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#666;background:#f8f9fa;position:sticky;top:0}.zone-region-zones{padding:4px 0}.zone-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:none;border:none;font-size:14px;color:#333;cursor:pointer;text-align:left;transition:background-color .15s}.zone-option:hover{background:#f5f8ff}.zone-option.selected{background:#e8f4ff;color:#06c}.zone-option:disabled{opacity:.5;cursor:not-allowed}.zone-checkbox{width:18px;height:18px;border:2px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff}.zone-checkbox.checked{background:#06c;border-color:#06c}.zone-comparison-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.zone-tag{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#e8f4ff;border-radius:20px;font-size:13px;color:#06c}.zone-tag-remove{background:none;border:none;padding:0;font-size:16px;color:#06c;cursor:pointer;line-height:1}.zone-tag-remove:hover{color:#049}.zone-selector-loading,.zone-selector-error{padding:16px;text-align:center;color:#666;background:#f8f9fa;border-radius:8px}.zone-selector-error{color:#dc3545;background:#f8d7da}.season-explorer,.projections-explorer{background:#f8f9fa;border-radius:12px;padding:24px}.explorer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.explorer-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.explorer-mode-toggle{display:flex;gap:4px;background:#fff;border-radius:6px;padding:4px;border:1px solid #e9ecef}.baseline-summary{background:#fff;border-radius:8px;padding:16px;margin-bottom:20px;border:1px solid #e9ecef}.baseline-header{margin-bottom:12px}.baseline-label{font-size:13px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.baseline-stats{display:flex;gap:24px;flex-wrap:wrap}.baseline-stat{display:flex;align-items:center;gap:8px}.baseline-stat svg{color:#06c}.baseline-stat .stat-value{font-weight:600;color:#333}.baseline-stat .stat-label{color:#666;font-size:13px}.chart-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.chart-metric-selector{display:flex;gap:4px;background:#fff;border-radius:6px;padding:4px;border:1px solid #e9ecef}.chart-type-btn{padding:8px 16px;border:none;background:transparent;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;color:#666}.chart-type-btn:hover{background:#f5f5f5}.chart-type-btn.active{background:#06c;color:#fff}.season-limit-select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.chart-container{background:#fff;border-radius:8px;padding:20px;height:350px;margin-bottom:24px}.seasons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.season-card{background:#fff;border:2px solid #e9ecef;border-radius:10px;padding:16px;cursor:pointer;transition:all .2s}.season-card:hover{border-color:#06c;box-shadow:0 4px 12px #0066cc26}.season-card.selected{border-color:#06c;background:#f5f8ff}.season-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.season-label{font-size:16px;font-weight:700;color:#333}.season-ranking{font-size:11px;font-weight:600;color:#06c;background:#e8f4ff;padding:2px 8px;border-radius:10px}.season-card-stats{display:flex;flex-direction:column;gap:8px}.season-stat{display:flex;align-items:center;gap:8px}.season-stat .stat-label{font-size:12px;color:#666;min-width:40px}.season-stat .stat-value{font-weight:600;color:#333;font-size:14px}.season-stat .stat-diff{display:flex;align-items:center;gap:2px;font-size:12px;font-weight:600;margin-left:auto}.stat-diff.positive{color:#28a745}.stat-diff.negative{color:#dc3545}.trend-icon.positive{color:#28a745}.trend-icon.negative{color:#dc3545}.trend-icon.neutral{color:#6c757d}.comparison-view{margin-top:20px}.comparison-instructions{text-align:center;padding:12px;background:#fff3cd;border-radius:8px;margin-bottom:16px;color:#856404}.seasons-selection-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.season-select-btn{padding:8px 16px;border:2px solid #e9ecef;background:#fff;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.season-select-btn:hover:not(:disabled){border-color:#06c}.season-select-btn.selected{background:#06c;border-color:#06c;color:#fff}.season-select-btn:disabled{opacity:.4;cursor:not-allowed}.comparison-results{overflow-x:auto}.comparison-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.comparison-table th,.comparison-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e9ecef}.comparison-table th{background:#f8f9fa;font-weight:600;font-size:13px;color:#666}.comparison-table td{font-size:14px}.comparison-table td small{display:block;font-size:12px;margin-top:2px}.comparison-table td small.positive{color:#28a745}.comparison-table td small.negative{color:#dc3545}.ssp-selector,.period-selector{margin-bottom:24px}.selector-label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:12px}.ssp-tabs{display:flex;gap:12px;flex-wrap:wrap}.ssp-tab{flex:1;min-width:150px;padding:16px;background:#fff;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;text-align:center;transition:all .2s}.ssp-tab:hover{border-color:var(--ssp-color, #0066cc)}.ssp-tab.active{border-color:var(--ssp-color, #0066cc);background:linear-gradient(180deg,#fff,#f8f9fa);box-shadow:0 4px 12px #0000001a}.ssp-name{display:block;font-weight:700;font-size:15px;color:#333;margin-bottom:4px}.ssp-short{display:block;font-size:12px;color:#666}.ssp-description{display:flex;align-items:center;gap:8px;margin-top:12px;padding:12px;background:#f8f9fa;border-radius:6px;font-size:13px;color:#666}.ssp-description svg{flex-shrink:0}.period-buttons{display:flex;gap:12px;flex-wrap:wrap}.period-btn{flex:1;min-width:140px;padding:16px;background:#fff;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;text-align:center;transition:all .2s}.period-btn:hover{border-color:#06c}.period-btn.active{border-color:#06c;background:#f5f8ff}.period-name{display:block;font-weight:600;font-size:14px;color:#333;margin-bottom:4px}.period-years{display:block;font-size:13px;color:#06c}.projection-summary{background:#fff;border-radius:10px;padding:20px;margin-bottom:24px}.projection-summary h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.summary-card{display:flex;gap:16px;padding:16px;background:#f8f9fa;border-radius:8px}.summary-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon.gdd{background:#fef3c7;color:#d97706}.summary-icon.temp{background:#fee2e2;color:#dc2626}.summary-icon.rain{background:#dbeafe;color:#2563eb}.summary-content{display:flex;flex-direction:column}.summary-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.3px}.summary-value{font-size:20px;font-weight:700;color:#333;margin:4px 0}.summary-change{font-size:13px}.summary-change.positive{color:#28a745}.summary-change.negative{color:#dc3545}.monthly-details{margin-top:24px}.monthly-details h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.monthly-table-wrapper{overflow-x:auto}.monthly-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.monthly-table th,.monthly-table td{padding:10px 14px;text-align:center;border-bottom:1px solid #e9ecef;font-size:13px}.monthly-table th{background:#f8f9fa;font-weight:600;color:#666}.monthly-table td.positive{color:#dc2626;font-weight:600}.monthly-table td.negative{color:#2563eb;font-weight:600}.climate-attribution{display:flex;align-items:center;gap:8px;margin-top:24px;padding:12px 16px;background:#f8f9fa;border-radius:8px;font-size:12px;color:#666}.climate-attribution svg{flex-shrink:0;color:#999}.climate-about-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.climate-about-modal{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.about-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef}.about-header h2{margin:0;font-size:22px;font-weight:700;color:#333}.about-content{flex:1;overflow-y:auto;padding:24px}.about-section{margin-bottom:32px}.about-section:last-child{margin-bottom:0}.about-section h3{margin:0 0 12px;font-size:18px;font-weight:600;color:#333}.section-icon.warning{background:#fff3cd;color:#856404}.section-content p{margin:0 0 12px;line-height:1.6;color:#555}.variables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px}.variable-card{padding:16px;background:#f8f9fa;border-radius:8px}.variable-card h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#333}.variable-card p{margin:0 0 8px;font-size:13px;color:#666;line-height:1.5}.variable-card code{display:block;padding:8px;background:#fff;border-radius:4px;font-size:12px;color:#06c}.ssp-list{margin-top:16px}.ssp-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;margin-bottom:8px}.ssp-item.ssp126{background:#dcfce7}.ssp-item.ssp245{background:#fef3c7}.ssp-item.ssp370{background:#fee2e2}.ssp-badge{padding:4px 10px;background:#fff;border-radius:4px;font-size:12px;font-weight:700;white-space:nowrap}.ssp-desc{font-size:13px;color:#333;line-height:1.4}.periods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.period-item{text-align:center;padding:16px;background:#f8f9fa;border-radius:8px}.period-item .period-label{display:block;font-weight:600;color:#333;margin-bottom:4px}.period-item .period-years{display:block;font-size:14px;color:#06c;font-weight:600;margin-bottom:8px}.period-item .period-desc{font-size:12px;color:#666;line-height:1.4}.guidelines-list{margin:16px 0 0;padding-left:20px}.guidelines-list li{margin-bottom:12px;line-height:1.5;color:#555}.citations-list{margin:12px 0 0;padding-left:0;list-style:none}.citations-list li{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #eee;font-size:13px;color:#555}.citations-list a{color:#06c}.about-footer{padding:20px 24px;border-top:1px solid #e9ecef;background:#f8f9fa;text-align:center}.about-footer p{margin:0 0 16px;font-size:15px;color:#666}.close-about-btn{padding:10px 32px;background:#06c;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.close-about-btn:hover{background:#0052a3}@media (max-width: 768px){.public-climate-container{padding:16px}.header-title h2{font-size:20px}.view-toggle{width:100%}.view-toggle-btn{flex:1;padding:10px 12px;font-size:13px}.zone-dropdown-trigger,.zone-dropdown-menu{max-width:100%}.season-explorer,.projections-explorer{padding:16px}.explorer-header,.baseline-stats{flex-direction:column;gap:12px}.chart-controls{flex-direction:column;align-items:stretch}.chart-metric-selector{width:100%;overflow-x:auto}.chart-container{height:280px}.seasons-grid{grid-template-columns:repeat(2,1fr)}.ssp-tabs{flex-direction:column}.ssp-tab{min-width:unset}.period-buttons{flex-direction:column}.period-btn{min-width:unset}.summary-grid,.periods-grid{grid-template-columns:1fr}.climate-about-modal{max-height:95vh;margin:10px}.about-content{padding:16px}.variables-grid{grid-template-columns:1fr}}@media (max-width: 480px){.seasons-grid{grid-template-columns:1fr}.chart-type-btn{padding:6px 10px;font-size:12px}}.explorer-header{display:flex;align-items:baseline;gap:12px;margin-bottom:16px}.explorer-header h3{margin:0;font-size:20px;font-weight:600;color:#1a1a1a}.zone-region{font-size:14px;color:#666}.view-mode-selector{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;padding:12px;background:#f8f9fa;border-radius:8px}.mode-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:1px solid #e0e0e0;background:#fff;border-radius:6px;font-size:14px;font-weight:500;color:#555;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:#3b82f6;color:#3b82f6}.mode-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.include-lta-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:#666;cursor:pointer}.include-lta-toggle input{cursor:pointer}.season-selector{display:flex;align-items:center;gap:8px}.season-selector label{font-size:13px;color:#666}.season-select{padding:6px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.compare-type-toggle{display:flex;gap:16px}.compare-type-toggle label{display:flex;align-items:center;gap:6px;font-size:13px;color:#555;cursor:pointer}.comparison-season-selector{margin-bottom:16px;padding:12px;background:#f8f9fa;border-radius:8px}.selector-label{display:block;margin-bottom:10px;font-size:13px;font-weight:500;color:#555}.season-pills{display:flex;flex-wrap:wrap;gap:8px}.season-pill{padding:6px 12px;border:1px solid #e0e0e0;background:#fff;border-radius:20px;font-size:13px;color:#555;cursor:pointer;transition:all .2s}.season-pill:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.season-pill.selected{background:#3b82f6;border-color:#3b82f6;color:#fff}.season-pill:disabled{opacity:.5;cursor:not-allowed}.seasons-section{margin-top:24px}.seasons-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.seasons-header h4{margin:0;font-size:16px;font-weight:600;color:#333}.seasons-pagination{display:flex;align-items:center;gap:8px}.page-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #e0e0e0;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;color:#555}.page-btn:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:13px;color:#666;min-width:50px;text-align:center}.season-card.comparing{border-color:#f59e0b;background:#f59e0b0d}.season-card.comparing .season-label{color:#f59e0b}.chart-loading{display:flex;align-items:center;justify-content:center;height:300px;color:#666;font-size:14px}.chart-placeholder{display:flex;align-items:center;justify-content:center;height:300px;color:#999;font-size:14px;background:#f8f9fa;border-radius:8px}.explorer-placeholder,.explorer-loading,.explorer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#666}.explorer-placeholder svg{margin-bottom:16px;color:#ccc}.explorer-error{color:#dc3545}@media (max-width: 768px){.view-mode-selector{flex-direction:column}.mode-btn{width:100%;justify-content:center}.chart-controls{flex-direction:column;gap:12px}.comparison-season-selector{padding:10px}.season-pills{gap:6px}.season-pill{padding:4px 10px;font-size:12px}}.zone-selector-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.zone-comparison-section{margin-top:12px;padding:12px;background:#f8f9fa;border-radius:8px}.comparison-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.comparison-label{font-size:13px;font-weight:500;color:#555}.add-comparison-container{position:relative}.add-comparison-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed #ccc;background:#fff;border-radius:6px;font-size:13px;color:#666;cursor:pointer;transition:all .2s}.add-comparison-btn:hover{border-color:#3b82f6;color:#3b82f6}.comparison-menu{max-height:250px}.comparison-hint{font-size:12px;color:#999;font-style:italic}.zone-comparison-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.zone-tag{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 12px;background:#e0e7ff;border-radius:20px;font-size:13px;color:#3730a3}.zone-tag-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:#c7d2fe;border-radius:50%;cursor:pointer;color:#4338ca;transition:all .2s}.zone-tag-remove:hover{background:#a5b4fc}.model-thresholds{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #E5E7EB}.model-thresholds span{font-size:.7rem;padding:.25rem .5rem;background:#f3f4f6;border-radius:4px;color:#4b5563}.stages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.stage-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#f9fafb;border-radius:8px;border-left:3px solid #8B5CF6}.stage-name{font-weight:600;color:#111827;font-size:.9rem}.stage-desc{font-size:.8rem;color:#6b7280;line-height:1.4}.citation-item{padding:.75rem;background:#f9fafb;border-radius:8px;margin-bottom:.75rem}.citation-item strong{display:block;color:#1f2937;margin-bottom:.25rem}.citation-item p{margin:0;font-size:.85rem;color:#4b5563;line-height:1.4}.formula-note{font-size:.8rem;color:#6b7280;margin-top:.5rem;font-style:italic}.about-section code{display:inline-block;background:#1f2937;color:#f9fafb;padding:.5rem .75rem;border-radius:6px;font-family:Monaco,Menlo,monospace;font-size:.8rem;margin:.5rem 0}@media (max-width: 768px){.public-climate-container{padding:16px;border-radius:8px}.climate-header{flex-direction:column;align-items:flex-start;gap:12px}.header-title{width:100%;flex-wrap:wrap;gap:8px}.header-title h2{font-size:18px;width:100%}.about-btn{order:2}.close-btn{position:absolute;top:16px;right:16px}.zone-dropdown-trigger,.zone-dropdown-menu{max-width:100%}.selector-trigger{min-width:100%!important;width:100%}.chart-container{height:250px!important;min-height:200px;padding:12px}.summary-grid,.variables-grid,.stats-summary-grid{grid-template-columns:1fr 1fr}.ssp-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ssp-tab{min-width:auto;padding:12px}.ssp-name{font-size:13px}.ssp-short{font-size:11px}.period-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.period-btn{min-width:auto;padding:10px}.period-name{font-size:13px}.period-years{font-size:11px}.chart-metric-selector{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px}.chart-type-btn{padding:8px 12px;font-size:12px;white-space:nowrap;flex-shrink:0}.projection-summary{padding:12px}.projection-summary h4{font-size:14px}.summary-card{padding:12px;gap:10px}.summary-icon{width:36px;height:36px}.summary-value{font-size:18px}.summary-label{font-size:11px}.monthly-table-wrapper,.recent-days-table-wrapper{margin:0 -16px;padding:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.monthly-table,.recent-days-table{min-width:600px}.monthly-table th,.monthly-table td,.recent-days-table th,.recent-days-table td{padding:8px 10px;font-size:12px;white-space:nowrap}.seasons-grid{grid-template-columns:repeat(3,1fr);gap:8px}.season-card{padding:12px}.season-label{font-size:14px}.season-explorer,.projections-explorer{padding:16px}.explorer-header{flex-direction:column;align-items:flex-start;gap:12px}.climate-attribution{padding:10px 12px;font-size:11px}}@media (max-width: 480px){.public-climate-container{padding:12px}.header-title h2{font-size:16px}.chart-container{height:200px!important;min-height:180px;padding:8px}.summary-grid,.variables-grid{grid-template-columns:1fr;gap:8px}.stats-summary-grid{grid-template-columns:1fr 1fr}.ssp-tabs{grid-template-columns:1fr}.period-buttons{grid-template-columns:1fr 1fr}.seasons-grid{grid-template-columns:repeat(2,1fr)}.season-card{padding:10px}.season-label{font-size:13px}.stages-grid{grid-template-columns:1fr}.season-explorer,.projections-explorer{padding:12px}}@media (max-width: 768px){.current-season-explorer,.phenology-explorer,.disease-pressure-explorer{padding:12px}.season-header,.phenology-header,.disease-header{flex-direction:column;align-items:flex-start;gap:8px}.season-title h3,.header-title h3{font-size:1.1rem}.season-meta,.header-meta{width:100%;align-items:flex-start;font-size:.75rem}.summary-cards{grid-template-columns:1fr 1fr;gap:10px}.summary-card{padding:12px;gap:10px}.card-icon{width:36px;height:36px}.card-icon svg{width:18px;height:18px}.card-value{font-size:1.25rem}.card-label{font-size:.65rem}.card-comparison{font-size:.75rem}.status-badge{font-size:.6rem;padding:2px 6px}.chart-section .chart-container{height:220px}.chart-controls{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.chart-tab{padding:6px 10px;font-size:.75rem;white-space:nowrap;flex-shrink:0}.variety-filter{flex-direction:column;align-items:flex-start;gap:8px}.variety-chips{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px}.variety-chip{flex-shrink:0;padding:6px 10px;font-size:.75rem}.variety-card-header{padding:12px;flex-wrap:wrap}.variety-info{flex:1 1 60%}.variety-name{font-size:.9rem}.variety-gdd{font-size:.8rem}.key-dates-summary{padding:8px 12px;gap:6px}.date-chip{padding:6px 10px;min-width:65px}.date-label{font-size:.55rem}.date-value{font-size:.75rem}.harvest-grid{grid-template-columns:repeat(2,1fr);gap:8px}.harvest-item{padding:10px}.harvest-label{font-size:.65rem}.harvest-date{font-size:.8rem}.disease-card-header{padding:12px}.disease-name{font-size:.9rem}.disease-score{order:-1;width:100%;justify-content:flex-end;margin-bottom:6px}.score-value{font-size:1.25rem}.factors-grid{grid-template-columns:1fr 1fr;gap:6px}.factor-item{padding:8px}.factor-label{font-size:.65rem}.factor-value{font-size:.7rem}.disease-pressure-explorer .chart-header{flex-direction:column;align-items:flex-start;gap:8px;padding:12px}.days-selector{width:100%;justify-content:flex-start}.disease-pressure-explorer .chart-container{height:200px;padding:8px}.general-recommendations{padding:12px}.general-recommendations h4{font-size:.85rem}.general-recommendations li{font-size:.8rem}.phenology-legend,.disease-legend{flex-direction:column;align-items:flex-start;gap:6px;font-size:.7rem}.timeline{padding-left:1.5rem}.timeline-marker{left:-1.5rem}.stage-name{font-size:.8rem}.gdd-threshold{font-size:.7rem}.timeline-date{font-size:.75rem}}@media (max-width: 480px){.summary-cards{grid-template-columns:1fr}.chart-section .chart-container,.disease-pressure-explorer .chart-container{height:180px}.factors-grid{gap:4px}.factor-item{padding:6px}}.climate-view-tabs-wrapper{position:relative;margin:-8px -24px 16px;padding:0 24px;background:#f8f9fa;border-bottom:1px solid #e5e7eb}.climate-view-tabs-wrapper:before,.climate-view-tabs-wrapper:after{content:"";position:absolute;top:0;bottom:0;width:24px;pointer-events:none;z-index:1;opacity:0;transition:opacity .2s}.climate-view-tabs-wrapper:before{left:0;background:linear-gradient(to right,#f8f9fa 0%,transparent 100%)}.climate-view-tabs-wrapper:after{right:0;background:linear-gradient(to left,#f8f9fa 0%,transparent 100%)}.climate-view-tabs{display:flex;gap:4px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;padding:12px 0;-webkit-overflow-scrolling:touch}.climate-view-tabs::-webkit-scrollbar{display:none}.view-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;color:#4b5563;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s ease}.view-tab:hover{border-color:#5b6830;color:#5b6830;background:#f0fdf4}.view-tab.active{background:#5b6830;border-color:#5b6830;color:#fff;box-shadow:0 2px 4px #5b683033}.view-tab.active svg{color:#fff}.view-tab svg{flex-shrink:0;color:#5b6830;transition:color .2s}.tab-label-short{display:none}.tab-label-full{display:inline}@media (max-width: 768px){.climate-view-tabs-wrapper{margin:-8px -16px 12px;padding:0 16px}.climate-view-tabs-wrapper:before,.climate-view-tabs-wrapper:after{opacity:1}.climate-view-tabs{gap:6px;padding:10px 0}.view-tab{padding:8px 12px;font-size:13px;gap:6px}.tab-label-short{display:inline}.tab-label-full{display:none}.view-tab svg{width:16px;height:16px}}@media (max-width: 480px){.climate-view-tabs-wrapper{margin:-8px -12px 10px;padding:0 12px}.view-tab{padding:8px 10px;font-size:12px;gap:5px;border-radius:6px}.view-tab svg{width:14px;height:14px}}@media (max-width: 360px){.view-tab{padding:10px;min-width:44px;justify-content:center}.tab-label-short,.tab-label-full{display:none}.view-tab svg{width:18px;height:18px}}@media (max-width: 768px){.view-tab{-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px}.view-tab:active{transform:scale(.97)}.view-tab.active:active{transform:none}}@media (max-width: 768px) and (orientation: landscape){.climate-view-tabs-wrapper{margin-bottom:8px}.climate-view-tabs{padding:8px 0}.view-tab{padding:6px 10px;min-height:38px}}.view-tab:focus-visible{outline:2px solid #5B6830;outline-offset:2px}@media (prefers-reduced-motion: reduce){.climate-view-tabs{scroll-behavior:auto}.view-tab{transition:none}}.datasets-hero-btn{display:inline-flex;align-items:center;gap:12px;padding:16px 28px;background:linear-gradient(135deg,#5b6830,#4a5628);color:#fff;font-size:1.1rem;font-weight:600;text-decoration:none;border-radius:12px;box-shadow:0 4px 14px #5b68304d;transition:all .3s ease;margin-top:1.5rem}.datasets-hero-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #5b683066;background:linear-gradient(135deg,#6a7a3a,#5b6830)}.datasets-hero-btn:active{transform:translateY(0)}.demo-cta-banner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:12px 20px;margin-bottom:20px;background:linear-gradient(135deg,#f0f5e8,#e8f0dd);border:1px solid rgba(91,104,48,.2);border-radius:10px;font-size:14px;color:#3d4a1e}.demo-cta-banner span{font-weight:500}.demo-cta-btn{background:#d1583b;color:#fff;border:none;padding:8px 20px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.demo-cta-btn:hover{background:#b84a2e;transform:translateY(-1px);box-shadow:0 4px 12px #d1583b4d}.zone-dropdown-trigger.demo-locked{background:#f8faf5;border-color:#5b68304d;cursor:pointer}.zone-dropdown-trigger.demo-locked:hover{border-color:#5b6830}.demo-lock-icon{color:#5b6830;opacity:.6}@media (max-width: 768px){.demo-cta-banner{flex-direction:column;text-align:center;padding:10px 16px;font-size:13px}.demo-cta-btn{width:100%}}.zone-option.demo-locked-zone{opacity:.6;justify-content:space-between}.zone-option.demo-locked-zone:hover{background:#d1583b14}.zone-lock-icon{color:#999;flex-shrink:0}@media (max-width: 480px){.landing-header{padding:12px 16px}.header-logo img{height:32px}.header-nav{gap:8px}.header-nav a,.header-nav button{padding:6px 10px;font-size:12px}.header-nav .nav-text{display:none}.hero-content h1{font-size:1.75rem;line-height:1.2}.hero-content p{font-size:.9rem}.insights-grid{grid-template-columns:1fr!important;gap:12px}.insight-card{padding:16px}.active-insight-container{padding:16px;margin:0 -16px;border-radius:0}.map-sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;max-width:100%;max-height:60vh;border-radius:16px 16px 0 0;z-index:200;transform:translateY(calc(100% - 60px));transition:transform .3s ease}.map-sidebar.expanded{transform:translateY(0)}.sidebar-handle{display:block;width:40px;height:4px;background:#d1d5db;border-radius:2px;margin:8px auto}.map-container{height:calc(100vh - 60px)}.region-popup,.gi-popup,.block-popup{position:fixed!important;bottom:70px;left:16px;right:16px;top:auto!important;max-width:none;max-height:50vh;overflow-y:auto}.public-climate-container{padding:16px;border-radius:8px}.climate-header{flex-direction:column;align-items:flex-start;gap:12px}.header-title{flex-direction:column;align-items:flex-start;gap:8px;width:100%}.header-title h2{font-size:18px}.about-btn{padding:6px 10px;font-size:12px}.close-btn{position:absolute;top:12px;right:12px}.view-toggle{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.view-toggle::-webkit-scrollbar{display:none}.view-toggle-btn{padding:8px 12px;font-size:12px;white-space:nowrap;flex-shrink:0}.zone-dropdown-trigger{max-width:100%}.zone-dropdown-menu{max-width:100%;left:0;right:0}.season-explorer,.projections-explorer{padding:16px}.explorer-header{flex-direction:column;align-items:flex-start;gap:12px}.explorer-header h3{font-size:16px}.chart-container{height:220px!important;min-height:200px}.ssp-tabs{flex-direction:column}.ssp-tab{min-width:100%;padding:12px}.period-buttons{display:grid;grid-template-columns:1fr 1fr}.period-btn{min-width:auto;padding:12px}.summary-grid,.variables-grid,.stages-grid{grid-template-columns:1fr!important}.seasons-grid{grid-template-columns:1fr 1fr!important;gap:8px}.season-card{padding:12px}.season-label{font-size:14px}.chart-controls{flex-direction:column;align-items:stretch}.chart-metric-selector{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;-webkit-overflow-scrolling:touch}.chart-type-btn{padding:6px 12px;font-size:12px;white-space:nowrap;flex-shrink:0}.monthly-table-wrapper{margin:0 -16px;padding:0 16px}.monthly-table th,.monthly-table td{padding:8px 10px;font-size:11px}.projection-summary{padding:12px}.projection-summary h4{font-size:14px}.summary-card{padding:12px;gap:12px}.summary-icon{width:36px;height:36px}.summary-value{font-size:18px}.current-season-explorer,.phenology-explorer,.disease-pressure-explorer{padding:12px}.season-header,.phenology-header,.disease-header{flex-direction:column;align-items:flex-start;gap:8px}.season-title h3,.header-title h3,.disease-header h3{font-size:1.1rem}.season-meta,.header-meta{align-items:flex-start;font-size:.75rem}.summary-cards{grid-template-columns:1fr!important;gap:12px}.summary-card{padding:12px}.card-icon{width:40px;height:40px}.card-value{font-size:1.25rem}.card-label{font-size:.7rem}.milestones-section{padding:12px}.milestones-list{gap:8px}.milestone-item{padding:8px 12px;flex:1 1 auto;min-width:calc(50% - 4px)}.chart-section{margin-bottom:1rem}.chart-controls{overflow-x:auto;padding-bottom:4px}.chart-tab{padding:6px 10px;font-size:.75rem;white-space:nowrap}.recent-days-table-wrapper{margin:0 -12px;overflow-x:auto}.recent-days-table th,.recent-days-table td{padding:8px;font-size:.75rem;white-space:nowrap}.variety-filter{flex-direction:column;align-items:flex-start;gap:8px}.variety-chips{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}.variety-chip{flex-shrink:0;padding:6px 10px;font-size:.75rem}.variety-card-header{padding:12px}.variety-name{font-size:.9rem}.variety-gdd{font-size:.8rem}.key-dates-summary{padding:8px 12px;gap:6px}.date-chip{padding:6px 10px;min-width:70px}.date-label{font-size:.6rem}.date-value{font-size:.8rem}.variety-card-expanded{padding:12px}.harvest-grid{grid-template-columns:1fr 1fr!important;gap:8px}.harvest-item{padding:10px}.phenology-legend{gap:.75rem;font-size:.7rem}.disease-card-header{padding:12px;flex-wrap:wrap}.disease-info{gap:8px}.disease-name{font-size:.9rem}.disease-score{order:-1;width:100%;justify-content:flex-end;margin-bottom:8px}.score-value{font-size:1.25rem}.risk-bar-container{margin:0 12px}.factors-grid{grid-template-columns:1fr 1fr!important;gap:8px}.factor-item{padding:8px 10px}.factor-label{font-size:.7rem}.factor-value{font-size:.75rem}.chart-header{flex-direction:column;align-items:flex-start;gap:8px;padding:12px}.days-selector{width:100%;justify-content:flex-start}.disease-legend{flex-direction:column;align-items:flex-start;gap:6px}.general-recommendations{padding:12px}.general-recommendations h4{font-size:.85rem}.general-recommendations li{font-size:.8rem}.zone-selector-realtime{width:100%}.selector-trigger{min-width:100%!important;width:100%}.selector-dropdown{min-width:100%;left:0;right:0}.cta-modal{padding:1.5rem;margin:1rem}.cta-icon{width:60px;height:60px}.cta-modal h3{font-size:1.25rem}.region-stats-overlay{padding:12px}.region-stats-modal{max-height:90vh;padding:16px;border-radius:12px}.region-stats-header h2{font-size:1.1rem}.stats-summary-grid{grid-template-columns:1fr 1fr!important;gap:8px}.stat-item{padding:12px}.stat-value{font-size:1.25rem}.varieties-table-wrapper{margin:0 -16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.auth-modal-content{margin:0;max-height:100vh;border-radius:0}.auth-modal-header{padding:24px 20px 16px}.auth-modal-header h2{font-size:22px}.auth-modal-body{padding:20px}.signup-progress{margin-bottom:20px}.progress-line{width:32px}.progress-step{width:28px;height:28px;font-size:12px}.about-page{padding:16px}.about-hero h1{font-size:1.75rem}.features-grid{grid-template-columns:1fr!important}.contact-grid{flex-direction:column}.climate-about-overlay{padding:12px}.climate-about-modal{max-width:100%;border-radius:12px}.about-header{padding:16px 20px}.about-header h2{font-size:18px}.about-content{padding:16px 20px}.about-section{margin-bottom:24px}.about-section h3{font-size:16px}.section-icon{float:none;display:block;margin:0 0 12px}}@media (max-width: 768px){.landing-header{padding:16px 20px}.header-logo img{height:40px}.header-nav{gap:12px}.hero-content h1{font-size:2rem}.insights-grid{grid-template-columns:1fr 1fr;gap:16px}.active-insight-container{padding:20px}.map-sidebar{width:260px;max-height:calc(100vh - 120px)}.map-container{height:500px}.public-climate-container{padding:20px}.header-title h2{font-size:20px}.view-toggle-btn{padding:10px 16px;font-size:13px}.chart-container{height:280px}.ssp-tabs{display:grid;grid-template-columns:1fr 1fr}.ssp-tab{min-width:auto}.seasons-grid{grid-template-columns:repeat(3,1fr)}.summary-grid,.variables-grid,.stages-grid,.summary-cards{grid-template-columns:1fr 1fr}.harvest-grid{grid-template-columns:repeat(3,1fr)}.factors-grid{grid-template-columns:1fr 1fr}.stats-summary-grid{grid-template-columns:repeat(3,1fr)}.auth-modal-content{max-width:100%;margin:0 16px;border-radius:12px}.form-row{grid-template-columns:1fr}}@media (max-width: 1024px){.insights-grid{grid-template-columns:repeat(2,1fr)}.map-sidebar{width:280px}.ssp-tabs{gap:8px}.ssp-tab{padding:12px}.period-buttons{gap:8px}.period-btn{padding:12px}}@media (hover: none) and (pointer: coarse){.view-toggle-btn,.chart-type-btn,.chart-tab,.variety-chip,.season-pill,.zone-option,.rt-zone-option{min-height:44px;display:flex;align-items:center;justify-content:center}.view-toggle-btn:hover,.chart-type-btn:hover,.zone-option:hover,.season-card:hover{transform:none;box-shadow:none}.chart-controls,.variety-chips,.view-toggle{position:relative}.chart-controls:after,.variety-chips:after,.view-toggle:after{content:"";position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(to left,white,transparent);pointer-events:none}}@media (max-height: 500px) and (orientation: landscape){.map-sidebar{max-height:80vh}.chart-container{height:180px!important}.region-popup,.gi-popup,.block-popup{max-height:70vh}.auth-modal-content{max-height:100vh;overflow-y:auto}.cta-modal{max-height:95vh;overflow-y:auto}}@supports (padding: env(safe-area-inset-bottom)){.map-sidebar{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.region-popup,.gi-popup,.block-popup{bottom:calc(70px + env(safe-area-inset-bottom))}.auth-modal-content{padding-bottom:env(safe-area-inset-bottom)}}@media (prefers-reduced-motion: reduce){.map-sidebar,.view-toggle-btn,.chart-type-btn,.season-card,.variety-card,.disease-card,.auth-submit-btn{transition:none}.spinning{animation:none}}@media print{.map-sidebar,.view-toggle,.chart-controls,.zone-selector,.about-btn,.close-btn,.auth-modal-overlay{display:none!important}.chart-container{height:auto!important;page-break-inside:avoid}.public-climate-container{box-shadow:none;border:1px solid #ddd}}.current-season-explorer,.phenology-explorer{padding:1rem;background:var(--bg-primary, #ffffff);border-radius:8px}.loading-state,.error-state,.no-zone-message,.no-data-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:var(--text-secondary, #6B7280)}.loading-state svg,.error-state svg,.no-zone-message svg,.no-data-message svg{margin-bottom:1rem;opacity:.5}.loading-state h3,.no-zone-message h3,.no-data-message h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary, #1F2937)}.loading-state p,.error-state p,.no-zone-message p,.no-data-message p{margin:0;font-size:.875rem}.spinning{animation:spin 1s linear infinite}.trend-icon{vertical-align:middle}.trend-icon.positive{color:#22c55e}.trend-icon.negative{color:#ef4444}.trend-icon.neutral{color:#6b7280}.season-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #E5E7EB)}.season-title h3{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1F2937)}.season-label{display:inline-block;margin-top:.25rem;padding:.25rem .75rem;background:var(--primary-light, #EFF6FF);color:var(--primary, #3B82F6);border-radius:9999px;font-size:.875rem;font-weight:500}.season-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;font-size:.875rem;color:var(--text-secondary, #6B7280)}.data-date,.days-count{display:flex;align-items:center;gap:.25rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{position:relative;display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-secondary, #F9FAFB);border-radius:12px;border:1px solid var(--border-color, #E5E7EB);transition:box-shadow .2s}.summary-card:hover{box-shadow:0 4px 12px #00000014}.card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--bg-primary, #ffffff)}.gdd-card .card-icon{color:#f59e0b}.rainfall-card .card-icon{color:#0ea5e9}.temp-card .card-icon{color:#ef4444}.card-content{flex:1;min-width:0}.card-label{display:block;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #6B7280);margin-bottom:.25rem}.card-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary, #1F2937);line-height:1.2}.card-comparison{display:flex;align-items:center;gap:.25rem;margin-top:.5rem;font-size:.875rem}.comparison-value{font-weight:500}.temp-range{display:flex;gap:1rem;margin-top:.5rem;font-size:.8rem;color:var(--text-secondary, #6B7280)}.temp-min{color:#3b82f6}.temp-max{color:#ef4444}.status-badge{position:absolute;top:.75rem;right:.75rem;padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.status-badge.ahead{background:#dcfce7;color:#166534}.status-badge.behind{background:#fee2e2;color:#991b1b}.status-badge.normal{background:#f3f4f6;color:#4b5563}.milestones-section{margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary, #F9FAFB);border-radius:8px}.milestones-section h4{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--text-primary, #1F2937)}.milestones-list{display:flex;gap:1rem;flex-wrap:wrap}.milestone-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-primary, #ffffff);border-radius:8px;border:1px solid var(--border-color, #E5E7EB)}.milestone-item.reached{border-color:#22c55e;background:#f0fdf4}.milestone-item.reached .milestone-marker{color:#22c55e}.milestone-item.pending .milestone-marker{color:#9ca3af}.milestone-info{display:flex;flex-direction:column}.milestone-name{font-size:.875rem;font-weight:500;color:var(--text-primary, #1F2937)}.milestone-gdd{font-size:.75rem;color:var(--text-secondary, #6B7280)}.baseline-status{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border-color, #E5E7EB);font-size:.875rem;color:var(--text-secondary, #6B7280)}.chart-section{margin-bottom:1.5rem}.chart-controls{display:flex;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color, #E5E7EB)}.chart-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;background:transparent;color:var(--text-secondary, #6B7280);font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s}.chart-tab:hover{background:var(--bg-secondary, #F9FAFB);color:var(--text-primary, #1F2937)}.chart-tab.active{background:var(--primary, #3B82F6);color:#fff}.chart-container{height:300px;position:relative}.recent-days-section h4{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--text-primary, #1F2937)}.recent-days-table-wrapper{overflow-x:auto}.recent-days-table{width:100%;border-collapse:collapse;font-size:.875rem}.recent-days-table th,.recent-days-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color, #E5E7EB)}.recent-days-table th{font-weight:600;color:var(--text-secondary, #6B7280);background:var(--bg-secondary, #F9FAFB);white-space:nowrap}.recent-days-table td{color:var(--text-primary, #1F2937)}.recent-days-table tr:hover td{background:var(--bg-secondary, #F9FAFB)}.phenology-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #E5E7EB)}.header-title h3{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1F2937)}.vintage-label{display:inline-block;margin-top:.25rem;padding:.25rem .75rem;background:var(--primary-light, #EFF6FF);color:var(--primary, #3B82F6);border-radius:9999px;font-size:.875rem;font-weight:500}.header-meta{font-size:.875rem;color:var(--text-secondary, #6B7280)}.estimate-date{display:flex;align-items:center;gap:.25rem}.variety-filter{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-label{font-size:.875rem;font-weight:500;color:var(--text-secondary, #6B7280)}.variety-chips{display:flex;gap:.5rem;flex-wrap:wrap}.variety-chip{padding:.375rem .75rem;border:1px solid var(--border-color, #E5E7EB);background:var(--bg-primary, #ffffff);border-radius:9999px;font-size:.8rem;color:var(--text-secondary, #6B7280);cursor:pointer;transition:all .2s}.variety-chip:hover{border-color:var(--primary, #3B82F6);color:var(--primary, #3B82F6)}.variety-chip.selected{background:var(--primary, #3B82F6);border-color:var(--primary, #3B82F6);color:#fff}.variety-cards{display:flex;flex-direction:column;gap:1rem}.variety-card{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #E5E7EB);border-radius:12px;overflow:hidden;transition:box-shadow .2s}.variety-card:hover{box-shadow:0 4px 12px #00000014}.variety-card.expanded{border-color:var(--primary, #3B82F6)}.variety-card-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;cursor:pointer;transition:background .2s}.variety-card-header:hover{background:var(--bg-secondary, #F9FAFB)}.variety-info{flex:1;min-width:0}.variety-name{display:block;font-size:1rem;font-weight:600;color:var(--text-primary, #1F2937)}.variety-code{font-size:.75rem;color:var(--text-secondary, #6B7280)}.current-stage{flex-shrink:0}.stage-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:500;border:1px solid}.variety-gdd{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--text-primary, #1F2937)}.variety-gdd svg{color:#f59e0b}.expand-icon{color:var(--text-secondary, #6B7280)}.progress-bar-container{position:relative;height:8px;background:var(--bg-secondary, #F3F4F6);margin:0 1.25rem}.progress-bar{height:100%;border-radius:4px;transition:width .5s ease}.progress-label{position:absolute;right:0;top:-1.25rem;font-size:.7rem;color:var(--text-secondary, #6B7280)}.key-dates-summary{display:flex;gap:.75rem;padding:.75rem 1.25rem;flex-wrap:wrap}.date-chip{display:flex;flex-direction:column;align-items:center;padding:.5rem .75rem;background:var(--bg-secondary, #F9FAFB);border-radius:8px;min-width:80px}.date-chip.actual{background:#f0fdf4}.date-chip.harvest{background:#fef3c7}.date-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #6B7280)}.date-value{font-size:.875rem;font-weight:600;color:var(--text-primary, #1F2937)}.days-away{font-size:.7rem;color:var(--primary, #3B82F6);font-weight:500}.variety-card-expanded{padding:1.25rem;border-top:1px solid var(--border-color, #E5E7EB);background:var(--bg-secondary, #F9FAFB)}.stage-timeline h4,.harvest-windows h4{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--text-primary, #1F2937)}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--border-color, #E5E7EB)}.timeline-item{position:relative;padding-bottom:1.25rem}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-2rem;width:18px;height:18px;background:var(--bg-primary, #ffffff);display:flex;align-items:center;justify-content:center}.marker-icon.completed{color:#22c55e}.marker-icon.pending{color:#d1d5db}.timeline-item.past .marker-icon.pending{color:#22c55e}.timeline-item.current{font-weight:500}.timeline-content{padding-left:.5rem}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.stage-name{font-size:.875rem;font-weight:500;color:var(--text-primary, #1F2937)}.gdd-threshold{font-size:.75rem;color:var(--text-secondary, #6B7280)}.timeline-date{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:var(--text-secondary, #6B7280)}.timeline-date em{color:#22c55e}.days-from-now{color:var(--primary, #3B82F6)}.no-date{font-style:italic}.baseline-diff{font-size:.75rem;color:var(--text-secondary, #6B7280);margin-top:.25rem}.harvest-windows{margin-top:1.5rem}.harvest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.harvest-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--bg-primary, #ffffff);border-radius:8px;border:1px solid var(--border-color, #E5E7EB)}.harvest-label{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary, #6B7280);margin-bottom:.25rem}.harvest-date{font-size:.875rem;font-weight:600;color:var(--text-primary, #1F2937)}.harvest-days{font-size:.75rem;color:var(--primary, #3B82F6);font-weight:500}.phenology-legend{display:flex;gap:1.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color, #E5E7EB);font-size:.75rem;color:var(--text-secondary, #6B7280);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.375rem}.legend-item .completed{color:#22c55e}.legend-item .pending{color:#d1d5db}.phenology-note{display:flex;gap:.75rem;margin-top:1rem;padding:1rem;background:#fef3c7;border:1px solid #F59E0B;border-radius:8px;font-size:.8rem;color:#92400e}.phenology-note svg{flex-shrink:0;margin-top:.125rem}.phenology-note p{margin:0;line-height:1.5}.phenology-note strong{font-weight:600}.zone-selector-realtime{position:relative}.selector-wrapper{display:flex;flex-direction:column;gap:.375rem}.selector-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #6B7280)}.selector-trigger{display:flex;align-items:center;gap:.5rem;padding:0 1rem;background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #E5E7EB);border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem;text-align:left;min-width:250px;height:44px;box-sizing:border-box}.selector-trigger:hover{border-color:var(--primary, #3B82F6)}.selector-trigger:disabled{opacity:.6;cursor:not-allowed}.selector-trigger .trigger-icon{flex-shrink:0;color:var(--text-secondary, #6B7280)}.selector-trigger .zone-name{font-weight:500;color:var(--text-primary, #1F2937);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.selector-trigger .zone-name.placeholder{font-weight:400;color:var(--text-secondary, #6B7280)}.selector-trigger .region-name{font-size:.8rem;color:var(--text-secondary, #6B7280);white-space:nowrap;flex-shrink:0}.selector-trigger .chevron{margin-left:auto;transition:transform .2s}.selector-trigger .chevron.open{transform:rotate(180deg)}.selector-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.selector-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:300px;max-height:400px;overflow-y:auto;background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #E5E7EB);border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:101}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #E5E7EB);font-size:.8rem;font-weight:500;color:var(--text-secondary, #6B7280)}.data-hint{display:flex;align-items:center;gap:.25rem;color:#22c55e;font-size:.7rem}.zone-selector-realtime .dropdown-content{padding:.5rem 0}.rt-region-group{margin-bottom:.25rem!important}.rt-region-header{padding:6px 12px!important;font-size:.7rem!important;font-weight:600!important;text-transform:uppercase!important;letter-spacing:.05em!important;color:var(--text-secondary, #6B7280)!important;background:var(--bg-secondary, #F9FAFB)!important}.rt-zone-option{all:unset;box-sizing:border-box;display:flex!important;align-items:center!important;justify-content:space-between!important;width:100%!important;padding:6px 12px!important;margin:0!important;gap:8px!important;background:transparent!important;border:none!important;text-align:left!important;cursor:pointer!important;font-size:.875rem!important;line-height:1.2!important;transition:background .15s!important}.rt-zone-option:hover{background:var(--bg-secondary, #F9FAFB)!important}.rt-zone-option.rt-selected{background:var(--primary-light, #EFF6FF)!important}.rt-zone-name{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;margin:0!important;padding:0!important;flex:1!important}.rt-zone-option.rt-has-data .rt-zone-name{color:var(--text-primary, #1F2937)!important}.rt-zone-option.rt-no-data{opacity:.7!important}.rt-zone-option.rt-no-data .rt-zone-name{color:var(--text-secondary, #6B7280)!important}.rt-indicator{display:flex!important;align-items:center!important;flex-shrink:0!important;margin:0!important;padding:0!important}.rt-indicator.rt-available{color:#22c55e!important}.rt-indicator.rt-unavailable{color:#f59e0b!important}.cta-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.cta-modal{position:relative;max-width:480px;width:100%;background:var(--bg-primary, #ffffff);border-radius:16px;padding:2rem;text-align:center}.cta-close{position:absolute;top:1rem;right:1rem;padding:.5rem;border:none;background:transparent;color:var(--text-secondary, #6B7280);cursor:pointer;border-radius:8px}.cta-close:hover{background:var(--bg-secondary, #F9FAFB)}.cta-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:#fef3c7;color:#f59e0b;border-radius:50%;margin-bottom:1.5rem}.cta-modal h3{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1F2937)}.cta-zone-name{margin:0 0 1rem;font-size:1.1rem;font-weight:500;color:var(--primary, #3B82F6)}.cta-description{margin:0 0 1.5rem;font-size:.9rem;color:var(--text-secondary, #6B7280);line-height:1.6}.cta-benefits{text-align:left;background:var(--bg-secondary, #F9FAFB);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.5rem}.cta-benefits h4{margin:0 0 .5rem;font-size:.8rem;font-weight:600;color:var(--text-primary, #1F2937)}.cta-benefits ul{margin:0;padding-left:1.25rem;font-size:.85rem;color:var(--text-secondary, #6B7280)}.cta-benefits li{margin-bottom:.25rem}.cta-actions{display:flex;flex-direction:column;gap:.75rem}.cta-email-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--primary, #3B82F6);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.cta-email-btn:hover{background:#2563eb}.cta-learn-more{display:flex;align-items:center;justify-content:center;gap:.375rem;font-size:.85rem;color:var(--text-secondary, #6B7280);text-decoration:none}.cta-learn-more:hover{color:var(--primary, #3B82F6)}.cta-privacy{margin:1.5rem 0 0;font-size:.75rem;color:var(--text-secondary, #9CA3AF)}@media (max-width: 768px){.summary-cards{grid-template-columns:1fr}.variety-card-header{flex-wrap:wrap}.variety-info{flex:1 1 100%;margin-bottom:.5rem}.key-dates-summary{justify-content:flex-start}.chart-controls{overflow-x:auto;flex-wrap:nowrap}.chart-tab{white-space:nowrap}.harvest-grid{grid-template-columns:repeat(2,1fr)}}.disease-pressure-explorer{display:flex;flex-direction:column;gap:1.5rem}.disease-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.75rem}.disease-header .header-title{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.disease-header .header-title h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.overall-risk-badge{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600}.disease-cards{display:flex;flex-direction:column;gap:1rem}.disease-card{background:#fff;border:1px solid #E5E7EB;border-left-width:4px;border-radius:12px;overflow:hidden;transition:box-shadow .15s ease}.disease-card:hover{box-shadow:0 2px 8px #0000000f}.disease-card.expanded{box-shadow:0 4px 12px #00000014}.disease-card-header{display:flex;align-items:center;padding:1rem 1.25rem;cursor:pointer;gap:1rem}.disease-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.disease-name-wrapper{display:flex;flex-direction:column;gap:.15rem}.disease-name{font-size:1rem;font-weight:600;color:#111827}.risk-label{font-size:.75rem;font-weight:600;text-transform:uppercase}.disease-score{display:flex;align-items:baseline;gap:.2rem}.score-value{font-size:1.5rem;font-weight:700;color:#111827}.score-label{font-size:.75rem;color:#9ca3af}.risk-icon.low{color:#22c55e}.risk-icon.moderate{color:#f59e0b}.risk-icon.high{color:#ef4444}.risk-icon.extreme{color:#991b1b}.risk-icon.unknown{color:#6b7280}.risk-bar-container{height:8px;background:#f3f4f6;margin:0 1.25rem;position:relative;border-radius:4px}.risk-bar{height:100%;border-radius:4px;transition:width .3s ease}.risk-thresholds{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.risk-thresholds .threshold{position:absolute;top:12px;transform:translate(-50%);font-size:.6rem;color:#9ca3af}.disease-card-expanded{padding:1rem 1.25rem 1.25rem;border-top:1px solid #F3F4F6;margin-top:.75rem}.disease-description{display:flex;gap:.75rem;padding:.75rem;background:#f9fafb;border-radius:8px;margin-bottom:1rem}.disease-description svg{color:#6b7280;flex-shrink:0;margin-top:.1rem}.disease-description p{margin:0;font-size:.875rem;color:#4b5563;line-height:1.5}.contributing-factors{margin-bottom:1rem}.contributing-factors h4{margin:0 0 .75rem;font-size:.85rem;font-weight:600;color:#374151}.factors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.factor-item{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:#f9fafb;border-radius:8px}.factor-item svg{color:#6b7280;flex-shrink:0}.factor-label{font-size:.75rem;color:#6b7280;flex:1}.factor-value{font-size:.8rem;font-weight:600;color:#374151}.factor-value.favorable{color:#dc2626}.spray-recommendation{padding:.75rem;background:#fef3c7;border:1px solid #FDE68A;border-radius:8px}.spray-recommendation h4{margin:0 0 .5rem;font-size:.8rem;font-weight:600;color:#92400e}.spray-recommendation p{margin:0;font-size:.85rem;color:#78350f;line-height:1.4}.disease-pressure-explorer .chart-section{background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow:hidden}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#f9fafb;border-bottom:1px solid #E5E7EB}.chart-header h4{margin:0;font-size:.9rem;font-weight:600;color:#374151}.days-selector{display:flex;align-items:center;gap:.5rem}.days-selector span{font-size:.75rem;color:#6b7280}.days-btn{padding:.35rem .65rem;background:#fff;border:1px solid #D1D5DB;border-radius:6px;font-size:.75rem;font-weight:500;color:#4b5563;cursor:pointer;transition:all .15s ease}.days-btn:hover{background:#f3f4f6}.days-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.disease-pressure-explorer .chart-container{height:280px;padding:1rem}.general-recommendations{background:#f0fdf4;border:1px solid #BBF7D0;border-radius:12px;padding:1rem 1.25rem}.general-recommendations h4{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:#166534}.general-recommendations ul{margin:0;padding-left:1.25rem}.general-recommendations li{font-size:.85rem;color:#15803d;padding:.25rem 0;line-height:1.4}.data-quality-note{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef3c7;border-radius:8px;font-size:.8rem;color:#92400e}.disease-legend{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding-top:.5rem;border-top:1px solid #F3F4F6}.legend-title{font-size:.75rem;font-weight:500;color:#6b7280}.disease-legend .legend-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:#4b5563}.legend-dot{width:10px;height:10px;border-radius:50%}@media (max-width: 640px){.disease-card-header{padding:.875rem 1rem;flex-wrap:wrap}.disease-score{order:-1;width:100%;justify-content:flex-end;margin-bottom:.5rem}.factors-grid{grid-template-columns:1fr 1fr}.chart-header{flex-direction:column;align-items:flex-start;gap:.75rem}.disease-legend{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 768px){.public-climate-container{padding:16px;border-radius:8px;margin:0}.climate-header{margin-bottom:12px;padding-bottom:12px}.header-title{flex-wrap:wrap;gap:8px}.header-title h2{font-size:20px}.about-btn{padding:6px 10px;font-size:12px}.about-btn span{display:none}.climate-attribution{padding:10px 12px;font-size:11px;flex-wrap:wrap}}@media (max-width: 480px){.public-climate-container{padding:12px;border-radius:0;box-shadow:none}.header-title h2{font-size:18px}}@media (max-width: 768px){.zone-selector{margin-bottom:16px}.zone-selector-row{flex-direction:column;align-items:stretch;gap:8px}.zone-dropdown-trigger{max-width:100%;padding:10px 12px}.zone-dropdown-menu{max-width:100%;max-height:60vh;left:0;right:0}.zone-comparison-section{margin-top:12px}.comparison-header{flex-direction:column;align-items:flex-start;gap:8px}.add-comparison-btn{width:100%;justify-content:center;padding:10px}.zone-comparison-tags{gap:6px}.zone-tag{font-size:12px;padding:5px 8px}}@media (max-width: 768px){.zone-selector-realtime .selector-wrapper{flex-direction:column;align-items:stretch;gap:6px}.zone-selector-realtime .selector-trigger{padding:12px;width:100%}.zone-selector-realtime .selector-dropdown{max-height:60vh;width:calc(100% - 24px);left:12px;right:12px}.rt-zone-option{padding:12px;min-height:44px}.cta-modal{width:95%;max-width:none;max-height:90vh;overflow-y:auto;padding:20px;border-radius:12px}.cta-icon svg{width:40px;height:40px}.cta-modal h3{font-size:1.25rem}.cta-benefits{padding:12px}.cta-benefits h4{font-size:.85rem}.cta-benefits li{font-size:.8rem}.cta-email-btn{width:100%;padding:12px;font-size:.9rem}}.chart-container{position:relative;width:100%;min-height:200px}@media (min-width: 769px){.chart-container{height:350px}.disease-pressure-explorer .chart-container{height:280px}}@media (max-width: 768px){.chart-container{height:280px;padding:12px}.disease-pressure-explorer .chart-container{height:240px;padding:10px}}@media (max-width: 640px){.chart-container{height:240px;padding:8px;border-radius:6px}.disease-pressure-explorer .chart-container{height:200px}}@media (max-width: 480px){.chart-container{height:200px;padding:6px;margin-bottom:16px}.disease-pressure-explorer .chart-container{height:180px}}@media (max-width: 768px) and (orientation: landscape){.chart-container{height:180px}.disease-pressure-explorer .chart-container{height:160px}}@media (max-width: 768px){.chart-controls{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:12px}.chart-metric-selector{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px;gap:2px}.chart-metric-selector::-webkit-scrollbar{display:none}.chart-type-btn{padding:8px 12px;font-size:12px;white-space:nowrap;flex-shrink:0}}@media (max-width: 480px){.chart-metric-selector{justify-content:stretch}.chart-type-btn{flex:1;padding:10px 8px;font-size:11px;min-width:0}}@media (max-width: 768px){.chart-section .chart-controls{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;margin:0 -12px 12px;padding:0 12px 8px}.chart-tab{padding:8px 12px;font-size:.8rem;white-space:nowrap;flex-shrink:0;min-height:40px}.chart-tab svg{width:14px;height:14px}}@media (max-width: 480px){.chart-tab{padding:8px 10px;font-size:.75rem;gap:4px}}@media (max-width: 768px){.summary-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}.summary-card{padding:1rem;flex-direction:column;text-align:center;gap:.5rem}.card-icon{width:40px;height:40px;margin:0 auto}.card-icon svg{width:20px;height:20px}.card-label{font-size:.65rem}.card-value{font-size:1.25rem}.card-comparison{justify-content:center;font-size:.75rem}.status-badge{position:static;margin-top:.5rem;align-self:center}.temp-range{flex-direction:column;gap:.25rem;font-size:.75rem}}@media (max-width: 480px){.summary-cards{grid-template-columns:1fr;gap:.5rem}.summary-card{flex-direction:row;text-align:left;padding:.875rem;gap:.75rem}.card-icon{margin:0}.card-content{flex:1}.status-badge{position:absolute;top:.5rem;right:.5rem;margin:0}.temp-range{flex-direction:row;gap:1rem}}@media (max-width: 768px){.ssp-selector{margin-bottom:16px}.ssp-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.ssp-tab{min-width:0;padding:12px 8px}.ssp-name{font-size:12px}.ssp-short{font-size:10px}.ssp-description{font-size:12px;padding:10px}}@media (max-width: 480px){.ssp-tabs{grid-template-columns:1fr;gap:6px}.ssp-tab{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;text-align:left}.ssp-name{font-size:13px}.ssp-short{font-size:11px;margin-left:auto}}@media (max-width: 768px){.period-selector{margin-bottom:16px}.period-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.period-btn{min-width:0;padding:10px 8px}.period-name{font-size:11px}.period-years{font-size:10px}}@media (max-width: 480px){.period-buttons{grid-template-columns:1fr;gap:6px}.period-btn{display:flex;align-items:center;justify-content:space-between;text-align:left;padding:10px 12px}.period-name{font-size:13px}.period-years{margin-left:auto;font-size:12px}}@media (max-width: 768px){.projection-summary{padding:16px}.projection-summary h4{font-size:14px;margin-bottom:12px}.summary-grid{grid-template-columns:1fr;gap:12px}.summary-card{padding:12px;gap:12px}.summary-icon{width:40px;height:40px}.summary-label{font-size:10px}.summary-value{font-size:18px}.summary-change{font-size:12px}}@media (max-width: 768px){.monthly-details{margin-top:16px}.monthly-details h4{font-size:14px;margin-bottom:10px}.monthly-table-wrapper{margin:0 -16px;padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.monthly-table-wrapper:before,.monthly-table-wrapper:after{content:"";position:absolute;top:0;bottom:0;width:20px;pointer-events:none;z-index:1}.monthly-table{min-width:500px}.monthly-table th,.monthly-table td{padding:8px 10px;font-size:11px;white-space:nowrap}}@media (max-width: 480px){.monthly-table-wrapper{margin:0 -12px;padding:0 12px}.monthly-table th,.monthly-table td{padding:6px 8px;font-size:10px}}@media (max-width: 768px){.recent-days-section h4{font-size:14px;margin-bottom:10px}.recent-days-table-wrapper{margin:0 -16px;padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.recent-days-table{min-width:600px}.recent-days-table th,.recent-days-table td{padding:8px 10px;font-size:11px;white-space:nowrap}}@media (max-width: 480px){.recent-days-table-wrapper{margin:0 -12px;padding:0 12px}.recent-days-table th,.recent-days-table td{padding:6px 8px;font-size:10px}}@media (max-width: 768px){.season-explorer{padding:16px;border-radius:8px}.explorer-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}.explorer-header h3{font-size:16px}.explorer-mode-toggle{width:100%;justify-content:center}.baseline-summary{padding:12px;margin-bottom:16px}.baseline-stats{gap:16px;flex-wrap:wrap}.baseline-stat{flex:1 1 calc(50% - 8px);min-width:120px}.baseline-stat .stat-value{font-size:14px}.baseline-stat .stat-label{font-size:11px}.seasons-grid{grid-template-columns:repeat(2,1fr);gap:10px}.season-card{padding:12px}.season-label{font-size:14px}.season-ranking{font-size:10px;padding:2px 6px}.season-stat .stat-label{font-size:10px;min-width:32px}.season-stat .stat-value{font-size:12px}.season-stat .stat-diff{font-size:10px}}@media (max-width: 480px){.season-explorer{padding:12px}.seasons-grid{grid-template-columns:1fr;gap:8px}.baseline-stat{flex:1 1 100%}}@media (max-width: 768px){.comparison-instructions{padding:10px;font-size:12px}.seasons-selection-grid{gap:6px}.season-select-btn{padding:6px 12px;font-size:12px}.comparison-results{margin:0 -16px;padding:0 16px}.comparison-table th,.comparison-table td{padding:8px 10px;font-size:11px}}@media (max-width: 768px){.phenology-explorer{padding:1rem}.phenology-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:1rem;padding-bottom:.75rem}.header-title h3{font-size:1.25rem}.vintage-label{font-size:.8rem;padding:.2rem .6rem}.header-meta{font-size:.75rem}.variety-filter{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:1rem}.filter-label{font-size:.8rem}.variety-chips{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;padding-bottom:4px;margin:0 -1rem;padding:0 1rem 4px}.variety-chips::-webkit-scrollbar{display:none}.variety-chip{flex-shrink:0;padding:8px 12px;font-size:.75rem;min-height:36px}.variety-card-header{padding:12px;flex-wrap:wrap;gap:8px}.variety-info{flex:1 1 60%}.variety-name{font-size:.95rem}.variety-gdd{font-size:.8rem}.key-dates-summary{gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:8px 12px}.date-chip{padding:8px 10px;min-width:70px;flex-shrink:0}.date-label{font-size:.6rem}.date-value{font-size:.8rem}.progress-bar-container{margin:0 12px}.progress-label{font-size:.65rem;top:-1rem}.variety-card-expanded{padding:1rem}.stage-timeline h4,.harvest-windows h4{font-size:.8rem}.timeline{padding-left:1.5rem}.timeline-marker{left:-1.5rem}.stage-name{font-size:.8rem}.gdd-threshold{font-size:.7rem}.timeline-date{font-size:.75rem;flex-wrap:wrap}.days-from-now{display:block;width:100%;margin-top:2px}.baseline-diff{font-size:.7rem}.harvest-windows{margin-top:1rem}.harvest-grid{grid-template-columns:repeat(2,1fr);gap:8px}.harvest-item{padding:10px}.harvest-label{font-size:.7rem}.harvest-date{font-size:.85rem}.harvest-days{font-size:.7rem}.phenology-legend{flex-direction:row;flex-wrap:wrap;gap:10px;font-size:.7rem;padding-top:10px;margin-top:10px}.legend-item{display:flex;align-items:center;gap:4px}}@media (max-width: 480px){.phenology-header{padding-bottom:.5rem}.header-title h3{font-size:1.1rem}.variety-card-header{padding:10px}.variety-info{flex:1 1 100%;order:1}.variety-gdd{order:2}.expand-icon{order:3}.harvest-grid{gap:6px}.harvest-item{padding:8px}}@media (max-width: 768px){.disease-pressure-explorer{gap:1rem}.disease-header{flex-direction:column;align-items:flex-start;gap:8px}.disease-header .header-title{width:100%;justify-content:space-between}.disease-header .header-title h3{font-size:1.1rem}.overall-risk-badge{padding:.3rem .6rem;font-size:.75rem}.disease-card-header{padding:12px;gap:10px}.disease-info{gap:.5rem}.disease-name{font-size:.9rem}.disease-score{flex-direction:column;align-items:flex-end;gap:0}.score-value{font-size:1.25rem}.score-label{font-size:.65rem}.risk-bar-container{margin:0 12px;height:6px}.risk-thresholds .threshold{font-size:.55rem;top:10px}.disease-card-expanded{padding:12px}.disease-description{padding:10px;gap:8px}.disease-description p,.contributing-factors h4{font-size:.8rem}.factors-grid{grid-template-columns:1fr 1fr;gap:6px}.factor-item{padding:8px;gap:6px}.factor-item svg{width:14px;height:14px}.factor-label{font-size:.65rem}.factor-value{font-size:.75rem}.spray-recommendation{padding:10px}.spray-recommendation h4{font-size:.75rem}.spray-recommendation p{font-size:.8rem}.disease-pressure-explorer .chart-section{border-radius:8px}.chart-header{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px}.chart-header h4{font-size:.85rem}.days-selector{width:100%;justify-content:flex-start}.days-selector span{font-size:.7rem}.days-btn{padding:6px 10px;font-size:.7rem;min-height:32px}.general-recommendations{padding:12px}.general-recommendations h4{font-size:.85rem;margin-bottom:8px}.general-recommendations li{font-size:.8rem;padding:3px 0}.data-quality-note{padding:10px;font-size:.75rem}.disease-legend{flex-direction:row;flex-wrap:wrap;gap:8px;font-size:.7rem}.legend-title{width:100%;font-size:.7rem}.disease-legend .legend-item{font-size:.7rem}.legend-dot{width:8px;height:8px}}@media (max-width: 480px){.disease-header .header-title h3{font-size:1rem}.disease-card-header{padding:10px}.disease-score{order:-1;width:100%;flex-direction:row;justify-content:flex-end;margin-bottom:4px}.factors-grid{gap:4px}.factor-item{padding:6px}}@media (max-width: 768px){.current-season-explorer{padding:.75rem}.season-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:1rem;padding-bottom:.75rem}.season-title h3{font-size:1.25rem}.season-label{font-size:.8rem;padding:.2rem .6rem}.season-meta{align-items:flex-start;font-size:.75rem}}@media (max-width: 480px){.current-season-explorer{padding:.5rem}.season-title h3{font-size:1.1rem}}@media (max-width: 768px){.climate-about-overlay{padding:0;align-items:flex-end}.climate-about-modal{max-width:100%;max-height:90vh;border-radius:16px 16px 0 0}.about-header{padding:16px 20px}.about-header h2{font-size:18px}.about-content{padding:16px 20px}}@media (max-width: 768px){.projections-explorer{padding:16px;border-radius:8px}.explorer-header h3{font-size:16px}}@media (max-width: 480px){.projections-explorer{padding:12px}}@media (max-width: 768px){.loading-state,.error-state,.no-zone-message,.no-data-message,.explorer-placeholder,.explorer-loading,.explorer-error{padding:2rem 1.5rem}.loading-state svg,.error-state svg,.no-zone-message svg,.no-data-message svg,.explorer-placeholder svg{width:40px;height:40px}.loading-state h3,.no-zone-message h3,.no-data-message h3{font-size:1.1rem}.loading-state p,.error-state p,.no-zone-message p,.no-data-message p,.explorer-placeholder p{font-size:.8rem}}@media (max-width: 768px){.ssp-tab,.period-btn,.chart-type-btn,.chart-tab,.variety-chip,.season-card,.season-select-btn,.disease-card-header,.variety-card-header,.days-btn,.zone-option,.rt-zone-option{min-height:44px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.ssp-tab:active,.period-btn:active,.chart-type-btn:active,.chart-tab:active,.variety-chip:active,.season-card:active,.season-select-btn:active,.days-btn:active{transform:scale(.98);transition:transform .1s}}@media (prefers-reduced-motion: reduce){.spinning{animation:none}.progress-bar,.risk-bar,.ssp-tab,.period-btn,.chart-type-btn,.chart-tab,.variety-chip,.season-card,.variety-card,.disease-card{transition:none}}@supports (padding: env(safe-area-inset-bottom)){@media (max-width: 768px){.public-climate-container{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.climate-about-modal{padding-bottom:env(safe-area-inset-bottom)}}}@media print{.chart-container{height:auto!important;min-height:200px;page-break-inside:avoid}.zone-selector,.ssp-selector,.period-selector,.chart-controls,.about-btn,.close-btn{display:none}}.site-banners{max-width:1400px;margin:0 auto;padding:12px 24px 0}.site-banner{position:relative;display:flex;align-items:center;gap:14px;padding:14px 20px;border-radius:10px;font-size:14px;background:#fdf6e3;border:1px solid rgba(91,104,48,.2);color:#2f2f2f;transition:opacity .4s ease,transform .4s ease}.site-banner-update .banner-icon{color:#5b6830}.site-banner-coming_soon .banner-icon{color:#d1583b}.banner-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:#5b683014}.site-banner-coming_soon .banner-icon{background:#d1583b14}.banner-content{flex:1;display:flex;gap:6px;align-items:baseline;flex-wrap:wrap;min-width:0}.banner-content strong{font-weight:700;color:#5b6830;white-space:nowrap}.site-banner-coming_soon .banner-content strong{color:#d1583b}.banner-content span{color:#505050;line-height:1.5}.banner-dismiss{background:none;border:none;cursor:pointer;opacity:.3;transition:opacity .2s;padding:4px;display:flex;align-items:center;flex-shrink:0;color:#2f2f2f}.banner-dismiss:hover{opacity:.8}.banner-dots{display:flex;justify-content:center;gap:8px;padding:10px 0 0}.banner-dot{width:6px;height:6px;border-radius:50%;background:#5b683033;border:none;padding:0;cursor:pointer;transition:all .3s ease}.banner-dot.active{background:#5b6830;width:18px;border-radius:3px}.banner-slide-enter{opacity:0;transform:translateY(-8px)}.banner-slide-active{opacity:1;transform:translateY(0)}.banner-slide-exit{opacity:0;transform:translateY(8px)}@media (max-width: 768px){.site-banners{padding:8px 16px 0}.site-banner{font-size:13px;padding:12px 14px;gap:10px}.banner-icon{width:28px;height:28px}.banner-content{flex-direction:column;gap:2px}}.site-header{position:sticky;top:0;z-index:1000;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d;transition:transform .3s ease;will-change:transform}.site-header.header-hidden{transform:translateY(-100%);box-shadow:none}.header-container{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}a.header-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}.header-logo{height:100px;width:auto}.header-title-block h1{margin:0;font-size:22pt;font-weight:700;color:#2f2f2f}.header-title-block p{margin:0;font-size:16pt;font-style:italic;color:#5b6830}.header-nav{display:flex;align-items:center;gap:24px}.header-nav a{color:#5b6830;text-decoration:none;font-size:14pt;font-weight:600;transition:color .2s}.header-nav a:hover{color:#d1583b}.header-nav .nav-cta{padding:8px 16px;background:#d1583b;color:#fff!important;border-radius:6px;transition:background .2s}.header-nav .nav-cta:hover{background:#b84a2e}.auth-header-btn{padding:8px 20px;background:#d1583b;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.auth-header-btn:hover{background:#b84a2e;transform:translateY(-1px)}.user-menu-container{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:14px;font-weight:500;color:#2f2f2f;cursor:pointer;transition:all .2s}.user-menu-trigger:hover{background:#e8e8e8;border-color:#5b6830}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px #00000026;z-index:1000;overflow:hidden}.user-dropdown-header{padding:16px;background:linear-gradient(135deg,#446145,#5b6830);color:#fff;border-bottom:1px solid rgba(255,255,255,.2)}.user-dropdown-header strong{display:block;font-size:14px;margin-bottom:4px}.user-dropdown-header small{display:block;font-size:12px;opacity:.9;text-transform:capitalize}.user-dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;border-top:1px solid #f0f0f0;font-size:14px;color:#2f2f2f;text-align:left;cursor:pointer;transition:background .2s}.user-dropdown-item:hover{background:#f5f5f5}.user-dropdown-item:first-of-type{border-top:none}.user-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.admin-header-link{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;text-decoration:none;transition:all .2s ease;box-shadow:0 2px 3px #0000001a;color:#5b6830;font-size:14pt;font-weight:600}.admin-header-link:hover{transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.user-dropdown .user-dropdown-item.admin-link,.user-dropdown a.user-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem 1rem;background:none;border:none;color:#374151;font-size:.875rem;text-align:left;text-decoration:none;cursor:pointer;transition:background-color .15s ease}.user-dropdown a.user-dropdown-item:hover{background-color:#f3f4f6;color:#1f2937}.admin-header-link svg,.user-dropdown-item svg{flex-shrink:0}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:none;border:1px solid #e0e0e0;color:#5b6830;cursor:pointer;border-radius:8px;transition:all .2s;flex-shrink:0}.mobile-menu-btn:hover{background:#f5f5f5;border-color:#5b6830}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:9998;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-nav{position:fixed;top:0;right:0;bottom:0;width:300px;max-width:85vw;background:#fff;z-index:9999;display:flex;flex-direction:column;box-shadow:-8px 0 30px #0003;animation:slideIn .3s ease;overflow-y:auto}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-nav-close{position:absolute;top:16px;right:16px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:8px;color:#666;cursor:pointer;transition:all .2s}.mobile-nav-close:hover{background:#e5e5e5;color:#333}.mobile-nav>a:first-of-type{margin-top:70px}.mobile-nav a,.mobile-nav .mobile-nav-item{display:flex;align-items:center;gap:14px;padding:16px 24px;color:#2f2f2f;text-decoration:none;font-size:16px;font-weight:500;background:none;border:none;cursor:pointer;transition:background-color .2s;width:100%;text-align:left}.mobile-nav a:hover,.mobile-nav .mobile-nav-item:hover{background:#f8f8f8}.mobile-nav svg{flex-shrink:0;color:#5b6830}.mobile-nav-divider{height:1px;background:#e5e5e5;margin:16px 24px}.mobile-admin-link{background:#eff6ff!important;margin:8px 16px;border-radius:8px;padding:14px 20px!important}.mobile-admin-link svg{color:#1e40af!important}.mobile-admin-link:hover{background:#dbeafe!important}.mobile-auth-btn{background:#d1583b!important;color:#fff!important;margin:16px;border-radius:8px;justify-content:center;font-weight:600}.mobile-auth-btn svg{color:#fff!important}.mobile-auth-btn:hover{background:#b84a2e!important}.mobile-user-info{display:flex;align-items:center;gap:14px;padding:20px 24px;background:#f8f9fa;margin:8px 16px;border-radius:12px}.mobile-user-info>svg{width:44px;height:44px;padding:10px;background:#5b6830;color:#fff!important;border-radius:50%;flex-shrink:0}.mobile-user-info div{display:flex;flex-direction:column;min-width:0}.mobile-user-info strong{font-size:15px;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-user-info small{font-size:13px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.mobile-logout{color:#dc3545!important}.mobile-logout svg{color:#dc3545!important}.mobile-logout:hover{background:#fee2e2!important}@media (max-width: 768px){.mobile-menu-btn{display:flex}.desktop-nav{display:none!important}.user-menu-trigger span{display:none}.user-dropdown{right:-8px}.header-container{padding:10px 16px}.header-logo{height:44px}.header-title-block h1{font-size:15pt}.header-title-block p{font-size:10pt}.mobile-menu-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-menu-btn:active{transform:scale(.95);background:#f0f0f0}}@media (max-width: 480px){.header-container{padding:8px 12px}.header-logo{height:38px}.header-title-block h1{font-size:14pt}.header-title-block p{font-size:9pt}.mobile-nav{width:100%;max-width:100%}}@media (max-width: 360px){.header-title-block{display:none}.header-logo{height:36px}}@media (prefers-reduced-motion: reduce){.site-header{transition:none}.site-header.header-hidden{transform:none;opacity:.7;padding:4px 0}}@media (max-width: 768px) and (orientation: landscape){.header-container{padding:6px 16px}.header-logo{height:32px}.header-title-block{display:none}.mobile-menu-btn{width:40px;height:40px}}.about-page{min-height:100vh;background:#f8f9fa;display:flex;flex-direction:column}.about-page-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fff;border-bottom:1px solid #e9ecef;position:sticky;top:0;z-index:100}.back-link{display:inline-flex;align-items:center;gap:8px;color:#06c;text-decoration:none;font-weight:500;font-size:14px;transition:color .2s}.back-link:hover{color:#004999}.about-logo{height:40px;width:auto}.about-page-content{flex:1;padding:40px 24px}.about-container{max-width:800px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;overflow:hidden}.about-hero{padding:48px 32px;background:linear-gradient(135deg,#1a365d,#2c5282);color:#fff;text-align:center}.about-hero h1{margin:0 0 12px;font-size:32px;font-weight:700}.hero-subtitle{margin:0;font-size:18px;opacity:.9}.about-section{padding:32px;border-bottom:1px solid #e9ecef}.about-section:last-child{border-bottom:none}.about-section h2{margin:0 0 16px;font-size:20px;font-weight:600;color:#333}.section-icon{float:left;margin-right:16px;padding:12px;background:#f5f8ff;border-radius:10px;color:#06c}.section-content{overflow:hidden}.section-content p{margin:0 0 12px;line-height:1.7;color:#555}.section-content p:last-child{margin-bottom:0}.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px}.feature-card{padding:20px;background:#f8f9fa;border-radius:10px;border:1px solid #e9ecef}.feature-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:#e0e7ff;border-radius:8px;color:#3730a3;margin-bottom:12px}.feature-card h3{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.feature-card p{margin:0;font-size:14px;line-height:1.6;color:#666}.data-sources-list{display:flex;flex-direction:column;gap:20px;margin-top:16px}.data-source-item{padding:20px;background:#f8f9fa;border-radius:10px;border-left:4px solid #0066cc}.data-source-item h4{margin:0 0 8px;font-size:15px;font-weight:600;color:#333}.data-source-item p{margin:0 0 12px;font-size:14px;line-height:1.6;color:#666}.source-link{display:inline-flex;align-items:center;gap:6px;color:#06c;font-size:14px;font-weight:500;text-decoration:none}.source-link:hover{text-decoration:underline}.premium-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.premium-content h2{color:#0369a1}.premium-content p{color:#555;line-height:1.6;margin-bottom:20px}.premium-features{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.premium-feature{padding:6px 14px;background:#fff;border-radius:20px;font-size:13px;color:#0369a1;border:1px solid #bae6fd}.premium-btn{display:inline-block;padding:14px 28px;background:#06c;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:15px;transition:background .2s}.premium-btn:hover{background:#004999}.contact-section{text-align:center}.contact-grid{display:flex;justify-content:center;gap:20px;margin-top:20px}.contact-card{display:flex;align-items:center;gap:10px;padding:16px 24px;background:#f8f9fa;border-radius:10px;text-decoration:none;color:#333;border:1px solid #e9ecef;transition:all .2s}.contact-card:hover{background:#e9ecef;border-color:#06c;color:#06c}.about-page-footer{padding:24px;text-align:center;background:#fff;border-top:1px solid #e9ecef}.about-page-footer p{margin:0;font-size:14px;color:#666}.footer-location{margin-top:4px!important;font-size:13px!important;color:#999!important}@media (max-width: 768px){.about-page-header{padding:12px 16px}.back-link span{display:none}.about-page-content{padding:20px 16px}.about-container{border-radius:12px}.about-hero{padding:32px 24px}.about-hero h1{font-size:26px}.hero-subtitle{font-size:16px}.about-section{padding:24px}.section-icon{float:none;margin:0 0 16px}.features-grid{grid-template-columns:1fr}.contact-grid{flex-direction:column;align-items:center}.contact-card{width:100%;max-width:280px;justify-content:center}}@media (max-width: 480px){.about-hero h1{font-size:22px}.about-section h2{font-size:18px}.premium-features{justify-content:center}}.legal-content{line-height:1.7;color:#333;font-size:.95rem}.legal-content h1{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem;border-bottom:2px solid #10b981;padding-bottom:.75rem}.legal-content h2{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin-top:2rem;margin-bottom:1rem}.legal-content h3{font-size:1.05rem;font-weight:600;color:#374151;margin-top:1.5rem;margin-bottom:.75rem}.legal-content p{margin-bottom:1rem}.legal-content ul{margin-bottom:1rem;padding-left:1.5rem}.legal-content li{margin-bottom:.5rem}.legal-content section{margin-bottom:1.5rem}.legal-content address{font-style:normal;background:#f9fafb;padding:1rem;border-radius:8px;margin:1rem 0}.legal-content a{color:#059669;text-decoration:none}.legal-content a:hover{text-decoration:underline}.legal-effective{color:#6b7280;font-size:.9rem;margin-bottom:1.5rem}.cookie-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.cookie-table th,.cookie-table td{border:1px solid #e5e7eb;padding:.75rem;text-align:left}.cookie-table th{background:#f3f4f6;font-weight:600}.cookie-table tr:hover{background:#f9fafb}.legal-tabs{display:flex;flex-direction:column;height:100%}.legal-tabs-header{display:flex;border-bottom:1px solid #e5e7eb;background:#f9fafb;padding:0 .5rem;flex-shrink:0}.legal-tab{background:none;border:none;padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.legal-tab:hover{color:#374151}.legal-tab.active{color:#059669;border-bottom-color:#059669;background:#fff}.legal-tabs-content{flex:1;overflow-y:auto;padding:1.5rem}.legal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.legal-modal{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.legal-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.legal-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1a1a1a}.legal-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;line-height:1;border-radius:4px;transition:all .2s}.legal-modal-close:hover{color:#1a1a1a;background:#f3f4f6}.legal-modal-body{flex:1;overflow-y:auto;min-height:0}.legal-modal-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb;flex-shrink:0;border-radius:0 0 12px 12px}.legal-checkbox-label{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem;cursor:pointer;font-size:.9rem;color:#374151}.legal-checkbox-label input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:#059669;cursor:pointer}.legal-checkbox-label strong{color:#1a1a1a}.legal-modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.legal-btn-cancel,.legal-btn-accept{padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s}.legal-btn-cancel{background:#fff;border:1px solid #d1d5db;color:#374151}.legal-btn-cancel:hover{background:#f3f4f6;border-color:#9ca3af}.legal-btn-accept{background:#059669;border:none;color:#fff}.legal-btn-accept:hover:not(:disabled){background:#047857}.legal-btn-accept:disabled{background:#9ca3af;cursor:not-allowed}.legal-page{min-height:100vh;background:#f9fafb;padding:2rem 1rem}.legal-page-container{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:240px 1fr;gap:2rem}.legal-sidebar{position:sticky;top:2rem;height:fit-content}.legal-sidebar h3{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:1rem}.legal-sidebar ul{list-style:none;padding:0;margin:0}.legal-sidebar li{margin-bottom:.25rem}.legal-nav-link{display:block;width:100%;text-align:left;background:none;border:none;padding:.75rem 1rem;font-size:.95rem;color:#374151;cursor:pointer;border-radius:8px;transition:all .2s}.legal-nav-link:hover{background:#e5e7eb}.legal-nav-link.active{background:#059669;color:#fff;font-weight:500}.legal-sidebar-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #e5e7eb;font-size:.85rem;color:#6b7280}.legal-sidebar-footer p{margin-bottom:.5rem}.legal-sidebar-footer a{color:#059669;text-decoration:none}.legal-sidebar-footer a:hover{text-decoration:underline}.legal-main{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.legal-back-to-top{display:block;margin:2rem auto 0;background:none;border:1px solid #d1d5db;padding:.5rem 1rem;font-size:.85rem;color:#6b7280;cursor:pointer;border-radius:6px;transition:all .2s}.legal-back-to-top:hover{background:#f3f4f6;color:#374151}@media (max-width: 768px){.legal-page-container{grid-template-columns:1fr}.legal-sidebar{position:static;background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.legal-sidebar ul{display:flex;gap:.5rem;flex-wrap:wrap}.legal-sidebar li{margin:0}.legal-nav-link{padding:.5rem .75rem;font-size:.85rem}.legal-sidebar-footer{display:none}.legal-main{padding:1.5rem}.legal-modal{max-height:90vh;margin:.5rem}.legal-tabs-header{overflow-x:auto}.legal-tab{white-space:nowrap;padding:.75rem;font-size:.85rem}}.articles-page{min-height:100vh;background:#f9fafb}.articles-filters{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem}.articles-filters-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1rem}.articles-search{display:flex;align-items:center;gap:.5rem;background:#f3f4f6;border-radius:8px;padding:.5rem .75rem;flex:1;max-width:400px}.articles-search input{border:none;background:none;outline:none;font-size:.875rem;width:100%;color:#374151}.articles-search svg{color:#9ca3af;flex-shrink:0}.articles-clear-filters{background:none;border:1px solid #d1d5db;border-radius:6px;padding:.4rem .75rem;font-size:.8rem;color:#6b7280;cursor:pointer}.articles-clear-filters:hover{background:#f3f4f6}.articles-content{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.articles-loading,.articles-error,.articles-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;color:#6b7280}.articles-loading .spin{animation:spin 1s linear infinite}.articles-error{color:#ef4444}.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.article-card{background:#fff;border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;box-shadow:0 1px 3px #00000014;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.article-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.article-card-image{position:relative;aspect-ratio:16 / 9;overflow:hidden}.article-card-image img{width:100%;height:100%;object-fit:cover}.article-card-badge{position:absolute;top:.75rem;right:.75rem;padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.article-card-badge.pro{background:#f59e0b;color:#fff}.article-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}.article-card-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.article-tag{background:#eff6ff;color:#2563eb;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.article-card-title{font-size:1.1rem;font-weight:600;margin:0 0 .5rem;color:#111827;line-height:1.4}.article-card-excerpt{font-size:.875rem;color:#6b7280;margin:0 0 1rem;line-height:1.5;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article-card-meta{display:flex;gap:1rem;font-size:.75rem;color:#9ca3af;margin-top:auto}.article-meta-item{display:flex;align-items:center;gap:3px}.articles-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;padding:1rem 0}.articles-pagination button{display:flex;align-items:center;gap:4px;padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.875rem;color:#374151;cursor:pointer}.articles-pagination button:hover:not(:disabled){background:#f3f4f6}.articles-pagination button:disabled{opacity:.5;cursor:not-allowed}.articles-pagination-info{font-size:.875rem;color:#6b7280}@media (max-width: 768px){.articles-header h1{font-size:1.5rem}.articles-grid{grid-template-columns:1fr}.articles-filters-inner{flex-direction:column;align-items:stretch}.articles-search{max-width:none}}.article-detail-page{min-height:100vh;background:#f9fafb}.article-detail-loading,.article-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#6b7280;gap:1rem}.article-detail-loading .spin{animation:spin 1s linear infinite}.article-detail-error a{color:#2563eb}.article-detail-gate{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:2rem;background:#f9fafb}.article-gate-card{text-align:center;max-width:420px;padding:3rem 2.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;border:1px solid #e5e7eb}.article-gate-card h2{margin:0 0 .75rem;font-size:1.5rem;font-weight:700;color:#1f2937}.article-gate-card p{margin:0 0 2rem;font-size:.95rem;color:#6b7280;line-height:1.6}.article-gate-actions{display:flex;flex-direction:column;gap:12px;align-items:center}.article-gate-signin{display:inline-block;width:100%;padding:12px 32px;background:#d1583b;color:#fff;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s}.article-gate-signin:hover{background:#b84a2e;transform:translateY(-1px);box-shadow:0 4px 12px #d1583b4d}.article-gate-back{display:inline-flex;align-items:center;gap:4px;color:#6b7280;font-size:.875rem;text-decoration:none;transition:color .2s}.article-gate-back:hover{color:#374151}.articles-back-link{display:inline-flex;align-items:center;gap:4px;color:#fffc;text-decoration:none;font-size:.875rem;margin-bottom:1rem}.articles-back-link:hover{color:#fff}.article-detail-hero{background:linear-gradient(135deg,#1e3a5f,#2d5a87);color:#fff;padding:2rem 1.5rem 3rem}.article-detail-hero-content{max-width:800px;margin:0 auto}.article-detail-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.article-detail-hero .article-tag{background:#ffffff26;color:#ffffffe6}.article-detail-hero h1{font-size:2.25rem;font-weight:700;margin:0 0 1rem;line-height:1.3}.article-detail-meta{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.875rem;color:#fffc}.article-detail-meta span{display:flex;align-items:center;gap:4px}.article-detail-featured-image{max-width:800px;margin:-2rem auto 0;padding:0 1.5rem}.article-detail-featured-image img{width:100%;border-radius:12px;box-shadow:0 4px 12px #00000026}.article-detail-body{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.article-detail-body-content{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 1px 3px #00000014;line-height:1.8;font-size:1.05rem;color:#374151}.article-detail-body-content h2{font-size:1.5rem;margin:2rem 0 1rem;color:#111827}.article-detail-body-content h3{font-size:1.25rem;margin:1.5rem 0 .75rem;color:#1f2937}.article-detail-body-content p{margin:0 0 1rem}.article-detail-body-content blockquote{border-left:4px solid #2563eb;margin:1.5rem 0;padding:1rem 1.5rem;background:#eff6ff;border-radius:0 8px 8px 0;color:#1e40af}.article-detail-body-content pre{background:#1f2937;color:#e5e7eb;padding:1rem;border-radius:8px;overflow-x:auto;font-size:.875rem}.article-detail-body-content img{max-width:100%;border-radius:8px;margin:1rem 0}.article-detail-body-content a{color:#2563eb;text-decoration:underline}.article-detail-body-content ul,.article-detail-body-content ol{margin:.5rem 0 1rem 1.5rem}.article-detail-body-content li{margin-bottom:.25rem}.article-engagement-bar{display:flex;gap:.75rem;padding:1.5rem 0;border-top:1px solid #e5e7eb;margin-top:2rem}.engagement-btn{display:flex;align-items:center;gap:6px;padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:.875rem;color:#6b7280;cursor:pointer;transition:all .15s}.engagement-btn:hover:not(:disabled){background:#f3f4f6;color:#374151}.engagement-btn:disabled{opacity:.5;cursor:not-allowed}.engagement-btn.liked{color:#ef4444;border-color:#fecaca;background:#fef2f2}.related-articles-section{padding:2rem 1.5rem;background:#f9fafb}.related-articles-inner{max-width:800px;margin:0 auto}.related-articles-inner h3{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 1.25rem}.related-articles-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.related-article-card{display:flex;flex-direction:column;background:#fff;border-radius:10px;overflow:hidden;text-decoration:none;border:1px solid #e5e7eb;transition:box-shadow .2s,transform .15s}.related-article-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.related-article-thumb{height:140px;overflow:hidden}.related-article-thumb img{width:100%;height:100%;object-fit:cover}.related-article-info{padding:1rem}.related-article-info h4{font-size:.95rem;font-weight:600;color:#1f2937;margin:0 0 .4rem;line-height:1.4}.related-article-info p{font-size:.8rem;color:#6b7280;margin:0 0 .5rem;line-height:1.5}.related-article-date{font-size:.75rem;color:#9ca3af}.article-comments-section{background:#fff;border-top:1px solid #e5e7eb;padding:2rem 1.5rem}.article-comments-inner{max-width:800px;margin:0 auto}.article-comments-inner h3{font-size:1.25rem;margin:0 0 1.5rem;color:#111827}.comment-form{margin-bottom:2rem}.comment-form textarea{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:.75rem;font-size:.875rem;resize:vertical;font-family:inherit}.comment-form textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.comment-form button[type=submit]{display:inline-flex;align-items:center;gap:6px;margin-top:.5rem;padding:.5rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer}.comment-form button[type=submit]:hover:not(:disabled){background:#1d4ed8}.comment-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.comment-replying-to{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#6b7280;margin-bottom:.5rem}.comment-replying-to button{background:none;border:none;color:#ef4444;cursor:pointer;font-size:.8rem}.comment-signin-prompt{color:#6b7280;font-size:.875rem;margin-bottom:2rem}.comment-signin-prompt a{color:#2563eb}.comments-list{display:flex;flex-direction:column;gap:1rem}.comment{padding:1rem;border:1px solid #f3f4f6;border-radius:8px}.comment-reply{margin-left:2rem;border-color:#e5e7eb;background:#fafafa}.comment-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.comment-author{font-weight:600;font-size:.875rem;color:#111827}.comment-date{font-size:.75rem;color:#9ca3af}.comment-body{font-size:.875rem;color:#374151;margin:0 0 .5rem;line-height:1.5}.comment-actions{display:flex;gap:.5rem}.comment-action-btn{display:flex;align-items:center;gap:4px;background:none;border:none;font-size:.75rem;color:#6b7280;cursor:pointer;padding:.2rem .4rem;border-radius:4px}.comment-action-btn:hover{background:#f3f4f6;color:#374151}.comment-action-btn.danger:hover{color:#ef4444;background:#fef2f2}.comment-replies{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}@media (max-width: 768px){.article-detail-hero h1{font-size:1.5rem}.article-detail-body-content{padding:1.5rem;font-size:1rem}.related-articles-grid{grid-template-columns:1fr}.comment-reply{margin-left:1rem}}.research-page{min-height:100vh;background:#f9fafb}.research-header{background:linear-gradient(135deg,#1a3c34,#2d6a5a);color:#fff;padding:2rem 1.5rem}.research-header-content{max-width:1200px;margin:0 auto}.research-back-link{display:inline-flex;align-items:center;gap:4px;color:#fffc;text-decoration:none;font-size:.875rem;margin-bottom:1rem}.research-back-link:hover{color:#fff}.research-header h1{font-size:2rem;font-weight:700;margin:0 0 .5rem}.research-header p{font-size:1rem;color:#ffffffd9;margin:0;max-width:600px}.research-filters{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;position:sticky;top:0;z-index:10}.research-filters-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1rem}.research-search{display:flex;align-items:center;gap:.5rem;background:#f3f4f6;border-radius:8px;padding:.5rem .75rem;flex:1;max-width:400px}.research-search input{border:none;background:none;outline:none;font-size:.875rem;width:100%;color:#374151}.research-search svg{color:#9ca3af;flex-shrink:0}.research-clear-filters{background:none;border:1px solid #d1d5db;border-radius:6px;padding:.4rem .75rem;font-size:.8rem;color:#6b7280;cursor:pointer}.research-content{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.research-loading,.research-error,.research-empty{display:flex;flex-direction:column;align-items:center;padding:4rem 1rem;color:#6b7280}.research-loading .spin{animation:spin 1s linear infinite}.research-list{display:flex;flex-direction:column;gap:1rem}.research-card{display:flex;gap:1.5rem;background:#fff;border-radius:12px;padding:1.5rem;text-decoration:none;color:inherit;box-shadow:0 1px 3px #00000014;transition:box-shadow .2s}.research-card:hover{box-shadow:0 4px 12px #0000001f}.research-card-icon{flex-shrink:0;width:48px;height:48px;background:#ecfdf5;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#059669}.research-card-body{flex:1;min-width:0}.research-card-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.research-tag{background:#ecfdf5;color:#059669;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.research-card-title{font-size:1.15rem;font-weight:600;margin:0 0 .5rem;color:#111827}.research-card-abstract{font-size:.875rem;color:#6b7280;margin:0 0 .75rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.research-card-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.75rem;color:#9ca3af}.research-meta-item{display:flex;align-items:center;gap:3px}.research-badge-pro{display:inline-block;background:#f59e0b;color:#fff;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;margin-top:.5rem}.research-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem}.research-pagination button{display:flex;align-items:center;gap:4px;padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.875rem;color:#374151;cursor:pointer}.research-pagination button:hover:not(:disabled){background:#f3f4f6}.research-pagination button:disabled{opacity:.5;cursor:not-allowed}.research-pagination span{font-size:.875rem;color:#6b7280}@media (max-width: 768px){.research-header h1{font-size:1.5rem}.research-card{flex-direction:column;gap:1rem}.research-card-icon{display:none}.research-filters-inner{flex-direction:column;align-items:stretch}.research-search{max-width:none}}.research-detail-page{min-height:100vh;background:#f9fafb}.research-detail-loading,.research-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#6b7280;gap:1rem}.research-detail-loading .spin{animation:spin 1s linear infinite}.research-detail-error a{color:#059669}.research-detail-hero{background:linear-gradient(135deg,#1a3c34,#2d6a5a);color:#fff;padding:2rem 1.5rem 3rem}.research-detail-hero-content{max-width:800px;margin:0 auto}.research-detail-hero h1{font-size:2rem;font-weight:700;margin:1rem 0;line-height:1.3}.research-detail-meta{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.875rem;color:#fffc}.research-detail-meta span{display:flex;align-items:center;gap:4px}.research-detail-content{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.research-detail-abstract{background:#fff;border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #00000014}.research-detail-abstract h2{font-size:1.25rem;margin:0 0 1rem;color:#111827}.research-detail-abstract p{font-size:1rem;line-height:1.7;color:#374151;margin:0}.research-detail-sections{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1.5rem}.research-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #00000014}.research-section h3{font-size:1.15rem;margin:0 0 1rem;color:#111827}.section-text{line-height:1.7;color:#374151}.section-text p{margin:0 0 1rem}.section-caption{font-size:.8rem;color:#6b7280;font-style:italic;margin-top:.75rem}.section-image{max-width:100%;border-radius:8px}.section-chart-placeholder,.section-table-placeholder{display:flex;flex-direction:column;align-items:center;padding:2rem;background:#f3f4f6;border-radius:8px;color:#6b7280;gap:.5rem}.research-detail-files{background:#fff;border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #00000014}.research-detail-files h3{font-size:1.15rem;margin:0 0 1rem;color:#111827}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid #e5e7eb;border-radius:8px;text-decoration:none;color:#374151;transition:background .15s}.file-item:hover{background:#f9fafb}.file-item svg:first-child{color:#059669;flex-shrink:0}.file-item svg:last-child{color:#9ca3af;margin-left:auto;flex-shrink:0}.file-name{font-size:.875rem;font-weight:500;display:block}.file-desc{font-size:.75rem;color:#6b7280;display:block}.research-detail-citation{background:#fff;border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #00000014}.research-detail-citation h3{font-size:1.15rem;margin:0 0 1rem;color:#111827}.citation-box{display:flex;align-items:flex-start;gap:1rem;background:#f9fafb;padding:1rem;border-radius:8px;border:1px solid #e5e7eb}.citation-box p{font-size:.875rem;color:#374151;margin:0;flex:1;line-height:1.5;font-style:italic}.citation-box button{display:flex;align-items:center;gap:4px;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:.4rem .75rem;font-size:.8rem;color:#6b7280;cursor:pointer;flex-shrink:0}.citation-box button:hover{background:#f3f4f6}.research-detail-funding{background:#fffbeb;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #fde68a}.research-detail-funding h3{font-size:1rem;margin:0 0 .5rem;color:#92400e}.research-detail-funding p{font-size:.875rem;color:#78350f;margin:0}.research-engagement-bar{display:flex;gap:.75rem;padding:1.5rem 0;border-top:1px solid #e5e7eb}.research-comments-section{background:#fff;border-top:1px solid #e5e7eb;padding:2rem 1.5rem}.research-comments-inner{max-width:800px;margin:0 auto}.research-comments-inner h3{font-size:1.25rem;margin:0 0 1.5rem;color:#111827}@media (max-width: 768px){.research-detail-hero h1{font-size:1.5rem}.research-detail-abstract,.research-section{padding:1.5rem}.citation-box{flex-direction:column}}.admin-nav-bar{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:50}.admin-nav-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:4rem}.admin-nav-brand{display:flex;align-items:center}.admin-nav-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}.admin-nav-logo-text{font-size:1.25rem;font-weight:700;color:#111827}.admin-nav-logo-badge{padding:.125rem .5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;font-size:.75rem;font-weight:600;border-radius:.25rem}.admin-nav-links{display:flex;align-items:center;gap:.25rem}.admin-nav-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:#6b7280;text-decoration:none;font-size:.875rem;font-weight:500;border-radius:.375rem;transition:all .15s ease}.admin-nav-link:hover{color:#374151;background-color:#f3f4f6}.admin-nav-link.active{color:#2563eb;background-color:#eff6ff}.admin-nav-link svg{flex-shrink:0}.admin-nav-right{display:flex;align-items:center}.admin-nav-exit{padding:.5rem 1rem;color:#6b7280;text-decoration:none;font-size:.875rem;font-weight:500;border-radius:.375rem;transition:all .15s ease}.admin-nav-exit:hover{color:#374151;background-color:#f3f4f6}.admin-main{min-height:calc(100vh - 4rem)}@media (max-width: 768px){.admin-nav-links,.admin-nav-link span{display:none}}.admin-page{min-height:100vh;background-color:#f9fafb}.admin-container{max-width:1400px;margin:0 auto;padding:1.5rem}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.admin-header h1{font-size:1.5rem;font-weight:700;color:#111827;margin:0}.admin-header p{color:#6b7280;margin:.25rem 0 0;font-size:.875rem}.admin-header-actions{display:flex;align-items:center;gap:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;border:none}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8}.btn-primary:disabled{background-color:#93c5fd;cursor:not-allowed}.btn-secondary{background-color:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background-color:#f9fafb}.btn-icon{padding:.5rem}.card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.card-header h2,.card-header h3{font-size:1.125rem;font-weight:600;color:#111827;margin:0}.card-header p{font-size:.875rem;color:#6b7280;margin:.25rem 0 0}.card-body{padding:1.5rem}.stats-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;border-left:4px solid #3b82f6}.stats-card.green{border-left-color:#10b981}.stats-card.yellow{border-left-color:#f59e0b}.stats-card.red{border-left-color:#ef4444}.stats-card.purple{border-left-color:#8b5cf6}.stats-card.indigo{border-left-color:#6366f1}.stats-card.cyan{border-left-color:#06b6d4}.stats-card-content{display:flex;align-items:center;justify-content:space-between}.stats-card-title{font-size:.875rem;color:#6b7280;font-weight:500;margin:0}.stats-card-value{font-size:1.875rem;font-weight:700;color:#111827;margin:.25rem 0}.stats-card-subtitle{font-size:.75rem;color:#9ca3af;margin:0}.stats-card-icon{padding:.75rem;border-radius:9999px;background-color:#eff6ff}.stats-card.green .stats-card-icon{background-color:#d1fae5}.stats-card.yellow .stats-card-icon{background-color:#fef3c7}.stats-card.red .stats-card-icon{background-color:#fee2e2}.stats-card.purple .stats-card-icon{background-color:#ede9fe}.stats-card-icon svg{width:1.5rem;height:1.5rem;color:#3b82f6}.stats-card.green .stats-card-icon svg{color:#10b981}.stats-card.yellow .stats-card-icon svg{color:#f59e0b}.stats-card.red .stats-card-icon svg{color:#ef4444}.stats-card.purple .stats-card-icon svg{color:#8b5cf6}.stats-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1rem;margin-bottom:1.5rem}@media (min-width: 640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.two-column-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.two-column-grid{grid-template-columns:2fr 1fr}}.three-column-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.three-column-grid{grid-template-columns:1fr 1fr 1fr}}.stations-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.stations-grid{grid-template-columns:repeat(2,1fr)}}.table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background-color:#f9fafb}.admin-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e7eb}.admin-table th.sortable{cursor:pointer}.admin-table th.sortable:hover{background-color:#f3f4f6}.admin-table tbody tr{border-bottom:1px solid #f3f4f6}.admin-table tbody tr:hover{background-color:#f9fafb}.admin-table td{padding:.75rem 1rem;font-size:.875rem;color:#374151}.admin-table .text-muted{color:#9ca3af}.admin-table .font-medium{font-weight:500;color:#111827}.admin-table .font-mono{font-family:ui-monospace,SFMono-Regular,monospace}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-green{background-color:#d1fae5;color:#065f46}.badge-yellow{background-color:#fef3c7;color:#92400e}.badge-red{background-color:#fee2e2;color:#991b1b}.badge-blue{background-color:#dbeafe;color:#1e40af}.badge-gray{background-color:#f3f4f6;color:#374151}.badge-purple{background-color:#ede9fe;color:#5b21b6}.badge-indigo{background-color:#e0e7ff;color:#3730a3}.badge-cyan{background-color:#cffafe;color:#0e7490}.badge svg{width:.75rem;height:.75rem}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-healthy{background-color:#d1fae5;color:#065f46}.status-stale{background-color:#fef3c7;color:#92400e}.status-offline{background-color:#fee2e2;color:#991b1b}.status-active{background-color:#d1fae5;color:#065f46}.status-inactive{background-color:#fee2e2;color:#991b1b}.status-pending{background-color:#f3f4f6;color:#374151}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;color:#111827;background-color:#fff;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.search-input-wrapper{position:relative}.search-input-wrapper svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:#9ca3af}.search-input-wrapper input{padding-left:2.5rem}.toggle-switch{position:relative;display:inline-flex;height:1.5rem;width:2.75rem;cursor:pointer;border-radius:9999px;background-color:#d1d5db;transition:background-color .2s ease}.toggle-switch.active{background-color:#2563eb}.toggle-switch-handle{position:absolute;top:.125rem;left:.125rem;height:1.25rem;width:1.25rem;background-color:#fff;border-radius:9999px;transition:transform .2s ease;box-shadow:0 1px 3px #0000001a}.toggle-switch.active .toggle-switch-handle{transform:translate(1.25rem)}.filters-panel{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1rem;margin-bottom:1rem}.filters-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.filters-header h3{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:#374151;margin:0}.filters-clear{font-size:.75rem;color:#6b7280;background:none;border:none;cursor:pointer}.filters-clear:hover{color:#374151}.filters-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1rem}@media (min-width: 768px){.filters-grid{grid-template-columns:repeat(4,1fr)}}.filter-group label{display:block;font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.filter-group select{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;background-color:#fff}.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding:0 .5rem}.pagination-info{font-size:.875rem;color:#6b7280}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-btn{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;cursor:pointer;transition:background-color .15s ease}.pagination-btn:hover:not(:disabled){background-color:#f9fafb}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn svg{width:1rem;height:1rem;color:#374151}.pagination-text{font-size:.875rem;color:#374151}.back-link{display:inline-flex;align-items:center;gap:.25rem;color:#6b7280;font-size:.875rem;text-decoration:none;margin-bottom:1rem;transition:color .15s ease}.back-link:hover{color:#374151}.back-link svg{width:1rem;height:1rem}.info-row{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.info-row:last-child{border-bottom:none}.info-row-icon{flex-shrink:0;color:#9ca3af;margin-top:.125rem}.info-row-icon svg{width:1.25rem;height:1.25rem}.info-row-content{flex:1;min-width:0}.info-row-label{font-size:.875rem;color:#6b7280;margin:0}.info-row-value{color:#111827;margin:0;word-break:break-word}.station-card{display:block;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1rem;text-decoration:none;transition:box-shadow .15s ease}.station-card:hover{box-shadow:0 4px 6px #0000001a}.station-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.station-card-title{font-weight:500;color:#111827;margin:0}.station-card-subtitle{font-size:.75rem;color:#6b7280;margin:0}.station-card-stats{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.station-card-stat{display:flex;align-items:center;justify-content:space-between;color:#4b5563}.station-card-stat-label{display:flex;align-items:center;gap:.25rem}.station-card-stat-label svg{width:1rem;height:1rem}.station-card-stat-value{font-weight:500}.station-card-stat-value.green{color:#059669}.station-card-stat-value.yellow{color:#d97706}.station-card-stat-value.red{color:#dc2626}.station-card-variables{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f3f4f6}.station-card-variable{padding:.125rem .5rem;background-color:#f3f4f6;color:#4b5563;border-radius:.25rem;font-size:.75rem}.station-card-footer{display:flex;align-items:center;justify-content:flex-end;margin-top:.75rem;color:#2563eb;font-size:.875rem}.station-card-footer svg{width:1rem;height:1rem}.metric-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1rem;border-left:4px solid #3b82f6}.metric-card.green{border-left-color:#10b981}.metric-card.yellow{border-left-color:#f59e0b}.metric-card.red{border-left-color:#ef4444}.metric-card-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.metric-card-label svg{width:1rem;height:1rem}.metric-card-value{font-size:1.5rem;font-weight:700;color:#111827}.metric-card-unit{font-size:.875rem;font-weight:400;color:#6b7280;margin-left:.25rem}.progress-bar{width:100%;height:.5rem;background-color:#e5e7eb;border-radius:9999px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:9999px;transition:width .3s ease}.progress-bar-fill.green{background-color:#10b981}.progress-bar-fill.yellow{background-color:#f59e0b}.progress-bar-fill.red{background-color:#ef4444}.progress-with-label{display:flex;align-items:center;gap:.5rem}.progress-with-label .progress-bar{width:5rem}.progress-label{font-size:.875rem;font-weight:500;min-width:2.5rem;text-align:right}.progress-label.green{color:#059669}.progress-label.yellow{color:#d97706}.progress-label.red{color:#dc2626}.ingestion-log-item{display:flex;flex-direction:column;padding:.75rem 1rem;border-bottom:1px solid #f3f4f6}.ingestion-log-item:hover{background-color:#f9fafb}.ingestion-log-header{display:flex;align-items:center;justify-content:space-between}.ingestion-log-source{display:flex;align-items:center;gap:.5rem}.ingestion-log-dot{width:.5rem;height:.5rem;border-radius:9999px}.ingestion-log-dot.success{background-color:#10b981}.ingestion-log-dot.failed{background-color:#ef4444}.ingestion-log-dot.pending{background-color:#f59e0b}.ingestion-log-name{font-weight:500;color:#111827}.ingestion-log-station{font-size:.875rem;color:#6b7280}.ingestion-log-meta{display:flex;align-items:center;gap:1rem;margin-top:.25rem;font-size:.75rem;color:#6b7280}.ingestion-log-error{margin-top:.25rem;font-size:.75rem;color:#dc2626;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-list{list-style:none;padding:0;margin:0}.activity-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #f3f4f6}.activity-item:hover{background-color:#f9fafb}.activity-item-left{display:flex;align-items:center;gap:.75rem}.activity-dot{width:.5rem;height:.5rem;border-radius:9999px}.activity-dot.signup{background-color:#10b981}.activity-dot.login{background-color:#3b82f6}.activity-dot.verification{background-color:#8b5cf6}.activity-user-name{font-size:.875rem;font-weight:500;color:#111827}.activity-user-email{font-size:.75rem;color:#6b7280}.activity-item-right{text-align:right}.activity-type{font-size:.875rem;color:#374151;text-transform:capitalize}.activity-time{font-size:.75rem;color:#9ca3af}.data-source-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1rem}.data-source-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.data-source-name{font-weight:600;color:#111827}.data-source-stats{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.data-source-stat{display:flex;justify-content:space-between}.data-source-stat-label{color:#6b7280}.data-source-stat-value{font-weight:500;color:#374151}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.empty-state-icon{color:#d1d5db;margin-bottom:.75rem}.empty-state-icon svg{width:3rem;height:3rem}.empty-state-text{color:#6b7280;margin:0}.empty-state-success .empty-state-icon{color:#86efac}.loading-container{display:flex;align-items:center;justify-content:center;min-height:16rem}.loading-spinner{animation:spin 1s linear infinite;color:#2563eb}.loading-spinner svg{width:2rem;height:2rem}.error-container{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:1rem;margin-bottom:1rem}.error-text{color:#b91c1c;margin:0}.error-link{color:#b91c1c;text-decoration:underline;margin-top:.5rem;display:inline-block}.error-link:hover{color:#991b1b}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:#111827;margin:0}.section-title svg{width:1.25rem;height:1.25rem}.section-link{font-size:.875rem;color:#2563eb;text-decoration:none}.section-link:hover{color:#1d4ed8}.breakdown-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (min-width: 768px){.breakdown-grid{grid-template-columns:repeat(5,1fr)}}.breakdown-item{text-align:center;padding:.5rem;background-color:#f9fafb;border-radius:.375rem}.breakdown-value{font-size:1.125rem;font-weight:600;color:#111827}.breakdown-label{font-size:.75rem;color:#6b7280;text-transform:capitalize}.opt-in-badges{display:flex;flex-wrap:wrap;gap:.5rem}.scrollable-table{max-height:24rem;overflow-y:auto}.scrollable-table thead{position:sticky;top:0;z-index:10}.show-more-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;margin-top:.75rem;background:none;border:none;color:#2563eb;font-size:.875rem;cursor:pointer}.show-more-btn:hover{color:#1d4ed8}.show-more-btn svg{width:1rem;height:1rem;transition:transform .2s ease}.show-more-btn.expanded svg{transform:rotate(180deg)}.table-link{color:#2563eb;text-decoration:none;font-weight:500}.table-link:hover{color:#1d4ed8;text-decoration:underline}.text-green{color:#059669}.text-yellow{color:#d97706}.text-red{color:#dc2626}.text-blue{color:#2563eb}.text-gray{color:#6b7280}.text-muted{color:#9ca3af}.bg-green-light{background-color:#d1fae5}.bg-yellow-light{background-color:#fef3c7}.bg-red-light{background-color:#fee2e2}.bg-blue-light{background-color:#dbeafe}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.capitalize{text-transform:capitalize}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.tiptap-editor-wrapper{border:1px solid #d1d5db;border-radius:6px;overflow:hidden;background:#fff}.tiptap-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px 8px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.tiptap-toolbar-group{display:flex;gap:2px;padding-right:8px;margin-right:6px;border-right:1px solid #e5e7eb}.tiptap-toolbar-group:last-child{border-right:none;margin-right:0;padding-right:0}.tiptap-toolbar button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;background:none;color:#4b5563;cursor:pointer;transition:background-color .15s,color .15s}.tiptap-toolbar button:hover{background:#e5e7eb;color:#111827}.tiptap-toolbar button.is-active{background:#dbeafe;color:#2563eb}.tiptap-toolbar button:disabled{opacity:.4;cursor:not-allowed}.tiptap-content{padding:1rem;min-height:400px;max-height:70vh;overflow-y:auto}.tiptap-content .ProseMirror{outline:none;min-height:380px;font-size:.95rem;line-height:1.7;color:#1f2937}.tiptap-content .ProseMirror p{margin:.5em 0}.tiptap-content .ProseMirror h2{font-size:1.5rem;font-weight:700;margin:1.2em 0 .6em;color:#111827}.tiptap-content .ProseMirror h3{font-size:1.25rem;font-weight:600;margin:1em 0 .5em;color:#1f2937}.tiptap-content .ProseMirror h4{font-size:1.1rem;font-weight:600;margin:.8em 0 .4em;color:#374151}.tiptap-content .ProseMirror ul,.tiptap-content .ProseMirror ol{padding-left:1.5rem;margin:.5em 0}.tiptap-content .ProseMirror li{margin:.25em 0}.tiptap-content .ProseMirror blockquote{border-left:3px solid #d1d5db;margin:.75em 0;padding:.5em 0 .5em 1em;color:#6b7280;font-style:italic}.tiptap-content .ProseMirror pre{background:#1f2937;color:#e5e7eb;padding:.75em 1em;border-radius:6px;font-family:Fira Code,Consolas,monospace;font-size:.85rem;overflow-x:auto;margin:.75em 0}.tiptap-content .ProseMirror code{background:#f3f4f6;padding:.15em .3em;border-radius:3px;font-size:.9em;font-family:Fira Code,Consolas,monospace}.tiptap-content .ProseMirror pre code{background:none;padding:0;border-radius:0;color:inherit}.tiptap-content .ProseMirror a{color:#2563eb;text-decoration:underline;cursor:pointer}.resizable-image-wrapper{position:relative;display:inline-block;max-width:100%;margin:.75em 0;border-radius:6px;transition:outline .15s;cursor:default}.resizable-image-wrapper.selected{outline:2px solid #2563eb;outline-offset:2px}.resizable-image-controls{position:absolute;top:8px;left:50%;transform:translate(-50%);display:flex;gap:2px;padding:3px;background:#000000a6;border-radius:6px;z-index:10}.resizable-image-controls button{padding:3px 10px;border:none;border-radius:4px;background:transparent;color:#fffc;font-size:.7rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;width:auto;height:auto}.resizable-image-controls button:hover{background:#fff3;color:#fff}.resizable-image-controls button.active{background:#2563eb;color:#fff}.tiptap-content .ProseMirror img{max-width:100%;height:auto;border-radius:6px}.tiptap-content .ProseMirror hr{border:none;border-top:1px solid #e5e7eb;margin:1.5em 0}.tiptap-content .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:#9ca3af;pointer-events:none;height:0}.tiptap-image-uploading{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:#f3f4f6;border-radius:4px;font-size:.8rem;color:#6b7280}.tiptap-image-uploading svg{animation:spin 1s linear infinite}.image-upload-wrapper{width:100%}.image-upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:2rem 1rem;border:2px dashed #d1d5db;border-radius:8px;background:#f9fafb;cursor:pointer;transition:border-color .2s,background-color .2s;text-align:center}.image-upload-dropzone:hover{border-color:#93c5fd;background:#eff6ff}.image-upload-dropzone.dragging{border-color:#2563eb;background:#dbeafe}.image-upload-dropzone.uploading{pointer-events:none;opacity:.7}.image-upload-dropzone-icon{color:#9ca3af}.image-upload-dropzone-text{font-size:.85rem;color:#6b7280}.image-upload-dropzone-text strong{color:#2563eb}.image-upload-dropzone-hint{font-size:.75rem;color:#9ca3af}.image-upload-preview{position:relative;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.image-upload-preview img{display:block;width:100%;max-height:300px;object-fit:cover}.image-upload-preview-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px}.image-upload-remove-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border:none;border-radius:4px;background:#0009;color:#fff;font-size:.75rem;cursor:pointer;transition:background .2s}.image-upload-remove-btn:hover{background:#dc2626d9}.image-upload-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--primary: #446145;--primary-dark: #388E3C;--primary-light: #A5D6A7;--secondary: #8BC34A;--accent: #FFC107;--terracotta: #D1583B;--olive: #5B6830;--charcoal: #2F2F2F;--text: #525151;--text-light: #505050;--background: #ffffff;--card-bg: #FDF6E3;--white: #FFFFFF;--border-radius: 4px;--box-shadow: 0 2px 5px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Calibri,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;color:var(--charcoal);background-color:var(--background);padding:20px}.home-page{min-height:100vh;padding:24px 16px 40px;color:var(--charcoal);font-family:Calibri,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.home-brand{display:flex;align-items:center;gap:12px}.home-logo{height:70px;width:auto}.home-title-block{display:flex;flex-direction:column}.home-title{margin:0;font-size:24pt;font-weight:700;color:var(--charcoal)}.home-subtitle{margin:2px 0 0;font-size:14pt;font-style:italic;color:var(--olive)}.home-content{display:flex;flex-direction:column;gap:16px}.stats-container,.content-container{background:var(--white);border-radius:12px;padding:16px;box-shadow:0 2px 6px #2f2f2f14;border-top:4px solid var(--terracotta)}.container-title span{font-size:14pt;font-weight:700;color:var(--olive)}.stats-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.stat-card{background:var(--card-bg);border-radius:10px;padding:10px;text-decoration:none;color:inherit;display:flex;flex-direction:column;justify-content:center;gap:4px;border:1px solid rgba(91,104,48,.25);transition:transform .1s ease,box-shadow .1s ease,border-color .1s ease}.stat-card:hover{transform:translateY(-1px);box-shadow:0 3px 8px #2f2f2f1f;border-color:var(--terracotta)}.stat-value{font-size:20px;font-weight:700}.stat-label,.actions-title{font-size:20px;color:var(--charcoal)}.icon-wrapper{display:inline-flex;align-items:center;justify-content:center;margin-bottom:4px;color:var(--olive)}.two-column-section{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.column-item{height:100%;display:flex;flex-direction:column}.weather-container{flex:1;display:flex;flex-direction:column}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:var(--text-light)}@media (max-width: 768px){.home-title{font-size:20pt}.home-subtitle{font-size:12pt}.two-column-section,.stats-grid{grid-template-columns:1fr}}@media (max-width: 480px){body{padding:10px}.home-page{padding:16px 8px 40px}.home-logo{height:50px}.home-title{font-size:18pt}.container-title span{font-size:12pt}.stat-value,.stat-label,.actions-title{font-size:16px}}
