:root {
  --paper: #f7f2e9;
  --paper-2: #fffaf1;
  --ink: #17211c;
  --muted: #5e6a61;
  --line: #d9cdbb;
  --green: #1f6a4f;
  --green-dark: #0f3d31;
  --honey: #c8851a;
  --amber: #f0b43b;
  --blue: #2b5d8f;
  --danger: #a84432;
  --shadow: 0 22px 60px rgba(37, 29, 16, 0.16);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--ink);
  background: #eef1ed;
  font-family: "Inter", "Segoe UI", Arial, sans-serif;
  line-height: 1.45;
}

.site-zen-intro {
  position: fixed;
  inset: 0;
  z-index: 10000;
  overflow: hidden;
  pointer-events: none;
  background: #10251b url("assets/images/beehives.jpg") center / cover no-repeat;
  animation: siteZenIntroExit 8.8s ease-in-out forwards;
}

.site-zen-intro::before,
.site-zen-intro::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.site-zen-intro::before {
  background:
    radial-gradient(circle at 70% 18%, rgba(255, 244, 174, 0.34), transparent 18rem),
    linear-gradient(180deg, rgba(255, 250, 241, 0.06), rgba(15, 61, 49, 0.06));
}

.site-zen-intro::after {
  background:
    linear-gradient(180deg, rgba(255, 250, 241, 0) 0 62%, rgba(15, 61, 49, 0.18) 100%);
}

html.zen-disabled .site-zen-intro,
.site-zen-intro.is-skipped {
  display: none;
}

.zen-intro-controls {
  position: absolute;
  right: max(14px, env(safe-area-inset-right));
  top: max(14px, env(safe-area-inset-top));
  z-index: 4;
  display: grid;
  gap: 0.45rem;
  justify-items: end;
  pointer-events: auto;
}

.zen-skip-button {
  min-height: 2.72rem;
  padding: 0.68rem 0.92rem;
  border: 1px solid rgba(255, 250, 241, 0.7);
  border-radius: 999px;
  color: #10251b;
  background: rgba(255, 250, 241, 0.84);
  box-shadow: 0 14px 34px rgba(15, 61, 49, 0.22);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
  backdrop-filter: blur(8px);
}

.zen-skip-button:focus-visible,
.zen-audio-button:focus-visible,
.zen-preference-check:focus-within {
  outline: 3px solid rgba(247, 211, 111, 0.95);
  outline-offset: 3px;
}

.zen-preference-check {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 2.28rem;
  padding: 0.48rem 0.72rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 999px;
  background: rgba(255, 250, 241, 0.86);
  color: #10251b;
  box-shadow: 0 12px 28px rgba(15, 61, 49, 0.18);
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  backdrop-filter: blur(8px);
}

.zen-preference-check input {
  width: 1rem;
  height: 1rem;
  margin: 0;
  accent-color: var(--green);
}

.zen-audio-button {
  position: absolute;
  right: max(14px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 4;
  display: grid;
  gap: 0.05rem;
  min-height: 3.1rem;
  padding: 0.64rem 0.86rem 0.7rem;
  border: 1px solid rgba(255, 250, 241, 0.72);
  border-radius: 999px;
  color: #10251b;
  background: rgba(255, 250, 241, 0.84);
  box-shadow: 0 16px 38px rgba(15, 61, 49, 0.24);
  font: inherit;
  line-height: 1;
  text-align: left;
  cursor: pointer;
  pointer-events: auto;
  backdrop-filter: blur(8px);
}

.zen-audio-button span {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.zen-audio-button strong {
  font-size: 0.9rem;
}

.zen-audio-button[aria-pressed="true"] {
  background: rgba(247, 211, 111, 0.92);
  border-color: rgba(255, 250, 241, 0.9);
}

.zen-bee {
  position: absolute;
  z-index: 2;
  left: var(--zen-left, -3rem);
  top: var(--zen-top, 54%);
  width: var(--zen-size-x, 24px);
  height: var(--zen-size-y, 13px);
  border-radius: 999px;
  background:
    linear-gradient(90deg, #11140d 0 17%, #f3bd35 17% 38%, #11140d 38% 53%, #f3bd35 53% 76%, #11140d 76% 100%);
  box-shadow: 0 0 20px rgba(250, 213, 92, 0.52), 0 2px 8px rgba(0, 0, 0, 0.24);
  opacity: 0;
  transform: rotate(var(--zen-rotate, -8deg));
  animation: zenBeeFlight var(--zen-duration, 6.9s) cubic-bezier(0.36, 0, 0.18, 1) var(--zen-delay, 0s) infinite;
}

.zen-bee::before,
.zen-bee::after {
  content: "";
  position: absolute;
  top: -9px;
  width: 12px;
  height: 9px;
  border-radius: 50% 50% 45% 45%;
  background: rgba(255, 250, 230, 0.76);
  border: 1px solid rgba(255, 255, 255, 0.38);
  transform-origin: 50% 100%;
  animation: beeWingBeat 70ms linear infinite alternate;
}

.zen-bee::before {
  left: 3px;
  --wing-rest: -22deg;
  --wing-open: -54deg;
}

.zen-bee::after {
  right: 3px;
  --wing-rest: 22deg;
  --wing-open: 54deg;
}

.zen-bee-one { --zen-top: 54%; --zen-size-x: 28px; --zen-size-y: 15px; --zen-delay: -1.8s; --zen-duration: 7.6s; --zen-rotate: -8deg; --zen-y1: -3.6rem; --zen-y2: 1.2rem; --zen-y3: -2.4rem; }
.zen-bee-two { --zen-top: 42%; --zen-size-x: 22px; --zen-size-y: 12px; --zen-delay: -4.4s; --zen-duration: 7.9s; --zen-rotate: 7deg; --zen-y1: 1.8rem; --zen-y2: -2.2rem; --zen-y3: 0.5rem; }
.zen-bee-three { --zen-top: 64%; --zen-size-x: 19px; --zen-size-y: 10px; --zen-delay: -6.1s; --zen-duration: 7.1s; --zen-rotate: -12deg; --zen-y1: -2rem; --zen-y2: -0.4rem; --zen-y3: -3.4rem; }
.zen-bee-four { --zen-top: 31%; --zen-size-x: 17px; --zen-size-y: 9px; --zen-delay: -0.7s; --zen-duration: 6.8s; --zen-rotate: 14deg; --zen-y1: 2.8rem; --zen-y2: -1.2rem; --zen-y3: 1.6rem; }
.zen-bee-five { --zen-top: 73%; --zen-size-x: 24px; --zen-size-y: 13px; --zen-delay: -3.2s; --zen-duration: 6.6s; --zen-rotate: -4deg; --zen-y1: -1.4rem; --zen-y2: 2.6rem; --zen-y3: -0.8rem; }
.zen-bee-six { --zen-top: 48%; --zen-size-x: 15px; --zen-size-y: 8px; --zen-delay: -5.3s; --zen-duration: 5.9s; --zen-rotate: 18deg; --zen-y1: -4rem; --zen-y2: -1.7rem; --zen-y3: -4.8rem; }
.zen-bee-seven { --zen-top: 58%; --zen-size-x: 18px; --zen-size-y: 10px; --zen-delay: -2.7s; --zen-duration: 6.1s; --zen-rotate: 2deg; --zen-y1: 2.4rem; --zen-y2: 0.7rem; --zen-y3: 2.9rem; }
.zen-bee-eight { --zen-top: 37%; --zen-size-x: 23px; --zen-size-y: 12px; --zen-delay: -4.9s; --zen-duration: 5.8s; --zen-rotate: -16deg; --zen-y1: -1rem; --zen-y2: -3.2rem; --zen-y3: -1.5rem; }
.zen-bee-nine { --zen-top: 68%; --zen-size-x: 16px; --zen-size-y: 9px; --zen-delay: -1.2s; --zen-duration: 5.5s; --zen-rotate: 11deg; --zen-y1: 1.3rem; --zen-y2: -1.8rem; --zen-y3: 0.9rem; }

html.video-lightbox-open,
body.video-lightbox-open {
  overflow: hidden;
}

body.video-lightbox-open {
  position: fixed;
  left: 0;
  right: 0;
  width: 100%;
}

a {
  color: inherit;
}

.bee-term {
  position: relative;
  display: inline;
  border-bottom: 2px dotted rgba(31, 106, 79, 0.56);
  color: inherit;
  font-weight: 820;
  text-decoration: none;
  cursor: help;
}

.bee-term:focus-visible {
  outline: 3px solid rgba(240, 180, 59, 0.7);
  outline-offset: 3px;
  border-radius: 4px;
}

.bee-term::after {
  content: attr(data-definition);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 0.52rem);
  z-index: 120;
  width: max-content;
  max-width: min(21rem, calc(100vw - 2rem));
  padding: 0.72rem 0.82rem;
  border: 1px solid rgba(255, 242, 168, 0.68);
  border-radius: 7px;
  color: #fffaf1;
  background: rgba(15, 61, 49, 0.98);
  box-shadow: 0 18px 42px rgba(15, 33, 24, 0.28);
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.28;
  white-space: normal;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-50%, 0.35rem, 0);
  transition: opacity 160ms ease, transform 160ms ease;
}

.bee-term:hover::after,
.bee-term:focus-visible::after {
  opacity: 1;
  transform: translate3d(-50%, 0, 0);
}

img {
  display: block;
  max-width: 100%;
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: -4rem;
  z-index: 20;
  padding: 0.7rem 1rem;
  background: var(--ink);
  color: #fff;
  border-radius: 4px;
}

.skip-link:focus {
  top: 1rem;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  border-bottom: 1px solid rgba(23, 33, 28, 0.12);
  background: rgba(247, 242, 233, 0.93);
  backdrop-filter: blur(18px);
}

.nav-shell {
  width: min(1600px, calc(100% - 32px));
  min-height: 62px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  text-decoration: none;
  min-width: 0;
}

.brand-mark {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border: 1px solid var(--green);
  background: var(--green-dark);
  color: var(--amber);
  font-weight: 900;
  letter-spacing: 0;
}

.brand strong,
.brand small {
  display: block;
}

.brand strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.05rem;
}

.brand small {
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.nav-toggle {
  display: none;
  width: auto;
  height: 44px;
  min-width: 92px;
  padding: 0 0.72rem;
  border: 1px solid var(--line);
  background: var(--paper-2);
  border-radius: 4px;
  align-items: center;
  justify-content: center;
  gap: 0.58rem;
  color: var(--green-dark);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
}

.nav-toggle::after {
  content: "Menu";
  line-height: 1;
  letter-spacing: 0.08em;
}

.nav-toggle-icon {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
}

.nav-toggle-icon span {
  width: 19px;
  height: 2px;
  background: var(--ink);
}

.nav-links {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.25rem;
}

.nav-links a,
.nav-tool-button,
.nav-tools-menu summary,
.zen-nav-preference {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 0.62rem;
  border: 0;
  border-radius: 4px;
  background: transparent;
  text-decoration: none;
  color: var(--muted);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
}

.nav-links a:hover,
.nav-tool-button:hover,
.nav-tools-menu summary:hover,
.zen-nav-preference:hover {
  color: var(--ink);
}

.nav-links .nav-cta {
  margin-left: 0.3rem;
  color: #fff;
  background: var(--green-dark);
}

.nav-links .nav-tool-button,
.nav-tools-menu summary,
.zen-nav-preference {
  border: 1px solid rgba(31, 106, 79, 0.16);
  background: rgba(255, 250, 241, 0.72);
  color: var(--green-dark);
}

.zen-nav-preference {
  gap: 0.38rem;
  box-shadow: none;
  backdrop-filter: none;
}

.zen-page-preference-panel {
  position: fixed;
  left: max(12px, env(safe-area-inset-left));
  bottom: max(12px, env(safe-area-inset-bottom));
  z-index: 35;
  pointer-events: none;
}

.zen-page-preference-panel .zen-preference-check {
  pointer-events: auto;
  box-shadow: 0 16px 38px rgba(15, 61, 49, 0.2);
}

.site-ambient-life {
  position: fixed;
  inset: 72px 0 0;
  z-index: 38;
  pointer-events: none;
  overflow: hidden;
}

.site-ambient-life .yard-critter {
  opacity: 0.82;
  filter: drop-shadow(0 4px 8px rgba(15, 35, 24, 0.2));
}

.site-ambient-life .ambient-bee {
  animation: ambientBeeHover 14s ease-in-out infinite;
  bottom: auto;
  --ambient-scale: 0.86;
  --ambient-rotate: -8deg;
}

.site-ambient-life .ambient-bee-one {
  left: -1.65rem;
  top: 18%;
  --ambient-scale: 0.66;
  --ambient-rotate: 8deg;
  animation-duration: 13s;
  animation-delay: -4s;
}

.site-ambient-life .ambient-bee-two {
  left: auto;
  right: -1.65rem;
  top: 42%;
  --ambient-scale: 0.72;
  --ambient-rotate: -12deg;
  animation-name: ambientBeeHoverRight;
  animation-duration: 15s;
  animation-delay: -14s;
}

.site-ambient-life .ambient-bee-three {
  left: -1.7rem;
  top: 68%;
  --ambient-scale: 0.58;
  --ambient-rotate: -5deg;
  animation-duration: 16s;
  animation-delay: -22s;
}

.site-ambient-life .ambient-bee-four {
  left: auto;
  right: -1.7rem;
  top: 84%;
  --ambient-scale: 0.64;
  --ambient-rotate: 11deg;
  animation-name: ambientBeeHoverRight;
  animation-duration: 17s;
  animation-delay: -9s;
}

.nav-tools-menu {
  position: relative;
}

.nav-tools-menu summary {
  list-style: none;
  gap: 0.35rem;
}

.nav-tools-menu summary::-webkit-details-marker {
  display: none;
}

.nav-tools-menu summary::after {
  content: "";
  width: 0.42rem;
  height: 0.42rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
}

.nav-tools-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 60;
  width: 180px;
  display: grid;
  gap: 0.2rem;
  padding: 0.35rem;
  border: 1px solid rgba(23, 33, 28, 0.14);
  border-radius: 6px;
  background: var(--paper-2);
  box-shadow: 0 18px 44px rgba(37, 29, 16, 0.18);
}

.nav-tools-panel .nav-tool-button {
  width: 100%;
  justify-content: flex-start;
  border-color: transparent;
  background: transparent;
}

.nav-tool-button-flash {
  position: relative;
  overflow: hidden;
  border-color: rgba(168, 68, 50, 0.35);
  background: #fff3c4;
  color: #6d3600;
  animation: weatherButtonPulse 1.7s ease-in-out infinite;
}

.nav-tool-button-flash::after {
  content: "";
  position: absolute;
  inset: -60% auto auto -30%;
  width: 42%;
  height: 220%;
  transform: rotate(18deg);
  background: rgba(255, 255, 255, 0.58);
  animation: weatherButtonSweep 2.8s ease-in-out infinite;
}

@keyframes weatherButtonPulse {
  0%,
  100% {
    box-shadow: 0 0 0 rgba(240, 180, 59, 0);
  }
  50% {
    box-shadow: 0 0 0 4px rgba(240, 180, 59, 0.24);
  }
}

@keyframes weatherButtonSweep {
  0% {
    left: -42%;
  }
  45%,
  100% {
    left: 120%;
  }
}

@keyframes utilityFloatIn {
  0% {
    opacity: 0;
    transform: translate(-50%, -18px) scale(0.96);
  }

  65% {
    opacity: 1;
    transform: translate(-50%, 3px) scale(1.01);
  }

  100% {
    opacity: 1;
    transform: translate(-50%, 0) scale(1);
  }
}

@keyframes utilityBeeSignal {
  0%,
  100% {
    transform: translateY(-50%) scale(1);
  }

  38% {
    transform: translate(4px, -62%) scale(0.78);
  }

  52% {
    transform: translate(-1px, -38%) scale(1.18);
  }

  70% {
    transform: translate(3px, -52%) scale(0.94);
  }
}

.floating-utility {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 70px);
  left: 50%;
  z-index: 30;
  display: flex;
  gap: 0.42rem;
  width: min(680px, calc(100% - 24px));
  padding: 0.42rem;
  border: 1px solid rgba(255, 250, 241, 0.32);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(15, 61, 49, 0.9), rgba(23, 33, 28, 0.88)),
    rgba(15, 61, 49, 0.9);
  box-shadow: 0 18px 48px rgba(7, 10, 8, 0.28);
  transform: translateX(-50%);
  backdrop-filter: blur(16px) saturate(1.18);
  animation: utilityFloatIn 720ms cubic-bezier(0.2, 0.9, 0.2, 1) 420ms both;
}

.floating-utility-button {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
  min-height: 54px;
  display: grid;
  align-content: center;
  gap: 0.12rem;
  padding: 0.62rem 0.8rem 0.62rem 2.25rem;
  border: 1px solid rgba(247, 211, 111, 0.28);
  border-radius: 6px;
  overflow: hidden;
  background: rgba(255, 250, 241, 0.1);
  color: #fffaf1;
  text-align: left;
  cursor: pointer;
}

.floating-utility-button::before {
  content: "";
  position: absolute;
  left: 0.8rem;
  top: 50%;
  width: 0.72rem;
  height: 0.72rem;
  border-radius: 999px;
  background: var(--amber);
  box-shadow: 0 0 0 4px rgba(240, 180, 59, 0.16), 0 0 24px rgba(240, 180, 59, 0.62);
  transform: translateY(-50%);
  animation: utilityBeeSignal 1.9s ease-in-out infinite;
}

.floating-utility-button::after {
  content: "";
  position: absolute;
  inset: auto -12% -55% 24%;
  height: 84%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 250, 241, 0.34), rgba(255, 250, 241, 0) 68%);
  transform: rotate(-10deg);
  opacity: 0;
  transition: opacity 220ms ease, transform 360ms ease;
}

.floating-utility-button:hover,
.floating-utility-button:focus-visible {
  border-color: rgba(247, 211, 111, 0.58);
  background: rgba(255, 250, 241, 0.17);
  outline: 0;
}

.floating-utility-button:hover::after,
.floating-utility-button:focus-visible::after {
  opacity: 1;
  transform: rotate(0deg) translateY(-8%);
}

.floating-utility-button span,
.floating-utility-button strong {
  position: relative;
  z-index: 1;
  display: block;
  min-width: 0;
}

.floating-utility-button span {
  color: #f7d36f;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1;
  text-transform: uppercase;
}

.floating-utility-button strong {
  font-size: clamp(0.86rem, 2vw, 1rem);
  line-height: 1.05;
}

