/* ============ SAKKAN visual system ============ */
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --serif:'Cormorant Garamond',Georgia,serif; --serif-w:500;
  --sans:'Avenir Next','Avenir','Mulish',system-ui,sans-serif;
  --bg:#f1ebdf; --ink:#191510; --line:rgba(25,21,16,.14);
  --accent:var(--ink); --michelin:#b4232f;
  --pad:24px; --header-h:56px; --bar-h:50px;
  --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,body{height:100%;}
body{background:var(--bg);font-family:var(--sans);color:var(--ink);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}

/* ---- production mobile shell ---- */
.sk-stage{min-height:100dvh;background:var(--bg);}
.sk-phone{position:relative;width:100%;height:100dvh;min-height:100dvh;
  background:var(--bg);overflow:hidden;display:flex;flex-direction:column;}
.sk-screen{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
  scroll-behavior:auto;position:relative;background:var(--bg);}
.sk-screen::-webkit-scrollbar{width:0;display:none;}

/* ---- typography primitives ----
   Three Avenir registers (distinction from weight nuance + caps + whitespace, no extra fonts):
   · Light/soft  = 400  → body, captions, section sentences
   · Medium      = 500  → subtitles, CTAs, prices, short emphasis
   · Caps label  = 500 uppercase + wide tracking → STAY, THE ROOFTOP, MARRAKECH · MICHELIN KEY RIAD
   Serif is reserved only for the few big editorial statements (hero, closing). */
.sk-label{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ink-soft);}
.sk-display{font-family:var(--serif);font-weight:var(--serif-w);font-size:38px;line-height:1.04;
  letter-spacing:-.01em;text-wrap:balance;}
.sk-h2-serif{font-family:var(--serif);font-weight:var(--serif-w);font-size:30px;line-height:1.08;letter-spacing:-.01em;text-wrap:balance;}
.sk-lede{font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.6;color:var(--ink-soft);}
.sk-body{font-size:15.5px;line-height:1.68;font-weight:400;color:var(--ink);}
.sk-muted{color:var(--ink-soft);}
.sk-section-lede{font-family:var(--sans);font-weight:400;font-size:18px;line-height:1.5;text-wrap:balance;color:var(--ink-soft);}
.sk-explore{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(247,244,238,.92);white-space:nowrap;}
.sk-explore--ink{color:var(--ink);}

/* buttons */
.sk-btn-line{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:15px 22px;border:1px solid var(--ink);background:none;color:var(--ink);cursor:pointer;
  transition:background .5s ease,color .5s ease;}
.sk-btn-line:hover{background:var(--ink);color:var(--bg);}
.sk-btn-fill{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:16px 22px;border:1px solid var(--ink);background:var(--ink);color:var(--bg);cursor:pointer;transition:opacity .4s;}
.sk-btn-fill:disabled{opacity:.32;cursor:not-allowed;}
.sk-btn-over{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:15px 24px;border:1px solid rgba(247,244,238,.85);background:rgba(247,244,238,.06);color:#f7f4ee;
  cursor:pointer;backdrop-filter:blur(2px);transition:background .5s ease,color .5s ease;}
.sk-btn-over:hover{background:#f7f4ee;color:#191510;}
.sk-app button:focus:not(:focus-visible){outline:none;}
.sk-app button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
/* iOS Safari tints button text with the system blue unless pinned — keep all controls ink */
.sk-app, .sk-app button, .sk-app a{-webkit-tap-highlight-color:transparent;}
.sk-app button, .sk-app a{-webkit-text-fill-color:currentColor;}

/* ---- header ---- */
.sk-header{position:sticky;top:0;z-index:20;height:var(--header-h);box-sizing:border-box;
  display:flex;align-items:center;justify-content:space-between;padding:0 18px;
  background:color-mix(in oklab,var(--bg) 88%,transparent);backdrop-filter:blur(12px) saturate(1.1);
  border-bottom:1px solid transparent;transition:border-color .4s ease,background .4s ease;}
.sk-header.is-scrolled{border-bottom-color:var(--line);}
.sk-icon-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--ink);}
.sk-burger{display:flex;flex-direction:column;gap:5px;width:20px;}
.sk-burger i{display:block;height:1.2px;background:var(--ink);width:100%;}
.sk-burger i:last-child{width:13px;}
.sk-wordmark{background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:6px 8px;color:var(--ink);}
.sk-wordmark--static{cursor:default;}
.sk-logo{line-height:0;color:inherit;}
.sk-logo svg{display:block;width:100%;height:100%;fill:currentColor;}
.sk-logo svg path{fill:currentColor;}
.sk-book{background:none;border:1px solid var(--ink);cursor:pointer;font-family:var(--sans);
  font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);
  padding:10px 16px;min-height:40px;transition:background .5s,color .5s;}
.sk-book:hover{background:var(--ink);color:var(--bg);}

/* ---- menu overlay ---- */
.sk-menu{position:absolute;inset:0;z-index:60;background:var(--bg);
  display:flex;flex-direction:column;padding:0 var(--pad) 40px;transition:opacity .55s ease;}
.sk-menu-top{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;margin:0 -6px;}
.sk-close{position:relative;width:20px;height:20px;}
.sk-close i{position:absolute;top:9px;left:0;width:20px;height:1.2px;background:var(--ink);}
.sk-close i:first-child{transform:rotate(45deg);}
.sk-close i:last-child{transform:rotate(-45deg);}
.sk-menu-nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px;}
.sk-menu-link{display:flex;align-items:baseline;justify-content:space-between;background:none;border:none;
  cursor:pointer;text-align:left;padding:13px 0;color:var(--ink);border-bottom:1px solid var(--line);
  font-family:var(--sans);font-weight:500;font-size:21px;letter-spacing:.005em;}
.sk-menu-arrow{font-family:var(--sans);font-size:14px;color:var(--ink-faint);}
.sk-menu-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;padding-top:24px;}
.sk-menu-addr{font-size:13px;line-height:1.6;font-weight:400;color:var(--ink-soft);}
.sk-menu-links{display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.sk-menu-links a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;}
.sk-text-cta{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;}

