:root {
  --bg: #08110d;
  --bg-deep: #040b08;
  --surface: rgba(10, 20, 15, 0.68);
  --surface-strong: rgba(8, 18, 13, 0.84);
  --surface-soft: rgba(12, 24, 18, 0.54);
  --surface-frost: rgba(18, 31, 23, 0.56);
  --text: #eef5ea;
  --text-soft: #b7c5b8;
  --text-muted: #8f9f93;
  --forest: #91b587;
  --forest-deep: #18271e;
  --navy: #7f98bb;
  --moss: #5e7d63;
  --firefly: #f3e79d;
  --firefly-soft: rgba(243, 231, 157, 0.2);
  --line: rgba(218, 233, 214, 0.12);
  --line-strong: rgba(218, 233, 214, 0.22);
  --shadow: 0 28px 80px rgba(0, 0, 0, 0.4);
  --glow: 0 0 32px rgba(243, 231, 157, 0.12);
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --container: min(1180px, calc(100vw - 3rem));
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 50% 120%, rgba(53, 84, 63, 0.44), transparent 34%),
    radial-gradient(circle at 18% 8%, rgba(49, 78, 58, 0.24), transparent 28%),
    radial-gradient(circle at 82% 14%, rgba(28, 41, 52, 0.22), transparent 28%),
    linear-gradient(180deg, #07100d 0%, #08120d 48%, #050a08 100%);
  font-family: "Avenir Next", "Yu Gothic", "Hiragino Sans", sans-serif;
  line-height: 1.7;
  overflow-x: hidden;
}

main,
.site-header,
.status-band,
.site-footer {
  position: relative;
  z-index: 1;
}

a {
  color: inherit;
}

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

.site-aura {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 8% 12%, rgba(243, 231, 157, 0.12), transparent 18%),
    radial-gradient(ellipse at 11% 36%, rgba(135, 178, 144, 0.12), transparent 24%),
    radial-gradient(ellipse at 7% 78%, rgba(116, 146, 206, 0.12), transparent 22%),
    radial-gradient(ellipse at 92% 14%, rgba(243, 231, 157, 0.11), transparent 18%),
    radial-gradient(ellipse at 89% 42%, rgba(135, 178, 144, 0.12), transparent 24%),
    radial-gradient(ellipse at 94% 80%, rgba(116, 146, 206, 0.11), transparent 22%),
    radial-gradient(circle at 50% 92%, rgba(104, 141, 99, 0.14), transparent 22%),
    radial-gradient(ellipse at 50% 30%, rgba(3, 8, 6, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(2, 6, 4, 0.14), rgba(2, 6, 4, 0.34)),
    repeating-linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.01) 0,
      rgba(255, 255, 255, 0.01) 26px,
      rgba(0, 0, 0, 0.02) 26px,
      rgba(0, 0, 0, 0.02) 52px
    );
  opacity: 0.95;
  z-index: 0;
}

.site-aura::before,
.site-aura::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-repeat: no-repeat;
  mix-blend-mode: screen;
}

.site-aura::before {
  opacity: 0.26;
  filter: blur(18px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.24) 0 4px, transparent 16px),
    radial-gradient(circle, rgba(153, 194, 164, 0.18) 0 5px, transparent 18px),
    radial-gradient(circle, rgba(127, 152, 187, 0.17) 0 6px, transparent 20px),
    radial-gradient(circle, rgba(243, 231, 157, 0.22) 0 4px, transparent 16px),
    radial-gradient(circle, rgba(153, 194, 164, 0.16) 0 5px, transparent 18px),
    radial-gradient(circle, rgba(127, 152, 187, 0.16) 0 6px, transparent 20px),
    radial-gradient(circle, rgba(243, 231, 157, 0.2) 0 4px, transparent 16px),
    radial-gradient(circle, rgba(153, 194, 164, 0.16) 0 5px, transparent 18px),
    radial-gradient(circle, rgba(243, 231, 157, 0.2) 0 4px, transparent 16px),
    radial-gradient(circle, rgba(127, 152, 187, 0.16) 0 6px, transparent 20px);
  background-position:
    6% 12%,
    12% 26%,
    9% 46%,
    15% 72%,
    91% 14%,
    86% 30%,
    93% 52%,
    88% 70%,
    4% 88%,
    96% 86%;
  animation: drift-far 48s linear infinite reverse, twinkle 10s ease-in-out infinite alternate;
}

