  :root{
    --sand:#F5F1E8; --ivory:#FBF8F1; --ink:#2A2620; --ink2:#4A443B; --ink3:#6E665A;
    --teal:#5E7A77; --teal2:#9FB4B1; --dark:#22201B; --darker:#1A1814;
    --warm:#EAE0D0; --cream:#EFE8DA; --line:rgba(42,38,32,0.14);
    --serif:'Cormorant Garamond',Georgia,serif; --sans:'Jost',-apple-system,Segoe UI,sans-serif;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth;scroll-padding-top:76px}
  body{margin:0;background:var(--sand);color:var(--ink);font-family:var(--sans);
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;line-height:1.5}
  img{display:block;max-width:100%}
  a{color:inherit;text-decoration:none}
  h1,h2,h3{margin:0;font-weight:400}
  ::selection{background:var(--teal);color:var(--sand)}
  .serif{font-family:var(--serif)}
  .wrap{max-width:1280px;margin:0 auto;padding:0 40px}

  /* shared bits */
  .eyebrow{margin:0 0 22px;font-size:12px;font-weight:400;letter-spacing:0.34em;text-transform:uppercase;color:var(--teal)}
  .sec-h{font-family:var(--serif);font-weight:400;color:var(--ink);line-height:1.04;letter-spacing:-0.01em}
  .lede{font-size:17px;font-weight:300;line-height:1.78;color:var(--ink2)}
  .section{padding:130px 0}

  @keyframes escFade{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
  @keyframes escCue{0%,100%{transform:translateY(0);opacity:.55}50%{transform:translateY(7px);opacity:1}}
  .reveal{opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s ease}
  .reveal.in{opacity:1;transform:none}

  /* ============ NAV ============ */
  header{position:fixed;top:0;left:0;width:100%;z-index:100;background:rgba(245,241,232,0.82);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(42,38,32,0.10)}
  .nav-inner{max-width:1280px;margin:0 auto;padding:0 40px;height:76px;display:flex;align-items:center;justify-content:space-between}
  .brand{display:flex;flex-direction:column;line-height:1}
  .brand .name{font-family:var(--serif);font-size:23px;font-weight:500;letter-spacing:0.04em;color:var(--ink)}
  .brand .sub{font-size:9.5px;font-weight:400;letter-spacing:0.42em;text-transform:uppercase;color:var(--teal);margin-top:3px}
  nav.links{display:flex;align-items:center;gap:38px}
  .nav-link{font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink2);transition:color .25s}
  .nav-link:hover{color:var(--teal)}
  .nav-cta{font-size:11.5px;letter-spacing:0.20em;text-transform:uppercase;color:var(--sand);background:var(--ink);padding:11px 22px;transition:background .25s}
  .nav-cta:hover{background:var(--teal)}
  .burger{display:none;background:none;border:0;cursor:pointer;width:34px;height:26px;padding:0}
  .burger span{display:block;height:1.5px;background:var(--ink);margin:6px 0;transition:.3s}

  /* ============ BUTTONS ============ */
  .btn{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:400;letter-spacing:0.20em;text-transform:uppercase;transition:background .25s,color .25s;cursor:pointer}
  .btn-light{background:var(--ivory);color:var(--ink);padding:17px 32px}
  .btn-light:hover{background:var(--teal);color:var(--ivory)}
  .btn-ghost{background:transparent;color:var(--ivory);border:1px solid rgba(251,248,241,0.55);padding:16px 32px}
  .btn-ghost:hover{background:rgba(251,248,241,0.12)}
  .btn-dark{background:var(--ink);color:var(--sand);padding:17px 34px}
  .btn-dark:hover{background:var(--teal)}
  .airbnb{display:inline-flex;align-items:center;gap:8px;margin-top:20px;color:var(--ink);border-bottom:1px solid rgba(42,38,32,0.4);padding-bottom:4px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;transition:color .25s,border-color .25s}
  .airbnb:hover{color:var(--teal);border-color:var(--teal)}

  /* ============ HERO ============ */
  .hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
  .hero-bg{position:absolute;inset:0;background:#C9BBA2 url('/assets/hero.webp') center 42%/cover no-repeat;transform:scale(1.04)}
  .hero-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,24,18,0.34) 0%,rgba(28,24,18,0.06) 34%,rgba(28,24,18,0.22) 64%,rgba(28,24,18,0.70) 100%)}
  .hero-inner{position:relative;z-index:2;width:100%;max-width:1280px;margin:0 auto;padding:0 40px 92px}
  .hero-eyebrow{margin:0 0 24px;font-size:12px;letter-spacing:0.42em;text-transform:uppercase;color:#EBE3D4;animation:escFade 1s ease both}
  .hero h1{font-family:var(--serif);color:#FBF8F1;font-size:clamp(58px,11vw,150px);line-height:0.92;letter-spacing:-0.015em;animation:escFade 1.1s ease .08s both}
  .hero .at{margin:14px 0 0;font-family:var(--serif);font-style:italic;font-weight:300;color:#EBE3D4;font-size:clamp(22px,3vw,34px);animation:escFade 1.1s ease .16s both}
  .hero .intro{margin:30px 0 38px;max-width:540px;font-size:17px;font-weight:300;line-height:1.7;color:#F0E9DB;animation:escFade 1.1s ease .24s both}
  .hero-btns{display:flex;gap:16px;flex-wrap:wrap;animation:escFade 1.1s ease .32s both}
  .scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px}
  .scrollcue span.t{font-size:9px;letter-spacing:0.3em;text-transform:uppercase;color:rgba(251,248,241,0.7)}
  .scrollcue span.l{width:1px;height:34px;background:linear-gradient(180deg,rgba(251,248,241,0.7),transparent);animation:escCue 2.4s ease-in-out infinite}

  /* ============ HOUSE ============ */
  #house{background:var(--sand)}
  .house-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:88px;align-items:center}
  .house-h{font-size:clamp(34px,4.4vw,58px);margin:0 0 30px}
  .figure{position:relative;width:100%;background:#E7DCCB;overflow:hidden}
  .figure img{width:100%;height:100%;object-fit:cover}
  .house-fig{height:560px}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:96px;border-top:1px solid var(--line)}
  .stat{padding:40px 32px 0;border-right:1px solid var(--line)}
  .stat:first-child{padding-left:0}
  .stat:last-child{border-right:0;padding-right:0}
  .stat .n{margin:0 0 10px;font-family:var(--serif);font-size:44px;color:var(--ink)}
  .stat p{margin:0;font-size:13px;font-weight:300;line-height:1.6;color:var(--ink3);letter-spacing:0.02em}

  /* ============ ROOMS ============ */
  #rooms{background:var(--ivory)}
  .rooms-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:64px}
  .rooms-head h2{font-size:clamp(34px,4.4vw,56px)}
  .rooms-head .note{margin:0;max-width:360px;font-size:15px;font-weight:300;line-height:1.72;color:var(--ink3)}
  .rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
  .room .ph{height:420px;margin-bottom:24px}
  .room-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}
  .room-top h3{font-family:var(--serif);font-weight:500;font-size:28px;color:var(--ink)}
  .room-tag{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--teal);white-space:nowrap}
  .room p.d{margin:0 0 18px;font-size:14.5px;font-weight:300;line-height:1.7;color:var(--ink3)}
  .chips{display:flex;flex-wrap:wrap;gap:8px}
  .chip{font-size:11px;letter-spacing:0.06em;color:var(--ink2);border:1px solid rgba(42,38,32,0.16);padding:6px 12px}

  /* ============ SUITE ============ */
  #suite{background:var(--sand)}
  .suite-grid{display:grid;grid-template-columns:1.15fr 1fr;align-items:stretch}
  .suite-fig{min-height:640px}
  .suite-panel{background:var(--dark);color:var(--cream);padding:84px 72px;display:flex;flex-direction:column;justify-content:center}
  .suite-panel .eyebrow{color:var(--teal2)}
  .suite-panel h2{font-family:var(--serif);color:var(--ivory);font-size:clamp(34px,4vw,54px);line-height:1.05;letter-spacing:-0.01em;margin:0 0 28px}
  .suite-panel p{margin:0 0 22px;font-size:16px;font-weight:300;line-height:1.8;color:#D7CFC0}
  .suite-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
  .suite-chips .chip{color:var(--cream);border-color:rgba(239,232,218,0.28);padding:7px 14px;letter-spacing:0.08em}
  .suite-link{display:inline-flex;align-items:center;gap:8px;margin-top:38px;align-self:flex-start;color:var(--cream);border-bottom:1px solid rgba(239,232,218,0.45);padding-bottom:4px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;transition:color .25s,border-color .25s}
  .suite-link:hover{color:var(--teal2);border-color:var(--teal2)}

  /* ============ POOL BAND ============ */
  .band{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden}
  .band-bg{position:absolute;inset:0;background:#C9BBA2 url('/assets/pool.webp') center/cover no-repeat}
  .band-grad{position:absolute;inset:0;background:linear-gradient(90deg,rgba(24,21,16,0.66) 0%,rgba(24,21,16,0.34) 46%,rgba(24,21,16,0.08) 100%)}
  .band-inner{position:relative;z-index:2;max-width:1280px;width:100%;margin:0 auto;padding:0 40px}
  .band-inner .box{max-width:560px}
  .band-inner .eyebrow{color:#C9D6D4}
  .band-inner h2{font-family:var(--serif);color:var(--ivory);font-size:clamp(36px,5vw,64px);line-height:1.02;letter-spacing:-0.015em;margin:0 0 28px}
  .band-inner p{margin:0;font-size:17px;font-weight:300;line-height:1.8;color:var(--cream)}

  /* ============ WHOLE HOUSE ============ */
  #whole{background:var(--ivory);text-align:center}
  #whole .inner{max-width:1000px;margin:0 auto}
  #whole h2{font-size:clamp(36px,5vw,62px);margin:0 0 30px;letter-spacing:-0.012em}
  #whole .lede{margin:0 auto 40px;max-width:620px;text-align:center}
  .whole-actions{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;align-items:center}
  .whole-actions .alt{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid rgba(42,38,32,0.4);padding-bottom:4px;transition:color .25s,border-color .25s}
  .whole-actions .alt:hover{color:var(--teal);border-color:var(--teal)}

  /* ============ LOCATION ============ */
  #location{background:var(--sand)}
  .loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center}
  .map{position:relative;width:100%;height:540px;background:#E7DCCB;overflow:hidden;border:1px solid var(--line)}
  .map iframe{width:100%;height:100%;border:0;filter:saturate(0.82) contrast(0.96)}
  .loc-h{font-size:clamp(34px,4.4vw,56px);margin:0 0 28px}
  .loc-facts{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
  .fact{padding:26px 24px;border-bottom:1px solid var(--line)}
  .fact:nth-child(odd){border-right:1px solid var(--line);padding-left:0}
  .fact:nth-child(even){padding-right:0}
  .fact:nth-child(3),.fact:nth-child(4){border-bottom:0;padding-bottom:0}
  .fact .n{margin:0 0 6px;font-family:var(--serif);font-size:30px;color:var(--ink)}
  .fact p{margin:0;font-size:12.5px;font-weight:300;line-height:1.55;color:var(--ink3)}
  .loc-note{margin:30px 0 0;font-size:13.5px;font-weight:300;line-height:1.7;color:var(--ink3)}

  /* ============ GALLERY ============ */
  #gallery{background:var(--sand)}
  #gallery .wrap{padding-bottom:130px}
  .gal{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:200px;gap:16px}
  .gal a{position:relative;overflow:hidden;background:#E7DCCB}
  .gal img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
  .gal a:hover img{transform:scale(1.06)}
  .g1{grid-column:span 7;grid-row:span 2}
  .g2{grid-column:span 5}
  .g3{grid-column:span 5}
  .g4{grid-column:span 4}
  .g5{grid-column:span 4}
  .g6{grid-column:span 4}

  /* ============ COLLECTION ============ */
  #collection{padding:110px 0;background:var(--warm);text-align:center}
  #collection .inner{max-width:1000px;margin:0 auto}
  #collection h2{font-size:clamp(30px,3.8vw,48px);line-height:1.1;margin:0 0 26px}
  #collection .lede{margin:0 auto 36px;max-width:600px;font-size:16px;line-height:1.78;text-align:center}
  .coll-link{display:inline-flex;align-items:center;gap:10px;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:5px;font-size:12px;letter-spacing:0.18em;text-transform:uppercase;transition:color .25s,border-color .25s}
  .coll-link:hover{color:var(--teal);border-color:var(--teal)}

  /* ============ INQUIRE ============ */
  #book{padding:92px 0;background:var(--dark);color:var(--cream);text-align:center}
  #book .wrap{max-width:1060px}
  .enq-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:88px;align-items:start}
  #book .eyebrow{color:var(--teal2)}
  #book h2{font-family:var(--serif);color:var(--ivory);font-size:clamp(30px,3.8vw,46px);line-height:1.05;letter-spacing:-0.01em;margin:0 0 14px}
  #book .intro{margin:0 auto 38px;max-width:520px;font-size:15.5px;font-weight:300;line-height:1.7;color:#D7CFC0}
  .contacts{display:flex;flex-direction:column;gap:26px;border-top:1px solid rgba(239,232,218,0.18);padding-top:36px}
  .contact{color:var(--cream);transition:color .25s}
  .contact:hover{color:var(--teal2)}
  .contact .k{margin:0 0 4px;font-size:10.5px;letter-spacing:0.24em;text-transform:uppercase;color:var(--teal2)}
  .contact .v{margin:0;font-family:var(--serif);font-size:24px}
  form{display:flex;flex-direction:column;gap:22px}
  .frow2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  .frow3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px}
  .field{display:flex;flex-direction:column;gap:9px}
  .field label{font-size:10.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal2)}
  .field input,.field select,.field textarea{background:transparent;border:0;border-bottom:1px solid rgba(239,232,218,0.3);
    color:var(--ivory);font-family:var(--sans);font-size:16px;font-weight:300;padding:10px 0;color-scheme:dark;width:100%}
  .field textarea{resize:vertical}
  .field input::placeholder,.field textarea::placeholder{color:rgba(239,232,218,0.4)}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal)}
  .field select option{color:var(--ink)}
  .submit{margin-top:12px;align-self:flex-start;background:var(--ivory);color:var(--dark);border:0;font-size:12px;letter-spacing:0.20em;text-transform:uppercase;padding:17px 38px;cursor:pointer;font-family:var(--sans);transition:background .25s,color .25s}
  .submit:hover{background:var(--teal);color:var(--ivory)}
  #sent-msg{display:none;margin:4px 0 0;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--teal2)}

  /* ============ FOOTER ============ */
  footer{background:var(--darker);color:#B7AE9E;padding:70px 0 40px}
  .foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:44px;border-bottom:1px solid rgba(183,174,158,0.16)}
  .foot-brand{display:flex;flex-direction:column;line-height:1}
  .foot-brand .name{font-family:var(--serif);font-size:27px;font-weight:500;letter-spacing:0.03em;color:var(--cream)}
  .foot-brand .sub{font-size:9.5px;letter-spacing:0.42em;text-transform:uppercase;color:#7E8E8B;margin-top:6px}
  .foot-links{display:flex;gap:40px;flex-wrap:wrap}
  .foot-link{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:#B7AE9E;transition:color .25s}
  .foot-link:hover{color:var(--cream)}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:28px}
  .foot-bottom p{margin:0;font-size:11.5px;letter-spacing:0.06em;color:#7E8E8B}
  .foot-credit{margin:22px 0 0;text-align:center;font-size:11px;letter-spacing:0.1em;color:#6B675C}
  .foot-credit a{color:#7E8E8B;border-bottom:1px solid rgba(126,142,139,0.35);padding-bottom:1px;transition:color .25s,border-color .25s}
  .foot-credit a:hover{color:var(--cream);border-color:var(--cream)}

  /* mobile menu panel */
  .mobile-menu{display:none}

  /* ============ RESPONSIVE ============ */
  @media (max-width:1024px){
    .wrap,.nav-inner,.hero-inner,.band-inner{padding-left:30px;padding-right:30px}
    .house-grid,.loc-grid,.enq-grid{gap:54px}
    .suite-panel{padding:64px 48px}
  }
  @media (max-width:900px){
    nav.links{display:none}
    .burger{display:block}
    header.open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
    header.open .burger span:nth-child(2){opacity:0}
    header.open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
    .mobile-menu{display:block;position:fixed;top:76px;left:0;width:100%;z-index:99;background:rgba(245,241,232,0.97);
      backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
      transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .3s,transform .3s}
    header.open + .mobile-menu{transform:none;opacity:1;pointer-events:auto}
    .mobile-menu a{display:block;padding:18px 30px;font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink2);border-top:1px solid var(--line)}
    .section{padding:90px 0}
    .house-grid{grid-template-columns:1fr;gap:48px}
    .house-fig{height:440px;order:-1}
    .stats{margin-top:64px}
    .suite-grid{grid-template-columns:1fr}
    .suite-fig{min-height:420px}
    .loc-grid{grid-template-columns:1fr;gap:40px}
    .map{height:400px;order:-1}
    .enq-grid{grid-template-columns:1fr;gap:48px}
    .rooms-head{flex-direction:column;align-items:flex-start;gap:22px;margin-bottom:48px}
    .rooms-grid{grid-template-columns:1fr 1fr;gap:26px}
    #book,#collection,.section{}
  }
  @media (max-width:600px){
    .wrap,.nav-inner,.hero-inner,.band-inner{padding-left:22px;padding-right:22px}
    .hero-inner{padding-bottom:70px}
    .section{padding:74px 0}
    .stats{grid-template-columns:1fr 1fr;row-gap:36px}
    .stat{padding:36px 20px 0 0}
    .stat:nth-child(2){border-right:0;padding-right:0;padding-left:20px}
    .stat:nth-child(3){padding-left:0}
    .stat:nth-child(odd){border-right:1px solid var(--line)}
    .stat:nth-child(even){border-right:0;padding-left:20px;padding-right:0}
    .rooms-grid{grid-template-columns:1fr;gap:40px}
    .room .ph{height:360px}
    .suite-panel{padding:48px 26px}
    .band{min-height:74vh}
    .frow2,.frow3{grid-template-columns:1fr}
    .gal{grid-auto-rows:150px;gap:10px}
    .g1{grid-column:span 12;grid-row:span 2}
    .g2,.g3{grid-column:span 12}
    .g4,.g5,.g6{grid-column:span 6}
    .hero-btns .btn,.whole-actions .btn{padding-top:15px;padding-bottom:15px}
    .foot-top{gap:28px}
    .foot-links{gap:22px}
  }
  @media (prefers-reduced-motion:reduce){
    *{animation:none!important;scroll-behavior:auto}
    .reveal{opacity:1;transform:none;transition:none}
    .hero-bg{transform:none}
  }


/* ===================== ROOM PAGES ===================== */
.btn-outline-dark{background:transparent;color:var(--ink);border:1px solid rgba(42,38,32,0.4);padding:16px 30px}
.btn-outline-dark:hover{background:var(--ink);color:var(--sand)}
.mobile-menu a.mm-cta{background:var(--ink);color:var(--sand);margin:12px 22px;padding:15px;text-align:center;border-top:0;letter-spacing:0.2em}

.room-hero{padding:152px 0 56px;background:var(--sand)}
.crumb{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal);transition:color .25s}
.room-hero .crumb{margin-bottom:30px}
.room-hero .eyebrow{margin-bottom:18px}
.room-hero h1{font-family:var(--serif);font-weight:400;color:var(--ink);font-size:clamp(42px,6.5vw,84px);line-height:0.98;letter-spacing:-0.018em;margin:0 0 22px}
.room-hero .lead{max-width:680px;font-size:17.5px;font-weight:300;line-height:1.75;color:var(--ink2);margin:0 0 30px}
.room-meta{margin-top:4px}
.room-cta-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center;margin-top:34px}

.room-gallery{padding:18px 0 56px;background:var(--sand)}
.gallery{column-count:3;column-gap:16px}
.gallery .shot{display:block;width:100%;margin:0 0 16px;padding:0;border:0;background:#E7DCCB;cursor:zoom-in;overflow:hidden;break-inside:avoid;line-height:0}
.gallery .shot img{width:100%;height:auto;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.gallery .shot:hover img{transform:scale(1.045)}
.also-note{margin:36px auto 0;max-width:700px;text-align:center;color:var(--ink3);font-size:14px;font-weight:300;line-height:1.7}

.book-band{background:var(--dark);color:var(--cream);padding:104px 0;text-align:center}
.book-band .eyebrow{color:var(--teal2)}
.book-band h2{font-family:var(--serif);color:var(--ivory);font-size:clamp(32px,4.4vw,56px);line-height:1.05;margin:0 0 22px;letter-spacing:-0.01em}
.book-band p{max-width:560px;margin:0 auto 36px;font-size:16px;font-weight:300;line-height:1.8;color:#D7CFC0}
.book-band .btn-light{background:var(--ivory);color:var(--dark)}
.book-band .btn-light:hover{background:var(--teal);color:var(--ivory)}

.other{padding:104px 0;background:var(--ivory)}
.other-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:48px;flex-wrap:wrap}
.other-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.6vw,44px);color:var(--ink);line-height:1.05}
.other-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.other-card{display:block;color:var(--ink)}
.other-card .oc-fig{height:300px;overflow:hidden;background:#E7DCCB;margin-bottom:18px}
.other-card .oc-fig img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.other-card:hover .oc-fig img{transform:scale(1.05)}
.other-card .oc-name{font-family:var(--serif);font-size:23px;font-weight:500;margin:0 0 5px}
.other-card .oc-tag{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--teal)}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(20,18,14,0.93);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}
.lb.open{display:flex;opacity:1}
.lb figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px}
.lb img{max-width:92vw;max-height:84vh;object-fit:contain;box-shadow:0 24px 70px rgba(0,0,0,0.55)}
.lb figcaption{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(239,232,218,0.7)}
.lb-btn{position:absolute;background:none;border:0;color:#EFE8DA;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0.75;transition:opacity .2s}
.lb-btn:hover{opacity:1}
.lb-close{top:22px;right:26px;width:44px;height:44px;font-size:22px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:56px;height:56px}
.lb-prev{left:14px}.lb-next{right:14px}
.lb-btn svg{width:30px;height:30px;stroke:currentColor;stroke-width:1.4;fill:none}

@media (max-width:900px){
  .gallery{column-count:2}
  .other-grid{grid-template-columns:1fr 1fr}
  .room-hero{padding:128px 0 44px}
}
@media (max-width:600px){
  .gallery{column-count:1;column-gap:10px}
  .gallery .shot{margin-bottom:10px}
  .other-grid{grid-template-columns:1fr;gap:30px}
  .book-band{padding:74px 0}
  .other{padding:74px 0}
  .lb-prev{left:4px}.lb-next{right:4px}
}

/* ===================== BOOKING (card links + modal) ===================== */
.room-actions{display:flex;align-items:center;gap:18px;margin-top:20px;flex-wrap:wrap}
.room-actions .airbnb{margin-top:0}
.viewlink{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink3);transition:color .25s}
.viewlink:hover{color:var(--teal)}
.suite-actions{display:flex;align-items:center;gap:20px;margin-top:38px;flex-wrap:wrap}
.suite-actions .suite-link{margin-top:0}
.suite-view{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--teal2);transition:color .25s}
.suite-view:hover{color:var(--cream)}

