/* compact variant for homepage to reduce height */
.locations-section.compact .locations-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); /* responsive fit */
    gap: 1.5rem;
    max-width: 1200px; /* match other sections */
    margin: 0 auto;
    padding: 0 2rem; /* match other sections */
}

.locations-section.compact .location-card {
    padding: 1.5rem; /* match service card padding */
    border-radius: 12px; /* match service card radius */
    min-width: 0; /* prevent overflow */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 120px; /* consistent card height */
}

.locations-section.compact .location-flag {
    display: flex;
    justify-content: center;
    margin-bottom: 8px;
}

.locations-section.compact .location-flag img {
    width: 28px;
    height: 20px;
    object-fit: cover;
    border-radius: 2px;
}

.locations-section.compact .location-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.locations-section.compact .location-info h3 {
    font-size: 0.95rem;
    margin: 0 0 2px 0;
    font-weight: 600;
}

.locations-section.compact .location-country {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 0;
}

.locations-section.compact .location-features { display: none; }

.locations-section.compact .section-header { margin-bottom: 1.25rem; }

/* responsive: stack on mobile */
@media (max-width: 768px) {
    .locations-section.compact .locations-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }
}

@media (max-width: 480px) {
    .locations-section.compact .locations-grid {
        grid-template-columns: 1fr;
    }
}
