:root{--bone:#EDE6D9;--paper:#F5EFE4;--ink:#2A221B;--taupe:#8B7C6B;--line:#D8CBB8;--patina:#5C7E78;--maxw:1280px;--gut:clamp(24px,5vw,72px)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{background:var(--bone);color:var(--ink);font-family:'Hanken Grotesk',system-ui,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
img{display:block;max-width:100%}a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.serif{font-family:'Fraunces',Georgia,serif;font-weight:400;font-optical-sizing:auto}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--taupe);font-weight:500}
:focus-visible{outline:2px solid var(--patina);outline-offset:3px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s,box-shadow .4s}
header.scrolled{background:rgba(237,230,217,.9);backdrop-filter:blur(8px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:'Fraunces',serif;font-size:21px}.brand span{color:var(--taupe);font-style:italic}
.links{display:flex;gap:34px;align-items:center}
.links a{font-size:13.5px;letter-spacing:.04em;position:relative;padding:4px 0}
.links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--ink);transition:width .3s}
.links a:hover::after{width:100%}
.links a.book{border:1px solid var(--ink);padding:9px 18px}.links a.book::after{display:none}
.links a.book:hover{background:var(--ink);color:var(--bone)}
.menu-btn{display:none;background:none;border:0;font-size:13px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;color:var(--ink)}
@media(max-width:820px){.links{position:fixed;top:0;left:0;right:0;height:100vh;height:100dvh;background:var(--bone);flex-direction:column;justify-content:center;gap:30px;transform:translateY(-100%);transition:transform .45s cubic-bezier(.4,0,.1,1)}.links.open{transform:translateY(0)}.links a{font-size:24px}.links a.book{border:0;padding:0}.menu-btn{display:block;position:relative;z-index:101}}
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;background:radial-gradient(120% 90% at 22% 8%,rgba(255,247,232,.55),rgba(255,247,232,0) 55%),linear-gradient(155deg,#d9c7ad,#c8b196 30%,#9c8468 62%,#5f4f3d 100%)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,0) 42%,rgba(0,0,0,.5) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,9vh,96px);color:#F7F1E6}
.hero .eyebrow{color:rgba(247,241,230,.82)}
.hero h1{font-family:'Fraunces',serif;font-weight:300;line-height:.96;letter-spacing:-.01em;font-size:clamp(52px,12vw,150px);margin:.12em 0 .28em}
.hero .tag{font-size:clamp(16px,2.1vw,22px);max-width:30ch;color:rgba(247,241,230,.92)}
.hero .meta{margin-top:26px;display:flex;flex-wrap:wrap;gap:14px 26px;font-size:13px;letter-spacing:.06em}
.hero .meta .dot{color:rgba(247,241,230,.55)}
.hero .cta{display:inline-flex;gap:10px;margin-top:30px;border:1px solid rgba(247,241,230,.7);color:#F7F1E6;padding:12px 22px;font-size:13.5px;letter-spacing:.05em;transition:.3s}
.hero .cta:hover{background:#F7F1E6;color:var(--ink)}
.sec{padding-block:clamp(56px,9vh,96px)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;border-top:1px solid var(--line);padding-top:22px;margin-bottom:38px}
.sec-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,4vw,42px)}
.sec-head .count{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--taupe)}
.masonry{column-gap:14px;column-count:4}
@media(max-width:900px){.masonry{column-count:2}}@media(max-width:560px){.masonry{column-count:1}}
/* Editorial — uniform 3:2 landscape thumbs (vertical shots center-cropped; full image in lightbox) */
.edit-rows{display:flex;flex-direction:column;gap:14px}
.grid-edit{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid-edit .tile{aspect-ratio:3/2;overflow:hidden}
.grid-edit .tile picture{display:block;width:100%;height:100%}
.grid-edit .tile .fill{width:100%;height:100%;object-fit:cover;object-position:center 38%}
/* Carousel row: shows 3 across, the rest revealed by swipe / arrow */
.scroll-wrap{position:relative}
.grid-edit.row-scroll{grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:calc((100% - 28px)/3);overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
.grid-edit.row-scroll::-webkit-scrollbar{display:none}
.grid-edit.row-scroll .tile{scroll-snap-align:start}
.row-next,.row-prev{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:38px;height:38px;border-radius:50%;border:0;background:rgba(245,239,228,.92);color:var(--ink);font-size:24px;line-height:1;cursor:pointer;box-shadow:0 2px 10px rgba(42,34,27,.28);display:flex;align-items:center;justify-content:center;transition:opacity .25s,transform .2s}
.row-next{right:8px}.row-prev{left:8px}
.row-next:hover,.row-prev:hover{transform:translateY(-50%) scale(1.08)}
.row-next[hidden],.row-prev[hidden]{display:none}
/* Tablet & mobile: single column at the photo's natural ratio — nothing cropped, arrow retired, every frame inline */
@media(max-width:900px){
  .grid-edit{grid-template-columns:1fr;gap:12px}
  .grid-edit .tile{aspect-ratio:auto}
  .grid-edit .tile picture{height:auto}
  .grid-edit .tile .fill{height:auto;object-fit:fill;object-position:center!important}
  .grid-edit.row-scroll{grid-auto-flow:row;grid-auto-columns:auto;overflow:visible}
  .row-next,.row-prev{display:none}
}
.three{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:760px){.three{grid-template-columns:1fr}}
.tile{position:relative;width:100%;margin-bottom:14px;break-inside:avoid;cursor:pointer;overflow:hidden;background:#cdb79c;border:0;padding:0;display:block}
.three .tile{margin:0}
.tile .fill{width:100%;height:auto;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.three .tile{aspect-ratio:.8}
.three .tile .fill{width:100%;height:100%;object-fit:cover}
.tile:hover .fill{transform:scale(1.045)}
.tile::after{content:"";position:absolute;inset:0;background:rgba(42,34,27,0);transition:background .4s;pointer-events:none}
.tile:hover::after{background:rgba(42,34,27,.12)}
.statement{padding-block:clamp(80px,14vh,150px);text-align:center}
.statement p{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(26px,4.4vw,52px);line-height:1.16;max-width:20ch;margin:0 auto}
.statement .lede{margin:30px auto 0;font-family:'Hanken Grotesk';font-size:17px;color:var(--taupe);max-width:50ch}
.about{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,6vw,80px);align-items:center}
@media(max-width:820px){.about{grid-template-columns:1fr;gap:36px}}
.about .portrait{position:relative;aspect-ratio:4/5;overflow:hidden;background:linear-gradient(150deg,#dac9af,#b39a7b 70%,#7d6850)}
.about .portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about h3{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(24px,3.2vw,34px);margin-bottom:8px}
.about .kicker{margin-bottom:18px}.about p{color:#3c332a;margin-bottom:16px;max-width:54ch}.about p.muted{color:var(--taupe)}
/* pricing — packages */
.packages{display:grid;grid-template-columns:repeat(3,minmax(0,280px));gap:clamp(18px,3vw,26px);justify-content:center}
@media(max-width:1000px){.packages{grid-template-columns:repeat(2,minmax(0,300px))}}
@media(max-width:680px){.packages{grid-template-columns:minmax(0,360px)}}
.pkg--custom{border-style:dashed;border-color:var(--taupe);background:linear-gradient(165deg,#f3eee3,#ece3d4)}
.pkg--custom .price{color:var(--ink);font-style:italic}
.pkg--custom li::before{background:var(--ink)}
.pkg .pcta{display:inline-block;margin-top:22px;font-size:13px;letter-spacing:.05em;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;transition:opacity .25s}
.pkg .pcta:hover{opacity:.65}
.pkg{border:1px solid var(--line);background:var(--paper);padding:clamp(28px,3.4vw,40px)}
.pkg .pname{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);font-weight:500;margin-bottom:12px}
.pkg .price{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(38px,5vw,54px);line-height:1}
.pkg ul{list-style:none;margin-top:26px;border-top:1px solid var(--line)}
.pkg li{display:flex;gap:12px;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line);color:#3c332a;font-size:15.5px}
.pkg li::before{content:"";flex:0 0 auto;width:5px;height:5px;border-radius:50%;background:var(--patina);transform:translateY(-2px)}
.booking{background:var(--paper)}
.book-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,6vw,72px)}
@media(max-width:820px){.book-grid{grid-template-columns:1fr;gap:30px}}
.book-intro h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(30px,4.4vw,46px);line-height:1.05;margin:14px 0 18px}
.book-intro p{color:var(--taupe);max-width:40ch}
form{display:grid;grid-template-columns:1fr 1fr;gap:18px 16px}
.field{display:flex;flex-direction:column;gap:7px;min-width:0}.field.full{grid-column:1/-1}
label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe)}
input,select,textarea{font-family:inherit;font-size:15px;color:var(--ink);background:var(--bone);border:1px solid var(--line);padding:12px 13px;transition:border-color .25s}
input:focus,select:focus,textarea:focus{border-color:var(--ink);outline:none}
textarea{resize:vertical;min-height:110px}
/* Mobile form: stack into one column (prevents right-edge overflow) + 16px inputs (stops iOS focus-zoom) */
@media(max-width:600px){form{grid-template-columns:1fr}}
@media(max-width:820px){input,select,textarea{font-size:16px}}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.submit{grid-column:1/-1;display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:4px}
button.send{background:var(--ink);color:var(--bone);border:0;padding:14px 30px;font-family:inherit;font-size:14px;letter-spacing:.05em;cursor:pointer;transition:opacity .25s}
button.send:hover{opacity:.85}button.send:disabled{opacity:.5;cursor:default}
.form-msg{font-size:13px;color:var(--patina)}.form-msg.error{color:#9a4a3a}
footer{border-top:1px solid var(--line);padding:clamp(48px,8vh,80px) 0 50px}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px;align-items:flex-end}
.foot .brand{font-size:30px}.foot .cols{display:flex;gap:clamp(30px,6vw,90px);flex-wrap:wrap}
.foot .col span{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);margin-bottom:10px}
.foot .col a,.foot .col p{font-size:15px;margin-bottom:5px}.foot .col a:hover{color:var(--patina)}
.copyright{margin-top:46px;font-size:12px;color:var(--taupe)}
.lb{position:fixed;inset:0;z-index:1000;background:rgba(28,22,17,.94);display:none;align-items:center;justify-content:center;flex-direction:column;padding:24px}
.lb.open{display:flex}
.lb .stage{display:flex;align-items:center;justify-content:center;max-width:min(92vw,1400px)}
.lb .stage img{max-width:100%;max-height:80vh;width:auto;height:auto;object-fit:contain;background:#1c1611}
.lb .cap{color:#F7F1E6;margin-top:18px;font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.lb .x{position:absolute;top:22px;right:26px;color:#F7F1E6;font-size:28px;background:none;border:0;cursor:pointer}
.lb .arrow{position:absolute;top:50%;transform:translateY(-50%);color:#F7F1E6;background:none;border:0;font-size:40px;cursor:pointer;padding:10px 18px;opacity:.7}
.lb .arrow:hover{opacity:1}.lb .prev{left:8px}.lb .next{right:8px}
