/** Extra Large Devices **/
@media (min-width: 1650px) {
    .block-featured {
        min-height: 525px;
    }

    .featured-content {
        position: relative;
        display: flex;
        width: 100%;
        height: 100%;
        padding: 125px;
    }

    .featured-content--background {
        clip-path: url(#featured-clipPath-large);
    }
}

/** Mobile Menu Breakpoint **/
@media (max-width: 1024px) {
    #site-header .wrap {
        padding: 20px 3.5% 10px;
    }

    #site-header #header-hide-on-mobile {
        display: none;
        position: absolute;
        background-color: var(--white);
        z-index: 99;
        padding: 40px;
        right: 0;
        -webkit-box-shadow: 0px 10px 12px 0px rgba(0,0,0,0.25); 
        box-shadow: 0px 10px 12px 0px rgba(0,0,0,0.25);
        transition: 0.5s ease-in-out;
    }

    #site-header #header-hide-on-mobile.active {
        display: block;
    }

    #site-header .float-right #header-hide-on-mobile > div:first-of-type {
        display: block;
    }

    #site-header #mobile-menu-toggle {
        display: block;
    }

    #menu-header-menu > li {
        display: block;
        margin: 1.125rem 0 0 0;
    }

    #site-header .float-right .search {
        padding: 0;
        margin: 0 0 1.25rem;
    }

    #menu-header-menu .sub-menu {
        position: relative;
        display: block;
        text-align: right;
        width: 100%;
        margin: 0;
        padding: 0;
        left: 0;
    }

    #menu-header-menu .sub-menu li {
        font-family: var(--OpenSansR);
        font-size: 0.875rem;
        padding: 5px 0 0 0;
    }

    #site-header .float-left {
        width: 65%;
    }

    #site-header .float-right {
        width: 35%;
    }

}

/** Font Size Breakpoint **/
@media (max-width: 964px) {
    h1,
    .h1,
    .h1 p {
        font-size: 2.625rem;
    }

    h2,
    .h2,
    .h2 p {
        font-size: 2.1875rem;
    }

    h3,
    .h3,
    .h3 p {
        font-size: 1.3125rem;
    }

    h4,
    .h4,
    .h4 p {
        font-size: 0.875rem;
    }

    h5,
    .h5,
    .h5 p
    h6,
    .h6,
    .h6 p {
        font-size: 0.875rem;
    }

    p .lead,
    .lead {
        font-size: 1.3125rem;
    }

    p {
        font-size: 0.875rem;
    }

    .testimonial-desc q {
        font-size: 1.75rem;
    }

    .fullwidth-hero--slide-text {
        padding-bottom: 1.75rem;
    }

    .fullwidth-hero--slider-navigation {
        position: absolute;
        width: 100%;
        bottom: 20px;
        padding: 0;
        text-align: center;
    }

    .fullwidth-hero--slider-navigation .wrap {
        position: relative;
        width: 100%;
        bottom: 0;
        right: 0;
    }

    .fullwidth-hero--badge-container .fullwidth-hero--badge {
        width: 180px;
        top: -12px;
    }

    .fullwidth-hero--badge a {
        font-size: 1.3125rem;
    }

    .fullwidth-hero--badge a span img {
        margin: 0.5rem auto 0;
    }

    .fullwidth-hero--slide img {
        height: 485px;
    }

    #site-footer .bottom .wrap {
        display: block;
        text-align: center;
    }

    #menu-footer-menu {
        margin-bottom: 1rem;
    }

    #site-footer .bottom {
        padding: 20px 3.5%;
    }

    #site-footer .bottom p {
        margin-top: 1rem;
    }

    .single-default img {
        height: 400px;
    }

}

