/*
Theme Name: Muse Lab Spa
Theme URI: https://muselabspa.uk
Description: Custom theme for Muse Lab Spa — dark, cream, gold wellness brand
Version: 2.5
Author: Pink Pine Media
Author URI: https://pinkpinemedia.com
License: Private
Text Domain: muse-lab
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --dark:   #080806;
  --cream:  #F4EDD8;
  --cream2: #E8D9B8;
  --gold:   #C9A96E;
  --gold2:  rgba(201,169,110,0.35);
  --white:  #FAFAF7;
  --dim:    #888070;
  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Jost', system-ui, sans-serif;
  --nav-h:  68px;
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  font-weight: 300;
  background: var(--white);
  color: var(--dark);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: var(--sans); cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }

/* ============================================================
   TYPOGRAPHY GLOBALS
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--serif);
  font-weight: 300;
  line-height: 1.1;
}

/* WordPress alignment */
.alignleft  { float: left; margin-right: 1.5em; }
.alignright { float: right; margin-left: 1.5em; }
.aligncenter { margin: 0 auto; display: block; }
.wp-block-image img { max-width: 100%; }
.wp-block-html { width: 100%; }

/* ============================================================
   SITE WRAPPER
   ============================================================ */
#page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

#main { flex: 1; }

/* Full-width pages — no container padding */
.page-template-default #main,
body.page #main {
  padding: 0;
}

/* ============================================================
   HEADER + NAV
   Matches the homepage nav exactly
   ============================================================ */
#site-header {
  position: sticky;
  top: 0;
  z-index: 200;
  width: 100%;
  background: var(--white);
  border-bottom: 1px solid rgba(8,8,6,0.1);
  height: var(--nav-h);
  transition: background 0.3s, border-color 0.3s;
}

/* Transparent on homepage only — JS adds this class on load */
body.home #site-header.is-top {
  background: transparent;
  border-bottom-color: rgba(201,169,110,0.15);
}

body.home #site-header.is-top .nav-logo { color: var(--cream); }
body.home #site-header.is-top .nav-link { color: rgba(244,237,216,0.55); }
body.home #site-header.is-top .nav-link:hover { color: var(--cream); }
body.home #site-header.is-top .nav-hamburger span { background: var(--cream); }

.nav-inner {
  max-width: 100%;
  height: var(--nav-h);
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.nav-logo {
  font-family: var(--serif);
  font-size: 13px;
  font-weight: 300;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dark);
  text-decoration: none;
  flex-shrink: 0;
  z-index: 2;
  transition: color 0.3s;
}

/* Desktop nav links — hidden on mobile */
.nav-links {
  display: none;
  align-items: center;
  gap: 32px;
}

.nav-link {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dim);
  text-decoration: none;
  transition: color 0.2s;
  white-space: nowrap;
}

.nav-link:hover { color: var(--dark); }

/* Book Now button */
.nav-book {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dark);
  background: var(--gold);
  padding: 11px 24px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  display: none; /* shown on desktop */
  transition: background 0.2s;
  min-height: 40px;
  line-height: 18px;
}

.nav-book:hover { background: var(--gold); color: var(--dark); opacity: 0.85; }

/* Hamburger — shown on mobile */
.nav-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 32px;
  height: 32px;
  padding: 4px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 2;
}

.nav-hamburger span {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--dark);
  transition: transform 0.3s, opacity 0.3s;
}

