
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;600;700;800;900&family=JetBrains+Mono:wght@500;700;800&display=swap');

:root{
  --pfn-red:#e50914;
  --pfn-red-2:#ff2a2a;
  --pfn-black:#050506;
  --pfn-black-2:#0b0b0d;
  --pfn-panel:#111114;
  --pfn-panel-2:#18181d;
  --pfn-gray:#a6a6ad;
  --pfn-muted:#73737d;
  --pfn-line:rgba(255,255,255,.12);
  --pfn-line-dark:#d9d9de;
  --pfn-light:#f3f3f5;
  --pfn-white:#fff;
  --pfn-green:#20e070;
  --max:1240px;
  color-scheme:dark;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,sans-serif;
  background:#070708;
  color:#fff;
}
a{color:inherit}
button,input,select{font:inherit}
.pfn-page{
  min-height:100vh;
  background:
    radial-gradient(circle at 82% 4%,rgba(229,9,20,.22),transparent 30rem),
    linear-gradient(180deg,#141416 0%,#070708 42%,#050506 100%);
}
.pfn-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(5,5,6,.86);
  border-bottom:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(16px);
}
.pfn-header-inner{
  width:min(var(--max),calc(100% - 34px));
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  margin:0 auto;
}
.pfn-brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  min-width:0;
}
.pfn-mark{
  width:42px;height:42px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--pfn-red),#560004);
  box-shadow:0 0 24px rgba(229,9,20,.22);
  font-family:'Bebas Neue',sans-serif;
  font-size:24px;
  letter-spacing:.03em;
}
.pfn-brand-text strong{
  display:block;
  font-family:'Bebas Neue',sans-serif;
  font-size:30px;
  line-height:.9;
  letter-spacing:.045em;
}
.pfn-brand-text span{
  display:block;
  margin-top:3px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:rgba(255,255,255,.56);
}
.pfn-nav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.pfn-nav a{
  text-decoration:none;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  padding:10px 13px;
  color:rgba(255,255,255,.78);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:.18s ease;
}
.pfn-nav a:hover,.pfn-nav a.active{
  color:#fff;
  background:var(--pfn-red);
  border-color:var(--pfn-red);
}
.pfn-mobile-toggle{display:none}
.pfn-main{
  width:min(var(--max),calc(100% - 34px));
  margin:0 auto;
  padding:36px 0 54px;
}
.pfn-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,.55fr);
  gap:24px;
  align-items:end;
  margin-bottom:28px;
}
.eyebrow{
  display:block;
  color:var(--pfn-red-2);
  font-size:11px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.22em;
  margin-bottom:10px;
}
.pfn-hero h1{
  margin:0;
  max-width:850px;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(64px,8.2vw,132px);
  line-height:.88;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.pfn-hero h1 .red{color:var(--pfn-red-2)}
.pfn-hero p{
  max-width:780px;
  color:rgba(255,255,255,.72);
  font-size:18px;
  line-height:1.7;
  margin:18px 0 0;
}
.hero-status-card{
  border:1px solid rgba(255,255,255,.13);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.035));
  box-shadow:0 24px 70px rgba(0,0,0,.26);
  padding:22px;
}
.hero-status-card h2{
  margin:0;
  font-family:'Bebas Neue',sans-serif;
  font-size:38px;
  letter-spacing:.05em;
}
.hero-status-card p{font-size:13px;line-height:1.6;margin:10px 0 0;color:rgba(255,255,255,.58)}
.pfn-panel{
  border:1px solid rgba(255,255,255,.12);
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035));
  box-shadow:0 24px 70px rgba(0,0,0,.26);
}
.pfn-panel.pad{padding:22px}
.pfn-toolbar{
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:end;
  margin-bottom:22px;
}
.pfn-form label{
  display:block;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  letter-spacing:.13em;
  margin-bottom:8px;
}
.input-row{
  display:flex;
  gap:10px;
}
.pfn-form input{
  width:100%;
  min-height:48px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background:rgba(0,0,0,.22);
  color:#fff;
  padding:0 14px;
  outline:none;
}
.pfn-form input:focus{
  border-color:rgba(229,9,20,.65);
  box-shadow:0 0 0 4px rgba(229,9,20,.12);
}
.pfn-btn{
  min-height:48px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background:#151519;
  color:#fff;
  padding:0 16px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
  cursor:pointer;
  transition:.18s ease;
  white-space:nowrap;
}
.pfn-btn:hover,.pfn-btn.primary{
  background:var(--pfn-red);
  border-color:var(--pfn-red);
}
.pfn-status{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:rgba(255,255,255,.55);
}
.forecast-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.current-card{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:20px;
  align-items:center;
}
.current-temp{
  font-family:'Bebas Neue',sans-serif;
  font-size:88px;
  line-height:.9;
}
.current-meta h2{
  margin:0 0 8px;
  font-size:24px;
}
.current-meta p{
  margin:0;
  color:rgba(255,255,255,.68);
  line-height:1.6;
}
.metric-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.metric-tile{
  min-height:96px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(0,0,0,.20);
  padding:14px;
}
.metric-tile b{
  display:block;
  font-family:'Bebas Neue',sans-serif;
  font-size:34px;
  line-height:1;
}
.metric-tile span{
  display:block;
  margin-top:7px;
  color:rgba(255,255,255,.50);
  font-size:10px;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
}
.section-card{
  margin-top:18px;
}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
.section-head h2{
  margin:0;
  font-family:'Bebas Neue',sans-serif;
  font-size:42px;
  letter-spacing:.04em;
}
.section-head p{
  margin:0;
  color:rgba(255,255,255,.52);
  font-size:13px;
}
.daily-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(175px,1fr));
  gap:12px;
}
.daily-card,.hourly-card,.alert-card{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(0,0,0,.20);
  padding:15px;
}
.daily-card h3{
  margin:0 0 10px;
  font-size:15px;
}
.daily-temp{
  display:flex;
  align-items:baseline;
  gap:8px;
  margin:10px 0;
}
.daily-temp strong{
  font-family:'Bebas Neue',sans-serif;
  font-size:42px;
  line-height:1;
}
.daily-temp span{color:rgba(255,255,255,.52)}
.daily-card p,.hourly-card p,.alert-card p{
  margin:0;
  color:rgba(255,255,255,.65);
  font-size:13px;
  line-height:1.5;
}
.hourly-scroll{
  display:flex;
  gap:10px;
  overflow:auto;
  padding-bottom:8px;
}
.hourly-card{
  flex:0 0 150px;
}
.hourly-card strong{
  display:block;
  font-family:'Bebas Neue',sans-serif;
  font-size:40px;
  margin:8px 0;
}
.alert-list{
  display:grid;
  gap:12px;
}
.alert-card{
  border-left:4px solid var(--pfn-red);
}
.alert-card h3{
  margin:0 0 8px;
  font-size:15px;
}
.alert-meta{
  color:rgba(255,255,255,.46);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:8px;
}