/* ---- carousel ---- */
.sk-carousel{position:relative;width:100%;background:#e7e2d8;overflow:hidden;}
.sk-carousel-track{display:flex;width:100%;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.sk-carousel-track::-webkit-scrollbar{display:none;}
.sk-carousel-cell{flex:0 0 100%;width:100%;height:100%;scroll-snap-align:center;}
.sk-counter{position:absolute;top:14px;right:14px;font-size:11px;letter-spacing:.12em;
  color:#f7f4ee;background:rgba(12,10,7,.34);padding:5px 9px;backdrop-filter:blur(3px);}
.sk-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;gap:7px;justify-content:center;}
.sk-dot{width:6px;height:6px;border-radius:50%;border:none;cursor:pointer;background:rgba(247,244,238,.55);transition:all .4s;}
.sk-dot.is-on{background:#f7f4ee;width:18px;border-radius:3px;}

/* ---- footer ---- */
.sk-footer{background:#14110c;color:#f3efe6;padding:56px var(--pad) 40px;}
.sk-foot-mark{color:#f3efe6;margin-bottom:30px;}
.sk-foot-addr{font-size:13.5px;line-height:1.75;font-weight:400;color:rgba(243,239,230,.66);margin-bottom:34px;}
.sk-foot-col{margin-bottom:32px;}
.sk-foot-links{display:flex;flex-direction:column;gap:13px;margin-top:18px;}
.sk-foot-links button{background:none;border:none;cursor:pointer;text-align:left;color:#f3efe6;
  font-family:var(--sans);font-weight:400;font-size:16px;letter-spacing:.005em;}
.sk-foot-book{background:none;border:1px solid rgba(243,239,230,.4);color:#f3efe6;cursor:pointer;
  font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:15px 22px;width:100%;
  transition:background .5s,color .5s;margin-bottom:30px;}
.sk-foot-book:hover{background:#f3efe6;color:#14110c;}
.sk-foot-legal{display:flex;gap:9px;align-items:center;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(243,239,230,.45);}
.sk-foot-legal-link{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);padding:0;transition:color .3s;}
.sk-foot-legal-link:hover{color:rgba(243,239,230,.85);}

/* ---- pages ---- */
.sk-page{background:var(--bg);}

/* hero */
.sk-hero{position:relative;height:calc(100dvh - var(--header-h));min-height:560px;overflow:hidden;background:#1a1610;}
.sk-hero-stack{position:absolute;inset:0;}
.sk-hero-stack img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.02);transition:opacity 1.55s ease;}
.sk-hero-img.is-visible{opacity:1;transform:scale(1.035);}
.sk-hero-img.is-active{opacity:1;animation:skkenburns 3.35s ease-out both;}
.sk-hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,8,5,.12) 0%,rgba(10,8,5,0) 30%,rgba(10,8,5,.08) 60%,rgba(10,8,5,.62) 100%);}
.sk-hero-copy{position:absolute;left:var(--pad);bottom:78px;right:var(--pad);}
.sk-hero-title{font-family:var(--serif);font-weight:var(--serif-w);color:#f7f4ee;font-size:46px;line-height:1.0;letter-spacing:-.012em;text-shadow:0 2px 30px rgba(0,0,0,.3);}
.sk-scrollcue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);width:1px;height:34px;background:rgba(247,244,238,.45);overflow:hidden;}
.sk-scrollcue span{position:absolute;top:-34px;left:0;width:1px;height:34px;background:#f7f4ee;animation:cue 2.4s cubic-bezier(.6,0,.2,1) infinite;}
@keyframes cue{0%{top:-34px}55%{top:34px}100%{top:34px}}
@keyframes skkenburns{0%{transform:scale(1.02) translate3d(0,0,0);}100%{transform:scale(1.075) translate3d(0,-1%,0);}}

/* intro */
.sk-intro{padding:72px var(--pad) 28px;display:flex;flex-direction:column;gap:22px;}
.sk-stay-line{margin-top:20px;display:flex;flex-direction:column;gap:12px;}
.sk-stay-line p{font-family:var(--sans);font-weight:500;font-size:18px;color:var(--ink);}

/* stay / moods */
.sk-stay{padding:8px var(--pad) 64px;}
.sk-section-lede{margin-bottom:54px;}
.sk-choose{margin-bottom:34px;display:flex;flex-direction:column;gap:12px;}
.sk-choose .sk-muted{font-size:15px;line-height:1.6;font-weight:400;max-width:30ch;}
.sk-mood-grid{display:flex;flex-direction:column;gap:46px;}
.sk-mood{background:none;border:none;cursor:pointer;text-align:left;display:flex;flex-direction:column;width:100%;color:var(--ink);}
.sk-mood-body{padding-top:20px;display:flex;flex-direction:column;gap:11px;}
.sk-mood-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;}
.sk-mood-from{font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.01em;color:var(--ink);white-space:nowrap;}
.sk-mood-title{font-family:var(--sans);font-weight:600;font-size:23px;line-height:1.1;letter-spacing:-.005em;color:var(--ink);-webkit-text-fill-color:currentColor;}
.sk-mood-desc{font-size:15px;line-height:1.6;font-weight:400;color:var(--ink-soft);max-width:34ch;}
.sk-mood-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line);margin-top:6px;}
.sk-mood-types{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);}
.sk-mood .sk-explore{color:var(--ink);transition:opacity .3s;}

/* book-direct strip (between mood tiles) */
.sk-bookdirect{display:flex;flex-direction:column;gap:9px;padding:26px 2px;cursor:pointer;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;align-items:center;}
.sk-bd-label{font-family:var(--sans);font-weight:500;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--michelin);}
.sk-bd-line{font-family:var(--sans);font-weight:400;font-size:15.5px;line-height:1.5;color:var(--ink-soft);max-width:30ch;text-wrap:balance;}
.sk-bd-cta{font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:3px;margin-top:2px;}

/* book-direct reassurance note (inside booking module) */
.sk-bd-note{display:flex;flex-direction:column;gap:4px;padding:14px 0 2px;text-align:center;}
.sk-bd-note-h{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.04em;color:var(--michelin);}
.sk-bd-note-p{font-family:var(--sans);font-weight:400;font-size:12.5px;line-height:1.5;color:var(--ink-soft);}

