:root, html { scroll-behavior: smooth!important; scroll-padding-top: 50px; }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes thumbPulse {
  0% { transform: scale(1); box-shadow: 0 2px 4px rgba(79, 70, 229, 0.3); }
  50% { transform: scale(1.25); box-shadow: 0 6px 14px rgba(79, 70, 229, 0.45); }
  100% { transform: scale(1); box-shadow: 0 2px 4px rgba(79, 70, 229, 0.3); }
}
.slider-container { margin-top: 30px; }
.another_quote_btn_top { display: block; padding: 15px 40px; font-weight: 600; transition: all 0.3s; border-radius: 100px; border: 1px solid #36323245; background: #0044eb; color: #fff; border-color: #0044eb; margin: 0 auto 40px; }
.inactive_section { display: none; animation: fadeIn 0.3s ease-in; }
.inactive_section.active { display: block; }
.slider-item { margin-bottom: 15px; display: flex; align-items: center; justify-content: space-between; }
.slider-item:last-child { margin-bottom: 0; }
.slider-item label { font-weight: 600; color: #1e3a5f; min-width: 270px; font-size: 1.05em; }
.slider-wrapper { flex: 1; display: flex; align-items: center; gap: 15px; margin: 0 20px; }
.slider-btn { background: none; border: none; font-size: 20px; cursor: pointer; color: #1e3a5f; padding: 5px 10px; transition: all 0.2s; }
.slider-btn:hover { color: #0044eb; transform: scale(1.2); }
input[type="range"] { flex: 1; -webkit-appearance: none; appearance: none; height: 6px; background: #e5e7eb; border-radius: 5px; outline: none; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 20px; height: 20px; background: #0044eb; border-radius: 50%; cursor: pointer; box-shadow: 0 2px 4px rgba(79, 70, 229, 0.3); transition: all 0.5s ease; }
input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.2); box-shadow: 0 3px 6px rgba(79, 70, 229, 0.4); }
input[type="range"]::-moz-range-thumb { width: 20px; height: 20px; background: #0044eb; border-radius: 50%; cursor: pointer; border: none; box-shadow: 0 2px 4px rgba(79, 70, 229, 0.3); }
.combined_cc_container { max-width: 1000px; margin: 0 auto 0; }

/* Animate thumb while user is changing the slider */
input[type="range"].is-changing::-webkit-slider-thumb { animation: thumbPulse 220ms ease-out; }
input[type="range"].is-changing::-moz-range-thumb { animation: thumbPulse 220ms ease-out; }

/* Optional: also animate while dragging (even without JS) */
input[type="range"]:active::-webkit-slider-thumb { transform: scale(1.25); }
input[type="range"]:active::-moz-range-thumb { transform: scale(1.25); }
.value-display { min-width: 190px; color: #0044eb; font-weight: 600; font-size: 16px; background: transparent; padding: 8px 16px; border-radius: 8px; transition: all .3s ease; text-align: center; }
.slider-item .slider-wrapper:hover + .value-display { background: #0044eb; color: #fff; }
.quote-message { border: 2px solid #e5e7eb; border-radius: 8px; padding: 18px; background: #fff; margin-top: 20px; }
.quote-success { background: #fff; text-align: center; padding: 40px 20px 30px; }
.quote-success h3 { margin: 0 0 8px; color: #1e3a5f; font-weight: 700; }
.quote-success p { margin: 0 0 14px; color: #1e3a5f; }
.quote-error { border-color: #ef4444; background: #fff1f2; color: #991b1b; margin-bottom: 18px; padding: 8px 20px; text-align: center; }
.quote-success .another-quote-btn { background: #18c85f; padding: 15px 50px; color: #fff; font-weight: 600; transition: all 0.3s; border-radius: 100px; }
.pricing-btn { display: block; margin: 40px auto 0; padding: 15px 50px; color: #fff; font-weight: 600; transition: all 0.3s; background-color: var(--bs-primary); border: 1px solid var(--bs-primary); border-radius: var(--bs-border-radius-pill); }
.pricing-btn:hover { transform: translateY(-2px); }
/* Pricing Table Styles */
.quote_form_title { text-align: center; margin: 80px auto 30px; max-width: 700px; }
.pricing-table { background: #fff; border-radius: 8px; overflow: hidden; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); margin-bottom: 30px; }
.table-header { display: grid; grid-template-columns: 2fr 1fr 1fr; background: #020842; color: #fff; padding: 16px 20px; font-weight: 600; font-size: 1.1em; }
.header-empty { grid-column: 1; }
.header-low { text-align: center; }
.header-high { text-align: center; background: #0044eb; margin: -16px -20px -16px 0; padding: 16px 20px; }
.pricing-row { display: grid; grid-template-columns: 2fr 1fr 1fr; padding: 10px 20px; border-bottom: 1px solid #e5e7eb; align-items: center; }
.pricing-row:nth-child(even) { background: #e3f0ff45; }
.row-label { font-weight: 600; color: #1e3a5f; font-size: 16px; line-height: 1.5; }
.row-description { color: #6b7280; font-size: 14px; line-height: 1.6; }
.row-high, .row-low { text-align: center; font-weight: 600; font-size: 1.1em; color: #0044eb; }
.total-row { display: grid; grid-template-columns: 2fr 1fr 1fr; padding: 16px 20px; font-weight: 700; font-size: 1.2em; }
.total-low { text-align: center; color: #fff; background: #020842; margin: -16px 0 -16px -20px; padding: 16px 20px; }
.total-high { text-align: center; color: #fff; background: #0044eb; margin: -16px -20px -16px 0; padding: 16px 20px; }

/* Form Styles */
.combined_cc_container form { background: #fff; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); border-radius: 8px; padding: 45px 50px 20px; }

.combined_cc_container form .quote-box, .combined_cc_container form input:not([type="submit"]) { width: 100%; padding: 12px 15px; border: 1px solid #36323245; border-radius: 6px; font-size: 16px; font-family: inherit; transition: border-color 0.3s; }

.combined_cc_container form .quote-box p { margin: 0; color: #000; line-height: 1.5; }

.combined_cc_container form .wpcf7-form-control-wrap { display: block; }
.combined_cc_container form .field_row { display: grid; gap: 20px; grid-template-columns: repeat(2, 1fr); margin: 20px 0 20px; }

.combined_cc_container form .field_submit input { display: block; margin: 30px auto 0; padding: 15px 50px; color: #fff; font-weight: 600; transition: all 0.3s; background-color: #0044eb; border: 1px solid #0044eb; border-radius: 50px; }

.combined_cc_container form .field_submit input:hover { transform: translateY(-2px); }

.combined_cc_container form .wpcf7-response-output { margin-top: 0; text-align: center; }

/* .quote_form { background: #fff; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); border-radius: 8px; padding: 45px 50px; }
.quote_form .form-row { display: flex; justify-content: space-between; gap: 30px; }
.quote-success .another-quote-btn { background: #18c85f; padding: 15px 50px; color: #fff; font-weight: 600; transition: all 0.3s; border-radius: 100px; }
.quote_form .button-group button { background: #fff; padding: 15px 40px; color: #020842; font-weight: 600; transition: all 0.3s; border-radius: 100px; border: 1px solid #36323245; }
.quote_form .button-group { justify-content: space-between; }
.quote_form .button-group button[type="submit"] { background: #0044eb; color: #fff; border-color: #0044eb; }
.quote_form .form-row .form-col { flex: 1 0 max-content; }
.form-group { margin-bottom: 25px; }
.form-group label { display: block; font-weight: 600; color: #020842; margin-bottom: 8px; font-size: 15px; line-height: 1; }
.required { color: #ef4444; }
.form-group input, .form-group textarea { width: 100%; padding: 12px 15px; border: 1px solid #36323245; border-radius: 6px; font-size: 16px; font-family: inherit; transition: border-color 0.3s; }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: #0044eb; }
.form-group textarea { min-height: 252px; background: #f9fafb; color: #1e3a5f; resize: none; }
.button-group { display: flex; gap: 15px; justify-content: center; margin-top: 30px; }
.quote_form .button-group button:hover { transform: translateY(-2px); } */
/* ----------- Pros and Cons table design starts here ------- */
.pros_cons_table { max-width: 1100px; margin: 0 auto; border-radius: 14px; overflow: hidden; border: 1px solid rgb(255 255 255 / 36%); background: #e3f0ff; }
.pc-row { display: grid; grid-template-columns: 30% 45% 25%; align-items: center; }
.pc-head { background: var(--pc-header-bg); color: #fff; font-weight: 700; font-size: 18px; }
.pc-cell { padding: 18px 26px; line-height: 1.4; color: #020842!important; }
.pc-body .pc-row { background: #fff; }
.pc-body .pc-row + .pc-row { border-top: 1px solid #e3f0ff; }
.pc-body .pc-row:nth-child(even) { background: #f5f5f5a1; }
.pc-what { color: var(--pc-muted); }
.pc-price { font-weight: 800; color: var(--pc-price); white-space: nowrap; }
@media (max-width: 767px) {
  .pc-cell { padding: 18px 16px; font-size: 16px; }
  .module_navigation ul.elementor-icon-list-items li { width: 100%!important; }
  .slider-item { flex-direction: column; align-items: flex-start; margin-bottom: 15px; padding-bottom: 15px; border-bottom: 1px solid #a1a1a13b; }
  .slider-item label { margin-bottom: 0; padding: 0 0 0 10px; }
  .slider-wrapper { width: 100%; margin: 0 0; }
  .value-display { text-align: left; width: 100%; padding: 0 0 0 10px; }
  .pricing-row,   .table-header, .total-row { grid-template-columns: 2fr 1fr 1fr; font-size: 14px; padding: 10px 10px; }
  .button-group { flex-direction: column; }
  .header-high, .total-high { padding: 10px 10px; margin: -10px -10px -10px 0; }
  .row-high, .row-label { font-size: 14px; }
  .total-low { padding: 10px 20px; margin: -10px 0 -10px -20px; }
  .quote_form_title { margin: 50px auto 20px; font-size: 16px; }
  .combined_cc_container form { padding: 25px 20px 10px; }
  .combined_cc_container form .field_row { grid-template-columns: repeat(1, 1fr); }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .slider-item { flex-wrap: wrap!important; justify-content: space-between; margin-bottom: 25px; }
  .slider-item .slider-wrapper { width: 100%; order: 2; flex: 1 0 auto; margin: 0!important; }
  .slider-item label { width: fit-content; order: 0; padding: 0 0 0 10px; }
  .slider-item .value-display { order: 1; text-align: right; line-height: 1; padding-bottom: 0; }
  .module_navigation ul.elementor-icon-list-items li:nth-child(odd) { width: calc(42% - 20px)!important; }
  .module_navigation ul.elementor-icon-list-items li:nth-child(even) { width: calc(58% - 20px)!important; }
}

@media (max-width: 1024px) {
  .pc-row { grid-template-columns: 33% 33% 34%; }
  .pros_cons_table { overflow-x: auto; }
  .pros_cons_table .inner_table { min-width: 670px; }
  .pc-cell { word-break: break-word; white-space: normal; }
  .slider-item .slider-wrapper:hover + .value-display { background: unset; color: #0044eb; }
}

@media (min-width: 1025px) and (max-width: 1200px) {
  .no_mid_tab { display: none!important; }
}
