
/*-- -------------------------- -->
<---        Content Page        -->
<--- -------------------------- -*/

/* Mobile - 360px */
@media only screen and (min-width: 0rem) {
    #content-page-714 {
        padding: var(--sectionPadding);
        background-color: #fff;
        /* clips the wave background from causing overflow issues when it goes off screen */
        overflow: hidden;
        position: relative;
        z-index: 1;
    }
    #content-page-714 .cs-container {
        width: 100%;
        max-width: 80rem;
        margin: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        /* 48px - 64px */
        gap: clamp(3rem, 6vw, 4rem);
        position: relative;
    }
    #content-page-714 .cs-content {
        /* set text align to left if content needs to be left aligned */
        text-align: left;
        width: 100%;
        max-width: 46.125rem;
        display: flex;
        flex-direction: column;
        /* centers content horizontally, set to flex-start to left align */
        align-items: flex-start;
    }
    #content-page-714 .cs-content img {
        width: 100%;
        height: auto;
        margin: 1rem 0;
        display: block;
    }
    #content-page-714 .cs-title {
        font-size: var(--headerFontSize);
        font-weight: 900;
        line-height: 1.2em;
        text-align: inherit;
        width: 100%;
        max-width: 100%;
        margin: 0 0 1rem 0;
        color: var(--headerColor);
        position: relative;
    }
    #content-page-714 h2,
    #content-page-714 h3,
    #content-page-714 h4,
    #content-page-714 h5,
    #content-page-714 h6 {
        font-weight: 700;
        text-align: inherit;
        margin: 0 0 1rem 0;
        color: var(--headerColor);
    }
    #content-page-714 h2 {
        font-size: 2rem;
        margin-top: 2rem;
    }
    #content-page-714 h3 {
        font-size: 1.5rem;
        color: var(--primary);
    }
    #content-page-714 h4,
    #content-page-714 h5,
    #content-page-714 h6 {
        font-size: 1.25rem;
    }
    #content-page-714 .cs-button-solid {
        margin-bottom: 2rem;
    }
    #content-page-714 .cs-color {
        color: var(--primary);
    }
    #content-page-714 p {
        font-size: var(--bodyFontSize);
        line-height: 1.5em;
        text-align: inherit;
        width: 100%;
        margin: 0 0 1rem 0;
        color: var(--bodyTextColor);
    }
    #content-page-714 p:last-of-type {
        margin-bottom: 2rem;
    }
    #content-page-714 p a {
        font-size: inherit;
        line-height: inherit;
        text-decoration: underline;
        color: var(--primary);
    }
    #content-page-714 ol,
    #content-page-714 ul {
        padding-left: 1.5rem;
        margin: 0 0 2rem 0;
        color: var(--bodyTextColor);
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }
    #content-page-714 ul li {
        list-style: none;
        color: inherit;
        position: relative;
    }
    #content-page-714 ul li:before {
        /* custom list bullet */
        content: "";
        width: 3px;
        height: 3px;
        background: currentColor;
        opacity: 1;
        border-radius: 50%;
        position: absolute;
        display: block;
        top: 0.625rem;
        left: -0.75rem;
    }
    #content-page-714 .cs-image-group {
        /* scales the whole section down and ties the font size to the vw and stops at 70% of the vale of 1em, changes at desktop */
        font-size: min(1vw, 1em);
        /* everything inside this box is in ems so we can scale it all down proportionally with a font size */
        width: 33.875em;
        height: 48.3125em;
        display: none;
        /* prevents flexbox from squishing it */
        flex: none;
        position: relative;
        z-index: 1;
    }
    #content-page-714 .cs-picture {
        width: 33.875em;
        height: 40.4375em;
        border-radius: 17.8125em;
        border: 0.75em solid #ffffff;
        background-color: #f7f7f7;
        /* prevents border from affecting height and width */
        box-sizing: border-box;
        /* clips img tag corners */
        overflow: hidden;
        display: block;
        position: absolute;
        top: 0;
        left: 0;
    }
    #content-page-714 .cs-picture img {
        width: 100%;
        height: 100%;
        /* makes it act like a background image */
        object-fit: cover;
        position: absolute;
        top: 0;
        left: 0;
    }
    #content-page-714 .cs-flower {
        width: 22.625em;
        height: auto;
        display: block;
        position: absolute;
        bottom: -2.375em;
        right: -3em;
        z-index: -1;
        transform: rotate(142deg);
    }
    #content-page-714 .cs-sense {
        width: 5em;
        height: auto;
        position: absolute;
        top: -0.25em;
        left: 0.625em;
        transform: rotate(90deg);
    }
    #content-page-714 .cs-background {
        display: none;
    }
}
/* Tablet - 768px */
@media only screen and (min-width: 48rem) {
    #content-page-714 .cs-container {
        flex-direction: row;
        align-items: flex-start;
    }
    #content-page-714 .cs-image-group {
        display: block;
        /* sends it to the left in the 1st position */
        order: -1;
    }
    #content-page-714 .cs-content {
        margin-left: auto;
    }
    #content-page-714 .cs-background {
        width: 20%;
        height: 100%;
        background-color: #f7f7f7;
        display: block;
        position: absolute;
        left: 0;
        top: 0;
        z-index: -1;
    }
    #content-page-714 .cs-background img {
        width: 100%;
        height: 100%;
        opacity: 0.2;
        object-fit: cover;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1;
    }
}
/* Large Desktop 1300px */
@media only screen and (min-width: 81.25rem) {
    #content-page-714 .cs-image-group {
        /* position absolute so we can have it overflow the container as seen in the design. */
        font-size: inherit;
        position: absolute;
        top: 0rem;
        left: -6.25rem;
    }
    #content-page-714 .cs-background {
        width: 50%;
        /* with the left edge always positioned at the center line, we push right of the center line by 335px.  This ensures that this element will stay exactly in this position no matter hoe wide the screen gets */
        margin-right: 20.9375rem;
        left: auto;
        /* sets the right edge of the element to be at the center line */
        right: 50%;
    }
}
/*-- -------------------------- -->
<---           Quote            -->
<--- -------------------------- -*/

