/* Bianca Wellness Haven — Styles */
:root{
  --bg:#0f0f11;
  --panel:#15161a;
  --ink:#f3efe7;
  --muted:#c8c3b6;
  --brand:#f2c791; /* soft gold-peach */
  --brand-2:#e6a3ad; /* blush */
  --accent:#89c5b6;  /* sage */
  --shadow:rgba(0,0,0,.25);
  --radius:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;scroll-behavior:smooth}
h1,h2,h3{font-family:"Playfair Display",serif;line-height:1.15;margin:0 0 .5rem}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.2vw,2.2rem)}
h3{font-size:1.15rem;letter-spacing:.2px}
p{line-height:1.7;color:var(--muted)}
.container{width:min(1100px,92%);margin-inline:auto}
.btn{display:inline-block;padding:.9rem 1.2rem;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#121212;text-decoration:none;font-weight:600;border:none;cursor:pointer;box-shadow:0 6px 18px var(--shadow)}
.btn:hover{transform:translateY(-1px)}
.btn.small{padding:.6rem 1rem;font-size:.9rem}
.btn.outline{background:transparent;border:1px solid var(--brand);color:var(--ink)}
.btn.outline:hover{background:rgba(242,199,145,.1)}

.site-header{position:sticky;top:0;z-index:50;background:rgba(15,15,17,.7);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0}
.brand{display:flex;align-items:center;gap:.6rem;color:var(--ink);text-decoration:none;font-weight:600}
.brand img{width:34px;height:34px}
.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:var(--muted);text-decoration:none;font-weight:500}
.nav a:hover{color:var(--ink)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0}
.hamburger span{display:block;width:24px;height:2px;background:var(--ink)}


.hero{min-height:82vh;display:grid;place-items:center;position:relative;background:transparent}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background:url('assets/hero-beach.jpg') center/cover no-repeat;
  opacity:.35; /* reduce opacity as requested */
  filter:saturate(115%);
  z-index:0;
}
.hero-inner{position:relative;z-index:1;padding:4rem 0;text-align:center}

.hero p{max-width:720px;margin:0 auto 1.4rem}

.section{padding:4.5rem 0}
.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem}
.card{background:var(--panel);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:1.4rem;box-shadow:0 12px 28px var(--shadow)}
.copy p{margin:.3rem 0 1rem}

.ticks{list-style:none;padding:0;margin:1rem 0 0}
.ticks li{padding-left:28px;position:relative;margin:.4rem 0;color:var(--ink)}
.ticks li:before{content:"✓";position:absolute;left:0;top:0;color:var(--brand)}

.services .cards,.etiquette .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.service-card{background:var(--panel);border:1px solid rgba(255,255,255,.06);padding:1.2rem;border-radius:var(--radius);min-height:150px}

.rate-table{background:var(--panel);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:1rem}
.rate-row{display:flex;justify-content:space-between;padding:1rem;border-top:1px dashed rgba(255,255,255,.08)}
.rate-row:first-child{border-top:none}
.rate-row span:last-child{font-weight:700;color:var(--ink)}
.note{padding:1rem;border-radius:12px;background:rgba(242,199,145,.12);border:1px solid rgba(242,199,145,.25);margin-top:1rem;color:var(--ink)}

.gallery .masonry{columns:3 260px;column-gap:14px}
.gallery figure{break-inside:avoid;display:block;overflow:hidden;margin:0 0 14px;}


.gallery .ph{background-image:linear-gradient(135deg, rgba(242,199,145,.15), rgba(230,163,173,.15));}

.form-card .field{display:flex;flex-direction:column;margin:.7rem 0}
.field input,.field select,.field textarea{padding:.9rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0f1013;color:var(--ink);outline:none}
.split{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.status{margin-top:.7rem;min-height:1.2em}

.reviews .quotes{display:grid;gap:1rem}
.reviews blockquote{margin:0;background:var(--panel);border:1px solid rgba(255,255,255,.06);padding:1rem;border-radius:var(--radius);font-style:italic;color:var(--ink)}

.site-footer{border-top:1px solid rgba(255,255,255,.08);padding-top:2rem;margin-top:2rem}
.footer-inner{display:flex;align-items:center;justify-content:space-between}
.legal{border-top:1px dashed rgba(255,255,255,.08);margin-top:1rem;padding:1rem 0}
.center{text-align:center}
.muted{color:var(--muted)}

@media (max-width: 900px){
  .two-col{grid-template-columns:1fr}
  .services .cards,.etiquette .cards{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .hamburger{display:flex}
}
@media (max-width: 540px){
  .services .cards,.etiquette .cards{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
}

.gallery img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 14px;
}


/* Reviews form styles */
#reviews form#reviewForm{
  display:grid;
  gap:12px;
  margin-top:16px;
  max-width:600px
}
#reviews form#reviewForm input,
#reviews form#reviewForm select,
#reviews form#reviewForm textarea{
  padding:12px;
  border:1px solid #ddd;
  border-radius:8px;
  font:inherit
}
#reviews form#reviewForm button{
  padding:12px 16px;
  border:0;
  border-radius:8px;
  cursor:pointer;
}
#reviews .quotes blockquote span{ margin-left:6px; }



