@media only screen and (min-width: 0rem) {
    :root {
        /* 13px - 16px */
        --topperFontSize: clamp(0.8125rem, 1.6vw, 1rem);
        /* 31px - 49px */
        --headerFontSize: clamp(1.9375rem, 4.5vw, 3.0625rem);
        --bodyFontSize: 1rem;
        /* 60px - 100px top and bottom */
        --sectionPadding: clamp(3.75em, 7.82vw, 6.25em) 1rem;
    }
    #booking {
        /*background: var(--bodyTextColorWhite);*/
        /*padding: var(--sectionPadding);*/
        margin: auto;
        overflow: hidden;
        padding-bottom: 3.25rem;
    }

    #booking iframe{
        background: var(--bodyTextColorWhite);
    }

    #booking-iframe-container{
        padding: var(--sectionPadding);
        height: 100%;
    }

    #sj-contact{
        padding: var(--sectionPadding);
    }

    .contact-container{
        margin: auto;
        /* changes to 1280px at desktop */
        max-width: 50rem;
        width: 100%;
    }

    .contact-content{
        width: 100%;

    }

    .contact-topper {
        /* 8px - 12px */
        margin-bottom: clamp(0.5rem, 1.4vw, 1rem);
        text-align: left;
        font-size: var(--topperFontSize);
        color: var(--primaryDark);
    }

    #contact-form{
        margin-bottom: 2.5rem;

    }
    .c-title {
        font-size: var(--headerFontSize);
        max-width: 50rem;
        text-align: left;
        color: var(--bodyTextColorWhite);

    }

    .c-text {
        margin: 0 auto 0 0;
        /* 40px - 48px */
        margin-bottom: clamp(2.5rem, 6.3vw, 3rem);
        /* 404px - 522px */
        max-width: clamp(25.25rem, 50vw, 42.625rem);
        text-align: left;
        font-size: var(--bodyFontSize);
        color: var(--bodyTextColorWhite);
        line-height: var(--bodyFontSize);
    }

    #sj-contact label {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        /* 12px - 20px */
        margin-bottom: clamp(0.75rem, 1.3em, 1.25rem);
        font-size: 1rem;
        line-height: 1.5em;
        font-weight: 700;
        color: var(--headerColor);
    }

    .c-label-message {
        /* 32px - 48px */
        margin-bottom: clamp(2rem, 6.3vw, 3rem);
    }

    #contact-form input,
    #sj-contact #contact-form textarea {
        border: 1px solid #b4b2c7;
        border-radius: 0.5rem;
        margin-top: 0.25rem;
        height: 4rem;
        width: 100%;
        /* prevents border & padding from affecting height */
        box-sizing: border-box;
        padding-left: 1.25rem;
        font-size: 1rem;
        transition: border 0.3s;
    }
    #sj-contact #contact-form input:hover,
    #sj-contact #contact-form textarea:hover {
        border: 1px solid var(--primary);
    }
    #sj-contact #contact-form textarea {
        min-height: 7.5rem;
        padding-top: 1.25rem;
        font-family: inherit;
    }
    #sj-contact #contact-form .cs-button-solid {
        border: none;
        width: 100%;
        color: var(--bodyTextColorWhite);
        background-color: var(--secondaryLight);
    }
    #sj-contact .c-right-section {
        position: relative;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        align-items: flex-start;
        border-radius: 0.5rem;
        height: 20rem;
        /* cuts off corners on img tag */
        overflow: hidden;
        /* 24px - 40px top & bottom */
        /* 20px - 40px left & right */
        padding: clamp(1.5rem, 3vw, 2.5rem) clamp(1.25rem, 3vw, 2.5rem);
    }

    #sj-contact .c-header {
        display: block;
        margin-bottom: 0.5rem;
        /* 16px - 20px */
        font-size: clamp(1rem, 3vw, 1.25rem);
        line-height: 1.2em;
        font-weight: 700;
        color: var(--bodyTextColorWhite);
    }
    #sj-contact .c-link {
        position: relative;
        display: block;
        margin-bottom: 1.25rem;
        text-decoration: none;
        /* 16px - 20px */
        font-size: clamp(1rem, 3vw, 1.25rem);
        line-height: 1.2em;
        color: var(--bodyTextColorWhite);
    }
    #sj-contact .c-link:before {
        position: absolute;
        bottom: calc(-2 / 16 * 1rem);
        left: 0;
        /* Animated underline */
        content: "";
        opacity: 1;
        display: block;
        /* current color of the parent */
        background: currentColor;
        height: 2px;
        width: 0%;
        transition: width 0.3s;
    }
    #sj-contact .cs-link:hover:before {
        width: 100%;
    }
    #sj-contact .cs-link:last-of-type {
        margin-bottom: 0;
    }
    #sj-contact .cs-block {
        /* sends second address line to the bottom on its own line */
        display: block;
    }
}

/* Tablet */
@media only screen and (min-width: 43.75rem) {
    #booking{
        margin: auto;
        /*max-width: 50rem;*/
    }

    #sj-contact #contact-form {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: flex-start;
    }
    #sj-contact #contact-form label {
        width: 48%;
    }
    #sj-contact #contact-form .c-label-message {
        width: 100%;
    }
}
/* Small Desktop */
@media only screen and (min-width: 64rem) {
    #booking{
        margin: auto;
        max-width: 90%;
    }
    #sj-contact .contact-container {
        display: flex;
        justify-content: flex-end;
        align-items: flex-start;
        max-width: 80rem;
        gap: 5rem;
    }
    #sj-contact #c-form {
        max-width: 39.375rem;
    }
    #sj-contact #c-form label {
        width: 100%;
    }
    #sj-contact .c-right-section {
        /* changes to 578px at 1300px wide */
        height: 42.875rem;
        max-width: 33.875rem;
        width: 40%;
        /* prevents flexbox from squishing it */
        flex: none;
    }
    #sj-contact .c-right-section:hover .c-bg-picture {
        transform: scale(1.1);
    }
    #sj-contact .c-block {
        /* goes back to inline so it stays "in line" with the rest of the text */
        display: inline-block;
    }
}

@media only screen and (min-width: 81.25em) {
    #sj-contact #contact-form {
        column-gap: 0rem;
    }
    #sj-contact #contact-form label {
        max-width: 19.0625rem;
        width: 48%;
    }
    #sj-contact #contact-form .c-label-message {
        max-width: 100%;
    }
    #sj-contact .c-right-section {
        height: 36.125rem;
    }
}