/* Radar page */
.radar-main{padding-bottom:36px}
.radar-engine-panel{
  border:1px solid rgba(255,255,255,.12);
  border-radius:26px;
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035));
  box-shadow:0 24px 70px rgba(0,0,0,.28);
  overflow:hidden;
}
.radar-engine-top{
  display:grid;
  grid-template-columns:1fr minmax(280px,420px);
  gap:18px;
  align-items:end;
  padding:20px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.radar-engine-top h2{
  margin:0;
  font-family:'Bebas Neue',sans-serif;
  font-size:44px;
  letter-spacing:.04em;
}
.radar-engine-top p{
  margin:8px 0 0;
  color:rgba(255,255,255,.56);
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
}
.radar-search label{
  display:block;
  font-size:10px;
  color:rgba(255,255,255,.55);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:7px;
}
.radar-search div{
  display:flex;
  gap:8px;
}
.radar-search input{
  width:100%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.25);
  color:#fff;
  border-radius:14px;
  min-height:46px;
  padding:0 12px;
}
.radar-search button{
  border:0;
  border-radius:14px;
  background:var(--pfn-red);
  color:#fff;
  min-height:46px;
  padding:0 14px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
}
.radar-map-shell{
  position:relative;
  height:min(72vh,760px);
  min-height:520px;
  background:#08080a;
}
#radarMap{
  position:absolute;
  inset:0;
}
.radar-time-bubble{
  position:absolute;
  z-index:20;
  top:14px;
  left:50%;
  transform:translateX(-50%);
  min-width:min(440px,calc(100% - 30px));
  text-align:center;
  padding:10px 15px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:16px;
  background:rgba(5,5,6,.76);
  backdrop-filter:blur(10px);
  box-shadow:0 18px 40px rgba(0,0,0,.25);
  pointer-events:none;
}
.radar-time-bubble strong{
  display:block;
  font-family:'Bebas Neue',sans-serif;
  color:#fff;
  font-size:28px;
  letter-spacing:.04em;
  line-height:1;
}
.radar-time-bubble span{
  display:block;
  margin-top:3px;
  color:rgba(255,255,255,.60);
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
}
.radar-map-actions{
  position:absolute;
  z-index:21;
  left:14px;
  top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.radar-map-actions button,.layer-menu-toggle,.layer-menu-panel button,
.radar-product-buttons button,.radar-playback button{
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(5,5,6,.78);
  color:#fff;
  min-height:38px;
  padding:0 12px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  backdrop-filter:blur(10px);
}
.radar-map-actions button:hover,.layer-menu-toggle:hover,.layer-menu-panel button:hover,
.radar-product-buttons button.active,.radar-product-buttons button:hover,.radar-playback button:hover{
  background:var(--pfn-red);
  border-color:var(--pfn-red);
}
.radar-layer-menu{
  position:absolute;
  z-index:22;
  right:14px;
  top:14px;
}
.layer-menu-panel{
  display:none;
  min-width:240px;
  margin-top:8px;
  padding:14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background:rgba(5,5,6,.88);
  backdrop-filter:blur(12px);
  box-shadow:0 18px 44px rgba(0,0,0,.35);
}
.radar-layer-menu.open .layer-menu-panel,
.layer-menu-panel.open{display:block}
.layer-menu-panel strong{
  display:block;
  margin-bottom:9px;
  color:#fff;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.layer-menu-panel label{
  display:flex;
  gap:8px;
  align-items:center;
  color:rgba(255,255,255,.72);
  font-size:12px;
  margin:9px 0;
}
.layer-menu-panel small{
  display:block;
  margin-top:10px;
  color:rgba(255,255,255,.42);
  line-height:1.45;
}
.radar-legend-custom{
  position:absolute;
  z-index:20;
  left:14px;
  bottom:14px;
  width:min(360px,calc(100% - 28px));
  padding:12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  background:rgba(5,5,6,.75);
  backdrop-filter:blur(10px);
}
.radar-legend-gradient{
  height:9px;
  border-radius:999px;
  background:linear-gradient(90deg,#4aa3c7,#1fd14f,#0b8f24,#f5e642,#ff9d00,#d7191c,#fff,#ff38d1,#8d30ff);
}
.legend-ticks{
  display:flex;
  justify-content:space-between;
  margin-top:6px;
  color:rgba(255,255,255,.58);
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
}
.radar-console-web{
  display:grid;
  grid-template-columns:auto auto minmax(220px,1fr) minmax(150px,220px) minmax(140px,190px);
  gap:12px;
  align-items:center;
  padding:16px;
  border-top:1px solid rgba(255,255,255,.10);
}
.radar-product-buttons,.radar-playback{display:flex;gap:8px;flex-wrap:wrap}
.radar-slider-wrap{
  display:grid;
  gap:6px;
  color:rgba(255,255,255,.56);
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.radar-slider-wrap input,.radar-slider-wrap select{
  width:100%;
}
.radar-footnotes{
  padding:0 20px 20px;
  color:rgba(255,255,255,.55);
  line-height:1.65;
  font-size:13px;
}
.maplibregl-popup-content{
  background:#111114!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.14)!important;
  border-radius:14px!important;
}
.maplibregl-popup-tip{border-top-color:#111114!important}
.pfn-us-city-label,.volwx-us-city-label{
  color:#fff!important;
  text-shadow:0 1px 4px rgba(0,0,0,.95);
  font-weight:900;
  letter-spacing:.02em;
}

.pfn-footer{
  border-top:1px solid rgba(255,255,255,.10);
  background:#050506;
  color:rgba(255,255,255,.52);
}
.pfn-footer-inner{
  width:min(var(--max),calc(100% - 34px));
  margin:0 auto;
  padding:24px 0;
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  font-size:12px;
}
.pfn-footer strong{color:#fff}

@media(max-width:980px){
  .pfn-hero,.forecast-grid,.pfn-toolbar,.radar-engine-top{grid-template-columns:1fr}
  .radar-console-web{grid-template-columns:1fr}
}
@media(max-width:760px){
  .pfn-header-inner{min-height:68px}
  .pfn-nav{display:none}
  .pfn-mobile-toggle{display:inline-flex}
  .pfn-nav.open{
    display:flex;
    position:absolute;
    top:68px;
    left:17px;
    right:17px;
    flex-direction:column;
    align-items:stretch;
    background:#09090b;
    border:1px solid rgba(255,255,255,.14);
    border-radius:20px;
    padding:12px;
  }
  .pfn-nav.open a{text-align:center}
  .input-row,.radar-search div{flex-direction:column}
  .metric-grid{grid-template-columns:1fr}
  .current-card{grid-template-columns:1fr}
  .radar-map-shell{height:68vh;min-height:470px}
  .radar-map-actions{top:auto;bottom:92px}
  .radar-layer-menu{left:14px;right:auto;top:14px}
}


/* v3 radar cleanup: use the proven VolWX radar layout with PFN colors and a dark-gray, not black, map */
.radar-engine-page{
  background:
    radial-gradient(circle at 84% 4%,rgba(229,9,20,.16),transparent 30rem),
    linear-gradient(180deg,#151519 0%,#0e0e10 42%,#09090b 100%)!important;
}
.radar-page-title{
  margin:0 0 20px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:16px;
  align-items:end;
}
.radar-page-title h1{
  margin:0;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(58px,7.5vw,112px);
  line-height:.88;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.radar-page-title .lede{
  grid-column:1 / -1;
  max-width:850px;
  color:rgba(255,255,255,.68);
  font-size:18px;
  line-height:1.6;
  margin:0;
}
.radar-engine-panel{
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035))!important;
  border:1px solid rgba(255,255,255,.14)!important;
  border-radius:24px!important;
  box-shadow:0 24px 70px rgba(0,0,0,.28)!important;
}
.radar-engine-top{
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(0,0,0,.04))!important;
}
.radar-engine-top h2{
  color:#fff!important;
}
.radar-engine-top p{
  color:rgba(255,255,255,.56)!important;
}
.radar-map-shell{
  background:#4f5257!important;
}
#radarMap{
  background:#4f5257!important;
}
.maplibregl-canvas-container,
.maplibregl-canvas{
  background:#4f5257!important;
}
.radar-time-bubble,
.radar-legend-custom,
.layer-menu-panel,
.radar-map-actions button,
.layer-menu-toggle{
  background:rgba(14,14,16,.78)!important;
  border-color:rgba(255,255,255,.16)!important;
  color:#fff!important;
}
.radar-map-actions button:hover,
.layer-menu-toggle:hover,
.layer-menu-panel button:hover,
.radar-product-buttons button:hover,
.radar-product-buttons button.active,
.radar-playback button:hover{
  background:var(--pfn-red)!important;
  border-color:var(--pfn-red)!important;
  color:#fff!important;
}
.radar-console-web{
  background:rgba(5,5,6,.20)!important;
}
.radar-footnotes{
  color:rgba(255,255,255,.58)!important;
}
.radar-search input{
  background:rgba(0,0,0,.24)!important;
  border-color:rgba(255,255,255,.15)!important;
}
.radar-search button{
  background:var(--pfn-red)!important;
}
.pfn-us-city-label,.volwx-us-city-label{
  color:#f4f4f5!important;
  text-shadow:0 1px 4px rgba(0,0,0,.95),0 0 8px rgba(0,0,0,.65)!important;
}
@media(max-width:760px){
  .radar-page-title{grid-template-columns:1fr}
}


/* v4 shared readability for forecast/radar pages */
.pfn-header{
  background:rgba(10,10,12,.92)!important;
}
.pfn-brand-text strong{
  color:#fff!important;
}
.pfn-footer{
  color:rgba(255,255,255,.70)!important;
}


/* v5 radar load + sizing fix */
body.radar-engine-page{
  background:
    radial-gradient(circle at 84% 4%,rgba(229,9,20,.14),transparent 30rem),
    linear-gradient(180deg,#17181c 0%,#111216 46%,#0b0c0f 100%)!important;
}

body.radar-engine-page .radar-main,
.radar-main{
  width:min(1320px, calc(100% - 42px))!important;
  max-width:1320px!important;
  margin:0 auto!important;
  padding:32px 0 42px!important;
}

.radar-page-title{
  margin-bottom:18px!important;
}

.radar-page-title h1{
  font-size:clamp(58px,6.4vw,104px)!important;
}

.radar-page-title .lede{
  max-width:880px!important;
  font-size:17px!important;
  color:rgba(255,255,255,.72)!important;
}

.radar-engine-panel{
  max-width:1320px!important;
  margin:0 auto!important;
  border-radius:24px!important;
  overflow:hidden!important;
}

.radar-engine-top{
  padding:18px 20px!important;
  grid-template-columns:minmax(0,1fr) minmax(280px,430px)!important;
}

.radar-map-shell{
  height:620px!important;
  min-height:520px!important;
  max-height:70vh!important;
  background:#55585d!important;
}

#radarMap,
.maplibregl-canvas-container,
.maplibregl-canvas{
  background:#55585d!important;
}

.radar-time-bubble{
  top:12px!important;
  max-width:min(460px, calc(100% - 32px))!important;
}

.radar-time-bubble strong{
  font-size:27px!important;
}

.radar-console-web{
  padding:14px 16px!important;
  grid-template-columns:auto auto minmax(220px,1fr) minmax(150px,210px) minmax(140px,180px)!important;
}

.radar-footnotes{
  padding:0 20px 18px!important;
}

@media(max-width:980px){
  body.radar-engine-page .radar-main,
  .radar-main{
    width:min(100% - 28px, 1320px)!important;
  }
  .radar-engine-top{
    grid-template-columns:1fr!important;
  }
  .radar-map-shell{
    height:560px!important;
    max-height:72vh!important;
  }
  .radar-console-web{
    grid-template-columns:1fr!important;
  }
}

@media(max-width:700px){
  .radar-map-shell{
    height:520px!important;
    min-height:460px!important;
  }
  .radar-page-title h1{
    font-size:58px!important;
  }
}


/* v6 radar UI layering fix: controls above city labels */
.radar-map-shell{
  isolation:isolate!important;
}

#radarMap{
  z-index:1!important;
}

#radarMap .pfn-us-city-marker-shell,
#radarMap .pfn-us-city-label,
#radarMap .maplibregl-marker.pfn-us-city-marker-shell,
#radarMap .volwx-us-city-label{
  z-index:5!important;
  pointer-events:none!important;
}

.radar-time-bubble{
  z-index:600!important;
}

.radar-map-actions{
  z-index:700!important;
}

.radar-layer-menu{
  z-index:800!important;
}

.radar-legend-custom{
  z-index:650!important;
}

.radar-console-web{
  position:relative!important;
  z-index:900!important;
}

.radar-engine-top{
  position:relative!important;
  z-index:950!important;
}

.radar-footnotes{
  position:relative!important;
  z-index:900!important;
}

/* Clear a protected top operational-control lane over the map */
.radar-map-shell:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:82px;
  z-index:550;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(20,21,24,.78),rgba(20,21,24,.42) 58%,transparent);
}

