/* ============================================================
   SHABEELAY — shared design system
   Leopard-coat palette · Fraunces + Jost · grain · hairline
   rules · guest-facing components · booking flow.
   ============================================================ */

:root{
  --sand:#F4EFE6; --bone:#EFE9DD; --paper:#FBF8F2;
  --ink:#1A1510; --ink-soft:#2a241c; --muted:#6a6052;
  --ochre:#A85A2E; --clay:#C8743C;
  --gold:#C8973C; --gold-soft:#E8D9B0;
  --green:#27382B; --green-deep:#1E2C22;
  --indigo:#243042; --indigo-deep:#1a2330;
  --rule:rgba(168,90,46,0.20);
  --rule-soft:rgba(168,90,46,0.12);
  --line-dark:rgba(239,233,221,0.16);
  --ease:cubic-bezier(0.16,1,0.3,1);
  --ease-slow:cubic-bezier(0.7,0,0.2,1);
  --maxw:1280px;
  --nav-h:74px; --bar-h:64px;
  /* warm, ink-tinted elevation — a consistent depth language */
  --sh-1:0 2px 8px rgba(26,21,16,.06),0 8px 24px -12px rgba(26,21,16,.10);
  --sh-2:0 10px 30px -12px rgba(26,21,16,.16);
  --sh-3:0 30px 60px -28px rgba(26,21,16,.34);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--sand);color:var(--ink);font-family:'Jost',system-ui,sans-serif;
  font-weight:400;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
@media (hover:hover) and (pointer:fine){body{cursor:none}}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
.serif{font-family:'Fraunces',Georgia,serif}
em{font-style:italic}
::selection{background:var(--gold-soft);color:var(--ink)}

/* ---------- texture / cursor -------------------------------- */
.grain{position:fixed;inset:0;pointer-events:none;z-index:9990;opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:9995;pointer-events:none;border-radius:50%;
  transform:translate(-50%,-50%)}
.cursor{width:32px;height:32px;border:1px solid var(--gold);
  transition:width .35s var(--ease),height .35s var(--ease),background .35s var(--ease),opacity .3s}
.cursor-dot{width:5px;height:5px;background:var(--gold)}
.cursor.is-link{width:58px;height:58px;background:rgba(200,151,60,.10)}
body.cursor-hidden .cursor,body.cursor-hidden .cursor-dot{opacity:0}
@media (hover:none),(pointer:coarse){.cursor,.cursor-dot{display:none}}

/* ---------- layout primitives ------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 56px;width:100%}
.eyebrow{font-size:12px;letter-spacing:3.2px;text-transform:uppercase;color:var(--ochre);
  display:inline-flex;align-items:center;gap:14px;font-weight:500}
.eyebrow::before{content:'';width:30px;height:1px;background:currentColor}
.eyebrow .num{font-family:'Fraunces',serif;font-size:13px;letter-spacing:2px}
.eyebrow.on-dark{color:var(--gold-soft)}
h1,h2,h3{font-weight:300;letter-spacing:-0.015em;line-height:1.04}
.h-xl{font-family:'Fraunces',serif;font-size:clamp(40px,6.4vw,86px)}
.h-lg{font-family:'Fraunces',serif;font-size:clamp(32px,5vw,64px)}
.h-md{font-family:'Fraunces',serif;font-size:clamp(26px,3.4vw,42px)}
.lead{font-size:clamp(17px,1.5vw,20px);max-width:60ch;color:var(--ink-soft);line-height:1.72}
.on-dark,.on-dark .lead{color:var(--bone)}
.on-dark .lead{color:rgba(244,239,230,.9)}
.rule{height:1px;background:var(--rule);border:none;width:100%}
.section{padding:clamp(80px,11vw,150px) 0;position:relative}
.section.bone{background:var(--bone)}
.section.paper{background:var(--paper)}
.section.green{background:var(--green);color:var(--bone)}
.section.green-deep{background:var(--green-deep);color:var(--bone)}
.section.indigo{background:var(--indigo);color:var(--bone)}
.section.ink{background:var(--ink);color:var(--bone)}
.section.green .lead,
.section.green-deep .lead,
.section.indigo .lead,
.section.ink .lead{color:rgba(239,233,221,.94)}
.center{text-align:center}
.divider{display:flex;align-items:center;gap:24px;max-width:var(--maxw);margin:0 auto;padding:0 56px}
.divider .rule{flex:1}
.rosette{display:inline-block;color:var(--gold);width:24px;height:24px;flex:none}

/* ---------- buttons ----------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:2.4px;
  text-transform:uppercase;font-weight:500;padding:15px 28px;border:1px solid var(--ink);
  background:transparent;color:var(--ink);transition:background .4s var(--ease),color .4s var(--ease),border-color .4s,transform .4s var(--ease)}
.btn .ar{font-family:'Fraunces',serif}
.btn:hover{background:var(--ink);color:var(--bone)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn.gold:hover{background:var(--ink);border-color:var(--ink);color:var(--bone)}
.btn.ghost-light{border-color:rgba(239,233,221,.5);color:var(--bone)}
.btn.ghost-light:hover{background:var(--bone);color:var(--ink);border-color:var(--bone)}
.btn.sm{padding:11px 20px;font-size:11px;letter-spacing:2px}
.link-ar{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:2px;
  text-transform:uppercase;font-weight:500;color:var(--ochre);transition:gap .35s var(--ease)}
.link-ar .ar{font-family:'Fraunces',serif}
.link-ar:hover{gap:16px}
.on-dark .link-ar{color:var(--gold-soft)}

/* ---------- reveal ------------------------------------------ */
[data-reveal]{will-change:transform,opacity}
[data-reveal="up"]{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform 1s var(--ease)}
[data-reveal="rise"]{opacity:0;transform:translateY(60px);transition:opacity 1.1s var(--ease),transform 1.2s var(--ease)}
[data-reveal="fade"]{opacity:0;transition:opacity 1.3s var(--ease)}
[data-reveal="img"]{opacity:0;transform:scale(1.05);transition:opacity 1.1s var(--ease),transform 1.5s var(--ease-slow)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][style*="--d"]{transition-delay:var(--d)}

