/* ============================================================
   Mystik reskin — override layer (loads last).
   Flips remaining light surfaces to dark, makes CTAs gold-on-black,
   refines type, and adds the zodiac + newsletter components.
   ============================================================ */

/* ---- Atmospheric body backdrop: deep black + faint gold embers + stars ---- */
body {
  background-color: var(--black);
  position: relative;
}
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(60% 50% at 80% 0%, rgba(255,195,103,0.08), transparent 60%),
    radial-gradient(50% 50% at 0% 100%, rgba(120,90,180,0.07), transparent 60%),
    var(--black);
}
body::after { /* sparse starfield */
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.5;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(255,255,255,0.4), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(255,195,103,0.5), transparent),
    radial-gradient(1px 1px at 90% 20%, rgba(255,255,255,0.35), transparent),
    radial-gradient(1px 1px at 55% 15%, rgba(255,255,255,0.3), transparent);
  background-repeat: repeat;
  background-size: 600px 600px;
}

/* ---- Type refinements (Marcellus is a single 400 weight) ---- */
h1, h2, h3, h4 { font-weight: 400; letter-spacing: 0.005em; }
.hero__title .accent { font-style: normal; color: var(--gold); }
.eyebrow {
  font-family: var(--font-ui);
  color: var(--gold);
  letter-spacing: 0.28em;
}
.eyebrow--gold { color: var(--gold); }
.eyebrow--light { color: var(--gold-soft); }
.brand__name { letter-spacing: 0.02em; }

