#product {
    padding: 34px 0 22px;
    border-bottom: 1px solid #D5D5D5;
}

.product-left {
    max-width: 43.3%;
    margin-right: 52px;
    padding-right: 0;
    flex-basis: 554px;
    flex-grow: 0;
    flex-shrink: 1;
}


.product-left .swiper-slide {
    display: flex;
    height: auto;
}

.product-right {
    flex-shrink: 1;
    flex-basis: 631px;
    flex-grow: 0;
}

.product-right>h1.product-title {
    width: auto;
    font-size: 32px;
    line-height: normal;
}

.product-right .brand {
    margin-bottom: 6px;
}

.product-terms {
    margin-top: 20px;
    font-size: 16px;
    line-height: 28px;
}

.product-disclaimer {
    padding: 0;
}

.product-disclaimer p {
    font-size: 16px;
    line-height: 24px;
    max-width: 478px;
    margin: 0;
}

.pd-price {
    font-size: 61px;
    line-height: 1;
}

.pd-price sup {
    top: -.4em;
    font-size: 60%;
}

.pd-price .flex-column sup {
    top: 0.1em;
}

.pd-price .period {
    font-size: 22.95082%;
    margin: 0 0 0 2px;
}

.price-wrap .or {
    font-size: 38px;
    line-height: 1;
    margin: 10px 33px 0 35px;
}
.product-buttons button {
    padding: 0;
    margin-top: 7px;
    margin-right: 20px;
    height: 39px;
    width: 191px;
    border-radius: 20px;
    font-size: 20px;
    margin-bottom: 0;
}

.product-buttons .button-round-invert {
    margin-right: 0;
    border-width: 2px;
}

.product-services {
    padding-top: 45px;
}

.product-services p {
    font-size: 18px;
    line-height: 1;
    margin-top: 0;
}

.product-services .desc {
    font-size: 24px;
    line-height: 1em;
    margin-bottom: 22px;
}

.product-services .image {
    margin-right: 5px;
}

.product-services .product-service {
    margin-bottom: 22px;
    padding: 0;
}

#product-details {
    border-top: 1px solid #D0D0D0;
    margin-top: 12px;
    padding: 0px;
}

.accordionjs .acc_section>.acc_head {
    background: transparent !important;
    border: none !important;
    font-size: 24px;
    padding: 10px 0 0 0;
}

.accordionjs .acc_section>.acc_head::after {
    content: '';
    position: absolute;
    top: 23px;
    right: 0;
    height: 12px;
    width: 17px;
    background-image: url('../../images/icons/icon-accord.png');
    background-size: auto;
    background-position: center;
    background-repeat: no-repeat;
}

.accordionjs .acc_section.acc_active>.acc_head::after {
    transform: scaleY(-1);
}

.accordionjs .acc_section:last-of-type,
.accordionjs .acc_section:last-of-type .acc_content {
    border: none !important;
    padding-bottom: 0;
}

.accordionjs .acc_section>.acc_content {
    font-size: 16px;
    line-height: 24px;
    padding: 21px 0 0 0;
    max-width: 554px;
}

.checkout-step {
    background-color: #F5F5F5;
    background-image: url('../../../images/2025/product/checkout-step-bg.png');
    background-image: image-set(url('../../../images/2025/product/checkout-step-bg.png') 1x, url('../../../images/2025/product/checkout-step-bg@2x.png') 2x);
    background-size: auto;
    background-position: top center;
    background-repeat: no-repeat;
    border-radius: 3px;
    padding: 0 15px 37px 15px;
    margin-bottom: 47px;
    padding-top: 21px;
}

.checkout-step .congrats {
    margin-bottom: 3px;
}

.checkout-step .form-title {
    margin-bottom: 6px;
    font-size: 24px;
}

.checkout-step .special {
    font-size: 18px;
    margin-bottom: 55px;
}

.checkout-step .close {
    top: 10px;
    right: 18px;
    font-size: 16px;
}

.step-payment .form-row {
}

.step-payment .img {
    margin-bottom: 9px;
    margin-top: 16px;
}

.step-payment .today {
    font-size: 32px;
    line-height: 1;
    margin-top: 24px;
}

#product .step-payment .form-field {
    padding: 10px 6px;
}
#product .step-payment .form-field.cvv,
#product .step-payment .form-field.exp {
    flex-basis: 100px;
    flex-grow: 0;
}

