/* ============================================
   HOME — AURA layout (scoped to .page--home)
   ============================================ */

.page--home {
  --aura-pad: clamp(3rem, 8vw, 9.5rem);
  font-family: 'Jost', var(--font-sans);
}

.page--home .main-content {
  position: relative;
  z-index: 1;
  padding-top: 0;
}

/* ---- Animations ---- */
@keyframes home-hero-glow-drift {
  0%, 100% {
    transform: translate3d(-28%, 14%, 0) rotate(-28deg) scale(0.9);
    opacity: 0.72;
  }
  20% {
    transform: translate3d(10%, -22%, 0) rotate(-8deg) scale(1.14);
    opacity: 1;
  }
  42% {
    transform: translate3d(38%, 8%, 0) rotate(18deg) scale(1.1);
    opacity: 0.96;
  }
  62% {
    transform: translate3d(22%, 32%, 0) rotate(26deg) scale(0.88);
    opacity: 0.78;
  }
  82% {
    transform: translate3d(-14%, 24%, 0) rotate(4deg) scale(1.06);
    opacity: 0.9;
  }
}

@keyframes home-fade-up {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

.page--home .home-fu { animation: home-fade-up 1s ease both; }
.page--home .home-fu--2 { animation-delay: 0.22s; }
.page--home .home-fu--3 { animation-delay: 0.44s; }

@media (prefers-reduced-motion: reduce) {
  .page--home .home-fu,
  .page--home .home-fu--2,
  .page--home .home-fu--3,
  .page--home .home-hero__glow-orbit {
    animation: none;
  }

  .page--home .masseuse-card__photo-wrap::before,
  .page--home .masseuse-card__photo {
    transition: none;
  }
}

/* ---- Shared primitives ---- */
.page--home .home-gline {
  display: block;
  width: clamp(2rem, 5vw, 3rem);
  height: 1px;
  background: var(--aura-gold);
  flex-shrink: 0;
}

.page--home .home-label {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
}

.page--home .home-label__text {
  font-size: 0.5625rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--aura-gold);
  font-weight: 300;
}

.page--home .home-label__num {
  opacity: 0.5;
  margin-right: 0.5rem;
}

.page--home .home-section {
  padding-block: var(--aura-pad);
  position: relative;
  overflow: hidden;
}

.page--home #masseuses {
  overflow: visible;
}

.page--home .home-section--dark,
.page--home .home-section--surface,
.page--home .home-section--cta {
  background: transparent;
}

.page--home .home-section__inner {
  max-width: 75rem;
  margin-inline: auto;
}

.page--home .home-section__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: clamp(2rem, 5vw, 3.75rem);
}

.page--home .home-section__title {
  font-size: clamp(1.875rem, 4vw, 3.625rem);
  font-weight: 200;
  letter-spacing: -0.025em;
  color: var(--aura-cream);
  line-height: 1.05;
  margin: 0;
}

.page--home .home-section__title--solo {
  margin-bottom: clamp(2rem, 5vw, 3.75rem);
}

.page--home .section__more {
  color: var(--aura-gold);
  font-size: 0.6875rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  font-weight: 300;
}

.page--home .section__more:hover {
  color: var(--aura-gold-light);
}

/* ---- Hero ---- */
.page--home .home-hero {
  position: relative;
  min-height: 100dvh;
  min-height: -webkit-fill-available;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: transparent;
  padding-block: clamp(2rem, 5vw, 4rem);
  text-align: center;
}

.page--home .home-hero__glow {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}