/* Make the top buttons readable even when radar/city labels are busy underneath */
.radar-map-actions button,
.layer-menu-toggle{
  box-shadow:0 10px 28px rgba(0,0,0,.35)!important;
}

/* Keep the time bubble from being crowded by labels */
.radar-time-bubble{
  box-shadow:0 14px 36px rgba(0,0,0,.42)!important;
}


/* v8 official PlacefileNation logo/header icon update */
.pfn-brand-logo{
  min-width:0;
  gap:0!important;
}
.pfn-header-logo{
  display:block;
  width:min(360px, 42vw);
  max-width:360px;
  height:auto;
  object-fit:contain;
}
.pfn-brand-fallback{
  display:none;
}
.pfn-mark,
.pfn-brand-text{
  display:none!important;
}
.pfn-header-inner{
  min-height:74px!important;
}
.pfn-nav{
  flex-shrink:0;
}
@media(max-width:860px){
  .pfn-header-logo{
    width:min(300px, 58vw);
  }
  .pfn-header-inner{
    min-height:68px!important;
  }
}
@media(max-width:520px){
  .pfn-header-logo{
    width:min(245px, 62vw);
  }
}


/* v9 shared PFN page consistency */
body.forecast-unified-page .pfn-header,
body.radar-engine-page .pfn-header{
  background:rgba(5,5,6,.90)!important;
  border-bottom:1px solid rgba(255,255,255,.10)!important;
}
body.forecast-unified-page .pfn-nav a.active,
body.radar-engine-page .pfn-nav a.active{
  background:var(--pfn-red)!important;
  border-color:var(--pfn-red)!important;
  color:#fff!important;
}