/* Floating Contact Buttons */
.floating-contact{
  position:fixed;
  right:16px;
  bottom:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  transform: translateY(30px);
  opacity:0;
  pointer-events:none;
  transition: transform .25s ease, opacity .25s ease;
  z-index:9999;
}
.floating-contact.visible{
  transform: translateY(0);
  opacity:1;
  pointer-events:auto;
}
.fc-btn{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  background:#111;
  color:#fff;
  text-decoration:none;
  box-shadow:0 6px 16px rgba(0,0,0,.25);
  font-weight:600;
  letter-spacing:.2px;
}
.fc-btn svg{ display:block }
.fc-btn.fc-wa{ background:#25D366; color:#001b00 }
.fc-btn.fc-sms{ background:#0ea5e9; }
.fc-btn:hover{ transform: translateY(-2px); }
@media (max-width: 480px){
  .fc-btn span{ display:none; } /* show only icons on small screens */
}



.fc-btn.fc-tg{ background:#0088cc; color:#fff; }



/* ===========================
   THEME POLISH — Bianca Haven
   =========================== */
:root{
  --bg:#0e0f12;            /* deep charcoal */
  --panel:#14171c;         /* card surface */
  --panel-2:#171a20;
  --ink:#ecf0f3;           /* main text */
  --muted:#c4c9d1;         /* secondary text */
  --brand:#e9b872;         /* warm gold */
  --brand-2:#8ad0c7;       /* seafoam accent */
  --accent:#b884f6;        /* soft violet accent */
  --line:#262a32;
  --radius:16px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* Body & Typography refinements */
body{ background:linear-gradient(180deg,#0e0f12 0%, #101319 100%); color:var(--ink); }
p{ color:var(--muted); }
a{ color:var(--brand-2); text-decoration:none }
a:hover{ opacity:.9 }

/* Container spacing */
.section{ padding: clamp(56px, 8vw, 96px) 0; }
.section .container{ width:min(1100px,92%); }

/* Header polish */
.site-header{
  position:sticky; top:0; z-index:1000;
  backdrop-filter: blur(8px);
  background: rgba(16,19,25,.6);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition: box-shadow .2s ease, background .2s ease;
}
.site-header.scrolled{ box-shadow: var(--shadow); background: rgba(16,19,25,.85); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; min-height:64px; }
.site-header .brand{ display:flex; align-items:center; gap:10px; color:var(--ink); font-weight:600 }
.site-header .brand img{ height:28px }
.nav a{ margin:0 .6rem; color:var(--ink); opacity:.85; position:relative; }
.nav a:hover{ opacity:1 }
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px;
  background:linear-gradient(90deg,var(--brand),var(--accent)); transform:scaleX(0);
  transform-origin:left; transition:transform .22s ease;
}
.nav a:hover::after{ transform:scaleX(1) }

/* Buttons */
.btn{ 
  display:inline-block; padding:.9rem 1.1rem; border-radius:999px; border:1px solid transparent;
  background: linear-gradient(180deg, var(--brand), #dba353);
  color:#24190a; font-weight:700; letter-spacing:.2px; box-shadow: 0 8px 18px rgba(233,184,114,.25);
  transition: transform .15s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn:hover{ transform: translateY(-2px); box-shadow: 0 10px 22px rgba(233,184,114,.35); }
.btn.outline{ background:transparent; color:var(--ink); border-color:var(--line) }
.btn.small{ padding:.55rem .9rem; font-weight:600 }

/* Cards / panels */
.panel{
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow: var(--shadow);
}
/* Services / Rates grid polish */
.services .grid, .rates .grid, .gallery .grid { 
  display:grid; gap:18px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.services .card, .rates .card{ padding:20px; border-radius:var(--radius); border:1px solid var(--line); background:rgba(20,23,28,.8) }
.card h3{ color:var(--ink); margin-bottom:.35rem }
.card p{ color:var(--muted) }
.rates .price{ font-size:1.25rem; font-weight:700; color:var(--brand) }

/* Gallery polish */
.gallery .grid img{
  width:100%; height:280px; object-fit:cover; border-radius:14px; border:1px solid var(--line);
  transition: transform .25s ease, box-shadow .25s ease;
}
.gallery .grid img:hover{ transform: translateY(-4px) scale(1.02); box-shadow: 0 12px 26px rgba(0,0,0,.35) }

/* Booking form polish */
#booking form{
  display:grid; gap:14px; max-width:640px;
  background:rgba(20,23,28,.7); padding:22px; border-radius:var(--radius); border:1px solid var(--line);
}
#booking input, #booking select, #booking textarea{
  background:#10141b; color:var(--ink); border:1px solid var(--line); border-radius:10px;
  padding:12px 14px; outline:none;
}
#booking input::placeholder, #booking textarea::placeholder{ color:#7e8794 }
#booking button[type=submit]{ justify-self:start }

/* Reviews layout polish */
.reviews .quotes{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
  gap:16px; margin-top:18px;
}
.reviews blockquote{
  margin:0; padding:16px 18px; border-radius:14px;
  border:1px solid var(--line); background:rgba(20,23,28,.75); color:var(--ink);
}
.reviews blockquote span{ color:#ffd36b } /* star color */
.reviews h3{ margin-top:28px }
#reviews form#reviewForm button{ background:linear-gradient(180deg, var(--accent), #9a6df2); color:#100d18; font-weight:700 }

/* Contact cards polish */
#contact-cards .container, .contact-cards .container{ width:min(900px,92%) }
.contact-card{ display:flex; align-items:center; gap:12px; padding:14px 16px; border-radius:12px; border:1px solid var(--line); background:rgba(20,23,28,.7) }
.contact-card svg{ flex:0 0 auto }

/* Footer */
.site-footer{
  padding:28px 0; border-top:1px solid var(--line);
  background:linear-gradient(180deg, #0f1217, #0e0f12);
}
.site-footer .footer-inner{ display:flex; align-items:center; justify-content:space-between }
.site-footer p{ margin:0; color:#9aa3af }

/* Floating contact minor nudge */
.floating-contact .fc-btn{ border:1px solid rgba(255,255,255,.08) }

