/* =========================================================
   Evergrain Photobooth — Page-specific styles
   ========================================================= */

/* ---------- Homepage Hero ----------
   Background photo with dark evergreen gradient overlay.
   The overlay is intentionally darkest on the left (where the title +
   lede sit) to maintain WCAG AA contrast (~4.6:1 for body text on
   any photo brightness), and lightens on the right so the image
   remains visible behind the floating logo monogram.
*/
.hero {
  position: relative;
  min-height: 100vh;
  background-color: var(--evergreen-dark); /* loaded-image fallback */
  background-image:
    linear-gradient(
      110deg,
      rgba(22, 48, 36, 0.90) 0%,
      rgba(22, 48, 36, 0.78) 50%,
      rgba(22, 48, 36, 0.55) 100%
    ),
    url("https://zjwobaopuhanqsyyilzb.supabase.co/storage/v1/object/public/media/images/homepage/Homepage%20Hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--linen);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-block: clamp(7rem, 14vw, 10rem) clamp(2.5rem, 5vw, 4rem);
  overflow: hidden;
  gap: clamp(2rem, 5vh, 4rem);
}
/* On narrow screens, even out the overlay so text on either side stays legible
   regardless of how the image crops. */
@media (max-width: 720px) {
  .hero {
    background-image:
      linear-gradient(rgba(22, 48, 36, 0.85), rgba(22, 48, 36, 0.85)),
      url("https://zjwobaopuhanqsyyilzb.supabase.co/storage/v1/object/public/media/images/homepage/Homepage%20Hero.jpg");
  }
}
.hero__content {
  position: relative;
  z-index: 2;
  max-width: 920px;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hero__eyebrow {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: var(--space-md);
}
.hero__eyebrow::before {
  content: "";
  width: 48px;
  height: 1px;
  background: var(--champagne);
}
.hero__eyebrow span {
  font-family: var(--font-eyebrow);
  font-size: 0.78rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--champagne);
  font-weight: 500;
}
.hero__title {
  font-family: var(--font-display);
  font-size: var(--fs-hero);
  font-weight: 300;
  line-height: 0.98;
  letter-spacing: -0.03em;
  color: var(--linen);
  margin: 0 0 var(--space-lg);
  text-wrap: balance;
}
.hero__title em {
  font-style: italic;
  font-weight: 300;
  color: var(--champagne);
}
.hero__lede {
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  line-height: 1.55;
  color: var(--champagne);
  max-width: 56ch;
  margin-bottom: var(--space-lg);
}
.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.hero__meta {
  position: relative;
  z-index: 2;
  flex: 0 0 auto;
}
.hero__meta-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-md);
  border-top: 1px solid rgba(244, 237, 224, 0.15);
  padding-top: var(--space-md);
}
.hero__meta-item {
  font-family: var(--font-eyebrow);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--champagne);
}
.hero__meta-item strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 300;
  letter-spacing: 0;
  text-transform: none;
  color: var(--linen);
  margin-bottom: 0.2rem;
}

/* Hero floating logo monogram */
.hero__monogram {
  position: absolute;
  top: 50%;
  right: -4%;
  transform: translateY(-50%);
  width: clamp(380px, 50vw, 720px);
  opacity: 0.07;
  z-index: 1;
  pointer-events: none;
  filter: brightness(0) invert(1);
}

@media (max-width: 720px) {
  .hero__monogram {
    width: 120%;
    right: -10%;
    opacity: 0.05;
  }
}

/* ---------- Homepage "What we do" CTA cards ---------- */
.cta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

/* ---------- Homepage "How it works" edge-to-edge wave carousel ----------
   - Track is 2x duplicated so the loop is seamless
   - Carousel translates X 0 → -50% (one full set width) infinitely
   - Each card bobs on translateY with its own --bob-delay so the
     5 boxes form a traveling sine wave (one wavelength = 5 cards)
   - No hover pause, no interaction — pure ambient motion
*/
.how-carousel {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  overflow: hidden;
  /* Top + bottom padding gives the bob animation room without clipping */
  padding-block: 2.5rem;
  /* Soft edge fades to suggest "infinite" */
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%);
}
.how-carousel__track {
  display: flex;
  gap: clamp(1.5rem, 2.5vw, 2.5rem);
  width: max-content;
  animation: how-carousel-scroll 45s linear infinite;
  will-change: transform;
}
@keyframes how-carousel-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.how-card {
  flex: 0 0 auto;
  width: clamp(280px, 26vw, 340px);
}
/* Inner element handles the vertical bob so it doesn't fight the
   parent track's translateX. Stacking transforms on different
   elements composes cleanly at the rendering layer. */
