/* ============ SAKKAN — Desktop visual system ============ */
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --serif:'Newsreader',Georgia,serif; --serif-w:400;
  --sans:'Avenir Next','Avenir','Mulish',system-ui,sans-serif;
  --bg:#f6f5f2; --ink:#16130e; --line:rgba(22,19,14,.13);
  --accent:var(--ink); --michelin:#b4232f;
  --nav-h:78px; --nav-h-solid:64px;
  --mar:clamp(28px,5vw,104px);
  --maxw:1680px;
  --ink-soft:color-mix(in oklab, var(--ink) 82%, transparent);
  --ink-faint:color-mix(in oklab, var(--ink) 60%, transparent);
}
[data-serif="humanist"]{--serif:'Cormorant Garamond',Georgia,serif;--serif-w:500;}
[data-serif="editorial"]{--serif:'Bodoni Moda',Georgia,serif;--serif-w:500;}
[data-serif="modern"]{--serif:'Newsreader',Georgia,serif;--serif-w:400;}
[data-tone="cool"]{--bg:#f6f5f2;--ink:#16130e;--line:rgba(22,19,14,.13);}
[data-tone="ivory"]{--bg:#f1ebdf;--ink:#191510;--line:rgba(25,21,16,.14);}
[data-tone="warm"]{--bg:#ece3d2;--ink:#1d1810;--line:rgba(29,24,16,.15);}
[data-accent="none"]{--accent:var(--ink);}
[data-accent="brass"]{--accent:#9a7b46;}
[data-accent="red"]{--accent:#8d2733;}

html{scroll-behavior:smooth;}
body{background:var(--bg);font-family:var(--sans);color:var(--ink);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
::selection{background:var(--ink);color:var(--bg);}
img{display:block;}
button{font-family:inherit;}
a{color:inherit;}

/* ---- type primitives (three Avenir registers + serif for big statements) ---- */
.d-label{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ink-soft);}
.d-display{font-family:var(--serif);font-weight:var(--serif-w);letter-spacing:-.012em;text-wrap:balance;}
.d-sec-title{font-family:var(--sans);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  font-size:clamp(13px,0.95vw,16px);line-height:1.2;color:var(--ink);}
.d-sec-title--light{color:#f7f4ee;text-shadow:0 2px 22px rgba(0,0,0,.4);}
.d-body{font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.7;color:var(--ink);}
.d-muted{color:var(--ink-soft);}

/* ---- circle CTA ---- */
.d-circle{position:relative;width:132px;height:132px;border-radius:50%;border:1px solid var(--ink);
  background:none;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  transition:transform .6s cubic-bezier(.2,.6,.2,1),background .5s ease,color .5s ease;flex:none;text-decoration:none;}
.d-circle-in{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  line-height:1.55;text-align:center;}
.d-circle-arrow{display:block;margin-top:6px;font-size:16px;letter-spacing:0;line-height:1;}
.d-circle-ring{position:absolute;inset:-1px;border-radius:50%;border:1px solid currentColor;opacity:0;transform:scale(.84);
  transition:opacity .6s ease,transform .85s cubic-bezier(.2,.6,.2,1);pointer-events:none;}
.d-circle:hover{transform:scale(1.045);}
.d-circle:hover .d-circle-ring{opacity:.4;transform:scale(1.16);}
.d-circle--light{border-color:rgba(247,244,238,.8);color:#f7f4ee;}
.d-circle--fill:hover{background:var(--ink);color:var(--bg);}
.d-circle--light.d-circle--fill:hover{background:#f7f4ee;color:#16130e;}

/* ---- buttons / links ---- */
.d-btn{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:15px 30px;border:1px solid currentColor;background:none;color:inherit;cursor:pointer;
  transition:background .5s ease,color .5s ease;text-decoration:none;display:inline-block;}
.d-btn--ink{border-color:var(--ink);color:var(--ink);}
.d-btn--ink:hover{background:var(--ink);color:var(--bg);}
.d-btn--fill{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.d-btn--fill:hover{background:transparent;color:var(--ink);}
.d-btn--fill:disabled{opacity:.32;cursor:not-allowed;}
.d-ulink{position:relative;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink);background:none;border:none;cursor:pointer;padding:4px 0;text-decoration:none;display:inline-block;}
.d-ulink::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;
  transition:right .5s cubic-bezier(.2,.6,.2,1);}
.d-ulink:hover::after{right:0;}
.d-ulink--light{color:#f7f4ee;}
.d-ulink--red{color:var(--michelin);}

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

/* ---- SImg ---- */
.d-img{overflow:hidden;position:relative;background:#e7e2d8;}
.d-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.d-img--reveal img{transform:scale(1.06);opacity:.001;transition:transform 1.5s cubic-bezier(.2,.6,.2,1),opacity 1.2s ease;}
.d-img--reveal.is-in img{transform:scale(1);opacity:1;}

/* =================== NAV =================== */
.d-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:60;
  display:flex;align-items:center;justify-content:space-between;column-gap:32px;
  padding:0 var(--mar);color:#f7f4ee;
  transition:height .5s ease,background .5s ease,color .5s ease,border-color .5s ease,opacity .4s ease;
  border-bottom:1px solid transparent;}
.d-nav.is-solid{height:var(--nav-h-solid);background:color-mix(in oklab,var(--bg) 90%,transparent);
  backdrop-filter:blur(16px) saturate(1.1);color:var(--ink);border-bottom-color:var(--line);}
.d-nav-side{display:flex;align-items:center;gap:clamp(14px,1.6vw,30px);min-width:0;}
.d-nav-side--r{justify-content:flex-end;}
.d-nav-right{display:flex;align-items:center;gap:clamp(16px,1.8vw,30px);}
.d-nav-inline{display:none;}
.d-nav-burger{display:flex;flex-direction:column;gap:6px;width:30px;height:24px;align-items:flex-start;justify-content:center;
  background:none;border:none;cursor:pointer;padding:0;color:inherit;}
.d-nav-burger span{display:block;height:1.5px;width:26px;background:currentColor;transition:width .4s ease;}
.d-nav-burger span:nth-child(2){width:18px;}
.d-nav-burger:hover span{width:26px;}
.d-nav.is-hidden{opacity:0;pointer-events:none;}
.d-nav-link{position:relative;font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:.13em;
  text-transform:uppercase;color:inherit;background:none;border:none;cursor:pointer;padding:6px 0;white-space:nowrap;opacity:.92;}
.d-nav-link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;
  transition:right .45s cubic-bezier(.2,.6,.2,1);}
.d-nav-link:hover{opacity:1;}
.d-nav-link:hover::after,.d-nav-link.is-active::after{right:0;}
.d-nav-logo{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:inherit;padding:6px;}
.d-nav-book{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:inherit;border:1px solid currentColor;background:none;cursor:pointer;padding:11px 20px;transition:background .5s,color .5s;}
.d-nav.is-solid .d-nav-book:hover{background:var(--ink);color:var(--bg);}
.d-nav:not(.is-solid) .d-nav-book:hover{background:#f7f4ee;color:#16130e;}
.d-nav-key{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--michelin);cursor:pointer;background:none;border:none;}
.d-nav-key svg{height:15px;width:auto;}
.d-keyicon{height:16px;width:auto;flex:none;}

/* ---- full-screen menu overlay ---- */
.d-menu{position:fixed;inset:0;z-index:80;background:var(--bg);display:flex;flex-direction:column;
  padding:0 var(--mar);transition:opacity .55s ease;overflow-y:auto;}
.d-menu-top{height:var(--nav-h);flex:none;display:flex;align-items:center;justify-content:space-between;}
.d-menu-logo{background:none;border:none;cursor:pointer;color:var(--ink);padding:6px;display:flex;align-items:center;}
.d-menu-close{position:relative;width:34px;height:34px;background:none;border:none;cursor:pointer;color:var(--ink);}
.d-menu-close span{position:absolute;left:6px;top:16px;width:22px;height:1.5px;background:currentColor;}
.d-menu-close span:first-child{transform:rotate(45deg);}
.d-menu-close span:last-child{transform:rotate(-45deg);}
.d-menu-close:hover span{background:var(--michelin);}
.d-menu-main{flex:1;display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(40px,6vw,120px);
  align-items:center;padding:clamp(24px,4vw,64px) 0 clamp(40px,6vw,80px);}
.d-menu-nav{display:flex;flex-direction:column;}
.d-menu-link{display:flex;align-items:baseline;gap:clamp(16px,2vw,34px);background:none;border:none;cursor:pointer;
  text-align:left;padding:clamp(12px,1.4vw,20px) 0;border-bottom:1px solid var(--line);color:var(--ink);}
.d-menu-link-i{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.1em;color:var(--ink-faint);width:24px;flex:none;}
.d-menu-link-t{font-family:var(--sans);font-weight:500;font-size:clamp(24px,2.6vw,40px);line-height:1;letter-spacing:-.01em;
  flex:1;transition:transform .5s cubic-bezier(.2,.6,.2,1),color .4s ease;}
.d-menu-link-a{font-family:var(--sans);font-size:clamp(16px,1.6vw,22px);color:var(--ink-faint);opacity:0;
  transform:translateX(-12px);transition:opacity .5s ease,transform .5s cubic-bezier(.2,.6,.2,1);}
.d-menu-link:hover .d-menu-link-t{transform:translateX(14px);}
.d-menu-link:hover .d-menu-link-a{opacity:1;transform:translateX(0);}
.d-menu-link:hover .d-menu-link-i{color:var(--michelin);}
.d-menu-aside{display:flex;flex-direction:column;gap:clamp(26px,3vw,40px);max-width:340px;}
.d-menu-block{display:flex;flex-direction:column;gap:10px;}
.d-menu-block-h{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);}
.d-menu-addr{font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.7;color:var(--ink);}
.d-menu-line{font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.7;color:var(--ink);text-decoration:none;width:fit-content;position:relative;}
.d-menu-line::after{content:"";position:absolute;left:0;right:100%;bottom:1px;height:1px;background:currentColor;transition:right .4s ease;}
.d-menu-line:hover::after{right:0;}
.d-menu-mkey{display:flex;align-items:center;gap:9px;font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--michelin);}
.d-menu-mkey b{font-weight:600;}
.d-menu-mkey .d-keyicon{height:18px;}
.d-menu-book{margin-top:4px;width:fit-content;}

/* =================== HERO =================== */
.d-hero{position:relative;height:100vh;min-height:640px;overflow:hidden;background:#15110b;}
.d-hero-stack{position:absolute;inset:0;}
.d-hero-stack img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.02);transition:opacity 1.65s ease;}
.d-hero-img.is-visible{opacity:1;transform:scale(1.04);}
.d-hero-img.is-active{opacity:1;animation:dkenburns 3.45s ease-out both;}
.d-hero-veil{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(8,6,4,.34) 0%,rgba(8,6,4,0) 26%,rgba(8,6,4,0) 58%,rgba(8,6,4,.62) 100%);}
.d-hero-zone{position:absolute;top:var(--nav-h);bottom:170px;background:none;border:none;cursor:pointer;z-index:3;}
.d-hero-zone--l{left:0;width:30%;}
.d-hero-zone--r{right:0;width:30%;}
.d-hero-copy{position:absolute;left:var(--mar);bottom:clamp(64px,10vh,128px);right:var(--mar);z-index:4;}
.d-hero-title{font-family:var(--serif);font-weight:var(--serif-w);color:#f7f4ee;
  font-size:clamp(50px,6.6vw,108px);line-height:.98;letter-spacing:-.015em;text-shadow:0 2px 40px rgba(0,0,0,.32);}
.d-hero-cta{position:absolute;right:var(--mar);bottom:clamp(72px,11vh,140px);z-index:5;}
.d-hero-cta .d-circle{width:clamp(120px,11vw,158px);height:clamp(120px,11vw,158px);}
.d-hero-dots{position:absolute;left:50%;transform:translateX(-50%);bottom:46px;display:flex;gap:9px;z-index:5;}
.d-hero-dot{width:8px;height:8px;border-radius:50%;border:none;cursor:pointer;background:rgba(247,244,238,.45);
  transition:all .45s;padding:0;}
.d-hero-dot.is-on{background:#f7f4ee;width:26px;border-radius:4px;}
.d-hero-scroll{position:absolute;left:var(--mar);bottom:46px;z-index:5;display:flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(247,244,238,.7);}
.d-hero-scroll i{display:block;width:34px;height:1px;background:rgba(247,244,238,.5);position:relative;overflow:hidden;}
.d-hero-scroll i::after{content:"";position:absolute;left:-34px;top:0;width:34px;height:1px;background:#f7f4ee;animation:dscroll 2.4s cubic-bezier(.6,0,.2,1) infinite;}
@keyframes dscroll{0%{left:-34px}55%{left:34px}100%{left:34px}}
@keyframes dkenburns{0%{transform:scale(1.02) translate3d(0,0,0);}100%{transform:scale(1.085) translate3d(0,-1.25%,0);}}

/* =================== layout shell =================== */
.d-wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--mar);padding-right:var(--mar);}
.d-section{max-width:var(--maxw);margin:0 auto;}

/* =================== INTRO =================== */
.d-intro{padding-top:clamp(90px,11vw,180px);padding-bottom:clamp(70px,8vw,130px);
  display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(40px,6vw,110px);align-items:end;}
.d-intro-h{font-size:clamp(32px,3.3vw,56px);line-height:1.06;color:var(--ink);margin-top:24px;max-width:16ch;}
.d-intro-r{display:flex;flex-direction:column;gap:34px;padding-bottom:10px;}
.d-lede{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1vw,17px);line-height:1.6;color:var(--ink-soft);max-width:36ch;}
.d-stay-line{display:flex;flex-direction:column;gap:12px;}
.d-stay-line p{font-family:var(--sans);font-weight:500;font-size:16px;color:var(--ink);}

/* michelin key accordion */
.d-mkey{align-self:start;}
.d-mkey-trigger{display:inline-flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;white-space:nowrap;}
.d-mkey-place{font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);}
.d-mkey-cred{position:relative;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--michelin);padding-bottom:3px;}
.d-mkey-cred::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--michelin);transition:right .5s cubic-bezier(.2,.6,.2,1);}
.d-mkey-trigger:hover .d-mkey-cred::after{right:0;}
.d-mkey-plus{font-size:16px;line-height:1;color:var(--ink-faint);}
.d-acc{overflow:hidden;height:0;transition:height .6s cubic-bezier(.4,0,.1,1);}
.d-mkey-panel{padding-top:18px;display:flex;flex-direction:column;align-items:flex-start;gap:13px;max-width:42ch;}
.d-mkey-about{font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.62;color:var(--ink-soft);}
.d-mkey-line{font-family:var(--sans);font-weight:500;font-size:16.5px;line-height:1.45;color:var(--ink);text-wrap:balance;}