/* ============================================================
   NAV  (injected by site.js)
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:9000;display:flex;align-items:center;
  justify-content:space-between;height:var(--nav-h);padding:0 56px;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),height .5s var(--ease);
  border-bottom:1px solid transparent}
.nav.solid{background:rgba(251,248,242,.94);backdrop-filter:saturate(1.2) blur(14px);border-color:var(--rule-soft)}
/* white text only while translucent AND not yet solid; once solid the nav
   inherits the default dark ink, exactly like the interior pages */
.nav.translucent:not(.solid){color:var(--bone)}
.nav .brand{display:flex;align-items:center;gap:12px;z-index:2}
.nav .brand .em{width:26px;height:28px}
.nav .brand .wm{font-family:'Fraunces',serif;font-weight:400;font-size:18px;letter-spacing:5px}
.nav.translucent:not(.solid) .brand{color:var(--bone)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:12px;letter-spacing:1.6px;text-transform:uppercase;font-weight:500;position:relative;
  transition:color .3s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:18px}
.nav .book-btn{border:1px solid var(--gold);color:var(--gold);padding:9px 18px;font-size:11px;
  letter-spacing:2px;text-transform:uppercase;font-weight:600;transition:background .35s,color .35s}
.nav .book-btn:hover{background:var(--gold);color:var(--ink)}
.cur-toggle{display:inline-flex;border:1px solid var(--rule);border-radius:2px;overflow:hidden}
.nav.translucent:not(.solid) .cur-toggle{border-color:rgba(239,233,221,.4)}
.cur-toggle button{background:none;border:none;color:inherit;padding:6px 10px;font-size:11px;
  letter-spacing:1px;font-weight:500;opacity:.55;transition:opacity .3s,background .3s,color .3s}
.cur-toggle button.active{opacity:1;background:var(--gold);color:var(--ink)}
.nav-burger{display:none;flex-direction:column;gap:5px;width:26px;background:none;border:none;z-index:2}
.nav-burger span{display:block;height:1.5px;background:currentColor;transition:transform .4s var(--ease),opacity .3s}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:8999;background:var(--paper);transform:translateY(-100%);
  transition:transform .6s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:0 32px}
.drawer.open{transform:translateY(0)}
.drawer a{font-family:'Fraunces',serif;font-size:30px;font-weight:300;padding:9px 0;color:var(--ink);
  border-bottom:1px solid var(--rule-soft)}
.drawer .d-foot{margin-top:34px;display:flex;gap:18px;align-items:center}

@media (max-width:980px){
  .nav,.wrap,.divider{padding-left:32px;padding-right:32px}
  .nav-links{display:none}
  .nav .book-btn{display:none}
  .nav-burger{display:flex}
  .nav .brand .wm-sub{display:none}
  body.drawer-open .nav-burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  body.drawer-open .nav-burger span:nth-child(2){opacity:0}
  body.drawer-open .nav-burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* ============================================================
   FOOTER (injected)
   ============================================================ */
.foot{background:var(--ink);color:var(--bone);padding:96px 0 48px}
.foot .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;align-items:start}
.foot .em{width:48px;height:52px;margin-bottom:18px}
.foot .fwm{font-family:'Fraunces',serif;font-size:22px;letter-spacing:6px;margin-bottom:12px}
.foot .ftag{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold-soft);margin-bottom:20px}
.foot .fabout{font-size:14px;color:rgba(244,239,230,.7);max-width:34ch;line-height:1.8}
.foot h5{font-family:'Fraunces',serif;font-weight:500;font-size:12px;letter-spacing:2.4px;text-transform:uppercase;
  color:rgba(244,239,230,.55);margin-bottom:16px}
