@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/32687112bd2dd8db-s.0gspg~~t9nou8.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/28868e710e86be81-s.0rx81dn62y51_.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.0rd3rjvnnhw7n.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk Fallback;src:local(Arial);ascent-override:89.71%;descent-override:26.62%;line-gap-override:0.0%;size-adjust:109.69%}.space_grotesk_11bf8cd-module__L78yXa__className{font-family:Space Grotesk,Space Grotesk Fallback;font-style:normal}.space_grotesk_11bf8cd-module__L78yXa__variable{--font-space:"Space Grotesk", "Space Grotesk Fallback"}
@font-face{font-family:Public Sans;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6e8df35dd937fa7a-s.05uvaxv85y..0.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Public Sans;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fc2699ecc8323b38-s.0gyljc-fku7zg.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Public Sans;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fa0520225c6f3d07-s.p.0_88erakuzr64.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Public Sans Fallback;src:local(Arial);ascent-override:90.59%;descent-override:21.46%;line-gap-override:0.0%;size-adjust:104.87%}.public_sans_d5d29eea-module__-Gswca__className{font-family:Public Sans,Public Sans Fallback;font-style:normal}.public_sans_d5d29eea-module__-Gswca__variable{--font-public:"Public Sans", "Public Sans Fallback"}
body{font-family:var(--font-public);background-color:#f0f0f0;margin:0}h1,h2,h3,h4,h5{font-family:var(--font-space)}.primary{color:#0f2d24}.primary-bcg{background-color:#0f2d24}.secondary{color:#004b7c}.secondary-bcg{background-color:#004b7c}.accent{color:gold}.accent-bcg{background-color:gold}.neutral{color:#f2f4f5}.neutral-bcg{background-color:#f2f4f5}main{padding:.5rem 1rem}main h1{padding-left:1rem}main h1:first-child{border-left:.5rem solid #0f2d24}a{color:#000;transition:color .5s}a:hover{color:#0f2d24}.text{margin:0 8rem}.text p{font-weight:400}header{border-bottom:.15rem solid #d3d3d3;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}header h1 a{color:inherit;text-decoration:none}nav{justify-content:space-evenly;align-items:center;gap:1.5rem;display:flex}nav a{color:#000;font-size:1.1rem;font-weight:500;text-decoration:none;transition:all .5s}nav a:hover,nav .active{color:#0f2d24;text-underline-offset:15px;padding-bottom:15px;-webkit-text-decoration:underline #0f2d24;text-decoration:underline #0f2d24;text-decoration-thickness:5px}footer{border-top:.15rem solid #d3d3d3;justify-content:center;align-items:center;padding:.5rem 1rem;display:flex}footer p a{color:#0f2d24;text-decoration:none}footer p a:hover{text-decoration:underline}.coffee .BlackToYellow{color:#000;transition:color .5s}.coffee .YellowToGreen{color:gold;transition:color .5s}.coffee .WhiteToYellow{color:#fff;transition:color .5s}.coffee:hover .BlackToYellow{color:gold}.coffee:hover .YellowToGreen{color:#0f2d24}.coffee:hover .WhiteToYellow{color:gold}.coffee svg{height:auto}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-wrap table{min-width:640px}table{border-collapse:collapse;border:1px solid #d1d5db;border-radius:8px;width:100%;margin-top:1rem;font-size:.95rem;overflow:hidden}caption{text-align:left;color:#374151;margin-bottom:.5rem;font-weight:600}thead{background-color:#e5e7eb}thead th{color:#374151;text-align:left;border-bottom:2px solid #d1d5db;padding:.75rem 1rem;font-weight:600}tbody tr{border-bottom:1px solid #d1d5db}tbody tr:nth-child(2n){background-color:#f3f4f6}tbody tr:hover{background-color:#eaecef}tbody td{color:#374151;padding:.75rem 1rem}.DataBox{background-color:#fff;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:1rem;display:inline-flex}.DataBox .red{color:#8b0000}.DataBox h2{color:#374151;margin:0}.DataBox p{margin-top:1rem;margin-bottom:0;font-size:2rem;font-weight:900}.leaflet-container{z-index:1;border:2px solid #d1d5db;border-radius:12px;width:100%;height:75vh;overflow:hidden}.map-popup h3{color:#0f2d24;margin:0 0 .5rem}.map-popup p{color:#374151;margin:.25rem 0}.map-popup img{border-radius:8px;width:100%;margin-bottom:.5rem}.map-popup a{color:#004b7c;margin-top:.5rem;font-weight:700;text-decoration:none;display:inline-block}.map-popup a:hover{text-decoration:underline}.chain-status{font-weight:700}.chain-status.r0{color:#16a34a}.chain-status.r1{color:#ca8a04}.chain-status.r2,.chain-status.r3{color:#dc2626}.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:0 0}.marker-cluster div{color:#fff;background-color:#0f2d24f2;border:3px solid gold;border-radius:999px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 0 12px #00000080,0 0 6px #ffd70059;width:42px!important;height:42px!important;margin-top:-21px!important;margin-left:-21px!important}.marker-cluster:hover div{transform:scale(1.08)}.leaflet-cluster-spider-leg{stroke:gold!important;stroke-width:2px!important}.status-badge{color:#fff;white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.85rem;font-weight:700;display:inline-block}.status-badge.r0{background-color:#16a34a}.status-badge.r1{background-color:#ca8a04}.status-badge.r2,.status-badge.r3{background-color:#dc2626}.legend{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;margin:1rem 0;padding:.75rem 1rem}.legend summary{cursor:pointer;color:#374151;font-weight:600}.legend ul{flex-direction:column;gap:.5rem;margin:.75rem 0 0;padding:0;list-style:none;display:flex}.legend li{color:#374151;align-items:center;gap:.75rem;display:flex}.filter-chips{flex-wrap:wrap;gap:.5rem;margin:1rem 0;display:flex}.filter-chips .chip{font-family:var(--font-public);color:#374151;cursor:pointer;background-color:#fff;border:1px solid #d1d5db;border-radius:999px;padding:.45rem 1rem;font-size:.95rem;font-weight:600;transition:all .25s}.filter-chips .chip:hover{color:#0f2d24;border-color:#0f2d24}.filter-chips .chip.active{color:#fff;background-color:#0f2d24;border-color:#0f2d24}.webcam-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem;display:grid}.webcam-grid .webcam-card{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;flex-direction:column;text-decoration:none;transition:all .25s;display:flex;overflow:hidden}.webcam-grid .webcam-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.webcam-grid .webcam-card:hover img{transform:scale(1.04)}.webcam-grid .webcam-card img{aspect-ratio:4/3;object-fit:cover;background-color:#e5e7eb;width:100%;transition:transform .35s}.webcam-grid .webcam-card .webcam-info{padding:.75rem 1rem}.webcam-grid .webcam-card .webcam-info h2{color:#0f2d24;margin:0;font-size:1.05rem}.webcam-grid .webcam-card .webcam-info p{color:#374151;margin:.25rem 0 0;font-size:.9rem}.back-link{margin-top:.5rem;font-weight:600;text-decoration:none;display:inline-block}.webcam-meta{color:#374151;font-weight:600}.webcam-snapshot img{border:1px solid #d1d5db;border-radius:8px;width:100%}main video{background-color:#000;border:1px solid #d1d5db;border-radius:8px}.webcam-player-error{text-align:center;color:#374151;background-color:#fff;border:1px solid #d1d5db;border-radius:8px;padding:1.5rem}.webcam-player-error button{font-family:var(--font-public);color:#fff;cursor:pointer;background-color:#0f2d24;border:none;border-radius:8px;margin:.75rem auto 0;padding:.6rem 1.5rem;font-size:1rem;font-weight:600;transition:background-color .25s;display:block}.webcam-player-error button:hover{background-color:#004b7c}.page-note{color:#374151}.stale-note{color:#8b0000;font-weight:600}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes livePulse{0%,to{box-shadow:0 0 #22c55e8c}70%{box-shadow:0 0 0 7px #22c55e00}}@keyframes livePulseWhite{0%,to{box-shadow:0 0 #fff9}70%{box-shadow:0 0 0 7px #fff0}}@keyframes alertPulse{0%,to{box-shadow:0 0 #dc262673}50%{box-shadow:0 0 0 10px #dc262600}}@keyframes spin{to{transform:rotate(360deg)}}main>*{animation:.45s both fadeInUp}main>:nth-child(2){animation-delay:60ms}main>:nth-child(3){animation-delay:.12s}main>:nth-child(4){animation-delay:.18s}main>:nth-child(5){animation-delay:.24s}.hero{background:url(/hero.jpg) 50%/cover no-repeat;border-radius:16px;align-items:center;min-height:400px;margin:.5rem 0 1.5rem;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 32px #0f2d2440}.hero:before{content:"";background:linear-gradient(105deg,#0f2d24e0 0%,#0f2d248c 45%,#0f2d241f 100%);position:absolute;inset:0}.hero .hero-content{color:#fff;max-width:680px;padding:3rem 2.5rem;position:relative}.hero .hero-content h1{color:#fff;border-left:none;margin:0 0 1rem;padding-left:0;font-size:2.75rem;line-height:1.1}.hero .hero-content>p{opacity:.92;max-width:34rem;margin:0 0 1.5rem;font-size:1.15rem;line-height:1.5}.hero-status{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:999px;align-items:center;gap:.6rem;margin-bottom:1.75rem;padding:.6rem 1.2rem;font-weight:700;display:inline-flex}.hero-status .live-dot{background-color:#fff;animation:2s ease-in-out infinite livePulseWhite}.hero-status.clear{background-color:#16a34aeb}.hero-status.alert{background-color:#dc2626eb;animation:2.5s ease-in-out infinite alertPulse}.hero-status.unknown{background-color:#ffffff2e}.hero-actions{flex-wrap:wrap;gap:.75rem;display:flex}.btn{border-radius:10px;padding:.7rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .25s;display:inline-block}.btn.solid{color:#0f2d24;background-color:gold}.btn.solid:hover{color:#0f2d24;transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.btn.ghost{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#ffffff14;border:2px solid #ffffffb3}.btn.ghost:hover{color:#fff;background-color:#ffffff38;transform:translateY(-2px)}.live-indicator{color:#374151;white-space:nowrap;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:inline-flex}.live-dot{background-color:#22c55e;border-radius:999px;width:10px;height:10px;animation:2s ease-in-out infinite livePulse}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding-right:1rem;display:flex}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;display:flex}.section-head h2{color:#0f2d24;margin:0}.loading{color:#374151;align-items:center;gap:.75rem;padding:2rem 1rem;font-weight:600;display:flex}.loading:before{content:"";border:3px solid #e5e7eb;border-top-color:#0f2d24;border-radius:999px;width:22px;height:22px;animation:.8s linear infinite spin}@media (max-width:1100px){.text{margin:0 2rem}}@media (max-width:920px){header{flex-wrap:wrap;row-gap:.5rem}header h1{margin:.25rem 0;font-size:1.5rem}header .coffee svg{width:180px}nav{order:3;justify-content:space-between;gap:.5rem;width:100%;padding-bottom:.25rem;overflow-x:auto}nav a{white-space:nowrap;padding:.5rem 0;font-size:1rem}nav a:hover,nav .active{text-underline-offset:8px;padding-bottom:.5rem}}@media (max-width:720px){.table-wrap{overflow-x:visible}.table-wrap table{min-width:0}table{background-color:#0000;border:none;border-radius:0}thead{display:none}table,tbody td{display:block}tbody{flex-direction:column;gap:.85rem;display:flex}tbody tr{background-color:#fff;border:1px solid #d1d5db;border-radius:12px;display:block;overflow:hidden;box-shadow:0 2px 8px #0000000f}tbody tr:nth-child(2n),tbody tr:hover{background-color:#fff}tbody td{text-align:right;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem 1rem;display:flex}tbody td:last-child{border-bottom:none}tbody td:before{content:attr(data-label);color:#374151;text-align:left;flex-shrink:0;font-weight:600}}@media (max-width:640px){main{padding:.5rem .75rem}main h1{font-size:1.6rem}.text{margin:0}header .coffee svg{width:150px}.leaflet-container{height:65vh}.hero{border-radius:12px;min-height:320px}.hero .hero-content{padding:1.75rem 1.25rem}.hero .hero-content h1{font-size:2rem}.hero .hero-content>p{font-size:1.05rem}.btn{padding:.65rem 1.2rem;font-size:.95rem}.page-head{padding-right:0}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
