/* Nails Theory Beauty - final footer and visibility fix
   Fixes footer/contact visibility after concept design update.
   Must load AFTER all previous rose quartz/concept CSS files. */
:root {
  --ntb-final-ink: #2d211f;
  --ntb-final-muted: #6d5b56;
  --ntb-final-line: rgba(160, 95, 105, 0.18);
  --ntb-final-panel: rgba(255, 253, 251, 0.965);
  --ntb-final-panel-solid: #fffdfb;
  --ntb-final-rose: #bd7b8d;
  --ntb-final-rose-soft: #ead0d6;
  --ntb-final-rose-hover: #a96678;
  --ntb-final-shadow: 0 22px 60px rgba(68, 42, 39, 0.12);
}

/* Keep the header fully readable when it overlaps page content */
.site-header,
header.site-header {
  background: rgba(255, 253, 251, 0.985) !important;
  box-shadow: 0 10px 28px rgba(80, 48, 44, 0.08) !important;
  border-bottom: 1px solid var(--ntb-final-line) !important;
  backdrop-filter: blur(18px) saturate(1.05) !important;
}
.site-header *,
header.site-header * {
  text-shadow: none !important;
}

/* Softer rose buttons across the site */
.btn-primary,
.header-actions .btn-primary,
.hero-actions .btn-primary,
.gallery-book-link,
.filter-button.active,
.action-pill,
.mobile-sticky a:first-child,
.sticky-book,
.lead-offer-button {
  background: linear-gradient(135deg, #d6a0ab, var(--ntb-final-rose)) !important;
  border-color: rgba(189, 123, 141, 0.26) !important;
  color: #fff !important;
  box-shadow: 0 12px 26px rgba(150, 88, 102, 0.16) !important;
}
.btn-primary:hover,
.gallery-book-link:hover,
.filter-button.active:hover,
.action-pill:hover,
.sticky-book:hover {
  background: linear-gradient(135deg, #ca8f9d, var(--ntb-final-rose-hover)) !important;
  color: #fff !important;
}

/* Footer visibility reset: previous concept CSS made footer text white while the footer card was white. */
.site-footer {
  background:
    linear-gradient(180deg, rgba(255, 250, 248, 0.92), rgba(255, 244, 243, 0.94)),
    url('rose-quartz-concept-desktop.webp') center/cover fixed !important;
  color: var(--ntb-final-ink) !important;
  padding: 64px 0 72px !important;
  border-top: 1px solid var(--ntb-final-line) !important;
}
.site-footer .footer-shell {
  background: var(--ntb-final-panel) !important;
  border: 1px solid var(--ntb-final-line) !important;
  border-radius: 32px !important;
  box-shadow: var(--ntb-final-shadow) !important;
  color: var(--ntb-final-ink) !important;
  padding: 38px !important;
  backdrop-filter: blur(14px) saturate(1.05) !important;
}
.site-footer .footer-shell,
.site-footer .footer-shell *,
.site-footer .footer-col,
.site-footer .footer-col *,
.site-footer .footer-bottom,
.site-footer .footer-bottom *,
.site-footer .footer-copy {
  color: var(--ntb-final-ink) !important;
  text-shadow: none !important;
  opacity: 1 !important;
}
.site-footer .footer-copy,
.site-footer .footer-bottom,
.site-footer .footer-bottom span,
.site-footer .footer-col span,
.site-footer .footer-col p {
  color: var(--ntb-final-muted) !important;
}
.site-footer .footer-col h3 {
  color: var(--ntb-final-ink) !important;
  font-size: clamp(1.45rem, 2vw, 1.95rem) !important;
  line-height: 1.05 !important;
  margin: 0 0 8px !important;
}
.site-footer .footer-col a,
.site-footer .footer-link-row a,
.site-footer .footer-col .pill-link {
  color: var(--ntb-final-ink) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(160, 95, 105, 0.13) !important;
  border-radius: 999px !important;
  padding: 8px 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  max-width: 100% !important;
}
.site-footer .footer-col a:hover,
.site-footer .footer-link-row a:hover {
  background: #fff !important;
  border-color: rgba(189, 123, 141, 0.28) !important;
  color: var(--ntb-final-rose-hover) !important;
  transform: translateY(-1px);
}
.site-footer .footer-logo {
  background: transparent !important;
  filter: none !important;
  opacity: 1 !important;
  max-width: 270px !important;
}
.site-footer .footer-grid {
  gap: 26px !important;
  align-items: start !important;
}
.site-footer .footer-col {
  background: rgba(255, 255, 255, 0.78) !important;
  border: 1px solid rgba(160, 95, 105, 0.12) !important;
  border-radius: 22px !important;
  padding: 22px !important;
  min-height: 100% !important;
  box-shadow: 0 10px 28px rgba(80, 48, 44, 0.05) !important;
}
.site-footer .footer-action-strip {
  gap: 12px !important;
  margin-bottom: 26px !important;
}
.site-footer .action-pill {
  color: #fff !important;
  border: 0 !important;
  padding: 14px 18px !important;
  font-weight: 700 !important;
  letter-spacing: 0.13em !important;
  text-align: center !important;
}
.site-footer .footer-action-strip a[href="#"],
.site-footer a[data-instagram-link][href="#"] {
  display: none !important;
}
.site-footer .footer-action-strip:has(a[href="#"]) {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}
.site-footer .footer-bottom {
  border-top: 1px solid var(--ntb-final-line) !important;
  margin-top: 26px !important;
  padding-top: 20px !important;
}

/* Prevent any section from placing pale/white text directly on a light card */
.luxury-action-band,
.page-end-actions-section .luxury-action-band,
.cta-band,
.review-proof-shell,
.page-cta,
.contact-card,
.hours-card,
.location-feature,
.destination-card {
  color: var(--ntb-final-ink) !important;
}
.luxury-action-band *,
.cta-band *,
.review-proof-shell *,
.page-cta *,
.contact-card *,
.hours-card *,
.location-feature *,
.destination-card * {
  text-shadow: none !important;
}
.luxury-action-band p,
.cta-band p,
.review-proof-shell p,
.page-cta p,
.contact-card p,
.hours-card p,
.location-feature p,
.destination-card p {
  color: var(--ntb-final-muted) !important;
}

@media (max-width: 980px) {
  .site-footer {
    background:
      linear-gradient(180deg, rgba(255, 250, 248, 0.94), rgba(255, 244, 243, 0.96)),
      url('rose-quartz-concept-mobile.webp') center/cover scroll !important;
  }
  .site-footer .footer-grid,
  .site-footer .footer-action-strip {
    grid-template-columns: 1fr !important;
  }
  .site-footer .footer-shell {
    padding: 24px !important;
    border-radius: 26px !important;
  }
  .site-footer .footer-col {
    padding: 18px !important;
  }
}
