:root {
  --night: #111128;
  --deep: #1a1738;
  --violet: #3a2d67;
  --plum: #56315f;
  --mist: #f6ecdc;
  --cream: #fff2cf;
  --gold: #e8c873;
  --gold-soft: #f5dfaa;
  --lav: #cbb8ff;
  --blue: #9dc8ff;
  --rose: #f0a8c8;
  --line: rgba(255,255,255,.14);
  --panel: rgba(30, 24, 58, .62);
  --panel-2: rgba(57, 38, 84, .46);
  --shadow: 0 24px 70px rgba(7, 4, 20, .38);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--mist);
  background:
    radial-gradient(circle at 14% 8%, rgba(232,200,115,.17), transparent 16rem),
    radial-gradient(circle at 86% 10%, rgba(203,184,255,.22), transparent 22rem),
    radial-gradient(circle at 20% 44%, rgba(93,132,255,.14), transparent 28rem),
    radial-gradient(circle at 80% 62%, rgba(240,168,200,.14), transparent 30rem),
    linear-gradient(180deg,#181642 0%, #362b68 24%, #6a3d79 48%, #47306c 76%, #121328 100%);
  font-family: Inter, system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,.06), transparent 18%, transparent 78%, rgba(0,0,0,.28));
  z-index: -1;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, textarea, select { font: inherit; }
.hidden { display: none; }