/* v10 index-matched navigation for forecast.php and radar.php */
:root{
  --nav-h:74px;
  --line:rgba(255,255,255,.12);
  --red:#e50914;
  --red-2:#ff2a2a;
}

.nav.pfn-index-nav{
  position:sticky;
  top:0;
  height:var(--nav-h);
  z-index:5000;
  background:rgba(5,5,5,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  box-shadow:0 8px 26px rgba(0,0,0,.32);
}

.pfn-index-nav .container{
  width:min(1240px, calc(100% - 34px));
  margin:0 auto;
}

.pfn-index-nav .nav-inner{
  height:100%;
  display:flex;
  align-items:center;
  gap:22px;
}

.pfn-index-nav .logo{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:max-content;
  text-decoration:none;
}

.pfn-index-nav .site-logo picture{
  display:flex;
  align-items:center;
  line-height:0;
}

.pfn-index-nav .site-logo-img{
  display:block;
  height:62px;
  width:auto;
  max-width:min(430px,44vw);
  object-fit:contain;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.55));
}

.pfn-index-nav .site-logo-fallback{
  display:none;
  align-items:center;
  gap:12px;
}

.pfn-index-nav .site-logo.logo-fallback picture{
  display:none;
}

.pfn-index-nav .site-logo.logo-fallback .site-logo-fallback{
  display:flex;
}