.site-aura::after {
  opacity: 0.3;
  filter: blur(0.8px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.76) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.7) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.74) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.72) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.86) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.78) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.76) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.74) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.86) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.78) 0 0.9px, transparent 2.6px);
  background-position:
    6% 10%,
    12% 18%,
    8% 28%,
    14% 40%,
    10% 54%,
    15% 66%,
    7% 78%,
    13% 88%,
    94% 12%,
    88% 20%,
    92% 34%,
    86% 46%,
    91% 58%,
    87% 72%,
    95% 82%,
    89% 90%,
    97% 6%;
  animation: drift-far 54s linear infinite, twinkle 11s ease-in-out infinite alternate;
}

.sky-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.96;
  -webkit-mask-image: linear-gradient(
    90deg,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 1) 24%,
    rgba(0, 0, 0, 0.56) 34%,
    rgba(0, 0, 0, 0.05) 42%,
    rgba(0, 0, 0, 0.05) 58%,
    rgba(0, 0, 0, 0.56) 66%,
    rgba(0, 0, 0, 1) 76%,
    rgba(0, 0, 0, 1) 100%
  );
  mask-image: linear-gradient(
    90deg,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 1) 24%,
    rgba(0, 0, 0, 0.56) 34%,
    rgba(0, 0, 0, 0.05) 42%,
    rgba(0, 0, 0, 0.05) 58%,
    rgba(0, 0, 0, 0.56) 66%,
    rgba(0, 0, 0, 1) 76%,
    rgba(0, 0, 0, 1) 100%
  );
}

.firefly-layer {
  position: fixed;
  inset: -12%;
  pointer-events: none;
  z-index: 0;
  background-repeat: no-repeat;
  mix-blend-mode: screen;
  -webkit-mask-image: linear-gradient(
    90deg,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 1) 17%,
    rgba(0, 0, 0, 0.82) 24%,
    rgba(0, 0, 0, 0.18) 34%,
    rgba(0, 0, 0, 0.02) 42%,
    rgba(0, 0, 0, 0.02) 58%,
    rgba(0, 0, 0, 0.18) 66%,
    rgba(0, 0, 0, 0.82) 76%,
    rgba(0, 0, 0, 1) 83%,
    rgba(0, 0, 0, 1) 100%
  );
  mask-image: linear-gradient(
    90deg,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 1) 17%,
    rgba(0, 0, 0, 0.82) 24%,
    rgba(0, 0, 0, 0.18) 34%,
    rgba(0, 0, 0, 0.02) 42%,
    rgba(0, 0, 0, 0.02) 58%,
    rgba(0, 0, 0, 0.18) 66%,
    rgba(0, 0, 0, 0.82) 76%,
    rgba(0, 0, 0, 1) 83%,
    rgba(0, 0, 0, 1) 100%
  );
}

.firefly-layer::before,
.firefly-layer::after {
  content: "";
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  mix-blend-mode: screen;
}

.firefly-layer--far {
  opacity: 0.28;
  filter: blur(0.7px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.95) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 1px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.72) 0 1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.2px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.78) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.76) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.85) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.74) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.7) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1px, transparent 2.8px);
  background-position:
    6% 18%,
    14% 36%,
    21% 12%,
    28% 44%,
    35% 22%,
    42% 10%,
    49% 34%,
    57% 18%,
    64% 42%,
    73% 16%,
    81% 38%,
    88% 14%,
    92% 48%,
    97% 24%;
  animation: drift-far 34s linear infinite, twinkle 8s ease-in-out infinite alternate;
}

.firefly-layer--far::before {
  opacity: 0.22;
  filter: blur(0.8px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.74) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.7) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.76) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.78) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.74) 0 0.9px, transparent 2.6px);
  background-position:
    4% 56%,
    11% 78%,
    18% 52%,
    26% 72%,
    38% 58%,
    47% 82%,
    58% 62%,
    71% 76%,
    84% 58%,
    93% 72%;
  animation: drift-far 40s linear infinite reverse, twinkle 9s ease-in-out infinite alternate;
}