.how-card__bob {
  background: var(--evergreen);
  color: var(--linen);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  min-height: 290px;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border: 1px solid rgba(217, 201, 168, 0.10);
  box-shadow: 0 18px 40px -20px rgba(26, 20, 16, 0.35);
  animation: how-card-bob 3.5s ease-in-out infinite;
  animation-delay: var(--bob-delay, 0s);
  will-change: transform;
}
/* Subtle topographic texture on each card */
.how-card__bob::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../assets/img/topographic-bg.svg");
  background-size: 220%;
  background-position: center;
  opacity: 0.05;
  pointer-events: none;
  z-index: -1;
}

.how-card__icon-wrap {
  width: 60px;
  height: 60px;
  border-radius: 999px;
  background: rgba(164, 122, 42, 0.16);
  color: var(--brass-light);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-sm);
}
.how-card__icon {
  width: 30px;
  height: 30px;
}
.how-card__step {
  font-family: var(--font-eyebrow);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--champagne);
  opacity: 0.7;
}
.how-card__title {
  font-family: var(--font-display);
  font-size: 1.85rem;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--linen);
  margin: 0;
  line-height: 1.05;
}
.how-card__copy {
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--champagne);
  opacity: 0.85;
  margin: 0;
  max-width: none;
}

@keyframes how-card-bob {
  0%, 100% { transform: translateY(-22px); }
  50%      { transform: translateY(32px); }
}

/* Honor user preference — kill the motion if requested */
@media (prefers-reduced-motion: reduce) {
  .how-carousel__track,
  .how-card__bob {
    animation: none;
  }
}

/* ---------- Stats strip ---------- */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-lg);
  padding-block: var(--space-xl);
  border-top: 1px solid rgba(92, 74, 53, 0.18);
  border-bottom: 1px solid rgba(92, 74, 53, 0.18);
}
.stat__number {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  font-weight: 300;
  line-height: 1;
  color: var(--evergreen);
  margin-bottom: 0.5rem;
  letter-spacing: -0.02em;
}
.stat__label {
  font-family: var(--font-eyebrow);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bark);
}

/* ---------- Testimonials ---------- */
.testimonial {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}
.testimonial__quote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.5rem, 2.8vw, 2.25rem);
  line-height: 1.3;
  color: var(--char);
  margin-bottom: var(--space-md);
  text-wrap: balance;
}
.testimonial__author {
  font-family: var(--font-eyebrow);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bark);
}

/* ---------- Inquiry form section ---------- */
.inquiry {
  background: var(--linen-warm);
}
.inquiry__intro {
  margin-bottom: var(--space-xl);
}

/* ---------- Service Areas ---------- */
.areas {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}
.area-pill {
  background: var(--white);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid rgba(92, 74, 53, 0.15);
  border-radius: 999px;
  font-size: 0.95rem;
  text-align: center;
  color: var(--char);
  text-decoration: none;
  transition: background-color var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
}
a.area-pill:hover {
  background: var(--evergreen);
  color: var(--linen);
  border-color: var(--evergreen);
  transform: translateY(-2px);
}

/* ---------- Our Story page ---------- */
.story-prose {
  max-width: 56ch;
  margin: 0 auto;
}
.story-prose p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--char);
  margin-bottom: var(--space-md);
  max-width: none;
}
.story-prose p:last-child { margin-bottom: 0; }
.story-prose strong { font-weight: 600; }
.story-prose em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
}
.story-signoff {
  margin-top: var(--space-lg);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--bark);
}

/* Editorial image mosaic — 7 images in a varied grid */
.story-mosaic {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-md);
  margin-block: var(--space-2xl);
}
.story-mosaic__item {
  overflow: hidden;
  border-radius: var(--radius-md);
  background: var(--linen-warm);
  position: relative;
}
.story-mosaic__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease-out);
}
.story-mosaic__item:hover img { transform: scale(1.03); }

