/* =========================
   HOME
========================= */
.facilities-section {
    align-items: flex-start;
}

.facilities-left,
.facilities-right {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.facilities-text-block {
    margin-bottom: 24px;
}

    .facilities-text-block h3 {
        margin-bottom: 10px;
    }

    .facilities-text-block p {
        margin-bottom: 20px;
        line-height: 1.8;
    }

.facilities-main-img,
.facilities-sub-img,
.facilities-shower-img,
.dormitory-main-img,
.dormitory-sub-img,
.lounge-img,
.lounge-main-img,
.floor-img,
.floor-main-img {
    width: 100%;
    border-radius: 8px;
}

.facilities-main-img,
.dormitory-main-img {
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.facilities-sub-img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.facilities-shower-img {
    height: 100%;
    max-height: 720px;
    object-fit: cover;
}

.dormitory-section,
.lounge-section {
    margin-top: 40px;
    margin-bottom: 40px;
}

.dormitory-text p,
.lounge-description {
    line-height: 1.8;
}

.lounge-img {
    height: 220px;
    object-fit: cover;
}

.lounge-main-img {
    height: 460px;
    object-fit: cover;
}

.lounge-right {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.floor-img {
    height: 160px;
    object-fit: cover;
}

.floor-main-img {
    height: 300px;
    object-fit: cover;
}

@media (max-width: 991.98px) {
    .facilities-right,
    .dormitory-images {
        margin-top: 24px;
    }

    .facilities-shower-img,
    .lounge-main-img,
    .lounge-img,
    .floor-main-img,
    .floor-img {
        height: auto;
        max-height: none;
    }
}

/* =========================
   ACCESS
========================= */
.access-hero img {
    width: 100%;
    height: 500px;
    object-fit: cover;
}

.access-container {
    max-width: 1200px;
    margin: auto;
    padding: 40px 20px;
}

.access-title {
    font-size: 42px;
    margin-bottom: 20px;
}

.access-address p {
    margin: 4px 0;
}

.access-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    margin-top: 40px;
    margin-left: 130px;
}

.access-left {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.access-map iframe,
.access-right img,
.access-map-photo img {
    width: 100%;
    border-radius: 8px;
}

.access-right img,
.access-map-photo img {
    object-fit: cover;
}

.access-subtitle {
    margin-top: 60px;
    margin-bottom: 20px;
    margin-left: 90px;
}

.access-spots {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(200px,1fr));
    gap: 20px;
    margin-left: 90px;
}

.spot-card img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    border-radius: 8px;
}

.spot-title {
    text-align: center;
    margin-top: 8px;
}

@media (max-width: 768px) {
    .access-hero img {
        height: 300px;
    }

    .access-layout,
    .access-map-section {
        grid-template-columns: 1fr;
    }

    .access-layout,
    .access-subtitle,
    .access-spots {
        margin-left: 0;
    }
}

/* =========================
   PAGE HERO GRID
========================= */
.no-gap {
    margin-right: 0;
    margin-left: 0;
}

    .no-gap > [class^="col-"] {
        padding-right: 0;
        padding-left: 0;
    }

.page-hero-grid img {
    width: 100%;
    height: 350px;
    object-fit: cover;
}
