:root {
    --hover-box-shadow: rgb(0 0 0 / 8%) 0px 4px 4px -4px;
    --progress-bar-color: #3fc3b2;
}

body {
    line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--heading-font);
}

h2 {
    line-height: 30px;
}

.c-badge {
    font-family: var(--body-font);
    font-size: 1.125rem;
    background: var(--primary-color);
}
.c-profile-tile {
    background: var(--accent-color);
}
.c-profile-tile__complete {
    color: hsl(var(--primary-h), 41%, 90%);
}
.c-profile-tile__button {
    background: #fff;
    color: var(--text-color-primary);
    font-weight: 400;
}
.c-input-box {
    font-size: 0.875rem;
}
.InputLabelLg {
    font-size: 1.375rem;
    font-family: var(--heading-font);
    font-weight: var(--heading-font-weight);
}
.QuestionSwatchLabelText {
    font-weight: normal;
}
.OnboardingHeader {
    font-family: var(--button-font);
}
.InputHelpText {
    font-size: 0.875rem;
}
.c-help-text {
    font-size: 0.875rem;
}
.c-pill {
    font-size: calc(14 / var(--body-font-number) * var(--text-ratio));
}
.c-pill--large {
    font-size: calc(14 / var(--body-font-number) * var(--text-ratio));
}
.AccountMainLocationJoined,
.AccountMainEmail {
    font-size: calc(14 / var(--body-font-number) * var(--text-ratio));
    color: var(--text-color-secondary);
}
.AccountMainLocation,
.AccountMainJoined {
    color: var(--text-color-secondary);
}
.AccountMainEmail path,
.AccountMainLocationJoined path {
    fill: #90979d;
}

.AccountIndexStatsBlank {
    font-size: calc(14 / var(--body-font-number) * var(--text-ratio));
}
.AccountIndexAwardsIconText {
    font-weight: 400;
}
.AccountIndexStatsText {
    font-size: calc(12 / var(--body-font-number) * var(--text-ratio));
}

.flow--subtitle {
    font-family: var(--body-font);
}

.AvailableForYouProductDescription {
    font-size: calc(14 / var(--body-font-number) * var(--text-ratio));
}
.AvailableForYouProductTitle {
    font-size: calc(20 / var(--body-font-number) * var(--text-ratio));
}
.AvailableForYouProductBrand {
    font-size: calc(14 / var(--body-font-number) * var(--text-ratio));
}

a {
    color: inherit;
}

@media (max-width: 400px) {
    .AccountHeaderMenu {
        position: absolute;
        top: auto;
        right: 0;
        width: auto;
        height: auto;
        grid-row: 1 / 1;
        grid-column: 1 / -1;
    }
}

.AccountAvatarMenuImage {
    width: 2.625rem;
    display: block;
}

.c-account-footer {
    background: hsl(var(--primary-h), var(--primary-s), 97%);
}

b,
strong,
h2,
h3,
.OnboardingQuestionText,
.OnboardingHeaderStepContainer .u-heading-font,
#react-address-form label,
.QuestionText,
.c-profile-tile__title,
.c-tabs,
.AvatarEditorTabItem,
.InputLabelLg {
    font-family: var(--button-font);
}

h2 {
    font-size: calc(24 / var(--body-font-number) * var(--text-ratio));
}
h3 {
    font-size: calc(20 / var(--body-font-number) * var(--text-ratio));
}
.OnboardingQuestionText,
#react-address-form label,
.QuestionText,
.c-profile-tile__title,
.InputLabelLg {
    font-size: calc(18 / var(--body-font-number) * var(--text-ratio));
}
.c-tabs {
    font-size: calc(20 / var(--body-font-number) * var(--text-ratio));
}

.c-button {
    border-radius: 50px;
}
.c-button:hover {
    --l: 35%;
}

.c-badge {
    background: var(--secondary-color);
}
.c-progress__bar {
    background: var(--progress-bar-color);
}

.c-input-box__link,
.c-account-footer__nav a {
    color: var(--secondary-color);
}

.c-tabs__item.is-selected,
.AvatarEditorTabItem.selected,
.AvatarOptionButton.selected {
    color: var(--secondary-color);
    border-color: var(--secondary-color);
}
.AccountSidebarSettingsItem.AccountSidebarSettingsItemSelected a {
    color: var(--secondary-color);
}
.AccountSidebarSettingsItem.AccountSidebarSettingsItemSelected::after {
    background-color: var(--secondary-color);
}

input.u-font-size-20,
select.u-font-size-20 {
    font-size: calc(16 / var(--body-font-number) * var(--text-ratio));
}
.c-input-box__label::after {
    --h: var(--secondary-h);
}
.c-input-box__input:checked {
    border-color: var(--secondary-color);
}
.c-input-box__input:checked ~ .c-input-box__label::after {
    border-color: var(--secondary-color);
    background: var(--secondary-color-faded);
}
.c-input-box--radio .c-input-box__checkmark::after,
.c-radio__checkmark::after {
    background: var(--secondary-color);
}
.c-input-box__checkmark {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='hsl(50,100%,27%)' stroke-width='3' d='M5,12.5373721 L9.93086252,17 C15.9769542,9.66666667 19,6 19,6'/%3E%3C/svg%3E%0A");
}
.c-input-box:hover {
    transition: box-shadow 200ms ease-in-out;
    box-shadow: var(--hover-box-shadow);
}
.c-input-box:hover input,
.c-swatches__label:hover .c-radio__checkmark {
    transition: border-color 200ms ease-in-out;
    border-color: var(--secondary-color);
}
.c-swatches__input:checked + .c-swatches__label {
    box-shadow: inset 0px 0px 0px 2px var(--background-color), 0px 0px 0px 2px var(--secondary-color) !important;
}
:checked + .c-swatches__label .c-radio__checkmark,
:checked + .c-swatches__label .c-input-box__checkmark {
    border-color: var(--secondary-color);
}

.c-cookie__button,
.cta-order-sample,
.reviewBtn {
    --h: var(--secondary-h);
    --s: var(--secondary-s);
    --l: var(--secondary-l);
}
.cta-order-sample:disabled,
.cta-order-sample[disabled] {
    --s: 0%;
    --l: 62%;
}
.reviewBtn:disabled,
.reviewBtn[disabled] {
    --s: 32%;
    --l: 72%;
}

.c-cookie__button {
    display: flex;
    color: #fff;
}
