@import url('./sections/hero.css');
@import url('./sections/content-2-images-links.css');

:root {
    --hero-height: 90svh;
}

/* Header overlays the hero on the home page (no padding-top on #main),
   so header-height must not be added to the frame-top calculation. */
body.home .site-shell::before {
    --frame-top: calc(var(--hero-height) - var(--frame-top-spacing));
}

.section-heading {
    padding-block: 4rem 2rem;

    .page-heading {
        max-width: 100%;
        text-align: center;

        img {
            width: 48px;
        }

        .smaller {
            font-size: var(--text-36px);
        }

        & :is(h1,
            h2,
            h3,
            h4,
            h5,
            h6) {
            font-size: var(--text-40px);
            letter-spacing: 0.06em;
            line-height: 1.5;
        }
    }
}

.our-suites {
    padding-block: 4rem 10rem;

    .container {
        max-width: 100%;
        margin: 0;
        padding-inline-start: 0;
        display: flex;
        gap: 5.25rem;
    }

    .right img {
        width: 100%;
        max-width: 870px;
        aspect-ratio: 870 / 826;
        object-fit: cover;
    }

    .left {
        display: flex;
        flex-direction: column;
        gap: 6.25rem;
        padding-block-start: 2.375rem;

        .texts {
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            gap: 3rem;
            padding-inline-start: 4rem;
        }

        .section-content {
            max-width: 550px;

            & :is(h1,
                h2,
                h3,
                h4,
                h5,
                h6) {
                font-size: var(--text-50px);
                letter-spacing: var(--ls-titles);
            }
        }

        .left-img {
            width: 100%;
            max-width: 746px;
            aspect-ratio: 746 / 552;
            object-fit: cover;
        }
    }
}

.special-offers {
    padding-block: 4.75rem;
    color: var(--color-white);
    position: relative;
    background-color: black;

    &::before {
        content: '';
        position: absolute;
        inset: 0;
        background-image: var(--bg-image);
        opacity: 0.15;
        pointer-events: none;
    }

    .container {
        max-width: 100%;
        position: relative;
    }

    .section-content {
        padding-block-start: 1rem;

        img {
            max-width: fit-content;
        }

        .title {
            font-size: var(--text-58px);
        }

        .smaller {
            font-size: var(--text-40px);
        }
    }

    .top {
        display: flex;
        align-items: center;
        gap: 3rem;
    }

    .heading {
        flex-shrink: 0;
        max-width: 320px;
    }

    .offers-swiper {
        width: 100%;
        position: relative;
        overflow: hidden;
    }

    .offers-grid .offers-cards {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5625rem;
    }

    .offer-card-wrap {
        display: flex;
        flex-direction: column;
    }

    .offer-card {
        display: flex;
        flex-direction: column;
        gap: 1rem;
        user-select: none;

        .title {
            font-size: var(--text-36px);
        }

        .card-img img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            aspect-ratio: 1;
        }

        .content {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .link {
            display: flex;
            align-items: center;

            svg {
                transition: transform 0.25s ease;
            }
        }

        &:hover .link svg {
            transform: translateX(-3px);
        }
    }

    .view-all-link {
        grid-column: span 2;
        display: flex;
        align-items: center;
        justify-content: center;
        padding-block-start: 4rem;

        a {
            color: inherit;
        }
    }
}

.bg-img-content {
    display: flex;
    align-items: center;
    height: 528px;
    background: linear-gradient(rgba(0, 0, 0, 0.6)), var(--bg-image) center / cover no-repeat;
    background-attachment: fixed;

    .container {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 4rem;
        text-align: center;

        .title {
            font-size: var(--text-96px);
            line-height: var(--lh-heading);
            color: var(--color-white);
            letter-spacing: 0.02em;

            .subtitle {
                font-size: var(--text-36px);
                font-weight: 500;
                letter-spacing: 0.17em;
            }
        }

        .link {
            background: transparent;
            color: var(--color-white);
            border: 1px solid var(--color-white);

            &:hover {
                color: inherit;
            }

            &::before {
                background: var(--color-white);
            }
        }
    }
}