/* feature modules */
.sk-feature{position:relative;height:calc(100dvh - var(--header-h));min-height:540px;overflow:hidden;background:#1a1610;}
.sk-feature-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.28) 0%,rgba(8,6,4,0) 40%,rgba(8,6,4,.5) 100%);}
.sk-feature.is-dark .sk-feature-scrim{background:linear-gradient(180deg,rgba(6,5,3,.5) 0%,rgba(6,5,3,.2) 45%,rgba(6,5,3,.72) 100%);}
.sk-feature-copy{position:absolute;left:var(--pad);right:var(--pad);bottom:60px;display:flex;flex-direction:column;gap:18px;}
.sk-feature-text{font-family:var(--sans);font-weight:500;color:#f7f4ee;font-size:25px;line-height:1.25;letter-spacing:-.005em;text-wrap:balance;max-width:20ch;text-shadow:0 2px 24px rgba(0,0,0,.28);}
.sk-feature-cta{align-self:flex-start;}

/* house */
.sk-house{padding:78px var(--pad) 70px;display:flex;flex-direction:column;gap:16px;}
.sk-house-lede{font-family:var(--sans);font-weight:500;font-size:19px;line-height:1.4;margin-bottom:18px;text-wrap:balance;}
.sk-house-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.sk-boutique{display:flex;gap:18px;align-items:flex-start;margin-top:40px;padding-top:36px;border-top:1px solid var(--line);}
.sk-boutique .sk-label{margin-bottom:12px;}
.sk-boutique-copy{font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.5;margin-bottom:16px;}

/* neighbourhood */
.sk-hood{padding:18px var(--pad) 74px;display:flex;flex-direction:column;gap:30px;}
.sk-hood-text{display:flex;flex-direction:column;gap:18px;}
.sk-hood-h{margin:2px 0 6px;font-size:30px;}

/* beyond */
.sk-beyond{padding:0 var(--pad) 86px;display:flex;flex-direction:column;gap:20px;}
.sk-beyond-copy{font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.55;text-wrap:balance;color:var(--ink-soft);}

/* stay with us cta */
.sk-cta{position:relative;height:calc(100dvh - var(--header-h));min-height:560px;overflow:hidden;background:#1a1610;}
.sk-cta-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.34) 0%,rgba(8,6,4,.12) 40%,rgba(8,6,4,.66) 100%);}
.sk-cta-copy{position:absolute;left:var(--pad);right:var(--pad);bottom:64px;display:flex;flex-direction:column;gap:24px;align-items:flex-start;}
.sk-cta-title{font-family:var(--serif);font-weight:var(--serif-w);color:#f7f4ee;font-size:42px;line-height:1.04;letter-spacing:-.012em;text-shadow:0 2px 26px rgba(0,0,0,.3);}
.sk-cta-fine{font-size:13px;line-height:1.6;font-weight:400;color:rgba(247,244,238,.74);max-width:38ch;}

/* ---------- rooms page ---------- */
.sk-rooms-intro{padding:46px var(--pad) 30px;display:flex;flex-direction:column;gap:22px;}
.sk-rooms-title{font-family:var(--serif);font-weight:var(--serif-w);font-size:42px;line-height:1;letter-spacing:-.012em;}
.sk-rooms-lede{font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.55;color:var(--ink-soft);text-wrap:balance;}
.sk-strip{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x proximity;margin:4px calc(var(--pad)*-1) 0;padding:0 var(--pad);}
.sk-strip::-webkit-scrollbar{display:none;}
.sk-strip-cell{flex:0 0 70%;aspect-ratio:4/3;scroll-snap-align:start;overflow:hidden;}
.sk-rooms-note{font-size:12.5px;line-height:1.62;font-weight:400;color:var(--ink-soft);border-left:1px solid var(--line);padding-left:14px;}

.sk-anchorbar{position:sticky;top:0;z-index:15;background:color-mix(in oklab,var(--bg) 92%,transparent);
  backdrop-filter:blur(12px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);height:var(--bar-h);display:flex;align-items:stretch;}
.sk-anchorbar-scroll{width:100%;overflow-x:auto;overflow-y:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 20px,#000 calc(100% - 20px),transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 20px,#000 calc(100% - 20px),transparent 100%);}
.sk-anchorbar-scroll::-webkit-scrollbar{display:none;}
.sk-anchorbar-inner{display:inline-flex;align-items:stretch;gap:24px;padding:0 var(--pad);height:100%;position:relative;width:max-content;}
.sk-anchor{flex:none;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:11px;
  font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);-webkit-text-fill-color:currentColor;padding:0;
  display:inline-flex;align-items:center;height:100%;transition:color .4s;white-space:nowrap;-webkit-tap-highlight-color:transparent;}
.sk-anchor.is-on{color:var(--accent);}
.sk-anchor-count{font-size:8.5px;letter-spacing:0;font-weight:400;margin-left:4px;align-self:flex-start;
  margin-top:13px;color:color-mix(in oklab,var(--ink) 32%,transparent);transition:color .4s;}
.sk-anchor.is-on .sk-anchor-count{color:color-mix(in oklab,var(--accent) 60%,transparent);}
.sk-anchor-label{position:relative;color:inherit;-webkit-text-fill-color:currentColor;}
.sk-anchor.is-on .sk-anchor-label::after{content:"";position:absolute;left:0;right:0;bottom:-9px;height:1.4px;background:var(--accent);}

.sk-mood-section{padding:54px var(--pad) 18px;}
.sk-mood-section-head{margin-bottom:34px;display:flex;flex-direction:column;gap:14px;}
.sk-mood-section-intro{font-family:var(--sans);font-weight:400;font-size:18px;line-height:1.5;text-wrap:balance;color:var(--ink-soft);}

.sk-roomcard{margin-bottom:52px;}
.sk-roomcard-body{padding-top:20px;}
.sk-roomcard-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;}
.sk-room-name{font-family:var(--sans);font-weight:600;font-size:21px;line-height:1.1;letter-spacing:-.005em;}
.sk-room-from{font-family:var(--sans);font-size:13px;font-weight:500;white-space:nowrap;color:var(--ink);}
.sk-room-from em{font-style:normal;color:var(--ink-faint);font-size:11px;}
.sk-room-blurb{font-size:15px;line-height:1.6;font-weight:400;color:var(--ink-soft);margin:13px 0 16px;}
.sk-room-specs{font-size:12px;letter-spacing:.04em;color:var(--ink);padding-top:14px;border-top:1px solid var(--line);}
.sk-room-note{font-size:12.5px;color:var(--ink-faint);margin-top:6px;font-family:var(--sans);font-weight:400;letter-spacing:.01em;}

