/*
Theme Name:     mdp
Theme URI:      http://mattressdisposalplus.com/
Description:    Custom theme
Author:         LoadUp
Author URI:     goloadup.com
Template:       genesis
Version:        1.0
*/

@media only screen and (min-width: 840px) {
	a[href^="tel"]:link,
	a[href^="tel"]:visited,
	a[href^="tel"]:hover {
	    text-decoration: none;
	    color: #333333;
	    pointer-events: none;
	    cursor: default;
	}
}
.border-box,.border-box *{
    box-sizing:border-box !important;
}


/* new form 15, 16 styles 9/30/2025 */
.bg-size-cover{
    background-size: cover;
}
.disc-light-blue{
    background-color: #A6D2FF;
    display: inline-flex;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    align-items: center;
    justify-content: center;
}
#gform_wrapper_8,
#gform_wrapper_9{
    max-width:500px;
}
#gform_wrapper_9{
    margin-left:auto;
    margin-right:auto;
}
@media (max-width: 991px) {
    #gform_wrapper_8{
        margin-left:auto;
        margin-right:auto;
    }
}
#gform_wrapper_8 .gform_heading,
#gform_wrapper_9 .gform_heading,
#field_8_5 .gfield_label,
#field_9_5 .gfield_label,
#gform_wrapper_8 .gfield_validation_message,
#gform_wrapper_9 .gfield_validation_message,
#gform_8_validation_container,
#gform_9_validation_container{
    display:none !important;
}
#gform_fields_8,
#gform_fields_9{
    position:relative;
    grid-column-gap: 0;
    border-radius: 3px;
    overflow: hidden;
    margin-bottom:20px;
}
#gform_fields_8{
    box-shadow:1px 1px 10px rgba(0,0,0,0.25);
}
#field_8_5,
#field_9_5{
    grid-column: span 7;
}
#gform_wrapper_8 #field_submit,
#gform_wrapper_9 #field_submit{
    grid-column: span 5;
}
@media (min-width: 768px) {
    #field_8_5,
    #field_9_5{
        grid-column: span 8;
    }
    #gform_wrapper_8 #field_submit,
    #gform_wrapper_9 #field_submit{
        grid-column: span 4;
    }
}
#field_8_5 .ginput_container,
#field_9_5 .ginput_container{
    padding-left:60px;
    background-color: #fff;
    background-image:url('https://couchdisposalplus.com/wp-content/uploads/2025/09/map-marker.svg');
    background-repeat: no-repeat;
    background-position: 12px center;
    background-size: 30px auto;
}
#field_9_5 .ginput_container {
    background-color:white;
}
@media (max-width: 499px) {
    #field_9_5 .ginput_container{
        padding-left:50px;
    }
}
#input_8_5,
#input_9_5{
    border:0;
    outline: none;
    box-shadow: none;
    background:transparent;
    height:60px;
}
#input_8_5::placeholder,
#input_9_5::placeholder{
    color: #231F20;
}
#gform_wrapper_8.gform_validation_error #input_8_5::placeholder,
#gform_wrapper_9.gform_validation_error #input_9_5::placeholder{
    color: #c02b0a;
    font-weight:bold;
}
#gform_submit_button_8,
#gform_submit_button_9{
    height:60px;
    width:100%;
    color:#231F20;
    background: #fff;
    border: 3px solid #83C0FF;
    outline: none;
    box-shadow: none;
    font-weight: bold;
}
/*
#gform_submit_button_9{
    border-color:#fff;
    color:#fff;
}
*/
#gform_wrapper_8 .gform_ajax_spinner,
#gform_wrapper_9 .gform_ajax_spinner {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translate(-50%, -50%);
}
.bg-lime{
    background-color: rgba(160, 235, 68, 0.2);
}
#accordionFaq .accordion-item,#accordionFaqCity .accordion-item{
    box-shadow: 2px 6px 17px rgba(0,0,0,0.1);
}
#accordionFaq .accordion-button,#accordionFaqCity .accordion-button{
    box-shadow: none;
}
#accordionFaq .accordion-button:after,#accordionFaqCity .accordion-item:after {
    background-size:12px;
    width: 28px;
    height: 28px;
    box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.15);
}
#accordionFaq .accordion-button:not(.collapsed):after,#accordionFaqCity .accordion-button:not(.collapsed):after{
    box-shadow: inset 0 2px 0 rgba(0, 0, 0, 0.15) !important;
}
#accordionFaq .accordion-button.collapsed:after,#accordionFaqCity .accordion-button.collapsed:after {
    background-color:rgba(160, 235, 68, 0.24);
}
.accordion-body p:last-child {
    margin-bottom: 0 !important;
}
/* TL;DR */
.tldr, .mdp-expert { border-radius:12px; padding:14px 16px; margin:16px 0; line-height:1.55; background:#eff6ff; border:1px solid #93c5fd; color:#0c4a6e; }
/* scroll-box */

.scroll-container{
    overflow:hidden;
}
.scroll-container-inner{
    margin:0 0 0 -16px;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    overflow-x: auto;
}
.scroll-box{
    flex-shrink: 0;
    width:180px;
    margin:0 16px;
    padding-bottom:.75rem;
}
.scroll-box-img{
    height:180px;
    width:180px;
    margin-bottom:2rem;
}
@media (min-width:768px){
    .scroll-box{
        width:220px;
    }
    .scroll-box-img{
        height:220px;
        width:220px;
    }
}
@media (min-width:992px){
    .scroll-box{
        width:240px;
    }
    .scroll-box-img{
        height:240px;
        width:240px;
    }
}
@media (min-width:1200px){
    .scroll-container-inner{
        margin:0 -24px;
    }
    .scroll-box{
        width:260px;
        margin:0 24px;
    }
    .scroll-box-img{
        height:260px;
        width:260px;
    }
}
/* Minimal, readable styling (inherits site fonts) */
.faq-wrap { max-width: 860px; margin: 28px auto; }
.faq-title { margin: 0 0 14px; font: 700 26px/1.25 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #111827; }
.faq-accordion details { border: 1px solid #e5e7eb; border-radius: 12px; background: #f9fafb; margin: 10px 0; overflow: hidden; }
.faq-accordion summary { list-style: none; padding: 14px 16px; cursor: pointer; display: flex; align-items: center; gap: 10px; font-weight: 700; color: #111827; }
.faq-accordion summary::-webkit-details-marker { display: none; }
.faq-accordion .caret { margin-left: auto; transition: transform .2s ease; font-size: 14px; color: #6b7280; }
.faq-accordion details[open] .caret { transform: rotate(180deg); }
.faq-accordion .answer { padding: 0 16px 16px; background: #fff; border-top: 1px solid #e5e7eb; color: #374151; line-height: 1.55; }
.faq-accordion .answer p { margin: 12px 0 0; }
.faq-accordion a { color: #8ac646; font-weight: 600; text-decoration: none; }
.faq-accordion a:hover { text-decoration: underline; }

.cdp-statbox {
    border-left: 4px solid #8ac646;
    background-color: rgb(237 248 218 / 30%);
    padding: 14px 16px;
    border-radius: 8px;
    margin: 24px 0;
    font-family: 'Figtree', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    font-size: 15px;
    color: #374151;
    line-height: 1.6;
}
.mdp-checklist {
    font-family:'Figtree',system-ui,Segoe UI,Roboto,Arial,sans-serif;
    max-width:780px;
    margin:20px auto;
    background:#f9fafb;
    border:1px solid #8ac646;
    border-radius:12px;
    padding:16px 18px;
}
.mdp-checklist h3 {
    margin:0 0 10px;
    font-size:18px;
    line-height:1.3;
    font-weight:700;
}
.mdp-checklist ul {
    list-style:none;
    padding:0;
    margin:0;
}
.mdp-checklist li {
    display:flex;
    gap:10px;
    align-items:flex-start;
    padding:10px 0;
    border-top:1px solid #8ac64638;
}
.mdp-checklist li:first-child {
    border-top:0;
}
.mdp-checklist .tick {
    width:18px;
    height:18px;
    flex:0 0 18px;
    display:inline-grid;
    place-items:center;
    border-radius:999px;
    background:#8ac64638;
    color:#8ac646;
    font-weight:700;
    font-size:14px;
    line-height:1;
    margin-top:3px;
}
.mdp-checklist .text {
    font-size:16px;
    color:#1f2937;
    line-height:1.45;
}
.cdp-steps {
    font-family:'Figtree',system-ui,Segoe UI,Roboto,Arial,sans-serif;
    max-width:700px;
    margin:22px auto;
    background:#8ac64638;
    border:1px solid #8ac64638;
    border-radius:12px;
    padding:16px;
}
.cdp-steps h3 {
    margin:0 0 12px;
    font-size:18px;
    font-weight:700;
}
.cdp-steps .grid {
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}
.cdp-steps .card {
    background:#ffffff;
    border:1px solid #f3f4f6;
    border-radius:12px;
    padding:14px;
    text-align:center;
}
.cdp-steps .num {
    display:inline-grid;
    place-items:center;
    width:28px;
    height:28px;
    border-radius:999px;
    background:#8ac646;
    color:#F6FFEC;
    font-weight:700;
    margin:0 auto 8px;
    font-size:14px;
}
.cdp-steps .title {
    font-weight:700;
    font-size:15px;
    margin-bottom:4px;
    color:#111827;
}
.cdp-steps .desc {
    font-size:14px;
    color:#374151;
    line-height:1.4;
}
@media (max-width:700px){
    .cdp-steps .grid {
        grid-template-columns:1fr;
    }
}
.cdp-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, 1fr);
  margin: 24px 0;
}
.cdp-card2 {
  border: 1.5px solid #8ac646;
  border-radius: 12px;
  background: #f8faf9;
  padding: 20px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.03);
  color: #111827;
  font-family: 'Figtree', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  transition: all 0.2s ease-in-out;
}
.cdp-card2:hover {
  transform: translateY(-2px);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.06);
}
.cdp-card2 h4 {
  font-size: 16px;
  font-weight: 800;
  margin: 0 0 6px;
}
.cdp-price {
  font-size: 15px;
  font-weight: 700;
  color: #111827;
  margin: 0 0 8px;
}
.cdp-note {
  font-size: 14px;
  color: #374151;
  margin: 0;
  line-height: 1.5;
}
@media (max-width: 992px) {
  .cdp-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 576px) {
  .cdp-grid { grid-template-columns: 1fr; }
}
.mdp-compare{
    border:1px solid #e5e7eb; background:#f9fafb; border-radius:12px;
    padding:14px 16px; margin:14px 0; line-height:1.55;
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.mdp-compare-title{
    margin:0 0 8px; font-size:16px; font-weight:700; color:#111827;
}
/* Remove divider lines and use spacing instead */
.mdp-compare-list{ margin:0; padding:0; list-style:none; display:grid; gap:8px; }
.mdp-compare-list li{
    padding:6px 0; color:#374151; /* no borders */
}
.mdp-compare-note{ margin:10px 0 0; color:#111827; font-weight:600; }

/* Related links hover color per your brand */
.related-link { color:#8AC646; text-decoration:none; font-weight:600; transition:color .2s; }
.related-link:hover { color:#6C9EFF; text-decoration:underline; }
.text-black { color:#000 !important; }

.mdp-steps .grid { display:grid; gap:14px; grid-template-columns:repeat(2,minmax(0,1fr)); }
@media (max-width:800px){ .mdp-steps .grid { grid-template-columns:1fr; } }
.mdp-steps .card { background:#f9fafb; border:1px solid #e5e7eb; border-radius:12px; padding:16px; display:grid; grid-template-columns:auto 1fr; gap:10px; }
.mdp-steps .num { width:34px; height:34px; display:grid; place-items:center; border-radius:999px; background:#8ac6461f; color:#8ac646; font-weight:800; }
.mdp-steps .title { font-weight:700; color:#111827; }
.mdp-steps .desc { grid-column:1 / -1; color:#374151; line-height:1.5; }

/* Pros/Cons comparison block with ticks & Xs only */
.cdp-proscons { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:16px 0; font-family:'Figtree',system-ui,Segoe UI,Roboto,Arial,sans-serif; }
@media (max-width:800px){ .cdp-proscons { grid-template-columns:1fr; } }
.cdp-col { background:#f9fafb; border:1px solid #e5e7eb; border-radius:12px; padding:16px; }
.cdp-col h3 { margin:0 0 8px; font-size:18px; color:#111827; }
.cdp-col ul { list-style:none; padding:0; margin:0; }
.cdp-col li { padding:8px 0; display:flex; align-items:center; gap:8px; border-top:1px solid #e5e7eb; }
.cdp-col li:first-child { border-top:0; }
.cdp-col .ok::before { content:"✓"; color:#74AA37; font-weight:700; margin-right:10px; font-size:16px; }
.cdp-col .warn::before { content:"✕"; color:#dc2626; font-weight:700; margin-right:10px; font-size:16px; }

  /* ===== Table Base Styling ===== */
  .cdp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 16px;
  }
  .cdp-table caption {
    text-align: left;
    font-weight: 700;
    margin: 0 0 8px;
  }
  .cdp-table th,
  .cdp-table td {
    padding: 10px 12px;
    border-bottom: 1px solid #e5e7eb;
    text-align: left;
    vertical-align: top;
  }
  .cdp-table thead th {
    background: rgb(237 248 218 / 30%);
    border-bottom: 2px solid #8ac646;
  }
  .cdp-table td:first-child,
  .cdp-table th:first-child {
    width: 120px;
    white-space: nowrap;
  }
  .cdp-code {
    font-weight: 700;
  }

  /* ===== Mobile card layout (≤640px) ===== */
  @media (max-width: 640px) {
    .cdp-table {
      border-collapse: separate;
      border-spacing: 0;
    }

    .cdp-table thead {
      display: none; /* show labels via data-labels */
    }

    .cdp-table tbody tr {
      display: block;
      background: #ffffff;
      border: 1px solid #e5e7eb;
      border-radius: 14px;
      box-shadow: 0 1px 2px rgba(0,0,0,.04);
      margin: 12px 0;
      overflow: hidden;
    }

    .cdp-table tbody tr td {
      display: block;
      border: 0;
      padding: 12px 14px;
    }

    /* Top badge for the Type cell */
    .cdp-table tbody tr td:first-child {
      background: #f5faf1;
      font-weight: 800;
      font-size: 18px;
      color: #1f2937;
      border-bottom: 1px solid #e5e7eb;
    }
    .cdp-table tbody tr td:first-child::before {
      content: "Type";
      display: inline-block;
      font-weight: 700;
      font-size: 12px;
      color: #3f6212;
      background: #eaffd1;
      border: 1px solid #d9f99d;
      padding: 2px 8px;
      border-radius: 999px;
      margin-right: 8px;
      vertical-align: middle;
    }

    /* Label/value pairs for the other cells */
    .cdp-table tbody tr td:not(:first-child) {
      padding-top: 10px;
      padding-bottom: 10px;
    }
    .cdp-table tbody tr td:not(:first-child)::before {
      content: attr(data-label);
      display: block;
      font-weight: 700;
      font-size: 13px;
      color: #374151;
      margin-bottom: 4px;
    }

    /* Divider between middle rows */
    .cdp-table tbody tr td:nth-child(2) {
      border-bottom: 1px dashed #e5e7eb;
    }
  }
/* Compare row component */
.compare-row {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  gap: 1rem;
  width: min(100% - 2rem, 1100px);
  margin: 1.5rem auto;
}

.compare-card {
  flex: 1 1 0;
  background: #fff;
  border: 2px solid #b4d88b;
  border-radius: 16px;
  padding: 1.2rem 1.3rem;
  box-sizing: border-box;
}

.compare-card summary {
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0;
  cursor: pointer;
  text-align: center;
  list-style: none;
}

.compare-card summary::-webkit-details-marker {
  display: none;
}

.card-subtitle {
  display: block;
  font-size: 1rem;
  font-weight: 500;
  color: #6b6b6b;
  margin-top: 0.3rem;
}

.compare-card ul {
  margin: 0.9rem 0 0 0;
  padding-left: 1.1rem;
  line-height: 1.45;
  font-size: 0.96rem;
  color: #444;
}

.compare-card li {
  margin-bottom: 0.5rem;
}

.compare-card li:last-child {
  margin-bottom: 0;
}

/* Decision guide component */
.decision-guide {
  margin: 26px 0;
}

.decision-guide-container {
  margin: 0 auto;
  max-width: 820px;
  border-radius: 12px;
  border: 1.5px solid #8ac646;
  background: #f8faf9;
  padding: 16px 18px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.03);
}

.decision-guide-intro {
  margin-bottom: 10px;
  font-size: 12px;
  color: #6b7280;
}

.decision-options {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.decision-option {
  margin: 0;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
}

.decision-option summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: 8px 10px;
}

.decision-option summary::-webkit-details-marker {
  display: none;
}

.option-number {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid #d1d5db;
  background: #f9fafb;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: #4b5563;
  flex-shrink: 0;
  margin-right: 8px;
}

.option-content {
  flex: 1 1 auto;
}

.option-title {
  font-size: 13px;
  font-weight: 700;
  color: #111827;
}

.option-description {
  font-size: 12px;
  color: #6b7280;
}

.option-arrow {
  margin-left: auto;
  font-size: 14px;
  color: #9ca3af;
}

.option-details {
  margin: 0;
  padding: 8px 10px 10px;
  border-top: 1px dashed #d1d5db;
  background: rgba(249, 250, 251, 0.9);
  border-radius: 0 0 10px 10px;
  font-size: 13px;
  color: #374151;
  line-height: 1.5;
}

/* Responsive design */
@media (max-width: 768px) {
  .compare-row {
    flex-wrap: wrap;
  }
  
  .compare-card {
    flex: 1 1 100%;
  }
  
  .decision-guide-container {
    padding: 12px 14px;
  }
  
  .option-content {
    min-width: 0;
  }
}

@media (max-width: 480px) {
  .compare-card summary {
    font-size: 1.2rem;
  }
  
  .card-subtitle {
    font-size: 0.9rem;
  }
  
  .compare-card ul {
    font-size: 0.9rem;
  }
}

  /* Do’s & Don’ts widget */
  .cdp-dos-donts { 
    border: 1px solid #e6efe0; 
    background: rgb(237 248 218 / 30%); 
    border-radius: 16px; 
    padding: 16px; 
    margin: 20px 0; 
  }
  .c-title { 
    margin: 0 0 12px; 
    font-size: clamp(18px, 2.4vw, 22px); 
    font-weight: 800; 
    color: #111827;
  }
  .c-grid {
    display: grid; 
    gap: 14px; 
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  @media (max-width: 760px) { 
    .c-grid { grid-template-columns: 1fr; } 
  }
  .c-card {
    background: #fff;
    border: 1px solid #e6efe0; 
    border-radius: 14px; 
    padding: 14px; 
    box-shadow: 0 1px 6px rgba(0,0,0,.04);
  }
  .c-card--do { border-top: 4px solid #8ac646; }
  .c-card--dont { border-top: 4px solid #ef4444; }
  .c-h4 { 
    margin: 0 0 8px; 
    font-size: clamp(16px, 2.1vw, 18px); 
    font-weight: 800; 
    color: #111827;
  }
  .c-list { 
    margin: 0; 
    padding-left: 18px; 
    line-height: 1.55; 
    color: #374151;
  }
  .c-list li { margin: 6px 0; }
  .c-list--donts li b { color: #b91c1c; }