/* ============================================================================
   MONSUAU — Cala d'Or · Adults-only
   Concept: "THE SUN HOURS" — the hotel read as one Mallorcan day told by the
   light, laid along a sundial. Signature motif: a thin charcoal SOLAR ARC with
   hour-ticks + a travelling sun-bead, and each section is a station of the day
   carried by an hour-mark (time · sun-angle glyph). Palette pulled from the real
   sky-lounge sunset: charcoal ink, blush/travertine paper, sunset gold.
   Lane: Bodoni Moda (display) + Inter (body). Charcoal + blush, refined.
   ========================================================================== */

:root{
  /* — palette, from the property's own light — */
  --ink:#211c1a;            /* charcoal — the silhouetted hills at dusk     */
  --ink-soft:#4a403b;       /* softened ink for body                        */
  --paper:#f4e9e2;          /* warm travertine / blush — the daytime paper  */
  --paper-2:#efe0d7;        /* a half-tone blush for alternating bands      */
  --paper-3:#e7d6cc;        /* deeper blush, hairlines on light             */
  --cream:#fbf5f1;          /* near-white card                              */
  --gold:#c08a3c;           /* sunset gold — the accent (deeper for AA)     */
  --gold-bright:#d9a24e;    /* brighter gold for dark grounds               */
  --gold-brand:#c8b783;     /* the real logo gold — used sparingly (stars)  */
  --blush-deep:#b86a4e;     /* the coral of the cocktail — rare warm note   */
  --aqua:#5fb6ad;           /* pool turquoise — a RARE secondary glint      */
  --line:#d8c4b8;           /* hairline on paper                            */
  --line-ink:rgba(255,255,255,.16); /* hairline on ink                     */

  --shadow:0 1px 0 rgba(33,28,26,.04), 0 22px 50px -28px rgba(33,28,26,.30);
  --shadow-lg:0 40px 90px -50px rgba(33,28,26,.55);

  --pad:clamp(1.15rem, 5vw, 6rem);
  --maxw:1240px;
  --r:3px;                  /* sharp, refined edge — barely-there radius     */

  --serif:"Bodoni Moda", "Didot", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.55s var(--ease);
}

