/* ─────────────────────────────────────────────────────────
   Ada Hotel Istanbul · Quiet luxury reset
   Palette: cream paper · ink · soft brass · warm sand
   Type:    Cormorant Garamond (display) · EB Garamond (body) · Inter (labels)
   ───────────────────────────────────────────────────────── */

:root{
  /* paper & ink */
  --paper:        #F8F4EC;
  --paper-deep:   #F1ECE0;
  --paper-warm:   #FBF8F1;
  --ink:          #1A1815;
  --ink-soft:     #3A3530;
  --ink-quiet:    #6B635A;

  /* metal & sand */
  --brass:        #8A7B65;
  --brass-soft:   #B5A88E;
  --sand:         #C9B896;
  --sand-deep:    #A8946F;

  /* hairlines */
  --line:         rgba(26,24,21,0.12);
  --line-soft:    rgba(26,24,21,0.06);
  --line-strong:  rgba(26,24,21,0.20);

  /* type */
  --display:      "Cormorant Garamond", "EB Garamond", Garamond, serif;
  --serif:        "EB Garamond", Garamond, "Times New Roman", serif;
  --label:        "Inter", -apple-system, system-ui, sans-serif;

  /* spacing rhythm */
  --pad-section:  clamp(96px, 16vh, 200px);
  --pad-edge:     clamp(20px, 6vw, 96px);
  --max:          1320px;
  --read:         640px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--serif);
  font-size:18px;
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  font-weight:400;
}
img{max-width:100%;display:block}
button{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
hr{border:0;border-top:1px solid var(--line);margin:0}

/* ─────────── type primitives ─────────── */
.display{
  font-family:var(--display);
  font-weight:300;
  letter-spacing:-0.012em;
  line-height:1.02;
  color:var(--ink);
  margin:0;
  text-wrap:balance;
}
.it{font-style:italic;font-weight:300}

.eyebrow{
  font-family:var(--label);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--ink-quiet);
}

.numeral{
  font-family:var(--display);
  font-style:italic;
  font-weight:300;
  font-size:14px;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--brass);
}

.lede{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(22px,2vw,28px);
  line-height:1.45;
  color:var(--ink-soft);
  text-wrap:pretty;
  font-style:italic;
}

.prose p{
  font-size:18px;
  line-height:1.7;
  color:var(--ink-soft);
  margin:0 0 1.2em;
  text-wrap:pretty;
  max-width:var(--read);
}

/* ─────────── layout ─────────── */
.section{
  padding:var(--pad-section) var(--pad-edge);
  position:relative;
}
.container{
  max-width:var(--max);
  margin:0 auto;
  width:100%;
}

/* ornamental hairline divider, used very sparingly */
.rule{
  display:flex;align-items:center;gap:18px;
  color:var(--brass-soft);
  font-family:var(--display);font-style:italic;font-size:13px;
}
.rule::before,.rule::after{content:"";flex:1;height:1px;background:var(--line)}

