/* Cassie & the Bees — warm, readable, mobile-first */

:root {
  /* Safety / high-visibility yellow page background */
  --color-bg: #ffdc2e;
  --color-surface: #fffef2;
  --color-text: #1f1a12;
  --color-text-muted: #453d2a;
  --color-accent: #c4850c;
  --color-accent-dark: #8a5e06;
  --color-honey: #c9a010;
  --color-honey-soft: #fff59a;
  --color-border: #b8941a;
  --color-card-friendly: #fff9e0;
  --color-card-spicy: #ffefe4;
  --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --radius: 12px;
  --shadow: 0 8px 24px rgba(31, 26, 18, 0.12);
  --max-width: 40rem;
  --space-xs: 0.35rem;
  --space-sm: 0.75rem;
  --space-md: 1.25rem;
  --space-lg: 2rem;
  --space-xl: 3rem;
  /* Skep-style contact buttons */
  --hive-band-a: #f2e4c4;
  --hive-band-b: #dcc48a;
  --hive-band-shadow: #b8941a;
  --hive-shade-top: rgba(255, 255, 255, 0.38);
  --hive-shade-bottom: rgba(60, 40, 12, 0.12);
  --hive-border: #4a3410;
  --hive-entrance: #2a1c0a;
  --hive-dome-r: 1.65rem;
  --hive-foot-r: 0.45rem;
  --hive-band-size: 9px;
}

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

html {
  scroll-behavior: smooth;
  overflow-x: clip;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--color-text);
  background: var(--color-bg);
  overflow-x: hidden;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 100;
  padding: var(--space-sm) var(--space-md);
  background: var(--color-accent-dark);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}

.skip-link:focus {
  left: var(--space-md);
  top: var(--space-md);
  outline: 3px solid var(--color-honey);
  outline-offset: 2px;
}

.wrap {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: 1rem;
}

/* Header */
.site-header {
  padding: var(--space-lg) 0 var(--space-lg);
  background: linear-gradient(
    165deg,
    var(--color-honey-soft) 0%,
    var(--color-bg) 55%,
    var(--color-bg) 100%
  );
  border-bottom: 1px solid var(--color-border);
}

.hero-photo {
  margin: 0 0 var(--space-lg);
  max-width: 100%;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}

.hero-photo img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

.site-header h1 {
  margin: 0 0 var(--space-sm);
  font-size: clamp(1.85rem, 5vw, 2.35rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.tagline {
  margin: 0 0 var(--space-md);
  font-size: 1.125rem;
  color: var(--color-text);
  max-width: 36ch;
}

.region {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--color-text-muted);
}

.region strong {
  color: var(--color-text);
}

/* Main */
main {
  padding: var(--space-xl) 0;
}

.section {
  margin-bottom: var(--space-xl);
}

.section:last-child {
  margin-bottom: 0;
}

.section h2 {
  margin: 0 0 var(--space-md);
  font-size: 1.35rem;
  font-weight: 750;
  letter-spacing: -0.02em;
  color: var(--color-text);
}

.section h3 {
  margin: 0 0 var(--space-sm);
  font-size: 1.1rem;
  font-weight: 700;
}

.section p {
  margin: 0 0 var(--space-md);
  color: var(--color-text-muted);
}

.section p:last-child {
  margin-bottom: 0;
}

.list-plain {
  margin: 0 0 var(--space-md);
  padding-left: 1.25rem;
  color: var(--color-text-muted);
}

.list-plain li {
  margin-bottom: var(--space-xs);
}

.list-plain li:last-child {
  margin-bottom: 0;
}

.note {
  padding: var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-size: 0.9375rem;
}

.pricing-intro {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
}

.pricing-intro strong {
  color: var(--color-text);
}

.pricing-grid {
  display: grid;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

@media (min-width: 640px) {
  .pricing-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-lg);
  }
}

.card {
  padding: var(--space-lg);
  border-radius: var(--radius);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}

.card-friendly {
  background: var(--color-card-friendly);
}

.card-spicy {
  background: var(--color-card-spicy);
}

.card p {
  margin-bottom: var(--space-md);
}

.card p:last-child {
  margin-bottom: 0;
}

