/* ============================================================
   MEL HAIR BRAIDING — Global Styles
   Dark Luxury Theme
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root {
  /* Dark theme palette */
  --clay:        #c97a3a;
  --clay-dark:   #a85f20;
  --clay-light:  #e09060;
  --bg:          #0e0b09;
  --bg-2:        #161210;
  --bg-3:        #1f1a16;
  --bg-card:     #1a1410;
  --surface:     #231d18;
  --gold:        #c9a96e;
  --gold-light:  #e8d5a3;
  --text:        #f0e8df;
  --text-muted:  #9a8878;
  --text-dim:    #6b5a4e;
  --border:      rgba(201,121,58,0.18);
  --border-dim:  rgba(255,255,255,0.07);
  --shadow:      0 8px 40px rgba(0,0,0,0.5);
  --nav-h:       72px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'Jost', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  overflow-x: hidden;
}

h1,h2,h3,h4 { font-family:'Cormorant Garamond',serif; line-height:1.2; font-weight:400; }
h1 { font-size:clamp(2.8rem,6vw,5.5rem); }
h2 { font-size:clamp(2rem,4vw,3.5rem); }
h3 { font-size:clamp(1.4rem,2.5vw,2rem); }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }

/* ── NAV ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--nav-h);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(1.5rem,5vw,4rem);
  background:rgba(14,11,9,0.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-dim);
  transition:box-shadow .3s;
}
.nav.scrolled { box-shadow:0 4px 30px rgba(0,0,0,.6); border-bottom-color:var(--border); }

.nav-logo { font-family:'Cormorant Garamond',serif; font-size:1.5rem; letter-spacing:.04em; color:var(--text); }
.nav-logo span { color:var(--clay); }

.nav-links { display:flex; gap:2.5rem; list-style:none; }
.nav-links a { font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); transition:color .2s; position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-3px; left:0; right:0; height:1px; background:var(--clay); transform:scaleX(0); transform-origin:left; transition:transform .3s; }
.nav-links a:hover, .nav-links a.active { color:var(--clay); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }

.nav-cta { background:var(--clay) !important; color:var(--text) !important; padding:.5rem 1.4rem; border-radius:2px; letter-spacing:.1em; font-size:.78rem; transition:background .2s !important; }
.nav-cta:hover { background:var(--clay-dark) !important; }
.nav-cta::after { display:none !important; }

.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.nav-hamburger span { display:block; width:24px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; }

/* ── BUTTONS ── */
.btn { display:inline-block; padding:.8rem 2.2rem; font-family:'Jost',sans-serif; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; border-radius:2px; cursor:pointer; transition:all .25s; border:none; }
.btn-primary { background:var(--clay); color:var(--text); }
.btn-primary:hover { background:var(--clay-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,122,58,.35); }
.btn-outline { background:transparent; color:var(--clay); border:1.5px solid var(--clay); }
.btn-outline:hover { background:var(--clay); color:var(--text); transform:translateY(-2px); }
.btn-light { background:rgba(255,255,255,.08); color:var(--text); border:1px solid var(--border-dim); }
.btn-light:hover { background:rgba(255,255,255,.14); transform:translateY(-2px); }

/* ── SECTIONS ── */
.section { padding:clamp(4rem,8vw,7rem) clamp(1.5rem,7vw,6rem); }
.section-inner { max-width:1200px; margin:0 auto; }

.eyebrow { display:block; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--clay); margin-bottom:.8rem; }
.section-heading { color:var(--text); margin-bottom:1.2rem; }
.section-sub { font-size:1.05rem; color:var(--text-muted); max-width:560px; line-height:1.8; }

/* ── PAGE HERO ── */
.page-hero { position:relative; height:55vh; min-height:380px; display:flex; align-items:center; justify-content:center; overflow:hidden; margin-top:var(--nav-h); }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.08); transition:transform 8s ease; }
.page-hero.loaded .page-hero-bg { transform:scale(1); }
.page-hero-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(0,0,0,.75) 0%,rgba(201,122,58,.2) 100%); }
.page-hero-content { position:relative; z-index:2; text-align:center; color:var(--text); }
.page-hero-content h1 { color:var(--text); text-shadow:0 2px 20px rgba(0,0,0,.5); margin-bottom:.5rem; }
.page-hero-content .eyebrow { color:var(--gold-light); }

/* ── DIVIDER ── */
.divider { width:60px; height:2px; background:linear-gradient(90deg,var(--clay),var(--clay-light)); margin:1.2rem 0 2rem; }
.divider.center { margin-left:auto; margin-right:auto; }

/* ── CARDS ── */
.card { background:var(--bg-card); border:1px solid var(--border-dim); border-radius:4px; padding:2.2rem; transition:transform .3s,box-shadow .3s,border-color .3s; }
.card:hover { transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--border); }