/* Specific cell sizing for editorial rhythm */
.story-mosaic__item--1 { grid-column: span 4; aspect-ratio: 16 / 11; }
.story-mosaic__item--2 { grid-column: span 2; aspect-ratio: 3 / 4; }
.story-mosaic__item--3 { grid-column: span 2; aspect-ratio: 1 / 1; }
.story-mosaic__item--4 { grid-column: span 2; aspect-ratio: 1 / 1; }
.story-mosaic__item--5 { grid-column: span 2; aspect-ratio: 1 / 1; }
.story-mosaic__item--6 { grid-column: span 3; aspect-ratio: 4 / 3; }
.story-mosaic__item--7 { grid-column: span 3; aspect-ratio: 4 / 3; }

@media (max-width: 800px) {
  .story-mosaic { grid-template-columns: repeat(2, 1fr); }
  .story-mosaic__item--1,
  .story-mosaic__item--2,
  .story-mosaic__item--3,
  .story-mosaic__item--4,
  .story-mosaic__item--5,
  .story-mosaic__item--6,
  .story-mosaic__item--7 { grid-column: span 1; }
  .story-mosaic__item--1 { grid-column: 1 / -1; aspect-ratio: 16 / 11; }
}

.story-timeline {
  display: grid;
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}
.story-timeline__item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-lg);
  align-items: start;
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid rgba(92, 74, 53, 0.15);
}
.story-timeline__item:last-child { border-bottom: 0; }
.story-timeline__year {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 300;
  color: var(--brass);
  line-height: 1;
}
.story-timeline__body h3 {
  margin-bottom: var(--space-sm);
}

.values-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}
.value {
  border-top: 2px solid var(--brass);
  padding-top: var(--space-md);
}
.value h3 {
  font-size: 1.25rem;
  margin-bottom: var(--space-xs);
}
.value p {
  font-size: 0.95rem;
  color: var(--bark);
}

/* ---------- The Booth page ---------- */
.booth-hero {
  background: var(--evergreen);
  color: var(--linen);
  position: relative;
  padding-block: clamp(6rem, 12vw, 9rem) clamp(4rem, 6vw, 6rem);
}
.booth-spec {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-md);
  align-items: start;
  padding-block: var(--space-md);
  border-bottom: 1px solid rgba(92, 74, 53, 0.15);
}
.booth-spec:last-child { border-bottom: 0; }
.booth-spec__number {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--brass);
  min-width: 2.5rem;
  letter-spacing: 0.05em;
}
.booth-spec__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  margin: 0 0 var(--space-xs);
}
.booth-spec__copy {
  font-size: 0.95rem;
  color: var(--bark);
  margin: 0;
  max-width: 56ch;
}

.booth-image-frame {
  background: var(--char);
  border-radius: var(--radius-md);
  aspect-ratio: 4 / 5;
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.booth-image-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ---------- Packages page ---------- */
.packages {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-lg);
  margin-top: var(--space-xl);
  align-items: stretch;
}

.package {
  position: relative;
  background: var(--white);
  border: 1.5px solid rgba(92, 74, 53, 0.12);
  border-radius: var(--radius-md);
  padding: var(--space-xl) var(--space-lg) var(--space-lg);
  display: flex;
  flex-direction: column;
  transition: transform var(--dur-med) var(--ease-out), border-color var(--dur-med) var(--ease-out), box-shadow var(--dur-med) var(--ease-out);
}
.package:hover {
  transform: translateY(-6px);
  border-color: var(--brass);
  box-shadow: var(--shadow-md);
}
.package.is-selected {
  border-color: var(--evergreen);
  border-width: 2px;
  box-shadow: 0 0 0 4px rgba(31, 67, 50, 0.08), var(--shadow-md);
}

.package--featured {
  background: var(--evergreen);
  color: var(--linen);
  border-color: var(--evergreen);
}
.package--featured h2,
.package--featured h3,
.package--featured .package__price-amount { color: var(--linen); }
.package--featured .package__features li { color: var(--champagne); border-color: rgba(244, 237, 224, 0.18); }
.package--featured .package__tag {
  background: var(--brass);
  color: var(--white);
}
.package--featured.is-selected {
  box-shadow: 0 0 0 4px rgba(164, 122, 42, 0.25), var(--shadow-lg);
}

.package__tag {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--brass);
  color: var(--white);
  font-family: var(--font-eyebrow);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.45rem 1rem;
  border-radius: 999px;
  font-weight: 600;
}