/* ─────────── reveal-on-scroll ─────────── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 1.1s ease, transform 1.1s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* ─────────── nav ─────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px var(--pad-edge);
  transition:background 0.5s ease, color 0.5s ease, border-color 0.5s ease, padding 0.4s ease;
  border-bottom:1px solid transparent;
}
.nav.on-dark{color:var(--paper)}
.nav.scrolled{
  background:rgba(248,244,236,0.94);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom-color:var(--line-soft);
  color:var(--ink);
  padding-top:16px;padding-bottom:16px;
}
.nav-brand{display:flex;align-items:baseline;gap:10px;font-family:var(--display);font-weight:400}
.nav-brand .name{font-size:22px;letter-spacing:0.02em}
.nav-brand .est{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;font-family:var(--label);font-weight:400;opacity:0.7}
.nav-links{display:flex;gap:36px;font-family:var(--label);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:400}
.nav-links a{position:relative;padding:4px 0;opacity:0.85;transition:opacity 0.3s}
.nav-links a:hover{opacity:1}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform 0.4s ease}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{
  font-family:var(--label);font-size:11px;font-weight:500;
  letter-spacing:0.24em;text-transform:uppercase;
  padding:12px 22px;
  border:1px solid currentColor;background:transparent;
  cursor:pointer;transition:all 0.3s ease;
}
.nav.on-dark .nav-cta:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.nav.scrolled .nav-cta:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.nav-actions{display:flex;align-items:center;gap:18px}
.nav-contact{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--label);font-size:11px;letter-spacing:0.16em;
  opacity:0.85;transition:opacity 0.3s ease;
  white-space:nowrap;
}
.nav-contact:hover{opacity:1}
.nav-contact svg{flex-shrink:0;opacity:0.8}
.nav-contact-text{font-variant-numeric:tabular-nums}
@media (max-width: 1180px){
  .nav-contact-text{display:none}
  .nav-actions{gap:14px}
  .nav-contact{padding:6px;border:1px solid currentColor;border-radius:50%;opacity:0.55}
  .nav-contact:hover{opacity:1}
}

/* ─────────── hero ─────────── */
.hero{
  position:relative;
  height:100vh;min-height:680px;
  overflow:hidden;
  background:linear-gradient(180deg, #5a4634 0%, #3a2d20 55%, #2a1f15 100%);
}
.hero-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(0.92) brightness(0.92);
  opacity:0;
  transition:opacity 1.6s ease;
}
.hero-stage{position:absolute;inset:0}
.hero-img.is-active{opacity:1;animation:heroFirst 8s ease-out}
.hero-img.is-active.cycling{animation:heroIn 7s ease-out}
.hero-dots{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  display:flex;gap:10px;z-index:3;
}
.hero-dot{
  width:28px;height:2px;background:rgba(255,255,255,0.35);
  border:none;padding:0;cursor:pointer;
  transition:background 0.3s ease,width 0.3s ease;
}
.hero-dot:hover{background:rgba(255,255,255,0.6)}
.hero-dot.is-active{background:rgba(255,255,255,0.95);width:44px}
.hero::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(20,16,12,0.42) 0%, rgba(20,16,12,0.18) 22%, rgba(20,16,12,0) 50%, rgba(20,16,12,0) 60%, rgba(20,16,12,0.55) 100%);
}
@keyframes heroIn{from{transform:scale(1.04);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes heroFirst{from{transform:scale(1.025);opacity:1}to{transform:scale(1);opacity:1}}

.hero-content{
  position:relative;z-index:2;
  height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--pad-edge) clamp(56px,10vh,120px);
  color:var(--paper);
  max-width:var(--max);
  margin:0 auto;
}
.hero-est{
  font-family:var(--label);font-size:11px;letter-spacing:0.4em;text-transform:uppercase;
  display:flex;align-items:center;gap:14px;
  opacity:0.85;
  margin-bottom:28px;
}
.hero-est::before{content:"";width:42px;height:1px;background:currentColor;opacity:0.6}
.hero-name{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(72px, 12vw, 200px);
  line-height:0.92;
  letter-spacing:-0.02em;
  margin:0;
  color:var(--paper);
}
.hero-name .it{font-style:italic;font-weight:300;display:block}
.hero-tagline{
  font-family:var(--display);
  font-style:italic;
  font-weight:300;
  font-size:clamp(20px, 1.8vw, 26px);
  line-height:1.45;
  max-width:46ch;
  margin:36px 0 0;
  color:var(--paper);
  opacity:0.92;
  text-wrap:pretty;
}
.hero-foot{
  position:absolute;bottom:36px;right:var(--pad-edge);left:var(--pad-edge);
  z-index:2;
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:24px;color:var(--paper);
  pointer-events:none;
}
.hero-foot > *{pointer-events:auto}
.hero-rating{
  font-family:var(--display);font-style:italic;font-size:14px;letter-spacing:0.2em;text-transform:uppercase;
  opacity:0.85;
}
.hero-rating .score{font-style:normal;font-size:18px;letter-spacing:0;color:var(--sand);margin-right:6px}
.hero-scroll{
  font-family:var(--label);font-size:10px;letter-spacing:0.4em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0.7;
}
.hero-scroll .line{width:1px;height:48px;background:currentColor;animation:scrollLine 2.4s ease-in-out infinite}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* ─────────── story ─────────── */
.story{background:var(--paper);padding-left:0;padding-right:0}
.story-intro{
  max-width:840px;
  margin:0 auto clamp(64px,10vh,120px);
  padding:0 var(--pad-edge);
  text-align:left;
}
.story-numeral{margin-bottom:32px;display:block}
.story-h{
  font-size:clamp(44px, 5.6vw, 84px);
  margin-top:8px;
  max-width:18ch;
}
.story-image{
  width:100%;
  aspect-ratio:21/9;
  overflow:hidden;
  margin:0;
}
.story-image img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.95);
  transition:transform 2s ease;
}
.story-image:hover img{transform:scale(1.03)}
.story-body{
  max-width:840px;
  margin:clamp(48px,8vh,96px) auto 0;
  padding:0 var(--pad-edge);
  display:grid;grid-template-columns:1fr 1fr;gap:48px clamp(48px,8vw,96px);
  align-items:start;
}
.story-prose{color:var(--ink-soft)}
.story-prose p{margin:0 0 1.2em;font-size:18px;line-height:1.75}
.story-prose p:last-child{margin-bottom:0}
.story-meta{
  display:grid;grid-template-columns:1fr;gap:28px;margin:0;
  padding-top:8px;
  border-top:1px solid var(--line);
}
.story-meta > div{padding-top:20px;border-top:1px solid var(--line-soft)}
.story-meta > div:first-child{padding-top:24px;border-top:none}
.story-meta dt{font-family:var(--label);font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-quiet);margin-bottom:8px}
.story-meta dd{font-family:var(--display);font-size:26px;font-weight:300;margin:0;color:var(--ink);line-height:1.15}
.story-meta dd .small{font-size:13px;font-family:var(--label);font-weight:400;letter-spacing:0.04em;color:var(--ink-quiet);display:block;margin-top:6px}

/* ─────────── featured (Begin here) ─────────── */
.featured{
  background:var(--paper-warm);
  padding-top:clamp(80px, 12vh, 140px);
  padding-bottom:clamp(80px, 12vh, 140px);
  overflow:hidden;
}
.featured-header{
  max-width:var(--max);margin:0 auto clamp(48px, 8vh, 80px);
  display:grid;grid-template-columns:200px 1fr;gap:64px;align-items:start;
}
.featured-header .numeral{
  padding-top:14px;
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:18px;color:var(--brass);letter-spacing:0.04em;
  text-transform:none;
}
.featured-h{
  font-size:clamp(36px, 4.4vw, 60px);
  max-width:18ch;margin:0;
}
.featured-sub{
  font-family:var(--display);font-style:italic;font-size:18px;
  color:var(--ink-quiet);margin:18px 0 0;max-width:48ch;line-height:1.5;
  grid-column:2;
}

