@font-face {
    font-family: "SFProBold";
    src: url("../css/fonts/SFPRODISPLAYBOLD.OTF") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}


@font-face {
    font-family: "SFPro";
    src: url("../css/fonts/SFPRODISPLAYREGULAR.OTF") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

.body-wrap {
    background: radial-gradient(50% 50% at 50% 50%, #97E6FF 0%, rgba(151, 230, 255, 0.85) 100%);
    text-align: center;
}

.top_area_content {
    padding: 50px 0;
}

h1 {
    font-weight: 700;
    font-size: 30px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    text-transform: capitalize;
    color: #000;
    font-family: "SFProBold";
    margin-bottom: 20px;
}

.top_area_content>div {
    background: #0000001A;
    display: inline-flex;
    padding: 10px 20px;
    border-radius: 50px;
    gap: 10px;
}

.teeth_area h3 {
    font-family: "SFPro";
    font-weight: 400;
    font-size: 15px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: uppercase;
    text-align: left;
    color: #00000040;
}

.teeth_area {
    max-width: 880px;
    margin: 0 auto;
}

.upper_teeth {
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.upper_teeth img {
    position: relative;
    z-index: 999;
}


/* upper teeth positioning */
.teeth1 {
    margin-right: -22px;
    /* margin-top: -5px; */
    z-index: 1;
}

.teeth2 {
    margin-right: -18px;
    margin-top: 5px;
    z-index: 2;
}

.teeth3 {
    margin-right: -13px;
    margin-top: 3px;
    z-index: 3;
}

.teeth4 {
    margin-right: -7px;
    margin-top: -5px;
    z-index: 4;
}

.teeth5 {
    margin-right: -7px;
    margin-top: -6px;
    z-index: 5;
}

.teeth6 {
    margin-right: -7px;
    margin-top: -5px;
    z-index: 6;
}

.teeth7 {
    margin-right: 0px;
    margin-top: -5px;
    z-index: 7;
}

.teeth8 {
    margin-right: 0px;
    margin-top: -5px;
    z-index: 7;
}

.teeth9 {
    margin-left: -5px;
    margin-top: -5px;
    z-index: 6;
}

.teeth10 {
    margin-left: -7px;
    margin-top: -6px;
    z-index: 5;
}

.teeth11 {
    margin-left: -7px;
    margin-top: -6px;
    z-index: 4;
}

.teeth12 {
    margin-left: -9px;
    margin-top: -2px;
    z-index: 3;
}

.teeth13 {
    margin-left: -12px;
    margin-top: -3px;
    z-index: 2;
}

.teeth14 {
    margin-left: -14px;
    margin-top: -3px;
    z-index: 1;
}

/* upper teeth posiitoining */

.lower_teeth {
    display: flex;
    align-items: flex-start;
    justify-content: center;
}


.lower_teeth img {
    position: relative;
    z-index: 999;
}

.upper_teeth div>span,
.lower_teeth div>span {
    display: none;
    position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 99999;
    top: 50%;
    color: #777777;
    font-size: 25px;
}

.all_teeth div>* {
    cursor: pointer;
    position: relative;
}

.all_teeth .active span {
    display: block;
}

/* .all_teeth .active:after {
    content: '';
    position: absolute;
    width: 100px;
    height: 200px;
    border: 2px solid #FF0000;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 200px;
    z-index: 999999999999999999999;
} */

@keyframes zoomPulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.2);
    }

    100% {
        transform: scale(1);
    }
}

.active-wave {
    animation: zoomPulse 2s infinite ease-in-out;
    z-index: 999999 !important;
}

.active.active-wave:after {
    content: '';
    position: absolute;
    width: 100px;
    height: 200px;
    background-image: url(../images/highlight_icon.svg);
    background-size: 100px 200px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 9999;
}

/* lower teeth positioning */
.b_teeth1 {
    margin-right: -22px;
    /* margin-top: -5px; */
    z-index: 1;
}

.b_teeth2 {
    margin-right: -18px;
    margin-top: -5px;
    z-index: 2;
}

.b_teeth3 {
    margin-right: -13px;
    margin-top: -3px;
    z-index: 3;
}

.b_teeth4 {
    margin-right: -7px;
    margin-top: 5px;
    z-index: 4;
}

.b_teeth5 {
    margin-right: -7px;
    margin-top: 6px;
    z-index: 5;
}

.b_teeth6 {
    margin-right: -7px;
    margin-top: 5px;
    z-index: 6;
}

.b_teeth7 {
    margin-right: 0px;
    margin-top: 5px;
    z-index: 7;
}

.b_teeth8 {
    margin-right: 0px;
    margin-top: 5px;
    z-index: 7;
}

.b_teeth9 {
    margin-left: -5px;
    margin-top: 5px;
    z-index: 6;
}

.b_teeth10 {
    margin-left: -7px;
    margin-top: 6px;
    z-index: 5;
}

