:root {
  --gold: #c8a45d;
  --gold-dark: #7a5a1d;
  --ink: #141414;
  --cream: #f7f1e8;
  --muted: #5d6268;
  --focus: #48a6ff;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: Georgia, "Times New Roman", serif; color: var(--ink); background: #fff; }
p, .nav-link, .btn, .form-control, .form-select, li, .topbar, .text-muted, label, input, textarea, select { font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
a { color: #684915; }
a:hover { color: #3f2b0b; }
.skip-link {
  position: absolute;
  left: 1rem;
  top: -4rem;
  z-index: 2000;
  padding: .75rem 1rem;
  background: #fff;
  color: #000;
  border: 3px solid var(--focus);
}
.skip-link:focus { top: 1rem; }
:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 3px;
}
.topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1041;
  background: #101010;
  color: rgba(255,255,255,.88);
  font-size: .9rem;
  padding: .45rem 0;
}
.topbar a { color: #fff; text-decoration: underline; text-underline-offset: 3px; }
.main-nav {
  top: 0;
  background: rgba(8,8,8,.72);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.16);
}
@media (min-width: 992px) { .main-nav { top: 35px; } }
.logo-brand img {
  height: 60px;
  width: auto;
  display: block;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.28));
}
.nav-link { color: rgba(255,255,255,.9); }
.nav-link:hover, .nav-link:focus { color: #fff; text-decoration: underline; text-underline-offset: 5px; }
.btn-gold {
  background: var(--gold);
  border-color: var(--gold);
  color: #111;
  font-family: system-ui, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .055em;
}
.btn-gold:hover, .btn-gold:focus {
  background: var(--gold-dark);
  border-color: var(--gold-dark);
  color: #fff;
}
.hero-section {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  background: #111;
}
.hero-section .carousel { position: absolute; inset: 0; }
.hero-img { background-position: center; background-size: cover; }
.hero-1 { background-image: url("https://images.unsplash.com/photo-1600607687644-c7171b42498f?auto=format&fit=crop&w=1900&q=80"); }
.hero-2 { background-image: url("https://images.unsplash.com/photo-1613490493576-7fde63acd811?auto=format&fit=crop&w=1900&q=80"); }
.hero-3 { background-image: url("https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1900&q=80"); }
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.88), rgba(0,0,0,.48), rgba(0,0,0,.28));
}
.hero-content { z-index: 2; padding-top: 110px; }
.eyebrow, .section-kicker {
  font-family: system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 900;
  font-size: .78rem;
  color: var(--gold);
}
.text-white-75 { color: rgba(255,255,255,.84); }
.availability-card {
  background: rgba(255,255,255,.97);
  padding: 1.6rem;
  border-top: 5px solid var(--gold);
  box-shadow: 0 25px 80px rgba(0,0,0,.35);
}
.form-label { font-weight: 700; color: #1d1d1d; }
.form-control, .form-select {
  min-height: 46px;
  border-radius: 0;
  border: 1px solid #8f8f8f;
}
.section-title {
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.05;
  font-weight: 700;
}
.suite-card {
  background: #fff;
  border: 1px solid #d9ccb9;
  transition: transform .2s ease, box-shadow .2s ease;
}
.suite-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 1.2rem 3rem rgba(0,0,0,.14);
}
.suite-card img {
  width: 100%;
  height: 265px;
  object-fit: cover;
}
.suite-card-body { padding: 1.35rem; }
.suite-card h3 { font-size: 1.7rem; margin: .4rem 0 .8rem; }
.suite-card ul { padding-left: 1.1rem; color: var(--muted); }
.suite-label {
  font-family: system-ui, sans-serif;
  color: var(--gold-dark);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .75rem;
}
.amenities-section, .location-section { background: linear-gradient(180deg, #fff, var(--cream)); }
.bg-cream { background: var(--cream); }
.feature-tile {
  height: 100%;
  background: #fff;
  border-left: 5px solid var(--gold-dark);
  padding: 1rem;
  font-family: system-ui, sans-serif;
  font-weight: 800;
  box-shadow: 0 .5rem 1.5rem rgba(0,0,0,.05);
}
.gallery-grid img {
  width: 100%;
  height: 270px;
  object-fit: cover;
}
.concierge-section { background: linear-gradient(135deg, #090909, #242018); }
.text-gold { color: var(--gold); }
.mini-chat-preview {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.18);
  padding: 1.25rem;
  font-family: system-ui, sans-serif;
}
.mini-chat-preview p {
  background: rgba(255,255,255,.08);
  padding: .85rem;
  margin-bottom: .7rem;
}
.contact-form .form-control { padding: .9rem 1rem; }
.footer {
  background: #0c0c0c;
  color: rgba(255,255,255,.82);
  font-family: system-ui, sans-serif;
  font-size: .92rem;
}
.chat-toggle {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  border: 0;
  background: var(--gold);
  color: #111;
  font-size: 1.4rem;
  z-index: 1040;
  box-shadow: 0 1rem 2rem rgba(0,0,0,.25);
}
.chat-widget {
  position: fixed;
  right: 24px;
  bottom: 94px;
  width: min(410px, calc(100vw - 32px));
  height: 555px;
  background: #fff;
  overflow: hidden;
  z-index: 1040;
  display: flex;
  flex-direction: column;
  border: 1px solid #d9ccb9;
}
.chat-header {
  background: #111;
  color: #fff;
  padding: 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: system-ui, sans-serif;
}
.chat-header button {
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 1.7rem;
  line-height: 1;
}
.chat-messages {
  flex: 1;
  padding: 1rem;
  overflow-y: auto;
  background: #f7f1e8;
  font-family: system-ui, sans-serif;
}
.bot-message, .user-message {
  padding: .75rem .9rem;
  margin-bottom: .7rem;
  max-width: 88%;
  font-size: .95rem;
}
.bot-message {
  background: #fff;
  border: 1px solid #d9ccb9;
}
.user-message {
  background: #111;
  color: #fff;
  margin-left: auto;
}
.chat-input {
  display: flex;
  border-top: 1px solid #d9ccb9;
  font-family: system-ui, sans-serif;
}
.chat-input input {
  flex: 1;
  border: 0;
  padding: .9rem;
  outline: none;
}
.chat-input button {
  border: 0;
  background: var(--gold);
  color: #111;
  font-weight: 900;
  padding: 0 1rem;
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .carousel { display: none; }
  .hero-section { background: url("https://images.unsplash.com/photo-1600607687644-c7171b42498f?auto=format&fit=crop&w=1900&q=80") center/cover no-repeat; }
}
@media (max-width: 767px) {
  .display-2 { font-size: 2.6rem; }
  .gallery-grid img, .suite-card img { height: 220px; }
  .hero-content { padding-top: 120px; }
  .logo-brand img { height: 48px; }
  .topbar { position: static; }
  .main-nav { top: 0; }
}