.featured-rail{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
  max-width:var(--max);
  margin:0 auto;
}
.featured-card{
  display:flex;flex-direction:column;
  background:transparent;
}
.featured-photo{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  margin-bottom:22px;
  display:block;width:100%;
  border:0;padding:0;background:transparent;
  cursor:zoom-in;
  text-align:left;
}
.featured-photo-count{
  position:absolute;bottom:14px;right:14px;
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;
  background:rgba(15,12,10,0.78);color:var(--paper);
  font-family:var(--label);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  border-radius:2px;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  pointer-events:none;
  opacity:0;transition:opacity 0.3s ease;
}
.featured-card:hover .featured-photo-count{opacity:1}
.featured-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.92);
  transition:transform 1.6s ease;
}
.featured-card:hover .featured-photo img{transform:scale(1.04)}
.featured-tag{
  position:absolute;top:18px;left:18px;
  padding:6px 12px;
  background:rgba(248,244,236,0.92);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  font-family:var(--label);font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--ink);
}
.featured-name{
  font-family:var(--display);font-weight:300;
  font-size:clamp(22px, 1.8vw, 26px);
  line-height:1.2;color:var(--ink);
  margin:0 0 12px;
  text-wrap:balance;
}
.featured-blurb{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:15px;line-height:1.55;color:var(--ink-soft);
  margin:0 0 24px;
  text-wrap:pretty;
  flex:1;
}
.featured-foot{
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding-top:18px;
  border-top:1px solid rgba(138,123,101,0.25);
}
.featured-price{
  font-family:var(--display);font-weight:300;font-size:22px;color:var(--ink);
}
.featured-price .from{
  font-size:9px;font-family:var(--label);font-weight:500;
  letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-quiet);
  margin-right:6px;vertical-align:0.4em;
}
.featured-price .per{
  font-size:11px;font-family:var(--display);font-style:italic;
  color:var(--ink-quiet);margin-left:2px;
}
.featured-btn{
  font-family:var(--label);font-size:10px;letter-spacing:0.24em;text-transform:uppercase;
  padding:6px 0;
  cursor:pointer;
}

.featured-foot-link{
  max-width:var(--max);margin:clamp(48px, 6vh, 72px) auto 0;
  text-align:center;
}
.featured-foot-link a{
  font-family:var(--label);font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--ink-quiet);text-decoration:none;
  border-bottom:1px solid var(--brass-soft);
  padding-bottom:8px;
  transition:color 0.2s ease, border-color 0.2s ease;
}
.featured-foot-link a:hover{color:var(--ink);border-color:var(--ink)}

@media (max-width:1080px){
  .featured-rail{grid-template-columns:repeat(2,1fr);gap:32px 24px}
}
@media (max-width:720px){
  .featured-header{grid-template-columns:1fr;gap:24px}
  .featured-sub{grid-column:1}
  .featured-rail{grid-template-columns:1fr;gap:48px}
  .featured-photo{aspect-ratio:5/4}
}

/* ─────────── section header (shared) ─────────── */
.s-header{
  max-width:var(--max);margin:0 auto clamp(64px, 10vh, 120px);
  display:grid;grid-template-columns:200px 1fr;gap:64px;align-items:start;
}
.s-header .numeral{padding-top:14px}
.s-header .s-h{font-size:clamp(40px, 5vw, 72px);max-width:18ch}
.s-header .s-sub{font-family:var(--display);font-style:italic;font-size:18px;color:var(--ink-quiet);margin-top:18px;max-width:48ch;line-height:1.5}

/* ─────────── rooms (editorial list) ─────────── */
.rooms{background:var(--paper)}
.rooms-list{display:flex;flex-direction:column;max-width:var(--max);margin:0 auto}
.room-row{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(48px,8vw,120px);
  align-items:center;
  padding:clamp(56px,9vh,120px) 0;
  border-bottom:1px solid var(--line-soft);
}
.room-row:last-child{border-bottom:none}
.room-row.flip{grid-template-columns:1fr 1.2fr}
.room-row.flip .room-photo{order:2}
.room-row.flip .room-info{order:1}

.room-photo{
  position:relative;aspect-ratio:5/4;overflow:hidden;
  border:none;padding:0;background:none;cursor:pointer;
  display:block;width:100%;
  font:inherit;color:inherit;text-align:left;
}
.room-photo:focus-visible{outline:2px solid var(--ink);outline-offset:4px}
.room-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(0.92);transition:transform 1.6s ease}
.room-row:hover .room-photo img{transform:scale(1.03)}
.room-photo-num{
  position:absolute;top:24px;left:24px;
  font-family:var(--display);font-style:italic;font-weight:300;font-size:18px;
  letter-spacing:0.18em;
  color:var(--paper);
  text-shadow:0 1px 8px rgba(0,0,0,0.4);
  z-index:2;
}
.room-photo-count{
  position:absolute;bottom:18px;right:18px;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;
  background:rgba(20,16,12,0.6);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:var(--paper);
  font-family:var(--label);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.18);
  z-index:2;
  transition:background 0.2s ease, transform 0.2s ease;
}
.room-photo:hover .room-photo-count{background:rgba(20,16,12,0.85);transform:translateY(-2px)}
.room-photo-count svg{opacity:0.9}

