/****** HATHAWAY PROVIDED CSS ******/

.left-chevron-link {
    font-family: 'Montserrat', sans-serif;
    color: #000;
    font-weight: bold;
    font-size: 11px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    letter-spacing: 2px;
    padding: 0 0 2rem;
}

.left-chevron-link svg {
    margin-right: 15px;
}

.fcw-checkout-wrap .accordion-title {
    padding: 15px 0;
    border: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.fcw-checkout-wrap .accordion-title span {
    font-size: 22px;
}

.form-wrap h2:after {
    content: '';
    background: url("../img/dotted-border-custom.65e0adef6317.svg") left bottom / contain repeat-x;
    width: 100%;
    height: 4px;
    display: block;
    background-size: 10px;
}

main.checkout h1,
main.checkout h2,
main.checkout h3,
.fcw-checkout-wrap .accordion-title {
    font-family: "Financier Display", serif;
    font-weight: bold;
    font-size: 26px;
    color: #000;
    padding: 15px 0px;
    text-transform: none;
    font-variant: inherit;
    background: none;
    margin: 0;
    text-align: left;
}

.fcw-checkout-wrap .accordion-title>strong {
    padding-right: 30px;
}

main.checkout h2 {
    padding: 0;
}

main.checkout h3 {
    font-size: 22px;
}

main.checkout h4 {
    font-size: 16px;
    font-family: 'Montserrat', sans-serif;
    font-weight: bold;
    text-align: left;
}

main.checkout .accordion-item.is-active .accordion-content:before,
main.checkout .accordion-item:after {
    content: '';
    background: url("../img/dotted-border-custom.65e0adef6317.svg") left bottom / contain repeat-x;
    width: 100%;
    height: 4px;
    display: block;
    background-size: 10px;
}

main.checkout .accordion-item.is-active {
    margin-bottom: 25px;
}

main.checkout .accordion-item.is-active:after {
    display: none;
}

main.checkout :last-child>.accordion-content:last-child,
main.checkout :last-child:not(.is-active)>.accordion-title {
    border-bottom: none;
}

main.checkout .accordion-content {
    border: none;
    padding: 0;
}

main.checkout .accordion-title::before {
    display: none;
}

.fcw-arrow {
    position: relative;
}

.fcw-arrow .minus,
.fcw-arrow .minus-animate {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 23px;
    height: 3px;
}

.is-active .fcw-arrow .minus {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: -webkit-transform 300ms ease-out;
    transition: -webkit-transform 300ms ease-out;
    transition: transform 300ms ease-out;
    transition: transform 300ms ease-out, -webkit-transform 300ms ease-out;
}

.fcw-arrow .minus {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition: -webkit-transform 300ms ease-out;
    transition: -webkit-transform 300ms ease-out;
    transition: transform 300ms ease-out;
    transition: transform 300ms ease-out, -webkit-transform 300ms ease-out;
}

.fcw-order-summary {
    background: #F6F5EF;
    padding: 2rem;
    margin-top: 30px;
}

.fcw-order-summary span {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    color: #474038;
    margin: 10px 0;
    display: block;
    font-weight: 600;
}

.promo-item {
    width: auto;
    -webkit-box-flex: 0;
    -ms-flex-positive: 0;
    flex-grow: 0;
    display: inline-block;
    background: #474038;
    padding: 5px 30px 5px 5px;
    position: relative;
}

.promo-item p {
    margin: 0;
    color: #FFF;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: bold;
}

.promo-item a {
    position: absolute;
    width: 9px;
    height: 9px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    right: 6px;
    top: 8px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.order-sum-group,
.fcw-order-total {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.fcw-order-total span {
    font-family: "Financier Display", serif;
    font-weight: bold;
    font-size: 22px;
    color: #000;
}

.form-group {
    position: relative;
}

.toggle-hidden .form-group {
    margin-top: 15px;
}

.billing-group .flex-container .form-group {
    margin: 0 15px 0 0;
}

.billing-group .flex-container .form-group:last-child {
    margin: 0;
}

#fcw-add-payment-form .flex-container>.form-group {
    margin-top: 0;
}

.billing-group .flex-container .form-group.animate {
    margin-top: 30px;
}

main.checkout [type=date],
main.checkout [type=email],
main.checkout [type=month],
main.checkout [type=number],
main.checkout [type=password],
main.checkout [type=search],
main.checkout [type=text],
main.checkout textarea,
main.checkout select {
    margin: 0 0 1rem;
}

.cvv-group input,
.form-group input,
.gift-card-group input,
textarea {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    color: #000;
    font-size: 14px;
    height: 42px;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 1px solid #979797;
}

main.checkout textarea {
    height: auto;
}

main.checkout input::-webkit-input-placeholder {
    color: #6C6B6B;
}

main.checkout input:-ms-input-placeholder {
    color: #6C6B6B;
}

main.checkout input::placeholder {
    color: #6C6B6B;
}

main.checkout label {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    color: #6C6B6B;
    font-size: 14px;
}

.group-select label {
    display: none;
}

.form-group label {
    position: absolute;
    padding: 8px 15px;
    top: 0;
    -webkit-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

.form-group.animate {
    margin-top: 30px;
    -webkit-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

.form-group.animate label {
    top: -32px;
    padding-left: 0;
    -webkit-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

.fcw-service,
.fcw-address,
.fcw-shipped-to,
.fcw-address-item,
.fcw-saved-card {
    border: none;
    margin: 0;
    width: 100%;
    background: none;
    position: relative;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.fcw-service.selected,
.fcw-address.selected,
.fcw-shipped-to.selected,
.fcw-address-item.selected,
.fcw-saved-card.selected {
    background-color: #F6F5EF;
}

.fcw-service p,
.fcw-address p,
.fcw-shipped-to p,
.fcw-address-item p,
.fcw-gift-card-item p,
.fcw-card-item p {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: #6C6B6B;
    margin: 0 auto;
    padding: 20px;
}

.fcw-service p strong,
.fcw-address p strong,
.fcw-shipped-to p strong,
.fcw-address-item p strong,
.fcw-saved-card p strong {
    font-weight: bold;
    color: #000;
}

.fcw-address p {
    padding: 15px 15px 15px 60px;
}

.fcw-checkmark-circle {
    border-radius: 16px;
    border: 1px solid #000;
    position: absolute;
    left: 20px;
    top: 18px;
    right: inherit;
    background: none;
    padding: 11px;
    width: 24px;
    height: 24px;
}

.fcw-checkmark-circle svg {
    display: none;
}

.fcw-checkmark {
    border: 1px solid #000;
    background: none;
    display: block;
    position: absolute;
    left: 20px;
    top: 20px;
    right: inherit;
    padding: 5px;
    max-width: inherit;
    height: 24px;
    width: 24px;
}

.selected .fcw-checkmark {
    background: #EEC474;
    border: none;
}

.fcw-checkmark svg {
    display: none;
}

.selected .fcw-checkmark svg {
    display: block;
}

.selected .fcw-checkmark-circle {
    padding: 5px;
    background: #EEC474;
    border: none;
}

.selected .fcw-checkmark-circle svg {
    display: block;
}

.gift-card-group {
    padding: 0 0 15px 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.gift-card-group input {
    margin: 0;
    max-width: 150px;
}

#shippingserviceslist {
    margin-bottom: 15px;
}

#shippingserviceslist .fcw-service {
    position: relative;
    padding-left: 60px;
    margin: 0;
    /*border-left: 1px solid #979797;*/
    /*border-right: 1px solid #979797;*/
}

#shippingserviceslist .fcw-service.selected,
#shippingserviceslist .fcw-service.selected.remove-border {
    border-top: none;
}

#shippingserviceslist>div:nth-child(2) {
    border: 1px solid #979797;
    border-top: none;
}

#shippingserviceslist .fcw-service.remove-border {
    border: none;
}

.fcw-services-premier {
    padding: 15px 70px;
    font-family: 'Montserrat', sans-serif;
    color: #6C6B6B;
    border: 1px solid #979797;
    border-bottom: none;
}

.fcw-services-premier p {
    font-size: 12px;
    font-weight: 500;
    margin-bottom: 10px;
}

.fcw-services-premier strong {
    color: #000;
}

.fcw-services-premier a {
    font-family: 'Montserrat', sans-serif;
    color: #000;
    font-weight: bold;
    font-size: 12px;
    letter-spacing: 2px;
}

.disclaimer {
    color: #5F6164;
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 10px;
}

#fcw-promo-code form {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 25px 0;
}

#fcw-promo-code form input[type="text"] {
    margin: 0;
    height: 42px;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 0;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    font-size: 14px;
    color: #6C6B6B;
}