/* Hamburger → X when open */
.nav-open .nav-hamburger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-open .nav-hamburger span:nth-child(2) { opacity: 0; }
.nav-open .nav-hamburger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ── Mobile drawer ── */
.nav-drawer {
  position: fixed;
  inset: 0;
  background: var(--dark);
  z-index: 190;
  display: flex;
  flex-direction: column;
  padding: calc(var(--nav-h) + 32px) 28px 40px;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

.nav-open .nav-drawer { transform: translateX(0); }

.nav-drawer-links {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid rgba(244,237,216,0.1);
  margin-bottom: 32px;
}

.nav-drawer-link {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 300;
  color: var(--cream);
  text-decoration: none;
  padding: 20px 0;
  border-bottom: 1px solid rgba(244,237,216,0.1);
  display: block;
  letter-spacing: 0.02em;
  transition: color 0.2s, padding-left 0.2s;
}

.nav-drawer-link:hover {
  color: var(--gold);
  padding-left: 8px;
}

.nav-drawer-book {
  display: block;
  background: var(--gold);
  color: var(--dark);
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-align: center;
  padding: 18px 28px;
  margin-top: 8px;
  transition: background 0.2s;
}

.nav-drawer-book:hover { background: #b8943e; }

.nav-drawer-contact {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid rgba(244,237,216,0.1);
  font-size: 13px;
  font-weight: 300;
  color: rgba(244,237,216,0.4);
  letter-spacing: 0.1em;
  line-height: 2;
}

.nav-drawer-contact a { color: rgba(244,237,216,0.6); }

/* ============================================================
   DESKTOP NAV — 900px+
   ============================================================ */
@media (min-width: 900px) {
  .nav-inner { padding: 0 52px; }
  .nav-links, ul.nav-links { display: flex; }
  .nav-book { display: inline-block; }
  .nav-hamburger { display: none; }
}

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer {
  background: var(--dark);
  border-top: 1px solid rgba(201,169,110,0.12);
}

/* Newsletter strip */
.footer-nl {
  padding: 48px 24px;
  border-bottom: 1px solid rgba(244,237,216,0.08);
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.footer-nl-title {
  font-family: var(--serif);
  font-size: clamp(20px, 4vw, 28px);
  font-weight: 300;
  font-style: italic;
  color: var(--cream);
  line-height: 1.2;
}

.footer-nl-label {
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 8px;
}

.footer-nl-form {
  display: flex;
  max-width: 440px;
  width: 100%;
}

.footer-nl-input {
  flex: 1;
  padding: 13px 16px;
  background: rgba(244,237,216,0.06);
  border: 1px solid var(--gold2);
  border-right: none;
  color: var(--cream);
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 300;
  outline: none;
  transition: border-color 0.2s;
  min-height: 48px;
}

.footer-nl-input:focus { border-color: var(--gold); }
.footer-nl-input::placeholder { color: rgba(244,237,216,0.3); }

.footer-nl-btn {
  padding: 13px 20px;
  background: var(--gold);
  border: none;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dark);
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s;
  min-height: 48px;
}

.footer-nl-btn:hover { background: #b8943e; }

/* Footer grid */
.footer-grid {
  padding: 48px 24px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  background: var(--white);
}

.footer-col-label {
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 16px;
}

.footer-brand-name {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 300;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dark);
  margin-bottom: 8px;
}

.footer-brand-tag {
  font-size: 14px;
  font-weight: 300;
  font-style: italic;
  color: var(--dim);
  line-height: 1.6;
  max-width: 200px;
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-links a {
  font-size: 13px;
  font-weight: 300;
  color: var(--dim);
  text-decoration: none;
  transition: color 0.2s;
  line-height: 1.4;
}
.footer-links span { color: var(--dim); }

.footer-links a:hover { color: var(--dark); }

/* Footer bottom bar */
.footer-bottom {
  padding: 16px 24px;
  border-top: 1px solid rgba(8,8,6,0.08);
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--white);
}

.footer-copy {
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dim);
}

.footer-copy a { transition: color 0.2s; }
.footer-copy a:hover { color: var(--dark); }

/* Footer desktop */
@media (min-width: 600px) {
  .footer-nl {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 48px 52px;
  }

  .footer-nl-title { margin-bottom: 0; }

  .footer-grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    padding: 52px;
  }

  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 18px 52px;
  }
}