/* Lightbox */
.lightbox{
  position:fixed !important;
  top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;
  width:100vw !important;height:100vh;height:100dvh;
  z-index:9999 !important;
  background:rgba(15,12,10,0.96);
  display:flex;flex-direction:column;align-items:stretch;
  padding:72px 24px 16px;
  box-sizing:border-box;
  overflow:hidden;
  animation:lbIn 0.25s ease-out;
}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lb-close{
  position:absolute;top:20px;right:24px;
  width:44px;height:44px;
  background:none;border:1px solid rgba(255,255,255,0.2);
  color:var(--paper);
  font-size:28px;line-height:1;font-family:var(--display);font-weight:200;
  cursor:pointer;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s ease;
}
.lb-close:hover{background:rgba(255,255,255,0.08)}
.lb-counter{
  position:absolute;top:32px;left:32px;
  display:flex;flex-direction:column;gap:4px;
  color:var(--paper);
}
.lb-title{font-family:var(--display);font-style:italic;font-weight:300;font-size:18px}
.lb-num{font-family:var(--label);font-size:10px;letter-spacing:0.3em;text-transform:uppercase;opacity:0.6}
.lb-stage{
  flex:1 1 0;min-height:0;width:100%;max-width:1200px;
  margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.lb-stage img{
  display:block;
  max-width:100%;
  max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  box-shadow:0 30px 80px rgba(0,0,0,0.5);
}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.18);
  color:var(--paper);
  font-size:36px;line-height:1;font-weight:200;
  cursor:pointer;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  padding-bottom:4px;
  transition:background 0.2s ease;
}
.lb-nav:hover{background:rgba(255,255,255,0.16)}
.lb-prev{left:24px}
.lb-next{right:24px}
.lb-thumbs{
  flex:0 0 auto;
  display:flex;gap:8px;
  padding:16px 8px 4px;
  max-width:100%;
  overflow-x:auto;
  scrollbar-width:thin;
  justify-content:center;
}
.lb-thumb{
  flex:0 0 auto;width:72px;height:54px;
  background:none;border:1px solid transparent;padding:0;cursor:pointer;
  opacity:0.45;transition:opacity 0.2s ease, border-color 0.2s ease;
}
.lb-thumb img{width:100%;height:100%;object-fit:cover}
.lb-thumb:hover{opacity:0.8}
.lb-thumb.is-active{opacity:1;border-color:var(--brass)}
@media (max-width:720px){
  .lb-counter{top:20px;left:20px}
  .lb-nav{width:44px;height:44px;font-size:28px}
  .lb-prev{left:12px}
  .lb-next{right:12px}
  .lb-thumb{width:56px;height:42px}
}

.room-info{display:flex;flex-direction:column;max-width:520px}
.room-tag{
  font-family:var(--label);font-size:10px;letter-spacing:0.32em;text-transform:uppercase;color:var(--brass);
  margin-bottom:18px;
}
.room-name{
  font-family:var(--display);font-weight:300;
  font-size:clamp(32px,3.5vw,48px);
  line-height:1.05;letter-spacing:-0.005em;
  margin:0;
}
.room-name .small-it{font-style:italic;font-size:0.55em;color:var(--brass);display:block;margin-top:6px;letter-spacing:0.04em}
.room-blurb{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:20px;line-height:1.55;color:var(--ink-soft);
  margin:24px 0 0;text-wrap:pretty;max-width:46ch;
}
.room-specs{
  display:flex;gap:32px;margin:32px 0 0;
  font-family:var(--label);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-quiet);
  flex-wrap:wrap;
}
.room-specs > div span{display:block;font-family:var(--display);font-style:italic;font-size:18px;letter-spacing:0;text-transform:none;color:var(--ink);margin-top:4px}
.room-feature-line{
  display:flex;flex-wrap:wrap;gap:6px 18px;
  margin-top:24px;
  font-family:var(--label);font-size:12px;color:var(--ink-quiet);
}
.room-feature-line span{display:inline-flex;align-items:center;gap:8px}
.room-feature-line span::before{content:"·";color:var(--brass-soft)}
.room-feature-line span:first-child::before{display:none}
.room-action-row{
  display:flex;align-items:baseline;gap:32px;margin-top:40px;flex-wrap:wrap;
}
.room-price{font-family:var(--display);font-weight:300;font-size:32px;color:var(--ink)}
.room-price .from{font-size:11px;font-family:var(--label);font-weight:500;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-quiet);margin-right:8px;vertical-align:0.4em}
.room-price .per{font-size:13px;font-family:var(--display);font-style:italic;color:var(--ink-quiet);margin-left:4px}

/* unified buttons */
.btn{
  font-family:var(--label);font-size:11px;font-weight:500;
  letter-spacing:0.24em;text-transform:uppercase;
  padding:14px 28px;
  border:1px solid var(--ink);background:var(--ink);color:var(--paper);
  cursor:pointer;transition:all 0.3s ease;display:inline-flex;align-items:center;gap:10px;
  white-space:nowrap;
}
.btn:hover{background:transparent;color:var(--ink)}
.btn-light{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn-light:hover{background:transparent;color:var(--paper)}
.btn-quiet{
  background:transparent;border:none;border-bottom:1px solid var(--ink);
  color:var(--ink);padding:8px 0;border-radius:0;
}
.btn-quiet:hover{background:transparent;color:var(--brass);border-color:var(--brass)}
.btn-lg{padding:18px 36px;font-size:12px}

/* ─────────── breakfast ─────────── */
.dining{background:var(--paper-warm)}
.dining-hero{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:clamp(48px,8vw,120px);align-items:center;
  max-width:var(--max);margin:0 auto;
}
.dining-image{aspect-ratio:5/6;overflow:hidden}
.dining-image img{width:100%;height:100%;object-fit:cover;filter:saturate(0.92)}
.dining-text{max-width:520px}
.dining-prose{margin-top:32px;font-size:19px;line-height:1.7;color:var(--ink-soft)}
.dining-prose p{margin:0 0 1em;text-wrap:pretty}
.dining-meta{
  margin-top:48px;padding-top:32px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;
}
.dining-meta dt{font-family:var(--label);font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-quiet);margin-bottom:6px}
.dining-meta dd{font-family:var(--display);font-size:18px;font-weight:300;margin:0;color:var(--ink)}
.dining-meta dd .it{font-style:italic;color:var(--ink-quiet)}
.dining-strip{
  margin-top:clamp(64px,10vh,120px);
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  max-width:var(--max);margin-left:auto;margin-right:auto;
}
.dining-strip img{aspect-ratio:4/5;width:100%;object-fit:cover;filter:saturate(0.92)}

