/* =====================================================================
   THE VOY — brand stylesheet
   Colors sampled directly from the logo:
     Red   #E20613   |   Gold  #F5D59A → #C9A669 → #A27A3D
   ===================================================================== */

:root{
  --red:        #E20613;
  --red-deep:   #B00410;
  --gold:       #C9A669;
  --gold-light: #F5D59A;
  --gold-deep:  #A27A3D;
  --gold-text:  #80622B;   /* AA-contrast deep gold for small text (>=4.5:1 on light bg) */
  --gold-grad:  linear-gradient(135deg, #F5D59A 0%, #C9A669 45%, #A27A3D 100%);

  --ink:        #181614;   /* near-black, warm */
  --ink-soft:   #3a3633;
  --bg:         #FBFAF6;   /* warm white */
  --bg-alt:     #F3EEE4;   /* soft sand */
  --line:       #e7e0d3;
  --muted:      #76706a;

  --serif: "Playfair Display", Georgia, serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw: 1180px;
  --radius: 14px;
  --shadow: 0 14px 40px rgba(24,22,20,.12);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.12; letter-spacing:-.01em; }
h1{ font-size:clamp(2.4rem, 6vw, 4.4rem); }
h2{ font-size:clamp(1.9rem, 3.6vw, 2.9rem); }
h3{ font-size:1.35rem; }
p{ color:var(--ink-soft); }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding:clamp(60px, 9vw, 120px) 0; }
.center{ text-align:center; }

/* --- Eyebrow / section labels --- */
.eyebrow{
  font-family:var(--sans);
  font-size:.78rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-text);
  display:inline-block; margin-bottom:14px;
}
.eyebrow::before{ content:""; display:inline-block; width:26px; height:2px;
  background:var(--gold-grad); vertical-align:middle; margin-right:10px; }

/* ============================ BUTTONS ============================ */
.btn{
  display:inline-block; font-family:var(--sans); font-weight:600;
  font-size:.95rem; letter-spacing:.02em;
  padding:14px 30px; border-radius:999px; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  border:none;
}
.btn-gold{
  background:var(--gold-grad); color:var(--ink);
  box-shadow:0 8px 22px rgba(162,122,61,.35);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(162,122,61,.45); }
.btn-red{ background:var(--red); color:#fff; box-shadow:0 8px 22px rgba(226,6,19,.28); }
.btn-red:hover{ background:var(--red-deep); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.7); }
.btn-ghost:hover{ background:#fff; color:var(--ink); }
.btn-outline{ background:transparent; color:var(--ink); border:1.5px solid var(--gold); }
.btn-outline:hover{ background:var(--gold); color:var(--ink); }

/* ============================ HEADER ============================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,250,246,.88); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{ display:flex; align-items:center; gap:12px; font-family:var(--serif);
  font-size:1.25rem; font-weight:700; letter-spacing:.04em; }
.brand img{ height:54px; width:auto; }
.brand span{ background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.nav-links{ display:flex; align-items:center; gap:30px; list-style:none; }
.nav-links a{ font-size:.95rem; font-weight:500; color:var(--ink-soft); position:relative; }
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--gold-grad); transition:width .22s ease; }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:6px; }
.nav-toggle span{ width:24px; height:2px; background:var(--ink); transition:.2s; }

/* ============================ HERO ============================ */
.hero{ position:relative; min-height:88vh; display:flex; align-items:center;
  color:#fff; text-align:center; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-bg::after{ content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 55% at center 48%, rgba(18,16,14,.5) 0%, rgba(18,16,14,.7) 100%),
    linear-gradient(180deg, rgba(18,16,14,.55) 0%, rgba(18,16,14,.6) 40%, rgba(18,16,14,.88) 100%); }
.hero-inner{ position:relative; z-index:2; max-width:820px; margin:0 auto; padding:120px 24px; }
.hero .logo-mark{ height:92px; width:auto; margin:0 auto 22px; filter:drop-shadow(0 6px 18px rgba(0,0,0,.5)); }
.hero h1{ color:#fff; margin-bottom:18px; }
.hero h1 .dot{ color:var(--gold-light); }
.hero .lede{ font-size:1.2rem; color:rgba(255,255,255,.92); max-width:620px; margin:0 auto 34px; }
.hero-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.hero-tags{ margin-top:40px; font-size:.85rem; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.8); }
.hero-tags b{ color:var(--gold-light); font-weight:600; }

/* ============================ SECTION HEADS ============================ */
.section-head{ max-width:680px; margin:0 auto 54px; text-align:center; }
.section-head p{ margin-top:14px; font-size:1.08rem; }

/* ============================ ROOMS GRID ============================ */
.cards{ display:grid; grid-template-columns:repeat(auto-fit, minmax(250px,1fr)); gap:26px; }
.card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; transition:transform .2s ease, box-shadow .2s ease; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.card-img{ aspect-ratio:1/1; overflow:hidden; }
.card-img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.card:hover .card-img img{ transform:scale(1.06); }
.card-body{ padding:22px 22px 26px; }
.card-body .tag{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red); font-weight:700; }
.card-body h3{ margin:8px 0 14px; }
.card-link{ font-weight:600; font-size:.92rem; color:var(--gold-text);
  display:inline-flex; align-items:center; gap:6px; }
