/* Global */
body {
    font-family: myriad-pro, sans-serif;
}
:root {
    --light-gray: #FAFAFA;
    --med-gray: #808080;
    --primary-orange: #F37343;
    --primary-orange-hover: #ff5500;
    --dark-purple: #57417C;
    --pale-purple: #EBE9F3;
    --primary-purple: #71579D;
    --primary-purple-hover: #8c69c7;
    --primary-red: #DA132D;
    --primary-red-hover: #f20021;
    --med-yellow: #FFE5A5;
    --pale-yellow: #FCF6E7;
}
a {
    color: var(--primary-purple);
    transition: all .3s;
}
a:hover {
    color: var(--primary-purple-hover);
}
.bg-gray {
    background-color: var(--light-gray);
}
.bg-purple {
    background-color: var(--pale-purple);
}
.bg-white {
    background-color: #fff;
}
.bg-yellow {
    background-color: var(--pale-yellow);
}
.block-padding {
    padding-bottom: 2rem;
    padding-top: 2rem;
}
.block-padding.extra-padding-top {
    padding-top: 4rem;
}
.block-padding-bottom {
    padding-bottom: 2rem;
}
.border-purple {
    border: 2px solid var(--dark-purple);
}
.border-bottom-purple {
    border-bottom: 2px solid var(--dark-purple);
}
.border-top-purple {
    border-top: 2px solid var(--dark-purple);
}
.btn {
    background-color: var(--primary-purple);
    border: none;
    border-radius: 0;
    color: #fff;
    font-weight: 700;
    padding: .5rem 1.25rem;
    transition: all .3s;
}
.btn-highlight {
    font-size: 1.1rem;
    padding: .7rem 1.6rem;
}
.btn.btn-orange {
    background-color: var(--primary-orange);
}
.btn.btn-orange:hover {
    background-color: var(--primary-orange-hover);
}
.btn:hover {
    background-color: var(--primary-purple-hover);
    border: none;
    color: #fff;
}
.card {
    border-radius: 0;;
}
.d-purple {
    color: var(--dark-purple);
}
h1, h2, h3, h4  {
    font-family: merriweather, serif;
    font-weight: 700;
}
h5, h6 {
    font-weight: 700;
}
.h-children-purple h1,
.h-children-purple h2,
.h-children-purple h3,
.h-children-purple h4,
.h-children-purple h5,
.h-children-purple h6 {
    color: var(--primary-purple);
}
.light-italic {
    font-weight: 400;
    font-style: italic;
}
.p-orange {
    color: var(--primary-purple);
}
.p-purple {
    color: var(--primary-purple);
}
table td,
table th {
    border: 1px solid #000;
    padding: .25rem;
}
.text-children-center * {
    text-align: center;
}
.text-children-highlight p,
.text-children-highlight ul,
.text-children-highlight ol {
    font-size: 1.1rem;
}
@media only screen and (min-width: 576px) {
    .block-padding {
        padding-bottom: 2.5rem;
        padding-top: 2.5rem;
    }
    .block-padding-bottom {
        padding-bottom: 2.5rem;
    }
}
@media only screen and (min-width: 768px) {
    .block-padding {
        padding-bottom: 3rem;
        padding-top: 3rem;
    }
    .block-padding-bottom {
        padding-bottom: 3rem;
    }
    .border-bottom-md-none {
        border-bottom: none;
    }
    .border-left-md-purple {
        border-left: 2px solid var(--dark-purple);
    }
    .border-right-md-purple {
        border-right: 2px solid var(--dark-purple);
    }
}
@media only screen and (min-width: 992px) {
    .block-padding {
        padding-bottom: 4rem;
        padding-top: 4rem;
    }
    .block-padding-bottom {
        padding-bottom: 4rem;
    }
}
@media only screen and (min-width: 1200px) {
    .block-padding {
        padding-bottom: 5rem;
        padding-top: 5rem;
    }
    .block-padding-bottom {
        padding-bottom: 5rem;
    }
}
@media only screen and (min-width: 1400px) and (max-width: 1599px) {
    .xxl-pad {
        padding: 0 3rem;
    }
}
/* /Global */

/* Did You Know Quote Boxes */
.dq-box {
    padding: .75rem 1.25rem 1.25rem .75rem;
    position: relative;
}
.dq-box:after {
    content: '';
    background-color: var(--pale-yellow);
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -100;
}
.dq-box:before {
    border: 3px solid var(--dark-purple);
    content: '';
    height: 100%;
    left: -.5rem;
    position: absolute;
    top: -.5rem;
    width: 100%;
    z-index: -50;
}
.dq-box .dq-heading h5 {
    margin: 0;
}
.dq-box .dq-icon {
    width: 40px;
}
.dq-box .quote-box-attr {
    color: var(--primary-purple);
    font-weight: 700;
}
.related-content-inner {
    padding-left: 56px;
}
.related-content-inner a {
    color: var(--primary-purple);
}
.related-content-inner a:hover {
    color: var(--primary-purple-hover);
}
@media only screen and (max-width: 991px) {
    .dq-box {
        font-size: .9rem;
    }
}
@media only screen and (min-width: 992px) {
    .dq-box {
        padding: 1rem 2rem 2rem 1rem;
    }
    .dq-box .dq-heading h5 {
        font-size: 1.5rem;
    }
    .dq-box .dq-icon {
        width: 55px;
    }
    .related-content-inner {
        padding-left: 71px;
    }
}
/* /Did You Know Boxes */