@media (max-width: 768px) {
    .block-upcoming-events .events-list .upcoming-event {
        width: 100%;
        margin: 0 auto 0 0;
        padding: 0 3.5% 3rem;
    }

    .block-upcoming-events .events-list .upcoming-event .top {
        width: 42%;
    }

    .block-upcoming-events .events-list .upcoming-event .bottom {
        width: calc(58% - 2rem);
        margin-left: 2rem;
    }

    .block-upcoming-events .events-list .upcoming-event a {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .block-upcoming-events .events-list .upcoming-event:last-of-type {
        padding-bottom: 0;
    }

    .block-upcoming-events .header .readMore-arrow {
        margin-top: 1rem;
    }

    .block-callout .left {
        width: 100%;
        margin-bottom: 1.5rem;
    }

    .block-callout .right {
        width: 100%;
    }

    .block-testimonials .testimonials {
        padding: 35px 0 10px;
    }

    .testimonial-content {
        width: 100%;
        padding: 0;
    }

    .testimonial-badge {
        width: 100%;
        max-width: 250px;
        margin-top: 1rem;
    }

    .block-featured {
        min-height: 400px;
    }

    .featured-content--background {
        min-width: 350px;
    }

    .featured-content .wrap {
        padding-left: 0;
        max-width: 325px;
    }

    #site-footer .social .left-column, 
    .block-social .social .left-column {
        width: 100%;
        padding-right: 0;
        margin-bottom: 32px;
    }

    #site-footer .social .right-column, 
    .block-social .social .right-column {
        width: 100%;
    }

    .block-social .social {
        padding: 50px 0 10px;
    }

    .block-social .social h2 {
        margin-bottom: 0.875rem;
    }

    .affiliates {
        display: block;
        padding: 50px 0;
    }

    .affilitates-title {
        display: block;
        margin-bottom: 1.25rem;
    }

    .affilitates-content {
        width: 100%;
        padding: 0;
    }

    .left-column {
        width: 100%;
        padding: 0;
        margin-bottom: 2rem;
    }

    .right-column {
        width: 100%;
    }

    .block-two-column {
        margin: 1.875rem 0 0;
    }

    #main > .wrap.default-template {
        margin: 10px 0 35px;
    }

    .single-default img {
        height: 325px;
    }

    .woocommerce table.shop_table_responsive tr td::before, .woocommerce-page table.shop_table_responsive tr td::before {
        content: '';
    }

    .woocommerce-account .woocommerce-MyAccount-content table.shop_table td {
        text-align: left!important;
    }

}

@media (max-width: 650px) {
    .single-post-archive a {
        display: flex;
        flex-wrap: wrap;
    }

    .single-post-archive .left {
        width: 100%;
        padding: 0;
        order: 2;
    }

    .single-post-archive .right {
        width: 100%;
        order: 1;
        max-width: 500px;
        margin: 0 auto 1rem 0;
    }

    .single-post-archive img {
        height: 250px;
    }

}

@media (max-width: 500px) {
    .fullwidth-hero--slide-text h1 {
        font-size: 2.1875rem;
        padding: 0 4%;
    }

    .block-upcoming-events .events-list .upcoming-event .top,
    .block-upcoming-events .events-list .upcoming-event .bottom {
        width: 100%;
        margin: 0;
    }

    .block-upcoming-events .wrap {
        padding: 32px 3.5% 50px;
    }

    .block-callout .wrap {
        padding: 35px 3.5%;
    }

    .block-featured {
        min-height: 325px;
    }

    .featured-content--background {
        min-width: 300px;
    }

    .block-social .social {
        padding: 35px 0 0;
    }

    .affiliates {
        padding: 35px 0;
    }

    .affilitates-content > .affiliate {
        width: 100%;
        margin-bottom: 1.5rem;
    }

    .affilitates-content > a {
        margin-top: 0;
    }

    .block-two-column .content .column {
        width: 100%;
        padding: 0;
    }

    .block-two-column .right .content-group:last-of-type {
        margin-bottom: 0;
    }

    .single-default img {
        height: 275px;
    }

    div.wpforms-container-full .wpforms-form .wpforms-one-half {
        width: 100%!important;
        margin: 0!important;
        padding: 0 0 0.5rem!important;
    }

}

@media (max-width: 400px) {
    .single-post-archive img {
        height: 200px;
    }
}