.pfn-index-nav .fallback-mark{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(145deg,rgba(229,9,20,.95),rgba(10,10,12,.95));
  border:1px solid rgba(255,255,255,.18);
  font-family:'Bebas Neue',sans-serif;
  font-size:34px;
  line-height:1;
  color:#fff;
  box-shadow:0 0 28px rgba(229,9,20,.26);
}

.pfn-index-nav .logo-text strong{
  display:block;
  font-family:'Bebas Neue',sans-serif;
  font-size:30px;
  letter-spacing:.075em;
  line-height:.9;
  color:#fff;
}

.pfn-index-nav .logo-text span{
  display:block;
  font-size:9px;
  font-weight:900;
  letter-spacing:.28em;
  color:var(--red-2);
  text-transform:uppercase;
  margin-top:4px;
}

.pfn-index-nav .nav-links{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:4px;
}

.pfn-index-nav .nav-links a{
  text-decoration:none;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
  padding:10px 12px;
  border-radius:11px;
  border:none;
  background:transparent;
  transition:.18s ease;
}

.pfn-index-nav .nav-links a:hover,
.pfn-index-nav .nav-links a.active{
  color:#fff;
  background:rgba(229,9,20,.22);
}

.pfn-index-nav .menu-btn{
  display:none;
  margin-left:auto;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:12px;
  padding:10px 12px;
  font-weight:900;
  cursor:pointer;
}

