/* Compact layout, higher contrast, and blurred-image background focus */
:root{
  --text:#02101e; --muted:#1c2b36;
  --primary:#8d7cf7; --primary-700:#6f5be8; --accent:#c084fc; --ring:#d6bcfa;
}
body{
  color:var(--text);
  background-color:#94efe2;
  background-image:
    linear-gradient(0deg, rgba(148,239,226,0.88), rgba(148,239,226,0.88)),
    url('assets/bg.png');
  background-size: 480px auto;
  background-repeat: repeat;
  background-attachment: scroll;
  background-position: 0 0;
  background-blend-mode: lighten;
}
.section{ padding:2.25rem 0; }
h1{ font-size:clamp(1.8rem,2.5vw + 1rem,2.4rem); }
.header-inner{ padding:.4rem 0; flex-wrap:wrap; gap:.6rem; align-items:center; }
.header-actions{ display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; margin-left:auto; }
.toolbar-btn{
  border:1px solid rgba(2,16,30,.12);
  border-radius:999px;
  background:#fff;
  color:var(--text);
  font-size:.85rem;
  font-weight:600;
  padding:.35rem .85rem;
  line-height:1.2;
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease,opacity .2s ease;
}
.toolbar-btn:hover{
  text-decoration:none;
  background:rgba(255,255,255,.9);
  border-color:var(--primary-700);
  color:var(--primary-700);
}
.social-btn{ color:#fff; border-color:transparent; }
.tiktok-btn{
  background:linear-gradient(135deg,#25f4ee,#fe2c55);
  color:#02101e;
}
.facebook-btn{
  background:#1877f2;
  border-color:#1877f2;
}
.reset-btn{
  background:#fff;
  color:var(--text);
  border-style:dashed;
}
.reset-btn[disabled]{ opacity:.55; cursor:wait; }
/* Make accent button match primary purple */
.btn-accent{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
}
.btn-accent:hover{
  background:var(--primary-700);
}
@media(max-width:700px){
  .header-actions{
    width:100%;
    order:4;
    justify-content:flex-start;
  }
}
.btn{ padding:.6rem .85rem; border-radius:10px; }
.card{ padding:.8rem; border-radius:12px; }
.card-grid{ gap:.75rem; }
.services-grid{ grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }
.hero{ padding-top:2.2rem; }
.hero-media{ gap:.5rem; }
.portrait img,.sample img{ border-radius:12px; box-shadow:0 2px 10px rgba(2,6,23,.06); }
.form-grid{ gap:.8rem; }
.form-control input,.form-control select,.form-control textarea{ padding:.7rem .85rem; border-radius:10px; }
/* Tighten white panels and add soft transparency */
.hero-copy{
  padding:.75rem 1rem;
  background:rgba(255,255,255,.9);
}
.section-shell{
  padding:1rem 1.25rem;
  background:rgba(255,255,255,.9);
  border-radius:18px;
  box-shadow:0 12px 40px rgba(15,23,42,.08);
}

/* Denser tools pattern tile */
/* Force-hide any legacy sky/zodiac elements */
.sky,#sky,.zodiac-label{ display:none !important; }

/* Gallery tweaks */
.gallery-tiles{
  gap:1rem;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
}
.gallery-tiles .service-category{
  grid-column:1 / -1;
  margin:1.2rem 0 .15rem;
  padding-top:.35rem;
  border-top:1px solid #e5e7eb;
  font-size:1rem;
  letter-spacing:.01em;
}
.gallery-tile{
  border:1px solid #e5e7eb;
  border-radius:26px;
  box-shadow:0 14px 32px rgba(15,23,42,.08);
  padding:0;
  overflow:hidden;
}
.gallery-tile .gallery-img{
  aspect-ratio:1 / 1;
}
.gallery-tile figcaption{
  position:absolute;
  left:.6rem;
  bottom:.6rem;
  padding:.25rem .5rem;
  border-radius:999px;
  font-size:.78rem;
  color:var(--text);
  background:rgba(255,255,255,.88);
  box-shadow:0 4px 10px rgba(15,23,42,.18);
}
/* Staggered two-layer tools pattern for better rhythm */

/* Header brand refresh */
.brand-text{
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.95rem;
}
.site-logo{
  height:42px;
  width:auto;
  display:block;
}

/* Services section refinements */
.service-category{
  margin-top:1.75rem;
  margin-bottom:.75rem;
  font-size:1rem;
  font-weight:700;
  color:var(--text);
}
.service-item{
  display:block;
}
.service-title{
  margin:0 0 .25rem;
  font-size:.98rem;
  color:var(--primary);
}
.service-desc{
  margin:0;
  font-size:.9rem;
}
.service-unavailable{
  opacity:.7;
}
.service-note{
  margin-top:.4rem;
  font-size:.8rem;
  color:var(--muted);
}

/* Map tweaks so it fills the column cleanly */
.map-placeholder{
  min-height:260px;
  border-radius:14px;
  overflow:hidden;
  background:linear-gradient(135deg,rgba(99,102,241,.06),rgba(6,182,212,.04));
  border:1px solid #e5e7eb;
}
.map-placeholder iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

/* Embedded Square booking */
/* Booking callout handoff to Square */
.booking-helper{
  margin-top:1rem;
  text-align:center;
  font-size:.85rem;
  opacity:.8;
}
.booking-callout{
  max-width:700px;
  margin:0 auto;
  padding:2.5rem 1.75rem;
  border-radius:1.25rem;
  background:#ffffff;
  box-shadow:0 18px 45px rgba(0,0,0,0.12);
}
.booking-steps{
  margin:0 0 1.75rem;
  padding-left:1.2rem;
  font-size:.96rem;
  line-height:1.6;
}
.booking-steps li+li{
  margin-top:.4rem;
}
.booking-btn{
  display:inline-block;
  margin-bottom:1rem;
}

#booking{
  scroll-margin-top:6rem;
}

.site-header .logo{
  display:flex;
  align-items:center;
}

.service-card{
  cursor:pointer;
  transition:box-shadow .2s ease,transform .2s ease;
}
.service-card:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(0,0,0,0.08);
}
.service-card.selected{
  box-shadow:0 0 0 2px var(--primary);
}
.selected-service-hint{
  margin-bottom:1rem;
  font-weight:600;
  font-size:1rem;
}