.firefly-layer--far::after {
  opacity: 0.18;
  filter: blur(1px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.72) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.76) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.7) 0 0.9px, transparent 2.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.74) 0 1px, transparent 2.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.8) 0 0.9px, transparent 2.6px);
  background-position:
    9% 88%,
    23% 90%,
    34% 86%,
    46% 92%,
    57% 88%,
    69% 90%,
    81% 86%,
    94% 92%;
  animation: drift-far 46s linear infinite, twinkle 10s ease-in-out infinite alternate;
}

.firefly-layer--mid {
  opacity: 0.42;
  filter: blur(0.45px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.98) 0 1.2px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.5px, transparent 3.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.4px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.94) 0 1.3px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1.2px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.96) 0 1.4px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.25px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.35px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.25px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.2px, transparent 3px);
  background-position:
    8% 26%,
    15% 58%,
    24% 34%,
    33% 18%,
    41% 48%,
    52% 28%,
    61% 12%,
    69% 54%,
    77% 32%,
    85% 18%,
    91% 44%,
    96% 26%;
  animation: drift-mid 24s linear infinite, twinkle 5.8s ease-in-out infinite alternate;
}

.firefly-layer--mid::before {
  opacity: 0.3;
  filter: blur(0.4px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.94) 0 1.2px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.86) 0 1.35px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.25px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.96) 0 1.4px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.2px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.25px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.2px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.3px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.85) 0 1.1px, transparent 3px);
  background-position:
    6% 44%,
    13% 20%,
    27% 58%,
    39% 36%,
    48% 56%,
    55% 40%,
    67% 22%,
    74% 48%,
    86% 30%,
    95% 54%;
  animation: drift-mid 28s linear infinite reverse, twinkle 6.4s ease-in-out infinite alternate;
}

.firefly-layer--mid::after {
  opacity: 0.24;
  filter: blur(0.5px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.15px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.82) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.94) 0 1.25px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.86) 0 1.2px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.3px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.1px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.2px, transparent 3px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.15px, transparent 3px);
  background-position:
    10% 8%,
    22% 16%,
    37% 10%,
    51% 14%,
    63% 8%,
    76% 18%,
    88% 10%,
    97% 16%;
  animation: drift-mid 30s linear infinite, twinkle 7s ease-in-out infinite alternate;
}

.firefly-layer--near {
  opacity: 0.5;
  filter: blur(0.2px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 1) 0 1.5px, transparent 4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.7px, transparent 4.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.35px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.96) 0 1.6px, transparent 4.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.3px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.94) 0 1.7px, transparent 4.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.4px, transparent 3.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.5px, transparent 4px);
  background-position:
    12% 72%,
    22% 64%,
    36% 76%,
    49% 68%,
    63% 74%,
    77% 66%,
    88% 78%,
    94% 62%;
  animation: drift-near 18s ease-in-out infinite alternate, twinkle 4s ease-in-out infinite alternate;
}

.firefly-layer--near::before {
  opacity: 0.26;
  filter: blur(0.15px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.98) 0 1.45px, transparent 3.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.3px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.5px, transparent 4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.25px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.95) 0 1.55px, transparent 4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.9) 0 1.35px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.94) 0 1.5px, transparent 4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.86) 0 1.3px, transparent 3.6px);
  background-position:
    7% 66%,
    18% 82%,
    31% 64%,
    44% 80%,
    59% 66%,
    72% 82%,
    86% 64%,
    98% 80%;
  animation: drift-near 16s ease-in-out infinite alternate-reverse, twinkle 4.8s ease-in-out infinite alternate;
}

.firefly-layer--near::after {
  opacity: 0.2;
  filter: blur(0.3px);
  background-image:
    radial-gradient(circle, rgba(243, 231, 157, 0.84) 0 1.2px, transparent 3.2px),
    radial-gradient(circle, rgba(243, 231, 157, 0.92) 0 1.35px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.86) 0 1.25px, transparent 3.4px),
    radial-gradient(circle, rgba(243, 231, 157, 0.94) 0 1.4px, transparent 3.8px),
    radial-gradient(circle, rgba(243, 231, 157, 0.88) 0 1.3px, transparent 3.6px),
    radial-gradient(circle, rgba(243, 231, 157, 0.96) 0 1.45px, transparent 4px);
  background-position:
    16% 48%,
    29% 52%,
    47% 46%,
    61% 50%,
    79% 44%,
    92% 48%;
  animation: drift-near 20s ease-in-out infinite alternate, twinkle 5.5s ease-in-out infinite alternate;
}