/* ─────────── neighborhood ─────────── */
.neighborhood{
  background:var(--paper);
  position:relative;overflow:hidden;
}
.neighborhood::before{
  /* subtle archival map texture */
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(138,123,101,0.05) 0, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(138,123,101,0.04) 0, transparent 35%);
  background-size:cover;opacity:0.6;pointer-events:none;
}
.neighborhood::after{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent, transparent 80px, rgba(138,123,101,0.025) 80px, rgba(138,123,101,0.025) 81px),
    repeating-linear-gradient(-45deg, transparent, transparent 80px, rgba(138,123,101,0.025) 80px, rgba(138,123,101,0.025) 81px);
  pointer-events:none;
}
.neighborhood > .container{position:relative;z-index:1}
.landmark-list{
  max-width:920px;margin:0 auto;
  display:flex;flex-direction:column;
}
.landmark{
  display:grid;grid-template-columns:60px 1fr auto;gap:32px;align-items:baseline;
  padding:28px 0;
  border-bottom:1px solid var(--line);
  transition:padding-left 0.3s ease;
}
.landmark:hover{padding-left:8px}
.landmark:last-child{border-bottom:none}
.landmark-num{font-family:var(--display);font-style:italic;font-size:14px;letter-spacing:0.2em;color:var(--brass)}
.landmark-name{font-family:var(--display);font-weight:300;font-size:clamp(24px,2.5vw,32px);line-height:1.15;color:var(--ink)}
.landmark-name .it{font-style:italic}
.landmark-walk{font-family:var(--label);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;color:var(--ink-quiet);white-space:nowrap}

/* ─────────── reviews ─────────── */
.reviews{background:var(--paper-deep)}
.reviews-header{
  text-align:center;
  max-width:760px;margin:0 auto clamp(64px,10vh,100px);
}
.reviews-score{
  font-family:var(--display);font-weight:300;
  font-size:clamp(96px, 12vw, 180px);
  line-height:0.9;
  color:var(--ink);
  margin:24px 0 8px;
  letter-spacing:-0.02em;
}
.reviews-score .of{font-size:0.32em;color:var(--ink-quiet);font-style:italic;margin-left:8px}
.reviews-label{font-family:var(--display);font-style:italic;font-size:24px;color:var(--brass);margin-bottom:8px}
.reviews-count{font-family:var(--label);font-size:11px;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-quiet)}
.reviews-quotes{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(32px,5vw,64px);
  max-width:var(--max);margin:0 auto;
}
.review-quote{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.review-quote .mark{font-family:var(--display);font-style:italic;font-size:64px;line-height:0.5;color:var(--brass-soft);margin-bottom:-12px}
.review-quote-text{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:22px;line-height:1.45;color:var(--ink-soft);
  text-wrap:pretty;flex:1;
}
.review-quote-room{font-family:var(--label);font-size:10px;letter-spacing:0.32em;text-transform:uppercase;color:var(--brass);margin-top:auto}
.review-quote-room .score{color:var(--ink);margin-right:8px}

/* ─────────── gallery ─────────── */
.gallery{background:var(--paper)}
.gallery-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:120px;
  gap:8px;
}
.gallery-cell{overflow:hidden}
.gallery-cell img{width:100%;height:100%;object-fit:cover;filter:saturate(0.92);transition:transform 1.4s ease}
.gallery-cell:hover img{transform:scale(1.05)}
.gallery-cell.tall{grid-row:span 3}
.gallery-cell.wide{grid-column:span 2;grid-row:span 2}
.gallery-cell.std{grid-column:span 1;grid-row:span 2}
.gallery-cell.big{grid-column:span 2;grid-row:span 3}

/* ─────────── location ─────────── */
.location{background:var(--paper-warm)}
.location-grid{
  display:grid;grid-template-columns:1fr 1.3fr;
  gap:clamp(48px,8vw,96px);
  max-width:var(--max);margin:0 auto;
  align-items:start;
}
.location-info dl{display:grid;gap:32px;margin:0}
.location-info dt{font-family:var(--label);font-size:10px;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-quiet);margin-bottom:8px}
.location-info dd{font-family:var(--display);font-weight:300;font-size:20px;margin:0;color:var(--ink);line-height:1.45}
.location-info dd .it{font-style:italic;color:var(--ink-quiet);font-size:0.85em;display:block;margin-top:2px}
.location-map{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line)}
.location-map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(0.6) sepia(0.18)}
.location-amenities{
  margin-top:clamp(64px,10vh,100px);padding-top:48px;border-top:1px solid var(--line);
}
.location-amenities-title{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(24px,2.5vw,32px);margin-bottom:32px;color:var(--ink)}
.amenities-list{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px 32px;
}
.amenities-list span{
  font-family:var(--display);font-weight:400;font-size:18px;color:var(--ink-soft);
  display:flex;align-items:baseline;gap:14px;
}
.amenities-list span::before{
  content:"";width:18px;height:1px;background:var(--brass-soft);flex-shrink:0;position:relative;top:-5px;
}