/* Contact */
.section-contact {
  padding: var(--space-lg);
  text-align: center;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.section-contact h2 {
  margin-bottom: var(--space-sm);
}

/* Specificity beats `.section p` so max-width blocks stay centered (margin auto). */
.section-contact p.contact-subline {
  margin: var(--space-sm) auto var(--space-md);
  max-width: 28rem;
  font-size: 0.9375rem;
  line-height: 1.55;
  text-align: center;
  color: var(--color-text-muted);
}

.section-contact p.contact-subline:last-child {
  margin-bottom: 0;
}

.contact-subline .contact-inline {
  color: var(--color-text);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

.contact-subline .contact-inline:hover {
  color: var(--color-accent-dark);
}

.contact-subline .contact-inline:focus-visible {
  outline: 3px solid var(--color-honey);
  outline-offset: 2px;
  border-radius: 2px;
}

.button {
  position: relative;
  display: inline-block;
  margin-top: var(--space-sm);
  padding: 0.85rem 1.4rem 1rem;
  min-height: 2.75rem;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.25;
  text-decoration: none;
  cursor: pointer;
  color: var(--color-text);
  border: 2px solid var(--hive-border);
  border-radius: var(--hive-dome-r) var(--hive-dome-r) var(--hive-foot-r) var(--hive-foot-r);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.35) inset,
    0 -1px 0 rgba(0, 0, 0, 0.06) inset,
    0 3px 6px rgba(31, 26, 18, 0.18);
  background-color: var(--hive-band-b);
  background-image:
    linear-gradient(
      180deg,
      var(--hive-shade-top) 0%,
      transparent 38%,
      transparent 62%,
      var(--hive-shade-bottom) 100%
    ),
    repeating-linear-gradient(
      180deg,
      var(--hive-band-a) 0 calc(var(--hive-band-size) - 2px),
      var(--hive-band-shadow) calc(var(--hive-band-size) - 2px) var(--hive-band-size)
    );
}

.button::after {
  content: "";
  position: absolute;
  bottom: 0.35rem;
  left: 50%;
  width: 0.55rem;
  height: 0.38rem;
  transform: translateX(-50%);
  background: var(--hive-entrance);
  border-radius: 50% 50% 45% 45%;
  opacity: 0.9;
  pointer-events: none;
}

.button:hover {
  filter: brightness(1.04) saturate(1.05);
}

.button:focus-visible {
  outline: 3px solid var(--color-accent-dark);
  outline-offset: 3px;
}

/* Video */
.section-video .video-intro {
  margin: 0 0 var(--space-md);
  text-align: center;
  color: var(--color-text-muted);
}

.section-video h2 {
  text-align: center;
}

.section-video .video-frame {
  margin: 0 auto;
  max-width: 42rem;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  background: #000;
}

.section-video video {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

/* Footer */
.site-footer {
  padding: var(--space-lg) 0 var(--space-xl);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg);
}

.site-footer p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-align: center;
}

/* Decorative flying bee (viewport loop) */
.bee-flight {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 10;
  width: clamp(2.5rem, 10vw, 5rem);
  height: auto;
  pointer-events: none;
  transform-origin: center center;
  opacity: 0.92;
  will-change: transform;
  animation: bee-orbit 22s linear infinite;
}

@keyframes bee-orbit {
  0% {
    transform: translate(4vw, 12vh) rotate(12deg);
  }
  20% {
    transform: translate(calc(100vw - 100% - 6vw), 8vh) rotate(-18deg);
  }
  40% {
    transform: translate(calc(100vw - 100% - 4vw),42vh) rotate(8deg);
  }
  60% {
    transform: translate(10vw, calc(100vh - 100% - 18vh)) rotate(-22deg);
  }
  80% {
    transform: translate(6vw, 55vh) rotate(15deg);
  }
  100% {
    transform: translate(4vw, 12vh) rotate(12deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .bee-flight {
    animation: none !important;
    opacity: 0;
    will-change: auto;
  }

  .bee-hive-fx {
    display: none !important;
  }
}

/* Hive button click: bee emerges, orbits 5×, returns (driven by contact-bee.js) */
.bee-hive-fx {
  position: fixed;
  z-index: 60;
  left: 0;
  top: 0;
  width: clamp(2rem, 11vw, 4.5rem);
  height: auto;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transform-origin: center center;
  --orbit-r: 48px;
  will-change: transform, opacity;
}

.bee-hive-fx.is-active {
  visibility: visible;
  opacity: 1;
  animation: bee-hive-orbit 2.4s ease-in-out forwards;
}

@keyframes bee-hive-orbit {
  0% {
    transform: translate(-50%, -50%) rotate(0deg) translateY(0) scale(0);
  }
  10% {
    transform: translate(-50%, -50%) rotate(0deg) translateY(0) scale(1);
  }
  12% {
    transform: translate(-50%, -50%) rotate(0deg) translateY(calc(-1 * var(--orbit-r))) scale(1);
  }
  88% {
    transform: translate(-50%, -50%) rotate(1800deg) translateY(calc(-1 * var(--orbit-r))) scale(1);
  }
  92% {
    transform: translate(-50%, -50%) rotate(1800deg) translateY(0) scale(1);
  }
  100% {
    transform: translate(-50%, -50%) rotate(1800deg) translateY(0) scale(0);
  }
}