.container {
  width: var(--container);
  margin: 0 auto;
}

.status-band {
  background: rgba(5, 10, 8, 0.7);
  color: rgba(238, 245, 234, 0.86);
  border-bottom: 1px solid rgba(218, 233, 214, 0.09);
  backdrop-filter: blur(14px);
}

.status-band__inner {
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
  padding: 0.9rem 0;
  font-size: 0.92rem;
}

.status-band__inner p {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.28rem 0.7rem;
  border-radius: 999px;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}

.status-pill--active {
  background: rgba(243, 231, 157, 0.14);
  color: var(--firefly);
  border: 1px solid rgba(243, 231, 157, 0.26);
  box-shadow: var(--glow);
}

.status-pill--prep {
  background: rgba(127, 152, 187, 0.14);
  color: #d2def1;
  border: 1px solid rgba(127, 152, 187, 0.24);
}

.status-pill--outline {
  background: transparent;
  color: var(--text-muted);
  border: 1px solid rgba(218, 233, 214, 0.14);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(5, 10, 8, 0.38);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(218, 233, 214, 0.08);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1rem 0;
}

.brand {
  display: inline-flex;
  flex-direction: column;
  gap: 0.18rem;
  text-decoration: none;
}

.brand strong,
h1,
h2,
h3,
.consultation-card h3,
.site-footer h2 {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Baskerville Old Face", Georgia, serif;
}

.brand strong {
  font-size: 1.1rem;
  letter-spacing: 0.08em;
}

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

.site-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 1.1rem;
}

.site-nav a {
  text-decoration: none;
  color: var(--text-soft);
  font-size: 0.92rem;
  padding: 0.15rem 0;
}

.site-nav a:hover,
.site-nav a:focus-visible {
  color: var(--firefly);
}

.hero {
  padding: 4.8rem 0 3.8rem;
}

.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 2rem;
  align-items: stretch;
}

.hero__copy {
  display: flex;
  flex-direction: column;
  gap: 1.45rem;
}

.eyebrow {
  margin: 0;
  color: var(--firefly);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.78rem;
  font-weight: 700;
}

h1 {
  margin: 0;
  font-size: clamp(2.9rem, 5vw, 5rem);
  line-height: 1.12;
  letter-spacing: 0.01em;
  max-width: 12ch;
  text-shadow: 0 10px 34px rgba(0, 0, 0, 0.34);
}

.hero__lead {
  margin: 0;
  font-size: 1.08rem;
  color: var(--text-soft);
  max-width: 54ch;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.2rem;
  padding: 0.75rem 1.2rem;
  border-radius: 999px;
  border: 1px solid transparent;
  text-decoration: none;
  font-weight: 700;
  cursor: pointer;
  transition:
    transform 0.24s ease,
    background-color 0.24s ease,
    color 0.24s ease,
    border-color 0.24s ease,
    box-shadow 0.24s ease;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-2px);
}

.button--primary {
  background:
    linear-gradient(135deg, rgba(243, 231, 157, 0.94), rgba(181, 202, 139, 0.88));
  color: #122017;
  border-color: rgba(243, 231, 157, 0.34);
  box-shadow:
    0 18px 36px rgba(0, 0, 0, 0.3),
    0 0 34px rgba(243, 231, 157, 0.16);
}

.button--secondary {
  background: rgba(122, 146, 178, 0.12);
  color: #dbe7f8;
  border-color: rgba(127, 152, 187, 0.22);
}

.button--ghost {
  background: rgba(9, 16, 13, 0.2);
  color: var(--text);
  border-color: rgba(218, 233, 214, 0.14);
}

.hero__summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
  gap: 1rem;
}

.summary-card,
.panel-card,
.pillar-card,
.service-card,
.project-card,
.timeline-card,
.consultation-card,
.faq-column {
  position: relative;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid rgba(218, 233, 214, 0.1);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  backdrop-filter: blur(22px);
}

