:root {
    --top-bar-height: 85px;
    --row-max-width: 77.875rem;
    --column-inline-padding: 0.9375rem;
    --shadow-100: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
    --shadow-300: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
    --shadow-400: 0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23);
    --shadow-700: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
    --shadow-900: 0 19px 38px rgba(0,0,0,0.30), 0 15px 12px rgba(0,0,0,0.22);
    --brand-clr-appleone: hsla(115, 32%, 45%, 1);
    --brand-clr-allstem: hsla(160, 100%, 16%, 1);
    --brand-clr-allswell: hsla(176, 37%, 36%, 1);
    --brand-clr-agileone: hsla(29, 79%, 60%, 1);
    --brand-clr-allsource: var(--brand-clr-agileone);
    --brand-clr-actonegvt: hsla(188, 24%, 58%, 1);
}

.ltgray a {
    color: #4e6f71;
    text-decoration: underline
}

.clr-neutral--100 {
    color: white !important;
}

.box-shadow--100 {
    box-shadow: var(--shadow-100);
}

.box-shadow--300 {
    box-shadow: var(--shadow-300);
}

.box-shadow--400 {
    box-shadow: var(--shadow-400);
}

.box-shadow--700 {
    box-shadow: var(--shadow-700);
}

.box-shadow--900 {
    box-shadow: var(--shadow-900);
}


.homesection--landing-page-mil-clr-200 {
    background-color: #f7f9f5
}

.homesection--landing-page-mil-clr-400 {
    background-color: #eef1e8
}

.homesection--landing-page-mil-clr-700 {
    background-color: #82a860;
    color: #fff
}

.homesection--landing-page-mil-clr-alt {
    background-color: #52788a;
    color: #fff
}

.homesection--landing-page-mil-clr-alt-200 {
    background-color: #eff4f5
}

.pg-landing .row {
    max-width: var(--row-max-width);
}

.pg-landing .section-hero {
    background: url(/sourcewell/imgs/sourcewell-hero-img.jpg) no-repeat center center;
    background-size: cover;
    margin-top: var(--top-bar-height);
    min-height: 51.45vw;
    display: grid;
    align-content: end;
}

.section-hero--overlay {
    border-image: fill 1 linear-gradient(hsl(0 0% 62% / 0) 32%,hsl(0 0% 100% / 1) 78%)
}

.pg-landing .heading {
    font-family: "Montserrat",Segoe,"Segoe UI",Optima,Arial,Sans-Serif;
    font-weight: 700;
    font-style: normal;
    text-wrap: balance;
}

.heading--hero {
    font-size: clamp(1.625rem, 5.5vw + -0.025rem, 4.375rem);
    line-height: 1;
    color: #58595B;
}

.pg-landing .heading--secondary {
    font-size: clamp(2rem, 1vw + 1.7rem, 2.5rem);
}

.pg-landing p, .pg-landing li {
    font-size: clamp(1rem, 0.5vw + 0.85rem, 1.25rem);
    line-height: clamp(1.7rem, 0.35vw + 1.595rem, 1.875rem);
    color: #58595B;
}

#copyright p {
    color: inherit;
}

.heading--hero small {
    font-size: .71em;
    font-weight: 400;
    display: block;
    line-height: 1.2;
    color: #7CA7AD;
}


.homesection--2col {
    padding: 0
}

.homesection-2col__col1 {
    padding-block: 5rem;
    margin-inline-start: 14vw;
    padding-inline-end: 2rem
}

    .homesection-2col__col1 h2 {
        font-size: 1.5rem
    }

    .homesection-2col__col1 li + li {
        margin-block-start: 1.25em
    }

.homesection-2col__col-img-bg {
    background-repeat: no-repeat;
    background-size: cover;
    background-position-x: center;
    min-height: 300px
}

.interiorhero--landing {
    padding-block: 7vw
}

p.lead {
    font-size: 1.5rem;
    font-weight: 500
}

.icon-block--horz {
    display: flex;
    align-items: center
}

.icon-block__img {
    max-width: 80px
}

.icon-block__text > strong {
    font-size: 1.25em
}

.icon-block__text > * {
    margin-bottom: 0
}

.icon-block__text > h3 {
    font-size: 1.25em;
    font-family: 'Montserrat',sans-serif
}

.icon-block__text > * + * {
    margin-block-start: .5rem
}

.icon-block--horz .icon-block__text {
    flex-grow: 1;
    margin-inline-start: 1.5rem;
    margin-block: 0;
    font-size: 1.25rem
}

.icon-block--horz .icon-block__icon {
    width: 25%;
    flex-shrink: 2
}

.logo--company {
    max-height: 175px;
    margin-block-end: 1rem
}

.text--teal {
    color: #7da7ad !important
}

.landing-page__hero-heading {
    font-size: clamp(2rem, 1.617vw + 1.582rem, 2.875rem);
    font-family: Montserrat,sans-serif;
    font-weight: 500;
    font-style: normal;
    line-height: 1.1;
    text-transform: uppercase;
    margin-bottom: .5em
}

.interiorhero--landing, .interiorhero--marketo {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center bottom
}