/* =================== BRIDGE =================== */
.d-bridge{position:relative;width:100%;height:clamp(280px,40vh,440px);overflow:hidden;background:#e7e2d8;margin-top:8px;}
.d-bridge img{position:absolute;inset:0;width:100%;height:120%;object-fit:cover;top:-10%;}

/* =================== ROOM MOODS =================== */
.d-moods{padding-top:clamp(56px,6vw,96px);padding-bottom:clamp(80px,9vw,140px);}
.d-moods-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;margin-bottom:clamp(44px,5vw,72px);}
.d-moods-teaser{font-family:var(--sans);font-weight:500;font-size:clamp(17px,1.25vw,21px);letter-spacing:.01em;color:var(--ink);}
.d-moods-sub{font-family:var(--sans);font-weight:400;font-size:14px;color:var(--ink-soft);}
.d-mood-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,1.8vw,30px);align-items:stretch;}
.d-mood-grid>*{display:flex;}
.d-mood{display:flex;flex-direction:column;background:none;border:none;cursor:pointer;text-align:left;padding:0;color:var(--ink);width:100%;height:100%;}
.d-mood-fig{width:100%;aspect-ratio:4/5;overflow:hidden;}
.d-mood-fig img{transition:transform 1.1s cubic-bezier(.2,.6,.2,1);}
.d-mood:hover .d-mood-fig img{transform:scale(1.05);}
.d-mood-body{padding-top:22px;display:flex;flex-direction:column;gap:11px;flex:1;}
.d-mood-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;}
.d-mood-from{font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.01em;color:var(--ink);white-space:nowrap;}
.d-mood-title{font-family:var(--sans);font-weight:600;font-size:clamp(17px,1.2vw,20px);line-height:1.12;letter-spacing:-.005em;}
.d-mood-desc{font-family:var(--sans);font-weight:400;font-size:13.5px;line-height:1.6;color:var(--ink-soft);}
.d-mood-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 0;border-bottom:1px solid var(--line);margin-top:auto;}
.d-mood-types{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);}
.d-mood-explore{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:inline-flex;gap:7px;}
.d-mood-explore span{transition:transform .45s cubic-bezier(.2,.6,.2,1);}
.d-mood:hover .d-mood-explore span{transform:translateX(5px);}
.d-bookdirect{display:flex;flex-direction:column;align-items:center;text-align:center;gap:11px;cursor:pointer;
  margin-top:clamp(48px,5vw,86px);padding:clamp(30px,3vw,46px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.d-bd-label{font-family:var(--sans);font-weight:500;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--michelin);}
.d-bd-line{font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.2vw,19px);line-height:1.45;color:var(--ink-soft);max-width:40ch;text-wrap:balance;}
.d-bd-cta{font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:3px;margin-top:3px;transition:opacity .3s;}
.d-bookdirect:hover .d-bd-cta{opacity:.6;}

