/* ===========================================================
   Masseria Montanari — shared stylesheet
   Palette: pietra leccese / clay / olive + brand wine
   =========================================================== */
:root{
  --cream:#f5eddf;
  --paper:#fbf6ec;
  --ink:#2c261d;
  --ink-soft:#5f5648;
  --line:#e3d8c4;
  --clay:#bd6741;
  --clay-deep:#a4542f;
  --olive:#4c5a3f;
  --olive-deep:#3a4631;
  --gold:#c79a4e;
  --wine:#6f3a38;
  --display:'Cormorant Garamond',Georgia,serif;
  --script:'Pinyon Script',cursive;
  --body:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{position:relative}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--clay);display:inline-block}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.05;letter-spacing:-.01em;overflow-wrap:break-word}
p,li,.sub,.eyebrow,.cap{overflow-wrap:break-word}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* buttons */
.btn{font-family:var(--body);font-size:13.5px;font-weight:600;letter-spacing:.04em;padding:13px 26px;border-radius:2px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:9px;transition:.25s;white-space:nowrap}
.btn-clay{background:var(--clay);color:#fff}
.btn-clay:hover{background:var(--clay-deep);transform:translateY(-1px)}
.btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.btn-dark{border-color:var(--ink);color:var(--ink)}
.btn-dark:hover{background:var(--ink);color:var(--paper)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}

/* ===================== LOGO ===================== */
.logo{display:flex;align-items:center;gap:14px;line-height:1}
.logo .logo-img{height:50px;width:auto;display:block}
.logo .brown{display:none}
.logo .gold{display:block}
.logo .word{display:flex;flex-direction:column}
.logo .word .nm{font-family:var(--script);font-size:30px;color:var(--wine);line-height:.9;white-space:nowrap}
.logo .word .tg{font-family:var(--body);font-size:9px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
/* light backgrounds → brown lockup */
header.nav.solid .logo .gold,header.nav.scrolled .logo .gold{display:none}
header.nav.solid .logo .brown,header.nav.scrolled .logo .brown{display:block}

/* ===================== NAV ===================== */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:28px;padding:16px 40px;transition:background .4s,padding .4s,box-shadow .4s,border-color .4s;border-bottom:1px solid transparent}
header.nav.solid,header.nav.scrolled{background:rgba(251,246,236,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);box-shadow:0 8px 30px -22px rgba(44,38,29,.6)}
header.nav.scrolled{padding:10px 40px}
nav.links{display:flex;align-items:center;gap:28px}
nav.links a{font-size:14px;font-weight:500;transition:color .25s,opacity .25s;opacity:.9;position:relative;color:var(--ink);white-space:nowrap}
header.nav.transparent:not(.scrolled) nav.links a{color:#fff}
header.nav.transparent:not(.scrolled) .logo .word .nm{color:#f0d6a4}
header.nav.transparent:not(.scrolled) .logo .word .tg{color:rgba(255,255,255,.82)}
nav.links a::after{content:'';position:absolute;left:0;bottom:-5px;height:1.5px;width:0;background:var(--clay);transition:width .3s}
nav.links a:hover::after,nav.links a.active::after{width:100%}
nav.links a.active{color:var(--clay)}
.nav-right{display:flex;align-items:center;gap:18px}

/* language switcher */
.lang{position:relative}
.lang .cur{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;letter-spacing:.06em;cursor:pointer;padding:7px 10px;border:1px solid var(--line);border-radius:2px;background:rgba(255,255,255,.5);color:var(--ink)}
header.nav.transparent:not(.scrolled) .lang .cur{color:#fff;border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.08)}
.lang .cur .car{font-size:9px;opacity:.7}
.lang .menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--paper);border:1px solid var(--line);border-radius:3px;box-shadow:0 18px 40px -20px rgba(44,38,29,.5);overflow:hidden;min-width:130px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:.22s;z-index:60}
.lang.open .menu{opacity:1;visibility:visible;transform:none}
.lang .menu button,.lang .menu a{display:flex;width:100%;align-items:center;gap:10px;padding:11px 14px;background:none;border:none;font-family:var(--body);font-size:13.5px;color:var(--ink);cursor:pointer;text-align:left;text-decoration:none;transition:.15s}
.lang .menu button:hover,.lang .menu a:hover{background:var(--cream)}
.lang .menu button.sel,.lang .menu a.sel{color:var(--clay);font-weight:700}

.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
.menu-toggle span{width:26px;height:2px;background:var(--ink);display:block;transition:.3s}
header.nav.transparent:not(.scrolled) .menu-toggle span{background:#fff}

/* mobile panel */
.mobile-panel{position:fixed;inset:0;z-index:70;background:var(--olive-deep);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:22px;transform:translateX(100%);transition:transform .45s cubic-bezier(.5,0,.2,1)}
.mobile-panel.open{transform:none}
.mobile-panel a{font-family:var(--display);font-size:30px;color:#fff}
.mobile-panel a.active{color:var(--gold)}
.mobile-panel .close{position:absolute;top:22px;right:26px;font-size:34px;background:none;border:none;color:#fff;cursor:pointer}
.mobile-panel .mlang{display:flex;gap:16px;margin-top:14px}
.mobile-panel .mlang button,.mobile-panel .mlang a{background:none;border:none;color:rgba(255,255,255,.7);font-family:var(--body);font-size:15px;letter-spacing:.1em;cursor:pointer;text-decoration:none}
.mobile-panel .mlang button.sel,.mobile-panel .mlang a.sel{color:var(--gold);font-weight:700}

/* ===================== PAGE HERO (interior) ===================== */
.phero{min-height:62vh;position:relative;display:flex;align-items:flex-end;color:#fff;padding-top:90px}
.phero image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.phero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,23,16,.58),rgba(28,23,16,.14) 42%,rgba(28,23,16,.74))}
.phero .wrap{position:relative;z-index:2;padding-bottom:54px;width:100%}
.phero .crumb{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#e9c98f;font-weight:600;margin-bottom:14px}
.phero h1{font-size:clamp(40px,6vw,82px);max-width:18ch;line-height:1.1;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.phero h1 em{font-style:italic;color:#f0d6a4}
.phero p.sub{font-size:clamp(16px,1.4vw,19px);max-width:50ch;margin-top:20px;opacity:.95}

/* ===================== HERO (home full) ===================== */
.hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;color:#fff;padding-top:96px}
.hero image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,23,16,.6),rgba(28,23,16,.12) 30%,rgba(28,23,16,.2) 55%,rgba(28,23,16,.85)),linear-gradient(105deg,rgba(28,23,16,.62) 0%,rgba(28,23,16,.28) 38%,transparent 62%)}
.hero .wrap{position:relative;z-index:2;padding-bottom:78px;width:100%}
.hero .eyebrow{color:#e9c98f}
.hero h1{font-size:clamp(46px,7vw,104px);margin:16px 0 0;max-width:14ch;line-height:1.08;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 em{font-style:italic;color:#f0d6a4}
.hero p.sub{font-size:clamp(16px,1.5vw,20px);max-width:46ch;margin-top:28px;opacity:.95}
.hero .cta-row{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.scroll-hint{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:2;color:#fff;font-size:11px;letter-spacing:.25em;text-transform:uppercase;opacity:.8;display:flex;flex-direction:column;align-items:center;gap:9px}
.scroll-hint .line{width:1px;height:42px;background:linear-gradient(#fff,transparent);animation:drop 2s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===================== GENERIC SECTIONS ===================== */
.pad{padding:110px 0}
.pad-sm{padding:80px 0}
.bg-paper{background:var(--paper)}
.bg-olive{background:var(--olive-deep);color:var(--paper)}
.bg-olive .eyebrow{color:var(--gold)}
.bg-olive h1,.bg-olive h2,.bg-olive h3{color:#fff}
.sec-head{text-align:center;max-width:660px;margin:0 auto 58px}
.sec-head h2{font-size:clamp(34px,4.2vw,58px);margin-top:14px}
.sec-head p{color:var(--ink-soft);font-size:17px;margin-top:18px}
.bg-olive .sec-head p{color:rgba(255,255,255,.78)}

/* split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
.split.rev .txt{order:2}
.split h2{font-size:clamp(32px,4vw,54px);margin:14px 0 24px;max-width:16ch}
.split p{color:var(--ink-soft);font-size:17px;margin-bottom:16px;max-width:54ch}
.bg-olive .split p{color:rgba(255,255,255,.8)}
.split image-slot{width:100%;height:540px}
.tick{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:12px}
.tick li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px}
.tick li::before{content:'';flex:none;width:8px;height:8px;border-radius:50%;background:var(--clay);margin-top:8px}
.bg-olive .tick li::before{background:var(--gold)}

/* round stamp */
.stamp{position:absolute;bottom:-26px;left:-26px;width:138px;height:138px;border-radius:50%;background:var(--olive);color:var(--paper);display:grid;place-items:center;text-align:center;font-family:var(--display);box-shadow:0 20px 50px -20px rgba(44,38,29,.7);z-index:3}
.stamp .yr{font-size:40px;line-height:1;font-weight:600}
.stamp small{font-family:var(--body);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;display:block;margin:5px auto 0;max-width:88px;line-height:1.3;opacity:.85}
.posrel{position:relative}

/* dark fallback behind overlay slots so white text stays legible before a photo is dropped */
.hero image-slot,.phero image-slot,.book image-slot{background:linear-gradient(135deg,#4c5a3f,#2c261d)}
.svc image-slot,.place image-slot{background:#3a4631}

/* facts strip */
.facts{background:var(--olive-deep);color:var(--paper);padding:46px 0}
.facts .row{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;text-align:center}
.facts .f .n{font-family:var(--display);font-size:46px;font-weight:600;line-height:1;color:#fff}
.facts .f .n span{font-size:20px}
.facts .f .l{font-size:12px;letter-spacing:.13em;text-transform:uppercase;opacity:.72;margin-top:8px}
.facts .f{border-right:1px solid rgba(255,255,255,.14)}
.facts .f:last-child{border-right:none}

/* service cards (home) */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.svc-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.svc{position:relative;min-height:460px;overflow:hidden;display:flex;align-items:flex-end;color:#fff}
.svc image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.svc::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,23,16,.12),rgba(28,23,16,.82));transition:.4s}
.svc:hover::after{background:linear-gradient(180deg,rgba(28,23,16,.25),rgba(28,23,16,.9))}
.svc .c{position:relative;z-index:2;padding:34px}
.svc .c .eyebrow{color:#e9c98f}
.svc h3{font-size:30px;color:#fff;margin:10px 0 10px}
.svc p{font-size:14.5px;opacity:.9;margin-bottom:16px;max-width:32ch}
.svc .more{font-size:13px;font-weight:600;letter-spacing:.05em;color:#fff;display:inline-flex;gap:8px;align-items:center;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:3px}

/* room cards */
.room-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.room-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.room{background:var(--paper);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:.35s}
.room:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(44,38,29,.55)}
.room image-slot,.room .rimg{width:100%;height:auto;aspect-ratio:4/3}
.room .body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.room .tag{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);font-weight:600}
.room h3{font-size:26px;margin:8px 0 10px}
.room p{color:var(--ink-soft);font-size:14.5px;margin-bottom:16px}
.amen{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.amen span{font-size:11.5px;color:var(--ink-soft);border:1px solid var(--line);border-radius:30px;padding:5px 12px;background:var(--cream)}
.room .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}
.room .cap{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink)}
.room .cap svg{width:21px;height:21px;stroke:var(--clay);fill:none;flex:0 0 auto}
.room .px{font-family:var(--display);font-size:21px;color:var(--ink)}
.room .px small{font-family:var(--body);font-size:12px;color:var(--ink-soft)}

/* feature band (alternating) */
.band{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.feat{display:grid;grid-template-columns:1fr 1fr;align-items:center}
.feat .txt{padding:86px clamp(40px,6vw,108px)}
.feat:nth-child(even) .txt{order:2}
.feat image-slot{width:100%;height:520px}
.feat h3{font-size:clamp(30px,3.4vw,46px);margin:14px 0 22px;max-width:15ch}
.feat p{color:var(--ink-soft);font-size:16.5px;margin-bottom:16px;max-width:48ch}

/* territory tiles */
.terr-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.place{position:relative;height:340px;overflow:hidden}
.place image-slot{width:100%;height:100%}
.place .lbl{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:22px;background:linear-gradient(transparent,rgba(20,16,10,.85));pointer-events:none}
.place .lbl .d{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
.place .lbl h3{font-size:24px;color:#fff;margin-top:5px}

/* gallery */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal-grid image-slot{width:100%;height:100%}

/* events — chips, values, capacity, how-cards */
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:840px;margin:0 auto}
.chip{border:1px solid var(--line);background:var(--paper);border-radius:40px;padding:11px 22px;font-size:15px;font-weight:500;display:flex;align-items:center;gap:9px}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--clay);flex:none}
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:18px}
.vgrid .v{border-top:2px solid var(--clay);padding-top:18px}
.vgrid .v h4{font-family:var(--display);font-size:23px;font-weight:600;margin-bottom:8px}
.vgrid .v p{color:var(--ink-soft);font-size:14.5px}
.bg-olive .vgrid .v p{color:rgba(255,255,255,.78)}
.svc .cap{display:inline-block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#e9c98f;font-weight:700;margin:2px 0 10px}
.howgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.howcard{background:var(--paper);border:1px solid var(--line);padding:38px 36px;display:flex;flex-direction:column;color:var(--ink)}
.howcard h3{font-size:26px;margin-bottom:8px;color:var(--ink)}
.howcard .xlist li{color:var(--ink)}
.howcard.feature{background:var(--olive-deep);color:var(--paper);border-color:var(--olive-deep)}
.howcard.feature h3{color:#fff}
.howcard.feature .xlist li{color:var(--paper)}
.howcard .lead{color:var(--ink-soft);font-size:15.5px;margin-bottom:18px}
.howcard.feature .lead{color:rgba(255,255,255,.82)}
.howcard .xlist{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:6px}
.howcard .xlist li{display:flex;gap:12px;align-items:flex-start;font-size:15px}
.howcard .xlist li::before{content:'';flex:none;width:8px;height:8px;border-radius:50%;background:var(--gold);margin-top:8px}
.fmt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.fmt{display:flex;gap:22px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);padding:26px;transition:.3s}
.fmt:hover{transform:translateY(-4px);box-shadow:0 24px 50px -34px rgba(44,38,29,.5)}
.fmt .num{font-family:var(--display);font-size:40px;line-height:.9;color:var(--clay);flex:none;width:48px}
.fmt h3{font-size:23px;margin-bottom:8px}
.fmt p{color:var(--ink-soft);font-size:14.5px}
@media (max-width:760px){.vgrid{grid-template-columns:repeat(2,1fr)}.howgrid,.fmt-grid{grid-template-columns:1fr}}

/* reviews */
.rev-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:880px;margin:0 auto}
.rev-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;background:var(--paper);border:1px solid var(--line);padding:38px 32px;transition:.3s;color:var(--ink)}
.rev-card:hover{transform:translateY(-5px);box-shadow:0 28px 56px -34px rgba(44,38,29,.5);border-color:var(--clay)}
.rev-logo{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:24px;font-weight:600;color:#fff;margin-bottom:4px}
.rev-logo.g{background:#4285F4}
.rev-logo.b{background:#003580}
.rev-score{font-family:var(--display);font-size:46px;line-height:1;font-weight:600;color:var(--ink)}
.rev-score span{font-size:20px;color:var(--ink-soft)}
.rev-stars{color:var(--gold);letter-spacing:3px;font-size:18px}
.rev-plat{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.rev-cta{margin-top:10px;font-size:13.5px;font-weight:600;color:var(--clay);display:inline-flex;gap:7px;align-items:center}
.bg-olive .rev-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.16)}
.bg-olive .rev-card .rev-score,.bg-olive .rev-card{color:#fff}
.bg-olive .rev-score span{color:rgba(255,255,255,.7)}
.bg-olive .rev-plat{color:rgba(255,255,255,.7)}
.bg-olive .rev-cta{color:#e9c98f}
@media (max-width:680px){.rev-cards{grid-template-columns:1fr;gap:18px}}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(20,16,10,.93);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .28s,visibility .28s}
.lb.open{opacity:1;visibility:visible}
.lb .lb-stage{margin:0;display:flex;flex-direction:column;align-items:center;gap:16px;max-width:92vw;max-height:90vh;cursor:zoom-out}
.lb .lb-stage img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:2px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7);background:#241f17}
.lb .lb-cap{font-family:var(--body);font-size:13.5px;letter-spacing:.02em;color:rgba(255,255,255,.82);text-align:center;max-width:70ch}
.lb .lb-close{position:absolute;top:18px;right:24px;width:48px;height:48px;border:none;background:rgba(255,255,255,.08);color:#fff;font-size:30px;line-height:1;border-radius:50%;cursor:pointer;transition:.2s;z-index:2}
.lb .lb-close:hover{background:rgba(255,255,255,.2)}
.lb .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;border:none;background:rgba(255,255,255,.08);color:#fff;font-size:40px;line-height:1;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;z-index:2}
.lb .lb-nav:hover{background:var(--clay)}
.lb .lb-prev{left:28px}
.lb .lb-next{right:28px}
.lb .lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);font-family:var(--body);font-size:12.5px;letter-spacing:.18em;color:rgba(255,255,255,.7)}
@media (max-width:760px){
  .lb .lb-nav{width:46px;height:46px;font-size:30px}
  .lb .lb-prev{left:10px}.lb .lb-next{right:10px}
  .lb .lb-stage img{max-height:74vh}
}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* room detail */
.rimg{display:block;width:100%;height:100%;object-fit:cover}
.rd-spec{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:8px}
.rd-spec .s{background:var(--paper);padding:24px 20px;text-align:center}
.rd-spec .s .ic{font-family:var(--display);font-size:30px;color:var(--clay);line-height:1}
.rd-spec .s .ic svg{width:30px;height:30px;display:block;margin:0 auto;stroke:var(--clay);fill:none}
.rd-spec .s .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}
.rd-spec .s .v{font-size:15px;font-weight:600;margin-top:3px}
.amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 30px;margin-top:6px}
.amen-grid div{display:flex;gap:11px;align-items:center;font-size:15px;padding:9px 0;border-bottom:1px solid var(--line)}
.amen-grid div::before{content:'';flex:none;width:7px;height:7px;border-radius:50%;background:var(--clay)}

/* booking cta block */
.book{position:relative;color:#fff;overflow:hidden}
.book image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.book::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(30,24,16,.9),rgba(30,24,16,.55))}
.book .wrap{position:relative;z-index:2;padding:110px 32px;display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.book h2{font-size:clamp(36px,4.4vw,58px);max-width:13ch}
.book .eyebrow{color:var(--gold)}
.book p{font-size:17px;opacity:.92;margin-top:20px;max-width:44ch}
.infocard{background:rgba(251,246,236,.97);color:var(--ink);padding:40px;border-radius:3px}
.infocard h3{font-size:25px;margin-bottom:20px}
.inforow{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:15px}
.inforow:last-of-type{border-bottom:none}
.card-note{margin-top:18px;padding-top:6px;border-top:1px solid var(--line)}
.card-note .inforow{padding:10px 0;font-size:14px}
.inforow .k{color:var(--ink-soft)}
.inforow .v{font-weight:600;text-align:right}
.infocard .btn{margin-top:24px;width:100%;justify-content:center}

/* contact form */
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .full{grid-column:1/-1}
.field label{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--line);background:var(--paper);font-family:var(--body);font-size:15px;color:var(--ink);border-radius:2px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--clay)}
.field textarea{min-height:130px;resize:vertical}
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.form-status{display:none;padding:14px 16px;border-radius:2px;font-size:14.5px;line-height:1.5}
.form-status.sending{display:block;background:var(--paper);border:1px solid var(--line);color:var(--ink-soft)}
.form-status.ok{display:block;background:#eef3ea;border:1px solid #bcd0ad;color:#3a4631}
.form-status.err,.form-status.warn,.form-status.cfg{display:block;background:#f7ece6;border:1px solid #e0b9a4;color:#9a4a2c}

/* footer */
footer.ft{background:#241f17;color:rgba(255,255,255,.72);padding:80px 0 36px}
footer.ft .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.12)}
footer.ft p{font-size:14px;line-height:1.7}
footer.ft .logo .logo-img{height:74px}
footer.ft .logo .word .nm{color:#f0d6a4}
footer.ft .logo .word .tg{color:rgba(255,255,255,.7)}
footer.ft h4{font-family:var(--body);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:600}
footer.ft ul{list-style:none}
footer.ft ul li{margin-bottom:11px;font-size:14px}
footer.ft ul li a{transition:.2s}
footer.ft ul li a:hover{color:#fff}
footer.ft .bottom{display:flex;justify-content:space-between;padding-top:26px;font-size:12.5px;opacity:.6;flex-wrap:wrap;gap:12px}

/* responsive */
@media (max-width:1080px){
  nav.links{display:none}
  .menu-toggle{display:flex}
}
@media (max-width:1024px){
  .split,.feat,.book .wrap{grid-template-columns:1fr;gap:40px}
  .split.rev .txt,.feat:nth-child(even) .txt{order:0}
  .feat .txt{padding:56px 40px}
  .feat image-slot,.feat .rimg{height:380px}
  .terr-grid,.svc-grid,.room-grid{grid-template-columns:repeat(2,1fr)}
  .facts .row{grid-template-columns:repeat(3,1fr);gap:34px 24px}
  .facts .f:nth-child(3){border-right:none}
  .rd-spec{grid-template-columns:repeat(2,1fr)}
  .amen-grid{grid-template-columns:repeat(2,1fr)}
  footer.ft .top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:760px){
  .wrap{padding:0 22px}
  header.nav,header.nav.scrolled{padding:14px 22px}
  nav.links{display:none}
  .menu-toggle{display:flex}
  .nav-right{gap:12px}
  .nav-right .lang,.nav-right>.btn-clay{display:none}
  .room-grid,.room-grid.cols-2,.terr-grid,.svc-grid,.svc-grid.cols-2,.form{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .g-tall,.g-wide{grid-row:auto;grid-column:auto}
  .rd-spec,.amen-grid{grid-template-columns:repeat(2,1fr)}
  .pad{padding:64px 0}.pad-sm{padding:52px 0}
  .split .rimg,.split image-slot{height:320px}
  .feat .txt{padding:44px 22px}
  .feat .rimg,.feat image-slot{height:300px}
  .howcard{padding:28px 24px}
  .book .wrap{padding:72px 22px}
  .infocard{padding:30px 24px}
  .logo .logo-img{height:46px}
  .logo .word .nm{font-size:24px}
  .sec-head{margin-bottom:42px}
  .svc{min-height:380px}
  .stamp{width:106px;height:106px;left:auto;right:14px;bottom:-22px}
  .stamp .yr{font-size:32px}
  .stamp small{font-size:8.5px;letter-spacing:.1em;max-width:68px;margin-top:4px}
  footer.ft{padding:56px 0 30px}
  footer.ft .top{grid-template-columns:1fr;gap:34px;padding-bottom:36px}
  footer.ft .bottom{flex-direction:column;align-items:flex-start;gap:14px}
}
@media (max-width:560px){
  .facts .row{grid-template-columns:repeat(2,1fr);gap:30px 18px}
  .facts .f{border-right:none}
  .facts .f .n{font-size:40px}
  .vgrid{grid-template-columns:repeat(2,1fr);gap:22px}
  .rd-spec{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:1fr;grid-auto-rows:230px}
  .phero h1{font-size:clamp(34px,9vw,46px)}
  .hero h1{font-size:clamp(38px,11vw,56px)}
}

/* ===========================================================
   REFINEMENT LAYER — elegance & micro-interactions
   =========================================================== */
/* typography polish */
body{text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern" 1,"liga" 1}
h1,h2,h3,h4{font-feature-settings:"kern" 1,"liga" 1,"dlig" 1}
::selection{background:var(--clay);color:#fff}
.sec-head h2{letter-spacing:-.015em}

/* legibility of the logo & nav over bright photos (transparent nav) */
header.nav.transparent:not(.scrolled) .logo .word .nm{text-shadow:0 1px 18px rgba(20,16,10,.55),0 1px 3px rgba(20,16,10,.4)}
header.nav.transparent:not(.scrolled) .logo .word .tg{text-shadow:0 1px 10px rgba(20,16,10,.5)}
header.nav.transparent:not(.scrolled) nav.links a{text-shadow:0 1px 12px rgba(20,16,10,.45)}
.hero .eyebrow,.phero .crumb{text-shadow:0 1px 1px rgba(15,12,8,.9),0 1px 4px rgba(15,12,8,.7),0 2px 16px rgba(15,12,8,.6)}
.svc .c .eyebrow,.svc .cap,.place .lbl .d,.book .eyebrow{text-shadow:0 1px 1px rgba(15,12,8,.9),0 1px 3px rgba(15,12,8,.7),0 2px 14px rgba(15,12,8,.55)}
.hero h1{text-shadow:0 3px 28px rgba(20,16,10,.55),0 1px 6px rgba(20,16,10,.4)}
.hero h1 em,.phero h1 em{text-shadow:0 2px 20px rgba(20,16,10,.75),0 1px 5px rgba(20,16,10,.6)}
.hero p.sub{text-shadow:0 1px 14px rgba(20,16,10,.55)}

/* elegant centered kicker with flanking hairlines */
.sec-head .eyebrow{display:inline-flex;align-items:center;gap:14px}
.sec-head .eyebrow::before,.sec-head .eyebrow::after{content:'';width:30px;height:1px;background:currentColor;opacity:.5}

/* refined buttons */
.btn{letter-spacing:.06em;border-radius:3px}
.btn-clay{box-shadow:0 12px 26px -16px rgba(164,84,47,.95)}
.btn-clay:hover{box-shadow:0 16px 30px -14px rgba(164,84,47,.9);transform:translateY(-2px)}
.btn-dark:hover,.btn-ghost:hover{transform:translateY(-2px)}

/* soft image zoom on hover for cards & tiles (containers already clip) */
.svc img,.svc image-slot,.place img,.place image-slot,.room img,.room image-slot{transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.svc:hover img,.svc:hover image-slot,.place:hover img,.place:hover image-slot,.room:hover img,.room:hover image-slot{transform:scale(1.06)}

/* gallery: gentle warmth + clip-safe lift on hover */
.gal-grid img{transition:filter .45s,box-shadow .45s,transform .45s;will-change:filter}
.gal-grid img:hover{filter:saturate(1.06) brightness(1.04);box-shadow:0 22px 44px -26px rgba(44,38,29,.6)}

/* editorial images get a refined frame + depth */
.split .rimg,.feat .rimg{box-shadow:0 30px 60px -40px rgba(44,38,29,.55)}

/* dividers between stacked sections of same bg add quiet rhythm */
.facts .f .n{letter-spacing:-.01em}

/* focus-visible for accessibility/polish */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--clay);outline-offset:3px;border-radius:2px}

/* room amenity chips: subtle hover */
.amen span{transition:.2s}
.room:hover .amen span{border-color:#d8c8ab}

/* nav link weight refinement */
nav.links a{font-weight:500}
@media (prefers-reduced-motion:reduce){
  .svc:hover img,.place:hover img,.room:hover img,.svc:hover image-slot,.place:hover image-slot,.room:hover image-slot{transform:none}
}

/* FAQ accordion (native <details>) */
.faq-section{background:var(--cream)}
.faq-section h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:28px}
.faq-list{max-width:820px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 40px 20px 0;position:relative;font-family:var(--body);font-weight:600;font-size:clamp(16px,1.5vw,18px);color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:24px;font-weight:400;color:var(--clay)}
.faq-item[open] summary::after{content:'\2013'}
.faq-item summary:hover{color:var(--clay)}
.faq-item:not([open]) .faq-a{display:none}
.faq-a{padding:0 40px 22px 0}
.faq-a p{color:var(--ink-soft);line-height:1.65;max-width:64ch}

/* ---- consent (cookie banner + preferences) ---- */
.cc-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;background:var(--paper);border:1px solid var(--line);border-radius:6px;box-shadow:0 24px 60px -24px rgba(44,38,29,.6);padding:20px 22px;display:flex;gap:22px;align-items:center;flex-wrap:wrap;max-width:1040px;margin:0 auto}
.cc-banner-text{flex:1 1 360px;min-width:260px}
.cc-banner-text strong{font-family:var(--display);font-size:19px;font-weight:600;display:block;margin-bottom:5px}
.cc-banner-text p{font-size:13.5px;line-height:1.6;color:var(--ink-soft);margin:0}
.cc-banner-text a{color:var(--clay);text-decoration:underline}
.cc-banner-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cc-btn{font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.03em;padding:11px 20px;border-radius:2px;cursor:pointer;border:1px solid var(--ink);background:transparent;color:var(--ink);transition:.22s;white-space:nowrap}
.cc-btn-ghost:hover{background:var(--ink);color:var(--paper)}
.cc-btn-primary{background:var(--clay);border-color:var(--clay);color:#fff}
.cc-btn-primary:hover{background:var(--clay-deep);border-color:var(--clay-deep)}
.cc-modal-wrap{position:fixed;inset:0;z-index:10000;background:rgba(28,23,16,.55);display:flex;align-items:center;justify-content:center;padding:20px}
.cc-modal{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:6px;max-width:560px;width:100%;max-height:88vh;overflow:auto;padding:34px 32px 28px}
.cc-modal h2{font-size:26px;margin-bottom:8px}
.cc-modal-intro{font-size:13.5px;color:var(--ink-soft);line-height:1.6;margin-bottom:18px}
.cc-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:30px;line-height:1;color:var(--ink-soft);cursor:pointer}
.cc-row{border-top:1px solid var(--line);padding:16px 0}
.cc-row-h{display:flex;align-items:center;gap:12px}
.cc-row-title{font-weight:600;font-size:15px}
.cc-row-state{margin-left:auto;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--clay)}
.cc-row-desc{font-size:13px;color:var(--ink-soft);line-height:1.55;margin:8px 0 0 56px}
.cc-switch{position:relative;display:inline-block;width:44px;height:24px;flex:0 0 auto}
.cc-switch input{opacity:0;width:0;height:0;position:absolute}
.cc-slider{position:absolute;inset:0;background:#cbbfa8;border-radius:24px;transition:.22s;cursor:pointer}
.cc-slider:before{content:'';position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.22s}
.cc-switch input:checked+.cc-slider{background:var(--clay)}
.cc-switch input:checked+.cc-slider:before{transform:translateX(20px)}
.cc-switch input:disabled+.cc-slider{opacity:.6;cursor:not-allowed}
.cc-modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:22px}
.cc-mapbox{display:flex;align-items:center;justify-content:center;text-align:center;background:var(--cream);border:1px solid var(--line);border-radius:3px;padding:24px}
.cc-mapbox-in{max-width:34ch}
.cc-mapbox-in strong{font-family:var(--display);font-size:18px;display:block;margin-bottom:6px}
.cc-mapbox-in p{font-size:13px;color:var(--ink-soft);line-height:1.55;margin-bottom:14px}
.legal-doc{max-width:760px;margin:0 auto}
.legal-doc h2{font-size:24px;margin:34px 0 12px}
.legal-doc p,.legal-doc li{color:var(--ink-soft);line-height:1.7;font-size:15.5px}
.legal-doc p{margin-bottom:14px}
.legal-doc ul{margin:0 0 16px 0;padding-left:20px}
.legal-doc li{margin-bottom:8px}
.legal-doc a{color:var(--clay);text-decoration:underline}
.legal-doc strong{color:var(--ink)}
.legal-doc code{font-size:13px;background:var(--cream);padding:1px 5px;border-radius:3px}
.legal-upd{font-size:13px!important;opacity:.8}
.cc-consent-lbl{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--ink-soft);line-height:1.5;cursor:pointer}
.cc-consent-lbl input{margin:2px 0 0;flex:0 0 auto;width:18px;height:18px;min-width:0;padding:0;accent-color:var(--clay)}
.cc-consent-lbl a{color:var(--clay);text-decoration:underline}
.ft-legal{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.ft-legal a,.ft-cookie-btn{font-size:12.5px;color:inherit;opacity:.8;background:none;border:none;padding:0;cursor:pointer;font-family:var(--body);text-decoration:underline}
.ft-legal a:hover,.ft-cookie-btn:hover{opacity:1;color:var(--clay)}
@media(max-width:640px){.cc-banner{padding:16px}.cc-banner-actions{width:100%}.cc-banner-actions .cc-btn{flex:1 1 auto}}