/* ─────────── footer ─────────── */
.footer{
  background:var(--ink);color:var(--paper);
  padding:clamp(80px,12vh,140px) var(--pad-edge) 48px;
}
.footer .container{position:relative}
.footer-mark{
  font-family:var(--display);font-weight:300;
  font-size:clamp(72px,9vw,140px);
  line-height:0.9;
  color:var(--paper);
  margin:0 0 64px;
  letter-spacing:-0.015em;
}
.footer-mark .it{font-style:italic;display:block;color:var(--brass-soft)}
.footer-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:48px;
  padding-top:48px;border-top:1px solid rgba(248,244,236,0.14);
}
.footer-col h5{
  font-family:var(--label);font-size:10px;font-weight:500;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--brass-soft);margin:0 0 16px;
}
.footer-col p,.footer-col a{
  font-family:var(--display);font-weight:300;font-size:17px;line-height:1.55;
  color:var(--paper);opacity:0.85;margin:0 0 4px;display:block;
}
.footer-col a:hover{opacity:1;color:var(--sand)}
.footer-base{
  margin-top:80px;padding-top:24px;
  border-top:1px solid rgba(248,244,236,0.1);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-family:var(--label);font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
  color:rgba(248,244,236,0.5);
}

/* ─────────── booking drawer (slide from right) ─────────── */
.drawer-backdrop{
  position:fixed;inset:0;z-index:90;
  background:rgba(20,16,12,0.5);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;
  transition:opacity 0.4s ease;
}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:100;
  width:min(560px, 100%);
  background:var(--paper-warm);
  transform:translateX(100%);
  transition:transform 0.5s cubic-bezier(0.32,0.72,0.24,1);
  display:flex;flex-direction:column;
  box-shadow:-30px 0 80px rgba(20,16,12,0.25);
}
.drawer.open{transform:translateX(0)}
.drawer-head{
  padding:32px var(--pad-edge) 24px;
  display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--line);
}
.drawer-head .brand{font-family:var(--display);font-size:22px;font-weight:400}
.drawer-head .brand .it{font-style:italic;font-size:0.7em;color:var(--brass);margin-left:8px;letter-spacing:0.18em;text-transform:uppercase;font-family:var(--label);font-weight:500}
.drawer-close{
  background:none;border:1px solid var(--line);
  width:40px;height:40px;
  font-size:20px;cursor:pointer;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:all 0.3s;
}
.drawer-close:hover{border-color:var(--ink)}
.drawer-steps{
  display:flex;gap:8px;padding:20px var(--pad-edge);
  border-bottom:1px solid var(--line);
  font-family:var(--label);font-size:10px;letter-spacing:0.24em;text-transform:uppercase;
}
.drawer-steps span{flex:1;color:var(--ink-quiet);padding-bottom:8px;border-bottom:1px solid var(--line);transition:all 0.3s;text-align:center}
.drawer-steps span.active{color:var(--ink);border-bottom-color:var(--ink)}
.drawer-steps span.done{color:var(--brass);border-bottom-color:var(--brass-soft)}

.drawer-body{flex:1;overflow-y:auto;padding:40px var(--pad-edge);display:flex;flex-direction:column;gap:24px}
.drawer-body .step-h{
  font-family:var(--display);font-weight:300;font-size:36px;line-height:1.05;letter-spacing:-0.01em;margin:0;
}
.drawer-body .step-sub{font-family:var(--display);font-style:italic;font-size:17px;color:var(--ink-quiet);margin:0;text-wrap:pretty;line-height:1.5}

.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.span-2{grid-column:span 2}
.field label{font-family:var(--label);font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-quiet)}
.field input,.field select,.field textarea{
  font-family:var(--display);font-weight:400;font-size:17px;
  padding:13px 14px;border:1px solid var(--line);background:var(--paper);color:var(--ink);
  border-radius:0;transition:border-color 0.25s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field textarea{resize:vertical;min-height:80px}

.summary-line{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 18px;background:var(--paper);border-left:2px solid var(--brass);
  font-family:var(--label);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft);
}

.rate-toggle{
  display:grid;grid-template-columns:1fr 1fr;
  border:1px solid var(--line);
}
.rate-toggle label{
  font-family:var(--label);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  padding:14px 16px;cursor:pointer;display:flex;flex-direction:column;gap:4px;
  color:var(--ink-quiet);transition:background 0.25s,color 0.25s;
  border-right:1px solid var(--line);
}
.rate-toggle label:last-child{border-right:none}
.rate-toggle label .small{font-family:var(--display);font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;color:var(--ink-quiet);margin-top:2px}
.rate-toggle label:has(input:checked){background:var(--ink);color:var(--paper)}
.rate-toggle label:has(input:checked) .small{color:var(--brass-soft)}
.rate-toggle input{display:none}

.room-pick-list{display:flex;flex-direction:column;gap:14px}
.room-pick{
  display:grid;grid-template-columns:120px 1fr;gap:16px;
  padding:14px;border:1px solid var(--line);background:var(--paper);
  cursor:pointer;transition:all 0.25s;
  align-items:start;
}
.room-pick:hover{border-color:var(--brass)}
.room-pick.sel{border-color:var(--ink);background:var(--paper-deep)}
.room-pick-photo{position:relative;display:block;padding:0;border:0;background:transparent;cursor:zoom-in;width:120px;height:96px;overflow:hidden}
.room-pick-photo img{width:120px;height:96px;object-fit:cover;filter:saturate(0.92);display:block;transition:transform 0.3s ease}
.room-pick-photo:hover img{transform:scale(1.05)}
.room-pick-photo-count{position:absolute;bottom:6px;right:6px;display:inline-flex;align-items:center;gap:4px;padding:3px 7px;background:rgba(20,16,10,0.78);color:#f4ede0;font-family:var(--label);font-size:10px;letter-spacing:0.12em;border-radius:2px;backdrop-filter:blur(2px)}
.room-pick-photo-count svg{display:block}
.room-pick-body h4{font-family:var(--display);font-weight:400;font-size:20px;margin:0 0 4px;line-height:1.15}
.room-pick-body .meta{font-family:var(--label);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-quiet);margin:0 0 8px}
.room-pick-body .feat{font-family:var(--display);font-style:italic;font-size:14px;color:var(--ink-soft);line-height:1.45;margin:0}
.room-pick-row{display:flex;justify-content:space-between;align-items:flex-end;margin-top:8px;gap:12px}
.room-pick-price{font-family:var(--display);font-size:24px;font-weight:300;color:var(--ink)}
.room-pick-price .per{font-size:11px;font-family:var(--label);color:var(--ink-quiet);letter-spacing:0.18em;text-transform:uppercase;margin-left:4px}