.package__name {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 300;
  margin: 0 0 var(--space-xs);
  letter-spacing: -0.01em;
}
.package__tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--brass);
  margin-bottom: var(--space-lg);
}
.package--featured .package__tagline { color: var(--champagne); }

.package__price {
  margin-bottom: var(--space-lg);
}
.package__price-amount {
  font-family: var(--font-display);
  font-size: 3.25rem;
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.03em;
}
.package__price-amount sup {
  font-size: 1.25rem;
  vertical-align: super;
  margin-right: 0.2rem;
  font-weight: 400;
}
.package__price-meta {
  font-family: var(--font-eyebrow);
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bark);
  margin-top: 0.3rem;
}
.package--featured .package__price-meta { color: var(--champagne); }

.package__features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-lg);
  flex: 1;
}
.package__features li {
  padding: 0.7rem 0 0.7rem 1.8rem;
  border-bottom: 1px solid rgba(92, 74, 53, 0.1);
  font-size: 0.95rem;
  position: relative;
}
.package__features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1rem;
  width: 14px;
  height: 8px;
  border-left: 1.5px solid var(--brass);
  border-bottom: 1.5px solid var(--brass);
  transform: rotate(-45deg);
}

.package__cta {
  margin-top: auto;
}

.package__selected-indicator {
  display: none;
  text-align: center;
  margin-top: var(--space-sm);
  font-family: var(--font-eyebrow);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brass);
}
.package.is-selected .package__selected-indicator {
  display: block;
}

/* ---------- Every Package Includes section (on /packages + area pages) ---------- */
.every-package {
  margin-top: var(--space-2xl);
  padding: var(--space-xl) var(--space-lg);
  background: var(--linen-warm);
  border-radius: var(--radius-md);
  border: 1px solid rgba(92, 74, 53, 0.10);
}
.every-package__header {
  text-align: center;
  margin-bottom: var(--space-lg);
}
.every-package__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  font-weight: 300;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--char);
}
.every-package__list {
  list-style: none;
  padding: 0;
  margin: 0;
  columns: 2;
  column-gap: clamp(2rem, 5vw, 4rem);
  max-width: 880px;
  margin-inline: auto;
}
.every-package__list li {
  padding: 0.65rem 0 0.65rem 1.8rem;
  border-bottom: 1px solid rgba(92, 74, 53, 0.12);
  font-size: 0.98rem;
  position: relative;
  break-inside: avoid;
  color: var(--char);
}
.every-package__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.95rem;
  width: 14px;
  height: 8px;
  border-left: 1.5px solid var(--brass);
  border-bottom: 1.5px solid var(--brass);
  transform: rotate(-45deg);
}
@media (max-width: 640px) {
  .every-package__list { columns: 1; }
}

.compare-note {
  text-align: center;
  margin-top: var(--space-xl);
  color: var(--bark);
  font-style: italic;
  font-family: var(--font-display);
  font-size: 1.05rem;
}

/* ---------- Add-Ons page — Sticky "currently building on" banner ----------
   Champagne background sits between the linen page and dark evergreen
   hero — distinct enough to read as a status indicator, soft enough not
   to compete with the brand. Extends from <body> top so the transparent
   navbar overlays its champagne color (no top-of-page strip artifact).
*/
.selected-package-banner {
  background: var(--champagne);
  color: var(--char);
  padding: calc(80px + 0.85rem) 0 0.85rem;
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(26, 20, 16, 0.08);
}
.selected-package-banner__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.selected-package-banner p {
  margin: 0;
  color: var(--bark);
  font-family: var(--font-eyebrow);
  font-size: 0.74rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
/* Small brass dot — quiet visual anchor */
.selected-package-banner p::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brass);
  flex: 0 0 auto;
}
.selected-package-banner p strong {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--evergreen);
  font-size: 1.15rem;
  letter-spacing: -0.01em;
  text-transform: none;
}
/* Change-package link override for the champagne banner */
.selected-package-banner .link-arrow {
  color: var(--evergreen);
  font-weight: 600;
}
.selected-package-banner .link-arrow:hover {
  color: var(--brass);
}
.selected-package-banner.is-hidden { display: none; }