/* Mobile - 360px */
@media only screen and (min-width: 0rem) {
    #quote-560 {
        padding: var(--sectionPadding);
        background-color: var(--primary);
    }
    #quote-560 .cs-container {
        width: 100%;
        max-width: 80rem;
        margin: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        /* 48px - 64px */
        gap: clamp(3rem, 6vw, 4rem);
    }
    #quote-560 .cs-content {
        /* set text align to left if content needs to be left aligned */
        text-align: left;
        width: 100%;
        display: flex;
        flex-direction: column;
        /* centers content horizontally, set to flex-start to left align */
        align-items: flex-start;
        /* 16px - 20px */
        gap: clamp(1rem, 2vw, 1.25rem);
    }

    #quote-560 .cs-topper:before {
        /* yellow line */
        content: "";
        width: 3.125rem;
        height: 2px;
        background: var(--secondary);
        opacity: 1;
        display: block;
    }
    #quote-560 .cs-quote {
        /* 31px - 49px */
        font-size: clamp(1.9375rem, 5.1vw, 3.0625rem);
        line-height: 1.2em;
        font-weight: 900;
        margin: 0;
        color: var(--bodyTextColorWhite);
    }
    #quote-560 .cs-name {
        /* 16px - 20px */
        font-size: clamp(1rem, 1.7vw, 1.25rem);
        line-height: 1.2em;
        font-weight: 700;
        text-transform: uppercase;
        margin: 0;
        color: var(--secondary);
        display: block;
        letter-spacing: 0.01em;
    }
}
/*-- -------------------------- -->
<---       Contact Form         -->
<--- -------------------------- -*/

