/**
 * Miami Cash for Gold — Apple-inspired motion & responsive media
 */

:root {
  --ease-apple: cubic-bezier(0.25, 0.1, 0.25, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --motion-duration: 0.85s;
  --motion-distance: 28px;
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --motion-duration: 0.01ms;
    --motion-distance: 0;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .reveal {
    opacity: 1 !important;
    transform: none !important;
  }
}

html {
  scroll-behavior: smooth;
}

/* ── Scroll reveal ── */
.reveal {
  opacity: 0;
  transform: translate3d(0, var(--motion-distance), 0);
  transition:
    opacity var(--motion-duration) var(--ease-out-expo),
    transform var(--motion-duration) var(--ease-out-expo);
  will-change: opacity, transform;
}

.reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.reveal-scale {
  opacity: 0;
  transform: scale(0.96);
  transition:
    opacity var(--motion-duration) var(--ease-out-expo),
    transform var(--motion-duration) var(--ease-out-expo);
}

.reveal-scale.is-visible {
  opacity: 1;
  transform: scale(1);
}

/* ── Service cards with images ── */
.service-card {
  overflow: hidden;
  transition:
    transform 0.55s var(--ease-apple),
    box-shadow 0.55s var(--ease-apple),
    border-color 0.45s var(--ease-apple);
}

.service-card:hover {
  transform: translateY(-6px);
}

.service-card__media {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  background: #0a0a0a;
  aspect-ratio: 4 / 3;
}

.service-card--carousel .service-card__media {
  min-height: 0;
}

.service-card__media--grid {
  aspect-ratio: 16 / 10;
  margin-bottom: 1.25rem;
}

.service-card__img,
.img-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.9s var(--ease-out-expo), opacity 0.6s var(--ease-apple);
}

.service-card:hover .service-card__img {
  transform: scale(1.05);
}

.service-card--carousel .product-img {
  min-height: 0 !important;
  font-size: inherit !important;
  padding: 0;
}

.what-we-buy-card__media {
  padding: 0 !important;
  min-height: 0 !important;
  font-size: inherit !important;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 12px;
  background: #0a0a0a;
}

.what-we-buy-card__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.9s var(--ease-out-expo), opacity 0.6s var(--ease-apple);
}

.what-we-buy-card:hover .what-we-buy-card__img {
  transform: scale(1.05);
}

.service-card--grid.feature-style {
  padding: 0;
  display: flex;
  flex-direction: column;
  text-align: left;
  border-radius: 14px;
  overflow: hidden;
  height: 100%;
}

.service-card--grid .service-card__media--grid {
  aspect-ratio: 16 / 10;
  margin-bottom: 0;
  border-radius: 0;
  flex-shrink: 0;
}

.service-card--grid .feature-style__title {
  padding: 1.15rem 1.25rem 0.5rem;
  margin-bottom: 0;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.service-card--grid .feature-style__text {
  padding: 0 1.25rem 1.25rem;
  margin-top: auto;
  margin-bottom: 0;
  line-height: 1.65;
}

/* ── Gallery & responsive media ── */
.grid-container .view-style img,
.img-box5 img,
.img-box4 img,
.img-box6 img,
.breadcumb-wrapper.background-image {
  transition: transform 1.1s var(--ease-out-expo), opacity 0.6s var(--ease-apple);
}

.grid-container .view-style {
  overflow: hidden;
}

.grid-container .view-style:hover img {
  transform: scale(1.04);
}

.media-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.media-responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

.img-loaded {
  opacity: 1;
}

img[data-src],
.service-card__img:not(.img-loaded) {
  opacity: 0;
}

img.img-loaded,
.service-card__img.img-loaded {
  opacity: 1;
}

/* ── Buttons & links — subtle press/hover ── */
.vs-btn,
.product-cart,
.view-link,
.main-menu a {
  transition:
    color 0.35s var(--ease-apple),
    background-color 0.35s var(--ease-apple),
    border-color 0.35s var(--ease-apple),
    box-shadow 0.35s var(--ease-apple),
    transform 0.25s var(--ease-apple);
}

.vs-btn:active {
  transform: scale(0.98);
}

/* Hero slide text — no motion.css fade that can leave slides hidden */
.hero-cinematic .hero-main.style3 .hero-content {
  animation: none !important;
  opacity: 1 !important;
  transform: none !important;
}

@keyframes heroContentIn {
  from {
    opacity: 0;
    transform: translate3d(0, 36px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* ── Mobile refinements ── */
@media (max-width: 767px) {
  :root {
    --motion-distance: 18px;
    --motion-duration: 0.65s;
  }

  .service-card:hover {
    transform: none;
  }

  .service-card:hover .service-card__img {
    transform: none;
  }

  .service-card__media--grid {
    aspect-ratio: 16 / 11;
  }
}

@media (max-width: 991px) {
  .product-carousel2 .service-card__media {
    aspect-ratio: 16 / 11;
  }
}
