/* Field guide rotate handles: animatable mask sweep (conic stops use var) */
@property --fg-rot-trim{
  syntax:'<number>';
  inherits:false;
  initial-value:0}
:root {
  --bg:#0e0d0a;--surface:#161410;--surface2:#1e1b16;--surface3:#252219;
  --border:#2e2a22;--border2:#3d3828;--text:#e8e0cc;--muted:#7a7060;
  --faint:#3a3528;--amber:#d4883a;--amber2:#f0a84a;--green:#5a9e6a;
  --green2:#7ec48c;--teal:#4a8e8a;--red:#c06050;--cream:#c8b88a;
  /* Top chrome height for full-height panels (sticky tab bar + inline waveform + peeper glow padding) */
  --wfts-layout-chrome:72px;
  /* Space reserved above fixed footer amb bar (matches body padding-bottom) */
  --wfts-footer-reserve:calc(52px + env(safe-area-inset-bottom, 0px));
  /* Repeated UI chroma (deduped from longhand rgba across the sheet) */
  --wfts-c-stone-12:rgba(92,90,88,0.12);
  --wfts-c-stone-15:rgba(92,90,88,0.15);
  --wfts-c-stone-18:rgba(92,90,88,0.18);
  --wfts-c-stone-20:rgba(92,90,88,0.2);
  --wfts-c-stone-22:rgba(92,90,88,0.22);
  --wfts-c-stone-25:rgba(92,90,88,0.25);
  --wfts-c-stone-35:rgba(92,90,88,0.35);
  --wfts-c-mute-12:rgba(138,136,132,0.12);
  --wfts-c-mute-35:rgba(138,136,132,0.35);
  --wfts-c-mute-40:rgba(138,136,132,0.4);
  --wfts-c-mute-50:rgba(138,136,132,0.5);
  --wfts-c-mute-78:rgba(138,136,132,0.78);
  --wfts-c-mute-88:rgba(138,136,132,0.88);
  --wfts-c-surface-40:rgba(28,27,26,0.4);
  --wfts-c-surface-50:rgba(28,27,26,0.5);
  --wfts-c-amber-12:rgba(212,168,90,0.12);
  --wfts-c-amber-35:rgba(212,168,90,0.35);
  --wfts-c-amber-50:rgba(212,168,90,0.5);
  --wfts-c-amber-55:rgba(212,168,90,0.55);
  --wfts-c-amberdeep-12:rgba(212,136,58,0.12);
  --wfts-c-amberdeep-25:rgba(212,136,58,0.25);
  --wfts-c-amberdeep-35:rgba(212,136,58,0.35);
  --wfts-c-amberdeep-45:rgba(212,136,58,0.45);
  --wfts-c-text-95:rgba(232,224,204,0.95);
  --wfts-c-gold-55:rgba(240,185,95,0.55);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html{background-color:#000010}
html.wfts-boot-lock body{overflow:hidden}
html.wfts-boot-loading:not(.wfts-boot-done) body.wfts-boot-fixed{
  position:fixed;left:0;right:0;width:100%;overflow:hidden}
body{background-color:#000010;color:var(--text);font-family:'IBM Plex Mono',monospace;min-height:100vh;
  /* Instant padding-top: animated chrome + instant fixed→flow switch caused header to sit under tabs briefly */
  transition:padding-top 0s linear;
  background-image:none}
/* Persistent star/sky layer — must stay below .tab-panel so predictor content stays visible */
#app-sky-bg{position:fixed;inset:0;overflow:hidden;pointer-events:none;background:#000010;
  z-index:0;transition:opacity 1.15s ease-out,z-index 0s linear}
#app-sky-bg iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}
/* Boot: black frame → stars fade → logo seq → “Frog Night” + chrome */
html.wfts-boot-loading:not(.wfts-boot-phase-sky) #app-sky-bg{opacity:0}
html.wfts-boot-loading.wfts-boot-phase-sky #app-sky-bg{opacity:1}
html.wfts-boot-loading:not(.wfts-boot-phase-sky) body{
  background-color:#000010!important;
  background-image:none!important}
html.wfts-boot-loading #main-nav{
  opacity:0;
  pointer-events:none;
  transition:opacity 0.88s cubic-bezier(0.25,0.85,0.3,1)}
html.wfts-boot-loading.wfts-boot-phase-chrome #main-nav{
  opacity:1;
  pointer-events:auto}
html.wfts-boot-loading .app-footer{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity 0.65s ease,visibility 0s linear 0.5s}
html.wfts-boot-loading.wfts-boot-phase-chrome .app-footer{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transition:opacity 0.65s ease,visibility 0s linear}
html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card .pcc-logo-wrap{
  opacity:0;
  transition:opacity 0.95s cubic-bezier(0.25,0.85,0.3,1),transform 1.15s cubic-bezier(0.25,0.85,0.3,1)}
html.wfts-boot-loading.wfts-boot-phase-logo body:not(.loaded) #predictor-countdown-card .pcc-logo-wrap{opacity:1}
html.wfts-boot-loading:not(.wfts-boot-phase-title) .predictor-countdown-card .pcc-title-brand{
  opacity:0!important;
  transition:opacity 0.95s cubic-bezier(0.33,0.86,0.22,1)}
html.wfts-boot-loading:not(.wfts-boot-phase-title) .predictor-countdown-card .pcc-title-brand.wave-words span{
  animation:none!important}
html.wfts-boot-loading.wfts-boot-phase-title .predictor-countdown-card .pcc-title-brand{
  opacity:1!important}
html.wfts-boot-loading:not(.wfts-boot-phase-title) .predictor-countdown-card .pcc-title-subline{
  opacity:0!important;
  transition:opacity 0.95s cubic-bezier(0.33,0.86,0.22,1)}
html.wfts-boot-loading.wfts-boot-phase-title .predictor-countdown-card .pcc-title-subline{
  opacity:1!important}
/* Boot poem — same voice as Frog Night title; line timings set in app.js (fade + 3s hold + fade) */
.predictor-countdown-card .pcc-boot-poem{
  margin:0 auto;
  max-width:min(34em,92vw);
  pointer-events:none;
  text-align:center;
  position:relative;
  min-height:clamp(78px,10.5vw,122px);
  transition:opacity 0.55s ease,margin 0.45s ease}
html.wfts-boot-loading:not(.wfts-boot-phase-poem) .pcc-boot-poem{
  opacity:0;
  max-height:0;
  margin:0;
  overflow:hidden;
  visibility:hidden}
html.wfts-boot-loading.wfts-boot-phase-poem .pcc-boot-poem{
  opacity:1;
  max-height:min(58vh,34rem);
  margin:0 auto 14px;
  overflow:visible;
  visibility:visible}
.predictor-countdown-card .pcc-boot-poem-line{
  font-family:'Playfair Display',serif;
  font-size:clamp(17.325px, 3.05vw, 26.4px);
  font-weight:400;
  font-style:italic;
  line-height:1.5;
  color:var(--cream);
  letter-spacing:0.015em;
  margin:0;
  padding:0 8px;
  opacity:0;
  text-shadow:0 1px 24px rgba(0,0,0,0.35);
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  white-space:nowrap}
body.loaded .pcc-boot-poem{display:none!important}
@media (prefers-reduced-motion:reduce){
  html.wfts-boot-loading #app-sky-bg{transition-duration:0.15s}
  html.wfts-boot-loading #main-nav{transition-duration:0.12s}
  html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card .pcc-logo-wrap{transition-duration:0.12s}
  html.wfts-boot-loading:not(.wfts-boot-phase-title) .predictor-countdown-card .pcc-title-brand,
  html.wfts-boot-loading.wfts-boot-phase-title .predictor-countdown-card .pcc-title-brand{transition-duration:0.12s}
  html.wfts-boot-loading .pcc-boot-poem{transition:none}}
body>#main-nav{position:relative;z-index:0;transition:z-index 0s linear}
body>.tab-panel{position:relative;z-index:1;transition:z-index 0s linear}
/* Keep tab bar above .tab-panel (z-index:1). body.loaded alone can miss a frame if boot unlock desyncs. */
html:not(.wfts-boot-loading) body>#main-nav.tabs,
body.loaded>#main-nav.tabs{z-index:40}
/* Stars off: same base as live star layer (#000010), hide WebGL iframe */
body.star-bg-off{
  background-color:#000010;
  background-image:none}
body.star-bg-off #app-sky-bg iframe{display:none!important}
body.star-bg-off #app-sky-bg::after{display:none!important}

/* Header */
.header{padding:0;border-bottom:none;position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--wfts-c-surface-50) 0%,var(--bg) 100%);
  transition:background .45s cubic-bezier(0.22,1,0.36,1),box-shadow .45s ease}
body.hdr-scroll-compact .header{
  box-shadow:0 10px 28px rgba(0,0,0,0.22);
  background:linear-gradient(180deg,rgba(20,19,17,0.92) 0%,rgba(14,13,10,0.96) 100%)}
.hdr-inner{padding:18px 48px 22px;
  transition:padding .5s cubic-bezier(0.25,0.9,0.3,1)}
body.hdr-scroll-compact .hdr-inner{padding:11px 48px 14px}
.app-footer{text-align:center;padding:14px 20px calc(14px + 56px + env(safe-area-inset-bottom,0)) 20px;font-size:11.1375px;letter-spacing:1px;color:var(--muted);
  border-top:1px solid var(--wfts-c-stone-18);background:rgba(14,13,10,0.4);
  transition:padding-bottom .22s ease}
html.wfts-amb-bar-collapsed .app-footer{
  padding-bottom:calc(14px + 44px + env(safe-area-inset-bottom,0))}
.app-footer a{color:rgba(138,136,132,0.9);text-decoration:none}
.app-footer a:hover{color:var(--cream)}
h1{font-family:'Playfair Display',serif;font-size:clamp(27.225px, 4.95vw, 54.45px);font-weight:400;line-height:1.1;letter-spacing:-.5px}
h1 em{font-style:italic;color:var(--amber2)}
.sub{margin-top:8px;font-size:13.6125px;color:var(--muted);letter-spacing:.5px;line-height:1.7;max-width:580px}
.hdr-title-row{display:flex;align-items:center;justify-content:flex-start;gap:14px;width:100%;flex-wrap:wrap}
.hdr-title-row--wave-only{justify-content:flex-end}
.hdr-title-block{flex:0 1 auto;min-width:0}
.hdr-title-row h1{
  margin:0 0 4px 0;padding-bottom:10px;max-height:min(200px,14rem);opacity:1;overflow:hidden;
  font-size:clamp(24.75px, 4.5169vw, 49.5px);line-height:1.14;
  transform:translate3d(0,0,0);
  transition:transform .52s cubic-bezier(0.22,1,0.36,1),max-height .52s cubic-bezier(0.22,1,0.36,1),margin .45s ease,padding .45s ease,opacity .38s ease .02s}
/* Scroll-compact: gentle fade + small lift (avoids long translate + height fight with nav) */
body.hdr-scroll-compact .hdr-title-row{justify-content:flex-end}
body.hdr-scroll-compact .hdr-title-row--wave-only{justify-content:flex-end}
body.hdr-scroll-compact .hdr-title-row h1{
  transform:translate3d(0,-10px,0);max-height:0;margin:0;padding:0;opacity:0;pointer-events:none;border:0}
@media (prefers-reduced-motion:reduce){
  .hdr-title-row h1{transition:none}
  body.hdr-scroll-compact .hdr-title-row h1{transform:none;opacity:0;max-height:0;margin:0;padding:0}
}
.hdr-subtitle-row{
  transition:opacity .45s cubic-bezier(0.22,1,0.36,1) .04s,max-height .48s cubic-bezier(0.22,1,0.36,1),margin .42s ease,padding .42s ease;
  max-height:12em;opacity:1;overflow:hidden}
body.hdr-scroll-compact .hdr-subtitle-row{max-height:0;opacity:0;margin:0;padding:0;pointer-events:none}
.hdr-title-row h1 .hdr-tm{
  font-family:'IBM Plex Mono',monospace;font-size:0.374em;font-weight:500;line-height:0;
  vertical-align:super;position:relative;top:0.02em;margin-left:0.1em;
  color:var(--wfts-c-mute-78);letter-spacing:0;white-space:nowrap}
.hdr-title-row h1 .hdr-title-main{font-size:1.023em;font-weight:400}
.hdr-title-row h1 .hdr-tagline{font-style:italic;font-size:0.715em;letter-spacing:0.02em}
.hdr-title-row h1 .hdr-emdash{opacity:0.9}
.hdr-subtitle-row{display:flex;align-items:baseline;gap:10px 20px;flex-wrap:wrap;margin-top:5px;padding-left:45px;max-width:100%}
.hdr-subtitle{font-size:8.6625px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(92,90,88,0.6);margin:0;padding:0;flex-shrink:0}
.hdr-attrib{margin:0;flex:1;min-width:min(100%,220px);max-width:720px;font-family:'IBM Plex Mono',monospace;font-size:8.6625px;line-height:1.5;letter-spacing:0.25px;color:var(--wfts-c-mute-78);font-weight:400}
.hdr-sub-row{display:flex;align-items:center;gap:16px;margin-top:8px;flex-wrap:wrap}
.hdr-sub-row .sub{margin-top:0;flex:1;min-width:0}
.hdr-waveform-wrap{flex-shrink:0;background:transparent;border:none;padding:4px 0 4px 8px;height:40px;display:flex;align-items:center;justify-content:center;
  transition:transform .5s cubic-bezier(0.25,0.9,0.3,1),opacity .42s ease}
#main-nav.tabs .main-nav-waveform-slot{
  flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  padding:0 0 0 clamp(2px,0.8vw,10px)}
#main-nav.tabs .hdr-waveform-wrap{
  flex:0 0 auto;margin-left:0;
  padding:clamp(2px,0.6vw,4px) 0 clamp(2px,0.6vw,4px) 0;
  min-width:56px;max-width:min(200px,30vw);height:clamp(26px,6vw,40px)}
body.hdr-scroll-compact #main-nav.tabs .hdr-waveform-wrap{transform:scale(0.96);transform-origin:center;opacity:0.98}
.hdr-waveform{display:block;width:200px;height:40px;vertical-align:middle}
#main-nav.tabs .hdr-waveform{
  display:block;width:100%;height:100%;max-width:200px;max-height:40px;aspect-ratio:5/1;vertical-align:middle}

/* Layout */
.app{display:grid;grid-template-columns:1fr;min-height:calc(100vh - var(--wfts-layout-chrome));justify-items:center}

.predictor-center{width:100%;max-width:min(1920px,98vw);padding:clamp(28px,5vw,52px) max(24px,4vw) clamp(40px,6vw,72px);box-sizing:border-box;display:flex;flex-direction:column;gap:clamp(32px,4vw,48px);align-items:stretch}
/* Narrow composed column: calmer reading measure */
.predictor-compose{width:100%;max-width:min(700px,90vw);margin:0 auto;display:flex;flex-direction:column;gap:clamp(22px,3vw,34px);align-items:stretch}
.predictor-page-title{
  font-family:'Playfair Display',serif;font-size:clamp(32.175px, 4.3312vw, 42.075px);font-weight:400;color:var(--cream);
  margin:0;line-height:1.12}
.predictor-lede{
  font-family:'Playfair Display',serif;font-size:clamp(17.325px, 2.475vw, 21.0375px);font-weight:400;font-style:italic;line-height:1.55;
  color:rgba(200,184,138,0.72);letter-spacing:0.01em;margin:10px 0 0}
.predictor-countdown-card .predictor-page-title .wave-words span{
  display:inline-block;
  opacity:0.35;
  animation:wordOpacityWave 10.5s ease-in-out infinite;
  animation-delay:calc(var(--i,0) * 0.38s);
}
/* Loading + hold: “Frog Night” uses boot shimmer */
html.wfts-boot-loading .predictor-countdown-card .pcc-title-brand.wave-words span,
html.wfts-boot-hold .predictor-countdown-card .pcc-title-brand.wave-words span{
  animation:wordOpacityWaveBoot 6.5s cubic-bezier(0.45,0,0.55,1) infinite;
  animation-delay:calc(var(--i,0) * 0.55s);
}
@keyframes pccTitleBrandEase{
  0%{opacity:1}
  42%{opacity:0.2}
  100%{opacity:1}
}
body.loaded .predictor-countdown-card .pcc-title-brand{
  animation:pccTitleBrandEase 1.75s cubic-bezier(0.33,0.86,0.22,1) forwards;
}
@keyframes wordOpacityWave{
  0%,100%{opacity:0.28}
  45%{opacity:1}
  75%{opacity:0.42}
}
@keyframes wordOpacityWaveBoot{
  0%,100%{opacity:0.34}
  50%{opacity:0.92}
}
/* Placeholder: opacity pulse travels left → right (per-character delays) */
.predictor-countdown-card .predictor-input-wave-placeholder.wave-words span{
  display:inline-block;
  opacity:0.32;
  animation:placeholderLtrOpacity 2.6s ease-in-out infinite;
  animation-delay:calc(var(--i,0) * 0.065s);
}
@keyframes placeholderLtrOpacity{
  0%,100%{opacity:0.28}
  22%{opacity:1}
  44%{opacity:0.28}
}
.predictor-countdown-card .predictor-page-title{
  font-size:clamp(25.9875px, 3.8363vw, 37.125px);text-align:center;margin:0 0 8px;line-height:1.15;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:0}
.predictor-countdown-card .pcc-title-subline{
  margin:0 0 6px;
  font-family:'Playfair Display',serif;
  font-size:clamp(13px,1.75vw,17px);
  font-style:italic;
  line-height:1.2;
  letter-spacing:0.01em;
  color:rgba(92,90,88,0.86);
  text-align:center}
.predictor-countdown-card .pcc-title-subline.wave-words span{
  display:inline-block;
  opacity:0.28;
  animation:wordOpacityWave 10.5s ease-in-out infinite;
  animation-delay:calc(var(--i,0) * 0.28s)}
/* Animated “Enter a location…” as overlay inside the field (native placeholder can’t run word wave) */
.predictor-countdown-card .predictor-linput-with-wave{position:relative;width:100%}
.predictor-countdown-card .predictor-input-wave-placeholder{
  position:absolute;left:18px;right:100px;top:50%;transform:translateY(-50%);z-index:2;
  pointer-events:none;text-align:left;
  font-family:'Playfair Display',serif;font-size:clamp(17.325px, 2.475vw, 21.0375px);font-weight:400;font-style:italic;line-height:1.55;
  color:rgba(200,184,138,0.72);letter-spacing:0.01em;
  white-space:nowrap;overflow:visible;
  transition:opacity 0.28s ease,visibility 0.28s ease}
.predictor-countdown-card .predictor-linput-with-wave.predictor-linput-has-value .predictor-input-wave-placeholder{
  opacity:0;visibility:hidden}
@media (prefers-reduced-motion:reduce){
  .predictor-countdown-card .predictor-input-wave-placeholder{transition:none}
  .predictor-countdown-card .predictor-input-wave-placeholder.wave-words span{animation:none;opacity:0.7}
  .predictor-countdown-card .predictor-location-stack > *{animation:none}
}
.predictor-countdown-card .predictor-location-stack{
  display:flex;flex-direction:column;align-items:stretch;width:100%;gap:8px;margin:4px 0 12px}
.predictor-countdown-card .predictor-location-stack > *{
  transform-origin:center center;
  animation:pccLocNoise 33s ease-in-out infinite;
  will-change:transform}
.predictor-countdown-card .predictor-location-stack > :nth-child(2){animation-duration:37s;animation-delay:-4.5s}
.predictor-countdown-card .predictor-location-stack > :nth-child(3){animation-duration:35s;animation-delay:-9s}
.predictor-countdown-card .predictor-location-stack > :nth-child(4){animation-duration:39s;animation-delay:-6s}
.predictor-countdown-card .predictor-location-stack > :nth-child(5){animation-duration:36s;animation-delay:-12s}
@keyframes pccLocNoise{
  0%,100%{transform:translate3d(0,0,0)}
  18%{transform:translate3d(1.5px,-0.8px,0)}
  37%{transform:translate3d(-1.2px,1.1px,0)}
  56%{transform:translate3d(1.1px,0.9px,0)}
  74%{transform:translate3d(-1.4px,-0.9px,0)}
  90%{transform:translate3d(0.8px,0.6px,0)}
}
.predictor-countdown-card .predictor-location-stack .fo-row{margin-bottom:0}
.predictor-countdown-card .predictor-location-stack .selloc{align-self:stretch;max-width:none;width:100%}
.predictor-countdown-card .predictor-location-stack .predictor-primary-actions{margin-top:4px}
.predictor-countdown-card .predictor-location-stack .sresults{margin-top:0;order:0}
.predictor-countdown-card .predictor-location-stack .swrap{min-width:0!important;width:100%;flex:1 1 auto}
.predictor-location-row{display:flex;flex-wrap:wrap;align-items:center;gap:18px}
.predictor-location-row .slabel{width:100%;margin:0 0 10px 0;flex:0 0 100%;font-size:11.1375px;letter-spacing:0.38em;text-transform:uppercase;color:rgba(138,136,132,0.55);
  font-weight:500;padding-bottom:12px;border-bottom:1px solid var(--wfts-c-amber-12)}
.predictor-location-row .pred-loc-input-wrap{display:flex;align-items:center;gap:16px;flex:1;min-width:0}
.predictor-location-row .fo-row{width:100%;max-width:100%}
.predictor-gps-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;user-select:none;flex-shrink:0;padding:4px 0}
.predictor-gps-chk{width:22px;height:22px;border-radius:4px;font-size:14.85px}
.predictor-gps-label{font-size:9.9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.predictor-gps-wrap:hover .predictor-gps-label{color:#8a8884}
.predictor-location-row .swrap{flex:1;min-width:400px}
.predictor-location-row .swrap-with-gps{display:flex;align-items:stretch;gap:0}
.predictor-location-row .swrap-with-gps .predictor-loc-trailing{display:flex;align-items:center;flex-shrink:0;gap:2px;
  padding:0 6px 0 8px;border:1px solid var(--wfts-c-stone-20);border-left:none;border-radius:0 14px 14px 0;
  background:linear-gradient(90deg,rgba(22,21,18,0.2),rgba(34,32,28,0.55))}
.predictor-location-row .swrap-with-gps .predictor-gps-wrap{flex-shrink:0;padding:0 2px;align-self:center}
.predictor-location-row .swrap-with-gps .sinput{flex:1;min-width:0;padding:16px 18px;
  border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}
.predictor-location-row .swrap-with-gps .sbtn{position:static;top:auto;right:auto;bottom:auto;align-self:stretch;
  display:flex;align-items:center;justify-content:center;padding:0 12px;min-width:44px;border:none;background:transparent;border-radius:0}
.predictor-location-row .swrap-with-gps:has(#linput:focus) .predictor-loc-trailing{border-color:var(--wfts-c-mute-50)}
@keyframes predictorSearchPulse{
  0%,100%{opacity:0.4}
  50%{opacity:0.82}}
/* Predictor: GPS + search sit inside the input on the right */
#panel-predictor .predictor-location-row .swrap-with-gps{display:block;position:relative}
#panel-predictor .predictor-location-row .swrap-with-gps .sinput{
  width:100%;box-sizing:border-box;
  padding:16px 102px 16px 18px;
  border-radius:14px;border:1px solid var(--wfts-c-stone-22);border-right:1px solid var(--wfts-c-stone-22)}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-loc-trailing{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  display:grid;grid-template-columns:auto auto;grid-template-rows:auto auto;
  column-gap:4px;row-gap:3px;align-items:center;justify-items:center;
  padding:0 14px 0 0;border:none;background:transparent;border-radius:0;
  box-shadow:none}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-gps-wrap{display:contents}
#panel-predictor .predictor-location-row .swrap-with-gps .sbtn{
  grid-column:1;grid-row:1;align-self:center;justify-self:center;
  position:relative;min-width:0;width:max-content;padding:0 6px 0 4px;font-size:25.9875px;line-height:1;
  opacity:0.55;color:var(--amber);
  animation:predictorSearchPulse 7.2s ease-in-out infinite;
  transition:opacity .28s ease,transform .24s ease,color .2s ease}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-gps-chk{
  grid-column:2;grid-row:1;align-self:center;justify-self:center}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-gps-label{
  grid-column:2;grid-row:2;justify-self:center;margin:0;line-height:1.1}
#panel-predictor .predictor-location-row .swrap-with-gps .sbtn:hover{
  opacity:1;color:var(--amber2);animation:none;transform:scale(1.15)}
#panel-predictor .predictor-location-row .swrap-with-gps:has(#linput:focus) .predictor-loc-trailing{border-color:transparent}
.predictor-location-row .selloc{flex:0 1 auto;min-width:0;max-width:min(360px,100%);width:fit-content}
.predictor-location-row .predictor-primary-actions{flex:1 1 100%;margin-top:12px;display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;align-items:stretch;width:100%}
.predictor-location-row .predictor-primary-actions .fetchbtn{flex:1 1 calc(50% - 5px);min-width:0;margin-top:0;width:auto;min-height:52px}
/* Forecast location row + buttons: subtle float drift (transform from wftsPredictorLocMicroDrift in app.js) */
#panel-predictor #predictor-linput-wrap,
#panel-predictor .predictor-primary-actions,
#panel-predictor #predictor-loc-reset{will-change:transform}
@media (prefers-reduced-motion:reduce){
  #panel-predictor #predictor-linput-wrap,
  #panel-predictor .predictor-primary-actions,
  #panel-predictor #predictor-loc-reset{will-change:auto}}
.predictor-location-row .sresults{width:100%;order:10}
/* FIELD OBSERVATION — logo above title; location + fetch below hero */
.field-obs-merged{display:flex;flex-direction:column;align-items:center;width:100%;max-width:min(1920px,100%);margin:0 auto}
.field-obs-merged .fo-form,.predictor-center .fo-form{width:100%;text-align:left;pointer-events:auto}
.field-obs-merged .fo-form .slabel{font-size:13.6125px;letter-spacing:5px;text-transform:uppercase;color:rgba(92,90,88,0.75);
  padding-bottom:11px;border-bottom:1px solid var(--wfts-c-stone-15);margin-bottom:20px;width:100%}
.predictor-center .fo-form.predictor-location-row .slabel{margin-bottom:0}
.field-obs-merged .fo-row,.predictor-center .fo-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.field-obs-merged .fo-row .swrap,.predictor-center .fo-row .swrap{flex:1;min-width:220px}
.field-obs-merged .fo-row .sinput,.predictor-center .fo-row .sinput{font-size:22.275px;padding:20px 52px 20px 20px;border-radius:12px}
.field-obs-merged .fo-row .swrap-with-gps .sinput,.predictor-center .fo-row .swrap-with-gps .sinput{padding:20px 22px 20px 20px;border-radius:12px 0 0 12px}
.field-obs-merged .fo-row .swrap-with-gps .predictor-loc-trailing,.predictor-center .fo-row .swrap-with-gps .predictor-loc-trailing{border-radius:0 12px 12px 0}
.field-obs-merged .fo-row .swrap-with-gps .sbtn,.predictor-center .fo-row .swrap-with-gps .sbtn{padding:0 18px;min-width:52px;font-size:27.225px}
.field-obs-merged .fo-row .a-layer-row,.predictor-center .fo-row .a-layer-row{font-size:13.6125px;padding:10px 14px;flex-shrink:0;margin:0}
.field-obs-merged .selloc,.predictor-center .selloc{width:100%;margin-bottom:18px;font-size:18.5625px}
.field-obs-merged .predictor-primary-actions,.predictor-center .predictor-primary-actions{margin-top:0;width:100%;display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;align-items:stretch}
.field-obs-merged .predictor-primary-actions .fetchbtn,.predictor-center .predictor-primary-actions .fetchbtn{
  flex:1 1 calc(50% - 6px);min-width:0;margin-top:0;min-height:56px;padding:clamp(16px,3.5vw,22px) clamp(12px,3vw,20px);
  font-size:clamp(12.5px,1.1rem + 0.35vw,16.0875px);
  letter-spacing:clamp(0.06em,0.04em + 0.25vw,0.14em)}
.field-obs-merged .sresults,.predictor-center .sresults{width:100%;order:unset;margin-top:14px}
.field-obs-merged .sbox,.predictor-center .sbox{width:100%;margin-top:14px}
.field-obs-merged .sbtn,.predictor-center .sbtn{font-size:27.225px}
/* Countdown card — outer float (water drift). 0%/100% keyframes = rest pose: vertically centered in layout above */
.predictor-countdown-float{width:100%;max-width:min(100%,640px);margin:0 auto;transform-origin:center center;
  animation:pccDriftX 44s ease-in-out infinite}
.predictor-countdown-float-inner{transform-origin:center center;
  animation:pccDriftY 34s ease-in-out infinite reverse}
@keyframes pccDriftX{
  0%,100%{transform:translate3d(0,0,0)}
  14%{transform:translate3d(5px,-2px,0)}
  31%{transform:translate3d(-4px,3px,0)}
  48%{transform:translate3d(-3px,-4px,0)}
  64%{transform:translate3d(4px,2px,0)}
  81%{transform:translate3d(2px,-3px,0)}}
@keyframes pccDriftY{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  18%{transform:translate3d(0,-6px,0) rotate(0.1deg)}
  36%{transform:translate3d(0,5px,0) rotate(-0.08deg)}
  55%{transform:translate3d(0,3px,0) rotate(0.06deg)}
  74%{transform:translate3d(0,-4px,0) rotate(-0.05deg)}
  90%{transform:translate3d(0,2px,0) rotate(0.04deg)}}
.predictor-countdown-card{position:relative;width:100%;max-width:min(680px,92vw);margin:0 auto;padding:clamp(18px,3.2vw,26px) clamp(18px,3.2vw,24px) clamp(20px,2.8vw,24px);box-sizing:border-box;
  border:none;border-radius:0;background:transparent;box-shadow:none;
  transform-origin:center center;
  isolation:isolate;
  transition:padding 0.48s cubic-bezier(0.22,1,0.36,1)}
@supports (interpolate-size:allow-keywords){
  :root{interpolate-size:allow-keywords}
  .predictor-countdown-card{transition:padding 0.48s cubic-bezier(0.22,1,0.36,1),block-size 0.48s cubic-bezier(0.22,1,0.36,1)}
}
.predictor-countdown-card > *{position:relative;z-index:1}
.predictor-countdown-card > .pcc-boot-seq{z-index:0}
.predictor-countdown-card > .pcc-boot-copy{z-index:2}
/* Boot sequence stage: fixed square rail — img scale/intrinsic changes never shift poem/title */
.predictor-countdown-card .pcc-boot-seq{
  position:relative;z-index:0;display:flex;align-items:center;justify-content:center;
  width:100%;height:clamp(86px,24vw,112px);min-height:clamp(86px,24vw,112px);
  margin:0 auto 14px;flex-shrink:0}
.predictor-countdown-card .pcc-boot-copy{
  position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;width:100%}
.boot-skip-btn{
  margin-top:8px;
  font-family:'IBM Plex Mono',monospace;
  font-size:10.89px;
  letter-spacing:0.8px;
  color:rgba(252,236,200,0.9);
  background:rgba(14,13,10,0.62);
  border:1px solid rgba(212,168,90,0.42);
  border-radius:999px;
  padding:6px 12px;
  cursor:pointer;
  opacity:0.38;
  transition:opacity 0.7s ease-in-out,background .15s ease,border-color .15s ease,color .15s ease;
}
.boot-skip-btn:hover,
.boot-skip-btn:focus-visible{
  opacity:1;
}
.boot-skip-btn:hover{
  background:rgba(212,136,58,0.16);
  border-color:rgba(240,185,95,0.66);
}
html.wfts-boot-done .boot-skip-btn,
body.loaded .boot-skip-btn{display:none!important}
/* After boot: keep final boot frame (e.g. 31.webp) visually — no idle pccLogoNoise on the wrap; hover / call JS unchanged */
body.loaded .predictor-countdown-card .pcc-boot-seq .pcc-logo-wrap{
  animation:none;
}
/* Logo + loading seq: fixed square rail so every frame matches final logo (centered, same slot) */
.predictor-countdown-card .pcc-boot-seq .pcc-logo-wrap{margin:0}
.predictor-countdown-card .pcc-logo-wrap{
  display:flex;align-items:center;justify-content:center;
  width:clamp(86px,24vw,112px);max-width:100%;aspect-ratio:1;height:auto;min-width:0;min-height:0;
  margin:0 auto 14px;cursor:pointer;
  animation:pccLogoNoise 36s ease-in-out infinite}
/* Shared transform target: peeper image scales & moves with hover/call */
.predictor-countdown-card .pcc-logo-motion{
  position:relative;display:block;width:100%;aspect-ratio:1;max-height:100%;
  flex:1 1 auto;min-width:0;min-height:0;
  transform-origin:center center;will-change:transform;
  transition:transform 0.55s cubic-bezier(0.22,1,0.36,1)}
/* 30× silhouette lace overlay (stroke trace driven by js/app.js + .pcc-30x-tracing) */
.predictor-countdown-card .pcc-logo-30x{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;overflow:visible;
  filter:blur(var(--pcc-30x-blur,0px));
  opacity:0;
  transition:opacity 0.28s ease,filter 0.1s linear}
.predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--30x-mouse .pcc-logo-30x,
.predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo-30x{
  opacity:1}
.predictor-countdown-card .pcc-logo-30x-path--lace{
  fill:none;
  stroke:rgba(255,220,165,0.9);
  stroke-linecap:round;stroke-linejoin:round;
  stroke-width:var(--pcc-30x-trace-stroke,1.1);
  stroke-dasharray:var(--pcc-30x-dash,none);
  stroke-dashoffset:var(--pcc-30x-trace-len,0);
  opacity:0}
.predictor-countdown-card .pcc-logo-30x-path--lace.pcc-30x-tracing{
  opacity:1;
  animation:pcc30xLaceTrace var(--pcc-30x-trace-dur,1s) var(--pcc-30x-trace-ease,ease-out) forwards}
@keyframes pcc30xLaceTrace{
  from{stroke-dashoffset:var(--pcc-30x-trace-len)}
  to{stroke-dashoffset:0}}
@media (prefers-reduced-motion:reduce){
  .predictor-countdown-card .pcc-logo-30x-path--lace.pcc-30x-tracing{
    animation:none;stroke-dashoffset:0;opacity:0.22}}
/* Forecast hero: peeper portrait — idle = soft depth only; warm glow on :hover (mouse) */
.predictor-countdown-card .pcc-logo{
  display:block;flex-shrink:0;box-sizing:border-box;
  width:100%;height:100%;max-width:100%;max-height:100%;margin:0;
  object-fit:contain;object-position:center center;
  mix-blend-mode:normal;opacity:1;
  transform-origin:center center;
  animation:none;
  filter:drop-shadow(0 5px 14px rgba(0,0,0,0.38));
  transition:filter 0.45s ease,opacity 0.45s ease}
@media (prefers-reduced-motion:reduce){
  .predictor-countdown-card .pcc-logo{
    filter:drop-shadow(0 5px 14px rgba(0,0,0,0.38))}}
body:not(.loaded) .predictor-countdown-card .pcc-logo-wrap{
  animation:none;
  transition:transform 1.15s cubic-bezier(0.25,0.85,0.3,1);
  transform-origin:center center;will-change:transform}
/* Hover / focus scale + peeper call: only after load or on final boot frame (31) — not frames 1…30 */
body.loaded .predictor-countdown-card .pcc-logo-wrap:hover .pcc-logo-motion,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap:hover .pcc-logo-motion,
body.loaded .predictor-countdown-card .pcc-logo-wrap:focus-visible .pcc-logo-motion,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap:focus-visible .pcc-logo-motion,
body.loaded .predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--hovering .pcc-logo-motion,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap.pcc-logo-wrap--hovering .pcc-logo-motion,
body.loaded .predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo-motion,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo-motion{
  transform:scale(1.16) translate3d(var(--pcc-shake-x,0px),var(--pcc-shake-y,0px),0) rotate(var(--pcc-shake-r,0deg))}
body.loaded .predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--hovering:not(:hover):not(:focus-visible) .pcc-logo,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap.pcc-logo-wrap--hovering:not(:hover):not(:focus-visible) .pcc-logo{
  animation:none;
  filter:drop-shadow(0 5px 14px rgba(0,0,0,0.38))}
body.loaded .predictor-countdown-card .pcc-logo-wrap:focus-visible:not(:hover) .pcc-logo,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap:focus-visible:not(:hover) .pcc-logo{
  animation:none;
  filter:
    blur(var(--pcc-call-blur,0px))
    drop-shadow(0 0 6px rgba(248,210,150,0.32))
    drop-shadow(0 5px 14px rgba(0,0,0,0.36))}
body.loaded .predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active:not(:hover) .pcc-logo,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active:not(:hover) .pcc-logo{
  animation:none;
  filter:
    blur(var(--pcc-call-blur,0px))
    drop-shadow(0 5px 14px rgba(0,0,0,0.36))}
body.loaded .predictor-countdown-card .pcc-logo-wrap:hover .pcc-logo,
body.loaded .predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active:hover .pcc-logo{
  animation:none;
  filter:
    blur(var(--pcc-call-blur,0px))
    drop-shadow(0 0 8px rgba(248,210,150,0.42))
    drop-shadow(0 0 18px rgba(212,168,90,0.26))
    drop-shadow(0 6px 16px rgba(0,0,0,0.34))}
/* Boot-final (last loading frame): no warm glow behind the hover image */
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap:hover .pcc-logo,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active:hover .pcc-logo{
  animation:none;
  filter:
    blur(var(--pcc-call-blur,0px))
    drop-shadow(0 5px 14px rgba(0,0,0,0.38))}
body.loaded .predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--hovering:not(.pcc-logo-wrap--pcc-call-active) .pcc-logo-motion,
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-boot-seq.pcc-boot-seq--at-final .pcc-logo-wrap.pcc-logo-wrap--hovering:not(.pcc-logo-wrap--pcc-call-active) .pcc-logo-motion{
  animation:pccLogoHoverWobble 2.2s ease-in-out infinite;
}
@keyframes pccLogoHoverWobble{
  0%,100%{transform:scale(1.16) translate3d(0,0,0) rotate(0deg)}
  20%{transform:scale(1.168) translate3d(1px,-0.8px,0) rotate(0.25deg)}
  40%{transform:scale(1.16) translate3d(-1.1px,0.9px,0) rotate(-0.22deg)}
  60%{transform:scale(1.178) translate3d(0.8px,1px,0) rotate(0.2deg)}
  80%{transform:scale(1.168) translate3d(-0.9px,-0.7px,0) rotate(-0.18deg)}
}
.predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active{animation:none}
.predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo-motion{
  transition:transform 0.08s linear}
.predictor-countdown-card .pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo{
  transition:opacity 0.45s ease,filter 0.45s ease}
@keyframes pccLogoNoise{
  0%,100%{transform:translate3d(0,0,0)}
  9%{transform:translate3d(3px,-2px,0)}
  19%{transform:translate3d(-2px,2px,0)}
  31%{transform:translate3d(-4px,-1px,0)}
  44%{transform:translate3d(2px,3px,0)}
  56%{transform:translate3d(4px,1px,0)}
  68%{transform:translate3d(-3px,-3px,0)}
  81%{transform:translate3d(1px,2px,0)}
  92%{transform:translate3d(-2px,0,0)}}
body:not(.loaded) .predictor-countdown-card .pcc-entrance:not(.pcc-boot-hero){opacity:0}
body:not(.loaded) .predictor-countdown-card .pcc-boot-hero{opacity:1}
body.loaded .predictor-countdown-card .pcc-entrance{
  animation:pccEntranceIn 1.22s cubic-bezier(0.22,0.99,0.36,1) forwards;
  animation-delay:calc(0.32s + var(--pcc-e,0) * 0.14s)}
body.loaded .predictor-countdown-card .pcc-boot-hero{
  animation:none;
  opacity:1;
  transform:none}
@keyframes pccEntranceIn{
  from{opacity:0;transform:translate3d(0,14px,0)}
  100%{opacity:1;transform:translate3d(0,0,0)}}
/* Card shell + frog logo visible during load; inner .pcc-entrance fades in after body.loaded */
body:not(.loaded) #predictor-countdown-card{opacity:1;visibility:visible;pointer-events:auto}
body.loaded #predictor-countdown-card{pointer-events:auto}
html.wfts-boot-skip-now body.loaded .predictor-countdown-card .pcc-entrance{
  animation:none!important;
  animation-delay:0s!important;
  opacity:1!important;
  transform:none!important;
}
/* Boot: opacity-0 .pcc-entrance still took layout space — collapse so logo/poem/title sit at viewport vertical center */
html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-entrance:not(.pcc-boot-hero){
  max-height:0;
  min-height:0;
  margin-top:0;
  margin-bottom:0;
  padding-top:0;
  padding-bottom:0;
  overflow:hidden;
  border-width:0;
  pointer-events:none}
html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card .predictor-primary-actions,
html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card #predictor-loc-reset,
html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card #sbox{
  max-height:0;
  min-height:0;
  margin-top:0;
  margin-bottom:0;
  padding-top:0;
  padding-bottom:0;
  overflow:hidden;
  opacity:0;
  pointer-events:none;
  border-width:0}
@media (prefers-reduced-motion:reduce){
  .predictor-countdown-float,.predictor-countdown-float-inner{animation:none}
  .predictor-countdown-card{animation:none;transition:none}
  body:not(.loaded) .predictor-countdown-card .pcc-entrance:not(.pcc-boot-hero){opacity:1}
  body.loaded .predictor-countdown-card .pcc-entrance{animation:none}
  .predictor-countdown-card .pcc-logo-wrap{animation:none}
  html.wfts-boot-loading .predictor-countdown-card .pcc-title-brand.wave-words span,
  html.wfts-boot-hold .predictor-countdown-card .pcc-title-brand.wave-words span{animation:none;opacity:0.88}
  body.loaded .predictor-countdown-card .pcc-title-brand{animation:none!important}
  html.wfts-boot-loading body:not(.loaded) .predictor-countdown-card .pcc-entrance:not(.pcc-boot-hero){
    max-height:none;
    min-height:0;
    margin-top:revert;
    margin-bottom:revert;
    padding-top:revert;
    padding-bottom:revert;
    overflow:visible;
    border-width:revert;
    pointer-events:none}
  html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card .predictor-primary-actions,
  html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card #predictor-loc-reset,
  html.wfts-boot-loading body:not(.loaded) #predictor-countdown-card #sbox{
    max-height:none;
    min-height:0;
    margin-top:revert;
    margin-bottom:revert;
    padding-top:revert;
    padding-bottom:revert;
    overflow:visible;
    opacity:revert;
    border-width:revert}
}
.predictor-countdown-card .pcc-corner{display:none}
.predictor-countdown-card .pcc-countdown-block{width:100%}
.predictor-countdown-card .pcc-lbl{font-family:'IBM Plex Mono',monospace;font-size:9.9px;letter-spacing:0.22em;color:var(--wfts-c-mute-50);text-align:center;text-transform:uppercase;margin-top:4px}
.predictor-countdown-card #countdown-val{font-family:'Playfair Display',serif;font-size:clamp(24.75px, 5.1975vw, 34.65px);font-weight:400;color:rgba(232,224,204,0.92);text-align:center;margin:12px 0 6px;line-height:1.12;letter-spacing:-0.02em}
.predictor-countdown-card #countdown-val.countdown-season{font-size:clamp(21.0375px, 4.3312vw, 25.9875px);color:rgba(126,196,140,0.95)}
.predictor-countdown-card .pcc-live-astro{font-family:'IBM Plex Mono',monospace;font-size:clamp(11.1375px, 2.1656vw, 13.6125px);font-weight:400;color:rgba(154,148,136,0.88);margin:3px auto 4px;line-height:1.28;max-width:min(22em,94%);letter-spacing:0.02em}
.predictor-countdown-card .pcc-live-astro .pcc-astro-inner{display:flex;flex-direction:column;align-items:stretch;gap:5px;width:100%}
.predictor-countdown-card .pcc-live-astro .pcc-dt{
  display:block;margin:0;font-variant-numeric:tabular-nums;font-size:clamp(10.5187px, 2.0419vw, 12.9938px);letter-spacing:0.04em;
  color:rgba(168,162,148,0.85);text-align:center;line-height:1.25;padding:0 2px 4px;border-bottom:1px solid rgba(92,90,88,0.1);
  width:100%;box-sizing:border-box}
.predictor-countdown-card .pcc-live-astro .pcc-moon-compact{
  display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;width:100%;color:rgba(210,198,168,0.95)}
.predictor-countdown-card .pcc-live-astro .pcc-moon-text{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0;text-align:left}
.predictor-countdown-card .pcc-live-astro .pcc-moon-primary{
  font-family:'IBM Plex Mono',monospace;font-size:7.425px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;
  line-height:1.35;color:rgba(138,136,132,0.48)}
.predictor-countdown-card .pcc-live-astro .pcc-moon-tag{
  margin-right:4px}
.mobile-advisory{
  position:fixed;
  right:14px;
  bottom:14px;
  z-index:1200;
  display:flex;
  align-items:center;
  gap:8px;
  max-width:min(560px,calc(100vw - 28px));
  background:rgba(14,13,10,0.9);
  border:1px solid rgba(212,168,90,0.42);
  border-radius:10px;
  padding:10px 12px;
  color:rgba(252,236,200,0.95);
  box-shadow:0 6px 20px rgba(0,0,0,0.45);
  backdrop-filter:blur(8px);
}
.mobile-advisory[hidden]{display:none!important}
.mobile-advisory-text{
  font-family:'IBM Plex Mono',monospace;
  font-size:10.89px;
  line-height:1.45;
}
.mobile-advisory-close{
  flex:0 0 auto;
  font-family:'IBM Plex Mono',monospace;
  font-size:10.4px;
  color:rgba(252,236,200,0.95);
  background:rgba(212,136,58,0.16);
  border:1px solid rgba(212,168,90,0.45);
  border-radius:999px;
  padding:4px 10px;
  cursor:pointer;
}
.predictor-countdown-card .pcc-live-astro .pcc-moon-graphic{flex-shrink:0;width:clamp(22px,5.5vw,28px);height:clamp(22px,5.5vw,28px);display:flex;align-items:center;justify-content:center}
.predictor-countdown-card .pcc-live-astro .pcc-moon-graphic .pcc-moon-svg{display:block;width:100%;height:100%}
.predictor-countdown-card .pcc-live-astro .pcc-solar-line{
  font-size:clamp(9.9px, 1.8562vw, 11.7562px);letter-spacing:0.04em;color:rgba(138,136,132,0.82);line-height:1.25;max-width:100%}
.predictor-countdown-card .pcc-live-astro .pcc-solar-line.pcc-solar-line--today{color:rgba(212,168,90,0.88);font-weight:500}
.predictor-countdown-card .pcc-foot{font-family:'IBM Plex Mono',monospace;font-size:7.425px;color:rgba(92,90,88,0.4);text-align:center;letter-spacing:0.1em;text-transform:uppercase;margin:0;padding:0;line-height:1.35}
#panel-predictor .empty{margin:0;padding:0;justify-content:center}
#panel-predictor .empty-inner{padding:0;max-width:100%;margin:0 auto;background:transparent;border:none}
/* Location stack: one calm card */
#panel-predictor .predictor-countdown-card .predictor-location-stack .sinput{
  border-radius:14px;border-color:var(--wfts-c-stone-22);
  background:rgba(12,11,10,0.45);font-size:21.0375px}

/* Input panel — HUD instrument panel (legacy; location now in predictor-center) */
.sidebar{border-right:1px solid var(--wfts-c-stone-20);padding:26px 22px;position:sticky;top:0;
  height:calc(100vh - 120px);overflow-y:auto;display:flex;flex-direction:column;gap:18px;
  background:linear-gradient(180deg,rgba(28,27,26,0.25) 0%,transparent 40%)}
.slabel{font-size:9.9px;letter-spacing:4px;text-transform:uppercase;color:#5c5a58;
  padding-bottom:8px;border-bottom:1px solid var(--wfts-c-stone-20)}

/* Search — HUD input */
.swrap{position:relative}
.sinput{background:rgba(28,27,26,0.45);border:1px solid var(--wfts-c-stone-25);border-radius:10px;
  color:var(--text);font-family:'IBM Plex Mono',monospace;font-size:19.8px;
  padding:16px 48px 16px 18px;width:100%;outline:none;transition:border-color .2s,box-shadow .2s}
.sinput:focus{border-color:var(--wfts-c-mute-50);box-shadow:0 0 0 3px var(--wfts-c-stone-15)}
.sinput::placeholder{color:rgba(138,136,132,0.45)}
/* Location field: soft breathing caret (amber); slows default blink read as gentle fade */
@keyframes linputCaretBreath{
  0%,100%{caret-color:var(--wfts-c-amberdeep-12);}
  50%{caret-color:rgba(240,185,95,0.92);}
}
#linput{
  caret-color:var(--wfts-c-amberdeep-45);
}
#linput:focus{
  animation:linputCaretBreath 3.6s ease-in-out infinite;
  caret-animation:manual;
}
@supports not (caret-animation:manual){
  #linput:focus{animation:linputCaretBreath 3.6s ease-in-out infinite;}
}
/* Location entry: pulse amber until a location is entered (class removed in pickLoc / when selloc shown) */
@keyframes linputAmberPulse{
  0%,100%{border-color:var(--wfts-c-stone-25);box-shadow:0 0 0 0 rgba(212,136,58,0);}
  50%{border-color:rgba(212,136,58,0.6);box-shadow:0 0 0 4px var(--wfts-c-amberdeep-25);}
}
.predictor-location-row.loc-pulse #linput{
  animation:linputAmberPulse 7.8s ease-in-out infinite;
}
.predictor-location-row.loc-pulse #linput:focus{
  animation:linputCaretBreath 3.6s ease-in-out infinite,linputAmberPulse 7.8s ease-in-out infinite;
}
.sbtn{position:absolute;right:0;top:0;bottom:0;background:none;border:none;
  padding:0 12px;color:var(--amber);cursor:pointer;font-size:18.5625px;transition:color .15s}
.sbtn:hover{color:var(--amber2)}
.sresults{display:none;background:var(--surface2);border:1px solid var(--border2);
  border-radius:6px;margin-top:4px;overflow:hidden;max-height:190px;overflow-y:auto}
.sresult{padding:12px 16px;font-size:16.0875px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.sresult:last-child{border-bottom:none}
.sresult:hover{background:var(--surface3)}
.sresult .rname{color:var(--text);font-weight:500}
.sresult .rdetail{color:var(--muted);font-size:14.85px;margin-top:2px}
.selloc{display:none;padding:14px 18px;background:rgba(36,35,34,0.45);
  border:1px solid rgba(92,90,88,0.28);border-radius:10px;font-size:16.0875px}
.selloc .lname{color:var(--green2);font-weight:500;letter-spacing:0.3px;line-height:1.3}
.selloc .lcoords{color:var(--muted);font-size:12.375px;margin-top:1px;letter-spacing:0.2px;line-height:1.3}
.selloc .lchange{float:right;color:var(--amber);cursor:pointer;font-size:12.375px;text-decoration:none;letter-spacing:0.5px}
.selloc .lchange:hover{text-decoration:underline}

/* Buttons — field instrument (glass: blur behind; no rim) */
.fetchbtn{width:100%;background:rgba(16,14,12,0.42);border:none;border-radius:12px;color:#c8c4b8;
  font-family:'IBM Plex Mono',monospace;
  font-size:16.0875px;font-weight:500;letter-spacing:3.5px;text-transform:uppercase;
  padding:20px 24px;cursor:pointer;transition:background .22s ease,transform .25s ease,filter .22s ease,box-shadow .22s ease,opacity .2s ease;
  box-shadow:none;
  backdrop-filter:blur(14px) saturate(1.15);-webkit-backdrop-filter:blur(14px) saturate(1.15)}
.fetchbtn:hover:not(:disabled){transform:translateY(-2px);background:rgba(24,20,16,0.52);box-shadow:none}
.fetchbtn:disabled{opacity:.35;cursor:not-allowed;transform:none}
@keyframes fetchbtnAmberPulse{
  0%,100%{box-shadow:none;filter:none}
  20%{box-shadow:0 0 22px rgba(212,136,58,0.38);filter:brightness(1.1)}
  45%{box-shadow:0 0 32px rgba(212,136,58,0.22);filter:brightness(1.06)}
  70%{box-shadow:0 0 18px rgba(240,185,95,0.28);filter:brightness(1.05)}
}
.fetchbtn.fetchbtn-pulse-ready:not(:disabled){
  animation:fetchbtnAmberPulse 2.1s ease-in-out 1;
}
@keyframes wftsForecastCtaGlowPulse{
  0%,100%{opacity:1;filter:brightness(1);
    box-shadow:0 0 14px rgba(212,136,58,0.28),0 0 28px rgba(180,110,45,0.12)}
  50%{opacity:0.86;filter:brightness(1.05);
    box-shadow:0 0 26px rgba(240,170,95,0.48),0 0 44px rgba(200,120,55,0.22)}}
#panel-predictor .fetchbtn.wfts-forecast-cta-glow:not(:disabled){
  animation:wftsForecastCtaGlowPulse 4s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){
  #panel-predictor .fetchbtn.wfts-forecast-cta-glow:not(:disabled){
    animation:none;
    opacity:1;
    box-shadow:0 0 12px rgba(212,136,58,0.22)}}

/* Status */
.sbox{padding:14px 18px;border-radius:8px;font-size:16.0875px;line-height:1.65;display:none}
.sbox.loading{background:var(--surface2);border:1px solid var(--border2);color:var(--muted);display:block}
.sbox.error{background:rgba(192,96,80,.1);border:1px solid rgba(192,96,80,.3);color:#e08070;display:block}
.spinner{display:inline-block;width:10px;height:10px;border:1.5px solid var(--faint);
  border-top-color:var(--amber);border-radius:50%;animation:spin .8s linear infinite;
  margin-right:5px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

.predictor-center .notebox{flex-shrink:0}
/* Predictor page: no background boxes */
#panel-predictor .notebox{background:transparent;border:none}
#panel-predictor .selloc{background:transparent;border:none;box-shadow:none;border-radius:0;
  padding:14px 20px;margin-bottom:4px;max-width:100%;width:100%}
#panel-predictor .selloc-head{display:flex;align-items:center;justify-content:flex-start;flex-wrap:wrap;gap:10px;margin-bottom:6px}
#panel-predictor .selloc-label{font-size:9.9px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(212,168,90,0.65);font-weight:500}
#panel-predictor .selloc .lname{font-family:'Playfair Display',serif;font-size:clamp(19.8px, 2.97vw, 23.5125px);font-weight:400;color:var(--wfts-c-text-95)}
@keyframes wftsLnameGlowPulse{
  0%,100%{opacity:1;filter:brightness(1);
    text-shadow:0 0 10px rgba(110,190,130,0.42),0 0 22px rgba(70,160,100,0.22)}
  50%{opacity:0.88;filter:brightness(1.06);
    text-shadow:0 0 18px rgba(130,215,150,0.62),0 0 36px rgba(90,185,120,0.38)}}
#panel-predictor .selloc .lname.wfts-lname-glow{
  animation:wftsLnameGlowPulse 4.2s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){
  #panel-predictor .selloc .lname.wfts-lname-glow{
    animation:none;
    opacity:1;
    text-shadow:0 0 8px rgba(110,190,130,0.35),0 0 16px rgba(70,160,100,0.18)}}
#panel-predictor .selloc .lcoords{font-size:12.375px;letter-spacing:0.04em;margin-top:4px}
#panel-predictor .selloc .lchange{display:none}
#panel-predictor .tbox{
  background:transparent;border:none;box-shadow:none;border-radius:0;
  padding:clamp(14px,2vw,22px) clamp(22px,3vw,30px) clamp(20px,2.8vw,28px);
  overflow:visible}
@keyframes wftsForecastPanelGlowPulse{
  0%,100%{opacity:1;filter:brightness(1);
    box-shadow:0 0 18px rgba(212,130,55,0.18),0 0 36px rgba(160,90,40,0.08)}
  50%{opacity:0.9;filter:brightness(1.04);
    box-shadow:0 0 32px rgba(235,165,85,0.38),0 0 52px rgba(190,110,50,0.16)}}
#panel-predictor #rcontent .tbox.wfts-forecast-panel-glow{
  animation:wftsForecastPanelGlowPulse 4.5s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){
  #panel-predictor #rcontent .tbox.wfts-forecast-panel-glow{
    animation:none;
    opacity:1;
    box-shadow:0 0 16px rgba(212,130,55,0.2)}}
#panel-predictor .tbox::after{display:none}
#panel-predictor .tbox-eyebrow-row{
  display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:10px 16px;
  margin-bottom:14px}
#panel-predictor .tbox-eyebrow-row .teyebrow{margin-bottom:0;flex:1;min-width:min(100%,220px)}
#panel-predictor .teyebrow{margin-bottom:14px}
#panel-predictor .teyebrow::before{display:none}
#panel-predictor .teyebrow-lead-dot{
  font-size:9.9px;flex-shrink:0;margin:0.35em 4px 0 0;opacity:0.75;line-height:1;color:var(--wfts-c-mute-88)}
#panel-predictor .teyebrow-main{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 10px;line-height:1.5}
#panel-predictor .banner.season,#panel-predictor .banner.location{
  background:transparent;border:none;box-shadow:none;border-radius:0;backdrop-filter:none;-webkit-backdrop-filter:none}
/* Forecast strip: no card chrome — color + scale only for state */
#rcontent .wday{
  background:transparent;border:none;border-radius:0;box-shadow:none}
#rcontent .wday.today{background:transparent}
#rcontent .wday.hotn{
  background:transparent;border:none;box-shadow:none;animation:none}
#rcontent .wday.hotn .dlabel{color:rgba(212,168,90,0.88)}
#rcontent .wday.hotn:hover,
#rcontent .wday.hotn.hover-day,
#rcontent .wday.hotn.selected-day{
  background:transparent;border:none;box-shadow:none;transform:scale(1.06);transform-origin:center top;animation:none}
#rcontent .wday.today.hotn{background:transparent}
/* Species outlook cards: neutral frosted glass, low tint, no chroma wash / species color bar */
#rcontent .scard{
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  isolation:auto}
#rcontent .scard::after{display:none}
#rcontent .scard > *{position:relative;z-index:auto}
#rcontent .scard .topbar{display:none!important}
#rcontent .scard:hover{
  border:none;
  transform:none;
  box-shadow:none}
#panel-predictor #rcontent .sprob-box{
  background:transparent;
  border:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  box-shadow:none}
/* Species outlook — two equal columns; height follows content so footer/attr isn’t below empty scroll */
#panel-predictor #rcontent .rcontent-outlook-main{
  flex:0 1 auto;
  display:flex;
  flex-direction:column;
  min-height:0;
  width:100%;
  margin-bottom:clamp(18px,2.5vw,26px)}
#panel-predictor #rcontent .sgrid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  grid-auto-rows:auto;
  flex:0 1 auto;
  gap:clamp(10px,1.6vw,14px);
  margin-bottom:22px;
  align-content:start}
#panel-predictor #rcontent .scard{
  padding:clamp(10px,1.4vw,14px) clamp(12px,1.8vw,16px);
  border-radius:0;
  min-height:0;
  height:auto;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
  overflow:auto}
#panel-predictor #rcontent .scard .scard-row{
  display:flex;
  flex-direction:row;
  align-items:stretch;
  gap:clamp(10px,1.6vw,14px);
  flex:1 1 auto;
  min-height:0;
  min-width:0}
#panel-predictor #rcontent .scard .scard-main{
  flex:1 1 auto;
  min-width:0;
  min-height:0;
  display:flex;
  flex-direction:column}
#panel-predictor #rcontent .scard .scard-main .sinfo{margin-top:auto}
#panel-predictor #rcontent .sphoto-wrap{
  width:48px;height:48px;margin:0;border-radius:8px;overflow:visible;
  background:transparent;border:none;flex-shrink:0;align-self:center;
  position:relative;z-index:2}
#panel-predictor #rcontent .sphoto{
  display:block;width:100%;height:100%;object-fit:contain;
  transform:translateY(-4px) scale(1.18);
  transform-origin:center bottom}
#panel-predictor #rcontent .sname{font-size:17.325px}
#panel-predictor #rcontent .slatin{font-size:12.375px;margin-bottom:7px}
#panel-predictor #rcontent .sprob-main{gap:6px;margin-bottom:5px}
#panel-predictor #rcontent .sprob-num{
  font-size:29.7px;
  color:rgba(240,168,74,0.95);
  font-weight:600}
#panel-predictor #rcontent .forecast-pct{color:rgba(240,168,74,0.95);font-weight:600}
#panel-predictor #rcontent .sprob-desc{font-size:11.1375px;letter-spacing:1px;max-width:11em;line-height:1.3}
#panel-predictor #rcontent .sprob-wx{font-size:12.375px;line-height:1.4;margin-bottom:4px}
#panel-predictor #rcontent .sprob-note{font-size:11.1375px;line-height:1.4}
#panel-predictor #rcontent .sprob-box{margin:0 0 6px;padding:0 0 6px}
#panel-predictor #rcontent .sstatus{margin-bottom:6px;gap:6px}
#panel-predictor #rcontent .sstatustxt{font-size:13.6125px}
#panel-predictor #rcontent .sinfo{font-size:13.6125px;line-height:1.5;margin-bottom:6px}
#panel-predictor #rcontent .sdot{width:6px;height:6px}
#panel-predictor #rcontent .rcontent-outlook-block{display:flex;flex-direction:column;
  margin-top:4px;margin-bottom:clamp(18px,2.5vw,26px);
  padding:clamp(16px,2.2vw,22px) clamp(14px,2vw,20px);background:transparent;border:none;box-shadow:none;border-radius:0}
#panel-predictor #rcontent .rcontent-outlook-headrow{margin:0 0 16px;padding-bottom:14px;border-bottom:none}
#panel-predictor #rcontent .rcontent-outlook-title{font-family:'Playfair Display',serif;font-size:clamp(21.0375px, 2.7225vw, 25.9875px);font-weight:400;
  color:var(--wfts-c-text-95);margin:0 0 6px;letter-spacing:0.02em;line-height:1.25}
#panel-predictor #rcontent .rcontent-outlook-sub{font-size:12.375px;color:var(--wfts-c-mute-78);line-height:1.5;margin:0;letter-spacing:0.06em;max-width:48em}
#panel-predictor #rcontent .rcontent-forecast-wx{font-size:13.6125px;color:rgba(200,192,172,0.88);line-height:1.55;margin:0 0 18px;padding:0 0 4px;
  background:transparent;border:none;border-radius:0;box-shadow:none}
#panel-predictor #rcontent .rcontent-model-note{font-size:11.1375px;color:rgba(138,136,132,0.62);line-height:1.5;margin:14px 0 0;padding:0 6px;text-align:center;letter-spacing:0.04em;max-width:52em;margin-left:auto;margin-right:auto}
#panel-predictor #rcontent .attr{margin-top:26px;padding-top:12px;border-top:none;background:transparent;
  scroll-margin-bottom:var(--wfts-footer-reserve)}
/* Species cards only (per-species “first ≥50% night” list removed) */
#panel-predictor #rcontent .rcontent-outlook-main .sgrid{margin-bottom:0}
/* 14-day forecast strip: no visible scrollbars (hover scale still scrolls via trackpad/touch) */
#panel-predictor #rcontent .wstrip{
  scrollbar-width:none;
  -ms-overflow-style:none;
  /* Extra top room: frog-night row + scale(1.06) must not clip spring peeper under overflow */
  padding:10px 0 12px;
  overflow-x:auto}
#panel-predictor #rcontent .wstrip::-webkit-scrollbar{display:none;width:0;height:0}
#panel-predictor .results{overflow-x:hidden}
/* Field Guide: no background boxes on cards, stage slots, or audio */
#panel-guide .fg-card-v2,#panel-guide .fg-card,#panel-guide .fg-stage-img,#panel-guide .fg-audio{background:transparent;border:none;box-shadow:none}
.notebox{padding:18px 20px;background:rgba(28,27,26,0.3);border:1px solid var(--wfts-c-stone-18);
  border-radius:12px;font-size:14.85px;color:var(--muted);line-height:1.8;letter-spacing:0.2px}
.notebox a{color:#8a8884;text-decoration:none;transition:color .15s}
.notebox a:hover{color:var(--cream)}
.notebox strong{color:rgba(138,136,132,0.95);font-weight:500}

/* Results */
#panel-predictor .results{padding:clamp(24px,3vw,40px) max(20px,3.5vw) clamp(40px,5vw,64px);overflow-y:auto;box-sizing:border-box;width:100%;max-width:min(1920px,98vw);margin:0 auto;
  scroll-padding-bottom:var(--wfts-footer-reserve)}
/* Empty state: fill viewport column; forecast card stays vertically centered until Fetch is clicked */
#panel-predictor .results.predictor-empty-layout{
  display:flex;flex-direction:column;
  min-height:calc(100svh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve) - 6px);
  min-height:calc(100dvh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve) - 6px);
  padding:clamp(16px,3vw,32px) max(16px,3.5vw)}
/* No scroll (main or #results) until user clicks “Fetch Weather & Predict” */
#panel-predictor .results.predictor-empty-layout:not(.predictor-fetch-unlocked){
  overflow-y:hidden;
  overscroll-behavior:none}
html.wfts-boot-done:has(#panel-predictor.active #results.predictor-empty-layout:not(.predictor-fetch-unlocked)),
html.wfts-boot-done:has(#panel-predictor.active #results.predictor-empty-layout:not(.predictor-fetch-unlocked)) body{
  overflow:hidden;
  overscroll-behavior:none}
#panel-predictor .results.predictor-empty-layout:not(.predictor-fetch-unlocked) .predictor-center{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  width:100%;
  min-height:0;
  box-sizing:border-box;
  padding:clamp(12px,2.5vw,24px) max(16px,3.5vw);
  gap:clamp(20px,3vw,32px)}
#panel-predictor .results.predictor-empty-layout.predictor-fetch-unlocked .predictor-center{
  flex:1 1 auto;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;
  min-height:0;
  box-sizing:border-box;
  padding:calc(clamp(28px,5vw,52px) + clamp(10px,2vh,28px)) max(24px,4vw) clamp(40px,6vw,72px);
  gap:clamp(32px,4vw,48px)}
/* Hero #empty is hidden — remove the countdown card’s outer padding so forecast isn’t pushed down */
#panel-predictor .results:not(.predictor-empty-layout) .predictor-center{
  padding-top:0;padding-bottom:0;gap:0;min-height:0}
#panel-predictor .results:not(.predictor-empty-layout){
  padding-top:clamp(10px,1.5vw,18px)}
/* After user has scrolled elsewhere: loading/error empty state can collapse to normal flow */
body.wfts-user-scrolled #panel-predictor .results.predictor-empty-layout.predictor-fetch-unlocked{min-height:0}
body.wfts-user-scrolled #panel-predictor .results.predictor-empty-layout.predictor-fetch-unlocked .predictor-center{
  flex:0 1 auto;justify-content:flex-start}
#panel-predictor .predictor-primary-actions{width:100%;display:flex;flex-direction:row;flex-wrap:wrap;gap:10px;align-items:stretch;box-sizing:border-box}
#panel-predictor .predictor-primary-actions .fetchbtn{
  flex:1 1 calc(50% - 5px);min-width:0;width:auto;margin:0;
  display:inline-flex;align-items:center;justify-content:center;gap:0.42em;
  white-space:nowrap;text-transform:none;
  background:rgba(22,20,18,0.25);
  border:none;
  letter-spacing:clamp(0.05em,0.03em + 0.35vw,0.16em);
  font-size:clamp(11.5px,0.2rem + 2.35vw,13.6125px);font-weight:500;
  padding:clamp(14px,2.8vw,18px) clamp(10px,2.2vw,16px);border-radius:14px;
  box-shadow:none;
  backdrop-filter:blur(22px) saturate(1.18);-webkit-backdrop-filter:blur(22px) saturate(1.18);
  transition:background .22s ease,transform .2s ease,filter .22s ease,color .2s ease,box-shadow .22s ease,backdrop-filter .22s ease,-webkit-backdrop-filter .22s ease}
#panel-predictor .predictor-primary-actions .fetchbtn .fetchbtn-glyph{
  flex-shrink:0;font-size:1.05em;line-height:1;opacity:0.92;transform:translateY(0.04em)}
#panel-predictor .predictor-primary-actions .fetchbtn .fetchbtn-text{flex-shrink:0;line-height:1.15}
/* Hero (centered empty state): slightly larger label, same no-wrap behavior */
#panel-predictor .predictor-center .predictor-primary-actions .fetchbtn{
  min-height:56px;padding:clamp(16px,3.5vw,22px) clamp(12px,3vw,20px);
  font-size:clamp(12.5px,1.1rem + 0.35vw,16.0875px);
  letter-spacing:clamp(0.055em,0.03em + 0.22vw,0.14em)}
@media (max-width:400px){
  #panel-predictor .predictor-primary-actions,.predictor-location-row .predictor-primary-actions,
  .field-obs-merged .predictor-primary-actions,.predictor-center .predictor-primary-actions{
    flex-direction:column}
  #panel-predictor .predictor-primary-actions .fetchbtn,.predictor-location-row .predictor-primary-actions .fetchbtn,
  .field-obs-merged .predictor-primary-actions .fetchbtn,.predictor-center .predictor-primary-actions .fetchbtn{
    flex:1 1 auto;width:100%;max-width:100%}
}
#panel-predictor .predictor-primary-actions .fetchbtn:hover:not(:disabled),
#panel-predictor .predictor-primary-actions .fetchbtn-find-pond:hover:not(:disabled){
  border:none;
  color:rgba(252,236,200,0.96);
  box-shadow:
    0 0 0 1px rgba(240,185,95,0.2) inset,
    0 0 28px rgba(212,168,90,0.26),
    0 4px 22px rgba(212,136,58,0.12);
  backdrop-filter:blur(26px) saturate(1.22);-webkit-backdrop-filter:blur(26px) saturate(1.22)}
#panel-predictor .predictor-primary-actions .fetchbtn:hover:not(:disabled){
  background:rgba(30,26,22,0.38)}
#panel-predictor .predictor-primary-actions .fetchbtn:active:not(:disabled){
  transform:translateY(0);
  color:var(--amber2);
  background:rgba(34,28,22,0.48);
  box-shadow:
    0 0 0 1px rgba(255,220,160,0.32) inset,
    0 0 40px rgba(240,168,74,0.45),
    0 0 56px rgba(212,168,90,0.22),
    0 2px 14px rgba(212,136,58,0.14)}
#panel-predictor .predictor-primary-actions .fetchbtn-find-pond{
  background:rgba(18,20,26,0.25);
  border:none;color:rgba(210,202,184,0.95)}
#panel-predictor .predictor-primary-actions .fetchbtn-find-pond:hover:not(:disabled){
  background:rgba(28,26,24,0.4)}
#panel-predictor .predictor-primary-actions .fetchbtn-find-pond:active:not(:disabled){
  transform:translateY(0);
  color:var(--amber2);
  background:rgba(32,28,26,0.48);
  box-shadow:
    0 0 0 1px rgba(255,220,160,0.32) inset,
    0 0 40px rgba(240,168,74,0.45),
    0 0 56px rgba(212,168,90,0.22),
    0 2px 14px rgba(212,136,58,0.14)}
/* Secondary reset — below Forecast, same width, glass blur */
#panel-predictor .predictor-loc-reset-btn{
  display:flex;align-items:center;justify-content:center;width:100%;margin-top:4px;padding:14px 18px;box-sizing:border-box;
  font-family:'IBM Plex Mono',monospace;font-size:12.375px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(200,192,172,0.82);cursor:pointer;border-radius:12px;border:none;
  background:rgba(22,20,18,0.25);
  box-shadow:none;
  backdrop-filter:blur(22px) saturate(1.18);-webkit-backdrop-filter:blur(22px) saturate(1.18);
  transition:background .22s ease,color .22s ease,transform .2s ease,box-shadow .22s ease,backdrop-filter .22s ease,-webkit-backdrop-filter .22s ease}
#panel-predictor .predictor-loc-reset-btn:hover{
  color:rgba(252,236,200,0.95);border:none;
  background:rgba(30,26,22,0.38);
  box-shadow:
    0 0 0 1px rgba(240,185,95,0.2) inset,
    0 0 26px rgba(212,168,90,0.24),
    0 4px 20px rgba(212,136,58,0.1);
  backdrop-filter:blur(26px) saturate(1.22);-webkit-backdrop-filter:blur(26px) saturate(1.22);transform:translateY(-1px)}
#panel-predictor .predictor-loc-reset-btn:active{
  transform:translateY(0);
  color:var(--amber2);
  background:rgba(34,28,22,0.48);
  box-shadow:
    0 0 0 1px rgba(255,220,160,0.3) inset,
    0 0 38px rgba(240,168,74,0.42),
    0 0 52px rgba(212,168,90,0.2)}
#panel-predictor .predictor-loc-reset-btn:focus-visible{
  outline:2px solid rgba(212,168,90,0.45);outline-offset:2px}
#panel-predictor .get-involved-cta-wrap{
  width:100%;
  display:flex;
  justify-content:center;
  margin:12px auto 0}
.get-involved-cta{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  max-width:100%;
  padding:14px 18px;
  border-radius:14px;
  text-decoration:none;
  background:rgba(22,20,18,0.25);
  border:1px solid rgba(212,168,90,0.32);
  color:rgba(252,236,200,0.95);
  font-family:'IBM Plex Mono',monospace;
  font-size:12.375px;
  font-weight:500;
  letter-spacing:0.22em;
  text-transform:uppercase;
  backdrop-filter:blur(22px) saturate(1.18);
  -webkit-backdrop-filter:blur(22px) saturate(1.18);
  box-shadow:
    0 0 0 1px rgba(212,168,90,0.10) inset,
    0 0 18px rgba(212,168,90,0.10);
  transition:background .22s ease,color .22s ease,transform .2s ease,backdrop-filter .22s ease,-webkit-backdrop-filter .22s ease,
    border-color .22s ease,box-shadow .22s ease;
  cursor:pointer;
  white-space:nowrap}
.get-involved-cta-short{
  flex-shrink:0;
  letter-spacing:0.22em;
  text-transform:uppercase}
.get-involved-cta-ext{
  display:inline-flex;
  align-items:baseline;
  overflow:hidden;
  max-width:0;
  opacity:0;
  transition:max-width .42s cubic-bezier(0.33,1,0.68,1),opacity .28s ease;
  vertical-align:baseline}
.get-involved-cta-ext-dash{
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(252,236,200,0.55)}
.get-involved-cta-ext-rest{
  letter-spacing:0.06em;
  text-transform:none;
  font-weight:450;
  color:rgba(252,236,200,0.88)}
@media (hover:hover){
  .get-involved-cta:hover .get-involved-cta-ext,
  .get-involved-cta:focus-visible .get-involved-cta-ext{
    max-width:min(42em,calc(100vw - 48px));
    opacity:1}}
@media (hover:none){
  .get-involved-cta-ext{
    max-width:none;
    opacity:1}}
@media (prefers-reduced-motion:reduce){
  .get-involved-cta-ext{transition:none}
  @media (hover:hover){
    .get-involved-cta .get-involved-cta-ext{max-width:none;opacity:1}}}
.get-involved-cta:hover{
  color:var(--wfts-c-text-95);
  background:rgba(28,24,20,0.3);
  border-color:rgba(240,185,95,0.55);
  box-shadow:
    0 0 0 1px rgba(240,185,95,0.16) inset,
    0 0 26px rgba(212,168,90,0.18);
  transform:translateY(-1px)}
.get-involved-cta:active{transform:translateY(0)}
.get-involved-cta:focus-visible{
  outline:2px solid rgba(212,168,90,0.45);
  outline-offset:2px}
.get-involved-social{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:8px 10px;
  margin:14px auto 0;
  padding:0 10px}
.get-involved-social-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(212,168,90,0.72);
  text-decoration:none;
  transition:color .22s ease,filter .22s ease,transform .2s ease}
.get-involved-social-link:hover{
  color:rgba(252,220,140,0.98);
  filter:drop-shadow(0 0 5px rgba(240,180,90,0.9)) drop-shadow(0 0 14px rgba(212,168,90,0.55)) drop-shadow(0 0 26px rgba(212,168,90,0.28));
  transform:translateY(-1px)}
.get-involved-social-link:focus{outline:none}
.get-involved-social-link:focus-visible{
  color:rgba(252,220,140,0.98);
  filter:drop-shadow(0 0 5px rgba(240,180,90,0.9)) drop-shadow(0 0 14px rgba(212,168,90,0.55));
  outline:2px solid rgba(212,168,90,0.45);
  outline-offset:4px;
  border-radius:4px}
.get-involved-social-svg{
  display:block;
  width:22px;
  height:22px}
@media (prefers-reduced-motion:reduce){
  .get-involved-social-link{transition-duration:.01ms}
  .get-involved-social-link:hover,.get-involved-social-link:focus-visible{transform:none}}
#panel-predictor .tbox-eyebrow-row .predictor-loc-reset-btn--tbox{
  width:auto;max-width:none;margin:0;flex-shrink:0;align-self:flex-start;
  padding:10px 16px;white-space:nowrap}
@media (max-width:560px){
  #panel-predictor .tbox-eyebrow-row .predictor-loc-reset-btn--tbox{width:100%;margin-top:4px}}
/* Predictor card: reset control hidden until a location is set; then slides down + fades in */
#panel-predictor #predictor-loc-reset{
  transition:max-height .45s cubic-bezier(0.33,1,0.68,1),opacity .4s ease,transform .45s cubic-bezier(0.33,1,0.68,1),
    margin-top .45s ease,padding-top .45s ease,padding-bottom .45s ease,background .22s ease,color .22s ease}
#panel-predictor #predictor-loc-reset:not(.predictor-loc-reset--panel-open){
  max-height:0;opacity:0;margin-top:0;padding-top:0;padding-bottom:0;overflow:hidden;border:none;
  transform:translateY(-12px);pointer-events:none;visibility:hidden;box-shadow:none}
#panel-predictor #predictor-loc-reset.predictor-loc-reset--panel-open{
  max-height:120px;opacity:1;margin-top:4px;padding:14px 18px;overflow:visible;border:none;
  transform:translateY(0);pointer-events:auto;visibility:visible}
@media (prefers-reduced-motion:reduce){
  #panel-predictor .predictor-loc-reset-btn{transition:color .15s ease,background .15s ease,box-shadow .15s ease}
  #panel-predictor .predictor-loc-reset-btn:hover{transform:none}
  #panel-predictor #predictor-loc-reset{transition:opacity .18s ease,margin-top .18s ease,padding-top .18s ease,padding-bottom .18s ease,color .15s ease}
  #panel-predictor #predictor-loc-reset:not(.predictor-loc-reset--panel-open){transform:none}
  #panel-predictor #predictor-loc-reset.predictor-loc-reset--panel-open{transform:none}}
@media (prefers-reduced-transparency:reduce){
  #panel-predictor .predictor-primary-actions .fetchbtn,
  #panel-predictor .predictor-primary-actions .fetchbtn-find-pond,
  #panel-predictor .predictor-loc-reset-btn,
  .fetchbtn{
    backdrop-filter:none;-webkit-backdrop-filter:none;
    background:rgba(32,28,24,0.88)}
  #panel-predictor .predictor-primary-actions .fetchbtn:hover:not(:disabled),
  #panel-predictor .predictor-primary-actions .fetchbtn-find-pond:hover:not(:disabled){
    background:rgba(38,34,30,0.92);
    color:rgba(252,236,200,0.96);
    box-shadow:
      0 0 0 1px rgba(240,185,95,0.22) inset,
      0 0 26px rgba(212,168,90,0.28),
      0 4px 18px rgba(212,136,58,0.12)}
  #panel-predictor .predictor-primary-actions .fetchbtn:active:not(:disabled),
  #panel-predictor .predictor-primary-actions .fetchbtn-find-pond:active:not(:disabled){
    color:var(--amber2);
    background:rgba(42,36,30,0.95);
    box-shadow:
      0 0 0 1px rgba(255,220,160,0.35) inset,
      0 0 36px rgba(240,168,74,0.48),
      0 0 48px rgba(212,168,90,0.24)}
  #panel-predictor .predictor-primary-actions .fetchbtn-find-pond{background:rgba(26,28,34,0.88)}
  #panel-predictor .predictor-primary-actions .fetchbtn-find-pond:hover:not(:disabled){background:rgba(36,32,30,0.92)}
  #panel-predictor .predictor-loc-reset-btn{background:rgba(28,26,22,0.88)}
  #panel-predictor .predictor-loc-reset-btn:hover{
    background:rgba(36,32,28,0.92);
    color:rgba(252,236,200,0.95);
    box-shadow:
      0 0 0 1px rgba(240,185,95,0.22) inset,
      0 0 24px rgba(212,168,90,0.26),
      0 4px 16px rgba(212,136,58,0.1)}
  #panel-predictor .predictor-loc-reset-btn:active{
    color:var(--amber2);
    background:rgba(40,34,28,0.96);
    box-shadow:
      0 0 0 1px rgba(255,220,160,0.32) inset,
      0 0 34px rgba(240,168,74,0.44),
      0 0 46px rgba(212,168,90,0.22)}}
#panel-predictor .sresults{margin-top:10px;border-radius:0;border:none;box-shadow:none;background:transparent;overflow:hidden;max-height:220px}
#panel-predictor .sbox{border-radius:0}
#panel-predictor .sbox.loading{background:transparent;border:none;box-shadow:none}
#panel-predictor .predictor-gps-wrap{padding:8px 10px;border-radius:12px;transition:background .2s}
#panel-predictor .predictor-gps-wrap:hover{background:rgba(212,168,90,0.07)}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-gps-wrap{padding:0}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-loc-trailing:hover .predictor-gps-label{color:#8a8884}
#panel-predictor .predictor-location-row .swrap-with-gps .predictor-loc-trailing:hover .predictor-gps-chk{
  border-color:rgba(212,168,90,0.38);box-shadow:0 0 0 1px rgba(212,168,90,0.12)}
#panel-predictor .notebox.predictor-footnote{
  display:block;
  margin:clamp(20px,3vw,36px) auto 0;
  padding:clamp(12px,2vw,18px) clamp(8px,2vw,16px);
  border:none;border-radius:0;
  background:transparent;
  box-shadow:none;
  text-align:center;
  max-width:min(44em,92vw);
  width:100%;
  box-sizing:border-box;
  font-size:13.6125px;line-height:1.85;color:var(--wfts-c-mute-78);letter-spacing:0.02em}
#panel-predictor .notebox.predictor-footnote strong{color:rgba(200,190,165,0.88);font-weight:500}
.results{padding:32px 40px;overflow-y:auto}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  text-align:center;gap:0;padding:44px 0;min-height:0;flex-shrink:0}
.empty-inner{background:rgba(28,27,26,0.25);border:1px solid var(--wfts-c-stone-20);border-radius:18px;
  padding:42px 36px;display:block;width:fit-content}
.field-frame{width:min(640px,92vw);height:auto;max-width:92vw;display:block;vertical-align:top}

/* Banners — field notes */
.banner{border-radius:13px;padding:26px 28px;margin-bottom:26px;display:flex;gap:18px;align-items:flex-start}
.banner.season{background:rgba(70,68,66,.1);border:1px solid var(--wfts-c-stone-25)}
.banner.location{background:rgba(212,136,58,.05);border:1px solid rgba(212,136,58,.15)}
.bicon{font-size:39.6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px}
.bicon-svg{width:36px;height:36px;display:block;overflow:visible}
.btitle{font-family:'Playfair Display',serif;font-size:28.4625px;margin-bottom:8px}
.banner.season .btitle{color:var(--teal)}
.banner.location .btitle{color:var(--amber)}
.bbody{font-size:17.325px;color:var(--muted);line-height:1.75}
.bbody strong{color:var(--cream);font-weight:400}

/* Tonight box — field reading */
.tbox{background:rgba(28,27,26,0.45);border:1px solid var(--wfts-c-stone-25);border-radius:13px;
  padding:28px 30px;margin-bottom:26px;position:relative;overflow:hidden}
.tbox::after{content:'';position:absolute;bottom:-28px;right:-28px;width:100px;height:100px;
  border-radius:50%;background:radial-gradient(circle,rgba(92,90,88,.12),transparent);pointer-events:none}
.teyebrow{font-size:13.6125px;letter-spacing:0.04em;text-transform:none;color:var(--wfts-c-mute-88);
  margin-bottom:14px;display:flex;align-items:center;flex-wrap:wrap;gap:6px 10px;line-height:1.5}
.teyebrow::before{content:'◉';font-size:9.9px;flex-shrink:0;margin-right:4px;opacity:0.75;transform:translateY(0.5px)}
.teyebrow .teyebrow-poem{font-family:'Playfair Display',serif;font-size:clamp(14.85px, 2.3512vw, 18.5625px);font-style:italic;font-weight:400;
  letter-spacing:0.02em;color:rgba(200,184,138,0.9);line-height:1.4}
.teyebrow .teyebrow-sep{color:rgba(92,90,88,0.65);font-weight:300;padding:0 1px;user-select:none}
.teyebrow .teyebrow-meta{font-family:'IBM Plex Mono',monospace;font-size:12.375px;letter-spacing:0.05em;color:rgba(154,148,138,0.82);line-height:1.45}
.tdetail{font-size:17.325px;color:var(--muted);line-height:1.75;margin-top:2px}
.tdetail strong{color:var(--cream);font-weight:400}

/* Section label */
.sec{font-size:13.6125px;letter-spacing:4px;text-transform:uppercase;color:#5c5a58;
  margin-bottom:16px;display:flex;align-items:center;gap:10px}
.sec::before{content:'◈';font-size:9.9px}

/* Weather strip — instrument readout */
.wstrip{display:grid;grid-template-columns:repeat(14,1fr);gap:8px;margin-bottom:26px;overflow-x:auto}
.wday{background:var(--wfts-c-surface-40);border:1px solid var(--wfts-c-stone-18);border-radius:10px;
  padding:14px 10px;text-align:center;min-width:68px;cursor:pointer;
  transition:border-color .2s,background .2s,box-shadow .2s,transform .2s ease;position:relative}
.wday:hover,.wday.hover-day{border-color:var(--wfts-c-amber-50);background:rgba(212,168,90,0.08);box-shadow:0 0 0 1px rgba(212,168,90,0.2);transform:scale(1.06)}
.wday.selected-day{border-color:rgba(212,136,58,0.6);background:var(--wfts-c-amberdeep-12);box-shadow:0 0 0 1px var(--wfts-c-amberdeep-35);transform:scale(1.06)}
.wday.today{border-color:rgba(212,136,58,0.4);background:rgba(212,136,58,0.05)}
.wday.today:hover,.wday.today.hover-day{border-color:var(--wfts-c-amber-55);background:var(--wfts-c-amber-12);transform:scale(1.06)}
.wday.today.selected-day{transform:scale(1.06)}
.wday.hotn{
  border-color:rgba(212,168,90,0.38);
  background:rgba(212,136,58,0.06);
  box-shadow:0 0 0 1px rgba(212,168,90,0.2),0 0 16px rgba(212,136,58,0.16),0 0 28px rgba(212,168,90,0.07);
  /* Default origin center clips the peeper row when scale(1.06) + .wstrip overflow — anchor top */
  transform-origin:center top;
  animation:none}
.wday.hotn:hover,.wday.hotn.hover-day{
  border-color:var(--wfts-c-amber-50);
  background:rgba(212,168,90,0.09);
  box-shadow:0 0 0 1px var(--wfts-c-amber-35),0 0 20px rgba(212,136,58,0.22),0 0 34px rgba(212,168,90,0.1);
  transform:scale(1.06);
  animation:none}
.wday.hotn.selected-day{
  border-color:rgba(212,136,58,0.58);
  background:var(--wfts-c-amberdeep-12);
  box-shadow:0 0 0 1px rgba(212,136,58,0.4),0 0 18px var(--wfts-c-amberdeep-25),0 0 32px rgba(212,168,90,0.1);
  transform:scale(1.06);
  animation:none}
/* Predictor #rcontent: override generic .wday hover/selected chrome (no card boxes) */
#rcontent .wday:hover,#rcontent .wday.hover-day{
  border-color:transparent;background:transparent;box-shadow:none}
#rcontent .wday.selected-day{border-color:transparent;background:transparent;box-shadow:none}
#rcontent .wday.today{border-color:transparent;background:transparent}
#rcontent .wday.today:hover,#rcontent .wday.today.hover-day{
  border-color:transparent;background:transparent;box-shadow:none}
/* Forecast strip: proximity glow (±2 cells); strength via --w-strip-a from JS */
#rcontent .wday.wstrip-glow{position:relative}
#rcontent .wday.wstrip-glow > *{position:relative;z-index:1}
#rcontent .wday.wstrip-glow::before{
  content:'';
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:0;
  background:rgba(212,168,90,calc(0.028 + 0.22 * var(--w-strip-a, 0)));
  box-shadow:0 0 0 1px rgba(212,168,90,calc(0.06 + 0.32 * var(--w-strip-a, 0)));
  transition:background .05s ease,box-shadow .05s ease}
/* Forecast strip: hover + selected → amber text; SVG strokes/fills follow */
#panel-predictor #rcontent .wday.hover-day .dlabel,
#panel-predictor #rcontent .wday.selected-day .dlabel,
#panel-predictor #rcontent .wday.hover-day .dhi,
#panel-predictor #rcontent .wday.selected-day .dhi,
#panel-predictor #rcontent .wday.hover-day .dlo,
#panel-predictor #rcontent .wday.selected-day .dlo,
#panel-predictor #rcontent .wday.hover-day .dwind,
#panel-predictor #rcontent .wday.selected-day .dwind{
  color:rgba(240,184,95,0.95)!important}
#panel-predictor #rcontent .wday.hover-day .w-ico.w-ico--dim,
#panel-predictor #rcontent .wday.selected-day .w-ico.w-ico--dim{opacity:1}
#panel-predictor #rcontent .wday.hover-day .w-ico svg [fill="none"],
#panel-predictor #rcontent .wday.selected-day .w-ico svg [fill="none"]{
  stroke:rgba(240,184,95,0.92)!important}
#panel-predictor #rcontent .wday.hover-day .w-ico svg [stroke]:not([stroke="none"]),
#panel-predictor #rcontent .wday.selected-day .w-ico svg [stroke]:not([stroke="none"]){
  stroke:rgba(240,184,95,0.92)!important}
#panel-predictor #rcontent .wday.hover-day .w-ico svg circle:not([fill="none"]):not([fill="#141312"]),
#panel-predictor #rcontent .wday.hover-day .w-ico svg rect:not([fill="none"]),
#panel-predictor #rcontent .wday.hover-day .w-ico svg path:not([fill="none"]),
#panel-predictor #rcontent .wday.selected-day .w-ico svg circle:not([fill="none"]):not([fill="#141312"]),
#panel-predictor #rcontent .wday.selected-day .w-ico svg rect:not([fill="none"]),
#panel-predictor #rcontent .wday.selected-day .w-ico svg path:not([fill="none"]){
  fill:rgba(240,184,95,0.9)!important}
#panel-predictor #rcontent .wday.hover-day .w-ico svg circle[fill="#141312"],
#panel-predictor #rcontent .wday.selected-day .w-ico svg circle[fill="#141312"]{
  fill:rgba(18,16,14,0.92)!important}
#panel-predictor #rcontent .wstrip:hover ~ .rcontent-outlook-block .rcontent-forecast-wx,
#panel-predictor #rcontent .wstrip:has(.wday.selected-day) ~ .rcontent-outlook-block .rcontent-forecast-wx{
  color:rgba(228,198,148,0.92)!important}
#panel-predictor #rcontent .wstrip:hover ~ .rcontent-outlook-block .rcontent-forecast-wx strong,
#panel-predictor #rcontent .wstrip:has(.wday.selected-day) ~ .rcontent-outlook-block .rcontent-forecast-wx strong{
  color:rgba(252,220,160,0.96)!important;font-weight:500}
.wday .dlabel{font-size:12.375px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;white-space:nowrap}
.wday.today .dlabel{color:var(--amber)}
.wday .dicon{font-size:0;line-height:0;display:flex;justify-content:center;align-items:center;margin-bottom:3px;min-height:32px}
/* Forecast weather: monochrome glyphs (clouds outlined; sun / precip / fog filled) */
.w-ico{display:inline-flex;align-items:center;justify-content:center}
.w-ico svg{width:26px;height:26px;display:block;overflow:visible}
.w-ico.w-ico--dim svg{opacity:0.72}
.wday .dhi{font-size:18.5625px;color:var(--amber2);font-weight:500}
.wday .dlo{font-size:16.0875px;color:var(--teal)}
.wday .dwind{font-size:12.375px;color:var(--muted);margin-top:2px}
.w-hot-badge{position:absolute;top:5px;right:5px;width:6px;height:6px;border-radius:50%;
  background:rgba(250,220,170,0.95);
  box-shadow:0 0 0 1px var(--wfts-c-amberdeep-35),0 0 8px rgba(212,136,58,0.55),0 0 14px rgba(212,168,90,0.3);
  pointer-events:none}
/* Peak “frog nights” (strong combined chorus): label + spring peeper above day readout */
.wday-frog-night-hero{
  display:flex;flex-direction:column;align-items:center;gap:7px;width:100%;
  margin:-2px 0 7px;padding:0 2px;box-sizing:border-box}
.wday-frog-night-species{
  display:flex;align-items:center;justify-content:center;gap:4px;
  width:100%;min-height:24px}
.wday-frog-night-species-img{
  width:24px;height:24px;object-fit:contain;display:block;border-radius:999px;
  border:1px solid rgba(212,168,90,0.36);background:rgba(12,12,14,0.78);
  box-shadow:0 1px 6px rgba(0,0,0,0.35)}
.wday-frog-night-title{
  display:block;max-width:100%;text-align:center;box-sizing:border-box;
  font-family:'IBM Plex Mono',monospace;
  font-size:clamp(11px,2.35vw,14px);
  font-weight:600;
  letter-spacing:0.11em;
  text-transform:lowercase;
  line-height:1.2;
  color:rgba(252,236,208,0.96);
  padding:4px 11px 5px;
  border-radius:999px;
  background:rgba(212,136,58,0.1);
  border:1px solid rgba(212,168,90,0.32);
  box-shadow:
    inset 0 1px 0 rgba(255,240,210,0.07),
    0 0 20px rgba(212,136,58,0.12),
    0 1px 4px rgba(0,0,0,0.22);
  text-shadow:0 1px 2px rgba(0,0,0,0.35)}
.wday-frog-night-peeper{
  width:clamp(26px,6.8vw,32px);height:clamp(26px,6.8vw,32px);object-fit:contain;display:block;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,0.35)) drop-shadow(0 0 8px rgba(240,185,95,0.4))}
@media (prefers-reduced-motion:reduce){
  #rcontent .wday.hotn,.wday.hotn{animation:none!important}
  #rcontent .wday.wstrip-glow::before{transition:none}}

/* Species grid — specimen cards */
.sgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;margin-bottom:30px}
.scard{background:var(--wfts-c-surface-40);border:1px solid var(--wfts-c-stone-20);border-radius:12px;
  padding:22px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s;cursor:default}
.scard:hover{transform:translateY(-2px);border-color:var(--wfts-c-mute-40)}
.scard .topbar{position:absolute;top:0;left:0;right:0;height:3px}
.semoji{font-size:34.65px;margin-bottom:10px;display:block}
.sname{font-family:'Playfair Display',serif;font-size:21.0375px;font-weight:400;color:var(--text);margin-bottom:3px}
.slatin{font-size:14.85px;color:var(--muted);font-style:italic;margin-bottom:12px}
.sstatus{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.sdot{width:8px;height:8px;border-radius:50%;flex-shrink:0;position:relative}
.sdot.pulse::after{content:'';position:absolute;inset:0;border-radius:50%;
  border:1px solid currentColor;animation:pring 1.5s ease-out infinite;opacity:.5}
@keyframes pring{0%{transform:scale(.8);opacity:.5}100%{transform:scale(2.5);opacity:0}}
/* Atlas GPS: larger marker, stronger glow + scale pulse */
@keyframes a-gps-core-pulse{
  0%,100%{opacity:0.45}
  50%{opacity:1}}
@keyframes a-gps-halo-pulse{
  0%,100%{opacity:0.28}
  50%{opacity:0.82}}
@keyframes a-gps-acc-pulse{
  0%,100%{opacity:0.35}
  50%{opacity:0.72}}
@keyframes a-gps-dot-breathe{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.24)}}
#a-gps-svg #a-gps-dot{
  transform-box:fill-box;
  transform-origin:50% 50%;
  animation:a-gps-dot-breathe 2.35s ease-in-out infinite}
#a-gps-svg .a-gps-core{
  fill:#ffc266;
  stroke:rgba(20,18,14,0.5);
  stroke-width:1.45;
  animation:a-gps-core-pulse 2.2s ease-in-out infinite}
#a-gps-svg .a-gps-halo{
  fill:rgba(255,200,100,0.26);
  stroke:rgba(255,220,160,0.82);
  stroke-width:2.05;
  animation:a-gps-halo-pulse 2.8s ease-in-out infinite;
  animation-delay:0.2s}
#a-gps-svg .a-gps-acc{
  fill:rgba(240,168,74,0.16);
  stroke:rgba(255,200,120,0.58);
  stroke-width:1.2;
  animation:a-gps-acc-pulse 3.4s ease-in-out infinite;
  animation-delay:0.45s}
@media (prefers-reduced-motion:reduce){
  #a-gps-svg #a-gps-dot{animation:none;filter:none!important}
  #a-gps-svg .a-gps-core,#a-gps-svg .a-gps-halo,#a-gps-svg .a-gps-acc{animation:none;opacity:1}}
.sstatustxt{font-size:16.0875px;font-weight:500;letter-spacing:.5px}
.sinfo{font-size:16.0875px;color:var(--muted);line-height:1.65;margin-bottom:12px}
.sinfo strong{color:var(--cream);font-weight:400}
.smeter{height:4px;background:var(--faint);border-radius:2px;overflow:hidden;margin-bottom:5px}
.smfill{height:100%;border-radius:2px;transition:width .8s cubic-bezier(.16,1,.3,1)}
.smlab{display:flex;justify-content:space-between;font-size:13.6125px;color:var(--muted)}
.sprob-box{margin:0 0 12px;padding:0 0 10px;background:transparent;border:none;border-radius:0;box-shadow:none}
.sprob-main{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px;margin-bottom:8px}
.sprob-num{font-family:'Playfair Display',serif;font-size:39.6px;font-weight:600;line-height:1;letter-spacing:-0.5px}
.sprob-desc{font-size:13.6125px;letter-spacing:1.2px;text-transform:uppercase;color:rgba(212,168,90,0.65);max-width:14em;line-height:1.35}
.sprob-wx{font-size:14.85px;color:var(--muted);line-height:1.55;margin-bottom:5px}
.sprob-note{font-size:12.375px;color:rgba(92,90,88,0.65);line-height:1.45}

/* Timeline — phenology record */
.tltitle{font-size:12.375px;letter-spacing:4px;text-transform:uppercase;color:#5c5a58;
  margin-bottom:18px;display:flex;align-items:center;gap:10px}
.tltitle::before{content:'◈';font-size:9.9px}
.tlwrap{position:relative;padding-left:0}
.tlitem{position:relative;margin-bottom:18px;padding:3px 0 6px 0;
  background:transparent;border:none;border-radius:0}
.tldate{font-size:13.6125px;color:var(--muted);letter-spacing:.5px;margin-bottom:3px}
.tlname{font-family:'Playfair Display',serif;font-size:21.0375px;color:var(--text);margin-bottom:3px}
.tldetail{font-size:14.85px;color:var(--muted);line-height:1.65}

/* Attribution */
.attr{margin-top:26px;padding-top:16px;border-top:1px solid var(--border);
  font-size:13.6125px;color:var(--faint);line-height:1.8}
.attr a{color:var(--muted);text-decoration:none}
.attr a:hover{color:var(--amber)}

/* Animations */
.fi{animation:fi .4s ease forwards}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.d1{animation-delay:.04s;opacity:0}.d2{animation-delay:.08s;opacity:0}
.d3{animation-delay:.12s;opacity:0}.d4{animation-delay:.16s;opacity:0}
.d5{animation-delay:.20s;opacity:0}.d6{animation-delay:.24s;opacity:0}
.d7{animation-delay:.28s;opacity:0}.d8{animation-delay:.32s;opacity:0}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid var(--wfts-c-stone-20)}
  .sgrid{grid-template-columns:1fr}
  #panel-predictor #rcontent .sgrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px}
  .predictor-center{padding:22px 16px 36px;gap:28px}
  .predictor-countdown-card .predictor-input-wave-placeholder{font-size:16.0875px;right:96px}
  .hdr-inner{padding:14px 18px 16px}
  .frog-logo{width:28px;height:28px;top:-4px;margin-right:9px;mix-blend-mode:plus-lighter}
  .hdr-subtitle-row{padding-left:37px}
  .sidebar,.results{padding:24px 20px}
  .wstrip{grid-template-columns:repeat(7,1fr)}
  .field-frame{width:min(360px,92vw)}
}

/* TABS — specimen label (sticky at top; stays visible when content scrolls) */
.tabs{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;flex-wrap:nowrap;gap:0 clamp(0px,0.35vw,2px);
  border-bottom:1px solid var(--wfts-c-stone-20);padding:0 clamp(14px,3.2vw,48px) 0 clamp(6px,1.1vw,16px);
  background:rgba(22,21,19,0.82);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  transition:box-shadow .35s ease,background .35s ease;min-width:0;
  overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
#main-nav.tabs .main-nav-tabs-scroll::-webkit-scrollbar{height:4px}
#main-nav.tabs .main-nav-tabs-scroll::-webkit-scrollbar-thumb{background:var(--wfts-c-stone-35);border-radius:2px}
/* Main nav: tabs scroll left; small gap after Contact; social sits left; second spacer pushes waveform right */
#main-nav.tabs{
  gap:0;
  padding:10px clamp(14px,3.4vw,40px) 10px clamp(10px,2.4vw,26px);
  justify-content:flex-start;
  overflow-x:visible;
  overflow-y:visible}
#main-nav.tabs .main-nav-tabs-scroll{
  display:flex;align-items:center;flex-wrap:nowrap;
  gap:clamp(0px,0.38vw,6px);
  flex:0 1 auto;min-width:0;
  overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
#main-nav.tabs .main-nav-tabs-scroll + .main-nav-rail-spacer{
  flex:0 0 clamp(12px,2.4vw,24px);
  width:clamp(12px,2.4vw,24px);
  min-width:clamp(12px,2.4vw,24px);
  max-width:clamp(12px,2.4vw,24px);
  align-self:stretch;
  pointer-events:none}
#main-nav.tabs .main-nav-social + .main-nav-rail-spacer{
  flex:1 1 0;
  min-width:0;
  align-self:stretch;
  pointer-events:none}
/* Forecast panel: no rule between nav and “Frog Night / Forecast” hero */
body:has(#panel-predictor.active) #main-nav.tabs{border-bottom:none}
body.hdr-scroll-compact:has(#panel-predictor.active) #main-nav.tabs{box-shadow:none}
/* Scroll-compact: tabs (and waveform) pin to top of viewport under notch */
body.hdr-scroll-compact{
  --wfts-tabs-inner-h:72px;
  --wfts-tabs-band:calc(env(safe-area-inset-top, 0px) + var(--wfts-tabs-inner-h));
  --wfts-layout-chrome:var(--wfts-tabs-band);
  padding-top:var(--wfts-layout-chrome)}
body.hdr-scroll-compact #main-nav.tabs{
  position:fixed;top:0;left:0;right:0;width:100%;margin:0;
  z-index:45;
  min-height:var(--wfts-tabs-band);
  padding-top:calc(env(safe-area-inset-top, 0px) + 10px);
  padding-bottom:10px;
  padding-left:clamp(10px,2.4vw,26px);padding-right:clamp(14px,3.4vw,40px);
  gap:0;
  align-items:center;
  box-shadow:0 1px 0 var(--wfts-c-stone-25)}
@media (max-width:860px){
  body.hdr-scroll-compact #main-nav.tabs{padding-left:clamp(8px,2vw,16px);padding-right:clamp(12px,3vw,22px)}}
@media (prefers-reduced-motion:reduce){
  body{transition:none}}
.tab{font-size:11.1375px;letter-spacing:3px;text-transform:uppercase;padding:14px 20px;color:var(--muted);
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .2s ease,border-color .2s ease;user-select:none}
#main-nav.tabs .tab{
  padding:clamp(9px,1.6vw,14px) clamp(2px,0.55vw,7px);
  font-size:clamp(8.0438px, 1.9181vw, 11.1375px);
  letter-spacing:clamp(0.75px,0.2vw,3px);
  flex:0 0 auto;white-space:nowrap}
.tab:hover{color:#8a8884}
.tab.active{color:#8a8884;border-bottom-color:#5c5a58}
#main-nav.tabs .tab.active{color:var(--amber2);border-bottom-color:rgba(240,168,74,0.9)}
#main-nav.tabs .tab.active:hover{color:var(--amber)}
#main-nav .main-nav-social{
  display:flex;align-items:center;justify-content:flex-start;gap:0 clamp(2px,0.5vw,5px);
  flex:0 0 auto;margin:0;padding:0 2px 0 0;
  border:none}
#main-nav .main-nav-social-link{
  display:inline-flex;align-items:center;justify-content:center;
  width:clamp(24px,4.1vw,30px);height:clamp(24px,4.1vw,30px);
  color:var(--muted);text-decoration:none;border-radius:6px;
  border-bottom:2px solid transparent;margin-bottom:-1px;box-sizing:border-box;
  transition:color .2s ease,background-color .2s ease,border-color .2s ease}
#main-nav .main-nav-social-link:hover{color:var(--amber2);background:rgba(212,168,90,0.08)}
#main-nav .main-nav-social-link:focus-visible{
  outline:2px solid rgba(212,168,90,0.45);outline-offset:2px}
#main-nav .main-nav-social-svg{display:block;width:clamp(12px,2.5vw,15px);height:clamp(12px,2.5vw,15px)}
#main-nav .tab.tab-forecast{display:inline-flex;align-items:center;gap:clamp(7px,1.15vw,13px);overflow:visible;position:relative;z-index:1}
#main-nav .nav-frog-logo-wrap{
  position:relative;width:clamp(22px,3.85vw,32px);height:clamp(22px,3.85vw,32px);flex-shrink:0;
  z-index:1;overflow:visible}
/* Forecast peeper hover: amber glow on nav logo; --nav-frog-call-env 0–1 from call RMS (pulses with audio) */
#main-nav .nav-frog-logo{
  width:100%;height:100%;object-fit:contain;display:block;pointer-events:none;position:relative;z-index:0;
  transition:filter 0.2s ease}
html.wfts-pcc-logo-hover #main-nav .nav-frog-logo{
  filter:
    drop-shadow(0 0 calc(1.5px + var(--nav-frog-call-env,0)*4px) rgba(255,200,120,0.46))
    drop-shadow(0 0 calc(4px + var(--nav-frog-call-env,0)*8px) rgba(240,168,74,0.24))
    drop-shadow(0 0 calc(9px + var(--nav-frog-call-env,0)*13px) rgba(212,140,60,0.12))}
@media (prefers-reduced-motion:reduce){
  #main-nav .nav-frog-logo{transition:none}
  html.wfts-pcc-logo-hover #main-nav .nav-frog-logo{
    filter:drop-shadow(0 0 3px rgba(240,168,74,0.34)) drop-shadow(0 0 8px rgba(212,140,60,0.16))}}
#main-nav .nav-brand-frognight{
  flex-shrink:0;white-space:nowrap;font-family:'Playfair Display',serif;font-size:clamp(12px,2.15vw,17px);
  letter-spacing:0.02em;font-weight:400;color:inherit;
  text-transform:none}
#main-nav .nav-brand-frognight .nav-tm{font-size:0.55em;font-weight:400;vertical-align:super;margin-left:0.08em;line-height:0;opacity:0.88}
.tab-panel{position:relative;display:none}.tab-panel.active{display:block}
#panel-predictor{padding-top:6px}
/* Global footer: ambient + star sky + UI sounds (all tabs) */
.amb-bar-group{position:fixed;bottom:0;left:0;right:0;z-index:96;display:flex;flex-direction:row;flex-wrap:nowrap;
  align-items:center;justify-content:flex-start;gap:10px 12px;pointer-events:auto;
  padding:8px 12px calc(8px + env(safe-area-inset-bottom,0)) 14px;
  background:rgba(14,13,10,0.92);border-top:1px solid var(--wfts-c-stone-22);
  backdrop-filter:blur(10px);font-family:'IBM Plex Mono',monospace;
  transition:padding .22s ease}
.amb-bar-toggles{
  flex:1 1 auto;min-width:0;display:flex;flex-direction:row;flex-wrap:wrap;
  align-items:center;gap:8px 12px}
.amb-bar-collapse{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  width:auto;height:32px;margin:0;padding:0 10px;gap:7px;
  border-radius:8px;border:1px solid rgba(212,168,90,0.45);
  background:rgba(28,27,26,0.92);cursor:pointer;box-sizing:border-box;
  color:var(--amber2);
  box-shadow:0 0 0 1px var(--wfts-c-amber-12) inset,0 0 14px rgba(212,168,90,0.2);
  transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,color .18s ease,transform .15s ease}
.amb-bar-collapse:hover{
  border-color:rgba(212,168,90,0.72);
  color:var(--amber2);
  box-shadow:0 0 0 1px rgba(212,168,90,0.14) inset,0 0 18px rgba(240,168,74,0.28)}
.amb-bar-collapse:focus-visible{
  outline:2px solid var(--wfts-c-amber-55);outline-offset:2px}
.amb-bar-collapse-arrow{
  font-size:13px;line-height:1;display:block;
  transition:transform .24s cubic-bezier(0.33,1,0.68,1)}
.amb-bar-collapse-lbl{
  font-size:9px;line-height:1;letter-spacing:0.11em;text-transform:uppercase;
  white-space:nowrap;opacity:0.95}
html.wfts-amb-bar-collapsed{
  --wfts-footer-reserve:calc(44px + env(safe-area-inset-bottom, 0px))}
html.wfts-amb-bar-collapsed .amb-bar-group{
  padding-top:6px;padding-bottom:calc(6px + env(safe-area-inset-bottom,0));
  justify-content:center}
html.wfts-amb-bar-collapsed .amb-bar-toggles{
  display:none}
html.wfts-amb-bar-collapsed .amb-bar-collapse{
  margin-left:0}
html.wfts-amb-bar-collapsed .amb-bar-collapse-arrow{
  transform:rotate(180deg)}
.amb-bar-group .amb-toggle{flex-shrink:0}
body{padding-bottom:calc(52px + env(safe-area-inset-bottom,0));
  transition:padding-bottom .22s ease}
html.wfts-amb-bar-collapsed body{
  padding-bottom:calc(44px + env(safe-area-inset-bottom,0))}
html.wfts-amb-bar-collapsed body:has(#panel-historical.tab-panel.active),
html.wfts-amb-bar-collapsed body:has(#panel-calling.tab-panel.active){
  padding-bottom:0}
/* Atlas + Calendar: fill viewport below tabs and above fixed footer — no extra document scroll */
body:has(#panel-historical.tab-panel.active),
body:has(#panel-calling.tab-panel.active){
  padding-bottom:0;
  overflow-x:hidden;
  overflow-y:hidden;
  overscroll-behavior:none;
}
/* Learn quiz: full width; no panel scroll (dial uses its own wheel handler; avoids rubber-band / stray page motion) */
body:has(#panel-vocalizations.tab-panel.active){
  overflow-x:hidden;
  overflow-y:hidden;
  overscroll-behavior:none;
  padding-bottom:0}
/* About: explicitly re-enable page scrolling when this tab is active. */
body:has(#panel-about.tab-panel.active){
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:auto;
  padding-bottom:calc(52px + env(safe-area-inset-bottom,0))}
html:has(#panel-about.tab-panel.active){
  overflow-x:hidden;
  overflow-y:auto;
}
html:has(#panel-vocalizations.tab-panel.active){
  overflow-x:hidden;
  overflow-y:hidden;
  height:100%}
html:has(#panel-historical.tab-panel.active),
html:has(#panel-calling.tab-panel.active){
  overflow:hidden;
  height:100%;
}
/* ATLAS — Strobridge-inspired frame layout */
#panel-historical.tab-panel.active{display:flex;flex-direction:column;
  height:calc(100dvh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  max-height:calc(100svh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  overflow:hidden;min-height:0;
  padding-top:var(--atlas-subnav-h,0px);box-sizing:border-box;
  background:transparent}
#panel-calling.tab-panel.active{display:flex;flex-direction:column;
  height:calc(100dvh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  max-height:calc(100svh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  overflow:hidden;min-height:0;
  padding-top:var(--calling-subnav-h,0px);box-sizing:border-box}
.atlas-wrap{display:flex;flex:1;min-height:0;flex-direction:column;position:relative;background:transparent}
/* Station route click — multi-lane intensity waveform (1981–2024) */
.a-waveform-panel{
  display:none;
  flex-shrink:0;
  padding:0;
  background:linear-gradient(180deg,rgba(10,9,8,0.97) 0%,rgba(6,6,5,0.98) 100%);
  border-bottom:1px solid rgba(212,168,90,0.22);
  box-shadow:inset 0 1px 0 rgba(255,248,230,0.04)}
.a-waveform-hdr{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px 14px;
  padding:8px 14px 6px;font-family:'IBM Plex Mono',monospace;
  border-bottom:1px solid rgba(92,90,88,0.25)}
.a-waveform-title{font-size:10.5px;letter-spacing:0.06em;color:rgba(212,184,138,0.88);line-height:1.35;flex:1 1 220px;min-width:0}
.a-waveform-title strong{color:rgba(244,228,196,0.95);font-weight:500}
.a-waveform-all-yr-lbl{
  display:inline-flex;align-items:center;gap:7px;flex-shrink:0;
  font-size:9px;letter-spacing:0.05em;text-transform:uppercase;color:rgba(168,162,148,0.92);
  cursor:pointer;user-select:none;white-space:nowrap}
.a-waveform-all-yr-lbl input{
  width:13px;height:13px;accent-color:rgba(212,168,90,0.95);cursor:pointer;margin:0;flex-shrink:0}
.a-waveform-chart text.a-wf-lab{pointer-events:none}
.a-waveform-close{
  flex-shrink:0;background:rgba(40,36,32,0.6);border:1px solid rgba(138,136,132,0.35);
  color:rgba(200,192,172,0.85);width:30px;height:30px;border-radius:6px;cursor:pointer;
  font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:background .15s,border-color .15s,color .15s}
.a-waveform-close:hover{background:rgba(60,54,48,0.75);border-color:rgba(212,168,90,0.45);color:var(--amber2)}
.a-waveform-panel .a-waveform-svg-host{padding:4px 10px 6px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}
.a-waveform-panel svg.a-waveform-chart{
  display:block;min-width:min(100%,640px);width:100%;height:auto;
  max-height:none;min-height:120px;overflow:visible}
.a-waveform-axis-strip{
  flex-shrink:0;padding:6px 10px 10px;font-family:'IBM Plex Mono',monospace;
  border-top:1px solid rgba(92,90,88,0.2);
  background:rgba(5,5,4,0.96)}
.a-waveform-axis-strip .a-waveform-axis-inner{
  display:grid;grid-template-columns:repeat(9,1fr);align-items:center;
  column-gap:2px;min-width:min(100%,620px);margin:0 auto;max-width:1192px;
  padding:0 2px}
.a-waveform-axis-strip span{
  font-size:clamp(10px,2.4vw,12px);font-variant-numeric:tabular-nums;
  color:rgba(228,216,188,0.96);letter-spacing:0.02em;white-space:nowrap;
  text-align:center;text-shadow:0 1px 2px rgba(0,0,0,0.75)}
.a-waveform-axis-strip span:first-child{text-align:left}
.a-waveform-axis-strip span:last-child{text-align:right}
.atlas-wrap.atlas-compact-panels .a-map-left-rail{
  opacity:0;visibility:hidden;pointer-events:none}
.atlas-map{position:relative;background:transparent;overflow:hidden;
  flex:1;min-height:0;width:100%;margin:0;border:1px solid var(--wfts-c-stone-20);border-radius:0}
.atlas-map::before{content:'';position:absolute;inset:0;border:1px solid rgba(138,136,132,0.1);
  border-radius:10px;pointer-events:none;z-index:4}
/* Map artwork clipped to rounded frame; inner padding keeps station-dot glow inside clip */
.atlas-map-viewport{
  position:absolute;inset:0;overflow:hidden;border-radius:10px;z-index:1;
  padding:clamp(2px,0.65vw,8px);box-sizing:border-box}
/* Single transform on viewport: grid, nature centers, and crosshairs live inside it (same box as #a-svg) — avoids per-layer scale + origin mismatch. */
#panel-historical .atlas-map > .atlas-map-viewport{
  transform:scale(0.935);
  transform-origin:50% 48%}
.atlas-map-viewport svg{position:absolute;inset:0;width:100%;height:100%}
/* Nature + GPS: fill viewport content box (padding already on .atlas-map-viewport). */
#a-nc-svg.atlas-nc-overlay.atlas-nc-top,
#a-gps-layer.a-gps-layer--map{
  position:absolute;
  pointer-events:none;
  box-sizing:border-box;
  inset:0;
  width:100%;
  height:100%}
.atlas-nc-overlay #a-nature-centers a{pointer-events:auto}
#a-nc-svg.atlas-nc-overlay.atlas-nc-top{
  z-index:6;
  overflow:visible}
/* GPS + crosshairs above nature preserves (still below #a-svg-ui grid). */
#a-gps-layer.a-gps-layer--map{
  z-index:7;
  isolation:isolate}
#a-gps-layer.a-gps-layer--map #a-gps-svg{
  z-index:1;
  overflow:visible}
#a-svg{overflow:visible}
/* Survey route polylines: amber + flowing dash; labels sit above #a-pts */
#a-svg .a-route-line{
  stroke:rgba(212,168,90,0.68);
  stroke-width:1.35px;
  stroke-linecap:round;
  vector-effect:non-scaling-stroke;
  stroke-dasharray:5 14;
  stroke-dashoffset:0;
  animation:aRouteLineDashFlow 2.8s linear infinite;
  animation-delay:var(--a-route-d,0s)}
@keyframes aRouteLineDashFlow{
  to{stroke-dashoffset:-38}}
#a-svg .a-route-name-label{
  font-family:'IBM Plex Mono',monospace;
  font-size:8.1px;
  font-weight:600;
  letter-spacing:0.04em;
  fill:rgba(244,200,120,0.96);
  pointer-events:none}
@media (prefers-reduced-motion:reduce){
  #a-svg .a-route-line{
    animation:none;
    stroke-dasharray:none;
    stroke:rgba(212,168,90,0.58)}}
#a-svg-ui.atlas-map-ui-svg{z-index:5;pointer-events:none;overflow:visible}
/* iNaturalist observation dots (main map SVG, clipped to WI; fill set per species) */
#a-svg #a-inat-obs a{pointer-events:auto}
#a-svg #a-inat-obs .a-inat-obs-dot{
  transition:opacity .12s ease,filter .12s ease;
  transform-origin:center;
  transform-box:fill-box}
#a-svg #a-inat-obs a:hover .a-inat-obs-dot{
  filter:brightness(1.18)}
/* Wisconsin DNR reference layers (ArcGIS GeoJSON from dnrmaps.wi.gov) */
#a-svg #a-great-lakes .a-great-lakes-p{
  fill:rgba(52,112,158,0.2);
  stroke:none;
  pointer-events:none}
#a-svg #a-waterways .a-dnr-waterway{
  stroke:rgba(108,168,206,0.48);
  stroke-width:0.48;
  stroke-linecap:round;
  stroke-linejoin:round;
  vector-effect:non-scaling-stroke;
  fill:none;
  pointer-events:none}
/* Lake Winnebago (24K lake polygon on waterways layer): same blue as major river strokes */
#a-svg #a-waterways .a-dnr-waterway.a-dnr-waterway--openwater{
  fill:rgba(108,168,206,0.38)}
#a-svg #a-inland-lakes .a-dnr-inland-lake{
  fill:rgba(48,108,152,0.2);
  stroke:rgba(118,176,214,0.32);
  stroke-width:0.38;
  stroke-linejoin:round;
  vector-effect:non-scaling-stroke;
  pointer-events:none}
/* Nature preserve dots — slow staggered pulse (above all map paints in viewport stack) */
#a-nature-centers .a-nature-center-dot{
  transform-origin:center;
  transform-box:fill-box;
  animation:aNatureCenterPulse 3.8s ease-in-out infinite;
  animation-delay:var(--a-nc-d,0s);
  will-change:transform,opacity}
@keyframes aNatureCenterPulse{
  0%,100%{opacity:0.55;transform:scale(0.9)}
  50%{opacity:1;transform:scale(1.12)}}
@media (prefers-reduced-motion:reduce){
  #a-nature-centers .a-nature-center-dot{
    animation:none;
    opacity:0.92;
    transform:none}}
/* Atlas map: timeline scrubber on map; stations legend in atlas history dock */
.a-map-bottom-bar{
  position:absolute;bottom:12px;left:14px;right:14px;z-index:16;
  pointer-events:none;box-sizing:border-box}
.a-map-bottom-bar .a-timeline-wrap{width:100%;pointer-events:none}
.a-map-bottom-bar .a-timeline-track{pointer-events:auto}
/* Species legend + live banner: floating left rail on map (was .atlas-sidebar) — fixed 100% scale (no UI zoom) */
.a-map-left-rail{
  position:absolute;top:10px;left:10px;bottom:68px;width:min(292px,calc(100vw - 140px));
  max-width:calc(100% - 24px);box-sizing:border-box;z-index:14;display:flex;flex-direction:column;gap:8px;
  padding:4px 2px 4px 0;overflow:hidden;pointer-events:auto;
  background:transparent;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:0;
  transition:opacity .2s,visibility .2s}
.a-map-left-rail-scroll{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin}
#panel-historical .a-map-left-rail .a-now{min-height:0;margin:0;padding:0;line-height:1.35}
#panel-historical .a-map-left-rail #a-gps-msg{min-height:0;margin:0;padding:0;line-height:1.35}
#panel-historical .a-map-left-rail .a-map-rail-status{
  display:flex;flex-direction:column;gap:4px;margin:0;padding:0;background:transparent;border:none}
#panel-historical .a-map-left-rail .a-map-rail-status:has(#a-now:empty):has(#a-gps-msg:empty){
  display:none;margin:0;padding:0;height:0;overflow:hidden;gap:0}
#panel-historical .a-map-left-rail .a-legend .a-item{
  background:transparent;border:none;box-shadow:none;border-radius:0;padding:3px 2px}
#panel-historical .a-map-left-rail .a-legend .a-item.solo{
  border-left:2px solid var(--wfts-c-mute-50);padding-left:6px;background:transparent}
#panel-historical .a-map-left-rail .a-legend .a-item.inat-solo{
  border-right:2px solid rgba(118,168,208,0.58);
  padding-right:5px;
  background:rgba(100,155,195,0.05)}
#panel-historical .a-map-left-rail .a-legend .a-item.solo.inat-solo{
  border-right:2px solid rgba(118,168,208,0.58);
  padding-right:5px}
.a-map-zoom-cluster{
  position:relative;top:auto;right:auto;z-index:auto;
  display:flex;flex-direction:row;align-items:center;gap:5px;pointer-events:auto;
  flex-shrink:0;align-self:center;
  padding:0;border-radius:0;
  background:transparent;border:none;
  box-shadow:none;
  backdrop-filter:none;-webkit-backdrop-filter:none}
.atlas-reset-view-wrap .a-map-zoom-cluster{margin-right:4px}
.a-map-zoom-glass{
  flex-shrink:0;color:rgba(240,168,74,0.92);opacity:0.95;display:block;margin-right:1px;
  pointer-events:none;
  filter:drop-shadow(0 0 5px rgba(212,136,58,0.35))}
.a-map-zoom-btn{
  width:30px;height:30px;margin:0;display:inline-flex;align-items:center;justify-content:center;
  padding:5px;
  font-family:'IBM Plex Mono',monospace;font-size:15.84px;font-weight:500;line-height:1;
  color:rgba(252,236,200,0.95);background:rgba(212,136,58,0.14);
  border:1px solid rgba(212,168,90,0.45);border-radius:5px;cursor:pointer;
  pointer-events:auto;touch-action:manipulation;
  transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease}
.a-map-zoom-btn:hover{
  background:rgba(212,168,90,0.22);border-color:rgba(240,185,95,0.65);
  box-shadow:0 0 10px rgba(212,136,58,0.25)}
.a-map-zoom-btn:active{transform:scale(0.96)}
.a-map-zoom-pct{
  min-width:48px;margin-right:8px;padding:2px 8px;text-align:center;
  font-family:'IBM Plex Mono',monospace;font-size:12.375px;font-weight:600;line-height:1;
  color:rgba(236,172,88,0.58);
  letter-spacing:.45px;user-select:none;
  text-shadow:0 0 12px rgba(212,136,58,0.2),0 1px 1px rgba(0,0,0,0.28);
}
.a-big-year{font-family:'Playfair Display',serif;font-size:59.4px;font-weight:700;line-height:1;
  color:rgba(200,180,140,.25);position:absolute;top:12px;right:16px;z-index:16;pointer-events:none;letter-spacing:-1px;text-align:right}
.a-lbl{font-size:9.9px;letter-spacing:2px;text-transform:uppercase;color:rgba(92,90,88,0.65);
  display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.a-yr-val{font-family:'Playfair Display',serif;font-size:19.8px;color:var(--cream)}
.a-slider{-webkit-appearance:none;width:100%;height:2px;background:var(--wfts-c-stone-25);border-radius:2px;cursor:pointer}
.a-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;
  background:#8a8884;box-shadow:0 0 8px var(--wfts-c-mute-40)}
.a-pb{display:flex;gap:4px}
.a-play{flex:1;background:linear-gradient(135deg,#4a4846,#3a3836);border:1px solid var(--wfts-c-mute-35);
  border-radius:5px;color:#c8c4b8;font-family:'IBM Plex Mono',monospace;font-size:11.1375px;font-weight:500;
  letter-spacing:1px;padding:7px;cursor:pointer;transition:background .2s,border-color .2s,color .2s,box-shadow .2s}
.a-play:not(.playing):hover{
  color:var(--amber2);
  border-color:rgba(212,168,90,0.58);
  background:linear-gradient(135deg,rgba(82,62,38,0.95),rgba(52,40,26,0.98));
  box-shadow:0 0 12px rgba(212,136,58,0.22)}
.a-play.playing{background:linear-gradient(145deg,rgba(180,120,45,0.95),rgba(120,75,22,0.98));
  border-color:rgba(240,185,95,0.65);color:#fff8e8;box-shadow:0 0 14px var(--wfts-c-amberdeep-35)}
.a-play.playing:hover{border-color:rgba(250,210,140,0.75);box-shadow:0 0 18px var(--wfts-c-amberdeep-45)}
.a-scope-pills{display:flex;gap:3px;margin-bottom:4px}
.a-scope-pill{flex:1;background:var(--wfts-c-surface-40);border:1px solid var(--wfts-c-stone-18);color:var(--muted);
  font-family:'IBM Plex Mono',monospace;font-size:8.6625px;padding:4px 2px;border-radius:4px;
  cursor:pointer;transition:all .15s;letter-spacing:.3px;text-align:center}
.a-scope-pill.on{border-color:#8a8884;color:#8a8884;background:rgba(138,136,132,.08)}
.a-scope-pill:hover{border-color:var(--wfts-c-mute-35);color:var(--cream)}
.a-yr-pick{display:flex;align-items:center;gap:5px;margin-bottom:4px}
.a-yr-pick select{background:var(--wfts-c-surface-50);border:1px solid var(--wfts-c-stone-25);color:var(--text);
  font-family:'IBM Plex Mono',monospace;font-size:12.375px;padding:4px 6px;border-radius:4px;
  flex:1;outline:none;cursor:pointer;appearance:auto}
.a-yr-pick select:focus{border-color:#8a8884}
.a-yr-pick label{font-size:8.6625px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.a-legend{display:flex;flex-direction:column;gap:3px}
/* Atlas species row: R / S / I — key hints (tooltips on letters + matching title on each button in JS) */
.a-legend-instructions{
  margin:0 0 6px;
  padding:5px 7px 6px;
  font-family:'IBM Plex Mono',monospace;
  font-size:8.6625px;
  line-height:1.45;
  letter-spacing:0.04em;
  color:rgba(212,184,138,0.72);
  background:rgba(8,10,8,0.35);
  border:1px solid rgba(138,136,132,0.2);
  border-radius:4px;
  box-sizing:border-box}
.a-legend-instructions-tail{
  color:rgba(138,136,132,0.65);
  letter-spacing:0.02em;
  font-weight:400}
.a-legend-keyhint{
  display:inline;
  cursor:help;
  color:rgba(212,168,90,0.92);
  font-weight:600;
  text-decoration:underline dotted rgba(212,168,90,0.35);
  text-underline-offset:2px}
.a-legend-keyhint:hover{
  color:rgba(252,236,200,0.96);
  text-decoration-color:rgba(212,168,90,0.55)}
.a-legend-keysep{
  color:rgba(138,136,132,0.55);
  margin:0 0.15em;
  font-weight:400;
  text-decoration:none;
  cursor:default}
.a-item{display:flex;align-items:center;gap:5px;padding:4px 7px;border-radius:4px;
  background:var(--wfts-c-surface-40);border:1px solid var(--wfts-c-stone-18);cursor:pointer;user-select:none;font-size:11.1375px}
.a-item.off{opacity:.22}
.a-item.solo{border-color:#8a8884;background:rgba(138,136,132,.08)}
.a-item.inat-solo{
  box-shadow:inset 0 0 0 1px rgba(130,175,210,0.28),0 0 12px rgba(100,155,195,0.08)}
.a-item.solo.inat-solo{
  box-shadow:inset 0 0 0 1px rgba(130,175,210,0.22),inset 0 -1px 0 0 rgba(138,136,132,0.15)}
.a-solo-btn.on{background:rgba(200,168,78,0.2);border-color:rgba(200,168,78,0.5);color:var(--amber)}
.a-solo-btn{background:none;border:1px solid #8a8884;color:#8a8884;
  font-family:'IBM Plex Mono',monospace;font-size:8.6625px;padding:1px 4px;border-radius:3px;
  cursor:pointer;letter-spacing:.5px;line-height:1;flex-shrink:0;
  transition:color .18s ease,border-color .18s ease,background-color .18s ease,box-shadow .18s ease,filter .18s ease}
.a-solo-btn:hover{
  border-color:rgba(212,168,90,0.72);
  color:rgba(252,236,200,0.96);
  background:rgba(212,168,90,0.1);
  box-shadow:0 0 0 1px rgba(212,168,90,0.2),0 0 14px rgba(212,168,90,0.32),0 0 28px rgba(212,168,90,0.12);
  filter:drop-shadow(0 0 6px rgba(212,168,90,0.25))}
.a-solo-btn.on:hover{
  background:rgba(212,168,90,0.26);
  border-color:rgba(212,168,90,0.78);
  color:rgba(255,244,214,0.98);
  box-shadow:0 0 0 1px rgba(212,168,90,0.28),0 0 16px rgba(212,168,90,0.38),0 0 30px rgba(212,168,90,0.14)}
.a-solo-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(212,168,90,0.35),0 0 14px rgba(212,168,90,0.28)}
.a-item.solo .a-solo-btn.on{background:rgba(200,168,78,0.2);border-color:rgba(200,168,78,0.5);color:var(--amber)}
.a-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.a-name{
  color:var(--text);flex:1;font-size:11.1375px;
  transition:color .18s ease,text-shadow .18s ease,filter .18s ease}
.a-item:not(.off) .a-name:hover{
  color:rgba(252,236,200,0.96);
  text-shadow:0 0 14px rgba(212,168,90,0.38),0 0 26px rgba(212,168,90,0.16);
  filter:drop-shadow(0 0 5px rgba(212,168,90,0.22))}
.a-item.off .a-name:hover{
  color:rgba(220,200,170,0.55);
  text-shadow:0 0 10px rgba(212,168,90,0.2)}
.a-box{background:var(--wfts-c-surface-40);border:1px solid var(--wfts-c-stone-18);border-radius:5px;padding:8px}
.a-stat{display:flex;align-items:center;gap:5px;font-size:11.1375px;padding:1px 0}
.a-snd-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.a-snd-btn{background:var(--wfts-c-surface-50);border:1px solid var(--wfts-c-stone-20);color:var(--muted);
  font-family:'IBM Plex Mono',monospace;font-size:9.9px;padding:2px 6px;border-radius:3px;cursor:pointer}
.a-snd-btn.on{background:var(--wfts-c-mute-12);border-color:#8a8884;color:#8a8884}
.a-now{font-size:9.9px;color:#8a8884;margin-top:3px;min-height:12px}
.a-load{font-size:12.375px;color:var(--muted);text-align:center;padding:20px;font-style:italic}
@media(max-width:860px){.tabs{padding:0 12px 0 6px}
  .atlas-map-viewport{border-radius:0}
  .a-map-bottom-bar{bottom:8px;left:8px;right:8px}
  .a-map-left-rail{width:min(260px,calc(100vw - 120px));bottom:64px;padding:8px 10px}
  .a-map-zoom-cluster{padding:5px;gap:4px}
  .a-map-zoom-btn{width:28px;height:28px;padding:5px;font-size:14.52px}
  .a-map-zoom-pct{min-width:44px;margin-right:6px;padding:2px 6px;font-size:11.55px}}
.a-tooltip{position:fixed;background:rgba(28,27,26,0.6);border:1px solid var(--wfts-c-stone-35);
  border-radius:5px;padding:8px 11px;font-size:11.1375px;color:var(--text);pointer-events:none;
  opacity:0;transition:opacity .15s;z-index:100;max-width:300px;line-height:1.5;
  box-shadow:0 4px 20px rgba(0,0,0,.6);backdrop-filter:blur(8px)}
.a-tooltip.visible{opacity:1}
.a-mode-pills{display:flex;gap:3px;margin-bottom:6px}
.a-mode-pill{flex:1;background:var(--wfts-c-surface-40);border:1px solid var(--wfts-c-stone-18);color:var(--muted);
  font-family:'IBM Plex Mono',monospace;font-size:8.6625px;padding:5px 3px;border-radius:4px;
  cursor:pointer;transition:all .15s;letter-spacing:.5px;text-transform:uppercase;text-align:center}
.a-mode-pill.on{border-color:#8a8884;color:#8a8884;background:rgba(138,136,132,.08)}
.a-mode-pill:hover{border-color:var(--wfts-c-mute-35);color:var(--cream)}
.a-viz-pills{display:flex;gap:4px;margin-bottom:6px}
.a-viz-pill{background:var(--surface2);border:1px solid var(--border);color:var(--muted);
  font-size:11.1375px;padding:5px 10px;border-radius:5px;cursor:pointer}
.a-viz-pill.on{border-color:var(--amber);color:var(--amber)}
.a-layers{margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--wfts-c-stone-12)}
.a-layers-title{font-size:8.6625px;letter-spacing:2px;text-transform:uppercase;color:rgba(92,90,88,0.5);margin-bottom:4px}
/* Atlas dock: layer toggles in one horizontal run */
.atlas-history-dock .a-layers{display:flex;flex-flow:row wrap;align-items:center;gap:4px 10px;margin:0;padding:0;border:none;border-bottom:none;flex:1 1 200px;min-width:0}
.atlas-history-dock .a-layer-row{flex-shrink:0;padding:2px 4px;white-space:nowrap}
.a-layer-row{display:flex;align-items:center;gap:5px;padding:2px 1px;cursor:pointer;font-size:9.9px;color:var(--cream);
  transition:all .15s;border-radius:3px}
.a-layer-row:hover{background:rgba(138,136,132,.04);color:var(--text)}
.a-layer-chk{width:12px;height:12px;border-radius:2px;border:1px solid var(--wfts-c-stone-25);background:var(--wfts-c-surface-50);
  display:flex;align-items:center;justify-content:center;font-size:9.9px;transition:all .15s;flex-shrink:0}
.a-layer-chk.on{background:rgba(138,136,132,.25);border-color:#8a8884;color:#8a8884}
.a-timeline-track{pointer-events:auto;position:relative;cursor:pointer}
.a-playhead-hit{position:absolute;top:-8px;height:18px;width:14px;margin-left:-7px;cursor:grab;z-index:2;display:flex;align-items:center;justify-content:center;transition:left .12s ease-out}
html.wfts-atlas-anim-off #panel-historical .a-playhead-hit{transition:none}
/* UI animation off: freeze decorative/CSS motion on History map + Compare chart. */
html.wfts-atlas-anim-off #panel-historical #a-svg .a-route-line{
  animation:none;
  stroke-dasharray:none;
  stroke:rgba(212,168,90,0.58)}
html.wfts-atlas-anim-off #panel-historical #a-nature-centers .a-nature-center-dot{
  animation:none;
  opacity:0.92;
  transform:none}
html.wfts-atlas-anim-off #panel-historical #a-gps-svg #a-gps-dot{
  animation:none;
  filter:none!important}
html.wfts-atlas-anim-off #panel-historical #a-gps-svg .a-gps-core,
html.wfts-atlas-anim-off #panel-historical #a-gps-svg .a-gps-halo,
html.wfts-atlas-anim-off #panel-historical #a-gps-svg .a-gps-acc{
  animation:none;
  opacity:1}
html.wfts-atlas-anim-off #panel-historical .atlas-map-viewport .ac{
  transition:none}
html.wfts-atlas-anim-off #panel-historical .a-waveform-panel svg,
html.wfts-atlas-anim-off #panel-historical .a-waveform-panel svg *{
  transition:none!important;
  animation:none!important}
.a-playhead-hit:active,.a-playhead-hit.dragging{cursor:grabbing}
.a-playhead-hit .a-cur-inner{position:absolute;width:2px;height:10px;background:var(--amber2);border-radius:1px;box-shadow:0 0 8px rgba(240,168,74,.8)}
/* What's calling now */
.wcn-banner{display:none;background:rgba(70,68,66,.1);border:1px solid var(--wfts-c-stone-25);border-radius:7px;padding:11px}
.wcn-banner.visible{display:block}
.wcn-title{font-size:11.1375px;letter-spacing:2px;text-transform:uppercase;color:#8a8884;margin-bottom:6px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.wcn-title::before{content:'◉';font-size:8.6625px;animation:wcn-pulse 2s ease-in-out infinite}
.wcn-play{background:var(--wfts-c-stone-25);border:1px solid var(--wfts-c-mute-40);border-radius:4px;color:#8a8884;font-size:9.9px;padding:3px 8px;cursor:pointer;font-family:'IBM Plex Mono',monospace}
.wcn-play:hover{background:rgba(138,136,132,.35)}
@keyframes wcn-pulse{0%,100%{opacity:1}50%{opacity:.3}}
.wcn-body{font-size:12.375px;color:var(--muted);line-height:1.6}
.wcn-body strong{color:var(--cream);font-weight:400}
.wcn-species{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.wcn-sp{font-size:11.1375px;padding:3px 7px;border-radius:4px;border:1px solid;display:flex;align-items:center;gap:4px}
.wcn-sp.active{background:var(--wfts-c-mute-12);border-color:rgba(138,136,132,.35);color:#8a8884}
.wcn-sp.inactive{background:var(--surface);border-color:var(--border);color:var(--muted);opacity:.5}
/* ── NEW PAGES ── */
.page-scroll{max-width:820px;margin:0 auto;padding:32px 28px;overflow-y:auto;max-height:calc(100vh - var(--wfts-layout-chrome))}
/* Default h2 in scroll pages (overridden inside .tab-panel for icon+title row) */
.page-scroll h2{font-family:'Playfair Display',serif;font-size:32.175px;font-weight:400;color:var(--cream);margin-bottom:6px}
.page-scroll h3{font-family:'Playfair Display',serif;font-size:22.275px;font-weight:400;color:#8a8884;margin:22px 0 8px}
.page-scroll p,.page-scroll li{font-size:14.85px;color:var(--muted);line-height:1.8;margin-bottom:10px}
.page-scroll ul{list-style:none;padding-left:0}
.page-scroll li::before{content:'◈ ';color:rgba(58,110,53,0.5);font-size:9.9px}
.page-scroll strong{color:var(--cream);font-weight:500}
.page-scroll em{color:#8a8884;font-style:italic}
.page-scroll .warn-box{background:rgba(192,96,80,.08);border:1px solid rgba(192,96,80,.2);
  border-radius:8px;padding:14px 16px;margin:14px 0}
.page-scroll .warn-box strong{color:#e08070}
.page-scroll .info-box{background:rgba(70,68,66,.08);border:1px solid var(--wfts-c-stone-20);
  border-radius:8px;padding:14px 16px;margin:14px 0}
.page-scroll .divider{border:none;border-top:1px solid var(--wfts-c-stone-15);margin:24px 0}
/* Contact — single mailto CTA */
#panel-contact > .page-scroll{
  max-width:min(900px,96vw);
  width:100%;
  margin:0 auto;
  box-sizing:border-box;
  padding:28px max(16px,2.5vw) calc(44px + env(safe-area-inset-bottom,0px));
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  max-height:none;
  flex:1;
  min-height:0}
#panel-contact.tab-panel.active{
  display:flex;
  flex-direction:column;
  min-height:0;
  overflow:visible}
#panel-contact .contact-email-wrap{
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  max-width:min(720px,100%);
  margin:clamp(12px,2.5vw,28px) auto 0}
/* Forecast hero title voice — same Playfair scale + opacity wave as “Frog Night” on the countdown card */
#panel-contact .contact-email-link{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:0;
  box-sizing:border-box;
  padding:clamp(8px,2vw,16px) 12px;
  font-family:'Playfair Display',serif;
  font-size:clamp(25.9875px,3.8363vw,37.125px);
  font-weight:400;
  line-height:1.15;
  text-align:center;
  text-decoration:none;
  color:var(--cream);
  overflow-wrap:anywhere;
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  transition:color .22s ease,opacity .22s ease;
  max-width:100%}
#panel-contact .contact-email-link .contact-email-wave.wave-words span{
  display:inline-block;
  opacity:0.35;
  animation:wordOpacityWave 10.5s ease-in-out infinite;
  animation-delay:calc(var(--i,0) * 0.38s)}
#panel-contact .contact-email-link .contact-email-at{
  padding:0 0.03em}
#panel-contact .contact-email-link:hover{
  color:var(--amber2)}
#panel-contact .contact-email-link:focus{outline:none}
#panel-contact .contact-email-link:focus-visible{
  box-shadow:0 0 0 2px rgba(212,168,90,0.42);
  border-radius:4px}
@media (prefers-reduced-motion:reduce){
  #panel-contact .contact-email-link{transition-duration:.01ms}
  #panel-contact .contact-email-link .contact-email-wave.wave-words span{
    animation:none;
    opacity:0.92}}
#panel-contact > .page-scroll > p:first-of-type{
  text-align:center;
  max-width:42em;
  margin-left:auto;
  margin-right:auto}
#panel-contact .contact-get-involved-lead{
  text-align:center;
  max-width:42em;
  margin:clamp(8px,2vw,16px) auto 0;
  font-size:12.8px;
  line-height:1.42;
  color:rgba(138,136,132,0.92)}
#panel-contact .contact-newsletter{
  margin:clamp(8px,2vw,16px) auto 0;
  padding:clamp(4px,1vw,8px) 0 0;
  text-align:center}
/* Contact: Spring Peeper + 30× lace overlay — same behavior as forecast PCC hero */
#panel-contact .contact-peeper-stack.pcc-logo-wrap{
  display:flex;align-items:center;justify-content:center;
  width:clamp(84px,14vw,128px);max-width:100%;aspect-ratio:1;height:auto;min-width:0;min-height:0;
  margin:0 auto 10px;cursor:pointer;animation:none;
  -webkit-tap-highlight-color:transparent}
#panel-contact .contact-peeper-stack .pcc-logo-motion{
  position:relative;display:block;width:100%;aspect-ratio:1;max-height:100%;
  flex:1 1 auto;min-width:0;min-height:0;
  transform-origin:center center;will-change:transform;
  transition:transform 0.55s cubic-bezier(0.22,1,0.36,1)}
#panel-contact .contact-peeper-stack .pcc-logo-30x{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;overflow:visible;
  filter:blur(var(--pcc-30x-blur,0px));
  opacity:0;
  transition:opacity 0.28s ease,filter 0.1s linear}
#panel-contact .contact-peeper-stack.pcc-logo-wrap.pcc-logo-wrap--30x-mouse .pcc-logo-30x,
#panel-contact .contact-peeper-stack.pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo-30x{
  opacity:1}
#panel-contact .contact-peeper-stack .pcc-logo-30x-path--lace{
  fill:none;
  stroke:rgba(255,220,165,0.9);
  stroke-linecap:round;stroke-linejoin:round;
  stroke-width:var(--pcc-30x-trace-stroke,1.1);
  stroke-dasharray:var(--pcc-30x-dash,none);
  stroke-dashoffset:var(--pcc-30x-trace-len,0);
  opacity:0}
#panel-contact .contact-peeper-stack .pcc-logo-30x-path--lace.pcc-30x-tracing{
  opacity:1;
  animation:pcc30xLaceTrace var(--pcc-30x-trace-dur,1s) var(--pcc-30x-trace-ease,ease-out) forwards}
@media (prefers-reduced-motion:reduce){
  #panel-contact .contact-peeper-stack .pcc-logo-30x-path--lace.pcc-30x-tracing{
    animation:none;stroke-dashoffset:0;opacity:0.22}}
#panel-contact .contact-peeper-stack .pcc-logo{
  display:block;flex-shrink:0;box-sizing:border-box;
  width:100%;height:100%;max-width:100%;max-height:100%;margin:0;
  object-fit:contain;object-position:center center;
  mix-blend-mode:normal;opacity:1;
  transform-origin:center center;
  animation:none;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,0.3));
  transition:filter 0.45s ease,opacity 0.45s ease}
@media (prefers-reduced-motion:reduce){
  #panel-contact .contact-peeper-stack .pcc-logo{
    filter:drop-shadow(0 8px 22px rgba(0,0,0,0.3))}}
body.loaded #panel-contact .contact-peeper-stack:hover .pcc-logo-motion,
body.loaded #panel-contact .contact-peeper-stack:focus-visible .pcc-logo-motion,
body.loaded #panel-contact .contact-peeper-stack.pcc-logo-wrap--hovering .pcc-logo-motion,
body.loaded #panel-contact .contact-peeper-stack.pcc-logo-wrap--pcc-call-active .pcc-logo-motion{
  transform:scale(1.16) translate3d(var(--pcc-shake-x,0px),var(--pcc-shake-y,0px),0) rotate(var(--pcc-shake-r,0deg))}
body.loaded #panel-contact .contact-peeper-stack.pcc-logo-wrap--hovering:not(.pcc-logo-wrap--pcc-call-active) .pcc-logo-motion{
  animation:pccLogoHoverWobble 2.2s ease-in-out infinite}
body.loaded #panel-contact .contact-peeper-stack:focus-visible:not(:hover) .pcc-logo,
body.loaded #panel-contact .contact-peeper-stack.pcc-logo-wrap--pcc-call-active:not(:hover) .pcc-logo{
  animation:none;
  filter:
    blur(var(--pcc-call-blur,0px))
    drop-shadow(0 0 6px rgba(248,210,150,0.32))
    drop-shadow(0 8px 22px rgba(0,0,0,0.3))}
body.loaded #panel-contact .contact-peeper-stack:hover .pcc-logo,
body.loaded #panel-contact .contact-peeper-stack.pcc-logo-wrap--pcc-call-active:hover .pcc-logo{
  animation:none;
  filter:
    blur(var(--pcc-call-blur,0px))
    drop-shadow(0 0 8px rgba(248,210,150,0.42))
    drop-shadow(0 0 18px rgba(212,168,90,0.26))
    drop-shadow(0 8px 22px rgba(0,0,0,0.3))}
#panel-contact .contact-peeper-stack.pcc-logo-wrap--pcc-call-active{animation:none}
#panel-contact .contact-peeper-stack.pcc-logo-wrap--pcc-call-active .pcc-logo-motion{
  transition:transform 0.08s linear}
#panel-contact .contact-peeper-stack.pcc-logo-wrap--pcc-call-active .pcc-logo{
  transition:opacity 0.45s ease,filter 0.45s ease}
#panel-contact .contact-peeper-stack .contact-newsletter-peeper,
#panel-contact .contact-peeper-stack .pcc-logo--peeper{
  user-select:none;-webkit-user-drag:none;pointer-events:none}
#panel-contact .contact-peeper-stack.pcc-logo-wrap:focus-visible{
  outline:2px solid rgba(212,168,90,0.45);outline-offset:4px;border-radius:10px}
#panel-contact .contact-newsletter-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(15.5px,2.05vw,22px);
  font-weight:400;
  color:inherit;
  letter-spacing:0.02em;
  margin:0 0 6px;
  line-height:1.14;
  text-transform:none}
#panel-contact .contact-newsletter-title::before{
  content:'';
  display:inline-block;
  margin-right:0;
  font-size:0;
  color:transparent;
  vertical-align:0}
#panel-contact .contact-newsletter-lead{
  max-width:36em;
  margin:0 auto 12px;
  font-size:12.5px;
  line-height:1.42;
  color:rgba(138,136,132,0.92)}
/* MailerLite embed — panel + HUD inputs (same voice as predictor / compare) */
#panel-contact .contact-newsletter-form-card{
  max-width:min(300px,92vw);
  margin:0 auto;
  padding:clamp(9px,1.8vw,13px) clamp(10px,2vw,14px) clamp(11px,2.2vw,15px);
  box-sizing:border-box;
  text-align:left;
  color-scheme:dark;
  border:1px solid rgba(212,168,90,0.45);
  border-radius:7px;
  background:transparent;
  background-size:auto;
  box-shadow:0 0 0 1px rgba(212,168,90,0.12) inset,0 0 12px rgba(212,168,90,0.18)}
#panel-contact .contact-newsletter .ml-embedded{
  width:100%;
  max-width:none;
  margin:0;
  min-height:72px}
#panel-contact .contact-newsletter-form-card iframe{
  width:100%!important;
  max-width:100%;
  min-height:148px;
  border:none!important;
  border-radius:5px;
  background:transparent!important}
#panel-contact .contact-newsletter-form-card .ml-form-embedContainer,
#panel-contact .contact-newsletter-form-card .ml-form-embedWrapper,
#panel-contact .contact-newsletter-form-card .ml-form-embedBody{
  background:transparent!important}
#panel-contact .contact-newsletter-form-card h1,
#panel-contact .contact-newsletter-form-card h2,
#panel-contact .contact-newsletter-form-card h3,
#panel-contact .contact-newsletter-form-card .ml-form-title,
#panel-contact .contact-newsletter-form-card .ml-form-description{
  display:none!important}
/* Hide any embed intro copy above the actual form fields/button. */
#panel-contact .contact-newsletter-form-card .ml-form-embedBody > :not(form){
  display:none!important}
#panel-contact .contact-newsletter-form-card form{
  display:flex;
  flex-direction:column;
  gap:0;
  align-items:stretch;
  margin:0;
  padding:0}
#panel-contact .contact-newsletter-form-card label,
#panel-contact .contact-newsletter-form-card .ml-form-label{
  font-family:'IBM Plex Mono',monospace;
  font-size:8.8px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(138,136,132,0.78);
  font-weight:500;
  line-height:1.35}
#panel-contact .contact-newsletter-form-card p,
#panel-contact .contact-newsletter-form-card .ml-form-description{
  font-family:'IBM Plex Mono',monospace;
  font-size:12.375px;
  line-height:1.55;
  color:rgba(200,194,178,0.82);
  margin:0 0 12px}
#panel-contact .contact-newsletter-form-card input[type="email"],
#panel-contact .contact-newsletter-form-card input[type="text"],
#panel-contact .contact-newsletter-form-card input[type="tel"],
#panel-contact .contact-newsletter-form-card textarea{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  margin:3px 0 8px;
  padding:6px 9px;
  border-radius:8px;
  border:1px solid var(--wfts-c-stone-22);
  background:rgba(12,11,10,0.52);
  color:var(--text);
  font-family:'IBM Plex Mono',monospace;
  font-size:11.25px;
  outline:none;
  transition:border-color .2s ease,box-shadow .2s ease}
#panel-contact .contact-newsletter-form-card textarea{
  min-height:64px;
  resize:vertical}
#panel-contact .contact-newsletter-form-card input::placeholder,
#panel-contact .contact-newsletter-form-card textarea::placeholder{
  color:rgba(138,136,132,0.45)}
#panel-contact .contact-newsletter-form-card input:hover,
#panel-contact .contact-newsletter-form-card textarea:hover{
  border-color:rgba(92,90,88,0.38)}
#panel-contact .contact-newsletter-form-card input:focus,
#panel-contact .contact-newsletter-form-card textarea:focus{
  border-color:var(--wfts-c-mute-50);
  box-shadow:0 0 0 3px var(--wfts-c-stone-15)}
#panel-contact .contact-newsletter-form-card input[type="checkbox"],
#panel-contact .contact-newsletter-form-card input[type="radio"]{
  width:auto;
  margin:0 8px 0 0;
  accent-color:rgba(212,168,90,0.88);
  vertical-align:0.12em}
#panel-contact .contact-newsletter-form-card .ml-form-checkbox-row,
#panel-contact .contact-newsletter-form-card label:has(input[type="checkbox"]){
  display:flex;
  align-items:flex-start;
  gap:0;
  font-size:12px;
  letter-spacing:0.04em;
  text-transform:none;
  color:rgba(200,194,178,0.88);
  margin-bottom:12px;
  line-height:1.45}
#panel-contact .contact-newsletter-form-card button[type="submit"],
#panel-contact .contact-newsletter-form-card input[type="submit"]{
  width:100%;
  margin-top:2px;
  padding:8px 12px;
  border-radius:9px;
  border:1px solid rgba(176,118,24,0.92);
  background:linear-gradient(180deg,rgba(238,180,82,0.98) 0%,rgba(214,145,41,0.96) 100%);
  color:rgba(34,19,3,0.96);
  font-family:'IBM Plex Mono',monospace;
  font-size:9.5px;
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .22s ease,border-color .22s ease,transform .2s ease,box-shadow .22s ease,color .2s ease;
  backdrop-filter:blur(14px) saturate(1.12);
  -webkit-backdrop-filter:blur(14px) saturate(1.12);
  box-shadow:0 0 0 1px rgba(255,222,165,0.24) inset,0 4px 14px rgba(170,103,20,0.22)}
#panel-contact .contact-newsletter-form-card button[type="submit"]:hover,
#panel-contact .contact-newsletter-form-card input[type="submit"]:hover{
  background:linear-gradient(180deg,rgba(249,194,95,1) 0%,rgba(226,157,50,0.98) 100%);
  border-color:rgba(190,124,20,0.98);
  color:rgba(26,14,2,0.96);
  transform:translateY(-1px);
  box-shadow:0 0 0 1px rgba(255,232,183,0.3) inset,0 9px 24px rgba(184,111,24,0.34)}
#panel-contact .contact-newsletter-form-card button[type="submit"]:active,
#panel-contact .contact-newsletter-form-card input[type="submit"]:active{
  transform:translateY(0)}
#panel-contact .contact-newsletter-form-card button[type="submit"]:focus-visible,
#panel-contact .contact-newsletter-form-card input[type="submit"]:focus-visible{
  outline:2px solid rgba(212,168,90,0.45);
  outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  #panel-contact .contact-newsletter-form-card button[type="submit"]:hover,
  #panel-contact .contact-newsletter-form-card input[type="submit"]:hover{
    transform:none}}
#panel-contact .get-involved-cta-wrap{
  width:100%;
  display:flex;
  justify-content:center;
  margin:clamp(12px,2vw,18px) auto 0}
#panel-compare.tab-panel.active{
  display:flex;
  flex-direction:column;
  min-height:0;
  overflow:visible;
}
#panel-compare > .page-scroll{
  max-width:min(1920px,98vw);
  width:100%;
  box-sizing:border-box;
  padding:12px max(12px,2.2vw) calc(34px + env(safe-area-inset-bottom,0px));
  margin:0 auto;
  overflow-x:hidden;
  overflow-y:auto;
  flex:1;
  min-height:0;
  max-height:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
#panel-compare .compare-lead{
  font-size:11px;
  line-height:1.45;
  color:var(--muted);
  margin:0 0 2px;
  max-width:56em;
}
#panel-compare .compare-controls{
  position:relative;
  z-index:6;
  display:flex;flex-wrap:wrap;align-items:flex-end;gap:clamp(8px,1.4vw,14px);
  margin:4px 0 6px;padding:10px 12px;
  background:rgba(14,13,10,0.55);border:1px solid rgba(92,90,88,0.22);border-radius:8px;
  box-sizing:border-box}
#panel-compare .compare-ab-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(240px,1fr));
  gap:10px;
  flex:1 1 100%;
}
#panel-compare .compare-ab-col{
  border:1px solid rgba(92,90,88,0.22);
  border-radius:7px;
  padding:8px;
  background:rgba(10,9,8,0.22);
  display:grid;
  gap:6px;
}
#panel-compare .compare-ab-col:first-child{
  border-color:rgba(86,228,140,0.55);
  box-shadow:0 0 0 1px rgba(86,228,140,0.1) inset;
}
#panel-compare .compare-ab-hdr{
  margin:0 0 2px;
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;
  letter-spacing:0.16em;
  color:rgba(240,185,95,0.86);
}
#panel-compare .compare-ab-col:first-child .compare-ab-hdr{
  color:rgba(120,235,175,0.96);
}
#panel-compare .compare-point{
  display:flex;flex-direction:column;gap:4px;min-width:min(168px,42vw)}
#panel-compare .compare-point label{
  font-family:'IBM Plex Mono',monospace;font-size:7.5px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(212,168,90,0.72)}
#panel-compare .compare-ab-col:first-child .compare-point label{
  color:rgba(130,230,185,0.94);
}
#panel-compare .compare-ab-col:last-child .compare-point label[for="cmp-b-species"]{
  color:rgba(240,176,84,0.95);
}
#panel-compare .compare-point select{
  position:relative;
  z-index:7;
  background:var(--wfts-c-surface-50);border:1px solid var(--wfts-c-stone-25);color:var(--text);
  border-radius:5px;padding:5px 8px;font-family:'IBM Plex Mono',monospace;font-size:11px;cursor:pointer;min-width:7em}
#panel-compare .compare-ab-col:first-child .compare-point select{
  color:rgba(198,248,218,0.96);
  border-color:rgba(86,228,140,0.52);
  box-shadow:0 0 0 1px rgba(86,228,140,0.16) inset;
}
#panel-compare #cmp-b-species{
  border-color:rgba(240,176,84,0.46);
  box-shadow:0 0 0 1px rgba(240,176,84,0.14) inset;
}
#panel-compare .compare-metric-row{
  min-width:min(220px,88vw);
  flex:1 1 200px}
#panel-compare .compare-metric-row select{
  width:100%;
  min-width:0;
  box-sizing:border-box}
#panel-compare .compare-actions{align-self:flex-end}
#panel-compare .compare-run-btn{
  background:linear-gradient(145deg,rgba(120,82,32,0.95),rgba(70,48,18,0.98));border:1px solid rgba(240,185,95,0.45);
  border-radius:5px;color:#fff4e0;font-family:'IBM Plex Mono',monospace;font-size:10px;padding:6px 14px;cursor:pointer;letter-spacing:0.06em;
  transition:filter .18s ease,box-shadow .22s ease,border-color .18s ease,transform .1s ease}
#panel-compare .compare-run-btn:hover{
  filter:brightness(1.12);
  border-color:rgba(255,214,160,0.72);
  box-shadow:0 0 0 1px rgba(212,168,90,0.35),0 0 20px rgba(212,136,58,0.38),0 0 36px rgba(240,185,95,0.22)}
#panel-compare .compare-run-btn:active{
  transform:scale(0.98);
  filter:brightness(1.06);
  box-shadow:0 0 0 1px rgba(212,168,90,0.5),0 0 14px rgba(212,136,58,0.45)}
#panel-compare .compare-run-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(10,9,8,0.92),0 0 0 4px rgba(212,168,90,0.55),0 0 22px rgba(240,185,95,0.35)}
@media(max-width:920px){
  #panel-compare .compare-ab-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  #panel-compare .compare-run-btn{transition-duration:0.01ms}
  #panel-compare .compare-run-btn:active{transform:none}}
#panel-compare .compare-chart-stage{
  position:relative;
  z-index:1;
  position:relative;
  width:100%;
  max-width:100%;
  margin:0;
  box-sizing:border-box;
  flex:0 1 auto;
  min-height:0;
  max-height:min(280px,calc(100svh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve) - 300px));
  padding:8px 10px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(rgba(255,255,255,0.028) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.028) 1px,transparent 1px),
    rgba(10,9,8,0.35);
  background-size:22px 22px,22px 22px,auto;
  border:1px solid rgba(92,90,88,0.16);
  border-radius:8px;
}
#panel-compare #compare-chart-host{
  position:relative;
  z-index:1;
  margin:0;
  width:100%;
  max-width:100%;
  min-height:0;
  max-height:min(260px,calc(100svh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve) - 318px));
  display:flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box}
#panel-compare .compare-chart-svg{
  width:100%;
  max-width:100%;
  max-height:100%;
  height:auto;
  display:block;
  margin:0 auto;
}
@media (prefers-reduced-motion:reduce){
  #panel-compare .compare-chart-svg .compare-chart-series,
  #panel-compare .compare-chart-svg .compare-chart-reg{
    filter:none!important}}
html.wfts-atlas-anim-off #panel-compare .compare-chart-svg .compare-chart-series,
html.wfts-atlas-anim-off #panel-compare .compare-chart-svg .compare-chart-reg,
html.wfts-atlas-anim-off #panel-compare .compare-chart-svg .compare-chart-series-a,
html.wfts-atlas-anim-off #panel-compare .compare-chart-svg .compare-chart-series-b{
  filter:none!important}
#panel-compare .compare-empty{font-size:11px;color:var(--muted);padding:10px}
#panel-compare #compare-summary{
  font-size:11px;color:rgba(200,192,172,0.82);line-height:1.45;max-width:56em;margin:2px 0 0}
#panel-compare .compare-notes{
  margin-top:6px;
  padding-top:8px;
  border-top:1px solid rgba(92,90,88,0.14);
  max-width:56em;
  flex:0 0 auto;
  min-height:0;
  max-height:none;
  overflow:visible;
  -webkit-overflow-scrolling:touch;
}
#panel-compare .compare-notes-hdr{
  font-family:'Playfair Display',serif;
  font-size:clamp(14px,1.6vw,17px);
  font-weight:400;
  color:var(--cream);
  margin:0 0 6px;
  letter-spacing:0.02em}
#panel-compare .compare-chart-node{
  will-change:transform;
}
/* Dot motion + polyline follow use JS (runCompare*Plexus); CSS-only jitter was double-moving vs paths */
#panel-compare .compare-chart-pt{
  filter:drop-shadow(0 0 3px rgba(240,185,95,0.2));
  will-change:transform;
}
#panel-compare .compare-chart-pt--soft{
  opacity:0.58;
}
#panel-compare .compare-chart-pt--key{
  opacity:0.98;
}
#panel-compare .compare-chart-pt circle{
  transform-origin:center;
  stroke:rgba(245,236,210,0.22);
  stroke-width:0.85;
}
#panel-compare .compare-chart-pt-a circle{
  filter:drop-shadow(0 0 6px rgba(86,228,140,0.32));
}
#panel-compare .compare-chart-pt-b circle{
  filter:drop-shadow(0 0 6px rgba(240,176,84,0.28));
}
#panel-compare .compare-chart-pt--soft circle{
  stroke:rgba(245,236,210,0.12);
  stroke-width:0.65;
}
#panel-compare .compare-chart-pt--key circle{
  stroke:rgba(250,238,204,0.56);
  stroke-width:1.05;
}
#panel-compare .compare-notes .compare-phenology-context{
  margin:0;padding:0;max-width:none}
#panel-compare .compare-phenology-context{
  margin:0 0 10px;padding:4px 0 2px;max-width:56em;
  background:transparent;border:none;border-radius:0;box-shadow:none}
#panel-compare .compare-phenology-hdr{
  font-family:'IBM Plex Mono',monospace;font-size:7.425px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--wfts-c-amber-55);margin:0 0 6px}
#panel-compare .compare-phenology-list{
  margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:4px}
#panel-compare .compare-phenology-list li{
  font-size:9px;line-height:1.38;color:rgba(200,194,178,0.78);margin:0;padding:0;list-style:none}
#panel-compare .compare-phenology-list li::before{content:none!important;display:none!important}
#panel-compare .compare-ph-label{
  display:block;font-family:'IBM Plex Mono',monospace;font-size:7.425px;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(138,136,132,0.68);margin-bottom:2px}
#panel-compare .compare-phenology-list strong{color:var(--wfts-c-text-95);font-weight:500}
#panel-compare .page-scroll > h2{
  font-size:clamp(22px,3.1vw,28px);
  margin:0 0 6px;
  gap:8px;
}
#panel-compare .page-scroll > h2::before{content:'⇄';color:rgba(212,168,90,0.88);font-size:clamp(17px,2.2vw,22px);margin-top:0.22em}
/* Field Guide: wide content width (match Compare). Global .page-scroll is 100vh−tabs only; subtract --wfts-footer-reserve so the inner scroller ends above the fixed amb bar (avoids bottom clip). */
#panel-guide > .page-scroll{
  position:relative;
  max-width:min(1920px,98vw);
  width:100%;
  box-sizing:border-box;
  padding:28px max(16px,2.5vw) calc(44px + env(safe-area-inset-bottom,0px));
  margin:0 auto;
  max-height:calc(100vh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  max-height:calc(100dvh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  /* Inset for scrollIntoView / focus — align with species dock + JS paddingTop base (via --fg-guide-pad-top-base) */
  scroll-padding-top:calc(var(--fg-guide-pad-top-base, 28px) + var(--fg-subnav-h, 0px) + 110px);
  scroll-padding-bottom:var(--wfts-footer-reserve)}
/* Field Guide — extra air around hr dividers between species blocks */
#panel-guide .page-scroll hr.divider{
  margin:clamp(26px,3.2vw,36px) max(10px,2vw);
}
/* Field Guide — fixed top-right toolbar under main nav (+ species dock when active) */
#panel-guide .fg-fib-spiral-rail{
  position:fixed;
  top:calc(var(--wfts-layout-chrome) + var(--fg-subnav-h, 0px) + 10px);
  right:max(14px,calc(10px + env(safe-area-inset-right,0px)));
  transform:none;
  z-index:150;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:6px;
  width:min(132px,calc(100vw - 28px));
  max-height:calc(100dvh - var(--wfts-layout-chrome) - var(--fg-subnav-h, 0px) - var(--wfts-footer-reserve) - 20px);
  max-height:calc(100svh - var(--wfts-layout-chrome) - var(--fg-subnav-h, 0px) - var(--wfts-footer-reserve) - 20px);
  padding:7px 6px 8px 8px;
  overflow-x:hidden;
  overflow-y:auto;
  border-radius:10px;
  background:rgba(12,11,9,0.88);
  border:1px solid rgba(212,168,90,0.2);
  box-shadow:0 6px 22px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,255,255,0.04);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  pointer-events:auto}
#panel-guide .fg-fib-spiral-rail__tools{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  align-items:stretch;
  justify-content:stretch;
  gap:5px}
/* Match Atlas dock layer rows (.a-layer-row + .a-layer-chk) */
#panel-guide .fg-fib-spiral-rail__toggles{
  display:flex;
  flex-direction:column;
  gap:2px;
  padding-top:4px;
  margin-top:2px;
  border-top:1px solid var(--wfts-c-stone-22)}
#panel-guide .fg-fib-spiral-rail__lbl{
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:flex-start;
  gap:5px;
  cursor:pointer;
  user-select:none;
  margin:0;
  padding:2px 4px;
  border-radius:3px;
  font-size:9.9px;
  color:var(--cream);
  transition:all .15s;
  font-family:'IBM Plex Mono',monospace}
#panel-guide .fg-fib-spiral-rail__lbl:hover{
  background:rgba(138,136,132,.04);
  color:var(--text)}
#panel-guide .fg-fib-spiral-rail__lbl:focus-within{
  outline:1px solid rgba(138,136,132,0.35);
  outline-offset:1px}
#panel-guide .fg-fib-spiral-rail__chk{
  order:0;
  position:relative;
  -webkit-appearance:none;
  appearance:none;
  box-sizing:border-box;
  width:12px;
  height:12px;
  margin:0;
  flex-shrink:0;
  border-radius:2px;
  border:1px solid var(--wfts-c-stone-25);
  background:var(--wfts-c-surface-50);
  cursor:pointer;
  transition:all .15s;
  padding:0}
#panel-guide .fg-fib-spiral-rail__chk:checked{
  background:rgba(138,136,132,.25);
  border-color:#8a8884;
  color:#8a8884}
#panel-guide .fg-fib-spiral-rail__chk:checked::after{
  content:'✓';
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-52%);
  font-size:9.9px;
  line-height:1;
  pointer-events:none}
#panel-guide .fg-fib-spiral-rail__text{
  order:1;
  flex:1;
  min-width:0;
  font-family:inherit;
  font-size:inherit;
  line-height:1.25;
  letter-spacing:0.02em;
  text-transform:none;
  color:inherit;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
#panel-guide .fg-fib-spiral-rail__lbl--grease-opt{
  color:var(--muted)}
#panel-guide .fg-fib-spiral-rail__lbl--grease-opt:hover{
  color:var(--text)}
#panel-guide .fg-fib-spiral-rail__lbl--grease-opt .fg-fib-spiral-rail__text{
  font-size:8.6625px}
#panel-guide .fg-fib-spiral-rail__lbl--grease-seq{
  padding-left:8px;
  opacity:0.95}
#panel-guide .fg-fib-spiral-rail__lbl--grease-seq .fg-fib-spiral-rail__text{
  font-size:8.25px}
/* Grease pencil — icon toggle; --fg-grease-pencil-cursor used when tool is on */
#panel-guide{
  --fg-grease-pencil-cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24'%3E%3Cpath fill='%23e8c060' stroke='%235a4614' stroke-width='0.5' stroke-linejoin='round' d='M3 17.35V21h3.65L17.85 9.8l-3.65-3.65L3 17.35z'/%3E%3Cpath fill='%23fff8e6' stroke='%235a4614' stroke-width='0.35' d='M20.65 6.2a1.03 1.03 0 0 0 0-1.45L19.25 3.35a1.03 1.03 0 0 0-1.45 0l-1.7 1.7 3.65 3.65 1.7-1.5z'/%3E%3C/svg%3E") 3 21}
#panel-guide .fg-cursor-tool-btn,
#panel-guide .fg-grease-pencil-btn,
#panel-guide .fg-screenshot-btn,
#panel-guide .fg-screencast-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  flex:1 1 0;
  min-width:0;
  margin:0;
  padding:0;
  height:32px;
  border:1px solid rgba(212,168,90,0.28);
  border-radius:6px;
  background:rgba(212,168,90,0.06);
  color:rgba(228,190,108,0.9);
  cursor:pointer;
  line-height:0;
  transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}
#panel-guide .fg-cursor-tool-btn:hover,
#panel-guide .fg-grease-pencil-btn:hover,
#panel-guide .fg-screenshot-btn:hover:not(:disabled),
#panel-guide .fg-screencast-btn:hover:not(:disabled){
  background:rgba(212,168,90,0.12);
  border-color:rgba(212,168,90,0.42);
  color:rgba(255,228,160,0.96);
  box-shadow:0 0 10px rgba(212,168,90,0.14)}
#panel-guide .fg-cursor-tool-btn:focus-visible,
#panel-guide .fg-grease-pencil-btn:focus-visible,
#panel-guide .fg-screenshot-btn:focus-visible,
#panel-guide .fg-screencast-btn:focus-visible{
  outline:2px solid rgba(212,168,90,0.45);
  outline-offset:1px}
#panel-guide .fg-screenshot-btn:disabled,
#panel-guide .fg-screencast-btn:disabled{
  opacity:0.45;
  cursor:wait}
#panel-guide .fg-grease-pencil-btn.on{
  background:rgba(212,168,90,0.2);
  border-color:rgba(212,168,90,0.55);
  color:rgba(255,236,180,1);
  box-shadow:0 0 0 1px rgba(212,168,90,0.25),0 0 12px rgba(212,168,90,0.22);
  cursor:var(--fg-grease-pencil-cursor),pointer}
#panel-guide .fg-cursor-tool-icon,
#panel-guide .fg-grease-pencil-icon,
#panel-guide .fg-screenshot-icon,
#panel-guide .fg-screencast-icon{display:block}
#panel-guide .fg-grease-clear-btn{
  display:block;
  width:100%;
  margin:0;
  padding:5px 6px;
  border:1px solid rgba(212,168,90,0.22);
  border-radius:5px;
  background:rgba(212,168,90,0.05);
  color:rgba(220,198,158,0.85);
  font-family:'IBM Plex Mono',monospace;
  font-size:7.2px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  cursor:pointer;
  line-height:1.2;
  transition:background .16s ease,border-color .16s ease,color .16s ease}
#panel-guide .fg-grease-clear-btn:hover{
  background:rgba(212,168,90,0.12);
  border-color:rgba(212,168,90,0.38);
  color:rgba(255,244,220,0.94)}
#panel-guide .fg-grease-clear-btn:focus-visible{
  outline:2px solid rgba(212,168,90,0.42);
  outline-offset:1px}
@media(max-width:860px){
  #panel-guide .fg-fib-spiral-rail{
    width:min(124px,calc(100vw - 30px));
    padding:6px 5px 7px 6px;
    gap:5px}
  #panel-guide .fg-fib-spiral-rail__lbl{font-size:8.6625px}
  #panel-guide .fg-fib-spiral-rail__lbl--grease-opt .fg-fib-spiral-rail__text{font-size:7.875px}
  #panel-guide .fg-fib-spiral-rail__lbl--grease-seq .fg-fib-spiral-rail__text{font-size:7.5px}
  #panel-guide .fg-cursor-tool-btn,
  #panel-guide .fg-grease-pencil-btn,
  #panel-guide .fg-screenshot-btn,
  #panel-guide .fg-screencast-btn{height:30px}}
/* Field Guide — optional golden-ratio / Fibonacci overlay on photo pile */
#panel-guide .fg-fibonacci-overlay{
  position:absolute;
  inset:0;
  z-index:5;
  pointer-events:none;
  overflow:hidden;
  border-radius:10px;
  opacity:0;
  visibility:hidden}
#panel-guide.fg-fib-overlay--on .fg-fibonacci-overlay,
#panel-guide.fg-fib-overlay--fib-closing .fg-fibonacci-overlay{
  opacity:1;
  visibility:visible}
/* Golden wash + construction guides fade; spiral trims via stroke-dashoffset in JS */
#panel-guide .fg-fibonacci-overlay .fg-fib-wash,
#panel-guide .fg-fibonacci-overlay .fg-fib-guide{
  opacity:0;
  transition:opacity .52s cubic-bezier(0.4,0,0.2,1)}
#panel-guide.fg-fib-overlay--on:not(.fg-fib-overlay--fib-closing) .fg-fibonacci-overlay .fg-fib-wash,
#panel-guide.fg-fib-overlay--on:not(.fg-fib-overlay--fib-closing) .fg-fibonacci-overlay .fg-fib-guide{
  opacity:1}
#panel-guide.fg-fib-overlay--fib-closing .fg-fibonacci-overlay .fg-fib-wash,
#panel-guide.fg-fib-overlay--fib-closing .fg-fibonacci-overlay .fg-fib-guide{
  opacity:0;
  transition:opacity .42s cubic-bezier(0.4,0,0.2,1)}
#panel-guide .fg-fibonacci-overlay .fg-fib-svg{
  display:block;
  width:100%;
  height:100%}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-fibonacci-overlay .fg-fib-wash,
  #panel-guide .fg-fibonacci-overlay .fg-fib-guide{
    transition-duration:0.01ms}}
/* Grease pencil — drawing layer over each species photo pile */
#panel-guide .fg-grease-layer{
  position:absolute;
  inset:0;
  z-index:7;
  pointer-events:none;
  overflow:hidden;
  border-radius:10px;
  transform:translate3d(0,0,0);
  will-change:transform}
#panel-guide.fg-grease-pencil--armed .fg-grease-layer{
  pointer-events:auto;
  touch-action:none;
  cursor:var(--fg-grease-pencil-cursor),crosshair}
#panel-guide .fg-grease-canvas{
  display:block;
  width:100%;
  height:100%;
  vertical-align:top;
  touch-action:none;
  opacity:0.97}
/* Icons: Field Guide = hex (field / life-stage lattice) */
.tab-icon{font-family:'IBM Plex Mono',monospace;font-size:12.375px;opacity:.92;margin-right:2px}
.tab-icon-guide{color:rgba(212,168,90,0.9)}
/* In-tab page titles — icon first, large title, left-aligned */
.tab-panel .page-scroll > h2{
  display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;
  font-family:'Playfair Display',serif;font-size:clamp(32.175px, 4.3312vw, 42.075px);font-weight:400;color:var(--cream);
  margin:0 0 14px;line-height:1.15;text-align:left}
.tab-panel .page-scroll > h2::before{
  content:'◈';font-family:'IBM Plex Mono',monospace;font-size:clamp(21.0375px, 2.5987vw, 27.225px);line-height:1;
  color:var(--wfts-c-mute-88);flex-shrink:0;letter-spacing:0;margin-top:0.28em}
/* About: explicit in-panel scrolling (same pattern as Contact/Compare). */
#panel-about.tab-panel.active{
  display:flex;
  flex-direction:column;
  height:calc(100vh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  min-height:0;
  overflow:hidden}
#panel-about > .page-scroll{
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  max-height:100%;
  flex:1;
  min-height:0;
  padding-bottom:clamp(40px,6vw,72px)}
#panel-about .page-scroll > h2,
#panel-about .page-scroll > h3,
#panel-about .page-scroll p,
#panel-about .page-scroll li{
  font-size:14.85px;
  line-height:1.8}
#panel-about .page-scroll > h2,
#panel-about .page-scroll > h3{
  font-weight:700;
  color:var(--text);
  margin:0 0 8px;
  display:block;
  letter-spacing:0.01em}
#panel-about .page-scroll > h2::before{content:none}
/* Spring peeper portrait (if used in About body) — match Contact peeper scale */
#panel-about img[src*="springpeeper.png"]{
  width:clamp(84px,14vw,128px);
  height:auto;
  max-width:100%}
#panel-about .about-source-block{margin:0 0 clamp(18px,3vw,24px);padding-bottom:clamp(14px,2.5vw,20px);border-bottom:1px solid rgba(92,90,88,0.14)}
#panel-about .about-beta-label{margin:0 0 8px;font-size:8.6625px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(92,90,88,0.62)}
#panel-about .about-data-source{margin:0;max-width:52em;font-family:'IBM Plex Mono',monospace;font-size:9.9px;line-height:1.55;letter-spacing:0.25px;color:rgba(138,136,132,0.85);font-weight:400}
#panel-about .about-illustrator-block{
  margin-top:clamp(28px,5vw,44px);
  padding-top:clamp(18px,3vw,26px);
  border-top:1px solid rgba(92,90,88,0.14)}
#panel-about .about-illustrator-figure{
  margin:0;
  max-width:min(360px,100%)}
#panel-about .about-mary-photo{
  display:block;
  width:100%;
  max-width:360px;
  height:auto;
  aspect-ratio:1;
  object-fit:cover;
  border-radius:clamp(8px,1.5vw,14px);
  border:1px solid rgba(255,255,255,0.1);
  box-shadow:0 8px 32px rgba(0,0,0,0.28);
  margin-bottom:clamp(12px,2vw,16px);
  background:rgba(20,18,16,0.6)}
#panel-about .about-illustrator-caption{
  margin:0;
  max-width:36em;
  font-family:'IBM Plex Mono',monospace;
  font-size:9.9px;
  line-height:1.6;
  letter-spacing:0.2px;
  color:rgba(138,136,132,0.88);
  font-weight:400}
#panel-about .about-illustrator-caption strong{
  color:var(--cream);
  font-weight:500}
#panel-about .about-illustrator-wiki{
  margin:clamp(10px,2vw,14px) 0 0;
  max-width:36em;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px}
#panel-about .about-wiki-link{
  display:inline-flex;
  align-items:center;
  flex-shrink:0;
  border:1px solid rgba(110,165,210,0.42);
  border-radius:999px;
  padding:6px 16px;
  font-family:'IBM Plex Mono',monospace;
  font-size:9.9px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(168,210,248,0.95);
  background:rgba(45,85,125,0.14);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 2px 12px rgba(0,0,0,0.1);
  text-decoration:none;
  transition:background .18s ease,color .18s ease,border-color .18s ease}
#panel-about .about-wiki-link:hover{
  color:rgba(210,234,255,0.98);
  border-color:rgba(140,195,235,0.55);
  background:rgba(55,105,150,0.2)}
#panel-about .about-wiki-note{
  font-family:'IBM Plex Mono',monospace;
  font-size:9.2px;
  line-height:1.5;
  letter-spacing:0.15px;
  color:rgba(138,136,132,0.82);
  flex:1;
  min-width:min(100%,12em)}
#panel-guide .page-scroll > h2::before{content:'⬡';color:rgba(212,168,90,0.9);font-size:clamp(22.275px, 2.7225vw, 29.7px)}
#panel-vocalizations .page-scroll > h2::before{content:'♪';color:rgba(212,168,90,0.9);font-size:clamp(22.275px, 2.7225vw, 29.7px)}
/* Atlas tab — full-width head above map (no .page-scroll) */
.atlas-page-head{
  display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;
  padding:18px max(16px,2.5vw) 10px;max-width:min(1920px,98vw);margin:0 auto;box-sizing:border-box}
.atlas-page-head-icon{margin-top:0.28em}
.atlas-page-head-icon{
  font-family:'IBM Plex Mono',monospace;font-size:clamp(27.225px, 3.465vw, 37.125px);line-height:1;color:var(--wfts-c-mute-88);
  flex-shrink:0}
.atlas-page-head-title{
  font-family:'Playfair Display',serif;font-size:clamp(32.175px, 4.3312vw, 42.075px);font-weight:400;color:var(--cream);
  margin:0;line-height:1.15}
/* Learn — viewport column below tabs and above fixed amb bar (same height math as Atlas / Calendar) */
#panel-vocalizations.tab-panel.active{
  display:flex;
  flex-direction:column;
  width:100%;
  max-width:100%;
  height:calc(100dvh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  max-height:calc(100svh - var(--wfts-layout-chrome) - var(--wfts-footer-reserve));
  min-height:0;
  box-sizing:border-box;
  /* Horizontal: visible so habitat rings / orbit can extend past the dial (body/html already clip x on this tab) */
  overflow-x:visible;
  overflow-y:hidden;
  overscroll-behavior:none}
#panel-vocalizations > .page-scroll{
  max-width:none;
  width:100%;
  box-sizing:border-box;
  padding-top:12px;
  padding-bottom:calc(24px + env(safe-area-inset-bottom,0));
  padding-left:max(16px,4vw,env(safe-area-inset-left,0px));
  padding-right:max(16px,4vw,env(safe-area-inset-right,0px));
  margin:0;
  flex:1 1 auto;
  min-height:0;
  min-width:0;
  max-height:none;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:stretch;
  overflow-x:visible;
  overflow-y:hidden;
  overscroll-behavior:none}
/* Learn — hub landing (sub-activities); quiz is #learn-view-quiz */
#panel-vocalizations .learn-hub{
  flex:1 1 auto;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:contain;
  max-width:min(520px,100%);
  margin:0 auto;
  padding:6px 0 28px;
  box-sizing:border-box}
#panel-vocalizations .learn-hub[hidden]{display:none!important}
#panel-vocalizations .learn-hub-h{
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,3.8vw,40px);
  font-weight:400;
  color:var(--cream);
  margin:0 0 10px;
  line-height:1.12}
#panel-vocalizations .learn-hub-lead{
  margin:0 0 22px;
  font-size:13.6125px;
  line-height:1.55;
  color:rgba(232,224,208,0.72);
  max-width:40em}
#panel-vocalizations .learn-hub-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px}
#panel-vocalizations .learn-hub-list > li{margin:0;padding:0}
#panel-vocalizations .learn-hub-item{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  justify-content:space-between;
  gap:8px 14px;
  width:100%;
  box-sizing:border-box;
  text-align:left;
  padding:14px 16px;
  border-radius:10px;
  border:1px solid var(--wfts-c-stone-22);
  background:rgba(18,17,16,0.35);
  color:rgba(232,224,208,0.92);
  font-family:'IBM Plex Mono',monospace;
  font-size:11.88px;
  letter-spacing:0.04em;
  line-height:1.35;
  transition:border-color .15s ease,background .15s ease}
#panel-vocalizations .learn-hub-item--action{
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none}
#panel-vocalizations .learn-hub-item--action:hover{
  border-color:rgba(212,168,90,0.38);
  background:rgba(28,26,22,0.5)}
#panel-vocalizations .learn-hub-item--action:focus{outline:none}
#panel-vocalizations .learn-hub-item--action:focus-visible{
  box-shadow:0 0 0 2px rgba(212,168,90,0.35)}
#panel-vocalizations .learn-hub-item-title{
  display:block;
  font-weight:600;
  color:var(--cream);
  letter-spacing:0.06em;
  text-transform:uppercase;
  font-size:11.1375px}
#panel-vocalizations .learn-hub-item--action .learn-hub-item-title{width:100%}
#panel-vocalizations .learn-hub-item-desc{
  display:block;
  width:100%;
  font-weight:400;
  font-size:11.1375px;
  letter-spacing:0.03em;
  text-transform:none;
  color:rgba(200,194,180,0.75);
  line-height:1.45}
#panel-vocalizations .learn-hub-item--soon{
  cursor:default;
  opacity:0.88;
  border-style:dashed;
  border-color:rgba(92,90,88,0.35)}
#panel-vocalizations .learn-hub-item--soon .learn-hub-item-title{
  width:auto;
  flex:1 1 auto;
  min-width:0;
  margin:0}
#panel-vocalizations .learn-hub-soon{
  flex-shrink:0;
  font-size:9.9px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(212,168,90,0.55);
  white-space:nowrap}
#panel-vocalizations #learn-view-quiz[hidden]{display:none!important}
#panel-vocalizations #learn-view-quiz:not([hidden]){
  flex:1 1 auto;
  min-height:0;
  min-width:0;
  display:flex;
  flex-direction:column;
  overflow:hidden}
#panel-vocalizations .learn-quiz-topbar{
  flex-shrink:0;
  padding:0 0 10px}
#panel-vocalizations .learn-back-to-hub{
  font-family:'IBM Plex Mono',monospace;
  font-size:11.1375px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--amber2);
  background:transparent;
  border:1px solid var(--wfts-c-stone-25);
  border-radius:8px;
  padding:8px 14px;
  cursor:pointer;
  transition:background .15s ease,border-color .15s ease,color .15s ease}
#panel-vocalizations .learn-back-to-hub:hover{
  background:var(--wfts-c-stone-12);
  border-color:rgba(212,168,90,0.32);
  color:var(--amber)}
#panel-vocalizations .learn-back-to-hub:focus{outline:none}
#panel-vocalizations .learn-back-to-hub:focus-visible{
  box-shadow:0 0 0 2px rgba(212,168,90,0.35)}
#panel-vocalizations #learn-view-quiz:not([hidden]) .learn-wrap{
  flex:1 1 auto;
  min-height:0;
  min-width:0}
#panel-guide .page-scroll li::before{content:'⬡ ';color:var(--wfts-c-amber-50);font-size:11.1375px}
/* Learn — dense stack; selector ball on horizontal track */
#panel-vocalizations .learn-wrap{
  max-width:100%;
  margin:0 auto;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  position:relative;
  overflow-x:visible;
  overflow-y:visible}
/* Quiz onboarding overlay (large simple instructions). */
#panel-vocalizations .learn-how-overlay{
  position:fixed;
  inset:0;
  z-index:120;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(16px,3vw,34px);
  box-sizing:border-box;
  background:rgba(5,7,11,0.8);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  opacity:0;
  pointer-events:none;
  transition:opacity .34s ease;
  cursor:pointer}
#panel-vocalizations .learn-how-overlay.learn-how-overlay--visible{
  opacity:1;
  pointer-events:auto}
#panel-vocalizations .learn-how-panel{
  width:min(94vw,840px);
  text-align:center;
  border:none;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(16,16,20,0.46),rgba(12,12,16,0.3));
  box-shadow:0 18px 48px rgba(0,0,0,0.45);
  padding:clamp(12px,2.2vw,22px) clamp(14px,2.6vw,28px)}
#panel-vocalizations .learn-how-title{
  margin:0 0 10px;
  font-family:'Playfair Display',serif;
  font-size:clamp(19px,2.5vw,26px);
  color:var(--cream);
  line-height:1.08;
  letter-spacing:0.012em}
#panel-vocalizations .learn-how-title.wave-words span{
  display:inline-block;
  opacity:0.34;
  animation:wordOpacityWaveBoot 6.5s cubic-bezier(0.45,0,0.55,1) infinite;
  animation-delay:calc(var(--i,0) * 0.55s)}
#panel-vocalizations .learn-how-step{
  margin:0 0 6px;
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:clamp(12.5px,1.55vw,17px);
  letter-spacing:0.01em;
  color:rgba(200,184,138,0.88);
  line-height:1.38}
#panel-vocalizations .learn-how-step.wave-words span{
  display:inline-block;
  opacity:0.3;
  animation:wordOpacityWave 10.5s ease-in-out infinite;
  animation-delay:calc(var(--i,0) * 0.085s)}
#panel-vocalizations .learn-how-tip{
  margin:10px 0 0;
  font-family:'IBM Plex Mono',monospace;
  font-size:clamp(7.5px,0.85vw,9.25px);
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(212,168,90,0.82)}
#panel-vocalizations .learn-how-tip.wave-words span{
  display:inline-block;
  opacity:0.34;
  animation:wordOpacityWaveBoot 6.5s cubic-bezier(0.45,0,0.55,1) infinite;
  animation-delay:calc(var(--i,0) * 0.1s)}
/* Quiz UX: prevent selecting/dragging any dial/deco images. */
#panel-vocalizations .learn-wrap img{
  user-select:none;
  -webkit-user-select:none;
  -moz-user-select:none;
  -ms-user-select:none;
  -webkit-user-drag:none;
  pointer-events:none;
  -webkit-touch-callout:none}
/* Quiz UX: disable all text/image highlighting on this panel. */
#panel-vocalizations,
#panel-vocalizations *{
  user-select:none;
  -webkit-user-select:none;
  -moz-user-select:none;
  -ms-user-select:none;
  -webkit-touch-callout:none}
#panel-vocalizations .learn-toolbar{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:8px 12px;width:100%}
#panel-vocalizations .learn-intro{
  text-align:left;
  margin:0;
  font-size:11.1375px;
  color:rgba(188,182,168,0.78);
  line-height:1.4;
  letter-spacing:0.02em}
#panel-vocalizations .learn-track-head{
  font-family:'IBM Plex Mono',monospace;
  font-size:6.8062px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(212,168,90,0.4);
  margin:1px auto 0;
  padding:0;
  text-align:center}
.learn-waveform-wrap{width:100%;max-width:100%;position:relative;margin:0;background:transparent;padding:0;box-sizing:border-box}
.learn-waveform-wrap canvas{display:block;width:100%;max-width:100%;height:44px;margin:0;background:transparent;vertical-align:middle;opacity:1}
.learn-dial-stack{
  --learn-dial-stack-pad-top:clamp(10px,2.5vw,20px);
  --learn-dial-stack-pad-bottom:clamp(14px,3vw,28px);
  --learn-selector-pad-top:2px;
  /* cqw: matches .learn-dial-stage width = min(88vw,412px,max parent) for waveform/dial alignment */
  container-type:inline-size;
  container-name:learn-dial;
  position:relative;
  width:100%;
  max-width:100%;
  margin:0 auto;
  padding:var(--learn-dial-stack-pad-top) 0 var(--learn-dial-stack-pad-bottom);
  box-sizing:border-box;
  overflow:visible}
/* Minimal amber play control — above the dial */
.learn-dial-play-wrap{
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  margin:0 0 6px;
  padding:0;
  position:relative;
  z-index:3;
  pointer-events:auto}
.learn-dial-play-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:clamp(44px,12.5vw,56px);
  height:clamp(44px,12.5vw,56px);
  margin:0;
  padding:0;
  border:none;
  border-radius:50%;
  box-sizing:border-box;
  background:rgba(212,168,90,0.06);
  color:rgba(212,168,90,0.88);
  cursor:pointer;
  box-shadow:inset 0 0 0 1px rgba(212,168,90,0.42);
  transition:color .18s ease,background .18s ease,box-shadow .18s ease,transform .15s ease}
.learn-dial-play-btn__icon{
  display:block;
  width:90%;
  height:90%;
  margin:0;
  flex-shrink:0;
  /* Glyph’s visual mass sits slightly right of viewBox center (24×24 path) — nudge left to center in the circle */
  transform:translateX(-3.125%)}
.learn-dial-play-btn:hover{
  color:rgba(252,230,190,0.96);
  background:rgba(212,168,90,0.11);
  box-shadow:inset 0 0 0 1px rgba(240,185,95,0.55),0 2px 14px rgba(212,168,90,0.12)}
.learn-dial-play-btn:focus{outline:none}
.learn-dial-play-btn:focus-visible{
  box-shadow:inset 0 0 0 1px rgba(240,185,95,0.65),0 0 0 2px var(--wfts-c-amber-35)}
.learn-dial-play-btn:active{transform:scale(0.96)}
@media (prefers-reduced-motion:reduce){
  .learn-dial-play-btn{transition-duration:.01ms}
  .learn-dial-play-btn:active{transform:none}}
.learn-waveform-wrap--behind-dial{
  position:absolute;
  left:50%;
  width:min(88vw,412px);
  max-width:100%;
  aspect-ratio:1;
  top:calc(var(--learn-dial-stack-pad-top) + clamp(44px,12.5vw,56px) + 6px + var(--learn-selector-pad-top) + min(88vw,412px) / 2);
  transform:translate(-50%,-50%);
  z-index:0;
  pointer-events:none;
  margin:0;
  height:auto}
@supports (width:1cqw){
  .learn-waveform-wrap--behind-dial{
    width:min(100cqw,min(88vw,412px));
    top:calc(var(--learn-dial-stack-pad-top) + clamp(44px,12.5vw,56px) + 6px + var(--learn-selector-pad-top) + min(100cqw,min(88vw,412px)) / 2);
  }
}
.learn-waveform-wrap--behind-dial canvas{
  opacity:1;
  width:100%;
  height:auto;
  aspect-ratio:1;
  display:block}
.learn-dial-stack .learn-selector{
  position:relative;
  z-index:1;
  max-width:100%;
  width:100%}
.learn-selector{
  position:relative;
  width:100%;
  max-width:min(412px,100%);
  margin:0 auto;
  padding:var(--learn-selector-pad-top,2px) 0 0;
  box-sizing:border-box}
.learn-dial-stage{
  position:relative;
  width:min(88vw,412px);
  max-width:100%;
  aspect-ratio:1;
  margin:0 auto;
  border-radius:50%;
  touch-action:none;
  cursor:grab;
  box-sizing:border-box;
  /* Species orbit radius (frog portraits); habitat rings derive outer radii as multiples — shared with deco rings */
  container:learn-dial / inline-size;
  --learn-ring-r:min(6.44rem,30.6vw);
  --learn-ring-r:min(27.2cqw,16.25rem);
  background:
    repeating-conic-gradient(from -12deg at 50% 50%,transparent 0deg 5deg,rgba(255,255,255,0.02) 5deg 6deg,transparent 6deg 11deg),
    radial-gradient(circle at 50% 50%,rgba(34,32,30,0.55) 0%,rgba(20,18,16,0.4) 42%,transparent 44%),
    radial-gradient(circle at 50% 50%,transparent 46%,rgba(255,255,255,0.04) 48%,transparent 52%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.09),0 6px 28px rgba(0,0,0,0.22);
  /* transform driven in JS (idle noise drift + grab scale) — no transition on transform */
  transition:box-shadow .22s ease}
.learn-dial-stage:focus{outline:none}
.learn-dial-stage:focus-visible{box-shadow:inset 0 0 0 1px rgba(255,255,255,0.09),0 0 0 2px var(--wfts-c-amber-35)}
/* Habitat rings extend past the stage; clip to the stage box (no viewport clip — avoids locking a tight crop when the tab opens). */
.learn-dial-deco-clip{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden}
/* Learn quiz: rings/slots use large radii — expand circular clip so outer habitat art isn’t sheared off */
#panel-vocalizations .learn-dial-stage{
  overflow:visible}
#panel-vocalizations .learn-dial-deco-clip{
  /* Outer habitat ring ×6.3 + deco-r can reach ~60rem+ from center — need a very large clip disc */
  inset:-280%;
  border-radius:50%;
  overflow:hidden}
/* Concentric habitat rings — placeholders; alternate spin vs species orbit (frog CW → tadpoles CCW → insects CW → flowers CCW). */
.learn-dial-deco-rings{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  border-radius:50%;
  overflow:visible}

/* Idle + damped user motion: habitat ring transforms are driven in app.js (avoid CSS animation fighting smoothing). */
/* Negative inset expands the ring equally on all sides — stays concentric with .learn-dial-stage */
.learn-dial-deco-ring{
  position:absolute;
  inset:0;
  margin:0;
  width:auto;
  height:auto;
  box-sizing:border-box;
  transform-origin:50% 50%;
  border-radius:50%;
  pointer-events:none;
  transition:none}
/* Outer ring R = species orbit × multiplier: tadpoles ×2.25, insects ×3.45, flowers ×4.75. inset = 50cqw − R_out */
.learn-dial-deco-ring--tadpoles{
  --deco-out-r:calc(var(--learn-ring-r) * 2.25);
  inset:calc(50cqw - var(--deco-out-r));
  --deco-r:clamp(14rem,70vw,24rem);
  --deco-r:calc(var(--deco-out-r) - 1px);
  box-shadow:none;
  opacity:0.72}
.learn-dial-deco-ring--insects{
  --deco-out-r:calc(var(--learn-ring-r) * 3.45);
  inset:calc(50cqw - var(--deco-out-r));
  --deco-r:clamp(21rem,105vw,36rem);
  --deco-r:calc(var(--deco-out-r) - 1px);
  box-shadow:none;
  opacity:0.56}
.learn-dial-deco-ring--flowers{
  --deco-out-r:calc(var(--learn-ring-r) * 4.75);
  inset:calc(50cqw - var(--deco-out-r));
  --deco-r:clamp(30rem,140vw,52rem);
  --deco-r:calc(var(--deco-out-r) - 1px);
  box-shadow:none;
  opacity:0.42}
/* Outer habitat ring (birds + predators): larger than flowers */
.learn-dial-deco-ring--birdpred{
  --deco-out-r:calc(var(--learn-ring-r) * 6.3);
  inset:calc(50cqw - var(--deco-out-r));
  /* Keep within sane bounds across screen sizes */
  --deco-r:clamp(40rem,175vw,66rem);
  --deco-r:calc(var(--deco-out-r) - 1px);
  box-shadow:none;
  opacity:0.3}
.learn-dial-deco-slot{
  position:absolute;
  left:50%;
  top:50%;
  --slot-rot:0deg;
  /* Subcircles doubled in size (also updates the centering margin). */
  width:clamp(30px,10.5vw,42px);
  height:clamp(30px,10.5vw,42px);
  margin:calc(-0.5 * clamp(30px,10.5vw,42px)) 0 0 calc(-0.5 * clamp(30px,10.5vw,42px));
  transform-origin:center center;
  transform:rotate(var(--slot-rot)) translateY(calc(-1 * var(--deco-r)));
  pointer-events:none}
/* Subtle uncorrelated drift on habitat placeholder discs (quiz learn dial). */
.learn-dial-deco-ph-drift{
  display:block;
  width:100%;
  height:100%;
  border-radius:50%;
  box-sizing:border-box;
  transform-origin:center center;
  animation-name:learnDialLocationDrift;
  animation-timing-function:ease-in-out;
  animation-iteration-count:infinite;
  will-change:transform}
.learn-dial-deco-ph{
  width:100%;
  height:100%;
  border-radius:0;
  box-sizing:border-box;
  border:none;
  /* Empty placeholder slot (image is a blank PNG; only border/tint remains) */
  background:transparent;
  opacity:1;
  overflow:visible}
.learn-dial-deco-ph--tadpole{
  background:transparent;
  border-color:rgba(130,175,145,0)}
.learn-dial-deco-ph--insect{
  background:transparent;
  border-color:rgba(150,170,210,0)}
.learn-dial-deco-ph--flower{
  background:transparent;
  border-color:rgba(220,175,110,0)}
/* Bird vs predator placeholder “subcircle” styles for the outer ring */
.learn-dial-deco-ph--bird{
  background:transparent;
  border-color:rgba(130,210,235,0)}
.learn-dial-deco-ph--predator{
  background:transparent;
  border-color:rgba(240,185,95,0)}

.learn-dial-deco-ph-img{
  width:100%;
  height:100%;
  display:block;
  border-radius:0;
  object-fit:contain;
  pointer-events:none;
  user-select:none;
  position:relative;
  z-index:20}
/* Outermost ring: toadlet art from assets/toadlets/ — fill the small circles */
.learn-dial-deco-ph-img--toadlet{
  object-fit:cover}
/* Outermost toadlet ring: keep holder chrome invisible + subtle noisy motion (slow rotate + micro breathing). */
.learn-dial-deco-ring--birdpred .learn-dial-deco-ph{
  border-color:rgba(255,255,255,0)!important;
  background:rgba(0,0,0,0)!important;
  opacity:1}
.learn-dial-deco-ring--birdpred .learn-dial-deco-ph-drift{
  animation-name:learnDialLocationDriftToadletNoise}
/* Quiz deco rings visible (non-toadlet rings now show boot-seq imagery). */
#learn-dial-ring-tadpoles,
#learn-dial-ring-insects,
#learn-dial-ring-flowers{
  display:block!important}
@keyframes learnDialLocationDriftToadletNoise{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg) scale(1)}
  12%{transform:translate3d(0.46px,-0.28px,0) rotate(-0.55deg) scale(0.988)}
  25%{transform:translate3d(-0.42px,0.36px,0) rotate(0.7deg) scale(1.014)}
  39%{transform:translate3d(-0.54px,-0.34px,0) rotate(-0.85deg) scale(0.992)}
  53%{transform:translate3d(0.34px,0.48px,0) rotate(0.6deg) scale(1.017)}
  66%{transform:translate3d(0.58px,-0.24px,0) rotate(-0.72deg) scale(0.989)}
  79%{transform:translate3d(-0.3px,-0.45px,0) rotate(0.78deg) scale(1.012)}
  91%{transform:translate3d(0.22px,0.3px,0) rotate(-0.48deg) scale(0.995)}}
.learn-selector.is-grabbing .learn-dial-stage{
  cursor:grabbing;
  transform:scale(1.012);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.12),
    inset 0 5px 22px rgba(0,0,0,0.35),
    0 4px 14px rgba(0,0,0,0.28),
    0 0 0 1px rgba(212,168,90,0.12)}
@media (prefers-reduced-motion:reduce){
  .learn-selector.is-grabbing .learn-dial-stage{transform:none}
  .learn-dial-stage{transition:box-shadow .15s ease}
  .learn-selector:not(.is-grabbing) .learn-dial-orbit{transition-duration:.2s}
  .learn-dial-slot-inner--at-marker img{animation:none}
  .learn-dial-slot-drift,
  .learn-dial-deco-ph-drift{animation:none!important}
  .learn-dial-marker{animation:none;opacity:1;transform:translateX(-50%)}
  .learn-dial-marker.learn-dial-marker--on-target{
    animation:none;
    filter:drop-shadow(0 0 10px rgba(255,210,140,0.75)) drop-shadow(0 1px 3px rgba(0,0,0,0.45))}
  .learn-dial-active-name{transition-duration:.08s}}
@keyframes learnDialMarkerIdle{
  0%,100%{transform:translateX(-50%) translateY(0);opacity:0.88}
  50%{transform:translateX(-50%) translateY(-3px);opacity:1}}
@keyframes learnDialMarkerGlowPulse{
  0%,100%{filter:drop-shadow(0 0 6px rgba(255,200,130,0.55)) drop-shadow(0 0 12px rgba(212,168,90,0.35)) drop-shadow(0 1px 3px rgba(0,0,0,0.45))}
  50%{filter:drop-shadow(0 0 12px rgba(255,220,160,0.88)) drop-shadow(0 0 20px rgba(212,168,90,0.55)) drop-shadow(0 1px 3px rgba(0,0,0,0.45))}}
.learn-dial-marker{
  position:absolute;
  left:50%;
  top:2px;
  transform:translateX(-50%);
  width:0;height:0;
  border-left:11px solid transparent;
  border-right:11px solid transparent;
  border-top:17px solid rgba(212,168,90,0.92);
  z-index:6;
  pointer-events:none;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,0.45));
  animation:learnDialMarkerIdle 3.4s ease-in-out infinite;
  will-change:transform,opacity}
.learn-dial-marker.learn-dial-marker--on-target{
  border-top-color:rgba(255,224,168,0.96);
  animation:learnDialMarkerIdle 3.4s ease-in-out infinite,learnDialMarkerGlowPulse 2.6s ease-in-out infinite}
/* Below amber marker, above the top orbit slot — name for the species at the selector. */
.learn-dial-active-name{
  position:absolute;
  left:50%;
  top:clamp(21px,6.5vw,33px);
  transform:translateX(-50%);
  z-index:4;
  pointer-events:none;
  max-width:min(220px,56vw);
  padding:0 8px;
  box-sizing:border-box;
  font-family:'IBM Plex Mono',monospace;
  font-size:clamp(8.75px,2.5vw,11px);
  font-weight:500;
  line-height:1.18;
  letter-spacing:0.03em;
  text-align:center;
  color:rgba(252,244,228,0.96);
  text-shadow:0 0 10px rgba(0,0,0,0.88),0 1px 2px rgba(0,0,0,0.82);
  opacity:0;
  transition:opacity .26s ease;
  min-height:1.2em}
.learn-dial-orbit{
  position:absolute;
  inset:6.25%;
  border-radius:50%;
  pointer-events:auto;
  /* Above habitat deco rings; below marker (6), knob (5), active name (4) */
  z-index:3;
  transform-origin:50% 50%;
  transition:transform 0s linear;
  isolation:isolate}
.learn-selector:not(.is-grabbing) .learn-dial-orbit{
  transition:transform .42s cubic-bezier(0.2,0.85,0.22,1)}
.learn-dial-slot{
  position:absolute;
  left:50%;top:50%;
  /* Square anchor so transform origin matches portrait center on the ring. */
  --slot-h:clamp(48px,20vw,72px);
  width:var(--slot-h);
  height:var(--slot-h);
  margin:calc(-0.5 * var(--slot-h)) 0 0 calc(-0.5 * var(--slot-h));
  transform-origin:center center;
  --slot-angle:0deg;
  transform:rotate(var(--slot-angle)) translateY(calc(-1 * var(--learn-ring-r)));
  /* Base; syncDialVisuals raises z-index for slots nearer the marker so portraits stack above neighbors */
  z-index:10;
  overflow:visible;
  pointer-events:auto}
.learn-dial-slot-inner{
  position:relative;
  display:block;
  box-sizing:border-box;
  width:100%;
  height:100%;
  border-radius:50%;
  overflow:visible;
  border:none;
  background:transparent;
  box-shadow:none;
  transition:opacity .18s ease,transform .22s cubic-bezier(0.22,0.82,0.28,1);
  transform-origin:center center;
  will-change:opacity,transform}
/* Slow pseudo-random position jitter inside each species portrait (does not replace JS orbit transform on parent). */
.learn-dial-slot-drift{
  display:block;
  width:100%;
  height:100%;
  border-radius:50%;
  box-sizing:border-box;
  transform-origin:center center;
  animation-name:learnDialLocationDrift;
  animation-timing-function:ease-in-out;
  animation-iteration-count:infinite;
  will-change:transform}
@keyframes learnDialLocationDrift{
  0%,100%{transform:translate3d(0,0,0)}
  9%{transform:translate3d(0.52px,-0.31px,0)}
  21%{transform:translate3d(-0.44px,0.48px,0)}
  34%{transform:translate3d(-0.58px,-0.38px,0)}
  47%{transform:translate3d(0.36px,0.54px,0)}
  59%{transform:translate3d(0.68px,-0.26px,0)}
  72%{transform:translate3d(-0.32px,-0.49px,0)}
  85%{transform:translate3d(0.26px,0.34px,0)}
  95%{transform:translate3d(-0.22px,0.21px,0)}}
.learn-selector.is-grabbing .learn-dial-slot-inner{
  transition:opacity .12s ease,transform .12s cubic-bezier(0.22,0.82,0.28,1)}
.learn-dial-slot-media{
  width:100%;
  height:100%;
  border-radius:0;
  overflow:visible;
  box-sizing:border-box;
  border:1.5px solid rgba(255,255,255,0);
  background:rgba(8,7,6,0);
  position:relative;
  z-index:20}
.learn-dial-slot-media img{
  display:block;
  position:relative;
  z-index:21;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  -webkit-user-drag:none;
  user-select:none;
  -webkit-user-select:none;
  -moz-user-select:none;
  pointer-events:none}
@keyframes learnDialImgVibrate{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  22%{transform:translate3d(1.6px,-1.1px,0) rotate(-1.4deg)}
  48%{transform:translate3d(-1.4px,1.3px,0) rotate(1.1deg)}
  72%{transform:translate3d(1.1px,0.6px,0) rotate(-0.7deg)}}
.learn-dial-slot-inner--at-marker .learn-dial-slot-media{
  border-color:rgba(212,168,90,0);
  box-shadow:none}
.learn-dial-slot-inner--at-marker .learn-dial-slot-media::before{
  content:'';
  position:absolute;
  inset:-8%;
  border-radius:50%;
  pointer-events:none;
  z-index:-1;
  background:radial-gradient(circle,rgba(240,185,95,0.34) 0%,rgba(240,185,95,0.14) 45%,rgba(240,185,95,0) 72%);
  filter:blur(8px)}
.learn-dial-slot-inner--at-marker img{
  animation:learnDialImgVibrate 0.52s ease-in-out infinite;
  transform-origin:center center}
.learn-dial-slot-media img.learn-dial-slot-img--contain{
  object-fit:contain;
  padding:3px;
  box-sizing:border-box}
.learn-dial-knob{
  --learn-knob-size:clamp(52px,26%,78px);
  position:absolute;
  left:50%;
  top:50%;
  width:var(--learn-knob-size);
  height:var(--learn-knob-size);
  margin:calc(-0.5 * var(--learn-knob-size)) 0 0 calc(-0.5 * var(--learn-knob-size));
  border-radius:50%;
  z-index:5;
  pointer-events:auto;
  box-sizing:border-box;
  border:1.5px solid rgba(240,185,95,0.5);
  background:rgba(14,13,10,0.62);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.22),0 2px 14px rgba(0,0,0,0.35);
  transition:background-color .4s ease,border-color .4s ease,box-shadow .4s ease,color .4s ease,transform .18s ease;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(6px,1.5vmin,11px);
  -webkit-appearance:none;
  appearance:none;
  font:inherit;
  color:rgba(252,228,180,0.96)}
.learn-dial-knob-label{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  justify-content:center;
  max-width:100%;
  white-space:nowrap;
  font-family:'Playfair Display',serif;
  font-size:clamp(7.5px,2vmin,10.5px);
  font-weight:400;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(252,236,200,0.94);
  line-height:1.05;
  text-align:center;
  pointer-events:none;
  transition:opacity .22s ease}
#panel-vocalizations .learn-dial-knob-label.wave-words span{
  display:inline-block;
  opacity:0.34;
  animation:wordOpacityWaveBoot 6.5s cubic-bezier(0.45,0,0.55,1) infinite;
  animation-delay:calc(var(--i,0) * 0.55s)}
@media (prefers-reduced-motion:reduce){
  #panel-vocalizations .learn-dial-knob-label.wave-words span{
    animation:none;
    opacity:0.88}}
.learn-dial-knob--correct .learn-dial-knob-label{
  opacity:0}
.learn-dial-knob:focus{outline:none}
.learn-dial-knob:focus-visible{
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.2),0 2px 12px rgba(0,0,0,0.25),0 0 0 2px var(--wfts-c-amber-35)}
.learn-dial-knob-icon{
  font-size:clamp(16px,5.2vmin,26px);
  line-height:1;
  font-weight:600;
  pointer-events:none}
/* Show ✓ only briefly on correct answers */
.learn-dial-knob-icon{
  opacity:0;
  position:absolute;
  left:50%;top:50%;
  z-index:2;
  transform:translate(-50%,-50%) scale(0.78);
  display:flex;
  align-items:center;
  justify-content:center}
.learn-dial-knob--correct .learn-dial-knob-icon{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
  animation:learn-dial-correct-check-pop 900ms ease both}
@keyframes learn-dial-correct-check-pop{
  0%{opacity:0;transform:translate(-50%,-50%) scale(0.7) translateY(2px)}
  22%{opacity:1;transform:translate(-50%,-50%) scale(1.04) translateY(0px)}
  78%{opacity:1;transform:translate(-50%,-50%) scale(1.0) translateY(0px)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.12) translateY(-2px)}
}
.learn-selector.is-hover:not(.is-grabbing) .learn-dial-knob{
  background:rgba(212,136,58,0.2);
  border-color:rgba(240,185,95,0.66);
  color:rgba(255,238,205,0.99);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18),0 2px 16px rgba(0,0,0,0.32)}
.learn-selector.is-grabbing .learn-dial-knob{
  background:rgba(212,136,58,0.28);
  border-color:rgba(252,220,150,0.86);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.15),0 0 18px rgba(240,185,95,0.12);
  transition:background-color .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease}
.learn-dial-knob--correct{
  background:rgba(94,200,160,0.34)!important;
  border-color:rgba(170,245,210,0.92)!important;
  color:rgba(212,255,236,0.98)!important}
.learn-dial-knob:active{transform:scale(0.96)}
.sr-only-learn-range{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;opacity:0;pointer-events:none}
.learn-selector-label{
  font-size:13.6125px;
  font-weight:500;
  color:var(--cream);
  text-align:center;
  line-height:1.25;
  margin-top:4px;
  min-height:1.25em}
.learn-selector-label--visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);
  white-space:nowrap;border:0;opacity:0;pointer-events:none}
.learn-progress{
  font-family:'IBM Plex Mono',monospace;
  font-size:8.6625px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(138,136,132,0.68);
  text-align:left;
  margin:0;
  flex-shrink:0}
#panel-vocalizations .learn-species-list{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:0 6px;
  margin:0 auto;
  width:min(100%,720px);
  align-self:center;
  justify-items:center}
@media(max-width:420px){
  #panel-vocalizations .learn-species-list{grid-template-columns:repeat(3,minmax(0,1fr));width:min(100%,420px)}}
.learn-species-item{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:3px;
  padding:1px 0;
  background:transparent;
  border:none;
  border-radius:0;
  font-size:8.6625px;
  color:rgba(168,162,148,0.85);
  line-height:1.25}
.learn-species-item.correct{color:rgba(130,210,170,0.92)}
.learn-species-item .learn-check{opacity:0;width:0.85em;flex-shrink:0;font-size:9.9px}
.learn-species-item.correct .learn-check{opacity:1;color:rgba(94,200,160,0.9)}
.learn-result{
  text-align:left;
  font-size:11.1375px;
  line-height:1.35;
  margin:0;
  min-height:1.2em;
  width:100%;
  color:rgba(200,194,178,0.72)}
.learn-result.correct{color:rgba(130,210,170,0.92)}
.learn-result.wrong{color:rgba(232,120,108,0.88)}
.learn-done{
  text-align:left;
  padding:4px 0 0;
  margin:0;
  background:transparent;
  border:none;
  width:100%;
  box-sizing:border-box}
.learn-done p{margin:0 0 6px;font-size:12.375px;color:rgba(232,224,204,0.9);line-height:1.35}
#panel-vocalizations .learn-reset{padding:4px 0;font-size:9.9px;letter-spacing:0.16em}
.learn-reset{
  padding:8px 0;font-family:'IBM Plex Mono',monospace;font-size:11.1375px;letter-spacing:0.2em;text-transform:uppercase;
  background:transparent;border:none;border-radius:0;color:var(--amber2);cursor:pointer;
  border-bottom:1px solid var(--wfts-c-amber-35);transition:color .2s,border-color .2s}
.learn-reset:hover{color:rgba(252,230,190,0.95);border-bottom-color:var(--wfts-c-gold-55)}
.learn-welldone-overlay{
  position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;
  padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));
  box-sizing:border-box;background:rgba(4,6,12,0);backdrop-filter:blur(0);
  transition:background .5s ease,backdrop-filter .5s ease,opacity .5s ease;pointer-events:none;opacity:0}
.learn-welldone-overlay--visible{
  pointer-events:auto;opacity:1;background:rgba(4,6,12,0.82);backdrop-filter:blur(10px)}
.learn-welldone-panel{
  width:100%;max-width:min(22rem,92vw);text-align:center;padding:32px 28px;border-radius:18px;box-sizing:border-box;
  border:1px solid rgba(212,168,90,0.32);background:rgba(18,16,22,0.96);
  box-shadow:0 28px 64px rgba(0,0,0,0.5),0 0 48px rgba(94,200,160,0.1);
  transform:translateY(14px) scale(0.98);opacity:0;transition:transform .48s cubic-bezier(0.22,1,0.36,1),opacity .48s ease}
.learn-welldone-overlay--visible .learn-welldone-panel{transform:translateY(0) scale(1);opacity:1}
.learn-welldone-title{
  font-family:'Playfair Display',serif;font-size:clamp(26px,5.5vw,38px);font-weight:400;color:rgba(210,248,220,0.96);
  margin:0 0 10px;letter-spacing:0.03em;line-height:1.15;
  text-shadow:0 0 24px rgba(110,231,168,0.35)}
.learn-welldone-sub{font-size:12.375px;color:rgba(200,194,178,0.78);margin:0 0 22px;line-height:1.45}
.learn-welldone-panel .learn-reset{margin-top:4px}
@keyframes learn-dial-celebrate-shake{
  0%,100%{transform:translate(0,0) scale(1)}
  22%{transform:translate(-3px,2px) scale(1.05)}
  48%{transform:translate(3px,-2px) scale(1.03)}
  72%{transform:translate(-2px,-3px) scale(1.06)}
}
.learn-dial-slot-inner--celebrate .learn-dial-slot-media{
  animation:learn-dial-celebrate-shake .1s ease-in-out 16;
  transform-origin:center center}
@media (prefers-reduced-motion:reduce){
  .learn-welldone-overlay,.learn-welldone-panel{transition-duration:0.01ms!important}
  .learn-dial-slot-inner--celebrate .learn-dial-slot-media{animation:none!important}
}
/* Field guide cards */
#panel-guide .fg-card-img-credit{
  font-size:8.6625px;line-height:1.45;color:var(--faint);margin:0 0 10px;max-width:42em;
  letter-spacing:0.02em}

/* Field Guide v2 */
.fg-card-v2{background:transparent;border:none;border-radius:0;
  padding:16px;margin-bottom:16px;position:relative}
.fg-card-header{margin-bottom:12px}
.fg-card-badge{font-size:9.9px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;color:var(--muted)}
.fg-card-name{font-family:'Playfair Display',serif;font-size:27.225px;color:var(--cream);line-height:1.2;margin-bottom:2px}
.fg-card-folk{
  margin:4px 0 6px;
  padding:5px 0 1px;
  max-width:min(38em,100%);
  border-top:1px solid rgba(212,168,90,0.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04)}
.fg-card-folk-label{
  display:block;
  font-family:'IBM Plex Mono',monospace;
  font-size:6.6px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:rgba(188,168,138,0.52);
  margin-bottom:3px}
.fg-card-folk-line{
  display:block;
  font-family:'IBM Plex Mono',monospace;
  font-size:8.1px;
  line-height:1.45;
  letter-spacing:0.04em;
  color:rgba(210,196,168,0.76)}
.fg-card-latin{font-size:12.375px;font-style:italic;color:var(--amber2);letter-spacing:0.5px;margin-bottom:4px;margin-top:0}
.fg-stages{display:flex;gap:6px;overflow-x:auto;padding:10px 0;margin-bottom:12px;
  scrollbar-width:thin;scrollbar-color:rgba(200,180,140,0.15) transparent}
.fg-stage{flex:0 0 auto;width:270px;text-align:center}
.fg-stage-img{width:270px;height:204px;background:transparent;border:none;
  border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;margin-bottom:4px}
.fg-stage-icon{font-size:22.275px;opacity:0.25}
.fg-stage-file{font-size:7.425px;color:var(--muted);opacity:0.5;word-break:break-all;padding:0 4px;line-height:1.3}
.fg-stage-lbl{font-size:8.6625px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.fg-card-layout{display:flex;flex-direction:row;align-items:stretch;gap:0;margin-bottom:12px}
.fg-card-adult{flex:0 0 auto;width:270px;align-self:flex-start}
.fg-card-adult .fg-stage-img{width:270px;height:204px}
.fg-card-adult-divider{flex:0 0 1px;width:1px;align-self:stretch;pointer-events:none}
.fg-card-info{flex:1;min-width:0;display:flex;flex-direction:column}
.fg-card-desc{font-size:12.375px;line-height:1.7;color:rgba(232,224,208,0.7);margin-bottom:12px;flex:1;min-width:0}
.fg-card-audio{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.fg-audio{display:flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;
  border:none;border-radius:0;font-size:9.9px;color:var(--muted)}
.fg-audio-file{font-size:8.6625px;opacity:0.5}
.fg-audio-lbl{font-size:8.6625px;letter-spacing:1px;text-transform:uppercase;color:var(--amber);opacity:0.6}
.fg-link{display:inline-block;font-size:11.1375px;color:var(--green);text-decoration:none;
  border:1px solid var(--wfts-c-stone-25);border-radius:5px;padding:4px 10px;transition:all 0.15s}
.fg-link:hover{background:var(--wfts-c-stone-12);border-color:var(--wfts-c-mute-40)}
/* Field guide — jump nav, breeding sections, media */
.fg-species-nav{
  display:flex;flex-wrap:wrap;align-items:center;gap:2px 0;margin:0 0 12px;padding:10px 0 12px;
  border-top:1px solid var(--wfts-c-stone-22);border-bottom:1px solid var(--wfts-c-stone-18);
  overflow-x:auto;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.fg-species-nav-link{
  font-family:'IBM Plex Mono',monospace;font-size:10.5187px;letter-spacing:0.05em;
  color:var(--amber2);text-decoration:none;background:transparent;border:none;padding:6px 10px;
  opacity:0.8;transition:opacity .2s ease,color .15s ease;cursor:pointer;
  display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;
  white-space:normal;text-align:left}
.fg-species-nav-link .fg-species-nav-name{
  display:block;font-weight:500;line-height:1.2;letter-spacing:0.04em;color:inherit}
.fg-species-nav-link .fg-species-nav-latin{
  display:block;font-size:0.82em;font-style:italic;font-weight:400;letter-spacing:0.02em;
  line-height:1.25;color:var(--amber2);opacity:0.88}
.fg-species-nav-link:hover{opacity:1;color:var(--amber)}
.fg-species-nav-link:hover .fg-species-nav-latin{color:var(--amber2);opacity:0.95}
#panel-guide .fg-species-nav{
  border-top-color:var(--wfts-c-stone-12);border-bottom-color:rgba(92,90,88,0.1)}
#fg-species-nav.fg-species-nav--dock{
  position:fixed;left:0;right:0;z-index:44;display:none;flex-direction:column;align-items:center;
  margin:0;padding:0;
  border-bottom:1px solid var(--wfts-c-stone-22);
  background:rgba(18,17,15,0.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-sizing:border-box;width:100%}
#fg-species-nav.fg-species-nav--dock:not([hidden]){display:flex}
#fg-species-nav.fg-species-nav--dock .fg-species-dock-track{
  display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;gap:0;
  overflow-x:hidden;overflow-y:hidden;
  width:min(1920px,100%);max-width:100%;margin:0 auto;box-sizing:border-box;align-self:center;
  padding:4px clamp(10px,2.4vw,28px) 6px;
  scroll-behavior:auto}
#fg-species-nav.fg-species-nav--dock .fg-species-nav-link{
  flex:1 1 0;min-width:0;padding:7px clamp(3px,0.9vw,8px) 6px;box-sizing:border-box;
  border-bottom:2px solid transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  white-space:normal;overflow:hidden;
  font-size:clamp(7.92px,1.85vw,10.1375px);letter-spacing:0.03em;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  transition:opacity .2s ease,color .15s ease,border-color .2s ease}
#fg-species-nav.fg-species-nav--dock .fg-species-nav-link .fg-species-nav-name{
  text-align:center;max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden}
#fg-species-nav.fg-species-nav--dock .fg-species-nav-link .fg-species-nav-latin{
  text-align:center;font-size:max(7px,0.78em);-webkit-line-clamp:2;display:-webkit-box;
  -webkit-box-orient:vertical;overflow:hidden;max-width:100%}
#fg-species-nav.fg-species-nav--dock .fg-species-nav-link:not(:last-child){
  border-right:1px solid var(--wfts-c-stone-22)}
#fg-species-nav.fg-species-nav--dock .fg-species-nav-link--inview{
  opacity:1;color:rgba(244,228,196,0.96);border-bottom-color:rgba(212,168,90,0.92)}
/* Atlas — history playback + date controls (fixed under main nav, like species strip) */
.atlas-history-dock{
  position:fixed;left:0;right:0;z-index:44;box-sizing:border-box;
  border-bottom:1px solid var(--wfts-c-stone-22);
  background:rgba(18,17,15,0.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;
  font-family:'IBM Plex Mono',monospace}
.atlas-history-dock:not([hidden]){display:block}
.atlas-history-dock[hidden]{display:none!important}
.atlas-history-dock-inner{
  display:flex;flex-wrap:wrap;align-items:center;align-content:center;row-gap:8px;
  padding:6px clamp(10px,2.5vw,36px) 8px;max-width:min(1920px,98vw);margin:0 auto;box-sizing:border-box}
.atlas-history-dock-seg{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;flex-shrink:0;
  padding:0 12px 0 0;margin-right:4px;border-right:1px solid var(--wfts-c-stone-22)}
.atlas-history-dock-seg:last-child{border-right:0;padding-right:0;margin-right:0}
.atlas-history-dock .a-play,
.calling-subnav .a-play{
  flex:0 0 auto;min-width:92px;margin:0;padding:6px 12px;font-size:9.9px;letter-spacing:0.5px}
.atlas-history-dock .a-scope-pills{margin:0}
.atlas-history-dock .a-scope-pill{padding:5px 9px;font-size:8.6625px}
.atlas-history-dock .a-yr-pick,.calling-subnav .a-yr-pick{margin:0;gap:6px}
.atlas-history-dock .a-yr-pick label,.calling-subnav .a-yr-pick label{font-size:7.425px;letter-spacing:0.12em;white-space:nowrap}
.atlas-history-dock #a-yr-select,.atlas-history-dock #a-month-select{
  min-width:4.6em;padding:4px 7px;font-size:11.1375px}
/* Calendar — play + year under main tabs (fixed strip) */
.calling-subnav{
  position:fixed;left:0;right:0;z-index:44;box-sizing:border-box;
  border-bottom:1px solid var(--wfts-c-stone-22);
  background:rgba(18,17,15,0.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  font-family:'IBM Plex Mono',monospace}
.calling-subnav[hidden]{display:none!important}
.calling-subnav:not([hidden]){display:block}
.calling-subnav-inner{
  display:flex;flex-wrap:wrap;align-items:center;gap:12px 20px;
  padding:6px clamp(10px,2.5vw,36px) 8px;max-width:min(1920px,98vw);margin:0 auto;box-sizing:border-box}
.calling-subnav #sm-yr-select{
  min-width:4.6em;padding:4px 7px;font-size:11.1375px;
  background:var(--wfts-c-surface-50);border:1px solid var(--wfts-c-stone-25);color:var(--text);
  border-radius:4px;outline:none;cursor:pointer;appearance:auto}
.calling-subnav #sm-yr-select:focus{border-color:#8a8884}
.atlas-history-dock #atlas-dock-slider-seg{flex:1 1 180px;min-width:min(240px,42vw)}
.atlas-history-dock #a-slider-wrap{margin:0;width:100%}
.atlas-history-dock #a-slider-lbl{margin-bottom:3px;font-size:7.425px}
.atlas-history-dock .a-slider{width:100%}
.atlas-history-dock .a-mode-pills{display:flex;gap:4px;margin:0;flex-shrink:0;flex-wrap:wrap}
.atlas-history-dock .a-mode-pill{flex:0 1 auto;min-width:4.5em;padding:5px 10px}
.atlas-history-dock .ab-toggle,.audio-bar .ab-toggle{display:flex;align-items:center;gap:6px;font-size:11.1375px;letter-spacing:1px;color:var(--muted);cursor:pointer;user-select:none;transition:color 0.15s}
.atlas-history-dock .ab-toggle:hover,.audio-bar .ab-toggle:hover{color:var(--cream)}
.atlas-history-dock .ab-toggle.on,.audio-bar .ab-toggle.on{color:var(--amber)}
.atlas-history-dock .ab-toggle .ab-icon,.audio-bar .ab-toggle .ab-icon{font-size:14.85px}
.atlas-history-dock .ab-sep{width:1px;height:16px;background:rgba(200,180,140,0.1);flex-shrink:0;margin:0 6px}
.audio-bar .ab-sep{width:1px;height:16px;background:rgba(200,180,140,0.1)}
.atlas-history-dock-seg.atlas-dock-map-layers{
  flex:1 1 min(420px,100%);min-width:min(100%,220px);max-width:100%}
.fg-guide-back-top-wrap{
  position:fixed;z-index:100;bottom:max(18px,env(safe-area-inset-bottom,0px));right:max(18px,env(safe-area-inset-right,0px));
  display:flex;align-items:center;justify-content:flex-end;gap:10px;pointer-events:none}
.fg-guide-back-top-wrap[hidden]{display:none!important}
.fg-guide-back-top-lbl{
  pointer-events:none;font-family:'IBM Plex Mono',monospace;font-size:10.395px;letter-spacing:0.06em;
  color:rgba(212,168,90,0.78);white-space:nowrap;text-shadow:none}
.fg-guide-back-top-fab{
  pointer-events:auto;flex-shrink:0;width:44px;height:44px;border-radius:50%;border:1px solid var(--wfts-c-stone-35);
  background:rgba(22,21,19,0.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:rgba(212,168,90,0.92);font-size:22.275px;line-height:1;cursor:pointer;
  box-shadow:0 4px 20px rgba(0,0,0,0.25);transition:background .15s ease,color .15s ease,border-color .15s ease;
  display:flex;align-items:center;justify-content:center;padding:0}
.fg-guide-back-top-fab:hover{color:var(--amber2);border-color:rgba(212,168,90,0.45);background:rgba(28,27,26,0.92)}
.atlas-reset-view-wrap{
  position:fixed;z-index:100;
  /* Vertically center with footer amb toggles (same band as --wfts-footer-reserve) */
  bottom:calc(var(--wfts-footer-reserve) / 2);
  transform:translateY(50%);
  right:max(18px,env(safe-area-inset-right,0px));
  display:flex;align-items:center;justify-content:flex-end;gap:10px;pointer-events:none;
  flex-direction:row;flex-wrap:nowrap}
.atlas-reset-view-wrap[hidden]{display:none!important}
.atlas-reset-view-lbl{
  pointer-events:none;font-family:'IBM Plex Mono',monospace;font-size:10.395px;letter-spacing:0.06em;
  color:rgba(212,168,90,0.78);white-space:nowrap;text-shadow:0 1px 8px rgba(0,0,0,0.65)}
.atlas-reset-view-fab{
  pointer-events:auto;flex-shrink:0;width:44px;height:44px;border-radius:50%;border:1px solid var(--wfts-c-stone-35);
  background:rgba(22,21,19,0.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:rgba(212,168,90,0.92);font-size:22.275px;line-height:1;font-family:'IBM Plex Mono',monospace;cursor:pointer;
  box-shadow:0 4px 20px rgba(0,0,0,0.25);transition:background .15s ease,color .15s ease,border-color .15s ease;
  display:flex;align-items:center;justify-content:center;padding:0}
.atlas-reset-view-fab:hover{color:var(--amber2);border-color:rgba(212,168,90,0.45);background:rgba(28,27,26,0.92)}
/* Match JS paddingTop (base + dock) + slack so scrollIntoView / hash / focus don’t hide the species header under the fixed strip */
#panel-guide .fg-card-v2[id^="fg-"]{
  scroll-margin-top:calc(var(--fg-guide-pad-top-base, 28px) + var(--fg-subnav-h, 0px) + 110px)}
/* Active species (nav / scroll): viewport-tall frame — title high, carousel centered on star field, copy + audio low */
#panel-guide .fg-card-v2--species-frame > .fg-card-layout{
  min-height:calc(100svh - var(--wfts-layout-chrome, 56px) - var(--fg-subnav-h, 0px) - 32px);
  display:flex;
  flex-direction:column}
#panel-guide .fg-card-v2--species-frame > .fg-card-layout > .fg-card-info{
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
  gap:0}
#panel-guide .fg-card-v2--species-frame .fg-card-header{
  flex-shrink:0;
  margin-bottom:clamp(-84px,-14vw,-52px)}
#panel-guide .fg-card-v2--species-frame .fg-card-name{
  font-size:clamp(28px,4vw,40px);
  line-height:1.08;
  color:rgba(252,240,210,0.98)}
#panel-guide .fg-card-v2--species-frame .fg-card-folk{
  margin:6px 0 8px;
  padding-top:6px;
  border-top-color:rgba(212,168,90,0.2)}
#panel-guide .fg-card-v2--species-frame .fg-card-folk-label{
  font-size:clamp(6.2px,1vw,7.2px);
  margin-bottom:4px;
  color:rgba(200,176,140,0.58)}
#panel-guide .fg-card-v2--species-frame .fg-card-folk-line{
  font-size:clamp(7.6px,1.15vw,9.25px);
  color:rgba(218,202,172,0.82)}
#panel-guide .fg-card-v2--species-frame .fg-card-badge--latin-label{
  margin-top:clamp(8px,1.2vw,12px)}
#panel-guide .fg-card-v2--species-frame .fg-card-latin{
  font-size:clamp(13px,1.85vw,17px);
  margin-top:2px}
#panel-guide .fg-card-v2--species-frame .fg-gallery-wrap.fg-card-carousel{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:stretch;
  min-height:min(50svh,440px);
  margin:6px 0 14px}
#panel-guide .fg-card-v2--species-frame .fg-photo-pile-wrap.fg-card-carousel{
  flex:1 1 auto;
  min-height:min(50svh,440px);
  margin:6px auto 14px}
#panel-guide .fg-card-v2--species-frame .fg-card-desc{
  flex-shrink:0;
  margin-top:4px;
  max-width:min(52em,100%)}
#panel-guide .fg-card-v2--species-frame .fg-card-audio,
#panel-guide .fg-card-v2--species-frame .fg-card-extlinks,
#panel-guide .fg-card-v2--species-frame .fg-link{
  flex-shrink:0}
/* Stacked: species name → photo gallery (hero + thumbnails) → description → audio / links */
#panel-guide .fg-card-layout{
  flex-direction:column;
  align-items:stretch;
  gap:12px;
  margin-bottom:12px}
#panel-guide .fg-card-info{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:0;
  position:relative}
/* Common name, folk names, Latin overlap the photo strip (no dark scrim over images) */
#panel-guide .fg-card-info .fg-card-header{
  position:relative;
  z-index:3;
  align-items:flex-end;
  margin-bottom:clamp(-68px,-12vw,-44px);
  margin-left:calc(-1 * clamp(6px,1.6vw,14px));
  margin-right:calc(-1 * clamp(6px,1.6vw,14px));
  padding:6px clamp(10px,2.2vw,18px) clamp(14px,2.8vw,22px);
  border-radius:0 0 clamp(12px,2vw,18px) clamp(12px,2vw,18px);
  background:transparent;
  box-shadow:none}
#panel-guide .fg-card-header{
  display:flex;flex-direction:row;align-items:flex-end;gap:clamp(10px,2.5vw,16px)}
#panel-guide .fg-card-header-thumb{
  width:clamp(52px,11vw,84px);height:clamp(52px,11vw,84px);object-fit:contain;flex-shrink:0;
  border-radius:10px;background:transparent;border:none;
  box-sizing:border-box;
  opacity:0;
  visibility:visible;
  -moz-force-broken-image-icon:0;
  transition:opacity .42s ease}
#panel-guide .fg-card-header-thumb.fg-img-loaded{
  visibility:visible;
  opacity:1}
#panel-guide .fg-card-header-thumb.fg-img-failed{
  -moz-force-broken-image-icon:0;
  visibility:hidden!important;
  opacity:0!important}
#panel-guide .fg-card-header-text{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:0}
#panel-guide .fg-card-desc{
  flex:0 1 auto;
  min-width:0;
  width:auto;
  max-width:none;
  margin:0 0 12px;
  text-align:left}
#panel-guide .fg-breed-legend{
  font-size:8.6625px;color:var(--muted);letter-spacing:0.06em;margin:12px 0 6px;line-height:1.5}
#panel-guide .fg-guild-label{
  font-size:11.1375px;color:var(--muted);margin:18px 0 8px;line-height:1.45;font-weight:400;letter-spacing:0.02em}
#panel-guide .fg-phenology{
  margin:8px 0 10px;padding:6px 0 2px;
  background:transparent;border:none;border-radius:0;box-shadow:none}
#panel-guide .fg-phenology-hdr{
  font-family:'IBM Plex Mono',monospace;font-size:7.425px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--wfts-c-amber-55);margin:0 0 5px}
#panel-guide .fg-phenology-list{
  margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:5px}
#panel-guide .fg-phenology-list li{
  font-size:9.9px;line-height:1.45;color:rgba(200,194,178,0.78);margin:0;padding:0;list-style:none}
#panel-guide .fg-phenology-list li::before{content:none!important;display:none!important}
#panel-guide .fg-ph-label{
  display:block;font-family:'IBM Plex Mono',monospace;font-size:7.425px;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(138,136,132,0.68);margin-bottom:1px}
#panel-guide .fg-phenology-list strong{color:var(--wfts-c-text-95);font-weight:500}
/* Species photos: hidden until .fg-img-loaded (no custom-property opacity — avoids calc/var bugs in some engines) */
#panel-guide .fg-stage-img img{
  opacity:0;
  visibility:visible;
  -moz-force-broken-image-icon:0;
  transition:opacity .42s ease}
#panel-guide .fg-stage-img img.fg-img-loaded{
  visibility:visible;
  opacity:1}
/* Paths with `_vintage_`: old plate scans may include a footnote band at the bottom — clip slightly. */
#panel-guide .fg-stage-img img.fg-plate-scan-crop.fg-img-loaded{
  -webkit-clip-path:inset(0 0 clamp(18px,6.2%,52px) 0);
  clip-path:inset(0 0 clamp(18px,6.2%,52px) 0)}
#panel-guide .fg-stage-img img.fg-img-failed{
  -moz-force-broken-image-icon:0;
  visibility:hidden!important;
  opacity:0!important}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-stage-img img,
  #panel-guide .fg-card-header-thumb,
  #panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img{
    transition:none}}
.fg-stage-img img{width:100%;height:100%;object-fit:contain;object-position:center center;display:block;border-radius:1px;border:none;outline:none;box-shadow:none}
.fg-stage-img--stack{display:flex;flex-direction:column;gap:9px;height:auto;min-height:204px;justify-content:center}
.fg-stage-img--stack img{height:96px;width:100%;object-fit:contain;background:transparent}
.fg-stage-img--na{display:flex;align-items:center;justify-content:center}
.fg-stage-na{font-size:13.6125px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);opacity:0.5}
/* Field guide: empty transparent cells when photos are omitted (replaces missing assets/fieldguide/*) */
.fg-stage-img--ph{background:transparent}
.fg-stage-img--stack > .fg-stage-stack-slot{
  height:96px;width:100%;flex-shrink:0;background:transparent;border-radius:1px}
#fg-grid .fg-grid-ph{
  width:100%;height:420px;border-radius:6px;margin-bottom:10px;background:transparent}
.fg-audio audio{height:28px;width:min(200px,44vw);max-width:100%}
.fg-audio{align-items:center;gap:8px}
/* Field guide — draggable photo pile */
#panel-guide .fg-photo-pile-wrap{
  position:relative;
  width:100%;
  max-width:none;
  margin:2px auto 14px;
  /* Gutter for photos dragged past .fg-photo-pile-canvas — keep in sync with js PILE_DRAG_PAD_X / PILE_DRAG_PAD_Y */
  --fg-pile-drag-pad-x:clamp(8px,4vw,120px);
  --fg-pile-drag-pad-y:clamp(8px,2.5vw,72px);
  padding:var(--fg-pile-drag-pad-y) var(--fg-pile-drag-pad-x);
  box-sizing:border-box;
  overflow:visible}
#panel-guide .fg-photo-pile-wrap::before{display:none}
#panel-guide .fg-photo-pile-canvas{
  position:relative;
  z-index:1;
  width:100%;
  min-height:clamp(260px,42vw,420px);
  margin:0;
  padding:0;
  list-style:none;
  overflow:visible;
  contain:layout;
  background:
    linear-gradient(rgba(212,168,90,0.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,168,90,0.045) 1px,transparent 1px);
  background-size:20px 20px,20px 20px;
  background-position:0 0,0 0;
  touch-action:none}
#panel-guide .fg-photo-pile-canvas .fg-stage{
  position:absolute;
  left:0;
  top:0;
  margin:0;
  padding:0;
  box-sizing:border-box;
  text-align:center;
  cursor:grab;
  user-select:none;
  border:none;
  border-radius:4px;
  background:transparent;
  container-type:inline-size;
  container-name:fg-pile-stage;
  --fg-photo-rot:0deg;
  --fg-photo-scale:1.25;
  --fg-pile-x:0px;
  --fg-pile-y:0px;
  transform:translate3d(var(--fg-pile-x,0px),var(--fg-pile-y,0px),0) rotate(calc(var(--fg-desk-thumb-rot,0deg) + var(--fg-photo-rot,0deg))) scale(var(--fg-photo-scale,1.25));
  transform-origin:center center;
  overflow:visible;
  box-shadow:none;
  will-change:auto;
  backface-visibility:hidden}
#panel-guide .fg-photo-pile-canvas .fg-stage::before{display:none}
#panel-guide .fg-photo-pile-canvas .fg-stage--active{
  filter:drop-shadow(0 6px 18px rgba(0,0,0,0.22))}
#panel-guide .fg-photo-pile-canvas .fg-stage.is-dragging{
  cursor:grabbing;
  will-change:transform;
  filter:drop-shadow(0 12px 26px rgba(0,0,0,0.32));
  animation:none!important}
#panel-guide .fg-photo-pile-canvas .fg-stage:focus-visible{
  outline:1px solid rgba(212,168,90,0.58);
  outline-offset:3px}
/* Stable mat size — do not tie min-height to :has() (failed/hidden img used to drop min-height → tiny box).
   Min width/height can exceed a small bitmap’s box; without centering, the extra paper shows on the right and bottom only (block img defaults to top-left), which looks like uneven matting. */
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img:not(.fg-stage-img--stack){
  min-height:clamp(96px,20vw,200px);
  min-width:min(100%,max(72px,26vw));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center}
/* Paper mat + handle spacing track photo frame width (container query) so layout stays consistent across aspects */
/* Stack depth + edge fade (--fg-stack-opacity, --fg-edge-opacity on .fg-stage) apply to mat + photo together */
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img{
  container-type:inline-size;
  container-name:fg-pile-photo;
  --fg-pile-mat:clamp(5px,2.8cqw,12px);
  /* Pile handles: uniform stroke + rest (near frame) vs out (on stage hover) */
  --fg-handle-line:2px;
  --fg-scale-handle-rest:clamp(6px,3.2cqw,20px);
  --fg-scale-handle-out:clamp(15px,6cqw,38px);
  --fg-rot-handle-rest:clamp(4px,2.2cqw,14px);
  --fg-rot-handle-out:clamp(8px,3.6cqw,22px);
  --fg-l-arm:clamp(10px,3.2cqw,17px);
  width:fit-content;
  max-width:100%;
  margin:0 auto;
  position:relative;
  box-sizing:border-box;
  padding:var(--fg-pile-mat);
  height:auto;
  border-radius:2px;
  overflow:visible;
  isolation:isolate;
  opacity:calc(var(--fg-edge-opacity, 1) * var(--fg-stack-opacity, 1));
  transition:opacity .42s ease;
  background:linear-gradient(168deg,rgba(252,248,238,0.98) 0%,rgba(236,228,210,0.95) 46%,rgba(218,206,182,0.93) 100%);
  border:1px solid rgba(40,36,32,0.28);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 6px 16px rgba(0,0,0,0.16),
    0 2px 5px rgba(0,0,0,0.08)}
/* Paper layer under bitmaps so mix-blend-mode darkens photos into the stock */
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img::before{
  content:'';
  position:absolute;
  z-index:0;
  left:var(--fg-pile-mat);
  top:var(--fg-pile-mat);
  right:var(--fg-pile-mat);
  bottom:var(--fg-pile-mat);
  border-radius:1px;
  pointer-events:none;
  background:linear-gradient(168deg,rgba(252,248,238,0.99) 0%,rgba(234,224,200,0.97) 42%,rgba(212,196,168,0.96) 100%)}
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img--stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:clamp(6px,2cqw,11px);
  width:fit-content;
  max-width:100%;
  margin:0 auto;
  overflow:visible}
/* Pile photos: stay visible by default — do not gate on .fg-img-loaded (lazy/hidden-tab/rAF stalls left opacity:0 forever). */
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img img{
  position:relative;
  z-index:1;
  display:block;
  width:auto;
  height:auto;
  max-width:100%;
  min-width:0;
  object-fit:contain;
  object-position:center center;
  mix-blend-mode:normal;
  opacity:1;
  filter:none;
  visibility:visible;
  -moz-force-broken-image-icon:0;
  transition:opacity .32s ease}
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img img.fg-img-failed{
  visibility:hidden!important;
  opacity:0!important}
/* Hover sequence: player wraps poster img; hit-testing uses stage rect + panel pointer probe (see app.js). */
#panel-guide .fg-photo-pile-canvas .fg-stage--hylaseq .fg-seq-player{
  position:relative;
  display:block;
  width:100%;
  max-width:100%}
#panel-guide .fg-photo-pile-canvas .fg-stage--hylaseq .fg-seq-player .fg-seq-img{
  position:relative;
  z-index:1}
/* Broken poster must not block geometry (stage rect still receives pointer). */
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img img.fg-seq-img.fg-img-failed{
  pointer-events:none!important}
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img--stack img{
  width:auto;
  max-width:100%;
  height:96px;
  max-height:96px;
  flex-shrink:0;
  object-fit:contain;
  mix-blend-mode:normal;
  opacity:1;
  visibility:visible;
  -moz-force-broken-image-icon:0;
  transition:opacity .32s ease}
#panel-guide .fg-photo-pile-canvas .fg-stage .fg-stage-img--stack img.fg-img-failed{
  visibility:hidden!important;
  opacity:0!important}
/* Label lives inside .fg-stage-img so width tracks the photo + mat, not the draggable card */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-stage-lbl{
  position:absolute;
  left:var(--fg-pile-mat);
  right:var(--fg-pile-mat);
  top:var(--fg-pile-mat);
  bottom:auto;
  margin:0;
  z-index:12;
  pointer-events:none;
  text-align:center;
  font-size:7.05px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  line-height:1.35;
  color:rgba(0,0,0,0.72);
  text-shadow:none;
  padding:5px 7px 6px;
  background:transparent;
  box-sizing:border-box;
  max-width:100%}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-stage-lbl--caption{
  text-transform:none;
  letter-spacing:0.04em;
  line-height:1.38;
  font-size:6.75px;
  font-style:italic;
  color:rgba(0,0,0,0.68);
  max-height:3.2em;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical}
#panel-guide .fg-photo-pile-canvas .fg-stage.fg-stage--light-field-text .fg-stage-img > .fg-stage-lbl,
#panel-guide .fg-photo-pile-canvas .fg-stage.fg-stage--light-field-text .fg-stage-img > .fg-stage-lbl--caption{
  color:rgba(255,255,255,0.96);
  mix-blend-mode:normal;
  text-shadow:none}
#panel-guide .fg-photo-pile-canvas .fg-stage.fg-stage--light-field-text .fg-stage-img > .fg-stage-source-word{
  color:rgba(255,255,255,0.94);
  text-shadow:none}
#panel-guide .fg-photo-pile-canvas .fg-stage.fg-stage--light-field-text .fg-stage-img > .fg-stage-source-word:hover{
  color:rgba(255,255,255,1)}
/* Corner hits: rotate = solid rings at outer card corners; scale = L-brackets, retract+fade out when idle */
#panel-guide .fg-photo-pile-canvas .fg-corner-hit{
  position:absolute;
  z-index:10;
  margin:0;
  padding:0;
  border:none;
  background:transparent;
  -webkit-tap-highlight-color:transparent}
/* Rotation hits: size from photo mat width (same cqw basis as scale handles) */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--rot{
  --fg-corner-hit-size:clamp(48px,28cqw,82px);
  width:var(--fg-corner-hit-size);
  height:var(--fg-corner-hit-size);
  z-index:18}
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--rot{
  pointer-events:none;
  cursor:grab}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--scale{
  --fg-corner-hit-size:clamp(48px,28cqw,82px);
  width:var(--fg-corner-hit-size);
  height:var(--fg-corner-hit-size);
  z-index:20;
  cursor:nwse-resize;
  opacity:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  transition:
    opacity .32s cubic-bezier(0.4,0,0.2,1),
    transform .45s cubic-bezier(0.33,1.02,0.45,1)}
/* Upper-right: near frame when idle; stage hover slides grip outward */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tr{
  left:auto;
  right:0;
  top:0;
  bottom:auto;
  transform:translate(calc(50% + var(--fg-scale-handle-rest,8px)),calc(-50% - var(--fg-scale-handle-rest,8px))) scale(0.48)}
/* Lower-left */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--bl{
  left:0;
  right:auto;
  top:auto;
  bottom:0;
  transform:translate(calc(-50% - var(--fg-scale-handle-rest,8px)),calc(50% + var(--fg-scale-handle-rest,8px))) scale(0.48)}
/* TR scale: ⌝ — uniform line thickness (--fg-handle-line) */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tr::before{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:var(--fg-l-arm,12px);
  height:var(--fg-handle-line,2px);
  margin-top:calc(var(--fg-handle-line,2px) / -2);
  transform:translate(-100%,0);
  background:rgba(212,168,90,0.97);
  pointer-events:none}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tr::after{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:var(--fg-handle-line,2px);
  margin-left:calc(var(--fg-handle-line,2px) / -2);
  height:var(--fg-l-arm,12px);
  transform:translate(0,0);
  background:rgba(212,168,90,0.97);
  pointer-events:none}
/* BL scale: ⌞ */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--bl::before{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:var(--fg-l-arm,12px);
  height:var(--fg-handle-line,2px);
  margin-top:calc(var(--fg-handle-line,2px) / -2);
  transform:translate(0,0);
  background:rgba(212,168,90,0.97);
  pointer-events:none}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--bl::after{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:var(--fg-handle-line,2px);
  margin-left:calc(var(--fg-handle-line,2px) / -2);
  height:var(--fg-l-arm,12px);
  transform:translate(0,-100%);
  background:rgba(212,168,90,0.97);
  pointer-events:none}
#panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-stage-img > .fg-corner-hit--tr,
#panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-stage-img > .fg-corner-hit--tr,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tr:focus-visible,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tr.fg-corner-hit--dragging{
  opacity:1;
  transform:translate(calc(50% + var(--fg-scale-handle-out,18px)),calc(-50% - var(--fg-scale-handle-out,18px))) scale(1);
  pointer-events:auto}
#panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-stage-img > .fg-corner-hit--bl,
#panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-stage-img > .fg-corner-hit--bl,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--bl:focus-visible,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--bl.fg-corner-hit--dragging{
  opacity:1;
  transform:translate(calc(-50% - var(--fg-scale-handle-out,18px)),calc(50% + var(--fg-scale-handle-out,18px))) scale(1);
  pointer-events:auto}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--scale:focus-visible{
  outline:none}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--scale:focus-visible::before,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--scale:focus-visible::after{
  filter:drop-shadow(0 0 3px rgba(212,168,90,0.75))}
/* Rotation affordance: ring trim (--fg-rot-trim 0→1) and tilt scale together on hover; reverses on mouse off */
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--tl::after,
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--br::after{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:clamp(16px,5.2cqw,28px);
  height:clamp(16px,5.2cqw,28px);
  margin:0;
  box-sizing:border-box;
  border-radius:50%;
  border:2px solid rgba(212,168,90,0.9);
  background:transparent;
  pointer-events:none;
  opacity:0;
  --fg-rot-trim:0;
  transform:translate(-50%,-50%) scale(0.45) rotate(0deg);
  transform-origin:center center;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-size:100% 100%;
  mask-size:100% 100%;
  transition:
    opacity .32s cubic-bezier(0.4,0,0.2,1),
    transform .5s cubic-bezier(0.33,1.02,0.45,1),
    --fg-rot-trim .52s cubic-bezier(0.45,0,0.15,1)}
/* Counter-rotate mask vs ring tilt (±14°) so trim stays on the frame bisector */
@media (prefers-reduced-motion:no-preference){
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--tl::after{
    -webkit-mask-image:conic-gradient(from 14deg at 50% 50%,#000 0deg,#000 calc(45deg * var(--fg-rot-trim)),transparent calc(45deg * var(--fg-rot-trim)),transparent 225deg,#000 225deg,#000 calc(225deg + 135deg * var(--fg-rot-trim)),transparent calc(225deg + 135deg * var(--fg-rot-trim)),transparent 360deg);
    mask-image:conic-gradient(from 14deg at 50% 50%,#000 0deg,#000 calc(45deg * var(--fg-rot-trim)),transparent calc(45deg * var(--fg-rot-trim)),transparent 225deg,#000 225deg,#000 calc(225deg + 135deg * var(--fg-rot-trim)),transparent calc(225deg + 135deg * var(--fg-rot-trim)),transparent 360deg)}
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--br::after{
    -webkit-mask-image:conic-gradient(from -14deg at 50% 50%,transparent 0deg,transparent calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg + 90deg * var(--fg-rot-trim)),transparent calc(135deg + 90deg * var(--fg-rot-trim)),transparent 360deg);
    mask-image:conic-gradient(from -14deg at 50% 50%,transparent 0deg,transparent calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg + 90deg * var(--fg-rot-trim)),transparent calc(135deg + 90deg * var(--fg-rot-trim)),transparent 360deg)}
}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--tl::after{
    -webkit-mask-image:conic-gradient(from 0deg at 50% 50%,#000 0deg,#000 calc(45deg * var(--fg-rot-trim)),transparent calc(45deg * var(--fg-rot-trim)),transparent 225deg,#000 225deg,#000 calc(225deg + 135deg * var(--fg-rot-trim)),transparent calc(225deg + 135deg * var(--fg-rot-trim)),transparent 360deg);
    mask-image:conic-gradient(from 0deg at 50% 50%,#000 0deg,#000 calc(45deg * var(--fg-rot-trim)),transparent calc(45deg * var(--fg-rot-trim)),transparent 225deg,#000 225deg,#000 calc(225deg + 135deg * var(--fg-rot-trim)),transparent calc(225deg + 135deg * var(--fg-rot-trim)),transparent 360deg)}
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--br::after{
    -webkit-mask-image:conic-gradient(from 0deg at 50% 50%,transparent 0deg,transparent calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg + 90deg * var(--fg-rot-trim)),transparent calc(135deg + 90deg * var(--fg-rot-trim)),transparent 360deg);
    mask-image:conic-gradient(from 0deg at 50% 50%,transparent 0deg,transparent calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg - 90deg * var(--fg-rot-trim)),#000 calc(135deg + 90deg * var(--fg-rot-trim)),transparent calc(135deg + 90deg * var(--fg-rot-trim)),transparent 360deg)}
}
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--rot.fg-corner-hit--tl.fg-corner-hit--dragging::after{
  opacity:1;
  --fg-rot-trim:1;
  transform:translate(-50%,-50%) scale(1.07) rotate(-14deg)}
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--rot.fg-corner-hit--br.fg-corner-hit--dragging::after{
  opacity:1;
  --fg-rot-trim:1;
  transform:translate(-50%,-50%) scale(1.07) rotate(14deg)}
@media (hover:hover){
  #panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-corner-hit--rot,
  #panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-corner-hit--rot{
    pointer-events:auto}
  #panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-corner-hit--tl::after,
  #panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-corner-hit--tl::after{
    opacity:1;
    --fg-rot-trim:1;
    transform:translate(-50%,-50%) scale(1.07) rotate(-14deg)}
  #panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-corner-hit--br::after,
  #panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-corner-hit--br::after{
    opacity:1;
    --fg-rot-trim:1;
    transform:translate(-50%,-50%) scale(1.07) rotate(14deg)}}
@media (hover:none){
  #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-corner-hit--rot{
    pointer-events:auto}
  #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-corner-hit--tl::after{
    opacity:1;
    --fg-rot-trim:1;
    transform:translate(-50%,-50%) scale(1.07) rotate(-14deg)}
  #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-corner-hit--br::after{
    opacity:1;
    --fg-rot-trim:1;
    transform:translate(-50%,-50%) scale(1.07) rotate(14deg)}
  #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-stage-img > .fg-corner-hit--tr{
    opacity:1;
    transform:translate(calc(50% + var(--fg-scale-handle-out,18px)),calc(-50% - var(--fg-scale-handle-out,18px))) scale(1);
    pointer-events:auto}
  #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-stage-img > .fg-corner-hit--bl{
    opacity:1;
    transform:translate(calc(-50% - var(--fg-scale-handle-out,18px)),calc(50% + var(--fg-scale-handle-out,18px))) scale(1);
    pointer-events:auto}}
/* Rotate corners: slide outward on stage hover (same motion model as scale L-brackets) */
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tl{
  left:0;
  top:0;
  right:auto;
  bottom:auto;
  transition:transform .45s cubic-bezier(0.33,1.02,0.45,1);
  transform:translate(calc(-50% - var(--fg-rot-handle-rest,5px)),calc(-50% - var(--fg-rot-handle-rest,5px)))}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--br{
  right:0;
  bottom:0;
  left:auto;
  top:auto;
  transition:transform .45s cubic-bezier(0.33,1.02,0.45,1);
  transform:translate(calc(50% + var(--fg-rot-handle-rest,5px)),calc(50% + var(--fg-rot-handle-rest,5px)))}
#panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-stage-img > .fg-corner-hit--tl,
#panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-stage-img > .fg-corner-hit--tl,
#panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-stage-img > .fg-corner-hit--tl,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tl.fg-corner-hit--dragging{
  transform:translate(calc(-50% - var(--fg-rot-handle-out,10px)),calc(-50% - var(--fg-rot-handle-out,10px)))}
#panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-stage-img > .fg-corner-hit--br,
#panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-stage-img > .fg-corner-hit--br,
#panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-stage-img > .fg-corner-hit--br,
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--br.fg-corner-hit--dragging{
  transform:translate(calc(50% + var(--fg-rot-handle-out,10px)),calc(50% + var(--fg-rot-handle-out,10px)))}
/* Scale handles: position + translate set above (corner-centered, equal pad from top/bottom as from sides) */
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--dragging{
  cursor:grabbing}
#panel-guide .fg-photo-pile-canvas .fg-corner-hit--scale.fg-corner-hit--dragging{
  cursor:nwse-resize}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-photo-pile-canvas .fg-stage{transition:none!important}
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--rot,
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--scale{transition:none!important}
  #panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--tl,
  #panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-corner-hit--br{transition:none!important}
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--tl::after,
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--br::after{transition:none!important}
  @media (hover:hover){
    #panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-corner-hit--tl::after,
    #panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-corner-hit--tl::after{
      opacity:1;
      --fg-rot-trim:1;
      transform:translate(-50%,-50%) scale(1.04)}
    #panel-guide .fg-photo-pile-canvas .fg-stage:hover .fg-corner-hit--br::after,
    #panel-guide .fg-photo-pile-canvas .fg-stage:focus-within .fg-corner-hit--br::after{
      opacity:1;
      --fg-rot-trim:1;
      transform:translate(-50%,-50%) scale(1.04)}}
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--rot.fg-corner-hit--tl.fg-corner-hit--dragging::after,
  #panel-guide .fg-photo-pile-canvas .fg-corner-hit--rot.fg-corner-hit--br.fg-corner-hit--dragging::after{
    --fg-rot-trim:1;
    transform:translate(-50%,-50%) scale(1.04)}
  @media (hover:none){
    #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-corner-hit--tl::after,
    #panel-guide .fg-photo-pile-canvas .fg-stage--active .fg-corner-hit--br::after{
      --fg-rot-trim:1;
      transform:translate(-50%,-50%) scale(1.04)}}}
/* Field guide — hero + thumbnail strip (replaces single-file horizontal carousel) */
.fg-gallery-wrap{
  position:relative;
  max-width:100%;
  margin:0 0 12px;
  padding:0;
  box-sizing:border-box}
/* Slightly rotated “sheets on a desk” — tilts from --fg-desk-* on .fg-gallery-wrap--desk-paper (see app.js) */
#panel-guide .fg-gallery-wrap--desk-paper::before{display:none}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-hero-col,
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs,
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-nav{position:relative;z-index:1}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-hero .fg-stage--hero .fg-stage-img{
  transform:rotate(var(--fg-desk-hero-rot,-0.7deg));
  transform-origin:center center;
  padding:7.5px;
  box-sizing:border-box;
  min-height:calc(15px + clamp(160px,28vw,240px));
  max-height:calc(15px + clamp(280px,52vh,520px));
  margin-bottom:0;
  border-radius:2px;
  background:linear-gradient(168deg,rgba(252,248,238,0.98) 0%,rgba(236,228,210,0.95) 46%,rgba(218,206,182,0.93) 100%);
  border:1px solid rgba(40,36,32,0.32);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.24) inset,
    0 16px 36px rgba(0,0,0,0.38),
    0 5px 14px rgba(0,0,0,0.22),
    1px 3px 0 rgba(0,0,0,0.07);
  transition:transform .4s cubic-bezier(0.25,0.46,0.45,0.94),box-shadow .35s ease}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-hero .fg-stage--hero .fg-stage-img{transition-duration:0.01ms}}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-gallery-thumbs-track{
  padding:12px 10px 16px;
  gap:11px;
  align-items:center}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage{
  transform:rotate(var(--fg-desk-thumb-rot,0deg));
  transform-origin:center center;
  position:relative;
  z-index:0;
  width:98px;
  padding:7px 7px 8px;
  border-radius:2px;
  border:1px solid rgba(42,38,34,0.34);
  background:linear-gradient(168deg,rgba(250,246,234,0.98),rgba(232,222,198,0.94));
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 9px 20px rgba(0,0,0,0.34),
    0 3px 8px rgba(0,0,0,0.18),
    0.5px 2px 0 rgba(0,0,0,0.08);
  transition:transform .32s cubic-bezier(0.25,0.46,0.45,0.94),box-shadow .28s ease,border-color .2s ease,background .2s ease}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage:hover{
  z-index:5;
  transform:rotate(var(--fg-desk-thumb-rot,0deg));
  border-color:rgba(212,168,90,0.42);
  background:linear-gradient(168deg,rgba(255,252,244,0.99),rgba(240,230,208,0.97));
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 9px 20px rgba(0,0,0,0.34),
    0 3px 8px rgba(0,0,0,0.18),
    0.5px 2px 0 rgba(0,0,0,0.08)}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage--active{
  z-index:3;
  transform:rotate(var(--fg-desk-thumb-rot,0deg)) translateY(-3px);
  border-color:rgba(212,168,90,0.48);
  background:linear-gradient(168deg,rgba(254,251,242,0.99),rgba(242,232,208,0.97));
  box-shadow:
    0 1px 0 rgba(255,255,255,0.24) inset,
    0 12px 24px rgba(0,0,0,0.36),
    0 0 0 1px rgba(212,168,90,0.22),
    0 3px 10px rgba(212,168,90,0.12)}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage--active:hover{z-index:5}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage .fg-stage-img{
  position:relative;
  padding:7.5px;
  box-sizing:border-box;
  height:calc(15px + 76px);
  background:linear-gradient(168deg,rgba(252,248,238,0.98) 0%,rgba(236,228,210,0.95) 46%,rgba(218,206,182,0.93) 100%);
  border:1px solid rgba(40,36,32,0.26);
  border-radius:2px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.2) inset,
    inset 0 1px 2px rgba(0,0,0,0.06)}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage .fg-stage-img img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center center}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage .fg-stage-img--stack{
  height:auto;
  min-height:calc(15px + 76px)}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage .fg-stage-img > .fg-stage-lbl{
  position:absolute;
  left:0;
  right:0;
  top:0;
  margin:0;
  z-index:3;
  pointer-events:none;
  text-align:center;
  padding:5px 6px 8px;
  font-size:6.75px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  line-height:1.3;
  color:rgba(0,0,0,0.72);
  text-shadow:none;
  background:transparent;
  box-sizing:border-box;
  max-width:100%}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage:hover,
  #panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage--active{
    transform:none}}
.fg-gallery-hero-col{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  margin-bottom:8px}
.fg-gallery-hero{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center}
#panel-guide .fg-gallery-hero .fg-stage--hero{
  width:100%;
  max-width:min(560px,100%);
  margin:0;
  text-align:center;
  position:relative}
#panel-guide .fg-gallery-hero .fg-stage--hero .fg-stage-img{
  position:relative;
  width:100%;
  min-height:clamp(160px,28vw,240px);
  height:auto;
  max-height:clamp(280px,52vh,520px);
  margin-bottom:0;
  border-radius:2px;
  overflow:visible;
  display:flex;
  align-items:center;
  justify-content:center}
#panel-guide .fg-gallery-hero .fg-stage--hero .fg-stage-img--stack{
  height:auto;
  min-height:clamp(160px,28vw,280px)}
#panel-guide .fg-gallery-hero .fg-stage--hero .fg-stage-img img{
  width:auto;
  height:auto;
  max-width:100%;
  max-height:clamp(260px,52vh,520px);
  object-fit:contain;
  object-position:center center;
  vertical-align:middle}
#panel-guide .fg-gallery-hero .fg-stage--hero .fg-stage-img > .fg-stage-lbl{
  position:absolute;
  left:0;
  right:0;
  top:0;
  margin:0;
  z-index:3;
  pointer-events:none;
  padding:10px 12px 20px;
  font-size:8.6625px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  text-align:center;
  line-height:1.35;
  color:rgba(0,0,0,0.72);
  text-shadow:none;
  background:transparent;
  box-sizing:border-box;
  max-width:100%}
.fg-gallery-nav{
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:center;
  gap:28px}
.fg-gallery-arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  margin:0;
  padding:0;
  border:none;
  border-radius:50%;
  font-size:22.275px;
  line-height:1;
  cursor:pointer;
  flex-shrink:0;
  transition:background .15s ease,color .15s ease}
#panel-guide .fg-gallery-arrow{
  background:rgba(16,15,14,0.22);
  color:rgba(232,224,208,0.82);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:none}
#panel-guide .fg-gallery-arrow:hover{
  background:var(--wfts-c-amber-12);
  color:var(--amber2)}
#panel-guide .fg-gallery-arrow:focus-visible{
  outline:1px solid rgba(212,168,90,0.55);
  outline-offset:2px}
.fg-gallery-thumbs{
  width:100%;
  box-sizing:border-box}
#panel-guide .fg-gallery-thumbs .fg-gallery-thumbs-track{
  display:flex;
  flex-direction:row;
  flex-wrap:nowrap;
  align-items:stretch;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  padding:4px 0 10px;
  margin:0;
  scrollbar-width:thin;
  scrollbar-color:rgba(200,180,140,0.2) transparent;
  -webkit-overflow-scrolling:touch;
  justify-content:flex-start}
#panel-guide .fg-gallery-thumbs .fg-stage{
  flex:0 0 auto;
  width:96px;
  margin:0;
  padding:5px 5px 7px;
  box-sizing:border-box;
  text-align:center;
  cursor:pointer;
  border-radius:8px;
  border:1px solid transparent;
  background:transparent;
  position:relative;
  transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}
#panel-guide .fg-gallery-thumbs .fg-stage:hover{
  background:rgba(212,168,90,0.06);
  border-color:rgba(212,168,90,0.22)}
#panel-guide .fg-gallery-thumbs .fg-stage--active{
  border-color:rgba(212,168,90,0.5);
  background:rgba(212,168,90,0.09);
  box-shadow:0 0 0 1px rgba(212,168,90,0.12)}
#panel-guide .fg-gallery-thumbs .fg-stage .fg-stage-img{
  position:relative;
  width:100%;
  height:76px;
  margin-bottom:0;
  border-radius:2px;
  overflow:visible;
  display:flex;
  align-items:center;
  justify-content:center}
#panel-guide .fg-gallery-thumbs .fg-stage .fg-stage-img--stack{
  height:auto;
  min-height:76px}
#panel-guide .fg-gallery-thumbs .fg-stage .fg-stage-img > .fg-stage-lbl{
  position:absolute;
  left:0;
  right:0;
  top:0;
  margin:0;
  z-index:3;
  pointer-events:none;
  max-width:100%;
  padding:4px 5px 8px;
  font-size:6.5px;
  line-height:1.3;
  letter-spacing:0.08em;
  text-transform:uppercase;
  text-align:center;
  color:rgba(0,0,0,0.72);
  text-shadow:none;
  background:transparent;
  box-sizing:border-box}
#panel-guide .fg-gallery-thumbs .fg-stage:focus-visible{
  outline:1px solid rgba(212,168,90,0.55);
  outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-gallery-thumbs .fg-stage{transition-duration:0.01ms}}

/* Per-species carousel (legacy DOM): center largest, sides scale down, arrows + drag */
#panel-guide .fg-stages{display:flex;position:relative;z-index:1}
#panel-guide .fg-stage{flex:0 0 auto;width:clamp(300px,34vw,460px);text-align:center;position:relative}
#panel-guide .fg-stage-img{
  position:relative;
  width:100%;
  height:clamp(220px,26vw,340px);
  background:transparent;border:none;border-radius:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;margin-bottom:0}
.fg-carousel-wrap{position:relative;max-width:100%;margin:12px 0;padding:0 36px;min-height:300px}
.fg-carousel-wrap.fg-card-carousel{margin:0 0 12px;padding:0 32px;min-height:270px}
.fg-carousel{overflow:hidden;touch-action:pan-y pinch-zoom}
/* Species carousel: fade tiles toward left/right of viewport (mask on the clip, not the arrows) */
#panel-guide .fg-carousel{
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 14%,#000 86%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 14%,#000 86%,transparent 100%);
  -webkit-mask-size:100% 100%;
  mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat}
.fg-carousel-track{display:flex;align-items:center;justify-content:center;gap:10px;transition:transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);cursor:grab;user-select:none}
.fg-carousel-track.dragging{transition:none;cursor:grabbing}
.fg-carousel-track .fg-stage{transition:transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);pointer-events:none}
.fg-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:rgba(28,27,26,0.9);border:1px solid rgba(92,90,88,0.4);color:#8a8884;font-size:22.275px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:border-color .15s,background .15s}
.fg-carousel-arrow:hover{background:rgba(36,35,34,0.95);border-color:var(--wfts-c-mute-50)}
/* Field guide: clickable slides + glass controls (no hard boxes) */
#panel-guide .fg-carousel-track .fg-stage{pointer-events:auto;cursor:pointer;position:relative}
#panel-guide .fg-carousel-track .fg-stage .fg-stage-img{margin-bottom:0}
#panel-guide .fg-carousel-track .fg-stage .fg-stage-img > .fg-stage-lbl{
  pointer-events:none;
  position:absolute;
  left:0;
  right:0;
  top:0;
  z-index:4;
  margin:0;
  padding:10px 12px 22px;
  text-align:center;
  font-size:8.1px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  line-height:1.35;
  color:rgba(0,0,0,0.72);
  text-shadow:none;
  background:transparent;
  box-sizing:border-box;
  max-width:100%}
#panel-guide .fg-stage--active .fg-stage-img{
  box-shadow:none}
#panel-guide .fg-carousel-arrow{
  background:rgba(16,15,14,0.2);border:none;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:none;color:rgba(232,224,208,0.78);transition:background .15s ease,color .15s ease}
#panel-guide .fg-carousel-arrow:hover{
  background:var(--wfts-c-amber-12);color:var(--amber2)}
/* Field guide: minimal amber audio rows (no card chrome; matches phenology / mono labels) */
#panel-guide .fg-card-v2 + .fg-card-v2{
  margin-top:6px;padding-top:18px;border-top:1px solid rgba(92,90,88,0.1)}
#panel-guide .fg-card-badge{letter-spacing:0.2em;color:rgba(138,136,132,0.82)}
#panel-guide .fg-card-badge--latin-label{
  margin-top:10px;
  margin-bottom:1px}
#panel-guide .fg-card-v2 .fg-card-latin{
  color:var(--amber2)}
#panel-guide .fg-stage-lbl{color:rgba(0,0,0,0.7)}
#panel-guide .fg-stage-img > .fg-stage-lbl{font-weight:700}
/* Per-photo attribution: visible “Source”; full credit in native title tooltip on hover. Above handles (z 18–20). */
#panel-guide .fg-stage-img > .fg-stage-source-word{
  position:absolute;
  z-index:30;
  right:6px;
  bottom:5px;
  margin:0;
  padding:0;
  box-sizing:border-box;
  pointer-events:auto;
  cursor:help;
  font-family:'IBM Plex Mono',monospace;
  font-size:clamp(5.5px,1.75cqw,7.5px);
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(12,10,8,0.82);
  text-shadow:none;
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  line-height:1.2;
  transition:color .15s ease,opacity .15s ease}
#panel-guide .fg-stage-img > .fg-stage-source-word:hover{
  background:transparent;
  border:none;
  color:rgba(12,10,8,0.92)}
#panel-guide .fg-photo-pile-canvas .fg-stage-img > .fg-stage-source-word{
  right:calc(var(--fg-pile-mat,8px) + 4px);
  bottom:calc(var(--fg-pile-mat,8px) + 8px);
  font-size:clamp(5px,1.65cqw,7px);
  padding:0}
#panel-guide .fg-gallery-wrap--desk-paper .fg-gallery-thumbs .fg-stage .fg-stage-img > .fg-stage-source-word{
  right:calc(7.5px + 3px);
  bottom:calc(7.5px + 8px);
  font-size:4.75px;
  padding:0}
#panel-guide .fg-gallery-hero .fg-stage--hero .fg-stage-img > .fg-stage-source-word{
  right:calc(10px + 4px);
  bottom:calc(10px + 10px);
  font-size:5.25px}
/* Spring Peeper “X” photo: 30× lace overlay + trace — same classes as forecast/contact PCC */
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap.pcc-logo-wrap{
  display:block;position:relative;width:fit-content;max-width:100%;
  margin:0;line-height:0;cursor:default;
  -webkit-tap-highlight-color:transparent}
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap .pcc-logo-motion{
  position:relative;display:block;width:100%;max-width:100%;
  line-height:0;transform-origin:center center;will-change:transform}
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap .pcc-logo-30x{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;overflow:visible;
  filter:blur(var(--pcc-30x-blur,0px));
  opacity:0;
  transition:opacity 0.28s ease,filter 0.1s linear}
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap.pcc-logo-wrap.pcc-logo-wrap--30x-mouse .pcc-logo-30x,
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap.pcc-logo-wrap.pcc-logo-wrap--pcc-call-active .pcc-logo-30x{
  opacity:1}
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap .pcc-logo-30x-path--lace{
  fill:none;
  stroke:rgba(255,220,165,0.9);
  stroke-linecap:round;stroke-linejoin:round;
  stroke-width:var(--pcc-30x-trace-stroke,1.1);
  stroke-dasharray:var(--pcc-30x-dash,none);
  stroke-dashoffset:var(--pcc-30x-trace-len,0);
  opacity:0}
#panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap .pcc-logo-30x-path--lace.pcc-30x-tracing{
  opacity:1;
  animation:pcc30xLaceTrace var(--pcc-30x-trace-dur,1s) var(--pcc-30x-trace-ease,ease-out) forwards}
@media (prefers-reduced-motion:reduce){
  #panel-guide .fg-stage-img .fg-spring-peeper-x-30x-wrap .pcc-logo-30x-path--lace.pcc-30x-tracing{
    animation:none;stroke-dashoffset:0;opacity:0.22}}
#panel-guide .fg-card-audio{
  gap:12px 20px;margin-bottom:12px}
#panel-guide .fg-audio{
  padding:2px 0;gap:10px;flex-wrap:nowrap;align-items:center;
  background:transparent;border:none;border-radius:0;box-shadow:none;
  transition:opacity .15s ease}
#panel-guide .fg-audio:hover{opacity:1}
#panel-guide .fg-audio-lbl{
  flex-shrink:0;min-width:7.5em;font-family:'IBM Plex Mono',monospace;font-size:7.425px;letter-spacing:0.18em;
  text-transform:uppercase;color:rgba(212,168,90,0.72);opacity:1}
#panel-guide .fg-audio:hover .fg-audio-lbl{color:rgba(212,184,130,0.92)}
#panel-guide .fg-audio audio{
  flex:1;min-width:0;height:30px;max-width:100%;
  accent-color:rgba(212,168,90,0.95);color-scheme:dark;border-radius:0;vertical-align:middle;
  background:transparent;filter:none}
#panel-guide .fg-audio audio::-webkit-media-controls-enclosure{
  background:transparent;border-radius:0}
#panel-guide .fg-audio audio::-webkit-media-controls-panel{
  background:rgba(14,13,12,0.35);border-radius:4px;border:none}
#panel-guide .fg-audio audio::-webkit-media-controls-play-button,
#panel-guide .fg-audio audio::-webkit-media-controls-mute-button{
  -webkit-filter:brightness(1.15);filter:brightness(1.15)}
#panel-guide .fg-audio audio::-webkit-media-controls-timeline{
  border-radius:2px;background:var(--wfts-c-amber-12)}
#panel-guide .fg-audio audio::-webkit-media-controls-current-time-display,
#panel-guide .fg-audio audio::-webkit-media-controls-time-remaining-display{
  color:rgba(212,184,150,0.75);text-shadow:none}
#panel-guide .fg-audio--wfts{
  cursor:pointer;padding:6px 2px;border-radius:6px;outline-offset:2px;
  transition:background .15s ease,opacity .15s ease}
#panel-guide .fg-audio--wfts:hover{background:rgba(212,168,90,0.08)}
#panel-guide .fg-audio--wfts:focus-visible{outline:1px solid rgba(212,168,90,0.55)}
#panel-guide .fg-audio-play{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;
  font-size:11px;line-height:1;color:rgba(212,184,130,0.95);
  background:rgba(212,168,90,0.14);border:1px solid rgba(212,168,90,0.28)}
#panel-guide .fg-audio--wfts:hover .fg-audio-play{
  background:rgba(212,168,90,0.22);border-color:rgba(212,168,90,0.42)}
#panel-guide .fg-card-extlinks{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
  align-self:flex-start;
  width:max-content;
  max-width:100%;
  margin-top:4px}
#panel-guide .fg-card-extlinks .fg-link{
  flex:0 0 auto}
#panel-guide .fg-link{
  display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(212,168,90,0.38);border-radius:999px;padding:6px 14px;
  font-family:'IBM Plex Mono',monospace;font-size:9.9px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--amber2);background:rgba(212,136,58,0.1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 2px 12px rgba(0,0,0,0.1);transition:background .18s ease,color .18s ease,border-color .18s ease;
  width:max-content;max-width:100%;box-sizing:border-box}
#panel-guide .fg-link:hover{
  color:rgba(252,244,228,0.96);border-color:var(--wfts-c-gold-55);background:rgba(212,168,90,0.16)}
.fg-carousel-prev{left:2px}
.fg-carousel-next{right:2px}
.fg-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0}
.fg-card{background:transparent;border:none;border-radius:0;
  padding:16px;position:relative;overflow:hidden}
.fg-card .fg-emoji{font-size:51.975px;display:block;margin-bottom:8px}
.fg-card .fg-name{font-family:'Playfair Display',serif;font-size:19.8px;color:var(--cream)}
.fg-card .fg-latin{font-size:11.1375px;color:var(--amber2);font-style:italic;margin-bottom:8px}
.fg-card .fg-desc{font-size:13.6125px;color:var(--muted);line-height:1.7;margin-bottom:10px}
.fg-card .fg-meta{font-size:11.1375px;color:rgba(92,90,88,0.55);line-height:1.6}
.fg-card .fg-meta strong{color:#8a8884}
.fg-play-btn{background:linear-gradient(135deg,#4a4846,#3a3836);border:1px solid var(--wfts-c-mute-35);
  border-radius:5px;color:#c8c4b8;font-family:'IBM Plex Mono',monospace;font-size:11.1375px;
  padding:5px 12px;cursor:pointer;letter-spacing:1px;margin-top:6px}
.fg-play-btn:hover{border-color:var(--wfts-c-mute-50)}
@media(max-width:860px){
/* Field Guide v2 */
.fg-card-v2{background:transparent;border:none;border-radius:0;
  padding:16px;margin-bottom:16px;position:relative}
.fg-card-header{margin-bottom:12px}
.fg-card-badge{font-size:9.9px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;color:var(--muted)}
.fg-card-name{font-family:'Playfair Display',serif;font-size:27.225px;color:var(--cream);line-height:1.2;margin-bottom:2px}
.fg-card-folk{
  margin:4px 0 6px;
  padding:5px 0 1px;
  max-width:min(38em,100%);
  border-top:1px solid rgba(212,168,90,0.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04)}
.fg-card-folk-label{
  display:block;
  font-family:'IBM Plex Mono',monospace;
  font-size:6.6px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:rgba(188,168,138,0.52);
  margin-bottom:3px}
.fg-card-folk-line{
  display:block;
  font-family:'IBM Plex Mono',monospace;
  font-size:8.1px;
  line-height:1.45;
  letter-spacing:0.04em;
  color:rgba(210,196,168,0.76)}
.fg-card-latin{font-size:12.375px;font-style:italic;color:var(--amber2);letter-spacing:0.5px;margin-bottom:4px;margin-top:0}
.fg-stages{display:flex;gap:6px;overflow-x:auto;padding:10px 0;margin-bottom:12px;
  scrollbar-width:thin;scrollbar-color:rgba(200,180,140,0.15) transparent}
.fg-stage{flex:0 0 auto;width:270px;text-align:center}
.fg-stage-img{width:270px;height:204px;background:transparent;border:none;
  border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;margin-bottom:4px}
.fg-stage-icon{font-size:22.275px;opacity:0.25}
.fg-stage-file{font-size:7.425px;color:var(--muted);opacity:0.5;word-break:break-all;padding:0 4px;line-height:1.3}
.fg-stage-lbl{font-size:8.6625px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.fg-card-layout{display:flex;flex-direction:row;align-items:stretch;gap:0;margin-bottom:12px}
.fg-card-adult{flex:0 0 auto;width:270px;align-self:flex-start}
.fg-card-adult .fg-stage-img{width:270px;height:204px}
.fg-card-adult-divider{flex:0 0 1px;width:1px;align-self:stretch;pointer-events:none}
.fg-card-info{flex:1;min-width:0;display:flex;flex-direction:column}
.fg-card-desc{font-size:12.375px;line-height:1.7;color:rgba(232,224,208,0.7);margin-bottom:12px;flex:1;min-width:0}
.fg-card-audio{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.fg-audio{display:flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;
  border:none;border-radius:0;font-size:9.9px;color:var(--muted)}
.fg-audio-file{font-size:8.6625px;opacity:0.5}
.fg-audio-lbl{font-size:8.6625px;letter-spacing:1px;text-transform:uppercase;color:var(--amber);opacity:0.6}
.fg-link{display:inline-block;font-size:11.1375px;color:var(--green);text-decoration:none;
  border:1px solid var(--wfts-c-stone-25);border-radius:5px;padding:4px 10px;transition:all 0.15s}
.fg-link:hover{background:var(--wfts-c-stone-12);border-color:var(--wfts-c-mute-40)}
.fg-grid{grid-template-columns:1fr}}
/* Quiz */
.quiz-wrap{max-width:600px;margin:0 auto;text-align:center}
.quiz-dial-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;margin:18px 0}
.quiz-dial{position:relative;width:253px;height:253px;margin:0 auto;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#1c1b1a,#050504);border:1px solid rgba(92,90,88,0.4);
  box-shadow:0 0 18px rgba(0,0,0,0.7);cursor:grab;user-select:none}
.quiz-dial:active{cursor:grabbing}
.quiz-dial-center{position:absolute;left:50%;top:50%;width:87.4px;height:87.4px;margin:-43.7px 0 0 -43.7px;
  border-radius:50%;background:radial-gradient(circle,#1f3820,#0a130b);border:1px solid rgba(200,184,138,0.4);
  display:flex;align-items:center;justify-content:center;font-size:11.1375px;color:var(--muted);text-align:center;padding:6px}
.quiz-dial-label{position:absolute;left:50%;top:50%;transform-origin:0 0;font-size:9.9px;
  color:var(--cream);text-shadow:0 0 4px rgba(0,0,0,0.8);white-space:nowrap}
.quiz-dial-caption{font-size:13.6125px;color:var(--muted)}
.quiz-prompt{font-family:'Playfair Display',serif;font-size:24.75px;color:var(--cream);margin:16px 0 8px}
.quiz-sub{font-size:13.6125px;color:var(--muted);margin-bottom:18px}
.quiz-play{background:linear-gradient(135deg,#4a4846,#3a3836);border:1px solid var(--wfts-c-mute-35);
  border-radius:8px;color:#c8c4b8;font-family:'IBM Plex Mono',monospace;font-size:14.85px;
  padding:12px 28px;cursor:pointer;letter-spacing:2px;margin-bottom:20px;display:inline-block}
.quiz-play:hover{border-color:var(--wfts-c-mute-50)}
.quiz-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 auto 20px;max-width:500px}
.quiz-opt{background:rgba(14,26,12,0.5);border:2px solid rgba(58,110,53,0.15);border-radius:10px;
  padding:18px 12px;cursor:pointer;transition:all .2s;text-align:center}
.quiz-opt:hover{border-color:rgba(90,158,106,0.4);background:rgba(14,26,12,0.7)}
.quiz-opt.correct{border-color:#8a8884;background:rgba(138,136,132,.15)}
.quiz-opt.wrong{border-color:#c06050;background:rgba(192,96,80,.1)}
.quiz-opt.reveal{border-color:rgba(90,158,106,0.3);opacity:.5}
.quiz-opt .qo-emoji{font-size:44.55px;display:block;margin-bottom:6px}
.quiz-opt .qo-name{font-size:13.6125px;color:var(--cream)}
.quiz-score{font-family:'Playfair Display',serif;font-size:34.65px;color:var(--cream);margin:20px 0 8px}
.quiz-detail{font-size:14.85px;color:var(--muted);margin-bottom:16px;line-height:1.8}
.quiz-restart{background:linear-gradient(135deg,#4a4846,#3a3836);border:1px solid var(--wfts-c-mute-35);
  border-radius:8px;color:#c8c4b8;font-family:'IBM Plex Mono',monospace;font-size:13.6125px;
  padding:10px 24px;cursor:pointer;letter-spacing:2px}
.quiz-progress{font-size:11.1375px;color:var(--muted);letter-spacing:2px;margin-bottom:6px}

/* Header logo (frog on pinecone) — sized & nudged to align with h1 cap height */
.frog-logo{display:inline-block;width:34px;height:34px;margin-right:11px;vertical-align:middle;
  position:relative;top:-5px;object-fit:contain;mix-blend-mode:plus-lighter;
  transition:width .45s cubic-bezier(0.22,1,0.36,1),height .45s cubic-bezier(0.22,1,0.36,1),margin .4s ease,top .4s ease}
/* Ambient / star / waveform / UI sound toggles */
.amb-toggle{display:none;align-items:center;gap:6px;
  background:rgba(28,27,26,0.85);border:1px solid var(--wfts-c-stone-25);border-radius:6px;
  padding:4px 8px;font-family:'IBM Plex Mono',monospace;font-size:9.0px;color:var(--muted);
  cursor:pointer;backdrop-filter:blur(8px);transition:all .2s;letter-spacing:1px}
.amb-toggle:hover{border-color:var(--wfts-c-amber-50);color:var(--amber2)}
.amb-toggle.on{border-color:rgba(212,168,90,0.72);color:var(--amber2)}
.amb-toggle .amb-dot{width:6px;height:6px;border-radius:50%;background:var(--faint);transition:all .2s;flex-shrink:0}
.amb-toggle.on .amb-dot{background:var(--amber2);box-shadow:0 0 8px rgba(240,168,74,.55)}
.amb-bar-group .amb-toggle{display:flex}

/* Breeding Season Timeline */
.breed-timeline{padding:8px 12px;background:rgba(28,27,26,0.45);border:1px solid var(--wfts-c-stone-18);border-radius:12px;overflow:hidden}
/* Calendar tab: full width + fill viewport height; timeline grid grows below toolbar */
#panel-calling > .calling-page-scroll{
  max-width:none;width:100%;margin:0;box-sizing:border-box;max-height:none;
  padding:clamp(10px,2vw,18px) clamp(16px,2.5vw,28px) clamp(10px,1.8vw,16px);
  flex:1;min-height:0;display:flow-root;overflow-x:hidden;overflow-y:auto;
  position:relative;overflow-anchor:none;overscroll-behavior-y:contain}
#panel-calling .breed-timeline{
  margin:0;max-width:none;width:100%;box-sizing:border-box;
  display:flex;flex-direction:column;
  overflow:visible;
  height:fit-content}
#panel-calling .bt-header{margin-bottom:8px}
#panel-calling .bt-header span{font-size:12.375px;letter-spacing:2.2px}
.bt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-family:'IBM Plex Mono',monospace;font-size:9.9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;flex-shrink:0}
.bt-week-readout{min-height:1.35em;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:9.9px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(212,168,90,0.82);margin:0 0 6px;padding:4px 8px;background:rgba(14,13,10,0.35);border-radius:6px;border:1px solid var(--wfts-c-stone-18);flex-shrink:0}
.bt-week-readout:empty::before{content:'Hover a week on the chart';color:rgba(138,136,132,0.45);letter-spacing:0.1em}
.bt-toggle{background:none;border:1px solid rgba(92,90,88,0.45);color:var(--muted);font-size:9.9px;border-radius:3px;padding:1px 4px;cursor:pointer}
.bt-toggle:hover{border-color:#8a8884;color:#8a8884}
.breed-timeline.collapsed .bt-wrap{display:none}
.bt-wrap{position:relative;height:auto;font-family:'IBM Plex Mono',monospace;flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.bt-months{display:flex;border-bottom:1px solid var(--wfts-c-stone-25);margin-bottom:4px;flex-shrink:0}
.bt-month{flex:1;text-align:center;font-size:8.6625px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);padding:2px 0 3px;position:relative}
.bt-survey{position:absolute;top:-18px;left:50%;transform:translateX(-50%);
  background:var(--wfts-c-stone-25);border:1px solid var(--wfts-c-stone-35);border-radius:3px;
  padding:1px 4px;font-size:7.425px;color:#8a8884;white-space:nowrap;letter-spacing:1px}
.bt-rows{position:relative;display:flex;flex-direction:column;height:200px;overflow:hidden;flex:1 1 auto;min-height:100px}
.bt-row{display:flex;align-items:stretch;flex:0 0 12px;min-height:10px;margin-bottom:1px;
  transition:flex .28s ease,min-height .28s ease}
.bt-row.bt-row-hover{flex:0 0 auto;min-height:38px;max-height:54px;align-items:center}
.bt-name-col{width:108px;flex-shrink:0;padding-right:6px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;position:relative}
.bt-label{width:100%;font-size:12.375px;color:var(--cream);text-align:left;line-height:1.2;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:0.02em}
.bt-latin{width:100%;font-size:10.5187px;font-style:italic;color:var(--wfts-c-mute-78);text-align:left;line-height:1.25;
  margin-top:0;max-height:0;opacity:0;overflow:hidden;pointer-events:none;
  transition:opacity .4s ease,max-height .32s ease,margin-top .32s ease,color .32s ease}
.bt-row.bt-row-hover .bt-latin{opacity:1;max-height:2.2em;margin-top:2px;line-height:1.15}
.bt-track{flex:1;position:relative;min-height:9px;height:100%}
.bt-week-grid{position:absolute;inset:0;pointer-events:none;border-radius:2px;z-index:0;
  background:repeating-linear-gradient(to right,rgba(92,90,88,0.06) 0,rgba(92,90,88,0.06) 1px,transparent 1px,transparent calc(100% * 7/183))}
/* Species-by-month tiles: discrete bins (grid) */
.bt-heatmap{position:absolute;inset:0;display:grid;grid-template-rows:minmax(0,1fr);gap:2px;pointer-events:auto;z-index:2;
  border-radius:3px;overflow:hidden;padding:1px;box-sizing:border-box}
.bt-cell{grid-row:1;min-width:0;min-height:100%;border-radius:2px;transition:filter .2s ease,box-shadow .2s ease,opacity .07s linear;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18);cursor:crosshair;position:relative;z-index:0}
.bt-cell.bt-cell-wf-target{box-shadow:inset 0 0 0 1px rgba(240,200,130,0.55),0 0 0 1px rgba(240,200,130,0.2)}
.bt-row.bt-row-hover .bt-cell{
  filter:brightness(1.22) saturate(1.2) contrast(1.02);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18)}
/* Row hover must not retint pulsing call-range amber or the Wood-frog peak frame */
.bt-row.bt-row-hover .bt-cell.bt-cell-amber-nb,
.bt-row.bt-row-hover .bt-cell.bt-cell-wf-target{
  filter:none}
.bt-row.bt-row-hover .bt-cell.bt-cell-amber-nb{
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18),
    0 0 5px rgba(255,215,130,0.48),
    0 0 12px rgba(242,160,70,0.28),
    0 0 20px rgba(225,120,45,0.14)}
.bt-row.bt-row-hover .bt-cell.bt-cell-wf-target{
  box-shadow:inset 0 0 0 1px rgba(240,200,130,0.55),0 0 0 1px rgba(240,200,130,0.2)}
/* Calendar: pulsing amber neighborhood (center + ±2 bins), only in active call range — toggled in app.js */
/* Same phase on d0/d1/d2 so the cursor cell is never dim while ±1/±2 are bright (staggered delay inverted that read) */
@keyframes btCalAmberPulse0{
  0%,100%{opacity:0.55}
  50%{opacity:0.95}}
@keyframes btCalAmberPulse1{
  0%,100%{opacity:0.3}
  50%{opacity:0.68}}
@keyframes btCalAmberPulse2{
  0%,100%{opacity:0.14}
  50%{opacity:0.42}}
/* Film grain over amber highlight; drift loops on tile size (64×64 SVG, stitchTiles) */
@keyframes btCalAmberGrainDrift{
  0%{background-position:0 0}
  100%{background-position:64px 64px}}
.bt-cell.bt-cell-amber-nb{
  isolation:isolate;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18),
    0 0 5px rgba(255,215,130,0.48),
    0 0 12px rgba(242,160,70,0.28),
    0 0 20px rgba(225,120,45,0.14)}
.bt-cell.bt-cell-amber-nb::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  z-index:4;
  opacity:0.26;
  mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2264%22%20height%3D%2264%22%3E%3Cfilter%20id%3D%22g%22%20x%3D%220%22%20y%3D%220%22%20width%3D%22100%25%22%20height%3D%22100%25%22%20color-interpolation-filters%3D%22sRGB%22%3E%3CfeTurbulence%20type%3D%22fractalNoise%22%20baseFrequency%3D%220.72%22%20numOctaves%3D%223%22%20stitchTiles%3D%22stitch%22%2F%3E%3C%2Ffilter%3E%3Crect%20width%3D%22100%25%22%20height%3D%22100%25%22%20filter%3D%22url(%23g)%22%2F%3E%3C%2Fsvg%3E");
  background-size:64px 64px;
  background-repeat:repeat;
  animation:btCalAmberGrainDrift 1.7s linear infinite}
.bt-cell.bt-cell-amber-nb--d1::before{animation-duration:2.05s;animation-direction:reverse}
.bt-cell.bt-cell-amber-nb--d2::before{animation-duration:2.45s}
.bt-cell.bt-cell-amber-nb::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  z-index:3;
  background:linear-gradient(168deg,rgba(255,228,140,0.78),rgba(240,130,45,0.68));
  mix-blend-mode:normal;
  box-shadow:inset 0 0 10px rgba(255,248,210,0.45),
    inset 0 0 22px rgba(255,185,85,0.22)}
.bt-cell.bt-cell-amber-nb--d0::after{animation:btCalAmberPulse0 1.05s ease-in-out infinite}
.bt-cell.bt-cell-amber-nb--d1::after{animation:btCalAmberPulse1 1.05s ease-in-out infinite}
.bt-cell.bt-cell-amber-nb--d2::after{animation:btCalAmberPulse2 1.05s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){
  .bt-cell.bt-cell-amber-nb::before{
    animation:none;
    background-position:22px 18px}
  .bt-cell.bt-cell-amber-nb--d0::after,.bt-cell.bt-cell-amber-nb--d1::after,.bt-cell.bt-cell-amber-nb--d2::after{
    animation:none}
  .bt-cell.bt-cell-amber-nb--d0::after{opacity:0.72}
  .bt-cell.bt-cell-amber-nb--d1::after{opacity:0.42}
  .bt-cell.bt-cell-amber-nb--d2::after{opacity:0.2}}
/* Row calling waveform: absolute in .bt-wrap; multiply darkens heatmap cells under the stroke (subtracts perceived opacity) */
.bt-cell-wave-overlay{position:absolute;left:0;top:0;width:0;height:0;pointer-events:none;z-index:8000;display:none;
  opacity:0;transition:left 0.1s ease-out,top 0.1s ease-out,width 0.1s ease-out,height 0.1s ease-out,opacity 0.15s ease;
  mix-blend-mode:multiply;border-radius:4px}
.bt-cell-wave-overlay.bt-cell-wave-on{display:block;opacity:0.92}
.bt-row.bt-row-hover .bt-label{color:rgba(255,206,120,0.98)}
.bt-row.bt-row-hover .bt-latin{color:rgba(255,214,160,0.88)}
.bt-species-img-wrap{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.bt-species-img{width:36px;height:36px;object-fit:cover;border-radius:7px;opacity:0;transition:opacity .25s ease;pointer-events:none;background:rgba(28,27,26,0.6);border:1px solid var(--wfts-c-stone-20)}
#panel-calling #bt-rows .bt-species-img--photo{object-fit:contain;background:rgba(28,27,26,0.45)}
.bt-row.bt-row-hover .bt-species-img{opacity:1}
.bt-playhead{position:absolute;top:0;width:12px;height:100%;margin-left:-6px;cursor:ew-resize;
  z-index:5;transition:none;pointer-events:auto;touch-action:none}
.bt-playhead::after{content:'';position:absolute;left:50%;top:0;bottom:0;width:1.5px;margin-left:-0.75px;
  background:var(--amber2);box-shadow:0 0 6px rgba(240,168,74,.6)}
.bt-legend{display:flex;flex-direction:column;align-items:center;gap:0;margin-top:6px;font-size:7.425px;color:var(--muted);flex-shrink:0}
.bt-legend-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}
.bt-view-pills{display:flex;border:1px solid var(--wfts-c-stone-35);border-radius:6px;overflow:hidden;background:rgba(14,13,10,0.45)}
.bt-view-pill{background:transparent;border:none;color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:8.6625px;letter-spacing:0.8px;text-transform:uppercase;padding:7px 14px;cursor:pointer;transition:color .15s,background .15s;white-space:nowrap}
.bt-view-pill:hover{color:var(--cream)}
.bt-view-pill.on{background:var(--wfts-c-amber-12);color:var(--amber2);box-shadow:inset 0 0 0 1px rgba(212,168,90,0.28)}
.bt-guide{width:100%;max-width:720px;margin:0 auto}
.bt-guide-heatmap,.bt-guide-breeder{padding-top:2px}
.bt-heatmap-scale{height:11px;border-radius:4px;border:1px solid var(--wfts-c-stone-35);margin:4px 0 3px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.04)}
.bt-heatmap-scale-labels{display:flex;justify-content:space-between;font-size:7.425px;color:var(--faint);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:2px}
.bt-guide-text{margin:8px 0 0;font-size:8.6625px;color:rgba(200,192,172,0.75);line-height:1.5;text-align:center;letter-spacing:0.2px}
.bt-guide-breeder{display:block}
.bt-guide-breeder .bt-guide-text{width:100%;margin-top:0}
.bt-timeline-controls{display:flex;flex-direction:column;align-items:stretch;gap:8px;margin:10px 0 4px;flex-shrink:0;padding:0 2px}
.bt-timeline-controls .bt-view-pills{align-self:center}
#panel-calling .bt-guild-toggles{display:flex;flex-direction:column;align-items:center;gap:3px;margin:0}
#panel-calling .bt-guild-toggles-lbl{font-family:'IBM Plex Mono',monospace;font-size:7.425px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(138,136,132,0.52)}
#panel-calling .bt-guild-pills{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:5px 8px;border:1px solid rgba(92,90,88,0.28);border-radius:6px;padding:6px 10px;background:rgba(14,13,10,0.38)}
#panel-calling .bt-guild-pill{
  background:transparent;border:1px solid rgba(92,90,88,0.32);border-radius:5px;color:rgba(138,136,132,0.55);
  font-family:'IBM Plex Mono',monospace;font-size:8.0438px;letter-spacing:0.55px;text-transform:uppercase;padding:6px 11px;cursor:pointer;
  transition:color .15s,background .15s,border-color .15s,opacity .15s;white-space:nowrap}
#panel-calling .bt-guild-pill:hover{color:var(--cream);border-color:var(--wfts-c-mute-40)}
#panel-calling .bt-guild-pill.on{opacity:1}
#panel-calling .bt-guild-pill:not(.on){opacity:0.42}
#panel-calling .bt-guild-pill--early.on{background:rgba(212,184,120,0.14);border-color:rgba(200,168,95,0.5);color:rgba(244,224,185,0.96);box-shadow:inset 0 0 0 1px rgba(220,190,120,0.22)}
#panel-calling .bt-guild-pill--mid.on{background:rgba(224,155,65,0.15);border-color:rgba(212,140,55,0.52);color:rgba(255,210,150,0.96);box-shadow:inset 0 0 0 1px rgba(235,165,70,0.24)}
#panel-calling .bt-guild-pill--late.on{background:rgba(185,105,45,0.16);border-color:rgba(200,95,40,0.55);color:rgba(255,200,155,0.96);box-shadow:inset 0 0 0 1px rgba(210,115,55,0.26)}
#panel-calling.bt-cal-view-green .bt-guild-pill--early.on{
  background:rgba(94,234,212,0.12);border-color:rgba(45,212,191,0.52);color:rgba(204,251,241,0.96);box-shadow:inset 0 0 0 1px rgba(45,212,191,0.22)}
#panel-calling.bt-cal-view-green .bt-guild-pill--mid.on{
  background:rgba(52,211,153,0.14);border-color:rgba(16,185,129,0.5);color:rgba(209,250,229,0.96);box-shadow:inset 0 0 0 1px rgba(52,211,153,0.24)}
#panel-calling.bt-cal-view-green .bt-guild-pill--late.on{
  background:rgba(5,150,105,0.16);border-color:rgba(4,120,87,0.52);color:rgba(220,252,231,0.96);  box-shadow:inset 0 0 0 1px rgba(16,185,129,0.26)}
#panel-calling .bt-view-pills{flex-wrap:wrap;justify-content:center}
#panel-calling .bt-row.bt-row-guild-hidden{display:none!important}
/* Calendar tab: tighter caption copy (season groups + heatmap notes) */
#panel-calling .bt-guide-text{
  font-size:7.425px;line-height:1.3;letter-spacing:0.12px;margin:2px auto 0;max-width:min(52em,96%);
  color:rgba(188,182,168,0.72)}
#panel-calling .bt-guide-breeder .bt-guide-text{margin-top:0}
#panel-calling .bt-guide-breeder,#panel-calling .bt-guide-heatmap{padding-top:0}
/* overflow:hidden keeps abspos (e.g. #bt-cell-wave) from inflating .calling-page-scroll scrollHeight */
#panel-calling .bt-wrap{
  flex:0 0 auto;min-height:0;overflow:hidden;display:flex;flex-direction:column;
  padding-top:22px;box-sizing:border-box}
#panel-calling .bt-rows-chart-wrap{
  position:relative;
  flex:0 0 auto;
  min-height:0;
  height:auto;
  padding-bottom:8px;
  box-sizing:border-box;
  overflow:visible}
#panel-calling .bt-rows-chart-wrap .bt-rows{
  position:relative;
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
  min-height:0;
  height:auto;
  overflow:visible}
.bt-heatmap-legend-overlay{
  position:absolute;
  top:4px;
  right:6px;
  z-index:7;
  width:min(38%,118px);
  max-width:118px;
  pointer-events:none;
  padding:5px 7px 6px;
  border-radius:6px;
  background:rgba(12,11,9,0.72);
  box-shadow:0 1px 0 rgba(255,248,230,0.06),inset 0 0 0 1px rgba(92,90,88,0.22);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:0;
  visibility:hidden;
  transition:opacity .32s ease,visibility 0s linear .32s}
#panel-calling.bt-cal-view-heatmap .bt-heatmap-legend-overlay{
  opacity:1;
  visibility:visible;
  transition:opacity .32s ease,visibility 0s linear 0s}
.bt-heatmap-legend-overlay .bt-heatmap-scale-labels{
  font-size:6.5px;
  margin-bottom:3px;
  letter-spacing:0.35px}
.bt-heatmap-legend-overlay .bt-heatmap-scale{
  height:7px;
  margin:0;
  border-radius:3px}
/* Calendar: row height tracks ~square heatmap cells (26 bins/row) + wider name rail */
#panel-calling #bt-rows .bt-row{
  flex:0 0 clamp(18px,min(2.6vw + 1.4vh,4vh),30px);
  min-height:clamp(16px,min(2.2vw + 1.1vh,3.5vh),28px);
  margin-bottom:clamp(2px,0.4vh,4px)}
#panel-calling #bt-rows .bt-row.bt-row-hover{
  min-height:clamp(48px,6.2vh,58px);
  max-height:clamp(68px,8.5vh,82px)}
#panel-calling #bt-rows .bt-track{min-height:clamp(14px,min(2vw + 1vh,3.2vh),26px)}
#panel-calling #bt-rows .bt-name-col{
  width:min(158px,42vw);
  padding-right:16px;
  border-right:none!important;
  box-shadow:none!important}
#panel-calling #bt-rows .bt-label{font-size:clamp(12.375px, 1.7325vw, 14.85px)}
#panel-calling #bt-rows .bt-latin{font-size:11.1375px}
#panel-calling #bt-rows .bt-heatmap{gap:2px;padding:2px 2px 3px 0}
#panel-calling .bt-months{
  margin-bottom:10px;
  padding-bottom:3px;
  border-bottom:1px solid rgba(92,90,88,0.16);
  box-shadow:0 1px 0 rgba(255,248,230,0.04)}
#panel-calling .bt-month{
  font-size:clamp(12px,1.9vw,16.5px);
  font-weight:500;
  letter-spacing:0.14em;
  padding:6px 3px 7px;
  color:rgba(205,196,176,0.92)}
/* Month column separators — low contrast in header; positions match flex bands (MAR/AUG slightly narrow) */
#panel-calling .bt-month:not(:first-child){
  border-left:1px solid rgba(92,90,88,0.10);
  box-shadow:inset 1px 0 0 rgba(255,244,214,0.04)}
#panel-calling .bt-survey{font-size:clamp(7.5px,1.05vw,9px);letter-spacing:0.08em}
#panel-calling .bt-week-readout{font-size:11.1375px;margin:0 0 8px;padding:6px 10px;min-height:1.5em}
#panel-calling .bt-timeline-controls{gap:4px;margin:6px 0 4px}
#panel-calling .bt-view-pill{padding:6px 14px;font-size:9.9px;letter-spacing:0.9px}
#panel-calling .bt-guild-pills{padding:5px 10px;gap:5px 8px}
#panel-calling .bt-guild-pill{font-size:8.6625px;padding:5px 11px;letter-spacing:0.6px}
#panel-calling .bt-guild-toggles-lbl{font-size:8.6625px;line-height:1.2;margin:0}
#panel-calling .bt-legend{margin-top:10px;font-size:8.6625px;gap:2px}
#panel-calling .bt-legend-bar{margin-bottom:10px;gap:12px}
/* Calendar: transparent panels, frames, and cell chrome (heatmap colors unchanged) */
#panel-calling .breed-timeline{background:transparent!important;border:none!important;box-shadow:none}
#panel-calling .bt-week-readout{background:transparent!important;border:none!important}
#panel-calling .bt-toggle{border-color:transparent!important}
#panel-calling .bt-toggle:hover{border-color:transparent!important}
#panel-calling .bt-survey{background:transparent!important;border:none!important}
/* Calendar: no weekly stripes; subtle verticals at calendar month starts (DOY-aligned to BT_DOY_MIN..BT_SPAN, Apr–Aug) */
#panel-calling .bt-week-grid{
  background-color:transparent!important;
  background-image:
    linear-gradient(to right,transparent 0,transparent calc(100% * 31 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 31 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 31 / 183 + 0.5px),transparent calc(100% * 31 / 183 + 0.5px)),
    linear-gradient(to right,transparent 0,transparent calc(100% * 61 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 61 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 61 / 183 + 0.5px),transparent calc(100% * 61 / 183 + 0.5px)),
    linear-gradient(to right,transparent 0,transparent calc(100% * 92 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 92 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 92 / 183 + 0.5px),transparent calc(100% * 92 / 183 + 0.5px)),
    linear-gradient(to right,transparent 0,transparent calc(100% * 122 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 122 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 122 / 183 + 0.5px),transparent calc(100% * 122 / 183 + 0.5px)),
    linear-gradient(to right,transparent 0,transparent calc(100% * 153 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 153 / 183 - 0.5px),rgba(92,90,88,0.09) calc(100% * 153 / 183 + 0.5px),transparent calc(100% * 153 / 183 + 0.5px)) !important}
#panel-calling #bt-rows .bt-species-img-wrap{border:none!important;box-shadow:none!important;background:transparent!important}
#panel-calling #bt-rows .bt-track{border-left:none!important;box-shadow:none!important}
#panel-calling .bt-cell{box-shadow:none!important}
#panel-calling #bt-rows .bt-cell.bt-cell-amber-nb{
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18),
    0 0 5px rgba(255,215,130,0.52),
    0 0 12px rgba(242,160,70,0.32),
    0 0 20px rgba(225,120,45,0.16)!important}
/* Row hover: brighten cells only (no amber borders; matches flat cells above) */
#panel-calling #bt-rows .bt-row.bt-row-hover .bt-cell{
  box-shadow:none!important;
  filter:brightness(1.24) saturate(1.28) contrast(1.03)}
#panel-calling #bt-rows .bt-row.bt-row-hover .bt-cell.bt-cell-amber-nb,
#panel-calling #bt-rows .bt-row.bt-row-hover .bt-cell.bt-cell-wf-target{
  filter:none}
#panel-calling #bt-rows .bt-row.bt-row-hover .bt-cell.bt-cell-wf-target{
  box-shadow:inset 0 0 0 1px rgba(240,200,130,0.55),0 0 0 1px rgba(240,200,130,0.2)!important}
#panel-calling #bt-rows .bt-row.bt-row-hover .bt-cell.bt-cell-amber-nb{
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.18),
    0 0 5px rgba(255,215,130,0.52),
    0 0 12px rgba(242,160,70,0.32),
    0 0 20px rgba(225,120,45,0.16)!important}
#panel-calling .bt-species-img{background:transparent!important;border:none!important;
  transform-origin:50% 50%}
/* Spring Peeper: textured silhouette PNG — multiply drops white “paper” on a soft rail */
#panel-calling #bt-rows .bt-species-img-wrap.bt-species-img-wrap--peeper{
  background:rgba(232,224,204,0.11);border-radius:7px}
#panel-calling .bt-species-img.bt-species-img--peeper-silhouette{
  object-fit:contain;mix-blend-mode:multiply;filter:brightness(1.06) contrast(1.04);padding:1px}
#panel-calling #bt-rows .bt-species-img-wrap.bt-species-img-wrap--gray-treefrog{
  background:rgba(232,224,204,0.09);border-radius:7px}
#panel-calling .bt-species-img.bt-species-img--gray-treefrog{
  object-fit:contain;padding:1px}
#panel-calling #bt-rows .bt-species-img-wrap.bt-species-img-wrap--copes-gray-treefrog{
  background:rgba(232,224,204,0.09);border-radius:7px}
#panel-calling .bt-species-img.bt-species-img--copes-gray-treefrog{
  object-fit:contain;padding:1px}
#panel-calling #bt-rows .bt-species-img-wrap.bt-species-img-wrap--mink-frog{
  background:rgba(232,224,204,0.09);border-radius:7px}
#panel-calling .bt-species-img.bt-species-img--mink-frog{
  object-fit:contain;padding:1px}
/* Blanchard's Cricket Frog: species portrait / plate art may read as a white box on the calendar strip */
#panel-calling #bt-rows .bt-species-img-wrap.bt-species-img-wrap--cricket-frog{
  background:rgba(232,224,204,0.11);border-radius:7px}
#panel-calling .bt-species-img.bt-species-img--cricket-frog{
  object-fit:contain;mix-blend-mode:multiply;filter:brightness(1.05) contrast(1.04);padding:1px}
/* Field Guide: same mat issue on transparent star header */
#panel-guide #fg-blanchards-cricket-frog .fg-card-header-thumb.fg-img-loaded{
  mix-blend-mode:multiply;
  filter:brightness(1.05) contrast(1.04)}
#panel-calling .bt-view-pills{background:transparent!important;border:none!important}
#panel-calling .bt-view-pill.on{background:transparent!important;box-shadow:none!important}
#panel-calling .bt-heatmap-scale{border:none!important;box-shadow:none!important}
#panel-calling .bt-guild-pills{background:transparent!important;border:none!important}
.audio-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px 14px;row-gap:6px;padding:6px 14px;background:rgba(18,17,16,0.75);border-bottom:1px solid var(--wfts-c-stone-15);font-family:'IBM Plex Mono',monospace}
.audio-bar .ab-map-layers{
  display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px 12px;
  flex:1 1 220px;min-width:0;margin:0;padding:0}
.audio-bar .ab-map-layers-label{
  font-size:8.6625px;letter-spacing:2px;text-transform:uppercase;color:rgba(92,90,88,0.5);
  flex-shrink:0;margin:0;line-height:1;align-self:center;padding-top:1px}
.audio-bar .ab-map-layers-items{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;flex:1;min-width:0}
/* Map layer strips: extends shared .ab-toggle (atlas dock + audio bar) */
.audio-bar .ab-toggle.ab-map-layer{flex-shrink:0}
.audio-bar .ab-toggle.ab-map-layer:has(.a-layer-chk.on){color:var(--amber)}
.audio-bar .ab-map-layer-slider{
  width:48px;height:14px;margin:0;padding:0;flex-shrink:0;vertical-align:middle;cursor:pointer;
  accent-color:var(--amber)}

/* Vocal Sac Animation */
.vocal-sac-demo{display:flex;flex-direction:column;align-items:center;padding:16px;
  background:var(--wfts-c-surface-50);border:1px solid var(--wfts-c-stone-20);border-radius:10px;margin:16px 0}
.vocal-frog{position:relative;width:80px;height:60px}
.vocal-body{width:60px;height:40px;background:radial-gradient(ellipse at 50% 60%,#7a9a6a,#4a6a3a);
  border-radius:50% 50% 45% 45%;position:absolute;bottom:0;left:10px}
.vocal-eye{width:8px;height:8px;background:radial-gradient(circle,#dda,#996);border-radius:50%;
  position:absolute;top:6px;border:1px solid #333}
.vocal-eye.l{left:16px}.vocal-eye.r{right:16px}
.vocal-sac{width:30px;height:0;background:radial-gradient(ellipse,rgba(200,200,160,0.7),rgba(160,170,130,0.5));
  border-radius:50%;position:absolute;bottom:-2px;left:25px;
  transition:height .15s ease,width .15s ease,bottom .15s ease;transform:translateX(-50%);left:50%}
.vocal-sac.inflated{height:22px;width:32px;bottom:-14px}
.vocal-waveform{width:200px;height:40px;margin-top:12px}

/* Counties: filled shapes + single boundary stroke */
.ac{
  fill:rgba(14,13,10,0.35);
  stroke:none;
  pointer-events:all;
  cursor:crosshair;
  transition:fill 0.22s ease,filter 0.22s ease;
  filter:none}
.ac .ac-fill path,
.ac > path.ac-fill{
  fill:inherit;
  stroke:none;
  pointer-events:all;
  vector-effect:non-scaling-stroke}
.ac-outline path{
  pointer-events:none;
  vector-effect:non-scaling-stroke}
.ac .ac-o{
  stroke:rgba(200,188,168,0.42);
  stroke-width:0.82;
  stroke-linejoin:round;
  stroke-linecap:round}
.ac:hover{
  fill:rgba(212,136,58,0.26);
  filter:url(#ac-county-hover-glow)}
.ac:hover .ac-o{
  stroke:rgba(255,244,214,0.88);
  stroke-width:0.98}
@media (prefers-reduced-motion:reduce){
  .ac{transition-duration:0.12s}
  .ac:hover{filter:none}
  .ac:hover .ac-o{stroke-width:0.92}}
/* Map outlines: line weight stays same on screen at any zoom (viewBox pan/zoom) */
#a-svg-ui #a-grid,#a-svg-ui #a-grid-labels{pointer-events:none}
#a-svg-ui #a-grid line{vector-effect:non-scaling-stroke}
#a-gps-svg #a-cross-h,#a-gps-svg #a-cross-v{vector-effect:non-scaling-stroke}
#a-gps-svg line,#a-gps-svg circle{vector-effect:non-scaling-stroke}
.ac-tip{position:absolute;pointer-events:none;display:none;z-index:100;font-size:12.375px;color:rgba(255,244,214,0.6);font-family:'IBM Plex Mono',monospace;letter-spacing:0.5px}
.a-coords{
  position:absolute;z-index:102;pointer-events:none;text-align:left;
  font-family:'IBM Plex Mono',monospace;font-size:10.395px;line-height:1.25;
  letter-spacing:0.04em;color:rgba(255,244,214,0.92);
  padding:5px 8px;border-radius:5px;max-width:min(240px,72vw);
  white-space:nowrap;
  background:rgba(10,9,8,0.82);
  border:1px solid rgba(212,168,90,0.28);
  box-shadow:0 2px 12px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,248,230,0.05);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}

/* Hidden regional auto-forecast (#auto-forecast) — no inner .page-scroll; use main document scroll */
#panel-auto-forecast.tab-panel.active{
  max-width:820px;
  margin:0 auto;
  padding:32px 28px calc(40px + env(safe-area-inset-bottom,0px));
  box-sizing:border-box;
  overflow:visible;
  min-height:0}
#panel-auto-forecast .auto-forecast-h1{
  font-family:'Playfair Display',serif;font-size:clamp(22px,3.2vw,28px);font-weight:500;color:var(--cream);margin:0 0 10px}
#panel-auto-forecast .auto-forecast-lead{
  font-size:14.025px;line-height:1.65;color:rgba(205,196,176,0.92);max-width:52rem;margin:0 0 18px}
#panel-auto-forecast .auto-forecast-gate{
  max-width:28rem;padding:20px 22px;border-radius:10px;background:rgba(14,13,12,0.72);
  border:1px solid rgba(212,168,90,0.22);box-shadow:0 4px 24px rgba(0,0,0,0.25)}
#panel-auto-forecast .auto-forecast-label{
  display:block;font-size:11.1375px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(205,196,176,0.65);margin:0 0 6px}
#panel-auto-forecast .auto-forecast-input{
  width:100%;max-width:20rem;padding:10px 12px;border-radius:6px;border:1px solid rgba(92,90,88,0.35);
  background:rgba(8,7,6,0.85);color:var(--cream);font-family:'IBM Plex Mono',monospace;font-size:14px}
#panel-auto-forecast .auto-forecast-gate-error{min-height:1.2em;margin:8px 0 0;font-size:12.87px;color:#c87870}
#panel-auto-forecast .auto-forecast-btn{
  margin-top:14px;padding:10px 20px;border-radius:7px;border:1px solid rgba(212,168,90,0.45);
  background:linear-gradient(135deg,rgba(212,168,90,0.22),rgba(120,90,40,0.12));color:var(--cream);
  font-family:'IBM Plex Mono',monospace;font-size:12.375px;letter-spacing:0.06em;cursor:pointer}
#panel-auto-forecast .auto-forecast-btn:hover{border-color:rgba(240,188,110,0.55)}
#panel-auto-forecast .auto-forecast-btn--secondary{
  background:linear-gradient(135deg,rgba(74,72,70,0.5),rgba(42,40,38,0.35));border-color:rgba(92,90,88,0.4)}
#panel-auto-forecast .auto-forecast-actions{margin:0 0 20px}
#panel-auto-forecast .auto-forecast-status{min-height:1.3em;font-size:12.87px;color:rgba(205,196,176,0.75);margin:0 0 8px}
#panel-auto-forecast .auto-forecast-meta{
  font-size:11.7px;line-height:1.55;color:rgba(205,196,176,0.65);margin:0 0 22px;padding-bottom:16px;
  border-bottom:1px solid rgba(92,90,88,0.18)}
#panel-auto-forecast .auto-forecast-region{
  margin:0 0 28px;padding-bottom:22px;border-bottom:1px solid rgba(92,90,88,0.15)}
#panel-auto-forecast .auto-forecast-region:last-child{border-bottom:none}
#panel-auto-forecast .auto-forecast-region-title{
  font-family:'Playfair Display',serif;font-size:20px;font-weight:500;color:rgba(240,210,170,0.95);margin:0 0 6px}
#panel-auto-forecast .auto-forecast-region-sub{
  font-size:12.375px;color:rgba(205,196,176,0.72);margin:0 0 8px;line-height:1.45}
#panel-auto-forecast .auto-forecast-region-wx{
  font-family:'IBM Plex Mono',monospace;font-size:11.7px;line-height:1.5;color:rgba(255,244,214,0.78);margin:0 0 12px}
#panel-auto-forecast .auto-forecast-narrative p{
  font-size:14.025px;line-height:1.65;color:rgba(228,220,200,0.9);margin:0 0 12px;max-width:50rem}
#panel-auto-forecast .auto-forecast-species{
  font-size:13.05px;line-height:1.55;color:rgba(205,196,176,0.88);margin:12px 0 0;padding-left:1.1em;max-width:48rem}
#panel-auto-forecast .auto-forecast-species li{margin:4px 0}
#panel-auto-forecast .auto-forecast-social{
  margin-top:36px;padding-top:28px;border-top:1px solid rgba(92,90,88,0.22);max-width:52rem}
#panel-auto-forecast .auto-forecast-social-title{
  font-family:'Playfair Display',serif;font-size:clamp(18px,2.4vw,22px);font-weight:500;color:rgba(240,210,170,0.95);margin:0 0 8px}
#panel-auto-forecast .auto-forecast-social-title--fb{margin-top:32px}
#panel-auto-forecast .auto-forecast-social-lead{
  font-size:12.87px;line-height:1.55;color:rgba(205,196,176,0.78);margin:0 0 16px;max-width:48rem}
#panel-auto-forecast .auto-forecast-social-card{
  margin:0 0 18px;padding:14px 16px;border-radius:8px;background:rgba(12,11,10,0.55);
  border:1px solid rgba(92,90,88,0.2)}
#panel-auto-forecast .auto-forecast-social-card-lbl{
  font-size:11.7px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(212,168,90,0.75);margin:0 0 8px}
#panel-auto-forecast .auto-forecast-social-textarea{
  width:100%;max-width:100%;box-sizing:border-box;min-height:5.5em;padding:10px 12px;margin:0 0 10px;
  border-radius:6px;border:1px solid rgba(92,90,88,0.35);background:rgba(8,7,6,0.88);color:var(--cream);
  font-family:'IBM Plex Mono',monospace;font-size:12.6px;line-height:1.45;resize:vertical}
#panel-auto-forecast .auto-forecast-social-textarea--fb{
  min-height:16em;font-size:13.05px;line-height:1.55;font-family:'IBM Plex Sans','IBM Plex Mono',system-ui,sans-serif}
#panel-auto-forecast .auto-forecast-social-actions{
  display:flex;flex-wrap:wrap;align-items:center;gap:12px}
#panel-auto-forecast .auto-forecast-copy-btn{margin-top:0}
#panel-auto-forecast .auto-forecast-social-meta{
  font-size:11.25px;color:rgba(205,196,176,0.55);font-family:'IBM Plex Mono',monospace}

/* Coarse pointer + narrow viewport: lighter glass (less backdrop-filter cost on many tablets). */
@media (pointer:coarse) and (max-width:900px){
  #panel-predictor .predictor-primary-actions .fetchbtn,
  #panel-predictor .predictor-loc-reset-btn,
  .get-involved-cta{
    backdrop-filter:blur(12px) saturate(1.12);
    -webkit-backdrop-filter:blur(12px) saturate(1.12)}
  #panel-predictor .predictor-primary-actions .fetchbtn:hover:not(:disabled),
  #panel-predictor .predictor-loc-reset-btn:hover{
    backdrop-filter:blur(14px) saturate(1.15);
    -webkit-backdrop-filter:blur(14px) saturate(1.15)}}
