/* =========================================================================
   TEMPLE HEALING — shared stylesheet
   Thesis: "entering a place of light." A dawn-light arch (the temple
   doorway / light rising) is the signature form across the whole site.
   Palette is earthy but deliberately avoids the cream+terracotta default:
   forest-ink ground, dawn-gold light, living-water teal, growth-sage,
   sacred plum.
   ========================================================================= */

:root{
  /* color — v3 approved direction: deep forest, antique gold, soft cream */
  --ink:#1F362A;        /* deep forest — text, header, dark bands */
  --ink-soft:#2A4636;   /* lighter forest — secondary dark surfaces */
  --paper:#FBF8F1;      /* soft cream — primary background */
  --paper-2:#FFFFFF;    /* white — cards */
  --gold:#C9A24B;       /* antique gold — primary accent */
  --gold-deep:#8A671F;  /* gold for text on light — 4.9:1 on cream, WCAG AA */
  --gold-soft:#E3C883;  /* luminous gold — glows */
  --water:#3C7C79;      /* living water teal — secondary accent */
  --water-deep:#2F6360;
  --sage:#788A63;       /* growth green — tertiary, used sparingly */
  --plum:#8A671F;       /* eyebrow accent — bronze gold (was plum) */
  --line:rgba(31,54,42,.16);
  --line-soft:rgba(31,54,42,.09);

  /* type — elegant serif display + light geometric sans */
  --display:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --body:"Jost",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  /* rhythm */
  --maxw:1200px;
  --gut:clamp(1.25rem,4vw,2.5rem);
  --section-y:clamp(4rem,8vw,6.5rem);
  --radius:8px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  font-size:clamp(1.02rem,.55vw + .92rem,1.18rem);
  line-height:1.75;
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--water-deep);text-decoration:none}
a:hover{color:var(--gold-deep)}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.08;margin:0;color:var(--ink)}
p{margin:0 0 1.1em}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.narrow{max-width:760px;margin-inline:auto}
.section{padding-block:var(--section-y)}
.center{text-align:center}

.eyebrow{
  font-family:var(--body);
  font-size:.74rem;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--plum);
  margin:0 0 1.1rem;
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--gold)}

.lead{font-size:1.22rem;color:var(--ink-soft)}
.h-xl{font-size:clamp(2.7rem,6.5vw,5rem);letter-spacing:-.01em}
.h-lg{font-size:clamp(2rem,4.4vw,3.2rem)}
.h-md{font-size:clamp(1.5rem,2.6vw,2.05rem)}
.serif-italic{font-style:italic;font-weight:400}
.muted{color:var(--ink-soft)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--body);font-weight:800;font-size:.96rem;
  letter-spacing:.01em;
  padding:.85em 1.5em;border-radius:999px;
  border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.btn--gold{background:var(--gold);color:#fff;box-shadow:0 8px 22px -10px rgba(165,108,32,.7)}
.btn--gold:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:currentColor;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--light{background:var(--paper);color:var(--ink)}
.btn--light:hover{background:#fff;transform:translateY(-2px);color:var(--ink)}
.btn--outline-light{background:transparent;border-color:rgba(244,237,220,.55);color:var(--paper)}
.btn--outline-light:hover{background:rgba(244,237,220,.12);color:#fff;border-color:var(--paper)}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem}
.btn-row.center{justify-content:center}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(244,237,220,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding-block:.85rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);
  font-size:1.3rem;font-weight:600;color:var(--ink);letter-spacing:.005em}
.brand:hover{color:var(--ink)}
.brand .mark{flex:0 0 auto}
.nav-links{display:flex;align-items:center;gap:1.55rem;list-style:none;margin:0;padding:0}
.nav-links a{
  font-family:var(--body);font-weight:700;font-size:.95rem;color:var(--ink-soft);
  position:relative;padding-block:.3rem;
}
.nav-links a:hover{color:var(--ink)}
.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--gold);border-radius:2px;
}
.nav-cta{display:flex;align-items:center;gap:.75rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink)}
.nav-mobile-cta{display:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

@media (max-width:920px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:.5rem var(--gut) 1.2rem;
    max-height:0;overflow:hidden;visibility:hidden;
    transition:max-height .3s ease;
  }
  .nav-links.open{max-height:80vh;visibility:visible}
  .nav-links li{width:100%}
  .nav-links a{display:block;width:100%;padding:.7rem 0;border-bottom:1px solid var(--line-soft);font-size:1.05rem}
  .nav-links a[aria-current="page"]::after{display:none}
  .nav-desktop-cta{display:none}
  .nav-mobile-cta{display:block}
}

