:root {
  --blush: #D7C6CC;
  --dusty: #B18793;
  --mauve: #A67D88;
  --gold: #D8C5A3;
  --ivory: #F3ECE7;
  --rose-gold: #C49A92;
  --cocoa: #4D3937;
  --taupe: #7D7374;
  --white: #FFFFFF;
  --shadow: rgba(77, 57, 55, 0.14);
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { margin: 0; font-family: 'Lato', sans-serif; color: var(--cocoa); background: var(--ivory); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--mauve); }
.skip-nav { position: absolute; left: 16px; top: -80px; background: var(--rose-gold); color: white; padding: 10px 16px; border-radius: 0 0 10px 10px; z-index: 1000; }
.skip-nav:focus { top: 0; }
.site-header { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 18px clamp(18px, 4vw, 54px); background: rgba(243, 236, 231, 0.94); border-bottom: 1px solid rgba(196,154,146,0.24); backdrop-filter: blur(12px); }
.brand { display: flex; align-items: center; gap: 12px; min-width: 0; }
.brand-mark { width: 44px; height: 44px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; color: white; background: linear-gradient(135deg, var(--rose-gold), var(--gold)); font-size: 28px; line-height: 1; flex: 0 0 auto; }
.brand strong { display: block; font-family: 'Cormorant Garamond', serif; font-size: clamp(1rem, 2vw, 1.3rem); line-height: 1; }
.brand small { display: block; color: var(--rose-gold); font-size: 0.68rem; letter-spacing: 2px; text-transform: uppercase; margin-top: 3px; }
.top-nav { display: flex; align-items: center; gap: clamp(12px, 2.3vw, 30px); font-size: 0.78rem; letter-spacing: 1.5px; text-transform: uppercase; }
.nav-cta, .btn { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: linear-gradient(135deg, var(--rose-gold), var(--dusty)); color: white; padding: 13px 24px; box-shadow: 0 8px 26px rgba(177,135,147,0.34); font-weight: 900; letter-spacing: 1px; }
.nav-cta:hover, .btn:hover { color: white; transform: translateY(-1px); }
.btn.secondary { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.92); border: 1px solid rgba(255,255,255,0.42); box-shadow: none; }
.btn.secondary:hover { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.62); }
.hero { min-height: 460px; display: grid; align-items: center; padding: clamp(72px, 10vw, 120px) 20px; background: linear-gradient(115deg, rgba(28,16,16,0.96), rgba(77,57,55,0.76)), url('/hero-bg.jpg') center/cover; color: white; }
.hero-inner { width: min(1120px, calc(100vw - 40px)); margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(290px, 0.82fr); gap: clamp(30px, 6vw, 76px); align-items: center; }
.hero-copy { max-width: 980px; width: min(1120px, calc(100vw - 40px)); margin: 0 auto; }
.hero-inner .hero-copy { width: auto; margin: 0; }
.hero-visual { margin: 0; position: relative; }
.hero-visual img { display: block; width: 100%; height: auto; border-radius: 32px; border: 1px solid rgba(243,236,231,0.18); box-shadow: 0 26px 80px rgba(0,0,0,0.32); background: rgba(243,236,231,0.08); }
.eyebrow { color: var(--gold); text-transform: uppercase; letter-spacing: 3px; font-weight: 900; font-size: 0.72rem; margin: 0 0 14px; }
h1, h2, h3 { font-family: 'Cormorant Garamond', serif; line-height: 1.12; margin: 0; }
h1 { font-size: clamp(2.8rem, 7vw, 5.5rem); max-width: 900px; }
.hero p:not(.eyebrow) { max-width: 760px; color: rgba(255,255,255,0.78); font-size: clamp(1rem, 2vw, 1.2rem); line-height: 1.75; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.section { padding: clamp(62px, 9vw, 100px) 20px; width: min(1180px, calc(100vw - 40px)); margin: 0 auto; }
.section-heading { max-width: 760px; margin: 0 auto 42px; text-align: center; }
.section-heading h2, .split h2, .cta-band h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
.section-heading p, .split p, .card p, .panel p, details p, .site-footer p { line-height: 1.75; color: var(--taupe); }
.prose { max-width: 860px; }
.prose h2 { margin-top: 34px; font-size: clamp(1.35rem, 2.5vw, 2rem); }
.prose p { color: var(--taupe); line-height: 1.8; }
.grid { display: grid; gap: 24px; }
.cards { grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)); }
.card, .panel { background: white; border: 1px solid rgba(196,154,146,0.18); border-radius: 26px; padding: clamp(24px, 4vw, 38px); box-shadow: 0 8px 30px var(--shadow); }
.card h2 { font-size: 1.55rem; margin-bottom: 12px; }
.compact h2 { font-size: 1.35rem; }
.text-link { color: var(--mauve); font-weight: 900; }
.split { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.8fr); gap: clamp(28px, 6vw, 70px); align-items: start; }
.reverse { grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.05fr); }
.check-list, .plain-list { list-style: none; padding: 0; margin: 22px 0 0; }
.check-list li, .plain-list li { padding: 9px 0; line-height: 1.55; }
.check-list li::before { content: '+'; color: var(--rose-gold); font-weight: 900; margin-right: 9px; }
.pill-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }
.pill-grid a { border: 1px solid rgba(196,154,146,0.28); border-radius: 999px; background: white; padding: 11px 16px; box-shadow: 0 4px 20px rgba(77,57,55,0.06); }
.faq { max-width: 900px; }
details { background: white; border: 1px solid rgba(196,154,146,0.18); border-radius: 18px; margin: 12px 0; padding: 18px 22px; box-shadow: 0 5px 20px rgba(77,57,55,0.06); }
summary { cursor: pointer; font-weight: 900; }
.cta-band { text-align: center; padding: clamp(60px, 9vw, 92px) 20px; background: #1C1010; color: white; }
.cta-band p { color: rgba(255,255,255,0.72); max-width: 660px; margin: 16px auto 28px; line-height: 1.75; }
.site-footer { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.15fr; gap: clamp(26px, 4vw, 52px); padding: 60px max(24px, calc(50vw - 580px)) 44px; background: var(--cocoa); color: rgba(243,236,231,0.92); }
.site-footer h2 { font-family: 'Lato', sans-serif; color: var(--gold); font-size: 0.74rem; letter-spacing: 2px; text-transform: uppercase; margin: 6px 0 16px; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin: 0 0 8px; color: rgba(243,236,231,0.68); font-size: 0.88rem; line-height: 1.5; }
.site-footer li a { color: rgba(243,236,231,0.66); }
.site-footer li a:hover { color: var(--gold); }
.site-footer p { color: rgba(243,236,231,0.6); max-width: 300px; font-size: 0.88rem; }
.brand-footer small { color: var(--gold); }
.socials { display: flex; gap: 10px; margin-top: 22px; }
.socials a { width: 38px; height: 38px; border-radius: 50%; border: 1px solid rgba(243,236,231,0.18); display: inline-flex; align-items: center; justify-content: center; color: rgba(243,236,231,0.7); transition: color 0.2s, border-color 0.2s; }
.socials a:hover { color: var(--gold); border-color: var(--gold); }
.site-footer > div:nth-child(3) ul { columns: 2; column-gap: 24px; }
.site-footer > div:nth-child(3) li { break-inside: avoid; }
.footer-bottom { grid-column: 1 / -1; border-top: 1px solid rgba(243,236,231,0.12); margin-top: 26px; padding-top: 22px; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 12px; }
.footer-bottom p { margin: 0; font-size: 0.8rem; color: rgba(243,236,231,0.5); max-width: none; }
.footer-bottom ul { display: flex; flex-wrap: wrap; gap: 8px 22px; }
.footer-bottom li { margin: 0; font-size: 0.8rem; }
.map-embed { display: block; border: 0; width: 100%; height: clamp(300px, 40vw, 420px); border-radius: 26px; box-shadow: 0 8px 30px var(--shadow); }
@media (max-width: 820px) {
  .site-header { align-items: flex-start; flex-direction: column; }
  .top-nav { flex-wrap: wrap; }
  .hero-inner, .split, .reverse { grid-template-columns: 1fr; }
  .site-footer { grid-template-columns: 1fr 1fr; }
  .site-footer > div:first-child { grid-column: 1 / -1; }
  .hero { min-height: 420px; }
  .hero-visual { max-width: 520px; }
}
@media (max-width: 520px) {
  .top-nav { font-size: 0.68rem; gap: 10px; }
  .nav-cta, .btn { width: 100%; padding: 13px 18px; }
  .hero-copy, .hero-inner, .section { width: min(100%, calc(100vw - 32px)); }
  .site-footer { grid-template-columns: 1fr; }
}