/* =================== SPLIT lifestyle spread =================== */
.d-split{display:grid;grid-template-columns:1fr 1fr;min-height:clamp(560px,72vh,860px);}
.d-split--reverse .d-split-media{order:2;}
.d-split-media{position:relative;overflow:hidden;background:#e7e2d8;}
.d-split-media img{transition:transform 1.4s cubic-bezier(.2,.6,.2,1);}
.d-split:hover .d-split-media img{transform:scale(1.04);}
.d-split-body{display:flex;flex-direction:column;justify-content:center;gap:26px;padding:clamp(48px,6vw,120px);}
.d-split-body--center{align-items:flex-start;}
.d-split-text{font-family:var(--sans);font-weight:400;font-size:clamp(18px,1.4vw,23px);line-height:1.38;color:var(--ink);max-width:22ch;text-wrap:balance;}
.d-split-cta{position:absolute;z-index:2;}
.d-split-cta--br{right:clamp(24px,2.5vw,46px);bottom:clamp(24px,2.5vw,46px);}
.d-split-cta--bl{left:clamp(24px,2.5vw,46px);bottom:clamp(24px,2.5vw,46px);}

/* boutique — centered contained 4:3 image with white text overlay */
.d-boutique{padding:clamp(60px,7vw,120px) var(--mar);display:flex;justify-content:center;}
.d-boutique-card{position:relative;width:100%;max-width:1180px;aspect-ratio:4/3;overflow:hidden;background:#e7e2d8;}
.d-boutique-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.14),rgba(8,6,4,0) 38%,rgba(8,6,4,.66));}
.d-boutique-card .d-feature-copy{left:clamp(30px,3.5vw,56px);right:clamp(30px,3.5vw,56px);bottom:clamp(34px,3.5vw,56px);}
.d-boutique-card:hover .d-feature-cta::after{right:0;}
.d-boutique-cta{position:absolute;right:clamp(30px,3.5vw,60px);bottom:clamp(34px,3.5vw,60px);z-index:3;}
.d-boutique-cta .d-circle-ring{animation:bpulse 2.8s cubic-bezier(.4,0,.3,1) infinite;}
@keyframes bpulse{0%{opacity:.5;transform:scale(1);}70%{opacity:0;transform:scale(1.28);}100%{opacity:0;transform:scale(1.28);}}
@media (prefers-reduced-motion:reduce){.d-boutique-cta .d-circle-ring{animation:none;}}

/* =================== IMMERSIVE full-bleed =================== */
/* unified "more than rooms" feature bands (rooftop / spa / lobby) */
.d-feature{position:relative;width:100%;height:clamp(440px,62vh,720px);overflow:hidden;background:#15110b;margin-bottom:10px;}
.d-feature img{position:absolute;inset:0;width:100%;height:150%;object-fit:cover;top:-25%;will-change:transform;}
.d-feature-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.12),rgba(8,6,4,0) 40%,rgba(8,6,4,.66));}
.d-feature-copy{position:absolute;left:var(--mar);right:var(--mar);bottom:clamp(40px,5vw,72px);display:flex;flex-direction:column;align-items:flex-start;gap:13px;}
.d-feature-sub{font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.3vw,21px);line-height:1.4;color:#f3efe6;text-shadow:0 1px 16px rgba(0,0,0,.5);max-width:34ch;}
.d-feature-cta{font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#f7f4ee;-webkit-text-fill-color:#f7f4ee;text-shadow:0 1px 12px rgba(0,0,0,.5);position:relative;padding-bottom:3px;cursor:pointer;}
.d-feature-cta::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:#f7f4ee;transition:right .5s cubic-bezier(.2,.6,.2,1);}
.d-feature:hover .d-feature-cta::after{right:0;}

/* =================== IMMERSIVE full-bleed =================== */
.d-immersive{position:relative;width:100%;height:clamp(600px,86vh,960px);overflow:hidden;background:#15110b;
  margin:clamp(72px,9vw,150px) 0;}
.d-immersive img{position:absolute;inset:0;width:100%;height:118%;object-fit:cover;top:-9%;}
.d-immersive-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.36),rgba(8,6,4,.08) 42%,rgba(8,6,4,.6));}
.d-immersive-copy{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  gap:22px;padding:0 var(--mar) clamp(64px,9vh,128px);}
.d-immersive-copy--center{align-items:center;justify-content:center;text-align:center;padding-bottom:0;}
.d-immersive-text{font-family:var(--sans);font-weight:400;color:#f7f4ee;font-size:clamp(20px,1.8vw,30px);
  line-height:1.32;text-wrap:balance;max-width:22ch;text-shadow:0 2px 28px rgba(0,0,0,.34);}
