/* ============================================================
   azure_lodge — Dark Luxury Hotel Template
   Palette: Navy #06091a · Navy-2 #0d1430 · Gold #ca8a04
            Gold-lt #d97706 · Cream #f5f0e8
   Fonts:   Cormorant Garamond · Inter
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --clr-navy:     #06091a;
  --clr-navy-2:   #0d1430;
  --clr-navy-3:   #141e40;
  --clr-gold:     #ca8a04;
  --clr-gold-lt:  #d97706;
  --clr-gold-px:  #f59e0b;
  --clr-cream:    #f5f0e8;
  --clr-text:     #e8e4d9;
  --clr-muted:    #8a8fa0;
  --clr-border:   rgba(202,138,4,.2);
  --ff-serif:     'Cormorant Garamond', Georgia, serif;
  --ff-sans:      'Inter', system-ui, sans-serif;
  --radius:       .75rem;
  --shadow-md:    0 8px 32px rgba(0,0,0,.4);
  --shadow-lg:    0 20px 64px rgba(0,0,0,.6);
  --transition:   .3s ease;
  --max-w:        1200px;
  --header-h:     80px;
}

html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--ff-sans);
  background: var(--clr-navy);
  color: var(--clr-text);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

/* ---- Utility ---- */
.az-container { max-width: var(--max-w); margin-inline: auto; padding-inline: 1.5rem; }
.az-label { font-size: .7rem; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: .75rem; display: block; }
.az-section-title { font-family: var(--ff-serif); font-size: clamp(2rem, 4.5vw, 3.5rem); font-weight: 300; line-height: 1.15; color: var(--clr-cream); margin-bottom: 2.5rem; }
.az-section-title em { font-style: italic; color: var(--clr-gold); }
.az-section { padding: 6rem 0; }

/* ---- Buttons ---- */
.az-btn {
  display: inline-flex; align-items: center;
  padding: .75rem 2rem; border-radius: .25rem;
  font-family: var(--ff-sans); font-size: .82rem; font-weight: 500;
  letter-spacing: .1em; text-transform: uppercase; text-decoration: none;
  cursor: pointer; border: 1px solid transparent;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform .15s;
}
.az-btn:hover { transform: translateY(-2px); }
.az-btn--gold { background: var(--clr-gold); color: var(--clr-navy); border-color: var(--clr-gold); font-weight: 600; }
.az-btn--gold:hover { background: var(--clr-gold-lt); border-color: var(--clr-gold-lt); }
.az-btn--outline { border-color: rgba(202,138,4,.5); color: var(--clr-cream); background: transparent; }
.az-btn--outline:hover { border-color: var(--clr-gold); color: var(--clr-gold); }
.az-btn--gold-sm { padding: .5rem 1.25rem; font-size: .78rem; background: transparent; border-color: var(--clr-gold); color: var(--clr-gold); }
.az-btn--gold-sm:hover { background: var(--clr-gold); color: var(--clr-navy); }
.az-btn--wide { width: 100%; justify-content: center; }

