/* =========================================================
   Maison Aurea — Luxury Animations
   ========================================================= */

/* --- Page load fade-in --- */
body:not(.is-ready) .site-main,
body:not(.is-ready) .site-header,
body:not(.is-ready) .site-footer {
  opacity: 0;
}

body.is-ready .site-main,
body.is-ready .site-header,
body.is-ready .site-footer {
  opacity: 1;
  transition: opacity 800ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* --- Base hidden states --- */
.animate-on-scroll,
.text-reveal,
.card-reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 900ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 900ms cubic-bezier(0.22, 1, 0.36, 1);
}

.heading-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1100ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 1100ms cubic-bezier(0.22, 1, 0.36, 1);
}

.animate-image {
  opacity: 0;
  transform: translateY(28px) scale(0.97);
  transition: opacity 1000ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 1000ms cubic-bezier(0.22, 1, 0.36, 1);
}

.grid-reveal-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 800ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 800ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* --- Visible state --- */
.is-visible {
  opacity: 1 !important;
  transform: none !important;
}

/* --- Image hover zoom --- */
.image-zoom-wrap {
  overflow: hidden;
}

.image-zoom-wrap img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1100ms cubic-bezier(0.22, 1, 0.36, 1),
              opacity 800ms ease;
}

.image-zoom-wrap:hover img {
  transform: scale(1.06);
}

/* --- Card hover lift --- */
.codex__card,
.heritage__image-wrap,
.commissions-card {
  transition: transform 400ms cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 400ms cubic-bezier(0.22, 1, 0.36, 1);
}

.codex__card:hover,
.heritage__image-wrap:hover {
  transform: translateY(-8px);
  box-shadow: 0 32px 64px rgba(15, 26, 43, 0.14);
}

.commissions-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px rgba(15, 26, 43, 0.12);
}

/* --- Enquiry pill transition --- */
.enquiry-pill {
  transition: background 300ms cubic-bezier(0.22, 1, 0.36, 1),
              color 300ms cubic-bezier(0.22, 1, 0.36, 1),
              border-color 300ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* --- Button hover shimmer --- */
.enquiry-submit,
.commissions-cta__button,
.about-result__button {
  position: relative;
  overflow: hidden;
  transition: background 400ms cubic-bezier(0.22, 1, 0.36, 1),
              color 400ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 300ms cubic-bezier(0.22, 1, 0.36, 1);
}

.enquiry-submit::after,
.commissions-cta__button::after,
.about-result__button::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.08);
  opacity: 0;
  transition: opacity 300ms ease;
}

.enquiry-submit:hover::after,
.commissions-cta__button:hover::after,
.about-result__button:hover::after {
  opacity: 1;
}

.enquiry-submit:hover,
.commissions-cta__button:hover,
.about-result__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(198, 167, 94, 0.25);
}

/* --- Nav link underline slide --- */
.site-nav__list a,
.menu-drawer__list a {
  position: relative;
}

.site-nav__list a::after,
.menu-drawer__list a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: currentColor;
  transition: width 400ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-nav__list a:hover::after,
.site-nav__list a.is-active::after,
.menu-drawer__list a:hover::after {
  width: 100%;
}

/* --- Section fade-in stagger for process items --- */
.process-item:nth-child(2) { transition-delay: 120ms; }
.process-item:nth-child(3) { transition-delay: 240ms; }

/* --- About pillars stagger --- */
.about-pillars .text-reveal:nth-child(1) { transition-delay: 0ms; }
.about-pillars .text-reveal:nth-child(2) { transition-delay: 140ms; }
.about-pillars .text-reveal:nth-child(3) { transition-delay: 280ms; }

/* --- Gold cursor --- */
.cursor-dot,
.cursor-ring {
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  will-change: transform;
}

.cursor-dot {
  width: 6px;
  height: 6px;
  background: rgba(198, 167, 94, 1);
  transition: width 200ms ease, height 200ms ease, background 200ms ease;
}

.cursor-ring {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(198, 167, 94, 0.6);
  transition: width 300ms cubic-bezier(0.22, 1, 0.36, 1),
              height 300ms cubic-bezier(0.22, 1, 0.36, 1),
              border-color 300ms ease,
              opacity 300ms ease;
}

.cursor-ring.is-hovering {
  width: 46px;
  height: 46px;
  border-color: rgba(198, 167, 94, 0.9);
}

.cursor-dot.is-hovering {
  width: 4px;
  height: 4px;
  background: rgba(198, 167, 94, 0.7);
}

@media (pointer: coarse), (max-width: 767px) {
  .cursor-dot,
  .cursor-ring {
    display: none;
  }
}

/* --- Parallax image subtle shift --- */
.heritage__image,
.codex__image {
  transition: transform 0.1s linear;
  will-change: transform;
}

/* --- Slow line reveal --- */
.philosophy__divider,
.about-line,
.commissions-divider,
.enquiry-info__line,
.enquiry-hero__divider,
.commissions-cta__line {
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 1000ms cubic-bezier(0.22, 1, 0.36, 1);
}

.is-visible .philosophy__divider,
.is-visible .about-line,
.philosophy__divider.is-visible,
.about-line.is-visible,
.commissions-divider.is-visible,
.enquiry-info__line.is-visible,
.enquiry-hero__divider.is-visible,
.commissions-cta__line.is-visible {
  transform: scaleX(1);
}

/* --- Header transition --- */
.site-header {
  transition: background 500ms cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 500ms cubic-bezier(0.22, 1, 0.36, 1),
              padding 500ms cubic-bezier(0.22, 1, 0.36, 1);
}