.page--home .home-hero__glow-orbit {
  position: absolute;
  left: 50%;
  top: 46%;
  width: min(88vw, 46rem);
  height: min(62vh, 32rem);
  margin-left: calc(min(88vw, 46rem) * -0.5);
  margin-top: calc(min(62vh, 32rem) * -0.5);
  border-radius: 48% 52% 54% 46% / 52% 46% 54% 48%;
  background:
    radial-gradient(
      ellipse 72% 58% at 44% 42%,
      rgba(232, 205, 155, 0.13) 0%,
      rgba(218, 175, 140, 0.07) 32%,
      transparent 58%
    ),
    radial-gradient(
      ellipse 95% 75% at 58% 48%,
      rgba(205, 145, 155, 0.07) 0%,
      rgba(190, 130, 145, 0.035) 38%,
      transparent 68%
    ),
    radial-gradient(
      ellipse 110% 85% at 50% 50%,
      rgba(200, 169, 110, 0.05) 0%,
      transparent 72%
    );
  filter: blur(52px);
  -webkit-filter: blur(52px);
  opacity: 0.92;
  transform-origin: center center;
  will-change: transform;
  animation: home-hero-glow-drift 20s ease-in-out infinite;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.page--home .home-hero__inner {
  position: relative;
  z-index: 2;
  max-width: 52rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.page--home .home-hero__eyebrow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.125rem;
  margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
}

.page--home .hero__eyebrow {
  margin: 0;
  font-size: 0.5625rem;
  letter-spacing: 0.38em;
  color: var(--aura-gold);
  font-weight: 300;
  text-transform: uppercase;
}

.page--home .hero__title {
  font-family: 'Jost', var(--font-sans);
  font-size: clamp(2.5rem, 8vw, 4.75rem);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--aura-cream);
  line-height: 1.05;
  margin: 0 0 clamp(1.25rem, 3vw, 2.25rem);
}

.page--home .hero__title-accent {
  display: block;
  color: var(--aura-gold-light);
  font-style: normal;
  font-weight: 200;
}

.page--home .hero__lead {
  font-size: clamp(0.875rem, 2vw, 1rem);
  color: var(--aura-cream-dim);
  font-weight: 300;
  line-height: 1.75;
  max-width: 42ch;
  margin: 0 auto clamp(1.75rem, 4vw, 3.5rem);
}

.page--home .hero__cta {
  margin-top: 0;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.page--home .hero__bullets {
  color: var(--aura-cream-dim);
  font-size: 0.8125rem;
  font-weight: 300;
}

.page--home .hero__bullets li::before {
  color: var(--aura-gold);
}

.page--home .home-hero__divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.125rem;
  margin-top: clamp(2rem, 5vw, 3.5rem);
}

.page--home .home-hero__star {
  font-size: 0.5rem;
  color: var(--aura-cream-faint);
}

/* ---- Hero / CTA buttons (layout only; visuals in btn-aura.css) ---- */
.page--home .hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  align-items: center;
}

.page--home .hero__cta a.btn.btn--aura {
  min-height: 44px;
}

.page--home .home-cta a.btn.btn--aura {
  margin-top: 0.5rem;
}

@media (max-width: 600px) {
  .page--home .hero__cta {
    flex-direction: column;
    align-items: center;
    padding-inline: var(--sp-2);
  }

  .page--home .hero__cta a.btn.btn--aura {
    box-sizing: border-box;
    width: 100%;
    max-width: 17.5rem;
    padding-inline: 1rem;
    padding-block: 0.7rem;
    font-size: 10px;
    letter-spacing: 0.12em;
    text-align: center;
    white-space: normal;
    line-height: 1.35;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }
}

html[lang="ru"] .page--home .hero__cta a.btn.btn--aura,
html[lang="uk"] .page--home .hero__cta a.btn.btn--aura {
  max-width: 18rem;
  letter-spacing: 0.1em;
}

@media (max-width: 360px) {
  .page--home .hero__cta a.btn.btn--aura {
    max-width: 100%;
    padding-inline: 0.875rem;
    font-size: 9px;
    letter-spacing: 0.1em;
  }
}

/* ---- Services grid (home layout) ---- */
.page--home .home-massage-grid {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-4);
}

.page--home .massage-card__image {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

/* Masseuse arch cards: masseuse-card-arch.css (.masseuse-bento--arch) */

/* ---- Gallery bento ---- */
.page--home .home-gallery {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: clamp(10rem, 22vw, 15.5rem) clamp(10rem, 22vw, 15.5rem);
  gap: 0.5rem;
}

.page--home .home-gallery__item {
  margin: 0;
  overflow: hidden;
  position: relative;
  background: var(--aura-bg);
}

.page--home .home-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  -webkit-user-drag: none;
  user-select: none;
}

.page--home .home-gallery__item--1 {
  grid-row: 1 / span 2;
}

.page--home .home-gallery__item--4 {
  grid-column: 2 / span 2;
}

/* ---- Reviews ---- */
.page--home .home-section--reviews::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(85vw, 60rem);
  height: min(85vw, 60rem);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200, 169, 110, 0.04), transparent 60%);
  pointer-events: none;
}