.interiorhero--marketo {
    min-height: calc(100vh - 5.3125rem);
    margin-top: 5.3125rem;
    position: relative;
    z-index: 1
}

    .interiorhero--marketo:before {
        content: "";
        background-color: rgb(0 0 0 / .05);
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 0
    }

    .interiorhero--marketo > row {
        position: relative;
        isolation: isolate
    }

    .interiorhero--marketo a {
        color: #fff;
        font-weight: 700;
        text-decoration: underline
    }

.landing-page__content {
    border-radius: .5rem;
    background-color: rgb(255 255 255 / 80%);
    padding-inline: 10%;
    padding-block-start: 1.5rem;
    padding-block-end: 3rem
}

    .landing-page__content h2 {
        line-height: 1.1;
        font-style: normal
    }

.marketo-form__container {
    margin-block-start: 2rem
}

    .marketo-form__container h2 {
        font-size: 2rem
    }

.mktoForm {
    width: 100% !important
}

    .mktoForm .mktoFormCol {
        width: 50%
    }

.mktoFormRow:nth-of-type(3) > .mktoFormCol, .mktoFormRow:nth-of-type(2) > .mktoFormCol {
    width: 100%
}

.mktoFormRow > .mktoFormCol .mktoOffset {
    display: none !important;
}

.mktoFormRow > .mktoFormCol .mktoFieldWrap {
    width: 100%
}

.mktoFormRow .mktoFormCol .mktoFieldWrap input:not([type="checkbox"],[type="radio"],#Email) {
    width: 99% !important
}

.mktoFormRow:nth-of-type(3) label, .mktoFormRow:nth-of-type(2) label {
    width: max-content !important
}

.mktoFormRow:nth-of-type(3) input, .mktoFormRow:nth-of-type(2) input {
    width: 100% !important
}

.mktoButtonRow {
    margin-block-start: 0.75rem !important
}

.mktoForm .mktoGutter {
    display: none !important;
}

.mktoClear {
    display: none;
}

.services {
    background-color: #fff;
    box-shadow: var(--shadow-100);
    border-radius: 10px;
    padding: clamp(3.125rem, 6.25vw + 1.25rem, 6.25rem) clamp(1.5rem, 3vw + 0.6rem, 3rem);
    display: grid;
    gap: 3rem;
    margin-top: .5rem;
    overflow: hidden;
}

.services__buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

    .services__buttons > * {
        flex: 1;
        max-width: 300px;
        min-width: 200px;
    }

.services__service-btn {
    background-color: #fff;
    border: 2px solid #58595B;
    box-shadow: var(--shadow-300);
    padding: 1rem 1.25rem;
    display: flex;
    gap: clamp(0.75rem, 0.75vw + 0.525rem, 1.125rem);
    align-items: center;
    transition: box-shadow .3s cubic-bezier(.25,.8,.25,1);
}

    .services__service-btn:is(:hover,:focus) {
        background-color: inherit;
        box-shadow: var(--shadow-400);
    }

.services__service-btn--active {
    box-shadow: var(--shadow-400);
    cursor: default;
}

.services__service-btn--appleone {
    border-color: var(--brand-clr-appleone);
}

.services__service-btn--allstem {
    border-color: var(--brand-clr-allstem);
}

.services__service-btn--allswell {
    border-color: var(--brand-clr-allswell);
}

.services__service-btn--allsource {
    border-color: var(--brand-clr-allsource);
}

.services__service-btn--agileone {
    border-color: var(--brand-clr-agileone);
}

.services__service-btn--actone-govt {
    border-color: var(--brand-clr-actonegvt);
}

.service-btn__icon {
    flex: 0 0 42px;
}


.services__descriptions {
    position: relative;
    align-content: stretch;
    display: grid;
}


.services .service-btn__text {
    font-size: clamp(0.75rem, 0.5vw + 0.6rem, 1rem);
    text-transform: initial;
    flex-grow: 1;
    margin: 0;
    text-align: left;
}

.services__service-card {
    background-color: #fff;
    border: 2px solid #58595B;
    box-shadow: var(--shadow-400);
    padding: 2.25rem 1.875rem;
    border-radius: 10px;
    align-items: center;
    pointer-events: none;
    position: relative;
    opacity: 0;
    z-index: 1;
    transition: opacity .5s ease-in-out;
}

.services__service-card--active {
    pointer-events: initial;
    z-index: 10;
    opacity: 1;
}

.services__service-card--appleone {
    border-color: var(--brand-clr-appleone);
}

.services__service-card--allstem {
    border-color: var(--brand-clr-allstem);
}

.services__service-card--allswell {
    border-color: var(--brand-clr-allswell);
}

    .services__service-card--allswell .service-card__img {
        object-position: center;
    }

.services__service-card--allsource {
    border-color: var(--brand-clr-allsource);
}

    .services__service-card--allsource .service-card__img {
        object-position: center;
    }

.services__service-card--agileone {
    border-color: var(--brand-clr-agileone);
}

    .services__service-card--agileone .service-card__img {
        object-position: 70%;
    }

