/* ============================================
   Card Component - Inspirado no shadcn/ui
   ============================================ */

/* Base Card Container */
.card {
  display: flex;
  flex-direction: column;
  background-color: var(--card-background);
  color: var(--card-foreground);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: all var(--transition-base);
}

/* Card Variants */
.card--elevated {
  box-shadow: var(--shadow-lg);
}

.card--outlined {
  border: 1px solid var(--border);
}

.card--interactive {
  cursor: pointer;
}

.card--interactive:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--primary-200);
}

/* ============================================
   Card Header
   ============================================ */
.card__header {
  display: flex;
  flex-direction: column;
  padding: var(--spacing-6);
  border-bottom: 1px solid var(--border);
}

.card__header--no-border {
  border-bottom: none;
}

/* ============================================
   Card Title
   ============================================ */
.card__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  color: var(--card-foreground);
  margin: 0;
}

.card__title--sm {
  font-size: var(--font-size-lg);
}

.card__title--lg {
  font-size: var(--font-size-2xl);
}

/* ============================================
   Card Description
   ============================================ */
.card__description {
  font-size: var(--font-size-sm);
  color: var(--foreground-muted);
  line-height: var(--line-height-relaxed);
  margin-top: var(--spacing-2);
  margin-bottom: 0;
}

/* ============================================
   Card Action
   ============================================ */
.card__action {
  margin-top: var(--spacing-4);
  display: inline-flex;
  align-items: center;
}

/* ============================================
   Card Content
   ============================================ */
.card__content {
  padding: var(--spacing-6);
}

.card__content--no-padding {
  padding: 0;
}

.card__content--compact {
  padding: var(--spacing-4);
}

/* ============================================
   Card Footer
   ============================================ */
.card__footer {
  display: flex;
  align-items: center;
  padding: var(--spacing-6);
  border-top: 1px solid var(--border);
}

.card__footer--no-border {
  border-top: none;
}

.card__footer--compact {
  padding: var(--spacing-4);
}

.card__footer--space-between {
  justify-content: space-between;
}

.card__footer--center {
  justify-content: center;
}

.card__footer--end {
  justify-content: flex-end;
}

/* ============================================
   Card Image
   ============================================ */
.card__image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.card__image--top {
  border-top-left-radius: var(--radius-xl);
  border-top-right-radius: var(--radius-xl);
}

.card__image--bottom {
  border-bottom-left-radius: var(--radius-xl);
  border-bottom-right-radius: var(--radius-xl);
}

/* ============================================
   Card Variants - Colored
   ============================================ */
.card--primary {
  background-color: var(--primary-50);
  border-color: var(--primary-200);
}

.card--primary .card__title {
  color: var(--primary-700);
}

.card--secondary {
  background-color: var(--secondary-50);
  border-color: var(--secondary-200);
}

.card--secondary .card__title {
  color: var(--secondary-700);
}

.card--success {
  background-color: var(--success-50);
  border-color: var(--success-200);
}

.card--success .card__title {
  color: var(--success-700);
}

.card--warning {
  background-color: var(--warning-50);
  border-color: var(--warning-200);
}

.card--warning .card__title {
  color: var(--warning-700);
}

.card--error {
  background-color: var(--error-50);
  border-color: var(--error-200);
}

.card--error .card__title {
  color: var(--error-700);
}

.card--info {
  background-color: var(--info-50);
  border-color: var(--info-200);
}

.card--info .card__title {
  color: var(--info-700);
}

/* ============================================
   Card Sizes
   ============================================ */
.card--sm {
  border-radius: var(--radius-lg);
}

.card--sm .card__header,
.card--sm .card__content,
.card--sm .card__footer {
  padding: var(--spacing-4);
}

.card--sm .card__title {
  font-size: var(--font-size-lg);
}

.card--lg {
  border-radius: var(--radius-2xl);
}

.card--lg .card__header,
.card--lg .card__content,
.card--lg .card__footer {
  padding: var(--spacing-8);
}

.card--lg .card__title {
  font-size: var(--font-size-2xl);
}

/* ============================================
   Card with Image Layout
   ============================================ */
.card--image-top .card__header {
  padding: var(--spacing-6);
  border-bottom: none;
}

.card--image-top .card__content {
  padding-top: var(--spacing-6);
}

.card--image-bottom .card__footer {
  padding-bottom: var(--spacing-6);
  border-top: none;
}

.card--image-bottom .card__content {
  padding-bottom: var(--spacing-6);
}

/* ============================================
   Responsive Card
   ============================================ */
@media (max-width: 768px) {

  .card__header,
  .card__content,
  .card__footer {
    padding: var(--spacing-4);
  }

  .card--lg .card__header,
  .card--lg .card__content,
  .card--lg .card__footer {
    padding: var(--spacing-6);
  }
}