/* ----------------------------------------------------------------- reset -- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--gold);color:var(--cream)}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;
  word-break:keep-all;overflow-wrap:normal;hyphens:none;
  letter-spacing:-.01em;font-optical-sizing:auto}
em{font-style:italic}

.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink);
  color:var(--cream);padding:.7em 1.1em;border-radius:var(--r)}
.skip:focus{left:.6rem;top:.6rem}

/* ====================================================== shared atoms ====== */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* kicker = the hour-mark: TIME · sun glyph · station label */
.kicker{display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-size:.74rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.kicker--light{color:var(--gold-bright)}
.kicker__time{font-variant-numeric:tabular-nums;color:inherit;
  padding:.18em .5em;border:1px solid currentColor;border-radius:100px;
  font-size:.72em;letter-spacing:.12em}
.kicker__sun{width:1.05em;height:1.05em;flex:0 0 auto;display:inline-block}
.kicker__sun path,.kicker__sun line,.kicker__sun circle{stroke:currentColor;
  stroke-width:1.4;fill:none;stroke-linecap:round}

.eyebrow{font-family:var(--sans);font-size:.76rem;font-weight:600;
  letter-spacing:.26em;text-transform:uppercase}

/* buttons */
.btn{--bg:var(--ink);--fg:var(--cream);--bd:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  min-height:50px;padding:.05em 1.7em;border-radius:100px;
  font-family:var(--sans);font-weight:600;font-size:.86rem;letter-spacing:.04em;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  transition:transform .25s var(--ease), background .3s var(--ease),
             color .3s var(--ease), box-shadow .3s var(--ease);
  will-change:transform}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.btn--solid{--bg:var(--gold);--fg:var(--cream);--bd:var(--gold);
  box-shadow:0 14px 30px -16px rgba(192,138,60,.8)}
.btn--solid:hover{--bg:#a9762f;--bd:#a9762f}
.btn--ink{--bg:var(--ink);--fg:var(--cream);--bd:var(--ink)}
.btn--ink:hover{--bg:#000;--bd:#000}
.btn--line{--bg:transparent;--fg:var(--ink);--bd:var(--ink)}
.btn--line:hover{--bg:var(--ink);--fg:var(--cream)}
.btn--ghost{--bg:transparent;--fg:var(--cream);--bd:rgba(251,245,241,.55)}
.btn--ghost:hover{--bg:var(--cream);--fg:var(--ink);--bd:var(--cream)}
.btn--lg{min-height:56px;padding-inline:2em;font-size:.92rem}

/* a small "tick link" — gold underline that draws on hover */
.tick{position:relative;font-weight:600;color:var(--gold);
  letter-spacing:.02em;white-space:nowrap;
  display:inline-flex;align-items:center;min-height:44px;padding-block:.3em}
.tick::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:100%;
  background:currentColor;transform:scaleX(.0);transform-origin:left;
  transition:transform .4s var(--ease)}
.tick:hover::after{transform:scaleX(1)}
.tick--light{color:var(--gold-bright)}

/* the SOLAR ARC — signature motif, pure SVG light-DOM (no <use> shadow) */
.arc{display:block;width:100%;height:auto;overflow:visible}
.arc__curve{fill:none;stroke:currentColor;stroke-width:1.2;opacity:.6}
.arc__tick{stroke:currentColor;stroke-width:1.2;opacity:.5}
.arc__bead{fill:var(--gold);stroke:none}
.arc__bead-ring{fill:none;stroke:var(--gold);stroke-width:1.2;opacity:.5}

/* section heading cluster */
.lead{max-width:46ch}
.lead--wide{max-width:60ch}
.title{font-size:clamp(2.1rem,1.4rem + 3.3vw,4rem)}
.title--xl{font-size:clamp(2.5rem,1.5rem + 4.6vw,5.2rem)}
.title em{color:var(--gold)}
.measure{max-width:54ch;color:var(--ink-soft)}

/* reveal-on-scroll */
.rise{opacity:0;transform:translateY(26px);
  transition:opacity .8s var(--ease), transform .8s var(--ease)}
.is-in .rise,.rise.is-in{opacity:1;transform:none}
.rise.d1{transition-delay:.08s}.rise.d2{transition-delay:.16s}
.rise.d3{transition-delay:.24s}.rise.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .rise{opacity:1!important;transform:none!important;transition:none!important}
}

/* ============================================================ HEADER ====== */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:clamp(.7rem,1.6vw,1.15rem) var(--pad);
  transition:background .4s var(--ease), box-shadow .4s var(--ease),
             padding .4s var(--ease);}
.nav::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--line-ink);opacity:1;transition:opacity .4s var(--ease)}
.nav__brand{display:inline-flex;align-items:center;min-height:44px}
.nav__logo{height:clamp(34px,4.6vw,46px);width:auto;
  filter:drop-shadow(0 1px 10px rgba(0,0,0,.28))}
.nav__logo--dark{display:none}
.nav__links{display:flex;gap:clamp(1rem,2vw,2rem);align-items:center}
.nav__links a{font-size:.82rem;font-weight:500;letter-spacing:.04em;
  color:var(--cream);opacity:.9;transition:opacity .25s, color .25s;
  position:relative;display:inline-flex;align-items:center;min-height:44px;padding:.2em 0}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;
  width:100%;background:var(--gold-bright);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__right{display:flex;align-items:center;gap:clamp(.7rem,1.5vw,1.3rem)}

.lang{display:flex;align-items:center;gap:.15em}
.lang__btn{font-size:.78rem;font-weight:600;letter-spacing:.05em;
  color:var(--cream);opacity:.55;padding:.35em .42em;min-height:44px;min-width:34px;
  display:inline-flex;align-items:center;justify-content:center;
  transition:opacity .25s,color .25s}
