:root {
  color-scheme: light;
  --display-stack: "Suisseintl", "Epilogue", "Inter", sans-serif;
  --body-stack: "Inter", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--body-stack);
  color: #171d17;
  background:
    radial-gradient(circle at top left, rgba(0, 107, 48, 0.12), transparent 32%),
    radial-gradient(circle at bottom right, rgba(163, 50, 77, 0.08), transparent 24%),
    #f5fbf1;
  -webkit-font-smoothing: antialiased;
}

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

a {
  color: inherit;
  text-decoration: none;
}

.material-symbols-outlined {
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.site-shell {
  width: min(1280px, calc(100vw - 2rem));
  margin: 0 auto;
}

.site-frame {
  padding-inline: clamp(1rem, 2vw, 1.5rem);
}

.display-face {
  font-family: var(--display-stack);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(20px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 700;
}

.glass-nav {
  background: rgba(255, 255, 255, 0.76);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 20px 60px rgba(23, 29, 23, 0.07);
}

.site-nav-backdrop {
  position: absolute;
  inset: 0 0 auto 0;
  height: 6.5rem;
  background: linear-gradient(180deg, rgba(245, 251, 241, 0.92) 0%, rgba(245, 251, 241, 0.76) 58%, rgba(245, 251, 241, 0) 100%);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  pointer-events: none;
}

.nav-trigger {
  appearance: none;
  border: 0;
  background: transparent;
  line-height: 1;
  cursor: pointer;
}

.nav-item {
  display: flex;
  align-items: center;
}

.mega-panel {
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    visibility 180ms ease;
  pointer-events: none;
}

.mega-panel::before {
  content: "";
  position: absolute;
  inset: 0.2rem 0.9rem auto;
  height: 1.25rem;
  border-radius: 1rem 1rem 0 0;
  background: rgba(248, 252, 245, 0.985);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
}

.mega-surface {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(180deg, rgba(251, 253, 249, 0.992) 0%, rgba(244, 248, 240, 0.988) 100%);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border: 1px solid rgba(255, 255, 255, 0.62);
  box-shadow:
    0 24px 70px rgba(23, 29, 23, 0.09),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.nav-item:hover .mega-panel,
.nav-item:focus-within .mega-panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.poster-hero {
  min-height: calc(100svh - 5.5rem);
}

.layer-panel {
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 28px 80px rgba(23, 29, 23, 0.07);
  backdrop-filter: blur(18px);
}

.gradient-button {
  background: linear-gradient(135deg, #006b30 0%, #00873f 100%);
  color: #fff;
}

.ghost-button {
  background: rgba(220, 229, 216, 0.92);
  color: #171d17;
}

.editorial-kicker {
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.75rem;
  font-weight: 700;
}

.editorial-quote {
  font-family: var(--display-stack);
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.media-bleed {
  overflow: visible;
}

.media-bleed img {
  width: 115%;
  max-width: none;
}

.field-shell {
  background: rgba(233, 240, 230, 0.9);
  border-radius: 1rem;
  padding: 0.35rem 1rem 0.45rem;
}

.field-shell input,
.field-shell textarea,
.field-shell select {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  font: inherit;
  color: #171d17;
  padding: 0.9rem 0 0.75rem;
  border-bottom: 2px solid rgba(71, 84, 69, 0.18);
}

.field-shell input:focus,
.field-shell textarea:focus,
.field-shell select:focus {
  border-bottom-color: rgba(0, 107, 48, 0.42);
}

.site-footer {
  background:
    linear-gradient(180deg, rgba(221, 231, 216, 0.38) 0%, rgba(233, 240, 230, 0.75) 100%);
}

.active-link {
  color: #006b30;
}

.active-link::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: rgba(0, 107, 48, 0.1);
  z-index: -1;
}

.mega-link-active {
  background: rgba(233, 240, 230, 0.98);
  box-shadow: 0 18px 42px rgba(23, 29, 23, 0.05);
}

.menu-sheet {
  display: none;
}

.menu-sheet[data-open="true"] {
  display: block;
}

.hero-orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(72px);
  pointer-events: none;
}

.mobile-menu-panel a {
  text-decoration: none;
}

@media (max-width: 900px) {
  .mega-panel {
    display: none;
  }

  .poster-hero {
    min-height: auto;
  }

  .media-bleed img {
    width: 100%;
  }
}