@media(max-width:980px){
  .pfn-index-nav .site-logo-img{
    height:56px;
    max-width:min(350px,54vw);
  }
  .pfn-index-nav .nav-links a{
    font-size:11px;
    padding:9px 10px;
  }
}

@media(max-width:760px){
  .nav.pfn-index-nav{
    height:68px;
  }
  .pfn-index-nav .site-logo-img{
    height:50px;
    max-width:min(300px,64vw);
  }
  .pfn-index-nav .menu-btn{
    display:block;
  }
  .pfn-index-nav .nav-links{
    display:none;
    position:absolute;
    top:68px;
    left:17px;
    right:17px;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    background:rgba(5,5,6,.96);
    border:1px solid rgba(255,255,255,.14);
    border-radius:20px;
    padding:12px;
    box-shadow:0 20px 50px rgba(0,0,0,.45);
  }
  .pfn-index-nav .nav-links.open{
    display:flex;
  }
  .pfn-index-nav .nav-links a{
    text-align:center;
    padding:13px 12px;
    border:1px solid rgba(255,255,255,.08);
    border-radius:14px;
  }
}


/* v11 logo consistency fix: match index.php/radar header, remove old forecast logo-card effects */
.nav.pfn-index-nav .site-logo,
body.forecast-page .nav.pfn-index-nav .site-logo,
body.radar-engine-page .nav.pfn-index-nav .site-logo{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
  overflow:visible!important;
  min-height:auto!important;
}

.nav.pfn-index-nav .site-logo picture,
body.forecast-page .nav.pfn-index-nav .site-logo picture,
body.radar-engine-page .nav.pfn-index-nav .site-logo picture{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
  overflow:visible!important;
}

.nav.pfn-index-nav .site-logo-img,
body.forecast-page .nav.pfn-index-nav .site-logo-img,
body.radar-engine-page .nav.pfn-index-nav .site-logo-img{
  display:block!important;
  height:62px!important;
  width:auto!important;
  max-width:min(430px,44vw)!important;
  object-fit:contain!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  padding:0!important;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.55))!important;
}

/* Prevent older shared header logo rules from touching the new index-style logo */
.nav.pfn-index-nav .pfn-header-logo,
.nav.pfn-index-nav .pfn-brand-logo,
.nav.pfn-index-nav .pfn-brand,
.nav.pfn-index-nav .pfn-mark,
.nav.pfn-index-nav .pfn-brand-text{
  display:none!important;
}

@media(max-width:980px){
  .nav.pfn-index-nav .site-logo-img,
  body.forecast-page .nav.pfn-index-nav .site-logo-img,
  body.radar-engine-page .nav.pfn-index-nav .site-logo-img{
    height:56px!important;
    max-width:min(350px,54vw)!important;
  }
}

@media(max-width:760px){
  .nav.pfn-index-nav .site-logo-img,
  body.forecast-page .nav.pfn-index-nav .site-logo-img,
  body.radar-engine-page .nav.pfn-index-nav .site-logo-img{
    height:50px!important;
    max-width:min(300px,64vw)!important;
  }
}


/* v12 unified navigation and page hero system */
:root{
  --nav-h:76px;
  --line:rgba(255,255,255,.12);
  --red:#e50914;
  --red-2:#ff2a2a;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:0;
  background:var(--red);
  color:#fff;
  padding:10px 16px;
  z-index:9999;
}
.skip-link:focus{left:12px;top:12px}

.top-strip{
  height:34px;
  background:linear-gradient(90deg,#2a0000,#e50914,#2a0000);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.12);
}

.nav.pfn-index-nav{
  position:sticky;
  top:0;
  height:var(--nav-h);
  z-index:5000;
  background:rgba(5,5,5,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  box-shadow:0 8px 26px rgba(0,0,0,.32);
}

.pfn-index-nav .container{
  width:min(1220px, calc(100% - 40px));
  margin:0 auto;
}

.pfn-index-nav .nav-inner{
  height:100%;
  display:flex;
  align-items:center;
  gap:22px;
}

.pfn-index-nav .logo,
.nav.pfn-index-nav .site-logo{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
  min-width:max-content!important;
  text-decoration:none!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
  overflow:visible!important;
}

.pfn-index-nav .site-logo picture{
  display:flex!important;
  align-items:center!important;
  line-height:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
}

.pfn-index-nav .site-logo-img{
  display:block!important;
  height:62px!important;
  width:auto!important;
  max-width:min(430px,44vw)!important;
  object-fit:contain!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  padding:0!important;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.55))!important;
}

