@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Inter:wght@400;500;600&display=swap');

/* James Munton — Light & Editorial design system */
:root{
  --paper:#faf8f4; --paper2:#f3efe7; --ink:#22201d; --muted:#6b655c;
  --line:#e7e2d8; --accent:#b06a4f; --accent-dk:#8f5037; --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--paper); color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:17px; line-height:1.7; -webkit-font-smoothing:antialiased}
img{max-width:100%; display:block}
a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}

/* typography */
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif; font-weight:500; letter-spacing:.005em; color:var(--ink)}
h1{font-size:clamp(38px,5.5vw,64px); line-height:1.07; margin:0 0 22px}
h2{font-size:clamp(28px,4vw,42px); line-height:1.12; margin:0 0 16px}
h3{font-size:26px; line-height:1.2; margin:1.4em 0 .5em}
.eyebrow{font-family:'Inter',sans-serif; font-size:12px; font-weight:600; letter-spacing:.24em;
  text-transform:uppercase; color:var(--accent); margin:0 0 22px}
.lede{font-size:18px; color:var(--muted); max-width:34em; margin:0 0 30px}

/* buttons */
.btn{display:inline-block; background:var(--ink); color:var(--paper)!important; font-size:13px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; padding:15px 30px; border-radius:2px; transition:background .2s}
.btn:hover{background:var(--accent); text-decoration:none}
button.btn{border:0; cursor:pointer; font-family:inherit}
.btn-wrap{margin:1.6em 0}
.btn-line{display:inline-block; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); border-bottom:2px solid var(--accent); padding-bottom:5px}
.btn-line:hover{color:var(--accent); text-decoration:none}

/* header */
.site-header{position:sticky; top:0; z-index:40; background:rgba(250,248,244,.92);
  backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--line)}
