/* public/assets/ui/framework/09_cards.css
   KomodUI Cards v0.1
   Stable cards + grids. Includes legacy bridge for existing master cards.
*/

/* =========================
   Generic Card primitive
   ========================= */

.card {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.card--pad {
  padding: var(--space-6);
}

/* =========================
   Grid: safe responsive grid
   ========================= */

.grid-cards {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 992px) {
  .grid-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 576px) {
  .grid-cards { grid-template-columns: minmax(0, 1fr); }
}

/* =========================
   Legacy bridge: masters list (search-results.css markup)
   Targets existing classes: .masters-grid, .master-card, .card-visual, etc.
   ========================= */

.masters-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 992px) {
  .masters-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 576px) {
  .masters-grid { grid-template-columns: minmax(0, 1fr); }
}

/* Prevent any child from forcing horizontal overflow */
.master-card,
.master-card * {
  min-width: 0;
}

/* The card shell */
.master-card {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

/* Make whole card layout stable */
.master-card {
  display: flex;
  flex-direction: column;
}

/* Visual (cover image area) */
.card-visual {
  display: block;
  width: 100%;
  overflow: hidden;
  background: #e5e7eb;
}

/* If legacy CSS sets fixed height, we still ensure image doesn't distort */
.card-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Body spacing */
.master-card .card-body {
  padding: var(--space-6);
}

/* Identity row: avatar + name/rating must not overflow */
.master-card .card-identity-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  min-width: 0;
}

.master-card .card-main-info {
  min-width: 0;
}

.master-card .card-name,
.master-card .card-name a {
  display: block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Meta rows should wrap safely */
.master-card .card-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  min-width: 0;
}

/* Footer area */
.master-card .card-footer {
  margin-top: auto;
  padding: var(--space-5) var(--space-6);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  min-width: 0;
}

/* Price should not push layout */
.master-card .card-price {
  min-width: 0;
  white-space: nowrap;
}

/* CTA block: buttons shouldn't overflow */
.master-card .card-cta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  justify-content: flex-end;
  min-width: 0;
}

.master-card .card-cta .btn,
.master-card .card-cta a.btn {
  max-width: 100%;
}

/* Mobile tightening */
@media (max-width: 576px) {
  .master-card .card-body {
    padding: var(--space-5);
  }

  .master-card .card-footer {
    padding: var(--space-4) var(--space-5);
    flex-direction: column;
    align-items: stretch;
  }

  .master-card .card-cta {
    justify-content: stretch;
  }

  .master-card .card-cta .btn,
  .master-card .card-cta a.btn {
    width: 100%;
    justify-content: center;
  }
} 