/* ---------- the signature: dawn-light arch ---------- */
.arch{
  position:relative;
  border-radius:50% 50% 12px 12px / 62% 62% 12px 12px;
  background:
    radial-gradient(120% 95% at 50% 108%,
      var(--gold-soft) 0%,
      #F4DEAE 26%,
      var(--paper-2) 55%,
      var(--paper-2) 100%);
  border:1.5px solid rgba(192,131,46,.5);
  overflow:hidden;
}

/* hero */
.hero{position:relative;background:var(--ink);color:var(--paper);overflow:hidden}
.hero::before{ /* faint rising glow behind everything */
  content:"";position:absolute;left:50%;bottom:-30%;transform:translateX(-50%);
  width:120vw;height:120vh;
  background:radial-gradient(closest-side,rgba(234,197,127,.22),rgba(234,197,127,0) 70%);
  pointer-events:none;
}
.hero .wrap{position:relative;padding-block:clamp(3.5rem,8vw,6.5rem)}
.hero-grid{display:grid;justify-items:center;text-align:center;gap:1.6rem}
.hero .eyebrow{color:var(--gold-soft)}
.hero .eyebrow::before{background:var(--gold-soft)}
.hero h1{color:#fff}
.hero h1 .glow{color:var(--gold-soft)}
.hero-sub{max-width:600px;font-size:1.2rem;color:rgba(244,237,220,.86)}
.hero-tag{font-family:var(--display);font-style:italic;font-size:1.1rem;color:var(--gold-soft);
  letter-spacing:.03em}
.hero-tag span{opacity:.5;padding-inline:.5rem}

/* the doorway light in the hero */
.doorway{
  width:min(330px,72vw);aspect-ratio:.72;margin:1rem auto .4rem;
  display:grid;place-items:end center;padding-bottom:11%;
  box-shadow:0 0 80px -10px rgba(234,197,127,.45);
  animation:breathe 7s ease-in-out infinite;
}
.doorway .sun{
  width:46%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,#fff 0%,var(--gold-soft) 45%,rgba(234,197,127,0) 72%);
  margin-bottom:8%;
}
@keyframes breathe{0%,100%{box-shadow:0 0 70px -14px rgba(234,197,127,.4)}
  50%{box-shadow:0 0 95px -6px rgba(234,197,127,.6)}}

/* ---------- generic surfaces ---------- */
.band-ink{background:var(--ink);color:var(--paper)}
.band-ink h2,.band-ink h3{color:#fff}
.band-soft{background:var(--paper-2)}
.divider-leaf{display:block;margin:0 auto;color:var(--gold)}

/* mission quote */
.mission{max-width:880px;margin-inline:auto;text-align:center}
.mission .q{
  font-family:var(--display);font-weight:400;
  font-size:clamp(1.7rem,3.6vw,2.7rem);line-height:1.28;color:var(--ink);
  letter-spacing:-.005em;
}
.mission .q .accent{color:var(--gold-deep);font-style:italic}

/* about teaser two-col */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.flip{grid-template-columns:.95fr 1.05fr}
.split h2{margin-bottom:1rem}
@media (max-width:820px){.split,.split.flip{grid-template-columns:1fr;gap:2.2rem}}
.media-arch{
  aspect-ratio:4/5;width:100%;
  display:grid;place-items:center;
  background:
    radial-gradient(110% 80% at 50% 105%,var(--gold-soft),#EBD7A8 30%,#DCE3CE 70%,#CBD8C7 100%);
}
.media-arch .ring{width:60%;aspect-ratio:1;border-radius:50%;border:2px solid rgba(255,255,255,.6);
  box-shadow:0 0 60px rgba(255,255,255,.35) inset}

/* offerings grid */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(225px,1fr));gap:1.2rem}
.card{
  background:var(--paper-2);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:1.7rem 1.5rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -26px rgba(28,43,35,.5);border-color:var(--line)}
.card .ico{width:38px;height:38px;color:var(--gold);margin-bottom:1rem}
.card h3{font-size:1.3rem;margin-bottom:.4rem}
.card p{font-size:1rem;color:var(--ink-soft);margin:0}

/* four paths — doorways, not steps */
.paths{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
@media (max-width:900px){.paths{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.paths{grid-template-columns:1fr}}
.path{
  display:flex;flex-direction:column;
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:130px 130px var(--radius) var(--radius);
  padding:2.2rem 1.4rem 1.6rem;text-align:center;
  transition:transform .2s ease,box-shadow .2s ease;
}
.path:hover{transform:translateY(-5px);box-shadow:0 22px 48px -28px rgba(28,43,35,.55)}
.path .door{
  width:62px;aspect-ratio:.7;margin:0 auto 1.1rem;
  border-radius:50% 50% 6px 6px / 62% 62% 6px 6px;
  background:radial-gradient(120% 90% at 50% 110%,var(--gold-soft),var(--paper-2) 72%);
  border:1.5px solid rgba(192,131,46,.5);
}
.path h3{font-size:1.5rem;margin-bottom:.35rem}
.path .kicker{font-family:var(--body);font-weight:800;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--water-deep);margin-bottom:.9rem}
.path p{font-size:.97rem;color:var(--ink-soft);margin-bottom:1.2rem}
.path .links{margin-top:auto;display:flex;flex-direction:column;gap:.55rem}
.path .links a{
  font-weight:700;font-size:.95rem;color:var(--ink);
  padding:.5rem .6rem;border-radius:10px;border:1px solid var(--line-soft);
  transition:background .15s ease,border-color .15s ease;
}
.path .links a:hover{background:var(--paper);border-color:var(--line);color:var(--gold-deep)}

/* testimonial */
.testimonial{max-width:820px;margin-inline:auto;text-align:center}
.testimonial .quote{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.5rem,3.2vw,2.25rem);line-height:1.34;color:#fff;
}
.testimonial cite{display:block;margin-top:1.4rem;font-family:var(--body);font-style:normal;
  font-weight:800;letter-spacing:.04em;color:var(--gold-soft);font-size:.95rem}
.placeholder-note{font-size:.82rem;color:rgba(244,237,220,.5);margin-top:1.4rem;font-style:italic}

/* mailing list / form */
.mail{max-width:620px;margin-inline:auto;text-align:center}
.field-row{display:flex;gap:.6rem;margin-top:1.4rem;flex-wrap:wrap;justify-content:center}
.field-row input{
  flex:1 1 240px;min-width:0;
  font-family:var(--body);font-size:1rem;color:var(--ink);
  padding:.85em 1.1em;border-radius:999px;border:1.5px solid var(--line);
  background:var(--paper-2);
}
.field-row input:focus{border-color:var(--gold);outline:none}
.form-hint{font-size:.82rem;color:var(--ink-soft);margin-top:.9rem}

/* generic form (contact / applications) */
.form{display:grid;gap:1.1rem;max-width:640px}
.form .group{display:grid;gap:.4rem}
.form label{font-weight:700;font-size:.92rem}
.form .req{color:var(--gold-deep)}
.form input,.form select,.form textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink);
  padding:.75em .9em;border:1.5px solid var(--line);border-radius:12px;background:var(--paper-2);
  width:100%;
}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--gold);outline:none}
.form textarea{min-height:130px;resize:vertical}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:560px){.two-col{grid-template-columns:1fr}}

