:root{
  --ink:#20242a;
  --muted:#5c6570;
  --paper:#f6f3ee;
  --paper-2:#efeae1;
  --sea:#1a8f9c;
  --sea-deep:#0f6f7a;
  --line:#ddd6ca;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--paper);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;letter-spacing:.2px;line-height:1.08;margin:0}
a{color:var(--sea-deep);text-decoration:none}
a:hover{text-decoration:underline}
img{display:block;max-width:100%}

/* top bar */
.topbar{
  position:absolute;top:0;left:0;right:0;z-index:5;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(18px,5vw,54px);color:#fff;
}
.wordmark{font-family:'Cormorant Garamond',serif;font-size:1.5rem;letter-spacing:.5px}
.topbar nav{display:flex;gap:clamp(14px,2.4vw,32px)}
.topbar nav a{color:rgba(255,255,255,.92);font-size:.82rem;letter-spacing:.09em;text-transform:uppercase}
.topbar nav a:hover{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.7)}

/* hero */
.hero{position:relative;height:min(92vh,760px);min-height:520px;overflow:hidden}
.hero-img{width:100%;height:100%;object-fit:cover;filter:saturate(1.02)}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,26,32,.42) 0%,rgba(20,26,32,.05) 34%,rgba(20,26,32,.5) 100%)}
.hero-inner{position:absolute;z-index:2;left:0;right:0;bottom:clamp(42px,8vh,96px);
  padding:0 clamp(18px,5vw,54px);color:#fff;max-width:var(--maxw);margin:0 auto}
.eyebrow{margin:0 0 .5rem;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.hero h1{font-size:clamp(3.2rem,9vw,6.4rem);text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero-sub{margin:.6rem 0 0;font-size:clamp(1.05rem,2.4vw,1.4rem);font-weight:400;color:rgba(255,255,255,.94);max-width:34ch}

/* generic wraps */
.wrap{max-width:760px;margin:0 auto;padding:0 clamp(18px,5vw,54px)}
section{padding:clamp(56px,9vw,110px) 0}

/* lede */
.lede .big{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,3.6vw,2.5rem);
  line-height:1.24;color:var(--ink);margin:0 0 1.1rem}
.lede p{color:var(--muted)}
.lede p:last-child{max-width:62ch}

/* split sections */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);
  align-items:center;max-width:var(--maxw);margin:0 auto;padding-left:clamp(18px,5vw,54px);padding-right:clamp(18px,5vw,54px)}
.split.reverse .split-text{order:2}
.split h2{font-size:clamp(2rem,4.6vw,3rem);margin-bottom:.8rem}
.split p{color:var(--muted);margin:0 0 1rem}
.split-fig{margin:0}
.split-fig img{width:100%;height:100%;max-height:560px;object-fit:cover;border-radius:3px;
  box-shadow:0 24px 50px -28px rgba(20,30,40,.5)}
.facts{list-style:none;margin:1.4rem 0 0;padding:0;border-top:1px solid var(--line)}
.facts li{padding:.62rem 0 .62rem 1.4rem;border-bottom:1px solid var(--line);color:var(--ink);
  font-size:.96rem;position:relative}
.facts li::before{content:"";position:absolute;left:0;top:1.02rem;width:7px;height:7px;
  border-radius:50%;background:var(--sea)}

/* three-image band */
.band{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:0}
.band figure{margin:0;aspect-ratio:4/5;overflow:hidden}
.band img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.band figure:hover img{transform:scale(1.04)}

/* gallery */
.gallery{background:var(--paper-2)}
.gallery h2{font-size:clamp(2rem,4.6vw,3rem);text-align:center}
.gallery-note{text-align:center;color:var(--muted);margin:.4rem auto 2.2rem;font-style:italic}
.grid{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,54px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;grid-auto-flow:dense}
.tile{overflow:hidden;border-radius:2px;aspect-ratio:1/1;background:#e6e0d5;cursor:zoom-in}
.tile.wide{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease,filter .4s}
.tile:hover img{transform:scale(1.05)}
.ta{text-align:center;color:var(--muted);margin:2.4rem auto 0;font-size:.95rem}

/* contact */
.contact{background:var(--sea-deep);color:#eef7f7;text-align:center}
.contact h2{font-size:clamp(2.2rem,5vw,3.2rem);color:#fff}
.contact .wrap p{color:rgba(238,247,247,.9)}
.contact a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.mail{margin-top:1.6rem !important;font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,4vw,2.1rem)}
.mail a{text-decoration:none;border-bottom:1px solid rgba(255,255,255,.5)}

/* footer */
.foot{background:#181c21;color:#9aa3ad;text-align:center;padding:40px 18px;font-size:.85rem}
.foot p{margin:.25rem 0}
.foot a{color:#c7ced4}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:50;background:rgba(12,14,17,.94);
  display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lightbox[hidden]{display:none}
.lightbox img{max-width:94vw;max-height:90vh;object-fit:contain;border-radius:2px}
.lightbox button{position:absolute;top:18px;right:24px;background:none;border:none;
  color:#fff;font-size:2.4rem;line-height:1;cursor:pointer}

@media(max-width:820px){
  .topbar nav{display:none}
  .split,.split.reverse{grid-template-columns:1fr}
  .split.reverse .split-text{order:0}
  .split-fig img{max-height:420px}
  .band{grid-template-columns:1fr 1fr}
  .band figure:last-child{grid-column:1/-1;aspect-ratio:16/9}
  .grid{grid-template-columns:repeat(2,1fr)}
  .tile.wide{grid-column:span 2;grid-row:auto;aspect-ratio:4/3}
}
