.place-directory {
    background: #f7f8f5;
    min-height: 70vh;
}

.place-directory__shell {
    margin: 0 auto;
    max-width: 1180px;
    padding-left: 24px;
    padding-right: 24px;
}

.place-directory__hero {
    background: linear-gradient(135deg, #163f32, #2d7258);
    color: #fff;
    padding: 72px 0 64px;
}

.place-directory__eyebrow {
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .18em;
    margin: 0 0 .8rem;
    text-transform: uppercase;
}

.place-directory__hero h1 {
    font-size: clamp(2.4rem, 6vw, 4.7rem);
    line-height: 1;
    margin: 0;
}

.place-directory__hero p:last-child {
    font-size: 1.15rem;
    margin: 1.2rem 0 0;
    max-width: 760px;
}

.place-directory__content {
    padding-bottom: 72px;
    padding-top: 48px;
}

.place-directory__grid {
    display: grid;
    gap: 24px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.place-directory-card {
    background: #fff;
    border: 1px solid rgba(19, 62, 49, .1);
    border-radius: 18px;
    box-shadow: 0 10px 30px rgba(19, 62, 49, .08);
    overflow: hidden;
}

.place-directory-card__image-link {
    display: block;
    height: 220px;
    overflow: hidden;
}

.place-directory-card img {
    height: 100%;
    object-fit: cover;
    transition: transform .3s ease;
    width: 100%;
}

.place-directory-card:hover img {
    transform: scale(1.025);
}

.place-directory-card__body {
    padding: 22px;
}

.place-directory-card h2 {
    margin: 0 0 .75rem;
}

.place-directory-card h2 a,
.place-directory-card__link {
    color: #18583f;
    text-decoration: none;
}

.place-directory-card p {
    color: #53615b;
    line-height: 1.65;
}

.place-directory-card__link {
    display: inline-flex;
    font-weight: 700;
    gap: .5rem;
    margin-top: .5rem;
}

.place-directory__empty {
    background: #fff;
    border-radius: 16px;
    padding: 2rem;
}

@media (max-width: 980px) {
    .place-directory__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
    .place-directory__grid { grid-template-columns: 1fr; }
    .place-directory__hero { padding: 52px 0 46px; }
}