.step-payment .button-round-invert {
    line-height: 37px;
    width: 243px;
    height: 39px;
    border-radius: 20px;
    margin-top: 23px;
    font-size: 1.25em;
}

#product form{
    width: 100%;
    --gray: #D8D8D8;
}

#product form > div {
    width: 488px;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}
#product form > div.form-action {
    width: 100%;
}
#product .form-field {
    padding: 9px;
    flex-basis: 50%;
    flex-grow: 1;
    margin: 0;
}
#product .form-field label {
    left: 16px;
    font-size: 1.125em;
    margin-bottom: 0;
    line-height: 1;
    margin-top: 0.3em;
    transition: all 0.3s;
}
#product .form-field .textarea_box label {
    margin-top: 16px;
}
#product .form-field input,
#product .form-field textarea,
#product .form-field select{
    font-size: 1.125em;
    height: 56px;
    background-color: #fff;
    width: 100%;
    text-indent: 16px;
    padding-top: 18px;
    border-radius: 12px;
}
#product .form-field select{
    background-image: none;
}
#product .form-field textarea {
    height: 126px;
    padding-top: 16px;
    resize: none;
}
#product .form-field .select_box:after{
    content: '';
    display: block;
    width: 17px;
    height: 10px;
    position: absolute;
    right: 15px;
    background-repeat: no-repeat;
    background-position: center;
	background-image: url(../../../images/2025/contact/down-arrow.png);
	background-image: -webkit-image-set(url("../../../images/2025/contact/down-arrow.png") 1x, url("../../../images/2025/contact/down-arrow@2x.png") 2x);
    background-size: cover;
    pointer-events: none;
}
@-moz-document url-prefix() {
    #product .form-field select {
       text-indent: 8px;
    }
}
#product .form-field select.selected,
#product .form-field input{
    color: var(--black);
}
#product .form-field select,
#product .form-field ::placeholder{
    opacity: 1;
    color: #262626;
}
#product .form-field input:-internal-autofill-selected,
#product .form-field input:-webkit-autofill,
#product .form-field input:-webkit-autofill:focus {
    background-color: #fff !important;
    transition: background-color 0s 600000s, color 0s 600000s !important;
}
#product .form-action [type="submit"] {
	width: 243px;
	height: 39px;
	border-radius: 20px;
	margin-top: 23px;
	font-size: 1.25em;
}
#product .form-action [type="submit"].button[disabled]{
    opacity: 0.8;
    cursor: not-allowed;
}

#product .form-field .select_box.focused:after {
    transform: scaleY(-1);
}
#product .form-field .focused label,
#product .form-field .has-value label {
    font-size: 0.84375em;
    margin-top: calc(-2.9em + 24px);
    color: var(--focus-color);
}
#product .form-field .textarea_box.focused label, 
#product .form-field .textarea_box.has-value label {
    margin-top: 8px;
}
#product .form-field .focused select,
#product .form-field .focused textarea,
#product .form-field .focused input{
    border-color: var(--focus-border);
    border-width: 2px;
}
#product .form-field .validation-error:before,
#product .form-field .incomplete-mask:before {
    content: '';
    display: block;
    width: 23px;
    height: 23px;
    position: absolute;
    z-index: 2;
    right: 16px;
    background-repeat: no-repeat;
    background-position: center;
	background-image: url(../../../../images/error.png);
	background-image: -webkit-image-set(url("../../../../images/error.png") 1x, url("../../../../images/error@2x.png") 2x);
    background-size: cover;
    pointer-events: none;
}

#product .form-field .validation-error select,
#product .form-field .validation-error textarea,
#product .form-field .validation-error input,
#product .form-field .incomplete-mask input{
    border-color: var(--error-border);
    border-width: 2px;
}
#product .form-field .validation-error label,
#product .form-field .incomplete-mask label{
    color: var(--error-color);
}
#product .form-field .form-field-error {
    bottom: -1.5em;
    left: 2em;
    font-size: 0.5em;
}
.container.promo-wrapper {
    margin-bottom: 39px;
}
.step-payment .form-action p {
    font-size: 24px;
    padding-top: 45px;
    border-top: 1px solid var(--gray);
    width: calc(100% + 30px);
    margin: 40px -15px 0;
}
@media screen and (max-width: 1099px) {

    .step-payment .form-action {
        flex-direction: column;
        gap: 0;
    }
}
@media screen and (max-width: 991px) {
    #product form {
        width: auto;
        max-width: 100%;
    }

    .product-buttons button {
        font-size: 16px;
        width: 155px;
        height: 32px;
        margin-right: 17px;
    }
    .step-payment .form-row {
        flex-wrap: wrap;
    }
    #product .step-payment .form-field.c-number {
        flex-basis: 100%;
    }
    #product .step-payment .form-field.cvv, 
    #product .step-payment .form-field.exp {
        flex-basis: 50%;
    }
}