.bm{position:fixed;inset:0;z-index:300;background:rgba(20,18,14,0.62);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .25s}
.bm.open{display:flex;opacity:1}
.bm-panel{position:relative;width:100%;max-width:540px;background:var(--sand);color:var(--ink);padding:46px 44px 38px;box-shadow:0 30px 80px rgba(0,0,0,0.42);transform:translateY(10px);transition:transform .3s}
.bm.open .bm-panel{transform:none}
.bm-close{position:absolute;top:15px;right:17px;background:none;border:0;font-size:19px;line-height:1;color:var(--ink3);cursor:pointer;width:38px;height:38px;transition:color .2s}
.bm-close:hover{color:var(--ink)}
.bm .eyebrow{margin-bottom:13px}
.bm h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,4vw,40px);line-height:1.04;letter-spacing:-0.01em;margin:0 0 12px}
.bm-sub{font-size:14px;font-weight:300;line-height:1.6;color:var(--ink2);margin:0 0 24px}
.bm-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.bm-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--line)}
.bm-row:last-child{border-bottom:0}
.bm-name{display:block;font-family:var(--serif);font-size:21px;font-weight:500;color:var(--ink);line-height:1.1}
.bm-meta{display:block;font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);margin-top:5px}
.bm-btn{flex:none;background:var(--ink);color:var(--sand);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;padding:12px 20px;transition:background .25s,color .25s;white-space:nowrap}
.bm-btn:hover{background:var(--teal);color:var(--ivory)}
.bm-row.whole{border-top:1px solid var(--line);margin-top:6px;padding-top:18px}
.bm-row.whole .bm-name{font-style:italic}
@media (max-width:600px){
  .bm-panel{padding:38px 24px 28px}
  .bm h2{font-size:28px}
  .bm-row{padding:13px 0}
  .bm-name{font-size:18px}
  .bm-btn{padding:11px 15px}
}