/* ── FOOTER ── */
.footer { background:var(--bg-2); border-top:1px solid var(--border-dim); color:var(--text-muted); padding:3.5rem clamp(1.5rem,7vw,6rem); }
.footer-inner { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr 1fr; gap:3rem; }
.footer-logo { font-family:'Cormorant Garamond',serif; font-size:1.6rem; color:var(--text); margin-bottom:.8rem; }
.footer-logo span { color:var(--clay); }
.footer h4 { font-family:'Jost',sans-serif; font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--text-dim); margin-bottom:1rem; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:.5rem; }
.footer-links a { color:var(--text-muted); font-size:.9rem; transition:color .2s; }
.footer-links a:hover { color:var(--clay); }
.footer-bottom { max-width:1200px; margin:2.5rem auto 0; padding-top:1.5rem; border-top:1px solid var(--border-dim); display:flex; justify-content:space-between; align-items:center; font-size:.8rem; color:var(--text-dim); }

/* ── ANIMATIONS ── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1; transform:none; }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }

/* ── RESPONSIVE ── */
@media(max-width:768px) {
  .nav-links { display:none; flex-direction:column; gap:0; }
  .nav-links.open { display:flex; position:fixed; top:var(--nav-h); left:0; right:0; background:var(--bg-2); padding:1.5rem 2rem 2rem; border-bottom:1px solid var(--border-dim); box-shadow:var(--shadow); }
  .nav-links.open li { padding:.7rem 0; border-bottom:1px solid var(--border-dim); }
  .nav-hamburger { display:flex; }
  .nav-cta { display:none; }
  .footer-inner { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; gap:.5rem; text-align:center; }
}

/* ── SOCIAL ICONS ── */
.social-links { display:flex; gap:.8rem; margin-top:1rem; }
.social-link {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border-dim);
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s, transform .2s;
  flex-shrink:0;
}
.social-link:hover { background:var(--clay); border-color:var(--clay); transform:translateY(-3px); }
.social-link svg { width:16px; height:16px; fill:var(--text-muted); transition:fill .2s; }
.social-link:hover svg { fill:#fff; }

/* ── STYLESEAT BOOKING BUTTON ── */
.styleseat-btn {
  display:inline-flex; align-items:center; gap:.7rem;
  background:var(--clay); color:#fff;
  padding:.75rem 1.6rem; border-radius:2px;
  font-family:'Jost',sans-serif; font-size:.82rem;
  letter-spacing:.1em; text-transform:uppercase;
  transition:background .2s, transform .2s;
  border:none; cursor:pointer;
}
.styleseat-btn:hover { background:var(--clay-dark); transform:translateY(-2px); }
.styleseat-btn svg { width:18px; height:18px; fill:#fff; flex-shrink:0; }

/* ── WELCOME BANNER ── */
.welcome-banner {
  position:relative; z-index:99;
  background:var(--clay);
  overflow:hidden;
  height:40px;
  display:flex; align-items:center;
}
.welcome-banner-track {
  display:flex; align-items:center; gap:4rem;
  white-space:nowrap;
  animation:marquee 18s linear infinite;
  padding-right:4rem;
}
.welcome-banner-track span {
  font-family:'Cormorant Garamond',serif;
  font-size:1rem; font-style:italic;
  color:#fff; letter-spacing:.08em;
}
.welcome-banner-track .dot {
  color:rgba(255,255,255,.5); font-style:normal; font-size:.6rem;
}
@keyframes marquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ── VIDEO HERO ── */
.hero-video-bg {
  position:absolute; inset:0; overflow:hidden;
}
.hero-video-bg video {
  width:100%; height:100%;
  object-fit:cover;
  opacity:0; transition:opacity 1s ease;
}
.hero-video-bg video.active { opacity:1; }
.hero-video-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.78) 0%,rgba(201,122,58,.18) 60%,transparent 100%);
}

/* ── SOCIAL TEXT BUTTONS ── */
.social-cta-links { display:flex; flex-direction:column; gap:.6rem; margin-top:1rem; }
.social-cta-link {
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.82rem; color:var(--text-muted);
  transition:color .2s;
  letter-spacing:.02em;
}
.social-cta-link:hover { color:var(--clay); }
.social-cta-link svg { width:15px; height:15px; fill:currentColor; flex-shrink:0; }

/* ── WELCOME BANNER FIX ── */
.welcome-banner {
  position:relative; z-index:98;
  background:var(--clay);
  overflow:hidden;
  height:38px;
  display:flex; align-items:center;
  margin-top:var(--nav-h);
}
.hero { margin-top:0 !important; }
.welcome-banner-track {
  display:flex; align-items:center; gap:3rem;
  white-space:nowrap;
  will-change:transform;
  animation:marquee 75s linear infinite;
}
.welcome-banner-track span {
  font-family:'Cormorant Garamond',serif;
  font-size:.95rem; font-style:italic;
  color:#fff; letter-spacing:.1em;
}
.welcome-banner-track .dot { color:rgba(255,255,255,.45); font-style:normal; }
@keyframes marquee {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