.floating-beekeeper::before {
  animation-delay: 340ms;
}

.floating-swarm-sequence {
  width: min(760px, calc(100% - 24px));
}

.floating-swarm-choice {
  min-height: 62px;
  padding: 0.74rem 0.72rem 0.74rem 2.2rem;
  border-color: rgba(255, 207, 72, 0.62);
  background: linear-gradient(135deg, rgba(255, 207, 72, 0.18), rgba(15, 61, 49, 0.95));
  text-decoration: none;
}

.floating-swarm-choice:nth-child(2)::before {
  animation-delay: 180ms;
}

.floating-swarm-choice:nth-child(3)::before {
  animation-delay: 360ms;
}

.floating-swarm-choice span {
  color: #fff2a8;
}

.floating-swarm-choice strong {
  font-size: clamp(0.98rem, 2.2vw, 1.22rem);
}

.floating-swarm-choice:hover,
.floating-swarm-choice:focus-visible {
  border-color: rgba(255, 207, 72, 0.86);
  background: linear-gradient(135deg, rgba(255, 207, 72, 0.32), rgba(15, 61, 49, 0.98));
  transform: translateY(-2px);
}

.floating-swarm {
  flex: 1.9 1 0;
  min-width: min(100%, 15.5rem);
  padding: 1.05rem 1rem 1.05rem 2.75rem;
  border-color: rgba(255, 207, 72, 0.74);
  background: linear-gradient(135deg, rgba(255, 207, 72, 0.28), rgba(15, 61, 49, 0.96) 48%, rgba(255, 250, 241, 0.18));
  box-shadow: 0 18px 42px rgba(37, 29, 16, 0.24), 0 0 0 3px rgba(255, 207, 72, 0.13);
  text-decoration: none;
  transform: translateY(-4px);
}

.floating-swarm span {
  color: #fff2a8;
  font-size: 0.78rem;
}

.floating-swarm strong {
  font-size: clamp(1.12rem, 3vw, 1.42rem);
  letter-spacing: 0;
}

.floating-swarm:hover,
.floating-swarm:focus-visible {
  background: linear-gradient(135deg, rgba(255, 207, 72, 0.42), rgba(15, 61, 49, 0.98) 52%, rgba(255, 250, 241, 0.22));
  transform: translateY(-7px) scale(1.015);
}

.floating-swarm::before {
  width: 1rem;
  height: 1rem;
  background: #ffcf48;
  box-shadow: 0 0 0 6px rgba(255, 207, 72, 0.22), 0 0 34px rgba(255, 207, 72, 0.82);
}

.swarm-hero-cta {
  min-height: 3.25rem;
  padding-inline: 1.25rem;
  box-shadow: 0 16px 34px rgba(200, 133, 26, 0.26);
}

.weather-top-panel,
.weather-cta-strip {
  width: min(760px, calc(100% - 20px));
  margin: 0 auto;
}

.weather-top-panel {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
  gap: 0.9rem;
  align-items: center;
  padding: 1rem;
  border: 1px solid rgba(15, 61, 49, 0.18);
  border-top: 0;
  background:
    linear-gradient(135deg, rgba(255, 250, 241, 0.98), rgba(238, 246, 229, 0.96) 48%, rgba(255, 238, 186, 0.74)),
    #fffaf1;
  box-shadow: 0 14px 40px rgba(37, 29, 16, 0.12);
}

.weather-top-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-top: 5px solid var(--amber);
}

.weather-top-panel h1 {
  max-width: 12ch;
  margin: 0.18rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2.05rem, 6vw, 4rem);
  line-height: 0.96;
  letter-spacing: 0;
}

.weather-top-panel p:not(.kicker) {
  margin: 0.7rem 0 0;
  color: #314338;
  font-weight: 750;
}

.weather-top-form {
  display: grid;
  gap: 0.42rem;
  padding: 0.85rem;
  border: 1px solid rgba(15, 61, 49, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.76);
}

.weather-top-form label {
  color: var(--green-dark);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.weather-top-row {
  display: grid;
  gap: 0.55rem;
}

.weather-top-row input {
  min-height: 48px;
  width: 100%;
  border: 1px solid rgba(15, 61, 49, 0.24);
  border-radius: 4px;
  padding: 0.7rem 0.78rem;
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-size: 1.15rem;
  font-weight: 900;
}

.weather-top-row .button {
  width: 100%;
  min-height: 52px;
  text-align: center;
}

.weather-cta-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.85rem;
  align-items: center;
  margin-top: 0.9rem;
  margin-bottom: 0.9rem;
  padding: 0.9rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-left: 6px solid var(--amber);
  border-radius: 8px;
  background: linear-gradient(135deg, #fffaf1, #eef3e9);
}

.weather-cta-strip h2 {
  margin: 0.18rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 3vw, 2rem);
  line-height: 1.04;
}

.weather-cta-strip p:not(.kicker) {
  margin: 0.44rem 0 0;
  color: #3d493f;
}

.compact-weather-cta {
  margin-top: 1.1rem;
  margin-bottom: 1.1rem;
}

.network-section {
  position: relative;
  overflow: hidden;
  margin-top: clamp(1.4rem, 4vw, 3rem);
}

.network-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(240, 180, 59, 0.16), rgba(31, 106, 79, 0) 32%),
    linear-gradient(180deg, rgba(255, 250, 241, 0.82), rgba(238, 241, 237, 0));
}

.network-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
}

.network-card {
  display: grid;
  align-content: start;
  gap: 0.72rem;
  padding: 1rem;
  border: 1px solid rgba(23, 33, 28, 0.14);
  border-radius: 8px;
  background: #fffaf1;
  box-shadow: 0 16px 34px rgba(37, 29, 16, 0.1);
}

.network-card span {
  color: var(--honey);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.network-card h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.24rem, 2.4vw, 1.72rem);
  line-height: 1.05;
}

.network-card p {
  margin: 0;
  color: var(--muted);
}

.network-card .button {
  align-self: end;
  width: fit-content;
  margin-top: 0.1rem;
}

.network-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-left: 6px solid var(--amber);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(255, 250, 241, 0.96), rgba(238, 246, 229, 0.9));
}

.network-panel h3 {
  margin: 0.18rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.25rem, 3vw, 1.95rem);
  line-height: 1.06;
}

.network-panel p:not(.kicker) {
  margin: 0.42rem 0 0;
  color: #3d493f;
}

.request-center {
  position: relative;
  overflow: hidden;
  margin-top: clamp(1.2rem, 4vw, 2.8rem);
}

.request-center::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(135deg, rgba(31, 106, 79, 0.12), rgba(240, 180, 59, 0.08) 50%, rgba(43, 93, 143, 0.08)),
    #f5efe3;
}

.request-center-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
}

.request-option-card {
  min-height: 100%;
  display: grid;
  align-content: start;
  gap: 0.72rem;
  padding: 1rem;
  border: 1px solid rgba(23, 33, 28, 0.14);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.94);
  box-shadow: 0 16px 34px rgba(37, 29, 16, 0.1);
}

.request-option-card span,
.honey-delivery-steps span {
  color: var(--honey);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.request-option-card h3,
.honey-delivery-section h2,
.honey-delivery-steps h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.05;
  letter-spacing: 0;
}

.request-option-card h3 {
  font-size: clamp(1.22rem, 2.4vw, 1.68rem);
}

.request-option-card p,
.honey-delivery-section p {
  margin: 0;
  color: #3d493f;
}

.request-option-card .button {
  justify-self: start;
  align-self: end;
}

.bee-opportunity-section,
.local-honey-benefits {
  display: grid;
  gap: 1.1rem;
}

.bee-opportunity-grid,
.honey-benefit-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.86rem;
}

.bee-opportunity-grid article,
.honey-benefit-grid article {
  display: grid;
  gap: 0.56rem;
  align-content: start;
  min-height: 100%;
  padding: clamp(1rem, 2vw, 1.2rem);
  border: 1px solid rgba(23, 33, 28, 0.14);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.92);
  box-shadow: 0 14px 30px rgba(37, 29, 16, 0.1);
}

.bee-opportunity-grid span,
.honey-benefit-grid span {
  color: var(--honey);
  font-size: 0.74rem;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.bee-opportunity-grid h3,
.honey-benefit-grid h3 {
  margin: 0;
  color: var(--green-dark);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.22rem, 2.2vw, 1.55rem);
  line-height: 1.05;
}

.bee-opportunity-grid p,
.honey-benefit-grid p {
  margin: 0;
  color: var(--muted);
  font-weight: 680;
}

.local-honey-benefits > .button {
  justify-self: start;
}

.honey-option-card {
  border-color: rgba(200, 133, 26, 0.3);
  background:
    linear-gradient(145deg, rgba(255, 250, 241, 0.96), rgba(255, 239, 199, 0.78)),
    #fffaf1;
}

.request-security-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: 1rem;
}

.request-security-strip div {
  padding: 0.85rem;
  border: 1px solid rgba(15, 61, 49, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.54);
}

.request-security-strip strong {
  color: var(--green-dark);
}

.request-security-strip p {
  margin: 0.32rem 0 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.honey-delivery-section {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(330px, 1.1fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
  border-color: rgba(200, 133, 26, 0.22);
  background:
    linear-gradient(135deg, rgba(255, 250, 241, 0.94), rgba(240, 180, 59, 0.14)),
    #fffaf1;
}

.honey-delivery-copy {
  display: grid;
  align-content: center;
  gap: 0.85rem;
}

.honey-delivery-section h2 {
  max-width: 13ch;
  font-size: clamp(2rem, 5vw, 3.6rem);
}

.honey-delivery-copy .button {
  justify-self: start;
}

.honey-delivery-steps {
  display: grid;
  gap: 0.75rem;
}

.honey-delivery-steps article {
  padding: 0.95rem;
  border: 1px solid rgba(15, 61, 49, 0.16);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.82);
}

.honey-delivery-steps h3 {
  margin-top: 0.18rem;
  font-size: 1.35rem;
}

.feed-breakout {
  width: min(760px, calc(100% - 20px));
  min-height: auto;
  margin: 0 auto;
  padding: 12px 0 8px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-items: start;
  justify-items: center;
  color: var(--ink);
  background: transparent;
  border-bottom: 0;
}

.feed-copy {
  width: 100%;
  max-width: none;
  margin: 0 auto;
  padding: 0 2px;
  text-align: left;
}

.feed-copy .kicker {
  color: var(--green);
  margin-bottom: 0.24rem;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
}

.video-library-heading .kicker {
  margin-bottom: 0.18rem;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
}

.feed-copy h1 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.45rem, 3vw, 2.05rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.feed-copy p:not(.kicker) {
  max-width: 680px;
  margin: 0.32rem 0 0;
  color: #3d493f;
  font-size: clamp(0.92rem, 1.3vw, 1rem);
}

.feed-actions {
  display: none;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.2rem;
}

.light-button {
  border-color: rgba(15, 61, 49, 0.22);
  background: rgba(255, 255, 255, 0.52);
  color: var(--green-dark);
}

.swarm-breakout-selector {
  width: 100%;
  display: grid;
  gap: 0.58rem;
  padding: 0.82rem;
  border: 1px solid rgba(200, 133, 26, 0.34);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(255, 250, 241, 0.98), rgba(255, 239, 186, 0.74));
  box-shadow: 0 14px 30px rgba(37, 29, 16, 0.12);
}

.swarm-breakout-selector h2 {
  margin: 0;
  color: var(--green-dark);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.32rem, 4vw, 2.1rem);
  line-height: 1.02;
}

.swarm-breakout-selector p:not(.kicker) {
  max-width: 620px;
  margin: 0.24rem 0 0;
  color: #3d493f;
  font-size: 0.92rem;
  font-weight: 720;
}

.swarm-selector-link {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.7rem;
  align-items: center;
  min-height: 3.65rem;
  padding: 0.62rem 0.7rem;
  border: 1px solid rgba(15, 61, 49, 0.18);
  border-radius: 8px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(37, 29, 16, 0.07);
}

.swarm-selector-link span {
  display: grid;
  width: 2.25rem;
  height: 2.25rem;
  place-items: center;
  border-radius: 999px;
  color: #fffaf1;
  background: var(--green-dark);
  font-weight: 950;
}

.swarm-selector-link strong {
  display: block;
  min-width: 0;
  color: var(--green-dark);
  font-size: clamp(0.98rem, 2.4vw, 1.2rem);
  line-height: 1.08;
}

.swarm-selector-link em {
  color: var(--honey);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
  white-space: nowrap;
}

.swarm-selector-link:hover,
.swarm-selector-link:focus-visible {
  border-color: var(--green-dark);
  background: #fffaf1;
  outline: none;
  box-shadow: 0 0 0 4px rgba(247, 211, 111, 0.26), 0 12px 24px rgba(37, 29, 16, 0.12);
}

.social-video-card {
  width: 100%;
  justify-self: center;
  border: 1px solid rgba(23, 33, 28, 0.16);
  background: #070907;
  border-radius: 8px;
  box-shadow: 0 10px 26px rgba(25, 35, 28, 0.16);
  overflow: hidden;
}

.feed-breakout > .social-video-card {
  order: 0;
}

.beekeeper-tips-card {
  width: 100%;
  display: grid;
  gap: 0.7rem;
  padding: 0.82rem;
  border: 1px solid rgba(15, 61, 49, 0.22);
  border-radius: 8px;
  background: linear-gradient(135deg, #fffaf1 0%, #f1e7d2 100%);
  box-shadow: 0 10px 24px rgba(25, 35, 28, 0.12);
}

.tips-card-head span {
  display: block;
  color: var(--green);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.tips-card-head strong {
  display: block;
  margin-top: 0.16rem;
  color: var(--ink);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.18rem, 3vw, 1.72rem);
  line-height: 1.02;
}

.tips-card-head p,
.tips-card-foot p {
  margin: 0.24rem 0 0;
  color: #3d493f;
  font-size: 0.92rem;
}

.tips-list {
  display: grid;
  gap: 0.42rem;
  margin: 0;
}

.tips-list div {
  display: grid;
  grid-template-columns: minmax(108px, 0.42fr) minmax(0, 1fr);
  gap: 0.6rem;
  padding: 0.52rem 0;
  border-top: 1px solid rgba(15, 61, 49, 0.14);
}

.tips-list dt {
  color: var(--green-dark);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tips-list dd {
  margin: 0;
  color: var(--ink);
  font-size: 0.9rem;
  line-height: 1.35;
}

.tips-card-foot {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.7rem;
  align-items: center;
  padding-top: 0.16rem;
}

.tips-card-foot p {
  margin: 0;
}

.tips-card-foot a {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.54rem 0.72rem;
  border: 1px solid rgba(15, 61, 49, 0.2);
  border-radius: 4px;
  background: var(--green-dark);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}

.social-card-head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.58rem 0.72rem;
  background: #111914;
}

.social-avatar {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(240, 180, 59, 0.55);
  background: var(--green-dark);
  color: var(--amber);
  font-weight: 900;
}

.social-card-head strong,
.social-card-head span {
  display: block;
}

.social-card-head span {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.78rem;
  font-weight: 800;
}

.social-video-frame {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: #000;
}

.social-video-frame iframe,
.social-video-frame .video-poster-link {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

.video-poster-link {
  position: relative;
  overflow: hidden;
  color: inherit;
  background: #050805;
  text-decoration: none;
}

.video-poster-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.06) contrast(1.03);
  transition: transform 260ms ease, filter 260ms ease;
}

.video-poster-link::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(7, 9, 7, 0.08), rgba(7, 9, 7, 0.26));
}

.video-play-symbol {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  width: clamp(56px, 9vw, 78px);
  height: clamp(56px, 9vw, 78px);
  border: 2px solid rgba(255, 250, 241, 0.88);
  border-radius: 999px;
  background: rgba(255, 250, 241, 0.9);
  box-shadow: 0 12px 34px rgba(7, 9, 7, 0.34);
  transform: translate(-50%, -50%);
  transition: transform 220ms ease, background 220ms ease;
}

.video-play-symbol::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0;
  height: 0;
  border-top: 13px solid transparent;
  border-bottom: 13px solid transparent;
  border-left: 19px solid var(--green-dark);
  transform: translate(-35%, -50%);
}

.video-poster-link:hover img,
.video-poster-link:focus-visible img {
  filter: saturate(1.12) contrast(1.08);
  transform: scale(1.035);
}

.video-poster-link:hover .video-play-symbol,
.video-poster-link:focus-visible .video-play-symbol {
  background: #f7d36f;
  transform: translate(-50%, -50%) scale(1.06);
}

.video-poster-link:focus-visible {
  outline: 3px solid #f7d36f;
  outline-offset: 3px;
}

.social-card-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.58rem;
  align-items: center;
  padding: 0.68rem 0.76rem;
  background: #111914;
}

.social-card-body strong {
  display: block;
  font-size: 0.98rem;
}

.social-card-body p {
  margin: 0.15rem 0 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.9rem;
}

.social-link-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
  margin-top: 0;
}

.social-link-row a {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.24);
  color: #fff;
  text-decoration: none;
  font-size: 0.78rem;
  font-weight: 900;
}

.feed-principles {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
}

.feed-principles span {
  min-height: 32px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(31, 106, 79, 0.18);
  background: rgba(255, 255, 255, 0.64);
  color: var(--green-dark);
  font-size: 0.72rem;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
}

.feed-heater-card {
  width: 100%;
  border: 1px solid rgba(15, 61, 49, 0.22);
  border-radius: 8px;
  background: #fffaf1;
  box-shadow: 0 8px 22px rgba(25, 35, 28, 0.1);
  overflow: hidden;
}

.feed-heater-card a {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.12rem 0.8rem;
  align-items: center;
  padding: 0.72rem 0.78rem;
  color: var(--ink);
  text-decoration: none;
}

.feed-heater-card span,
.feed-heater-card em {
  font-size: 0.7rem;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.feed-heater-card span {
  color: var(--green);
}

.feed-heater-card strong {
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.02rem, 2.2vw, 1.22rem);
  line-height: 1.08;
}

.feed-heater-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.feed-heater-card em {
  grid-row: 1 / span 3;
  grid-column: 2;
  padding: 0.52rem 0.64rem;
  border: 1px solid rgba(15, 61, 49, 0.2);
  border-radius: 4px;
  background: var(--green-dark);
  color: #fff;
  white-space: nowrap;
}

