/* ========================================================================
   Mystique Dancers — global stylesheet
   Deep noir + champagne gold + burgundy accents
   ======================================================================== */

:root {
  --ink: #0a0709;
  --ink-2: #14101a;
  --ink-3: #1d1722;
  --gold: #c9a44a;
  --gold-soft: #e6c987;
  --gold-deep: #8c6e2a;
  --burgundy: #6b1a2d;
  --rose: #c25b6f;
  --cream: #f6efe1;
  --cream-dim: #d9cfb8;
  --line: rgba(201, 164, 74, 0.25);
  --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.55);
  --shadow-md: 0 12px 40px rgba(0, 0, 0, 0.45);
  --radius: 4px;
  --maxw: 1240px;
  --font-display: "Playfair Display", "Cormorant Garamond", Georgia, serif;
  --font-body: "Inter", "Helvetica Neue", Arial, sans-serif;
  --transition: 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}

* { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--cream);
  background: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  width: 100%;
}

img { max-width: 100%; display: block; }
a { color: var(--gold-soft); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--cream); }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.01em;
  margin: 0 0 0.6em;
  color: var(--cream);
  line-height: 1.15;
}
h1 { font-size: clamp(2.4rem, 5.5vw, 4.4rem); }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.8rem); }
h3 { font-size: 1.4rem; }
p { margin: 0 0 1em; }

.container {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 24px;
}

.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-size: 0.72rem;
  color: var(--gold);
  margin-bottom: 18px;
}