.foot a,.foot p{font-size:14px;color:rgba(244,239,230,.82);line-height:1.95;display:block}
.foot a{transition:color .3s}
.foot a:hover{color:var(--gold-soft)}
.foot .langset{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px;font-size:12px;letter-spacing:1px;color:rgba(244,239,230,.6)}
.foot .bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  margin-top:72px;padding-top:28px;border-top:1px solid var(--line-dark);font-size:11px;letter-spacing:1.4px;
  text-transform:uppercase;color:rgba(244,239,230,.5)}
@media (max-width:860px){.foot .top{grid-template-columns:1fr 1fr;gap:38px}}
@media (max-width:560px){.foot .top{grid-template-columns:1fr}}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.pagehead{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:var(--bone);overflow:hidden}
.pagehead .bg{position:absolute;inset:0;z-index:0}
.pagehead .bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.66) saturate(.95)}
.pagehead .bg::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(26,21,16,.5),rgba(26,21,16,.15) 45%,rgba(26,21,16,.62))}
.pagehead .inner{position:relative;z-index:2;padding-bottom:64px;padding-top:140px}
.pagehead h1{font-family:'Fraunces',serif;font-size:clamp(44px,7vw,96px);margin-top:18px}
.pagehead .lead{margin-top:22px;color:rgba(244,239,230,.9)}
.crumb{font-size:11px;letter-spacing:2.4px;text-transform:uppercase;color:rgba(239,233,221,.62)}
.crumb a:hover{color:var(--gold-soft)}

/* ============================================================
   PLACEHOLDERS — graceful, palette-toned, never broken
   ============================================================ */
.ph{position:relative;overflow:hidden;background:linear-gradient(135deg,#dcd2bf,#cdbfa3 55%,#b89c79);
  display:flex;align-items:flex-end}
.ph::before{content:'';position:absolute;inset:0;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cg fill='none' stroke='%23A85A2E' stroke-opacity='0.18'%3E%3Cpath d='M0 80 Q40 50 80 80 T160 80'/%3E%3Cpath d='M0 110 Q40 80 80 110 T160 110'/%3E%3C/g%3E%3Cg fill='%23A85A2E' fill-opacity='0.12'%3E%3Cellipse cx='40' cy='40' rx='7' ry='4.5' transform='rotate(-18 40 40)'/%3E%3Cellipse cx='120' cy='130' rx='7' ry='4.5' transform='rotate(-18 120 130)'/%3E%3C/g%3E%3C/svg%3E")}
.ph .ph-dome{position:absolute;left:50%;bottom:-2px;transform:translateX(-50%);width:64%;height:58%;
  background:rgba(168,90,46,.16);border-radius:50% 50% 0 0/100% 100% 0 0}
.ph .ph-label{position:relative;z-index:2;padding:18px 20px;font-family:'Fraunces',serif;font-style:italic;
  font-size:15px;color:var(--ink-soft)}
.ph .ph-tag{position:absolute;top:14px;left:16px;z-index:2;font-size:9.5px;letter-spacing:2.2px;
  text-transform:uppercase;color:rgba(26,21,16,.5)}
.ph.green-toned{background:linear-gradient(135deg,#3a5040,#2c4232 60%,#22331f)}
.ph.green-toned .ph-label{color:var(--gold-soft)}
.ph.green-toned .ph-tag{color:rgba(232,217,176,.6)}
.ph.green-toned .ph-dome{background:rgba(232,217,176,.1)}

/* ============================================================
   HOME — hero
   ============================================================ */
/* full-height immersive hero (original). The booking card (below) overlaps
   far enough up that it lands fully inside the first screen — the only fix
   the original needed. Content keeps room above the card via padding-bottom. */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  overflow:hidden;color:var(--bone)}
.hero .bg{position:absolute;inset:-6% 0;z-index:0;will-change:transform}
.hero .bg img{width:100%;height:112%;object-fit:cover;filter:brightness(.6) saturate(.96)}
.hero .bg::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(26,21,16,.46) 0%,rgba(26,21,16,.12) 36%,rgba(30,44,34,.74) 100%)}
/* copy fills the space above the booking band and sits just above centre, so
   the eye meets the headline immediately under the nav — no dead zone */
.hero .inner{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;
  justify-content:center;padding-top:70px}
.hero .kicker{font-size:12px;letter-spacing:6px;text-transform:uppercase;color:var(--gold-soft);margin-bottom:26px}
.hero h1{font-family:'Fraunces',serif;font-size:clamp(46px,9vw,118px);line-height:.96;margin-bottom:26px;max-width:15ch}
.hero h1 em{color:var(--gold-soft)}
.hero .sub{display:flex;gap:26px;align-items:flex-start;max-width:620px}
.hero .sub .barline{width:1px;height:58px;background:var(--gold);flex:none;margin-top:4px}
.hero .sub p{font-size:clamp(15px,1.5vw,19px);line-height:1.7;color:rgba(239,233,221,.9)}
/* small screens: shrink the headline so the longest line clears the viewport
   (the clamp min was wider than a phone at the 15ch box) */
@media (max-width:600px){
  .hero h1{font-size:clamp(36px,11vw,54px);max-width:14ch;margin-bottom:20px}
  .hero .kicker{margin-bottom:18px}
  .hero .inner{padding-top:88px}
}
.hero-meta{position:absolute;bottom:30px;left:0;right:0;z-index:2;display:flex;justify-content:space-between;
  font-size:11px;letter-spacing:2.6px;text-transform:uppercase;color:rgba(239,233,221,.6)}
.scrollcue{display:flex;flex-direction:column;align-items:center;gap:9px;font-size:9px;letter-spacing:3px}
.scrollcue .line{width:1px;height:42px;background:linear-gradient(var(--gold-soft),transparent);position:relative;overflow:hidden}
.scrollcue .line::after{content:'';position:absolute;top:-50%;left:0;width:1px;height:50%;background:var(--gold);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{top:-50%}60%,100%{top:120%}}

/* hero booking card — a contained bone (cream) widget resting in the hero
   with the photo breathing around it. Solid and high-contrast so the
   make-or-break control is unmistakable, never camouflaged on the dark sky. */
.herobar{position:relative;z-index:3;width:100%;padding:0 56px 40px}
.herobar .row{max-width:1120px;margin:0 auto;display:flex;align-items:stretch;
  background:var(--bone);color:var(--ink);border-radius:4px;overflow:hidden;
  box-shadow:0 24px 60px -24px rgba(0,0,0,.45)}
.herobar .lead-label{display:flex;flex-direction:column;justify-content:center;padding:18px 28px 18px 32px;
  border-right:1px solid var(--rule)}
.herobar .lead-label .t{font-style:italic;font-size:20px;line-height:1;color:var(--ink)}
.herobar .lead-label .s{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ochre);margin-top:7px}
.herobar .lead-label .s strong{color:var(--ink);font-weight:600;letter-spacing:.6px}
/* each field is a self-evidently tappable cell: an icon, a label, the value,
   a hover tint and a gold underline that lights when the field is active */
