*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,sans-serif;color:#2b2b2b;background:#f1ece1;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;letter-spacing:.02em;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.5vw,3.25rem);line-height:1.1}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem);line-height:1.2}
h3{font-size:1.15rem;letter-spacing:.14em;text-transform:uppercase;font-family:'Inter',sans-serif;font-weight:600}
p{margin:0 0 1em}
a{color:inherit;text-decoration:none;border-bottom:1px solid currentColor;transition:opacity .2s,color .2s}
a:hover{opacity:.6}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.container-narrow{max-width:820px;margin:0 auto;padding:0 1.5rem}

/* Header */
.site-header{position:sticky;top:0;z-index:10;background:rgba(241,236,225,.94);backdrop-filter:saturate(140%) blur(8px);-webkit-backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid rgba(0,0,0,.06)}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:.75rem 1.5rem;max-width:1400px;margin:0 auto}
.brand{border:0;display:block}
.brand img{height:40px;width:auto}
.site-nav{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}
.site-nav a{border:0;opacity:.7;padding:.25rem 0}
.site-nav a:hover{opacity:1}
@media (max-width:720px){.site-header .inner{flex-direction:column;gap:.5rem;padding:.75rem}.site-nav{justify-content:center;gap:.75rem 1rem;font-size:.72rem}}

/* Hero */
.hero{padding:5rem 1.5rem 3rem;text-align:center}
.hero img.logo{max-width:520px;margin:0 auto 1.5rem}
.hero p.tagline{max-width:680px;margin:0 auto;font-size:1.2rem;font-family:'Cormorant Garamond',serif;font-style:italic;color:#5a4f3a}

/* Map */
.map{padding:1rem 1.5rem 5rem;text-align:center}
.map img{margin:0 auto;border-radius:2px;box-shadow:0 4px 30px rgba(0,0,0,.08)}

/* Plan your trip */
.plan{background:#fff;padding:5rem 1.5rem}
.plan h2{text-align:center;margin-bottom:3rem}
.venues{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}
.venue{text-align:center;padding:2rem 1.25rem;border:1px solid rgba(0,0,0,.08);border-radius:3px;background:#faf8f2;transition:transform .2s,box-shadow .2s}
.venue:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,.06)}
.venue h3{color:#8a6a34;margin-bottom:.85rem}
.venue h3 a{border:0;color:inherit}
.venue .offerings{margin:0 0 1rem;padding:0;list-style:none;font-size:.95rem}
.venue .offerings li{padding:.2rem 0}
.venue .hours{font-size:.82rem;color:#6a6a6a;line-height:1.5;border-top:1px solid rgba(0,0,0,.08);padding-top:.85rem;margin-top:1rem;margin-bottom:0}

/* CTA */
.cta{padding:5rem 1.5rem;background:#faf8f2;text-align:center}
.cta img{max-width:720px;margin:0 auto 2rem;border-radius:2px;box-shadow:0 4px 30px rgba(0,0,0,.08)}
.cta .eyebrow{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:#8a6a34;margin-bottom:.75rem;font-weight:600}
.btn{display:inline-block;margin-top:1rem;padding:.95rem 2.2rem;background:#2b2b2b;color:#f1ece1;border:0;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.btn:hover{background:#8a6a34;opacity:1}

/* Gallery */
.gallery{padding:5rem 1.5rem;background:#f1ece1}
.gallery h1{text-align:center;max-width:900px;margin:0 auto 3rem;font-style:italic;color:#4a4030}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem;max-width:1200px;margin:0 auto}
.gallery-grid img{width:100%;height:380px;object-fit:cover;border-radius:2px}

/* Quote band */
.quote{padding:5rem 1.5rem;text-align:center;background:#2b2b2b;color:#f1ece1}
.quote h2{font-style:italic;max-width:900px;margin:0 auto;font-weight:400}

/* Event */
.event{padding:5rem 1.5rem;background:#fff}
.event-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.event-text h2{margin-bottom:1.5rem}
.event-posters{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.event-posters img{border-radius:2px;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.social-links{display:flex;gap:1.5rem;margin-top:2rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;flex-wrap:wrap}
@media (max-width:720px){.event-inner{grid-template-columns:1fr;gap:2rem}}

/* Footer */
.site-footer{background:#2b2b2b;color:#c9c4b8;padding:3rem 1.5rem;text-align:center;font-size:.85rem;letter-spacing:.05em}
.site-footer a{border-bottom-color:rgba(255,255,255,.2)}
.site-footer .foot-nav{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem;text-transform:uppercase;font-size:.72rem;letter-spacing:.22em}

/* Article / content pages */
.page-hero{padding:6rem 1.5rem;text-align:center;min-height:320px;display:flex;align-items:center;justify-content:center}
.page-hero h1{margin:0 0 .5rem;font-size:clamp(2.2rem,5vw,3.6rem)}
.page-hero-sub{margin:0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;opacity:.9}
.page-content{max-width:820px;margin:0 auto;padding:4rem 1.5rem}
.page-content h2{margin-top:2.5rem;margin-bottom:.75rem;color:#8a6a34}
.page-content h2:first-child{margin-top:0}
.page-content p{font-size:1.05rem;line-height:1.75}
.page-content ul{padding-left:1.2rem}
.page-content ul li{margin-bottom:.35rem}
.page-content figure{margin:2rem 0}
.page-content figure img{width:100%;height:auto;border-radius:2px;box-shadow:0 4px 30px rgba(0,0,0,.08)}
.page-content a:not(.btn){color:#8a6a34}
.btn-ghost{background:transparent;color:#2b2b2b;border:1px solid #2b2b2b}
.btn-ghost:hover{background:#2b2b2b;color:#f1ece1}
.card{background:#fff;border-radius:3px;overflow:hidden;margin:2.5rem 0;box-shadow:0 4px 30px rgba(0,0,0,.07);display:grid;grid-template-columns:1fr 1fr;align-items:center}
.card img{width:100%;height:100%;object-fit:cover;max-height:360px}
.card-body{padding:2rem}
.card-body h2{margin-top:0}
@media (max-width:640px){.card{grid-template-columns:1fr}.card img{max-height:260px}}