.no-package-banner {
  background: rgba(164, 122, 42, 0.12);
  border-left: 3px solid var(--brass);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-xl);
  border-radius: var(--radius-sm);
}
.no-package-banner p { margin: 0; font-size: 0.95rem; }

.addons {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-xl);
}

/* Force exactly 2 columns for categories with 4 cards (Branded Touch Points). */
.addons--2col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 640px) {
  .addons--2col { grid-template-columns: 1fr; }
}

/* Trio of single-card categories side-by-side at 1/3 width each
   (Print Upgrades + Props + Backdrops). Collapses to a single column
   below 900px since 3 cards across get cramped on tablet. */
.addon-category-trio {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}
.addon-category-trio > .addon-category {
  margin-top: 0;
  /* Make each column a flex column so the inner grid + card can grow
     to fill the tallest sibling's height (boxes match heights). */
  display: flex;
  flex-direction: column;
}
.addon-category-trio .addons {
  grid-template-columns: 1fr;
  flex: 1; /* grow to fill the remaining .addon-category height */
}
@media (max-width: 900px) {
  .addon-category-trio {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .addon-category-trio > .addon-category + .addon-category {
    margin-top: var(--space-xl);
  }
}

/* Pair two single-card categories side-by-side on desktop, so each
   category gets its own label + card in a half-row pane.
   Used for (Print Upgrades + Filters) and (Props + Backdrops). */
.addon-category-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}
.addon-category-pair > .addon-category {
  margin-top: 0;
}
/* Force the single card inside each pair-half to a single column
   (it's already alone, but this overrides any wider auto-fit behavior). */
.addon-category-pair .addons {
  grid-template-columns: 1fr;
}
@media (max-width: 720px) {
  .addon-category-pair {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .addon-category-pair > .addon-category + .addon-category {
    margin-top: var(--space-xl);
  }
}
@media (max-width: 640px) {
  .addons { grid-template-columns: 1fr; }
}

/* Category-grouped add-ons (Branded Touch Points, Print Upgrades, etc.) */
.addon-category { margin-top: var(--space-xl); }
.addon-category__label {
  font-family: var(--font-eyebrow);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brass);
  display: block;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid rgba(92, 74, 53, 0.15);
  margin: 0;
}
.addon-category > .addons { margin-top: var(--space-md); }

/* ---------- Add-on Carousel (city pages) ---------- */
.addon-carousel-wrap {
  position: relative;
  padding-inline: clamp(0px, 2vw, 16px);
}
.addon-carousel {
  display: flex;
  gap: var(--space-md);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: 0.5rem;
  scroll-padding-left: 1rem;
  -webkit-overflow-scrolling: touch;
}
.addon-carousel::-webkit-scrollbar { display: none; }
.addon-carousel .addon {
  flex: 0 0 300px;
  scroll-snap-align: start;
}
@media (max-width: 600px) {
  .addon-carousel .addon { flex: 0 0 82vw; }
}
.addon-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--white);
  border: 1px solid rgba(92, 74, 53, 0.15);
  color: var(--evergreen);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  box-shadow: var(--shadow-sm);
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  padding-bottom: 4px;
  transition: background-color var(--dur-fast), color var(--dur-fast), transform var(--dur-fast);
}
.addon-carousel__arrow:hover {
  background: var(--evergreen);
  color: var(--linen);
  transform: translateY(-50%) scale(1.05);
}
.addon-carousel__arrow--prev { left: -10px; }
.addon-carousel__arrow--next { right: -10px; }
@media (min-width: 820px) {
  .addon-carousel__arrow { display: inline-flex; }
}

/* ---------- Inquiry form: multi-select checkbox grid ---------- */
.checkbox-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem 1rem;
  padding: var(--space-sm) 0 0;
}
.checkbox-grid label {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.95rem;
  color: var(--char);
  cursor: pointer;
  line-height: 1.4;
}
.checkbox-grid input[type="checkbox"] {
  margin-top: 0.2rem;
  flex-shrink: 0;
  accent-color: var(--evergreen);
  width: 16px;
  height: 16px;
}
@media (max-width: 600px) {
  .checkbox-grid { grid-template-columns: 1fr; }
}

