/* Home page enhancements for Welcome2025Hotel. Builds on base.css without duplicating foundations. */
:root {
  --neon-purple: #6c2bd9;
  --neon-blue: #00d1ff;
  --charcoal: #0f1220;
  --soft-cyan: #7de3f4;
  --magenta: #ff2aad;
}

/* Hero */
.hero {
  position: relative;
  min-height: clamp(540px, 70vh, 860px);
  display: grid;
  place-items: center;
  color: #fff;
  background: radial-gradient(1200px 600px at 75% 20%, rgba(0,209,255,0.28), transparent 60%),
              radial-gradient(1200px 600px at 25% 80%, rgba(255,42,173,0.25), transparent 60%),
              linear-gradient(180deg, rgba(15,18,32,0.7), rgba(15,18,32,0.95));
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url('/assets/images/virtual-tour.webp');
  background-size: cover;
  background-position: center;
  filter: saturate(1.2) brightness(0.7);
  z-index: -2;
}
.hero__overlay { display:none; }
.hero__content { text-align: center; max-width: 900px; }
.hero .eyebrow { letter-spacing: .12em; text-transform: uppercase; opacity: .9; }
.hero .lead { margin-block: 1rem 1.5rem; font-size: clamp(1.05rem, 1.2vw + .9rem, 1.35rem); opacity:.95; }
.hero__actions { display: inline-flex; gap: .75rem; flex-wrap: wrap; justify-content: center; }

/* Sections */
.section { padding-block: clamp(2.5rem, 6vw, 5rem);  }
.section:nth-of-type(odd) {    background: linear-gradient(180deg, rgba(122, 44, 255, .08), rgba(0, 183, 255, .06)); }
.section--nightlife { background: linear-gradient(180deg, #0f1220 0%, #131735 100%); color: #eef5ff; }

/* Grids and media */
.grid { display: grid; gap: clamp(1rem, 2.5vw, 2rem); align-items: center; }
.grid--2cols { grid-template-columns: 1fr; }
.grid--reverse { direction: rtl; }
.grid--reverse > * { direction: ltr; }
@media (min-width: 900px) { .grid--2cols { grid-template-columns: 1.05fr 0.95fr; } }
.media-wrap { position: relative; }
.media-wrap img { width: 100%; height: auto; border-radius: 14px; box-shadow: 0 20px 50px rgba(0,0,0,.25); }

/* Lists */
.list { margin: 0 0 1rem 0; padding: 0; list-style: none; }
.list--bullets li { list-style: disc; margin-left: 1.25rem; }
.list--check li { position: relative; padding-left: 1.75rem; margin: .4rem 0; }
.list--check li::before { content: ""; position: absolute; left: 0; top: .45em; width: 1rem; height: 1rem; border-radius: 4px; background: linear-gradient(135deg, var(--neon-purple), var(--neon-blue)); box-shadow: 0 0 0 2px rgba(255,255,255,.65) inset; }

/* Cards */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; }
.card {  border: 1px solid rgba(12,16,28,.08); border-radius: 14px; padding: 1.25rem; box-shadow: 0 10px 24px rgba(10,14,25,.06); }
.section--nightlife .card { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); }

/* Buttons & links - build on base, add gradients */
.btn-primary { background: linear-gradient(135deg, var(--neon-purple), var(--magenta)); color: #fff!important; }
.btn-secondary { background: linear-gradient(135deg, var(--neon-blue), var(--soft-cyan)); color: #081018; }
.btn-ghost { background: transparent; border: 1px solid #fff; color: #fff; }
.section--nightlife .btn-ghost { color: #eef5ff; border-color: rgba(255,255,255,.35); }
.btn:hover { transform: translateY(-1px); }

/* Forms */
.form { background: #0f1220; color: #eaf2ff; border-radius: 14px; padding: 1.25rem; box-shadow: 0 18px 40px rgba(10,14,25,.25); }
.form h3 { margin-top: 0; }
.form-row { display: grid; gap: .35rem; margin-bottom: .9rem; }
.form-row--inline { grid-template-columns: auto 1fr; align-items: start; gap: .6rem; }
.form input[type="text"], .form input[type="email"], .form textarea { background: #141a2e; color: #eaf2ff; border: 1px solid #2a335a; border-radius: 10px; padding: .7rem .85rem; }
.form input:focus, .form textarea:focus { outline: 2px solid var(--neon-blue); box-shadow: 0 0 0 3px rgba(0,209,255,.25); }
.form-note { font-size: .9rem; opacity: .85; }

/* Inline CTA group */
.cta-inline { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.stack-sm { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }

/* Accessibility tweaks */
:focus-visible { outline: 3px solid var(--neon-blue); outline-offset: 2px; }

/* Nightlife section text contrast */
.section--nightlife p { opacity: .95; max-width: 70ch; }

/* Utilities */
.eyebrow { font-size: .8rem; opacity: .8; }
.lead {  margin-inline: auto; }

/* Container utility fallback if not in base */
.container { width: min(1120px, 92vw); margin-inline: auto; }