.feed-ad-card:not(.feed-heater-card) {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.18rem 0.8rem;
  align-items: center;
  padding: 0.72rem 0.78rem;
  border: 1px solid rgba(15, 61, 49, 0.22);
  border-radius: 8px;
  background: #fffaf1;
  box-shadow: 0 8px 22px rgba(25, 35, 28, 0.1);
}

.feed-ad-card:not(.feed-heater-card) span {
  display: block;
  color: var(--green);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.feed-ad-card:not(.feed-heater-card) strong {
  display: block;
  margin-top: 0.08rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.02rem, 2.2vw, 1.22rem);
  line-height: 1.08;
}

.feed-ad-card:not(.feed-heater-card) p {
  margin: 0.16rem 0 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.feed-ad-card code {
  color: var(--green-dark);
  font-family: inherit;
  font-weight: 900;
  overflow-wrap: anywhere;
  user-select: all;
}

.feed-ad-card:not(.feed-heater-card) > a,
.feed-ad-card:not(.feed-heater-card) > button {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0.64rem;
  border: 1px solid rgba(15, 61, 49, 0.2);
  border-radius: 4px;
  background: var(--green-dark);
  color: #fff;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
}

.video-library {
  width: min(760px, calc(100% - 20px));
  margin: 0 auto;
  padding: 8px 0 28px;
}

.video-library-heading {
  margin: 0 0 6px;
  text-align: left;
}

.video-library-heading h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.22rem, 2.6vw, 1.55rem);
  line-height: 1.1;
}

.video-library-heading p:not(.kicker) {
  display: none;
}

.video-library-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 0;
}

.video-library .social-video-card {
  width: 100%;
}

.library-video-card {
  border: 1px solid rgba(23, 33, 28, 0.14);
  background: rgba(255, 250, 241, 0.82);
  box-shadow: 0 18px 46px rgba(37, 29, 16, 0.12);
  overflow: hidden;
}

.library-video-frame {
  aspect-ratio: 16 / 9;
  background: #050805;
}

.library-video-frame iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

.library-video-copy {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
}

.library-video-copy strong {
  font-size: 1rem;
}

.library-video-copy a {
  color: var(--green-dark);
  font-size: 0.86rem;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}

.hero {
  width: min(1220px, calc(100% - 32px));
  min-height: calc(100svh - 74px);
  margin: 0 auto;
  padding: clamp(1rem, 2.6vw, 2.5rem) 0 clamp(1.25rem, 2.6vw, 2.5rem);
  display: grid;
  grid-template-columns: minmax(330px, 0.76fr) minmax(520px, 1.24fr);
  gap: clamp(1rem, 2.6vw, 2.25rem);
  align-items: center;
}

.kicker {
  margin: 0 0 0.85rem;
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}

.hero h1,
.section h2,
.natural-band h2,
.contact-panel h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.02;
  letter-spacing: 0;
}

.hero h1 {
  max-width: 720px;
  font-size: clamp(2.25rem, 4.4vw, 4.7rem);
}

.lead {
  max-width: 650px;
  margin: 1rem 0 0;
  color: #344239;
  font-size: clamp(1rem, 1.45vw, 1.17rem);
}

.hero-invite {
  max-width: 660px;
  margin: 1rem 0 0;
  padding: 0.8rem 0.95rem;
  border-left: 4px solid var(--amber);
  background: rgba(255, 250, 241, 0.78);
  color: var(--green-dark);
  font-weight: 850;
}

.hero-actions,
.hero-facts {
  margin-top: 1.2rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0.75rem 1rem;
  border: 1px solid var(--green-dark);
  border-radius: 4px;
  text-decoration: none;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.button-primary {
  background: var(--green-dark);
  color: #fff;
}

.button-secondary {
  background: rgba(255, 250, 241, 0.8);
  color: var(--green-dark);
}

.weather-hero-button {
  border-color: #8d4510;
  background: linear-gradient(135deg, #8d4510, #a84432 52%, #0f3d31);
  color: #fff;
  box-shadow: 0 12px 30px rgba(168, 68, 50, 0.22);
}

.hero-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.hero-facts div {
  border: 1px solid var(--line);
  background: rgba(255, 250, 241, 0.72);
  padding: 0.7rem;
}

.hero-facts dt {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 900;
  text-transform: uppercase;
}

.hero-facts dd {
  margin: 0.25rem 0 0;
  font-weight: 900;
}

.hero-visual {
  position: relative;
  min-height: min(640px, calc(100svh - 128px));
  border: 1px solid rgba(23, 33, 28, 0.14);
  background: linear-gradient(145deg, rgba(255, 250, 241, 0.95), rgba(237, 229, 216, 0.96));
  box-shadow: var(--shadow);
  overflow: hidden;
}

.product-hero-panel {
  min-height: min(650px, calc(100svh - 118px));
  background: #21170f;
}

.hero-media-stack {
  display: grid;
  gap: 1rem;
  align-self: center;
}

.hero-media-stack .hero-visual,
.hero-media-stack .product-hero-panel {
  min-height: clamp(360px, 48svh, 560px);
}

.front-video-card {
  order: -1;
  border: 1px solid rgba(23, 33, 28, 0.14);
  background: rgba(255, 250, 241, 0.88);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.front-video-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.25rem 1rem;
  align-items: end;
  padding: 0.9rem 1rem;
  background: var(--green-dark);
  color: #fff;
}

.front-video-head .kicker {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--amber);
}

.front-video-head strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.25rem, 2vw, 1.8rem);
  line-height: 1.05;
}

.front-video-head span {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.84rem;
  font-weight: 800;
  text-align: right;
}

.front-video-frame {
  aspect-ratio: 16 / 9;
  background: #080b08;
}

.front-video-frame iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

.video-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  padding: 0.85rem 1rem 1rem;
  background: rgba(15, 61, 49, 0.96);
}

.video-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0.55rem 0.8rem;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 4px;
  color: #fff;
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 900;
}

.video-links a:hover {
  border-color: var(--amber);
  color: var(--amber);
}

.product-hero-panel .device-stage {
  display: none;
}

.hero-product-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.product-hero-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(11, 16, 13, 0.66), rgba(11, 16, 13, 0.08) 54%, rgba(11, 16, 13, 0.42)),
    linear-gradient(0deg, rgba(11, 16, 13, 0.72), transparent 44%);
  pointer-events: none;
}

.hero-product-summary,
.hero-qr-card,
.hero-battery-visual,
.hero-battery-cord,
.hero-power-chip,
.hero-sensor-chip,
.product-hero-panel .bench-label {
  z-index: 2;
}

.hero-product-summary {
  position: absolute;
  left: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  width: min(430px, calc(100% - 2rem));
  color: #fff;
}

.hero-product-summary strong,
.hero-product-summary span {
  display: block;
}

.hero-product-summary strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.55rem, 3.2vw, 2.8rem);
  line-height: 1.02;
}

.hero-product-summary span {
  margin-top: 0.55rem;
  color: rgba(255, 255, 255, 0.82);
  font-weight: 700;
}

.hero-qr-card {
  position: absolute;
  right: clamp(0.9rem, 2vw, 1.4rem);
  top: clamp(0.9rem, 2vw, 1.4rem);
  width: 82px;
  padding: 0.45rem;
  border: 2px solid #151515;
  background: #fff;
  color: #111;
  text-align: center;
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.32);
}

.hero-qr-card .qr-grid {
  width: 58px;
  height: 58px;
}