/* ── Global typography minimums ── */
.ml-trust-label { font-size: 15px !important; line-height: 1.75 !important; }
.ml-hs-price-name { font-size: 13px !important; color: #F4EDD8 !important; opacity: 1 !important; }
.ml-hero-badge-label { font-size: 12px !important; opacity: 1 !important; color: #F4EDD8 !important; }
.ml-hero-loc { font-size: 14px !important; }
.ml-lisa-cred { font-size: 15px !important; line-height: 1.8 !important; }
.ml-hs-tag, .ml-h2o-tag, .ml-meno-tag, .ml-night-label, .ml-fultan-tag, .ml-lisa-role, .ml-lisa-tag, .ml-testi-attr, .ml-h2o-card-dur, .ml-fultan-badge-sub { font-size: 12px !important; }
.ml-meno-opt-sub, .ml-night-price, .ml-fultan-price-sub { font-size: 13px !important; }
.footer-links a, .footer-links span { font-size: 15px !important; line-height: 1.9 !important; }
.footer-brand-tag, .footer-brand-name { font-size: 15px !important; }
.footer-col-label { font-size: 12px !important; }
.footer-copy { font-size: 12px !important; }
.card-desc, .diff-body, .event-body, .cred-body, .member-bio, .cat-desc, .hero-intro, .hero-sub, .info-body, .booking-sub, .form-sub, .story-body p, .private-body, .intro-body, .gv-intro-text, .faq-a, .note, .policy-item, .hour, .cta-sub, .book-band-sub, .event-cap, .booking-note, .cred, .hero-badge { font-size: 15px !important; line-height: 1.85 !important; }

/* ── Hero animation override — above-fold content visible immediately ── */
.ml-hero-eyebrow,
.ml-hero-h1,
.ml-hero-sub,
.ml-hero-ctas,
.ml-hero-bottom,
.ml-hero-inner,
.ml-hero-inner *,
.hero-inner,
.hero-inner * {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
}


/* ── NAV DROPDOWN ─────────────────────────────────── */
.nav-dropdown{position:relative;display:inline-flex;align-items:center}
.nav-dropdown-menu{display:none;position:absolute;top:calc(100% + (var(--nav-h) - 100%) / 2);left:0;background:#080806;min-width:220px;border-top:2px solid rgba(201,169,110,.3);z-index:200;padding:20px 0 24px}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-item{display:block;padding:14px 28px;font-size:13px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,237,216,.75);transition:color .2s;white-space:nowrap}
.nav-dropdown-item:hover{color:#C9A96E}

/* ── WP NAV MENU STRUCTURE ─────────────────────────────────── */
ul.nav-links{display:none;align-items:center;gap:32px;list-style:none;margin:0;padding:0}
ul.nav-links > li{position:relative;display:inline-flex;align-items:center}
ul.nav-links > li > a{font-size:13px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,237,216,.65);transition:color .2s;white-space:nowrap}
ul.nav-links > li > a:hover,ul.nav-links > li.current-menu-item > a{color:var(--cream)}
ul.nav-links .sub-menu{display:none;position:absolute;top:100%;left:0;background:#080806;min-width:220px;border-top:1px solid rgba(201,169,110,.2);z-index:100;padding:12px 0 16px;list-style:none;margin:0;border-bottom:1px solid rgba(201,169,110,.1)}
ul.nav-links li:hover > .sub-menu{display:block}
ul.nav-links .sub-menu li a{display:block;padding:13px 24px;font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,237,216,.6);transition:color .2s;white-space:nowrap}
ul.nav-links .sub-menu li a:hover{color:#C9A96E}
.nav{max-width:100%;height:var(--nav-h);padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:32px}

/* ── Inner page nav — solid dark background ── */
body:not(.home) .nav {
  background: #080806 !important;
  border-bottom: 1px solid rgba(201,169,110,.1);
}
body:not(.home) .nav-link,
body:not(.home) .nav-links a {
  color: rgba(244,237,216,.7) !important;
}
body:not(.home) .nav-link:hover,
body:not(.home) .nav-links a:hover {
  color: #C9A96E !important;
}
body:not(.home) .nav-logo {
  color: #F4EDD8 !important;
}

/* ── Mobile nav ── */
@media(max-width:767px){
  /* Hide desktop nav book, show hamburger */
  .nav-book{display:none}
  .nav-hamburger{display:flex}

  /* Nav drawer — hidden by default, shown when nav-open */
  .nav-links{
    display:none;
    flex-direction:column;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:#080806;
    z-index:200;
    overflow:hidden;
  }
  .nav-links.nav-open{
    display:flex !important;
  }

  /* Panel layout — slide left/right */
  .nav-panel{width:100%;transition:transform .3s ease;will-change:transform;flex-shrink:0}
  .nav-panel-main{transform:translateX(0)}
  .nav-panel-treatments{
    position:absolute;
    top:0;left:0;
    width:100%;
    transform:translateX(100%);
    background:#080806;
    padding:0;
  }
  .nav-links.show-treatments .nav-panel-main{transform:translateX(-100%)}
  .nav-links.show-treatments .nav-panel-treatments{transform:translateX(0)}

  /* Back button */
  .nav-back{display:flex;align-items:center;gap:8px;width:100%;padding:14px 24px;font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(201,169,110,.7);background:none;border:none;border-bottom:1px solid rgba(201,169,110,.1);cursor:pointer;font-family:inherit}
  .nav-back::before{content:'←';font-size:14px}

  /* Main panel links */
  .nav-panel-main .nav-link{
    display:block;
    padding:12px 24px;
    font-size:11px;
    font-weight:400;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(244,237,216,.7);
  }
  .nav-panel-main .nav-link:hover{color:#C9A96E}

  /* Treatments sub-panel links */
  .nav-panel-treatments a{display:block;padding:12px 24px;font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,237,216,.7)}
  .nav-panel-treatments a:first-of-type{border-bottom:1px solid rgba(201,169,110,.1);color:var(--gold);padding-bottom:14px;margin-bottom:4px}
  .nav-panel-treatments a:hover{color:#C9A96E}
}

@media(min-width:768px) {
  .nav-hamburger { display: none !important; }
}

/* ── Homepage section images — square on all screen sizes ── */
.meno-img-col {
  aspect-ratio: 1 / 1;
  overflow: hidden;
}
.meno-img-col img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.fultan-img {
  aspect-ratio: 1 / 1;
  min-height: unset;
  overflow: hidden;
}
.fultan-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: unset;
}

/* ── Footer brand column vertical centre ── */
.footer-brand {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* ── Footer credit (Pink Pine Media) ── */
.footer-credit {
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dim);
}
.footer-credit a {
  color: var(--dim);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.2s;
}
.footer-credit a:hover { color: var(--dark); }

/* Hero left column top padding — award badge distance from nav */
@media (min-width: 768px) {
  .hero-content { padding-top: 140px !important; }
}

/* ── Body text size increase ── */
body .hero-sub, body .hero-intro, body .card-desc, body .diff-body, body .story-body p, body .intro-body, body .event-body, body .info-body, body .team-intro, body .cta-sub, body .book-band-sub, body .packages-sub, body .cats-sub, body .faq-a, body .note, body .trust-label, body .member-bio, body .cred-body, body .fultan-body, body .hs-feature-body, body .meno-body, body .gv-intro-text, body .gv-step-body, body .services-sub, body .booking-sub, body .private-body, body .bc a, body .hour, body .policy-item {
  font-size: 18px !important;
  line-height: 1.85 !important;
}

/* ── Mobile drill-down nav ── */
@media(max-width:767px){
  /* Nav links container */
  .nav-links{
    display:none;
    flex-direction:column;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:#080806;
    z-index:200;
    overflow:hidden;
    border-top:1px solid rgba(201,169,110,.1);
  }
  .nav-links.nav-open{
    display:flex;
  }

  /* Panels */
  .nav-panel{
    width:100%;
    transition:transform .3s ease;
    flex-shrink:0;
  }
  .nav-panel-main{
    transform:translateX(0);
    display:flex;
    flex-direction:column;
  }
  .nav-panel-treatments{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    transform:translateX(100%);
    background:#080806;
    display:flex;
    flex-direction:column;
    min-height:100%;
  }
  .nav-links.show-treatments .nav-panel-main{
    transform:translateX(-100%);
  }
  .nav-links.show-treatments .nav-panel-treatments{
    transform:translateX(0);
  }

  /* Hide desktop dropdown on mobile */
  .nav-dropdown-menu{
    display:none !important;
  }

  /* Nav links */
  .nav-panel-main .nav-link,
  .nav-panel-main .nav-treatments-top{
    display:block;
    padding:14px 24px;
    font-size:11px;
    font-weight:400;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(244,237,216,.7);
    border-bottom:1px solid rgba(201,169,110,.07);
  }
  .nav-panel-main .nav-link:hover,
  .nav-panel-main .nav-treatments-top:hover{
    color:#C9A96E;
  }

  /* Treatments top link - show arrow */
  .nav-treatments-top::after{
    content:' →';
    color:rgba(201,169,110,.5);
  }

  /* Back button */
  .nav-back{
    display:flex;
    align-items:center;
    gap:8px;
    width:100%;
    padding:14px 24px;
    font-size:11px;
    font-weight:400;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(201,169,110,.7);
    background:none;
    border:none;
    border-bottom:1px solid rgba(201,169,110,.15);
    cursor:pointer;
    font-family:inherit;
    text-align:left;
  }
  .nav-back::before{
    content:'←';
    font-size:14px;
    margin-right:4px;
  }

  /* Treatment sub-links */
  .nav-panel-treatments a{
    display:block;
    padding:14px 24px;
    font-size:11px;
    font-weight:400;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(244,237,216,.7);
    border-bottom:1px solid rgba(201,169,110,.07);
  }
  .nav-panel-treatments a.nav-all-treatments{
    color:#C9A96E;
    border-bottom:1px solid rgba(201,169,110,.2);
    margin-bottom:4px;
  }
  .nav-panel-treatments a:hover{
    color:#C9A96E;
  }

  /* Book Now button — more padding on mobile */
  .nav-book{
    padding:16px 30px !important;
    display:block;
    text-align:center;
    margin:12px 16px 16px;
  }

  /* Hamburger — straight clean cross, no squint */
  .nav-hamburger{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    width:44px;
    height:44px;
    gap:0;
    background:none;
    border:none;
    cursor:pointer;
    padding:0;
    position:relative;
  }
  .nav-hamburger span{
    display:block;
    width:22px;
    height:2px;
    background:var(--cream);
    border-radius:2px;
    position:absolute;
    left:50%;
    transform-origin:center center;
    transition:transform .3s ease, opacity .3s ease;
  }
  .nav-hamburger span:nth-child(1){
    transform:translateX(-50%) translateY(-7px);
  }
  .nav-hamburger span:nth-child(2){
    transform:translateX(-50%);
  }
  .nav-hamburger span:nth-child(3){
    transform:translateX(-50%) translateY(7px);
  }
  .nav-hamburger.is-open span:nth-child(1){
    transform:translateX(-50%) translateY(0) rotate(45deg);
  }
  .nav-hamburger.is-open span:nth-child(2){
    opacity:0;
    transform:translateX(-50%) scaleX(0);
  }
  .nav-hamburger.is-open span:nth-child(3){
    transform:translateX(-50%) translateY(0) rotate(-45deg);
  }
}

@media(min-width:768px){
  .nav-back{display:none}
  .nav-panel-treatments{display:none}
  .nav-panel-main{display:contents}
  .nav-hamburger{display:none !important}
}