* {
    font-family: "Roboto";
}

h1,
h2,
h3,
h4,
h5,
p {
    margin-bottom: 0px;
}

header {
    padding: 15px 0;
    border-bottom: 1px solid #ddd;
}

.top-2 {
    display: none !important;
}

.step-container {
    display: flex;
}

.step-container .step-icon-container {
    align-self: center;
    width: 70px;
}

.step-container .step-icon-container.first {
    margin-left: 41px;
}

.step-container .step-icon-container .step-icon {
    padding: 7px 10.5px;
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    color: rgba(0, 0, 0, 0.4);
    border-radius: 100%;
    font-size: 11px;
    font-weight: 500;
    height: 29px;
    position: relative;
}

.step-container .step-icon-container .step-icon.active {
    border: 1px solid #8ae7ba;
    color: #62d69e;
}

.step-container .step-icon-container .step-icon.finished::before {
    position: absolute;
    display: block;
    width: 29.27px;
    height: 30px;
    z-index: 2;
    top: -1px;
    background: url(/assets/frontend/img/new-cart/finished.svg) no-repeat center center, #8AE7BA;
    border-radius: 100%;
    content: "";
}

.step-container .step-icon-container .step-icon.finished::after {
    background: #62d69e;
}

.step-container .step-icon-container .step-icon::after {
    position: absolute;
    top: 13px;
    left: 100%;
    display: block;
    width: 41px;
    height: 1px;
    background: rgba(0, 0, 0, 0.1);
    content: "";
}

.step-container .step-icon-container:last-child .step-icon::after {
    display: none;
}

.whatsapp-container {
    display: flex;
}

.whatsapp-container span {
    font-size: 13px;
    font-weight: 500;
    color: #666;
    align-self: center;
}

.whatsapp-container a {
    color: #009d43;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    align-self: center;
    border-bottom: 1px solid #1cbe36;
}

.main-content {
    margin-top: 2rem;
    min-height: 77vh;
}

.register-container {
    max-width: 450px;
    padding: 0 15px;
    width: 100%;
}

.register-container .register-title {
    font-family: 'Barlow';
    font-style: normal;
    font-weight: 600;
    font-size: 23px;
    text-align: center;
    letter-spacing: 0.8px;
    color: #212121;
}

.form-container .form-group label {
    font-weight: 400;
    font-size: 14px;
    letter-spacing: 0.13132px;
    color: rgba(0, 0, 0, 0.54);
}

.form-container .form-group .form-control {
    border-radius: 8px;
    border: 1px solid rgba(0, 0, 0, 0.23);
    font-size: 1rem;
}

.form-container .form-check .form-check-label {
    font-size: 14px;
    color: #616161;
}

.form-container .form-check .form-check-label a {
    font-weight: 400;
    font-size: 13px;
    line-height: 21px;
    letter-spacing: 0.16px;
    text-decoration: none;
    color: #64899D;
}

.blue-btn {
    margin-top: 36px;
    background: #004186;
    border-radius: 40px;
    color: #fff;
    border: transparent;
    width: 100%;
    padding: 9px 0;
}

.blue-btn[disabled] {
    opacity: .65;
    cursor: not-allowed;
}

.resume-container {
    border: 1px solid #dddddd;
    padding: 25px 21px;
    max-width: 450px;
}

.resume-title {
    font-family: "Barlow";
    font-weight: 500;
    font-size: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #e0e0e0;
    text-transform: uppercase;
    color: #4d4d4d;
}

.resume-content {
    margin-top: 15px;
}

.resume-content .course-title {
    font-family: "Barlow";
    font-weight: 700;
    font-size: 18px;
    line-height: 20px;
    letter-spacing: 0.6px;
    color: #000000;
}

.resume-content .course-price {
    font-weight: 400;
    font-size: 14px;
    text-align: right;
    letter-spacing: 0.4px;
    color: #616161;
    display: flex;
}

.resume-content .course-type {
    margin-top: 10px;
    font-weight: 400;
    font-size: 13px;
    letter-spacing: 0.2px;
    color: #616161;
    padding-bottom: 25px;
    border-bottom: 1px solid #e0e0e0;
}

.resume-price {
    display: flex;
    margin-top: 25px;
}

.resume-price .total {
    font-weight: 700;
    font-size: 15px;
    color: #212121;
}

.resume-price .price {
    margin-left: auto;
    font-weight: 700;
    font-size: 15px;
    color: #212121;
    text-align: end;
}

.resume-price .price span {
    color: #616161;
    font-size: 13px;
    font-weight: 400;
}

.coupon-container, .wallet-container {
    margin-top: 34px;
    max-width: 450px;
}

.coupon-container .coupon-title, .wallet-container .wallet-title {
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.13132px;
    color: rgba(0, 0, 0, 0.92);
    margin-bottom: 25px;
}

.coupon-container .coupon-placeholder, .wallet-container .wallet-placeholder {
    font-weight: 400;
    font-size: 16px;
    letter-spacing: 0.13132px;
    color: rgba(0, 0, 0, 0.54);
    margin-bottom: 8px;
}

.input-container-coupon, .input-container-wallet {
    position: relative;
    width: 100%;
}

.input-container-coupon .btn, .input-container-wallet .btn {
    position: absolute;
    right: 7px;
    top: 7px;
}