/* Hero card layout */
.hero-card{
  background:#ffffff;
  border-radius:1rem;
  padding:1.25rem 1.5rem;
  box-shadow:0 10px 25px rgba(0,0,0,0.06);
  max-width:520px;
}
.hero-main-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:1rem;
  margin-bottom:.5rem;
}
.hero-note{
  font-size:.9rem;
  opacity:.8;
}
.hero-portrait img{
  max-width:220px;
  border-radius:50%;
  display:block;
}

/* Align hero card + portrait nicely */
.hero .hero-grid{
  display:flex;
  flex-wrap:wrap;
  gap:1.5rem;
  align-items:center;
}
.hero-card{
  flex:1 1 260px;
}
.hero-portrait{
  flex:0 0 auto;
  display:flex;
  justify-content:center;
}
@media(max-width:700px){
  .hero .hero-grid{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* Quick actions strip */
.quick-actions{
  margin:1rem 0 2rem;
}
.quick-actions .container{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.75rem;
}
.quick-action{
  display:block;
  padding:.75rem .9rem;
  border-radius:.9rem;
  text-decoration:none;
  background:#f5f1ff;
  border:1px solid #e0d4ff;
}
.quick-action:hover{
  text-decoration:none;
  background:#ede4ff;
}
.qa-label{
  display:block;
  font-weight:600;
  font-size:.95rem;
  color:var(--text);
}
.qa-sub{
  display:block;
  font-size:.8rem;
  opacity:.75;
  color:var(--muted);
}

/* Service highlights */
.service-highlights{
  margin-top:1.5rem;
  margin-bottom:1rem;
}
.swipe-tip{
  display:none;
  margin:0 0 .25rem;
  font-size:.85rem;
}
.swipe-tip.show{
  display:block;
}
.service-highlight-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:.75rem;
}
.service-highlight{
  display:block;
  padding:.9rem 1rem;
  border-radius:.9rem;
  background:#faf7ff;
  border:1px solid #ece3ff;
}
.service-highlight h4{
  margin:0 0 .25rem;
  font-size:.98rem;
}
.service-highlight p{
  margin:0;
  font-size:.85rem;
}

/* Horizontal scroll for services on mobile */
@media(max-width:700px){
  .service-highlight-grid{
    display:flex;
    overflow-x:auto;
    gap:.75rem;
    padding-bottom:.5rem;
    scroll-snap-type:x proximity;
  }
  .swipe-tip.show{
    display:block;
  }
  .service-highlight-grid .service-highlight{
    flex:0 0 48%;
    min-width:48%;
    scroll-snap-align:start;
  }
  .card-grid.services-grid{
    display:flex;
    overflow-x:auto;
    gap:.75rem;
    padding-bottom:.5rem;
    scroll-snap-type:x proximity;
  }
  .card-grid.services-grid > .service-item{
    min-width:48%;
    flex:0 0 48%;
    scroll-snap-align:start;
  }
}


/* Purple bold text inside bubbles/cards */
.hero-copy strong,
.section-shell strong,
.card strong{
  color:var(--primary);
}

/* Make card headings match purple accent */
.card h3,
.card h4{
  color:var(--primary);
}

/* Inner Alignment page */
/* Make heart buttons much smaller so they don't cover photos */
.heart{
  top:.55rem;
  right:.55rem;
  padding:0;
  width:1.4rem;
  height:1.4rem;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  font-size:.8rem;
  border-radius:999px;
  border:1px solid rgba(226,232,240,.95);
  background:rgba(255,255,255,.92);
  box-shadow:0 2px 6px rgba(15,23,42,.2);
}

/* Gallery lightbox */
.gallery-lightbox{
  position:fixed;
  inset:0;
  display:none;
  z-index:80;
}
.gallery-lightbox[aria-hidden="false"]{
  display:grid;
  place-items:center;
}
.gallery-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.7);
}
.gallery-lightbox-inner{
  position:relative;
  z-index:1;
  max-width:min(520px,92vw);
  max-height:85vh;
  padding:1rem;
  border-radius:18px;
  background:#fff;
  box-shadow:0 24px 60px rgba(15,23,42,.35);
  display:grid;
  gap:.5rem;
}
.gallery-lightbox-inner img{
  max-width:100%;
  max-height:65vh;
  border-radius:14px;
  display:block;
}
.gallery-lightbox-close{
  position:absolute;
  top:.5rem;
  right:.5rem;
}

