/* ---------------------------------------------------------------------------------------------------------------- */
/* |                                                CARD                                                          | */
/* ---------------------------------------------------------------------------------------------------------------- */

.card
{
    box-shadow: 0px 0px 6px rgb(0 0 0 / 50%);
    position: relative;
}

.card .card-body
{
    position: absolute;
    background-color: transparent;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    transition: 0.25s top ease-in-out;
}

.card:hover .card-body
{
    top: 32.5%;
}

.card .card-body h2
{
    font-size: 2.5rem;
    color: white;
    text-shadow: 0 0 20px black;
}

.card .img-container.darken-on-hover .img-background 
{
    background-color: rgba(0, 0, 0, 0.35);
}

.card .img-container.show-content-on-hover .img-container-content 
{
    text-align: left;
    color: white;
}

.card:hover .img-container.show-content-on-hover .img-container-content 
{
    opacity: 1;
    visibility: visible;
}

.card .img-container.same-aspect-ratio .img-container-content 
{
    top: 8.5%;
}

.card .img-container.show-content-on-hover .img-container-content .card-icon
{
    width: 2rem;
    height: 2rem;
    fill: white;
}

.card .img-container.show-content-on-hover .img-container-content .card-icon.phone
{
    width: 1.8rem;
    height: 1.8rem;
}

.card .img-container.show-content-on-hover .img-container-content h3
{
    font-size: 1.5rem;
    margin: 0 1.5rem;
    text-align: center;
    text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000;
}

.card .img-container.show-content-on-hover .img-container-content a
{
    margin-top: 1rem;
    letter-spacing: 0.25rem;
    padding: 0.75rem 2rem;
    padding-left: 2.25rem;
}

.card .img-container.show-content-on-hover .img-container-content .row
{
    flex-flow: nowrap;
}

.card .img-container.show-content-on-hover .img-container-content .row:first-child
{
    margin-bottom: 1rem;
}

.card:hover .img-container.darken-on-hover .img-background 
{
    background-color: rgba(0, 0, 0, 0.75);
}

.card:hover .img-container.zoom-on-hover .img-background 
{
    transform: scale(1.05);
}

@media (max-width: 1400px)
{
    .card:hover .card-body
    {
        top: 32.5%;
    }

    .card .card-body h2
    {
        font-size: 2rem;
    }

    .card .img-container.show-content-on-hover .img-container-content h3
    {
        font-size: 1.15rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon
    {
        width: 1.75rem;
        height: 1.75rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon.phone
    {
        width: 1.5rem;
        height: 1.5rem;
    }

    .card .img-container.show-content-on-hover .img-container-content a
    {
        padding: 0.5rem 1.5rem;
        padding-left: 1.75rem;
        font-size: 1.25rem;
    }
}

@media (max-width: 1200px)
{
    .card:hover .card-body
    {
        top: 32%;
    }

    .card .img-container.same-aspect-ratio .img-container-content 
    {
        top: 10%;
    }

    .card .card-body h2
    {
        font-size: 1.75rem;
    }

    .card .img-container.show-content-on-hover .img-container-content a
    {
        margin-top: 0.5rem;
    }
}

@media (max-width: 990px)
{
    .body-body .container-lg
    {
        max-width: 600px;
    }

    .card:hover .card-body
    {
        top: 35%;
    }

    .card .card-body h2
    {
        font-size: 4rem;
    }

    .card .img-container.same-aspect-ratio .img-container-content 
    {
        top: 10%;
    }

    .card .img-container.show-content-on-hover .img-container-content h3
    {
        font-size: 2rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon
    {
        width: 2rem;
        height: 2rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon.phone
    {
        width: 1.75rem;
        height: 1.75rem;
    }

    .card .img-container.show-content-on-hover .img-container-content a
    {
        margin-top: 1rem;
        padding: 0.75rem 5rem;
        padding-left: 5.25rem;
        font-size: 2.5rem;
    }
}

@media (max-width: 560px)
{
    .card:hover .card-body
    {
        top: 37.5%;
    }

    .card .card-body h2
    {
        font-size: 3.25rem;
    }

    .card .img-container.same-aspect-ratio .img-container-content 
    {
        top: 10%;
    }

    .card .img-container.show-content-on-hover .img-container-content h3
    {
        font-size: 1.5rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon
    {
        width: 1.5rem;
        height: 1.5rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon.phone
    {
        width: 1.25rem;
        height: 1.25rem;
    }

    .card .img-container.show-content-on-hover .img-container-content a
    {
        padding: 0.5rem 3.5rem;
        padding-left: 3.75rem;
        font-size: 1.75rem;
    }
}

@media (max-width: 500px)
{
    .card .card-body h2
    {
        font-size: 2.75rem;
    }
}

@media (max-width: 460px)
{
    .card .img-container.same-aspect-ratio .img-container-content 
    {
        top: 15%;
    }
}

@media (max-width: 425px)
{
    .card:hover .card-body
    {
        top: 37.5%;
    }

    .card .img-container.same-aspect-ratio .img-container-content 
    {
        top: 10%;
    }

    .card .card-body h2
    {
        font-size: 2rem;
    }

    .card .img-container.show-content-on-hover .img-container-content h3
    {
        font-size: 1.25rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon
    {
        width: 1.25rem;
        height: 1.25rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .card-icon.phone
    {
        width: 1rem;
        height: 1rem;
    }

    .card .img-container.show-content-on-hover .img-container-content a
    {
        padding: 0.5rem 1.5rem;
        padding-left: 1.75rem;
        font-size: 1rem;
    }

    .card .img-container.show-content-on-hover .img-container-content .row:first-child 
    {
        margin-bottom: 0.5rem;
    }
}

@media (max-width: 359px)
{
    .card .card-body h2
    {
        font-size: 1.8rem;
    }
}

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

.footer .shop-info
{
    border-top: 0.25rem solid #937631;
}