.sk-accordion{overflow:hidden;height:0;transition:height .6s cubic-bezier(.4,0,.1,1);}
.sk-accordion-clip{min-height:0;}
.sk-detail{padding-top:22px;transition:opacity .5s ease .12s;}
.sk-detail-hr{height:1px;background:var(--line);margin-bottom:20px;}
.sk-detail-long{font-family:var(--sans);font-weight:400;font-size:15.5px;line-height:1.62;color:var(--ink);margin-bottom:22px;text-wrap:pretty;}
.sk-detail-rows{display:flex;flex-direction:column;}
.sk-drow{display:grid;grid-template-columns:96px 1fr;gap:14px;padding:13px 0;border-top:1px solid var(--line);}
.sk-drow-k{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);padding-top:2px;}
.sk-drow-v{font-size:14px;line-height:1.5;font-weight:400;}
.sk-feat{list-style:none;display:flex;flex-direction:column;gap:6px;}
.sk-feat li{font-size:14px;line-height:1.45;font-weight:400;position:relative;padding-left:14px;}
.sk-feat li::before{content:"";position:absolute;left:0;top:9px;width:4px;height:1px;background:var(--ink-faint);}
.sk-detail-book{width:100%;margin-top:24px;}

.sk-roomcard-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line);}
.sk-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:flex;align-items:center;gap:8px;}
.sk-room-toggle-sign{font-size:16px;width:14px;display:inline-block;color:var(--ink-soft);}
.sk-room-check{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent);white-space:nowrap;}

/* ---------- booking ---------- */
.sk-book-top{padding:46px var(--pad) 30px;display:flex;flex-direction:column;gap:20px;}
.sk-book-shell{margin:0 var(--pad) 18px;background:#faf7f0;border:1px solid var(--line);padding:24px 20px 28px;display:flex;flex-direction:column;gap:20px;}
[data-tone="cool"] .sk-book-shell{background:#fbfaf7;}
.sk-book-chip{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg);border:1px solid var(--line);}
.sk-book-chip-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.sk-book-chip-v{font-family:var(--sans);font-weight:600;font-size:16px;flex:1;}
.sk-book-chip button{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-decoration:underline;text-underline-offset:3px;}
.sk-book-dates{display:flex;align-items:stretch;gap:0;border:1px solid var(--line);}
.sk-book-field{flex:1;padding:14px 16px;display:flex;flex-direction:column;gap:6px;}
.sk-book-field-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.sk-book-field-v{font-family:var(--sans);font-weight:600;font-size:16px;color:var(--ink-faint);}
.sk-book-field-v.is-set{color:var(--ink);}
.sk-book-arrow{display:flex;align-items:center;padding:0 4px;color:var(--ink-faint);border-left:1px solid var(--line);border-right:1px solid var(--line);}
.sk-cal-nav{display:flex;align-items:center;justify-content:space-between;}
.sk-cal-nav span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.sk-cal-nav button{width:38px;height:38px;border:1px solid var(--line);background:none;cursor:pointer;font-size:18px;color:var(--ink);transition:background .3s;}
.sk-cal-nav button:disabled{opacity:.3;cursor:not-allowed;}
.sk-cal-head{font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;margin-bottom:12px;}
.sk-cal-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px;}
.sk-cal-dow span{text-align:center;font-size:10px;letter-spacing:.1em;color:var(--ink-faint);}
.sk-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.sk-cal-empty{aspect-ratio:1;}
.sk-cal-day{aspect-ratio:1;border:none;background:none;cursor:pointer;font-family:var(--sans);font-size:13.5px;color:var(--ink);transition:background .25s,color .25s;position:relative;}
.sk-cal-day:hover:not(:disabled){background:color-mix(in oklab,var(--ink) 8%,transparent);}
.sk-cal-day.is-range{background:color-mix(in oklab,var(--ink) 7%,transparent);}
.sk-cal-day.is-in,.sk-cal-day.is-out{background:var(--ink);color:var(--bg);}
.sk-cal-day.is-past{color:var(--ink-faint);opacity:.4;cursor:not-allowed;}
.sk-book-guests{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--line);}
.sk-stepper{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--line);}
.sk-stepper-label{font-size:15px;}
.sk-stepper-sub{font-size:11px;color:var(--ink-faint);letter-spacing:.06em;margin-top:2px;}
.sk-stepper-ctrl{display:flex;align-items:center;gap:16px;}
.sk-stepper-ctrl button{width:34px;height:34px;border:1px solid var(--ink);background:none;cursor:pointer;font-size:17px;color:var(--ink);border-radius:50%;transition:opacity .3s;}
.sk-stepper-ctrl button:disabled{opacity:.25;cursor:not-allowed;}
.sk-stepper-ctrl span{min-width:14px;text-align:center;font-size:15px;}
.sk-book-promo-toggle{align-self:flex-start;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}
.sk-book-promo{border:1px solid var(--line);background:var(--bg);padding:13px 14px;font-family:var(--sans);font-size:14px;color:var(--ink);letter-spacing:.08em;}
.sk-book-promo:focus{outline:none;border-color:var(--ink);}
.sk-book-submit{width:100%;margin-top:4px;}
.sk-book-done{align-items:flex-start;gap:18px;}
.sk-book-done .sk-h2-serif{font-size:27px;}
.sk-book-summary{width:100%;display:flex;flex-direction:column;}
.sk-book-summary div{display:flex;justify-content:space-between;gap:14px;padding:12px 0;border-top:1px solid var(--line);font-size:14px;}
.sk-book-summary div span:first-child{color:var(--ink-faint);font-size:11px;letter-spacing:.13em;text-transform:uppercase;padding-top:2px;}
.sk-book-summary div span:last-child{text-align:right;font-weight:400;}