.d-immersive-cta{position:absolute;right:var(--mar);top:50%;transform:translateY(-50%);z-index:3;}
.d-immersive-cta--left{right:auto;left:var(--mar);}
/* lobby = mirror of spa: copy aligned right */
.d-immersive-copy--right{align-items:flex-end;text-align:right;}
.d-immersive-copy--right .d-immersive-text{margin-left:auto;}

/* lobby contained feature (legacy, unused) */
.d-lobby{padding:0 var(--mar) clamp(60px,7vw,120px);display:flex;justify-content:center;}
.d-lobby-fig{position:relative;width:100%;max-width:1180px;aspect-ratio:16/9;overflow:hidden;background:#15110b;}
.d-lobby-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.42),rgba(8,6,4,.18) 45%,rgba(8,6,4,.5));}
.d-lobby-copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:20px;padding:0 32px;}
.d-lobby-text{font-family:var(--sans);font-weight:400;font-size:clamp(19px,1.6vw,26px);line-height:1.34;color:#f7f4ee;max-width:24ch;text-wrap:balance;text-shadow:0 2px 20px rgba(0,0,0,.4);}

/* boutique split sub */
.d-split-sub{font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.6;color:var(--ink-soft);max-width:30ch;}

/* =================== HOUSE gallery rail =================== */
.d-house{padding:clamp(80px,9vw,150px) 0 clamp(70px,8vw,130px);}
.d-house-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;margin-bottom:clamp(40px,4.5vw,68px);padding:0 var(--mar);}
.d-house-text{font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.2vw,19px);line-height:1.45;color:var(--ink);max-width:32ch;text-wrap:balance;}
.d-rail{display:flex;gap:clamp(14px,1.4vw,24px);overflow-x:auto;padding:0 var(--mar);scroll-snap-type:x proximity;
  cursor:grab;scrollbar-width:none;}
