
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Bold.woff2') format('woff2'),
    url('../fonts/Montserrat-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-ExtraBold.woff2') format('woff2'),
    url('../fonts/Montserrat-ExtraBold.woff') format('woff');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Regular.woff2') format('woff2'),
    url('../fonts/Montserrat-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-SemiBold.woff2') format('woff2'),
    url('../fonts/Montserrat-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

#poly_panel_builder::after {
    content: " ";
    clear: both;
    float: none;
    display: block;
}

#poly_panel_builder .disabled {
    pointer-events: none;
}


#poly_panel_builder_form .processing {
    color: #c00101;
    animation: text-pulsate 10s ease-out infinite;
    -webkit-animation: text-pulsate 1s ease-out infinite;
    opacity: .2;
    display: none;
    padding: 5px;;
}
@keyframes text-pulsate {
    0% {
        opacity: .2;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: .2;
    }
}
@-webkit-keyframes text-pulsate {
    0% {
        opacity: .2;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: .2;
    }
}

#poly_panel_messages, #poly_panel_warning {
    background: #e6435f;
    padding: 15px;
    text-align: center;
    color: white;
    font-size: 13px;
    font-weight: bold;
    display: none;
}

#poly_panel_warning {
    background: #a2772b;
}

#poly_panel_builder{
    font-family: 'Montserrat';
}

#poly_panel_builder table tr td:last-child{border-right:none;}

#poly_panel_messages.show, #poly_panel_warning.show {
    display: block;
}

#poly_panel_builder .poly_panel_preview_wrapper{
    width: 40%;
    border-right:1px solid #ccc;
}

#poly_panel_builder .poly_panel_settings_wrapper{width: 60%;padding-bottom: 18px;}
#poly_panel_builder{
    border:1px solid #ccc;
    display: flex;
    margin-bottom: 40px;
}

#poly_panel_builder_form table td:first-child{border-left: none}


.poly_panel_settings[data-step="1"] tr td:first-child{
    width:42%;
    vertical-align: middle;
}
.poly_panel_settings td{vertical-align: middle;}
.poly_panel_settings td.ch strong{font-size: 14px !important;text-align: center;font-family: 'Montserrat',sans-serif;}
.poly_panel_settings[data-step="1"] td{text-align: center;}

.poly_panel_settings .quantity {
    border: solid 1px #ccc;
}
.poly_panel_settings .s-title{
    font-weight:bold;
    font-size: 14px;
    display: block;
}


