/**
 * Shared villa card + grid styles.
 * Used by archive-villa.php, taxonomy-collection.php/bedrooms (clx markup) and
 * taxonomy-area.php so all villa grids render identical cards. Extracted from
 * taxonomy-area.php's scoped <style>. var() fallbacks make it self-sufficient on
 * pages that don't define the area template's :root (e.g. the CPT archive).
 */

.clx-villa-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
.clx-villa-card {
    background: var(--card, #111111);
    border: 1px solid var(--border, rgba(255,255,255,0.07));
    overflow: hidden;
    display: block;
    text-decoration: none;
    color: var(--text, #FBFBFB);
    transition: all 0.3s var(--ease, cubic-bezier(0.25,0.46,0.45,0.94));
}
.clx-villa-card:hover { border-color: var(--gold-b, rgba(0,170,123,0.22)); transform: translateY(-4px); }
.clx-villa-card__img {
    height: 240px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #1a2e2c, #0f1f1c);
    background-size: cover;
    background-position: center;
    transition: transform 0.6s var(--ease, cubic-bezier(0.25,0.46,0.45,0.94));
}
.clx-villa-card:hover .clx-villa-card__img { transform: scale(1.04); }
.clx-villa-card__badge {
    position: absolute;
    top: 14px; left: 14px;
    padding: 5px 12px;
    font-size: 0.58rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    background: var(--gold, #00AA7B);
    color: #020706;
    font-weight: 500;
    z-index: 1;
}
.clx-villa-card__body { padding: 1.5rem 1.5rem 1.75rem; }
.clx-villa-card__loc {
    font-size: 0.6rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--muted, #6B6B6B);
    margin: 0 0 8px 0;
}
.clx-villa-card__name {
    font-family: var(--fd, 'Albert Sans', -apple-system, BlinkMacSystemFont, sans-serif);
    font-size: 1.5rem;
    font-weight: 200;
    line-height: 1.05;
    margin: 0 0 0.75rem 0;
    color: var(--text, #FBFBFB);
}
.clx-villa-card__specs {
    font-size: 0.72rem;
    color: var(--muted, #6B6B6B);
    margin: 0 0 1rem 0;
}
.clx-villa-card__foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 0.85rem;
    border-top: 1px solid var(--border, rgba(255,255,255,0.07));
}
.clx-villa-card__cta {
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted, #6B6B6B);
    transition: color 0.2s;
}
.clx-villa-card:hover .clx-villa-card__cta { color: var(--gold, #00AA7B); }
.clx-villa-card__cat {
    font-size: 0.58rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(0, 170, 123, 0.6);
}

@media (max-width: 1024px) {
    .clx-villa-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .clx-villa-grid { grid-template-columns: 1fr; }
}