.input-container {
    display: flex;
}

.input-container .coupon-input, .input-container .wallet-input {
    border: 1px solid #DDDDDD;
    height: 100%;
    width: 100%;
    padding: 0px 10px;
    font-size: 22px;
    text-transform: uppercase;
}

.input-container .coupon-button, .input-container .wallet-button {
    background: #FFFFFF;
    border: 1px solid #004186;
    font-weight: 500;
    font-size: 20px;
    line-height: 14px;
    letter-spacing: 0.13132px;
    color: #004186;
    padding: 19px 27px;
    margin-left: 15px;
    display: flex;
}

.input-container .coupon-button:disabled, .input-container .wallet-button:disabled {
    cursor: not-allowed;
    background: #004186;
    color: #fff;
}

.input-container .coupon-button:hover, .input-container .wallet-button:hover {
    background: #004186;
    color: #fff;
}

.certificate-container {
    display: flex;
    justify-content: center;
    max-width: 450px;
    margin-top: 50px;
}


.address-container {
    max-width: 530px;
    padding: 0 15px;
    width: 100%;
    margin-bottom: 100px;
}

.address-container .register-title {
    font-family: 'Barlow';
    font-style: normal;
    font-weight: 600;
    font-size: 23px;
    text-align: center;
    letter-spacing: 0.8px;
    color: #212121;
}


.address-btn {
    border-radius: 8px;
    margin-top: 15px;
    font-family: 'Barlow';
    font-weight: 400;
    font-size: 16px;
}

.checkout-container {
    padding: 15px;
    margin-bottom: 110px;
}

.checkout-container .register-title {
    font-family: 'Barlow';
    font-style: normal;
    font-weight: 600;
    font-size: 23px;
    letter-spacing: 0.8px;
    color: #212121;
}

.payment-method-title {
    font-family: "Barlow";
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
    color: #9c9c9c;
}

.payment-method-container {
    display: flex;
    background: #eee;
    border-radius: 8px;
    border: 1px solid #ddd;
}

.btn-payment-method {
    display: flex;
    flex-wrap: wrap;
    color: #212121;
    width: 100%;
    justify-content: center;
    cursor: pointer;
    padding: 15px;
    border-radius: 8px;
}

.btn-payment-method .payment-method-img {
    font-size: 20px;
    display: flex;
    flex-wrap: wrap;
    margin-right: 0.5rem;
}

.btn-payment-method h2 {
    font-size: 14px;
    line-height: 1;
}

.btn-payment-method h2 span {
    font-size: 11px;
}

.btn-payment-method.active {
    background: #004186;
}

.btn-payment-method.active h2,
.btn-payment-method.active h2 span,
.btn-payment-method.active .payment-method-img {
    color: #fff;
}

.mobile-resume {
    width: 100%;
    position: fixed;
    bottom: 0;
    border-top: 1px solid #ddd;
    background: #f7f7f7;
    padding: 10px 15px;
}

.mobile-resume .mobile-resume-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    color: #666;
    margin-bottom: 10px;
    cursor: pointer;
}

.mobile-resume .mobile-resume-title i {
    color: #004186;
}

.mobile-resume .mobile-resume-content h5 {
    font-size: 13px;
    font-weight: 400;
    text-transform: uppercase;
    color: #666;
}

.mobile-resume .mobile-resume-content span {
    font-size: 12px;
    font-weight: 400;
    text-transform: uppercase;
    color: #666;
}

.mobile-resume .mobile-resume-content-full .title-container {
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    padding-top: 10px;
    padding-bottom: 20px;
}

.mobile-resume .mobile-resume-content-full .title-container h5 {
    font-weight: 700;
}

.mobile-resume .mobile-resume-content-full .title-container span {
    font-size: 14px;
    color: #666;
}

.mobile-resume .mobile-resume-content-full .price-container {
    display: flex;
    padding: 15px 0;
    border-bottom: 1px solid #ddd;
}

.mobile-resume .mobile-resume-content-full .price-container span {
    font-size: 16px;
    color: #212529;
    font-weight: 700;
}

.mobile-resume .mobile-resume-content-full .coupon-container {
    max-width: none;
    margin-top: 15px;
}

.mobile-resume .mobile-resume-content-full .coupon-container .coupon-title {
    font-size: 16px;
    margin-bottom: 5px;
}


.no-highlight {
    opacity: .4;
}

footer {
    border-top: 1px solid #ddd;
    padding: 35px 0;
    display: flex;
    justify-content: center;
    margin-top: 46px;
}

footer .footer-text {
    font-weight: 400;
    font-size: 10px;
    color: #666666;
    align-self: center;
}


@media (max-width:991px) {
    header {
        border: 0px;
    }

    .main-content {
        margin-top: 0px;
        min-height: 83vh;
    }

    .register-container,
    .address-container {
        max-width: none;
    }

    .register-container .blue-btn {
        border-radius: 8px;
    }
}

@media (max-width:768px) {
    .btn-payment-method {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        padding: 10px;
    }

    .btn-payment-method h2 {
        font-size: 11px;
    }

    .btn-payment-method h2 span {
        font-size: 9px;
    }

    .btn-payment-method .payment-method-img {
        margin: 0;
    }
}

@media (max-width:575px) {
    .main-content {
        margin-top: 0px;
        min-height: 100vh;
    }

}