.addon {
  background: var(--white);
  border: 1.5px solid rgba(92, 74, 53, 0.12);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  transition: transform var(--dur-med) var(--ease-out), border-color var(--dur-med), box-shadow var(--dur-med);
}
.addon:hover {
  transform: translateY(-3px);
  border-color: var(--brass);
  box-shadow: var(--shadow-sm);
}
.addon.is-selected {
  background: rgba(31, 67, 50, 0.06);
  border-color: var(--evergreen);
  box-shadow: inset 0 0 0 1px var(--evergreen);
}

.addon__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
}
.addon__name {
  font-family: var(--font-display);
  font-size: 1.2rem;
  margin: 0;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.addon__price {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--evergreen);
  white-space: nowrap;
}
.addon__price-meta {
  font-family: var(--font-eyebrow);
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bark);
  display: block;
  text-align: right;
  margin-top: 0.2rem;
}
.addon__copy {
  font-size: 0.9rem;
  color: var(--bark);
  margin: 0 0 var(--space-md);
  flex: 1;
}
.addon__toggle {
  background: transparent;
  border: 1.5px solid var(--evergreen);
  color: var(--evergreen);
  font-family: var(--font-eyebrow);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  cursor: pointer;
  transition: background-color var(--dur-fast), color var(--dur-fast);
}
.addon__toggle:hover {
  background: var(--evergreen);
  color: var(--linen);
}
.addon.is-selected .addon__toggle {
  background: var(--evergreen);
  color: var(--linen);
}
.addon.is-selected .addon__toggle::before {
  content: "✓ ";
  margin-right: 0.2rem;
}

/* ---------- Gallery page ---------- */
.gallery-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-bottom: var(--space-xl);
  justify-content: center;
}
.filter-pill {
  background: transparent;
  border: 1px solid rgba(92, 74, 53, 0.25);
  color: var(--bark);
  padding: 0.55rem 1.1rem;
  border-radius: 999px;
  font-family: var(--font-eyebrow);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.filter-pill:hover { color: var(--evergreen); border-color: var(--evergreen); }
.filter-pill.is-active {
  background: var(--evergreen);
  color: var(--linen);
  border-color: var(--evergreen);
}

.gallery {
  columns: 3;
  column-gap: var(--space-md);
}
@media (max-width: 900px) { .gallery { columns: 2; } }
@media (max-width: 500px) { .gallery { columns: 1; } }

.gallery__item {
  break-inside: avoid;
  margin-bottom: var(--space-md);
  display: block;
  overflow: hidden;
  border-radius: var(--radius-md);
  position: relative;
  background: var(--linen-warm);
}
.gallery__item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 600ms var(--ease-out), filter var(--dur-med);
  filter: saturate(0.85);
}
.gallery__item:hover img {
  transform: scale(1.04);
  filter: saturate(1);
}
.gallery__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(26, 20, 16, 0.6));
  opacity: 0;
  transition: opacity var(--dur-med);
  pointer-events: none;
}
.gallery__item:hover::after { opacity: 1; }

.gallery__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-md);
  color: var(--linen);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--dur-med), transform var(--dur-med);
  z-index: 1;
}
.gallery__item:hover .gallery__caption {
  opacity: 1;
  transform: none;
}

/* ---------- FAQ page ---------- */
.faq {
  max-width: 760px;
  margin: var(--space-xl) auto 0;
}
.faq-item {
  border-bottom: 1px solid rgba(92, 74, 53, 0.18);
}
.faq-item__summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 400;
  list-style: none;
  transition: color var(--dur-fast);
}
.faq-item__summary::-webkit-details-marker { display: none; }
.faq-item__summary::after {
  content: "+";
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 300;
  color: var(--brass);
  transition: transform var(--dur-med) var(--ease-out);
  flex: 0 0 auto;
}
.faq-item[open] .faq-item__summary::after { transform: rotate(45deg); }
.faq-item__summary:hover { color: var(--evergreen); }
.faq-item__body {
  padding: 0 0 var(--space-md);
  color: var(--bark);
  max-width: 65ch;
}
.faq-item__body p:last-child { margin-bottom: 0; }

/* ---------- City Page — Carousel ---------- */
.city-carousel-wrap {
  position: relative;
  padding-inline: clamp(0px, 2vw, 16px);
}
.city-carousel {
  display: flex;
  gap: var(--space-md);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: 0.5rem;
  scroll-padding-left: 1rem;
  -webkit-overflow-scrolling: touch;
}
.city-carousel::-webkit-scrollbar { display: none; }