.d-rail::-webkit-scrollbar{display:none;}
.d-rail.is-drag{cursor:grabbing;scroll-snap-type:none;}
.d-rail-cell{flex:0 0 clamp(280px,23vw,400px);aspect-ratio:3/4;overflow:hidden;scroll-snap-align:start;background:#e7e2d8;}
.d-rail-cell img{transition:transform 1s cubic-bezier(.2,.6,.2,1);}
.d-rail-cell:hover img{transform:scale(1.04);}
.d-rail-prog{margin:clamp(28px,3vw,44px) var(--mar) 0;height:1px;background:var(--line);position:relative;}
.d-rail-prog i{position:absolute;left:0;top:-0.5px;height:2px;background:var(--ink);transition:left .15s linear,width .15s linear;}

/* =================== NEIGHBOURHOOD / BEYOND =================== */
.d-centered-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;}
.d-centered-h{font-family:var(--sans);font-weight:400;font-size:clamp(21px,1.9vw,31px);line-height:1.22;letter-spacing:-.005em;color:var(--ink);max-width:24ch;text-wrap:balance;}
.d-centered-sub{font-family:var(--sans);font-weight:400;font-size:clamp(14px,1vw,16px);line-height:1.6;color:var(--ink-soft);max-width:48ch;text-wrap:balance;}
.d-hood{padding:clamp(80px,9vw,140px) 0 0;}
.d-hood-head{padding:0 var(--mar);margin-bottom:clamp(40px,4.5vw,64px);}
.d-band{position:relative;width:100%;height:clamp(360px,54vh,640px);overflow:hidden;background:#e7e2d8;}
.d-band img{position:absolute;inset:0;width:100%;height:122%;object-fit:cover;top:-11%;}
.d-beyond{padding:clamp(80px,9vw,140px) 0 clamp(90px,10vw,150px);}
.d-beyond-head{padding:0 var(--mar);margin-bottom:clamp(40px,4.5vw,64px);}
.d-beyond-band{height:clamp(380px,56vh,660px);}
.d-beyond-note{font-family:var(--sans);font-weight:400;font-size:15.5px;line-height:1.66;color:var(--ink-soft);
  text-align:center;max-width:52ch;margin:clamp(36px,4vw,60px) auto 0;padding:0 var(--mar);text-wrap:pretty;}
.d-beyond-excursion{margin-top:clamp(40px,4.5vw,72px);}

/* =================== CLOSING CTA =================== */
.d-cta{position:relative;width:100%;height:clamp(620px,90vh,1000px);overflow:hidden;background:#15110b;}
.d-cta img{position:absolute;inset:0;width:100%;height:116%;object-fit:cover;top:-8%;}
.d-cta-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.4),rgba(8,6,4,.16) 45%,rgba(8,6,4,.66));}
.d-cta-copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:30px;padding:0 var(--mar);}
.d-cta-title{font-family:var(--serif);font-weight:var(--serif-w);color:#f7f4ee;font-size:clamp(38px,4.4vw,72px);line-height:1.02;letter-spacing:-.014em;text-shadow:0 2px 30px rgba(0,0,0,.34);max-width:18ch;}
.d-cta-fine{font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.6;color:rgba(247,244,238,.74);max-width:48ch;}

/* =================== FOOTER =================== */
.d-footer{background:#14110c;color:#f3efe6;padding:clamp(70px,8vw,120px) var(--mar) 48px;}
.d-foot-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:clamp(40px,5vw,90px);align-items:start;}
.d-foot-mark{color:#f3efe6;margin-bottom:28px;}
.d-foot-addr{font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.8;color:rgba(243,239,230,.62);}
.d-foot-col-h{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(243,239,230,.5);margin-bottom:22px;}
.d-foot-links{display:flex;flex-direction:column;gap:14px;align-items:flex-start;}
.d-foot-links button{background:none;border:none;cursor:pointer;text-align:left;color:#f3efe6;font-family:var(--sans);font-weight:400;font-size:15px;opacity:.85;transition:opacity .3s;padding:0;}
.d-foot-links button:hover{opacity:1;}
.d-foot-book{margin-top:6px;}
.d-foot-bottom{max-width:var(--maxw);margin:clamp(50px,6vw,84px) auto 0;padding-top:30px;border-top:1px solid rgba(243,239,230,.14);
  display:flex;align-items:center;justify-content:space-between;gap:20px;}
.d-foot-legal{display:flex;gap:12px;align-items:center;font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(243,239,230,.45);}
.d-foot-legal button,.d-foot-legal a{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(243,239,230,.45);transition:color .3s;padding:0;text-decoration:none;}
.d-foot-legal button:hover,.d-foot-legal a:hover{color:rgba(243,239,230,.9);}
.d-foot-social{font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(243,239,230,.6);text-decoration:none;}

.d-logo{line-height:0;color:inherit;}
.d-logo svg{display:block;width:100%;height:100%;fill:currentColor;}
.d-logo svg path{fill:currentColor;}
.d-michelin{display:inline-block;vertical-align:middle;}

/* responsive easing for narrower desktops/tablets */
@media (max-width:1280px){
  /* nav already hamburger mode at all widths */
}
@media (max-width:1080px){
  .d-mood-grid{grid-template-columns:repeat(2,1fr);gap:36px 24px;}
  .d-intro{grid-template-columns:1fr;gap:30px;}
  .d-foot-grid{grid-template-columns:1fr 1fr;}
  .d-menu-main{grid-template-columns:1fr;align-content:start;align-items:start;gap:clamp(36px,5vw,60px);}
  .d-menu-aside{max-width:none;flex-direction:row;flex-wrap:wrap;gap:32px 56px;align-items:flex-start;}
}
/* =================== sub-page top =================== */
.d-ptop{padding-top:calc(var(--nav-h) + clamp(56px,7vw,120px));padding-bottom:clamp(36px,4vw,64px);}
.d-ptop-ey{margin-bottom:22px;}
.d-ptop-h{font-family:var(--serif);font-weight:var(--serif-w);font-size:clamp(40px,4.6vw,78px);line-height:1.0;letter-spacing:-.015em;color:var(--ink);}
.d-ptop-lede{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.05vw,18px);line-height:1.6;color:var(--ink-soft);max-width:56ch;margin-top:26px;}

/* =================== gallery (room rows) =================== */
.d-gal{position:relative;width:100%;overflow:hidden;background:#e7e2d8;}
.d-gal-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity 1s ease;}
.d-gal-arr{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;
  border:1px solid rgba(247,244,238,.7);background:rgba(12,10,7,.18);backdrop-filter:blur(3px);color:#f7f4ee;
  font-size:22px;line-height:0;cursor:pointer;opacity:0;transition:opacity .4s ease,background .4s ease;display:flex;align-items:center;justify-content:center;}
.d-gal:hover .d-gal-arr{opacity:1;}
.d-gal-arr:hover{background:rgba(12,10,7,.42);}
.d-gal-arr--l{left:18px;}
.d-gal-arr--r{right:18px;}
.d-gal-count{position:absolute;top:18px;right:18px;font-family:var(--sans);font-size:11px;letter-spacing:.12em;
  color:#f7f4ee;background:rgba(12,10,7,.34);padding:6px 10px;backdrop-filter:blur(3px);}
.d-gal-dots{position:absolute;bottom:18px;left:0;right:0;display:flex;gap:8px;justify-content:center;}
.d-gal-dot{width:7px;height:7px;border-radius:50%;border:none;cursor:pointer;background:rgba(247,244,238,.5);transition:all .4s;padding:0;}
.d-gal-dot.is-on{background:#f7f4ee;width:20px;border-radius:4px;}

/* =================== rooms page =================== */
.d-rooms-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(10px,1vw,18px);margin-top:clamp(36px,4vw,60px);}
.d-rooms-strip .d-img{aspect-ratio:3/4;}
.d-rooms-note{font-family:var(--sans);font-weight:400;font-size:13.5px;line-height:1.62;color:var(--ink-soft);
  border-left:1px solid var(--line);padding-left:16px;max-width:62ch;margin-top:clamp(30px,3vw,48px);}

.d-anchorbar{position:sticky;top:var(--nav-h-solid);z-index:30;background:color-mix(in oklab,var(--bg) 92%,transparent);
  backdrop-filter:blur(14px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.d-anchorbar-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--mar);display:flex;gap:clamp(20px,3vw,52px);align-items:center;height:62px;}
.d-anchor{position:relative;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;
  font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);padding:6px 0;white-space:nowrap;transition:color .4s;display:inline-flex;gap:7px;align-items:baseline;}
.d-anchor:hover{color:var(--ink-soft);}
.d-anchor.is-on{color:var(--accent);}
.d-anchor-count{font-size:9px;font-weight:500;color:color-mix(in oklab,var(--ink) 34%,transparent);}
.d-anchor.is-on .d-anchor-count{color:color-mix(in oklab,var(--accent) 60%,transparent);}
.d-anchor::after{content:"";position:absolute;left:0;right:100%;bottom:-1px;height:1.5px;background:var(--accent);transition:right .45s cubic-bezier(.2,.6,.2,1);}
.d-anchor.is-on::after{right:0;}

.d-mood-sec{padding:clamp(70px,8vw,128px) 0 0;}
.d-mood-sec-head{max-width:var(--maxw);margin:0 auto;padding:0 var(--mar);display:flex;flex-direction:column;gap:16px;margin-bottom:clamp(40px,4.5vw,64px);}
.d-mood-sec-intro{font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.25vw,20px);line-height:1.45;color:var(--ink);max-width:34ch;text-wrap:balance;}

/* room row — alternating split */
.d-roomrow{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,4.5vw,72px) var(--mar);display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,4vw,80px);align-items:center;border-top:1px solid var(--line);}
.d-roomrow:first-of-type{border-top:none;}
.d-roomrow--rev .d-roomrow-media{order:2;}
.d-roomrow-info{display:flex;flex-direction:column;}
.d-roomrow-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;}
.d-room-name{font-family:var(--sans);font-weight:600;font-size:clamp(22px,1.7vw,28px);line-height:1.08;letter-spacing:-.01em;}
.d-room-from{font-family:var(--sans);font-size:14px;font-weight:500;white-space:nowrap;color:var(--ink);}
.d-room-from em{font-style:normal;color:var(--ink-faint);font-size:12px;}
.d-room-blurb{font-family:var(--sans);font-weight:400;font-size:16.5px;line-height:1.62;color:var(--ink-soft);margin:18px 0 22px;max-width:42ch;}
.d-room-specs{font-family:var(--sans);font-size:13px;letter-spacing:.03em;color:var(--ink);padding-top:18px;border-top:1px solid var(--line);}
.d-room-note{font-family:var(--sans);font-size:13px;color:var(--ink-faint);margin-top:7px;}
.d-room-actions{display:flex;align-items:center;gap:26px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line);}
.d-room-toggle{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:9px;}
.d-room-toggle-s{font-size:16px;width:13px;display:inline-block;color:var(--ink-soft);}
.d-detail-long{font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.62;color:var(--ink);padding-top:22px;margin-bottom:20px;max-width:46ch;}
.d-drow{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:13px 0;border-top:1px solid var(--line);}
.d-drow-k{font-family:var(--sans);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);padding-top:2px;}
.d-drow-v{font-family:var(--sans);font-size:14px;line-height:1.5;font-weight:400;}
.d-feat{list-style:none;display:flex;flex-direction:column;gap:6px;}
.d-feat li{font-size:14px;line-height:1.45;font-weight:400;position:relative;padding-left:15px;}
.d-feat li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:1px;background:var(--ink-faint);}

/* =================== booking =================== */
.d-book{max-width:1180px;margin:0 auto;padding:0 var(--mar);}
.d-book-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,4vw,64px);align-items:start;}
.d-book-shell{background:#fbfaf7;border:1px solid var(--line);padding:clamp(28px,3vw,44px);}
[data-tone="ivory"] .d-book-shell{background:#faf7f0;}
.d-book-chip{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg);border:1px solid var(--line);margin-bottom:26px;}
.d-book-chip-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.d-book-chip-v{font-family:var(--sans);font-weight:600;font-size:17px;flex:1;}
.d-book-chip button{background:none;border:none;cursor:pointer;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-decoration:underline;text-underline-offset:3px;}
/* room category picker */
.d-book-cat{margin-bottom:24px;border:1px solid var(--line);background:var(--bg);}
.d-book-cat-trigger{display:flex;align-items:center;gap:14px;width:100%;background:none;border:none;cursor:pointer;padding:16px 18px;text-align:left;}
.d-book-cat-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);flex:none;}
.d-book-cat-v{font-family:var(--sans);font-weight:600;font-size:17px;color:var(--ink);flex:1;}
.d-book-cat-sign{font-size:17px;line-height:1;color:var(--ink-soft);flex:none;}
.d-book-cat-panel{padding:4px 10px 12px;display:flex;flex-direction:column;}
.d-book-cat-group{display:flex;flex-direction:column;}
.d-book-cat-group-h{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);padding:16px 8px 7px;}
.d-book-cat-opt{display:flex;align-items:baseline;justify-content:space-between;gap:16px;width:100%;background:none;border:none;cursor:pointer;
  text-align:left;padding:11px 8px;border-radius:2px;transition:background .25s ease;color:var(--ink);}