.summary-card::before,
.panel-card::before,
.pillar-card::before,
.service-card::before,
.project-card::before,
.timeline-card::before,
.consultation-card::before,
.faq-column::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.05), transparent 42%),
    linear-gradient(180deg, rgba(243, 231, 157, 0.02), transparent 54%);
  pointer-events: none;
}

.summary-card {
  padding: 1.4rem 1.45rem;
}

.summary-card--current {
  background:
    radial-gradient(circle at top right, rgba(145, 181, 135, 0.16), transparent 28%),
    var(--surface);
}

.summary-card--future {
  background:
    radial-gradient(circle at top left, rgba(127, 152, 187, 0.14), transparent 28%),
    var(--surface-soft);
}

.summary-card__label {
  display: inline-flex;
  margin-bottom: 0.75rem;
  color: var(--forest);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.summary-card h2 {
  margin: 0 0 0.65rem;
  font-size: 1.5rem;
}

.summary-card p {
  margin: 0;
  color: var(--text-soft);
}

.hero__panel {
  display: grid;
  gap: 1rem;
}

.panel-card {
  padding: 1.45rem 1.4rem;
}

.panel-card--primary {
  background:
    radial-gradient(circle at 18% 12%, rgba(243, 231, 157, 0.09), transparent 18%),
    linear-gradient(160deg, rgba(12, 22, 17, 0.94), rgba(7, 14, 11, 0.96));
  color: rgba(238, 245, 234, 0.92);
}

.panel-card--route {
  background:
    radial-gradient(circle at top right, rgba(243, 231, 157, 0.08), transparent 22%),
    var(--surface);
}

.panel-card__eyebrow,
.route-head span {
  margin: 0 0 0.8rem;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
}

.panel-list {
  margin: 0;
  padding-left: 1.1rem;
}

.panel-list li + li {
  margin-top: 0.6rem;
}

.route-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
  margin-bottom: 1rem;
}

.route-head small {
  color: var(--text-muted);
}

.route-steps {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1rem;
}

.route-steps li {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 0.8rem;
  align-items: start;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(218, 233, 214, 0.08);
}

.route-steps li:first-child {
  border-top: 0;
  padding-top: 0;
}

.route-steps strong {
  color: var(--firefly);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.82rem;
}

.route-steps p {
  margin: 0;
  color: var(--text-soft);
}

.section {
  padding: 2.1rem 0 4.4rem;
}

.section--tint {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.015), rgba(18, 29, 22, 0.14)),
    transparent;
}

.section--roadmap {
  padding-top: 2.4rem;
}

.section-heading {
  margin-bottom: 1.6rem;
  max-width: 72ch;
}

.section-heading--compact {
  max-width: 78ch;
}

.section-heading h2 {
  margin: 0.35rem 0 0.9rem;
  font-size: clamp(2rem, 3.5vw, 3rem);
  line-height: 1.22;
}

.section-heading p {
  margin: 0;
  color: var(--text-soft);
  font-size: 1rem;
}

.heading-badge,
.badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.pillar-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  gap: 1rem;
}

.pillar-card {
  padding: 1.55rem;
}

.pillar-card--current {
  background:
    radial-gradient(circle at top right, rgba(145, 181, 135, 0.14), transparent 28%),
    var(--surface);
}

.pillar-card--future {
  background:
    radial-gradient(circle at top left, rgba(127, 152, 187, 0.12), transparent 28%),
    var(--surface-soft);
  border-style: dashed;
}

.pillar-card__head {
  display: grid;
  gap: 0.8rem;
  margin-bottom: 1rem;
}

.pillar-card h3 {
  margin: 0;
  font-size: 1.55rem;
}

.pillar-note {
  margin: 1rem 0 0;
  color: var(--text-soft);
}

.feature-list {
  margin: 0;
  padding-left: 1.15rem;
}

.feature-list li + li {
  margin-top: 0.58rem;
}

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

.service-card {
  padding: 1.45rem;
  min-height: 100%;
}

.service-card--spotlight {
  grid-column: span 6;
  background:
    radial-gradient(circle at top right, rgba(243, 231, 157, 0.08), transparent 26%),
    var(--surface);
}