.b_teeth11 {
    margin-left: -7px;
    margin-top: 6px;
    z-index: 4;
}

.b_teeth12 {
    margin-left: -9px;
    margin-top: 2px;
    z-index: 3;
}

.b_teeth13 {
    margin-left: -12px;
    margin-top: 3px;
    z-index: 2;
}

.b_teeth14 {
    margin-left: -14px;
    margin-top: 3px;
    z-index: 1;
}

/* lower teeth posiitoining */
.logo_teeth {
    padding: 70px 0 25px;
}

.col.col-lg-cust-3.col-1 {
    background: #fff;
}

.sidebar {
    padding: 20px;
    text-align: left;
}

.sidebar h3 {
    font-weight: 700;
    font-size: 30px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: capitalize;
    color: #000;
    margin-bottom: 96px;
}

.sidebar h3 span {
    font-weight: 400;
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: capitalize;
    color: #777777;
    display: block;
}

.menu_wrap label {
    font-weight: 500;
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: capitalize;
    color: #000;
    display: block;
}

.menu_wrap select {
    font-weight: 500;
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: capitalize;
    color: #000;
    display: block;
    width: 100%;
    border-radius: 5px;
    padding: 10px;
    margin: 10px 0;
}

.radio_menu_col_3 {
    display: flex;
    gap: 13px;
    margin-bottom: 10px;
}

.radio_menu_col_3>* {
    text-align: center;
    position: relative;
    padding: 0;
}

.radio_menu_col_3 label.form-check-label {
    border: 1px solid #0000001A;
    width: 100%;
    border-radius: 5px;
    padding: 10px;
}

.radio_menu_col_3>* input {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 9;
    margin: 0 !important;
}

.radio_menu_col_3>* input:checked+label.form-check-label {
    background: #0000001A;
}

.radio_menu_col_3>* img {
    margin-bottom: 10px;
}

.radio_menu_col_mix {
    display: flex;
    gap: 13px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.radio_menu_col_mix .form-check {
    padding: 0;
    margin: 0;
    position: relative;
}

.radio_menu_col_mix.radio_menu_col_2 .form-check {
    width: calc(50% - 6.5px);
}

.radio_menu_col_mix.radio_menu_col_1 .form-check {
    width: 100%;
}

.radio_menu_col_mix.radio_menu_col_2_5 .form-check:nth-child(1) {
    width: calc(65% - 6.5px);
}

.radio_menu_col_mix.radio_menu_col_2_5 .form-check:nth-child(2) {
    width: calc(35% - 6.5px);
}

.radio_menu_col_mix label.form-check-label {
    border: 1px solid #0000001A;
    width: 100%;
    border-radius: 5px;
    padding: 10px;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
}

.radio_menu_col_mix>* input {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 9;
    margin: 0 !important;
}

.radio_menu_col_mix>* input:checked+label.form-check-label {
    background: #0000001A;
}

.filter_action_wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.btn.btn_reset {
    background: #000000;
    border-radius: 10px;
    padding: 10px;
    width: 40px;
    height: 40px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    transition: 0.3s;
}

.btn.btn_reset:hover {
    opacity: 0.8;
}

.btn.btn_apply {
    font-weight: 700;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: capitalize;
    color: #000;
    border: 2px solid #000;
    width: calc(100% - 50px);
    background: #97E6FF;
    padding: 10px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    text-decoration: none;
    transition: 0.3s;
}

.btn_apply:hover {
    background: #fff;
    color: #000;
}

.carts_wrap {
    background: #000000;
    margin: 20px 0;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px;
    min-height: 240px;
    text-align: center;
}

.carts_wrap img {
    margin-bottom: 20px;
}

.carts_wrap h5 {
    font-weight: 500;
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    text-transform: capitalize;
    color: #FFFFFF80;
}

.carts_wrap h5 span {
    color: #FFFFFFCC;
}

.pricing_details {
    width: 100%;
}

.pricing_head,
.pricing_body,
.pricing_footer {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.pricing_details .item_div {
    max-width: 90px;
    text-align: left;
    width: 100%;
}

.pricing_details .item_div h5 {
    text-align: left;
}

.pricing_details .qty_div {
    max-width: 20px;
    text-align: center;
    width: 100%;
}

.pricing_details .qty_div h5 {
    text-align: center;
}

.pricing_details .price_div {
    max-width: 50px;
    text-align: left;
    width: 100%;
}

.pricing_details .price_div h5 {
    text-align: left;
}

.pricing_footer {
    margin-top: 25px;
}

.pricing_footer h5 b {
    color: #fff;
}

.btn.btn_apply.btn_total {
    max-width: 100%;
    width: 100%;
    margin: 25px 0 0;
}



@media (min-width: 1199px) {
    .col-lg-cust-9.col-lg-9.col-md-11.col-11 {
        width: calc(100% - 304px)
    }

    .col.col-lg-cust-3.col-1 {
        width: 304px;
    }
}

@media (max-width: 1024px) {}