.bar{display:flex; align-items:center; justify-content:space-between; padding:16px 28px; max-width:var(--maxw); margin:0 auto}
.logo img{height:30px; width:auto}
nav.main{display:flex; align-items:center; gap:28px}
nav.main a{font-size:12.5px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:var(--muted)}
nav.main a:hover{color:var(--ink); text-decoration:none}
nav.main a.active{color:var(--ink); border-bottom:2px solid var(--accent); padding-bottom:3px}
nav.main a.book{background:var(--ink); color:#fff; padding:11px 20px; border-radius:2px; letter-spacing:.1em}
nav.main a.book:hover{background:var(--accent); color:#fff}
.navtoggle,.navbtn{display:none}

/* hero (home) */
.hero{display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:center; padding:84px 0 76px}
.hero-img{position:relative}
.hero-img img{width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:4px}
.hero-img::after{content:""; position:absolute; left:-14px; top:18px; right:18px; bottom:-14px;
  border:1px solid var(--accent); border-radius:4px; z-index:-1}
.cta-row{display:flex; align-items:center; gap:24px; flex-wrap:wrap}
.phone{font-size:15px; color:var(--muted)}

/* credential strip */
.cred{background:var(--ink); color:#efe9df}
.cred .wrap{padding:30px 28px; text-align:center}
.cred p{margin:0; font-family:'Cormorant Garamond',serif; font-size:clamp(22px,3vw,30px); font-weight:400}
.cred .star,.reviews .star{color:var(--accent); letter-spacing:.3em; font-family:'Inter',sans-serif; font-size:13px; display:block; margin-bottom:10px}

/* events (home) */
.events{padding:90px 0 30px; text-align:center}
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:54px; text-align:left}
.card{background:#fff; border:1px solid var(--line); border-radius:4px; overflow:hidden; display:flex; flex-direction:column}
.card img{width:100%; aspect-ratio:3/2; object-fit:cover}
.card-body{padding:28px 26px 30px; display:flex; flex-direction:column; flex:1}
.card h3{font-size:27px; margin:0 0 12px}
.card p{margin:0 0 22px; font-size:15px; color:var(--muted); line-height:1.65; flex:1}

/* reviews (home) */
.reviews{padding:96px 0; text-align:center; background:var(--paper2); margin-top:60px}
blockquote{font-family:'Cormorant Garamond',serif; font-size:clamp(26px,3.6vw,40px); font-weight:400;
  line-height:1.28; max-width:18em; margin:18px auto 22px; color:var(--ink)}
cite{font-style:normal; font-size:12.5px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted)}
.reviews .more{margin-top:34px}

/* home gallery strip */
.gallery-strip{display:grid; grid-template-columns:repeat(4,1fr); gap:8px}
.gallery-strip img{width:100%; aspect-ratio:1/1; object-fit:cover}

/* closing (home) */
.closing{padding:96px 0; text-align:center}
.closing p{font-size:18px; color:var(--muted); max-width:30em; margin:0 auto 32px}

/* ---------- interior pages ---------- */
main.content{padding:60px 0 80px}
main.content .wrap{max-width:780px}
main.content h1{position:relative; padding-bottom:22px; margin-bottom:30px}
main.content h1::after{content:""; position:absolute; left:0; bottom:0; width:64px; height:3px; background:var(--accent)}
main.content h2{margin-top:1.5em}
.prose{font-size:17px; line-height:1.78; color:#34302b}
.prose p{margin:0 0 1.1em}
.prose a{color:var(--accent); text-decoration:underline}
.prose ul,.prose ol{margin:0 0 1.2em; padding-left:1.2em}
.prose li{margin:.3em 0}
.prose h3{font-size:24px}
.prose em{color:var(--muted)}
figure{margin:1.8em 0}
figure img{width:100%; border-radius:4px}
main.content .gallery{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; margin:1.6em 0}
main.content .gallery img{width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:4px}
.faq{margin:1.4em 0}
.faq details{border:1px solid var(--line); border-radius:4px; padding:2px 18px; margin:.6em 0; background:#fff}
.faq summary{cursor:pointer; font-weight:600; padding:14px 0; font-size:16px; list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; float:right; color:var(--accent); font-size:20px; line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq .prose{margin:.2em 0 1em}
.video{position:relative; padding-bottom:56.25%; height:0; margin:1.6em 0; border-radius:6px; overflow:hidden}
.video iframe{position:absolute; inset:0; width:100%; height:100%; border:0}
[id^="ndrsl"]{margin:1.4em 0}

/* contact form */
.contact-form{margin:1.6em 0; max-width:640px}
.contact-form .field{margin-bottom:1rem}
.contact-form label{display:block; font-weight:600; font-size:14px; margin-bottom:.35rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%; padding:.8rem .9rem;
  border:1px solid var(--line); border-radius:4px; font:inherit; background:#fff; color:var(--ink)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;
  border-color:var(--accent); box-shadow:0 0 0 3px rgba(176,106,79,.15)}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
.req{color:var(--accent)}
.form-note{font-size:.9rem; color:var(--muted); margin-top:.7rem; min-height:1.2em}

/* footer */
footer{background:var(--ink); color:#cbc6bd; padding:64px 0 30px}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px}
footer h4{font-family:'Inter',sans-serif; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:#8c867c; margin:0 0 16px; font-weight:600}
footer a{color:#e9e4da}
footer a:hover{color:var(--accent); text-decoration:none}
.foot-brand .name{font-family:'Cormorant Garamond',serif; font-size:26px; color:#fff; margin-bottom:8px}
.foot-brand p{margin:0 0 14px; color:#a9a399; font-size:14px; line-height:1.6}
.foot-cities{display:flex; flex-wrap:wrap; gap:6px 14px; font-size:13.5px}
.foot-links{display:flex; flex-direction:column; gap:9px; font-size:14px}
.legal{border-top:1px solid rgba(255,255,255,.1); margin-top:46px; padding-top:22px; font-size:12.5px; color:#8c867c;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px}

/* mobile */
@media (max-width:900px){
  .hero{grid-template-columns:1fr; gap:40px; padding:54px 0}
  .hero-img{order:-1; max-width:420px}
  .hero-img::after{display:none}
  .cards{grid-template-columns:1fr; max-width:430px; margin:46px auto 0}
  .gallery-strip{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr}
  .navbtn{display:block; cursor:pointer; font-size:24px; color:var(--ink); padding:4px 8px; line-height:1}
  nav.main{display:none; position:absolute; left:0; right:0; top:100%; flex-direction:column; align-items:stretch;
    gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:8px 0}
  .navtoggle:checked ~ nav.main{display:flex}
  nav.main a{padding:13px 28px; color:var(--ink)}
  nav.main a.active{border-bottom:0; color:var(--accent); padding-bottom:13px}
  nav.main a.book{background:none; color:var(--ink); border-radius:0}
  nav.main a.book:hover{background:none; color:var(--accent)}
}