.accent-border {
    border-bottom: 1px solid #CCA36E !important;
}

main.checkout button,
main.checkout .button.fcw-alt-button,
main.checkout .button.toggle-button {
    font-family: 'Montserrat', sans-serif;
    font-weight: bold;
    font-size: 14px;
    width: auto;
    background: #000;
    color: #FFF;
    border: none;
    min-width: 120px;
    margin: 0 0 1rem 0;
}

main.checkout .button.toggle-button,
main.checkout .fcw-outline-button {
    background: none;
    border: 2px solid #000;
    color: #000;
}

main.checkout .button.toggle-button:hover,
main.checkout .fcw-outline-button:hover {
    background: #000;
    color: #FFF;
}

main.checkout button {
    padding: 15px 25px;
    width: 100%;
    text-align: center;
}

main.checkout form .button {
    height: 42px;
}

.fcw-product-block {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: inherit;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    padding: 35px;
    border: 1px solid #E0DFD8;
    border-top: none;
    margin: 0;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.fcw-product-details {
    width: 70%;
    background: none;
    padding: 0 25px;
}

.fcw-product-image {
    border: none;
    background: none;
    padding: 0;
    width: 25%;
}

.fcw-product-details>div {
    border: none;
    text-align: left;
}

.fcw-product-details>div:last-of-type {
    border: none;
    float: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.fcw-product-title a {
    text-align: left;
    padding: 0;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    color: #000;
    font-weight: bold;
}

.fcw-product-price span {
    color: #5F6164;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 600;
    margin: 10px 0;
}

.fcw-product-price .retail-wrap span {
    font-size: 14px;
    font-weight: bold;
}

.fcw-newsletter {
    margin: 20px 0;
}

.fcw-newsletter {
    background: #474038;
    color: #FFF;
}

.fcw-newsletter h3 {
    font-family: "Financier Display", serif;
    font-weight: bold;
    font-size: 24px;
    color: #FFF;
}

main.checkout .flex-container>div {
    width: 100%;
}

.fcw-checkout-wrap select,
main.checkout .reveal select {
    height: 42px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    color: #6C6B6B;
    font-size: 14px;
    border: 1px solid #979797;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background-position: right;
    background-size: 42px 42px;
    background-repeat: no-repeat;
    cursor: pointer;
    padding: 0 0 0 15px;
    appearance: menulist-button;
}

.group-select {
    padding: 0 15px;
}

.group-select>div {
    position: relative;
}

.group-select>div:after {
    content: '';
    background-image: url("data:image/svg+xml,%3Csvg id='Layer_1' data-name='Layer 1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='18.73' height='18.39' viewBox='0 0 18.73 18.39'%3E%3Cdefs%3E%3Cmask id='mask' x='-0.34' y='-3.51' width='20.27' height='21.9' maskUnits='userSpaceOnUse'%3E%3Cg transform='translate(-0.73 -0.89)'%3E%3Cg id='mask-2'%3E%3Cpolygon id='path-1' points='0.39 2.18 10.08 11.66 20.66 1.46 18.29 -2.62 3.79 -2.62 0.39 0.55 0.39 2.18' fill='%23fff' fill-rule='evenodd'/%3E%3C/g%3E%3C/g%3E%3C/mask%3E%3C/defs%3E%3Ctitle%3Echevron-down%3C/title%3E%3Cg id='Group'%3E%3Cg mask='url("#mask#mask")'%3E%3Cpath id='Rectangle' d='M18.43.89l1,1a24.39,24.39,0,0,1-3.08,3.7L5.53,16.26a24.59,24.59,0,0,1-3.77,3l-1-1a24.39,24.39,0,0,1,3.08-3.7L14.67,3.92A24.69,24.69,0,0,1,18.43.89Z' transform='translate(-0.73 -0.89)' fill='%23fff' fill-rule='evenodd'/%3E%3C/g%3E%3Cg mask='url("#mask#mask")'%3E%3Cpath d='M.73,1.9l1-1a25.27,25.27,0,0,1,3.77,3L16.38,14.57a24.39,24.39,0,0,1,3.08,3.7l-1,1a24,24,0,0,1-3.76-3L3.81,5.6A24.39,24.39,0,0,1,.73,1.9Z' transform='translate(-0.73 -0.89)' fill='%23fff' fill-rule='evenodd'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    background-size: 21px 23px;
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    width: 42px;
    height: 42px;
    pointer-events: none;
    background-repeat: no-repeat;
    cursor: pointer;
    background-position: 10px 14px;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: -webkit-transform 500ms ease-out;
    transition: -webkit-transform 500ms ease-out;
    transition: transform 500ms ease-out;
    transition: transform 500ms ease-out, -webkit-transform 500ms ease-out;
}

.group-select.focused>div:after {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    -webkit-transition: -webkit-transform 500ms ease-out;
    transition: -webkit-transform 500ms ease-out;
    transition: transform 500ms ease-out;
    transition: transform 500ms ease-out, -webkit-transform 500ms ease-out;
}

.info-wrap {
    position: relative;
    margin-left: 15px;
}

.info-wrap svg {
    width: 15px;
    height: 15px;
}

.info-wrap .info-text {
    position: absolute;
    background: #F6F5EF;
    bottom: 32px;
    width: 300px;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 500;
    padding: 10px;
    text-align: center;
    color: #000;
    line-height: 1.25em;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    visibility: hidden;
    opacity: 0;
    -webkit-transition: opacity 500ms ease-out;
    transition: opacity 500ms ease-out;
}

.info-wrap .info-text:after {
    content: '';
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 20px solid #F6F5EF;
    position: absolute;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    bottom: -10px;
}

.info-wrap:hover .info-text {
    opacity: 1;
    visibility: visible;
    -webkit-transition: opacity 500ms ease-out;
    transition: opacity 500ms ease-out;
}

#giftoptiontrigger {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.fcw-gift-message {
    margin-bottom: 15px;
}

.fcw-gift-message .custom-checkbox {
    margin-bottom: 20px;
}

.custom-checkbox input[type="checkbox"] {
    opacity: 0;
    display: none;
}

.custom-checkbox input[type="checkbox"]+label {
    margin: 0;
    padding: 5px 40px;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: #6C6B6B;
}

.custom-checkbox input[type="checkbox"]+label strong {
    color: #000;
}

.fcw-gift-message .custom-checkbox input[type="checkbox"]+label {
    padding: 0 40px;
}

.fcw-gift-message>div {
    padding: 0;
}

.custom-checkbox input[type="checkbox"]+label::before {
    content: '';
    display: inline-block;
    height: 24px;
    width: 24px;
    border: 1px solid;
    margin-right: 15px;
}

.custom-checkbox input[type="checkbox"]+label::after {
    content: "";
    display: inline-block;
    height: 13px;
    width: 14px;
    background-image: url("data:image/svg+xml,%3Csvg id='Layer_1' data-name='Layer 1' xmlns='http://www.w3.org/2000/svg' width='13.31' height='12.77' viewBox='0 0 13.31 12.77'%3E%3Ctitle%3Echeck-mark%3C/title%3E%3Cpath id='Path-5' d='M0,7.25c.68.91,1.5,2,2.48,3.21,1.92,2.41,3.61,3,4.52,1.43,2.35-4.11,4.44-8,5.17-9.32a18.93,18.93,0,0,0,1-2.1c.2-.46.27-.64-.07-.28-.7.75-1.05,1.05-1.76,1.94q-1.72,2.16-6.1,8L.29,7.25Z' transform='translate(0 0)' fill='%23474038' fill-rule='evenodd'/%3E%3C/svg%3E");
    background-position: center;
}

.custom-checkbox input[type="checkbox"]+label {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.custom-checkbox input[type="checkbox"]+label::before,
.custom-checkbox input[type="checkbox"]+label::after {
    position: absolute;
}

/*Outer-box*/
.custom-checkbox input[type="checkbox"]+label::before {
    top: 3px;
    left: 0;
}

/*Checkmark*/
.custom-checkbox input[type="checkbox"]+label::after {
    left: 4px;
    top: 7px;
}

/*Hide the checkmark by default*/
.custom-checkbox input[type="checkbox"]+label::after {
    content: none;
}

/*Unhide the checkmark on the checked state*/
.custom-checkbox input[type="checkbox"]:checked+label::after {
    content: "";
}

.custom-checkbox input[type="checkbox"]:checked+label::before {
    background: #EEC474;
    border: none;
}

.fcw-newsletter {
    margin: 20px 0;
}

main.checkout .fcw-newsletter h3 {
    font-family: "Financier Display", serif;
    font-weight: bold;
    font-size: 24px;
    color: #FFF;
    padding-top: 0;
    text-align: left;
}

main.checkout .fcw-newsletter p {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: #FFF;
}

.fcw-warning {
    border: none;
    margin: 0;
}

.sofiawarning {
    border: none;
    font-family: 'Montserrat', sans-serif;
    color: #474038;
    padding: 0 15px;
    font-size: 10px;
}

.add-new-card .group-select:first-child {
    padding: 0;
}

.fcw-card-item {
    position: relative;
}

.rewards-wrap {
    background: #F6F5EF;
    padding: 20px;
}

.submit-order {
    margin-top: 25px;
}

.pass-container {
    margin: 25px 0 0;
}

.fcw-card-item {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.fcw-card-item strong {
    color: #000;
}

main.checkout .fcw-card-item>div {
    width: auto;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.fcw-card-item.selected {
    background: #F6F5EF;
}

.fcw-card-cvv {
    padding: 0 35px 0 60px;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.cvv-group {
    max-width: 150px;
}

.fcw-card-edit,
.fcw-card-remove {
    padding: 15px;
}

.fcw-card-edit a,
.fcw-card-remove a {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    color: #000;
    text-decoration: underline;
    font-weight: bold;
}

.fcw-card-edit a:hover,
.fcw-card-remove a:hover {
    text-decoration: none;
}

.fcw-card-item span,
.fcw-gift-card-item span {
    display: block;
}

.fcw-card p,
.fcw-saved-card p {
    padding-left: 60px;
}

.fcw-add-card-form input {
    max-width: 215px;
}

.fcw-add-address-form,
.saved-cards {
    margin-top: 30px;
}

.more-saved-card-button {
    margin-top: 25px;
}

.rewards-image {
    max-width: 92px;
    height: 92px;
    border-radius: 50%;
    overflow: hidden;
    display: none;
}

.rewards-wrap .custom-checkbox input[type="checkbox"]+label {
    padding: 0 40px;
}

.rewards-wrap .inside-container .custom-checkbox input[type="checkbox"]+label {
    padding: 3px 0 3px 40px;
}

.inside-container a {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    color: #000;
    font-weight: bold;
    display: block;
    padding: 5px 3px;
    text-decoration: underline;
}

.inside-container a:hover {
    text-decoration: none;
}

.dashed-cta {
    position: relative;
    font-weight: bold;
    letter-spacing: 2px;
    text-decoration: none;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
}

.dashed-offset-border {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: absolute;
    bottom: -4px;
    left: 0;
    background: none;
    -webkit-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

.dashed-offset-border svg {
    height: 1px;
}

.dashed-cta.black svg {
    background: #000;
}

main.checkout .white {
    color: #FFF;
}

main.checkout .black {
    color: #000;
}

.dashed-cta.white svg rect {
    fill: #FFF;
    background: #FFF;
}

/*.dashed-offset-border svg rect {*/
/*fill: red;*/
/*}*/

.dashed-offset-border svg {
    width: 30%;
    margin-right: 7px;
    -webkit-transition: margin 500ms ease-out;
    transition: margin 500ms ease-out;
}

.dashed-offset-border svg:first-child {
    width: 65%;
    margin-right: 12px;
}

.dashed-offset-border svg:last-child {
    width: 5%;
    margin-right: 0;
}

.dashed-cta:hover .dashed-offset-border svg {
    width: 0;
    -webkit-transition: width 500ms ease-out;
    transition: width 500ms ease-out;
}

.dashed-cta:hover .dashed-offset-border svg:first-child {
    margin: 0;
    width: 100%;
}

.dashed-cta.white:hover .dashed-offset-border {
    background: #FFF;
    -webkit-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

.dashed-cta.black:hover .dashed-offset-border {
    background: #000;
    -webkit-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

.toggle-selected>div {
    cursor: pointer;
}

main.checkout .reveal {
    padding: 45px;
    border: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    background: #FFF;
}

main.checkout .reveal .reveal-header {
    position: relative;
    margin-bottom: 20px;
}

main.checkout .reveal h4 {
    color: #000;
    font-family: "Financier Display", serif;
    font-weight: bold;
    font-size: 30px;
    font-variant: inherit;
}

main.checkout .reveal p {
    font-family: 'Montserrat', sans-serif;
    color: #6C6B6B;
    font-size: 14px;
    line-height: 1em;
    font-weight: 500;
}

main.checkout .reveal .close-button {
    background: none;
    padding: 0;
    text-align: right;
    right: 26px;
    top: 0;
    min-width: inherit;
    height: 24px;
    width: 27px;
}

main.checkout .reveal .close-button:before,
main.checkout .reveal .close-button:after {
    position: absolute;
    left: 15px;
    content: ' ';
    height: 25px;
    width: 3px;
    background-color: #484139;
    top: 0;
}

main.checkout .reveal .close-button:before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

main.checkout .reveal .close-button:after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

main.checkout .reveal .button {
    width: 100%;
    margin-top: 30px;
}

main.checkout .reveal .group-select:first-child {
    padding: 0;
}

main.checkout .reveal .fcw-outline-button {
    margin-right: 15px;
}

/* Thank you page */
.order-confirmation,
.customer-info {
    padding: 15px;
    border: 1px solid #979797;
    margin-bottom: 25px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.customer-info>div h4 {
    margin-top: 15px;
}

.customer-info>div:first-child h4 {
    margin-top: 0;
}

.order-confirmation>div h4:first-child {
    margin: 10px 0 20px;
}

main.checkout .order-confirmation button {
    margin: 25px 0 0;
}

.order-confirmation p,
.customer-info p {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 12px;
    color: #6C6B6B;
    margin-bottom: 0;
}

.customer-info>div>div:first-child {
    margin-bottom: 15px;
}

.checkout-promos {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.checkout-promos a {
    font-size: 12px;
}

.checkout-promos>div {
    margin: 15px 0;
    background-size: contain;
    background-position: bottom right;
}

.checkout-promos>div:first-child {
    margin-left: 0;
}

.checkout-promos>div:last-child {
    margin-right: 0;
}

.checkout-promos h5 {
    font-family: "Financier Display", serif;
    font-weight: bold;
    color: #FFF;
    font-size: 30px;
}

.checkout-promos h5 span {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    display: block;
    font-weight: bold;
}

.checkout-promos p {
    font-size: 12px;
    color: #FFF;
    font-weight: 500;
    width: 70%;
}

.checkout-promos a {
    color: #FFF;
}

.promo {
    padding: 40px;
    width: 100%;
}

.promo1 {
    background: url("../img/promo1_bg.f16dd871e983.png") no-repeat;
    background-color: #A06910;
    background-position: right bottom;
    background-size: 19%;
}

.promo2 {
    background: url("../img/promo2_bg.bd6a799471ad.png") no-repeat;
    background-color: #194536;
    background-position: right center;
    background-size: 24%;
}

.fcw-shipping-premier-promo {
    background: url("../img/shipping-promo_bg.7e79f6946e5b.png") no-repeat;
    background-size: cover;
    background-position: top left;
}

main.checkout .fcw-shipping-premier-promo h3 {
    padding-top: 0;
    color: #FFF;
    font-size: 24px;
}

.fcw-contact {
    border: 1px solid #979797;
}

.fcw-contact h3 {
    padding: 0 0 10px;
}

.fcw-contact p {
    font-weight: 600;
    font-size: 12px;
    margin-bottom: 5px;
}

.fcw-contact a:hover {
    color: #000;
}

/*.join-rewards > div:last-child {
    margin-top: 30px;
}*/

.join-rewards>div .button {
    width: 100%;
}

.confirmation .flickity-page-dots {
    display: none;
}

main.checkout button.flickity-button {
    padding: 0;
    min-width: inherit;
    color: #FFF;
    background: #000;
}

main.checkout button.flickity-button:hover {
    color: #FFF;
    background: #000;
}

main.checkout button.flickity-prev-next-button {
    width: 38px;
    height: 38px;

}

#continueshopping {
    display: inline-block;
}

#continueshopping>svg {
    vertical-align: text-top;
}

#txtPromo {
    width: calc(100% - 120px);
}

.guest-container .accordion-title {
    color: #a0a0a0;
}

.guest-container.is-active .accordion-title {
    color: #000;
}

#customerEmailEditContainer,
#customerShippingsContainer,
#customerBillingContainer {
    padding-left: 26px;
    color: #a0a0a0;
    /*    font-weight: bold;*/
    font-size: 14px;
}

/* Medium and up */
@media screen and (min-width: 40em) {
    main.checkout button {
        /*max-width: 300px;*/
    }
}

/* Large and up */
@media screen and (min-width: 64em) {

    main.checkout h1,
    main.checkout h2,
    main.checkout h3,
    .fcw-checkout-wrap .accordion-title {
        font-size: 30px;
    }

    main.checkout h3 {
        font-size: 22px;
    }

    .fcw-card-cvv {
        padding: 15px;
    }

    .fcw-service,
    .fcw-address,
    .fcw-shipped-to,
    .fcw-address-item,
    .fcw-saved-card {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
    }

    .fcw-card-item.flex-container>.flex-container {
        width: 100%;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }

    .fcw-card-item.flex-container>.flex-container>div:first-child {
        width: 60%;
    }

    .gift-card-group {
        padding: 20px;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }

    .rewards-image {
        display: block;
    }

    .fcw-order-summary {
        margin-top: 0;
    }

    /* Thank you page */
    .order-confirmation,
    .customer-info {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
    }

    .order-confirmation>div:last-child {
        text-align: right;
    }

    .checkout-promos {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
    }

    .checkout-promos>div {
        margin: 35px 15px 15px;
    }

    .fcw-shipping-premier-promo {
        margin-top: 20px;
    }

    .join-rewards>div .button {
        width: auto;
    }

    .fcw-checkout-wrap>section:last-of-type {
        padding-left: 0;
    }
}

/* added by stb */
.shippingdiscount {
    color: #298742 !important;
}

#shipping-loading div {
    justify-content: center;
    width: 100%;
    height: 44px;
    background: url("../img/animated/loading.b5e24db8f84e.gif") center center no-repeat;
}

#address-loading div {
    justify-content: center;
    width: 100%;
    height: 44px;
    background: url("../img/animated/loading.b5e24db8f84e.gif") center center no-repeat;
}

#card-loading div {
    justify-content: center;
    width: 100%;
    height: 44px;
    background: url("../img/animated/loading.b5e24db8f84e.gif") center center no-repeat;
}