.herobar .f{position:relative;display:flex;flex-direction:column;gap:5px;justify-content:center;
  padding:14px 26px 14px 48px;border-right:1px solid var(--rule);
  transition:background .3s var(--ease)}
.herobar .f:hover{background:rgba(26,21,16,.035)}
.herobar .f:focus-within{background:rgba(26,21,16,.055)}
.herobar .f::before{content:'';position:absolute;left:24px;top:50%;transform:translateY(-50%);
  width:17px;height:17px;background:var(--ochre);opacity:.9}
.herobar .f::after{content:'';position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.herobar .f:focus-within::after{transform:scaleX(1)}
.herobar .f label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ochre);pointer-events:none}
.herobar .f input,.herobar .f select{background:none;border:none;color:var(--ink);font:inherit;font-size:15px;outline:none;padding:0}
.herobar .f select{appearance:none;-webkit-appearance:none;padding-right:20px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%23A85A2E' stroke-width='1.5'%3E%3Cpath d='M1 1.5 6 6.5l5-5'/%3E%3C/svg%3E") right center/10px no-repeat}
.herobar .f input::-webkit-calendar-picker-indicator{opacity:.55;cursor:pointer}
.herobar select option{color:var(--ink)}
/* the CTA states plainly what it will do: action on top, plan underneath */
.herobar .go{margin-left:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  background:var(--gold);color:var(--ink);border:none;padding:0 42px;cursor:pointer;
  transition:background .35s var(--ease),color .35s var(--ease)}
.herobar .go .go-main{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:2.4px;text-transform:uppercase;font-weight:600}
.herobar .go .go-sub{font-size:10px;letter-spacing:1.4px;text-transform:uppercase;font-weight:500;opacity:.72}
.herobar .go:hover{background:var(--ink);color:var(--bone)}
.herobar .go .ar{font-family:'Fraunces',serif}
/* field glyphs */
.herobar .f[data-field=date]::before{
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7'%3E%3Crect x='3' y='4.5' width='18' height='17' rx='2'/%3E%3Cpath d='M3 9.5h18M8 2.5v4M16 2.5v4'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7'%3E%3Crect x='3' y='4.5' width='18' height='17' rx='2'/%3E%3Cpath d='M3 9.5h18M8 2.5v4M16 2.5v4'/%3E%3C/svg%3E") center/contain no-repeat}
.herobar .f[data-field=guests]::before{
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7'%3E%3Ccircle cx='12' cy='8' r='3.6'/%3E%3Cpath d='M5 20c0-3.9 3.1-7 7-7s7 3.1 7 7'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.7'%3E%3Ccircle cx='12' cy='8' r='3.6'/%3E%3Cpath d='M5 20c0-3.9 3.1-7 7-7s7 3.1 7 7'/%3E%3C/svg%3E") center/contain no-repeat}
@media (max-width:900px){
  .herobar{padding:0 18px 26px}
  .herobar .row{flex-wrap:wrap}
  .herobar .lead-label{width:100%;border-right:none;border-bottom:1px solid var(--rule);padding:14px 18px}
  .herobar .f{flex:1 1 40%;border-right:none;border-bottom:1px solid var(--rule);padding:12px 12px 12px 40px}
  .herobar .f::before{left:14px}
  .herobar .go{flex:1 1 100%;padding:16px;margin-top:0}
}

/* ============================================================
   ROOM / DINING / EXPERIENCE CARDS
   ============================================================ */
.cards{display:grid;gap:clamp(20px,3vw,40px)}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.room-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--rule-soft);
  border-radius:4px;overflow:hidden;box-shadow:var(--sh-1);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.room-card:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.room-card .media{position:relative;aspect-ratio:3/2;overflow:hidden}
.room-card .media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease-slow)}
.room-card:hover .media img{transform:scale(1.05)}
.room-card .media .ph{position:absolute;inset:0}
/* a soft floor under the badge, and depth at the image base */
.room-card .media::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(0deg,rgba(26,21,16,.28),transparent 38%)}
.room-card .tier{position:absolute;top:12px;left:12px;z-index:2;background:rgba(26,21,16,.72);color:var(--gold-soft);
  font-size:9.5px;letter-spacing:2px;text-transform:uppercase;padding:5px 10px;border-radius:2px}