/* ===================== BOOK / RESERVATIONS SECTION ===================== */
.bookbtns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.bookbtn{flex:1 1 0;min-width:165px;max-width:215px;display:flex;flex-direction:column;gap:6px;align-items:center;padding:26px 14px;border:1px solid rgba(239,232,218,0.32);color:var(--cream);transition:background .25s,color .25s,border-color .25s}
.bookbtn:hover{background:var(--ivory);color:var(--dark);border-color:var(--ivory)}
.bookbtn .rn{font-family:var(--serif);font-size:21px;font-weight:500;line-height:1.05}
.bookbtn .rs{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--teal2)}
.bookbtn:hover .rs{color:var(--teal)}
.book-contacts{display:flex;gap:14px 26px;justify-content:center;align-items:center;flex-wrap:wrap;margin:42px 0 0;font-size:11.5px;letter-spacing:0.14em;text-transform:uppercase}
.book-contacts .bc-q{color:#8A8276}
.book-contacts a{color:var(--cream);border-bottom:1px solid rgba(239,232,218,0.3);padding-bottom:2px;transition:color .25s,border-color .25s}
.book-contacts a:hover{color:var(--teal2);border-color:var(--teal2)}
@media (max-width:620px){
  .bookbtn{flex:1 1 calc(50% - 7px);min-width:calc(50% - 7px);max-width:none;padding:20px 12px}
  .book-contacts{gap:11px 18px}
}
