/* Palm Luxury Spa — styles.css */
:root{
  --bg:#fff;
  --primary:#8ac9a8;
  --accent:#5aa07d;
  --muted:#6b7280;
  --max-width:1100px;
  --radius:12px;
}
*{box-sizing:border-box}
body{font-family:Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial; margin:0; color:#111; background:linear-gradient(180deg,#f8faf9,#fff)}
.container{max-width:var(--max-width); margin:0 auto; padding:2rem;}
.site-header{background:rgba(255,255,255,0.9); backdrop-filter: blur(6px); position:sticky; top:0; z-index:40; border-bottom:1px solid #eee}
.header-inner{display:flex; gap:1rem; align-items:center; justify-content:space-between}
.logo img{height:54px}
.nav{display:flex; gap:1rem; align-items:center}
.nav a{color:#111; text-decoration:none; padding:0.5rem 0.75rem; border-radius:8px}
.nav .call-btn{background:var(--primary); color:#fff}
.nav-toggle{display:none; background:none; border:0; font-size:1.6rem}

.hero{padding:4rem 0;}
.hero-inner{display:grid; grid-template-columns:1fr 520px; gap:2rem; align-items:center}
.hero-text h1{margin:0; font-size:2.25rem}
.tagline{color:var(--muted); margin-top:.5rem}
.lead{margin-top:1rem; color:var(--muted)}
.hero-ctas{margin-top:1.25rem; display:flex; gap:1rem}
.btn{padding:.75rem 1.25rem; border-radius:10px; text-decoration:none; display:inline-block}
.btn.primary{background:var(--accent); color:#fff}
.btn.outline{border:1px solid #ddd; color:#111}
.quick-info{list-style:none; padding:0; margin-top:1rem; color:var(--muted)}
.hero-media img{width:100%; border-radius:16px; box-shadow:0 10px 30px rgba(0,0,0,0.08)}

.services{padding:3rem 0}
.service-grid{display:grid; gap:1rem; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); margin-top:1.25rem}
.service{padding:1rem; border-radius:12px; background:linear-gradient(180deg,#fff,#f7f9f9); box-shadow:0 6px 20px rgba(12,20,27,0.04)}

.gallery{padding:3rem 0}
.gallery-grid{display:grid; gap:10px; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); margin-top:1rem}
.gallery-item{display:block; overflow:hidden; border-radius:10px}
.gallery-item img{width:100%; height:180px; object-fit:cover; transition:transform .28s ease}
.gallery-item:hover img{transform:scale(1.04)}

.contact{padding:3rem 0}
.contact-inner{display:grid; grid-template-columns:1fr 430px; gap:1.5rem; align-items:start}
.contact-card{padding:1.25rem; border-radius:12px; background:#fff; box-shadow:0 6px 20px rgba(12,20,27,0.06)}
.contact-actions{display:flex; gap:.75rem; margin-top:1rem}
.map-card iframe{width:100%; height:100%; min-height:320px; border:0; border-radius:12px}

/* Contact form styles */
.contact-form{margin-top:1rem; display:block}
.contact-form label{display:block; margin-bottom:.6rem; font-size:.95rem}
.contact-form input,.contact-form textarea{width:100%; padding:.65rem .75rem; border:1px solid #e6e6e6; border-radius:8px; margin-top:.35rem}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid rgba(138,201,168,0.22); border-color:var(--primary)}

/* Small nav tweak for mobile */
@media (max-width:920px){
  .nav{flex-direction:column; background:#fff; padding:1rem; border-radius:10px; box-shadow:0 8px 30px rgba(12,20,27,0.06)}
}

.site-footer{border-top:1px solid #eee; padding:1.25rem 0; background:transparent}
.footer-inner{display:flex; justify-content:space-between; gap:2rem; align-items:center}
.footer-logo{height:44px}

/* Lightbox */
.lightbox{position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,0.7); z-index:1000}
.lightbox img{max-width:90%; max-height:70vh; border-radius:8px}
.lightbox .caption{color:#fff; margin-top:.75rem}
.lightbox .close{position:absolute; right:24px; top:24px; border:0; background:transparent; color:#fff; font-size:1.6rem}
.lightbox.open{display:flex}

/* Responsive */
@media (max-width:920px){
  .hero-inner{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr}
  .header-inner{align-items:center}
  .nav{display:none}
  .nav-toggle{display:block}
}

@media (max-width:420px){
  .container{padding:1rem}
  .hero-text h1{font-size:1.6rem}
}