.pfn-index-nav .site-logo-fallback{display:none;align-items:center;gap:12px}
.pfn-index-nav .site-logo.logo-fallback picture{display:none!important}
.pfn-index-nav .site-logo.logo-fallback .site-logo-fallback{display:flex}

.pfn-index-nav .fallback-mark{
  width:46px;height:46px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(145deg,rgba(229,9,20,.95),rgba(10,10,12,.95));
  border:1px solid rgba(255,255,255,.18);
  font-family:'Bebas Neue',sans-serif;font-size:34px;line-height:1;color:#fff;
  box-shadow:0 0 28px rgba(229,9,20,.26);
}
.pfn-index-nav .logo-text strong{display:block;font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:.075em;line-height:.9;color:#fff}
.pfn-index-nav .logo-text span{display:block;font-size:9px;font-weight:900;letter-spacing:.28em;color:var(--red-2);text-transform:uppercase;margin-top:4px}

.pfn-index-nav .nav-links{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:4px;
}

.pfn-index-nav .nav-links a{
  text-decoration:none;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
  padding:10px 12px;
  border-radius:11px;
  border:none;
  background:transparent;
  transition:.18s ease;
}

.pfn-index-nav .nav-links a:hover,
.pfn-index-nav .nav-links a.active{
  color:#fff;
  background:rgba(229,9,20,.22);
}

.pfn-index-nav .nav-cta{
  background:var(--red)!important;
  color:#fff!important;
  box-shadow:0 8px 24px rgba(229,9,20,.28);
}

.pfn-index-nav .menu-btn{
  display:none;
  margin-left:auto;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:12px;
  padding:10px 12px;
  font-weight:900;
  cursor:pointer;
}

.radar-command-hero{
  margin:0 0 22px!important;
}
.radar-command-hero h1 .red{
  color:var(--red-2)!important;
}
.radar-command-hero .forecast-source-card{
  border:1px solid rgba(255,255,255,.13)!important;
  border-radius:24px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.035))!important;
  box-shadow:0 24px 70px rgba(0,0,0,.26)!important;
}

@media(max-width:980px){
  .pfn-index-nav .site-logo-img{height:56px!important;max-width:min(350px,54vw)!important}
  .pfn-index-nav .nav-links a{font-size:11px;padding:9px 10px}
}

@media(max-width:760px){
  .top-strip{font-size:9px;letter-spacing:.12em;padding:0 12px;text-align:center}
  .nav.pfn-index-nav{height:68px}
  .pfn-index-nav .site-logo-img{height:50px!important;max-width:min(300px,64vw)!important}
  .pfn-index-nav .menu-btn{display:block}
  .pfn-index-nav .nav-links{
    display:none;
    position:absolute;
    top:68px;
    left:17px;
    right:17px;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    background:rgba(5,5,6,.96);
    border:1px solid rgba(255,255,255,.14);
    border-radius:20px;
    padding:12px;
    box-shadow:0 20px 50px rgba(0,0,0,.45);
  }
  .pfn-index-nav .nav-links.open{display:flex}
  .pfn-index-nav .nav-links a{text-align:center;padding:13px 12px;border:1px solid rgba(255,255,255,.08);border-radius:14px}
}


/* v13 Placefile testing radar overlays */
.layer-menu-divider{
  border:0;
  border-top:1px solid rgba(255,255,255,.12);
  margin:12px 0 11px;
}
.layer-menu-subtitle{
  margin-top:4px!important;
  color:#ff4b4b!important;
}
.layer-menu-panel label input[id^="togglePfn"]{
  accent-color:#e50914;
}
.pfn-testing-popup strong{
  display:block;
  color:#ff4b4b;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.10em;
  margin-bottom:6px;
}
.pfn-testing-popup b{
  display:block;
  color:#fff;
  font-family:'Bebas Neue',sans-serif;
  font-size:30px;
  line-height:1;
  letter-spacing:.04em;
  margin-bottom:8px;
}
.pfn-testing-popup p{
  margin:0 0 8px;
  color:rgba(255,255,255,.76);
  font-size:12px;
  line-height:1.45;
}
.pfn-testing-popup small{
  display:block;
  color:rgba(255,255,255,.45);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.10em;
}