.celestial-layer { position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.ambient-star {
  position: absolute;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  background: var(--gold-soft);
  opacity: 0;
  box-shadow: 0 0 18px rgba(245,223,170,.55);
  animation: twinkle var(--twinkle) ease-in-out infinite;
  animation-delay: var(--delay);
}
.shooting-star {
  position: absolute;
  width: 9rem;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,244,218,.9), transparent);
  transform: rotate(-18deg) translateX(0);
  opacity: 0;
  filter: drop-shadow(0 0 8px rgba(245,223,170,.55));
  animation: shoot var(--duration) linear infinite;
  animation-delay: var(--delay);
}
.moon-glow {
  position: absolute;
  right: clamp(1rem, 5vw, 6rem);
  top: clamp(1.25rem, 5vw, 4rem);
  width: clamp(5.25rem, 9vw, 8.5rem);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232,200,115,.28), transparent 66%);
  filter: blur(.2px);
  animation: breathe 8s ease-in-out infinite;
}
.moon-glow.small { opacity: .7; }
.moon-core {
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  background: var(--gold-soft);
  box-shadow: 0 0 32px rgba(245,223,170,.24);
}
.moon-core::after {
  content: "";
  position: absolute;
  inset: -2% -22% -2% 34%;
  border-radius: 50%;
  background: #272150;
  box-shadow: -12px 0 26px rgba(39,33,80,.72);
}
@keyframes twinkle { 0%,100% { opacity: .15; transform: scale(.72); } 50% { opacity: var(--opacity); transform: scale(1.15); } }
@keyframes shoot { 0%, 76% { opacity: 0; transform: rotate(-18deg) translateX(0); } 80% { opacity: .86; } 100% { opacity: 0; transform: rotate(-18deg) translateX(-36rem); } }
@keyframes breathe { 0%,100% { transform: scale(.98); opacity: .7; } 50% { transform: scale(1.04); opacity: .98; } }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  width: min(1440px, calc(100% - 2rem));
  margin: 1rem auto 0;
  padding: .9rem 1rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(20, 17, 45, .58);
  box-shadow: 0 18px 50px rgba(8,6,22,.22);
  backdrop-filter: blur(18px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.brand-mark {
  font-family: Cinzel, serif;
  font-size: clamp(1.35rem, 2.4vw, 2.05rem);
  font-weight: 700;
  color: var(--gold);
  letter-spacing: .02em;
  text-shadow: 0 0 18px rgba(232,200,115,.22);
  padding-left: .6rem;
}
.site-nav { display: flex; align-items: center; gap: .55rem; }
.site-nav a {
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  padding: .72rem 1rem;
  color: var(--gold-soft);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: rgba(255,255,255,.055);
  transition: transform .2s, border-color .2s, background .2s;
}
.site-nav a:hover { transform: translateY(-1px); border-color: rgba(232,200,115,.55); background: rgba(255,255,255,.09); }
.menu-toggle { display: none; color: var(--gold); background: transparent; border: 0; font-size: 1.3rem; }

main, .site-footer { position: relative; z-index: 1; }
.section-shell, .section-block {
  width: min(1280px, calc(100% - 2rem));
  margin: 1rem auto;
  border: 1px solid var(--line);
  border-radius: 2rem;
  background: linear-gradient(180deg, rgba(36,29,69,.66), rgba(78,46,100,.42));
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  overflow: hidden;
}
.section-block { padding: clamp(2rem, 5vw, 4.5rem); }
.hero {
  min-height: min(790px, calc(100vh - 6rem));
  padding: clamp(2rem, 5vw, 5rem);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(310px, .8fr);
  align-items: center;
  gap: clamp(2rem, 6vw, 5rem);
  margin-top: 1.3rem;
}
.hero::before, .section-block::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 18%, rgba(232,200,115,.13), transparent 18rem),
    radial-gradient(circle at 82% 20%, rgba(203,184,255,.14), transparent 20rem),
    radial-gradient(circle at 44% 72%, rgba(255,255,255,.04), transparent 18rem);
}
.hero-ornament {
  position: absolute;
  left: 9%; top: 26%;
  width: 42%; height: 16rem;
  opacity: .5;
  border-top: 2px solid rgba(232,200,115,.42);
  border-radius: 50%;
  transform: rotate(-4deg);
  filter: drop-shadow(0 0 14px rgba(232,200,115,.24));
}
.hero-copy, .hero-card, .section-intro, .proof-grid, .service-grid, .package-grid, .earthborn-copy, .earthborn-art, .bridge > *, .contact-form, .gallery-grid, .page-hero > * { position: relative; z-index: 1; }
.kicker {
  margin: 0 0 1rem;
  color: var(--gold);
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .26em;
}
h1, h2, h3 { margin: 0; font-family: "Cormorant Garamond", Georgia, serif; line-height: .98; color: var(--cream); }
h1 { font-size: clamp(4rem, 9vw, 8rem); max-width: 8ch; letter-spacing: -.045em; }
h1 em { display: block; font-weight: 400; color: #f5e1ad; }
h2 { font-size: clamp(2.65rem, 5.6vw, 5.4rem); letter-spacing: -.04em; }
h3 { font-size: clamp(1.55rem, 2.5vw, 2.3rem); letter-spacing: -.025em; }
p { line-height: 1.72; }
.hero-lede { margin: 1.35rem 0 0; max-width: 48rem; font-size: clamp(1.2rem, 2vw, 1.55rem); font-weight: 700; color: #fff4df; }
.hero-support { margin: 1rem 0 0; max-width: 41rem; font-size: 1.08rem; color: rgba(246,236,220,.86); font-weight: 500; }
.button-row, .center-row { display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; margin-top: 2rem; }
.center-row { justify-content: center; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.2rem;
  padding: .85rem 1.35rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  transition: transform .2s, background .2s, border-color .2s;
}
.button:hover { transform: translateY(-2px); }
.button.primary { background: var(--gold); color: #261f4d; border-color: transparent; box-shadow: 0 16px 38px rgba(232,200,115,.18); }
.button.secondary { background: rgba(255,255,255,.06); color: var(--gold-soft); }
.button.secondary:hover { border-color: rgba(232,200,115,.5); background: rgba(255,255,255,.09); }
.hero-card {
  padding: clamp(1rem, 3vw, 2rem);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 2rem;
  background: linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.045));
  box-shadow: inset 0 1px rgba(255,255,255,.08), 0 24px 70px rgba(9,6,24,.28);
}
.portrait-frame { padding: 1.2rem; border: 1px solid rgba(255,255,255,.12); border-radius: 1.7rem; background: rgba(255,255,255,.07); }
.portrait-frame img { width: 100%; height: auto; border-radius: 1.1rem; aspect-ratio: 4/5; object-fit: cover; }
.portrait-caption { text-align: center; margin: 1.1rem 0 0; font-family: "Cormorant Garamond", serif; font-style: italic; color: #f4dfaa; font-size: 1.2rem; }
.role-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: 1.3rem; }
.role-grid span { padding: 1rem; border: 1px solid rgba(255,255,255,.1); border-radius: 1rem; background: rgba(255,255,255,.04); color: #f3e6d2; font-weight: 700; }
.section-intro { max-width: 820px; margin: 0 auto clamp(2rem, 4vw, 3.25rem); text-align: center; }
.section-intro.align-left { margin-left: 0; text-align: left; }
.section-intro p:not(.kicker), .page-hero p { font-size: clamp(1.05rem, 1.45vw, 1.28rem); color: rgba(246,236,220,.86); font-weight: 500; }
.proof-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.proof-card, .service-card, .package-card, .gallery-grid figure, .contact-form, .earthborn-art, .bridge {
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 1.6rem;
  background: rgba(14,12,31,.35);
  box-shadow: inset 0 1px rgba(255,255,255,.06);
  overflow: hidden;
}
.proof-card { position: relative; min-height: 30rem; display: flex; align-items: end; cursor: pointer; }
.proof-card.large { grid-row: span 2; }
.proof-card.wide { grid-column: span 2; min-height: 24rem; }
.proof-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .65s ease; }
.proof-card::after, .gallery-grid figure::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 28%, rgba(6,5,18,.88)); pointer-events: none; }
.proof-card:hover img { transform: scale(1.045); }
.proof-card div { position: relative; z-index: 1; padding: 1.35rem; }
.proof-card span, .package-kind { display: block; color: var(--gold); font-size: .72rem; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; margin-bottom: .55rem; }
.proof-card p { margin: .4rem 0 0; color: rgba(246,236,220,.85); font-weight: 500; }
.split { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.service-grid { display: grid; gap: 1rem; }
.service-card, .package-card { padding: clamp(1.3rem, 2.4vw, 2rem); }
.sigil { display: inline-flex; width: 2.7rem; height: 2.7rem; align-items: center; justify-content: center; border-radius: 50%; color: var(--gold); border: 1px solid rgba(232,200,115,.24); background: rgba(232,200,115,.08); margin-bottom: 1rem; }
.service-card p, .package-card p, .package-card li, .earthborn p, .bridge p { color: rgba(246,236,220,.86); font-size: 1rem; font-weight: 500; }
.package-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 1rem; }
.package-card.featured { background: linear-gradient(180deg, rgba(232,200,115,.14), rgba(255,255,255,.055)); border-color: rgba(232,200,115,.32); box-shadow: 0 0 0 1px rgba(232,200,115,.06), 0 24px 70px rgba(232,200,115,.1); }
.price { margin: .8rem 0; font-family: Cinzel, serif; color: #fff0bd !important; font-size: clamp(1.6rem, 3vw, 2.3rem) !important; font-weight: 700 !important; }
.best-for { min-height: 3.5rem; }
ul { padding-left: 1.1rem; margin: 1rem 0 0; }
li + li { margin-top: .6rem; }
.earthborn { display: grid; grid-template-columns: .78fr 1.22fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.earthborn-art img { width: 100%; max-height: 650px; object-fit: cover; }
.earthborn .button { margin-top: 1.5rem; }
.bridge { display: grid; grid-template-columns: minmax(220px,.45fr) 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; padding: clamp(1.2rem, 3vw, 2rem); }
.bridge img { border-radius: 1.25rem; width: 100%; aspect-ratio: 1/1; object-fit: cover; }
.contact-section { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(1.5rem, 4vw, 3rem); }
.contact-form { padding: clamp(1.2rem, 3vw, 2rem); display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 1rem; }
.contact-form label { display: grid; gap: .45rem; color: var(--gold-soft); font-size: .78rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.contact-form input, .contact-form textarea, .contact-form select {
  width: 100%; border: 1px solid rgba(255,255,255,.13); border-radius: 1rem; background: rgba(255,255,255,.075); color: #fff7ea; padding: .9rem 1rem; outline: 0; font-size: 1rem; font-weight: 500; letter-spacing: 0; text-transform: none;
}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus { border-color: rgba(232,200,115,.6); }
.contact-form option { background: #1b1738; color: #fff7ea; }
.span-2 { grid-column: span 2; }
.site-footer {
  width: min(1280px, calc(100% - 2rem)); margin: 1rem auto 2rem; padding: 1.4rem 1.6rem; border: 1px solid var(--line); border-radius: 1.5rem; background: rgba(14,12,31,.62); backdrop-filter: blur(14px); display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}
.site-footer strong { display: block; font-family: Cinzel, serif; color: var(--gold); font-size: 1.2rem; }
.site-footer span { display: block; margin-top: .25rem; color: rgba(246,236,220,.72); }
.site-footer nav { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; color: rgba(246,236,220,.82); font-size: .95rem; }
.site-footer a:hover { color: var(--gold-soft); }
.page-hero { padding: clamp(3rem, 7vw, 6rem); margin-top: 1.3rem; }
.page-hero h1 { max-width: 11ch; font-size: clamp(4rem, 8vw, 7rem); }
.page-hero p { max-width: 58rem; }
.gallery-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 1rem; }
.gallery-grid.landscape-first { grid-template-columns: 1.2fr .8fr .8fr; }
.gallery-grid figure { margin: 0; position: relative; cursor: pointer; min-height: 34rem; display: flex; align-items: end; }
.gallery-grid.landscape-first figure:first-child { grid-column: span 1; }
.gallery-grid.cards-grid figure:first-child { grid-column: span 2; }
.gallery-grid img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.gallery-grid figure:hover img { transform: scale(1.035); }
.gallery-grid figcaption { position: relative; z-index: 1; padding: 1.15rem; color: rgba(246,236,220,.9); font-weight: 600; }
.lightbox { width: min(92vw, 1100px); border: 1px solid rgba(255,255,255,.18); border-radius: 1.3rem; padding: 0; background: rgba(12,10,28,.94); box-shadow: var(--shadow); }
.lightbox::backdrop { background: rgba(5,4,14,.82); backdrop-filter: blur(8px); }
.lightbox img { width: 100%; max-height: 86vh; object-fit: contain; }
.lightbox-close { position: absolute; right: .7rem; top: .7rem; width: 2.4rem; height: 2.4rem; border: 1px solid rgba(255,255,255,.2); border-radius: 50%; color: var(--cream); background: rgba(0,0,0,.45); font-size: 1.5rem; z-index: 1; }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── Homepage category cards (replaces broken pricing-tier grid) ── */
.category-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}
.category-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: clamp(1.4rem, 2.6vw, 2.1rem);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 1.6rem;
  background: rgba(14,12,31,.42);
  box-shadow: inset 0 1px rgba(255,255,255,.06);
  transition: transform .25s ease, border-color .25s ease;
}
.category-card:hover { transform: translateY(-3px); border-color: rgba(232,200,115,.32); }
.category-card.featured {
  background: linear-gradient(180deg, rgba(232,200,115,.13), rgba(255,255,255,.05));
  border-color: rgba(232,200,115,.34);
  box-shadow: 0 0 0 1px rgba(232,200,115,.06), 0 24px 70px rgba(232,200,115,.1);
}
.category-card h3 {
  font-size: clamp(1.45rem, 2vw, 1.85rem);
  letter-spacing: -.02em;
  color: var(--cream);
}
.category-anchor {
  display: flex;
  align-items: baseline;
  gap: .6rem;
  margin: 0;
  padding: .85rem 0;
  border-top: 1px solid rgba(255,255,255,.1);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.anchor-label {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold-soft);
}
.anchor-price {
  font-family: Cinzel, serif;
  font-size: clamp(1.5rem, 2.6vw, 2.05rem);
  font-weight: 700;
  color: #fff0bd;
}
.category-body {
  margin: 0;
  color: rgba(246,236,220,.85);
  font-size: 1rem;
  line-height: 1.65;
}
.category-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .85rem;
}
.category-list li {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  padding-left: 1.1rem;
  position: relative;
  color: var(--mist);
}
.category-list li::before {
  content: "·";
  position: absolute;
  left: 0;
  top: -.05rem;
  color: var(--gold);
  font-size: 1.4rem;
  line-height: 1;
}
.tier-line {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.1rem;
  color: var(--mist);
  font-weight: 500;
}
.tier-desc {
  font-size: .82rem;
  font-style: italic;
  color: rgba(246,236,220,.62);
  line-height: 1.4;
}