.tally{
  display:flex;flex-direction:column;gap:10px;
  padding:20px;background:var(--paper);border:1px solid var(--line);
}
.tally-row{display:flex;justify-content:space-between;font-family:var(--label);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-quiet)}
.tally-row.total{padding-top:12px;border-top:1px solid var(--line);font-size:13px;color:var(--ink)}
.tally-row.total strong{font-family:var(--display);font-weight:300;font-size:28px;letter-spacing:0;color:var(--ink)}

.drawer-actions{
  padding:20px var(--pad-edge) 32px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:12px;
  background:var(--paper-warm);
}
.drawer-actions .btn{flex:1;justify-content:center;padding:16px 24px}
.drawer-actions .btn-quiet{flex:none;border:none;border-bottom:1px solid var(--line)}

.confirm-mark{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:64px;line-height:0.95;color:var(--brass);letter-spacing:0.04em;
  margin:8px 0 16px;
}

/* ─────────── responsive ─────────── */
@media (max-width: 960px){
  .nav-links{display:none}
  .dining-hero,.location-grid{grid-template-columns:1fr;gap:48px}
  .dining-image{aspect-ratio:5/4;max-height:60vh}
  .story-image{aspect-ratio:4/3}
  .story-body{grid-template-columns:1fr;gap:32px}
  .room-row,.room-row.flip{grid-template-columns:1fr;gap:32px;padding:64px 0}
  .room-row.flip .room-photo{order:1}
  .room-row.flip .room-info{order:2}
  .reviews-quotes{grid-template-columns:1fr;gap:48px}
  .gallery-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:100px}
  .gallery-cell.wide,.gallery-cell.big{grid-column:span 2}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .s-header{grid-template-columns:1fr;gap:24px;margin-bottom:64px}
  .s-header .numeral{padding-top:0}
  .field-grid{grid-template-columns:1fr}
  .field.span-2{grid-column:auto}
  .dining-strip{grid-template-columns:repeat(2,1fr)}
  .story-meta{grid-template-columns:1fr 1fr}
}
@media (max-width: 600px){
  .footer-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
  .gallery-cell.wide,.gallery-cell.big,.gallery-cell.tall{grid-column:span 2;grid-row:span 1}
  .gallery-cell.std{grid-column:span 1;grid-row:span 1}
  .dining-strip{grid-template-columns:1fr}
  .nav{padding:18px 20px}
  .hero-foot{flex-direction:column;align-items:flex-start;gap:24px}
  .hero-scroll{display:none}
  .room-action-row{margin-top:24px;gap:18px}
  .reviews-score{font-size:96px}
  .drawer{width:100%}
  .room-pick{grid-template-columns:80px 1fr}
  .room-pick-photo,.room-pick-photo img{width:80px;height:80px}
}


/* ─────────── room details modal ─────────── */
.rd-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(20,16,10,0.78);
  backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:32px;
  animation:rdFade 0.25s ease;
}
@keyframes rdFade{from{opacity:0}to{opacity:1}}
.rd-panel{
  position:relative;
  background:var(--paper-warm);
  width:100%;max-width:920px;max-height:calc(100vh - 64px);
  border-radius:4px;
  display:flex;flex-direction:column;
  box-shadow:0 40px 100px rgba(0,0,0,0.5);
  animation:rdSlide 0.3s ease;
  overflow:hidden;
}
@keyframes rdSlide{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.rd-close{
  position:absolute;top:16px;right:16px;z-index:5;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.92);border:0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);
  transition:background 0.15s ease, transform 0.15s ease;
}
.rd-close:hover{background:#fff;transform:scale(1.05)}
.rd-scroll{
  overflow-y:auto;
  padding:0 0 24px;
}
.rd-hero{
  display:block;width:100%;padding:0;border:0;background:transparent;
  position:relative;cursor:zoom-in;
  height:300px;overflow:hidden;
}
.rd-hero img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s ease}
.rd-hero:hover img{transform:scale(1.02)}
.rd-hero-count{
  position:absolute;bottom:14px;right:14px;
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;background:rgba(20,16,10,0.78);color:#f4ede0;
  font-family:var(--label);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  border-radius:2px;backdrop-filter:blur(2px);
}
.rd-thumbs{
  display:grid;grid-template-columns:repeat(6,1fr);gap:4px;
  padding:4px;
}
.rd-thumb{
  position:relative;aspect-ratio:1;
  padding:0;border:0;background:transparent;cursor:zoom-in;overflow:hidden;
}
.rd-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.3s ease;filter:saturate(0.92)}
.rd-thumb:hover img{transform:scale(1.06)}
.rd-thumb-more{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(20,16,10,0.65);color:#f4ede0;
  font-family:var(--display);font-size:24px;
}
.rd-head{padding:36px 40px 24px;border-bottom:1px solid var(--line)}
.rd-tag{font-family:var(--label);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:10px}
.rd-name{font-family:var(--display);font-weight:400;font-size:38px;line-height:1.1;letter-spacing:-0.01em;margin:0 0 10px;color:var(--ink)}
.rd-blurb{font-family:var(--display);font-style:italic;font-size:18px;line-height:1.5;color:var(--ink-soft);margin:0 0 18px;max-width:640px}
.rd-quickline{display:flex;flex-wrap:wrap;align-items:center;gap:14px;font-family:var(--display);font-size:14px;color:var(--ink-soft)}
.rd-quickline strong{font-weight:500;color:var(--ink);font-size:16px}
.rd-quickline-sep{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--ink-quiet);opacity:0.4}
.rd-quickline-price{margin-left:auto;font-family:var(--label);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink)}
.rd-quickline-price strong{font-family:var(--display);font-size:22px;font-weight:300;letter-spacing:0;text-transform:none}