.sk-why{padding:40px var(--pad) 10px;}
.sk-why-list{list-style:none;margin-top:24px;}
.sk-why-list li{font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.45;padding:17px 0;border-bottom:1px solid var(--line);}
.sk-special{padding:34px var(--pad) 70px;display:flex;flex-direction:column;gap:18px;}

/* ---------- contact ---------- */
.sk-contact-shell{gap:0;}
.sk-ctopic{display:flex;flex-direction:column;gap:12px;padding-bottom:22px;border-bottom:1px solid var(--line);}
.sk-ctopic-opts{display:flex;flex-wrap:wrap;gap:8px;}
.sk-ctopic-btn{font-family:var(--sans);font-size:12px;letter-spacing:.04em;color:var(--ink-soft);
  background:none;border:1px solid var(--line);padding:9px 14px;cursor:pointer;transition:all .35s ease;border-radius:1px;}
.sk-ctopic-btn:hover{border-color:var(--ink-faint);}
.sk-ctopic-btn.is-on{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.sk-cfield{display:flex;flex-direction:column;gap:8px;padding:18px 0;border-bottom:1px solid var(--line);}
.sk-cfield-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.sk-cinput{font-family:var(--sans);font-size:16px;font-weight:400;color:var(--ink);background:none;border:none;padding:2px 0;width:100%;}
.sk-cinput::placeholder{color:var(--ink-faint);}
.sk-cinput:focus{outline:none;}
.sk-ctextarea{resize:vertical;line-height:1.6;min-height:96px;font-family:var(--sans);}
.sk-book-submit{margin-top:22px;}
.sk-page--contact .sk-book-submit{width:100%;}
.sk-cnote{font-size:13px;color:var(--ink-soft);margin-top:16px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-weight:400;}
.sk-clink{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent);text-decoration:underline;text-underline-offset:3px;padding:0;}
.sk-cdirect{padding:46px var(--pad) 76px;display:flex;flex-direction:column;gap:8px;}
.sk-cdirect-rows{margin-top:18px;}
.sk-cdirect-row{display:flex;align-items:baseline;justify-content:space-between;gap:18px;padding:18px 0;
  border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:opacity .3s;}
a.sk-cdirect-row:hover{opacity:.62;}
.sk-cdirect-row:last-of-type{border-bottom:1px solid var(--line);}
.sk-cdirect-k{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);flex:none;padding-top:5px;}
.sk-cdirect-v{font-family:var(--sans);font-weight:600;font-size:18px;line-height:1.25;text-align:right;display:flex;flex-direction:column;gap:4px;}
.sk-cdirect-v em{font-family:var(--sans);font-style:normal;font-size:11px;letter-spacing:.06em;color:var(--ink-faint);}
.sk-chours{margin-top:22px;max-width:42ch;}

@media (prefers-reduced-motion:reduce){
  .sk-scrollcue span{animation:none;}
  *{scroll-behavior:auto !important;}
}