.lang__btn.is-active{opacity:1;color:var(--gold-bright)}
.lang__btn:hover{opacity:.9}
.lang__sep{opacity:.35;color:var(--cream);font-size:.7rem}

.nav__book{min-height:44px;padding-inline:1.25em;font-size:.8rem}

/* scrolled / on-light state */
.nav.is-solid{background:rgba(251,245,241,.92);
  -webkit-backdrop-filter:blur(12px) saturate(1.3);backdrop-filter:blur(12px) saturate(1.3);
  box-shadow:0 10px 40px -28px rgba(33,28,26,.45)}
.nav.is-solid::after{opacity:0}
.nav.is-solid .nav__logo--light{display:none}
.nav.is-solid .nav__logo--dark{display:block;filter:none}
.nav.is-solid .nav__links a{color:var(--ink-soft);opacity:.85}
.nav.is-solid .nav__links a:hover{color:var(--ink)}
.nav.is-solid .lang__btn{color:var(--ink-soft)}
.nav.is-solid .lang__btn.is-active{color:var(--gold)}
.nav.is-solid .lang__sep{color:var(--ink-soft)}
.nav.is-solid .nav__book.btn--ghost{--fg:var(--ink);--bd:var(--ink)}
.nav.is-solid .nav__book.btn--ghost:hover{--bg:var(--ink);--fg:var(--cream)}

/* burger (mobile) */
.burger{display:none;width:46px;height:46px;border-radius:var(--r);
  align-items:center;justify-content:center;flex:0 0 auto}
.burger span{display:block;width:22px;height:1.6px;background:var(--cream);
  position:relative;transition:background .25s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;
  width:22px;height:1.6px;background:var(--cream);transition:transform .3s var(--ease)}
.burger span::before{top:-6.5px}.burger span::after{top:6.5px}
.nav.is-solid .burger span,.nav.is-solid .burger span::before,
.nav.is-solid .burger span::after{background:var(--ink)}
.nav.is-open .burger span{background:transparent}
.nav.is-open .burger span::before{transform:translateY(6.5px) rotate(45deg)}
.nav.is-open .burger span::after{transform:translateY(-6.5px) rotate(-45deg)}

/* ============================================================== HERO ====== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  isolation:isolate;overflow:hidden;background:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:62% 50%;
  transform:scale(1.06);animation:heroDrift 22s var(--ease) forwards}
@keyframes heroDrift{to{transform:scale(1)}}
@media (prefers-reduced-motion:reduce){.hero__media img{animation:none;transform:none}}
/* scrim: dark up top-left for the headline + warm gradient bottom */
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(20,16,15,.62) 0%, rgba(20,16,15,.10) 32%, rgba(20,16,15,0) 50%),
    linear-gradient(8deg, rgba(20,16,15,.86) 4%, rgba(20,16,15,.30) 38%, rgba(20,16,15,0) 66%),
    radial-gradient(120% 80% at 18% 88%, rgba(20,16,15,.55), rgba(20,16,15,0) 60%)}
.hero__grain{position:absolute;inset:0;z-index:-1;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.hero__inner{position:relative;z-index:2;width:100%;
  padding:0 var(--pad) clamp(1.6rem,4vw,3rem);
  display:grid;gap:clamp(1rem,2.2vw,1.5rem)}
.hero__inner > *{max-width:min(20ch,100%)}
.hero__eyebrow{color:var(--gold-bright);
  display:inline-flex;align-items:center;gap:.7em;max-width:none}
.hero__eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--gold-bright);
  box-shadow:0 0 0 4px rgba(217,162,78,.18)}
.hero__title{color:var(--cream);font-size:clamp(2.9rem,1.5rem + 7vw,7.4rem);
  letter-spacing:-.018em;text-shadow:0 2px 40px rgba(0,0,0,.35);max-width:none}
.hero__title .ln{display:block}
.hero__title em{color:var(--gold-bright);font-style:italic}
.hero__sub{color:rgba(251,245,241,.92);font-size:clamp(1rem,.95rem + .5vw,1.2rem);
  max-width:42ch;line-height:1.58;text-shadow:0 1px 20px rgba(0,0,0,.4)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.7rem;max-width:none;margin-top:.3rem}