.room-card .body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.room-card h3{font-family:'Fraunces',serif;font-size:22px;font-weight:400;line-height:1.1}
.room-card .tg{font-style:italic;font-family:'Fraunces',serif;color:var(--ochre);font-size:14px;margin-top:2px}
.room-card .desc{margin-top:10px;color:var(--muted);font-size:13.5px;line-height:1.55;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.room-card .specs{display:flex;flex-wrap:wrap;gap:10px 14px;margin-top:12px;font-size:11.5px;letter-spacing:.4px;color:var(--ink-soft)}
.room-card .specs span{display:inline-flex;align-items:center;gap:6px}
.room-card .rc-foot{display:flex;align-items:flex-end;justify-content:space-between;margin-top:16px;
  padding-top:14px;border-top:1px solid var(--rule-soft)}
.room-card .price .from{font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted)}
.room-card .price .amt{font-family:'Fraunces',serif;font-size:22px;color:var(--ink)}
.room-card .price .per{font-size:12px;color:var(--muted)}
.room-card .rc-foot .link-ar{color:var(--ochre);font-weight:500}
.room-card:hover .rc-foot .link-ar{color:var(--gold)}
@media (max-width:740px){
  .cards.c3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .cards.c3,.cards.c2{grid-template-columns:1fr}
  .room-card .body{padding:14px 16px 16px}
  .room-card h3{font-size:20px}
  .room-card .rc-foot{margin-top:12px;padding-top:12px}
}

.feat{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.feat.flip .feat-media{order:2}
.feat-media{position:relative;overflow:hidden;aspect-ratio:5/4}
.feat-media img{width:100%;height:100%;object-fit:cover}
.feat-media .ph{position:absolute;inset:0}
.feat-body h3{font-family:'Fraunces',serif;font-size:clamp(26px,3.4vw,44px);font-weight:300;margin-top:18px}
.feat-body .lead{margin-top:18px}
.feat-body .cta-row{margin-top:28px;display:flex;gap:18px;flex-wrap:wrap;align-items:center}
@media (max-width:820px){
  .feat,.feat.flip{grid-template-columns:1fr;gap:26px}
  .feat.flip .feat-media{order:0}
}
/* matted editorial treatment — PILOT, scoped to one .feat for sign-off.
   image gets depth (shadow + radius + base gradient); a thin gold frame is
   offset behind the bottom-right corner; an oversized serif index numeral
   overlaps the top-left — the editorial signature. */
.feat.matted .matte{position:relative;z-index:1}
.feat.matted .feat-media{position:relative;z-index:1;border-radius:3px;box-shadow:var(--sh-3)}
.feat.matted .feat-media::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(0deg,rgba(26,21,16,.20),transparent 42%)}
.feat.matted .matte::before{content:'';position:absolute;z-index:0;right:-22px;bottom:-22px;
  width:64%;height:70%;border:1px solid var(--gold);opacity:.5;border-radius:3px}
.feat.matted .feat-index{position:absolute;z-index:2;top:-30px;left:-16px;
  font-family:'Fraunces',serif;font-weight:300;font-size:clamp(58px,7vw,108px);line-height:1;
  color:var(--ochre);opacity:.92;pointer-events:none;letter-spacing:-.02em}
@media (max-width:820px){
  .feat.matted .matte::before{right:-12px;bottom:-12px}
  .feat.matted .feat-index{font-size:clamp(48px,12vw,72px);top:-22px;left:-8px}
}