/* embed slot — where booking/scheduling/payment tools drop in */
.embed-slot{
  border:1.5px dashed rgba(192,131,46,.55);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(234,197,127,.12),rgba(234,197,127,.04));
  padding:2.4rem 1.6rem;text-align:center;color:var(--ink-soft);
}
.embed-slot strong{color:var(--ink);font-family:var(--display);font-size:1.2rem;font-weight:600;
  display:block;margin-bottom:.4rem}
.embed-slot code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;
  background:rgba(28,43,35,.06);padding:.15em .45em;border-radius:5px}

/* list of offerings (services page) */
.offer-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem 2rem;
  list-style:none;margin:1.4rem 0 0;padding:0}
.offer-list li{padding:1rem 0 1rem 1.7rem;border-top:1px solid var(--line-soft);position:relative}
.offer-list li::before{content:"";position:absolute;left:0;top:1.45rem;width:9px;height:9px;
  border-radius:50%;background:var(--gold)}
.offer-list li b{display:block;font-family:var(--display);font-weight:600;font-size:1.18rem;
  color:var(--ink);line-height:1.2;margin-bottom:.15rem}
.offer-list li span{font-size:.95rem;color:var(--ink-soft)}

/* add-on chips */
.chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.chip{display:inline-flex;align-items:center;gap:.5rem;
  background:var(--paper-2);border:1px solid var(--line);border-radius:999px;
  padding:.5em 1em;font-size:.92rem;font-weight:600;color:var(--ink-soft)}
