:root {
  --aubergine: #725c74;
  --aubergine-dark: #4d3d4f;
  --taupe: #a48a7a;
  --sand: #c6a278;
  --cream: #f5f0e9;
  --paper: #fcfaf7;
  --ink: #302d2c;
  --muted: #696361;
  --line: rgba(77, 62, 80, .18);
  --shadow: 0 22px 70px rgba(77, 62, 80, .13);
  --shell: min(1180px, calc(100% - 40px));
  --serif: Georgia, 'Times New Roman', serif;
  --sans: 'Century Gothic', 'Trebuchet MS', Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 124px; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); font-size: 16px; line-height: 1.7; }
body.menu-open { overflow: hidden; }
body, button, summary { font-family: var(--sans); }
img { display: block; width: 100%; height: auto; }
a { color: inherit; }
button, a, summary { -webkit-tap-highlight-color: transparent; }
:focus-visible { outline: 3px solid var(--sand); outline-offset: 4px; }
::selection { color: #fff; background: var(--aubergine); }

.shell { width: var(--shell); margin-inline: auto; }
.hero[id], .section[id] { scroll-margin-top: 124px; }
.section { position: relative; padding: clamp(88px, 11vw, 154px) 0; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 1000; top: 12px; left: 12px; padding: 10px 16px; color: #fff; background: var(--aubergine-dark); transform: translateY(-160%); }
.skip-link:focus { transform: none; }

.site-header { position: fixed; z-index: 100; top: 0; left: 0; display: flex; align-items: center; justify-content: space-between; width: 100%; min-height: 118px; padding: 12px clamp(20px, 5vw, 72px); color: #fff; transition: min-height .3s ease, padding .3s ease, color .3s ease, background-color .3s ease, box-shadow .3s ease; }
.site-header.is-compact { min-height: 76px; padding-block: 7px; color: var(--aubergine-dark); background: rgba(252,250,247,.96); box-shadow: 0 8px 28px rgba(45,37,46,.1); backdrop-filter: blur(12px); }
.brand { display: inline-flex; align-items: center; color: inherit; text-decoration: none; }
.brand-panel { padding: 8px 14px; border: 1px solid rgba(255,255,255,.45); border-radius: 14px; background: rgba(252,250,247,.94); box-shadow: 0 9px 28px rgba(38,27,35,.16); backdrop-filter: blur(8px); transition: padding .3s ease, border-color .3s ease, box-shadow .3s ease, background-color .3s ease; }
.brand-logo { width: 176px; height: auto; transition: width .3s ease, filter .3s ease, opacity .3s ease; }
.brand-hero {
  position: relative;
  margin-left: 6px;
  padding: 12px 10px 10px;
  isolation: isolate;
}
.brand-hero::before,
.brand-hero::after {
  position: absolute;
  content: '';
  inset: -28px -26px -24px;
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: screen;
}
.brand-hero::before {
  background:
    radial-gradient(ellipse at 46% 48%, rgba(246,240,233,.82) 0%, rgba(246,240,233,.52) 30%, rgba(246,240,233,.14) 58%, rgba(246,240,233,0) 79%),
    radial-gradient(ellipse at 58% 56%, rgba(255,247,234,.52) 0%, rgba(255,247,234,.18) 40%, rgba(255,247,234,0) 74%);
  filter: blur(26px);
  opacity: .95;
  transform: scale(1.08) rotate(-4deg);
}
.brand-hero::after {
  inset: -14px -10px -10px;
  background: radial-gradient(ellipse at 50% 50%, rgba(244,235,220,.48) 0%, rgba(244,235,220,.18) 40%, rgba(244,235,220,0) 72%);
  filter: blur(10px);
  opacity: .85;
  transform: scale(1.02);
}
.brand-hero .brand-logo { position: relative; z-index: 1; width: 214px; filter: brightness(1.08) contrast(1.12); }
.site-header.is-compact .brand-hero { padding: 4px 6px; }
.site-header.is-compact .brand-hero::before { inset: -18px -16px -14px; opacity: .38; filter: blur(18px); }
.site-header.is-compact .brand-hero::after { inset: -10px -8px -8px; opacity: .24; filter: blur(8px); }
.site-header.is-compact .brand-logo { width: 126px; }
.site-nav { display: flex; align-items: center; gap: clamp(22px, 3vw, 46px); }
.site-nav a { position: relative; font-size: .8rem; font-weight: 700; letter-spacing: .08em; text-decoration: none; text-transform: uppercase; }
.site-nav a:not(.nav-cta)::after { position: absolute; bottom: -6px; left: 0; width: 100%; height: 1px; content: ''; background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .25s ease; }
.site-nav a:hover::after, .site-nav a[aria-current='location']::after { transform: scaleX(1); transform-origin: left; }
.site-nav .nav-cta { padding: 10px 18px; border: 1px solid rgba(255, 255, 255, .65); border-radius: 100px; transition: color .25s, background .25s; }
.site-nav .nav-cta:hover { color: var(--aubergine-dark); background: #fff; }
.site-header.is-compact .site-nav .nav-cta { border-color: var(--aubergine); }
.site-nav .nav-cta[aria-current='location'] { color: var(--aubergine-dark); background: #fff; }
.site-header.is-compact .site-nav .nav-cta[aria-current='location'] { color: #fff; background: var(--aubergine); }
.nav-toggle { display: none; }

.hero { position: relative; display: grid; min-height: min(880px, 100svh); color: #fff; isolation: isolate; }
.hero-image, .hero-shade { position: absolute; z-index: -2; inset: 0; }
.hero-image { background: url('../images/hero.webp') center 62% / cover no-repeat; }
.hero-shade { z-index: -1; background: linear-gradient(90deg, rgba(31, 24, 28, .75) 0%, rgba(43, 31, 34, .34) 48%, rgba(43, 31, 34, .08) 80%), linear-gradient(0deg, rgba(28, 21, 23, .35), transparent 42%); }
.hero-content { align-self: center; width: min(770px, calc(100% - 40px)); margin: 120px max(20px, calc((100% - 1180px) / 2)); padding: clamp(42px, 8vw, 90px) 0; }
.eyebrow { margin: 0 0 17px; color: var(--aubergine); font-size: .72rem; font-weight: 700; letter-spacing: .19em; line-height: 1.4; text-transform: uppercase; }
.hero .eyebrow, .closing .eyebrow { color: #e0c5a8; }
h1, h2, h3 { margin: 0; font-family: var(--serif); font-weight: 400; line-height: 1.08; }
h1 { font-size: clamp(3.35rem, 8.2vw, 7.15rem); letter-spacing: -.045em; }
h1 em, .closing h2 em { color: #e0c5a8; font-weight: 400; }
.hero-intro { max-width: 560px; margin: 28px 0 35px; font-size: clamp(1rem, 1.6vw, 1.2rem); line-height: 1.7; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 11px 22px; border: 1px solid var(--aubergine); border-radius: 100px; font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-decoration: none; text-transform: uppercase; transition: transform .2s, color .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button-light { border-color: rgba(255,255,255,.7); color: var(--aubergine-dark); background: #fff; }
.button-light:hover { color: #fff; background: var(--aubergine); border-color: var(--aubergine); }
.scroll-cue { position: absolute; right: clamp(20px, 5vw, 72px); bottom: 30px; display: flex; align-items: center; gap: 15px; color: #fff; font-size: .67rem; font-weight: 700; letter-spacing: .16em; text-decoration: none; text-transform: uppercase; }
.scroll-cue i { display: block; width: 1px; height: 52px; background: rgba(255,255,255,.7); }

.welcome { overflow: hidden; background: var(--cream); }
.welcome-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(280px, .72fr); gap: clamp(50px, 10vw, 140px); align-items: start; }
h2 { font-size: clamp(2.4rem, 5.3vw, 4.9rem); letter-spacing: -.035em; }
.prose p { margin: 0 0 1.3em; }
.lead-prose { padding-top: 41px; font-size: 1.02rem; }
.signature-line { color: var(--aubergine); font-family: var(--serif); font-size: 1.35rem; font-style: italic; }
.sound-rings { position: absolute; width: 380px; aspect-ratio: 1; border: 1px solid rgba(114,92,116,.18); border-radius: 50%; pointer-events: none; }
.sound-rings::before, .sound-rings::after { position: absolute; border: 1px solid rgba(114,92,116,.15); border-radius: inherit; content: ''; inset: 16%; }
.sound-rings::after { inset: 33%; }
.sound-rings-one { right: -240px; bottom: -220px; }

.offer { background: var(--paper); }
.section-heading { max-width: 700px; margin-bottom: clamp(56px, 8vw, 100px); }
.section-heading > p:last-child { max-width: 570px; margin: 24px 0 0; color: var(--muted); }
.section-heading-tight { margin-bottom: 0; }
.offer-list { display: grid; gap: clamp(70px, 11vw, 140px); }
.offer-card { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(300px, .8fr); gap: clamp(38px, 8vw, 100px); align-items: center; }
.offer-card-reverse .offer-media { order: 2; }
.offer-card-reverse .offer-copy { order: 1; }
.offer-media { position: relative; overflow: hidden; aspect-ratio: 1.25; border-radius: 28px; box-shadow: none; }
.offer-card-reverse .offer-media { border-radius: 28px; }
.offer-media img { height: 100%; object-fit: cover; transition: transform .7s ease; }
.offer-card:hover .offer-media img { transform: scale(1.025); }
.offer-copy { position: relative; }
.offer-number { display: block; margin-bottom: 28px; color: var(--taupe); font-family: var(--serif); font-size: 1rem; }
.offer-copy h3 { color: var(--aubergine-dark); font-size: clamp(2.25rem, 4vw, 4rem); letter-spacing: -.03em; }
.offer-subtitle { max-width: 490px; margin: 18px 0 28px; color: var(--muted); font-size: 1.02rem; }
details { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
summary { display: flex; align-items: center; justify-content: space-between; padding: 16px 2px; color: var(--aubergine-dark); font-size: .73rem; font-weight: 700; letter-spacing: .1em; cursor: pointer; list-style: none; text-transform: uppercase; }
summary::-webkit-details-marker { display: none; }
summary span { position: relative; width: 19px; height: 19px; }
summary span::before, summary span::after { position: absolute; top: 9px; left: 2px; width: 15px; height: 1px; content: ''; background: currentColor; transition: transform .2s; }
summary span::after { transform: rotate(90deg); }
details[open] summary span::after { transform: rotate(0); }
.detail-copy { padding: 2px 0 17px; color: var(--muted); font-size: .93rem; }
.detail-copy p { margin: 0 0 1em; }

.events-section { overflow: hidden; background: linear-gradient(180deg, #f9f4ee 0%, #f5f0e9 100%); }
.events-intro { display: flex; justify-content: space-between; gap: 32px; align-items: end; margin-bottom: clamp(38px, 6vw, 64px); }
.events-note { max-width: 430px; margin: 0; color: var(--muted); font-size: .96rem; }
.events-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.event-card {
  padding: clamp(22px, 3.5vw, 30px);
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(255,255,255,.78);
  box-shadow: none;
  backdrop-filter: blur(8px);
}
.event-card-loading { border-style: dashed; background: rgba(255,255,255,.42); }
.event-card-header { display: flex; justify-content: space-between; gap: 18px; align-items: center; margin-bottom: 12px; }
.event-date, .event-chip {
  margin: 0;
  padding: 7px 12px;
  border-radius: 100px;
  color: var(--aubergine-dark);
  background: #f0e2d3;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.event-chip { color: #fff; background: var(--aubergine); }
.event-card h3 { margin-top: 4px; color: var(--aubergine-dark); font-size: clamp(1.7rem, 3vw, 2.4rem); letter-spacing: -.025em; }
.event-title-link { display: inline-flex; color: inherit; text-decoration: none; }
.event-title-link:hover h3 { color: var(--aubergine); }
.event-subtitle { margin: 10px 0 0; color: var(--taupe); font-size: .98rem; font-style: italic; }
.event-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 20px 0 18px;
}
.event-meta-item {
  margin: 0;
  padding: 12px 14px;
  border: 1px solid rgba(77,61,79,.12);
  border-radius: 14px;
  background: rgba(245,240,233,.72);
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.55;
}
.event-meta-item span {
  display: block;
  margin-bottom: 4px;
  color: var(--aubergine-dark);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
}
.event-note {
  margin: 0 0 16px;
  color: var(--aubergine-dark);
  font-size: .86rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.event-excerpt { margin: 0 0 18px; color: var(--muted); font-size: .95rem; }
.event-actions { display: flex; justify-content: flex-start; gap: 10px; flex-wrap: wrap; }
.event-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 18px;
  border: 1px solid var(--aubergine);
  border-radius: 100px;
  color: var(--aubergine-dark);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-decoration: none;
  text-transform: uppercase;
  transition: color .2s, background-color .2s, transform .2s;
}
.event-action-secondary {
  color: var(--aubergine-dark);
  background: rgba(255,255,255,.72);
}
.event-action:hover { color: #fff; background: var(--aubergine); transform: translateY(-1px); }
.events-empty {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: .96rem;
}

.about { overflow: hidden; color: #f7f2eb; background: var(--aubergine-dark); }
.about-grid { display: grid; grid-template-columns: minmax(280px, .82fr) minmax(320px, 1fr); gap: clamp(55px, 10vw, 135px); align-items: center; }
.about-photo-wrap { position: relative; padding: 0 0 58px 52px; }
.about-photo { overflow: hidden; aspect-ratio: .79; border-radius: 28px; box-shadow: none; }
.about-photo img { height: 100%; object-fit: cover; object-position: center; }
.photo-note { position: absolute; bottom: 0; left: 0; margin: 0; padding: 20px 22px; color: var(--aubergine-dark); background: #e5d5c1; font-family: var(--serif); font-size: 1rem; font-style: italic; line-height: 1.45; }
.about .eyebrow { color: #d8b991; }
.about-copy h2 { margin-bottom: 33px; }
.about-copy .prose { color: rgba(255,255,255,.76); }
blockquote { margin: 34px 0 0; padding: 2px 0 2px 24px; border-left: 1px solid #d8b991; color: #f0d8b9; font-family: var(--serif); font-size: clamp(1.2rem, 2vw, 1.55rem); font-style: italic; line-height: 1.55; }

.closing { position: relative; overflow: hidden; padding: clamp(100px, 13vw, 180px) 0; color: #fff; text-align: center; background: var(--aubergine); }
.closing-inner { position: relative; z-index: 1; }
.closing h2 { font-size: clamp(2.7rem, 6vw, 5.5rem); }
.closing p:not(.eyebrow) { margin: 27px 0 31px; color: rgba(255,255,255,.78); }
.sound-rings-two { top: 50%; left: 50%; width: min(780px, 95vw); border-color: rgba(255,255,255,.12); transform: translate(-50%, -50%); }
.sound-rings-two::before, .sound-rings-two::after { border-color: rgba(255,255,255,.1); }

.gift { background: linear-gradient(180deg, #f9f4ef 0%, #f5f0e9 100%); }
.gift-inner {
  max-width: 820px;
  margin-inline: auto;
  padding: clamp(26px, 4vw, 44px);
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(255,255,255,.58);
  text-align: center;
}
.gift h2 { margin-bottom: 18px; color: var(--aubergine-dark); }
.gift-copy { max-width: 640px; margin: 0 auto 24px; color: var(--muted); }
.gift-lines { margin: 18px 0 0; color: var(--aubergine-dark); font-family: var(--serif); font-size: 1.2rem; font-style: italic; line-height: 1.7; }
.gift-lines span { display: block; }
.gift .button { margin-top: 10px; }

.site-footer { padding: 70px 0 90px; color: #ddd4cb; background: #2d252e; }
.footer-grid { display: grid; grid-template-columns: 1.1fr .7fr .7fr .9fr; gap: 34px; padding-bottom: 56px; align-items: start; }
.footer-brand-wrap { display: flex; align-items: flex-start; }
.footer-brand { color: #f6efe7; }
.footer-brand .brand-logo { width: 228px; filter: brightness(0) saturate(100%) invert(91%) sepia(12%) saturate(320%) hue-rotate(329deg) brightness(105%) contrast(94%); }
.footer-grid > div > p { margin: 15px 0 0; color: #a99ea6; font-family: var(--serif); font-style: italic; }
.footer-nav { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.footer-nav a { color: #c6bdc4; font-size: .78rem; letter-spacing: .07em; text-decoration: none; text-transform: uppercase; }
.footer-nav a:hover { color: #fff; }
.footer-nav a[aria-current='page'], .legal-links a[aria-current='page'] { color: #fff; text-decoration: underline; text-decoration-color: var(--taupe); text-decoration-thickness: 2px; text-underline-offset: 6px; }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.1); color: #8f858d; font-size: .72rem; }
.footer-bottom p { margin: 0; }
.footer-contact { display: grid; justify-items: start; gap: 8px; color: #d8d0d4; }
.footer-label { margin: 0; color: #f4ece3; font-family: var(--serif); font-size: 1.3rem; }
.footer-contact-person { margin: 0; color: #f5efe6; font-size: .98rem; }
.footer-contact a { color: #c6bdc4; font-size: .82rem; text-decoration: none; }
.footer-contact a:hover { color: #fff; }
.footer-contact-actions { display: grid; gap: 10px; width: 100%; margin-top: 8px; }
.footer-action {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 11px 16px;
  border: 1px solid rgba(255,255,255,.62);
  border-radius: 999px;
  color: #f4ece3 !important;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  background: transparent;
  transition: background-color .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
}
.footer-action svg { width: 18px; height: 18px; fill: currentColor; flex: 0 0 auto; }
.footer-action:hover { color: var(--aubergine-dark) !important; background: #f5efe6; border-color: #f5efe6; transform: translateY(-1px); }
.legal-site-footer { padding-top: 52px; }
.legal-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 12px 28px; }
.legal-links a { color: #c6bdc4; font-size: .72rem; letter-spacing: .07em; text-decoration: none; text-transform: uppercase; }
.legal-links a:hover { color: #fff; }

.legal-page { background: var(--cream); }
.info-page { background: linear-gradient(180deg, #f7f2eb 0%, #fcfaf7 100%); }
.legal-header { position: sticky; min-height: 126px; color: var(--aubergine-dark); background: rgba(252,250,247,.97); border-bottom: 1px solid var(--line); }
.legal-header .brand-logo { width: 185px; }
.legal-header .site-nav a { color: var(--aubergine-dark); }
.legal-header .site-nav .nav-cta { border-color: var(--aubergine); }
.legal-main { min-height: 65vh; padding: clamp(70px, 10vw, 120px) 0; }
.legal-content { max-width: 940px; }
.legal-content h1 { margin-bottom: 30px; color: var(--aubergine-dark); font-size: clamp(3rem, 6vw, 5.4rem); }
.legal-content h2 { margin: 50px 0 14px; font-size: clamp(1.55rem, 3vw, 2.2rem); }
.legal-content h3 { margin: 30px 0 10px; font-size: 1.3rem; }
.legal-content p, .legal-content li { color: var(--muted); }
.legal-content a { color: var(--aubergine-dark); }
.notice { margin: 28px 0 40px; padding: 20px 22px; border-left: 3px solid var(--taupe); background: #fff; }
.notice strong { color: var(--aubergine-dark); }
.withdrawal-content { max-width: 940px; }
.legal-callout { margin: 24px 0 34px; padding: 24px 26px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.58); }
.legal-callout p { margin: 0; }

.info-main { padding-top: 22px; }
.info-hero { max-width: 860px; padding-bottom: 26px; }
.info-intro { max-width: 700px; margin: 22px 0 0; color: var(--muted); font-size: 1.02rem; }
.info-section { padding-top: 40px; padding-bottom: 40px; }
.info-section h2 { margin-bottom: 20px; color: var(--aubergine-dark); font-size: clamp(2rem, 4vw, 3.4rem); }
.info-rates { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-top: 22px; }
.info-rate {
  padding: 24px 22px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255,255,255,.68);
}
.info-rate h3 { margin-bottom: 12px; color: var(--aubergine-dark); font-size: 1.5rem; }
.info-rate p { margin: 0 0 8px; color: var(--muted); }
.info-rate strong { display: block; margin-top: 14px; color: var(--aubergine-dark); font-family: var(--serif); font-size: 1.45rem; font-weight: 400; }
.info-note { max-width: 650px; margin: 18px 0 0; color: var(--muted); }
.info-text-block {
  max-width: 780px;
  padding: 22px 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255,255,255,.62);
}
.info-callout {
  max-width: 780px;
  padding: 22px 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(245,240,233,.86);
}
.info-callout h3 {
  margin-bottom: 14px;
  color: var(--aubergine-dark);
  font-size: 1.6rem;
}
.info-callout p:last-child { margin-bottom: 0; }
.info-text-block p:last-child { margin-bottom: 0; }
.info-faq { display: grid; gap: 12px; max-width: 860px; }
.info-faq details {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.62);
}
.info-faq summary {
  padding: 18px 20px;
  font-size: .8rem;
  letter-spacing: .09em;
}
.info-faq .detail-copy { padding: 0 20px 18px; }
.info-contact-section { padding-bottom: 70px; }
.info-contact {
  display: grid;
  gap: 8px;
  max-width: 420px;
  padding: 22px 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255,255,255,.62);
}
.info-contact p,
.info-contact a { margin: 0; }
.info-contact a { color: var(--aubergine-dark); text-decoration: none; }
.info-contact-actions {
  display: grid;
  gap: 10px;
  margin-top: 6px;
}
.info-contact-action {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 11px 16px;
  border: 1px solid rgba(114,92,116,.32);
  border-radius: 999px;
  color: var(--aubergine-dark);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-decoration: none;
  text-transform: uppercase;
  background: rgba(255,255,255,.78);
  transition: background-color .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
}
.info-contact-action svg { width: 18px; height: 18px; fill: currentColor; flex: 0 0 auto; }
.info-contact-action:hover { color: #fff; background: var(--aubergine); border-color: var(--aubergine); transform: translateY(-1px); }
.info-contact-closing { margin-top: 8px !important; color: var(--muted) !important; font-style: italic; }
.info-cta {
  display: inline-flex;
  margin-top: 14px;
  color: var(--aubergine-dark);
  border-color: var(--aubergine);
  background: transparent;
}
.info-cta:hover { color: #fff; background: var(--aubergine); }

.event-detail-shell {
  max-width: 940px;
}
.event-detail-card {
  display: grid;
  gap: 22px;
  padding: clamp(24px, 4vw, 34px);
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(255,255,255,.72);
}
.event-detail-top {
  display: flex;
  justify-content: space-between;
  gap: 16px 20px;
  align-items: start;
  flex-wrap: wrap;
}
.event-detail-title { color: var(--aubergine-dark); }
.event-detail-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.event-detail-meta-item {
  margin: 0;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(245,240,233,.75);
}
.event-detail-meta-item span {
  display: block;
  margin-bottom: 4px;
  color: var(--aubergine-dark);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.event-detail-description {
  max-width: 760px;
}
.event-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.withdrawal-form { margin-top: 34px; padding: clamp(24px, 5vw, 48px); border: 1px solid var(--line); border-radius: 18px; background: var(--paper); box-shadow: 0 18px 55px rgba(77,61,79,.08); }
.form-intro { display: grid; gap: 3px; margin-bottom: 34px; padding: 17px 19px; border-left: 3px solid var(--taupe); background: var(--cream); color: var(--muted); font-size: .91rem; }
.form-intro strong { color: var(--aubergine-dark); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 23px 26px; }
.field-group { display: grid; gap: 8px; }
.field-wide { grid-column: 1 / -1; }
.field-group label, .request-type legend { color: var(--aubergine-dark); font-size: .83rem; font-weight: 700; letter-spacing: .025em; }
.optional { color: var(--muted); font-size: .72rem; font-weight: 400; }
.field-group input, .field-group textarea { width: 100%; min-height: 48px; padding: 11px 13px; border: 1px solid rgba(77,61,79,.3); border-radius: 7px; color: var(--ink); background: #fff; font: inherit; line-height: 1.45; transition: border-color .2s, box-shadow .2s; }
.field-group textarea { min-height: 130px; resize: vertical; }
.field-group input:hover, .field-group textarea:hover { border-color: var(--aubergine); }
.field-group input:focus, .field-group textarea:focus { border-color: var(--aubergine); outline: none; box-shadow: 0 0 0 3px rgba(114,92,116,.16); }
.request-type { display: grid; gap: 11px; margin: 32px 0; padding: 0; border: 0; }
.request-type legend { margin-bottom: 11px; }
.request-type > label { display: grid; grid-template-columns: 22px 1fr; gap: 12px; align-items: start; padding: 15px 16px; border: 1px solid var(--line); border-radius: 9px; background: #fff; cursor: pointer; }
.request-type > label:hover { border-color: var(--aubergine); }
.request-type input, .consent-field input { width: 19px; height: 19px; margin: 2px 0 0; accent-color: var(--aubergine); }
.request-type label > span { display: grid; gap: 2px; }
.request-type small { color: var(--muted); font-size: .8rem; font-weight: 400; line-height: 1.5; }
.consent-field { display: grid; grid-template-columns: 22px 1fr; gap: 12px; align-items: start; margin-top: 28px; color: var(--muted); font-size: .86rem; cursor: pointer; }
.form-privacy { margin: 19px 0 24px; font-size: .8rem; }
.form-submit[disabled] { border-color: #b8ada8; color: #766e6b; background: #e4dfda; cursor: not-allowed; opacity: 1; }
.form-submit[disabled]:hover { color: #766e6b; background: #e4dfda; transform: none; }

.back-to-top { position: fixed; z-index: 90; right: max(18px, env(safe-area-inset-right)); bottom: max(18px, env(safe-area-inset-bottom)); display: grid; place-items: center; width: 52px; height: 52px; padding: 0; border: 1px solid rgba(255,255,255,.3); border-radius: 50%; color: #fff; background: var(--aubergine); box-shadow: 0 10px 30px rgba(45,37,46,.24); cursor: pointer; opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(12px); transition: opacity .22s ease, visibility .22s ease, transform .22s ease, background-color .2s ease; }
.back-to-top.is-visible { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
.back-to-top:hover { background: var(--aubergine-dark); transform: translateY(-2px); }
.back-to-top svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

@media (max-width: 820px) {
  :root { --shell: min(100% - 32px, 620px); }
  .site-header { min-height: 100px; padding-inline: 14px; }
  .brand-panel { padding: 6px 10px; border-radius: 11px; }
  .brand-logo { width: 132px; }
  .site-header.is-compact { min-height: 68px; padding-block: 5px; }
  .site-header.is-compact .brand-panel { padding: 3px 8px; }
  .site-header.is-compact .brand-logo { width: 108px; }
  .nav-toggle { position: relative; z-index: 3; display: grid; place-content: center; width: 46px; height: 46px; padding: 0; border: 1px solid currentColor; border-radius: 50%; color: inherit; background: transparent; }
  .nav-toggle > span:not(.sr-only) { display: block; width: 18px; height: 1px; margin: 3px; background: currentColor; transition: transform .25s; }
  .nav-toggle[aria-expanded='true'] > span:nth-last-child(2) { transform: translateY(3.5px) rotate(45deg); }
  .nav-toggle[aria-expanded='true'] > span:last-child { transform: translateY(-3.5px) rotate(-45deg); }
  .site-nav { position: fixed; top: 0; right: 0; display: none; align-items: stretch; width: min(340px, 88vw); height: 100dvh; min-height: 100vh; padding: 105px 28px 40px; color: var(--aubergine-dark); background: var(--paper); box-shadow: -20px 0 50px rgba(30,20,30,.18); overflow-y: auto; }
  .site-nav.is-open { display: flex; flex-direction: column; }
  .site-nav a { padding: 10px 0; font-size: .86rem; }
  .site-nav .nav-cta { margin-top: 8px; padding: 12px 17px; text-align: center; border-color: var(--aubergine); }
  .nav-toggle[aria-expanded='true'] { color: var(--aubergine-dark); }
  .legal-header { min-height: 100px; }
  .legal-header .brand-logo { width: 140px; }
.hero { min-height: 780px; }
.hero-image { background-position: 61% center; }
.hero-shade { background: linear-gradient(90deg, rgba(35,25,29,.77), rgba(40,29,31,.22)), linear-gradient(0deg, rgba(30,22,24,.44), transparent 50%); }
.hero-content { width: var(--shell); margin-inline: auto; }
.hero-intro { max-width: 440px; }
.scroll-cue { display: none; }
.welcome-grid, .about-grid { grid-template-columns: 1fr; }
.lead-prose { padding-top: 0; }
.offer-card { grid-template-columns: 1fr; gap: 35px; }
.offer-card-reverse .offer-media, .offer-card-reverse .offer-copy { order: initial; }
.offer-media, .offer-card-reverse .offer-media { border-radius: 24px; }
.events-intro { flex-direction: column; align-items: start; }
.events-note { max-width: 560px; }
.events-grid { grid-template-columns: 1fr; }
  .event-meta { grid-template-columns: 1fr; }
  .event-detail-meta { grid-template-columns: 1fr; }
  .about-photo-wrap { width: min(100%, 500px); }
.footer-grid { grid-template-columns: 1fr 1fr; }
.footer-grid > div { grid-column: 1 / -1; }
.back-to-top { width: 48px; height: 48px; }
  .footer-bottom { align-items: flex-start; }
  .legal-links { max-width: 440px; }
  .info-rates { grid-template-columns: 1fr; }
  .gift-inner,
  .info-callout { border-radius: 18px; padding: 20px; }
  .gift-lines { font-size: 1.05rem; }
}

@media (max-width: 480px) {
  .hero { min-height: 720px; }
  .hero-content { padding-top: 72px; }
  h1 { font-size: clamp(3rem, 15.5vw, 4.4rem); }
  .offer-media { aspect-ratio: 1.05; }
  .about-photo-wrap { padding: 0 0 46px 30px; }
  .photo-note { padding: 15px 17px; font-size: .87rem; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-grid > div { grid-column: auto; }
  .footer-grid > div > p { margin-left: 0; }
  .footer-brand .brand-logo { width: 198px; }
  .footer-contact-actions { width: 100%; }
  .footer-bottom { gap: 20px; }
  .footer-bottom p:last-child { display: none; }
  .legal-site-footer .footer-bottom { flex-direction: column; }
  .legal-links { justify-content: flex-start; gap: 13px 20px; }
  .info-text-block,
  .info-rate,
  .info-callout,
  .info-contact { border-radius: 18px; padding: 20px; }
  .gift-inner { padding: 20px; }
  .gift h2 { font-size: clamp(2rem, 8vw, 3rem); }
  .gift-lines { font-size: 1rem; }
  .event-card-header { flex-direction: column; align-items: start; }
  .event-actions { width: 100%; }
  .event-action { width: 100%; }
  .form-grid { grid-template-columns: 1fr; }
  .field-wide { grid-column: auto; }
  .withdrawal-form { border-radius: 12px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; }
}