/* dining list */
.dine{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--rule)}
.dine-row{display:grid;grid-template-columns:0.9fr 1.1fr;gap:48px;padding:48px 0;border-bottom:1px solid var(--rule);align-items:center}
.dine-row .media{position:relative;aspect-ratio:5/4;overflow:hidden}
.dine-row .media img{width:100%;height:100%;object-fit:cover}
.dine-row .media .ph{position:absolute;inset:0}
.dine-row.flip .media{order:2}
.dine-row h3{font-family:'Fraunces',serif;font-size:clamp(28px,3.6vw,46px);font-weight:300}
.dine-row .kind{color:var(--ochre);font-size:12px;letter-spacing:2px;text-transform:uppercase;margin-top:8px}
.dine-row .hours{font-size:13px;color:var(--muted);margin-top:4px}
.dine-row .dishes{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:8px}
.dine-row .dishes li{padding-left:18px;position:relative;font-size:15px;color:var(--ink-soft)}
.dine-row .dishes li::before{content:'';position:absolute;left:0;top:11px;width:7px;height:4px;background:var(--gold);border-radius:50%;transform:rotate(-18deg)}
@media (max-width:820px){.dine-row,.dine-row.flip{grid-template-columns:1fr;gap:22px}.dine-row.flip .media{order:0}}

/* ============================================================
   ROOM DETAIL
   ============================================================ */
.rd-specs{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin:0}
.rd-specs .s{padding:26px 24px 24px 0;border-right:1px solid var(--rule)}
.rd-specs .s:last-child{border-right:none}
.rd-specs .s .l{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted)}
.rd-specs .s .v{font-family:'Fraunces',serif;font-size:clamp(20px,2.2vw,28px);margin-top:8px}
.rd-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:64px;align-items:start}
.rd-amen{list-style:none;columns:2;column-gap:30px}
.rd-amen li{padding:9px 0 9px 20px;position:relative;font-size:15px;break-inside:avoid;border-bottom:1px solid var(--rule-soft)}
.rd-amen li::before{content:'';position:absolute;left:0;top:16px;width:7px;height:4px;background:var(--gold);border-radius:50%;transform:rotate(-18deg)}
.rd-book{position:sticky;top:96px;background:var(--paper);border:1px solid var(--rule);padding:30px}
.rd-book .price .amt{font-family:'Fraunces',serif;font-size:40px}
.rd-book .price .per,.rd-book .price .from{color:var(--muted);font-size:13px}
.rd-book .mini{display:flex;flex-direction:column;gap:12px;margin:22px 0}
.rd-book .mini .f{display:flex;flex-direction:column;gap:4px;border:1px solid var(--rule);padding:10px 14px}
.rd-book .mini .f label{font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:var(--ochre)}
.rd-book .mini .f input,.rd-book .mini .f select{border:none;background:none;font:inherit;outline:none}
.rd-book .btn{width:100%;justify-content:center}
@media (max-width:900px){.rd-grid{grid-template-columns:1fr;gap:38px}.rd-book{position:static}.rd-specs{grid-template-columns:1fr 1fr}.rd-amen{columns:1}}

/* room gallery strip */
.rd-gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:14px;margin-top:18px}
.rd-gallery .g{position:relative;overflow:hidden;aspect-ratio:1/1}
.rd-gallery .g:first-child{aspect-ratio:auto}
.rd-gallery .g img{width:100%;height:100%;object-fit:cover}
.rd-gallery .g .ph{position:absolute;inset:0}
@media (max-width:640px){.rd-gallery{grid-template-columns:1fr 1fr}.rd-gallery .g:first-child{grid-column:1/-1}}

/* ============================================================
   SIGNATURE — horizontal leopard scroll
   ============================================================ */
