html {
    padding-bottom: 0 !important
}

body {
    display: flex;
    flex-direction: column
}

#MainContent {
    flex-grow: 1
}

.fec-challenge__container {
    padding: 48px 16px
}

.fec-challenge__container .fec-challenge__button {
    padding: .75rem 3rem;
    margin: 2rem auto;
    border-radius: .375rem;
    background-color: #000;
    cursor: pointer;
    background-image: none;
    color: #fff;
    transition: all var(--f-duration-default, 0.25s)
}

.fec-challenge__button:hover {
    background-color: #737373
}

.f-customer-forms {
    padding-bottom: 80px
}

@media screen and (max-width: 767px) {
    .f-customer-forms {
        padding-bottom: 60px
    }
}

@media screen and (min-width: 768px) {
    .f-customer-forms > .container {
        display: flex
    }
}

.f-customer-forms .f-login-form, .f-customer-forms .f-recover-form, .f-customer-forms .f-sign-up {
    width: 100%
}

@media screen and (min-width: 768px) {
    .f-customer-forms .f-login-form, .f-customer-forms .f-recover-form, .f-customer-forms .f-sign-up {
        width: 50%;
        margin-left: 40px;
        margin-right: 40px
    }
}

.f-customer-forms .f-recover-form {
    display: none
}

@media screen and (max-width: 767px) {
    .f-customer-forms .f-sign-up {
        margin-top: 40px
    }
}

.f-customer-forms .f-sign-up p {
    margin-bottom: 24px
}

.f-customer-forms h3 {
    font-size: 24px;
    line-height: 1.3333;
    font-weight: 500;
    margin-bottom: 24px
}

.f-customer-forms p {
    color: rgb(var(--color-foreground-secondary));
    margin-top: 0;
    margin-bottom: 16px
}

.f-customer-forms .f-reset-password-btn {
    text-decoration-line: underline;
    margin-top: 20px;
    margin-bottom: 30px;
    display: block
}

.f-customer-forms .f-recover-form__action {
    display: flex;
    gap: 16px;
    margin-top: 20px
}

.f-customer-forms .f-customer__recover-form-posted {
    font-size: calc(var(--font-base-size, 16) * 1px);
    margin-top: 20px;
    margin-bottom: 10px
}

.f-customer-forms.show-recover-password-form .f-login-form {
    display: none
}

.f-customer-forms.show-recover-password-form .f-recover-form {
    display: block
}

#recover:target {
    display: block
}

#recover:target ~ .f-login-form {
    display: none
}

.f-register-form {
    padding-bottom: 80px
}

@media screen and (max-width: 767px) {
    .f-register-form {
        padding-bottom: 60px
    }
}

.f-register-form__wrapper {
    width: 500px;
    max-width: 100%;
    margin: auto;
    padding-left: 15px;
    padding-right: 15px
}

.f-register-form h1 {
    font-size: 24px;
    line-height: 1.3333;
    font-weight: 500;
    margin-bottom: 24px
}

.f-register-form__description {
    color: rgb(var(--color-foreground-secondary));
    margin-top: 20px
}

.f-register-form button {
    margin-top: 24px;
    margin-bottom: 12px
}

.f-reset-password-form {
    padding-bottom: 80px
}

@media screen and (max-width: 767px) {
    .f-reset-password-form {
        padding-bottom: 60px
    }
}

.f-reset-password-form__wrapper {
    width: 500px;
    max-width: 100%;
    margin: auto;
    padding-left: 15px;
    padding-right: 15px
}

.f-reset-password-form h1 {
    font-size: 24px;
    line-height: 1.3333;
    font-weight: 500
}

.f-reset-password-form p {
    margin-top: 16px;
    margin-bottom: 32px
}

.f-reset-password-form button {
    width: 100%;
    margin-top: 16px
}

.f-customer-order-detail {
    padding-bottom: 80px
}

@media screen and (max-width: 767px) {
    .f-customer-order-detail {
        padding-bottom: 60px
    }
}

.f-customer-order-detail .f-row {
    display: flex;
    flex-wrap: wrap;
    margin-left: -15px;
    margin-right: -15px
}

.f-customer-order-detail .f-row > div {
    padding-left: 15px;
    padding-right: 15px
}

.f-customer-order-detail table {
    table-layout: auto;
    border-collapse: collapse
}

