/* --------------------------------------------------------------
    FOOTER
-------------------------------------------------------------- */

/* Outer wrapper */
.vits-footer {
    background-color: var(--hotel-inn-beyond--palette--white);
    border: none !important;
    padding: 0 !important;
    box-shadow: 0 -4px 16px 0 rgba(0, 0, 0, 0.1);
}

/* Top inner layout container */
.vits-footer__top-inner {
    max-width: var(--hotel-inn-beyond--content-container-width--bootstrap-max);
    padding: 3.2rem var(--hotel-inn-beyond--gutter-main-content);
    margin-inline: auto;
}

/* Logo container */
.vits-footer__logo {
    display: block;
    text-decoration: none;
    width: 146px;
    margin: 0 auto 2.8rem;

    img {
        display: block;
        width: 100%;
        height: auto;
        max-width: 100%;
    }
}

/* Social container */
.vits-footer__social {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
}

.vits-footer__social-tagline {
    font-size: 1.4rem;
    line-height: 1.25;
    text-align: center;
    margin: 0;
}

.vits-footer__social-links {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.8rem 2rem;

}

.vits-footer__social-link {
    font-size: 2rem;
    color: var(--hotel-inn-beyond--palette--primary);
    line-height: 1;
    transition: color 0.3s ease-in-out, transform 0.3s ease-in-out;
}

.vits-footer__social-link:focus,
.vits-footer__social-link:hover {
    color: var(--hotel-inn-beyond--palette--primary-light);
    transform: scale(1.25);
    transition: color 0.15s ease-in-out, transform 0.15s ease-in-out;
}


/* Divider */
.vits-footer__divider {
    width: 100%;
    border-top: 1px solid var(--hotel-inn-beyond--palette--very-light-grey);
    margin-block: 2rem;
}

/* Menu */
ul.vits-footer__menu-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

li.vits-footer__menu-item {
    line-height: 0;
    margin: 0;
    padding: 0;
}

a.vits-footer__menu-link {
    position: relative;
    display: inline-block;
    color: var(--hotel-inn-beyond--palette--primary);
    font-size: 1.8rem;
    line-height: 1.25;
    font-weight: 400;
    text-decoration: none;
    font-family: var(--hotel-inn-beyond--font-family--secondary);
    border: none;
    transition: color 0.3s ease-in-out;
}

a.vits-footer__menu-link::after {
    display: block;
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: var(--hotel-inn-beyond--palette--primary-light);
    transition: width 0.3s ease-in-out;
}

a.vits-footer__menu-link:focus,
a.vits-footer__menu-link:hover {
    color: var(--hotel-inn-beyond--palette--primary-light);
    transition: color 0.15s ease-in-out;
}

a.vits-footer__menu-link:focus::after,
a.vits-footer__menu-link:hover::after {
    width: 100%;
    transition: width 0.15s ease-in-out;
}

.vits-footer__cta-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    margin-top: 2rem;
}

.vits-button-solid {
    background-color: var(--hotel-inn-beyond--palette--blue-grey);
    border-radius: 0.4rem;
    box-sizing: border-box;
    color: var(--hotel-inn-beyond--palette--white);
    cursor: pointer;
    display: inline-block;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.8rem;
    margin: 0;
    min-width: 80px;
    padding: 0.8rem 1.6rem;
    text-align: center;
    transition: background-color 0.3s ease-in-out;
}

.vits-button-solid:focus,
.vits-button-solid:hover {
    background-color: var(--hotel-inn-beyond--palette--primary-light);
    color: var(--hotel-inn-beyond--palette--text-dark-background);
    text-decoration: none;
    transition: background-color 0.15s ease-in-out;
}

/* Bottom section */
.vits-footer__bottom {
    background-color: var(--hotel-inn-beyond--palette--dark-grey);
}

/* Bottom inner layout container */
.vits-footer__bottom-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    max-width: var(--hotel-inn-beyond--content-container-width--bootstrap-max);
    padding: 0.8rem var(--hotel-inn-beyond--gutter-main-content) 1.6rem;
    margin-inline: auto;
}

