:root{
  --accent:#B91C1C; --ink:#09090B; --muted:#52525B; --line:#E4E4E7;
  --bg:#FAFAF8; --serif:'Playfair Display',Georgia,serif;
  --serifcaps:'Playfair Display SC',serif; --sans:'Karla',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:400;line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2{font-family:var(--serif);font-weight:600;line-height:1.05}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.nav{position:fixed;inset:0 0 auto 0;z-index:50;display:flex;justify-content:space-between;align-items:center;
  padding:22px clamp(20px,5vw,56px);transition:.4s;mix-blend-mode:difference;color:#fff}
.nav.solid{mix-blend-mode:normal;background:var(--bg);color:var(--ink);padding:14px clamp(20px,5vw,56px);border-bottom:1px solid var(--line)}
.brand{font-family:var(--serifcaps);font-size:20px;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
.nav-cta{font-size:13px;font-weight:600;letter-spacing:.5px;border-bottom:1px solid currentColor;padding-bottom:2px;white-space:nowrap}

.hero{position:relative;height:100svh;min-height:560px;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-img{position:absolute;inset:-5% 0;background-size:cover;background-position:center;will-change:transform}
.hero-mask{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.7))}
.hero-inner{position:relative;z-index:2;padding:0 clamp(20px,5vw,56px) clamp(40px,7vw,84px);max-width:1000px}
.kicker{font-size:13px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:#fff;opacity:.85;margin-bottom:18px}
.hero h1{font-family:var(--serifcaps);font-size:clamp(44px,9vw,108px);font-weight:700;line-height:.98}
.lede{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2.5vw,28px);margin-top:16px;max-width:24ch;opacity:.95}
.stars{margin-top:22px;font-size:15px;letter-spacing:1px;color:var(--accent);background:#fff;display:inline-block;padding:8px 16px}
.stars span{color:var(--ink);font-family:var(--sans);letter-spacing:0;margin-left:6px;font-size:14px}

section.chapter,section.gallery,section.quotes,section.visit{
  max-width:1080px;margin:0 auto;padding:clamp(60px,11vw,150px) clamp(20px,5vw,56px);position:relative}
.num{display:block;font-family:var(--serif);font-size:clamp(40px,7vw,86px);color:var(--accent);line-height:1;margin-bottom:28px;opacity:.9}
h2{font-size:clamp(30px,5vw,56px);margin-bottom:26px}
.chapter{display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,5vw,64px);align-items:start}
.chapter-body p{font-size:clamp(17px,1.7vw,21px);color:var(--muted);max-width:60ch}
.link-cta{display:inline-block;margin-top:26px;font-weight:700;color:var(--accent);border-bottom:2px solid var(--accent);padding-bottom:3px}

.gallery{border-top:1px solid var(--line)}
.gallery-title{margin-bottom:34px}
.masonry{columns:3;column-gap:14px}
.masonry figure{break-inside:avoid;margin:0 0 14px;overflow:hidden}
.masonry img{width:100%;transition:.6s cubic-bezier(.2,.7,.2,1);filter:grayscale(.15)}
.masonry figure:hover img{transform:scale(1.05);filter:none}

.quotes{border-top:1px solid var(--line)}
.quote-list{display:flex;flex-direction:column;gap:0}
.review-card{padding:34px 0;border-bottom:1px solid var(--line)}
.review-stars{color:var(--accent);letter-spacing:2px;font-size:15px;margin-bottom:14px}
.review-text{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.6vw,30px);line-height:1.4;color:var(--ink);max-width:24ch}
.review-author{margin-top:16px;font-weight:700;font-size:14px;letter-spacing:.5px}
.review-meta{font-size:13px;color:var(--muted)}

.visit{border-top:1px solid var(--line)}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.hours{width:100%;border-collapse:collapse;margin:4px 0 24px}
.hours tr{border-bottom:1px solid var(--line)}
.hours td{padding:11px 0;font-size:15px}
.hours td:last-child{text-align:right;color:var(--muted)}
.visit-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;background:var(--accent);color:#fff;font-weight:600;padding:13px 26px;font-size:14px;letter-spacing:.5px;transition:.3s}
.btn:hover{opacity:.88}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#fff}
.map{height:360px;overflow:hidden;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(.4)}

.footer{text-align:center;padding:70px 20px;border-top:1px solid var(--line)}
.f-name{font-family:var(--serifcaps);font-size:24px}
.f-note{font-size:12px;color:var(--muted);margin-top:16px}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:760px){
  .chapter{grid-template-columns:1fr;gap:8px}
  .masonry{columns:2}
  .visit-grid{grid-template-columns:1fr}
  .map{height:280px}
}
@media(prefers-reduced-motion:reduce){.reveal{transition:none;opacity:1;transform:none}.hero-img{transform:none!important}}