/* ── Homepage card tier accordion ── */
.card-tiers {
  margin: 0;
}
.card-tiers-summary {
  cursor: pointer;
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .5rem 0;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  transition: color .2s;
}
.card-tiers-summary::-webkit-details-marker { display: none; }
.card-tiers-summary::marker { display: none; }
.card-tiers-summary:hover { color: var(--gold-soft); }
.card-tiers-summary:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 4px;
  border-radius: 4px;
}
.card-tiers-chevron {
  display: inline-flex;
  transition: transform .25s ease;
}
.card-tiers[open] .card-tiers-chevron { transform: rotate(180deg); }
.card-tiers[open] .card-tiers-summary { margin-bottom: .85rem; }
.card-tiers .category-list {
  animation: accordionFade .25s ease;
}
@media (prefers-reduced-motion: reduce) {
  .card-tiers-chevron { transition: none; }
  .card-tiers .category-list { animation: none; }
}
.category-link {
  margin-top: auto;
  padding-top: .5rem;
  color: var(--gold);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-bottom: 1px solid transparent;
  align-self: flex-start;
  transition: color .2s, border-color .2s;
}
.category-link:hover { color: var(--gold-soft); border-bottom-color: rgba(232,200,115,.5); }

/* ── Packages page: tier cards ── */
.packages-tier-block { padding-top: clamp(1.5rem, 3vw, 2.5rem); padding-bottom: clamp(1.5rem, 3vw, 2.5rem); }