.page--home .home-review__text {
  font-size: 0.9375rem;
  font-weight: 200;
  font-style: italic;
  color: var(--aura-cream);
  line-height: 1.74;
  margin: 0 0 1.75rem;
}

.page--home .home-review__meta {
  font-size: 0.5625rem;
  color: var(--aura-gold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 300;
}

.page--home .home-reviews__google {
  margin: clamp(2rem, 5vw, 3rem) 0 0;
  text-align: center;
  position: relative;
  z-index: 1;
}

.page--home .home-reviews__google a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.5rem 1.25rem;
  font-size: 0.5625rem;
  font-weight: 300;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--aura-gold);
  text-decoration: none;
  border: 1px solid rgba(200, 169, 110, 0.28);
  border-radius: 0;
  -webkit-tap-highlight-color: transparent;
  transition: color 0.25s ease, border-color 0.25s ease, background-color 0.25s ease;
}

@media (hover: hover) {
  .page--home .home-reviews__google a:hover,
  .page--home .home-reviews__google a:focus-visible {
    color: var(--aura-cream);
    border-color: rgba(200, 169, 110, 0.5);
    background-color: rgba(200, 169, 110, 0.06);
  }
}

/* FAQ on home: global faq-accordion.css */

/* ---- CTA ---- */
.page--home .home-cta {
  max-width: 42rem;
  margin-inline: auto;
  text-align: center;
}

.page--home .home-cta h2 {
  font-family: 'Jost', var(--font-sans);
  font-weight: 200;
  color: var(--aura-cream);
}

.page--home .home-cta p {
  color: var(--aura-cream-dim);
  font-weight: 300;
}

/* ---- Tablet ---- */
@media (max-width: 1024px) {
  .page--home .home-hero__glow-orbit {
    width: min(92vw, 40rem);
    height: min(58vh, 28rem);
    margin-left: calc(min(92vw, 40rem) * -0.5);
    margin-top: calc(min(58vh, 28rem) * -0.5);
    filter: blur(46px);
    -webkit-filter: blur(46px);
  }
}

@media (max-width: 768px) {
  .page--home .home-massage-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--sp-3);
  }

  .page--home .home-hero {
    padding-block: clamp(1.5rem, 4vw, 2.5rem);
  }

  .page--home .home-hero__glow-orbit {
    width: min(96vw, 36rem);
    height: min(52vh, 22rem);
    margin-left: calc(min(96vw, 36rem) * -0.5);
    margin-top: calc(min(52vh, 22rem) * -0.5);
    filter: blur(40px);
    -webkit-filter: blur(40px);
    opacity: 0.88;
    animation-duration: 24s;
  }

  .page--home .hero__cta {
    flex-direction: column;
    align-items: center;
    width: 100%;
    gap: 0.75rem;
  }

  .page--home .hero__cta a.btn.btn--aura {
    box-sizing: border-box;
    width: 100%;
    max-width: 17.5rem;
    padding-inline: 1rem;
    padding-block: 0.7rem;
    font-size: 10px;
    letter-spacing: 0.12em;
    white-space: normal;
    line-height: 1.35;
    overflow-wrap: anywhere;
    word-break: break-word;
    justify-content: center;
    text-align: center;
  }

  @media (hover: hover) {
    .page--home .masseuse-card:hover .masseuse-card__photo,
    .page--home .masseuse-card:focus-within .masseuse-card__photo {
      transform: scale(1.04);
    }
  }

  .page--home .home-gallery {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }

  .page--home .home-gallery__item--1 {
    grid-row: auto;
    grid-column: 1 / -1;
    aspect-ratio: 16 / 10;
  }

  .page--home .home-gallery__item--2,
  .page--home .home-gallery__item--3 {
    aspect-ratio: 1;
  }

  .page--home .home-gallery__item--4 {
    grid-column: 1 / -1;
    aspect-ratio: 16 / 10;
  }

  .page--home .home-section__header {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 480px) {
  .page--home .masseuse-bento {
    grid-template-columns: 1fr;
  }

  .page--home .home-massage-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--sp-3);
  }

  .page--home .home-gallery {
    grid-template-columns: 1fr;
  }

  .page--home .home-gallery__item--2,
  .page--home .home-gallery__item--3,
  .page--home .home-gallery__item--4 {
    aspect-ratio: 16 / 10;
  }
}

@supports (-webkit-touch-callout: none) {
  .page--home .home-gallery__item img {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }

  .page--home .masseuse-card__photo-wrap {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