.d-book-cat-opt:hover{background:color-mix(in oklab,var(--ink) 6%,transparent);}
.d-book-cat-opt span:first-child{font-family:var(--sans);font-weight:500;font-size:15px;}
.d-book-cat-from{font-family:var(--sans);font-size:12px;color:var(--ink-faint);white-space:nowrap;}
.d-book-cat-opt.is-on{background:var(--ink);}
.d-book-cat-opt.is-on span{color:var(--bg);}
.d-book-cat-any{border-bottom:1px solid var(--line);border-radius:0;margin-bottom:2px;}
.d-book-dates{display:flex;border:1px solid var(--line);margin-bottom:24px;}
.d-book-field{flex:1;padding:16px 18px;display:flex;flex-direction:column;gap:7px;}
.d-book-field-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.d-book-field-v{font-family:var(--sans);font-weight:600;font-size:18px;color:var(--ink-faint);}
.d-book-field-v.is-set{color:var(--ink);}
.d-book-arrow{display:flex;align-items:center;padding:0 6px;color:var(--ink-faint);border-left:1px solid var(--line);border-right:1px solid var(--line);}
.d-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.d-cal-nav span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.d-cal-nav button{width:40px;height:40px;border:1px solid var(--line);background:none;cursor:pointer;font-size:18px;color:var(--ink);transition:background .3s;}
.d-cal-nav button:hover:not(:disabled){background:color-mix(in oklab,var(--ink) 7%,transparent);}
.d-cal-nav button:disabled{opacity:.3;cursor:not-allowed;}
.d-cal-head{font-family:var(--sans);font-weight:600;font-size:15px;margin-bottom:14px;}
.d-cal-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px;}
.d-cal-dow span{text-align:center;font-size:10px;letter-spacing:.1em;color:var(--ink-faint);}
.d-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;}
.d-cal-empty{aspect-ratio:1;}
.d-cal-day{aspect-ratio:1;border:none;background:none;cursor:pointer;font-family:var(--sans);font-size:14px;color:var(--ink);transition:background .25s,color .25s;}
.d-cal-day:hover:not(:disabled){background:color-mix(in oklab,var(--ink) 8%,transparent);}
.d-cal-day.is-range{background:color-mix(in oklab,var(--ink) 7%,transparent);}
.d-cal-day.is-in,.d-cal-day.is-out{background:var(--ink);color:var(--bg);}
.d-cal-day.is-past{color:var(--ink-faint);opacity:.4;cursor:not-allowed;}
.d-book-guests{margin-top:24px;border-top:1px solid var(--line);}
.d-stepper{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--line);}
.d-stepper-label{font-size:15px;}
.d-stepper-sub{font-size:11px;color:var(--ink-faint);margin-top:2px;}
.d-stepper-ctrl{display:flex;align-items:center;gap:18px;}
.d-stepper-ctrl button{width:36px;height:36px;border:1px solid var(--ink);background:none;cursor:pointer;font-size:17px;color:var(--ink);border-radius:50%;transition:opacity .3s;}
.d-stepper-ctrl button:disabled{opacity:.25;cursor:not-allowed;}
.d-stepper-ctrl span{min-width:16px;text-align:center;font-size:15px;}
.d-book-promo-toggle{margin-top:22px;background:none;border:none;cursor:pointer;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}
.d-book-promo{margin-top:12px;width:100%;border:1px solid var(--line);background:var(--bg);padding:14px 16px;font-family:var(--sans);font-size:14px;color:var(--ink);letter-spacing:.06em;}
.d-book-promo:focus{outline:none;border-color:var(--ink);}
.d-book-submit{margin-top:26px;width:100%;}
.d-bd-note{display:flex;flex-direction:column;gap:4px;text-align:center;margin-top:22px;}
.d-bd-note-h{font-family:var(--sans);font-weight:600;font-size:13.5px;letter-spacing:.04em;color:var(--michelin);}
.d-bd-note-p{font-family:var(--sans);font-weight:400;font-size:13px;line-height:1.5;color:var(--ink-soft);}
.d-aside{display:flex;flex-direction:column;gap:18px;padding-top:6px;}
.d-aside-h{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);}
.d-aside-list{list-style:none;display:flex;flex-direction:column;}
.d-aside-list li{font-family:var(--sans);font-weight:400;font-size:15.5px;line-height:1.4;padding:15px 0;border-bottom:1px solid var(--line);color:var(--ink);}
.d-aside-list li:first-child{border-top:1px solid var(--line);}
.d-aside-note{font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.6;color:var(--ink-soft);margin-top:8px;}
.d-book-summary{display:flex;flex-direction:column;margin:8px 0 4px;}
.d-book-summary div{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-top:1px solid var(--line);font-size:15px;}
.d-book-summary div span:first-child{color:var(--ink-faint);font-size:11px;letter-spacing:.13em;text-transform:uppercase;padding-top:2px;}
.d-done-h{font-family:var(--serif);font-weight:var(--serif-w);font-size:clamp(26px,2.6vw,38px);line-height:1.08;margin:6px 0 8px;}