.hero-battery-visual {
  position: absolute;
  right: clamp(0.9rem, 2vw, 1.4rem);
  bottom: clamp(1rem, 3vw, 2rem);
  width: 138px;
  height: 106px;
  border: 3px solid #101411;
  background: linear-gradient(180deg, #303a34, #111614);
  color: #fff;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
}

.hero-battery-visual::after {
  content: "";
  position: absolute;
  right: -13px;
  bottom: 32px;
  width: 13px;
  height: 22px;
  background: #101411;
  border: 2px solid #66746b;
  border-left: 0;
}

.hero-battery-visual span {
  position: absolute;
  left: 14px;
  top: 14px;
  width: 64px;
  height: 34px;
  display: grid;
  place-items: center;
  color: #d9ffd9;
  background: #0c2015;
  border: 1px solid #75c884;
  font-family: "Courier New", monospace;
  font-weight: 900;
}

.hero-battery-visual strong {
  position: absolute;
  left: 14px;
  right: 12px;
  bottom: 16px;
  font-size: 0.72rem;
  line-height: 1.15;
  text-transform: uppercase;
}

.hero-battery-cord {
  position: absolute;
  right: calc(clamp(0.9rem, 2vw, 1.4rem) + 138px);
  bottom: calc(clamp(1rem, 3vw, 2rem) + 42px);
  width: min(190px, 28%);
  height: 42px;
  border-bottom: 7px solid #101411;
  border-left: 7px solid #101411;
  border-radius: 0 0 0 36px;
}

.hero-power-chip,
.hero-sensor-chip {
  position: absolute;
  right: clamp(0.9rem, 2vw, 1.4rem);
  padding: 0.55rem 0.7rem;
  max-width: 230px;
  color: #fff;
  background: rgba(15, 61, 49, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.22);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.hero-power-chip {
  bottom: clamp(8.2rem, 12vw, 9.7rem);
}

.hero-sensor-chip {
  bottom: clamp(10.8rem, 15vw, 12rem);
  background: rgba(43, 93, 143, 0.92);
}

.bench-label {
  position: absolute;
  left: 1.2rem;
  top: 1rem;
  z-index: 2;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.device-stage {
  position: absolute;
  inset: 0;
}

.hive-unit {
  position: absolute;
  right: 11%;
  bottom: 16%;
  width: 52%;
  min-width: 280px;
  height: 390px;
}

.hive-lid {
  position: absolute;
  left: 2%;
  top: 8%;
  width: 96%;
  height: 50px;
  background: linear-gradient(180deg, #f0c960, #c8851a);
  border: 3px solid #6b4216;
  box-shadow: 0 12px 0 rgba(107, 66, 22, 0.16);
}

.hive-lid::before {
  content: "";
  position: absolute;
  inset: 8px 18px;
  border-top: 2px solid rgba(255, 255, 255, 0.5);
}

.hive-body {
  position: absolute;
  left: 7%;
  top: 24%;
  width: 86%;
  height: 190px;
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 5px;
  padding: 18px 16px;
  border: 3px solid #6d4820;
  background: linear-gradient(180deg, #d89f45, #b7772d);
}

.hive-body span {
  border: 1px solid rgba(91, 57, 19, 0.5);
  background: linear-gradient(180deg, #f0d48a, #d49a3e);
}

.heated-base {
  position: absolute;
  left: 2%;
  top: 73%;
  width: 96%;
  height: 76px;
  border: 3px solid #242927;
  background: linear-gradient(180deg, #343d38, #181d1b);
}

.heat-band {
  position: absolute;
  left: 8%;
  right: 8%;
  top: 23px;
  height: 12px;
  background: repeating-linear-gradient(90deg, #ffcf69 0 16px, #d45b30 16px 30px);
  box-shadow: 0 0 28px rgba(220, 98, 42, 0.45);
}

.qr-placard {
  position: absolute;
  right: 13%;
  top: 31%;
  z-index: 3;
  width: 68px;
  padding: 7px;
  border: 2px solid #161916;
  background: #fff;
  text-align: center;
  font-size: 0.62rem;
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
}

.qr-grid {
  display: block;
  width: 50px;
  height: 50px;
  margin: 0 auto 4px;
  background:
    linear-gradient(#111 0 0) 5px 5px / 14px 14px no-repeat,
    linear-gradient(#111 0 0) 31px 5px / 14px 14px no-repeat,
    linear-gradient(#111 0 0) 5px 31px / 14px 14px no-repeat,
    linear-gradient(90deg, transparent 0 5px, #111 5px 10px, transparent 10px 15px, #111 15px 20px, transparent 20px 25px, #111 25px 30px, transparent 30px 35px, #111 35px 40px, transparent 40px 50px),
    linear-gradient(0deg, transparent 0 6px, rgba(17, 17, 17, 0.85) 6px 10px, transparent 10px 18px, rgba(17, 17, 17, 0.85) 18px 22px, transparent 22px 32px, rgba(17, 17, 17, 0.85) 32px 36px, transparent 36px 50px);
  border: 3px solid #111;
}

.sensor-port {
  position: absolute;
  left: -20px;
  top: 36%;
  z-index: 4;
}

.sensor-wire {
  position: absolute;
  left: -118px;
  top: 19px;
  width: 140px;
  height: 3px;
  background: var(--blue);
  transform: rotate(8deg);
  transform-origin: right;
}

.sensor-probe {
  position: absolute;
  left: 6px;
  top: 10px;
  width: 76px;
  height: 16px;
  border-radius: 99px;
  border: 2px solid #15385b;
  background: linear-gradient(90deg, #d8ebff, #6ca2d6);
}

.sensor-label {
  position: absolute;
  left: -116px;
  top: 38px;
  width: 122px;
  color: #15385b;
  font-size: 0.76rem;
  font-weight: 900;
}

.battery-pack {
  position: absolute;
  left: 8%;
  bottom: 18%;
  width: 148px;
  height: 185px;
  border: 3px solid #202622;
  background: linear-gradient(180deg, #303a34, #111614);
  box-shadow: 0 18px 34px rgba(17, 22, 20, 0.28);
}

.battery-screen {
  position: absolute;
  left: 18px;
  top: 18px;
  width: 82px;
  height: 42px;
  display: grid;
  place-items: center;
  color: #ddffdf;
  background: #0e2417;
  border: 1px solid #6fcf86;
  font-family: "Courier New", monospace;
  font-weight: 900;
}

.battery-brand {
  position: absolute;
  left: 18px;
  top: 75px;
  color: #fff;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.battery-port {
  position: absolute;
  right: 12px;
  bottom: 34px;
  width: 22px;
  height: 18px;
  background: #0a0d0c;
  border: 2px solid #6f7f75;
}

.power-cord {
  position: absolute;
  left: calc(8% + 124px);
  bottom: calc(18% + 44px);
  width: 34%;
  height: 74px;
  border-bottom: 8px solid #0f1412;
  border-right: 8px solid #0f1412;
  border-radius: 0 0 48px 0;
}

.controller-box {
  position: absolute;
  left: 28%;
  bottom: 22%;
  width: 170px;
  height: 108px;
  border: 3px solid #1b211d;
  background: linear-gradient(180deg, #f5f0e7, #d9d0c1);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.16);
}

.controller-display {
  position: absolute;
  left: 14px;
  top: 14px;
  right: 14px;
  padding: 0.5rem 0.45rem;
  color: #b8f6b4;
  background: #142218;
  font-family: "Courier New", monospace;
  font-size: 0.9rem;
  font-weight: 900;
  text-align: center;
}

.controller-row {
  position: absolute;
  left: 18px;
  bottom: 24px;
  width: 86px;
  height: 8px;
  background: #879084;
}

.controller-row.short {
  bottom: 12px;
  width: 58px;
}

.device-notes {
  position: absolute;
  right: 6%;
  bottom: 4%;
  left: 6%;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.55rem;
}

.device-notes span {
  border: 1px solid rgba(23, 33, 28, 0.16);
  background: rgba(255, 250, 241, 0.76);
  padding: 0.65rem;
  color: var(--green-dark);
  font-size: 0.72rem;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
}

.video-section {
  padding-top: clamp(3rem, 6vw, 5rem);
}

.heater-video-layout {
  display: grid;
  grid-template-columns: minmax(270px, 0.36fr) minmax(0, 1fr);
  gap: clamp(1rem, 2vw, 1.5rem);
  align-items: stretch;
  margin-top: 2rem;
}

.heater-info,
.video-feature,
.short-feature {
  border: 1px solid var(--line);
  background: rgba(255, 250, 241, 0.82);
  box-shadow: var(--shadow);
}

.heater-info {
  display: grid;
  grid-template-rows: auto auto 1fr;
}

.heater-thumb {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #20160e;
}

.heater-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.heater-copy {
  padding: 1.15rem 1.15rem 0;
}

.heater-copy h3,
.short-feature h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.08;
  font-size: clamp(1.45rem, 2.4vw, 2.15rem);
}

.heater-copy p:not(.kicker),
.short-feature p:not(.kicker),
.video-caption span {
  color: var(--muted);
}

.heater-facts {
  margin: 1rem 0 0;
  padding: 0 1.15rem 1.15rem;
  list-style: none;
  display: grid;
  gap: 0.55rem;
}

.heater-facts li {
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(31, 106, 79, 0.2);
  background: rgba(31, 106, 79, 0.07);
  color: var(--green-dark);
  font-size: 0.86rem;
  font-weight: 850;
}

.video-feature {
  overflow: hidden;
  background: #121712;
}

.video-frame {
  aspect-ratio: 16 / 9;
  background: #080b08;
}

.video-frame iframe,
.short-frame iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

.video-caption {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.95rem 1rem;
  color: #fff;
  background: var(--green-dark);
}

.video-caption strong {
  white-space: nowrap;
}

.short-feature {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.34fr);
  gap: clamp(1rem, 2vw, 1.5rem);
  align-items: center;
  margin-top: 1.2rem;
  padding: clamp(1rem, 3vw, 1.5rem);
}

.short-frame {
  aspect-ratio: 9 / 16;
  min-height: 420px;
  overflow: hidden;
  background: #080b08;
}

.natural-band,
.section {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
}

.natural-band {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 2rem;
  align-items: center;
  padding: clamp(1.4rem, 4vw, 2.6rem);
  border: 1px solid var(--line);
  background: var(--green-dark);
  color: #fff;
}

.natural-band .kicker {
  color: #f2c45e;
}

.natural-band h2 {
  font-size: clamp(1.8rem, 4vw, 3.4rem);
}

.natural-band p {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 1.04rem;
}

.section {
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.section-heading {
  max-width: 840px;
}

.section-heading.compact {
  max-width: none;
}

.section h2 {
  font-size: clamp(2rem, 4vw, 4rem);
}

.section-heading p:not(.kicker),
.product-copy p {
  color: var(--muted);
  font-size: 1.04rem;
}

.evidence-grid,
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}

.evidence-card,
.contact-grid article,
.citation-panel,
.control-panel,
.product-copy,
.contact-panel {
  border: 1px solid var(--line);
  background: rgba(255, 250, 241, 0.78);
}

.evidence-card {
  min-height: 250px;
  padding: 1.25rem;
}

.card-number {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  margin-bottom: 2rem;
  color: #fff;
  background: var(--green-dark);
  font-weight: 900;
}

.evidence-card h3,
.contact-grid h3,
.product-copy h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.08;
}

.evidence-card p,
.contact-grid p {
  color: var(--muted);
}

.citation-panel {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.8rem;
  margin-top: 1rem;
  padding: 1rem;
}

.citation-panel h3 {
  margin: 0 0.6rem 0 0;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.citation-panel a {
  color: var(--green-dark);
  font-weight: 800;
}

.split-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.75fr);
  gap: 2rem;
  align-items: start;
}

.control-panel {
  padding: 1rem;
  box-shadow: var(--shadow);
}

.control-panel label {
  display: grid;
  gap: 0.45rem;
  margin: 1rem 0;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 900;
  text-transform: uppercase;
}

.control-panel input {
  width: 100%;
  accent-color: var(--green);
}

.control-screen {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  color: #d9ffe0;
  background: #0f1d16;
  font-family: "Courier New", monospace;
}

.control-screen span {
  color: #87aa92;
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
}

.control-screen strong {
  font-size: 1.4rem;
}

.muted-screen {
  margin-top: 1rem;
  color: #fff2c6;
  background: #28322c;
}

.control-checks {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}

.control-checks li {
  padding: 0.65rem;
  border: 1px solid rgba(31, 106, 79, 0.2);
  background: rgba(31, 106, 79, 0.06);
  color: var(--green-dark);
  font-size: 0.82rem;
  font-weight: 800;
}

.product-section {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: center;
}

.product-image {
  border: 1px solid var(--line);
  background: var(--paper-2);
  box-shadow: var(--shadow);
}

.product-copy {
  padding: clamp(1.2rem, 4vw, 2.4rem);
}

.product-copy h2 {
  font-size: clamp(1.8rem, 4vw, 3.4rem);
}

.contact-grid article {
  padding: 1.1rem;
}

.hive-products-section {
  padding-top: 2.4rem;
}

.hive-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 1.2rem;
}

.hive-product-grid article {
  min-height: 100%;
  padding: 1rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.78);
}

.hive-product-grid span,
.product-popout-grid span,
.product-popout-feature span {
  display: block;
  color: var(--green);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.hive-product-grid h3,
.product-popout-grid h3 {
  margin: 0.22rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.18rem;
  line-height: 1.08;
}

.hive-product-grid p,
.product-popout-grid p {
  margin: 0.5rem 0 0;
  color: #3d493f;
  font-size: 0.9rem;
}

.hive-products-panel {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 8px;
  background: rgba(31, 106, 79, 0.06);
}

.hive-products-panel h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.35rem;
  line-height: 1.05;
}

.hive-products-panel p {
  margin: 0.32rem 0 0;
  color: #3d493f;
}

.contact-panel {
  margin-top: 1.2rem;
  padding: 1.4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.contact-panel h2 {
  font-size: clamp(1.7rem, 4vw, 3rem);
}

.site-footer {
  padding: 2rem 1rem;
  border-top: 1px solid var(--line);
  color: var(--muted);
  text-align: center;
}

.site-footer p {
  margin: 0.25rem 0;
}

.powered-by {
  color: var(--leaf);
  font-weight: 900;
  white-space: nowrap;
}

.ten32-bench-ad {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto 3rem;
  padding: clamp(1rem, 2.6vw, 1.45rem);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) minmax(190px, 0.34fr) auto;
  gap: 1rem;
  align-items: center;
  border: 3px solid var(--green-dark);
  border-radius: 4px;
  background: linear-gradient(90deg, var(--amber), #fff0b8 54%, var(--paper-2));
  box-shadow: var(--shadow);
}

.ten32-bench-ad .bench-label {
  margin: 0;
  padding: 0.32rem 0.5rem;
  border-radius: 4px;
  color: #fff;
  background: var(--green-dark);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.ten32-bench-ad strong {
  display: block;
  color: var(--green-dark);
  font-size: clamp(1.18rem, 2.3vw, 1.9rem);
  line-height: 1.06;
}

.ten32-bench-ad p:last-child {
  margin: 0.35rem 0 0;
  color: #3d493f;
  font-weight: 800;
}

.ten32-bench-ad .bench-video {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 0.62rem;
  align-items: center;
  min-height: 5rem;
  padding: 0.45rem;
  border: 2px solid rgba(15, 61, 49, 0.22);
  border-radius: 4px;
  color: var(--green-dark);
  background: rgba(255, 250, 241, 0.72);
  text-decoration: none;
}

.ten32-bench-ad .bench-video img {
  width: 92px;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 4px;
}

.ten32-bench-ad .bench-video b,
.ten32-bench-ad .bench-video small {
  display: block;
}

.ten32-bench-ad .bench-video b {
  font-size: 0.72rem;
  text-transform: uppercase;
}

.ten32-bench-ad .bench-video small {
  color: #3d493f;
  font-weight: 900;
}

.ten32-bench-ad .bench-video:hover,
.ten32-bench-ad .bench-video:focus-visible {
  border-color: var(--green-dark);
  background: var(--paper-2);
  outline: none;
}

.zinn-note {
  display: grid;
  gap: 0.55rem;
  padding: clamp(1.1rem, 3vw, 1.7rem);
  border: 1px solid rgba(57, 92, 67, 0.22);
  border-left: 8px solid var(--green);
  border-radius: 8px;
  background: linear-gradient(90deg, rgba(255, 250, 241, 0.96), rgba(237, 246, 229, 0.92));
  box-shadow: var(--shadow);
}

.zinn-note h2,
.zinn-note p {
  margin: 0;
}

.zinn-note h2 {
  max-width: 860px;
}

.zinn-note p:last-child {
  max-width: 960px;
  color: #3e4f43;
  font-size: 1.08rem;
  font-weight: 760;
}

.honey-ad-pair {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
  gap: 1rem;
}

.honey-ad-card {
  display: grid;
  gap: 0.8rem;
  align-content: space-between;
  min-height: 100%;
  padding: clamp(1.1rem, 3vw, 1.7rem);
  border: 1px solid rgba(113, 76, 22, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(240, 201, 96, 0.28), transparent 46%),
    #fffaf1;
  box-shadow: var(--shadow);
}

.honey-ad-card h2,
.honey-ad-card p {
  margin: 0;
}

.honey-ad-card h2 {
  color: var(--green-dark);
}

.honey-ad-card p:not(.kicker) {
  color: #4c4a34;
  font-weight: 760;
}

.honey-ad-card-funny {
  border-color: rgba(212, 91, 48, 0.32);
  background:
    linear-gradient(135deg, rgba(212, 91, 48, 0.2), transparent 48%),
    #fff7de;
}

.honey-ad-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.video-lightbox {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: grid;
  align-items: center;
  justify-items: center;
  overflow: auto;
  padding: max(1rem, env(safe-area-inset-top)) 1rem max(1rem, env(safe-area-inset-bottom));
  background: rgba(15, 61, 49, 0.78);
  backdrop-filter: blur(10px);
  -webkit-overflow-scrolling: touch;
}

.video-lightbox[hidden] {
  display: none;
}

.video-lightbox-card {
  width: min(980px, 100%);
  max-height: min(92vh, 760px);
  overflow: auto;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 8px;
  background: var(--paper);
  box-shadow: 0 34px 90px rgba(0, 0, 0, 0.34);
}

.video-lightbox-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
  padding: 1rem;
  background: var(--paper);
}

.video-lightbox-head h2,
.video-lightbox-head .kicker {
  margin: 0;
}

.video-lightbox-close {
  min-height: 2.75rem;
  padding: 0.5rem 0.72rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--green-dark);
  background: var(--paper-2);
  font: inherit;
  font-weight: 950;
  cursor: pointer;
}

.video-lightbox-frame {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #07150f;
}

.video-lightbox-frame iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.video-lightbox-source {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.9rem;
  margin: 1rem;
  padding: 0.55rem 0.8rem;
  border: 1px solid rgba(15, 61, 49, 0.18);
  border-radius: 8px;
  color: var(--green-dark);
  font-weight: 950;
  background: rgba(238, 246, 229, 0.82);
}

.email-modal {
  width: min(540px, calc(100% - 28px));
  border: 0;
  padding: 0;
  overflow: visible;
  color: var(--ink);
  background: transparent;
}

.email-modal::backdrop {
  background:
    radial-gradient(circle at 32% 18%, rgba(240, 180, 59, 0.28), transparent 26%),
    rgba(9, 13, 10, 0.78);
  backdrop-filter: blur(7px);
}

.email-modal-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(240, 180, 59, 0.45);
  border-radius: 8px;
  padding: 1.35rem;
  background: linear-gradient(145deg, #fffaf1, #f2ead8);
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
  opacity: 0;
  transform: scale(0.94) translateY(14px);
}

.email-modal[open] .email-modal-card {
  animation: email-modal-rise 360ms ease forwards;
}

.email-modal-glow {
  position: absolute;
  right: -20%;
  bottom: -45%;
  width: 70%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(240, 180, 59, 0.3);
  filter: blur(34px);
}

.email-modal-mark {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, 24px);
  gap: 5px;
  margin-bottom: 0.9rem;
}

.email-modal-mark span {
  width: 24px;
  height: 27px;
  background: var(--amber);
  clip-path: polygon(25% 4%, 75% 4%, 100% 50%, 75% 96%, 25% 96%, 0 50%);
  animation: email-cell-pulse 1.7s ease-in-out infinite;
}

.email-modal-mark span:nth-child(2) {
  animation-delay: 160ms;
}

.email-modal-mark span:nth-child(3) {
  animation-delay: 320ms;
}

.email-modal h2,
.email-modal p,
.email-modal a,
.email-modal-actions {
  position: relative;
  z-index: 1;
}

.email-modal h2 {
  max-width: 12ch;
  margin: 0.18rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2rem, 9vw, 3.15rem);
  line-height: 0.98;
  letter-spacing: 0;
}

.email-modal p:not(.kicker) {
  margin: 0.85rem 0 0;
  color: #3d493f;
}

.email-modal-policy {
  padding: 0.76rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  background: rgba(31, 106, 79, 0.06);
  font-size: 0.86rem;
}

.email-modal-policy strong {
  color: var(--green-dark);
}

.email-modal-address {
  display: block;
  width: 100%;
  margin: 1.05rem 0 0;
  padding: 0.85rem;
  border: 1px solid rgba(15, 61, 49, 0.28);
  background: #fff;
  color: var(--green-dark);
  text-align: center;
  text-decoration: none;
  font-size: clamp(1rem, 4.2vw, 1.35rem);
  font-weight: 900;
  overflow-wrap: anywhere;
}

.email-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
  margin-top: 1rem;
}

.email-modal-actions .button {
  width: 100%;
  cursor: pointer;
}

.email-modal-status {
  min-height: 1.2rem;
  font-size: 0.85rem;
  font-weight: 800;
}

.club-modal,
.weather-modal,
.feeding-modal,
.product-modal,
.keeper-tools-modal,
.request-modal {
  width: min(780px, calc(100% - 28px));
  max-height: min(860px, calc(100dvh - 28px));
  border: 0;
  padding: 0;
  overflow: visible;
  color: var(--ink);
  background: transparent;
}

.club-modal::backdrop,
.weather-modal::backdrop,
.feeding-modal::backdrop,
.product-modal::backdrop,
.keeper-tools-modal::backdrop,
.request-modal::backdrop {
  background:
    linear-gradient(rgba(9, 13, 10, 0.74), rgba(9, 13, 10, 0.82)),
    rgba(9, 13, 10, 0.78);
  backdrop-filter: blur(7px);
}

.club-modal[open]::backdrop,
.weather-modal[open]::backdrop,
.request-modal[open]::backdrop {
  animation: overlayFogIn 360ms ease-out both;
}

.club-modal-card,
.weather-modal-card,
.feeding-modal-card,
.product-modal-card,
.keeper-tools-card,
.request-modal-card {
  max-height: min(860px, calc(100dvh - 28px));
  overflow: auto;
  border: 1px solid rgba(31, 106, 79, 0.22);
  border-radius: 8px;
  padding: 1.15rem;
  background: #fffaf1;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
}

.club-modal[open] .club-modal-card {
  transform-origin: 50% 6%;
  animation: beekeeperOverlayIn 560ms cubic-bezier(0.18, 0.9, 0.22, 1) both;
}

.weather-modal[open] .weather-modal-card {
  transform-origin: 50% 0;
  animation: weatherOverlayIn 640ms cubic-bezier(0.16, 0.96, 0.22, 1) both;
}

.request-modal[open] .request-modal-card {
  transform-origin: 50% 4%;
  animation: requestOverlayIn 520ms cubic-bezier(0.18, 0.9, 0.22, 1) both;
}

.club-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}

.club-modal-close {
  min-height: 34px;
  padding: 0.46rem 0.7rem;
  border: 1px solid rgba(15, 61, 49, 0.2);
  border-radius: 4px;
  background: #fff;
  color: var(--green-dark);
  font-weight: 900;
  cursor: pointer;
}

.club-modal h2,
.weather-modal h2,
.feeding-modal h2,
.product-modal h2,
.keeper-tools-modal h2,
.request-modal h2 {
  max-width: 14ch;
  margin: 0.35rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2rem, 6vw, 3rem);
  line-height: 1;
  letter-spacing: 0;
}

.club-modal p:not(.kicker),
.weather-modal p:not(.kicker),
.feeding-modal p:not(.kicker),
.product-modal p:not(.kicker),
.keeper-tools-modal p:not(.kicker),
.request-modal p:not(.kicker) {
  color: #3d493f;
}

.request-modal {
  width: min(920px, calc(100% - 28px));
}

.request-modal-card {
  background:
    linear-gradient(145deg, rgba(255, 250, 241, 0.98), rgba(242, 232, 211, 0.96)),
    #fffaf1;
}

.request-modal h2 {
  max-width: 15ch;
}

.request-form {
  display: grid;
  gap: 0.9rem;
  margin-top: 1rem;
}

.request-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.request-form label,
.request-wide-label {
  display: grid;
  gap: 0.34rem;
  color: var(--green-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.request-form input,
.request-form select,
.request-form textarea {
  width: 100%;
  border: 1px solid rgba(15, 61, 49, 0.22);
  border-radius: 6px;
  padding: 0.75rem 0.8rem;
  background: rgba(255, 255, 255, 0.84);
  color: var(--ink);
  font: inherit;
  font-size: 0.95rem;
  font-weight: 650;
  letter-spacing: 0;
  text-transform: none;
}

.request-form textarea {
  min-height: 132px;
  resize: vertical;
}

.request-checks {
  display: grid;
  gap: 0.6rem;
  margin: 0;
  padding: 0.85rem;
  border: 1px solid rgba(15, 61, 49, 0.16);
  border-radius: 8px;
  background: rgba(31, 106, 79, 0.06);
}

.request-checks legend {
  padding: 0 0.35rem;
  color: var(--green-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.request-checks label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.55rem;
  align-items: start;
  color: #3d493f;
  font-size: 0.92rem;
  font-weight: 750;
  letter-spacing: 0;
  text-transform: none;
}

.request-checks input {
  width: 18px;
  height: 18px;
  margin-top: 0.12rem;
  accent-color: var(--green-dark);
}

.request-form-actions,
.request-packet-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
}

.request-packet-panel {
  display: grid;
  gap: 0.75rem;
  margin-top: 1rem;
  padding: 0.9rem;
  border: 1px solid rgba(200, 133, 26, 0.26);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 246, 222, 0.92), rgba(238, 246, 229, 0.84)),
    #fffaf1;
}

.request-packet-panel[hidden] {
  display: none;
}

.request-packet-panel h3 {
  margin: 0.1rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 3vw, 2rem);
  line-height: 1.05;
}

.request-packet-panel textarea {
  width: 100%;
  min-height: 190px;
  border: 1px solid rgba(15, 61, 49, 0.2);
  border-radius: 6px;
  padding: 0.75rem;
  background: #111914;
  color: #f7f2e9;
  font: 0.78rem/1.45 Consolas, "Courier New", monospace;
  resize: vertical;
  white-space: pre;
}

.request-packet-instructions {
  margin: 0;
  padding: 0.85rem;
  border-radius: 8px;
  color: var(--green-dark);
  background: rgba(238, 246, 229, 0.92);
  font-weight: 800;
}

.weather-modal {
  width: min(980px, calc(100% - 28px));
}

.weather-modal-card {
  background:
    linear-gradient(180deg, rgba(255, 250, 241, 0.98), rgba(242, 232, 211, 0.96)),
    #fffaf1;
}

.weather-modal h2 {
  max-width: 16ch;
}

@keyframes overlayFogIn {
  from {
    opacity: 0;
    backdrop-filter: blur(0);
  }

  to {
    opacity: 1;
    backdrop-filter: blur(7px);
  }
}

@keyframes beekeeperOverlayIn {
  0% {
    opacity: 0;
    transform: translateY(-18px) scale(0.92) rotateX(4deg);
  }

  62% {
    opacity: 1;
    transform: translateY(4px) scale(1.015) rotateX(0);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
  }
}

@keyframes weatherOverlayIn {
  0% {
    opacity: 0;
    clip-path: inset(0 44% 100% 44% round 12px);
    transform: translateY(-12px) scale(0.98);
  }

  46% {
    opacity: 1;
    clip-path: inset(0 9% 16% 9% round 10px);
  }

  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0 round 0);
    transform: translateY(0) scale(1);
  }
}

@keyframes requestOverlayIn {
  0% {
    opacity: 0;
    clip-path: inset(0 50% 100% 50% round 14px);
    transform: translateY(-16px) scale(0.94);
  }

  44% {
    opacity: 1;
    clip-path: inset(0 18% 18% 18% round 12px);
    transform: translateY(2px) scale(1.012);
  }

  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0 round 8px);
    transform: translateY(0) scale(1);
  }
}

.weather-search {
  display: grid;
  gap: 0.45rem;
  margin-top: 1rem;
}

.weather-search label {
  color: var(--green-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.weather-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
}

.weather-search-row input {
  min-height: 46px;
  width: 100%;
  border: 1px solid rgba(15, 61, 49, 0.22);
  border-radius: 4px;
  padding: 0.68rem 0.75rem;
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-weight: 900;
}

.weather-status {
  min-height: 1.4rem;
  margin: 0.75rem 0 0;
  color: var(--muted);
  font-weight: 850;
}

.weather-global-welcome {
  margin: 0.85rem 0 1rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(31, 106, 79, 0.2);
  border-left: 5px solid var(--green);
  border-radius: 6px;
  background: rgba(31, 106, 79, 0.08);
  color: var(--green-dark);
  font-weight: 850;
}

.weather-status[data-tone="success"] {
  color: var(--green-dark);
}

.weather-status[data-tone="error"] {
  color: var(--danger);
}

.weather-results {
  display: grid;
  gap: 0.85rem;
  margin-top: 0.85rem;
}

.weather-summary-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(220px, 0.65fr);
  gap: 0.75rem;
}

