    /* ── Page title ──────────────────────────────────────────────── */
    .ciudades-title {
        font-size: 1.75rem;
        font-weight: 800;
        color: var(--text-main);
        margin: 0 0 .25rem;
        line-height: 1.15;
    }
    .ciudades-subtitle {
        font-size: 1rem;
        color: var(--text-muted);
        margin: 0 0 1.25rem;
    }
    /* City cards */
    .cities-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1rem;
        margin-top: 1.25rem;
    }
    @media (max-width: 900px) {
        .cities-grid { grid-template-columns: repeat(2, 1fr); }
    }
    .city-card {
        border-radius: var(--radius-lg);
        overflow: hidden;
        text-decoration: none;
        color: var(--text-main);
        background: var(--bg-card);
        border-top: 3px solid var(--primary-color);
        box-shadow: var(--shadow-sm);
        display: flex;
        flex-direction: column;
        transition: transform .2s ease, box-shadow .2s ease;
    }
    .city-card:hover {
        transform: translateY(-3px);
        box-shadow: var(--shadow-hover);
        text-decoration: none;
    }
    .city-card-img {
        width: 100%;
        height: 110px;
        object-fit: cover;
        display: block;
    }
    .city-card-img--empty {
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--primary-soft);
        color: var(--primary-color);
        font-weight: 700;
        font-size: .95rem;
        text-align: center;
        padding: 0 .5rem;
    }
    .city-card-body {
        padding: .8rem 1rem;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: .3rem;
        flex: 1;
    }
    .city-card-name {
        font-weight: 700;
        font-size: .95rem;
    }
    .city-card-desc {
        font-size: .78rem;
        color: var(--text-muted);
        line-height: 1.4;
        flex: 1;
    }
    .city-card-cta {
        font-size: .8rem;
        font-weight: 700;
        color: var(--primary-color);
        white-space: nowrap;
        margin-top: .2rem;
    }
    @media (max-width: 600px) {
        .ciudades-title { font-size: 1.1rem; margin: 0 0 0.2rem; }
        .cities-grid { grid-template-columns: repeat(3, 1fr); }
        .city-card-img  { height: 70px; }
        .city-card-body { padding: .6rem .7rem; gap: .2rem; }
        .city-card-desc { display: none; }
        .city-card-cta  { display: none; }
    }