.service-card--landscape {
  grid-column: span 6;
  background:
    radial-gradient(circle at top left, rgba(145, 181, 135, 0.12), transparent 28%),
    var(--surface);
}

.service-card:not(.service-card--spotlight):not(.service-card--landscape) {
  grid-column: span 3;
}

.service-card h3,
.project-card h3,
.timeline-card strong,
.faq-column h3,
.consultation-card h3 {
  margin: 0 0 0.75rem;
  font-size: 1.3rem;
}

.service-card p,
.project-card p,
.timeline-card p,
.faq-column p,
.consultation-card p,
.site-footer p {
  margin: 0;
  color: var(--text-soft);
}

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

.project-card {
  padding: 1.5rem;
}

.project-card--caution {
  background:
    radial-gradient(circle at top left, rgba(243, 188, 157, 0.08), transparent 24%),
    var(--surface);
}

.project-roadmap__lead {
  margin-bottom: 1rem;
}

.roadmap-mini {
  margin: 0;
  padding-left: 1.1rem;
  color: var(--text-soft);
}

.roadmap-mini li + li {
  margin-top: 0.55rem;
}

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

.timeline-card {
  padding: 1.5rem;
}

.timeline-card--current {
  background:
    radial-gradient(circle at top right, rgba(243, 231, 157, 0.08), transparent 24%),
    var(--surface);
}

.timeline-card__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
}

.timeline-card__head span {
  color: var(--firefly);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.78rem;
  font-weight: 700;
}

.timeline-card__head strong {
  margin: 0;
}

.timeline-card__date {
  margin: 0.8rem 0 1rem;
  color: #d8d6a2;
  font-weight: 700;
}

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

.faq-column {
  padding: 1.4rem;
}

.faq-column__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  margin-bottom: 1rem;
}

.faq-mark {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(243, 231, 157, 0.12);
  color: var(--firefly);
  font-weight: 800;
  box-shadow: var(--glow);
}

.faq-mark--muted {
  background: rgba(127, 152, 187, 0.12);
  color: #d2def1;
}

.faq-column__head h3 {
  margin-bottom: 0.3rem;
}

.faq-column__head p {
  margin: 0;
  font-size: 0.96rem;
}

details {
  border-top: 1px solid rgba(218, 233, 214, 0.08);
  padding: 1rem 0;
}

details:first-of-type {
  border-top: 0;
  padding-top: 0;
}

summary {
  list-style: none;
  cursor: pointer;
  font-weight: 700;
  padding-right: 2rem;
  position: relative;
}

summary::-webkit-details-marker {
  display: none;
}

summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: -0.1rem;
  font-size: 1.2rem;
  color: var(--firefly);
}

details[open] summary::after {
  content: "−";
}

details p {
  margin-top: 0.7rem;
}

.section--consultation {
  padding-bottom: 4.8rem;
}

.consultation {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: 1rem;
  align-items: stretch;
}

.consultation-card {
  padding: 1.55rem;
  background:
    radial-gradient(circle at top right, rgba(243, 231, 157, 0.08), transparent 24%),
    var(--surface);
}

.consultation-card .button {
  margin-top: 1rem;
}

.contact-form {
  display: grid;
  gap: 1rem;
}

.contact-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.form-field {
  display: grid;
  gap: 0.45rem;
}

.form-field span {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  border: 1px solid rgba(218, 233, 214, 0.12);
  border-radius: 16px;
  background: rgba(6, 14, 10, 0.72);
  padding: 0.86rem 0.95rem;
  font: inherit;
  color: var(--text);
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background-color 0.2s ease;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: rgba(243, 231, 157, 0.28);
  box-shadow: 0 0 0 4px rgba(243, 231, 157, 0.07);
  background: rgba(8, 16, 12, 0.88);
}

.form-field textarea {
  resize: vertical;
  min-height: 12rem;
}

.checkbox-field {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.94rem;
  color: var(--text-soft);
}

.checkbox-field input {
  margin-top: 0.18rem;
}

.honeypot-field {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}

.contact-form__actions {
  display: grid;
  gap: 0.65rem;
}

.submit-button[disabled] {
  opacity: 0.72;
  cursor: wait;
}

.form-status {
  margin: 0;
  min-height: 1.6rem;
  font-size: 0.94rem;
}