/* =================== contact =================== */
.d-contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,5vw,90px);align-items:start;}
.d-cshell{background:#fbfaf7;border:1px solid var(--line);padding:clamp(28px,3vw,44px);}
[data-tone="ivory"] .d-cshell{background:#faf7f0;}
.d-ctopic{display:flex;flex-direction:column;gap:13px;padding-bottom:24px;border-bottom:1px solid var(--line);}
.d-ctopic-opts{display:flex;flex-wrap:wrap;gap:9px;}
.d-ctopic-btn{font-family:var(--sans);font-size:12.5px;color:var(--ink-soft);background:none;border:1px solid var(--line);padding:10px 16px;cursor:pointer;transition:all .35s ease;}
.d-ctopic-btn:hover{border-color:var(--ink-faint);}
.d-ctopic-btn.is-on{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.d-cfield{display:flex;flex-direction:column;gap:9px;padding:19px 0;border-bottom:1px solid var(--line);}
.d-cfield-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.d-cinput{font-family:var(--sans);font-size:16px;font-weight:400;color:var(--ink);background:none;border:none;padding:2px 0;width:100%;}
.d-cinput::placeholder{color:var(--ink-faint);}
.d-cinput:focus{outline:none;}
.d-ctextarea{resize:vertical;line-height:1.6;min-height:120px;}
.d-cnote{font-size:13.5px;color:var(--ink-soft);margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;}

/* ============ sub-pages (rooftop / spa / gnou / boutique) ============ */
.d-btn-fill{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  padding:16px 26px;border:1px solid var(--ink);background:var(--ink);color:var(--bg);cursor:pointer;text-decoration:none;display:inline-block;transition:opacity .4s;}
.d-btn-fill:hover{opacity:.84;}
.d-btn-line{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  padding:16px 26px;border:1px solid var(--line);background:none;color:var(--ink);cursor:pointer;text-decoration:none;display:inline-block;transition:border-color .4s;}
.d-btn-line:hover{border-color:var(--ink);}
.d-fineprint{font-family:var(--sans);font-weight:400;font-size:13px;line-height:1.55;color:var(--ink-faint);}
.d-fineprint--light{color:rgba(243,239,230,.6);}
.d-sub-lede{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.05vw,18px);line-height:1.6;color:var(--ink-soft);max-width:54ch;}

/* sub hero */
.d-sub-hero{position:relative;width:100%;height:clamp(520px,72vh,800px);overflow:hidden;background:#15110b;}
.d-sub-hero img{position:absolute;inset:0;width:100%;height:130%;object-fit:cover;top:-15%;will-change:transform;}
.d-sub-hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.34),rgba(8,6,4,.08) 44%,rgba(8,6,4,.6));}
.d-sub-hero-copy{position:absolute;left:0;right:0;bottom:clamp(46px,5vw,86px);display:flex;flex-direction:column;gap:18px;}
.d-sub-hero-title{font-family:var(--serif);font-weight:var(--serif-w);color:#f7f4ee;font-size:clamp(38px,4.4vw,72px);line-height:1.04;letter-spacing:-.014em;max-width:18ch;text-shadow:0 2px 30px rgba(0,0,0,.34);}

/* sub intro two-col */
.d-sub-intro{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(40px,6vw,110px);align-items:start;padding-top:clamp(70px,8vw,130px);padding-bottom:clamp(40px,5vw,80px);}
.d-sub-intro-col{display:flex;flex-direction:column;gap:18px;}
.d-sub-intro-h2{padding-top:6px;}
.d-rooftop-note{color:var(--michelin);font-weight:500;}
.d-arrive{display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center;padding:0 var(--mar) clamp(28px,3vw,46px);}
.d-arrive-h{font-family:var(--sans);font-weight:600;font-size:clamp(16px,1.2vw,19px);color:var(--ink);}
.d-arrive-p{font-family:var(--sans);font-weight:400;font-size:clamp(14px,1vw,16px);line-height:1.5;color:var(--ink-soft);}

/* meal rows (rooftop) + daynight (gnou) */
.d-meal{display:grid;grid-template-columns:1fr 1fr;min-height:clamp(440px,52vh,640px);}
.d-meal--rev .d-meal-media{order:2;}
.d-meal-media{position:relative;overflow:hidden;background:#e7e2d8;}
.d-meal-body{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:clamp(40px,5vw,90px) var(--mar);}
.d-meal-title{font-family:var(--sans);font-weight:600;font-size:clamp(22px,1.9vw,30px);line-height:1.16;letter-spacing:-.005em;color:var(--ink);max-width:18ch;}
.d-meal-title--light{color:#f7f4ee;}
.d-meal-accent{font-family:var(--serif);font-weight:var(--serif-w);font-style:italic;letter-spacing:0;}
.d-meal-body .d-body{max-width:42ch;}

.d-daynight{display:grid;grid-template-columns:1fr 1fr;min-height:clamp(460px,58vh,720px);}
.d-daynight--rev .d-daynight-media{order:2;}
.d-daynight-media{position:relative;overflow:hidden;background:#e7e2d8;}
.d-daynight-body{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:clamp(40px,5vw,90px) var(--mar);}
.d-daynight--dark{background:#14110c;}
.d-night-copy{color:rgba(243,239,230,.74);max-width:42ch;}

/* rooftop reservations block */
.d-sub-block{padding-top:clamp(60px,7vw,120px);padding-bottom:clamp(60px,7vw,120px);display:flex;justify-content:center;}
.d-sub-block-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;max-width:60ch;}
.d-sub-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:6px;}
.d-roof-menus{padding-top:clamp(72px,8vw,132px);padding-bottom:clamp(72px,8vw,132px);background:linear-gradient(180deg,rgba(246,244,239,.65),rgba(246,244,239,0));}
.d-roof-menus .d-sub-block-inner{max-width:1120px;width:100%;gap:20px;}
.d-roof-menu-heading{font-family:var(--serif);font-weight:var(--serif-w);font-size:clamp(30px,3vw,48px);line-height:1.06;letter-spacing:-.012em;color:var(--ink);text-wrap:balance;}
.d-roof-menu-lede{max-width:52ch;margin-left:auto;margin-right:auto;}
.d-roof-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px);width:100%;margin:clamp(22px,2.5vw,36px) 0 12px;text-align:center;}
.d-roof-menu{display:flex;flex-direction:column;align-items:center;gap:13px;min-height:100%;padding:clamp(26px,2.7vw,38px) clamp(20px,2vw,32px);border:1px solid var(--line);background:rgba(255,255,255,.28);}
.d-roof-menu-title{font-family:var(--serif);font-weight:var(--serif-w);font-size:clamp(22px,1.8vw,30px);line-height:1.08;color:var(--ink);}
.d-roof-menu .d-body{max-width:30ch;}
.d-roof-menu-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:3px;}
.d-roof-menu-list li{font-family:var(--sans);font-weight:400;font-size:14.5px;line-height:1.5;color:var(--ink);position:relative;padding-top:10px;}
.d-roof-menu-list li::before{content:"";position:absolute;left:50%;top:0;width:18px;height:1px;background:var(--line);transform:translateX(-50%);}
.d-roof-menu-note{max-width:58ch;margin:clamp(12px,1.5vw,22px) auto 0;}
.d-roof-menu-actions{margin-top:4px;}

/* spa layout */
.d-spa-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,120px);align-items:start;padding-top:clamp(70px,8vw,130px);padding-bottom:clamp(60px,7vw,110px);}
.d-spa-intro{display:flex;flex-direction:column;gap:30px;}
.d-spa-intro .d-body{max-width:42ch;}
.d-pricelist{display:flex;flex-direction:column;gap:clamp(34px,3vw,52px);}
.d-price-group{display:flex;flex-direction:column;}
.d-price-group .d-sec-title{margin-bottom:14px;}
.d-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:18px;padding:15px 0;border-top:1px solid var(--line);}
.d-price-name{display:flex;flex-direction:column;gap:3px;}
.d-price-name>span:first-child{font-family:var(--sans);font-weight:500;font-size:16px;color:var(--ink);}
.d-price-detail{font-family:var(--sans);font-weight:400;font-size:13px;color:var(--ink-faint);}
.d-price-val{font-family:var(--sans);font-weight:500;font-size:16px;color:var(--ink);white-space:nowrap;}

