/* * GOONDEX CARD BASE * Shared grid + card shell used by performer/studio/scene listings. */ :root { --gx-card-thumb-ratio: 3 / 4; --gx-card-min-width: 250px; } .gx-card-grid { display: grid; gap: 1.6rem; padding: 1rem 0; grid-template-columns: repeat(auto-fill, minmax(var(--gx-card-min-width), 1fr)); } .gx-card { background: var(--color-bg-card); border: 1px solid var(--color-border-soft); border-radius: var(--radius-soft); overflow: hidden; box-shadow: var(--shadow-elevated); transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition); cursor: pointer; position: relative; } .gx-card:hover { transform: translateY(-4px); border-color: var(--color-brand); box-shadow: 0 0 18px rgba(255, 79, 163, 0.28), 0 6px 24px rgba(0, 0, 0, 0.55); } .gx-card-thumb { width: 100%; aspect-ratio: var(--gx-card-thumb-ratio); background-size: cover; background-position: center; filter: brightness(0.92); transition: filter var(--transition-fast); } .gx-card:hover .gx-card-thumb { filter: brightness(1); } .gx-card-body { padding: 1rem; display: flex; flex-direction: column; gap: 0.35rem; } .gx-card-title { font-size: 1.1rem; font-weight: 600; background: linear-gradient(135deg, var(--color-text-primary), var(--color-header)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; } .gx-card-meta { font-size: 0.85rem; color: var(--color-text-secondary); opacity: 0.9; } .gx-card-tags { margin-top: 0.7rem; display: flex; flex-wrap: wrap; gap: 0.4rem; } .gx-card-tag { padding: 0.2rem 0.55rem; font-size: 0.75rem; border-radius: var(--radius); background: rgba(255, 79, 163, 0.08); color: var(--color-brand); border: 1px solid rgba(255, 79, 163, 0.25); text-transform: uppercase; letter-spacing: 0.03em; } @media (max-width: 550px) { .gx-card-grid { grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); } .gx-card-title { font-size: 1rem; } }