/* Suites page specific styles (lean, building on base.css) */
:root {
  --hb-gold: #d4af37;
  --hb-black: #0b0b0d;
  --hb-amber: #c98a2b;
  --hb-red: #8b1e2f;
  --hb-champagne: #f4efe7;
}

.suites-container { max-width: 1200px; margin-inline: auto; padding: 2rem 1.25rem; }
.section { padding: 2.5rem 0; }
.section--accent { background: linear-gradient(180deg, rgba(212,175,55,0.06), transparent); }
.section--highlight { background: linear-gradient(180deg, rgba(139,30,47,0.06), transparent); }
.eyebrow { letter-spacing: .12em; text-transform: uppercase; color: var(--hb-gold); font-weight: 600; }
.lead { font-size: clamp(1.05rem, 1vw + .8rem, 1.35rem); opacity: .9; }

/* Hero */
.suites-hero { position: relative; color: #fff; }
.suites-hero__media { position: relative; height: clamp(360px, 48vw, 560px); overflow: hidden; }
.suites-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.05) contrast(1.05); }
.suites-hero__overlay { position: absolute; inset: 0; background: radial-gradient(60% 70% at 50% 40%, rgba(0,0,0,.1), rgba(0,0,0,.6)); }
.suites-hero__content { position: absolute; inset: 0; display: grid; align-content: center; gap: 1rem; padding: clamp(1rem, 4vw, 3rem); max-width: 1200px; margin: 0 auto; }
.suites-hero__actions { display: flex; gap: .75rem; flex-wrap: wrap; }

/* Gallery */
.suites-gallery__wrap { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; max-width: 1200px; margin: -2rem auto 0; padding: 0 1.25rem; }
.suites-gallery__item { border-radius: 14px; overflow: hidden; background: #111; color: #eee; }
.suites-gallery__item img { width: 100%; height: 100%; max-height: 360px; object-fit: cover; display: block; }
.suites-gallery__item figcaption { padding: .75rem 1rem; font-size: .95rem; opacity: .9; }

/* Amenities */
.amenities-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem 1.25rem; margin-top: 1rem; }
.amenities-list li { background: rgba(244,239,231,0.06); border: 1px solid rgba(212,175,55,0.25); padding: .9rem 1rem; border-radius: 12px; }

/* Packages */
.packages-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.package-card { background: linear-gradient(180deg, rgba(12,12,16,.85), rgba(12,12,16,.7)); color: #f6f6f6; border: 1px solid rgba(212,175,55,.25); border-radius: 14px; padding: 1.25rem; backdrop-filter: blur(6px); }
.package-card .price { color: var(--hb-gold); font-weight: 600; }

/* Virtual tour */
.virtual-tour__wrap { display: grid; grid-template-columns: 1.2fr .8fr; gap: 1rem; align-items: center; }
.virtual-tour__poster { width: 100%; height: 100%; max-height: 360px; object-fit: cover; border-radius: 14px; }
.virtual-tour__cta { display: flex; flex-direction: column; gap: .75rem; }

/* Reviews */
.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.review { background: #101014; color: #eee; border: 1px solid rgba(201,138,43,.25); border-radius: 12px; padding: 1rem; }
.review footer { display: flex; justify-content: space-between; align-items: center; margin-top: .5rem; font-size: .95rem; }
.rating { color: var(--hb-gold); letter-spacing: .1em; }

/* Offers */
.offers { display: grid; gap: .75rem; }
.offers li { display: flex; justify-content: space-between; align-items: center; gap: 1rem; background: rgba(244,239,231,0.05); border: 1px solid rgba(212,175,55,0.2); border-radius: 12px; padding: .9rem 1rem; }

/* Visual */
.suites-visual { margin: 0; }
.suites-visual img { width: 100%; height: auto; border-radius: 14px; }
.suites-visual figcaption { font-size: .95rem; opacity: .9; padding-top: .5rem; }

/* Forms */
.form-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; align-items: end; }
.form-field { display: grid; gap: .4rem; }
.form-field--full { grid-column: 1 / -1; }
.form-actions { display: flex; gap: .75rem; align-items: center; }
.status { margin-top: .5rem; min-height: 1.25rem; color: var(--hb-amber); }
.availability-results { margin-top: 1rem; display: grid; gap: .75rem; }
.availability-results .result-card { border: 1px solid rgba(212,175,55,.25); border-radius: 12px; padding: .9rem 1rem; background: rgba(16,16,20,.8); color:#f2f2f2; display: grid; gap: .25rem; }

/* Dialog */
dialog { border: none; border-radius: 16px; padding: 0; max-width: 720px; width: min(92vw, 720px); background: #121218; color: #fff; }
dialog::backdrop { background: rgba(0,0,0,.6); backdrop-filter: blur(2px); }
.dialog__body { padding: 1rem; display: grid; gap: .75rem; }
.dialog__actions { display: flex; gap: .75rem; justify-content: flex-end; }

/* Crosslinks */
.crosslinks { display: flex; flex-wrap: wrap; gap: .5rem; }
.chip { display: inline-flex; align-items: center; padding: .45rem .8rem; border-radius: 999px; border: 1px solid rgba(212,175,55,.35); color: inherit; text-decoration: none; background: rgba(244,239,231,0.04); }

/* Buttons (lean overrides to match opulent palette) */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .7rem 1rem; border-radius: 10px; text-decoration: none; cursor: pointer; transition: transform .2s ease, background .2s ease, color .2s ease; }
.btn-primary { background: linear-gradient(180deg, var(--hb-gold), #b8902d); color: #0c0c10; border: 1px solid #a88327; font-weight: 700; }
.btn-primary:hover { transform: translateY(-1px); }
.btn-secondary { background: #15151c; color: #fff; border: 1px solid rgba(212,175,55,.4); }
.btn-outline { background: transparent; color: var(--hb-gold); border: 1px solid var(--hb-gold); }
.btn-link { background: transparent; color: var(--hb-gold); text-decoration: underline; border: none; padding: .25rem .5rem; }

/* Responsive */
@media (max-width: 1024px) {
  .packages-grid { grid-template-columns: repeat(2, 1fr); }
  .reviews { grid-template-columns: repeat(2, 1fr); }
  .form-grid { grid-template-columns: repeat(2, 1fr); }
  .virtual-tour__wrap { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .suites-gallery__wrap { grid-template-columns: 1fr; margin-top: 0; }
  .packages-grid, .reviews { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .offers li { flex-direction: column; align-items: flex-start; }
}
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
