/* =========================================================
   SITE EXTRAS — production layer on top of the canonical design
   export (colors_and_type.css + modern.css). Kept separate so the
   design files stay pristine. Adds: skip link, mobile nav, a11y
   focus, reduced-motion.
   ========================================================= */

/* Skip link (a11y) */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 100;
  background: var(--color-moss-dark);
  color: var(--color-sand-warm);
  padding: 10px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  border-radius: 0 0 6px 0;
}
.skip-link:focus { left: 0; }

/* Mobile nav burger — hidden on desktop */
.nav-burger {
  display: none;
  appearance: none;
  background: transparent;
  border: 0;
  width: 40px;
  height: 40px;
  cursor: pointer;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 0;
}
.nav-burger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-ink);
  transition: transform var(--dur-2) var(--ease), opacity var(--dur-1) var(--ease);
}
.nav.nav-open .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav.nav-open .nav-burger span:nth-child(2) { opacity: 0; }
.nav.nav-open .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 960px) {
  .nav-burger { display: inline-flex; }

  /* Reveal the hidden links as a stacked panel when toggled open */
  .nav.nav-open .nav-links {
    display: flex;
    position: absolute;
    top: 76px;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    background: rgba(237, 235, 228, 0.98);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(170, 143, 87, 0.35);
    padding: 8px 0 16px;
    box-shadow: 0 16px 32px rgba(27, 35, 29, 0.12);
    max-height: calc(100vh - 76px);
    overflow-y: auto;
  }
  .nav.nav-open .nav-links > a,
  .nav.nav-open .nav-link-group > a {
    padding: 13px 24px;
    width: 100%;
  }
  .nav.nav-open .nav-links a::after { display: none; }

  /* Flatten the hover dropdowns into the stacked panel */
  .nav.nav-open .nav-link-group { display: block; width: 100%; }
  .nav.nav-open .nav-link-group > a::before { display: none; }
  .nav.nav-open .nav-dropdown {
    position: static;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    min-width: 0;
    margin: 0;
    padding: 0 0 6px;
    border: 0;
    background: transparent;
    box-shadow: none;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }
  .nav.nav-open .nav-dropdown a { padding-left: 40px; }
}

/* Honor reduced-motion: kill reveal transitions + scroll progress motion */
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  * { scroll-behavior: auto !important; }
}

/* Hero text: the global p { color: var(--fg) } rule directly overrides inherited
   color from .hero. Force paragraphs inside the hero to use the hero's own color. */
.hero p { color: inherit; }

/* Legal / utility page prose (privacy, terms) */
.legal{ max-width: 720px; }
.legal h2{
  font-family: var(--font-display); font-weight: 300; text-transform: none;
  font-size: clamp(22px, 2vw, 30px); color: var(--color-ink);
  margin: 36px 0 12px; letter-spacing: -0.01em;
}
.legal p{
  font-family: var(--font-body); font-size: 17px; line-height: 1.7;
  color: var(--fg-2); margin: 0 0 18px;
}
.legal p.muted{ color: var(--fg-muted); font-style: italic; }
.legal a{
  color: var(--color-moss-light); text-decoration: none;
  border-bottom: 1px solid var(--color-gold-antique); padding-bottom: 1px; font-weight: 500;
}
.legal h3{
  font-family: var(--font-display); font-weight: 500; text-transform: none;
  font-size: clamp(17px, 1.5vw, 21px); color: var(--color-ink);
  margin: 28px 0 8px; letter-spacing: -0.01em;
}
.legal ol, .legal ul{
  font-family: var(--font-body); font-size: 17px; line-height: 1.7;
  color: var(--fg-2); margin: 0 0 18px; padding-left: 24px;
}
.legal li{ margin-bottom: 6px; }
.legal table{
  width: 100%; border-collapse: collapse;
  font-family: var(--font-body); font-size: 15px; line-height: 1.5;
  color: var(--fg-2); margin: 0 0 24px; overflow-x: auto; display: block;
}
.legal th{
  text-align: left; font-weight: 600; color: var(--color-ink);
  padding: 10px 12px; background: rgba(170,143,87,0.12);
  border-bottom: 2px solid var(--color-gold-antique);
}
.legal td{
  padding: 9px 12px; vertical-align: top;
  border-bottom: 1px solid rgba(170,143,87,0.2);
}
.legal tr:last-child td{ border-bottom: 0; }

/* Lead-gen / newsletter form messages */
.kit-msg{ font-family: var(--font-body); font-size: 15px; line-height: 1.5; }
.kit-msg.is-ok{
  color: var(--color-moss-dark);
  background: var(--color-gold-antique);
  padding: 10px 14px;
  border-radius: 6px;
  font-weight: 600;
}
.kit-msg.is-err{
  color: #fff;
  background: var(--color-oxblood);
  padding: 10px 14px;
  border-radius: 6px;
  font-weight: 600;
}