/* Mobile - 360px */
@media only screen and (min-width: 0rem) {
    @keyframes scaleFade {
        0% {
            transform: translate(-50%, -50%) scale(0);
        }
        50% {
            opacity: 1;
            transform: translate(-50%, -50%) scale(1.4);
        }
        100% {
            transform: translate(-50%, -50%) scale(1.7);
            opacity: 0;
        }
    }
    #cs-contact-549 {
        padding: var(--sectionPadding);
    }
    #cs-contact-549 .cs-container {
        width: 100%;
        max-width: 80rem;
        margin: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        /* 48px - 64px */
        gap: clamp(3rem, 6vw, 4rem);
    }
    #cs-contact-549 .cs-content {
        /* set text aling to left if content needs to be left aligned */
        text-align: center;
        width: 100%;
        display: flex;
        flex-direction: column;
        /* centers content horizontally, set to flex-start to left align */
        align-items: center;
    }
    #cs-contact-549 .cs-topper {
        font-size: var(--topperFontSize);
        line-height: 1.2em;
        text-transform: uppercase;
        text-align: inherit;
        letter-spacing: 0.1em;
        font-weight: 700;
        color: var(--primary);
        margin-bottom: 0.25rem;
        display: block;
    }
    #cs-contact-549 .cs-title {
        font-size: var(--headerFontSize);        
        color: var(--primary);
        font-weight: 900;
        line-height: 1.2em;
        text-align: inherit;
        /* max width of 24 characters including spaces */
        max-width: 24ch;
        margin: 0 0 1rem 0;        
        position: relative;
    }
    #cs-contact-549 .cs-text {
        font-size: var(--bodyFontSize);
        line-height: 1.5em;
        text-align: inherit;
        width: 100%;
        max-width: 40.625rem;
        margin: 0;
        color: var(--bodyTextColor);
    }
    #cs-contact-549 .cs-background {
        width: 100%;
        height: 19.5rem;
        display: block;
        position: relative;
    }
    #cs-contact-549 .cs-background:before {
        /* yellow dot */
        content: "";
        width: 1.125rem;
        height: 1.125rem;
        background: var(--primary);
        border-radius: 50%;
        opacity: 1;
        position: absolute;
        display: block;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 10;
    }
    #cs-contact-549 .cs-background:after {
        /* yellow animated ring */
        content: "";
        width: 1.125rem;
        height: 1.125rem;
        background: transparent;
        border-radius: 50%;
        border: 1px solid var(--primary);
        opacity: 1;
        position: absolute;
        display: block;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%) scale(0);
        z-index: 10;
        transition:
            transform 0.4s,
            opacity 0.4s;
        animation-name: scaleFade;
        animation-duration: 2s;
        animation-timing-function: linear;
        animation-fill-mode: forwards;
        animation-iteration-count: infinite;
    }
    #cs-contact-549 .cs-background img {
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        object-fit: cover;
    }
    #cs-contact-549 .cs-form {
        width: 100%;
        max-width: 66.5rem;
        display: flex;
        flex-direction: column;
        gap: 1.25rem;
    }
    #cs-contact-549 .cs-label {
        /* 16px - 20px */
        font-size: clamp(1rem, 2vw, 1.25rem);
        line-height: 1.5em;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
        position: relative;
    }
    #cs-contact-549 .cs-input,
    #cs-contact-549 .cs-textarea,
    #cs-contact-549 select,
    #cs-contact-549 .cs-select {
        /* added options for the select tag in case you add it, that way it will also have the same styles, add the cs-select class for better specificity when targeting it */
        /* 16px - 20px */
        font-size: clamp(1rem, 2vw, 1.25rem);
        font-family: inherit;
        margin: 0;
        /* 24px - 40px */
        padding: 0 clamp(1.5rem, 5vw, 2.5rem) 0;
        width: 100%;
        /* 70px - 90px */
        height: clamp(4.375rem, 7vw, 5.625rem);
        background-color: #f1f1f4;
        /* prevents border and padding from affecting height and width */
        box-sizing: border-box;
        border: 3px solid transparent;
        display: block;
        position: relative;
        transition: border-color 0.3s;
    }
    #cs-contact-549 .cs-input:hover,
    #cs-contact-549 .cs-textarea:hover,
    #cs-contact-549 select:hover,
    #cs-contact-549 .cs-select:hover,
    #cs-contact-549 .cs-input:focus,
    #cs-contact-549 .cs-textarea:focus,
    #cs-contact-549 select:focus,
    #cs-contact-549 .cs-select:focus {
        /* focus has a black outline, we override it here */
        outline: none;
        border-color: var(--primaryLight);
    }
    #cs-contact-549 .cs-textarea {
        width: 100%;
        margin: 0;
        padding-top: 1rem;
        /* changes at tablet */
        min-height: 12.5rem;
    }
    #cs-contact-549 .cs-icon {
        width: 1.875rem;
        height: auto;
        position: absolute;
        /* 24px - 40px, matches the padding left and right of input */
        right: clamp(1.5rem, 5vw, 2.5rem);
        /* these two center the icon inside the label */
        bottom: 50%;
        transform: translateY(115%);
    }
    #cs-contact-549 .cs-submit {
        /* 20px - 25px */
        font-size: clamp(1.25rem, 2vw, 1.5625rem);
        /* 56px - 84px */
        line-height: clamp(3.5rem, 6.5vw, 5.25rem);
        text-decoration: none;
        font-weight: 700;
        text-align: center;
        /* 28px - 44px, minus the gap value. Should be 48px - 64px, but with a 20px gap on the flexbox, we account for that space when adding our margin top value so its 48px - 64px */
        margin: clamp(1.75rem, 6vw, 2.75rem) auto 0;
        color: #1a1a1a;
        border: none;
        /* 150px - 234px */
        min-width: clamp(9.374rem, 18vw, 14.625rem);
        padding: 0 1.5rem;
        background-color: var(--primaryLight);
        border-radius: 0.25rem;
        display: inline-block;
        position: relative;
        z-index: 1;
        /* prevents padding from adding to the width */
        box-sizing: border-box;
        transition: color 0.3s;
    }
    #cs-contact-549 .cs-submit:before {
        content: "";
        position: absolute;
        height: 100%;
        width: 0%;
        background: #000;
        opacity: 1;
        top: 0;
        left: 0;
        z-index: -1;
        border-radius: 0.25rem;
        transition: width 0.3s;
    }
    #cs-contact-549 .cs-submit:hover {
        color: #fff;
        cursor: pointer;
    }
    #cs-contact-549 .cs-submit:hover:before {
        width: 100%;
    }
}
/* Tablet - 768px */
@media only screen and (min-width: 48rem) {
    #cs-contact-549 .cs-background {
        /* 310px - 568px */
        height: clamp(19.375rem, 43vw, 35.5rem);
    }
    #cs-contact-549 .cs-form {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    #cs-contact-549 .cs-label {
        width: 48%;
    }
    #cs-contact-549 .cs-textarea-label {
        width: 100%;
    }
    #cs-contact-549 .cs-textarea {
        /* 280px - 358px */
        min-height: clamp(17.5rem, 28vw, 22.375rem);
    }
}

                                

                                

                                

                                

                                