/* the SOLAR ARC riding the foot of the hero = the signature moment */
.hero__arc{position:relative;z-index:2;max-width:none;margin-top:clamp(.8rem,2vw,1.4rem)}
.hero__arc .arc{color:rgba(251,245,241,.78)}
.hero__arc .arc__bead{fill:var(--gold-bright)}
.hero__arc .arc__bead-ring{stroke:var(--gold-bright)}
.hero__arclabels{display:flex;justify-content:space-between;margin-top:.5em;
  font-family:var(--sans);font-size:.66rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(251,245,241,.7)}
.hero__arclabels b{color:var(--gold-bright);font-weight:600}

.hero__scroll{position:absolute;right:var(--pad);bottom:clamp(1.6rem,4vw,3rem);z-index:3;
  display:inline-flex;flex-direction:column;align-items:center;gap:.5em;
  font-family:var(--sans);font-size:.64rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(251,245,241,.8)}
.hero__scroll svg{width:16px;height:30px}
.hero__scroll line,.hero__scroll path{stroke:var(--gold-bright);stroke-width:1.4;
  fill:none;stroke-linecap:round}
.hero__scroll .dot{animation:scrollDot 1.8s var(--ease) infinite}
@keyframes scrollDot{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(4px);opacity:1}}
@media (prefers-reduced-motion:reduce){.hero__scroll .dot{animation:none}}

/* ====================================================== DAY / SUNDIAL ====== */
.day{background:var(--ink);color:var(--paper);position:relative;overflow:hidden;
  padding-block:clamp(3.4rem,8vw,7rem)}
.day__grain{position:absolute;inset:0;opacity:.04;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.day__inner{position:relative;display:grid;gap:clamp(2rem,4vw,3.2rem)}
.day__top{display:grid;grid-template-columns:minmax(0,1fr);gap:1.4rem;
  align-items:end}
@media(min-width:860px){.day__top{grid-template-columns:1.3fr .9fr}}
.day__title{color:var(--cream);font-size:clamp(2rem,1.3rem + 3.4vw,3.7rem);max-width:18ch}
.day__title em{color:var(--gold-bright)}
.day__intro{color:rgba(244,233,226,.82);max-width:50ch;align-self:end}

/* the day-strip: four stations along the arc */
.dial{position:relative;padding-top:clamp(2rem,5vw,3.5rem)}
.dial .arc{color:rgba(244,233,226,.45)}
.dial .arc__bead{fill:var(--gold-bright)}
.stations{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(.5rem,1.5vw,1.4rem);margin-top:1.4rem}
.station{display:grid;gap:.35em;min-width:0}
.station__time{font-family:var(--serif);font-size:clamp(1.2rem,.9rem+1vw,1.7rem);
  color:var(--gold-bright);font-variant-numeric:tabular-nums;line-height:1}
.station__k{font-family:var(--sans);font-size:.7rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--cream)}
.station__v{font-size:.84rem;color:rgba(244,233,226,.62);line-height:1.45}
@media(max-width:560px){
  .stations{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem 1rem}
}

/* ============================================== generic section frame ===== */
.section{padding-block:clamp(3.4rem,8vw,7rem);position:relative}
.section--blush{background:var(--paper-2)}
.section__head{display:grid;gap:.9rem;margin-bottom:clamp(1.8rem,4vw,3rem);
  max-width:var(--maxw)}
.section__head .title{margin-top:.1em}

/* ===================================================== POOL (midday) ====== */
.pool__grid{display:grid;gap:clamp(1.1rem,2.4vw,1.8rem);
  grid-template-columns:minmax(0,1fr)}
@media(min-width:880px){
  .pool__grid{grid-template-columns:1.35fr .9fr;align-items:stretch}
}
.pool__main{position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);min-height:clamp(280px,46vw,520px)}
.pool__main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pool__main .frametag{position:absolute;left:1rem;bottom:1rem;z-index:2}
.pool__side{display:grid;gap:clamp(1.1rem,2.4vw,1.8rem);
  grid-template-rows:auto 1fr}