.chip::before{content:"+";color:var(--gold-deep);font-weight:800}

/* pricing / tier note cards */
.note-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.note{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.note h3{font-size:1.25rem;margin-bottom:.5rem}
.note p{font-size:.97rem;color:var(--ink-soft);margin:0}

/* page hero (inner pages) */
.page-hero{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-12%;top:-40%;width:60vw;height:140%;
  background:radial-gradient(closest-side,rgba(234,197,127,.16),rgba(234,197,127,0) 70%);pointer-events:none}
.page-hero .wrap{position:relative;padding-block:clamp(3rem,7vw,5.5rem)}
.page-hero h1{color:#fff;max-width:14ch}
.page-hero .eyebrow{color:var(--gold-soft)}
.page-hero .eyebrow::before{background:var(--gold-soft)}
.page-hero p{max-width:60ch;color:rgba(244,237,220,.85);font-size:1.15rem;margin-top:1rem}

/* small label heading above sections */
.sec-head{max-width:680px;margin-bottom:2.6rem}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head p{margin-top:.9rem;color:var(--ink-soft);font-size:1.12rem}

/* footer */
.site-footer{background:var(--ink);color:rgba(244,237,220,.78);padding-block:clamp(3rem,6vw,4.5rem) 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr;gap:2rem}}
.site-footer .brand{color:#fff;margin-bottom:1rem}
.site-footer h4{font-family:var(--body);font-weight:800;font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-soft);margin:0 0 1rem}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.footer-links a{color:rgba(244,237,220,.78)}
.footer-links a:hover{color:#fff}
.footer-blessing{font-family:var(--display);font-style:italic;font-size:1.18rem;color:var(--gold-soft);
  max-width:34ch;line-height:1.4}
.footer-bottom{border-top:1px solid rgba(244,237,220,.14);margin-top:2.6rem;padding-top:1.6rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;
  font-size:.85rem;color:rgba(244,237,220,.55)}

/* misc */
.tag-line{font-family:var(--display);font-style:italic;color:var(--gold-deep);font-size:1.15rem}
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.pill{background:rgba(60,124,121,.1);color:var(--water-deep);border-radius:999px;
  padding:.35em .9em;font-size:.85rem;font-weight:700}

/* =========================================================================
   v2 — Berkshire-style pass: photo-ready dawn scenes, image feature cards,
   gold flourishes, and the booking / schedule / giving widgets.
   Appended last so it overrides earlier rules where intended.
   ========================================================================= */

/* ---------- photo-ready dawn scenes (painted placeholders) ----------
   To use a real photo: drop  <img src="photo.jpg" alt="">  inside any
   .media-arch or .media-scene and the painted scene hides automatically. */
.media-scene,.media-arch{
  position:relative;overflow:hidden;
  background:
    radial-gradient(58% 38% at 50% 76%, rgba(255,247,228,.92), rgba(234,197,127,0) 60%),
    linear-gradient(180deg,#23403B 0%, #3C7C79 30%, #E7C383 66%, #F4DEAE 100%);
}
.media-scene::before,.media-arch::before{ /* far ridge */
  content:"";position:absolute;left:-12%;right:-12%;bottom:30%;height:34%;
  background:#3A5446;border-radius:50%;transform:scaleX(1.5);opacity:.92;z-index:1;
}
.media-scene::after,.media-arch::after{ /* near ridge */
  content:"";position:absolute;left:-16%;right:-16%;bottom:-8%;height:40%;
  background:#1C2B23;border-radius:50% 50% 0 0;transform:scaleX(1.6);z-index:2;
}
.media-scene .sun,.media-arch .sun,.media-arch .ring{ /* rising sun (reuses old .ring) */
  position:absolute;left:50%;bottom:33%;transform:translateX(-50%);
  width:30%;aspect-ratio:1;border:0;border-radius:50%;z-index:1;
  background:radial-gradient(circle,#fff 0%,#FBE7BD 42%,rgba(234,197,127,0) 72%);
  box-shadow:0 0 60px 8px rgba(234,197,127,.5);
}
.media-scene img,.media-arch img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:4}
.media-scene:has(img)::before,.media-scene:has(img)::after,
.media-arch:has(img)::before,.media-arch:has(img)::after,
.media-arch:has(img) .ring,.media-arch:has(img) .sun,.media-scene:has(img) .sun{display:none}

/* scene moods (for variety across the feature cards) */
.scene-water{background:
   radial-gradient(58% 40% at 50% 78%, rgba(220,245,242,.9), rgba(60,124,121,0) 60%),
   linear-gradient(180deg,#1F3A40 0%, #2F6360 34%, #6FA9A0 70%, #CFE6DF 100%)}
.scene-meadow{background:
   radial-gradient(56% 38% at 50% 76%, rgba(255,247,224,.95), rgba(234,197,127,0) 60%),
   linear-gradient(180deg,#2A3B2A 0%, #5C7349 34%, #B6C07E 70%, #E7E7C6 100%)}
.scene-dusk{background:
   radial-gradient(56% 40% at 50% 80%, rgba(255,233,214,.9), rgba(85,58,85,0) 60%),
   linear-gradient(180deg,#241B2E 0%, #553A55 34%, #B07A6B 72%, #EAC8A6 100%)}

/* ---------- Berkshire-style image feature cards ---------- */
.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media(max-width:840px){.feature-row{grid-template-columns:1fr}}
.feature{position:relative;min-height:330px;border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--line-soft);
  transition:transform .2s ease,box-shadow .2s ease}
.feature:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(28,43,35,.6)}
.feature .ph{position:absolute;inset:0;z-index:0}
.feature::after{content:"";position:absolute;inset:0;z-index:3;
  background:linear-gradient(180deg,rgba(28,43,35,0) 26%,rgba(18,28,22,.86) 100%)}
.feature .ft{position:relative;z-index:4;padding:1.5rem 1.4rem 1.4rem;color:#fff}
.feature .ft h3{color:#fff;font-size:1.55rem;margin-bottom:.25rem}
.feature .ft p{color:rgba(244,237,220,.9);font-size:.95rem;margin:0 0 .9rem}
.feature .more{font-family:var(--body);font-weight:800;font-size:.82rem;letter-spacing:.05em;
  color:var(--gold-soft);text-transform:uppercase;display:inline-flex;align-items:center;gap:.4rem}
.feature .more::after{content:"→";transition:transform .2s ease}
.feature:hover .more{color:#fff}
.feature:hover .more::after{transform:translateX(4px)}

/* ---------- gold save-the-date ribbon (festival echo) ---------- */
.ribbon{background:var(--gold);color:#2A1C06;overflow:hidden;white-space:nowrap}
.ribbon .track{display:inline-block;padding-block:.55rem;font-family:var(--display);
  font-weight:600;letter-spacing:.04em;animation:marq 30s linear infinite}
.ribbon .track span{padding-inline:1rem;opacity:.55}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* gold section flourish */
.flourish{display:block;width:42px;height:3px;background:var(--gold);border-radius:3px;margin:.1rem 0 1.1rem}
.sec-head.center .flourish{margin-inline:auto}

/* ---------- embed wrapper (real Acuity / Sched mount here) ---------- */
.embed-wrap{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--paper-2);box-shadow:0 18px 44px -30px rgba(28,43,35,.5)}
.embed-wrap iframe{display:block;width:100%;border:0}
.embed-cap{font-size:.86rem;color:var(--ink-soft);margin-top:.85rem;text-align:center}
.embed-cap b{color:var(--gold-deep)}

/* ---------- mock booking widget (sample of the Acuity add-on flow) ---------- */
.booking{display:grid;grid-template-columns:1.3fr .9fr;gap:1.4rem;background:var(--paper-2);
  border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.3rem,3vw,2rem)}
@media(max-width:760px){.booking{grid-template-columns:1fr}}
.booking h3{font-size:.82rem;font-family:var(--body);font-weight:800;letter-spacing:.05em;
  text-transform:uppercase;color:var(--water-deep);margin:0 0 .9rem}
.booking h3+h3{margin-top:1.4rem}
.opt{display:flex;align-items:flex-start;gap:.7rem;padding:.7rem .85rem;border:1px solid var(--line);
  border-radius:12px;margin-bottom:.55rem;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.opt:hover{border-color:var(--gold);background:#fff}
.opt input{margin-top:.3rem;accent-color:var(--gold-deep);flex:0 0 auto}
.opt .t{font-weight:700;color:var(--ink);display:block}
.opt .d{font-size:.84rem;color:var(--ink-soft);display:block}
.opt .pr{margin-left:auto;font-weight:800;color:var(--gold-deep);white-space:nowrap;padding-left:.6rem}
.summary{background:var(--ink);color:var(--paper);border-radius:14px;padding:1.3rem;align-self:start}
.summary h4{font-family:var(--body);font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  font-size:.76rem;color:var(--gold-soft);margin:0 0 .8rem}
.summary .line{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem;
  color:rgba(244,237,220,.85);padding:.22rem 0}
.summary .line.empty{color:rgba(244,237,220,.5);font-style:italic}
.summary .tot{border-top:1px solid rgba(244,237,220,.22);margin-top:.7rem;padding-top:.75rem;
  font-family:var(--display);font-size:1.5rem;color:#fff;display:flex;justify-content:space-between;align-items:baseline}
.summary .btn{width:100%;justify-content:center;margin-top:1rem}
.summary small{display:block;color:rgba(244,237,220,.55);font-size:.76rem;margin-top:.7rem;line-height:1.5}

/* ---------- schedule tabs (built-in vs Sched) ---------- */
.tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1.6rem}
.tab{font-family:var(--body);font-weight:800;font-size:.92rem;padding:.6em 1.2em;border-radius:999px;
  border:1.5px solid var(--line);background:var(--paper-2);color:var(--ink-soft);cursor:pointer;
  transition:background .15s ease,color .15s ease,border-color .15s ease}
.tab[aria-selected="true"]{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tabpanel[hidden]{display:none}

/* built-in schedule list */
.sched{display:grid;gap:.7rem;max-width:880px;margin-inline:auto}
.sched-row{display:grid;grid-template-columns:auto 1fr auto;gap:1.1rem;align-items:center;
  background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:1rem 1.2rem}
@media(max-width:680px){.sched-row{grid-template-columns:auto 1fr;gap:.5rem 1rem}}
.sched-when{text-align:center;min-width:62px}
.sched-when .d{font-family:var(--display);font-size:1.7rem;color:var(--gold-deep);line-height:1}
.sched-when .m{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.sched-row .ttl{font-family:var(--display);font-size:1.3rem;color:var(--ink);line-height:1.15}
.sched-row .meta{font-size:.88rem;color:var(--ink-soft)}
@media(max-width:680px){.sched-row .btn{grid-column:1 / -1;justify-self:start}}

/* ---------- giving block (Stripe) ---------- */
.give{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.3rem,3vw,2.1rem);max-width:660px;margin-inline:auto;text-align:center}
.amts{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:1.1rem 0 .4rem}
.amt{font-family:var(--body);font-weight:800;font-size:1.05rem;padding:.55em 1.1em;border-radius:12px;
  border:1.5px solid var(--line);background:var(--paper);color:var(--ink);cursor:pointer;min-width:82px;
  transition:background .15s ease,color .15s ease,border-color .15s ease}
.amt[aria-pressed="true"]{background:var(--gold);color:#fff;border-color:var(--gold)}
.give .fund{font-family:var(--body);font-size:1rem;padding:.7em .9em;border:1.5px solid var(--line);
  border-radius:12px;background:var(--paper);width:100%;max-width:380px;margin:.5rem auto .2rem;color:var(--ink)}
.give-note{font-size:.84rem;color:var(--ink-soft);margin-top:.9rem}

/* photography-first: real photos fill feature cards, hero & page headers */
.feature img.ph{width:100%;height:100%;object-fit:cover}
.hero,.page-hero{background-size:cover;background-position:center center;background-repeat:no-repeat}
.hero-photo .hero-sub,.hero-photo .hero-tag{color:#fff}
.photo-credit{font-size:.72rem;color:rgba(244,237,220,.5);text-align:center;padding:.4rem 0}

/* =========================================================================
   v3 — APPROVED DIRECTION (matches the v2 mockup Steve & Edith liked):
   dark forest header, white+gold over photography, squared uppercase gold
   buttons, editorial serif marquee, lighter body weight.
   Appended last so it overrides earlier rules.
   ========================================================================= */

body{font-weight:300}
h1,h2,h3,h4{font-weight:600}

/* dark forest header, white nav, gold hover */
.site-header{background:var(--ink);border-bottom:0;backdrop-filter:none}
.site-header .brand{color:#fff;font-size:1.35rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.site-header .brand:hover{color:var(--gold-soft)}
.nav-links a{color:rgba(255,255,255,.88);font-weight:400;font-size:.8rem;
  letter-spacing:.16em;text-transform:uppercase}
.nav-links a:hover{color:var(--gold-soft)}
.nav-links a[aria-current="page"]{color:#fff}
.nav-toggle{color:#fff}
@media (max-width:920px){
  .nav-links{background:var(--ink);border-bottom:1px solid rgba(255,255,255,.14)}
  .nav-links a{border-bottom-color:rgba(255,255,255,.1)}
}

/* squared, uppercase, letter-spaced buttons */
.btn{border-radius:2px;text-transform:uppercase;letter-spacing:.2em;
  font-weight:500;font-size:.78rem;padding:1.05em 2.6em}
.btn--gold{box-shadow:none}
.btn--gold:hover{transform:none;background:var(--gold-deep)}

/* eyebrows — centered-friendly gold, no dash; tight lockup with heading */
.eyebrow{color:var(--gold-deep);font-weight:500;letter-spacing:.28em;font-size:.7rem;
  margin-bottom:.55rem}
.eyebrow::before{display:none}

/* heading scale tuned for Cormorant (smaller x-height than Fraunces) */
.h-xl{font-size:clamp(2.9rem,6.8vw,5.3rem)}
.h-lg{font-size:clamp(2.3rem,4.8vw,3.5rem)}
.h-md{font-size:clamp(1.7rem,2.9vw,2.3rem)}
.sec-head p{font-size:1.05rem;margin-top:.7rem}
.card h3{font-size:1.45rem}
.path h3{font-size:1.65rem}
.feature .ft h3{font-size:1.7rem}

/* ribbon — editorial: white band, serif, gold marks (was solid gold) */
.ribbon{background:#fff;color:var(--ink);border-top:1px solid #E9E2D2;border-bottom:1px solid #E9E2D2}
.ribbon .track{font-size:1.35rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;padding-block:.8rem}
.ribbon .track span{color:var(--gold);opacity:1}

/* squarer cards & paths (retire the heavy arch radius) */
.path{border-radius:var(--radius)}
.path .links a{border-radius:4px}

/* four-paths: photo-topped cards (replaces painted door glyph, photography-first) */
.path{padding:0;overflow:hidden}
.path .door{display:none}
.path-photo{display:block;aspect-ratio:4/3;overflow:hidden;background:var(--paper-2)}
.path-photo img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s ease}
.path:hover .path-photo img{transform:scale(1.04)}
.path-body{flex:1;display:flex;flex-direction:column;
  padding:1.6rem 1.4rem 1.5rem;text-align:center}
.path-body .kicker{margin-bottom:.5rem}
.path-body h3{margin-bottom:.5rem}
.path-body .links{margin-top:auto}
.field-row input{border-radius:2px;background:#fff}
.form input,.form select,.form textarea{border-radius:4px;background:#fff}
.tab{border-radius:2px;text-transform:uppercase;letter-spacing:.12em;font-weight:500;font-size:.8rem}
.chip{border-radius:4px}
.pill{border-radius:4px}
.amt{border-radius:4px}

/* hero type — large serif, airy sans tag */
.hero h1{font-weight:600}
.hero-tag{font-family:var(--body);font-style:normal;text-transform:uppercase;
  letter-spacing:.34em;font-size:.9rem;color:rgba(255,255,255,.95)}
.hero-tag span{color:var(--gold-soft);opacity:1}

/* nav & footer brand serif consistency */
.site-footer .brand{letter-spacing:.1em;text-transform:uppercase}
.site-footer h4{font-weight:500;letter-spacing:.2em}

/* collapse stacked padding between consecutive same-background sections */
main .section:not(.band-soft):not(.band-ink) + .section:not(.band-soft):not(.band-ink){
  padding-top:calc(var(--section-y)*.45)}

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