/* ============ sub-pages (rooftop / spa / gnou / boutique) ============ */
.sk-subpage{padding-bottom:0;}
.sk-sub-hero{position:relative;height:62dvh;min-height:420px;overflow:hidden;background:#1a1610;}
.sk-sub-hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.34),rgba(8,6,4,.1) 42%,rgba(8,6,4,.62));}
.sk-sub-hero-copy{position:absolute;left:var(--pad);right:var(--pad);bottom:34px;display:flex;flex-direction:column;gap:14px;}
.sk-sub-hero-title{font-family:var(--serif);font-weight:var(--serif-w);color:#f7f4ee;font-size:34px;line-height:1.08;letter-spacing:-.01em;text-wrap:balance;text-shadow:0 2px 24px rgba(0,0,0,.34);}
.sk-sub-intro{padding:46px var(--pad) 30px;display:flex;flex-direction:column;gap:18px;}
.sk-sub-h2{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-top:6px;}
.sk-rooftop-note{color:var(--michelin);font-weight:500;}
.sk-arrive{display:flex;flex-direction:column;gap:5px;align-items:center;text-align:center;padding:26px var(--pad) 0;}
.sk-arrive-h{font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;color:var(--ink);}
.sk-arrive-p{font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.5;color:var(--ink-soft);max-width:34ch;}
.sk-sub-lede{font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.6;color:var(--ink-soft);text-wrap:pretty;}

/* rooftop meals + gnou day/night */
.sk-meal{padding:0 0 8px;}
.sk-meal-body{padding:20px var(--pad) 36px;display:flex;flex-direction:column;gap:11px;}
.sk-meal-title{font-family:var(--sans);font-weight:600;font-size:21px;line-height:1.16;letter-spacing:-.005em;color:var(--ink);}
.sk-meal-title--light{color:#f7f4ee;}
.sk-meal-accent{font-family:var(--serif);font-weight:var(--serif-w);font-style:italic;letter-spacing:0;}
.sk-daynight{padding-bottom:4px;}
.sk-daynight-body{padding:20px var(--pad) 36px;display:flex;flex-direction:column;gap:11px;}
.sk-daynight--dark{background:#14110c;margin-top:8px;}
.sk-night-copy{color:rgba(243,239,230,.72);}

.sk-sub-block{padding:38px var(--pad) 48px;display:flex;flex-direction:column;gap:16px;}
.sk-sub-block--center{align-items:center;text-align:center;}
.sk-sub-actions{display:flex;flex-direction:column;gap:12px;margin-top:4px;}
.sk-btn-ghost{font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:15px 22px;border:1px solid var(--line);background:none;color:var(--ink);cursor:pointer;transition:border-color .4s;}
.sk-btn-ghost:hover{border-color:var(--ink);}
.sk-fineprint{font-family:var(--sans);font-weight:400;font-size:13px;line-height:1.55;color:var(--ink-faint);}
.sk-roof-menus{gap:22px;text-align:center;background:linear-gradient(180deg,rgba(246,244,239,.7),rgba(246,244,239,0));}
.sk-roof-menu-lede{max-width:31ch;margin:0 auto;}
.sk-roof-menu-grid{display:flex;flex-direction:column;gap:14px;}
.sk-roof-menu{display:flex;flex-direction:column;align-items:center;gap:11px;padding:26px 22px;border:1px solid var(--line);background:rgba(255,255,255,.28);}
.sk-roof-menu-title{font-family:var(--serif);font-weight:var(--serif-w);font-size:26px;line-height:1.08;letter-spacing:0;color:var(--ink);}
.sk-roof-menu-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:2px;}
.sk-roof-menu-list li{font-family:var(--sans);font-weight:400;font-size:14.5px;line-height:1.48;color:var(--ink);position:relative;padding-top:10px;}
.sk-roof-menu-list li::before{content:"";position:absolute;left:50%;top:0;width:18px;height:1px;background:var(--line);transform:translateX(-50%);}
.sk-roof-menu-note{max-width:32ch;margin:0 auto;}
.sk-roof-menu-actions{align-items:stretch;}

/* spa price list */
.sk-pricelist{padding:42px var(--pad) 48px;display:flex;flex-direction:column;gap:34px;}
.sk-price-group{display:flex;flex-direction:column;gap:6px;}
.sk-price-group .sk-sec-title{margin-bottom:10px;}
.sk-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:14px 0;border-top:1px solid var(--line);}
.sk-price-name{display:flex;flex-direction:column;gap:3px;}
.sk-price-name>span:first-child{font-family:var(--sans);font-weight:500;font-size:16px;color:var(--ink);}
.sk-price-detail{font-family:var(--sans);font-weight:400;font-size:12.5px;color:var(--ink-faint);}
.sk-price-val{font-family:var(--sans);font-weight:500;font-size:15px;color:var(--ink);white-space:nowrap;}

/* boutique catalogue */
.sk-prod-grid{padding:36px var(--pad) 20px;display:flex;flex-direction:column;gap:44px;}
.sk-prod-body{padding-top:18px;display:flex;flex-direction:column;gap:8px;}
.sk-prod-cat{font-family:var(--sans);font-weight:500;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);}
.sk-prod-name{font-family:var(--sans);font-weight:600;font-size:20px;line-height:1.14;letter-spacing:-.005em;color:var(--ink);}
.sk-prod-tag{font-family:var(--sans);font-weight:400;font-size:14.5px;line-height:1.5;color:var(--ink-soft);}
.sk-prod-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-top:12px;margin-top:4px;border-top:1px solid var(--line);}
.sk-prod-price{font-family:var(--sans);font-weight:500;font-size:15px;color:var(--ink);}
.sk-prod-toggle{background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.sk-prod-copy{margin-top:14px;}
.sk-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);}
.sk-prod-note{font-family:var(--sans);font-weight:400;font-size:12px;color:var(--ink-faint);margin-top:8px;font-style:italic;}
.sk-prod-gallery{position:relative;width:100%;background:#e7e2d8;overflow:hidden;}
.sk-prod-gallery-img{display:block;}
.sk-prod-gallery-btn{position:absolute;top:50%;z-index:2;width:34px;height:34px;border-radius:50%;border:1px solid rgba(246,245,242,.7);background:rgba(22,19,14,.45);color:#f6f5f2;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:23px;line-height:1;cursor:pointer;transform:translateY(-50%);backdrop-filter:blur(10px);transition:background .25s ease,border-color .25s ease;}
.sk-prod-gallery-btn--prev{left:10px;}
.sk-prod-gallery-btn--next{right:10px;}
.sk-prod-gallery-btn:active{background:rgba(22,19,14,.66);}
.sk-prod-gallery-dots{position:absolute;left:50%;bottom:12px;z-index:2;display:flex;gap:7px;transform:translateX(-50%);}
.sk-prod-gallery-dot{width:7px;height:7px;border-radius:50%;border:1px solid rgba(246,245,242,.9);background:rgba(22,19,14,.16);padding:0;cursor:pointer;}
.sk-prod-gallery-dot.is-active{background:#f6f5f2;}

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

/* sub-page closing */
.sk-subcta{padding:54px var(--pad) 66px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;border-top:1px solid var(--line);}

/* generic accordion (boutique) */
.sk-acc{overflow:hidden;height:0;transition:height .5s cubic-bezier(.4,0,.1,1);}
.sk-acc-clip{min-height:0;}

/* ---- single room page ---- */
.sk-room-gallery{width:100%;}
.sk-room-head{padding:30px var(--pad) 26px;display:flex;flex-direction:column;gap:14px;}
.sk-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;}
.sk-room-lead{font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.62;color:var(--ink-soft);text-wrap:pretty;}
.sk-room-keyline{display:flex;flex-direction:column;gap:8px;padding-top:16px;border-top:1px solid var(--line);}
.sk-room-from-big{font-family:var(--sans);font-weight:600;font-size:18px;color:var(--ink);}
.sk-room-from-big em{font-style:normal;font-weight:400;font-size:13px;color:var(--ink-faint);}
.sk-room-specs-inline{font-family:var(--sans);font-weight:400;font-size:13px;letter-spacing:.01em;color:var(--ink-soft);}
.sk-room-detailgrid{padding:14px var(--pad) 24px;display:flex;flex-direction:column;gap:30px;}
.sk-rd-block{display:flex;flex-direction:column;gap:14px;}
.sk-rd-block .sk-label{margin-bottom:0;}
.sk-rd-rows{display:flex;flex-direction:column;}
.sk-rd-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-top:1px solid var(--line);font-size:14px;line-height:1.4;}
.sk-rd-row span:first-child{color:var(--ink-faint);flex:none;}
.sk-rd-row span:last-child{text-align:right;font-weight:400;color:var(--ink);}
.sk-room-book{padding:34px var(--pad) 60px;display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--line);margin-top:14px;}
.sk-rd-amenities{margin-top:2px;padding-top:14px;border-top:1px solid var(--line);}
.sk-room-book .sk-book-shell{margin:8px 0 0;}