/* ── Packages page: accordion ── */
.package-accordion {
  padding: 0;
  overflow: hidden;
}
.package-accordion[open] {
  background: linear-gradient(180deg, rgba(36,29,69,.76), rgba(78,46,100,.5));
}
.accordion-summary {
  cursor: pointer;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: clamp(1rem, 2.5vw, 2rem);
  list-style: none;
  position: relative;
  z-index: 1;
  transition: background .2s ease;
}
.accordion-summary::-webkit-details-marker { display: none; }
.accordion-summary::marker { display: none; }
.accordion-summary:hover {
  background: rgba(232,200,115,.04);
}
.accordion-summary:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: -2px;
}
.accordion-summary-text {
  flex: 1;
  min-width: 0;
}
.accordion-summary-text .kicker { margin: 0 0 .85rem; }
.accordion-summary-text h2 {
  margin: 0 0 .9rem;
  font-size: clamp(2rem, 4vw, 3.4rem);
  letter-spacing: -.035em;
  line-height: 1.05;
}
.accordion-meta {
  margin: 0;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold-soft);
}
.accordion-chevron {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(232,200,115,.4);
  border-radius: 50%;
  color: var(--gold);
  background: rgba(232,200,115,.06);
  transition: transform .3s ease, background .25s ease, border-color .25s ease;
  margin-top: .3rem;
}
.accordion-summary:hover .accordion-chevron {
  background: rgba(232,200,115,.16);
  border-color: rgba(232,200,115,.65);
}
.package-accordion[open] .accordion-chevron {
  transform: rotate(180deg);
  background: rgba(232,200,115,.18);
  border-color: rgba(232,200,115,.55);
}
.accordion-body {
  padding: 0 clamp(1.5rem, 3vw, 2.5rem) clamp(1.5rem, 3vw, 2.5rem);
  animation: accordionFade .3s ease;
}
@keyframes accordionFade {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.accordion-intro {
  max-width: 75ch;
  margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
  font-size: clamp(1.05rem, 1.45vw, 1.28rem);
  color: rgba(246,236,220,.86);
  font-weight: 500;
}
@media (prefers-reduced-motion: reduce) {
  .accordion-body { animation: none; }
  .accordion-chevron { transition: none; }
}
.tier-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.tier-grid-four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.tier-grid-five { grid-template-columns: repeat(5, minmax(0, 1fr)); gap: .8rem; }
.tier-grid-five .tier-card { padding: clamp(1rem, 1.5vw, 1.4rem); }
.tier-grid-five .tier-name { font-size: 1.3rem; }
.tier-grid-five .tier-price { font-size: 1.4rem; padding-bottom: .7rem; margin-bottom: .7rem; }
.tier-grid-five .tier-fit { font-size: .98rem; margin-bottom: .8rem; }
.tier-grid-five .tier-card li { font-size: .88rem; }
.tier-card {
  display: flex;
  flex-direction: column;
  padding: clamp(1.3rem, 2.4vw, 1.9rem);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 1.5rem;
  background: rgba(14,12,31,.4);
  box-shadow: inset 0 1px rgba(255,255,255,.05);
}
.tier-card.tier-featured {
  background: linear-gradient(180deg, rgba(232,200,115,.14), rgba(255,255,255,.05));
  border-color: rgba(232,200,115,.34);
  box-shadow: 0 0 0 1px rgba(232,200,115,.06), 0 24px 70px rgba(232,200,115,.1);
}
.tier-name, h3.tier-name {
  margin: 0 0 .3rem;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 1.55rem;
  line-height: 1.15;
  color: var(--cream);
  letter-spacing: -.01em;
}
.tier-price {
  margin: 0 0 .9rem;
  padding-bottom: .9rem;
  border-bottom: 1px solid rgba(255,255,255,.1);
  font-family: Cinzel, serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: #fff0bd;
  letter-spacing: .01em;
}
.tier-fit {
  margin: 0 0 .9rem;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 1.05rem;
  color: rgba(246,236,220,.78);
  line-height: 1.45;
}
.tier-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .5rem;
}
.tier-card li {
  position: relative;
  padding-left: 1.1rem;
  font-size: .96rem;
  font-weight: 500;
  color: rgba(246,236,220,.86);
  line-height: 1.5;
}
.tier-card li::before {
  content: "✦";
  position: absolute;
  left: 0;
  top: .12rem;
  color: var(--gold);
  font-size: .65rem;
  opacity: .85;
}