.pool__note{background:var(--ink);color:var(--paper);border-radius:var(--r);
  padding:clamp(1.3rem,3vw,2rem);display:grid;gap:.7em;align-content:center;
  box-shadow:var(--shadow)}
.pool__note h3{color:var(--cream);font-size:clamp(1.3rem,1rem+1.3vw,1.9rem)}
.pool__note h3 em{color:var(--gold-bright)}
.pool__note p{color:rgba(244,233,226,.82);font-size:.95rem}
.pool__fig{position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);min-height:160px}
.pool__fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.frametag{font-family:var(--sans);font-size:.66rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--cream);
  background:rgba(20,16,15,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  padding:.4em .8em;border-radius:100px;display:inline-flex;gap:.5em;align-items:center}
.frametag .d{width:5px;height:5px;border-radius:50%;background:var(--aqua)}

/* facts strip under pool */
.facts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  border-top:1px solid var(--line);margin-top:clamp(1.8rem,4vw,2.6rem)}
.fact{padding:1.3rem .2rem .2rem;display:grid;gap:.25em;min-width:0}
.fact__n{font-family:var(--serif);font-size:clamp(1.5rem,1.1rem+1.4vw,2.3rem);
  color:var(--ink);line-height:1}
.fact__n em{color:var(--gold);font-style:normal}
.fact__k{font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft)}
@media(max-width:620px){.facts{grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem 1rem}
  .fact{border-top:1px solid var(--line)}
  .facts{border-top:none}}

/* ===================================================== ROOMS (afternoon) == */
.rooms__head{display:grid;gap:.9rem;margin-bottom:clamp(1.8rem,4vw,2.8rem)}
.roomgrid{display:grid;gap:clamp(1rem,2.2vw,1.6rem);
  grid-template-columns:minmax(0,1fr)}
@media(min-width:720px){.roomgrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.room{position:relative;border-radius:var(--r);overflow:hidden;background:var(--ink);
  box-shadow:var(--shadow);isolation:isolate;min-height:clamp(330px,52vw,440px);
  display:flex;align-items:flex-end}
.room__media{position:absolute;inset:0;z-index:-2}
.room__media img{width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease)}
.room:hover .room__media img{transform:scale(1.05)}
.room__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(0deg, rgba(20,16,15,.88) 2%, rgba(20,16,15,.35) 40%, rgba(20,16,15,0) 72%)}
.room__no{position:absolute;top:1rem;right:1.1rem;z-index:1;
  font-family:var(--serif);font-size:.9rem;color:var(--gold-bright);
  letter-spacing:.1em}
.room__body{padding:clamp(1.2rem,3vw,1.8rem);display:grid;gap:.5em;width:100%}
.room__name{color:var(--cream);font-size:clamp(1.45rem,1.1rem+1.5vw,2.1rem)}
.room__name em{color:var(--gold-bright)}
.room__txt{color:rgba(244,233,226,.86);font-size:.92rem;max-width:42ch}
.room__meta{display:flex;flex-wrap:wrap;gap:.45em;list-style:none;margin-top:.3em}
.room__meta li{font-size:.7rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--paper);
  border:1px solid var(--line-ink);border-radius:100px;padding:.35em .75em}
.room--wide{grid-column:1/-1}
@media(min-width:720px){.room--wide{min-height:clamp(300px,30vw,380px)}}

.rooms__foot{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1.2rem;
  margin-top:clamp(1.6rem,3vw,2.2rem);padding-top:1.3rem;
  border-top:1px solid var(--line);color:var(--ink-soft);font-size:.95rem}

/* ============================================ SKY LOUNGE (golden hour) ===== */
.sky{position:relative;background:var(--ink);color:var(--paper);overflow:hidden;
  padding-block:clamp(3.6rem,8vw,7.5rem)}