/* ============ home rev. 10 06 2026 (feedback) ============ */
/* circle CTA (JNcQUOI-style) */
.sk-circle{position:relative;width:104px;height:104px;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 .55s cubic-bezier(.2,.6,.2,1);flex:none;}
.sk-circle-in{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;line-height:1.5;text-align:center;-webkit-text-fill-color:currentColor;}
.sk-circle-ring{position:absolute;inset:-1px;border-radius:50%;border:1px solid currentColor;opacity:0;transform:scale(.86);
  transition:opacity .6s ease,transform .85s cubic-bezier(.2,.6,.2,1);pointer-events:none;}
.sk-circle:hover{transform:scale(1.05);}
.sk-circle:hover .sk-circle-ring{opacity:.4;transform:scale(1.14);}
.sk-circle--light{border-color:rgba(247,244,238,.82);color:#f7f4ee;}

/* hero engagement */
.sk-hero-copy{z-index:5;}
.sk-hero-zone{position:absolute;top:0;bottom:130px;background:none;border:none;cursor:pointer;z-index:3;-webkit-tap-highlight-color:transparent;}
.sk-hero-zone--l{left:0;width:34%;}
.sk-hero-zone--r{right:0;width:66%;}
.sk-hero-dots{position:absolute;left:0;right:0;bottom:34px;display:flex;justify-content:center;gap:7px;z-index:6;}
.sk-hero-dot{width:7px;height:7px;border-radius:50%;border:none;cursor:pointer;background:rgba(247,244,238,.5);transition:all .4s;padding:0;}
.sk-hero-dot.is-on{background:#f7f4ee;width:20px;border-radius:4px;}
.sk-hero-cta{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:6;}
.sk-hero-cta .sk-circle{width:128px;height:128px;}
.sk-hero-cta .sk-circle-in{font-size:9.5px;letter-spacing:.14em;line-height:1.55;}
.sk-circle-arrow{display:block;margin-top:5px;font-size:15px;letter-spacing:0;line-height:1;}

/* intro eyebrow + michelin mark */
.sk-eyebrow{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);}
.sk-eyebrow .sk-dot{opacity:.5;}
.sk-eyebrow-key{display:inline-flex;align-items:center;gap:6px;}
.sk-michelin{width:15px;height:15px;display:inline-block;vertical-align:middle;flex:none;}

/* michelin key — tappable credential accordion (intro) */
.sk-keyicon{height:20px;width:auto;flex:none;transform-origin:center;}
.sk-mkey-acc{align-self:flex-start;width:100%;}
.sk-mkey-trigger{display:inline-flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;padding:0;white-space:nowrap;}
.sk-mkey-place{font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);-webkit-text-fill-color:var(--ink-soft);}
.sk-mkey-cred{position:relative;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--michelin);-webkit-text-fill-color:var(--michelin);padding-bottom:3px;}
.sk-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);}
.sk-mkey-trigger:hover .sk-mkey-cred::after{right:0;}
.sk-mkey-plus{font-size:15px;line-height:1;color:var(--ink-faint);font-weight:400;margin-left:2px;}
.sk-mkey-panel{padding-top:18px;display:flex;flex-direction:column;align-items:flex-start;gap:13px;max-width:36ch;}
.sk-mkey-about{font-family:var(--sans);font-weight:400;font-size:13.5px;line-height:1.62;color:var(--ink-soft);text-align:left;}
.sk-mkey-line{font-family:var(--sans);font-weight:500;font-size:16px;line-height:1.45;letter-spacing:-.003em;color:var(--ink);text-align:left;text-wrap:balance;}
.sk-mkey-link{font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--michelin);-webkit-text-fill-color:var(--michelin);text-decoration:none;position:relative;padding-bottom:3px;margin-top:2px;}
.sk-mkey-link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--michelin);transition:right .5s cubic-bezier(.2,.6,.2,1);}
.sk-mkey-link:hover::after{right:0;}
/* luxurious entrance — fade + rise, with the key drawing in */
@media (prefers-reduced-motion:no-preference){
  .sk-mkey-trigger{opacity:0;animation:mkeyRise 1s cubic-bezier(.2,.6,.2,1) .25s both;}
  .sk-keyicon{opacity:0;animation:keyDraw 1.1s cubic-bezier(.2,.7,.2,1) .42s both;}
}
@keyframes mkeyRise{from{opacity:0;transform:translateY(9px);}to{opacity:1;transform:none;}}
@keyframes keyDraw{0%{opacity:0;transform:scale(.72) rotate(-12deg);}60%{opacity:1;}100%{opacity:1;transform:none;}}

/* room moods head (centered) */
.sk-stay{padding:0 var(--pad) 22px;}
.sk-connector{display:flex;justify-content:center;}
.sk-connector::before{content:"";width:1px;height:62px;background:var(--ink-faint);}
.sk-moods-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;margin-bottom:42px;padding-top:30px;}
.sk-moods-teaser{font-family:var(--sans);font-weight:500;font-size:19px;letter-spacing:.01em;color:var(--ink);}
.sk-moods-sub{font-size:14px;font-weight:400;color:var(--ink-soft);max-width:30ch;}

