/* ============================================
   ENSEMBLE CARDS (Clown Slider)
   3D hover effects and enhanced styling
   ============================================ */

/* ---------- SECTION WRAPPER ---------- */
#clown-slider {
  padding: var(--space-section) var(--space-6);
  background-color: var(--color-black);
}

#clown-slider h1 {
  font-family: var(--font-display);
  font-size: var(--text-h1);
  font-weight: var(--weight-black);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  text-align: center;
  color: var(--color-white);
  margin-bottom: var(--space-12);
}

/* ---------- SLIDER CONTAINER ---------- */
.slider {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-10);
  max-width: 1200px;
  margin: 0 auto;
}

/* ---------- CARD ---------- */
.imgcard {
  position: relative;
  flex: 1 1 350px;
  max-width: 480px;
  text-align: center;
  border-radius: var(--radius-xl);
  background: var(--color-dark-elevated);

  /* 3D transform setup */
  transform-style: preserve-3d;
  perspective: 1000px;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.imgcard:hover {
  transform: translateY(-12px);
  box-shadow: var(--shadow-xl), var(--shadow-glow);
}

/* ---------- CARD IMAGE ---------- */
.card-image {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}

.card-image img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  object-position: center top;
  transition: transform var(--transition-slow), filter var(--transition-base);
  filter: grayscale(10%);
}

.imgcard:hover .card-image img {
  transform: scale(1.05);
  filter: grayscale(0%);
}

/* Gradient overlay on image */
.card-image::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 50%;
  background: linear-gradient(
    to top,
    var(--color-dark-elevated) 0%,
    rgba(20, 20, 20, 0.8) 30%,
    transparent 100%
  );
  pointer-events: none;
  transition: var(--transition-base);
}

.imgcard:hover .card-image::after {
  height: 60%;
}

/* ---------- CARD TEXT ---------- */
.card-text {
  position: relative;
  padding: var(--space-6) var(--space-6) var(--space-8);
  background-color: var(--color-dark-elevated);
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

.card-text-split {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.card-text-left {
  text-align: left;
}

.card-text-right {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ---------- TITLES ---------- */
.card-title.clown-title {
  font-family: var(--font-display);
  font-size: var(--text-h3);
  font-weight: var(--weight-black);
  color: var(--color-white);
  line-height: var(--leading-snug);
  margin-bottom: var(--space-1);
}

.card-title.name {
  font-family: var(--font-body);
  font-size: var(--text-body-sm);
  font-weight: var(--weight-normal);
  font-style: italic;
  color: var(--color-gray-400);
}

/* Legacy clown-title class support */
.clown-title {
  font-family: var(--font-display);
  font-size: var(--text-h3);
  font-weight: var(--weight-black);
  color: var(--color-white);
  line-height: var(--leading-snug);
}

/* ---------- SOCIAL ICONS ---------- */
.card-text-right a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.05);
  transition: var(--transition-base);
}

.card-text-right a:hover {
  background: rgba(255, 255, 255, 0.15);
  transform: translateY(-2px);
}

.card-text-right img,
.card-text-right svg {
  width: 22px;
  height: 22px;
  transition: var(--transition-base);
}

.card-text-right img {
  filter: brightness(0) invert(1);
}

.card-text-right svg {
  stroke: var(--color-white);
}

.card-text-right a:hover img,
.card-text-right a:hover svg {
  opacity: 0.8;
}

/* ---------- CARD URL LINK ---------- */
.card-url {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);

  font-family: var(--font-body);
  font-size: var(--text-body-sm);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  text-decoration: none;
  white-space: nowrap;

  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  color: var(--color-white);
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.3);

  cursor: pointer;
  transition: var(--transition-base);
}

.card-url:hover {
  color: var(--color-black);
  background-color: var(--color-white);
  border-color: var(--color-white);
  opacity: 1;
}

/* ---------- RESPONSIVE ---------- */

/* Tablet */
@media (max-width: 1024px) {
  #clown-slider {
    padding: var(--space-section-sm) var(--space-4);
  }

  .slider {
    gap: var(--space-8);
  }

  .imgcard {
    flex: 1 1 320px;
    max-width: 420px;
  }

  .card-image img {
    height: 450px;
  }
}

/* Mobile */
@media (max-width: 640px) {
  #clown-slider h1 {
    margin-bottom: var(--space-8);
  }

  .slider {
    flex-direction: column;
    align-items: center;
    gap: var(--space-8);
  }

  .imgcard {
    width: 100%;
    max-width: 400px;
  }

  .card-image img {
    height: 400px;
  }

  .card-text {
    padding: var(--space-5) var(--space-5) var(--space-6);
  }

  .card-text-split {
    flex-direction: row;
    align-items: center;
    text-align: left;
  }

  .card-text-left {
    text-align: left;
    flex: 1;
  }

  .card-text-right {
    flex-shrink: 0;
  }

  .card-title.clown-title {
    font-size: var(--text-h2);
  }

  .card-title.name {
    font-size: var(--text-body);
  }

  .card-text .btn,
  .card-url {
    width: 100%;
    justify-content: center;
    font-size: var(--text-body-sm);
    padding: var(--space-3) var(--space-6);
  }
}

/* Small mobile */
@media (max-width: 400px) {
  .imgcard {
    max-width: 100%;
  }

  .card-image img {
    height: 350px;
  }
}