.sky__bg{position:absolute;inset:0;z-index:0}
.sky__bg img{width:100%;height:100%;object-fit:cover;opacity:.42}
.sky__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(20,16,15,.7), rgba(20,16,15,.55)),
    radial-gradient(120% 120% at 80% 10%, rgba(217,162,78,.22), rgba(20,16,15,0) 55%)}
.sky__inner{position:relative;z-index:1;display:grid;gap:clamp(1.8rem,4vw,3rem);
  grid-template-columns:minmax(0,1fr)}
@media(min-width:900px){.sky__inner{grid-template-columns:1.05fr .95fr;align-items:center}}
.sky__copy{display:grid;gap:1.1rem;max-width:52ch}
.sky__title{color:var(--cream);font-size:clamp(2.1rem,1.4rem+3.2vw,3.9rem)}
.sky__title em{color:var(--gold-bright)}
.sky__copy p{color:rgba(244,233,226,.86)}
.sky__copy .lede{font-size:clamp(1.05rem,1rem+.4vw,1.25rem);color:var(--paper)}
.sky__media{position:relative;display:grid;gap:clamp(.8rem,1.8vw,1.2rem);
  grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
.sky__shot{position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-lg)}
.sky__shot img{width:100%;height:100%;object-fit:cover;display:block}
.sky__shot--tall{grid-row:span 2;min-height:clamp(260px,40vw,440px)}
.sky__shot--a{min-height:120px}
.sky__shot--b{min-height:120px}
.sky__hours{display:flex;gap:.4em;align-items:center;flex-wrap:wrap;
  font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold-bright)}
.sky__hours .arc{color:rgba(244,233,226,.4);width:80px;height:24px}

/* ================================================ DINING (after dark) ===== */
.dine__grid{display:grid;gap:clamp(1.1rem,2.4vw,1.8rem);
  grid-template-columns:minmax(0,1fr)}
@media(min-width:860px){.dine__grid{grid-template-columns:.95fr 1.05fr;align-items:center}}
.dine__copy{display:grid;gap:1rem;max-width:50ch}
.dine__copy .title em{color:var(--gold)}
.dine__venues{display:grid;gap:.8rem;margin-top:.6rem}
.venue{display:flex;gap:.9rem;align-items:baseline;
  padding:.9rem 0;border-top:1px solid var(--line)}
.venue__name{font-family:var(--serif);font-size:1.2rem;color:var(--ink);flex:0 0 auto;
  min-width:5.5em}
.venue__name em{color:var(--gold)}
.venue__txt{font-size:.92rem;color:var(--ink-soft)}
.dine__media{display:grid;grid-template-columns:1fr 1fr;gap:clamp(.8rem,1.8vw,1.2rem)}
.dine__shot{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.dine__shot img{width:100%;height:100%;object-fit:cover;display:block;min-height:200px}
.dine__shot--tall{grid-row:span 2;min-height:clamp(280px,40vw,460px)}

/* ===================================================== SETTING / map ====== */
.setting{position:relative;min-height:clamp(440px,60vh,640px);
  display:flex;align-items:center;overflow:hidden;color:var(--paper);isolation:isolate}
.setting__bg{position:absolute;inset:0;z-index:-2}
.setting__bg img{width:100%;height:100%;object-fit:cover}
.setting__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg, rgba(20,16,15,.84) 0%, rgba(20,16,15,.5) 46%, rgba(20,16,15,.12) 100%)}
.setting__panel{max-width:46ch;display:grid;gap:1rem}
.setting__title{color:var(--cream);font-size:clamp(1.9rem,1.3rem+3vw,3.4rem)}
.setting__title em{color:var(--gold-bright)}
.setting__panel p{color:rgba(244,233,226,.88)}
.dist{display:grid;gap:0;margin-top:.6rem}
.dist__row{display:flex;justify-content:space-between;gap:1rem;
  padding:.7em 0;border-top:1px solid var(--line-ink);font-size:.92rem}