/* ---- Buttons: gold fill needs dark text ---- */
.btn--rose { color: #0a0a0a; }
.btn--rose:hover { color: #0a0a0a; }
.btn--outline { color: var(--warm-white); border-color: var(--gold); }
.btn--outline:hover { background: var(--gold); color: #0a0a0a; }
.btn--light { color: var(--warm-white); border-color: var(--gold-soft); }
.btn--light:hover { background: var(--gold-soft); color: #0a0a0a; }
::selection { background: var(--gold); color: #0a0a0a; }
.pagination .page-numbers.current { color: #0a0a0a; }
.skip-link { background: var(--gold); color: #0a0a0a; }

/* ---- Header / nav / drawer / sticky bar -> dark glass ---- */
.site-header { background: rgba(5,5,6,0.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.site-header.is-scrolled,
.site-header--transparent.is-scrolled { background: rgba(5,5,6,0.95); box-shadow: 0 12px 40px -24px rgba(0,0,0,0.9); }
.site-header__wave { display: none; }            /* drop the light wave under header */
.mobile-nav { background: #050506; }
.mobile-nav__list a { color: var(--warm-white); }
.sticky-call { background: rgba(5,5,6,0.94); border-top: 1px solid var(--line); }

/* ---- Cards & inputs -> dark surfaces ---- */
.field, .search-form__input {
  background: #0e0e11; color: var(--warm-white); border-color: var(--border);
}
.field::placeholder, .search-form__input::placeholder { color: var(--grey-soft); }
.field:focus, .search-form__input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--glow); }
label { color: var(--warm-white); }

.faq__item, .related-card, .value-card, .area-chip,
.service-aside__card, .mini-testi__item {
  background: var(--surface-1); border-color: var(--border);
}
.faq__q { color: var(--warm-white); }
.faq__a-inner { color: var(--grey); }
.badge { background: var(--surface-1); border: 1px solid var(--border); color: var(--warm-white); }
.value-card__icon, .contact__detail-icon, .related-card__icon { background: #0a0a0a; color: var(--gold); border: 1px solid var(--border); }

/* Sections: keep alt + night visibly distinct on black */
.section--alt { background: #08080a; border-block: 1px solid var(--line); }
.section--night { background: var(--bg-night); }
.cta-band, .page-hero, .hero { background: var(--aurora); }

/* Map frame */
.map-embed { background: #0a0a0a; border: 1px solid var(--border); }

/* Service rows / portrait masks on dark */
.service-row__mask, .post-card__mask, .intro__portrait, .about__portrait { background: #0a0a0a; }
.service-row__placeholder, .post-card__placeholder { color: var(--gold-soft); }

/* Links inside prose -> gold */
.prose a { color: var(--gold); text-decoration-color: rgba(255,195,103,0.4); }
.prose blockquote { border-left-color: var(--gold); color: var(--warm-white); }
a:hover { color: var(--gold); }

/* Step orbs + dividers a touch more golden */
.step__orb { border: 1px solid var(--gold-soft); }

/* Hero slider controls on dark */
.hero-slider__arrow { background: rgba(10,10,12,0.6); color: var(--warm-white); border: 1px solid var(--border); backdrop-filter: blur(6px); }
.hero-slider__arrow:hover { background: var(--gold); color: #0a0a0a; }
.hero-slider__viewport { border: 1px solid var(--border); }

/* Footer: brand + headings gold */
.site-footer { border-top: 1px solid var(--line); }
.site-footer__title { color: var(--gold); }
.nap__phone { color: var(--gold); }
.trust-strip__star { color: var(--gold); }

/* Custom scrollbar */
* { scrollbar-color: var(--gold-soft) #0a0a0a; }
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: #0a0a0a; }
::-webkit-scrollbar-thumb { background: #2a2a2a; border-radius: 8px; border: 2px solid #0a0a0a; }
::-webkit-scrollbar-thumb:hover { background: var(--gold-soft); }

/* ============================================================
   Full-bleed VERTICAL auto-slider hero (no title, no controls)
   ============================================================ */
/* Kill any horizontal overflow/wobble from off-screen decorative orbs.
   overflow-x: clip does NOT create a scroll container, so it won't break sticky. */
html, body { overflow-x: clip; max-width: 100%; }

.hero--full {
  min-height: 0;
  display: block;
  padding: 0;
  width: 100%;
  height: clamp(580px, 84vh, 880px);
  position: relative;
  overflow: hidden;
  background: #050507;
}
.has-transparent-header .hero--full { padding-top: 0; }

.hero-vslider { position: absolute; inset: 0; overflow: hidden; z-index: 1; }
.hero-vslider__track {
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform 0.9s var(--ease);
}
.hero-vslide { flex: 0 0 100%; width: 100%; height: 100%; margin: 0; position: relative; }
.hero-vslide picture { display: block; width: 100%; height: 100%; }
.hero-vslide img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
}

/* Top scrim for header legibility */
.hero--full::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: linear-gradient(180deg, rgba(2,2,3,0.70) 0%, rgba(2,2,3,0.10) 15%, transparent 32%);
}

/* Per-slide text overlay — real HTML, crisp & responsive on mobile + desktop */
.hero-vslide__content {
  position: absolute; inset: 0; z-index: 3;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: clamp(1.6rem, 5vw, 4.5rem);
  padding-top: calc(var(--header-h) + 1rem);
  background:
    linear-gradient(90deg, rgba(2,2,3,0.86) 0%, rgba(2,2,3,0.5) 40%, rgba(2,2,3,0.04) 76%, transparent 100%),
    linear-gradient(0deg, rgba(2,2,3,0.86) 0%, rgba(2,2,3,0.18) 36%, transparent 58%);
}
.hero-vslide__inner { max-width: 600px; }
.hero-vslide__eyebrow {
  font-family: var(--font-ui); text-transform: uppercase; letter-spacing: 0.26em;
  color: var(--gold); font-size: clamp(0.68rem, 2.6vw, 0.82rem); margin: 0 0 0.6rem;
}
.hero-vslide__title {
  font-family: var(--font-display); color: var(--warm-white); font-weight: 600;
  font-size: clamp(2.1rem, 8.5vw, 4.4rem); line-height: 1.03;
  margin: 0 0 0.7rem; text-shadow: 0 2px 26px rgba(0,0,0,0.75);
}
.hero-vslide__desc {
  font-family: var(--font-body); color: #ece4d6; font-weight: 600;
  font-size: clamp(1rem, 3.8vw, 1.35rem); line-height: 1.45;
  margin: 0 0 1.3rem; max-width: 34ch; text-shadow: 0 1px 14px rgba(0,0,0,0.85);
}
.hero-vslide__cta { display: flex; gap: 0.7rem; flex-wrap: wrap; }

@media (max-width: 768px) {
  .hero--full { height: 82vh; }
  .hero-vslide__cta .btn { flex: 1 1 auto; justify-content: center; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-vslider__track { transition: none; }
}

/* ============================================================
   Choose Your Zodiac Sign — daily horoscope
   ============================================================ */
.zodiac { position: relative; }
.zodiac__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0.9rem;
  margin-bottom: 2.5rem;
}
.zodiac-sign {
  display: flex; flex-direction: column; align-items: center; gap: 0.3rem;
  padding: 1.1rem 0.6rem; cursor: pointer;
  background: var(--surface-1); border: 1px solid var(--border); border-radius: var(--radius);
  color: var(--warm-white); text-align: center;
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease), box-shadow 0.3s var(--ease), background 0.3s var(--ease);
}
.zodiac-sign:hover { transform: translateY(-3px); border-color: var(--gold); box-shadow: 0 0 30px -8px var(--glow); }
.zodiac-sign.is-active { border-color: var(--gold); background: #11100c; box-shadow: 0 0 36px -8px var(--glow); }
.zodiac-sign__glyph { font-size: 2rem; line-height: 1; color: var(--gold); }
.zodiac-sign__name { font-family: var(--font-display); font-size: 1.05rem; }
.zodiac-sign__dates { font-size: 0.72rem; color: var(--grey-soft); letter-spacing: 0.02em; }

.zodiac__detail {
  display: grid; grid-template-columns: auto 1fr; gap: 1.5rem; align-items: center;
  background: var(--surface-1); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 4vw, 2.5rem); position: relative; overflow: hidden;
}
.zodiac__detail::before {
  content: ""; position: absolute; right: -40px; top: -40px; width: 220px; height: 220px;
  background: radial-gradient(circle, var(--glow), transparent 70%); pointer-events: none;
}
.zodiac__detail-glyph {
  width: 96px; height: 96px; display: grid; place-items: center;
  font-size: 3rem; color: var(--gold);
  border: 1px solid var(--gold-soft); border-radius: 50%;
  box-shadow: 0 0 40px -10px var(--glow);
}
.zodiac__detail-name { font-family: var(--font-display); font-size: 1.8rem; color: var(--warm-white); margin: 0; }
.zodiac__detail-dates { color: var(--gold); font-size: 0.9rem; letter-spacing: 0.04em; margin-bottom: 0.6rem; }
.zodiac__detail-text { color: var(--grey); margin: 0; }
.zodiac__detail-meta { font-size: 0.8rem; color: var(--grey-soft); margin-top: 0.8rem; }

@media (max-width: 1024px) { .zodiac__grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 600px) {
  .zodiac__grid { grid-template-columns: repeat(3, 1fr); gap: 0.6rem; }
  .zodiac__detail { grid-template-columns: 1fr; text-align: center; justify-items: center; }
}

/* ============================================================
   Vibrant services (more prominent imagery + gold interaction)
   ============================================================ */
.service-row__mask, .post-card__mask {
  border: 1px solid var(--border);
  box-shadow: 0 20px 55px -26px rgba(0,0,0,0.85);
  transition: border-color 0.4s var(--ease), box-shadow 0.4s var(--ease), transform 0.4s var(--ease);
}
.service-row:hover .service-row__mask,
.post-card:hover .post-card__mask {
  border-color: var(--gold-soft);
  box-shadow: 0 0 55px -10px var(--glow), 0 20px 55px -26px rgba(0,0,0,0.95);
}
.service-row__media::after { /* soft gold vignette over each service image */
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: linear-gradient(180deg, transparent 55%, rgba(2,2,3,0.55) 100%),
              radial-gradient(120% 80% at 80% 10%, rgba(255,195,103,0.10), transparent 60%);
}
.service-row__mask { position: relative; z-index: 0; }
.service-row__title a { color: var(--warm-white); transition: color 0.3s var(--ease); }
.service-row:hover .service-row__title a { color: var(--gold); }
.service-row__excerpt { color: var(--grey); }

/* Featured-services + archive section glow */
.service-list { position: relative; }
.featured-services .section-head h2,
.service-list + .section-cta { position: relative; }

/* Archive grid imagery taller / richer */
.service-row__mask { aspect-ratio: 3 / 2; }
.service-row__placeholder { color: var(--gold); }

/* ============================================================
   Image page-hero (services + locations) — photo bg + dark veil
   ============================================================ */
.page-hero--image { background: #050507; position: relative; }
.page-hero--image::before {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background-image: var(--hero-img);
  background-size: cover; background-position: center;
}
.page-hero--image::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(2,2,3,0.78) 0%, rgba(2,2,3,0.55) 45%, rgba(2,2,3,0.85) 100%);
}
.page-hero--image .page-hero__inner { position: relative; z-index: 2; }

/* ============================================================
   Service mini-grid (on location pages)
   ============================================================ */
.svc-mini-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
}
.svc-mini {
  display: block; background: var(--surface-1); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.svc-mini:hover { border-color: var(--gold-soft); transform: translateY(-3px); box-shadow: 0 0 40px -12px var(--glow); }
.svc-mini__media { display: block; aspect-ratio: 4/3; overflow: hidden; background: #0a0a0a; }
.svc-mini__media img { width: 100%; height: 100%; object-fit: cover; }
.svc-mini__ph { display: grid; place-items: center; height: 100%; color: var(--gold); }
.svc-mini__title { display: block; padding: 0.9rem 1rem; font-family: var(--font-display); color: var(--warm-white); font-size: 1.05rem; }
.svc-mini:hover .svc-mini__title { color: var(--gold); }
@media (max-width: 760px) { .svc-mini-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .svc-mini-grid { grid-template-columns: 1fr; } }

/* ============================================================
   Areas served grid (home + /areas/ + locations page)
   ============================================================ */
.areas-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.9rem; }
a.area-chip {
  display: block; background: var(--surface-1); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 1.1rem 1.2rem; text-decoration: none;
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
a.area-chip:hover { border-color: var(--gold); transform: translateY(-3px); box-shadow: 0 0 30px -10px var(--glow); }
.area-chip__name { font-family: var(--font-display); font-size: 1.1rem; color: var(--warm-white); display: flex; align-items: center; gap: 0.5rem; }
.area-chip__name svg { color: var(--gold); }
a.area-chip:hover .area-chip__name { color: var(--gold); }
.area-chip__note { display: block; font-size: 0.82rem; color: var(--grey-soft); margin-top: 0.3rem; }
@media (max-width: 900px) { .areas-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 620px) { .areas-grid { grid-template-columns: 1fr 1fr; } }

.areas-inline { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.areas-inline__link {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: var(--surface-1); border: 1px solid var(--border); border-radius: var(--radius-pill);
  padding: 0.5rem 1rem; font-size: 0.9rem; color: var(--warm-white);
}
.areas-inline__link svg { color: var(--gold); width: 15px; height: 15px; }
.areas-inline__link:hover { border-color: var(--gold); color: var(--gold); }

/* Tame the intro / about portrait height on small screens */
@media (max-width: 880px) {
  .intro__portrait, .about__portrait { aspect-ratio: 16/12; max-height: 60vh; }
}

/* ============================================================
   WhatsApp button + floating contact widget
   ============================================================ */
.btn--whatsapp { background: #25D366; color: #fff; border-color: #25D366; }
.btn--whatsapp:hover { background: #1eb558; color: #fff; }

/* Old mobile sticky bar removed; reclaim its body padding */
.sticky-call { display: none !important; }
@media (max-width: 700px) { body { padding-bottom: 0 !important; } }

.float-contact {
  position: fixed; right: 16px; bottom: 16px; z-index: 200;
  display: flex; flex-direction: column; align-items: flex-end; gap: 12px;
}
.float-contact__btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0;
  height: 56px; min-width: 56px; padding: 0 16px;
  border-radius: 999px; color: #fff; font-family: var(--font-ui); font-weight: 600;
  box-shadow: 0 12px 30px -8px rgba(0,0,0,0.6);
  position: relative; white-space: nowrap;
  transition: gap 0.3s var(--ease), background 0.3s var(--ease), transform 0.2s var(--ease);
}
.float-contact__btn:hover { transform: translateY(-2px); }
.float-contact__btn svg { flex: 0 0 auto; width: 24px; height: 24px; }
.float-contact__btn--wa { background: #25D366; }
.float-contact__btn--wa:hover { background: #1eb558; color: #fff; }
.float-contact__btn--call { background: var(--gold); color: #0a0a0a; }
.float-contact__btn--call:hover { background: var(--gold-deep); color: #0a0a0a; }

/* Label hidden by default → reveals on hover/focus (desktop) */
.float-contact__label { max-width: 0; overflow: hidden; opacity: 0; transition: max-width 0.35s var(--ease), opacity 0.25s, margin 0.35s; }
.float-contact__btn:hover .float-contact__label,
.float-contact__btn:focus-visible .float-contact__label { max-width: 150px; opacity: 1; margin-left: 0.55rem; }

/* Pulse rings */
.float-contact__btn::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  animation: ajay-ring 2.4s ease-out infinite;
}
.float-contact__btn--wa::after { box-shadow: 0 0 0 0 rgba(37,211,102,0.5); }
.float-contact__btn--call::after { box-shadow: 0 0 0 0 rgba(255,195,103,0.5); animation-delay: 1.2s; }
@keyframes ajay-ring {
  0% { box-shadow: 0 0 0 0 rgba(37,211,102,0.5); }
  70% { box-shadow: 0 0 0 16px rgba(37,211,102,0); }
  100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); }
}
.float-contact__btn--call::after { animation-name: ajay-ring-gold; }
@keyframes ajay-ring-gold {
  0% { box-shadow: 0 0 0 0 rgba(255,195,103,0.5); }
  70% { box-shadow: 0 0 0 16px rgba(255,195,103,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,195,103,0); }
}
@media (prefers-reduced-motion: reduce) { .float-contact__btn::after { animation: none; } }

/* On small screens collapse to icon-only circles so they don't crowd content */
@media (max-width: 700px) {
  .float-contact { right: 12px; bottom: 12px; gap: 10px; }
  .float-contact__btn { padding: 0; min-width: 52px; height: 52px; }
  .float-contact__label { display: none; }
}

/* ============================================================
   Newsletter strip
   ============================================================ */
.newsletter { position: relative; overflow: hidden; }
.newsletter__inner {
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center;
  background: linear-gradient(120deg, #0c0a06, #0a0a0c); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: clamp(1.8rem, 4vw, 3rem);
}
.newsletter__title { color: var(--warm-white); margin-bottom: 0.4rem; }
.newsletter__lead { color: var(--grey); margin: 0; }
.newsletter__form { display: flex; gap: 0.6rem; }
.newsletter__form .field { flex: 1; }
@media (max-width: 760px) {
  .newsletter__inner { grid-template-columns: 1fr; }
  .newsletter__form { flex-direction: column; }
}
