/* Emily's Enchanted Oasis — Styles */
:root{
  --bg:#0c0c0e;
  --bg-alt:#121216;
  --ink:#e9e6df;
  --muted:#b6b0a1;
  --gold:#c9a349;
  --gold-bright:#e3bf5a;
  --card:#15151b;
  --accent: #a07d2f;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;line-height:1.5}

img{max-width:100%;display:block}

.section{padding:64px 20px;max-width:1100px;margin:0 auto}
.section h2{font-size:clamp(1.6rem,2.5vw,2rem);margin:0 0 18px;color:var(--gold)}
.section.alt{background:linear-gradient(180deg,var(--bg),var(--bg-alt));border-top:1px solid #1b1b22;border-bottom:1px solid #1b1b22}

/* Header */
.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:rgba(12,12,14,.7);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid #1b1b22}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand img{width:44px;height:44px;object-fit:cover;border-radius:6px;box-shadow:var(--shadow)}
.brand-text{font-weight:700;letter-spacing:.3px}

/* Nav */
.nav{display:flex;gap:18px;align-items:center}
.nav a{color:var(--muted);text-decoration:none;font-size:.95rem;padding:8px 10px;border-radius:8px}
.nav a:hover{color:var(--ink);background:#1b1b22}
.cta-link{color:#0b0b0b;background:linear-gradient(180deg,var(--gold),var(--gold-bright));padding:8px 14px;border-radius:999px;font-weight:700}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:transparent;border:0;cursor:pointer}
.hamburger span{width:26px;height:2px;background:var(--ink);display:block}

/* Mobile nav */
@media (max-width: 880px){
  .hamburger{display:flex}
  .nav{position:fixed;inset:64px 12px auto 12px;background:#0e0e12;border:1px solid #1b1b22;border-radius:14px;padding:10px;flex-direction:column;align-items:stretch;transform:translateY(-16px) scale(.98);opacity:0;pointer-events:none;transition:.25s ease;box-shadow:var(--shadow)}
  .nav.open{opacity:1;transform:none;pointer-events:auto}
  .nav a{padding:12px 12px;font-size:1rem}
}

/* Hero */
.hero{min-height:68vh;display:grid;place-items:center;padding:64px 20px;background:
  radial-gradient(80% 60% at 50% 40%, rgba(201,163,73,.25), transparent 60%),
  linear-gradient(180deg, #0c0c0e, #0d0d11)}
.hero-content{max-width:880px;text-align:center}
.hero h1{font-size:clamp(2rem,5vw,3rem);margin:0 0 8px;color:var(--ink);text-shadow:0 4px 32px rgba(227,191,90,.25)}
.hero p{color:var(--muted);margin:0 0 18px}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

.btn{display:inline-block;padding:12px 18px;border-radius:12px;text-decoration:none;font-weight:700;border:1px solid #2a2a31}
.btn-primary{background:linear-gradient(180deg,var(--gold),var(--gold-bright));color:#0b0b0b;border:none}
.btn-ghost{background:transparent;color:var(--ink)}
.btn:hover{transform:translateY(-1px)}

.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.card{background:var(--card);padding:18px;border-radius:14px;border:1px solid #1b1b22;box-shadow:var(--shadow)}
.card h3{color:var(--gold);margin:.2rem 0 .6rem}

@media (max-width: 900px){
  .cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
}

.rates{max-width:560px;margin:0 auto;border:1px solid #1b1b22;border-radius:14px;overflow:hidden}
.rate-row{display:flex;justify-content:space-between;gap:12px;padding:14px 16px;background:#101015}
.rate-row:nth-child(odd){background:#0f0f14}
.fine-print{color:#8a867c;font-size:.9rem;margin-top:8px}

/* Gallery */

.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
}
.frame{border:1px solid #1b1b22;border-radius:14px;overflow:hidden;background:#0e0e13}
.frame img{aspect-ratio:4/3;object-fit:cover;opacity:.95}
.placeholder{display:grid;place-items:center}
.placeholder .ph{color:var(--muted);padding:40px 10px}
@media (max-width: 780px){
  
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
}
}

/* Etiquette & Reviews */
.etiquette{max-width:720px;margin:0 auto;color:var(--muted);display:grid;gap:8px}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.reviews blockquote{background:var(--card);border:1px solid #1b1b22;border-radius:14px;padding:16px;margin:0}
.reviews .stars{color:var(--gold);margin-bottom:6px}
.reviews cite{color:#9a9587;font-style:normal}
@media (max-width: 900px){
  .reviews{grid-template-columns:1fr 1fr}
}
@media (max-width: 560px){
  .reviews{grid-template-columns:1fr}
}

/* Booking */
.booking-form{max-width:820px;margin:0 auto}
.booking-form .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}
.booking-form label{display:grid;gap:6px;color:var(--muted);font-size:.95rem}
.booking-form input, .booking-form select, .booking-form textarea{
  padding:12px;border-radius:10px;border:1px solid #2a2a31;background:#111116;color:var(--ink)
}
.booking-form button{margin-top:8px}

/* Contact */
.contact-cards{display:flex;gap:12px;flex-wrap:wrap}
.contact-card{display:inline-flex;gap:8px;align-items:center;padding:12px 14px;border:1px solid #1b1b22;border-radius:12px;background:#111116;color:var(--ink);text-decoration:none}
.contact-card:hover{border-color:#2b2b33}

/* Footer */
.site-footer{padding:24px 16px;text-align:center;color:#8a867c;border-top:1px solid #1b1b22;background:#0b0b0e}

/* Floating CTA */
.floating-cta{position:fixed;right:16px;bottom:16px;padding:12px 16px;border-radius:999px;background:linear-gradient(180deg,var(--gold),var(--gold-bright));color:#0b0b0b;text-decoration:none;font-weight:800;box-shadow:var(--shadow);border:none}


/* --- Rates list styles --- */
.rate-list { list-style: none; padding: 0; margin: 1rem 0; max-width: 540px; }
.rate-list li { display: flex; justify-content: space-between; align-items: center; padding: 0.75rem 1rem; border-bottom: 1px solid rgba(0,0,0,0.08); }
.rate-list li span { font-weight: 500; }
.rate-list li strong { font-weight: 700; }
.note { font-size: 0.95rem; opacity: 0.8; margin-top: 0.5rem; }


/* === Homepage hero background === */
#home.hero {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  text-align: center;
  color: #fff;
  background-image: url("assets/home-bg.jpg");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
#home.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.35));
}
#home.hero > * {
  position: relative;
  z-index: 1;
}
@media (max-width: 768px) {
  #home.hero { min-height: 90vh; }
}


/* Responsive styles for mobile devices (360x640 to 414x896) */
@media (max-width: 414px) {
  body {
    font-size: 16px;
    padding: 10px;
  }

  
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
}

  .frame img {
    width: 100%;
    height: auto;
    border-radius: 6px;
  }

  .contact-cards, .reviews, .booking-form .grid {
    flex-direction: column;
    display: flex;
    gap: 12px;
  }

  header .brand-text {
    font-size: 16px;
  }

  .cta-row {
    flex-direction: column;
    gap: 12px;
  }

  .nav a {
    font-size: 14px;
    padding: 10px;
  }
}


.booking-form {
  background-color: #fff;
  padding: 2em;
  border-radius: 10px;
  box-shadow: 0 0 12px rgba(0,0,0,0.1);
  max-width: 600px;
  margin: 0 auto;
}

.booking-form h2 {
  font-size: 1.8em;
  margin-bottom: 0.5em;
  text-align: center;
}

.booking-form .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1em;
}

.booking-form label {
  display: block;
  font-weight: 600;
}

.booking-form input,
.booking-form select,
.booking-form textarea {
  width: 100%;
  padding: 0.75em;
  margin-top: 0.25em;
  margin-bottom: 0.5em;
  border-radius: 5px;
  border: 1px solid #ccc;
  font-size: 1em;
}

.booking-form textarea {
  resize: vertical;
}

.booking-form button {
  display: block;
  width: 100%;
  padding: 0.75em;
  font-size: 1.1em;
  background-color: #d14f8b;
  color: white;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.booking-form button:hover {
  background-color: #b13f75;
}
