/**
 * Holiday Banner Styles
 *
 * Base styles + holiday-specific modifiers
 */

/* ============================================
   Base Banner Styles
   ============================================ */

.holiday-banner {
  position: relative;
  border-radius: var(--dashboard-card-radius, 16px);
  padding: var(--dashboard-card-padding, 20px 24px);
  min-height: 160px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.holiday-banner:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.holiday-banner[hidden] {
  display: none !important;
}

/* Label */
.holiday-banner__label {
  margin: 0 0 4px;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.8);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Title */
.holiday-banner__title {
  margin: 0;
  font-size: 24px;
  font-weight: 600;
  color: #fff;
  max-width: 70%;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Date */
.holiday-banner__date {
  margin: 0;
  margin-top: auto;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.8);
}

/* Image */
.holiday-banner__image {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 150px;
  height: 150px;
  object-fit: contain;
  opacity: 0.9;
  transition: transform 0.2s ease;
  pointer-events: none;
}

.holiday-banner:hover .holiday-banner__image {
  transform: translateY(-50%) scale(1.08);
}

/* Effect Canvas */
.holiday-banner__canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

/* ============================================
   Holiday-Specific Modifiers
   ============================================ */

/* Christmas - snowy feel */
.holiday--christmas {
  background: linear-gradient(135deg, #14532d 0%, #166534 100%);
}

.holiday--christmas .holiday-banner__title {
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Valentine's - romantic pink */
.holiday--valentine {
  background: linear-gradient(135deg, #be185d 0%, #ec4899 100%);
}

/* New Year - night sky */
.holiday--newyear {
  background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%);
}

/* Halloween - spooky dark */
.holiday--halloween {
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
}

.holiday--halloween .holiday-banner__label {
  color: #f97316;
}

/* Easter - spring yellow */
.holiday--easter {
  background: linear-gradient(135deg, #ca8a04 0%, #facc15 100%);
}

.holiday--easter .holiday-banner__title,
.holiday--easter .holiday-banner__date {
  color: #422006;
}

.holiday--easter .holiday-banner__label {
  color: rgba(66, 32, 6, 0.7);
}

/* Thanksgiving - autumn warm */
.holiday--thanksgiving {
  background: linear-gradient(135deg, #b45309 0%, #f59e0b 100%);
}

/* Mother's Day / Women's Day - soft pink */
.holiday--mothersday,
.holiday--womensday {
  background: linear-gradient(135deg, #be185d 0%, #f472b6 100%);
}

/* Father's Day - classic blue */
.holiday--fathersday {
  background: linear-gradient(135deg, #1e40af 0%, #3b82f6 100%);
}

/* ============================================
   Responsive
   ============================================ */

@media (max-width: 768px) {
  .holiday-banner {
    padding: 16px 20px;
    min-height: 140px;
  }

  .holiday-banner__title {
    font-size: 24px;
  }

  .holiday-banner__image {
    width: 80px;
    height: 80px;
    right: 12px;
  }
}

@media (max-width: 480px) {
  .holiday-banner__image {
    width: 60px;
    height: 60px;
    opacity: 0.7;
  }

  .holiday-banner__title {
    max-width: 65%;
  }
}

/* ============================================
   Reduced Motion
   ============================================ */

@media (prefers-reduced-motion: reduce) {
  .holiday-banner,
  .holiday-banner__image {
    transition: none;
  }

  .holiday-banner:hover {
    transform: none;
  }

  .holiday-banner:hover .holiday-banner__image {
    transform: translateY(-50%);
  }

  .holiday-banner__canvas {
    display: none;
  }
}