/* ---- Reveal ---- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }
.reveal--d1 { transition-delay: .12s; }
.reveal--d2 { transition-delay: .24s; }

/* ========== HEADER ========== */
.az-header {
  position: fixed; inset-block-start: 0; inset-inline: 0; z-index: 100;
  height: var(--header-h);
  background: rgba(6,9,26,.9); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--clr-border);
  transition: box-shadow var(--transition);
}
.az-header.scrolled { box-shadow: 0 4px 30px rgba(0,0,0,.5); }
.az-header__inner { height: var(--header-h); display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.az-logo { font-family: var(--ff-serif); font-size: 1.2rem; font-weight: 300; color: var(--clr-cream); text-decoration: none; letter-spacing: .2em; text-transform: uppercase; }
.az-logo em { font-style: italic; color: var(--clr-gold); }
.az-logo__icon { color: var(--clr-gold); font-size: .9rem; }
.az-nav ul { display: flex; gap: 2.5rem; list-style: none; }
.az-nav a { font-size: .78rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; color: var(--clr-muted); text-decoration: none; transition: color var(--transition); }
.az-nav a:hover { color: var(--clr-gold); }
.az-burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.az-burger span { display: block; width: 22px; height: 1px; background: var(--clr-cream); transition: var(--transition); }

/* ========== DRAWER ========== */
.az-drawer {
  position: fixed; inset-block-start: var(--header-h); inset-inline-start: 0; inset-block-end: 0;
  width: 78%; max-width: 300px; background: var(--clr-navy-2);
  border-right: 1px solid var(--clr-border); z-index: 99;
  transform: translateX(-100%); transition: transform .3s cubic-bezier(.4,0,.2,1);
  padding: 2rem 1.5rem;
}
.az-drawer.open { transform: none; }
.az-drawer ul { list-style: none; display: flex; flex-direction: column; gap: .25rem; }
.az-drawer__link { display: block; padding: .9rem .5rem; font-size: .9rem; font-weight: 400; letter-spacing: .08em; text-transform: uppercase; color: var(--clr-text); text-decoration: none; border-bottom: 1px solid var(--clr-border); transition: color var(--transition); }
.az-drawer__link:hover { color: var(--clr-gold); }
.az-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.65); z-index: 98; display: none; }
.az-backdrop.show { display: block; }

/* ========== HERO ========== */
.az-hero {
  min-height: 100svh; position: relative; display: flex; align-items: center;
  padding-top: var(--header-h); overflow: hidden;
}
.az-hero__overlay {
  position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(ellipse at 30% 60%, rgba(15,30,80,.7) 0%, transparent 60%),
              linear-gradient(180deg, rgba(6,9,26,.85) 0%, rgba(6,9,26,.65) 40%, rgba(6,9,26,.95) 100%);
  background-color: var(--clr-navy);
}
.az-hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: center; padding-block: 5rem; }
.az-hero__pre { font-size: .72rem; font-weight: 400; letter-spacing: .2em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: 1.5rem; }
.az-hero__title { font-family: var(--ff-serif); font-size: clamp(3rem, 6vw, 5rem); font-weight: 300; line-height: 1.05; color: var(--clr-cream); margin-bottom: 1.5rem; }
.az-hero__title em { font-style: italic; color: var(--clr-gold); }
.az-hero__sub { font-size: 1rem; font-weight: 300; color: var(--clr-muted); max-width: 50ch; margin-bottom: 2.5rem; }
.az-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; }

/* Quick booking widget */
.az-hero__booking {
  background: rgba(13,20,48,.9); border: 1px solid var(--clr-border);
  border-radius: var(--radius); padding: 2rem; backdrop-filter: blur(16px);
}
.az-booking__label { font-size: .72rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: 1.25rem; }
.az-booking-form { display: flex; flex-direction: column; gap: 1rem; }
.az-booking-form__group { display: flex; flex-direction: column; gap: .35rem; }
.az-booking-form__group label { font-size: .72rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--clr-muted); }
.az-booking-form__group input,
.az-booking-form__group select {
  padding: .7rem 1rem; border: 1px solid var(--clr-border); border-radius: .35rem;
  background: rgba(6,9,26,.7); font-family: var(--ff-sans); font-size: .85rem;
  color: var(--clr-text); outline: none; transition: border-color var(--transition);
}
.az-booking-form__group input:focus,
.az-booking-form__group select:focus { border-color: var(--clr-gold); }
.az-booking-form__group select option { background: var(--clr-navy-2); }

/* Scroll indicator */
.az-hero__scroll {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem; z-index: 1;
  font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--clr-muted);
}
.az-scroll-line { display: block; width: 1px; height: 40px; background: linear-gradient(to bottom, transparent, var(--clr-gold)); animation: az-scroll-pulse 2s ease-in-out infinite; }
@keyframes az-scroll-pulse { 0%,100% { opacity: .4; } 50% { opacity: 1; } }

