/**
 * Card Components
 * 
 * Card styles following BEM methodology
 * 
 * @package wbl
 */

/* ================================================================
   CARD BASE STYLES
   ================================================================ */

.card {
  display: flex;
  flex-direction: column;
  background-color: var(--color-white);
  border-radius: var(--radius-medium);
  box-shadow: var(--shadow-light);
  transition: all var(--transition-medium);
  overflow: hidden;
  position: relative;
}

.card:hover {
  box-shadow: var(--shadow-medium);
  /* Remove problematic transform that breaks containment */
}

.card--interactive {
  cursor: pointer;
}

.card--interactive:hover {
  box-shadow: var(--shadow-heavy);
  /* Remove problematic transform that breaks containment */
}

/* ================================================================
   CARD COMPONENTS
   ================================================================ */

/* Card Header */
.card__header {
  padding: var(--spacing-lg);
  border-bottom: 1px solid #eee;
  background-color: var(--color-white);
}

.card__header--primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-bottom-color: rgba(255, 255, 255, 0.2);
}

/* Card Body */
.card__body {
  padding: var(--spacing-lg) ;
  flex: 1;
}

.card__body--compact {
  padding: var(--spacing-md);
}

.card__body--spacious {
  padding: var(--spacing-xl);
}

/* Card Footer */
.card__footer {
  padding: var(--spacing-lg);
  border-top: 1px solid #eee;
  background-color: #fafafa;
  margin-top: auto;
}

.card__footer--flush {
  padding: var(--spacing-md) var(--spacing-lg);
  background-color: transparent;
  border-top: none;
}

/* Card Title */
.card__title {
  margin: 0 0 var(--spacing-sm) 0;
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  line-height: var(--line-height-heading);
}

.card__subtitle {
  margin: 0 0 var(--spacing-md) 0;
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-secondary);
  line-height: var(--line-height-body);
}

/* Card Text */
.card__text {
  margin: 0 0 var(--spacing-sm) 0;
  color: var(--color-text-primary);
  line-height: var(--line-height-body);
}

.card__text:last-child {
  margin-bottom: 0;
}

/* Card Image */
.card__image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
}

.card__image--top {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.card__image--bottom {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

/* Card Image Container */
.card__image-container {
  position: relative;
  overflow: hidden;
  background-color: #f8f9fa;
}

.card__image-container--aspect-4-3 {
  aspect-ratio: 4/3;
}

.card__image-container--aspect-16-9 {
  aspect-ratio: 16/9;
}

.card__image-container--aspect-1-1 {
  aspect-ratio: 1/1;
}

.card__image-container img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity var(--transition-medium), filter var(--transition-medium);
}

.card:hover .card__image-container img {
  /* Replace problematic scale with safe opacity/filter effects */
  opacity: 0.9;
  filter: brightness(1.1);
}

/* Card Meta */
.card__meta {
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
  margin: 0 0 var(--spacing-xs) 0;
}

.card__meta-item {
  display: inline-block;
  margin-inline-end: var(--spacing-sm);
}

.card__meta-item:last-child {
  margin-inline-end: 0;
}

/* Card Badge */
.card__badge {
  position: absolute;
  top: var(--spacing-sm);
  left: var(--spacing-sm);
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  background-color: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-small);
  z-index: 2;
}

.card__badge--success {
  background-color: var(--color-success);
}

.card__badge--warning {
  background-color: var(--color-warning);
  color: var(--color-text-primary);
}

.card__badge--error {
  background-color: var(--color-error);
}

.card__badge--top-right {
  left: auto;
  right: var(--spacing-sm);
}

/* ================================================================
   CARD VARIANTS
   ================================================================ */

/* Horizontal Card */
.card--horizontal {
  flex-direction: row;
  align-items: stretch;
}

.card--horizontal .card__image-container {
  flex: 0 0 40%;
  max-width: 40%;
}

.card--horizontal .card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* Bordered Card */
.card--bordered {
  border: 2px solid #eee;
  box-shadow: none;
}

.card--bordered:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-light);
}

/* Outline Card */
.card--outline {
  background-color: transparent;
  border: 2px solid var(--color-primary);
  box-shadow: none;
}

.card--outline:hover {
  background-color: var(--color-white);
  box-shadow: var(--shadow-medium);
}

/* Flush Card */
.card--flush {
  box-shadow: none;
  border-radius: 0;
}

/* ================================================================
   CARD GRID
   ================================================================ */

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
}

.card-grid--2-cols {
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
}

.card-grid--3-cols {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.card-grid--4-cols {
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
}

/* ================================================================
   RESPONSIVE CARDS
   ================================================================ */

@media (max-width: 767px) {
  .card__header,
  .card__body,
  .card__footer {
    padding: var(--spacing-md);
  }
  
  .card__body--spacious {
    padding: var(--spacing-lg);
  }
  
  .card__title {
    font-size: var(--font-size-h5);
  }
  
  .card--horizontal {
    flex-direction: column;
  }
  
  .card--horizontal .card__image-container {
    flex: none;
    max-width: none;
  }
  
  .card-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
  
  .card-grid--2-cols,
  .card-grid--3-cols,
  .card-grid--4-cols {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .card-grid--3-cols,
  .card-grid--4-cols {
    grid-template-columns: repeat(2, 1fr);
  }
}