.poly_panel_settings table td{font-size: 10px;}
.poly_panel_settings[data-step="1"] tr td:first-child strong{display: inline-block;}
.poly_panel_settings[data-step="1"] tr td strong{display: block;font-size: 18px;}
.poly_panel_settings[data-step="1"] tr:first-child td{background: #f7f7f7}
.poly_panel_settings[data-step="1"] td{background:#fff; }
.poly_panel_settings table td strong{font-weight: 800;}
.poly_panel_settings table td.number{
    width: 12% !important;
    vertical-align: middle;
}
.poly_panel_settings table td.number span{
    width: 40px;
    height: 40px;
    display: block;
    text-align: center;
    line-height: 40px;
    background:#c00101;
    color:#fff;
    font-family: 'Montserrat',sans-serif;
    border-radius: 50%;
    font-weight: 600;
    font-size: 18px;
}
.poly_panel_settings input[type="radio"]{
    width: 12px;
    height: 12px;
}
.poly_panel_settings .inputs{
    width: 100%;
    display: flex;
    justify-content: space-between;
    padding-top: 7px;
}
.poly_panel_settings .inputs input{
    border-color:#ccc;
    border-radius: 0;
    color:#c00101;
    font-weight: 600;
    padding:0.5rem;
}
.poly_panel_settings .review-heading{
    background:#f7f7f7;
    font-size: 18px;
    font-weight: 800;
    padding:15px;
    border-color:#ccc;
    border-style: solid;
    border-width: 1px 1px 0 1px;
}
.poly_panel_settings .lbs{
    background:#c00101;
    color:#fff;
    font-weight: 800;
    padding:10px 20px 10px 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.poly_panel_settings .total-weights{
    float: right;
    background:#fff;
    font-weight: 600;
    text-align: center;
    color:#c00101;
    padding:7px 20px;
    min-width: 150px;
    margin-left: 10px;
}
.poly_panel_settings .total{
    background:#efefef;
    justify-content: center;
    display: flex;
    padding:0 15px;
    border-style: solid;
    border-color: #ccc;
    border-width: 0 1px 1px 1px;
}

.poly_panel_settings .total div.price{
    border:solid #ccc;
    border-width: 0 1px;
}

.poly_panel_settings .total > div{
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 0;
    width: 32%;
}
.poly_panel_settings em.limit{font-style: normal;}
.poly_panel_settings .total .qty{margin-right: 24px;}
.poly_panel_settings .total label{
    font-size: 12px;
    font-weight: bold;
    margin:0 14px 0 0;
}
.poly_panel_settings .total select{border-radius: 0;font-weight: 600;}
.poly_panel_settings .total .hold{
    background: #fff;
    font-weight: 600;
    padding: 7px 35px;
    margin: 0 25px;
    font-size: 15px;
}
.poly_panel_settings .total .add-cart button{
    background: #c10606;
    font-weight: 800;
    color: #fff;
    margin: 0 25px 0 46px;
    border-radius: 0;
    font-size: 15px;
    padding: 9px 25px;
    width: 100%;
}
.poly_panel_settings .total .add-cart button[disabled] {
    background: lightgray;
    border: darkgray;
}
.poly_panel_settings #poly_panel_pre_discount {
    color: darkgray;
    text-decoration: line-through;
}

#poly_panel_builder table tr td.eng-text{border-top:none;padding-left: 45px;border-bottom:none;}

.poly_panel_settings[data-step="1"] .nice-number{
    position: relative;
}

.poly_panel_settings[data-step="1"] .nice-number button{
    width: 20px;
    height: 20px;
    position: absolute;
    right:0;
    top:20px;
    padding:0;
    border-radius:0;
}
.poly_panel_settings[data-step="1"] .nice-number input ~ button{
    top:0;
}

.poly_panel_settings strong.m-title{
    font-size: 18px;
    font-weight: 800;
}
.poly_panel_settings input#eng-number{
    border:none;
    border-bottom:1px solid #ccc;
    font-size: 14px;
    font-weight: 600;
    border-radius: 0;
    background: none;
    padding-left: 0;
    padding-right: 104px;
    color:#000;
    margin-bottom: 10px;
}
.poly_panel_settings td.eng-text{position: relative;padding-bottom: 0;}
.poly_panel_settings td.eng-text span{
    position: absolute;
    right:15px;
    top:28px;
    font-size: 10px;
    color:#c00101;
}


.poly_panel_settings .quantity {
    position: relative;
    float: right;
}

.poly_panel_settings input[type=number]::-webkit-inner-spin-button,
.poly_panel_settings input[type=number]::-webkit-outer-spin-button
{
    -webkit-appearance: none;
    margin: 0;
}

.poly_panel_settings input[type=number]{
    -moz-appearance: textfield;
}


.poly_panel_settings .quantity input {
    width: 100px;
    color:#c00101;
    text-align: center;
    float: left;
    display: block;
    margin: 0;
    font-weight: 600;
    border:none;
    border-radius: 0;
    font-size: 1.6rem;
    padding: 0;
}

.poly_panel_settings .quantity input:focus {
    outline: 0;
}

.poly_panel_settings .quantity-nav {
    float: right;
    position: relative;
    height: 40px;
    width: 20px;
    border:1px solid #a8a8a8;
    overflow: hidden;
    margin: -1px -1px -1px 0;
}

.poly_panel_settings .quantity-button {
    position: relative;
    cursor: pointer;
    border-left: 1px solid #eee;
    width: 20px;
    text-align: center;
    color: #333;
    font-size: 13px;
    font-family: "Trebuchet MS", Helvetica, sans-serif !important;
    line-height: 1.7;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -o-user-select: none;
    user-select: none;
}

.poly_panel_settings .quantity-button.quantity-up {
    position: absolute;
    height: 50%;
    top: 0;
    border-bottom: 1px solid #a8a8a8;
    background: url(../img/g-arrow-t.png) no-repeat 5px 7px;
    background-size:8px auto;
    text-indent: -9999px;
}

.poly_panel_settings .quantity-button.quantity-down {
    position: absolute;
    background: url(../img/g-arrow-b.png) no-repeat 5px 4px;
    bottom: -1px;
    height: 50%;
    background-size:8px auto;
    text-indent: -9999px;
}
.poly_panel_settings span.sign{
    font-size: 16px;
    font-weight: 600;
    float: left;
    color:#c00101;
    margin:6px 0 0 -26px;
}
.poly_panel_settings_prevnext{padding:0 15px;}
.poly_panel_settings_prevnext button{
    border-color:#c00101;
    color:#c00101;
}
.poly_panel_settings_prevnext button:hover,
.poly_panel_settings_prevnext button:focus {background:#c00101; }

.poly_panel_bottom_messages {
    margin-bottom: 20px;
    border-color: #ccc;
    border-width: 0 1px 1px 1px;
    border-style: solid;
    min-height: 30px;
}

.poly_panel_settings h3 {
    font-size: 18px;
    font-weight: 800;
    padding: 10px;
    border-bottom: 1px solid #ccc;
    background: #f7f7f7;
    margin: 0 !important;
}
.poly_panel_settings:not(:nth-child(1)) h3 {
    border-top: 1px solid #ccc;
}
.poly_panel_settings p {
    padding: 10px;
    margin: 0 !important;
}
.poly_panel_settings .input_wrapper {
    padding: 0 10px;
    margin-bottom: 10px;
}
label:has(input[type="radio"]:hover) {
    background-color: unset !important; 
}
.poly_panel_settings .input_wrapper label {
    display: block;
    min-width: 100px;
    padding-top: 3px;
}
.poly_panel_settings .input_wrapper:after {
    content: " ";
    display: block;
    float: none;
    clear: both;
}
.poly_panel_settings .quantity {
    float: left;
}
.poly_panel_settings .small {
    font-size: 12px;
}
.poly_panel_settings ul {
    list-style: none;
    margin: 0 !important;
}
.poly_panel_settings label {
    color: #c00101;
    font-weight: 600;
    margin: 10px 25px 10px 0;
    display: flex;
    line-height: 15px;
    align-items: center;
    float: left;
}
.poly_panel_settings label input {
    margin-right: 5px;
}
.woocommerce div.product .poly_panel_preview div.woocommerce-product-gallery {
    width: 100%;
}

@media screen and (max-width:1200px){
    .poly_panel_settings span.sign{margin-left: -15px}
    .poly_panel_settings .quantity input{width: 75px;}
    .poly_panel_settings[data-step="1"] tr td strong{font-size: 16px}
}

@media screen and (max-width:991px){
    #poly_panel_builder .poly_panel_preview_wrapper{
        width: 100%;
        border-right:none;
    }
    #poly_panel_builder{
        display: block;
    }
    #poly_panel_builder .poly_panel_settings_wrapper{width: 100%;}
}