/* ------------------- Top utility bar ------------------- */
.topbar {
  background: #050306;
  color: var(--cream-dim);
  font-size: 0.82rem;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.topbar .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.topbar a { color: var(--cream-dim); }
.topbar a:hover { color: var(--gold); }
.topbar .tb-contact { display: flex; gap: 20px; align-items: center; }
.topbar .tb-contact span::before { content: ""; display: inline-block; width: 6px; height: 6px; background: var(--gold); border-radius: 50%; margin-right: 8px; vertical-align: middle; }
.topbar .tb-socials a { margin-left: 14px; }

/* ------------------- Header / nav ------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(10, 7, 9, 0.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 0;
  gap: 24px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
}
.brand-mark {
  width: 46px;
  height: 46px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--gold);
  letter-spacing: 0.02em;
}
.brand-name {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--cream);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.brand-sub {
  display: block;
  font-family: var(--font-body);
  font-size: 0.62rem;
  letter-spacing: 0.45em;
  color: var(--gold);
  text-transform: uppercase;
  margin-top: 2px;
}
nav.primary { display: flex; align-items: center; gap: 6px; }
nav.primary a {
  color: var(--cream);
  text-transform: uppercase;
  font-size: 0.82rem;
  letter-spacing: 0.18em;
  padding: 10px 14px;
  border-radius: var(--radius);
  position: relative;
}
nav.primary a:hover { color: var(--gold); }
nav.primary a.active { color: var(--gold); }
nav.primary a.active::after {
  content: "";
  position: absolute;
  left: 14px; right: 14px; bottom: 4px;
  height: 1px;
  background: var(--gold);
}

.btn {
  display: inline-block;
  padding: 14px 28px;
  border: 1px solid var(--gold);
  background: transparent;
  color: var(--gold);
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.28em;
  cursor: pointer;
  transition: all var(--transition);
  font-family: var(--font-body);
  max-width: 100%;
  word-break: break-word;
  white-space: normal;
  text-align: center;
}
.btn:hover { background: var(--gold); color: var(--ink); }
.btn-solid { background: var(--gold); color: var(--ink); }
.btn-solid:hover { background: var(--gold-soft); border-color: var(--gold-soft); }
.btn-lg { padding: 18px 36px; font-size: 0.85rem; }

.menu-toggle {
  display: none;
  background: none;
  border: 1px solid var(--gold);
  color: var(--gold);
  padding: 10px 14px;
  cursor: pointer;
  font-family: var(--font-body);
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  text-transform: uppercase;
}

/* ------------------- Hero ------------------- */
.hero {
  position: relative;
  min-height: 92vh;
  display: grid;
  place-items: center;
  text-align: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(201,164,74,0.18), transparent 55%),
    radial-gradient(ellipse at 70% 80%, rgba(107,26,45,0.45), transparent 55%),
    linear-gradient(180deg, #06040a 0%, #0a0709 100%);
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 12% 30%, rgba(255,255,255,0.06) 0 1px, transparent 2px),
    radial-gradient(circle at 78% 65%, rgba(255,255,255,0.06) 0 1px, transparent 2px),
    radial-gradient(circle at 45% 80%, rgba(201,164,74,0.18) 0 1px, transparent 2px);
  background-size: 220px 220px, 320px 320px, 180px 180px;
  opacity: 0.6;
  animation: drift 30s linear infinite;
}
@keyframes drift {
  from { background-position: 0 0, 0 0, 0 0; }
  to { background-position: 220px 220px, -320px 320px, 180px -180px; }
}
.hero-inner {
  position: relative;
  z-index: 2;
  padding: 80px 24px;
  max-width: 880px;
}
.hero h1 {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  margin-bottom: 24px;
}
.hero h1 .accent { color: var(--gold); font-style: italic; }
.hero p.hero-tagline {
  font-family: var(--font-body);
  font-size: clamp(0.78rem, 1.2vw, 0.95rem);
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--cream-dim);
  margin: 0 auto 28px;
  max-width: 760px;
  line-height: 1.8;
}
.hero p.lead {
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  color: var(--cream-dim);
  margin: 0 auto 36px;
  max-width: 620px;
}
.hero-ctas { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

.hero-scroll {
  position: absolute;
  bottom: 24px; left: 50%;
  transform: translateX(-50%);
  font-size: 0.7rem;
  letter-spacing: 0.4em;
  color: var(--gold);
  text-transform: uppercase;
}
.hero-scroll::after {
  content: "";
  display: block;
  width: 1px; height: 36px;
  background: var(--gold);
  margin: 10px auto 0;
  opacity: 0.5;
}

/* ------------------- Sections ------------------- */
section { padding: 90px 0; position: relative; overflow: hidden; }
section.tight { padding: 60px 0; }

.section-head { text-align: center; margin-bottom: 56px; }
.section-head p.kicker { color: var(--cream-dim); max-width: 640px; margin: 12px auto 0; }

.divider {
  height: 1px; width: 80px; margin: 28px auto;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

/* ------------------- Service grid ------------------- */
.services {
  background: linear-gradient(180deg, #0a0709 0%, #100b13 100%);
}
.service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
.service-card {
  position: relative;
  background: var(--ink-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  display: flex;
  flex-direction: column;
}
.service-card:hover {
  transform: translateY(-6px);
  border-color: var(--gold);
  box-shadow: var(--shadow-md);
}
.service-img {
  aspect-ratio: 4 / 3;
  width: 100%;
  background-size: cover;
  background-position: center;
  background-color: var(--ink-3);
  position: relative;
}
.service-img::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(10,7,9,0.85));
}
.service-body { padding: 22px 24px 26px; flex: 1; display: flex; flex-direction: column; }
.service-body h3 { font-size: 1.35rem; margin-bottom: 10px; }
.service-body p { color: var(--cream-dim); font-size: 0.93rem; flex: 1; }
.service-body .more {
  display: inline-flex;
  align-items: center;
  margin-top: 14px;
  color: var(--gold);
  font-size: 0.78rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}
.service-body .more::after {
  content: "→";
  margin-left: 8px;
  transition: transform var(--transition);
}
.service-card:hover .more::after { transform: translateX(6px); }

/* Decorative tiles (gradient-only fallback when no image) */
.tile-samba { background: linear-gradient(135deg, #6b1a2d 0%, #c25b6f 100%); }
.tile-bolly { background: linear-gradient(135deg, #b06a0a 0%, #e8b65c 100%); }
.tile-burles { background: linear-gradient(135deg, #2a0712 0%, #6b1a2d 100%); }
.tile-circus { background: linear-gradient(135deg, #1a3a5a 0%, #4a7ba8 100%); }
.tile-show   { background: linear-gradient(135deg, #5a1747 0%, #c9a44a 100%); }
.tile-latin  { background: linear-gradient(135deg, #8c2317 0%, #d8714d 100%); }
.tile-rhythm { background: linear-gradient(135deg, #1d4536 0%, #6a8f5e 100%); }
.tile-sahara { background: linear-gradient(135deg, #2a0a3a 0%, #8a5fb8 100%); }
.tile-podium { background: linear-gradient(135deg, #112a55 0%, #c9a44a 100%); }
.tile-promo  { background: linear-gradient(135deg, #420a26 0%, #c25b6f 100%); }
.tile-roving { background: linear-gradient(135deg, #3a2010 0%, #c9a44a 100%); }
.tile-bespoke{ background: linear-gradient(135deg, #0a0a0a 0%, #6b1a2d 50%, #c9a44a 100%); }

.tile-label {
  position: absolute;
  top: 16px; left: 16px;
  font-family: var(--font-display);
  font-style: italic;
  color: rgba(255,255,255,0.85);
  font-size: 1.1rem;
  letter-spacing: 0.04em;
}

/* ------------------- About preview ------------------- */
.about-split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 64px;
  align-items: center;
}
.about-split .photo {
  aspect-ratio: 4 / 5;
  background: linear-gradient(135deg, #2a0712, #6b1a2d, #c9a44a);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
}
.about-split .photo::after {
  content: "EST. 2000";
  position: absolute;
  bottom: 20px; right: 20px;
  font-family: var(--font-display);
  font-size: 0.85rem;
  letter-spacing: 0.4em;
  color: var(--cream);
  padding: 6px 14px;
  border: 1px solid var(--gold);
  background: rgba(10,7,9,0.65);
}
.about-split .copy h2 { margin-bottom: 20px; }
.about-split .copy p { color: var(--cream-dim); }
.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.about-stats .stat .num {
  font-family: var(--font-display);
  font-size: 2.1rem;
  color: var(--gold);
}
.about-stats .stat .label {
  font-size: 0.7rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--cream-dim);
}

/* ------------------- Testimonials ------------------- */
.testimonials {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(107,26,45,0.4), transparent 60%),
    var(--ink);
}
.tq-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
}
.tq {
  background: var(--ink-2);
  border: 1px solid var(--line);
  padding: 30px 28px;
  border-radius: var(--radius);
  position: relative;
}
.tq::before {
  content: "“";
  position: absolute;
  top: -6px; left: 18px;
  font-family: var(--font-display);
  color: var(--gold);
  font-size: 4.5rem;
  line-height: 1;
}
.tq p { color: var(--cream-dim); margin-bottom: 16px; }
.tq .who { color: var(--gold); font-size: 0.85rem; letter-spacing: 0.18em; text-transform: uppercase; }
.tq .role { color: var(--cream-dim); font-size: 0.75rem; }

/* ------------------- CTA band ------------------- */
.cta-band {
  text-align: center;
  background:
    radial-gradient(ellipse at center, rgba(201,164,74,0.18), transparent 65%),
    linear-gradient(180deg, #0a0709, #14101a);
  padding: 80px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cta-band h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
.cta-band p { color: var(--cream-dim); max-width: 560px; margin: 0 auto 28px; }

/* ------------------- Clients ------------------- */
.clients-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 28px;
  align-items: center;
}
.client-mark {
  height: 60px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  display: grid;
  place-items: center;
  color: var(--cream-dim);
  font-family: var(--font-display);
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  background: rgba(255,255,255,0.02);
  transition: border-color var(--transition), color var(--transition);
}
.client-mark:hover { border-color: var(--gold); color: var(--gold); }

/* ------------------- Footer ------------------- */
footer {
  background: #050306;
  padding: 70px 0 30px;
  border-top: 1px solid var(--line);
}
.foot-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  gap: 40px;
}
.foot-grid h4 {
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 18px;
}
.foot-grid ul { list-style: none; padding: 0; margin: 0; }
.foot-grid li { margin-bottom: 10px; }
.foot-grid a { color: var(--cream-dim); font-size: 0.92rem; }
.foot-grid a:hover { color: var(--gold); }
.foot-grid p { color: var(--cream-dim); font-size: 0.92rem; }

.foot-bottom {
  margin-top: 50px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  color: var(--cream-dim);
  font-size: 0.82rem;
}
.socials a {
  display: inline-grid;
  place-items: center;
  width: 36px; height: 36px;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--cream-dim);
  margin-left: 8px;
  font-size: 0.8rem;
}
.socials a:hover { border-color: var(--gold); color: var(--gold); }

/* ------------------- Inner page hero ------------------- */
.page-hero {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(201,164,74,0.15), transparent 60%),
    linear-gradient(180deg, #06040a, #0a0709);
  padding: 110px 0 70px;
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.page-hero h1 { margin-bottom: 14px; }
.page-hero p { color: var(--cream-dim); max-width: 640px; margin: 0 auto; }

.breadcrumb {
  display: flex;
  justify-content: center;
  gap: 8px;
  color: var(--cream-dim);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.breadcrumb a { color: var(--gold); }

/* ------------------- Contact form ------------------- */
.contact-split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 56px;
  align-items: start;
}
.contact-info p { color: var(--cream-dim); margin-bottom: 8px; }
.contact-info h3 { color: var(--gold); margin-top: 26px; margin-bottom: 6px; font-family: var(--font-body); font-size: 0.8rem; letter-spacing: 0.3em; text-transform: uppercase; font-weight: 500; }
.contact-info a { color: var(--cream); }
.contact-info a:hover { color: var(--gold); }

form.enquire {
  background: var(--ink-2);
  border: 1px solid var(--line);
  padding: 36px;
  border-radius: var(--radius);
}
form.enquire .row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
form.enquire label {
  display: block;
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}
form.enquire input,
form.enquire select,
form.enquire textarea {
  width: 100%;
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--cream);
  font-family: var(--font-body);
  font-size: 0.95rem;
  transition: border-color var(--transition);
}
form.enquire input:focus,
form.enquire select:focus,
form.enquire textarea:focus {
  outline: none;
  border-color: var(--gold);
}
form.enquire textarea { min-height: 130px; resize: vertical; }
form.enquire .single { margin-bottom: 16px; }
.form-success {
  display: none;
  padding: 14px;
  background: rgba(201,164,74,0.12);
  border: 1px solid var(--gold);
  color: var(--gold);
  margin-bottom: 16px;
  border-radius: var(--radius);
}

/* ------------------- Gallery ------------------- */
.gallery-filters {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.gallery-filters button {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--cream-dim);
  padding: 10px 18px;
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: var(--radius);
  font-family: var(--font-body);
  transition: all var(--transition);
}
.gallery-filters button:hover,
.gallery-filters button.active {
  border-color: var(--gold);
  color: var(--gold);
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.gallery-tile {
  aspect-ratio: 3 / 4;
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  cursor: pointer;
  transition: transform var(--transition);
}
.gallery-tile:hover { transform: scale(1.02); }
.gallery-tile::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(10,7,9,0.7));
  opacity: 0;
  transition: opacity var(--transition);
}
.gallery-tile:hover::after { opacity: 1; }
.gallery-tile .gt-label {
  position: absolute;
  bottom: 14px; left: 14px;
  font-family: var(--font-display);
  font-style: italic;
  z-index: 2;
  color: var(--cream);
  opacity: 0;
  transition: opacity var(--transition);
}
.gallery-tile:hover .gt-label { opacity: 1; }

/* ------------------- About page ------------------- */
.about-rich {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.about-rich .photo-tall {
  aspect-ratio: 3 / 4;
  background: linear-gradient(135deg, #0a0709 0%, #6b1a2d 60%, #c9a44a 100%);
  border-radius: var(--radius);
}
.values-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 22px;
  margin-top: 60px;
}
.value-card {
  border: 1px solid var(--line);
  padding: 28px;
  border-radius: var(--radius);
  background: var(--ink-2);
}
.value-card h3 { font-size: 1.15rem; color: var(--gold); }
.value-card p { color: var(--cream-dim); font-size: 0.94rem; margin: 0; }

/* ------------------- Service detail page ------------------- */
.services-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 26px;
}

/* ------------------- Dancers page ------------------- */
.featured-dancer {
  display: grid;
  grid-template-columns: 0.95fr 1.1fr;
  gap: 60px;
  align-items: center;
  margin-bottom: 80px;
}
.featured-dancer .portrait {
  aspect-ratio: 3 / 4.4;
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(255,255,255,0.06), transparent 60%),
    linear-gradient(180deg, #1a1620 0%, #0a0709 100%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
}
.featured-dancer .portrait .silhouette {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 28%, rgba(201,164,74,0.15), transparent 50%),
    repeating-linear-gradient(45deg, transparent 0 8px, rgba(255,255,255,0.025) 8px 9px),
    repeating-linear-gradient(-45deg, transparent 0 8px, rgba(255,255,255,0.025) 8px 9px);
}
.featured-dancer .portrait::after {
  content: "PHOTO · jacinta.jpg";
  position: absolute;
  bottom: 16px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-body);
  font-size: 0.62rem;
  letter-spacing: 0.3em;
  color: rgba(255,255,255,0.25);
  text-transform: uppercase;
}
.featured-dancer.has-photo .portrait::after { display: none; }
.featured-dancer.has-photo .portrait .silhouette { display: none; }
.featured-dancer .portrait img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.featured-dancer .copy h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 6px;
}
.featured-dancer .copy .role {
  color: var(--gold);
  font-size: 0.82rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin-bottom: 20px;
  display: block;
}
.featured-dancer .copy p { color: var(--cream-dim); }
.dancer-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 22px 0 28px;
}
.dancer-tags span {
  border: 1px solid var(--line);
  padding: 6px 14px;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--cream-dim);
  border-radius: 999px;
}

.dancers-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 22px;
}
.dancer-card {
  background: var(--ink-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform var(--transition), border-color var(--transition);
}
.dancer-card:hover { transform: translateY(-4px); border-color: var(--gold); }
.dancer-card .pic {
  aspect-ratio: 3 / 4;
  position: relative;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(201,164,74,0.12), transparent 55%),
    linear-gradient(180deg, #1d1722 0%, #0a0709 100%);
}
.dancer-card .pic::after {
  content: attr(data-filename);
  position: absolute;
  bottom: 14px; left: 50%;
  transform: translateX(-50%);
  font-size: 0.6rem;
  letter-spacing: 0.28em;
  color: rgba(255,255,255,0.2);
  text-transform: uppercase;
}
.dancer-card.has-photo .pic::after { display: none; }
.dancer-card .pic img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 15%;
}
.dancer-card .meta {
  padding: 18px 20px 22px;
}
.dancer-card h3 {
  font-size: 1.15rem;
  margin-bottom: 4px;
}
.dancer-card .role-line {
  color: var(--gold);
  font-size: 0.7rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

@media (max-width: 880px) {
  .featured-dancer { grid-template-columns: 1fr; gap: 30px; }
}

/* ------------------- Video reels ------------------- */
.reels {
  background: linear-gradient(180deg, #100b13 0%, #06040a 100%);
}
.reels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}
.reel {
  position: relative;
  aspect-ratio: 9 / 16;
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--line);
  transition: transform var(--transition), border-color var(--transition);
  width: 100%;
}
.reel.landscape { aspect-ratio: 16 / 9; }
.reel:hover { transform: translateY(-4px); border-color: var(--gold); }
.reel .thumb {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-color: var(--ink-3);
  background-repeat: no-repeat;
}
.reel .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.reel::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,7,9,0.1) 0%, rgba(10,7,9,0.7) 100%);
  pointer-events: none;
}
.reel .play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 72px; height: 72px;
  background: rgba(201, 164, 74, 0.92);
  border-radius: 50%;
  display: grid;
  place-items: center;
  transition: transform var(--transition), background var(--transition);
  z-index: 2;
  box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
.reel:hover .play {
  background: var(--gold-soft);
  transform: translate(-50%, -50%) scale(1.08);
}
.reel .play::after {
  content: "";
  display: block;
  width: 0; height: 0;
  border-left: 18px solid var(--ink);
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
  margin-left: 5px;
}
.reel .reel-label {
  position: absolute;
  bottom: 16px; left: 18px; right: 18px;
  z-index: 2;
  font-family: var(--font-display);
  color: var(--cream);
  font-size: 1.05rem;
}
.reel .reel-tag {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.65rem;
  letter-spacing: 0.32em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 4px;
}

/* Decorative thumbs (used until real thumbnail/poster image is added) */
.thumb-show    { background: linear-gradient(135deg, #5a1747, #c9a44a); }
.thumb-burles  { background: linear-gradient(135deg, #2a0712, #6b1a2d); }
.thumb-samba   { background: linear-gradient(135deg, #6b1a2d, #c25b6f); }
.thumb-bolly   { background: linear-gradient(135deg, #b06a0a, #e8b65c); }
.thumb-circus  { background: linear-gradient(135deg, #1a3a5a, #4a7ba8); }
.thumb-sahara  { background: linear-gradient(135deg, #2a0a3a, #8a5fb8); }
.thumb-latin   { background: linear-gradient(135deg, #8c2317, #d8714d); }
.thumb-rhythm  { background: linear-gradient(135deg, #1d4536, #6a8f5e); }
.thumb-gatsby  { background: linear-gradient(135deg, #3a2a10, #c9a44a); }
.thumb-country { background: linear-gradient(135deg, #2a1a0a, #d87a3d); }
.thumb-roving  { background: linear-gradient(135deg, #3a2010, #c9a44a); }
.thumb-fire    { background: linear-gradient(135deg, #3a1a0a, #d87a3d); }
.thumb-burles  { background: linear-gradient(135deg, #2a0712, #6b1a2d); }
.thumb-xmas    { background: linear-gradient(135deg, #1a3a1a, #5aaa5a); }
.thumb-led     { background: linear-gradient(135deg, #2a3a4a, #8a9aaa); }

/* Lightbox / video modal */
.video-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.video-modal.open { display: flex; }
.video-modal-inner {
  width: 100%;
  max-width: 1100px;
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-lg);
}
.video-modal-inner iframe,
.video-modal-inner video {
  width: 100%; height: 100%;
  border: 0;
  display: block;
}
.video-modal-close {
  position: absolute;
  top: -42px; right: 0;
  background: none;
  border: 1px solid var(--gold);
  color: var(--gold);
  width: 34px; height: 34px;
  border-radius: 50%;
  font-size: 1.2rem;
  cursor: pointer;
  font-family: var(--font-body);
  line-height: 1;
  transition: background var(--transition), color var(--transition);
}
.video-modal-close:hover { background: var(--gold); color: var(--ink); }

/* ------------------- Show detail modal ------------------- */
.show-detail-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.95);
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  overflow-y: auto;
}
.show-detail-modal.open { display: flex; }
.show-detail-inner {
  width: 100%;
  max-width: 1200px;
  background: var(--ink-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 40px;
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
}
.show-detail-close {
  position: absolute;
  top: 20px; right: 20px;
  background: none;
  border: 1px solid var(--gold);
  color: var(--gold);
  width: 40px; height: 40px;
  border-radius: 50%;
  font-size: 1.4rem;
  cursor: pointer;
  font-family: var(--font-body);
  line-height: 1;
  transition: background var(--transition), color var(--transition);
  z-index: 2001;
}
.show-detail-close:hover { background: var(--gold); color: var(--ink); }
.show-detail-content h2 {
  margin-bottom: 32px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 16px;
  color: var(--gold);
}

/* Video section in detail */
.video-container {
  width: 100%;
  aspect-ratio: 16 / 9;
  margin-bottom: 40px;
  border-radius: var(--radius);
  overflow: hidden;
}
.video-container iframe,
.video-container video {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* Photo gallery */
.show-gallery {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.gallery-main {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.gallery-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(201,164,74,0.85);
  border: none;
  color: var(--ink);
  width: 50px; height: 50px;
  border-radius: 50%;
  font-size: 2rem;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background var(--transition);
  z-index: 10;
}
.gallery-arrow:hover { background: var(--gold); }
.gallery-prev { left: 16px; }
.gallery-next { right: 16px; }
.gallery-thumbnails {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 12px;
}
.gallery-thumb {
  aspect-ratio: 1;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--transition), transform var(--transition);
}
.gallery-thumb:hover,
.gallery-thumb.active {
  border-color: var(--gold);
  transform: scale(1.05);
}
.gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Hero video option (commented in HTML until you have a video file) */
.hero-video {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.55;
}
.hero.has-video::before { opacity: 0; }
.hero.has-video {
  background: #000;
}

/* ------------------- Responsive ------------------- */
@media (max-width: 980px) {
  .about-split,
  .about-rich,
  .contact-split { grid-template-columns: 1fr; gap: 36px; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 760px) {
  .topbar { display: none; }

  /* Tighter section spacing */
  section { padding: 48px 0 !important; }
  .page-hero { padding: 60px 0 36px !important; }
  .show-section { padding: 48px 0 !important; }
  .cta-band { padding: 52px 0 !important; }
  .benefits-section { padding: 48px 0 !important; margin: 32px 0 !important; }
  .related-section { margin: 40px 0 !important; }
  .section-head { margin-bottom: 32px !important; }
  .gallery-section { margin: 8px 0 40px !important; }
  .gallery-section h2 { margin-bottom: 24px !important; }
  .show-section h2 { margin-bottom: 24px !important; }

  /* Container tighter on small screens */
  .container { padding: 0 18px; }

  /* Dancer cards — 2 per row */
  .dancers-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .dancer-card .meta { padding: 12px 14px 16px; }
  .dancer-card h3 { font-size: 0.95rem; }
  .dancer-card .role-line { font-size: 0.62rem; }

  /* Service cards — 1 per row */
  .service-grid { grid-template-columns: 1fr !important; }

  /* Testimonials — 1 per row */
  .tq-grid { grid-template-columns: 1fr !important; }

  /* Form padding */
  form.enquire { padding: 22px 18px !important; }

  /* Buttons */
  .btn-lg { padding: 14px 24px !important; font-size: 0.78rem !important; }
  .btn { padding: 12px 22px; font-size: 0.75rem; }

  /* Show intro stacks */
  .show-intro { grid-template-columns: 1fr !important; gap: 28px !important; }

  /* About split */
  .about-split { gap: 28px !important; }

  /* Footer */
  footer { padding: 48px 0 24px; }

  nav.primary {
    position: fixed;
    top: 0; right: 0;
    height: 100vh;
    width: 78%;
    max-width: 320px;
    background: var(--ink);
    flex-direction: column;
    align-items: flex-start;
    padding: 90px 24px 30px;
    transform: translateX(100%);
    transition: transform var(--transition);
    box-shadow: var(--shadow-lg);
    z-index: 999;
  }
  nav.primary.open { transform: translateX(0); }
  nav.primary a { width: 100%; padding: 14px 0; border-bottom: 1px solid var(--line); }
  nav.primary a.active::after { display: none; }
  .menu-toggle { display: inline-block; z-index: 1001; }
  .hero { min-height: 78vh; }
  section { padding: 60px 0; }
  .foot-grid { grid-template-columns: 1fr; }
  .about-stats { grid-template-columns: 1fr 1fr 1fr; }
  form.enquire .row { grid-template-columns: 1fr; }
}

@media (max-width: 420px) {
  .nav-row { padding: 12px 0; }
  .brand-name { font-size: 1.2rem; }
  .brand-mark { width: 38px; height: 38px; }
  .about-stats { grid-template-columns: 1fr; }
}

/* ------------------- Mobile nav backdrop ------------------- */
.nav-backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 998;
}
.nav-backdrop.open { display: block; }

/* ------------------- Show detail page ------------------- */
.show-detail-hero {
  background: linear-gradient(180deg, #06040a 0%, #0a0709 100%);
  padding: 80px 0 60px;
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.show-detail-hero h1 {
  margin-bottom: 0;
  font-size: clamp(2rem, 4vw, 3.5rem);
}
.back-link {
  display: inline-block;
  margin-bottom: 32px;
  color: var(--gold);
  font-size: 0.9rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  transition: color var(--transition);
}
.back-link:hover { color: var(--cream); }

.show-section {
  padding: 90px 0;
}
.show-section h2 {
  margin-bottom: 48px;
  color: var(--gold);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
}

/* Gallery container */
.show-gallery-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}
.gallery-main {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.gallery-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(201,164,74,0.85);
  border: none;
  color: var(--ink);
  width: 60px;
  height: 60px;
  border-radius: 50%;
  font-size: 2.5rem;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background var(--transition);
  z-index: 10;
}
.gallery-arrow:hover { background: var(--gold); }
.gallery-prev { left: 20px; }
.gallery-next { right: 20px; }

.gallery-thumbnails {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 12px;
}
.gallery-thumb {
  aspect-ratio: 1;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--transition), transform var(--transition);
}
.gallery-thumb:hover,
.gallery-thumb.active {
  border-color: var(--gold);
  transform: scale(1.05);
}
.gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Video container */
.show-video-container {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.show-video-container iframe,
.show-video-container video {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 760px) {
  .show-detail-hero { padding: 60px 0 40px; }
  .gallery-arrow { width: 48px; height: 48px; font-size: 2rem; }
  .gallery-prev { left: 12px; }
  .gallery-next { right: 12px; }
}