/* rooftop / spa / lobby — unified fullwidth 4:3 image tiles */
.sk-tile{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:#1a1610;margin-bottom:8px;}
.sk-tile-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.12),rgba(8,6,4,0) 38%,rgba(8,6,4,.66));}
.sk-tile-copy{position:absolute;left:var(--pad);right:var(--pad);bottom:30px;display:flex;flex-direction:column;align-items:flex-start;gap:9px;}
.sk-tile-sub{font-family:var(--sans);font-weight:400;font-size:15px;line-height:1.4;color:#f3efe6;text-shadow:0 1px 14px rgba(0,0,0,.5);max-width:30ch;}
.sk-tile-cta{font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#f7f4ee;-webkit-text-fill-color:#f7f4ee;text-shadow:0 1px 12px rgba(0,0,0,.5);}

/* rooftop band — image first, text below */
.sk-band{padding:62px var(--pad);}
.sk-band-figure{position:relative;}
.sk-band-cta{position:absolute;right:16px;bottom:16px;z-index:2;}
.sk-band-cta .sk-circle{width:98px;height:98px;}
.sk-band-cta .sk-circle-in{font-size:9.5px;letter-spacing:.15em;line-height:1.5;}
.sk-band-body{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding-top:24px;}
.sk-band-text{font-family:var(--sans);font-weight:400;font-size:19px;line-height:1.42;max-width:22ch;text-wrap:balance;}

/* spa — immersive text over image (white) */
.sk-immersive{position:relative;height:70dvh;min-height:460px;overflow:hidden;background:#1a1610;}
.sk-immersive-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.36),rgba(8,6,4,.12) 45%,rgba(8,6,4,.5));}
.sk-immersive-copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:24px;padding:0 var(--pad);}
.sk-immersive-copy--left{align-items:flex-start;justify-content:flex-end;text-align:left;gap:14px;padding:0 var(--pad) 42px;}
.sk-immersive-copy--left .sk-immersive-text{max-width:22ch;}
.sk-spa-cta{position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);z-index:3;}
.sk-spa-cta .sk-circle{width:104px;height:104px;}
.sk-spa-cta .sk-circle-in{font-size:9.5px;letter-spacing:.15em;line-height:1.5;}
.sk-immersive-text{font-family:var(--sans);font-weight:400;color:#f7f4ee;font-size:22px;line-height:1.38;text-wrap:balance;max-width:22ch;text-shadow:0 2px 24px rgba(0,0,0,.34);}

/* the lobby — centered white text over full-bleed square */
.sk-lobby{padding:0;margin-top:16px;}
.sk-lobby-text{font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.5;max-width:26ch;text-wrap:balance;}
.sk-lobby-text--over{color:#f7f4ee;}

/* square image block (lobby + boutique) */
.sk-square{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;background:#e7e2d8;}
.sk-square-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.22),rgba(8,6,4,.08) 32%,rgba(8,6,4,.74));}
.sk-square--center .sk-square-scrim{background:linear-gradient(180deg,rgba(8,6,4,.44),rgba(8,6,4,.3) 50%,rgba(8,6,4,.5));}
.sk-square-copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;text-align:center;gap:15px;padding:0 26px 34px;}
.sk-square-copy--center{justify-content:center;gap:18px;padding:0 30px;}
.sk-square-copy--left{align-items:flex-start;text-align:left;gap:9px;padding:0 26px 32px;}
.sk-boutique-cta{position:absolute;right:16px;top:40%;transform:translateY(-50%);z-index:3;}
.sk-boutique-cta .sk-circle{width:90px;height:90px;}
.sk-boutique-cta .sk-circle-in{font-size:10px;letter-spacing:.16em;}
.sk-square-title{font-family:var(--sans);font-weight:600;font-size:26px;color:#f7f4ee;letter-spacing:-.005em;-webkit-text-fill-color:#f7f4ee;text-shadow:0 2px 18px rgba(0,0,0,.5);}
.sk-square-sub{font-size:14px;font-weight:400;color:#f3efe6;max-width:26ch;text-shadow:0 1px 14px rgba(0,0,0,.6);}

/* boutique — above the house */
.sk-boutique-sec{padding:60px var(--pad);}

/* step link (subtle underline grow on hover) */
.sk-step-link{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink);padding:5px 0;position:relative;align-self:center;}
.sk-step-link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--ink);transition:right .45s cubic-bezier(.2,.6,.2,1);}
.sk-step-link:hover::after{right:0;}
.sk-step-link--light{color:#f7f4ee;}
.sk-step-link--light::after{background:#f7f4ee;}

/* centered editorial heads (house / neighbourhood / beyond) */
.sk-sec-title{font-family:var(--sans);font-weight:600;font-size:23px;line-height:1.12;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);-webkit-text-fill-color:currentColor;}
.sk-sec-title--light{color:#f7f4ee;-webkit-text-fill-color:#f7f4ee;text-shadow:0 2px 18px rgba(0,0,0,.45);}
.sk-centered-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;}
.sk-centered-text{font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.5;text-wrap:balance;max-width:28ch;}
.sk-centered-sub{font-size:15px;line-height:1.6;font-weight:400;color:var(--ink-soft);max-width:34ch;text-wrap:balance;}

/* the house — centered + horizontal rail */
.sk-house{padding:72px var(--pad) 62px;display:flex;flex-direction:column;gap:32px;}
.sk-house-rail{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x proximity;margin:0 calc(var(--pad)*-1);padding:0 var(--pad);-webkit-overflow-scrolling:touch;}
.sk-house-rail::-webkit-scrollbar{display:none;}
.sk-rail-cell{flex:0 0 40%;aspect-ratio:3/4;scroll-snap-align:start;overflow:hidden;}

/* neighbourhood — centered + letterbox band */
.sk-hood{padding:68px var(--pad) 18px;display:flex;flex-direction:column;gap:28px;}
.sk-hood-h{font-family:var(--sans);font-weight:400;font-size:20px;line-height:1.34;margin:0;text-wrap:balance;max-width:24ch;}

/* beyond — centered + letterbox band + concierge note (no CTA) */
.sk-beyond{padding:42px var(--pad) 78px;display:flex;flex-direction:column;gap:26px;}
.sk-beyond-note{font-size:14px;line-height:1.62;font-weight:400;color:var(--ink-soft);text-align:center;max-width:40ch;margin:0 auto;text-wrap:pretty;}
.sk-fullbleed{margin-left:calc(var(--pad)*-1);margin-right:calc(var(--pad)*-1);width:calc(100% + var(--pad)*2) !important;}
.sk-staytile{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:46px 0 8px;}
.sk-staytile-h{font-family:var(--serif);font-weight:var(--serif-w);font-size:34px;line-height:1.04;letter-spacing:-.012em;color:var(--ink);}
.sk-staytile-cta{font-family:var(--sans);font-weight:500;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:none;border:none;cursor:pointer;border-bottom:1px solid var(--ink);padding:0 0 4px;margin-top:4px;}