@media screen and (max-width:500px){
    table td, table th{padding:8px !important;}
    .poly_panel_settings .quantity input{width: 65px;}
    .poly_panel_settings span.sign{margin-left: -9px;}
    .poly_panel_settings td.eng-text span{top:18px;}
    .poly_panel_settings .total .hold{padding-left: 15px;padding-right: 15px;}
    .poly_panel_settings .total .add-cart button{margin:0 0 0 15px;padding:9px 13px;font-size: 12px;}
    .poly_panel_settings[data-step="1"] tr td:first-child {width: 35%;}
    .poly_panel_settings table {width: 100% !important;}
}

@media screen and (max-width:379px){
    table {
        width: 375px !important;
    }
    #poly_panel_builder_form .poly_panel_settings.current-step{overflow-x:auto; }
    .poly_panel_settings .total{
        display: block;
    }
    .poly_panel_settings .total > div{width: 100%;}
    .poly_panel_settings .total div.price{border:none;}
    .poly_panel_settings .total .hold{
        width: 100%;
        margin:0;
    }
    .poly_panel_settings .total .add-cart button{margin-left: 0;}
    .poly_panel_settings .total-weights{
        min-width: 130px
    }
}

#poly-panel-agreement {
    font-size: 14px;
}
#poly_panel_builder_form .poly_panel_settings {
    display: none;
}

/* Show active step only */
#poly_panel_builder_form .poly_panel_settings.current-step {
    display: block;
}

#poly_panel_builder_form .poly_panel_settings table {
    width: 100%;
}