/* boutique catalogue */
.d-prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,3vw,52px) clamp(24px,2.4vw,40px);padding-top:clamp(50px,5vw,80px);}
.d-prod{display:flex;flex-direction:column;}
.d-prod-media{width:100%;aspect-ratio:4/5;overflow:hidden;background:#e7e2d8;margin-bottom:20px;}
.d-prod-gallery{position:relative;width:100%;height:100%;background:#e7e2d8;overflow:hidden;}
.d-prod-gallery-btn{position:absolute;top:50%;z-index:2;width:38px;height:38px;border-radius:50%;border:1px solid rgba(246,245,242,.72);background:rgba(22,19,14,.42);color:#f6f5f2;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:25px;line-height:1;cursor:pointer;transform:translateY(-50%);backdrop-filter:blur(10px);transition:background .25s ease,border-color .25s ease,transform .25s ease;}
.d-prod-gallery-btn--prev{left:12px;}
.d-prod-gallery-btn--next{right:12px;}
.d-prod-gallery-btn:hover{background:rgba(22,19,14,.62);border-color:#f6f5f2;}
.d-prod-gallery-dots{position:absolute;left:50%;bottom:14px;z-index:2;display:flex;gap:8px;transform:translateX(-50%);}
.d-prod-gallery-dot{width:8px;height:8px;border-radius:50%;border:1px solid rgba(246,245,242,.9);background:rgba(22,19,14,.18);padding:0;cursor:pointer;transition:background .25s ease,transform .25s ease;}
.d-prod-gallery-dot.is-active{background:#f6f5f2;transform:scale(1.12);}
.d-prod-body{display:flex;flex-direction:column;gap:8px;}
.d-prod-cat{font-family:var(--sans);font-weight:500;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);}
.d-prod-name{font-family:var(--sans);font-weight:600;font-size:clamp(18px,1.3vw,22px);line-height:1.14;letter-spacing:-.005em;color:var(--ink);}
.d-prod-tag{font-family:var(--sans);font-weight:400;font-size:14.5px;line-height:1.5;color:var(--ink-soft);}
.d-prod-copy{margin-top:4px;}
.d-prod-spec{font-family:var(--sans);font-weight:400;font-size:12.5px;letter-spacing:.02em;color:var(--ink);margin-top:12px;padding-top:12px;border-top:1px solid var(--line);}
.d-prod-note{font-family:var(--sans);font-weight:400;font-size:12px;color:var(--ink-faint);margin-top:8px;font-style:italic;}
.d-prod-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:14px;}
.d-prod-price{font-family:var(--sans);font-weight:500;font-size:16px;color:var(--ink);}
.d-prod-note-row{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:clamp(46px,5vw,80px);padding-top:clamp(30px,3vw,48px);border-top:1px solid var(--line);}

/* photo placeholder */
.d-ph{width:100%;height:100%;min-height:240px;background-color:#e7e2d8;
  background-image:repeating-linear-gradient(135deg,rgba(25,21,16,.05) 0 14px,transparent 14px 28px);
  display:flex;align-items:center;justify-content:center;}
.d-ph-label{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;letter-spacing:.04em;color:var(--ink-faint);text-transform:lowercase;padding:0 28px;text-align:center;}

/* sub-page closing */
.d-subcta{padding:clamp(70px,8vw,130px) var(--mar);display:flex;flex-direction:column;align-items:center;text-align:center;gap:26px;border-top:1px solid var(--line);}
.d-subcta .d-cta-title{max-width:none;}

/* ---- single room page (desktop) ---- */
.d-room-name--link{cursor:pointer;transition:opacity .3s;}
.d-room-name--link:hover{opacity:.6;}
.d-room-hero{display:grid;grid-template-columns:1.15fr 1fr;min-height:clamp(520px,72vh,820px);}
.d-room-hero-media{position:relative;overflow:hidden;background:#e7e2d8;}
.d-room-hero-copy{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:clamp(50px,5vw,100px) var(--mar);}
.d-back{align-self:flex-start;background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:500;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);padding:0;transition:color .3s;}
.d-back:hover{color:var(--ink);}
.d-room-title{font-family:var(--serif);font-weight:var(--serif-w);font-size:clamp(38px,4vw,64px);line-height:1.02;letter-spacing:-.014em;color:var(--ink);}
.d-room-lead{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.05vw,17px);line-height:1.62;color:var(--ink-soft);max-width:42ch;}
.d-room-keyline{display:flex;flex-direction:column;gap:8px;padding-top:18px;margin-top:4px;border-top:1px solid var(--line);}
.d-room-from-big{font-family:var(--sans);font-weight:600;font-size:19px;color:var(--ink);}
.d-room-from-big em{font-style:normal;font-weight:400;font-size:13px;color:var(--ink-faint);}
.d-room-specs-inline{font-family:var(--sans);font-weight:400;font-size:14px;color:var(--ink-soft);}
.d-room-gallerygrid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(12px,1.2vw,20px);padding-top:clamp(40px,4vw,70px);}
.d-room-gcell{aspect-ratio:4/3;overflow:hidden;background:#e7e2d8;}
.d-room-gcell:first-child:nth-last-child(odd){grid-column:1 / -1;aspect-ratio:16/7;}
.d-room-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,110px);align-items:start;padding-top:clamp(56px,6vw,100px);padding-bottom:clamp(60px,7vw,110px);}
.d-room-details{display:flex;flex-direction:column;gap:clamp(30px,3vw,48px);}
.d-rd-block{display:flex;flex-direction:column;gap:14px;}
.d-rd-rows{display:flex;flex-direction:column;}
.d-rd-row{display:flex;justify-content:space-between;gap:18px;padding:13px 0;border-top:1px solid var(--line);font-size:15px;}
.d-rd-row span:first-child{color:var(--ink-faint);}
.d-rd-row span:last-child{text-align:right;color:var(--ink);}
.d-room-bookaside{position:sticky;top:calc(var(--nav-h) + 20px);}
.d-room-bookcard{border:1px solid var(--line);background:#faf7f0;padding:clamp(24px,2vw,34px);}
[data-tone="cool"] .d-room-bookcard{background:#fbfaf7;}
.d-room-bookcard .d-book-shell{background:none;border:none;padding:0;}
.d-cdirect{display:flex;flex-direction:column;gap:6px;}
.d-cdirect-rows{margin-top:14px;}
.d-cdirect-row{display:flex;align-items:baseline;justify-content:space-between;gap:20px;padding:20px 0;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:opacity .3s;}
a.d-cdirect-row:hover{opacity:.62;}
.d-cdirect-row:last-of-type{border-bottom:1px solid var(--line);}
.d-cdirect-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);flex:none;padding-top:6px;}
.d-cdirect-v{font-family:var(--sans);font-weight:600;font-size:19px;line-height:1.25;text-align:right;display:flex;flex-direction:column;gap:4px;}
.d-cdirect-v em{font-family:var(--sans);font-style:normal;font-size:11px;letter-spacing:.06em;color:var(--ink-faint);font-weight:400;}
.d-chours{font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.62;color:var(--ink-soft);margin-top:24px;}

@media (max-width:1080px){
  .d-book-grid,.d-contact-grid{grid-template-columns:1fr;}
  .d-rooms-strip{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:900px){
  .d-split{grid-template-columns:1fr;}
  .d-split--reverse .d-split-media{order:0;}
  .d-split-media{min-height:60vh;}
  .d-roomrow{grid-template-columns:1fr;gap:28px;}
  .d-roomrow--rev .d-roomrow-media{order:0;}
  .d-nav-book{display:none;}
}
@media (max-width:680px){
  .d-mood-grid{grid-template-columns:1fr;gap:40px;}
  .d-foot-grid{grid-template-columns:1fr;gap:40px;}
  .d-rooms-strip{grid-template-columns:repeat(2,1fr);}
  .d-menu-aside{flex-direction:column;}
  .d-prod-grid{grid-template-columns:1fr;}
}
@media (max-width:1024px){
  .d-sub-intro{grid-template-columns:1fr;gap:30px;}
  .d-spa-layout{grid-template-columns:1fr;gap:44px;}
  .d-meal,.d-daynight{grid-template-columns:1fr;}
  .d-meal--rev .d-meal-media,.d-daynight--rev .d-daynight-media{order:0;}
  .d-meal-media,.d-daynight-media{min-height:54vh;}
  .d-roof-menu-grid{grid-template-columns:1fr;}
  .d-prod-grid{grid-template-columns:repeat(2,1fr);}
}
