@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Pinyon+Script&display=swap');

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

:root {
  --rose:  #8a5a60;
  --pale:  #ead4d2;
  --cream: #faf8f6;
  --sub:   #f5eeec;
  --dark:  #3a2a2a;
  --mid:   #6a4a4a;
  --line:  #d8c4c0;
}

body {
  font-family: 'Cormorant Garamond', 'Hiragino Mincho ProN', 'Yu Mincho', Georgia, serif;
  background: var(--cream);
  color: var(--dark);
  line-height: 1.9;
}

.soft { filter: brightness(1.05) contrast(0.9) saturate(0.8) sepia(0.04); }

/* ── REVEAL ── */
.reveal {
  opacity: 0; transform: translateY(28px);
  transition: opacity 0.9s ease, transform 0.9s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 64px;
  background: rgba(250,248,246,0.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 0 40px;
}
.nav-logo {
  font-size: 10px; letter-spacing: 0.3em;
  color: var(--dark); text-decoration: none; white-space: nowrap;
}
.nav-links { display: flex; gap: 24px; list-style: none; }
.nav-links a {
  font-size: 10px; letter-spacing: 0.16em;
  color: var(--mid); text-decoration: none; transition: color 0.2s; white-space: nowrap;
}
.nav-links a:hover, .nav-links a.current { color: var(--rose); }
.nav-cta {
  font-size: 10px; letter-spacing: 0.2em;
  color: var(--rose); border: 1px solid var(--rose);
  padding: 8px 20px; text-decoration: none;
  transition: all 0.25s; margin-left: 8px; white-space: nowrap;
}
.nav-cta:hover { background: var(--rose); color: #fff; }
.hamburger {
  display: none; cursor: pointer;
  background: none; border: none; padding: 4px;
}
.hamburger span { display: block; width: 22px; height: 1px; background: var(--rose); margin: 5px 0; }
.mobile-nav {
  display: none;
  position: fixed; top: 64px; left: 0; right: 0; z-index: 99;
  background: var(--cream); border-bottom: 1px solid var(--line);
}
.mobile-nav a {
  display: block; padding: 16px 40px;
  font-size: 12px; letter-spacing: 0.1em;
  color: var(--mid); text-decoration: none;
  border-bottom: 1px solid rgba(216,196,192,0.5);
  transition: color 0.2s;
}
.mobile-nav a:hover { color: var(--rose); }
@media (max-width: 900px) {
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: block; }
  .mobile-nav.open { display: block; }
  nav { padding: 0 24px; }
}

/* ── PAGE HERO (sub-pages) ── */
.page-hero {
  margin-top: 64px;
  padding: 80px 48px 64px;
  background: var(--pale);
  text-align: center;
}
.page-hero-label {
  font-size: 9px; letter-spacing: 0.45em;
  color: var(--rose); margin-bottom: 16px; display: block;
}
.page-hero h1 {
  font-size: clamp(28px, 4.5vw, 56px);
  font-weight: 300; font-style: italic;
  color: var(--dark); line-height: 1.3;
}
@media (max-width: 560px) { .page-hero { padding: 56px 24px 40px; } }

/* ── COMMON SECTION ── */
.section-label {
  font-size: 9px; letter-spacing: 0.45em;
  color: var(--rose); text-align: center;
  margin-bottom: 16px; display: block;
}
.section-title {
  font-size: clamp(22px, 3.2vw, 42px);
  font-weight: 300; font-style: italic;
  text-align: center; color: var(--dark);
  margin-bottom: 60px; line-height: 1.4;
}

/* ── BUTTON ── */
.btn {
  display: inline-block; padding: 16px 56px;
  border: 1px solid var(--rose); color: var(--rose);
  font-family: inherit; font-size: 11px;
  letter-spacing: 0.22em; text-decoration: none;
  transition: all 0.3s;
}
.btn:hover { background: var(--rose); color: #fff; }
.btn.filled { background: var(--rose); color: #fff; }
.btn.filled:hover { background: var(--dark); border-color: var(--dark); }

/* ── DIVIDER ── */
.divider { width: 40px; height: 1px; background: var(--line); margin: 52px auto; }

/* ── MINI CTA ── */
.mini-cta { text-align: center; padding: 64px 28px; background: var(--sub); }
.mini-cta p { font-size: 15px; color: var(--mid); margin-bottom: 28px; font-style: italic; line-height: 2; }

/* ── PAGE CTA (sub-page bottom) ── */
.page-cta { padding: 96px 48px; text-align: center; background: var(--pale); }
.page-cta-label { font-size: 9px; letter-spacing: 0.45em; color: var(--rose); margin-bottom: 20px; display: block; }
.page-cta h2 { font-size: clamp(22px, 3.5vw, 44px); font-weight: 300; font-style: italic; color: var(--dark); margin-bottom: 24px; }
.page-cta p { font-size: 14px; color: var(--mid); line-height: 2.3; margin-bottom: 40px; max-width: 480px; margin-left: auto; margin-right: auto; }
@media (max-width: 560px) { .page-cta { padding: 72px 24px; } }

/* ── FOOTER ── */
footer { background: var(--dark); color: var(--pale); text-align: center; padding: 64px 24px; }
.footer-name { font-size: 10px; letter-spacing: 0.35em; margin-bottom: 24px; opacity: 0.7; }
.footer-links { display: flex; justify-content: center; gap: 36px; flex-wrap: wrap; margin-bottom: 28px; }
.footer-links a { font-size: 10px; letter-spacing: 0.2em; color: var(--pale); text-decoration: none; opacity: 0.6; transition: opacity 0.2s; }
.footer-links a:hover { opacity: 1; }
.footer-copy { font-size: 10px; opacity: 0.3; letter-spacing: 0.1em; }
