
:root{
  --bg:#f6f1eb;
  --bg-soft:#fcfaf7;
  --text:#161616;
  --muted:#5c5a58;
  --gold:#d6b16a;
  --gold-deep:#c49843;
  --border:rgba(255,255,255,.14);
  --dark:#111111;
  --dark-2:#1b1b1b;
  --shadow:0 18px 40px rgba(0,0,0,.12);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter", Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(214,177,106,.08), transparent 28%),
    linear-gradient(180deg, #f8f5f1 0%, #f2ece5 100%);
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.container{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.narrow{width:min(760px, calc(100% - 32px)); margin:0 auto}
.center{text-align:center}
.desktop-only{display:inline-flex}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter: blur(16px);
  background:linear-gradient(180deg, rgba(10,10,10,.92) 0%, rgba(12,12,12,.84) 100%);
  border-bottom:1px solid rgba(214,177,106,.24);
  box-shadow:0 10px 26px rgba(0,0,0,.18);
}
.header-inner{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  color:#fff;
}
.brand-mark{
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}
.brand img{height:56px; width:auto; display:block;}
.brand-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.brand-name{
  font-size:1rem;
  line-height:1;
  letter-spacing:.22em;
  font-weight:700;
  color:#f6efe4;
}
.brand-sub{
  font-size:.69rem;
  line-height:1;
  letter-spacing:.42em;
  font-weight:600;
  color:rgba(214,177,106,.92);
}
.nav{
  display:flex;
  align-items:center;
  gap:32px;
  color:rgba(255,255,255,.9);
  font-size:1rem;
  font-weight:500;
  letter-spacing:.03em;
}
.nav a{
  position:relative;
  padding:10px 0;
  transition:color .24s ease;
}
.nav a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:2px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(214,177,106,.95), transparent);
  transform:scaleX(.2);
  transform-origin:center;
  opacity:0;
  transition:transform .24s ease, opacity .24s ease;
}
.nav a:hover,
.nav a:focus-visible{color:#fff}
.nav a:hover::after,
.nav a:focus-visible::after{
  transform:scaleX(1);
  opacity:1;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 22px;
  border-radius:999px;
  font-weight:600;
  border:1px solid transparent;
  box-shadow:0 10px 22px rgba(0,0,0,.08);
  transition:transform .24s ease, opacity .24s ease, background .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn:focus-visible,
.nav a:focus-visible{
  outline:none;
}
.btn-gold{
  background:linear-gradient(180deg, #ebcf95 0%, var(--gold) 100%);
  color:#191919;
  border-color:rgba(255,255,255,.22);
  box-shadow:0 14px 28px rgba(198,152,67,.22);
}
.btn-gold:hover,
.btn-gold:focus-visible{
  box-shadow:0 18px 34px rgba(198,152,67,.28);
}
.btn-outline{
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  background:rgba(255,255,255,.06);
  box-shadow:0 14px 28px rgba(0,0,0,.12);
}
.btn-outline:hover,
.btn-outline:focus-visible{
  border-color:rgba(214,177,106,.56);
  background:rgba(255,255,255,.1);
  box-shadow:0 18px 34px rgba(0,0,0,.16);
}

.hero{
  position:relative;
  min-height:760px;
  display:grid;
  align-items:end;
  overflow:hidden;
  background:#090909;
}
.hero-media, .hero-overlay, .hero-signage{
  position:absolute; inset:0;
}
.hero-media img{
  width:100%; height:100%; object-fit:cover;
  filter:saturate(.92) brightness(1.03) contrast(1.02);
}
.hero-signage{pointer-events:none;}
.hero-signage img{
  position:absolute;
  right:12%;
  top:18%;
  width:min(24vw, 300px);
  border-radius:24px;
  box-shadow:0 20px 50px rgba(0,0,0,.28);
  opacity:.95;
}
.hero-overlay{
  background:
    radial-gradient(circle at 18% 38%, rgba(214,177,106,.18), transparent 24%),
    linear-gradient(90deg, rgba(7,7,7,.9) 0%, rgba(7,7,7,.58) 36%, rgba(7,7,7,.18) 66%, rgba(7,7,7,.36) 100%),
    linear-gradient(180deg, rgba(7,7,7,.18) 0%, rgba(7,7,7,.08) 24%, rgba(7,7,7,.68) 100%);
}
.hero-content{
  position:relative;
  z-index:2;
  padding:118px 0 92px;
}
.hero-copy{
  max-width:620px;
  color:#fff;
  padding:34px 36px 36px;
  border-radius:28px;
  background:linear-gradient(90deg, rgba(8,8,8,.56) 0%, rgba(8,8,8,.34) 62%, rgba(8,8,8,0) 100%);
}
.eyebrow{
  margin:0 0 16px;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--gold);
  font-weight:600;
}
.hero h1, .section h2{
  margin:0;
  font-family:"Cormorant Garamond", Georgia, serif;
  font-weight:600;
  letter-spacing:-.02em;
  line-height:.95;
}
.hero h1{font-size:clamp(3.4rem, 8vw, 6.4rem)}
.hero-text{
  margin:24px 0 0;
  font-size:1.1rem;
  line-height:1.88;
  max-width:560px;
  color:rgba(255,255,255,.9);
}
.hero-actions{
  display:flex; gap:14px; flex-wrap:wrap;
  margin-top:38px;
}

.section{
  padding:96px 0;
}
.intro{
  background:
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(255,255,255,.84)),
    radial-gradient(circle at top center, rgba(214,177,106,.12), transparent 60%);
}
.section h2{
  font-size:clamp(2.6rem, 5vw, 4rem);
  text-align:center;
  margin-bottom:22px;
}
.section-lead{
  text-align:center;
  color:var(--muted);
  font-size:1.06rem;
  line-height:1.88;
  max-width:700px;
  margin:0 auto;
}
.light{color:rgba(255,255,255,.82)}

.icon-grid{
  margin-top:48px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.icon-card{
  background:linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(250,245,239,.88) 100%);
  border:1px solid rgba(198,152,67,.18);
  box-shadow:0 22px 46px rgba(44,30,12,.1);
  border-radius:var(--radius);
  padding:32px 28px;
  text-align:center;
}
.icon-circle{
  width:68px; height:68px; border-radius:50%;
  display:grid; place-items:center;
  margin:0 auto 18px;
  background:linear-gradient(180deg, rgba(214,177,106,.3) 0%, rgba(214,177,106,.16) 100%);
  border:1px solid rgba(198,152,67,.3);
  color:#9c6f22;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.62), 0 10px 18px rgba(198,152,67,.12);
  font-size:1.8rem; font-weight:700;
}
.icon-card h3, .feature-card h3{
  margin:0 0 10px;
  font-size:1.25rem;
}
.icon-card h3{color:#17110b}
.icon-card p, .feature-card p, .contact-copy p, .contact-note p{
  margin:0;
  color:#4f4840;
  line-height:1.75;
}

.suites{
  background:linear-gradient(180deg, #fbf8f4 0%, #f3ece5 100%);
}
.suite-layout-note{
  margin:18px auto 0;
  max-width:560px;
  text-align:center;
  font-size:.96rem;
  line-height:1.7;
  color:#6a635b;
}
.gallery-grid{
  margin-top:42px;
  display:grid;
  grid-template-columns:1.15fr 1fr 1fr;
  gap:18px;
  grid-auto-rows:240px;
}
.gallery-card{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  box-shadow:var(--shadow);
  background:#ddd;
}
.gallery-card.tall{
  grid-row:span 2;
}
.gallery-card img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s ease;
}
.gallery-card:hover img{transform:scale(1.035)}
.gallery-card figcaption{
  position:absolute;
  left:16px;
  bottom:16px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(17,17,17,.72);
  color:#fff;
  font-size:.94rem;
  backdrop-filter: blur(8px);
}

.location-section{
  background:linear-gradient(180deg, #f8f3ed 0%, #f2ebe3 100%);
}
.location-map-block {
  max-width: 980px;
  margin: 42px auto 40px auto;
  text-align: center;
}

.location-address {
  margin-bottom: 20px;
}

.location-address h3 {
  margin: 0 0 10px;
  font-size: 28px;
  color: #17110b;
}

.location-address a {
  color: #c89b3c;
  font-weight: 600;
  text-decoration: none;
}

.location-address a:hover {
  text-decoration: underline;
}

.location-map-wrap {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}

.location-map-wrap iframe {
  display: block;
  width: 100%;
  height: 360px;
}
.location-grid{
  margin-top:46px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}
.location-card{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:24px 24px;
  border-radius:22px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(198,152,67,.14);
  box-shadow:0 14px 28px rgba(44,30,12,.06);
}
.location-marker{
  width:9px;
  height:9px;
  margin-top:8px;
  flex:0 0 9px;
  border-radius:50%;
  background:linear-gradient(180deg, #e0bf7d 0%, #c49843 100%);
  box-shadow:0 0 0 4px rgba(214,177,106,.12);
}
.location-card p{
  margin:0;
  color:#3f3831;
  font-size:1rem;
  line-height:1.75;
}

.suite-options {
  text-align:center;
  padding:104px 20px;
  background:linear-gradient(180deg, #faf6f1 0%, #f3ece5 100%);
}

.suite-options h2 {
  font-size:clamp(2.4rem, 4.4vw, 3.2rem);
  margin-bottom:14px;
}

.section-subtext {
  max-width:640px;
  margin:0 auto 52px;
  color:#5f5750;
  font-size:1.04rem;
  line-height:1.85;
}

.suite-options-grid {
  display:flex;
  justify-content:center;
  align-items:stretch;
  gap:32px;
  flex-wrap:wrap;
}

.suite-option-card {
  width:min(100%, 340px);
  min-height:330px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  text-align:center;
  background:linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(250,245,239,.92) 100%);
  border:1px solid rgba(198,152,67,.14);
  border-radius:24px;
  padding:38px 32px 34px;
  box-shadow:0 18px 38px rgba(44,30,12,.08);
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.suite-option-card:hover {
  transform:translateY(-4px);
  border-color:rgba(198,152,67,.24);
  box-shadow:0 24px 44px rgba(44,30,12,.12);
}

.suite-option-icon {
  width:96px;
  height:96px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 22px;
}

.suite-option-card img {
  width:80px;
  height:auto;
  display:block;
  margin:0 auto;
}

.suite-option-card h3 {
  margin:0 0 12px;
  font-size:1.38rem;
  color:#17110b;
}

.suite-option-card p {
  margin:0;
  font-size:.98rem;
  line-height:1.75;
  color:#4f4840;
}

.amenities{
  background:
    linear-gradient(180deg, rgba(255,255,255,.82) 0%, rgba(247,241,233,.96) 100%),
    radial-gradient(circle at top center, rgba(214,177,106,.12), transparent 58%);
}
.amenities-grid{
  margin-top:46px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:20px;
}
.amenity-card{
  min-height:214px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  text-align:center;
  padding:28px 22px 24px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(250,245,239,.92) 100%);
  border:1px solid rgba(198,152,67,.14);
  box-shadow:0 18px 38px rgba(44,30,12,.08);
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.amenity-card:hover{
  transform:translateY(-3px);
  border-color:rgba(198,152,67,.24);
  box-shadow:0 22px 42px rgba(44,30,12,.12);
}
.amenity-icon{
  width:84px;
  height:84px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
}
.amenity-icon img{
  max-width:72px;
  max-height:72px;
  width:auto;
  height:auto;
}
.amenity-title{
  margin:0;
  font-size:1.02rem;
  line-height:1.45;
  color:#1d1711;
}

.dark{
  position:relative;
  color:#fff;
  background:
    linear-gradient(180deg, rgba(13,13,13,.95), rgba(19,19,19,.96)),
    radial-gradient(circle at top left, rgba(214,177,106,.08), transparent 26%);
}
.feature-grid{
  margin-top:42px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.feature-card{
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  border-radius:24px;
  padding:28px 24px;
  box-shadow:0 18px 34px rgba(0,0,0,.18);
}
.feature-card p{color:rgba(255,255,255,.78)}

.contact-section{
  background:linear-gradient(180deg, #fbf8f3 0%, #efe6dc 100%);
}
.contact-wrap{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:start;
}
.contact-copy h2{
  text-align:left;
  margin-bottom:18px;
}
.contact-card{
  background:#141414;
  color:#fff;
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow);
}
.contact-person h3{
  margin:0 0 8px;
  font-size:1.15rem;
}
.contact-person a{
  color:var(--gold);
  word-break:break-word;
}
.divider{
  height:1px;
  background:rgba(255,255,255,.14);
  margin:18px 0;
}
.contact-note p{
  color:rgba(255,255,255,.76);
}

.site-footer{
  background:#121212;
  color:rgba(255,255,255,.7);
  border-top:1px solid rgba(214,177,106,.18);
}
.footer-inner{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}

@media (max-width: 980px){
  .desktop-only{display:none}
  .hero{min-height:700px}
  .icon-grid, .feature-grid, .contact-wrap{
    grid-template-columns:1fr;
  }
  .location-grid{
    grid-template-columns:1fr 1fr;
  }
  .amenities-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
  .gallery-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 720px){
  .header-inner{
    min-height:78px;
    flex-wrap:wrap;
    justify-content:center;
    padding:12px 0;
  }
  .brand{
    width:100%;
    justify-content:center;
  }
  .nav{
    width:100%;
    justify-content:center;
    gap:18px;
    font-size:.92rem;
  }
  .hero-content{padding:88px 0 60px}
  .hero-copy{
    padding:28px 24px 30px;
  }
  .hero h1{font-size:clamp(3rem, 14vw, 4.6rem)}
  .hero-text{font-size:1rem; line-height:1.7}
  .section{padding:72px 0}
  .gallery-grid{
    grid-template-columns:1fr;
    grid-auto-rows:240px;
  }
  .location-map-wrap iframe {
    height: 280px;
  }
  .suite-options-grid {
    gap: 24px;
  }
  .suite-option-card {
    width: min(100%, 320px);
  }
  .location-grid{
    grid-template-columns:1fr;
  }
  .amenities-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:18px;
  }
  .gallery-card.tall{grid-row:span 1}
  .contact-card{padding:24px}
}

@media (max-width: 520px){
  .container{width:min(100% - 22px, 1180px)}
  .btn{width:100%}
  .hero-actions{flex-direction:column}
  .amenities-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 900px){
  .hero-signage img{right:6%; top:14%; width:min(34vw, 220px);}
  .brand img{height:48px;}
  .brand-name{font-size:.92rem;}
  .brand-sub{font-size:.64rem;}
}
@media (max-width: 640px){
  .brand{
    gap:10px;
  }
  .brand img{height:40px;}
  .brand-name{font-size:.84rem; letter-spacing:.18em;}
  .brand-sub{font-size:.6rem; letter-spacing:.32em;}
  .hero-signage img{display:none;}
}