/* Section block scaffolding */
.rd-section-block{padding:28px 40px;border-bottom:1px solid var(--line)}
.rd-section-block:last-child{border-bottom:0}
.rd-section-label{
  display:flex;align-items:baseline;gap:10px;
  font-family:var(--label);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--ink-quiet);margin:0 0 18px;font-weight:500;
}
.rd-section-count{
  font-family:var(--display);font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;
  color:var(--brass);
}

.rd-specs{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.rd-specs > div{display:flex;flex-direction:column;gap:4px;padding:0 16px;border-right:1px solid var(--line)}
.rd-specs > div:last-child{border-right:0}
.rd-specs > div:first-child{padding-left:0}
.rd-spec-k{font-family:var(--label);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-quiet)}
.rd-spec-v{font-family:var(--display);font-size:20px;color:var(--ink);font-weight:400}
.rd-spec-v.rd-beds{font-size:13px;font-style:italic;line-height:1.35}

.rd-quickfeats{
  display:flex;flex-wrap:wrap;gap:8px;
}
.rd-chip{
  display:inline-flex;align-items:center;
  padding:6px 12px;
  background:var(--paper);border:1px solid var(--line);
  font-family:var(--label);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-soft);
  border-radius:2px;
}

.rd-review{
  display:flex;gap:20px;align-items:center;
  padding:18px 22px;
  background:var(--paper);border-left:2px solid var(--brass);
}
.rd-review-score{
  display:flex;align-items:baseline;gap:4px;
  font-family:var(--display);
}
.rd-review-score strong{font-size:36px;font-weight:400;color:var(--ink)}
.rd-review-score span{font-size:13px;color:var(--ink-quiet)}
.rd-review-text{display:flex;flex-direction:column;gap:4px;flex:1}
.rd-review-label{font-family:var(--label);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--brass)}
.rd-review-count{font-family:var(--display);font-style:italic;font-size:14px;color:var(--ink-soft)}
.rd-review-hl{margin:0;font-family:var(--display);font-size:14px;color:var(--ink-soft);line-height:1.4}

.rd-amenities-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px 40px;
}
.rd-amenity-col h4{
  font-family:var(--display);font-weight:400;font-size:16px;color:var(--ink);
  margin:0 0 10px;font-style:italic;
}
.rd-amenity-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.rd-amenity-col li{
  font-family:var(--display);font-size:14px;color:var(--ink-soft);line-height:1.4;
  position:relative;padding-left:14px;
}
.rd-amenity-col li::before{
  content:"";position:absolute;left:0;top:9px;
  width:5px;height:5px;border-radius:50%;background:var(--brass);
}

.rd-foot{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 40px;
  background:var(--paper-warm);
  border-top:1px solid var(--line);
  flex-shrink:0;
}
.rd-price{
  display:inline-flex;align-items:baseline;gap:6px;
  font-family:var(--display);
}
.rd-price .from{font-family:var(--label);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-quiet)}
.rd-price strong{font-size:32px;font-weight:300;color:var(--ink)}
.rd-price .per{font-family:var(--label);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-quiet)}
.rd-foot-actions{display:flex;gap:12px;align-items:center}

/* "Details" buttons on room rows */
.room-action-btns{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.featured-actions{display:flex;gap:10px;align-items:center}
.featured-detail{
  background:transparent;border:0;
  font-family:var(--label);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--ink-quiet);cursor:pointer;padding:8px 4px;
  border-bottom:1px solid transparent;
  transition:color 0.15s, border-color 0.15s;
}
.featured-detail:hover{color:var(--ink);border-bottom-color:var(--brass)}

.room-pick-details{
  background:transparent;border:0;
  font-family:var(--label);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--brass);cursor:pointer;padding:4px;
  border-bottom:1px solid transparent;
  transition:color 0.15s, border-color 0.15s;
}
.room-pick-details:hover{color:var(--ink);border-bottom-color:var(--brass)}

@media (max-width:760px){
  .rd-overlay{padding:0}
  .rd-panel{max-width:100%;max-height:100vh;border-radius:0;height:100%}
  .rd-hero{height:240px}
  .rd-thumbs{grid-template-columns:repeat(4,1fr)}
  .rd-thumbs .rd-thumb:nth-child(n+5){display:none}
  .rd-head{padding:24px 20px 18px}
  .rd-name{font-size:26px}
  .rd-blurb{font-size:15px}
  .rd-quickline{font-size:13px;gap:10px}
  .rd-quickline strong{font-size:14px}
  .rd-quickline-price{margin-left:0;width:100%;padding-top:8px;border-top:1px solid var(--line);margin-top:4px}
  .rd-section-block{padding:22px 20px}
  .rd-specs{grid-template-columns:repeat(2,1fr);gap:0}
  .rd-specs > div{padding:10px 12px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .rd-specs > div:nth-child(2n){border-right:0}
  .rd-specs > div:nth-last-child(-n+2){border-bottom:0}
  .rd-amenities-grid{grid-template-columns:1fr;gap:18px}
  .rd-foot{padding:14px 20px;flex-direction:column;align-items:stretch;gap:10px}
  .rd-foot-actions{justify-content:flex-end}
  .room-action-btns{width:100%;justify-content:flex-end}
}
