
  :root{
    --sand: #dfa974;
    --sand-dark: #c98e54;
    --sand-deep: #a26a36;
    --sand-50:  #fbf2e7;
    --teal: #13363d;
    --teal-2:#1d4a55;
    --ink: #1a2025;
    --muted:#6b6f73;
    --line:#e8e1d5;
    --cream:#faf5ee;
    --white:#ffffff;
    --shadow-sm: 0 1px 2px rgba(19,54,61,.06), 0 1px 1px rgba(19,54,61,.04);
    --shadow-md: 0 8px 24px -10px rgba(19,54,61,.18), 0 2px 6px rgba(19,54,61,.06);
    --shadow-lg: 0 30px 60px -30px rgba(19,54,61,.35), 0 10px 24px -16px rgba(19,54,61,.18);
    --radius: 4px;
    --radius-lg: 8px;
    --container: 1280px;
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--cream);color:var(--ink);font-family:'Manrope',ui-sans-serif,system-ui,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
  h1,h2,h3,h4,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;letter-spacing:-.01em;color:var(--teal)}
  h1{font-size:clamp(44px,6vw,80px);line-height:1.02;font-weight:500;margin:0}
  h2{font-size:clamp(32px,3.6vw,52px);line-height:1.05;margin:0 0 .35em;font-weight:500}
  h3{font-size:28px;line-height:1.15;margin:0 0 .3em;font-weight:600}
  h4{font-size:22px;margin:0 0 .25em}
  p{margin:0 0 1em}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  .container{max-width:var(--container);margin:0 auto;padding:0 28px}
  .eyebrow{font-family:'Manrope',sans-serif;text-transform:uppercase;letter-spacing:.22em;font-size:11px;font-weight:600;color:var(--sand-deep)}
  .eyebrow.on-dark{color:var(--sand)}
  .muted{color:var(--muted)}

  /* ===================== STICKY HEADER ===================== */
  .header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--line)}
  .header .row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;height:96px;gap:40px}
  .brand{display:flex;align-items:center;gap:14px}
  .brand-logo{height:74px;width:auto;display:block}
  footer .brand-logo{filter:brightness(0) invert(1);opacity:.92}
  .brand-mark{width:42px;height:42px;border-radius:50%;background:var(--teal);display:grid;place-items:center;color:var(--sand);font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600}
  .brand-name{display:flex;flex-direction:column;line-height:1}
  .brand-name .a{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--teal);font-weight:600;letter-spacing:.01em}
  .brand-name .b{font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:5px}
  .nav{display:flex;gap:32px;justify-content:center}
  .nav a{font-size:13.5px;font-weight:500;color:#2a3138;position:relative;padding:4px 0;transition:color .15s}
  .nav a:hover{color:var(--sand-deep)}
  .nav a.active{color:var(--teal)}
  .nav a.active:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--sand)}
  .header-cta{display:flex;align-items:center;gap:10px}
  .header-icon{position:relative;width:42px;height:42px;border-radius:4px;background:var(--cream);border:1px solid var(--line);display:grid;place-items:center;color:var(--teal);cursor:pointer;transition:all .18s;text-decoration:none}
  .header-icon:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:translateY(-1px)}
  .header-icon .tip{position:absolute;top:calc(100% + 10px);right:0;background:var(--teal);color:#fff;padding:8px 12px;border-radius:4px;font-size:12px;font-weight:600;letter-spacing:.02em;white-space:nowrap;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity .18s,transform .18s;box-shadow:var(--shadow-md)}
  .header-icon .tip:after{content:"";position:absolute;bottom:100%;right:14px;border:5px solid transparent;border-bottom-color:var(--teal)}
  .header-icon:hover .tip{opacity:1;transform:translateY(0)}
  .header-book{display:inline-flex;align-items:center;gap:10px;height:46px;padding:0 22px;border-radius:4px;background:var(--teal);color:#fff;font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:0;transition:all .18s;font-family:inherit;white-space:nowrap}
  .header-book:hover{background:var(--teal-2);transform:translateY(-1px);box-shadow:var(--shadow-md)}
  .header-book svg{transition:transform .2s}
  .header-book:hover svg{transform:translateX(2px)}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:46px;padding:0 22px;border-radius:4px;font-weight:600;font-size:13.5px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:0;transition:all .18s;white-space:nowrap}
  .btn-primary{background:var(--teal);color:#fff}
  .btn-primary:hover{background:var(--teal-2);transform:translateY(-1px);box-shadow:var(--shadow-md)}
  .btn-dark{background:var(--teal);color:#fff}
  .btn-dark:hover{background:var(--teal-2)}
  .btn-ghost{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}
  .btn-ghost:hover{background:var(--teal);color:#fff}
  .btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}
  .btn-ghost-light:hover{background:#fff;color:var(--teal);border-color:#fff}
  .btn-link{background:none;border:0;padding:0;color:var(--sand-deep);font-weight:600;font-size:13px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;display:inline-flex;gap:8px;align-items:center}
  .btn-link:after{content:"→";transition:transform .2s}
  .btn-link:hover:after{transform:translateX(4px)}

  /* ===================== MOBILE NAV (hamburger + drawer) ===================== */
  .nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;padding:0;border:1px solid var(--line);background:var(--cream);border-radius:4px;cursor:pointer;transition:border-color .18s}
  .nav-toggle:hover{border-color:var(--teal)}
  .nav-toggle span{display:block;width:20px;height:2px;background:var(--teal);border-radius:2px;transition:transform .26s ease,opacity .18s ease}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .mobile-menu{position:fixed;inset:0;z-index:200;visibility:hidden;opacity:0;transition:opacity .28s ease,visibility .28s ease}
  .mobile-menu.open{visibility:visible;opacity:1}
  .mobile-menu .backdrop{position:absolute;inset:0;background:rgba(13,32,37,.5);backdrop-filter:blur(2px)}
  .mobile-menu .panel{position:absolute;top:0;right:0;height:100%;width:min(84vw,360px);background:var(--cream);box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:20px 24px calc(28px + env(safe-area-inset-bottom));overflow-y:auto;-webkit-overflow-scrolling:touch}
  .mobile-menu.open .panel{transform:translateX(0)}
  .mm-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
  .mm-close{width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:4px;display:grid;place-items:center;color:var(--teal);cursor:pointer;transition:all .18s}
  .mm-close:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
  .mm-nav{display:flex;flex-direction:column;margin-top:6px}
  .mm-nav a{font-family:'Cormorant Garamond',serif;font-size:25px;font-weight:500;color:var(--teal);padding:14px 0;border-bottom:1px solid var(--line);transition:color .15s}
  .mm-nav a:hover,.mm-nav a.active{color:var(--sand-deep)}
  .mm-cta{margin-top:auto}
  .mm-cta .btn{width:100%;height:54px}
  .mm-call{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;color:var(--sand-deep);font-weight:600;font-size:14px;letter-spacing:.02em}

  /* ===================== HERO BOOKING CARD ===================== */
  .hero-grid{display:grid;grid-template-columns:1fr 400px;gap:50px;align-items:end;height:100%;padding-bottom:60px}
  .book-card{background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-radius:6px;box-shadow:0 30px 80px -20px rgba(0,0,0,.45);padding:28px 28px 24px;color:var(--ink);position:relative;align-self:end}
  .book-card .from-line{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:6px}
  .book-card .from-line .from{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}
  .book-card .from-line .nights{font-size:11.5px;color:var(--muted);font-weight:500}
  .book-card .price-hero{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
  .book-card .price-hero b{font-family:'Cormorant Garamond',serif;font-size:42px;color:var(--teal);font-weight:600;line-height:1}
  .book-card .price-hero small{font-size:13px;color:var(--muted);font-weight:500}
  .book-card .price-hero .strike{font-size:14px;color:#a89e94;text-decoration:line-through}
  .book-card .save-tag{display:inline-block;background:var(--sand-50);color:var(--sand-deep);font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:5px 10px;border-radius:99px;margin-bottom:20px}
  .book-fields{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:4px;overflow:hidden;margin-bottom:14px}
  .book-field{padding:12px 14px;cursor:pointer;transition:background .15s;position:relative}
  .book-field:hover{background:var(--sand-50)}
  .book-field+.book-field{border-left:1px solid var(--line)}
  .book-field.full{grid-column:1/-1;border-top:1px solid var(--line);border-left:0}
  .book-field .lbl{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:5px;margin-bottom:4px}
  .book-field .lbl svg{width:11px;height:11px;color:var(--sand-deep)}
  .book-field .vv{font-size:14px;font-weight:600;color:var(--teal);line-height:1.25;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
  .book-field .vv .caret{color:var(--muted);font-size:10px;margin-left:auto}
  .book-field .vv small{font-size:12px;color:var(--muted);font-weight:500;flex-basis:100%;margin-top:2px}
  .book-field .lbl{cursor:pointer}
  .book-field .book-date,.book-field .book-promo{width:100%;border:0;background:transparent;font-family:inherit;font-size:14px;font-weight:600;color:var(--teal);line-height:1.25;padding:0;outline:none}
  .book-field .book-date{cursor:pointer}
  .book-field .book-date::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}
  .book-field .book-promo::placeholder{color:var(--muted);font-weight:500}
  .book-cta{width:100%;height:54px;background:var(--teal);color:#fff;border:0;border-radius:4px;font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s;display:flex;align-items:center;justify-content:center;gap:10px}
  .book-cta:hover{background:var(--teal-2);transform:translateY(-1px)}
  .book-cta svg{transition:transform .2s}
  .book-cta:hover svg{transform:translateX(3px)}
  .book-perks{display:flex;flex-wrap:wrap;gap:8px 14px;padding-top:14px;margin-top:14px;border-top:1px dashed var(--line);font-size:11.5px;color:var(--muted);justify-content:center}
  .book-perks .pk{display:inline-flex;align-items:center;gap:5px}
  .book-perks svg{color:var(--sand-deep);flex:0 0 auto}
  /* Legal / utility pages (Privacy, Terms) */
  .legal{max-width:760px;margin:0 auto;color:#3a4046;font-size:16px;line-height:1.75}
  .legal h2{font-family:'Cormorant Garamond',serif;color:var(--teal);font-size:28px;font-weight:600;margin:36px 0 12px}
  .legal h3{color:var(--teal);font-size:18px;margin:24px 0 8px}
  .legal p{margin:0 0 16px}
  .legal ul{margin:0 0 16px;padding-left:20px}
  .legal li{margin:6px 0}
  .legal a{color:var(--teal);text-decoration:underline}
  .legal .muted{color:var(--muted);font-size:13.5px}
  .book-urgency{display:flex;align-items:center;gap:8px;font-size:12px;color:#b54a3a;font-weight:600;margin-bottom:14px;background:rgba(217,74,54,.06);padding:8px 12px;border-radius:4px}
  .book-urgency .blip{width:8px;height:8px;border-radius:50%;background:#d94a36;flex:0 0 auto;box-shadow:0 0 0 0 rgba(217,74,54,.6);animation:pulse 1.8s infinite}

  /* ===================== HERO ===================== */
  .hero{position:relative;min-height:680px;height:auto;overflow:hidden;color:#fff}
  .hero-img{position:absolute;inset:0}
  .hero-img img{width:100%;height:100%;object-fit:cover}
  .hero-img:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,54,61,.35) 0%,rgba(19,54,61,.15) 40%,rgba(19,54,61,.55) 100%),radial-gradient(ellipse 70% 90% at 18% 55%,rgba(13,32,37,.78) 0%,rgba(13,32,37,.55) 30%,rgba(13,32,37,0) 65%)}
  .hero-content{position:relative;height:100%;padding-top:80px}
  .hero-text{padding-bottom:20px}
  .hero-meta .stars{color:var(--sand);letter-spacing:2px}
  .hero-meta .dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.55)}
  .hero-meta span{font-size:13px;letter-spacing:.06em;font-weight:500}
  .hero h1{color:#fff;max-width:14ch;font-weight:400;text-shadow:0 2px 24px rgba(0,0,0,.35),0 1px 3px rgba(0,0,0,.25)}
  .hero h1 em{font-style:normal;color:var(--sand)}
  .hero-sub{font-size:17px;max-width:46ch;margin-top:18px;color:rgba(255,255,255,.95);font-weight:300;text-shadow:0 1px 12px rgba(0,0,0,.35)}
  .hero-meta{display:flex;gap:14px;align-items:center;margin-bottom:18px;flex-wrap:wrap;text-shadow:0 1px 8px rgba(0,0,0,.35)}
  .hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
  .hero-badges{position:absolute;right:28px;top:28px;display:flex;gap:10px;align-items:center;font-size:12px;color:#fff}
  .badge-pill{background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);padding:8px 14px;border-radius:99px;display:inline-flex;align-items:center;gap:8px}
  .scroll-hint{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);font-size:11px;letter-spacing:.3em;color:rgba(255,255,255,.7);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
  .scroll-hint:after{content:"";width:1px;height:32px;background:rgba(255,255,255,.5);animation:drop 2.2s ease-in-out infinite}
  @keyframes drop{0%,100%{transform:scaleY(1);transform-origin:top}50%{transform:scaleY(.3);transform-origin:top}}

  /* ===================== TRUST STRIP ===================== */
  .trust{background:var(--teal);color:#fff;padding:22px 0}
  .trust .inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
  .trust .item{display:flex;align-items:center;gap:12px;font-size:13.5px}
  .trust .item b{display:block;font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--sand);font-weight:600;line-height:1.1}
  .trust .item span{color:rgba(255,255,255,.78);font-size:12px}
  .trust .sep{width:1px;height:38px;background:rgba(255,255,255,.14)}

  /* ===================== SECTIONS ===================== */
  section{position:relative}
  .pad{padding:110px 0}
  .pad-sm{padding:70px 0}
  .section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:54px}
  .section-head .lead{max-width:560px}
  .section-head .lead h2{margin-bottom:.2em}
  .section-head .right{max-width:380px;color:var(--muted);font-size:15px}
  .center{text-align:center}
  .center .section-head{flex-direction:column;align-items:center;text-align:center}

  /* Welcome */
  .welcome{background:var(--cream)}
  .welcome-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center}
  .welcome-text .eyebrow{margin-bottom:18px;display:block}
  .welcome-text h2{margin-bottom:24px}
  .welcome-text h2 em{font-style:italic;color:var(--sand-deep)}
  .welcome-text p{color:#3a4046;font-size:17px;line-height:1.75}
  .welcome-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px;padding-top:32px;border-top:1px solid var(--line)}
  .welcome-stats .s b{display:block;font-family:'Cormorant Garamond',serif;font-size:38px;color:var(--teal);font-weight:600;line-height:1}
  .welcome-stats .s span{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:6px;display:block}
  .welcome-img{position:relative;height:540px}
  .welcome-img .a, .welcome-img .b{position:absolute;overflow:hidden;border-radius:2px;box-shadow:var(--shadow-lg)}
  .welcome-img .a{width:74%;height:80%;top:0;right:0;background:#ddd}
  .welcome-img .b{width:50%;height:50%;bottom:0;left:0;border:8px solid var(--cream);background:#ddd}
  .welcome-img img{width:100%;height:100%;object-fit:cover}
  .welcome-img .stamp{position:absolute;left:-10px;top:32%;background:var(--teal);color:#fff;padding:14px 18px;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;line-height:1.1;box-shadow:var(--shadow-md);transform:rotate(-3deg);z-index:2;max-width:170px;text-align:center}
  .welcome-img .stamp small{display:block;font-family:'Manrope',sans-serif;font-size:9px;letter-spacing:.22em;font-weight:700;margin-top:4px;color:var(--sand);text-transform:uppercase}

  /* ===================== AMENITIES BOXES ===================== */
  .amenities{background:var(--white)}
  .am-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
  .am-card{position:relative;overflow:hidden;border-radius:2px;background:#222;color:#fff;aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;cursor:pointer;transition:transform .4s ease}
  .am-card:hover{transform:translateY(-4px)}
  .am-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s ease;z-index:0}
  .am-card:hover img{transform:scale(1.06)}
  .am-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.15) 35%,rgba(19,54,61,.78) 100%);z-index:1}
  .am-card>*{position:relative;z-index:2}
  .am-card .ico{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);display:grid;place-items:center;margin-bottom:14px;color:#fff}
  .am-card h3{color:#fff;margin-bottom:8px;font-weight:500;font-size:30px}
  .am-card p{font-size:13.5px;color:rgba(255,255,255,.88);line-height:1.5;margin:0 0 14px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
  .am-card .more{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--sand);display:inline-flex;align-items:center;gap:8px}
  .am-card .more:after{content:"→"}
  .am-card .number{position:absolute;top:24px;left:24px;font-family:'Cormorant Garamond',serif;font-size:14px;color:rgba(255,255,255,.6);letter-spacing:.2em;font-weight:500;z-index:2}

  /* ===================== ROOMS GRID ===================== */
  .rooms{background:var(--cream)}
  .rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
  .room-card{background:#fff;border-radius:2px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .25s, box-shadow .25s;position:relative}
  .room-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
  .room-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#eee}
  .room-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .room-card:hover .room-img img{transform:scale(1.04)}
  .room-tag{position:absolute;top:14px;left:14px;background:#fff;color:var(--teal);font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:7px 12px;border-radius:2px}
  .room-tag.dark{background:var(--teal);color:#fff}
  .room-fav{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--teal);cursor:pointer;transition:all .2s}
  .room-fav:hover{background:#fff;color:var(--sand-deep)}
  .room-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
  .room-body h3{font-family:'Cormorant Garamond',serif;font-size:26px;margin-bottom:4px;color:var(--teal)}
  .room-body .room-title{margin-bottom:9px}
  .room-title a{color:inherit;text-decoration:none}
  .room-title a::after{content:"";position:absolute;inset:0;z-index:1}        /* stretched link → whole card opens the room */
  .room-card:hover .room-title a{color:var(--sand-deep)}
  /* spec row (guests · size) with hairline dividers + a separate bed line — replaces the old emoji .room-meta */
  .room-specs{list-style:none;margin:0 0 11px;padding:0;display:flex;flex-wrap:wrap;align-items:center}
  .room-specs li{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--teal-2)}
  .room-specs li + li{margin-left:13px;padding-left:13px;border-left:1px solid var(--line)}
  .room-specs svg{width:16px;height:16px;color:var(--sand-deep);flex:none}
  .room-bed{display:flex;align-items:flex-start;gap:8px;margin:0 0 16px;font-size:12.5px;line-height:1.45;color:var(--muted)}
  .room-bed svg{width:16px;height:16px;color:var(--sand-deep);flex:none;margin-top:2px}
  .room-bed span{flex:1}
  .room-feats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
  .room-feats .f{font-size:11px;color:#4a5258;background:var(--sand-50);padding:5px 10px;border-radius:2px;letter-spacing:.04em;font-weight:500}
  .room-bottom{margin-top:auto;display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:16px;border-top:1px solid var(--line)}
  .room-more{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--teal-2);transition:color .2s}
  .room-more span{transition:transform .2s}
  .room-card:hover .room-more{color:var(--sand-deep)}
  .room-card:hover .room-more span{transform:translateX(3px)}
  .room-book{position:relative;z-index:2}      /* breaks out above the stretched link → opens PHOBS */
  .price .from{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
  .price .num{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--teal);font-weight:600;line-height:1;display:flex;align-items:baseline;gap:4px}
  .price .num small{font-size:14px;font-family:'Manrope',sans-serif;font-weight:500;color:var(--muted)}
  .price .strike{font-size:13px;color:#a3a3a3;text-decoration:line-through;margin-left:6px}
  .room-bottom .btn-primary{height:40px;padding:0 18px;font-size:11.5px}
  .room-urgency{display:flex;align-items:center;gap:8px;font-size:12px;color:#b54a3a;font-weight:600;margin-bottom:14px}
  .room-urgency .blip{width:8px;height:8px;border-radius:50%;background:#d94a36;box-shadow:0 0 0 0 rgba(217,74,54,.6);animation:pulse 1.8s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(217,74,54,.6)}70%{box-shadow:0 0 0 10px rgba(217,74,54,0)}100%{box-shadow:0 0 0 0 rgba(217,74,54,0)}}
  .rooms-cta{text-align:center;margin-top:48px}

  /* ===================== BEST PRICE STRIPE ===================== */
  .stripe{background:var(--teal);color:#fff;padding:26px 0}
  .stripe .inner{display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap}
  .stripe .items{display:flex;gap:36px;flex-wrap:wrap}
  .stripe .item{display:flex;align-items:center;gap:12px;font-size:14.5px;font-weight:600}
  .stripe .item svg{flex:0 0 auto}
  .stripe .item small{display:block;font-weight:400;font-size:12px;color:rgba(255,255,255,.7);margin-top:2px}

  /* ===================== OFFERS ===================== */
  .offers{background:var(--white)}
  .offers-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
  .offer-card{position:relative;border-radius:2px;overflow:hidden;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;min-height:340px}
  .offer-card.feat{min-height:480px}
  .offer-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .8s}
  .offer-card:hover img{transform:scale(1.04)}
  .offer-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,54,61,.25),rgba(19,54,61,.85));z-index:1}
  .offer-card>*{position:relative;z-index:2}
  .offer-card .deal{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--sand);font-style:italic;margin-bottom:6px;font-weight:500}
  .offer-card h3{color:#fff;font-weight:500;font-size:32px;margin-bottom:10px}
  .offer-card.feat h3{font-size:44px}
  .offer-card p{font-size:14px;color:rgba(255,255,255,.85);margin-bottom:16px;max-width:42ch}
  .offer-card .save{display:inline-block;background:#fff;color:var(--teal);padding:6px 12px;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;border-radius:2px}

  /* ===================== RESTAURANT ===================== */
  .restaurant{background:var(--cream);overflow:hidden}
  .restaurant-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
  .restaurant-img{position:relative;height:600px}
  .restaurant-img .big{position:absolute;inset:0;overflow:hidden}
  .restaurant-img .big img{width:100%;height:100%;object-fit:cover}
  .restaurant-img .small{position:absolute;width:42%;height:46%;bottom:-30px;right:-30px;border:10px solid var(--cream);box-shadow:var(--shadow-lg);overflow:hidden}
  .restaurant-img .small img{width:100%;height:100%;object-fit:cover}
  .menu-list{list-style:none;padding:0;margin:28px 0 0}
  .menu-list li{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px dashed var(--line);gap:24px}
  .menu-list li:last-child{border-bottom:0}
  .menu-list .name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--teal);font-weight:600}
  .menu-list .desc{font-size:13px;color:var(--muted);font-style:italic;display:block;font-family:'Cormorant Garamond',serif;font-weight:400}
  .menu-list .price{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--sand-deep);font-weight:600;white-space:nowrap}

  /* ===================== EXCURSIONS ===================== */
  .excursions{background:var(--teal);color:#fff}
  .excursions h2{color:#fff}
  .excursions .right{color:rgba(255,255,255,.7)}
  .exc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .exc-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:2px;overflow:hidden;display:flex;flex-direction:column;transition:all .25s}
  .exc-card:hover{background:rgba(255,255,255,.07);transform:translateY(-3px)}
  .exc-img{aspect-ratio:5/3;overflow:hidden;background:#0a1f24;position:relative}
  .exc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .exc-card:hover .exc-img img{transform:scale(1.05)}
  .exc-img .dur{position:absolute;bottom:12px;left:12px;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);padding:6px 10px;font-size:11px;letter-spacing:.1em;font-weight:600;color:#fff}
  .exc-body{padding:24px}
  .exc-body h3{color:#fff;font-size:24px;margin-bottom:6px}
  .exc-body p{font-size:13.5px;color:rgba(255,255,255,.7);margin-bottom:18px}
  .exc-foot{display:flex;justify-content:flex-end;align-items:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}
  .exc-foot .p{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--sand);font-weight:600}
  .exc-foot .p small{font-size:11px;font-family:'Manrope',sans-serif;color:rgba(255,255,255,.5);font-weight:500;letter-spacing:.1em;display:block}
  .exc-foot button{background:transparent;color:var(--sand);border:1px solid rgba(223,169,116,.5);height:36px;padding:0 16px;font-size:11px;letter-spacing:.16em;font-weight:600;text-transform:uppercase;cursor:pointer;transition:all .2s;border-radius:4px}
  .exc-foot button:hover{background:var(--sand);color:var(--teal);border-color:var(--sand)}

  /* ===================== GETTING HERE ===================== */
  .getting{background:var(--cream)}
  .getting-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .way{background:#fff;padding:32px;border-radius:2px;border:1px solid var(--line);position:relative;transition:all .25s}
  .way:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--sand)}
  .way .num{position:absolute;top:24px;right:24px;font-family:'Cormorant Garamond',serif;font-size:60px;color:var(--sand);opacity:.3;line-height:1;font-weight:600}
  .way .ico{width:54px;height:54px;border-radius:50%;background:var(--sand-50);display:grid;place-items:center;color:var(--sand-deep);margin-bottom:20px}
  .way h3{font-size:26px;margin-bottom:10px}
  .way p{font-size:14px;color:#4a5258;line-height:1.6;margin-bottom:16px}
  .way .meta{display:flex;gap:14px;font-size:12px;color:var(--muted);padding-top:14px;border-top:1px solid var(--line)}
  .way .meta b{color:var(--teal);font-weight:600}

  /* ===================== TESTIMONIALS ===================== */
  .testi{background:var(--white)}
  .testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
  .testi-card{padding:36px 32px;background:var(--cream);position:relative;border-radius:2px}
  .testi-card .quote{font-family:'Cormorant Garamond',serif;font-size:80px;color:var(--sand);line-height:.6;height:36px;margin-bottom:8px;font-weight:600}
  .testi-card .stars{color:var(--sand);letter-spacing:2px;font-size:14px;margin-bottom:16px}
  .testi-card .text{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:#2a3138;line-height:1.45;margin-bottom:24px;font-style:italic}
  .testi-card .who{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line)}
  .testi-card .who .name{font-weight:600;font-size:14px;color:var(--teal)}
  .testi-card .who .src{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
  .testi-summary{display:flex;justify-content:center;gap:50px;margin-top:60px;flex-wrap:wrap}
  .testi-summary .s{text-align:center}
  .testi-summary .s b{display:block;font-family:'Cormorant Garamond',serif;font-size:46px;color:var(--teal);font-weight:600;line-height:1}
  .testi-summary .s span{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:6px;display:block}

  /* ===================== NEWSLETTER ===================== */
  .news{background:url('/app/uploads/2021/01/DJI_0818-2.jpg') center/cover no-repeat;position:relative;color:#fff;text-align:center}
  .news:before{content:"";position:absolute;inset:0;background:rgba(19,54,61,.75)}
  .news .inner{position:relative;padding:80px 0;max-width:680px;margin:0 auto;text-align:center}
  .news h2{color:#fff}
  .news p{color:rgba(255,255,255,.8);margin-bottom:28px}
  .news form{display:flex;gap:8px;max-width:480px;margin:0 auto}
  .news input{flex:1;height:54px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:#fff;padding:0 18px;font-family:inherit;font-size:14px;border-radius:2px}
  .news input::placeholder{color:rgba(255,255,255,.6)}
  .news input:focus{outline:none;border-color:var(--sand);background:rgba(255,255,255,.18)}
  .news button{height:54px}

  /* ===================== FOOTER ===================== */
  footer{background:var(--teal);color:rgba(255,255,255,.7);padding:80px 0 0}
  footer h4{color:#fff;font-family:'Manrope',sans-serif;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:24px}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:50px;margin-bottom:60px}
  .foot-grid p{font-size:14px;line-height:1.7;color:rgba(255,255,255,.7);max-width:36ch}
  .foot-grid .brand-name .a{color:#fff}
  .foot-grid .brand-name .b{color:rgba(255,255,255,.5)}
  .foot-grid ul{list-style:none;padding:0;margin:0}
  .foot-grid li{margin-bottom:10px;font-size:14px}
  .foot-grid a{color:rgba(255,255,255,.7);transition:color .2s}
  .foot-grid a:hover{color:var(--sand)}
  .foot-grid .ico-line{display:flex;gap:12px;font-size:14px;margin-bottom:14px;color:rgba(255,255,255,.85)}
  .foot-grid .ico-line svg{color:var(--sand);flex:0 0 18px}
  .socials{display:flex;gap:10px;margin-top:18px}
  .socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;transition:all .2s}
  .socials a:hover{background:var(--sand);color:var(--teal)}
  .copy{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;display:flex;justify-content:space-between;font-size:12.5px;color:rgba(255,255,255,.5)}
  .copy a{color:rgba(255,255,255,.6)}
  .copy .links{display:flex;gap:24px}

  /* ===================== MOBILE STICKY CTA ===================== */
  .mob-cta{display:none}

  /* ===================== RESPONSIVE ===================== */
  @media (max-width:1100px){
    .rooms-grid{grid-template-columns:repeat(2,1fr)}
    .am-grid{grid-template-columns:repeat(2,1fr)}
    .exc-grid,.getting-grid,.testi-grid{grid-template-columns:1fr 1fr}
    .offers-grid{grid-template-columns:1fr 1fr}
    .welcome-grid,.restaurant-grid{grid-template-columns:1fr;gap:50px}
    .welcome-img,.restaurant-img{height:480px}
    .header-icon[data-phone]{display:none}
    .hero-grid{grid-template-columns:1fr 360px;gap:32px}
  }
  /* collapse the nav into the drawer before the full menu would get cramped (tablets) */
  @media (max-width:1024px){
    .nav{display:none}
    .nav-toggle{display:flex}
    .header .row{grid-template-columns:auto 1fr;gap:20px}
    .header-cta{justify-content:flex-end}
  }
  @media (max-width:780px){
    .container{padding:0 20px}
    .pad{padding:64px 0}
    .pad-sm{padding:48px 0}

    /* mobile header → logo + hamburger only; Reserve lives in the bottom CTA bar + drawer */
    .header .row{height:64px;gap:16px}
    .header .brand-logo{height:46px}
    .header-book{display:none}

    .section-head{flex-direction:column;align-items:flex-start;text-align:left;gap:14px;margin-bottom:34px}
    .center .section-head{align-items:center;text-align:center}

    .hero{min-height:0;height:auto}
    .hero-content{padding:84px 20px 44px}
    .hero-grid{grid-template-columns:1fr;gap:24px}
    .hero-text{padding-bottom:0}
    .book-card{padding:22px 20px 20px}
    .book-card .price-hero b{font-size:34px}
    .book-fields{grid-template-columns:1fr 1fr}

    /* trust strip → tidy 2-up grid, no vertical dividers */
    .trust{padding:24px 0}
    .trust .inner{display:grid;grid-template-columns:1fr 1fr;gap:18px 14px}
    .trust .sep{display:none}
    .trust .item{align-items:flex-start}
    .trust .item b{font-size:18px}

    .welcome-stats{gap:12px}
    .welcome-stats .s{min-width:0}
    .welcome-stats .s b{font-size:28px;overflow-wrap:anywhere}
    .welcome-img{height:380px}

    .am-grid,.rooms-grid,.exc-grid,.getting-grid,.testi-grid,.offers-grid{grid-template-columns:1fr;gap:18px}
    .am-card{aspect-ratio:4/3}
    .offer-card.feat{min-height:380px}

    .stripe .inner{gap:18px}
    .stripe .items{gap:18px}
    .stripe .inner>.btn{width:100%}

    .testi-summary{gap:26px;margin-top:36px}

    /* newsletter → restore side padding (the .inner override had stripped it) + stack form */
    .news .inner{padding:56px 22px}
    .news form{flex-direction:column;max-width:none}
    .news input,.news form .btn{width:100%}

    .foot-grid{grid-template-columns:1fr 1fr;gap:28px 24px}
    footer{padding-top:60px}
    .copy{flex-direction:column;gap:10px;align-items:flex-start}

    /* sticky bottom CTA (paired with .mob-cta markup in footer) */
    .mob-cta{display:flex;gap:10px;position:fixed;bottom:0;left:0;right:0;z-index:60;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--line);box-shadow:0 -8px 24px rgba(19,54,61,.10)}
    .mob-cta .btn{flex:1;height:50px}
    body{padding-bottom:calc(74px + env(safe-area-inset-bottom))}
  }

  /* small icon helper */
  .ic{display:inline-block;vertical-align:middle}


  /* ===================== PAGE HERO (sub-pages) ===================== */
  .page-hero{position:relative;height:46vh;min-height:380px;overflow:hidden;color:#fff;display:flex;align-items:flex-end}
  .page-hero .ph-img{position:absolute;inset:0}
  .page-hero .ph-img img{width:100%;height:100%;object-fit:cover}
  /* Layered scrim: bottom band carries the text, left band guards against bright
     right-side images. Darker near-black-teal so even sunny photos keep contrast. */
  .page-hero .ph-img:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,22,26,.32) 0%,rgba(8,22,26,.14) 28%,rgba(8,22,26,.58) 66%,rgba(8,22,26,.86) 100%),linear-gradient(90deg,rgba(8,22,26,.46) 0%,rgba(8,22,26,.12) 48%,rgba(8,22,26,0) 80%)}
  .page-hero .inner{position:relative;width:100%;padding-bottom:60px}
  .crumbs{display:flex;gap:10px;align-items:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.82);font-weight:600;margin-bottom:20px;text-shadow:0 1px 6px rgba(0,0,0,.45)}
  .crumbs a{color:rgba(255,255,255,.7);transition:color .2s}
  .crumbs a:hover{color:var(--sand)}
  .crumbs .sep{color:rgba(255,255,255,.4)}
  .crumbs .here{color:var(--sand)}
  .page-hero h1{color:#fff;font-weight:400;text-shadow:0 2px 20px rgba(0,0,0,.5),0 1px 4px rgba(0,0,0,.55);font-size:clamp(38px,5vw,68px);max-width:18ch}
  .page-hero h1 em{font-style:italic;color:var(--sand);text-shadow:0 2px 20px rgba(0,0,0,.55),0 1px 4px rgba(0,0,0,.6)}
  .page-hero .sub{font-size:17px;max-width:54ch;margin-top:18px;color:rgba(255,255,255,.95);font-weight:400;text-shadow:0 1px 10px rgba(0,0,0,.5),0 1px 3px rgba(0,0,0,.45)}

  /* ===================== ROOM LIST PAGE ===================== */
  .room-row{display:grid;grid-template-columns:1.1fr 1fr;background:#fff;border-radius:2px;overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:32px;transition:box-shadow .25s,transform .25s}
  .room-row:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
  .room-row .pic{position:relative;aspect-ratio:auto;min-height:380px;overflow:hidden}
  .room-row .pic img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .room-row:hover .pic img{transform:scale(1.03)}
  .room-row .body{padding:38px 40px;display:flex;flex-direction:column}
  .room-row h3{font-size:34px;margin-bottom:4px}
  .room-row .row-meta{display:flex;flex-wrap:wrap;gap:14px;color:var(--muted);font-size:13px;margin-bottom:18px}
  .room-row p{color:#3a4046;font-size:15px;line-height:1.65;margin-bottom:20px}
  .room-row ul.amen{list-style:none;padding:0;margin:0 0 24px;display:grid;grid-template-columns:1fr 1fr;gap:6px 18px;font-size:13px;color:#3a4046}
  .room-row ul.amen li{display:flex;align-items:center;gap:8px}
  .room-row ul.amen svg{color:var(--sand-deep);flex:0 0 14px}
  .room-row .foot{margin-top:auto;padding-top:20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;align-items:center;gap:18px;flex-wrap:wrap}

  /* ===================== AMENITY PAGE BIG ===================== */
  .amen-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-bottom:100px}
  .amen-row:nth-child(even) .amen-pic{order:2}
  .amen-row:last-child{margin-bottom:0}
  .amen-pic{aspect-ratio:5/4;overflow:hidden;border-radius:2px;box-shadow:var(--shadow-lg)}
  .amen-pic img{width:100%;height:100%;object-fit:cover}
  .amen-text .eyebrow{display:block;margin-bottom:14px}
  .amen-text h2{margin-bottom:18px}
  .amen-text h2 em{font-style:italic;color:var(--sand-deep)}
  .amen-text p{color:#3a4046;font-size:16px;line-height:1.75}
  .amen-text ul.dots{list-style:none;padding:0;margin:24px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:10px 20px;font-size:14px;color:#3a4046}
  .amen-text ul.dots li{display:flex;gap:10px;align-items:flex-start}
  .amen-text ul.dots svg{color:var(--sand-deep);flex:0 0 16px;margin-top:3px}

  /* ===================== CONTACT PAGE ===================== */
  .contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px}
  .contact-info{background:#fff;padding:44px;border-radius:2px;box-shadow:var(--shadow-sm)}
  .contact-info h3{margin-bottom:24px;font-size:30px}
  .contact-info .ci{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
  .contact-info .ci:last-child{border-bottom:0}
  .contact-info .ci .ic-wrap{width:44px;height:44px;border-radius:50%;background:var(--sand-50);display:grid;place-items:center;color:var(--sand-deep);flex:0 0 44px}
  .contact-info .ci .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:4px}
  .contact-info .ci .val{font-size:15px;color:var(--teal);font-weight:600}
  .contact-info .ci .val small{display:block;font-weight:400;color:var(--muted);font-size:13px;margin-top:2px;letter-spacing:0;text-transform:none}
  .contact-form{background:var(--cream);padding:44px;border-radius:2px;border:1px solid var(--line)}
  .contact-form h3{margin-bottom:6px;font-size:30px}
  .contact-form .sub{color:var(--muted);font-size:14px;margin-bottom:28px}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
  .form-row.full{grid-template-columns:1fr}
  .field{display:flex;flex-direction:column}
  .field label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:6px}
  .field input,.field textarea,.field select{height:48px;background:#fff;border:1px solid var(--line);padding:0 14px;font-family:inherit;font-size:14px;color:var(--ink);border-radius:2px;transition:border-color .15s,box-shadow .15s}
  .field textarea{height:auto;padding:14px;min-height:140px;resize:vertical}
  .field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--sand);box-shadow:0 0 0 3px rgba(223,169,116,.18)}
  .map-wrap{margin-top:60px;border-radius:2px;overflow:hidden;height:480px;box-shadow:var(--shadow-md);background:#13363d url('/app/uploads/2020/11/DJI_0452.jpg') center/cover}
  .map-wrap iframe{width:100%;height:100%;border:0;display:block}

  /* ===================== OFFER PAGE LIST ===================== */
  .offer-list{display:grid;grid-template-columns:1fr;gap:32px}
  .offer-row{display:grid;grid-template-columns:1fr 1.2fr;background:#fff;border-radius:2px;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .25s,transform .25s}
  .offer-row:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
  .offer-row .pic{min-height:340px;position:relative;overflow:hidden}
  .offer-row .pic img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .offer-row:hover .pic img{transform:scale(1.04)}
  .offer-row .pic .badge{position:absolute;top:18px;left:18px;background:#fff;color:var(--teal);padding:8px 14px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;border-radius:2px}
  .offer-row .body{padding:40px;display:flex;flex-direction:column}
  .offer-row .body h3{font-size:34px;margin-bottom:6px}
  .offer-row .body .deal{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--sand-deep);font-size:18px;margin-bottom:14px}
  .offer-row .body p{color:#3a4046;font-size:15px;line-height:1.7;margin-bottom:18px}
  .offer-row .body ul.incl{list-style:none;padding:0;margin:0 0 22px;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;font-size:13.5px;color:#3a4046}
  .offer-row .body ul.incl li{display:flex;gap:8px;align-items:center}
  .offer-row .body ul.incl svg{color:var(--sand-deep);flex:0 0 14px}
  .offer-row .foot{margin-top:auto;padding-top:18px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:14px}
  .offer-row .price-block .from{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
  .offer-row .price-block b{font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--teal);font-weight:600;display:inline-flex;align-items:baseline;gap:8px}
  .offer-row .price-block b .strike{font-size:15px;color:#a89e94;text-decoration:line-through;font-weight:500}

  /* ===================== EXCURSION PAGE ===================== */
  .exc-grid-big{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
  .exc-card-big{background:#fff;border-radius:2px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
  .exc-card-big:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
  .exc-card-big .pic{aspect-ratio:16/9;overflow:hidden;position:relative}
  .exc-card-big .pic img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .exc-card-big:hover .pic img{transform:scale(1.04)}
  .exc-card-big .pic .dur{position:absolute;bottom:14px;left:14px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);padding:6px 12px;font-size:11px;letter-spacing:.12em;font-weight:600;color:#fff;text-transform:uppercase}
  .exc-card-big .body{padding:30px;display:flex;flex-direction:column;flex:1}
  .exc-card-big h3{font-size:28px;margin-bottom:8px}
  .exc-card-big .meta-row{display:flex;flex-wrap:wrap;gap:14px;font-size:12.5px;color:var(--muted);margin-bottom:14px}
  .exc-card-big p{color:#3a4046;font-size:14.5px;line-height:1.65;margin-bottom:18px}
  .exc-card-big .foot{margin-top:auto;padding-top:16px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;align-items:center;gap:14px}
  .exc-card-big .foot .p{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--teal);font-weight:600}
  .exc-card-big .foot .p small{font-size:11px;font-family:'Manrope',sans-serif;color:var(--muted);font-weight:600;letter-spacing:.1em;display:block;text-transform:uppercase}

  /* ===================== RESTAURANT PAGE ===================== */
  /* ----- Tabbed menu (Dinner / Daily) — editorial underline tabs ----- */
  .menu-sec .menu-intro{text-align:center;margin-bottom:36px}
  .menu-sec .menu-intro h2{margin-top:8px}
  .menu-tabs{display:flex;justify-content:center;gap:40px;border-bottom:1px solid var(--line);max-width:760px;margin:0 auto 52px}
  .menu-tab{background:none;border:0;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:600;color:var(--muted);padding:0 4px 16px;position:relative;transition:color .25s}
  .menu-tab:hover{color:var(--teal)}
  .menu-tab.is-active{color:var(--teal)}
  .menu-tab::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--sand-deep);transform:scaleX(0);transition:transform .3s ease}
  .menu-tab.is-active::after{transform:scaleX(1)}
  .menu-tab:focus-visible{outline:2px solid var(--teal);outline-offset:5px;border-radius:2px}
  .menu-panel:focus{outline:none}
  .menu-cats{columns:2;column-gap:66px;max-width:1000px;margin:0 auto}
  .menu-cat{break-inside:avoid;margin-bottom:42px}
  .mc-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;font-size:27px;color:var(--teal);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--line)}
  .mc-items{list-style:none;margin:0;padding:0}
  .menu-item{margin-bottom:17px}
  .mi-head{display:flex;align-items:baseline;gap:8px}
  .mi-name{font-weight:600;color:var(--ink);font-size:15.5px;line-height:1.35}
  .mi-dots{flex:1;align-self:flex-end;border-bottom:1px dotted #cdc4b5;transform:translateY(-4px);min-width:18px}
  .mi-price{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--sand-deep);white-space:nowrap}
  .mi-price small{font-family:'Manrope',sans-serif;font-size:11px;font-weight:600;letter-spacing:.03em;color:var(--muted)}
  .mi-desc{display:block;color:var(--muted);font-size:13px;font-style:italic;margin-top:3px;max-width:92%}
  .menu-note{max-width:780px;margin:30px auto 0;padding-top:24px;border-top:1px solid var(--line);text-align:center;color:var(--muted);font-size:12.5px;line-height:1.7}
  .menu-empty{text-align:center;max-width:520px;margin:24px auto 6px;padding:52px 28px;background:#fff;border:1px solid var(--line);border-radius:2px}
  .menu-empty .me-mark{display:block;font-size:22px;color:var(--sand);margin-bottom:14px}
  .menu-empty p{color:#3a4046;font-size:16px;line-height:1.7;margin:0}
  .open-hours{background:#fff;padding:36px;border-radius:2px;border:1px solid var(--line)}
  .open-hours .row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
  .open-hours .row:last-child{border-bottom:0}
  .open-hours .row b{font-weight:600;color:var(--teal)}
  .open-hours .row .closed{color:var(--muted)}

  /* primary buttons sitting on dark teal sections → invert to white pill
     (incl. .stripe's .btn-dark, which would otherwise be teal-on-teal) */
  .news .btn-primary,
  .room-cta-strip .btn-primary,
  .offer-card .btn-primary,
  .stripe .btn-primary,
  .stripe .btn-dark{background:#fff;color:var(--teal)}
  .news .btn-primary:hover,
  .room-cta-strip .btn-primary:hover,
  .offer-card .btn-primary:hover,
  .stripe .btn-primary:hover,
  .stripe .btn-dark:hover{background:var(--sand);color:var(--teal)}

  /* ===================== ROOM DETAIL PAGE ===================== */
  .room-detail{background:var(--cream);padding:80px 0 90px}
  .rd-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:flex-start}
  .rd-gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .rd-gallery .main{grid-column:1/-1;aspect-ratio:16/10;overflow:hidden;border-radius:2px;background:#ddd;cursor:pointer;position:relative}
  .rd-gallery .main img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
  .rd-gallery .main:hover img{transform:scale(1.03)}
  .rd-gallery .thumb{aspect-ratio:4/3;overflow:hidden;border-radius:2px;background:#ddd;cursor:pointer;position:relative}
  .rd-gallery .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .rd-gallery .thumb:hover img{transform:scale(1.05)}
  .rd-gallery button{display:block;width:100%;margin:0;padding:0;border:0;background:none;font:inherit;color:inherit}
  .rd-gallery .more{position:relative}
  .rd-gallery .more-label{position:absolute;inset:0;background:rgba(19,54,61,.62);display:grid;place-items:center;color:#fff;font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;pointer-events:none}

  /* ----- Fullscreen photo lightbox (gallery.js) ----- */
  .lightbox{position:fixed;inset:0;z-index:1000;display:none;background:rgba(9,20,23,.94);-webkit-tap-highlight-color:transparent}
  .lightbox.open{display:block}
  .lb-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;box-sizing:border-box}
  .lb-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:2px;box-shadow:0 24px 70px rgba(0,0,0,.55);user-select:none;-webkit-user-drag:none}
  .lb-btn{position:absolute;z-index:2;cursor:pointer;border:0;color:#fff;background:rgba(255,255,255,.12);backdrop-filter:blur(4px);display:grid;place-items:center;line-height:1;transition:background .2s}
  .lb-btn:hover{background:rgba(255,255,255,.26)}
  .lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;font-size:30px}
  .lb-prev{left:20px}
  .lb-next{right:20px}
  .lb-close{top:18px;right:18px;width:46px;height:46px;border-radius:50%;font-size:26px}
  .lb-counter{position:absolute;left:0;right:0;bottom:22px;text-align:center;color:rgba(255,255,255,.85);font-size:12.5px;letter-spacing:.18em;font-weight:600;pointer-events:none}
  body.lb-open{overflow:hidden}
  body.lb-open .mob-cta{display:none}      /* don't let the sticky Call/Reserve bar poke through the lightbox */
  @media (max-width:780px){
    .lb-stage{padding:10px}
    .lb-nav{width:42px;height:42px;font-size:24px}
    .lb-prev{left:8px}
    .lb-next{right:8px}
    .lb-close{top:10px;right:10px;width:42px;height:42px;font-size:24px}
    .lb-counter{bottom:14px}
  }
  .rd-info{position:sticky;top:100px;background:#fff;padding:36px 32px;border-radius:2px;box-shadow:var(--shadow-md);border:1px solid var(--line)}
  .rd-info .eyebrow{display:block;margin-bottom:12px}
  .rd-info h1{font-size:38px;line-height:1.1;margin-bottom:14px;color:var(--teal);font-family:'Cormorant Garamond',serif;font-weight:500}
  .rd-info p.lead{color:#3a4046;font-size:15px;line-height:1.7;margin-bottom:24px}
  .rd-specs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:24px}
  .rd-specs .sp{text-align:center}
  .rd-specs .sp:only-child{grid-column:1 / -1;text-align:left}   /* a lone spec (Superior: bed only) spans the full row, left-anchored, instead of being stranded in 1 of 3 columns */
  .rd-specs .sp .lbl{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:6px}
  .rd-specs .sp .v{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--teal);font-weight:600;line-height:1.1}
  .rd-specs .sp .v small{display:block;font-family:'Manrope',sans-serif;font-size:11px;color:var(--muted);font-weight:500;margin-top:4px;letter-spacing:.04em}
  .rd-info .btn-primary{width:100%;height:54px;font-size:13px}
  .rd-info .help{font-size:12px;color:var(--muted);text-align:center;margin-top:14px}
  .rd-info .help a{color:var(--sand-deep);font-weight:600}

  .amen-block{padding:90px 0;background:#fff}
  .amen-block .head{text-align:center;max-width:640px;margin:0 auto 50px}
  .amen-block .head .eyebrow{margin-bottom:14px;display:block}
  .amen-block .head h2{margin-bottom:14px}
  .amen-block .head p{color:var(--muted);font-size:15.5px}
  .amen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:2px;overflow:hidden}
  .amen-cell{background:#fff;padding:24px 18px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;transition:background .2s}
  .amen-cell:hover{background:var(--sand-50)}
  .amen-cell .ic{width:42px;height:42px;border-radius:50%;background:var(--sand-50);display:grid;place-items:center;color:var(--sand-deep);flex:0 0 42px}
  .amen-cell .ic svg{width:20px;height:20px}
  .amen-cell .lab{font-size:13.5px;color:var(--teal);font-weight:600;line-height:1.3}

  .room-cta-strip{background:var(--teal);color:#fff;padding:60px 0;text-align:center}
  .room-cta-strip h2{color:#fff;margin-bottom:14px}
  .room-cta-strip p{color:rgba(255,255,255,.75);max-width:540px;margin:0 auto 28px;font-size:15.5px}

  @media (max-width:1100px){
    .rd-grid{grid-template-columns:1fr;gap:32px}
    .rd-info{position:static}
    .amen-grid{grid-template-columns:repeat(3,1fr)}
  }
  @media (max-width:780px){
    .amen-grid{grid-template-columns:repeat(2,1fr)}
    .rd-specs{grid-template-columns:1fr;gap:10px}
    .rd-specs .sp{display:flex;justify-content:space-between;align-items:baseline;text-align:left}
    .rd-specs .sp .v{font-size:18px}
    .room-detail{padding:50px 0 60px}
  }

  /* ===================== RESPONSIVE EXTRAS ===================== */
  @media (max-width:1100px){
    .room-row{grid-template-columns:1fr}
    .offer-row{grid-template-columns:1fr}
    .room-row .pic, .offer-row .pic{min-height:260px}
    .amen-row{grid-template-columns:1fr;gap:32px;margin-bottom:60px}
    .amen-row:nth-child(even) .amen-pic{order:0}
    .contact-grid{grid-template-columns:1fr}
    .exc-grid-big{grid-template-columns:1fr}
  }
  @media (max-width:780px){
    .room-row .body, .offer-row .body, .contact-info, .contact-form{padding:28px}
    .room-row ul.amen, .offer-row .body ul.incl, .amen-text ul.dots, .form-row{grid-template-columns:1fr}
    .page-hero{height:auto;min-height:300px}
    .page-hero .inner{padding:108px 24px 46px}
    .page-hero h1{font-size:clamp(34px,8vw,44px)}
    .page-hero .sub{font-size:15px;margin-top:14px}
    /* menu → single column, smaller tabs */
    .menu-cats{columns:1}
    .menu-tabs{gap:26px}
    .menu-tab{font-size:22px}
    .mc-name{font-size:24px}
  }

  /* ===================== COOKIE CONSENT ===================== */
  /* Homegrown GDPR banner, built by assets/js/consent.js. Bottom-left card with
     equal-weight Accept/Decline; gates GA4 + The Hotels Network until opt-in. */
  .cookie-bar{position:fixed;left:24px;bottom:24px;z-index:300;width:min(440px,calc(100vw - 48px));background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px 22px;opacity:0;transform:translateY(14px);transition:opacity .3s ease,transform .3s ease}
  .cookie-bar.show{opacity:1;transform:none}
  .cookie-text{font-size:13px;line-height:1.55;color:var(--ink);margin:0 0 14px}
  .cookie-text a{color:var(--sand-deep);font-weight:600;text-decoration:underline;text-underline-offset:2px}
  .cookie-actions{display:flex;gap:10px}
  .cookie-btn{flex:1;height:44px;border-radius:4px;font-family:inherit;font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border:0;transition:all .18s}
  .cookie-accept{background:var(--teal);color:#fff}
  .cookie-accept:hover{background:var(--teal-2);transform:translateY(-1px);box-shadow:var(--shadow-md)}
  .cookie-decline{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}
  .cookie-decline:hover{background:var(--teal);color:#fff}
  .cookie-settings{cursor:pointer}
  @media (max-width:780px){
    /* clear the sticky Call/Reserve bar (.mob-cta, ~74px) on mobile */
    .cookie-bar{left:12px;right:12px;width:auto;bottom:calc(74px + env(safe-area-inset-bottom) + 12px)}
  }

  /* ===================== COPY-EMAIL (contact) ===================== */
  /* "Copy" affordance next to the contact email — many Gmail-web users can't use
     mailto:, so they copy. Fires the email_copy GA4 event (analytics.js). */
  .val-email{display:flex;align-items:center;flex-wrap:wrap;gap:10px}
  .copy-email{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border:1px solid var(--line);background:var(--white);border-radius:4px;color:var(--teal);font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .18s}
  .copy-email:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
  .copy-email.copied{background:var(--sand-deep);color:#fff;border-color:var(--sand-deep)}
  .copy-email svg{width:13px;height:13px}
