/* Subscription pages — entrance & hover motion */

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

@keyframes sub-scale-in {
  from {
    opacity: 0;
    transform: scale(0.96) translateY(12px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes sub-hero-zoom {
  from {
    transform: scale(1.08);
  }
  to {
    transform: scale(1);
  }
}

@keyframes sub-shine {
  from {
    background-position: 200% center;
  }
  to {
    background-position: -200% center;
  }
}

@keyframes sub-progress-fill {
  from {
    width: 0;
  }
}

@keyframes sub-marker-pop {
  0% {
    opacity: 0;
    transform: scale(0.6);
  }
  70% {
    transform: scale(1.08);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* Shared motion host (JS adds .is-visible after content loads) */
.fishme-sub-motion-host:not(.is-visible) .fishme-sub-reveal {
  opacity: 0;
}

.fishme-sub-motion-host.is-visible .fishme-sub-reveal {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-motion-host.is-visible .fishme-sub-reveal--scale {
  animation-name: sub-scale-in;
}

/* Subscription index */
.fishme-subscriptions-index-head {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-subscriptions-index-head h1 {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.05s both;
}

.fishme-subscriptions-index-head p {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.1s both;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card {
  animation: sub-scale-in 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card:nth-child(1) {
  animation-delay: 0.06s;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card:nth-child(2) {
  animation-delay: 0.12s;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card:nth-child(3) {
  animation-delay: 0.18s;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card:nth-child(4) {
  animation-delay: 0.24s;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card:nth-child(5) {
  animation-delay: 0.3s;
}

.fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card:nth-child(6) {
  animation-delay: 0.36s;
}

.fishme-sub-motion-host.is-visible > .col:nth-child(1) .fishme-subscriptions-index-card,
.fishme-sub-motion-host.is-visible > [class*='col-']:nth-child(1) .fishme-subscriptions-index-card {
  animation-delay: 0.06s;
}

.fishme-sub-motion-host.is-visible > .col:nth-child(2) .fishme-subscriptions-index-card,
.fishme-sub-motion-host.is-visible > [class*='col-']:nth-child(2) .fishme-subscriptions-index-card {
  animation-delay: 0.12s;
}

.fishme-sub-motion-host.is-visible > .col:nth-child(3) .fishme-subscriptions-index-card,
.fishme-sub-motion-host.is-visible > [class*='col-']:nth-child(3) .fishme-subscriptions-index-card {
  animation-delay: 0.18s;
}

.fishme-sub-motion-host.is-visible > .col:nth-child(4) .fishme-subscriptions-index-card,
.fishme-sub-motion-host.is-visible > [class*='col-']:nth-child(4) .fishme-subscriptions-index-card {
  animation-delay: 0.24s;
}

.fishme-subscriptions-index-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  border: 1px solid #ececec;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  transition:
    transform 0.3s ease,
    border-color 0.3s ease,
    box-shadow 0.3s ease;
}

.fishme-subscriptions-index-card:hover {
  transform: translateY(-6px);
  border-color: rgba(192, 2, 8, 0.28);
  box-shadow: 0 16px 36px rgba(31, 31, 37, 0.1);
}

.fishme-subscriptions-index-card__media {
  display: block;
  overflow: hidden;
  height: 220px;
}

.fishme-subscriptions-index-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.fishme-subscriptions-index-card:hover .fishme-subscriptions-index-card__media img {
  transform: scale(1.06);
}

.fishme-subscriptions-index-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 10px;
  padding: 20px;
}

.fishme-subscriptions-index-card__meta {
  margin: 0;
  font-size: 13px;
  color: var(--color-body);
}

.fishme-subscriptions-index-card__title {
  margin: 0;
  font-size: 20px;
  color: var(--color-heading-1);
}

.fishme-subscriptions-index-card__desc {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--color-body);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fishme-subscriptions-index-card__price {
  margin: 0;
  font-size: 18px;
  color: var(--color-heading-1);
}

.fishme-subscriptions-index-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.fishme-subscriptions-index-card__cta:hover {
  transform: translateX(4px);
}

.fishme-subscriptions-index-card__cta i {
  transition: transform 0.25s ease;
}

.fishme-subscriptions-index-card:hover .fishme-subscriptions-index-card__cta i {
  transform: translateX(3px);
}

/* Plan detail page */
.fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero {
  animation: sub-fade-up 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__image {
  animation: sub-hero-zoom 1.1s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__badges {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.12s both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__title {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.18s both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__desc {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.24s both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-stat {
  animation: sub-scale-in 0.5s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-stat:nth-child(1) {
  animation-delay: 0.28s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-stat:nth-child(2) {
  animation-delay: 0.34s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-stat:nth-child(3) {
  animation-delay: 0.4s;
}

.fishme-subscription-plan-stat {
  transition:
    transform 0.3s ease,
    border-color 0.3s ease,
    box-shadow 0.3s ease;
}

.fishme-subscription-plan-stat:hover {
  transform: translateY(-4px);
  border-color: rgba(192, 2, 8, 0.22);
  box-shadow: 0 10px 24px rgba(31, 31, 37, 0.07);
}

.fishme-subscription-plan-stat__icon {
  transition: transform 0.3s ease, background 0.3s ease;
}

.fishme-subscription-plan-stat:hover .fishme-subscription-plan-stat__icon {
  transform: scale(1.08);
  background: rgba(192, 2, 8, 0.14);
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-section {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.42s both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery {
  animation: sub-fade-up 0.5s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery:nth-child(1) {
  animation-delay: 0.48s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery:nth-child(2) {
  animation-delay: 0.54s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery:nth-child(3) {
  animation-delay: 0.6s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery:nth-child(4) {
  animation-delay: 0.66s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery:nth-child(5) {
  animation-delay: 0.72s;
}

.fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery__marker {
  animation: sub-marker-pop 0.45s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-subscription-summary {
  animation: sub-scale-in 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease,
    border-color 0.3s ease;
}

.fishme-subscription-detail__aside:hover .fishme-subscription-summary {
  box-shadow: 0 20px 44px rgba(31, 31, 37, 0.1);
}

.fishme-subscription-summary__cta {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.fishme-subscription-summary__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(192, 2, 8, 0.25);
}

.fishme-subscription-summary__cta i {
  transition: transform 0.25s ease;
}

.fishme-subscription-summary__cta:hover i {
  transform: translateX(4px);
}

/* Checkout */
.fishme-sub-checkout-panel {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.fishme-sub-checkout-panel--summary {
  animation-delay: 0.12s;
}

.fishme-sub-motion-host.is-visible .fishme-sub-checkout-plan-card {
  animation: sub-scale-in 0.5s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
}

.fishme-sub-checkout-panel .rts-btn.btn-primary {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.fishme-sub-checkout-panel .rts-btn.btn-primary:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(192, 2, 8, 0.25);
}

/* Account subscriptions tab */
.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card {
  animation: sub-scale-in 0.5s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card:nth-child(1) {
  animation-delay: 0.04s;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card:nth-child(2) {
  animation-delay: 0.1s;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card:nth-child(3) {
  animation-delay: 0.16s;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card:nth-child(4) {
  animation-delay: 0.22s;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card:nth-child(5) {
  animation-delay: 0.28s;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card:nth-child(6) {
  animation-delay: 0.34s;
}

.account-subscriptions.fishme-sub-motion-host.is-visible .account-subscriptions-empty {
  animation: sub-fade-up 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.account-subscription-card__progress-bar span {
  animation: sub-progress-fill 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.35s both;
}

.account-subscription-card__media img {
  transition: transform 0.45s ease;
}

.account-subscription-card:hover .account-subscription-card__media img {
  transform: scale(1.05);
}

.account-subscription-card__link i {
  transition: transform 0.25s ease;
}

.account-subscription-card:hover .account-subscription-card__link i {
  transform: translateX(4px);
}

@media (prefers-reduced-motion: reduce) {
  .fishme-subscriptions-index-head,
  .fishme-subscriptions-index-head h1,
  .fishme-subscriptions-index-head p,
  .fishme-sub-motion-host.is-visible .fishme-sub-reveal,
  .fishme-sub-motion-host.is-visible .fishme-subscriptions-index-card,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__image,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__badges,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__title,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-hero__desc,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-stat,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-section,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery,
  .fishme-sub-motion-host.is-visible .fishme-subscription-plan-delivery__marker,
  .fishme-subscription-summary,
  .fishme-sub-checkout-panel,
  .fishme-sub-motion-host.is-visible .fishme-sub-checkout-plan-card,
  .account-subscriptions.fishme-sub-motion-host.is-visible .account-subscription-card,
  .account-subscriptions.fishme-sub-motion-host.is-visible .account-subscriptions-empty,
  .account-subscription-card__progress-bar span {
    animation: none;
  }

  .fishme-subscriptions-index-card:hover,
  .fishme-subscription-plan-stat:hover,
  .fishme-subscription-summary__cta:hover,
  .fishme-sub-checkout-panel .rts-btn.btn-primary:hover:not(:disabled),
  .account-subscription-card:hover .account-subscription-card__media img {
    transform: none;
  }
}