/* FAQs */
.faq-accordion .accordion-body {
    padding: 1rem 1rem 0 1rem;
}
.faq-accordion .accordion-button {
    background-color: var(--primary-purple);
    border-radius: 0;
    border-bottom-left-radius: 0!important;
    border-bottom-right-radius: 0!important;
    color: #fff;
}
.faq-accordion .accordion-button::after {
    background-image: none;
    display: inline-block;
    font: var(--fa-font-solid);
    font-size: 1.5rem;
    text-rendering: auto;
    margin-left: 1rem;
    -webkit-font-smoothing: antialiased;
}
.faq-accordion .accordion-button.collapsed::after {
    content: "\2b";
}
.faq-accordion .accordion-button:not(.collapsed)::after {
    content: "\f068";
}
.faq-accordion .accordion-button:hover {
    background-color: var(--primary-purple-hover);
    color: #fff;
}
@media only screen and (min-width: 992px) {
    .faq-accordion .accordion-body {
        padding: 1.5rem 1.5rem .5rem 1.5rem;
    }
    .faq-accordion .accordion-button {
        padding: 1.5rem;
    }
}
@media only screen and (min-width: 1200px) {
    .faq-accordion .accordion-body {
        padding: 2rem 2rem 1rem 2rem;
    }
    .faq-accordion .accordion-button {
        padding: 2rem;
    }
}
/* /FAQs */

/* Filter Menus */
.filter-card {
    min-width: 200px;
    width: fit-content;
}
.filter-card a {
    font-size: 1.1rem;
}
.filter-card a:hover {
    color: var(--primary-purple-hover);
}
.filter-menu.dropdown {
    width: fit-content;
}
.filter-menu.dropdown .dropdown-toggle.show, {
    background-color: var(--primary-purple);
}
.filter-menu.dropdown .dropdown-menu.show {
    border: 2px solid var(--primary-purple);
    border-radius: 0;
    margin-top: -2px!important;
    width: 100%
}
.filter-menu.dropdown .dropdown-menu.show .dropdown-item {
    white-space: normal;
}
.filter-menu.fixed {
    position: absolute;
    top: -2px;
    left: .5rem;
    width: 60%;
}
.filter-menu.fixed .btn {
    background-color: var(--med-yellow);
    border: 2px solid var(--dark-purple);
    color: var(--dark-purple);
    text-align: left;
    text-transform: uppercase;
    width: 100%;
}
.filter-menu.fixed .btn:hover {
    filter: brightness(0.9) saturate(2);
}
.filter-menu.fixed .btn.show {
    background-color: var(--med-yellow);
    color: var(--dark-purple);
}
.filter-menu.fixed.dropdown .dropdown-menu.show {
    margin-top: -4px!important;
}
.job-submit-wrapper {
    font-weight: 700;
    padding: 1rem;
    position: absolute;
    right: 0;
    top: 0;
    width: 40%;
}
.job-submit-wrapper a {
    color: var(--primary-purple);
}
.job-submit-wrapper a:hover {
    color: var(--primary-purple-hover);
}
@media only screen and (min-width: 576px) {
    .filter-menu.fixed {
        width: 250px;
    }
    .job-submit-wrapper {
        width: fit-content;
    }
}
@media only screen and (min-width: 992px) {
    .job-submit-wrapper {
        font-size: 1.1rem;
    }
}
@media only screen and (min-width: 1400px) and (max-width: 1599px) {
    .filter-menu.fixed {
        left: 3.5rem;
    }
}
/* /Filter Menus */

