*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --cream:     #F9F6F0;
  --ivory:     #FFFFFF;
  --warm-gray: #EDE9E2;
  --linen:     #E2DAD0;
  --blush:     #C9B8A4;
  --ink:       #26211D;
  --ink-mid:   #5C564F;
  --ink-light: #8C847C;
  --gold:      #B07D45;
  --gold-pale: #CCA876;
  --nav-h:     76px;
  --pad-x:     72px;
  --pad-x-md:  36px;
  --pad-x-sm:  20px;
}
html { scroll-behavior: smooth; }
body { font-family:"DM Sans",sans-serif; background:var(--cream); color:var(--ink); font-weight:400; font-size: 16px; overflow-x:hidden; }
img { display:block; max-width:100%; }

/* ── UTILITY ── */
.label { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.label::after { content:""; display:block; width:28px; height:1px; background:var(--gold); }
.label-light { color:var(--gold-pale); }
.label-light::after { background:var(--gold-pale); }
h2.serif { font-family:"Playfair Display",serif; font-size:clamp(26px,3.2vw,44px); font-weight:400; line-height:1.25; color:var(--ink); margin-bottom:22px; }
h2.serif em { font-style:italic; color:var(--gold); }
.body-text {
  font-size: 16px; line-height: 1.95; letter-spacing: 0.01em; font-size:16px; line-height:1.95; color:var(--ink-mid); margin-bottom:14px; }
.btn-gold { display:inline-flex; align-items:center; gap:10px; background:var(--gold); color:#fff; font-family:"DM Sans",sans-serif; font-size:10px; letter-spacing:.14em; text-transform:uppercase; text-decoration:none; padding:15px 34px; transition:background .25s,transform .2s; white-space:nowrap; }
.btn-gold:hover { background:#926734; transform:translateY(-1px); }
.btn-ink { display:inline-flex; align-items:center; gap:10px; border:1px solid var(--ink); color:var(--ink); font-family:"DM Sans",sans-serif; font-size:10px; letter-spacing:.12em; text-transform:uppercase; text-decoration:none; padding:13px 26px; transition:background .25s,color .25s; white-space:nowrap; }
.btn-ink:hover { background:var(--ink); color:var(--cream); }
.btn-outline-white { display:inline-flex; align-items:center; gap:10px; border:1px solid rgba(255,255,255,0.5); color:#fff; font-family:"DM Sans",sans-serif; font-size:10px; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; padding:13px 26px; transition:background .25s,border-color .25s; }
.btn-outline-white:hover { background:rgba(255,255,255,0.1); border-color:#fff; }

/* ── NAV ── */
nav { position:fixed; top:0; left:0; width:100%; z-index:300; display:flex; align-items:center; justify-content:space-between; padding:0 var(--pad-x); height:84px; background:rgba(249,246,240,0.96); backdrop-filter:blur(14px); border-bottom:1px solid rgba(194,178,158,0.3); }
.nav-logo {
  font-family: 'Great Vibes', cursive;
  font-size: 30px; font-weight: 400;
  color: #26211D; text-decoration: none;
  letter-spacing: 0.02em; line-height: 1;
  display: inline-block;
}
.nav-logo em { font-style:italic; color:var(--gold); }
.nav-links { display:flex; gap:36px; list-style:none; }
.nav-links a { font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-mid); text-decoration:none; transition:color .25s; font-weight:500; }
.nav-links a:hover, .nav-links a.active { color:var(--gold); }
.nav-cta { font-size:10px; letter-spacing:.18em; text-transform:uppercase; background:var(--gold); color:#fff; text-decoration:none; padding:11px 26px; transition:background .25s; }
.nav-cta:hover { background:var(--ink); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; z-index:2; }
.hamburger span { display:block; width:24px; height:1.5px; background:var(--ink); transition:transform .35s,opacity .25s; }
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.mobile-menu { display:none; position:fixed; inset:0; z-index:250; background:var(--cream); flex-direction:column; align-items:center; justify-content:center; gap:32px; opacity:0; pointer-events:none; transition:opacity .35s; }
.mobile-menu.open { opacity:1; pointer-events:all; }
.mobile-menu a { font-family:"Playfair Display",serif; font-size:28px; font-weight:400; color:var(--ink); text-decoration:none; letter-spacing:.04em; transition:color .2s; }
.mobile-menu a:hover { color:var(--gold); }
.mobile-menu .mob-cta { font-family:"DM Sans",sans-serif; font-size:11px; letter-spacing:.2em; text-transform:uppercase; background:var(--gold); color:#fff; padding:14px 36px; font-style:normal; }

/* ── PAGE HERO (inner pages) ── */
.page-hero { position:relative; height:52vh; min-height:380px; margin-top:84px; overflow:hidden; }
.page-hero-bg { position:absolute; inset:0; }
.page-hero-bg img { width:100%; height:100%; object-fit:cover; object-position:center 25%; filter:brightness(.55) saturate(.8); }
.page-hero-bg::after { content:""; position:absolute; inset:0; background:linear-gradient(105deg,rgba(38,33,29,.65) 0%,rgba(38,33,29,.3) 60%,rgba(38,33,29,.1) 100%); }
.page-hero-content { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:0 var(--pad-x) 64px; }
.page-hero-tag { font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-pale); display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.page-hero-tag::before { content:""; display:block; width:24px; height:1px; background:var(--gold-pale); }
.page-hero h1 { font-family:"Playfair Display",serif; font-size:clamp(34px,5.5vw,72px); font-weight:400; line-height:1.12; color:#fff; max-width:750px; }
.page-hero h1 em { font-style:italic; color:var(--gold-pale); }
.page-hero-sub { font-size:16px; line-height:1.95; color:rgba(255,255,255,.7); max-width:580px; margin-top:20px; }

/* ── GOLD STRIP ── */
.gold-strip { background:var(--gold); padding:20px var(--pad-x); display:flex; align-items:center; justify-content:center; gap:36px; flex-wrap:wrap; }
.gold-strip p { font-family:"Playfair Display",serif; font-size:17px; font-style:italic; color:#fff; text-align:center; }
.gold-strip .sep { color:rgba(255,255,255,.4); font-size:18px; }

/* ── FOOTER ── */
footer { background:var(--ink); padding:44px var(--pad-x); display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.foot-logo { font-family:"Playfair Display",serif; font-size:19px; color:var(--cream); text-decoration:none; letter-spacing:.04em; }
.foot-logo em { font-style:italic; color:var(--gold-pale); }
.foot-links { display:flex; gap:28px; flex-wrap:wrap; }
.foot-links a { font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:rgba(249,246,240,.38); text-decoration:none; transition:color .25s; }
.foot-links a:hover { color:var(--gold-pale); }
.foot-copy { font-size:11px; color:rgba(249,246,240,.28); letter-spacing:.08em; }

/* ── SCROLL REVEAL ── */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .7s ease,transform .7s ease; }
.reveal-left { opacity:0; transform:translateX(-32px); transition:opacity .7s ease,transform .7s ease; }
.reveal-right { opacity:0; transform:translateX(32px); transition:opacity .7s ease,transform .7s ease; }
.reveal.in,.reveal-left.in,.reveal-right.in { opacity:1; transform:translate(0); }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  nav { padding:0 var(--pad-x-md); }
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
  .mobile-menu { display:flex; }
  .page-hero-content { padding:0 var(--pad-x-md) 52px; }
  .gold-strip { padding:18px var(--pad-x-md); gap:12px; }
  footer { padding:36px var(--pad-x-md); }
  .foot-links { display:none; }
}
@media (max-width:640px) {
  :root { --nav-h:64px; }
  nav { padding:0 var(--pad-x-sm); }
  .nav-logo { font-size:17px; }
  .page-hero { height:55vh; min-height:320px; }
  .page-hero-content { padding:0 var(--pad-x-sm) 40px; }
  .page-hero h1 { font-size:clamp(28px,8vw,42px); }
  .page-hero-sub { font-size:14px; }
  .gold-strip { padding:16px var(--pad-x-sm); flex-direction:column; gap:8px; }
  .gold-strip .sep { display:none; }
  footer { padding:32px var(--pad-x-sm); flex-direction:column; align-items:flex-start; gap:10px; }
}

.foot-social { display:flex; gap:20px; align-items:center; margin-top:20px; }
.foot-social a { color:rgba(249,246,240,.45); transition:color .25s; display:flex; align-items:center; }
.foot-social a:hover { color:var(--gold-pale); }

/* Connect section social links */
.connect-social {
  display: flex;
  gap: 32px;
  margin-top: 28px;
  align-items: center;
}
.connect-social a {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mid);
  text-decoration: none;
  transition: color .25s;
}
.connect-social a:hover { color: var(--gold); }

/* ── STORY-SPECIFIC ── */
.story-wrap {
  background:var(--ivory);
  display:grid;
  grid-template-columns:1fr 480px;
  gap:0;
  min-height:100vh;
}
.story-content {
  padding:100px var(--pad-x) 100px 80px;
}
.story-content p { font-size:16.5px; line-height:2.0.0; color:var(--ink-mid); margin-bottom:20px; }
.story-content p strong { color:var(--ink); font-weight:500; }
.story-sidebar {
  background:var(--warm-gray);
  padding:80px 52px;
  display:flex; flex-direction:column; gap:0;
  border-left:1px solid var(--linen);
  position:sticky; top:var(--nav-h); align-self:start;
  height:calc(100vh var(--nav-h)); overflow-y:auto;
}
.sidebar-quote {
  font-family:"Playfair Display",serif;
  font-size:20px; font-style:italic; color:var(--ink);
  line-height:1.6; border-left:2px solid var(--gold);
  padding-left:20px; margin-bottom:48px;
}
.sidebar-img { overflow:hidden; margin-bottom:36px; position:relative; }
.sidebar-img img { width:100%; aspect-ratio:3/4; object-fit:cover; object-position:center top; }
.sidebar-img::after { content:""; position:absolute; inset:14px; border:1px solid rgba(176,125,69,.3); pointer-events:none; }
.sidebar-stat { text-align:center; padding:32px 0; border-top:1px solid var(--linen); }
.sidebar-stat .num { font-family:"Playfair Display",serif; font-size:64px; color:var(--gold); line-height:1; display:block; }
.sidebar-stat .lbl { font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-light); margin-top:8px; display:block; }

/* milestones timeline */
.timeline { margin:48px 0; }
.timeline-item { display:flex; gap:24px; margin-bottom:36px; }
.timeline-dot { flex-shrink:0; width:10px; height:10px; border-radius:50%; background:var(--gold); margin-top:5px; }
.timeline-body h4 { font-family:"Playfair Display",serif; font-size:17px; color:var(--ink); margin-bottom:6px; }
.timeline-body p { font-size:14px; line-height:1.75; color:var(--ink-mid); margin:0; }
.timeline-line { width:1px; height:100%; background:var(--linen); position:absolute; }

/* values grid */
.values-section {
  background:var(--ink);
  padding:100px var(--pad-x);
}
.values-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:rgba(255,255,255,.06); margin-top:56px;
}
.value-card {
  background:var(--ink); padding:48px 40px;
  border-right:1px solid rgba(255,255,255,.07);
  transition:background .3s;
}
.value-card:last-child { border-right:none; }
.value-card:hover { background:rgba(176,125,69,.12); }
.value-num { font-family:"Playfair Display",serif; font-size:48px; color:rgba(176,125,69,.3); line-height:1; margin-bottom:16px; }
.value-card h3 { font-family:"Playfair Display",serif; font-size:22px; color:var(--cream); margin-bottom:12px; }
.value-card p { font-size:14px; color:rgba(255,255,255,.55); line-height:1.95; }

/* cta band */
.cta-band {
  background:var(--warm-gray);
  padding:100px var(--pad-x);
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
.cta-band-right { display:flex; flex-direction:column; gap:16px; }
.cta-card {
  background:var(--ivory); padding:32px 36px;
  border-left:3px solid var(--gold);
  display:flex; flex-direction:column; gap:10px;
}
.cta-card h4 { font-family:"Playfair Display",serif; font-size:20px; color:var(--ink); }
.cta-card p { font-size:14px; color:var(--ink-mid); line-height:1.7; }

@media (max-width:1024px) {
  .story-wrap { grid-template-columns:1fr; }
  .story-sidebar { position:static; height:auto; padding:60px var(--pad-x-md); border-left:none; border-top:1px solid var(--linen); }
  .story-content { padding:72px var(--pad-x-md); }
  .values-grid { grid-template-columns:1fr; }
  .value-card { border-right:none; border-bottom:1px solid rgba(255,255,255,.07); }
  .cta-band { grid-template-columns:1fr; gap:48px; padding:80px var(--pad-x-md); }
  .values-section { padding:80px var(--pad-x-md); }
}
@media (max-width:640px) {
  .story-content { padding:52px var(--pad-x-sm); }
  .story-sidebar { padding:48px var(--pad-x-sm); }
  .cta-band { padding:60px var(--pad-x-sm); }
  .values-section { padding:60px var(--pad-x-sm); }
  .sidebar-quote { font-size:17px; }
}