.city-carousel__item {
  flex: 0 0 auto;
  width: min(360px, 80vw);
  aspect-ratio: 4 / 5;
  scroll-snap-align: start;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--linen-warm);
  position: relative;
}
.city-carousel__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.9);
  transition: transform 600ms var(--ease-out), filter var(--dur-med);
}
.city-carousel__item:hover img {
  transform: scale(1.03);
  filter: saturate(1);
}

.city-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--white);
  border: 1px solid rgba(92, 74, 53, 0.15);
  color: var(--evergreen);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  box-shadow: var(--shadow-sm);
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  padding-bottom: 4px;
  transition: background-color var(--dur-fast), color var(--dur-fast), transform var(--dur-fast);
}
.city-carousel__arrow:hover {
  background: var(--evergreen);
  color: var(--linen);
  transform: translateY(-50%) scale(1.05);
}
.city-carousel__arrow--prev { left: -10px; }
.city-carousel__arrow--next { right: -10px; }
@media (min-width: 820px) {
  .city-carousel__arrow { display: inline-flex; }
}

/* ---------- City Page — compare-note link override ---------- */
.compare-note a {
  color: var(--evergreen);
  font-style: normal;
  font-family: var(--font-eyebrow);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* ---------- Privacy / Terms (long-form content) ---------- */
.longform {
  max-width: 720px;
  margin: 0 auto;
}
.longform h2 {
  font-size: 1.5rem;
  margin-top: var(--space-xl);
  margin-bottom: var(--space-sm);
}
.longform h2:first-child { margin-top: 0; }
.longform h3 {
  font-size: 1.15rem;
  margin-top: var(--space-lg);
  margin-bottom: var(--space-xs);
}
.longform p, .longform li {
  font-size: 1rem;
  color: var(--bark);
  line-height: 1.7;
}
.longform p { max-width: none; }
.longform ul, .longform ol {
  padding-left: 1.4rem;
  margin-bottom: var(--space-md);
}
.longform li { margin-bottom: 0.4rem; }
.longform .meta {
  font-family: var(--font-eyebrow);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bark);
  margin-bottom: var(--space-xl);
  display: block;
}

/* ---------- Breadcrumb ---------- */
.breadcrumb {
  background: var(--linen-warm);
  padding-block: var(--space-sm);
  padding-top: calc(80px + var(--space-sm));
  border-bottom: 1px solid rgba(92, 74, 53, 0.08);
  font-family: var(--font-eyebrow);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.breadcrumb__link {
  color: var(--bark);
  transition: color var(--dur-fast);
}
.breadcrumb__link:hover { color: var(--evergreen); }
.breadcrumb__current { color: var(--evergreen); font-weight: 600; }
.breadcrumb__sep {
  color: var(--bark);
  opacity: 0.5;
  margin-inline: 0.4rem;
  display: inline-block;
}

/* When breadcrumb sits directly above a page-hero, kill the hero's top padding */
.breadcrumb + main .page-hero,
.breadcrumb + main > .page-hero {
  padding-top: clamp(3rem, 6vw, 4.5rem);
}

/* Breadcrumb variant for placement INSIDE a dark hero (replaces eyebrow) */
.breadcrumb--hero {
  background: transparent;
  border-bottom: 0;
  padding: 0;
  margin-bottom: var(--space-md);
  font-family: var(--font-eyebrow);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.breadcrumb--hero .breadcrumb__link {
  color: var(--champagne);
  opacity: 0.7;
  transition: color var(--dur-fast), opacity var(--dur-fast);
}
.breadcrumb--hero .breadcrumb__link:hover {
  color: var(--linen);
  opacity: 1;
}
.breadcrumb--hero .breadcrumb__current {
  color: var(--linen);
  font-weight: 600;
}
.breadcrumb--hero .breadcrumb__sep {
  color: var(--champagne);
  opacity: 0.4;
}

/* ---------- Region grid (areas index page) ---------- */
.region-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--space-lg);
  margin-top: var(--space-lg);
}