/* v14 wind barb + dew point placefile testing overlays */
.layer-menu-panel label input#togglePfnWind,
.layer-menu-panel label input#togglePfnDewpoints{
  accent-color:#e50914;
}
.pfn-wind-marker{
  all:unset;
  width:58px;
  height:48px;
  display:block;
  position:relative;
  cursor:pointer;
  pointer-events:auto;
  transform:translate(-50%,-50%);
}
.pfn-wind-barb-svg{
  position:absolute;
  left:18px;
  top:3px;
  width:32px;
  height:38px;
  transform:rotate(var(--wind-rotate,0deg));
  transform-origin:50% 50%;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.85));
}
.pfn-wind-barb-svg svg{
  width:100%;
  height:100%;
  overflow:visible;
}
.pfn-wind-barb-svg line,
.pfn-wind-barb-svg path,
.pfn-wind-barb-svg circle{
  stroke:#fff;
  fill:#fff;
  stroke-width:2.4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.pfn-wind-barb-svg path{
  stroke-width:1.5;
}
.pfn-wind-marker-label{
  position:absolute;
  left:0;
  bottom:0;
  min-width:34px;
  padding:2px 5px;
  border-radius:999px;
  background:rgba(5,5,6,.78);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  font-weight:900;
  line-height:1;
  text-align:center;
  box-shadow:0 2px 8px rgba(0,0,0,.45);
}
.pfn-wind-marker:hover .pfn-wind-marker-label{
  background:#e50914;
  border-color:#e50914;
}


/* v15 HTML marker testing overlays: fixes GLM bolts + temp/dew/wind visibility */
.pfn-testing-marker{
  all:unset;
  position:relative;
  display:grid;
  place-items:center;
  cursor:pointer;
  pointer-events:auto;
  transform:translate(-50%,-50%);
  z-index:1000;
  font-family:'JetBrains Mono',monospace;
}
.pfn-testing-marker:hover{
  z-index:1200;
}

/* Tiny lightning bolts for GLM */
.pfn-glm-marker{
  width:18px;
  height:18px;
  color:#fff;
  font-size:13px;
  line-height:1;
  text-shadow:
    0 0 2px #000,
    0 0 5px rgba(0,0,0,.95),
    0 0 8px rgba(229,9,20,.85);
  filter:drop-shadow(0 0 5px rgba(229,9,20,.60));
}
.pfn-glm-marker span{
  display:block;
  transform:translateY(-1px);
}

/* Temperature / dew point / CoCoRaHS visible value badges */
.pfn-value-marker{
  min-width:30px;
  height:22px;
  padding:0 6px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  letter-spacing:-.03em;
  box-shadow:0 2px 8px rgba(0,0,0,.60);
}
.pfn-value-marker span{
  display:block;
  line-height:22px;
}
.pfn-temp-marker{
  background:rgba(248,250,252,.92);
  border:1px solid rgba(5,5,6,.65);
  color:#050506;
}
.pfn-dew-marker{
  background:rgba(0,229,255,.90);
  border:1px solid rgba(3,31,38,.80);
  color:#031f26;
}
.pfn-cocorahs-marker{
  background:rgba(56,189,248,.88);
  border:1px solid rgba(6,25,37,.80);
  color:#031f26;
}
.pfn-dot-marker{
  width:20px;
  height:20px;
  border-radius:999px;
  border:2px solid rgba(5,5,6,.72);
  color:#050506;
  font-size:12px;
  font-weight:900;
  box-shadow:0 2px 8px rgba(0,0,0,.55);
}
.pfn-mping-marker{
  background:#20e070;
}

/* Wind barb markers */
.pfn-wind-marker{
  width:58px;
  height:48px;
}
.pfn-wind-barb-svg{
  position:absolute;
  left:18px;
  top:3px;
  width:32px;
  height:38px;
  transform:rotate(var(--wind-rotate,0deg));
  transform-origin:50% 50%;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.85));
}
.pfn-wind-barb-svg svg{
  width:100%;
  height:100%;
  overflow:visible;
}
.pfn-wind-barb-svg line,
.pfn-wind-barb-svg path,
.pfn-wind-barb-svg circle{
  stroke:#fff;
  fill:#fff;
  stroke-width:2.4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.pfn-wind-barb-svg path{
  stroke-width:1.5;
}
.pfn-wind-marker-label{
  position:absolute;
  left:0;
  bottom:0;
  min-width:34px;
  padding:2px 5px;
  border-radius:999px;
  background:rgba(5,5,6,.78);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  font-weight:900;
  line-height:1;
  text-align:center;
  box-shadow:0 2px 8px rgba(0,0,0,.45);
}
.pfn-wind-marker:hover .pfn-wind-marker-label,
.pfn-temp-marker:hover,
.pfn-dew-marker:hover,
.pfn-cocorahs-marker:hover,
.pfn-mping-marker:hover{
  outline:2px solid #e50914;
  outline-offset:2px;
}

/* Make sure MapLibre markers are above raster radar/city-label layers but below the UI controls. */
.radar-map-shell .maplibregl-marker:has(.pfn-testing-marker){
  z-index:1000!important;
}


/* v18 radar boot status safety */
.radar-time-bubble strong#radarFrameLabel{min-width:110px}