.services__service-card--actone-govt {
    border-color: var(--brand-clr-actonegvt);
}

    .services__service-card--actone-govt .service-card__img {
        object-position: center;
    }

.service-card__content {
    display: flex;
    flex-direction: column;
    gap: 1.0rem;
}

    .service-card__content > * {
        margin: 0;
    }

.services__descriptions > .services__service-card {
    grid-row: 1;
    grid-column: 1;
}

.service-card__img {
    margin-block-start: 1.5rem;
    width: 100%;
    object-fit: cover;
    object-position: left;
}

.service-card__content > img {
    max-width: 100%;
}

.service-card__content > p {
    font-size: 1.125rem;
}

.solution {
    display: flex;
    flex-direction: column;
    justify-content: space-between
}

.solutions__description {
    margin-block-end: auto
}

.section-contact {
    position: relative;
    padding: 2rem var(--column-inline-padding);
}

.section-contact__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    position: absolute;
    inset: 0;
    z-index: -1;
    filter: blur(14px) grayscale(58%) saturate(129%);
}

.section-contact__form-container {
    background-color: #fff;
    border-radius: 10px;
    border: 2px solid hsla(220, 2%, 35%, 1);
    box-shadow: var(--shadow-300);
    padding: 3rem 3.625rem;
}

    .section-contact__form-container:has(.mktoForm:focus-within) {
        box-shadow: var(--shadow-700);
    }

@media screen and (max-width:640px) {
    .mktoForm .mktoFormCol {
        width: 100% !important
    }
}

@media (max-width:360px) {
    .tabs.client li {
        font-size: .75em
    }

    .homesection {
        padding-top: 0
    }
}

@media (min-width:37.5rem) {
    .homesection--2col {
        display: grid;
        grid-template-columns: 1fr 1fr
    }

    .section-contact {
        display: grid;
        grid-template-columns: minmax(var(--column-inline-padding),1fr) minmax(0,calc(var(--row-max-width)/4)) minmax(0,calc(var(--row-max-width)/4)) minmax(0,calc(var(--row-max-width)/2)) minmax(var(--column-inline-padding),1fr);
        grid-template-rows: 82px 1fr 70px;
        margin-block: 3rem;
        padding: 0;
    }

    .section-contact__img {
        position: relative;
        grid-row: 2/3;
        grid-column: 3/6;
        filter: initial;
    }

    .section-contact__form-container {
        grid-row: 1/4;
        grid-column: 2/4;
    }
}

@media (min-width:56.25rem) {

    .services {
        grid-template-columns: 320px 1fr;
    }

    .services__buttons {
        flex-direction: column;
        row-gap: 1.75rem;
    }

    .services__descriptions {
        align-content: stretch;
    }
}

@media (min-width:1281px) {
    .services__service-card {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 1.75rem;
    }

    .service-card__img {
        justify-self: stretch;
        height: 100%;
        object-fit: cover;
        object-position: left;
        margin-block-start: 0;
    }
}

@media (orientation: landscape) {
    .pg-landing .section-hero {
        min-height: 30.45vw;
        background-position-y: top;
    }
}

.full-width-split-screen {
    --row-max-width: 62.5rem;
}

    .full-width-split-screen > :not(img) {
        padding-block: var(--section-padding,3.125rem);
        padding-inline: var(--column-inline-padding);
    }
    .full-width-split-screen > :is(img){
                width: 100%;
    }
    
    @media screen and (min-width: 45em) {
        .full-width-split-screen {
        display: grid;
        grid-template-columns: minmax(var(--column-inline-padding), 1fr) minmax(0, calc(var(--row-max-width)/2)) minmax(0, calc(var(--row-max-width)/2)) minmax(var(--column-inline-padding), 1fr);
        position: relative;
    }

        .full-width-split-screen > img {
            height: 100%;
            object-fit: cover;
            object-position: center top;
        }

            .full-width-split-screen > img:first-child {
                grid-column: 1/3;
            }

            .full-width-split-screen > img:last-child {
                grid-column: 3/-1;
            }

        .full-width-split-screen > :not(img) {
            display: grid;
            align-content: center;
            justify-content: start;
        }

            .full-width-split-screen > :not(img):first-child {
                padding-left: 0;
                grid-column: 2/3;
            }

                .full-width-split-screen > :not(img):first-child::before {
                    grid-column: 1/2;
                }

            .full-width-split-screen > :not(img):last-child {
                padding-right: 0;
                grid-column: 3/4;
            }
                .full-width-split-screen > :not(img):last-child::before {
                    grid-column: 4/5;
                }
            .full-width-split-screen > :not(img)::before {
                content: '';
                position: absolute;
                inset: 0;
                background: inherit;
            }
}

.section__cta {
    background-color: #79acaf;
    color: #fff;
}

    .section__cta > .section__heading {
        color: #fff;
        font-size: clamp(1.75rem, 1.875vw + 0.813rem, 2.5rem);
        line-height: clamp(2.275rem, 1.188vw + 1.681rem, 2.75rem);
    }


.buttton-group {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: start;
    margin-top: 1.5rem;
}