/* ── Packages page: notes & cta stack ── */
.packages-notes { padding-top: clamp(1.5rem, 3vw, 2.5rem); }
.notes-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.note-card {
  padding: 1.3rem 1.4rem;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 1.2rem;
  background: rgba(14,12,31,.32);
}
.note-card p { margin: 0; line-height: 1.55; color: rgba(246,236,220,.84); font-size: .96rem; }
.note-label {
  margin-bottom: .5rem !important;
  color: var(--gold) !important;
  font-size: .72rem !important;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.cta-stack { display: flex; gap: .9rem; flex-wrap: wrap; margin-top: 1rem; }
.inline-link {
  color: var(--gold);
  border-bottom: 1px solid rgba(232,200,115,.4);
  transition: color .2s, border-color .2s;
}
.inline-link:hover { color: var(--gold-soft); border-bottom-color: var(--gold-soft); }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; } .reveal { opacity: 1; transform: none; } }
@media (max-width: 980px) {
  .site-header { border-radius: 1.25rem; align-items: flex-start; }
  .menu-toggle { display: block; }
  .site-nav { display: none; width: 100%; flex-direction: column; align-items: stretch; padding-top: .85rem; }
  .site-header.open { flex-wrap: wrap; }
  .site-header.open .site-nav { display: flex; }
  .site-nav a { text-align: center; }
  .hero, .split, .earthborn, .bridge, .contact-section { grid-template-columns: 1fr; }
  .proof-grid, .package-grid, .gallery-grid, .gallery-grid.landscape-first, .category-grid, .tier-grid, .tier-grid-four, .tier-grid-five, .notes-grid { grid-template-columns: 1fr 1fr; }
  .proof-card.large, .proof-card.wide, .gallery-grid.cards-grid figure:first-child { grid-column: span 2; grid-row: auto; }
  .hero { min-height: auto; padding-top: 5rem; }
  h1 { max-width: 10ch; }
}
@media (max-width: 640px) {
  .section-shell, .section-block, .site-footer { width: min(100% - 1rem, 1280px); border-radius: 1.35rem; }
  .section-block { padding: 1.35rem; }
  .hero { padding: 5rem 1.25rem 1.25rem; gap: 1.4rem; }
  h1 { font-size: clamp(3.35rem, 18vw, 4.5rem); }
  h2 { font-size: clamp(2.45rem, 13vw, 3.5rem); }
  .proof-grid, .package-grid, .gallery-grid, .gallery-grid.landscape-first, .category-grid, .tier-grid, .tier-grid-four, .tier-grid-five, .notes-grid { grid-template-columns: 1fr; }
  .proof-card.large, .proof-card.wide, .gallery-grid.cards-grid figure:first-child { grid-column: auto; }
  .proof-card, .gallery-grid figure { min-height: 28rem; }
  .contact-form { grid-template-columns: 1fr; }
  .span-2 { grid-column: auto; }
  .role-grid { grid-template-columns: 1fr; }
  .brand-mark { font-size: 1.25rem; }
}
