/* Reusable card primitives (site-wide) */
:root{
  --card-bg:#ffffff;
  --card-border: var(--border);
  --card-radius: 16px;
  --card-shadow: 0 2px 0 rgba(0,0,0,.01);
}

/* Base container */
.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--card-shadow)}
.card--pill{border-radius:999px}
.card--hover:hover{filter:brightness(1.02)}

/* Layout helpers */
.card-row{display:flex;gap:12px;align-items:center}
.card-col{display:flex;flex-direction:column;gap:10px}
.card-center{display:flex;align-items:center;justify-content:center;text-align:center}

/* Media */
.card-media{position:relative;display:block;aspect-ratio:16/9;background:#f3f4f6;overflow:hidden;border-bottom:1px solid var(--card-border)}
.card-media>img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.card-media--hover:hover>img{transform:scale(1.04)}

/* Text */
.card-title{margin:0;font-weight:800;color:#0f172a}
.card-title--sm{font-size:16px}
.card-title--md{font-size:18px}
.card-title--lg{font-size:22px}
.card-title a{text-decoration:none;color:inherit}
.card-title a:hover{color:var(--primary)}

.card-meta{display:flex;align-items:center;gap:10px;color:#6b7280;font-size:12px}
.card-meta .dot{width:3px;height:3px;background:#cbd5e1;border-radius:999px;display:inline-block}

/* Pills */
.pill{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid var(--card-border);background:#F3F4F6;color:#374151;font-size:12px;white-space:nowrap}

/* Spacing */
.card-pad{display:block;padding:14px;background:#fff}
.card-pad-lg{padding:16px}

/* Utilities */
.hide{display:none !important}

/* Line clamp utilities */
.line-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;line-clamp:1}
.line-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-clamp:2}

/* Description */
.card-desc{margin-top:6px;color:#4b5563;font-size:14px}

/* Card stats (icons + counts) */
.card-stats{display:flex;align-items:center;gap:14px;color:#6b7280;font-size:12px;margin-top:10px}
.card-stats .stat{display:inline-flex;align-items:center;gap:6px}
.card-stats .stat i{color:#9ca3af}