.dist__row dt{color:rgba(244,233,226,.72)}
.dist__row dd{color:var(--cream);font-weight:600;font-variant-numeric:tabular-nums;
  text-align:right}

/* ========================================================== BOOK ========== */
.book{background:var(--paper-2);position:relative;overflow:hidden;
  padding-block:clamp(3.6rem,8vw,7rem)}
.book__inner{position:relative;display:grid;gap:clamp(1.4rem,3vw,2rem);
  text-align:center;justify-items:center;max-width:62ch;margin-inline:auto}
.book__arc{width:min(280px,70%);color:var(--line)}
.book__arc .arc__bead{fill:var(--gold)}
.book__kick{justify-self:center}
.book__title{font-size:clamp(2.2rem,1.5rem+3.6vw,4.4rem)}
.book__title em{color:var(--gold)}
.book__txt{color:var(--ink-soft);max-width:48ch}
.book__cta{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:.3rem}
.book__contact{display:flex;flex-wrap:wrap;gap:.6rem 1.6rem;justify-content:center;
  align-items:center;margin-top:1rem;font-size:.92rem;color:var(--ink-soft)}
.book__contact a{font-weight:600;color:var(--ink);
  display:inline-flex;align-items:center;min-height:44px}
.book__contact a:hover{color:var(--gold)}
.book__rating{display:inline-flex;align-items:center;gap:.4em}
.book__rating .star{color:var(--gold)}

/* ========================================================= FOOTER ========= */
.foot{background:var(--ink);color:var(--paper);padding-block:clamp(2.6rem,5vw,4rem)}
.foot__grid{display:grid;gap:clamp(1.8rem,4vw,3rem);
  grid-template-columns:minmax(0,1fr)}
@media(min-width:760px){.foot__grid{grid-template-columns:1.4fr 1fr 1fr}}
.foot__brand{display:grid;gap:.8rem;align-content:start}
.foot__logo{height:46px;width:auto}
.foot__place{color:rgba(244,233,226,.6);font-size:.9rem;display:flex;
  align-items:center;gap:.5em}
.foot__place .d{width:4px;height:4px;border-radius:50%;background:var(--gold-bright)}
.foot__col h3{font-family:var(--sans);font-size:.76rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:.9rem}
.foot__col p{color:rgba(244,233,226,.78);font-size:.92rem;margin-bottom:.1rem}
.foot__col p a{display:inline-flex;align-items:center;min-height:44px}
.foot__col a:hover{color:var(--gold-bright)}
.foot__book{margin-top:.7rem}
.foot__base{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem 1rem;
  margin-top:clamp(2rem,4vw,3rem);padding-top:1.3rem;border-top:1px solid var(--line-ink);
  font-size:.8rem;color:rgba(244,233,226,.55)}
.foot__sign{font-family:var(--serif);font-style:italic;color:rgba(244,233,226,.7)}

/* ===================================================== MOBILE NAV ========= */
@media(max-width:880px){
  .burger{display:inline-flex}
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);
    flex-direction:column;align-items:flex-start;justify-content:center;
    gap:1.3rem;padding:2.2rem var(--pad);
    background:var(--ink);transform:translateX(105%);
    transition:transform .45s var(--ease);box-shadow:var(--shadow-lg);z-index:90}
  .nav__links a{color:var(--paper);font-size:1.15rem;opacity:.95}
  .nav__links a::after{background:var(--gold-bright)}
  .nav.is-open .nav__links{transform:translateX(0)}
  .nav.is-open::after{opacity:0}
  /* keep lang + book always visible in the bar */
  .nav__right{z-index:95}
  .nav__book{display:none}
  .nav.is-open .nav__links .nav__book{display:inline-flex;margin-top:.6rem}
}
@media(max-width:420px){
  .lang__btn{padding-inline:.22em}
  .hero__scroll{display:none}
}

/* tablet tweaks */
@media(min-width:560px) and (max-width:880px){
  .roomgrid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* print / no-js safety */
.no-js .rise{opacity:1;transform:none}
@media print{.nav,.hero__scroll,.burger{display:none}}