.weather-state-card,
.weather-risk-card,
.weather-advice-card,
.weather-forecast-panel,
.weather-day-card {
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
}

.weather-state-card {
  display: grid;
  grid-template-columns: minmax(150px, 0.48fr) minmax(0, 1fr);
  gap: 0.85rem;
  align-items: center;
  padding: 0.82rem;
}

.weather-state-card span,
.weather-risk-card span,
.weather-advice-card span,
.weather-panel-head span,
.weather-day-card > span {
  color: var(--green);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.weather-state-card strong,
.weather-risk-card strong {
  display: block;
  margin-top: 0.12rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.25rem, 3vw, 1.9rem);
  line-height: 1.04;
}

.weather-state-card p,
.weather-risk-card p,
.weather-advice-card p,
.weather-day-card p,
.weather-hourly-row p {
  margin: 0.45rem 0 0;
  color: #3d493f;
}

.weather-state-map {
  min-height: 142px;
  border: 1px solid rgba(15, 61, 49, 0.16);
  border-radius: 8px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(31, 106, 79, 0.12), rgba(240, 180, 59, 0.24));
}

.weather-state-placeholder {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 2.7rem;
  font-weight: 900;
  color: rgba(15, 61, 49, 0.45);
}

.weather-state-map svg {
  width: 100%;
  height: 100%;
  min-height: 142px;
}

.weather-map-field {
  fill: #f8edd9;
  stroke: rgba(15, 61, 49, 0.24);
  stroke-width: 2;
}

.weather-map-grid {
  fill: none;
  stroke: rgba(15, 61, 49, 0.13);
  stroke-width: 1;
}

.weather-map-state {
  fill: rgba(15, 61, 49, 0.18);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 58px;
  font-weight: 900;
}

.weather-map-label {
  fill: var(--green-dark);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.weather-map-pin {
  fill: #a84432;
  stroke: #fffaf1;
  stroke-width: 3;
}

.weather-map-pulse {
  fill: rgba(168, 68, 50, 0.18);
  stroke: rgba(168, 68, 50, 0.45);
  stroke-width: 2;
}

.weather-risk-card {
  padding: 0.9rem;
  border-left-width: 6px;
}

.weather-risk-card.risk-low {
  border-left-color: #1f6a4f;
}

.weather-risk-card.risk-medium {
  border-left-color: #f0b43b;
}

.weather-risk-card.risk-high {
  border-left-color: #a84432;
}

.weather-advice-panel {
  padding: 0.92rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(15, 61, 49, 0.06);
}

.weather-advice-panel h3,
.weather-forecast-panel h3,
.weather-advice-card h4,
.weather-day-card h4 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.08;
}

.weather-advice-panel h3,
.weather-forecast-panel h3 {
  font-size: 1.35rem;
}

.weather-advice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: 0.72rem;
}

.weather-advice-card {
  padding: 0.78rem;
}

.weather-advice-card h4 {
  margin-top: 0.22rem;
  font-size: 1rem;
}

.weather-forecast-panel {
  padding: 0.88rem;
}

.weather-panel-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 0.7rem;
  margin-bottom: 0.7rem;
}

.weather-hourly-list {
  display: grid;
  gap: 0.42rem;
  max-height: 430px;
  overflow: auto;
  padding-right: 0.2rem;
}

.weather-hourly-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.75fr) minmax(260px, 1.1fr) minmax(220px, 1fr);
  gap: 0.65rem;
  align-items: center;
  padding: 0.62rem;
  border: 1px solid rgba(31, 106, 79, 0.13);
  border-left-width: 5px;
  border-radius: 6px;
  background: #fff;
}

.weather-hourly-row.is-good {
  border-left-color: #1f6a4f;
}

.weather-hourly-row.is-caution {
  border-left-color: #f0b43b;
}

.weather-hourly-row.is-hold {
  border-left-color: #a84432;
}

.weather-hourly-row strong {
  display: block;
  color: var(--ink);
  font-size: 0.92rem;
}

.weather-hourly-row span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.weather-hourly-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.36rem;
}

.weather-hourly-metrics span {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  background: rgba(31, 106, 79, 0.07);
  color: var(--green-dark);
  font-size: 0.78rem;
  text-align: center;
}

.weather-daily-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
}

.weather-day-card {
  display: grid;
  gap: 0.35rem;
  align-content: start;
  padding: 0.78rem;
}

.weather-day-card h4 {
  font-size: 1.08rem;
}

.weather-day-metrics {
  display: grid;
  gap: 0.15rem;
}

.weather-day-metrics strong,
.weather-day-metrics span {
  color: #3d493f;
  font-size: 0.86rem;
  font-weight: 850;
}

.weather-empty {
  margin: 0;
  padding: 0.75rem;
  border: 1px dashed rgba(15, 61, 49, 0.22);
  border-radius: 6px;
  color: var(--muted);
}

.product-popout-feature {
  margin-top: 1rem;
  padding: 0.95rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 8px;
  background: linear-gradient(135deg, #fff 0%, #f1e7d2 100%);
}

.product-popout-feature strong {
  display: block;
  margin-top: 0.12rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.3rem, 4vw, 1.95rem);
  line-height: 1.04;
}

.product-popout-feature p {
  margin: 0.46rem 0 0;
  color: #3d493f;
}

.product-popout-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.85rem;
}

.product-popout-grid article {
  padding: 0.78rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}

.product-partnership-note {
  margin-top: 0.85rem;
  padding: 0.82rem;
  border: 1px solid rgba(240, 180, 59, 0.35);
  border-radius: 8px;
  background: rgba(240, 180, 59, 0.14);
  color: #3d493f;
  font-size: 0.92rem;
}

.product-partnership-note strong {
  color: var(--green-dark);
}

.keeper-tools-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 1rem;
}

.keeper-tool-card {
  display: grid;
  gap: 0.55rem;
  align-content: start;
  padding: 0.82rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}

.keeper-tool-card > span {
  color: var(--green);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.keeper-tool-card h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.18rem;
  line-height: 1.08;
}

.keeper-tool-card p {
  margin: 0;
  font-size: 0.9rem;
}

.keeper-tool-card label {
  display: grid;
  gap: 0.3rem;
  color: #3d493f;
  font-size: 0.88rem;
  font-weight: 800;
}

.keeper-tool-card label:has(input[type="checkbox"]) {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
}

.keeper-tool-card input,
.keeper-tool-card select {
  min-height: 38px;
  border: 1px solid rgba(15, 61, 49, 0.22);
  border-radius: 4px;
  padding: 0.46rem 0.55rem;
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-weight: 800;
}

.keeper-tool-card input[type="checkbox"] {
  min-height: auto;
  width: 18px;
  height: 18px;
  margin-top: 0.1rem;
  accent-color: var(--green-dark);
}

.keeper-tool-form {
  display: grid;
  gap: 0.55rem;
}

.keeper-tool-form .button {
  width: 100%;
}

.keeper-tool-result {
  display: grid;
  gap: 0.3rem;
  min-height: 40px;
  padding: 0.62rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 6px;
  background: rgba(31, 106, 79, 0.06);
  color: var(--green-dark);
  font-size: 0.88rem;
  font-weight: 900;
}

.keeper-tool-result span {
  display: block;
  color: #3d493f;
  font-weight: 800;
}

.feeding-recipe-card,
.feeding-best-card {
  margin-top: 1rem;
  padding: 0.9rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 8px;
  background: linear-gradient(135deg, #fff 0%, #f1e7d2 100%);
}

.feeding-recipe-card span,
.feeding-sources span {
  display: block;
  color: var(--green);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.feeding-recipe-card strong,
.feeding-best-card strong {
  display: block;
  margin-top: 0.12rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.25rem, 4vw, 1.85rem);
  line-height: 1.04;
}

.feeding-best-card {
  margin-top: 0.7rem;
  background: rgba(31, 106, 79, 0.06);
}

.feeding-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
  margin-top: 0.85rem;
}

.feeding-grid article,
.feeding-methods,
.feeding-policy,
.feeding-sources {
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}

.feeding-grid article {
  padding: 0.78rem;
}

.feeding-grid h3,
.feeding-methods h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.15rem;
  line-height: 1.08;
}

.feeding-grid p {
  margin: 0.45rem 0 0;
  font-size: 0.9rem;
}

.feeding-methods {
  margin-top: 0.85rem;
  padding: 0.85rem;
}

.feeding-methods ul {
  display: grid;
  gap: 0.55rem;
  margin: 0.7rem 0 0;
  padding-left: 1.15rem;
  color: #3d493f;
}

.feeding-methods li {
  padding-left: 0.12rem;
}

.feeding-policy {
  margin-top: 0.85rem;
  padding: 0.78rem;
  background: rgba(31, 106, 79, 0.06);
  color: #3d493f;
  font-size: 0.88rem;
}

.feeding-policy strong {
  color: var(--green-dark);
}

.feeding-sources {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-top: 0.85rem;
  padding: 0.68rem 0.78rem;
}

.feeding-sources span {
  margin-right: 0.2rem;
}

.feeding-sources a {
  color: var(--green-dark);
  font-size: 0.82rem;
  font-weight: 900;
}

.club-search {
  display: grid;
  gap: 0.45rem;
  margin-top: 1rem;
}

.club-search label {
  color: var(--green-dark);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.club-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
}

.club-search input {
  min-height: 44px;
  width: 100%;
  border: 1px solid rgba(15, 61, 49, 0.24);
  border-radius: 4px;
  padding: 0.64rem 0.72rem;
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-weight: 800;
}

.club-results {
  margin-top: 1rem;
}

.club-results-intro,
.club-empty {
  margin: 0 0 0.8rem;
  font-weight: 800;
}

.club-result-list,
.club-directory-list {
  display: grid;
  gap: 0.7rem;
}

.club-directory-list {
  margin-top: 1rem;
}

.club-directory-list > h3 {
  margin: 0;
  color: var(--green-dark);
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.club-result-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, 0.34fr);
  gap: 0.8rem;
  align-items: start;
  padding: 0.78rem;
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}