.parks{position:relative;background:var(--green)}
.parks .pin{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center}
.parks .track{display:flex;height:100%;will-change:transform}
.parks .panel{flex:none;height:100%;display:flex;align-items:center;position:relative}
.parks .panel.text{width:100vw;padding:0 56px}
.parks .panel.text .inner{max-width:var(--maxw);margin:0 auto;width:100%}
.parks .panel.text h2{font-family:'Fraunces',serif;font-size:clamp(36px,6vw,86px);line-height:1;max-width:16ch;color:var(--bone)}
.parks .panel.text h2 em{color:var(--gold)}
.parks .panel.text .lead{margin-top:28px;color:rgba(244,239,230,.9)}
.parks .panel.img{width:78vw;padding:0 2vw}
.parks .panel.img figure{position:relative;width:100%;height:78vh;overflow:hidden;margin:0}
.parks .panel.img img{width:100%;height:100%;object-fit:cover}
.parks .panel.img .cap{position:absolute;left:26px;bottom:22px;color:var(--bone)}
.parks .panel.img .cap .t{font-family:'Fraunces',serif;font-size:21px;font-style:italic}
.parks .panel.img .cap .s{font-size:10px;letter-spacing:2.4px;text-transform:uppercase;color:var(--gold-soft);margin-top:5px}
.parks .panel.img .idx{position:absolute;right:26px;top:22px;font-family:'Fraunces',serif;font-size:12px;letter-spacing:2px;color:rgba(239,233,221,.6)}
.parks .hint{position:absolute;bottom:28px;left:56px;z-index:5;font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(239,233,221,.5);display:flex;align-items:center;gap:12px}
.parks .hint .arl{width:38px;height:1px;background:var(--gold-soft);position:relative}
.parks .hint .arl::after{content:'';position:absolute;right:0;top:-2px;width:5px;height:5px;border-top:1px solid var(--gold-soft);border-right:1px solid var(--gold-soft);transform:rotate(45deg)}
.parks.no-h .pin{position:static;height:auto;display:block}
.parks.no-h .track{display:block;transform:none!important}
.parks.no-h .panel{width:auto!important;height:auto;padding:54px 0;display:block}
.parks.no-h .panel.text{padding:54px 56px}
.parks.no-h .panel.img figure{height:auto;aspect-ratio:16/10}
.parks.no-h .hint{display:none}

/* ============================================================
   STATS strip
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--rule)}
.stat{padding:34px 26px 28px 0;border-right:1px solid var(--rule)}
.stat:last-child{border-right:none}
.stat .n{font-family:'Fraunces',serif;font-size:clamp(32px,4vw,52px);line-height:1}
.stat .l{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);margin-top:12px}
.on-dark .stats{border-color:var(--line-dark)}
.on-dark .stat{border-color:var(--line-dark)}
.on-dark .stat .l{color:rgba(239,233,221,.6)}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr}.stat{border-right:none;border-bottom:1px solid var(--rule);padding-right:0}}

/* ============================================================
   GALLERY (masonry-ish)
   ============================================================ */
.gallery-grid{columns:3;column-gap:14px}
.gallery-grid figure{break-inside:avoid;margin:0 0 14px;position:relative;overflow:hidden}
.gallery-grid img{width:100%;height:auto;display:block;transition:transform 1s var(--ease-slow)}
.gallery-grid figure:hover img{transform:scale(1.04)}
.gallery-grid figcaption{position:absolute;left:14px;bottom:12px;color:var(--bone);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.6);opacity:0;transition:opacity .4s}
.gallery-grid figure:hover figcaption{opacity:1}
@media (max-width:860px){.gallery-grid{columns:2}}
@media (max-width:520px){.gallery-grid{columns:1}}

/* ============================================================
   BOOKING FLOW
   ============================================================ */
.booking{padding-top:calc(var(--nav-h) + 40px);min-height:100vh}
.steps{display:flex;gap:0;margin-bottom:48px;border-bottom:1px solid var(--rule)}
.steps .st{flex:1;padding:0 0 16px;font-size:12px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted);
  position:relative;display:flex;align-items:center;gap:10px}
.steps .st .dot{width:24px;height:24px;border-radius:50%;border:1px solid var(--rule);display:grid;place-items:center;
  font-family:'Fraunces',serif;font-size:12px;color:var(--muted)}
.steps .st.active{color:var(--ink)}
.steps .st.active .dot{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.steps .st.done .dot{background:var(--ink);border-color:var(--ink);color:var(--bone)}
.steps .st.active::after{content:'';position:absolute;left:0;bottom:-1px;width:100%;height:2px;background:var(--gold)}
@media (max-width:640px){.steps .st span{display:none}.steps .st{justify-content:center;padding-bottom:14px}}

.step-panel{display:none;animation:fadein .5s var(--ease)}
.step-panel.active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:760px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--ochre);font-weight:500}
.field input,.field select,.field textarea{border:1px solid var(--rule);background:var(--paper);font:inherit;
  font-size:15px;padding:13px 15px;color:var(--ink);outline:none;transition:border-color .3s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.field .err{font-size:12px;color:var(--clay);min-height:1em}
.field.invalid input,.field.invalid select{border-color:var(--clay)}

.avail-list{display:flex;flex-direction:column;gap:16px;margin-top:8px}
.avail-row{display:grid;grid-template-columns:160px 1fr auto;gap:24px;align-items:center;border:1px solid var(--rule);
  background:var(--paper);padding:16px;transition:border-color .3s,box-shadow .3s}
.avail-row:hover{border-color:var(--gold);box-shadow:0 14px 34px rgba(26,21,16,.08)}
.avail-row .media{position:relative;aspect-ratio:4/3;overflow:hidden}
.avail-row .media img{width:100%;height:100%;object-fit:cover}
.avail-row .media .ph{position:absolute;inset:0}
.avail-row h3{font-family:'Fraunces',serif;font-size:24px;font-weight:400}
.avail-row .meta{font-size:13px;color:var(--muted);margin-top:6px}
.avail-row .pricing{text-align:right}
.avail-row .pricing .amt{font-family:'Fraunces',serif;font-size:26px}
.avail-row .pricing .per{font-size:12px;color:var(--muted)}
.avail-row .pricing .total{font-size:13px;color:var(--ink-soft);margin-top:4px}
@media (max-width:720px){.avail-row{grid-template-columns:1fr;gap:14px}.avail-row .pricing{text-align:left;display:flex;align-items:baseline;gap:12px}}

.summary{background:var(--bone);border:1px solid var(--rule);padding:30px;position:sticky;top:96px}
.summary h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;margin-bottom:18px}
.summary .line{display:flex;justify-content:space-between;padding:9px 0;font-size:14px;border-bottom:1px solid var(--rule-soft)}
.summary .line .k{color:var(--muted)}
.summary .total{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;padding-top:16px;border-top:1px solid var(--rule)}
.summary .total .amt{font-family:'Fraunces',serif;font-size:30px}
.book-cols{display:grid;grid-template-columns:1.5fr .9fr;gap:44px;align-items:start}
@media (max-width:860px){.book-cols{grid-template-columns:1fr}.summary{position:static}}