.poly_panel_settings_prevnext button {
    position: relative;
    min-width: 120px;
    height: 40px;
    font-weight: 700;
    background: #fff;
}
.poly_panel_settings_prevnext button:disabled {
    color: #aaa;
    border-color: #aaa;
    cursor: not-allowed;
}

/* Hover state */
.poly_panel_settings_prevnext button:not(:disabled):hover {
    background: #c00101;
    color: #fff;
}

.polybox_settings_pagination {
    display: flex;
    width: 100%;
    margin-bottom: 20px;
   justify-content: space-between;
}

.polybox_settings_pagination .steps {
    color: #000000;
    text-align: center;
    padding: 40px 20px;
    border-right: 2px solid #fff;
    cursor: default;
    width: 33.33%;
}

/* Step number */
.polybox_settings_pagination .steps .step_number {
    display: block;
    font-size: 26px;
    font-weight: 600;
    color:#000000;
    margin-bottom: 5px;  
}

/* Step title */
.polybox_settings_pagination .steps .step_title {
    display: block;
    font-size: 16px;
    font-weight: 600;
}

.polybox_settings_pagination .steps.done {
    background: #c00101;
    color:#fff;
}
.polybox_settings_pagination .steps.done .step_number{
    color:#fff;
}

#poly_panel_builder {
    display: flex;
    flex-wrap: wrap;
}

#poly_panel_messages,
#poly_panel_warning {
    width: 100%;
    flex: 0 0 100%;
}
label:has(input[type="radio"]:checked) {
    background-color: transparent !important;
    color: #000000 !important;
}
.woocommerce div.product div.images img {
    min-height: 155px !important;
}

.features-added {
    font-size: 16px;
    padding: 13px 15px 9px;
    font-weight: 600 !important;
    color: #c00101 !important;
    line-height: 20px;
}
.features-added div {
    font-size: 14px;
    display: flex;
    align-items: center;
    line-height: 15px;
    margin: 7px 0;
    color: #212529;
}
.features-added div label {
    display: inline-flex;
    margin-right: 7px;
    font-weight: 600;
    color: #212529;
    margin-block: 0;
}
.features-added div span {
    font-weight: 400;
    display: inline-flex;
}

.poly_panel_settings_wrapper .steps.done:after {
    content: '↓';
    color: white;
    position: absolute;
    top: auto;
    font-size: 30px;
    left: 46%;
}
.poly_panel_settings_wrapper a.step_number{
        font-weight: 600;
    font-family: 'Montserrat', sans-serif;
}
.polybox_settings_pagination .steps.done {
    position: relative;
}
#poly_panel_builder .polybox_settings_pagination {
    border-bottom: 5px solid #c00101;
    margin-bottom: 0;
}
#poly_panel_builder .steps .step_number, #poly_panel_builder .steps .step_title {
    color: #909090 !important;
}
#poly_panel_builder .steps.done .step_title {
    color: #fff !important;
}
#poly_panel_builder .steps.done .step_number {
    color: #fff !important;
}
#poly_panel_builder .steps .step_title {
    font-weight: bold;
}
#poly_panel_builder_form .poly_panel_settings table td {
    font-size: 14px !important;
}
#poly_panel_builder_form td[colspan="2"] br {
    display: none;
}
#poly_panel_builder_form .polybox_settings_pagination .steps {
    border-right: 1px solid #e2e2e2;
}
#poly_panel_builder .steps:last-child {
    border-right: none;
}
#poly_panel_builder .polybox_settings_pagination .steps {
    cursor: pointer;
}
#poly_panel_builder_form .poly_panel_settings .quantity {   float: right;
}
#poly_panel_builder_form tr td.ch br {
    display: none;
}
#poly_panel_builder .poly_panel_settings table td.number span {
    background-color: #f1f1f1 !important;
    color: black !important;
    border: 1px solid #c00101 !important;
}
#poly_panel_builder  .poly_panel_settings_prevnext button {
    position: relative;
    min-width: auto !important;
    height: auto !important;
    font-weight: normal !important;
    background: #fff !important;
    border-radius: 0 !important;
}
#poly_panel_builder .poly_panel_settings_prevnext button.prev:hover, 
#poly_panel_builder .poly_panel_settings_prevnext button.next:hover {
    background: #c00101 !important;
}
