/**
 * Selectable card component - radio or checkbox selection cards
 * Use for: payment method selection, plan selection, option selection
 * Theme-aware; works in light and dark modes
 */

/* Grid container for selectable cards */
.selectable-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  width: 100%;
}

/* Base selectable card */
.selectable-card {
  position: relative;
  padding: 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 2px solid color-mix(in srgb, var(--primary-blue) 30%, transparent);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.2s ease;
  box-sizing: border-box;
}

body.theme-light .selectable-card {
  background: rgba(0, 0, 0, 0.02);
  border-color: color-mix(in srgb, var(--primary-blue) 40%, transparent);
}

/* Hover state */
.selectable-card:hover {
  border-color: color-mix(in srgb, var(--primary-blue) 60%, transparent);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px
    color-mix(in srgb, var(--primary-blue) 20%, transparent);
}

body.theme-light .selectable-card:hover {
  border-color: color-mix(in srgb, var(--primary-blue) 70%, transparent);
  box-shadow: 0 4px 12px
    color-mix(in srgb, var(--primary-blue) 15%, transparent);
}

/* Selected state */
.selectable-card.selected {
  background: color-mix(in srgb, var(--primary-blue) 10%, transparent);
  border-color: var(--primary-blue);
  box-shadow: 0 4px 16px
    color-mix(in srgb, var(--primary-blue) 30%, transparent);
}

body.theme-light .selectable-card.selected {
  background: color-mix(in srgb, var(--primary-blue) 8%, transparent);
  border-color: var(--primary-blue);
  box-shadow: 0 4px 16px
    color-mix(in srgb, var(--primary-blue) 20%, transparent);
}

/* Disabled state */
.selectable-card.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Radio/checkbox input positioning */
.selectable-card input[type='radio'],
.selectable-card input[type='checkbox'] {
  position: absolute;
  top: 16px;
  right: 16px;
  margin: 0;
}

/* Card title */
.selectable-card-title {
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 4px;
  color: var(--text-color);
}

/* Card description */
.selectable-card-desc {
  font-size: 13px;
  opacity: 0.7;
  color: var(--text-color);
  margin: 0;
}

/* Optional icon in title */
.selectable-card-title i {
  margin-right: 6px;
  opacity: 0.8;
}

/* Optional badge (e.g., "Recommended", "Popular") */
.selectable-card-badge {
  position: absolute;
  top: -8px;
  left: 16px;
  background: var(--primary-color, #3b82f6);
  color: white;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Optional price display */
.selectable-card-price {
  font-size: 20px;
  font-weight: 700;
  margin-top: 12px;
  color: var(--text-color);
}

.selectable-card-price-unit {
  font-size: 14px;
  font-weight: 400;
  opacity: 0.6;
}

/* Compact variant */
.selectable-card-compact {
  padding: 16px;
}

.selectable-card-compact .selectable-card-title {
  font-size: 14px;
}

.selectable-card-compact .selectable-card-desc {
  font-size: 12px;
}

/* Large variant for prominent choices */
.selectable-card-large {
  padding: 28px;
}

.selectable-card-large .selectable-card-title {
  font-size: 18px;
  margin-bottom: 8px;
}

.selectable-card-large .selectable-card-desc {
  font-size: 14px;
}

/* Full width variant (stack vertically) */
.selectable-card-grid-full {
  grid-template-columns: 1fr;
}

/* Two column variant */
.selectable-card-grid-2col {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

/* Three column variant */
.selectable-card-grid-3col {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Four column variant */
.selectable-card-grid-4col {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
