/* ============================================================
   assets/css/cards.css — Widget card grid
   ============================================================ */

.widget-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}

.widget-card {
  background: var(--bg2);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
  display: flex; flex-direction: column;
}
.widget-card:hover {
  border-color: rgba(93,62,248,0.45);
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 0 0 1px rgba(93,62,248,0.15);
}

/* Thumbnail */
.card-thumb-link { display: block; flex-shrink: 0; }
.card-thumb {
  position: relative; width: 100%; aspect-ratio: 16/9;
  overflow: hidden; background: var(--bg3);
}
.card-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.35s ease;
}
.widget-card:hover .card-thumb img { transform: scale(1.04); }
.card-thumb-fallback {
  position: absolute; inset: 0; background: var(--bg3);
  display: flex; align-items: center; justify-content: center;
  color: var(--txt3); font-size: 28px;
}
.card-thumb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(8,10,15,0.7));
}
.widget-tag {
  position: absolute; top: 8px; left: 8px;
  backdrop-filter: blur(4px);
}

/* Body */
.card-body {
  padding: 11px 13px 13px;
  display: flex; flex-direction: column; flex: 1;
}
.card-title {
  font-family: var(--font-display); font-size: 14px; font-weight: 600;
  margin-bottom: 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.card-title a { color: var(--txt); }
.card-title a:hover { color: var(--acc3); }

.card-desc {
  font-size: 12px; color: var(--txt3); line-height: 1.55;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; flex: 1; margin-bottom: 10px;
}

.card-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: auto;
}
.card-author {
  display: flex; align-items: center; gap: 5px;
  font-size: 12px; color: var(--txt3);
  transition: color 0.15s;
}
.card-author:hover { color: var(--txt2); }

.card-meta { display: flex; align-items: center; gap: 8px; }
.card-stat {
  font-size: 11px; color: var(--txt3);
  display: flex; align-items: center; gap: 3px;
}
.card-stat i { font-size: 12px; }

.btn-open {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px; color: var(--acc3);
  background: rgba(93,62,248,0.12); padding: 3px 9px;
  border-radius: 4px; transition: background 0.15s;
}
.btn-open:hover { background: rgba(93,62,248,0.22); }