/* Flow Charts */
.before-block-line {
    height: 30px;
    position: relative;
}
.chart-h-line {
    background-color: var(--med-gray);
    height: 2px;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
.chart-v-arrow {
    border-bottom: 2px solid var(--med-gray);
    border-right: 2px solid var(--med-gray);
    bottom: 6px;
    height: 10px;
    left : 50%;
    position: absolute;
    transform: translateX(-50%) rotate(45deg);
    width: 10px;
}
.chart-v-line {
    background-color: var(--med-gray);
    height: calc(100% - 8px );
    position: absolute;
    top: 4px;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
}
.chart-v-line.end {
    height: calc(100% - 4px);
}
.chart-v-line-end-wrapper {
    position: relative;
    min-height: 30px;
}
.chart-v-line.top-right {
    height: calc(50% + 4px);
    top: 50%;
}
.chart-h-line.bottom-right {
    left: 0;
    width: calc(50% + 1px);
}
.chart-h-line.bottom-left {
    left: unset;
    right: 0;
    width: calc(50% + 1px);
}
.chart-h-line.top-center {
    width: 100%;
}
.chart-h-line.top-right {
    width: calc(50% + 1px);
}
.flow-card {
    border: 2px solid var(--dark-purple);
    border-radius: 0;
    padding: 1rem 1rem 0 1rem;
    overflow-wrap: anywhere;
}
.flow-card h1,
.flow-card h2,
.flow-card h3,
.flow-card h4,
.flow-card h5,
.flow-card h6 {
    color: var(--primary-purple);
}
.flow-card.bg-gray {
    background-color: var(--light-gray);
    border-color: #717171;
}
.flow-card.bg-gray.big-nums ol li:before {
    background-color: #ddd;
    color: #717171;
}
.flow-card.bg-gray h1,
.flow-card.bg-gray h2,
.flow-card.bg-gray h3,
.flow-card.bg-gray h4,
.flow-card.bg-gray h5,
.flow-card.bg-gray h6 {
    color: #717171!important;
}
.flow-label h3 {
    color: var(--primary-purple);
    text-align: center;
    margin: 0;
}
@media only screen and (max-width: 575px) {
    .flow-card {
        font-size: .9rem;
    }
    .flow-card.big-nums ol {
        padding-left: 0;
    }
    .flow-card.big-nums ol li {
        margin: 1rem 0 0 2rem;
    }
    .flow-card.big-nums ol li:before {
        font-size: 1.3rem;
        height: 2rem;
        margin-left: -2.5rem;
        padding: 0;
        width: 1.6em;
    }
}
@media only screen and (min-width: 576px) {
    .before-block-line {
        height: 50px;
    }
    .chart-v-arrow {
        bottom: 8px;
        height: 20px;
        width: 20px;
    }
    .chart-v-line-end-wrapper {
        min-height: 50px;
    }
}
@media only screen and (max-width: 767px) {
    .chart-h-line.bottom-left {
        left: calc(50% - 1px);
        right: unset;
        width: calc(45% + 1px);
    }
    .chart-h-line.bottom-right {
        right: calc(50% - 1px);
        left: unset;
        width: calc(45% + 1px);
    }
    .chart-end-angle-left-small-wrapper {
        height: 30px;
        position: relative;
    }
    .chart-end-angle-right-small-wrapper {
        height: 30px;
        position: relative;
    }
    .chart-end-angle-left {
        background-color: var(--med-gray);
        height: calc(100% + 1px);
        position: absolute;
        right: 0;
        top: -1px;
        width: 2px;
    }
    .chart-end-angle-right {
        background-color: var(--med-gray);
        height: calc(100% + 1px);
        position: absolute;
        left: 0;
        top: -1px;
        width: 2px;
    }
    .chart-end-arrow-left {
        border-bottom: 2px solid var(--med-gray);
        border-right: 2px solid var(--med-gray);
        bottom: 2px;
        height: 10px;
        right: -9px;
        position: absolute;
        transform: translateX(-50%) rotate(45deg);
        width: 10px;
    }
    .chart-end-arrow-right {
        border-bottom: 2px solid var(--med-gray);
        border-left: 2px solid var(--med-gray);
        bottom: 2px;
        height: 10px;
        left: 1px;
        position: absolute;
        transform: translateX(-50%) rotate(-45deg);
        width: 10px;
    }
}
@media only screen and (max-width: 469px) {
    .chart-end-angle-left {
        right: -1px;
    }
    .chart-end-angle-right {
        left: -1px;
    }
    .chart-end-arrow-left {
        right: -10px;
    }
    .chart-end-arrow-right {
        left: 0;
    }
}
@media only screen and (max-width: 429px) {
    .chart-end-angle-left {
        right: -2px;
    }
    .chart-end-angle-right {
        left: -2px;
    }
    .chart-end-arrow-left {
        right: -11px;
    }
    .chart-end-arrow-right {
        left: -1px;
    }
}
@media only screen and (max-width: 389px) {
    .chart-end-angle-left {
        right: -3px;
    }
    .chart-end-angle-right {
        left: -3px;
    }
    .chart-end-arrow-left {
        right: -12px;
    }
    .chart-end-arrow-right {
        left: -2px;
    }
}
@media only screen and (max-width: 349px) {
    .chart-end-angle-left {
        right: -4px;
    }
    .chart-end-angle-right {
        left: -4px;
    }
    .chart-end-arrow-left {
        right: -13px;
    }
    .chart-end-arrow-right {
        left: -3px;
    }
}
@media only screen and (min-width: 768px) {
    .chart-end-angle-left {
        border-right: 2px solid var(--med-gray);
        border-top: 2px solid var(--med-gray);
        height: 100%;
        left: 0;
        position: absolute;
        top: -1px;
        width: 35%;
    }
    .chart-end-angle-right {
        border-left: 2px solid var(--med-gray);
        border-top: 2px solid var(--med-gray);
        height: 100%;
        right: 0;
        position: absolute;
        top: -1px;
        width: 35%;
    }
    .chart-end-angle-wrapper {
        height: 50px;
    }
    .chart-end-arrow-left {
        border-bottom: 2px solid var(--med-gray);
        border-right: 2px solid var(--med-gray);
        bottom: 2px;
        height: 20px;
        left : calc(35% - 1px);
        position: absolute;
        transform: translateX(-50%) rotate(45deg);
        width: 20px;
    }
    .chart-end-arrow-right {
        border-bottom: 2px solid var(--med-gray);
        border-right: 2px solid var(--med-gray);
        bottom: 2px;
        height: 20px;
        right: calc(25% - 9.5px);
        position: absolute;
        transform: translateX(-50%) rotate(45deg);
        width: 20px;
    }
}
@media only screen and (min-width: 992px) {
    .chart-end-angle-left {
        width: 40%;
    }
    .chart-end-angle-right {
        width: 40%;
    }
    .chart-end-arrow-left {
        left : calc(40% - 1px);
    }
    .chart-end-arrow-right {
        right: calc(30% - 5.5px);
    }
    .flow-card {
        padding: 1.5rem 1.5rem .5rem 1.5rem;
    }
}
@media only screen and (min-width: 1200px) {
    .chart-end-arrow-right {
        right: calc(30% - 2.5px);
    }
    .flow-card {
        padding: 2rem 2rem 1rem 2rem;
    }
}
@media only screen and (min-width: 1400px) {
    .chart-end-arrow-right {
        right: calc(30% - 1px);
    }
}
/* /Flow Charts */

/* Footer */
.footer {
    background-color: var(--primary-purple);
    border-top: 2px solid #000;
}
.footer a {
    color: #fff;
    text-decoration: none;
}
.footer .btn-col {
    width:fit-content;
}
.footer .footer-btn {
    background-color: var(--pale-yellow);
    color: var(--dark-purple);
    display: block;
    font-weight: 700;
    max-width: 300px;
    width: 100%;
}
.footer .footer-btn:hover {
    background-color: var(--med-yellow);
}
.footer-copyright {
    color: #fff;
}
.footer-email {
    display: block;
    font-size: .9rem;
    margin-bottom: -.25rem;
}
.footer-phone {
    display: block;
    font-size: 1.325rem;
    font-weight: 700;
    white-space: nowrap;
}
.footer-email:hover,
.footer-phone:hover {
    color: var(--med-yellow);
}
.footer-link {
    display: block;
    font-weight: 700;
}
.footer-link:hover {
    color: var(--med-yellow);
}
.footer-logo img {
    height: 60px;
}
@media only screen and (min-width: 992px) {
    .footer-btn {
        font-size: 1.1rem;
        padding: .625rem 1rem;
    }
    .footer-logo img {
        height: 70px;
    }
}
@media only screen and (min-width: 1200px) {
    .footer-btn {
        font-size: 1.2rem;
        padding: .75rem 1rem;
    }
    .footer-email {
        font-size: .95rem;
    }
    .footer-phone {
        font-size: 1.4rem;
    }
    .footer-logo img {
        height: 80px;
    }
    .footer-link {
        font-size: 1.1rem;
    }
}
/* /Footer */

/* Forms */
.fui-alert-error {
    border: 2px solid var(--fui-alert-error-color)!important;
    border-radius: 0!important;
}
.fui-alert-success {
    border: 2px solid var(--fui-alert-success-color)!important;
    border-radius: 0!important;
}
.fui-error-message {
    color: rgb(192, 7, 7)!important;
}
.fui-input.fui-error, .fui-select.fui-error {
    border-color: rgb(192, 7, 7)!important;
}
.basic-form .fui-btn {
    background-color: var(--primary-purple);
    border: none;
    border-radius: 0;
    color: #fff;
    font-weight: 700;
    padding: .5rem 1.25rem;
    transition: all .3s;
}
.basic-form .fui-btn:hover {
    background-color: var(--primary-purple-hover);
    border: none;
    color: #fff;
}
.basic-form input,
.basic-form textarea {
    border: 2px solid var(--med-gray);
    border-radius: 0;
}
.contact-form textarea {
    height: 200px;
}
.page-form-pdf-btn {
    background-color: var(--primary-purple);
    border: 1px solid var(--dark-purple);
    color: #fff;
    font-weight: 700;
    margin-bottom: -1px;
    padding: .2rem .4rem;
    text-decoration: none;
}
.page-form-pdf-btn:hover {
    background-color: var(--primary-purple-hover);
    color: #fff;
}
@media only screen and (min-width: 992px) {
    .page-form-pdf-btn {
        padding: .4rem .8rem;
    }
}
/* /Forms */

/* Icon Link Group */
.icon-link-group {
    text-decoration: none;
}
.icon-link-group:hover img {
    filter: brightness(1.05);
}
.icon-link-group:hover h5 {
    color: var(--primary-purple-hover);
}
.icon-link-group h5 {
    color: var(--primary-purple);
    text-decoration: none;
    transition: all .3s;
}
.icon-link-group img {
    transition: all .3s;
}
.icon-link-group p {
    color: #000;
    font-size: .9rem;
    text-decoration: none;
}
/* /Icon Link Group */

/* Intro Illustrations */
@media only screen and (max-width: 767px) {
    .intro-illustration {
        width: 30%;
    }
}
/* /Intro Illustrations */

/* Homepage Hero */
.homepage-carousel-slide .copy-area {
    background-color: var(--pale-purple);
    padding: 1.5rem;
    width: 100%;
}
.homepage-carousel-slide .copy-area a {
    display: block;
    width: fit-content;
}
.homepage-carousel-slide .copy-area a:not(.btn) {
    color: var(--dark-purple);
    font-weight: 700;
    text-decoration: none;
    transition: all .3s;
}
.homepage-carousel-slide .copy-area a:not(.btn):hover {
    color: var(--primary-purple);
    text-decoration: none;
}
.homepage-carousel-slide .image-area {
    background-size: cover;
    height: 350px;
    width: 100%;
}
.homepage-hero-bottom-bar {
    background-color: var(--pale-yellow);
    border-bottom: 2px solid var(--dark-purple);
    border-top: 2px solid var(--dark-purple);
    padding: 2rem 0;
}
.homepage-hero-bottom-bar-copy {
    font-style: italic;
    margin-bottom: .5rem;
}
.homepage-hero-bottom-bar .logo {
    height: 30px;
}
.homepage-hero .carousel-indicators button {
    border-radius: 100%;
    height: 30px;
    width: 30px;
}
@media only screen and (min-width: 576px) {
    .homepage-carousel-slide .copy-area {
        padding: 2rem;
        width: 50%;
    }
    .homepage-carousel-slide .image-area {
        height: unset;
        width: 50%;
    }
    .homepage-hero-bottom-bar .logo {
        height: 40px;
    }
}
@media only screen and (min-width: 768px) {
    .homepage-carousel-slide .copy-area {
        padding: 3rem; 
    }
}
@media only screen and (min-width: 992px) {
    .homepage-carousel-slide .copy-area {
        padding: 4rem; 
    }
    .homepage-carousel-slide .copy-area p {
        font-size: 1.1rem;
    }
    .homepage-hero-bottom-bar-copy {
        align-self: center;
        font-size: 1.1rem;
        margin: 0;
    }
    .homepage-hero-bottom-bar .logo {
        height: 50px;
    }
}
@media only screen and (min-width: 1200px) {
    .homepage-carousel-slide .copy-area {
        padding: 5rem; 
    }
    .homepage-carousel-slide .copy-area p {
        font-size: 1.2rem;
    }
    .homepage-hero-bottom-bar-copy {
        font-size: 1.2rem;
    }
}
@media only screen and (min-width: 1300px) {
    .homepage-carousel-slide .copy-area {
        padding: 6rem; 
    }
}
@media only screen and (min-width: 1400px) {
    .homepage-carousel-slide .copy-area {
        padding: 7rem; 
    }
}
@media only screen and (min-width: 1500px) {
    .homepage-carousel-slide .copy-area {
        padding: 7.5rem 7.5rem 7.5rem 8rem; 
    }
}
@media only screen and (min-width: 1600px) {
    .homepage-carousel-slide .copy-area {
        padding: 8rem 8rem 8rem 9rem; 
    }
}
@media only screen and (min-width: 1700px) {
    .homepage-carousel-slide .copy-area {
        padding: 8.5rem 8.5rem 8.5rem 10rem; 
    }
}
@media only screen and (min-width: 1800px) {
    .homepage-carousel-slide .copy-area {
        padding: 9rem 9em 9rem 11rem; 
    }
}
@media only screen and (min-width: 1900px) {
    .homepage-carousel-slide .copy-area {
        padding: 9.5rem 9.5rem 9.5rem 12rem; 
    }
}
@media only screen and (min-width: 2000px) {
    .homepage-carousel-slide .copy-area {
        padding: 10rem 10rem 10rem 13rem; 
    }
}
/* Homepage Hero */

/* Link Cards */
.link-card {
    border: 2px solid var(--primary-purple);
    border-radius: 0;
    padding: 1rem 1rem 0rem 1rem;
}
.link-card .btn {
    width: fit-content;
}
@media only screen and (max-width: 992px) {
    .link-card {
        font-size: .9rem;
    }
}
@media only screen and (min-width: 992px) {
    .link-card {
        padding: 1.5rem 1.5rem .5rem 1.5rem;
    }
}
@media only screen and (min-width: 1200px) {
    .link-card {
        padding: 2rem 2rem 1rem 2rem;
    }
}
/* /Link Cards */

/* Main Nav */
.main-nav {
    background-color: var(--pale-yellow);
    border-bottom: 2px solid var(--dark-purple);
    padding: 0;
}
.main-nav .main-nav-contact a {
    color: var(--primary-purple);
    text-decoration: none;
}
.main-nav .main-nav-contact a:hover {
    color: var(--primary-purple-hover);
    text-decoration: none;
}
.main-nav .main-nav-btns .btn {
    font-size: .85rem;
    font-weight: 400;
    padding: .25rem .5rem;
    text-transform: uppercase;
}
.main-nav .main-nav-email {
    font-size: .9rem;
    margin-bottom: -.25rem;
}
.main-nav .main-nav-phone {
    font-size: 1.325rem;
    font-weight: 700;
    white-space: nowrap;
}
.main-nav .navbar-brand {
    padding: 1rem 0;
}
.main-nav .navbar-brand img {
    height: 60px;
}
.main-nav .nav-item .dropdown-menu {
    background-color: var(--pale-yellow);
    border: 2px solid var(--primary-purple);
    border-radius: 0;
    margin-top: 0;
}
.main-nav .nav-item .dropdown-menu.icons .dropdown-icon {
    height: 80px;
}
.main-nav .nav-item .dropdown-menu.icons .dropdown-item:hover {
    background: none;
}
.main-nav .nav-item .dropdown-menu.icons .dropdown-item p {
    white-space: normal;
}
.main-nav .nav-item .dropdown-menu.icons .dropdown-menu-heading {
    color: var(--primary-purple);
    font-family: myriad-pro, sans-serif;
    font-weight: 700;;
    text-align: center;
}
.main-nav .nav-item .nav-link {
    color: #000;
}
.main-nav .nav-item .nav-link:hover {
    color: var(--primary-red);
}
.main-nav .nav-item .nav-link.dropdown-toggle:after {
    border: none;
    content: url('/assets/core/down-red.svg');
    margin: 0 0 0 4px;
    transition: all .3s;
    vertical-align: .125em;
    width: .75rem;
}
.main-nav .nav-item .nav-link.dropdown-toggle.flipped,
.main-nav .nav-item .nav-link.dropdown-toggle.selected {
    color: var(--primary-red);
}
.main-nav .nav-item .nav-link.dropdown-toggle.flipped:after {
    content: url('/assets/core/down-red.svg');
    transform: rotate(180deg);
}
.main-nav .red-icon {
    color: var(--primary-red);
}
@media only screen and (min-width: 576px) {
    .main-nav .navbar-collapse.show {
        display: flex;
    }
}
@media only screen and (max-width: 991px) {
    .main-nav .nav-item .dropdown-menu {
        background-color: #fff;
    }
    .main-nav .nav-item .dropdown-menu.icons {
        width: 100%;
    }
}
@media only screen and (min-width: 992px) {
    .main-nav .navbar-brand img {
        height: 70px;
    }
    .main-nav .nav-item .nav-link {
        padding-bottom: .25rem;
    }
    .main-nav .nav-item .dropdown-menu {
        margin-top: .5rem;
    }
    .main-nav .nav-item .dropdown-menu.icons {
        left: 50%;
        position: fixed;
        margin-top: 0;
        transform: translateX(-50%);
        top: 102px;
        width: 900px;
    }
    .main-nav .nav-item .dropdown-menu.icons .dropdown-icon {
        height: 100px;
    }
}
@media only screen and (min-width: 1200px) {
    .main-nav .main-nav-btns .btn {
        font-size: .9rem;
    }
    .main-nav .main-nav-email {
        font-size: .95rem;
    }
    .main-nav .main-nav-phone {
        font-size: 1.4rem;
    }
    .main-nav .navbar-brand img {
        height: 80px;
    }
    .main-nav .nav-item {
        margin-left: 1rem;
    }
    .main-nav .nav-item .dropdown-menu.icons {
        top: 112px;
        width: 1000px;
    }
    .main-nav .nav-item .dropdown-menu.icons .dropdown-icon {
        height: 120px;
    }
    .main-nav .nav-item .nav-link.dropdown-toggle {
        font-size: 1.1rem;
    }
}
/* /Main Nav */

/* Modals */
.modal-body {
    position: relative;
}
.modal-body .btn-close {
    position: absolute;
    top: .5rem;
    right: .5rem;
}
.modal-content {
    background-color: var(--pale-yellow);
    border: 2px solid var(--dark-purple);
    border-radius: 0;
}
.modal-title {
    color: var(--primary-purple);
}
@media only screen and (min-width: 576px) {
    .modal-body {
        padding: 1.25rem;
    }
}
@media only screen and (min-width: 768px) {
    .modal-body {
        padding: 1.5rem;
    }
}
@media only screen and (min-width: 992px) {
    .modal-body {
        padding: 2rem;
    }
    .modal-body .btn-close {
        top: 1rem;
        right: 1rem;
    }
}
/* /Modals */

/* Page Hero */
.page-hero {
    background-size: cover;
    border-bottom: 2px solid var(--dark-purple);
    height: 150px;
    width: 100%;
}
@media only screen and (min-width: 992px) {
    .page-hero {
        height: 220px;
    }
}
@media only screen and (min-width: 1200px) {
    .page-hero {
        height: 280px;
    }
}
/* /Page Hero */

/* Page Form */
.page-form {
    background-color: var(--pale-yellow);
    border: 2px solid var(--dark-purple);
    padding: 1rem;
}
.page-form input,
.page-form textarea,
.page-form select  {
    border: 2px solid var(--med-gray);
    border-radius: 0;
}
.page-form input::placeholder,
.page-form textarea::placeholder,
.page-form select::placeholder  {
    color: #000;
}
.page-form .fui-btn {
    background-color: var(--primary-purple);
    border: none;
    border-radius: 0;
    font-size: 1rem;
    font-weight: 700;
    padding: 0.5rem 1.25rem;
    transition: all .3s;
}
.page-form .fui-btn:hover {
    background-color: var(--primary-purple-hover);
}
.page-form .fui-checkbox label::before {
    border: 2px solid var(--med-gray);
    border-radius: 0;
}
.page-form .fui-checkbox input:checked + label::before {
    background-color: var(--primary-purple);
}
.page-form .fui-radio-label:before {
    border: 2px solid var(--med-gray);
}
.page-form .fui-radio input:checked + label::before {
    border: 2px solid var(--primary-purple);
    background-color: var(--primary-purple);
}
.page-form .fui-instructions,
.page-form .fui-limit-text {
    color: var(--med-gray);
}
.page-form-heading {
    background-color: var(--med-yellow);
    border: 2px solid var(--dark-purple);
    color: var(--dark-purple);
    margin-bottom: -2px;
    padding: 1rem;
    width: fit-content;
}
.page-form-heading h1 {
    font-family: myriad-pro, sans-serif;
    font-size: 1.75rem;
    margin: 0;
}
.page-form h2,
.page-form h3,
.page-form h4 {
    color: var(--primary-purple);
    margin: 1rem 0 -1rem 0;
}
.page-form.contract-form h2,
.page-form.contract-form h3,
.page-form.contract-form h4,
.page-form.contract-form h5  {
    color: var(--primary-purple);
    margin: 1rem 0 0 0;
}
@media only screen and (min-width: 992px) {
    .page-form {
        padding: 1.5rem;
    }
    .page-form-heading {
        font-size: 2rem;
        padding: 1rem 1.5rem;
    }
}
/* /Page Form */

/* Post Cards */
.bg-purple a.post-card:hover {
    background: var(--pale-yellow);
}
.bg-yellow a.post-card:hover {
    background: var(--pale-purple);
}
.post-card {
    background-color: #fff;
    border: 2px solid var(--dark-purple);
    display: block;
    text-decoration: none;
}
.post-card * {
    text-decoration: none;
}
.post-card:hover h4 {
    color: var(--primary-purple-hover)
}
.post-card:hover .post-card-image {
    filter: brightness(1.1);
}
.post-card .post-card-copy {
    padding: 1rem;
}
.post-card .post-card-copy h4 {
    color: var(--primary-purple);
    font-size: 1.4rem;
    text-decoration: none;
}
.post-card .post-card-copy p {
    color: #000;
    font-size: .9rem;
    margin: 0;
    text-decoration: none;
}
.post-card .post-card-image {
    border-bottom: 2px solid var(--dark-purple);
    transition: all .3s;
    width: 100%;
}
.post-card.small .image {
    background-size: cover;
    border-right: 2px solid var(--dark-purple);
    flex: 0 0 140px;
}
@media only screen and (min-width: 576px) {
    .post-card.small .image {
        flex: 0 0 160px;
    }
}
@media only screen and (min-width: 768px) {
    .post-card.small .image {
        flex: 0 0 180px;
    }
}
@media only screen and (min-width: 992px) {
    .post-card .post-card-copy {
        padding: 2rem;
    }
    .post-card.small .image {
        flex: 0 0 160px;
    }
}
@media only screen and (min-width: 1400px) {
    .post-card.small .image {
        flex: 0 0 200px;
    }
}
/* /Post Cards */

/* Post Pages */
.inline-image {
    border: 2px solid var(--dark-purple);
}
.inline-image.full {
    margin: 0 0 1rem 0;
    width: 100%;
}
.inline-image.half {
    width: 45%;
}
.inline-image.left {
    float: left;
    margin: 0 1rem 1rem 0;
}
.inline-image.right {
    float: right;
    margin: 0 0 1rem 1rem;
}
.post-hero-image {
    border: 2px solid var(--dark-purple);
    width: 100%;
}
.post-subhead {
    text-transform: uppercase;
}
@media only screen and (min-width: 992px) {
    .inline-image.left {
        margin: 0 1.5rem 1.5rem 0;
    }
    .inline-image.right {
        margin: 0 0 1.5rem 1.5rem;
    }
    .post-subhead {
        font-size: 1.1rem;
    }
}
/* /Post Pages */

/* Search Form */
.search-form input {
    border-bottom: 2px solid var(--primary-purple);
    border-left: 2px solid var(--primary-purple);
    border-top: 2px solid var(--primary-purple);
}
.search-form input::placeholder {
    color: #000;
}
.search-form .btn {
    padding: 0.125rem 0.5rem;
    font-size: 1.3rem;
}
/* /Search Form */

/* Text Embed Blocks */
.text-embed .embed-wrapper {
    border: 2px solid var(--dark-purple);
}
/* /Text Embed Blocks */

/* Text Image Blocks */
.copy-wrapper {
    padding: 0 1rem;
}
.text-image-block {
    margin-bottom: 3rem;
    margin-top: 3rem;
}
.text-image-block .image-wrapper {
    position: relative;
}
.text-image-block .image-wrapper:after {
    content: '';
    background-color: var(--pale-yellow);
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -100;
}
.text-image-block .image-wrapper:before {
    border: 3px solid var(--dark-purple);
    content: '';
    height: 100%;
    left: -.5rem;
    position: absolute;
    top: -.5rem;
    width: 100%;
    z-index: 100;
}
.text-image-block .image-wrapper img {
    height: 100%;
    left: .5rem;
    top: .5rem;
    width: 100%;
    z-index: -100;
}
@media only screen and (min-width: 576px) {
    .copy-wrapper {
        padding: 0 1.5rem;
    }
    .text-image-block {
        margin-bottom: 4.25rem;
        margin-top: 4.25rem;
    }
}
@media only screen and (max-width: 767px) {
    .text-image-block .image-wrapper {
        margin: 0 2rem;
        width: calc(100% - 4rem);
    }
}
@media only screen and (min-width: 768px) {
    .copy-wrapper {
        padding: 0 2rem;
    }
    .text-image-block {
        margin-bottom: 5.5rem;
        margin-top: 5.5rem;
    }

}
@media only screen and (min-width: 992px) {
    .copy-wrapper {
        padding: 0 2.5rem;
    }
    .text-image-block {
        margin-bottom: 6.75rem;
        margin-top: 6.75rem;
    }
}
@media only screen and (min-width: 1200px) {
    .copy-wrapper {
        padding: 0 3rem;
    }
    .text-image-block {
        margin-bottom: 8rem;
        margin-top: 8rem;
    }
}
/* /Text Image Blocks */

/* Text Image Blocked Blocks */
.big-nums ol {
    list-style: none;
    counter-reset: item;
    padding-left: 1rem;
}
.big-nums ol li {
    align-items: center;
    counter-increment: item;
    display: flex;
    margin: 1rem 0 0 3rem;
    min-height: 42px;
}
.big-nums ol li p {
    margin: 0;
}
.big-nums ol li:before {
    align-self: self-start;
    background: var(--med-yellow);
    border-radius: 100%;
    color: var(--primary-purple);
    content: counter(item);
    display: inline-block;
    font-family: merriweather, serif;
    font-size: 1.6rem;
    font-weight: 700;
    height: 2.75rem;
    margin-left: -3.5rem;
    margin-right: 10px;
    padding-top: .1rem;
    position: absolute;
    text-align: center;
    width: 1.75em;
}
.text-image-blocked .copy-wrapper {
    padding: 1rem 1rem .5rem 1rem;
}
.text-image-blocked .copy-wrapper h1,
.text-image-blocked .copy-wrapper h2,
.text-image-blocked .copy-wrapper h3,
.text-image-blocked .copy-wrapper h4,
.text-image-blocked .copy-wrapper h5,
.text-image-blocked .copy-wrapper h6 {
    color: var(--primary-purple);
}
.text-image-blocked .image {
    background-size: cover;
    height: 250px;
}
@media only screen and (min-width: 576px) {
    .text-image-blocked .copy-wrapper {
        padding: 2rem 2rem 1rem 2rem;
    }
}
@media only screen and (min-width: 768px) {
    .text-image-blocked .image {
        height: 100%;
    }
    .text-image-blocked .copy-wrapper {
        padding: 3rem 3rem 2rem 3rem;
    }
}
@media only screen and (min-width: 992px) {
    .text-image-blocked .copy-wrapper {
        padding: 4rem 4rem 3rem 4rem;
    }
}
@media only screen and (min-width: 1200px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 6rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 6rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1300px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 7rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 7rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1400px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 8rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 8rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1500px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 9rem;
    }
    .text-image-blocked .copy-wrapper-right {
        padding: 5rem 9rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1600px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 10rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 10rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1700px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 11rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 11rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1800px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 12rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 12rem 4rem 5rem;
    }
}
@media only screen and (min-width: 1900px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 13rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 13rem 4rem 5rem;
    }
}
@media only screen and (min-width: 2000px) {
    .text-image-blocked .copy-wrapper {
        padding: 5rem 5rem 4rem 14rem;
    }
    .text-image-blocked .copy-wrapper.right {
        padding: 5rem 14rem 4rem 5rem;
    }
}
/* /Text Image Blocked Blocks */

/* Video Cards */
.video-card {
    padding: 0;
}
.video-card-copy {
    padding: 1rem 1rem 0rem 1rem;
}
@media only screen and (min-width: 992px) {
    .video-card-copy {
        padding: 1.5rem 1.5rem .5rem 1.5rem;
    }
}
@media only screen and (min-width: 1200px) {
    .video-card-copy {
        padding: 2rem 2rem 1rem 2rem;
    }
}
/* /Video Cards */