.club-result-card span {
  display: block;
  color: var(--green);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.club-result-card h3 {
  margin: 0.12rem 0 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.12rem;
  line-height: 1.08;
}

.club-result-card p {
  margin: 0.32rem 0 0;
  font-size: 0.9rem;
}

.club-result-actions {
  display: grid;
  gap: 0.4rem;
}

.club-result-actions a,
.club-result-actions span {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.46rem 0.58rem;
  border: 1px solid rgba(15, 61, 49, 0.18);
  border-radius: 4px;
  background: var(--green-dark);
  color: #fff;
  text-align: center;
  text-decoration: none;
  font-size: 0.74rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.club-result-actions span {
  background: rgba(31, 106, 79, 0.08);
  color: var(--green-dark);
}

.club-policy {
  margin-top: 1rem;
  padding: 0.78rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 8px;
  background: rgba(31, 106, 79, 0.06);
  color: #3d493f;
  font-size: 0.88rem;
}

.club-policy strong {
  color: var(--green-dark);
}

.club-email-button {
  width: 100%;
  margin-top: 0.85rem;
}

@keyframes email-modal-rise {
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes email-cell-pulse {
  0%,
  100% {
    transform: translateY(0);
    background: var(--amber);
  }

  50% {
    transform: translateY(-6px);
    background: var(--honey);
  }
}

@media (max-width: 1500px) {
  .site-header {
    z-index: 80;
  }

  .nav-toggle {
    display: inline-flex;
  }

  .nav-shell {
    position: relative;
    width: min(1180px, calc(100% - 24px));
  }

  .nav-links {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 8px);
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    max-height: 0;
    overflow: hidden;
    border: 1px solid var(--line);
    gap: 0.35rem;
    padding: 0.35rem;
    border-radius: 8px;
    background: var(--paper-2);
    box-shadow: var(--shadow);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-10px);
    visibility: hidden;
    transition:
      max-height 320ms cubic-bezier(0.2, 0.9, 0.2, 1),
      opacity 180ms ease,
      transform 260ms cubic-bezier(0.2, 0.9, 0.2, 1),
      visibility 0s linear 320ms;
  }

  .nav-links.is-open {
    max-height: min(74vh, 540px);
    overflow: auto;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
    visibility: visible;
    transition:
      max-height 360ms cubic-bezier(0.2, 0.9, 0.2, 1),
      opacity 180ms ease,
      transform 260ms cubic-bezier(0.2, 0.9, 0.2, 1),
      visibility 0s;
  }

  .nav-links a,
  .nav-links .nav-tool-button,
  .nav-links .nav-cta,
  .nav-tools-menu summary {
    width: 100%;
    justify-content: flex-start;
    margin: 0;
    padding: 0.9rem 1rem;
  }

  .nav-tools-menu {
    width: 100%;
    grid-column: 1 / -1;
  }

  .nav-tools-menu summary {
    justify-content: space-between;
  }

  .nav-tools-panel {
    position: static;
    width: 100%;
    margin: 0.15rem 0 0.25rem;
    padding: 0.2rem 0.65rem 0.55rem;
    border: 0;
    box-shadow: none;
    background: rgba(15, 61, 49, 0.06);
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .nav-tools-panel .nav-tool-button {
    padding: 0.75rem 0.7rem;
    justify-content: center;
  }

  .nav-links .nav-cta {
    grid-column: 1 / -1;
    justify-content: center;
  }

  .feed-breakout {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 10px;
  }

  .top-swarm-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .swarm-field-notes {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .top-swarm-feature {
    grid-column: 1 / -1;
  }

  .weather-top-panel,
  .weather-cta-strip {
    grid-template-columns: 1fr;
  }

  .network-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .request-center-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bee-opportunity-grid,
  .honey-benefit-grid,
  .swarm-commentary-card,
  .swarm-callout-grid {
    grid-template-columns: 1fr;
  }

  .request-security-strip,
  .honey-delivery-section,
  .honey-ad-pair {
    grid-template-columns: 1fr;
  }

  .network-panel {
    grid-template-columns: 1fr;
  }

  .network-panel .button {
    width: fit-content;
  }

  .weather-cta-strip .button {
    width: fit-content;
  }

  .feed-copy {
    order: 0;
  }

  .social-video-card {
    order: 0;
  }

  .social-card-body {
    grid-template-columns: 1fr;
  }

  .social-link-row {
    margin-top: 0.2rem;
  }

  .hero,
  .natural-band,
  .split-section,
  .product-section,
  .video-library-grid,
  .heater-video-layout,
  .short-feature {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
    padding-top: 1rem;
  }

  .hero-media-stack {
    order: -1;
  }

  .hero-visual {
    min-height: 430px;
  }

  .product-hero-panel {
    min-height: 430px;
  }

  .evidence-grid,
  .contact-grid,
  .hive-product-grid {
    grid-template-columns: 1fr;
  }

  .weather-summary-grid,
  .weather-advice-grid,
  .weather-hourly-row {
    grid-template-columns: 1fr;
  }

  .weather-hourly-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .short-frame {
    width: min(360px, 100%);
    min-height: auto;
    justify-self: center;
  }
}

@media (max-width: 640px) {
  .nav-shell,
  .weather-top-panel,
  .weather-cta-strip,
  .feed-breakout,
  .video-library,
  .hero,
  .natural-band,
  .section {
    width: min(100% - 24px, 1180px);
  }

  .nav-shell {
    width: calc(100% - 16px);
    min-height: 58px;
  }

  .nav-links,
  .nav-tools-panel {
    grid-template-columns: 1fr;
  }

  .floating-utility {
    top: calc(env(safe-area-inset-top, 0px) + 62px);
    width: calc(100% - 16px);
    gap: 0.35rem;
    padding: 0.35rem;
  }

  .floating-utility-button {
    min-height: 50px;
    padding: 0.56rem 0.58rem 0.56rem 1.95rem;
  }

  .floating-utility-button::before {
    left: 0.64rem;
  }

  .floating-utility-button span {
    font-size: 0.62rem;
  }

  .floating-utility-button strong {
    font-size: 0.82rem;
  }

  .video-lightbox {
    align-items: start;
    padding: calc(env(safe-area-inset-top, 0px) + 0.45rem) 0.5rem calc(env(safe-area-inset-bottom, 0px) + 0.75rem);
  }

  .video-lightbox-card {
    width: 100%;
    max-height: calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 1.2rem);
    display: grid;
    grid-template-rows: auto auto auto;
    border-radius: 8px;
  }

  .video-lightbox-head {
    padding: 0.72rem;
  }

  .video-lightbox-head h2 {
    font-size: 1.18rem;
    line-height: 1.05;
  }

  .video-lightbox-close {
    min-width: 4.6rem;
  }

  .video-lightbox-frame {
    aspect-ratio: 16 / 9;
    min-height: 214px;
  }

  .video-lightbox-source {
    width: calc(100% - 1.2rem);
    margin: 0.6rem;
  }

  .weather-top-panel {
    width: calc(100% - 16px);
    padding: 0.85rem;
  }

  .weather-top-panel h1 {
    max-width: 14ch;
    font-size: clamp(1.95rem, 10vw, 3rem);
  }

  .network-grid {
    grid-template-columns: 1fr;
  }

  .request-center-grid,
  .bee-opportunity-grid,
  .honey-benefit-grid,
  .request-form-grid,
  .request-security-strip {
    grid-template-columns: 1fr;
  }

  .request-form-actions .button,
  .request-packet-actions .button,
  .honey-delivery-copy .button {
    width: 100%;
  }

  .weather-cta-strip {
    width: calc(100% - 16px);
    align-items: stretch;
    padding: 0.82rem;
  }

  .weather-cta-strip .button {
    width: 100%;
  }

  .feed-breakout {
    width: 100%;
    min-height: auto;
    padding: 8px 0 6px;
    align-content: start;
  }

  .top-swarm-section {
    width: calc(100% - 16px);
  }

  .top-swarm-grid {
    grid-template-columns: 1fr;
  }

  .swarm-field-notes {
    grid-template-columns: 1fr;
  }

  .top-swarm-feature {
    grid-column: auto;
  }

  .feed-copy,
  .video-library-heading {
    padding: 0 10px;
  }

  .swarm-selector-link {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .swarm-selector-link em {
    grid-column: 2;
    white-space: normal;
  }

  .feed-copy h1 {
    font-size: clamp(1.34rem, 7vw, 1.82rem);
  }

  .social-video-card {
    width: 100%;
    border-right: 0;
    border-left: 0;
    border-radius: 0;
  }

  .beekeeper-tips-card {
    border-right: 0;
    border-left: 0;
    border-radius: 0;
  }

  .tips-list div,
  .tips-card-foot {
    grid-template-columns: 1fr;
  }

  .tips-card-foot a {
    width: fit-content;
  }

  .social-video-frame {
    aspect-ratio: 16 / 9;
  }

  .social-link-row {
    grid-template-columns: 1fr;
  }

  .club-modal,
  .weather-modal,
  .feeding-modal,
  .product-modal,
  .keeper-tools-modal,
  .request-modal {
    width: calc(100% - 16px);
  }

  .club-modal-card,
  .weather-modal-card,
  .feeding-modal-card,
  .product-modal-card,
  .keeper-tools-card,
  .request-modal-card {
    padding: 1rem;
  }

  .weather-search-row,
  .weather-state-card,
  .weather-daily-grid {
    grid-template-columns: 1fr;
  }

  .weather-panel-head {
    align-items: start;
    flex-direction: column;
  }

  .weather-hourly-list {
    max-height: 520px;
  }

  .club-search-row,
  .club-result-card,
  .feeding-grid,
  .product-popout-grid,
  .keeper-tools-grid {
    grid-template-columns: 1fr;
  }

  .hive-products-panel {
    align-items: stretch;
    flex-direction: column;
  }

  .hive-products-panel .button {
    width: fit-content;
  }

  .feed-principles {
    padding: 0 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .feed-heater-card {
    border-right: 0;
    border-left: 0;
    border-radius: 0;
  }

  .feed-heater-card a {
    grid-template-columns: 1fr;
    padding: 0.68rem 0.78rem;
  }

  .feed-heater-card em {
    grid-row: auto;
    grid-column: auto;
    width: fit-content;
    margin-top: 0.28rem;
  }

  .feed-ad-card:not(.feed-heater-card) {
    grid-template-columns: 1fr;
    padding: 0.68rem 0.78rem;
    border-right: 0;
    border-left: 0;
    border-radius: 0;
  }

  .feed-ad-card:not(.feed-heater-card) > a {
    width: fit-content;
    margin-top: 0.28rem;
  }

  .video-library {
    width: 100%;
    padding: 6px 0 22px;
  }

  .video-library-grid {
    gap: 8px;
  }

  .library-video-copy {
    display: grid;
  }

  .library-video-copy a {
    white-space: normal;
  }

  .hero h1 {
    font-size: clamp(2rem, 10.5vw, 3.25rem);
  }

  .lead {
    margin-top: 0.8rem;
  }

  .hero-facts,
  .device-notes,
  .control-checks {
    grid-template-columns: 1fr;
  }

  .video-caption {
    display: grid;
  }

  .front-video-head {
    grid-template-columns: 1fr;
  }

  .front-video-head span {
    text-align: left;
  }

  .heater-copy {
    padding: 1rem 1rem 0;
  }

  .heater-facts {
    padding: 0 1rem 1rem;
  }

  .hero-visual {
    min-height: 350px;
  }

  .product-hero-panel {
    min-height: 350px;
  }

  .hero-product-image {
    object-position: 56% center;
  }

  .hero-product-summary {
    right: 0.85rem;
    bottom: 0.85rem;
    left: 0.85rem;
    width: auto;
  }

  .hero-product-summary strong {
    max-width: 78%;
    font-size: clamp(1.35rem, 7vw, 2.05rem);
  }

  .hero-product-summary span {
    max-width: 88%;
    font-size: 0.88rem;
  }

  .hero-qr-card {
    width: 70px;
    padding: 0.35rem;
  }

  .hero-qr-card .qr-grid {
    width: 48px;
    height: 48px;
  }

  .hero-power-chip,
  .hero-sensor-chip {
    left: 0.85rem;
    right: auto;
    max-width: min(240px, calc(100% - 6.4rem));
    font-size: 0.67rem;
  }

  .hero-battery-visual {
    top: 0.85rem;
    bottom: auto;
    left: 0.85rem;
    right: auto;
    transform: scale(0.7);
    transform-origin: left top;
  }

  .hero-battery-cord {
    top: 4.2rem;
    bottom: auto;
    left: 6.8rem;
    right: auto;
    width: 86px;
    height: 34px;
    transform: scale(0.72);
    transform-origin: left top;
  }

  .hero-power-chip {
    display: none;
    top: 0.85rem;
    bottom: auto;
  }

  .hero-sensor-chip {
    top: 5.65rem;
    bottom: auto;
  }

  .hive-unit {
    right: 5%;
    bottom: 18%;
    width: 68%;
    min-width: 230px;
    transform: scale(0.86);
    transform-origin: right bottom;
  }

  .battery-pack {
    left: 5%;
    bottom: 24%;
    transform: scale(0.82);
    transform-origin: left bottom;
  }

  .controller-box {
    left: 22%;
    bottom: 23%;
    transform: scale(0.82);
    transform-origin: left bottom;
  }

  .power-cord {
    left: 28%;
    width: 30%;
  }

  .contact-panel {
    align-items: stretch;
    flex-direction: column;
  }

  .email-modal-card {
    padding: 1rem;
  }

  .email-modal-actions {
    grid-template-columns: 1fr;
  }
}

.weather-modal {
  position: fixed;
  inset: 0;
  width: 100vw;
  max-width: 100vw;
  height: 100dvh;
  max-height: 100dvh;
  margin: 0;
}

.weather-modal-card {
  width: 100vw;
  min-height: 100dvh;
  height: 100dvh;
  max-height: 100dvh;
  border: 0;
  border-radius: 0;
  padding: clamp(0.9rem, 2.4vw, 2rem);
  overflow: auto;
  box-shadow: none;
}

.weather-modal-card > h2,
.weather-modal-card > p,
.weather-modal-card > .weather-search,
.weather-modal-card > .weather-status,
.weather-modal-card > .weather-results,
.weather-modal-card > .feeding-policy,
.weather-modal-card > .club-email-button,
.weather-modal-card > .weather-return-button,
.weather-modal .club-modal-head {
  width: min(1180px, 100%);
  margin-right: auto;
  margin-left: auto;
}

.weather-return-button {
  display: flex;
  margin-top: 0.85rem;
}

.weather-modal .club-modal-head {
  position: sticky;
  top: 0;
  z-index: 3;
  padding: 0.55rem 0;
  background: linear-gradient(180deg, #fffaf1 0%, rgba(255, 250, 241, 0.94) 76%, rgba(255, 250, 241, 0) 100%);
}

.weather-modal h2 {
  max-width: 24ch;
  font-size: clamp(2.2rem, 6vw, 4.8rem);
}

.weather-modal .weather-hourly-list {
  max-height: min(62dvh, 720px);
}

@supports (height: 100svh) {
  .weather-modal {
    height: 100svh;
    max-height: 100svh;
  }

  .weather-modal-card {
    min-height: 100svh;
    height: 100svh;
    max-height: 100svh;
  }
}

.field-school-hero {
  position: relative;
  min-height: calc(100svh - 62px);
  padding: clamp(5.5rem, 9vw, 8rem) max(20px, calc((100vw - 1120px) / 2)) clamp(2.8rem, 6vw, 5rem);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.78fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: end;
  isolation: isolate;
  overflow: hidden;
  background: #10251b;
  color: #fffaf1;
}

.field-school-hero::before,
.field-school-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.field-school-hero::before {
  z-index: -2;
  background: url("assets/images/beehives.jpg") center / cover no-repeat;
  transform: none;
  opacity: 0.96;
  filter: saturate(1.04) brightness(0.96);
  animation: hivePhotoFade 28s ease-out 1.2s forwards;
}

.field-school-hero::after {
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(14, 31, 23, 0.58), rgba(14, 31, 23, 0.36) 55%, rgba(14, 31, 23, 0.18)),
    linear-gradient(90deg, var(--amber), #fff2a6, var(--green)) bottom / 100% 12px no-repeat;
  opacity: 0.18;
  animation: hiveTextWash 28s ease-out 1.2s forwards;
}

.hero-bee-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.hero-bee {
  position: absolute;
  width: 18px;
  height: 10px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, #15160f 0 18%, #f2bd36 18% 40%, #15160f 40% 54%, #f2bd36 54% 78%, #15160f 78% 100%);
  box-shadow: 0 0 14px rgba(250, 213, 92, 0.34);
  opacity: 0.9;
  transform: translate3d(0, 0, 0) rotate(var(--bee-rotate, -8deg)) scale(var(--bee-scale, 1));
  transform-origin: 50% 50%;
  will-change: transform, opacity;
  animation: beeHiveLoopA var(--bee-speed, 6.8s) cubic-bezier(0.42, 0, 0.18, 1) infinite;
  animation-delay: var(--bee-delay, 0s);
}

.hero-bee::before,
.hero-bee::after {
  content: "";
  position: absolute;
  top: -7px;
  width: 10px;
  height: 8px;
  border-radius: 50% 50% 45% 45%;
  background: rgba(255, 250, 230, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.32);
  transform-origin: 50% 100%;
  animation: beeWingBeat 72ms linear infinite alternate;
}

.hero-bee::before {
  left: 2px;
  --wing-rest: -24deg;
  --wing-open: -52deg;
  transform: rotate(-24deg);
}

.hero-bee::after {
  right: 2px;
  --wing-rest: 24deg;
  --wing-open: 52deg;
  transform: rotate(24deg);
}

.bee-1 { left: 33%; top: 38%; --bee-rotate: -14deg; --bee-scale: 0.86; --bee-speed: 7.2s; --bee-delay: -0.8s; animation-name: beeHiveLoopA; }
.bee-2 { left: 43%; top: 34%; --bee-rotate: 9deg; --bee-scale: 0.72; --bee-speed: 8.1s; --bee-delay: -3.2s; animation-name: beeHiveLoopB; }
.bee-3 { left: 54%; top: 39%; --bee-rotate: -5deg; --bee-scale: 0.94; --bee-speed: 6.9s; --bee-delay: -1.4s; animation-name: beeHiveLoopC; }
.bee-4 { left: 64%; top: 32%; --bee-rotate: 18deg; --bee-scale: 0.68; --bee-speed: 8.6s; --bee-delay: -4.2s; animation-name: beeHiveLoopD; }
.bee-5 { left: 74%; top: 41%; --bee-rotate: -11deg; --bee-scale: 0.82; --bee-speed: 7.7s; --bee-delay: -2.4s; animation-name: beeHiveLoopA; }
.bee-6 { left: 84%; top: 36%; --bee-rotate: 12deg; --bee-scale: 0.64; --bee-speed: 9s; --bee-delay: -5.1s; animation-name: beeHiveLoopB; }
.bee-7 { left: 48%; top: 49%; --bee-rotate: -18deg; --bee-scale: 0.78; --bee-speed: 7.4s; --bee-delay: -3.7s; animation-name: beeHiveLoopD; }
.bee-8 { left: 59%; top: 53%; --bee-rotate: 7deg; --bee-scale: 0.9; --bee-speed: 8.3s; --bee-delay: -2s; animation-name: beeHiveLoopC; }
.bee-9 { left: 69%; top: 50%; --bee-rotate: -6deg; --bee-scale: 0.74; --bee-speed: 7.1s; --bee-delay: -5.8s; animation-name: beeHiveLoopA; }
.bee-10 { left: 77%; top: 57%; --bee-rotate: 14deg; --bee-scale: 0.82; --bee-speed: 9.2s; --bee-delay: -1.8s; animation-name: beeHiveLoopD; }
.bee-11 { left: 88%; top: 48%; --bee-rotate: -15deg; --bee-scale: 0.58; --bee-speed: 7.8s; --bee-delay: -4.6s; animation-name: beeHiveLoopB; }
.bee-12 { left: 38%; top: 56%; --bee-rotate: 10deg; --bee-scale: 0.64; --bee-speed: 8.8s; --bee-delay: -2.9s; animation-name: beeHiveLoopC; }

.yard-life-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.yard-critter {
  position: absolute;
  display: block;
  transform-origin: 50% 50%;
  will-change: transform;
}

.walking-bee {
  left: -3rem;
  bottom: 14%;
  width: 28px;
  height: 15px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, #11140d 0 18%, #f3bd35 18% 40%, #11140d 40% 54%, #f3bd35 54% 78%, #11140d 78% 100%);
  box-shadow: 0 0 12px rgba(247, 211, 111, 0.46);
  animation: beeWalkAcross 24s linear 5s infinite;
}

.walking-bee::before,
.walking-bee::after {
  content: "";
  position: absolute;
  top: -7px;
  width: 12px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255, 250, 241, 0.7);
  animation: beeWingBeat 90ms linear infinite alternate;
}

.walking-bee::before { left: 4px; --wing-rest: -20deg; --wing-open: -48deg; }
.walking-bee::after { right: 4px; --wing-rest: 20deg; --wing-open: 48deg; }

.bearding-hive {
  position: absolute;
  width: 74px;
  height: 68px;
  border-radius: 5px 5px 8px 8px;
  background:
    linear-gradient(#e7c87a 0 10px, #9b6a25 10px 12px, #e7c87a 12px 24px, #9b6a25 24px 26px, #e7c87a 26px 40px, #9b6a25 40px 42px, #e7c87a 42px 100%);
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.24);
  opacity: 0.92;
}

.bearding-hive::before {
  content: "";
  position: absolute;
  left: -6px;
  right: -6px;
  top: -9px;
  height: 12px;
  border-radius: 5px 5px 2px 2px;
  background: #f7d36f;
}

.bearding-hive span {
  position: absolute;
  width: 8px;
  height: 5px;
  border-radius: 999px;
  background: #15160f;
  box-shadow:
    12px 3px 0 #15160f,
    23px -1px 0 #15160f,
    34px 4px 0 #15160f,
    45px 0 0 #15160f;
  animation: beardBeesPulse 2.8s ease-in-out infinite;
}

.bearding-hive span:nth-child(1) { left: 10px; top: 44px; }
.bearding-hive span:nth-child(2) { left: 15px; top: 51px; animation-delay: -0.6s; }
.bearding-hive span:nth-child(3) { left: 22px; top: 58px; animation-delay: -1.1s; }
.bearding-hive span:nth-child(4) { left: 5px; top: 61px; animation-delay: -1.7s; }
.bearding-hive span:nth-child(n+5) { display: none; }
.bearding-hive-one { right: 4.6%; bottom: 8%; transform: rotate(2deg); }
.bearding-hive-two { right: 13%; bottom: 6%; transform: scale(0.78) rotate(-3deg); opacity: 0.82; }

.field-school-copy,
.field-school-lessons {
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: translateY(12px);
  animation: hiveHeroTextIn 0.75s ease-out 0.08s forwards;
}

.field-school-copy {
  max-width: 720px;
}

.field-school-copy h1 {
  margin: 0;
  max-width: 10ch;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(3.1rem, 8vw, 6.8rem);
  line-height: 0.92;
  letter-spacing: 0;
}

.field-school-lead {
  max-width: 690px;
  margin: 1.35rem 0 0;
  color: rgba(255, 250, 241, 0.9);
  font-size: clamp(1.02rem, 1.8vw, 1.28rem);
}

.field-school-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

.field-school-actions .button-secondary {
  background: rgba(255, 250, 241, 0.9);
  color: var(--green-dark);
  border-color: rgba(255, 250, 241, 0.72);
}

.hero-swarm-sequence {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.58rem;
  max-width: 720px;
  margin-top: 1.15rem;
}

.hero-swarm-sequence a {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.28rem 0.62rem;
  align-items: center;
  min-height: 4.75rem;
  padding: 0.74rem;
  border: 1px solid rgba(255, 242, 168, 0.42);
  border-radius: 8px;
  color: #fffaf1;
  background:
    linear-gradient(135deg, rgba(255, 207, 72, 0.24), rgba(15, 61, 49, 0.62)),
    rgba(10, 24, 18, 0.62);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.2);
  text-decoration: none;
  backdrop-filter: blur(8px) saturate(1.12);
}

.hero-swarm-sequence a:hover,
.hero-swarm-sequence a:focus-visible {
  border-color: #fff2a8;
  background:
    linear-gradient(135deg, rgba(255, 207, 72, 0.36), rgba(15, 61, 49, 0.78)),
    rgba(10, 24, 18, 0.72);
  outline: none;
}

.hero-swarm-sequence span {
  display: grid;
  width: auto;
  min-width: 2.95rem;
  height: 2.15rem;
  padding: 0 0.45rem;
  place-items: center;
  border-radius: 999px;
  color: var(--green-dark);
  background: #f7d36f;
  font-size: 0.82rem;
  font-weight: 950;
}

.hero-swarm-sequence strong {
  min-width: 0;
  color: #fffaf1;
  font-size: clamp(0.86rem, 1.45vw, 1.08rem);
  line-height: 1.05;
}

.hero-swarm-sequence em {
  grid-column: 2;
  color: #fff2a8;
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 950;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.weather-image-report {
  display: grid;
  grid-template-columns: minmax(120px, 0.4fr) minmax(0, 1fr);
  gap: 0.78rem;
  align-items: stretch;
  width: min(100%, 620px);
  margin-top: 0.85rem;
  padding: 0.58rem;
  border: 1px solid rgba(255, 242, 168, 0.48);
  border-radius: 10px;
  color: #fffaf1;
  background: rgba(10, 24, 18, 0.68);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
  font: inherit;
  text-align: left;
  cursor: pointer;
  overflow: hidden;
  backdrop-filter: blur(9px) saturate(1.08);
  animation: weatherImageBreathe 3.6s ease-in-out infinite;
}

.weather-image-report:hover,
.weather-image-report:focus-visible {
  border-color: #fff2a8;
  outline: none;
  box-shadow: 0 0 0 4px rgba(255, 207, 72, 0.22), 0 18px 42px rgba(0, 0, 0, 0.24);
}

.weather-image-scene {
  position: relative;
  min-height: 5.6rem;
  overflow: hidden;
  border-radius: 8px;
  background:
    linear-gradient(180deg, #9fd3ff 0%, #d9edff 48%, #f2dd92 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 250, 241, 0.28);
}

.weather-image-sun,
.weather-image-cloud,
.weather-image-rain {
  position: absolute;
  display: block;
}

.weather-image-sun {
  right: 1.1rem;
  top: 0.72rem;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 999px;
  background: radial-gradient(circle, #fff7ad 0 36%, #f0b43b 64%, rgba(240, 180, 59, 0) 72%);
  box-shadow: 0 0 2.4rem rgba(255, 220, 96, 0.72);
}

.weather-image-cloud {
  left: 1rem;
  top: 2.1rem;
  width: 4.5rem;
  height: 1.45rem;
  border-radius: 999px;
  background: rgba(255, 250, 241, 0.92);
  box-shadow:
    1.15rem -0.55rem 0 0.15rem rgba(255, 250, 241, 0.9),
    2.4rem -0.2rem 0 0.05rem rgba(255, 250, 241, 0.86);
}

.weather-image-cloud.cloud-small {
  left: auto;
  right: 2rem;
  top: 3.3rem;
  transform: scale(0.68);
  opacity: 0.72;
}

.weather-image-rain {
  top: 4.05rem;
  width: 0.18rem;
  height: 1.05rem;
  border-radius: 999px;
  background: rgba(43, 93, 143, 0.72);
  opacity: 0;
  transform: rotate(12deg);
}

.rain-one { left: 2rem; }
.rain-two { left: 3.15rem; }
.rain-three { left: 4.3rem; }

.weather-image-copy {
  display: grid;
  gap: 0.22rem;
  align-content: center;
  min-width: 0;
}

.weather-image-copy span {
  color: #f7d36f;
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.weather-image-copy strong {
  color: #fffaf1;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.15rem, 2.4vw, 1.58rem);
  line-height: 1.04;
}

.weather-image-copy em {
  color: rgba(255, 250, 241, 0.8);
  font-size: 0.88rem;
  font-style: normal;
  font-weight: 780;
}

.weather-image-report[data-weather-state="cloud"] .weather-image-scene {
  background: linear-gradient(180deg, #9fb5c5 0%, #d7dee0 56%, #d7c995 100%);
}

.weather-image-report[data-weather-state="rain"] .weather-image-scene,
.weather-image-report[data-weather-state="storm"] .weather-image-scene {
  background: linear-gradient(180deg, #4f6577 0%, #8fa1ab 54%, #657151 100%);
}

.weather-image-report[data-weather-state="snow"] .weather-image-scene {
  background: linear-gradient(180deg, #cbdff0 0%, #f4f8fb 58%, #dce8ec 100%);
}

.weather-image-report[data-weather-state="night"] .weather-image-scene {
  background: linear-gradient(180deg, #17233e 0%, #31405a 52%, #2b3c33 100%);
}

.weather-image-report[data-weather-state="rain"] .weather-image-rain,
.weather-image-report[data-weather-state="storm"] .weather-image-rain,
.weather-image-report[data-weather-state="snow"] .weather-image-rain {
  opacity: 0.9;
  animation: weatherDrop 0.72s linear infinite;
}

.weather-image-report[data-weather-state="storm"] .weather-image-sun,
.weather-image-report[data-weather-state="night"] .weather-image-sun {
  opacity: 0.28;
}

.weather-image-report[data-weather-state="snow"] .weather-image-rain {
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
}

.field-school-signal {
  max-width: 650px;
  margin-top: 1.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(255, 250, 241, 0.28);
}

.field-school-signal span,
.field-school-lessons span,
.upload-card span {
  display: block;
  margin-bottom: 0.35rem;
  color: #f7d36f;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.field-school-signal strong {
  display: block;
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  line-height: 1.08;
}

.field-school-signal p {
  max-width: 580px;
  margin: 0.55rem 0 0;
  color: rgba(255, 250, 241, 0.78);
}

.field-school-lessons {
  display: grid;
  gap: 0.85rem;
}

.field-school-lessons article {
  padding: 1rem;
  border: 1px solid rgba(255, 250, 241, 0.22);
  border-radius: 6px;
  background: rgba(15, 61, 49, 0.68);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.field-school-lessons h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.35rem;
  line-height: 1.05;
}

.field-school-lessons p {
  margin: 0.45rem 0 0;
  color: rgba(255, 250, 241, 0.78);
}

.hive-dictionary {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(320px, 1.22fr);
  gap: clamp(1.1rem, 4vw, 2rem);
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(247, 211, 111, 0.22), transparent 18rem),
    linear-gradient(135deg, #fffaf1, #eaf4ed);
}

.hive-dictionary::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.18;
  pointer-events: none;
  background-image:
    linear-gradient(30deg, transparent 37%, rgba(200, 133, 26, 0.4) 37% 41%, transparent 41% 59%, rgba(200, 133, 26, 0.4) 59% 63%, transparent 63%),
    linear-gradient(150deg, transparent 37%, rgba(200, 133, 26, 0.4) 37% 41%, transparent 41% 59%, rgba(200, 133, 26, 0.4) 59% 63%, transparent 63%),
    linear-gradient(90deg, transparent 41%, rgba(200, 133, 26, 0.4) 41% 45%, transparent 45% 55%, rgba(200, 133, 26, 0.4) 55% 59%, transparent 59%);
  background-size: 72px 124px;
}

.hive-dictionary-copy,
.hive-dictionary-tool {
  position: relative;
  z-index: 1;
}

.hive-dictionary h2 {
  max-width: 9ch;
}

.ten32-powered {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  margin-top: 1rem;
  padding: 0.62rem 0.78rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 999px;
  color: var(--green-dark);
  background: rgba(255, 255, 255, 0.72);
  font-size: 0.86rem;
  font-weight: 900;
}

.ten32-powered a {
  color: var(--green);
}

.hive-dictionary-tool {
  display: grid;
  gap: 0.9rem;
  padding: clamp(1rem, 3vw, 1.45rem);
  border: 1px solid rgba(31, 106, 79, 0.16);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.88);
  box-shadow: var(--shadow);
}

.hive-dictionary-form {
  display: grid;
  gap: 0.55rem;
}

.hive-dictionary-form label {
  color: var(--green-dark);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.hive-dictionary-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
}

.hive-dictionary-row input {
  width: 100%;
  min-height: 3.2rem;
  padding: 0.82rem 0.9rem;
  border: 1px solid rgba(31, 106, 79, 0.22);
  border-radius: 6px;
  color: var(--ink);
  background: #fff;
  font: inherit;
  font-weight: 750;
}

.hive-dictionary-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.hive-dictionary-chips button {
  min-height: 2.3rem;
  padding: 0.48rem 0.72rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-radius: 999px;
  color: var(--green-dark);
  background: #f7edd4;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 900;
  cursor: pointer;
}

.hive-dictionary-chips button:hover,
.hive-dictionary-chips button:focus-visible {
  border-color: var(--amber);
  background: #fff2a6;
  outline: none;
}

.hive-dictionary-prompt {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

.hive-dictionary-results {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

.dictionary-result-card {
  display: grid;
  gap: 0.38rem;
  min-height: 12rem;
  padding: 0.92rem;
  border: 1px solid rgba(31, 106, 79, 0.15);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(37, 29, 16, 0.08);
}

.dictionary-result-card span {
  color: var(--honey);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dictionary-result-card h3 {
  margin: 0;
  color: var(--green-dark);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.45rem;
  line-height: 1.02;
}

.dictionary-result-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.dictionary-result-card strong {
  color: var(--ink);
}

@keyframes weatherImageBreathe {
  0%,
  100% {
    filter: brightness(0.92);
  }

  48% {
    filter: brightness(1.18);
  }
}

@keyframes weatherDrop {
  from {
    transform: translateY(-0.35rem) rotate(12deg);
  }

  to {
    transform: translateY(0.7rem) rotate(12deg);
  }
}

@keyframes beeWalkAcross {
  0% {
    opacity: 0;
    transform: translate3d(-4rem, 0, 0) rotate(-2deg);
  }

  8%,
  88% {
    opacity: 0.92;
  }

  36% {
    transform: translate3d(42vw, -1.2rem, 0) rotate(7deg);
  }

  68% {
    transform: translate3d(78vw, 0.4rem, 0) rotate(-5deg);
  }

  100% {
    opacity: 0;
    transform: translate3d(112vw, -0.7rem, 0) rotate(3deg);
  }
}

@keyframes ambientBeeHover {
  0%,
  100% {
    opacity: 0.48;
    transform: translate3d(0, 0, 0) rotate(var(--ambient-rotate)) scale(var(--ambient-scale));
  }

  35% {
    opacity: 0.62;
    transform: translate3d(4px, -12px, 0) rotate(14deg) scale(var(--ambient-scale));
  }

  68% {
    opacity: 0.5;
    transform: translate3d(2px, 14px, 0) rotate(-9deg) scale(var(--ambient-scale));
  }
}

@keyframes ambientBeeHoverRight {
  0%,
  100% {
    opacity: 0.48;
    transform: translate3d(0, 0, 0) rotate(var(--ambient-rotate)) scale(var(--ambient-scale));
  }

  35% {
    opacity: 0.62;
    transform: translate3d(-4px, 12px, 0) rotate(-14deg) scale(var(--ambient-scale));
  }

  68% {
    opacity: 0.5;
    transform: translate3d(-2px, -14px, 0) rotate(9deg) scale(var(--ambient-scale));
  }
}

@keyframes beardBeesPulse {
  0%,
  100% {
    opacity: 0.74;
    transform: translateY(0);
  }

  52% {
    opacity: 0.96;
    transform: translateY(-1px);
  }
}

@keyframes siteZenIntroExit {
  0%,
  50% {
    opacity: 1;
    filter: brightness(1.02) saturate(1.05);
    transform: scale(1);
    visibility: visible;
  }

  72% {
    opacity: 0.96;
    filter: brightness(0.98) saturate(1.04);
    transform: scale(1.006);
  }

  100% {
    opacity: 0;
    filter: brightness(0.74) saturate(0.92) blur(1.2px);
    transform: scale(1.018);
    visibility: hidden;
  }
}

@keyframes zenBeeFlight {
  0% {
    opacity: 0;
    transform: translate3d(-3rem, 0, 0) rotate(var(--zen-rotate, -8deg)) scale(0.86);
  }

  12% {
    opacity: 0.96;
  }

  30% {
    transform: translate3d(26vw, var(--zen-y1, -3.6rem), 0) rotate(10deg) scale(1);
  }

  54% {
    transform: translate3d(58vw, var(--zen-y2, 1.2rem), 0) rotate(-7deg) scale(0.92);
  }

  78% {
    opacity: 0.92;
    transform: translate3d(86vw, var(--zen-y3, -2.4rem), 0) rotate(12deg) scale(0.78);
  }

  100% {
    opacity: 0;
    transform: translate3d(112vw, -1rem, 0) rotate(-4deg) scale(0.62);
  }
}

@keyframes hivePhotoFade {
  0%,
  58% {
    opacity: 0.96;
    filter: saturate(1.04) brightness(0.96);
    transform: scale(1);
  }

  100% {
    opacity: 0.82;
    filter: saturate(1) brightness(0.84);
    transform: scale(1.018);
  }
}

@keyframes hiveTextWash {
  0%,
  58% {
    opacity: 0.18;
  }

  100% {
    opacity: 0.56;
  }
}

@keyframes hiveHeroTextIn {
  0%,
  26% {
    opacity: 0;
    transform: translateY(12px);
  }

  48%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes beeWingBeat {
  from {
    opacity: 0.78;
    transform: rotate(var(--wing-rest)) scaleY(1);
  }

  to {
    opacity: 0.34;
    filter: blur(0.8px);
    transform: rotate(var(--wing-open)) scaleY(0.54);
  }
}

@keyframes beeHiveLoopA {
  0%,
  100% {
    opacity: 0.72;
    transform: translate3d(0, 0, 0) rotate(var(--bee-rotate)) scale(var(--bee-scale));
  }

  7% {
    transform: translate3d(7px, -4px, 0) rotate(10deg) scale(var(--bee-scale));
  }

  13% {
    opacity: 0.88;
    transform: translate3d(24px, -13px, 0) rotate(21deg) scale(var(--bee-scale));
  }

  18% {
    transform: translate3d(20px, -12px, 0) rotate(-8deg) scale(var(--bee-scale));
  }

  27% {
    transform: translate3d(9px, -34px, 0) rotate(-55deg) scale(var(--bee-scale));
  }

  36% {
    transform: translate3d(-19px, -23px, 0) rotate(-128deg) scale(var(--bee-scale));
  }

  46% {
    transform: translate3d(-7px, -1px, 0) rotate(88deg) scale(var(--bee-scale));
  }

  58% {
    transform: translate3d(34px, 17px, 0) rotate(15deg) scale(var(--bee-scale));
  }

  66% {
    transform: translate3d(39px, 14px, 0) rotate(4deg) scale(var(--bee-scale));
  }

  77% {
    transform: translate3d(52px, -11px, 0) rotate(-28deg) scale(var(--bee-scale));
  }

  88% {
    opacity: 0.82;
    transform: translate3d(18px, -3px, 0) rotate(148deg) scale(var(--bee-scale));
  }
}

@keyframes beeHiveLoopB {
  0%,
  100% {
    opacity: 0.68;
    transform: translate3d(0, 0, 0) rotate(var(--bee-rotate)) scale(var(--bee-scale));
  }

  8% {
    transform: translate3d(-8px, 7px, 0) rotate(132deg) scale(var(--bee-scale));
  }

  17% {
    transform: translate3d(-21px, 17px, 0) rotate(158deg) scale(var(--bee-scale));
  }

  24% {
    transform: translate3d(-13px, 18px, 0) rotate(82deg) scale(var(--bee-scale));
  }

  34% {
    transform: translate3d(8px, 35px, 0) rotate(42deg) scale(var(--bee-scale));
  }

  43% {
    opacity: 0.88;
    transform: translate3d(45px, 24px, 0) rotate(-11deg) scale(var(--bee-scale));
  }

  51% {
    transform: translate3d(41px, 20px, 0) rotate(-7deg) scale(var(--bee-scale));
  }

  64% {
    transform: translate3d(30px, -17px, 0) rotate(-74deg) scale(var(--bee-scale));
  }

  78% {
    transform: translate3d(-11px, -29px, 0) rotate(-169deg) scale(var(--bee-scale));
  }

  90% {
    transform: translate3d(-34px, 2px, 0) rotate(112deg) scale(var(--bee-scale));
  }
}

@keyframes beeHiveLoopC {
  0%,
  100% {
    opacity: 0.76;
    transform: translate3d(0, 0, 0) rotate(var(--bee-rotate)) scale(var(--bee-scale));
  }

  6% {
    transform: translate3d(9px, -8px, 0) rotate(-23deg) scale(var(--bee-scale));
  }

  15% {
    transform: translate3d(16px, -19px, 0) rotate(-34deg) scale(var(--bee-scale));
  }

  24% {
    transform: translate3d(49px, -13px, 0) rotate(9deg) scale(var(--bee-scale));
  }

  31% {
    transform: translate3d(47px, -8px, 0) rotate(18deg) scale(var(--bee-scale));
  }

  43% {
    transform: translate3d(56px, 21px, 0) rotate(88deg) scale(var(--bee-scale));
  }

  50% {
    opacity: 0.9;
    transform: translate3d(18px, 36px, 0) rotate(172deg) scale(var(--bee-scale));
  }

  64% {
    transform: translate3d(-21px, 22px, 0) rotate(-132deg) scale(var(--bee-scale));
  }

  73% {
    transform: translate3d(-17px, 18px, 0) rotate(-88deg) scale(var(--bee-scale));
  }

  82% {
    transform: translate3d(-8px, -8px, 0) rotate(-38deg) scale(var(--bee-scale));
  }

  91% {
    transform: translate3d(28px, 2px, 0) rotate(25deg) scale(var(--bee-scale));
  }
}

@keyframes beeHiveLoopD {
  0%,
  100% {
    opacity: 0.7;
    transform: translate3d(0, 0, 0) rotate(var(--bee-rotate)) scale(var(--bee-scale));
  }

  7% {
    transform: translate3d(-10px, -3px, 0) rotate(-148deg) scale(var(--bee-scale));
  }

  14% {
    opacity: 0.86;
    transform: translate3d(-27px, -9px, 0) rotate(-164deg) scale(var(--bee-scale));
  }

  23% {
    transform: translate3d(-39px, -34px, 0) rotate(-72deg) scale(var(--bee-scale));
  }

  31% {
    transform: translate3d(-34px, -31px, 0) rotate(-55deg) scale(var(--bee-scale));
  }

  43% {
    transform: translate3d(0, -48px, 0) rotate(6deg) scale(var(--bee-scale));
  }

  58% {
    transform: translate3d(36px, -24px, 0) rotate(66deg) scale(var(--bee-scale));
  }

  69% {
    transform: translate3d(31px, -18px, 0) rotate(82deg) scale(var(--bee-scale));
  }

  80% {
    transform: translate3d(24px, 18px, 0) rotate(142deg) scale(var(--bee-scale));
  }

  91% {
    transform: translate3d(-16px, 24px, 0) rotate(-126deg) scale(var(--bee-scale));
  }
}

@media (prefers-reduced-motion: reduce) {
  .field-school-hero::before,
  .field-school-hero::after,
  .field-school-copy,
  .field-school-lessons,
  .site-zen-intro,
  .zen-bee,
  .zen-bee::before,
  .zen-bee::after,
  .yard-critter,
  .yard-critter::before,
  .yard-critter::after,
  .bearding-hive span,
  .floating-utility,
  .floating-utility-button::before,
  .club-modal[open]::backdrop,
  .weather-modal[open]::backdrop,
  .request-modal[open]::backdrop,
  .club-modal[open] .club-modal-card,
  .weather-modal[open] .weather-modal-card,
  .request-modal[open] .request-modal-card {
    animation: none;
  }

  .site-zen-intro {
    display: none;
  }

  .field-school-hero::before {
    opacity: 0.82;
    filter: saturate(1) brightness(0.84);
  }

  .field-school-hero::after,
  .field-school-copy,
  .field-school-lessons {
    opacity: 1;
    transform: none;
  }

  .hero-bee {
    animation: none;
  }

  .hero-bee::before,
  .hero-bee::after {
    animation: none;
  }

  .yard-critter {
    display: none;
  }
}

.top-swarm-section {
  width: min(1180px, calc(100% - 32px));
  margin: clamp(1rem, 3vw, 2rem) auto clamp(1.4rem, 4vw, 3rem);
  display: grid;
  gap: 1rem;
}

.top-swarm-copy {
  display: grid;
  gap: 0.42rem;
  padding: clamp(1rem, 2.6vw, 1.5rem);
  border: 1px solid rgba(31, 106, 79, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(255, 250, 241, 0.96), rgba(239, 231, 211, 0.94));
  box-shadow: 0 14px 34px rgba(25, 35, 28, 0.12);
}

.top-swarm-copy h2 {
  max-width: 830px;
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.7rem, 4vw, 3.1rem);
  line-height: 1.02;
}

.top-swarm-copy p:not(.kicker) {
  max-width: 760px;
  margin: 0;
  color: #3d493f;
  font-weight: 720;
}

.swarm-field-notes {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.swarm-field-notes div {
  display: grid;
  gap: 0.32rem;
  min-height: 100%;
  padding: 0.9rem;
  border: 1px solid rgba(31, 106, 79, 0.18);
  border-left: 5px solid var(--honey);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.96);
  box-shadow: 0 12px 24px rgba(37, 29, 16, 0.08);
}

.swarm-field-notes span {
  color: var(--honey);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.swarm-field-notes strong {
  color: var(--green-dark);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.08rem, 1.7vw, 1.38rem);
  line-height: 1.08;
}

.swarm-field-notes p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.top-swarm-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.top-swarm-card {
  display: grid;
  align-content: start;
  overflow: hidden;
  border: 1px solid rgba(23, 33, 28, 0.15);
  border-radius: 8px;
  background: #fffaf1;
  box-shadow: 0 16px 34px rgba(37, 29, 16, 0.12);
}

.top-swarm-feature {
  border-color: rgba(200, 133, 26, 0.46);
  box-shadow: 0 18px 44px rgba(200, 133, 26, 0.18);
}

.top-swarm-frame {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #070907;
}

.top-swarm-frame iframe,
.top-swarm-frame .video-poster-link {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.top-swarm-card > div:last-child {
  display: grid;
  gap: 0.5rem;
  padding: 1rem;
}

.top-swarm-card span {
  color: var(--honey);
  font-size: 0.74rem;
  font-weight: 950;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.top-swarm-card h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.28rem, 2.6vw, 1.75rem);
  line-height: 1.04;
}

.top-swarm-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.top-swarm-card a {
  justify-self: start;
  min-height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 0.72rem;
  border-radius: 6px;
  color: #fffaf1;
  background: var(--green-dark);
  font-size: 0.86rem;
  font-weight: 900;
  text-decoration: none;
}

.top-swarm-card a:hover,
.top-swarm-card a:focus-visible {
  background: var(--green);
  outline: none;
}

.swarm-commentary-card {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.35fr);
  gap: 1rem;
  align-items: stretch;
  padding: clamp(1rem, 2.4vw, 1.35rem);
  border: 1px solid rgba(31, 106, 79, 0.2);
  border-radius: 8px;
  background: #173f32;
  color: #fffaf1;
  box-shadow: 0 18px 42px rgba(25, 35, 28, 0.18);
}

.swarm-commentary-card h3,
.swarm-commentary-card p {
  margin: 0;
}

.swarm-commentary-card h3 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.05;
}

.swarm-commentary-card p {
  color: rgba(255, 250, 241, 0.86);
  font-weight: 690;
}

.swarm-callout-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.72rem;
}

.swarm-callout-grid article {
  display: grid;
  gap: 0.42rem;
  min-height: 100%;
  padding: 0.86rem;
  border: 1px solid rgba(255, 250, 241, 0.18);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.1);
}

.swarm-callout-grid span {
  color: var(--amber);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.swarm-callout-grid strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.1rem;
  line-height: 1.05;
}

.swarm-callout-grid p {
  font-size: 0.9rem;
}

.upload-plan {
  width: min(1120px, calc(100% - 32px));
  margin: clamp(1.4rem, 4vw, 3rem) auto;
}

.upload-plan-heading {
  max-width: 850px;
  margin-bottom: 1.2rem;
}

.upload-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.upload-card {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  border: 1px solid rgba(23, 33, 28, 0.14);
  border-radius: 6px;
  background: #fffaf1;
  box-shadow: 0 16px 34px rgba(37, 29, 16, 0.12);
}

.upload-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #d9cdbb;
}

.upload-card div {
  display: grid;
  align-content: start;
  gap: 0.55rem;
  padding: 1rem;
}

.upload-card span {
  color: var(--honey);
  margin: 0;
}

.upload-card h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.42rem;
  line-height: 1.05;
}

.upload-card p {
  margin: 0;
  color: var(--muted);
}

.upload-card a {
  justify-self: start;
  margin-top: 0.2rem;
  color: var(--green-dark);
  font-weight: 900;
}

.lesson-start-times {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.42rem;
  margin-top: 0.15rem;
}

.lesson-start-times a {
  display: grid;
  align-content: center;
  justify-self: stretch;
  min-height: 4.1rem;
  margin: 0;
  padding: 0.58rem;
  border: 1px solid rgba(15, 61, 49, 0.18);
  border-radius: 6px;
  color: var(--green-dark);
  background: rgba(238, 246, 229, 0.78);
  text-decoration: none;
}

.lesson-start-times strong {
  display: block;
  color: var(--honey);
  font-size: 1.02rem;
  line-height: 1;
}

.lesson-start-times span {
  margin-top: 0.24rem;
  color: var(--green-dark);
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: none;
}

.lesson-start-times a:hover,
.lesson-start-times a:focus-visible {
  border-color: var(--green-dark);
  background: #fffaf1;
  outline: none;
  box-shadow: 0 0 0 4px rgba(247, 211, 111, 0.22);
}

.upload-commentary {
  display: grid;
  gap: 0.35rem;
  margin-top: 1rem;
  padding: 1rem;
  border-left: 5px solid var(--honey);
  border-radius: 8px;
  background: rgba(238, 246, 229, 0.86);
  color: var(--green-dark);
}

.upload-commentary strong,
.upload-commentary p {
  margin: 0;
}

.upload-commentary p {
  color: var(--muted);
  font-weight: 700;
}

.reader-tools {
  position: fixed;
  left: 0;
  top: 50%;
  z-index: 130;
  display: grid;
  grid-template-columns: auto minmax(0, 16rem);
  color: var(--green-dark);
  transform: translateY(-50%);
}

.reader-tools-toggle {
  writing-mode: vertical-rl;
  display: inline-grid;
  gap: 0.35rem;
  align-items: center;
  min-width: 2.85rem;
  min-height: 7.2rem;
  padding: 0.78rem 0.48rem;
  border: 3px solid var(--green-dark);
  border-left: 0;
  border-radius: 0 10px 10px 0;
  color: var(--green-dark);
  background: rgba(255, 250, 241, 0.9);
  box-shadow: var(--shadow);
  font: inherit;
  text-align: center;
  cursor: pointer;
}

.reader-tools-toggle span {
  font-size: 0.72rem;
  font-weight: 950;
  line-height: 1;
  text-transform: uppercase;
}

.reader-tools-toggle strong {
  display: inline-grid;
  min-width: 2rem;
  min-height: 2rem;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  background: var(--green-dark);
  font-size: 0.95rem;
  line-height: 1;
  writing-mode: horizontal-tb;
}

.reader-tools-toggle:hover,
.reader-tools-toggle:focus-visible,
.reader-tools.is-open .reader-tools-toggle {
  color: #fff;
  background: var(--green-dark);
  outline: none;
}

.reader-tools-toggle:hover strong,
.reader-tools-toggle:focus-visible strong,
.reader-tools.is-open .reader-tools-toggle strong {
  color: var(--green-dark);
  background: #fff;
}

.reader-tools-panel {
  display: grid;
  grid-template-columns: auto auto auto;
  gap: 0.45rem;
  align-items: center;
  width: min(16rem, calc(100vw - 3.6rem));
  padding: 0.72rem;
  border: 3px solid var(--green-dark);
  border-left: 0;
  border-radius: 0 10px 10px 0;
  background: rgba(255, 250, 241, 0.82);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
}

.reader-tools-panel[hidden] {
  display: none;
}

.reader-tools-panel strong {
  grid-column: 1 / -1;
  font-size: 0.82rem;
  font-weight: 950;
  line-height: 1;
  text-transform: uppercase;
}

.reader-tools-panel button,
.reader-tools-panel [data-reader-status] {
  display: inline-grid;
  min-width: 3rem;
  min-height: 3rem;
  place-items: center;
  border-radius: 8px;
  font: inherit;
  font-weight: 950;
}

.reader-tools-panel button {
  border: 2px solid rgba(15, 61, 49, 0.2);
  color: var(--green-dark);
  background: var(--paper-2);
  cursor: pointer;
}

.reader-tools-panel button:hover,
.reader-tools-panel button:focus-visible {
  color: #fff;
  background: var(--green-dark);
  border-color: var(--green-dark);
  outline: none;
}

.reader-tools-panel [data-reader-reset] {
  grid-column: 1 / -1;
  min-height: 2.6rem;
}

.reader-tools-panel [data-reader-status] {
  color: var(--ink);
  background: rgba(240, 180, 59, 0.24);
}

@media (max-width: 900px) {
  .field-school-hero {
    min-height: auto;
    grid-template-columns: 1fr;
    align-items: start;
  }

  .field-school-hero::after {
    background:
      linear-gradient(180deg, rgba(14, 31, 23, 0.56), rgba(14, 31, 23, 0.38)),
      linear-gradient(90deg, var(--amber), #fff2a6, var(--green)) bottom / 100% 12px no-repeat;
  }

  .hero-bee {
    opacity: 0.84;
  }

  .bee-1,
  .bee-4,
  .bee-6,
  .bee-11 {
    display: none;
  }

  .field-school-copy h1 {
    max-width: 9ch;
  }

  .hero-swarm-sequence {
    max-width: 100%;
  }

  .field-school-lessons,
  .hive-dictionary,
  .upload-card-grid,
  .bee-opportunity-grid,
  .honey-benefit-grid,
  .swarm-commentary-card,
  .swarm-callout-grid,
  .honey-ad-pair,
  .ten32-bench-ad {
    grid-template-columns: 1fr;
  }

  .lesson-start-times {
    grid-template-columns: 1fr;
  }

  .hive-dictionary-results {
    grid-template-columns: 1fr;
  }

  .bearding-hive-one {
    right: 1rem;
    bottom: 1.2rem;
    transform: scale(0.72) rotate(2deg);
  }

  .bearding-hive-two {
    display: none;
  }

  .lesson-start-times a {
    min-height: 3.35rem;
  }

  .ten32-bench-ad .button {
    width: 100%;
  }
}

@media (max-width: 560px) {
  body {
    padding-bottom: 2rem;
  }

  .site-header {
    width: calc(100% - 16px);
    max-width: calc(100% - 16px);
  }

  .field-school-hero {
    padding: 7.4rem 16px 2.6rem;
  }

  .zen-intro-controls {
    left: max(10px, env(safe-area-inset-left));
    right: max(10px, env(safe-area-inset-right));
    top: max(10px, env(safe-area-inset-top));
    justify-items: stretch;
  }

  .zen-skip-button,
  .zen-intro-controls .zen-preference-check {
    width: 100%;
    max-width: calc(100vw - 20px);
    justify-content: center;
    text-align: center;
  }

  .zen-audio-button {
    left: max(10px, env(safe-area-inset-left));
    right: max(10px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
    width: auto;
    justify-items: center;
    text-align: center;
  }

  .hero-swarm-sequence {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.36rem;
    width: min(100%, 374px);
    max-width: calc(100vw - 16px);
  }

  .hero-swarm-sequence a {
    grid-template-columns: 1fr;
    min-width: 0;
    min-height: 6rem;
    padding: 0.48rem 0.38rem;
  }

  .hero-swarm-sequence span {
    width: 1.75rem;
    height: 1.75rem;
  }

  .hero-swarm-sequence strong {
    font-size: 0.68rem;
    overflow-wrap: anywhere;
  }

  .hero-swarm-sequence em {
    grid-column: auto;
    font-size: 0.6rem;
    overflow-wrap: anywhere;
  }

  .field-school-actions .button {
    width: 100%;
  }

  .hive-dictionary-row {
    grid-template-columns: 1fr;
  }

  .hive-dictionary-row .button {
    width: 100%;
  }

  .hive-dictionary-chips {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hive-dictionary-chips button {
    width: 100%;
    min-width: 0;
  }

  .site-ambient-life {
    inset: 108px 0 0;
  }

  .site-ambient-life .ambient-bee-one { top: 16%; }
  .site-ambient-life .ambient-bee-two { top: 38%; }
  .site-ambient-life .ambient-bee-three { top: 62%; }
  .site-ambient-life .ambient-bee-four { top: 82%; }

  .bee-term::after {
    left: 0;
    width: min(20rem, calc(100vw - 2rem));
    transform: translate3d(0, 0.35rem, 0);
  }

  .bee-term:hover::after,
  .bee-term:focus-visible::after {
    transform: translate3d(0, 0, 0);
  }

  .floating-utility {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.3rem;
    width: min(calc(100% - 16px), 374px);
    max-width: calc(100vw - 16px);
    padding: 0.32rem;
  }

  .floating-utility-button {
    min-height: 3.35rem;
    padding: 0.48rem 0.34rem 0.48rem 1.28rem;
  }

  .floating-utility-button::before {
    left: 0.48rem;
    width: 0.52rem;
    height: 0.52rem;
  }

  .floating-utility-button span {
    font-size: 0.52rem;
    letter-spacing: 0;
  }

  .floating-utility-button strong {
    font-size: 0.72rem;
    overflow-wrap: anywhere;
  }

  .upload-plan {
    width: min(100% - 20px, 1120px);
  }

  .ten32-bench-ad {
    width: min(100% - 20px, 1180px);
  }

  .reader-tools {
    top: 44%;
  }

  .reader-tools-panel {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .floating-swarm-sequence {
    display: none;
  }

  .floating-utility {
    position: static;
    top: auto;
    left: auto;
    z-index: 1;
    width: min(calc(100% - 16px), 374px);
    max-width: calc(100vw - 16px);
    margin: 0.45rem auto 0;
    transform: none;
    animation: none;
  }

  .field-school-hero {
    min-height: calc(100svh - 62px);
    padding: 0.95rem 12px 1.8rem;
    align-content: start;
  }

  .field-school-copy h1 {
    max-width: 11ch;
    font-size: clamp(2.05rem, 10vw, 2.8rem);
  }

  .field-school-lead {
    margin-top: 0.72rem;
    font-size: 0.94rem;
    line-height: 1.38;
  }

  .hero-swarm-sequence {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.34rem;
    width: 100%;
    max-width: none;
    margin-top: 0.72rem;
  }

  .hero-swarm-sequence a {
    grid-template-columns: 1fr;
    gap: 0.24rem;
    min-height: 4.85rem;
    padding: 0.48rem 0.34rem;
  }

  .hero-swarm-sequence span {
    min-width: 0;
    width: 100%;
    max-width: 3.7rem;
    height: 1.65rem;
    justify-self: center;
    padding: 0 0.22rem;
    font-size: 0.72rem;
  }

  .hero-swarm-sequence strong {
    font-size: 0.68rem;
    text-align: center;
  }

  .hero-swarm-sequence em {
    grid-column: auto;
    font-size: 0.58rem;
    text-align: center;
  }

  .weather-image-report {
    grid-template-columns: 5.2rem minmax(0, 1fr);
    gap: 0.52rem;
    margin-top: 0.58rem;
    padding: 0.42rem;
  }

  .weather-image-scene {
    min-height: 4.2rem;
  }

  .weather-image-sun {
    right: 0.55rem;
    top: 0.45rem;
    width: 2rem;
    height: 2rem;
  }

  .weather-image-cloud {
    left: 0.55rem;
    top: 1.85rem;
    transform: scale(0.78);
    transform-origin: left center;
  }

  .weather-image-cloud.cloud-small {
    display: none;
  }

  .weather-image-copy span {
    font-size: 0.6rem;
  }

  .weather-image-copy strong {
    font-size: 0.98rem;
  }

  .weather-image-copy em {
    font-size: 0.72rem;
  }

  .field-school-actions {
    margin-top: 0.85rem;
  }

  .field-school-signal {
    margin-top: 0.9rem;
    padding-top: 0.85rem;
  }

  .field-school-signal p {
    font-size: 0.92rem;
  }

  .top-swarm-section {
    width: calc(100% - 16px);
    gap: 0.72rem;
  }

  .top-swarm-copy {
    padding: 0.92rem;
  }

  .top-swarm-copy h2 {
    font-size: clamp(1.5rem, 8vw, 2.2rem);
  }

  .swarm-field-notes {
    grid-template-columns: 1fr;
    gap: 0.58rem;
  }

  .swarm-field-notes div {
    min-height: auto;
    padding: 0.78rem;
  }

  .top-swarm-grid {
    display: flex;
    gap: 0.7rem;
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 0.1rem 0.45rem;
    scroll-padding-inline: 0.1rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .top-swarm-grid::-webkit-scrollbar {
    height: 0.45rem;
  }

  .top-swarm-grid::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(15, 61, 49, 0.28);
  }

  .top-swarm-card,
  .top-swarm-feature {
    flex: 0 0 min(86vw, 340px);
    width: min(86vw, 340px);
    grid-column: auto;
    scroll-snap-align: start;
  }

  .top-swarm-card > div:last-child {
    gap: 0.42rem;
    padding: 0.82rem;
  }

  .top-swarm-card h3 {
    font-size: clamp(1.18rem, 6vw, 1.55rem);
  }

  .top-swarm-card p {
    font-size: 0.9rem;
  }
}

.site-header .reader-tools {
  position: absolute;
  top: calc(100% + 0.55rem);
  right: 3.35rem;
  left: auto;
  z-index: 95;
  display: none;
  width: min(16rem, calc(100vw - 1.5rem));
  color: var(--green-dark);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(0.7rem, -0.35rem) scale(0.98);
  transition: opacity 0.2s ease, transform 0.24s cubic-bezier(0.2, 0.8, 0.2, 1), visibility 0.2s ease;
}

.site-header.is-menu-open .reader-tools {
  display: block;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(0, 0) scale(1);
}

.site-header .reader-tools-toggle {
  display: none;
}

.site-header .reader-tools-panel {
  width: 100%;
  border: 2px solid rgba(15, 61, 49, 0.2);
  border-left: 7px solid var(--amber);
  border-radius: 8px;
  background: rgba(255, 250, 241, 0.9);
  backdrop-filter: blur(14px);
}

@media (max-width: 1500px) {
  .nav-links .reader-tools {
    position: static;
    grid-column: 1 / -1;
    display: block;
    width: 100%;
    margin-top: 0.2rem;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
  }
}