@media screen and (min-width: 768px) {
    .f-customer-order-detail table {
        border: 1px solid var(--color-border, #dedede)
    }
}

.f-customer-order-detail table th, .f-customer-order-detail table td {
    padding: 16px;
    border: 1px solid var(--color-border, #dedede)
}

@media screen and (max-width: 767px) {
    .f-customer-order-detail table th, .f-customer-order-detail table td {
        padding: 10px 0;
        border: 0
    }
}

.f-customer-order-detail table th {
    text-align: left
}

.f-customer-order-detail table tfoot tr td:first-child {
    display: none
}

@media screen and (min-width: 768px) {
    .f-customer-order-detail table tfoot tr td:first-child {
        display: table-cell
    }
}

.f-customer-order-detail .f-order-discount {
    margin-top: 8px
}

.f-customer-order-detail .f-order-note {
    margin-top: 5px
}

.f-customer-order-detail__header {
    margin-bottom: 20px
}

.f-customer-order-detail__header h2 {
    font-size: 24px;
    line-height: 1.333
}

@media screen and (max-width: 1023px) {
    .f-customer-order-detail__address {
        margin-top: 40px
    }
}

.f-customer-order-detail__address > div {
    color: rgb(var(--color-foreground-secondary))
}

.f-customer-order-detail__address > div + div {
    padding-top: 24px
}

.f-customer-order-detail__address h3 {
    font-size: 24px;
    line-height: 1.666;
    padding-bottom: 8px
}

.f-activate-account {
    padding-top: 30px;
    padding-bottom: 80px
}

@media screen and (max-width: 767px) {
    .f-activate-account {
        padding-bottom: 60px
    }
}

.f-activate-account__heading {
    font-size: 24px;
    line-height: 1.333;
    margin-bottom: 20px
}

.f-activate-account__action {
    margin-top: 30px
}

.f-activate-account__action .f-button {
    cursor: pointer
}

.f-activate-account__action .f-button + .f-button {
    margin-left: 10px
}

.f-account {
    padding-bottom: 80px
}

@media screen and (max-width: 767px) {
    .f-account {
        padding-bottom: 60px
    }
}

.f-account > .container-fluid {
    display: flex;
    flex-wrap: wrap
}

.f-account__title {
    font-size: 24px;
    line-height: 1.333;
    font-weight: 500;
    margin-bottom: 30px
}

.f-account__title--medium {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 0;
    padding-bottom: 12px
}

.f-account__greeting {
    margin-bottom: 40px
}

.f-account__greeting span {
    font-weight: 600
}

.f-account__detail a {
    margin-top: 24px
}

.f-account__navigation {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 16.6667%;
    min-width: 200px;
    padding-right: 15px;
    border-right: 1px solid var(--color-border, #dedede)
}

.f-account__navigation a {
    color: rgb(var(--color-foreground-secondary));
    font-weight: 500;
    transition: all var(--f-duration-default, 0.25s) ease
}

.f-account__navigation a:hover, .f-account__navigation a.active {
    color: rgb(var(--color-foreground))
}

@media screen and (max-width: 767px) {
    .f-account__navigation {
        flex-direction: row;
        gap: 30px;
        width: 100%;
        overflow-x: scroll;
        padding-right: 0;
        margin-bottom: 40px;
        border-right: 0;
        border-bottom: 1px solid var(--color-border, #dedede)
    }

    .f-account__navigation::-webkit-scrollbar {
        display: none
    }

    .f-account__navigation a {
        flex-shrink: 0;
        padding-bottom: 20px
    }
}

.f-account__content {
    flex: 1 1 0%;
    padding-left: 100px;
    padding-bottom: 60px
}

@media screen and (max-width: 1279px) {
    .f-account__content {
        padding-left: 60px;
        padding-bottom: 40px
    }
}

@media screen and (max-width: 1023px) {
    .f-account__content {
        padding-left: 30px
    }
}

@media screen and (max-width: 767px) {
    .f-account__content {
        padding-left: 0;
        padding-bottom: 0
    }
}

.f-account .f-customer-order {
    margin-bottom: 60px
}

.f-account .f-customer-order table tr {
    padding-top: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color-border, #dedede)
}

.f-account .f-customer-order table th {
    font-weight: 500
}

.f-account .f-customer-order .notification a {
    font-weight: 600;
    margin-left: 8px;
    margin-right: 8px;
    text-decoration-line: underline
}

.f-account .f-customer-order .f-pagination {
    margin-top: 16px
}

.f-account .f-customer-info__field {
    display: flex;
    padding-top: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color-border, #dedede)
}

.f-account .f-customer-info__field > div:last-child {
    color: rgb(var(--color-foreground-secondary))
}

.f-account .f-customer-address {
    margin-top: 40px
}

@media screen and (max-width: 1279px) {
    .f-account .f-customer-address {
        margin-top: 30px
    }
}

@media screen and (max-width: 767px) {
    .f-account .f-customer-address {
        margin-top: 20px
    }
}

.f-account .f-customer__form-new-wrapper {
    margin-top: 0px
}

.f-account .f-customer__action {
    display: flex;
    margin-top: 24px
}

.f-account .f-customer__edit-btn {
    margin-right: 20px
}

.f-account .f-customer__form-delete {
    display: flex
}

.f-account .f-customer__cancel-edit-btn, .f-account .f-customer__cancel-add-btn {
    margin-left: 20px
}

.f-account .f-customer__cookies-consent {
    margin-top: 12px
}

.f-account .f-customer__cookies-consent label {
    cursor: pointer
}

.f-account .f-customer__cookies-consent span {
    margin-left: 8px
}

.f-account .f-pagination {
    margin-top: 60px
}

@media screen and (max-width: 767px) {
    .f-account .f-pagination {
        margin-top: 40px
    }
}
