/**
 * Card Components
 *
 * Reusable card styles for content containers, lists, and panels
 * across the entire site.
 */

/* Base Card */
.card {
  display: grid;
  gap: 1rem;
  padding: 1.5rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  background: var(--glass-subtle);
  transition: var(--transition-base);
}

.card:hover {
  background: var(--glass-medium);
  border-color: var(--border-strong);
}

/* Card as Link */
.card--link {
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

/* Compact Card */
.card--compact {
  padding: 1rem 1.25rem;
  gap: 0.75rem;
}

/* Elevated Card (same as base in flat design) */
.card--elevated {
  /* No additional styling needed in flat design */
}

/* Flat Card (minimal styling) */
.card--flat {
  background: var(--glass-subtle);
}

/* Upcoming/Highlight Card */
.card--highlight {
  border-style: dashed;
  border-color: var(--border-strong);
  background: var(--glass-subtle);
}

/* Active/Selected Card */
.card--active {
  border-color: rgba(var(--accent-primary-rgb), 0.4);
  background: rgba(var(--accent-primary-rgb), 0.08);
}

/* Card Header */
.card__header {
  display: grid;
  gap: 0.75rem;
}

.card__title {
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.3;
  margin: 0;
  color: rgba(226, 227, 234, 0.95);
}

.card__subtitle {
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(226, 227, 234, 0.7);
  margin: 0;
}

/* Card Meta */
.card__meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(226, 227, 234, 0.6);
}

/* Card Body */
.card__body {
  display: grid;
  gap: 0.75rem;
}

.card__text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(226, 227, 234, 0.75);
  margin: 0;
}

/* Card Footer */
.card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

/* List Card (for lists within cards) */
.card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}

.card-list__item {
  margin: 0;
}

.card-list__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  border-radius: var(--card-radius);
  border: 1px solid var(--card-border);
  background: var(--card-bg);
  color: inherit;
  text-decoration: none;
  transition: var(--card-transition);
}

.card-list__link:hover {
  background: var(--card-bg-hover);
  border-color: var(--card-border-hover);
}

/* Menu Card (for navigation menus) */
.menu-card {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}

.menu-card__item {
  margin: 0;
}

.menu-card__button {
  width: 100%;
  display: grid;
  gap: 0.5rem;
  padding: 1rem;
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  background: var(--card-bg);
  color: inherit;
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: var(--card-transition);
}

.menu-card__button:hover {
  background: var(--card-bg-hover);
  border-color: var(--card-border-hover);
}

.menu-card__button.is-active {
  border-color: rgba(var(--accent-primary-rgb), 0.4);
  background: rgba(var(--accent-primary-rgb), 0.08);
}

/* Light Theme */
html[data-theme="light"] .card__title {
  color: rgba(32, 36, 52, 0.95);
}

html[data-theme="light"] .card__subtitle {
  color: rgba(32, 36, 52, 0.7);
}

html[data-theme="light"] .card__meta {
  color: rgba(32, 36, 52, 0.6);
}

html[data-theme="light"] .card__text {
  color: rgba(47, 50, 68, 0.75);
}

html[data-theme="light"] .card__footer {
  border-top-color: rgba(0, 0, 0, 0.06);
}