@media screen and (max-width: 767px) {
    #product {
        padding-top: 18px;
        border-bottom: none;
    }

    .product-left {
        margin-right: 0;
        padding-right: 0;
        max-width: 100%;
    }

    .product-image {
        width: 100vw;
        margin-left: -15px;
    }

    .product-image>img {
        width: 100vw;
    }

    .product-right {
        display: block;
    }

    .product-right>h1.product-title {
        width: 100%;
        line-height: 38px;
        display: block !important;
        margin: 0 0 3px;
    }

    .product-right .brand {
        font-size: 16px;
        line-height: 26px;
        display: block !important;
        margin-bottom: 24px;
    }

    .checkout-step {
        margin: 18px -15px 0;
        max-width: calc(100% + 30px);
        background-size: 100%;
        background-position: 50% 0;
        padding: 8px 15px 42px;
    }

    .checkout-step .congrats {
        width: 151px;
    }

    .checkout-step .form-title {
        font-size: 19px;
    }

    .button-round {
        padding: 0 33px;
    }

    .checkout-step .special {
        font-size: 16px;
        margin-bottom: 12.5vw;
    }

    .checkout-step form {
        margin-top: 22px;
    }

    .checkout-step .close {
        top: 7px;
        right: 16px;
        font-size: 18px;
    }

    .product-right h1.product-title {
        font-size: 32px;
        line-height: 38px;
    }

    .product-image>a {
        display: none;
    }

    .price-wrap {
        justify-content: center;
        margin-top: 22px;
    }

    .pd-price {
        font-size: 43px;
    }

    .price-wrap .or {
        font-size: 44px;
        margin: 0 23px 0 28px;
        color: var(--black);
    }

    .pd-price sup {
        top: -16px;
    }

    .pd-price .flex-column sup {
        top: 1px;
    }

    .pd-price .period {
        font-size: 9px;
    }

    .product-buttons {
        justify-content: center;
    }

    .product-buttons br {
        display: none;
    }

    .product-buttons .button-round-invert,
    .product-buttons button {
        margin-top: 9px;
    }

    .product-services {
        padding-top: 38px;
    }

    .product-services .product-service {
        width: 100%;
        margin-bottom: 0;
    }

    .product-services .desc {
        margin-bottom: 0;
    }

    #product-details {
        margin-top: 29px;
    }

    .accordionjs .acc_section>.acc_head::after {
        top: 21px;
        width: 41px;
    }

    .accordionjs .acc_section>.acc_content {
        padding: 27px 0 0 0;
    }

    .product-right .details {
        border-top: 1px solid #D0D0D0;
    }

    .product-terms {
        margin: 16px 0 26px 0;
        border-bottom: 1px solid #D0D0D0;
        padding-bottom: 23px;
    }

    #product-details .product-terms p {
        font-size: 16px;
        line-height: 28px;
    }

    #product-details .product-disclaimer {
        border-bottom: 1px solid #D0D0D0;
        padding-bottom: 26px;
    }

    #product-details .product-disclaimer p {
        font-size: 14px;
        line-height: 24px;
    }

    .step-payment form {
        margin-top: 4px;
    }

    .step-payment .form-row {
    }
    #product .step-payment .form-field {
        padding: 6px 10px;
    }

    .step-payment .today {
        font-size: 20px;
        margin-top: 19px;
    }

    .step-payment .img {
        padding-bottom: 14px;
    }

    .step-payment .img img {
        max-width: 197px;
    }
    #trending {
        margin-top: 17px;
    }
    .container.promo-wrapper {
        margin-top: 39px !important;
        margin-bottom: 39px;
    }
    .bc-inner {
        padding-top: 8px;
    }
    #product .form-field {
        padding: 6px 17px;
    }
}
@media screen and (max-width: 567px) {
    .step-payment .form-action p {
        padding-top: 45px;
        border-top: 1px solid var(--gray);
        width: calc(100% + 30px);
        margin: 51px -15px 0;
        font-size: 16px;
    }
    .step-payment .button-round-invert {
        margin-top: 15px;
    }
}