/* confirmation — a reservation "ticket" with real depth, so it reads as
   "something happened" rather than a plain summary on the page */
.confirm{max-width:600px;margin:0 auto;padding:18px 0 10px}
.ticket{background:var(--paper);border:1px solid var(--rule-soft);border-radius:6px;overflow:hidden;
  box-shadow:var(--sh-3);text-align:center;animation:tk-in .7s var(--ease) both}
@keyframes tk-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.ticket-top{padding:40px 34px 30px}
.ticket .seal{width:64px;height:68px;margin:0 auto 18px;color:var(--gold);
  animation:seal-in .6s var(--ease) .12s both}
@keyframes seal-in{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:none}}
.ticket .eyebrow{justify-content:center}
.ticket h2{margin-top:12px}
.ticket-note{font-size:14.5px;line-height:1.65;color:var(--ink-soft);max-width:42ch;margin:14px auto 0}
.ticket-note strong{color:var(--ink);font-weight:600}
/* perforation seam with punched side-notches */
.perf{position:relative;height:0;border-top:2px dashed var(--rule)}
.perf::before,.perf::after{content:'';position:absolute;top:0;width:24px;height:24px;border-radius:50%;
  background:var(--sand);transform:translateY(-50%)}
.perf::before{left:-12px}
.perf::after{right:-12px}
.ticket-body{padding:30px 34px 36px}
.ref-hero{margin-bottom:24px}
.ref-hero .l{display:block;font-size:11px;letter-spacing:2.2px;text-transform:uppercase;color:var(--ochre);margin-bottom:9px}
.ref-hero .ref{font-family:'Fraunces',serif;font-size:clamp(28px,6vw,44px);letter-spacing:3px;color:var(--ink);
  display:inline-block;padding:8px 24px;border:1px solid var(--gold);border-radius:3px;background:rgba(200,151,60,.07)}
.tk-grid{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--rule-soft);text-align:left}
.tk-cell{display:flex;flex-direction:column;gap:5px;padding:14px 4px;border-bottom:1px solid var(--rule-soft)}
.tk-cell:nth-child(odd){padding-right:18px;border-right:1px solid var(--rule-soft)}
.tk-cell:nth-child(even){padding-left:18px}
.tk-cell:nth-last-child(-n+2){border-bottom:none}
.tk-cell .k{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted)}
.tk-cell .v{font-size:16px;color:var(--ink)}
.tk-cell .v.price{font-family:'Fraunces',serif;font-size:20px}
@media (prefers-reduced-motion:reduce){.ticket,.ticket .seal{animation:none}}
@media (max-width:480px){
  .tk-grid{grid-template-columns:1fr}
  .tk-cell:nth-child(odd){border-right:none;padding-right:4px}
  .tk-cell:nth-child(even){padding-left:4px}
  .tk-cell:nth-last-child(2){border-bottom:1px solid var(--rule-soft)}
}

.step-nav{display:flex;justify-content:space-between;margin-top:36px;gap:16px}
.step-nav .btn.back{border-color:var(--rule);color:var(--muted)}
.step-nav .btn.back:hover{background:var(--bone);color:var(--ink);border-color:var(--ink)}

/* ============================================================
   misc
   ============================================================ */
.notice{background:var(--bone);border-left:2px solid var(--gold);padding:16px 20px;font-size:14px;color:var(--ink-soft);margin:18px 0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px)}
@media (max-width:820px){.split{grid-template-columns:1fr;gap:30px}}
.tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.tag{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;border:1px solid var(--rule);padding:7px 13px;color:var(--ink-soft)}
.mt-s{margin-top:18px}.mt-m{margin-top:34px}.mt-l{margin-top:54px}

/* ---------- reduced motion ---------------------------------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
  .hero .bg{inset:0}
  .scrollcue .line::after{display:none}
}
