:root {
  --ink: #17223c;
  --night: #111b35;
  --night-soft: #1d2948;
  --cream: #f6f0e5;
  --paper: #fffdf8;
  --gold: #dfbd72;
  --gold-light: #f2d99a;
  --lavender: #c8c8e8;
  --muted: #6b7180;
  --line: rgba(23, 34, 60, .16);
  --serif: "Iowan Old Style", "Palatino Linotype", "Noto Serif TC", "Songti TC", serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans TC", sans-serif;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
img { max-width: 100%; }
.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; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 max(5vw, 28px);
  background: rgba(255, 253, 248, .9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(23, 34, 60, .08);
}
.brand { display: flex; gap: 12px; align-items: center; letter-spacing: .12em; }
.brand strong { display: block; font-family: var(--serif); font-size: 20px; line-height: 1; }
.brand small { display: block; margin-top: 5px; font-size: 8px; letter-spacing: .22em; color: var(--muted); }
.brand-moon {
  width: 30px;
  height: 30px;
  display: block;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: inset -9px 0 0 var(--paper);
}
.site-nav { display: flex; align-items: center; gap: clamp(15px, 2vw, 31px); font-size: 14px; }
.site-nav a { padding: 27px 0 23px; border-bottom: 2px solid transparent; }
.site-nav a:hover, .site-nav a.active { color: #9b7226; border-color: var(--gold); }
.site-nav .nav-cta { padding: 10px 17px; border: 1px solid var(--ink); }
.site-nav .nav-cta:hover { color: var(--paper); background: var(--ink); border-color: var(--ink); }
.menu-toggle { display: none; border: 0; background: transparent; color: var(--ink); }

.hero {
  min-height: calc(100vh - 78px);
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  align-items: center;
  padding: 8vh max(7vw, 42px) 11vh;
  color: var(--paper);
  background:
    radial-gradient(circle at 18% 20%, rgba(74, 91, 143, .34), transparent 32%),
    linear-gradient(125deg, #10192f 0%, #17213c 55%, #0e1730 100%);
}
.hero-copy { position: relative; z-index: 2; max-width: 680px; }
.eyebrow {
  margin: 0 0 20px;
  color: var(--gold-light);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .26em;
}
.eyebrow.dark { color: #a77728; }
.hero h1, .page-hero h1, .about-hero h1 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(48px, 6vw, 86px);
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -.04em;
}
.lead { max-width: 600px; margin: 30px 0 36px; color: rgba(255, 255, 255, .76); font-size: 18px; }
.button-row { display: flex; flex-wrap: wrap; gap: 14px; }
.button {
  display: inline-flex;
  min-height: 50px;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .2s, background .2s, color .2s;
}
.button:hover { transform: translateY(-2px); }
.button-primary { color: var(--night); background: var(--gold-light); }
.button-ghost { color: var(--paper); border-color: rgba(255, 255, 255, .55); }
.button-light { color: var(--night); background: var(--paper); }
.button-dark { color: var(--paper); background: var(--night); }

.hero-art { position: relative; width: min(38vw, 520px); aspect-ratio: 1; justify-self: center; }
.moon {
  position: absolute;
  z-index: 2;
  top: 20%;
  left: 20%;
  width: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 38% 33%, #fff3c8 0, #e2c073 48%, #b78e47 100%);
  box-shadow: 0 0 70px rgba(237, 208, 137, .28);
}
.moon::before, .moon::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  background: rgba(134, 98, 45, .14);
}
.moon::before { width: 23%; height: 18%; top: 18%; left: 24%; }
.moon::after { width: 16%; height: 12%; right: 18%; bottom: 25%; }
.moon-shadow { position: absolute; inset: 0 0 0 46%; border-radius: 0 100% 100% 0; background: rgba(81, 59, 39, .14); }
.orbit { position: absolute; inset: 7%; border: 1px solid rgba(255, 255, 255, .17); border-radius: 50%; transform: rotate(-22deg); }
.orbit-two { inset: 0 16%; transform: rotate(55deg); }
.orbit-dot { position: absolute; width: 10px; height: 10px; border-radius: 50%; background: var(--gold-light); }
.dot-one { top: 8%; left: 43%; }.dot-two { right: 8%; bottom: 27%; }
.hero-art p { position: absolute; z-index: 3; right: 4%; bottom: 4%; margin: 0; color: rgba(255,255,255,.56); font: 13px/1.7 var(--serif); letter-spacing: .22em; }
.stars { position: absolute; inset: 0; opacity: .45; background-image: radial-gradient(circle, #fff 1px, transparent 1px); background-size: 83px 83px; mask-image: linear-gradient(to right, transparent 5%, black 55%, transparent); }
.scroll-hint { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); color: rgba(255,255,255,.55); font-size: 11px; letter-spacing: .12em; }
.scroll-hint span { margin-left: 10px; color: var(--gold); }

.section { max-width: var(--max); margin: 0 auto; padding: 110px 28px; }
.section-number { color: #b78330; font-family: var(--serif); font-size: 13px; }
.song-invite { display: grid; grid-template-columns: 60px 1fr .9fr; gap: 50px; align-items: center; }
.song-invite h2, .section-heading h2, .about-preview h2, .moon-letter h2, .work-banner h2, .form-section h2, .simple-hero h1, .resource-criteria h2, .story-section h2, .values-section h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(36px, 4vw, 58px);
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -.025em;
}
.song-invite-copy > p:not(.eyebrow) { max-width: 500px; margin: 27px 0; color: var(--muted); }
.text-link { display: inline-block; padding-bottom: 5px; border-bottom: 1px solid var(--ink); font-weight: 600; }
.text-link span { color: #a77728; }
.lyric-card {
  min-height: 340px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 50px;
  color: var(--paper);
  background: var(--night);
  overflow: hidden;
}
.lyric-card::after { content: ""; position: absolute; width: 230px; height: 230px; right: -65px; top: -80px; border: 1px solid rgba(223,189,114,.45); border-radius: 50%; }
.quote-mark { color: var(--gold); font: 70px/1 var(--serif); }
.lyric-card p { margin: 0; font: 27px/1.7 var(--serif); }
.sound-wave { display: flex; gap: 7px; height: 40px; align-items: center; margin-top: 40px; }
.sound-wave i { width: 2px; height: 10px; background: var(--gold); }
.sound-wave i:nth-child(2n) { height: 27px; }.sound-wave i:nth-child(3n) { height: 38px; }

.pathways, .featured { border-top: 1px solid var(--line); }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 60px; margin-bottom: 50px; }
.section-heading > p { max-width: 460px; margin: 0; color: var(--muted); }
.path-grid, .article-grid, .course-grid, .belief-grid, .resource-grid, .values-grid, .now-grid { display: grid; gap: 22px; }
.path-grid { grid-template-columns: repeat(3, 1fr); }
.focus-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.focus-card { min-height: 520px; display: flex; flex-direction: column; align-items: start; padding: 52px; }
.focus-card-dark { color: var(--paper); background: var(--night); }
.focus-card-cream { background: #e9dcc2; }
.focus-card h3 { margin: 55px 0 15px; font: 38px/1.35 var(--serif); }
.focus-card p { opacity: .78; }
.focus-card ul { width: 100%; margin: 22px 0 32px; padding: 0; list-style: none; }
.focus-card li { padding: 8px 0; border-bottom: 1px solid rgba(128,128,128,.25); }
.focus-card li::before { content: "✓"; margin-right: 9px; color: #b6832b; }
.focus-card .button { margin-top: auto; }
.path-card { min-height: 390px; position: relative; padding: 34px; border: 1px solid var(--line); background: #fff; transition: transform .25s, box-shadow .25s; }
.path-card:hover { transform: translateY(-6px); box-shadow: 0 20px 45px rgba(23,34,60,.08); }
.path-index { color: #ad7c29; font: 12px var(--serif); }
.path-icon { width: 92px; height: 92px; display: grid; place-items: center; margin: 40px auto 34px; border-radius: 50%; background: var(--cream); color: #9c7229; font: 38px var(--serif); }
.path-card h3 { margin: 0 0 13px; font: 27px var(--serif); }
.path-card p { color: var(--muted); }
.path-card a { position: absolute; bottom: 32px; font-weight: 600; }

.article-grid { grid-template-columns: repeat(3, 1fr); }
.article-card { overflow: hidden; border: 1px solid var(--line); background: #fff; }
.article-visual { height: 220px; display: grid; place-items: center; overflow: hidden; font: 40px var(--serif); }
.image-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.article-card:hover .image-visual img { transform: scale(1.035); }
.visual-music { color: var(--gold-light); background: radial-gradient(circle, #2f3c62, #111b35); }
.visual-content { color: #fff; background: linear-gradient(135deg, #8e7565, #d1b5a2); }
.visual-travel { color: #fff; background: linear-gradient(160deg, #6f8b93, #d7c69f); }
.visual-lyric { color: var(--ink); background: #eadfc8; }
.visual-grid { color: #fff; background: #755e68; }
.visual-road { color: #fff; background: #7c8b76; }
.article-body { padding: 28px; }
.tag { display: inline-block; margin-bottom: 15px; color: #9c7229; font-size: 11px; font-weight: 700; letter-spacing: .1em; }
.article-body h2, .article-body h3 { margin: 0 0 13px; font: 25px/1.45 var(--serif); }
.article-body p { color: var(--muted); }
.article-body a { font-weight: 600; }
.coming { color: #9c7229; font-size: 13px; }

.moon-letter {
  min-height: 550px;
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: .8fr 1.1fr .4fr;
  gap: 70px;
  align-items: center;
  padding: 80px max(8vw, 42px);
  color: var(--paper);
  background: var(--night);
}
.letter-moon { width: min(30vw, 370px); aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle at 35% 30%, #fff4ca, #d1a950 68%, #8e6930); box-shadow: 0 0 90px rgba(223,189,114,.2); }
.letter-copy { max-width: 590px; }
.signature-mark { width: 160px; height: 70px; margin: -10px 0 12px; object-fit: contain; object-position: left center; }
.letter-copy > p:not(.eyebrow) { color: rgba(255,255,255,.68); }
.inline-form { display: flex; margin-top: 30px; }
.inline-form input { min-width: 0; flex: 1; padding: 15px 17px; color: #fff; border: 1px solid rgba(255,255,255,.3); border-right: 0; background: transparent; outline: none; }
.inline-form button { padding: 14px 20px; border: 1px solid var(--gold-light); color: var(--night); background: var(--gold-light); cursor: pointer; }
.letter-copy small { color: rgba(255,255,255,.45); }
.letter-note { color: rgba(255,255,255,.42); writing-mode: vertical-rl; letter-spacing: .15em; }

.about-preview { display: grid; grid-template-columns: 190px 1.15fr .55fr; gap: 60px; align-items: center; }
.portrait-placeholder { min-height: 480px; position: relative; display: flex; flex-direction: column; justify-content: end; padding: 35px; color: var(--paper); background: linear-gradient(165deg, #273454, #111a32); overflow: hidden; }
.portrait-placeholder > span { position: relative; z-index: 2; font: 34px var(--serif); letter-spacing: .18em; }
.portrait-placeholder small { position: relative; z-index: 2; opacity: .55; }
.portrait-photo::after { content: ""; position: absolute; inset: 45% 0 0; background: linear-gradient(transparent, rgba(11,19,39,.78)); }
.portrait-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.portrait-photo > span { position: relative; z-index: 2; }
.portrait-avatar {
  width: 170px;
  min-height: 170px;
  aspect-ratio: 1;
  align-self: center;
  padding: 0;
  border-radius: 50%;
  border: 7px solid var(--cream);
  box-shadow: 0 15px 35px rgba(23,34,60,.13);
}
.portrait-avatar::after { display: none; }
.portrait-avatar img { object-position: center 22%; }
.portrait-moon { position: absolute; width: 270px; height: 270px; left: 50%; top: 40%; transform: translate(-50%,-50%); border-radius: 50%; background: #daba70; }
.about-preview-copy > p:not(.eyebrow) { margin: 25px 0; color: var(--muted); }
.about-quote { align-self: end; padding-left: 25px; border-left: 1px solid var(--gold); color: var(--muted); font-family: var(--serif); }

.work-banner {
  display: grid;
  grid-template-columns: 1.2fr 1fr auto;
  gap: 60px;
  align-items: center;
  padding: 90px max(8vw, 42px);
  color: var(--paper);
  background: linear-gradient(130deg, #6d5549, #9e7860);
}
.work-services { display: flex; flex-direction: column; gap: 9px; color: rgba(255,255,255,.78); }
.work-services span::before { content: "＋"; margin-right: 9px; color: var(--gold-light); }

.site-footer {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 70px;
  align-items: end;
  padding: 65px max(6vw, 32px);
  color: rgba(255,255,255,.65);
  background: #0b1327;
  font-size: 13px;
}
.footer-brand { color: var(--paper); font: 27px var(--serif); letter-spacing: .2em; }
.footer-logo img { width: 82px; height: 82px; object-fit: contain; object-position: left center; }
.site-footer p { margin: 8px 0 0; }
.site-footer nav { display: flex; flex-wrap: wrap; gap: 25px; }
.site-footer a:hover { color: var(--gold-light); }
.footer-meta { display: flex; flex-direction: column; gap: 7px; text-align: right; }

.page-hero {
  min-height: 660px;
  display: grid;
  grid-template-columns: 1fr .8fr;
  align-items: center;
  gap: 50px;
  padding: 80px max(8vw, 42px);
  color: var(--paper);
  background: var(--night);
}
.page-hero-copy { max-width: 720px; }
.page-hero-copy > p:not(.eyebrow) { max-width: 600px; margin: 30px 0; color: rgba(255,255,255,.7); font-size: 18px; }
.song-page-hero { grid-template-columns: .9fr 1.1fr; }
.vinyl-art { width: min(38vw, 440px); aspect-ratio: 1; position: relative; justify-self: center; }
.song-hero-photo { width: min(48vw, 620px); aspect-ratio: 5 / 4; position: relative; justify-self: center; overflow: hidden; box-shadow: 25px 25px 0 rgba(223,189,114,.12); }
.song-hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, transparent 45%, rgba(17,27,53,.72)); }
.song-hero-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.song-hero-photo span { position: absolute; z-index: 2; right: 24px; bottom: 20px; color: var(--gold-light); font: 13px/1.6 var(--serif); letter-spacing: .18em; text-align: right; }
.vinyl { position: absolute; inset: 5%; display: grid; place-items: center; border-radius: 50%; background: repeating-radial-gradient(circle, #16171b 0 8px, #272832 9px 11px); box-shadow: 0 30px 60px rgba(0,0,0,.3); }
.vinyl::after { content: ""; position: absolute; width: 34%; height: 34%; border-radius: 50%; background: var(--gold); }
.vinyl span { position: relative; z-index: 2; color: var(--night); font: 12px/1.5 var(--serif); text-align: center; letter-spacing: .18em; }
.tone-arm { position: absolute; width: 38%; height: 8px; right: 0; top: 10%; transform: rotate(38deg); transform-origin: right; background: #c9c2b5; }
.belief-grid { grid-template-columns: repeat(3, 1fr); }
.belief-card { padding: 32px; border-top: 2px solid var(--gold); background: var(--cream); }
.belief-card strong { font: 24px var(--serif); }
.belief-card p { color: var(--muted); }
.course-section { padding-top: 40px; }
.course-grid { grid-template-columns: repeat(2, 1fr); }
.course-card { min-height: 600px; padding: 55px; }
.course-card-dark { color: var(--paper); background: var(--night); }
.course-card-cream { background: #e9dcc2; }
.course-no { font-size: 11px; letter-spacing: .2em; opacity: .62; }
.course-symbol { margin: 70px 0 35px; font: 65px var(--serif); color: var(--gold); }
.course-card h3 { margin: 0; font: 42px var(--serif); }
.course-subtitle { margin-top: 4px; color: #a77728; font-weight: 700; }
.course-card-dark .course-subtitle { color: var(--gold-light); }
.course-card ul { margin: 30px 0; padding: 0; list-style: none; }
.course-card li { padding: 7px 0; border-bottom: 1px solid rgba(128,128,128,.22); }
.course-card li::before { content: "✓"; margin-right: 10px; color: #b6832b; }
.compact-list { border-top: 1px solid var(--line); }
.compact-item { display: grid; grid-template-columns: 60px 1fr 130px 30px; gap: 20px; align-items: center; padding: 25px 10px; border-bottom: 1px solid var(--line); }
.compact-item span, .compact-item em { color: var(--muted); font-size: 12px; font-style: normal; }
.compact-item strong { font: 20px var(--serif); }
.form-section {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 90px;
  padding: 100px max(9vw, 50px);
  color: var(--paper);
  background: var(--night);
}
.form-intro > p:not(.eyebrow) { color: rgba(255,255,255,.65); }
.stack-form { display: grid; gap: 20px; }
.stack-form label { display: grid; gap: 7px; color: rgba(255,255,255,.7); font-size: 13px; }
.stack-form input, .stack-form select, .stack-form textarea {
  width: 100%;
  padding: 13px 14px;
  color: #fff;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 0;
  background: rgba(255,255,255,.04);
  outline: none;
}
.stack-form option { color: var(--ink); }
.form-split { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.consent-row { grid-template-columns: 18px 1fr !important; align-items: start; gap: 10px !important; }
.consent-row input { width: 16px; margin-top: 5px; accent-color: var(--gold); }
.form-note { margin: -8px 0 0; color: rgba(255,255,255,.48); font-size: 12px; }
.contact-fallback { display: flex; flex-direction: column; gap: 6px; margin-top: 24px; color: var(--gold-light); font-size: 14px; }

.booking-hero { padding-bottom: 30px; }
.booking-options { padding-top: 45px; }
.booking-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.booking-card {
  min-height: 510px;
  display: flex;
  flex-direction: column;
  align-items: start;
  padding: 42px;
  border: 1px solid var(--line);
  background: #fff;
}
.booking-card-soft { background: var(--cream); }
.booking-card > span { color: #a77728; font: 13px var(--serif); }
.booking-card .eyebrow { margin: 35px 0 12px; }
.booking-card h2 { margin: 0; font: 32px/1.35 var(--serif); }
.booking-card > p:not(.eyebrow) { color: var(--muted); }
.booking-card ul { margin: 20px 0 32px; padding: 0; list-style: none; color: var(--muted); }
.booking-card li { padding: 7px 0; border-bottom: 1px solid var(--line); }
.booking-card li::before { content: "✓"; margin-right: 9px; color: #a77728; }
.booking-card .button { margin-top: auto; }

.simple-hero { max-width: var(--max); margin: 0 auto; padding: 125px 28px 55px; }
.simple-hero > p:last-child { max-width: 650px; color: var(--muted); font-size: 18px; }
.filter-row { display: flex; gap: 10px; margin-bottom: 35px; }
.filter-button { padding: 9px 18px; border: 1px solid var(--line); color: var(--ink); background: transparent; cursor: pointer; }
.filter-button.active, .filter-button:hover { color: var(--paper); background: var(--night); }
.article-filter-grid .article-card[hidden] { display: none; }
.mini-letter { display: flex; justify-content: space-between; align-items: center; gap: 50px; padding: 65px max(10vw, 55px); color: var(--paper); background: #9b755d; }
.mini-letter h2 { margin: 0; font: 38px var(--serif); }
.mini-letter p { margin: 7px 0 0; }

.resource-hero { padding-bottom: 70px; }
.affiliate-note { margin-bottom: 45px; padding: 20px 24px; border-left: 3px solid var(--gold); background: var(--cream); color: var(--muted); }
.resource-grid { grid-template-columns: repeat(2, 1fr); }
.resource-card { min-height: 430px; padding: 45px; border: 1px solid var(--line); background: #fff; }
.resource-icon { float: right; display: grid; width: 65px; height: 65px; place-items: center; border-radius: 50%; color: #9c7229; background: var(--cream); font: 25px var(--serif); }
.resource-card h2 { margin: 0; font: 32px var(--serif); }
.resource-card > p:not(.eyebrow) { color: var(--muted); }
.resource-card ul { padding-left: 20px; color: var(--muted); }
.resource-criteria { display: grid; grid-template-columns: .8fr 1.2fr; gap: 70px; padding: 85px max(9vw, 50px); color: var(--paper); background: var(--night); }
.criteria-list p { padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.14); }
.criteria-list span { margin-right: 25px; color: var(--gold); font-family: var(--serif); }

.about-hero {
  min-height: 720px;
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  align-items: center;
  gap: 80px;
  padding: 80px max(8vw, 42px);
  color: var(--paper);
  background: var(--night);
}
.about-moon-art { min-height: 500px; position: relative; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.12); overflow: hidden; }
.about-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(17,27,53,.55)); }
.about-photo > img:first-child { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 43% center; }
.about-hero-copy h1 { font-size: clamp(48px, 4.7vw, 72px); line-height: 1.38; }
.giant-moon { width: 330px; height: 330px; border-radius: 50%; background: linear-gradient(120deg, #f1d893, #b58a42); box-shadow: 0 0 70px rgba(223,189,114,.22); }
.about-moon-art span { position: absolute; bottom: 25px; opacity: .45; font-size: 12px; }
.about-hero-copy > p:last-child { color: rgba(255,255,255,.65); font-size: 19px; }
.story-section { display: grid; grid-template-columns: .8fr 1.2fr; gap: 90px; }
.story-copy { max-width: 640px; color: var(--muted); }
.story-lead { color: var(--ink); font: 28px var(--serif); }
.experience-section { padding-top: 30px; }
.experience-list { border-top: 1px solid var(--line); }
.experience-item {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 35px;
  padding: 30px 8px;
  border-bottom: 1px solid var(--line);
}
.experience-item > span {
  width: 55px;
  height: 55px;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: transparent;
  border-radius: 50%;
  background: var(--cream);
  font-size: 0;
}
.experience-item > span::before { color: #a77728; font: 25px var(--serif); }
.experience-item:nth-child(1) > span::before { content: "♪"; }
.experience-item:nth-child(2) > span::before { content: "◐"; }
.experience-item:nth-child(3) > span::before { content: "✦"; }
.experience-item:nth-child(4) > span::before { content: "□"; }
.experience-item h3 { margin: 0; font: 26px var(--serif); }
.experience-item p { max-width: 760px; margin: 8px 0 0; color: var(--muted); }
.values-section { padding: 100px max(8vw, 42px); color: var(--paper); background: #7b6254; }
.values-grid { grid-template-columns: repeat(3, 1fr); }
.values-grid article { padding: 35px 0; border-top: 1px solid rgba(255,255,255,.35); }
.values-grid span { color: var(--gold-light); font-family: var(--serif); }
.values-grid h3 { font: 26px var(--serif); }
.values-grid p { color: rgba(255,255,255,.68); }
.now-grid { grid-template-columns: repeat(3, 1fr); }
.now-card { min-height: 300px; padding: 35px; border: 1px solid var(--line); }
.now-card > span { display: grid; width: 60px; height: 60px; place-items: center; border-radius: 50%; color: #a77728; background: var(--cream); font: 28px var(--serif); }
.now-card h3 { margin: 50px 0 10px; font: 25px var(--serif); }
.now-card p { color: var(--muted); }
.now-card b { font-size: 13px; }

.work-page-hero { background: linear-gradient(135deg, #111b35 50%, #253456); }
.work-art { min-height: 440px; position: relative; }
.work-frame { position: absolute; display: grid; width: 220px; height: 150px; place-items: center; border: 1px solid rgba(255,255,255,.35); color: var(--gold-light); font: 16px var(--serif); letter-spacing: .2em; }
.frame-a { top: 35px; left: 20px; transform: rotate(-8deg); }
.frame-b { top: 145px; right: 15px; transform: rotate(7deg); }
.frame-c { bottom: 20px; left: 90px; transform: rotate(-3deg); background: rgba(223,189,114,.12); }
.service-list { border-top: 1px solid var(--line); }
.credibility-note {
  display: grid;
  grid-template-columns: .7fr 1.3fr;
  gap: 45px;
  margin-bottom: 45px;
  padding: 30px 34px;
  border-left: 3px solid var(--gold);
  background: var(--cream);
}
.credibility-note strong { font: 24px/1.45 var(--serif); }
.credibility-note p { margin: 0; color: var(--muted); }
.service-row { display: grid; grid-template-columns: 70px 1fr 180px; gap: 25px; align-items: center; padding: 30px 5px; border-bottom: 1px solid var(--line); }
.service-row > span { color: #a77728; font-family: var(--serif); }
.service-row h3 { margin: 0; font: 27px var(--serif); }
.service-row p { margin: 6px 0 0; color: var(--muted); }
.service-row em { color: var(--muted); font-size: 12px; text-align: right; }
.process-section { padding: 100px max(8vw,42px); color: var(--paper); background: #816553; }
.process-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 25px; padding: 0; list-style: none; }
.process-list li { padding-top: 25px; border-top: 1px solid rgba(255,255,255,.35); }
.process-list span { color: var(--gold-light); font-family: var(--serif); }
.process-list strong { display: block; margin-top: 35px; font: 22px var(--serif); }
.process-list p { color: rgba(255,255,255,.68); }

.toast {
  position: fixed;
  z-index: 50;
  right: 25px;
  bottom: 25px;
  max-width: 350px;
  padding: 15px 20px;
  color: var(--paper);
  background: var(--night);
  box-shadow: 0 10px 35px rgba(0,0,0,.22);
  transform: translateY(130%);
  transition: transform .3s;
}
.toast.show { transform: translateY(0); }
.form-honey { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.form-status { min-height: 1.5em; margin: 0; color: var(--ink); font-size: 14px; }
.stack-form button:disabled { cursor: wait; opacity: .65; }
.article-page-hero { display: grid; place-items: center; padding: 110px max(8vw, 42px); text-align: center; background: var(--cream); }
.article-page-heading { max-width: 780px; }
.article-page-heading h1 { margin: 22px 0; font: clamp(52px, 6vw, 92px)/1.12 var(--serif); letter-spacing: -.03em; }
.article-deck { max-width: 620px; margin-inline: auto; color: var(--muted); font-size: 20px; line-height: 1.8; }
.article-meta { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px 24px; margin-top: 34px; color: var(--muted); font-size: 13px; letter-spacing: .08em; }
.article-content { max-width: 780px; margin: 0 auto; padding: 95px 28px 120px; color: #283149; font-size: 18px; line-height: 2; }
.article-content > p { margin: 0 0 1.55em; }
.article-content h2 { margin: 2.8em 0 .9em; color: var(--night); font: 34px/1.45 var(--serif); }
.article-lead { color: var(--night); font: 28px/1.75 var(--serif); }
.article-content blockquote { margin: 55px -45px; padding: 35px 45px; color: var(--night); border-left: 3px solid var(--gold); background: var(--cream); font: 29px/1.65 var(--serif); }
.article-lines { margin: 40px 0; padding: 28px 34px; border: 1px solid var(--line); background: #fff; }
.article-lines p { margin: .35em 0; color: var(--night); font-family: var(--serif); }
.article-cta { margin: 85px -90px 55px; padding: 60px 70px; color: var(--paper); background: var(--night); }
.article-cta h2 { margin: 12px 0 18px; color: var(--paper); }
.article-cta > p:not(.eyebrow) { color: rgba(255,255,255,.7); }
.article-back { display: inline-block; margin-top: 30px; color: var(--night); border-bottom: 1px solid var(--gold); }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 900px) {
  .site-header { min-height: 68px; }
  .menu-toggle { display: block; }
  .site-nav {
    position: absolute;
    top: 68px;
    left: 0;
    right: 0;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 12px 28px 25px;
    background: var(--paper);
    border-bottom: 1px solid var(--line);
  }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 12px 0; }
  .site-nav .nav-cta { margin-top: 8px; text-align: center; }
  .hero, .page-hero, .about-hero { grid-template-columns: 1fr; }
  .article-page-hero { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding-top: 90px; }
  .hero-art { width: min(80vw, 440px); }
  .song-invite { grid-template-columns: 1fr; }
  .section-number { display: none; }
  .path-grid, .article-grid, .belief-grid, .values-grid, .now-grid { grid-template-columns: 1fr; }
  .focus-grid { grid-template-columns: 1fr; }
  .course-grid, .resource-grid { grid-template-columns: 1fr; }
  .booking-grid { grid-template-columns: 1fr; }
  .moon-letter { grid-template-columns: .7fr 1fr; }
  .letter-note { display: none; }
  .about-preview { grid-template-columns: 170px 1fr; }
  .about-quote { grid-column: 2; }
  .work-banner { grid-template-columns: 1fr; }
  .site-footer { grid-template-columns: 1fr 1fr; align-items: start; }
  .footer-meta { grid-column: 1 / -1; text-align: left; }
  .story-section, .resource-criteria, .form-section { grid-template-columns: 1fr; }
  .process-list { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 620px) {
  .hero, .page-hero, .about-hero { padding: 70px 24px; }
  .hero h1, .page-hero h1, .about-hero h1 { font-size: 43px; }
  .section { padding: 75px 22px; }
  .section-heading { align-items: start; flex-direction: column; gap: 20px; }
  .song-invite h2, .section-heading h2, .about-preview h2, .moon-letter h2, .work-banner h2, .form-section h2, .simple-hero h1, .resource-criteria h2, .story-section h2, .values-section h2 { font-size: 36px; }
  .lyric-card { padding: 35px 28px; }
  .moon-letter { grid-template-columns: 1fr; padding: 70px 24px; }
  .letter-moon { width: 65vw; justify-self: center; }
  .inline-form { flex-direction: column; gap: 10px; }
  .inline-form input { border-right: 1px solid rgba(255,255,255,.3); }
  .about-preview { grid-template-columns: 1fr; gap: 40px; }
  .portrait-avatar { width: 150px; min-height: 150px; justify-self: start; }
  .about-quote { grid-column: auto; }
  .work-banner, .form-section, .values-section, .process-section, .resource-criteria { padding: 70px 24px; }
  .site-footer { grid-template-columns: 1fr; gap: 35px; }
  .site-footer nav { gap: 16px; }
  .footer-meta { grid-column: auto; }
  .compact-item { grid-template-columns: 35px 1fr 25px; }
  .compact-item em { display: none; }
  .course-card { min-height: auto; padding: 38px 28px; }
  .focus-card { min-height: auto; padding: 38px 28px; }
  .focus-card h3 { margin-top: 35px; font-size: 31px; }
  .form-split { grid-template-columns: 1fr; }
  .filter-row { overflow-x: auto; padding-bottom: 7px; }
  .filter-button { flex: 0 0 auto; }
  .mini-letter { align-items: start; flex-direction: column; padding: 55px 24px; }
  .resource-card { min-height: auto; padding: 35px 28px; }
  .about-moon-art { min-height: 390px; }
  .giant-moon { width: 245px; height: 245px; }
  .process-list { grid-template-columns: 1fr; }
  .service-row { grid-template-columns: 42px 1fr; }
  .service-row em { display: none; }
  .experience-item { grid-template-columns: 1fr; gap: 10px; }
  .experience-item > span { width: 48px; height: 48px; }
  .credibility-note { grid-template-columns: 1fr; gap: 12px; padding: 25px; }
  .booking-card { min-height: auto; padding: 34px 27px; }
  .article-page-hero { padding: 70px 24px; gap: 42px; }
  .article-page-heading h1 { font-size: 49px; }
  .article-content { padding: 70px 24px 90px; font-size: 17px; }
  .article-content h2 { font-size: 30px; }
  .article-content blockquote { margin: 45px 0; padding: 28px; font-size: 25px; }
  .article-cta { margin: 65px 0 45px; padding: 42px 28px; }
}

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