@media(max-width:600px){
  .gallery-lightbox-inner{
    max-width:calc(100vw - 2rem);
    padding:.75rem;
  }
  .gallery-lightbox-inner img{
    max-height:60vh;
  }
}

/* Floating CTAs (Book / Services / Top) */
.floating-cta{
  position:fixed;
  right:1rem;
  bottom:1rem;
  z-index:60;
  display:none;
  gap:.4rem;
  align-items:center;
  flex-wrap:wrap;
}
.floating-cta.show{
  display:flex;
}
.floating-cta .floating-link{
  font-size:.8rem;
  padding:.35rem .8rem;
}
.floating-cta .to-top{
  display:inline-flex;
  position:static;
}

/* Mobile-first readability tweaks */
@media(max-width:600px){
  body{
    font-size:17px;
  }
  .section{
    padding:2rem 0;
  }
  .section-shell{
    padding:.9rem 1rem;
  }
  .hero-copy{
    padding:.9rem 1rem;
  }
  .card{
    padding:.9rem;
  }
  .footer-grid{
    grid-template-columns:1fr;
  }
}

/* Tip modal */
.tip-modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:90;
}
.tip-modal.open{
  display:grid;
  place-items:center;
}
.tip-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.65);
}
.tip-modal-inner{
  position:relative;
  z-index:1;
  width:min(92vw,420px);
  padding:1.25rem 1.5rem;
  border-radius:18px;
  background:#fff;
  box-shadow:0 24px 60px rgba(15,23,42,.32);
  display:grid;
  gap:.75rem;
  text-align:center;
}
.tip-links{
  display:grid;
  gap:.5rem;
}
.tip-link{
  width:100%;
  justify-content:center;
}
.tip-modal-close{
  position:absolute;
  top:.6rem;
  right:.6rem;
}