/* Copyright text */
.vits-footer__copyright-text {
    font-size: 1.4rem;
    line-height: 1.25;
    font-family: var(--hotel-inn-beyond--font-family--primary);
    color: var(--hotel-inn-beyond--palette--text-dark-background);
    margin: 0;
}

/* Bottom right */
.vits-footer__bottom-right {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2rem;
}

/* Bottom Menu */
ul.vits-footer__bottom-menu-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

li.vits-footer__bottom-menu-item {
    line-height: 0;
    margin: 0;
    padding: 0;
}

a.vits-footer__bottom-menu-link {
    position: relative;
    display: inline-block;
    color: var(--hotel-inn-beyond--palette--text-dark-background);
    font-size: 1.4rem;
    line-height: 1.25;
    font-weight: 400;
    text-decoration: none;
    font-family: var(--hotel-inn-beyond--font-family--primary);
    border: none;
    transition: color 0.3s ease-in-out;
}

a.vits-footer__bottom-menu-link::after {
    display: block;
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: var(--hotel-inn-beyond--palette--text-dark-background);
    transition: width 0.3s ease-in-out;
}

a.vits-footer__bottom-menu-link:focus,
a.vits-footer__bottom-menu-link:hover {
    color: var(--hotel-inn-beyond--palette--text-dark-background);
}

a.vits-footer__bottom-menu-link:focus::after,
a.vits-footer__bottom-menu-link:hover::after {
    width: 100%;
    transition: width 0.15s ease-in-out;
}

/* Attribution */
a.vits-footer__attribution {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 1.4rem;
    line-height: 1.25;
    font-weight: 400;
    font-family: var(--hotel-inn-beyond--font-family--primary);
    color: var(--hotel-inn-beyond--palette--text-dark-background);
    margin: 0;
}

a.vits-footer__attribution::after {
    display: block;
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: var(--hotel-inn-beyond--palette--text-dark-background);
    transition: width 0.3s ease-in-out;
}

a.vits-footer__attribution:focus,
a.vits-footer__attribution:hover {
    color: var(--hotel-inn-beyond--palette--text-dark-background);
}

a.vits-footer__attribution:focus svg,
a.vits-footer__attribution:hover svg {
    fill: var(--hotel-inn-beyond--palette--primary-light);
    stroke: var(--hotel-inn-beyond--palette--primary-light);
    transition: fill 0.15s ease-in-out, stroke 0.15s ease-in-out;
}

a.vits-footer__attribution:focus::after,
a.vits-footer__attribution:hover::after {
    width: 100%;
    transition: width 0.15s ease-in-out;
}

a.vits-footer__attribution svg {
    display: block;
    width: 12px;
    height: 12px;
    fill: var(--hotel-inn-beyond--palette--text-dark-background);
    stroke: var(--hotel-inn-beyond--palette--text-dark-background);
    transition: fill 0.3s ease-in-out, stroke 0.3s ease-in-out;
}

/* Heart icon animation */
.vits-footer__heart-icon {
    animation: heartbeat 2s ease-in-out infinite;
    transform-origin: center;
}

@keyframes heartbeat {
    0% {
        transform: scale(1);
    }
    14% {
        transform: scale(1.1);
    }
    28% {
        transform: scale(1);
    }
    42% {
        transform: scale(1.1);
    }
    70% {
        transform: scale(1);
    }
    100% {
        transform: scale(1);
    }
}

/* Pause animation on hover for better UX */
a.vits-footer__attribution:hover .vits-footer__heart-icon {
    animation-play-state: paused;
}

@media (min-width: 768px) {

    /* Top inner layout container */
    .vits-footer__top-inner {
        padding-block: 4.4rem;
    }

    /* Menu */
    ul.vits-footer__menu-list {
        gap: 6rem;
    }

    a.vits-footer__menu-link {
        font-size: 2rem;
    }

    /* Bottom right */
    .vits-footer__bottom-right {
        flex-direction: row;
        justify-content: space-between;
        gap: 4rem;
    }

    /* Bottom Menu */
    ul.vits-footer__bottom-menu-list {
        gap: 4rem;
    }
}

@media (min-width: 992px) {
/* Bottom inner layout container */
.vits-footer__bottom-inner {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 4rem;
}
}