/* ---------- Region carousel (homepage only — horizontal swipe) ---------- */
.region-carousel-wrap {
  position: relative;
  padding-inline: clamp(0px, 2vw, 16px);
  margin-top: var(--space-lg);
}
.region-carousel {
  display: flex;
  gap: var(--space-lg);
  overflow-x: hidden; /* user scroll disabled — arrow buttons drive navigation */
  scroll-snap-type: x mandatory; /* programmatic scrollBy still snaps to cards */
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: var(--space-sm);
  scroll-behavior: smooth;
}
.region-carousel::-webkit-scrollbar { display: none; }
.region-carousel .region-card {
  flex: 0 0 auto;
  width: min(380px, 82vw);
  scroll-snap-align: start;
}
.region-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: var(--white);
  border: 1px solid rgba(92, 74, 53, 0.15);
  color: var(--evergreen);
  font-size: 1.8rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  box-shadow: var(--shadow-sm);
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  padding-bottom: 4px;
  transition: background-color var(--dur-fast), color var(--dur-fast), transform var(--dur-fast);
}
.region-carousel__arrow:hover {
  background: var(--evergreen);
  color: var(--linen);
  transform: translateY(-50%) scale(1.05);
}
.region-carousel__arrow--prev { left: -14px; }
.region-carousel__arrow--next { right: -14px; }
@media (min-width: 820px) {
  .region-carousel__arrow { display: inline-flex; }
}
.region-card {
  display: block;
  background: var(--white);
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: var(--char);
  border: 1px solid rgba(92, 74, 53, 0.08);
  transition: transform var(--dur-med) var(--ease-out), box-shadow var(--dur-med);
}
.region-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  color: var(--char);
}
.region-card__image {
  aspect-ratio: 3 / 2;
  overflow: hidden;
}
.region-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease-out);
}
.region-card:hover .region-card__image img { transform: scale(1.05); }
.region-card__body { padding: var(--space-lg); }
.region-card__title {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 300;
  margin: 0 0 var(--space-xs);
  letter-spacing: -0.01em;
}
.region-card__tagline {
  color: var(--bark);
  margin-bottom: var(--space-md);
  font-style: italic;
  font-family: var(--font-display);
  font-weight: 300;
}

/* ---------- Neighborhood grid (parent region page) ---------- */
.neighborhood-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.neighborhood-card {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: var(--linen);
  background: var(--char);
  isolation: isolate;
}
.neighborhood-card__image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.neighborhood-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.85) brightness(0.85);
  transition: transform 600ms var(--ease-out), filter var(--dur-med);
}
.neighborhood-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, transparent 30%, rgba(26, 20, 16, 0.85) 100%);
  transition: opacity var(--dur-med);
}
.neighborhood-card:hover .neighborhood-card__image img {
  transform: scale(1.05);
  filter: saturate(1) brightness(0.95);
}
.neighborhood-card__overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-md);
  z-index: 2;
  color: var(--linen);
}
.neighborhood-card__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 300;
  margin: 0 0 0.3rem;
  letter-spacing: -0.01em;
  color: var(--linen);
}
.neighborhood-card__blurb {
  font-size: 0.85rem;
  color: var(--champagne);
  margin: 0;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity var(--dur-med), max-height var(--dur-med);
}
.neighborhood-card:hover .neighborhood-card__blurb {
  opacity: 1;
  max-height: 100px;
}

/* ---------- Add-on Carousel (used on city pages) ---------- */
.addon-carousel-wrap {
  position: relative;
  padding-inline: clamp(0px, 2vw, 16px);
}
.addon-carousel {
  display: flex;
  gap: var(--space-md);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: var(--space-sm);
  -webkit-overflow-scrolling: touch;
}
.addon-carousel::-webkit-scrollbar { display: none; }
.addon-carousel .addon {
  flex: 0 0 auto;
  width: min(300px, 75vw);
  scroll-snap-align: start;
}
.addon-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--white);
  border: 1px solid rgba(92, 74, 53, 0.15);
  color: var(--evergreen);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  box-shadow: var(--shadow-sm);
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  padding-bottom: 4px;
  transition: background-color var(--dur-fast), color var(--dur-fast), transform var(--dur-fast);
}
.addon-carousel__arrow:hover {
  background: var(--evergreen);
  color: var(--linen);
  transform: translateY(-50%) scale(1.05);
}
.addon-carousel__arrow--prev { left: -10px; }
.addon-carousel__arrow--next { right: -10px; }
@media (min-width: 820px) {
  .addon-carousel__arrow { display: inline-flex; }
}
