/* ================================================
   ACF Listings Grid - Material Design
   ================================================ */
.acf-listings-grid{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:20px;
    max-width:1200px;
    margin:0 auto;
    padding:20px 16px;
}

/* Card */
.acf-listing-card{
    background:#fff;
    border-radius:8px;
    padding:16px;
    box-shadow:0 2px 4px -1px rgba(0,0,0,.2),
               0 4px 5px 0 rgba(0,0,0,.14),
               0 1px 10px 0 rgba(0,0,0,.12);
    transition:box-shadow .3s cubic-bezier(.4,0,.2,1);
}
.acf-listing-card:hover{
    box-shadow:0 5px 5px -3px rgba(0,0,0,.2),
               0 8px 10px 1px rgba(0,0,0,.14),
               0 3px 14px 2px rgba(0,0,0,.12);
}

.acf-listing-card {
    cursor: pointer;
}

/* Top row */
.acf-card-top{
    display:flex;
    gap:16px;
    align-items:center;
    margin-bottom:12px;
}

/* Logo wrapper - flexbox container for centering */
.acf-logo-wrapper{
    width:120px;
    height:90px;
    min-width:120px;
    border-radius:6px;
    border:1px solid #e0e0e0;
    background:#fff;
    padding:8px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    flex-shrink:0;
}

/* Logo image */
.acf-listing-logo{
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center;
    display:block;
}

/* No logo placeholder */
.acf-no-logo{
    width:120px;
    height:90px;
    min-width:120px;
    border-radius:6px;
    background:#0056b3;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:2rem;
    font-weight:600;
    flex-shrink:0;
}

/* Card info */
.acf-card-info{
    flex:1;
    min-width:0;
}

/* Title */
.acf-listing-title{
    font-size:1rem;
    font-weight:600;
    margin:0 0 4px;
    color:rgba(0,0,0,.87);
    line-height:1.3;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
.acf-listing-title a{
    color:inherit;
    text-decoration:none;
}
.acf-listing-title a:hover{
    color:#0056b3;
}

/* Stars */
.acf-listing-stars{
    display:flex;
    align-items:center;
    gap:4px;
    margin-bottom:3px;
    font-size:.9rem;
}
.acf-review-count{
    color:rgba(0,0,0,.54);
    font-size:.8rem;
}

/* Location */
.acf-listing-location{
    font-size:.8rem;
    color:rgba(0,0,0,.54);
}

/* Description */
.acf-listing-description{
    font-size:.85rem;
    color:rgba(0,0,0,.6);
    line-height:1.5;
    margin:0;
    padding-top:12px;
    border-top:1px solid rgba(0,0,0,.08);
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

/* ================================================
   USA States Grid
   ================================================ */
.usg{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
    gap:16px;
    padding:20px 16px;
    max-width:1100px;
    margin:0 auto;
}

.usg-block{
    background:#fff;
    border:1px solid #e5e7eb;
    border-radius:8px;
    overflow:hidden;
    box-shadow:0 1px 3px rgba(0,0,0,.08);
}
.usg-block:hover{
    box-shadow:0 4px 12px rgba(0,0,0,.12);
}

.usg-head{
    background:#1e3a5f;
    padding:10px 14px;
}
.usg-state{
    color:#fff;
    font-size:.95rem;
    font-weight:600;
    text-decoration:none;
    display:block;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.usg-state:hover{
    color:#e8f0fe;
}

.usg-cities{
    list-style:none;
    padding:8px 0;
    margin:0;
}
.usg-cities li{
    border-bottom:1px solid #f3f4f6;
}
.usg-cities li:last-child{
    border-bottom:none;
}
.usg-cities li a{
    display:flex;
    align-items:center;
    gap:6px;
    padding:7px 14px;
    font-size:.85rem;
    color:#374151;
    text-decoration:none;
    min-height:36px;
}
.usg-cities li a::before{
    content:'›';
    color:#0056b3;
    font-weight:700;
    flex-shrink:0;
}
.usg-cities li a:hover{
    background:#f0f7ff;
    color:#0056b3;
}

/* ================================================
   Responsive Breakpoints
   ================================================ */

/* Large desktop */
@media(min-width:1024px){
    .usg{
        grid-template-columns:repeat(3, 1fr);
    }
    .acf-listings-grid{
        grid-template-columns:repeat(2, 1fr);
    }
}

/* Tablet */
@media(max-width:768px){
    .usg{
        grid-template-columns:repeat(2, 1fr);
        gap:12px;
        padding:16px 12px;
    }
    .acf-listings-grid{
        grid-template-columns:1fr;
        gap:12px;
        padding:16px 12px;
    }
    .acf-listing-title{
        white-space:normal;
    }
}

/* Mobile */
@media(max-width:480px){
    .usg{
        grid-template-columns:repeat(2, 1fr);
        gap:8px;
        padding:12px 8px;
    }
    .usg-state{
        font-size:.85rem;
    }
    .usg-cities li a{
        font-size:.8rem;
        padding:6px 10px;
    }
    .acf-listings-grid{
        grid-template-columns:1fr;
        padding:12px;
    }
    .acf-logo-wrapper{
        width:80px;
        height:65px;
        min-width:80px;
    }
    .acf-no-logo{
        width:80px;
        height:65px;
        min-width:80px;
        font-size:1.5rem;
    }
    .acf-listing-title{
        font-size:.95rem;
    }
}