/* ========== ROOMS ========== */
.az-rooms { background: var(--clr-navy-2); }
.az-rooms-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.az-room { background: var(--clr-navy-3); border: 1px solid var(--clr-border); border-radius: var(--radius); overflow: hidden; transition: transform var(--transition), box-shadow var(--transition); }
.az-room:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.az-room__img { aspect-ratio: 4/3; position: relative; overflow: hidden; }
.az-room__img--1 { background: linear-gradient(135deg, #0d2040, #1a4070 50%, #205080); }
.az-room__img--2 { background: linear-gradient(135deg, #1a1000, #3d2808 50%, #6b4010); }
.az-room__img--3 { background: linear-gradient(135deg, #081a10, #143820 50%, #1e5030); }
.az-room__view {
  position: absolute; top: 1rem; left: 1rem;
  padding: .3rem .9rem; background: rgba(202,138,4,.2); border: 1px solid var(--clr-gold);
  border-radius: 2rem; font-size: .7rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--clr-gold);
}
.az-view--pool { background: rgba(13,100,150,.3); border-color: #60c7e8; color: #60c7e8; }
.az-view--garden { background: rgba(20,120,60,.3); border-color: #4ade80; color: #4ade80; }
.az-room__body { padding: 1.75rem; }
.az-room__body h3 { font-family: var(--ff-serif); font-size: 1.3rem; font-weight: 400; color: var(--clr-cream); margin-bottom: .35rem; }
.az-room__size { font-size: .78rem; color: var(--clr-gold); font-weight: 500; margin-bottom: .75rem; }
.az-room__body p { font-size: .875rem; color: var(--clr-muted); margin-bottom: 1.25rem; }
.az-room__amenities { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: .4rem .75rem; font-size: .78rem; color: var(--clr-muted); margin-bottom: 1.25rem; }
.az-room__footer { display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--clr-border); padding-top: 1.25rem; }
.az-room__price { font-size: .85rem; color: var(--clr-muted); }
.az-room__price strong { font-family: var(--ff-serif); font-size: 1.3rem; font-weight: 400; color: var(--clr-cream); }

/* ========== AMENITIES ========== */
.az-amenities { background: var(--clr-navy); }
.az-amen-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.75rem; }
.az-amen { padding: 2rem; border: 1px solid var(--clr-border); border-radius: var(--radius); transition: border-color var(--transition), transform var(--transition), background var(--transition); }
.az-amen:hover { border-color: var(--clr-gold); transform: translateY(-4px); background: var(--clr-navy-2); }
.az-amen__icon { font-size: 2rem; margin-bottom: 1rem; }
.az-amen h3 { font-family: var(--ff-serif); font-size: 1.25rem; font-weight: 400; color: var(--clr-cream); margin-bottom: .6rem; }
.az-amen p { font-size: .875rem; color: var(--clr-muted); }

/* ========== GALLERY ========== */
.az-gallery { background: var(--clr-navy-2); }
.az-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 240px 240px;
  gap: 1rem;
  margin-top: .5rem;
}
.az-gal {
  border-radius: .5rem; overflow: hidden; cursor: pointer;
  transition: transform var(--transition), filter var(--transition);
  position: relative;
}
.az-gal:hover { transform: scale(1.02); filter: brightness(1.1); }
.az-gal--wide { grid-column: span 2; }
.az-gal--1 { background: linear-gradient(135deg, #0a1a40, #083a6a); }
.az-gal--2 { background: linear-gradient(135deg, #1a0d00, #5a3010); }
.az-gal--3 { background: linear-gradient(135deg, #041018, #083050); }
.az-gal--4 { background: linear-gradient(135deg, #100a1a, #3d2080); }
.az-gal--5 { background: linear-gradient(135deg, #041a0c, #082a18); }
.az-gal--6 { background: linear-gradient(135deg, #0a1a30, #102850); }
.az-gal::after {
  content: '+ View'; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: var(--clr-cream); font-size: .78rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
  background: rgba(202,138,4,.15); opacity: 0; transition: opacity var(--transition);
}
.az-gal:hover::after { opacity: 1; }

/* ========== BOOKING ========== */
.az-booking { background: var(--clr-navy-3); }
.az-booking__inner { display: grid; grid-template-columns: 1fr 1.3fr; gap: 5rem; align-items: start; }
.az-booking__info p { color: var(--clr-muted); max-width: 46ch; margin-bottom: 2rem; }
.az-booking__perks { list-style: none; display: flex; flex-direction: column; gap: .6rem; margin-bottom: 2rem; }
.az-booking__perks li { font-size: .875rem; color: var(--clr-cream); }
.az-booking__perks li::first-letter { color: var(--clr-gold); }
.az-booking__contact { display: flex; flex-direction: column; gap: .5rem; }
.az-booking__contact p { font-size: .9rem; color: var(--clr-muted); }
.az-form { display: flex; flex-direction: column; gap: 1.25rem; }
.az-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.az-form__group { display: flex; flex-direction: column; gap: .4rem; }
.az-form__group label { font-size: .7rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--clr-muted); }
.az-form__group input,
.az-form__group select,
.az-form__group textarea {
  padding: .75rem 1rem; border: 1px solid var(--clr-border); border-radius: .35rem;
  background: rgba(6,9,26,.7); font-family: var(--ff-sans); font-size: .9rem;
  color: var(--clr-text); outline: none; transition: border-color var(--transition); resize: vertical;
}
.az-form__group input:focus,
.az-form__group select:focus,
.az-form__group textarea:focus { border-color: var(--clr-gold); }
.az-form__group select option { background: var(--clr-navy-2); }
.az-form__ok { text-align: center; font-size: .875rem; font-weight: 500; color: var(--clr-gold); min-height: 1.5em; }

/* ========== FOOTER ========== */
.az-footer { background: var(--clr-navy); border-top: 1px solid var(--clr-border); padding: 3rem 0; }
.az-footer__inner { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 2rem; align-items: flex-start; }
.az-footer__copy { font-size: .8rem; color: var(--clr-muted); margin-top: .5rem; }
.az-footer__cols { display: flex; gap: 4rem; }
.az-footer__cols h4 { font-size: .7rem; font-weight: 500; letter-spacing: .16em; text-transform: uppercase; color: var(--clr-gold); margin-bottom: 1rem; }
.az-footer__cols ul { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.az-footer__cols a { font-size: .85rem; color: var(--clr-muted); text-decoration: none; transition: color var(--transition); }
.az-footer__cols a:hover { color: var(--clr-gold); }

/* ========== LIGHTBOX ========== */
.az-lightbox {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.92); align-items: center; justify-content: center; flex-direction: column; gap: 1rem;
}
.az-lightbox.open { display: flex; }
.az-lightbox__close {
  position: absolute; top: 1.5rem; right: 1.5rem; background: none; border: none;
  color: var(--clr-cream); font-size: 1.5rem; cursor: pointer; opacity: .7; transition: opacity var(--transition);
}
.az-lightbox__close:hover { opacity: 1; }
.az-lightbox__img { width: 80vw; max-width: 900px; aspect-ratio: 16/9; border-radius: .5rem; }
.az-lightbox__caption { font-size: .85rem; color: var(--clr-muted); font-style: italic; }

/* ========== RESPONSIVE ========== */
@media (max-width: 1024px) {
  .az-hero__inner { grid-template-columns: 1fr; }
  .az-hero__booking { max-width: 480px; }
  .az-rooms-grid { grid-template-columns: 1fr; }
  .az-amen-grid { grid-template-columns: repeat(2, 1fr); }
  .az-booking__inner { grid-template-columns: 1fr; gap: 3rem; }
  .az-gallery-grid { grid-template-columns: repeat(2, 1fr); grid-template-rows: auto; }
  .az-gal--wide { grid-column: span 2; aspect-ratio: 21/9; }
}
@media (max-width: 768px) {
  .az-nav, .az-header .az-btn { display: none; }
  .az-burger { display: flex; }
  .az-amen-grid { grid-template-columns: 1fr; }
  .az-form__row { grid-template-columns: 1fr; }
  .az-footer__cols { flex-direction: column; gap: 1.5rem; }
  .az-footer__inner { flex-direction: column; }
  .az-rooms-grid { grid-template-columns: 1fr; }
  .az-gallery-grid { grid-template-columns: 1fr; }
  .az-gal--wide { grid-column: span 1; }
}