.form-status[data-tone="success"] {
  color: var(--firefly);
  font-weight: 700;
}

.form-status[data-tone="error"] {
  color: #f3b49b;
  font-weight: 700;
}

.consultation-note {
  margin-top: 0.95rem;
  font-size: 0.94rem;
  color: var(--text-muted);
}

.site-footer {
  background:
    linear-gradient(180deg, rgba(4, 8, 6, 0.32), rgba(4, 8, 6, 0.9)),
    rgba(3, 7, 5, 0.92);
  color: rgba(238, 245, 234, 0.9);
  padding: 2rem 0 2.4rem;
  border-top: 1px solid rgba(218, 233, 214, 0.08);
}

.site-footer__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.75fr);
  gap: 1.2rem;
  align-items: start;
}

.site-footer h2 {
  margin: 0 0 0.55rem;
  font-size: 1.8rem;
}

.site-footer p,
.site-footer a {
  color: rgba(238, 245, 234, 0.72);
}

.footer-meta {
  display: grid;
  gap: 0.5rem;
}

@keyframes rise-in {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes drift-far {
  from {
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    transform: translate3d(-3%, 2%, 0) scale(1.03);
  }
}

@keyframes drift-mid {
  from {
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    transform: translate3d(2.5%, -2%, 0) scale(1.04);
  }
}

@keyframes drift-near {
  from {
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    transform: translate3d(-2%, 1.4%, 0) scale(1.05);
  }
}

@keyframes twinkle {
  from {
    opacity: 0.24;
  }

  50% {
    opacity: 0.5;
  }

  to {
    opacity: 0.82;
  }
}

.hero__copy,
.hero__panel,
.section-heading,
.pillar-card,
.service-card,
.project-card,
.timeline-card,
.faq-column,
.consultation-card {
  animation: rise-in 0.7s ease both;
}

.hero__panel {
  animation-delay: 0.08s;
}

.pillar-card:nth-child(2),
.service-card:nth-child(2),
.project-card:nth-child(2),
.timeline-card:nth-child(2),
.faq-column:nth-child(2) {
  animation-delay: 0.1s;
}

.service-card:nth-child(3),
.project-card:nth-child(3),
.timeline-card:nth-child(3) {
  animation-delay: 0.16s;
}

.service-card:nth-child(4),
.project-card:nth-child(4) {
  animation-delay: 0.22s;
}

.service-card:nth-child(5) {
  animation-delay: 0.28s;
}

@media (max-width: 1080px) {
  .hero__grid,
  .consultation,
  .site-footer__inner,
  .pillar-grid,
  .timeline,
  .faq-grid,
  .project-grid,
  .contact-form__grid {
    grid-template-columns: 1fr;
  }

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

  .service-card--spotlight,
  .service-card--landscape,
  .service-card:not(.service-card--spotlight):not(.service-card--landscape) {
    grid-column: span 6;
  }
}

@media (max-width: 820px) {
  .status-band__inner,
  .site-header__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .site-nav {
    justify-content: flex-start;
    width: 100%;
    gap: 0.8rem 1rem;
  }

  .hero__actions .button {
    flex: 1 1 240px;
  }

  .hero {
    padding-top: 3.5rem;
  }

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

  .service-card--spotlight,
  .service-card--landscape,
  .service-card:not(.service-card--spotlight):not(.service-card--landscape) {
    grid-column: span 6;
  }
}

@media (max-width: 640px) {
  :root {
    --container: min(100vw - 1.4rem, 100%);
  }

  body {
    font-size: 0.98rem;
  }

  h1 {
    max-width: none;
  }

  .hero__actions,
  .status-band__inner,
  .badge-row,
  .heading-badge {
    gap: 0.7rem;
  }

  .status-band__inner p {
    align-items: flex-start;
  }

  .route-head,
  .timeline-card__head {
    flex-wrap: wrap;
  }

  .site-nav a {
    font-size: 0.88rem;
  }

  .button {
    width: 100%;
  }

  .route-steps li {
    grid-template-columns: 1fr;
  }

  .faq-column,
  .timeline-card,
  .project-card,
  .service-card,
  .summary-card,
  .consultation-card,
  .pillar-card,
  .panel-card {
    padding: 1.2rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}