.card-link:hover{ gap:10px; }

/* ============================ STORY / SPLIT ============================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.split.alt{ background:var(--bg-alt); }
.split-img img{ border-radius:var(--radius); box-shadow:var(--shadow); width:100%;
  aspect-ratio:4/3; object-fit:cover; }
.split-text .btn{ margin-top:26px; }

/* ============================ AMENITIES ============================ */
.amenity{ display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:26px; }
.amenity-card{ position:relative; border-radius:var(--radius); overflow:hidden; min-height:300px;
  display:flex; align-items:flex-end; color:#fff; }
.amenity-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.amenity-card::after{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(24,22,20,0) 30%, rgba(24,22,20,.85) 100%); }
.amenity-body{ position:relative; z-index:2; padding:26px; }
.amenity-body .status{ display:inline-block; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  font-weight:700; padding:5px 12px; border-radius:999px; margin-bottom:12px; }
.status.open{ background:var(--gold-grad); color:var(--ink); }
.status.soon{ background:var(--red); color:#fff; }
.amenity-body h3{ color:#fff; }
.amenity-body p{ color:rgba(255,255,255,.9); font-size:.95rem; margin-top:6px; }
.amenity-body a{ display:inline-block; margin-top:14px; font-weight:600; color:var(--gold-light); }

/* ============================ CTA BAND ============================ */
.cta-band{ background:var(--ink); color:#fff; text-align:center; }
.cta-band h2{ color:#fff; }
.cta-band h2 .gold{ background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.cta-band p{ color:rgba(255,255,255,.8); max-width:560px; margin:14px auto 30px; }

/* ============================ FOOTER ============================ */
.site-footer{ background:#100f0e; color:rgba(255,255,255,.75); padding:64px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-brand{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer-brand img{ height:84px; }
.footer-brand span{ font-family:var(--serif); font-size:1.3rem; color:#fff; letter-spacing:.04em; }
.site-footer h4{ color:#fff; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:16px; font-family:var(--sans); }
.site-footer ul{ list-style:none; }
.site-footer li{ margin-bottom:10px; font-size:.95rem; }
.site-footer a:hover{ color:var(--gold-light); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding-top:24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.85rem; color:rgba(255,255,255,.5); }

/* ============================ RESPONSIVE ============================ */
@media (max-width:860px){
  .nav-links{ position:fixed; inset:74px 0 auto 0; background:var(--bg);
    flex-direction:column; gap:0; padding:10px 0; border-bottom:1px solid var(--line);
    transform:translateY(-130%); transition:transform .28s ease; box-shadow:var(--shadow); }
  .nav-links.open{ transform:translateY(0); }
  .nav-links li{ width:100%; text-align:center; }
  .nav-links a{ display:block; padding:14px; }
  .nav-toggle{ display:flex; }
  .nav-desktop-cta{ display:none; }
  .split{ grid-template-columns:1fr; gap:34px; }
  .split.reverse .split-img{ order:-1; }
  .footer-grid{ grid-template-columns:1fr; gap:30px; }
}

/* =====================================================================
   PAGE COMPONENTS  (added for Rooms / Amenities / About / Contact)
   ===================================================================== */

/* --- Accessibility helpers --- */
.skip-link{ position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--ink); color:#fff; padding:12px 18px; border-radius:0 0 8px 0; font-weight:600; }
.skip-link:focus{ left:0; }
.visually-hidden{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
a:focus-visible, button:focus-visible, summary:focus-visible,
input:focus-visible, textarea:focus-visible{ outline:2px solid var(--gold-deep); outline-offset:2px; border-radius:4px; }
.eyebrow.light{ color:var(--gold-light); }

/* --- Layout helpers --- */
.section-tight{ padding:clamp(48px,7vw,90px) 0; }
.container.narrow{ max-width:840px; }
.alt-bg{ background:var(--bg-alt); }
.muted-lede{ color:var(--muted); }
.muted-note{ font-size:.85rem; color:var(--muted); }
.footer-tag{ color:rgba(255,255,255,.7); max-width:300px; }

/* --- Page hero (inner pages) --- */
.page-hero{ position:relative; min-height:46vh; display:flex; align-items:flex-end;
  color:#fff; overflow:hidden; }
.page-hero-short{ min-height:40vh; }
.page-hero-bg{ position:absolute; inset:0; }
.page-hero-bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(18,16,14,.42) 0%, rgba(18,16,14,.55) 55%, rgba(18,16,14,.85) 100%); }
.page-hero-inner{ position:relative; z-index:2; padding-block:clamp(48px,8vw,90px); }
.page-hero h1{ color:#fff; margin-bottom:12px; max-width:20ch; }
.page-hero p{ color:rgba(255,255,255,.92); font-size:1.12rem; max-width:60ch; }

/* --- Feature strip (Rooms "every stay includes") --- */
.feature-strip{ list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin-top:36px; }
.feature-strip li{ background:#fff; border:1px solid var(--line); border-radius:999px;
  padding:10px 20px; font-size:.9rem; font-weight:500; color:var(--ink-soft); }
.feature-strip li::before{ content:"✓"; color:var(--gold-text); font-weight:700; margin-right:8px; }

/* --- Room / amenity alternating rows --- */
.rooms-list{ display:flex; flex-direction:column; gap:clamp(46px,7vw,84px); }
.room{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,60px); align-items:center; }
.room.reverse .room-media{ order:2; }
.room-media{ position:relative; }
.room-media picture{ display:block; }
.room-media img{ width:100%; height:auto; border-radius:var(--radius); box-shadow:var(--shadow);
  aspect-ratio:4/3; object-fit:cover; }
.room-badge{ position:absolute; top:16px; left:16px; background:var(--gold-grad); color:var(--ink);
  font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:7px 14px; border-radius:999px; box-shadow:0 6px 16px rgba(0,0,0,.2); }
.room-info h2{ margin:10px 0 14px; }
.room-info .amp{ display:inline-block; color:var(--gold-deep); font-size:.5em; font-weight:600;
  letter-spacing:.02em; vertical-align:middle; }
.room-info > p{ margin-bottom:20px; }
.room-info .status{ display:inline-block; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  font-weight:700; padding:5px 12px; border-radius:999px; margin-bottom:12px; }

/* feature list inside a room/amenity row */
.room-features{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr);
  gap:10px 22px; margin:0 0 26px; }
.room-features li{ position:relative; padding-left:26px; font-size:.95rem; color:var(--ink-soft); }
.room-features li::before{ content:""; position:absolute; left:0; top:7px; width:14px; height:14px;
  border-radius:50%; background:var(--gold-grad); }
.room-features li.pet::before{ background:var(--red); }

/* graphic panel (photo-less rows: café, golf) */
.room-media.graphic{ aspect-ratio:4/3; border-radius:var(--radius); box-shadow:var(--shadow);
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(140deg,#26221d 0%, #14110f 100%); }
.room-media.graphic .graphic-inner{ color:rgba(201,166,105,.55); }

/* photo-less amenity cards on the Home grid */
.amenity-card.no-photo{ background:linear-gradient(140deg,#26221d 0%, #14110f 100%); }
.amenity-card.no-photo .amenity-graphic{ position:absolute; inset:0; z-index:0;
  display:flex; align-items:center; justify-content:center; color:rgba(201,166,105,.3); }
.amenity-card.no-photo::after{ background:linear-gradient(180deg, rgba(24,22,20,.05) 0%, rgba(24,22,20,.7) 100%); }

/* --- About: values + lead quote --- */
.values{ display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:26px; }
.value-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 28px; text-align:center; transition:transform .2s ease, box-shadow .2s ease; }
.value-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.value-icon{ width:66px; height:66px; margin:0 auto 18px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; background:var(--bg-alt); color:var(--gold-deep); }
.value-card h3{ margin-bottom:10px; }
.value-card p{ font-size:.97rem; }
.lead-quote{ font-family:var(--serif); font-style:italic; font-size:clamp(1.35rem,2.6vw,2rem);
  line-height:1.5; color:var(--ink); max-width:62ch; margin:6px auto 0; }
.split-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:26px; }

/* --- Contact: grid, details, form, map --- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(32px,5vw,64px); align-items:start; }
.contact-details h2{ margin:8px 0 0; }
.contact-list{ list-style:none; display:flex; flex-direction:column; gap:20px; margin:26px 0 30px; }
.contact-list li{ display:flex; gap:14px; align-items:flex-start; }
.contact-ico{ flex:none; width:42px; height:42px; border-radius:50%; background:var(--bg-alt);
  color:var(--gold-deep); display:flex; align-items:center; justify-content:center; }
.contact-label{ display:block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); font-weight:600; margin-bottom:2px; }
.contact-list a{ color:var(--ink); font-weight:500; }
.contact-list a:hover{ color:var(--gold-deep); }

.contact-form-wrap{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(24px,4vw,40px); box-shadow:var(--shadow); }
.form-title{ font-size:1.5rem; margin-bottom:20px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:.85rem; font-weight:600; margin-bottom:7px; color:var(--ink-soft); }
.field input, .field textarea{ width:100%; font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--bg); border:1.5px solid var(--line); border-radius:10px; padding:12px 14px;
  transition:border-color .15s ease, box-shadow .15s ease; }
.field textarea{ resize:vertical; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,166,105,.22); }
.field.invalid input, .field.invalid textarea{ border-color:var(--red); }
.field-error{ display:block; min-height:1em; font-size:.8rem; color:var(--red); margin-top:5px; }
.hp{ position:absolute!important; left:-9999px; width:1px; height:1px; opacity:0; }
.form-submit{ width:100%; margin-top:4px; }
.form-submit[disabled]{ opacity:.6; cursor:progress; }
.form-status{ margin-top:14px; font-size:.92rem; font-weight:600; min-height:1.2em; }
.form-status.success{ color:#1a7a3d; }
.form-status.error{ color:var(--red); }

.map-wrap{ position:relative; aspect-ratio:16/7; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.map-wrap iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.map-placeholder{ border:2px dashed var(--gold); border-radius:var(--radius); background:var(--bg);
  color:var(--gold-deep); text-align:center; padding:clamp(36px,6vw,60px) 24px; }
.map-placeholder svg{ margin:0 auto 8px; }
.map-placeholder strong{ color:var(--ink); font-family:var(--serif); font-size:1.2rem; }
.map-placeholder a{ color:var(--gold-text); font-weight:600; text-decoration:underline; }

/* --- FAQ accordion (native <details>) --- */
.faq{ display:flex; flex-direction:column; gap:14px; }
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.faq-item summary{ cursor:pointer; padding:20px 54px 20px 22px; list-style:none;
  font-family:var(--serif); font-size:1.08rem; font-weight:600; color:var(--ink); position:relative; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; position:absolute; right:22px; top:50%; transform:translateY(-50%);
  font-size:1.5rem; line-height:1; color:var(--gold-deep); }
.faq-item[open] summary::after{ content:"\2212"; }
.faq-item summary:hover{ color:var(--gold-deep); }
.faq-body{ padding:0 22px 22px; }
.faq-body p{ font-size:.98rem; }
.faq-body a{ color:var(--gold-text); font-weight:600; text-decoration:underline; }

/* =====================================================================
   RESPONSIVE — page components
   ===================================================================== */
@media (max-width:860px){
  .room{ grid-template-columns:1fr; gap:24px; }
  .room.reverse .room-media{ order:0; }      /* image back on top when stacked */
  .contact-grid{ grid-template-columns:1fr; }
  .page-hero{ min-height:40vh; }
}
@media (max-width:520px){
  .room-features{ grid-template-columns:1fr; }
  .feature-strip li{ font-size:.84rem; padding:9px 16px; }
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
}

/* =====================================================================
   2026 MULTI-BRANCH UPDATE — new components
   Branches & check-in · pet band · reviews · rooms-by-property ·
   restaurant · explore-the-area
   ===================================================================== */

/* --- Spacing helper for stacked sections --- */
.section-flush-top{ padding-top:clamp(28px,4vw,48px); }

/* --- Graphic page hero (pages without a photo yet) --- */
.page-hero.is-graphic{ background:linear-gradient(140deg,#26221d 0%, #14110f 100%); min-height:44vh; align-items:center; }
.page-hero.is-graphic::after{ background:radial-gradient(circle at 72% 18%, rgba(201,166,105,.18), transparent 55%); }
.page-hero.is-graphic .page-hero-inner{ padding-block:clamp(40px,7vw,80px); }

/* --- Prominent notice / front-desk callout --- */
.notice{ display:flex; gap:16px; align-items:flex-start; background:var(--bg-alt);
  border:1px solid var(--line); border-left:4px solid var(--gold); border-radius:var(--radius);
  padding:20px 24px; margin:0 auto; max-width:920px; }
.notice-ico{ flex:none; color:var(--gold-deep); margin-top:2px; }
.notice p{ margin:0; }
.notice a{ color:var(--gold-text); font-weight:600; text-decoration:underline; }

/* --- Branch cards --- */
.branch-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:22px; margin-top:40px; }
.branch-grid-contact{ margin-top:32px; }
.branch-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px 24px;
  display:flex; flex-direction:column; transition:transform .2s ease, box-shadow .2s ease; }
.branch-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.branch-card.is-frontdesk{ border-color:var(--gold); box-shadow:0 0 0 1px var(--gold) inset;
  background:linear-gradient(180deg,#fffdf7,#fff); }
.branch-tag{ font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  color:var(--gold-text); margin-bottom:10px; }
.branch-card.is-frontdesk .branch-tag{ align-self:flex-start; background:var(--gold-grad); color:var(--ink);
  padding:5px 14px; border-radius:999px; letter-spacing:.12em; white-space:nowrap; }
.branch-card h3{ margin-bottom:8px; }
.branch-card p{ font-size:.95rem; margin-bottom:8px; }
.branch-addr{ font-weight:600; color:var(--ink); }
.branch-meta{ color:var(--muted); font-size:.9rem; }
.branch-dir{ margin-top:auto; padding-top:10px; font-weight:600; color:var(--gold-text); }
.branch-dir:hover{ color:var(--gold-deep); }

/* --- How check-in works --- */
.checkin{ margin-top:54px; background:var(--ink); color:#fff; border-radius:var(--radius);
  padding:clamp(28px,5vw,48px); }
.checkin-title{ color:#fff; text-align:center; margin-bottom:30px; }
.checkin-steps{ list-style:none; display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:26px; }
.checkin-steps li{ display:flex; flex-direction:column; gap:12px; }
.step-num{ width:44px; height:44px; border-radius:50%; background:var(--gold-grad); color:var(--ink);
  font-family:var(--serif); font-weight:700; font-size:1.2rem; display:flex; align-items:center; justify-content:center; }
.step-body{ display:flex; flex-direction:column; gap:4px; }
.step-body strong{ font-family:var(--serif); font-size:1.1rem; color:#fff; }
.step-body span{ color:rgba(255,255,255,.75); font-size:.92rem; }
/* keep each step's description aligned across columns even when a title wraps */
@media (min-width:760px){ .checkin-steps .step-body strong{ min-height:2.4em; } }

/* --- Pet-friendly band --- */
.pet-band{ display:flex; gap:clamp(20px,4vw,44px); align-items:center; background:var(--bg-alt);
  border:1px solid var(--line); border-radius:var(--radius); padding:clamp(28px,5vw,48px); }
.pet-band-icon{ flex:none; font-size:clamp(52px,8vw,88px); line-height:1; }
.pet-points{ list-style:none; display:flex; flex-direction:column; gap:8px; margin:18px 0 24px; }
.pet-points li{ position:relative; padding-left:28px; color:var(--ink-soft); }
.pet-points li::before{ content:"🐾"; position:absolute; left:0; top:0; font-size:.95rem; }
.pet-points a{ color:var(--gold-text); font-weight:600; text-decoration:underline; }
.pet-band .btn{ margin-top:0; }

/* --- Reviews --- */
.rating-summary{ text-align:center; margin-bottom:46px; }
.rating-stars{ color:var(--gold-deep); font-size:1.9rem; letter-spacing:.1em; }
.rating-text{ margin:8px 0 20px; }
.review-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.review-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; }
.review-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px; margin:0; }
.review-stars{ color:var(--gold-deep); letter-spacing:.08em; margin-bottom:12px; }
.review-card blockquote{ font-family:var(--serif); font-style:italic; font-size:1.06rem; line-height:1.5;
  color:var(--ink); margin:0 0 16px; }
.review-card figcaption{ display:flex; flex-direction:column; }
.review-name{ font-weight:600; color:var(--ink); }
.review-src{ font-size:.82rem; color:var(--muted); }

/* Aggregate rating badges */
.rating-badges{ display:flex; flex-wrap:wrap; justify-content:center; gap:18px; }
.rating-badge{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:20px 30px; min-width:200px; display:flex; flex-direction:column; align-items:center; gap:4px; }
.rating-score{ font-family:var(--serif); font-weight:700; font-size:2.4rem; line-height:1; color:var(--ink); }
.rating-score span{ font-size:1rem; color:var(--muted); font-weight:600; }
.rating-badge .rating-stars{ font-size:1.05rem; }
.rating-grade{ font-weight:700; color:var(--gold-text); font-size:.9rem; letter-spacing:.04em; text-transform:uppercase; }
.rating-platform{ font-size:.85rem; color:var(--muted); }
.rating-cats{ list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:22px 0 24px; }
.rating-cats li{ background:#fff; border:1px solid var(--line); border-radius:999px; padding:7px 16px;
  font-size:.85rem; color:var(--ink-soft); }
.rating-cats b{ color:var(--gold-text); }

/* --- Rooms grouped by property --- */
.property-nav{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:28px; }
.property-nav a{ background:#fff; border:1px solid var(--line); border-radius:999px; padding:10px 22px;
  font-weight:600; font-size:.92rem; color:var(--ink-soft); transition:border-color .18s ease, color .18s ease, background .18s ease; }
.property-nav a:hover{ border-color:var(--gold); color:var(--ink); background:var(--bg-alt); }
.property-head{ text-align:center; max-width:680px; margin:0 auto; }
.property-head h2{ margin:6px 0 10px; }

/* --- Restaurant: gallery, menu, info cards --- */
.gallery{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; }
.gallery-item{ aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden; }
.gallery-item img{ width:100%; height:100%; object-fit:cover; }
.gallery-item.placeholder{ display:flex; align-items:center; justify-content:center; border:1px solid var(--line);
  background:linear-gradient(140deg,#26221d,#14110f); color:rgba(201,166,105,.6);
  font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; }

.menu-cols{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:32px; }
.menu-group h3{ padding-bottom:10px; border-bottom:2px solid var(--gold); margin-bottom:14px; }
.menu-list{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.menu-list li{ color:var(--ink-soft); }

.info-cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; }
.info-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px 28px; }
.info-ico{ width:54px; height:54px; border-radius:50%; background:var(--bg-alt); color:var(--gold-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.info-card h3{ margin-bottom:10px; }
.info-card p{ font-size:.95rem; margin-bottom:14px; }
.hours-list, .plain-list{ list-style:none; display:flex; flex-direction:column; gap:8px; }
.hours-list li{ display:flex; justify-content:space-between; gap:14px; font-size:.95rem;
  border-bottom:1px dashed var(--line); padding-bottom:6px; }
.plain-list a{ color:var(--ink); font-weight:500; }
.plain-list a:hover{ color:var(--gold-deep); }

/* --- Explore: themes & attractions --- */
.theme-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:26px; }
.theme-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:34px 30px;
  transition:transform .2s ease, box-shadow .2s ease; }
.theme-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.theme-ico{ width:64px; height:64px; border-radius:50%; background:var(--bg-alt); color:var(--gold-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.theme-card h3{ margin-bottom:10px; }
.theme-card p{ font-size:.97rem; }

.attraction-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; }
.attraction-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px;
  display:flex; flex-direction:column; transition:transform .2s ease, box-shadow .2s ease; }
.attraction-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.attraction-card h3{ margin-bottom:6px; }
.attraction-meta{ color:var(--gold-text); font-weight:600; font-size:.85rem; margin-bottom:12px; }
.attraction-card > p{ font-size:.95rem; margin-bottom:16px; }
.attraction-link{ margin-top:auto; font-weight:600; color:var(--gold-text); }
.attraction-link:hover{ color:var(--gold-deep); }

/* --- Rosie & Josie restaurant lockup --- */
.resto-logo{ text-align:center; }
.resto-est{ display:block; letter-spacing:.38em; text-transform:uppercase; font-size:.78rem;
  color:var(--gold-light); margin-bottom:8px; }
.resto-name{ font-family:var(--serif); color:#fff; font-weight:700; line-height:1;
  font-size:clamp(2.6rem,7vw,4.6rem); margin:0 auto; max-width:none; letter-spacing:.01em; }
.resto-flag{ display:block; width:min(440px,82%); height:8px; margin:16px auto 12px; border-radius:2px;
  background:linear-gradient(to right,#1a7a3d 0 33.33%, #ffffff 33.33% 66.66%, #c8102e 66.66% 100%); }
.resto-sub{ display:block; letter-spacing:.34em; text-transform:uppercase; font-size:.85rem;
  color:rgba(255,255,255,.85); }
.resto-lede{ color:rgba(255,255,255,.92); max-width:60ch; margin:24px auto 0; text-align:center; font-size:1.1rem; }

/* --- Responsive for new components --- */
@media (max-width:760px){
  .pet-band{ flex-direction:column; text-align:center; align-items:center; }
  .pet-band-text{ width:100%; }
  .pet-points{ text-align:left; display:inline-flex; }
}