.cards-grid {
    position: relative;
    background-color: black;
    padding-block: 2rem 6.25rem;

    &::before {
        content: '';
        position: absolute;
        inset: 0;
        background-image: var(--bg-image);
        opacity: 0.15;
        pointer-events: none;
    }

    .container {
        display: flex;
        flex-direction: column;
        gap: 2rem;
    }

    .section-titles .title {
        text-align: center;
        color: var(--color-white);
    }

    .cards {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 0.75rem;
        position: relative;
        z-index: 1;
    }

    .card {
        border: 1px solid var(--color-gold);
        display: flex;
        padding: 0.75rem;

        .card-wrap {
            display: flex;
            flex-direction: column;
            gap: 1rem;
            background-color: #fff;
            text-align: center;
            padding: 2.75rem;
        }

        .icon {
            margin: auto auto 0;
        }

        .title {
            font-size: var(--text-36px);
        }

        .content {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }
    }
}

/* ============================================================
   Google Reviews — Swiper section
   ============================================================ */

.google-reviews {
    padding-block: 3rem 6.25rem;

    .reviews-swiper {
        padding-block: 3rem;
    }
}

.review-card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    background-color: var(--color-white);
    padding: 1.75rem 1.25rem;
    box-shadow: -8px -4px 29px 0px rgba(0, 0, 0, 0.08);
    border-radius: 5px;
    user-select: none;
    height: auto;
}

.review-card .card-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.review-card .google-logo {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
}

.review-card .stars {
    display: flex;
    align-items: center;
}

.review-card .star {
    width: 28px;
    height: 28px;
    fill: hsl(var(--primary) / 0.15);
}

.review-card .star.filled {
    fill: #F5A623;
}

.review-card .review-text {
    line-height: var(--lh-body);
    color: hsl(var(--primary) / 0.8);
    overflow: hidden;
    flex: 1;
    text-align: center;
}

.review-card .author {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    margin-block-start: auto;
    padding-block-start: 1rem;
}

.review-card .author-name {
    font-size: var(--text-18px);
    font-weight: 700;
    color: var(--color-primary);
}

.review-card .review-date {
    font-weight: 400;
    color: hsl(var(--primary) / 0.5);
}

.review-card .avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.reviews-swiper .swiper-button-prev,
.reviews-swiper .swiper-button-next {
    --swiper-navigation-sides-offset: var(--container-padding);

    bottom: 0;
}

@media (max-width: 1023px) {
    .our-suites {
        .container {
            flex-direction: column;
            padding-inline-start: var(--container-padding);
        }

        .right img {
            max-width: 100%;
        }

        .left {
            padding-block-start: 0;

            .section-content {
                max-width: 100%;
            }

            .left-img {
                max-width: 100%;
            }

            .texts {
                padding-inline-start: 0;
                align-items: revert;
            }
        }
    }

    .special-offers {
        .container {
            padding-inline-start: var(--container-padding);
        }

        .top {
            flex-direction: column;
            align-items: flex-start;
        }

        .heading {
            max-width: 100%;
        }

        .section-content {
            padding-block-start: 0;
        }

        .offers-grid .offers-cards {
            grid-template-columns: repeat(2, 1fr);
        }
    }

    .cards-grid {
        .cards {
            grid-template-columns: 1fr;
        }

        .card .card-wrap {
            padding: 2rem 1rem;
        }
    }

    .google-reviews {
        padding-block: 3rem 5rem;

        .reviews-swiper {
            padding-block-end: 3rem;
        }
    }
}

@media (max-width: 600px) {
    .special-offers .offers-grid .offers-cards {
        grid-template-columns: repeat(1, 1fr);
    }
}