@font-face {
    font-family: 'MonotypeCorsiva';
    src: url('https://coa.demo.crawleragency.com/wp-content/themes/solor-child/assets/fonts/Monotype-Corsiva-Bold-Italic.ttf') format('truetype');
    font-weight: normal;
    font-style: italic;
}

.custom-font-div {
    font-family: 'MonotypeCorsiva', cursive;
    font-size: 24px;
    font-style: italic;
}
.step-form { display: none; }
.step-form.active { display: block; }
.progress-bar-container {
    background: #f1f1f1;
    border-radius: 2px;
    height: 10px;
    margin-bottom: 0px;
    overflow: hidden;
}
h1,h2,h3,h4,h5{
	font-family: 'Rajdhani';
}
p, p.map-text {
   font-family: 'Rubik';
   font-size: 16px !important;
   font-weight: 400 !important;
   color: #000 !important;
}
label.radio-option span {
    font-family: 'Rubik';
   font-size: 16px !important;
   font-weight: 400 !important;
   color: #000 !important;
}
.radio-option.active span {
  color: #fff !important;
}
.progress-bar-fill {
    background: #76b82a;
    height: 100%;
    width: 0%;
    transition: width 0.5s ease-in-out; /* Animation duration for progress bar */
    opacity: 0;
    animation: slideUp 0.5s ease-out forwards;
    animation-delay: 0.2s;
}

.time{
    width: 50px !important;
    height: 50px !important;
     opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 0.2s;
}

#prevBtn .pre-btn {
    width: 40px !important;
    height: 45px !important;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.2s;
}

.image-inner {
    display: flex;
    gap: 5%;
    margin-top: 50px;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
}

.step1-container .image-inner  {
    margin-top: 80px;
}
.image-inner .right h5 {
   font-family: 'Rajdhani';
    text-align: left;
    animation-delay: 0.4s;
}

.image-inner .right p {
    animation-delay: 0.6s;
}
.image-inner .right {
    width:100%
}
p {
	font-family:Rubik;
}
span {
	font-family:Rubik;
	
}
h5 {
font-size : 46px !important;
font-weight: bold !important;
}
span.zone {
  font-family: Rubik;
}
input[type="text"] {
  font-family: Rubik; 
}


h5{
    color: #000 !important;
    text-align: left;
}

#step-1 label.radio-option {
    width: 70% !important;
}

#step-3 p {
  margin-bottom: 0px !important;
}
#step-3 p.map-text {
  margin-bottom: 10px !important;
}
#step-3 .step3-text p.inner-text {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
}

#step-3 .step3-text p.inner-text:nth-child(2) { animation-delay: 0.8s; }
#step-3 .step3-text p.inner-text:nth-child(3) { animation-delay: 1.0s; }

#map {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.2s;
}

#step-2 #address {
    width: 55% !important;
    margin-top: 50px !important;
    margin-left: 74px !important;
    border: 2px solid #76b82a !important;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.8s;
    font-family: 'Rubik';
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #000 !important;
}


#step-2 button.search {
    background: #76b82a;
    color: #fff;
    border: 1px solid #76b82a;
    border-radius: 25px;
    align-items: center;
    justify-content: center;
    gap: 5px;
    overflow: hidden;
    padding: 12px;
    font-family: 'Rubik';
    font-size: 16px !important;
    font-weight: 400 !important;
    cursor: pointer;
    transition: color 0.3s ease-in-out;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 1.0s;
}
#step-2 button.search:hover {
    color: #76b82a;
}

#step-2 button.search:hover::before {
    width: 100%;
}

#step-2 button.search::before {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    height: 100%;
    width: 0%;
    background-color: #fff;
    transition: all 0.3s ease;
    z-index: -1;
    border-radius: 50px;
}



/* #step-2  button.search:hover {
  background-color: #0056b3;  
  color: #ffd700;            
}

#step-2 button.search:active {
  background-color: #003f7f;  
  color: #ffffff;             
} */

/* p.map-text {
    margin-bottom: 35px !important;
    line-height:normal;
}

p.inner-text {
    margin-bottom: 20px !important;
} */


.step1-container {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 40px;
    margin-top: 0px;
    flex-wrap: wrap;
}

.roof-type-options {
    display: flex;
    flex-direction: column;
    gap: 20px;
    flex: 1;
    min-width: 250px;
}

.radio-option {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #ffffff !important;
    padding: 14px 20px;
    border-radius: 10px;
    border: 2px solid #76b82a !important;
    cursor: pointer;
    transition: border-color 0.3s, background 0.3s;
    font-size: 16px;
}

.radio-option:hover {
    background: #76b82a !important;
}

.radio-option:hover .zone,  .radio-option:hover span{
    color: #ffffff !important;
}

.radio-option input[type="radio"] {
    transform: scale(1.3);
    accent-color: #4caf50;
    display: none;
}
.image-upload-box {
    flex: 1;
    /* min-width: 300px; */
}

.image-upload-box img {
    max-width: 100%;
    border-radius: 10px;
    border: 1px solid #ddd;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}


.step2-container {
    display: flex;
    gap: 30px;
    align-items: flex-start;
    margin-top: 20px;
}
.step2-container .address-form {
    flex: 1;
}
.step2-container .address-image {
    flex: 1;
}
.step2-container .address-image img {
    max-width: 100%;
    border-radius: 8px;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.2s;
}
#map-step2 {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.2s;
}
/* #step-5 .roof-type-options,
#step-8 .roof-type-options,
#step-11 .roof-type-options,
#step-14 .roof-type-options {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
    margin-top: 20px;
} */

/* Style radio-option elements in steps 5, 8, 11, and 14 */
/* #step-5 .roof-type-options .radio-option,
#step-8 .roof-type-options .radio-option,
#step-11 .roof-type-options .radio-option,
#step-14 .roof-type-options .radio-option {
    display: flex;
    justify-content: center;
    cursor: pointer;
    margin: auto !important;
    width: 70% !important;
} */

.step7-container {
    display: flex;
    gap: 30px;
    align-items: flex-start;
    margin-top: 20px;
}
.step7-text {
    flex: 1;
}
.step7-image {
    flex: 1;
}
.step7-image img {
    max-width: 100%;
    border-radius: 10px;
    border: 1px solid #ddd;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}

#step-3 .check-add {
    background-color: #fffbd0;
    padding:20px 10px;

}

#step-4 .step4-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
#step-6 .step6-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
#step-5 .step5-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
#step-8 .step8-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
#step-11 .step11-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}

#step-14 .step14-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
#step-15 .step15-image img {
    height: 500px !important; 
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
#step-12 .step12-image img {
    height: 500px !important;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
.step7-image img { 
    height: 500px !important;
}
#step-17 .step17-image img {
    height: 500px !important;
}
#step-7 .solar-install {
    background-color: #fffbd0;
    padding:20px 10px;  
}
#step-18 .contact-form input{
    width:70% !important;
    margin: auto 72px;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
}
#step-18 .contact-form input[type="checkbox"] {
    width:34% !important;
    position: relative;
    right: 16px;
    animation-delay: 1.8s;
}
#step-18  .form-inner label {
    position: absolute;
    left: 100px;
}

#step-18 .submit-data{
    padding: 10px;
    background-color: #76b82a;
    color: #ffffff;
    border: 1px solid #76b82a;
    border-radius: 25px;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s, color 0.3s ease-in-out;
    width: 50%;
    margin: auto;
    position: relative;
    overflow: hidden;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 2.0s;
    font-family: 'Rubik';
}

#step-18 .submit-data:hover {
    background: #ffffff;
    color: #76b82a;
}

#step-18 .submit-data::before {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    height: 100%;
    width: 0%;
    background-color: #fff;
    transition: all 0.3s ease;
    z-index: -1;
    border-radius: 25px;
}

#step-18 .submit-data:hover::before {
    width: 100%;
}

#step-18 .form-inner {
    position: relative;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 1.8s;
}
#step-18 .contact-form .form-group input {
	background:#EFF1ED !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #000 !important;
    font-family: 'Rubik';
}

#step-18 .form-inner label.terms {
   font-size: 16px !important;
    font-weight: 400 !important;
    color: #000 !important; 
    font-family: 'Rubik';
}
#step-18 .contact-form .form-group:nth-child(1) input { animation-delay: 0.8s; }
#step-18 .contact-form .form-group:nth-child(2) input { animation-delay: 1.0s; }
#step-18 .contact-form .form-group:nth-child(3) input { animation-delay: 1.2s; }
#step-18 .contact-form .form-group:nth-child(4) input { animation-delay: 1.4s; }
#step-18 .contact-form .form-group:nth-child(5) input { animation-delay: 1.6s; }

/* Steps 5, 8, 11, 14 Specific */
#step-5 .step5-image img,
#step-8 .step8-image img,
#step-11 .step11-image img,
#step-14 .step14-image img {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
}
/* Steps 9, 15 Specific */
#step-9 .step9-image img,
#step-15 .step15-image img {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
	height:500px !important;
}

/* Steps 10, 13, 16 Specific */
#step-10 .step10-image img,
#step-13 .step13-image img,
#step-16 .step16-image img {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.8s;
	height:500px !important;
}

/* Step 17 Specific */
#step-17 .step17-image img {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.0s;
}

/* Step 18 Specific */
#step-18 .step18-form input.meter {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.8s;
}

#step-18 .step18-form .form-group table {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.0s;
}

#step-18 .step18-image img {
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
    animation-delay: 1.2s;
}
.direction-label {
    position: absolute;
    background-color: rgba(0, 0, 0, 0.8);
    color: white;
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 14px;
    font-weight: bold;
    z-index: 1000;
    border: 1px solid #fff;
}

.north {
    top: 20px;
    left: 50%;
    transform: translateX(-50%); 
}

.south {
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%); 
}

.east {
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}

.west {
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
}

#map-container {
    position: relative;
    overflow: hidden; 
}



.direction-label {
    text-align: center;
    font-weight: bold;
}

.solar-install {
    background-color: #fffbd0;
    border-style: solid;
    border-color: #e5e7eb;
    padding: 10px 10px;
}

#step-1 .step1-container .roof-type-options label.radio-option{
    position: relative;
    margin: 20px 75px !important;
} 
#step-1 .step1-container .radio-option input[type="radio"] {
    position: absolute;
    right: 17px;
}

.solar-simulator-wrapper #stpe-1 .image-inner .right p {
    line-height: 3.5px !important;
}
.form-group input.meter {
    width: 50% !important;
    border-radius: 5px !important;
    margin: auto 75px !important;
    border: 1px solid #76b82a !important;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.8s;
}
#step-4 .step4-options label.radio-option{
    justify-content: space-between;
}

.roof-type-options.option-inner {
    display:flex;
}

.roof-type-options.option-inner label.radio-option {
    width: 100% !important;
    margin: auto 72px;
}
.radio-inner .radio-option.invalid-border,
.option-inner .radio-option.invalid-border,
.roof-type-options .radio-option.invalid-border,
.form-group .meter.invalid-border,
.contact-form .form-group input.invalid-border {
    border-color: red !important;
}


.radio-inner .radio-option.invalid-border.active {
    border-color: unset !important;
}

.form-group .error-message {
    margin: 10px 70px !important;
}
.roof-type-options {
    display: flex;
    flex-direction: unset;
    gap: 20px;
    flex-wrap: wrap;
}
.nav-buttons {
    position: relative;
    bottom: 0px;
    width: 88%;
	text-align: center;
    right: 26%;
}
.nav-buttons .nxt-btn{
    padding: 10px 35px !important;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.4s;
	font-family: 'Rubik';
}

.nav-button.top {
    position: relative;
    top: 55px;
    border: unset !important;
    right: 20px;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.4s;
}
.top button#prevBtn {
    color: #334155;
    background: unset !important;
    border-radius: unset !important;
    border: unset !important;
    box-shadow: unset !important;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.6s ease-out forwards;
    animation-delay: 0.2s;
	    font-family: 'Rubik';
}
#step-4 .roof-type-options {
    display:flex;
}
label.radio-option {
    width: 47%;
    display: flex;
    justify-content: center;
}
.radio-option {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #f9f9f9;
    padding: 14px 20px;
    border-radius: 10px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color 0.3s, background 0.3s;
    font-weight: 500;
    font-size: 16px;
    opacity: 0;
    transform: translateY(20px);
    animation: slideUp 0.8s ease-out forwards;
}
.radio-option:nth-child(1) { animation-delay: 0.8s; }
.radio-option:nth-child(2) { animation-delay: 1.0s; }
.radio-option:nth-child(3) { animation-delay: 1.2s; }
.radio-option:nth-child(4) { animation-delay: 1.4s; }
.radio-option:nth-child(5) { animation-delay: 1.6s; }

.radio-option:hover {
    background: #f1f1f1;
}
.radio-option input[type="radio"] {
    transform: scale(1.3);
    accent-color: #4caf50;
}
.radio-option {
    display: flex;
    align-items: center;
    padding: 10px;
    border: 1px solid transparent;
    border-radius: 5px;
    transition: border 0.3s ease;
}

.radio-option input[type="radio"]:checked + .radio-icon + span,
.radio-option input[type="radio"]:checked + span {
    border: none;
}

.radio-option:has(input[type="radio"]:checked) {
    border: 1px solid black;
}
.error {
    color: red;
    font-size: 14px;
    margin-top: 5px;
    min-height: 20px;
    margin-left: 74px
}

button#nextBtn{
    background: #fff;
    color: #76b82a;
    border: 1px solid #76b82a;
    border-radius: 25px;
}
button#nextBtn:hover {
    background: #76b82a;
    color: #fff;
}

.right-hover {
  display: none;

}

.nxt-btn:hover .right-hover {
  display: inline-block;
}

.nxt-btn:hover .right-ch {
  display: none;
  opacity: 0;
  transform: translateY(20px);
  animation: slideUp 0.4s ease-out forwards;
  animation-delay: 0.6s;
}
img.right-ch {
    left: 18px;
    position: relative;
    bottom: 1px;
}

img.right-hover {
    left: 18px;
    position: relative;
    bottom: 1px;
}

.radio-option.active {
    background-color: #76b82a !important;
    color: white;
  }

  .nav-buttons .next-btn-mobile {
    display: none !important;
}

.step17-image img {
    max-width: 600px; 
    height: 600px;
}

#step-18 .step18-image img {
    max-width: 500px; 
    height: 500px !important;
}
.step18-form #energy-savings-table {
    width: 70%; 
    border-collapse: collapse; 
    margin-top: 15px;
}

.step18-container .total-save {
    margin-top: 20px; 
    margin-left: 75px;
}

  @keyframes slideUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

#address-suggestions {
    position: absolute;
    z-index: 1000;
    background: #ffffff;
    border: 1px solid #cccccc;
    max-height: 200px;
    overflow-y: auto;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    border-radius: 4px;
    margin-top: 5px;
    width: 69%;
    margin-left: 73px;
    max-width: 500px; /* Limit max width for larger screens */
}

/* Individual suggestion items */
#address-suggestions div {
    padding: 10px 15px;
    cursor: pointer;
    border-bottom: 1px solid #eeeeee;
    font-size: 14px;
    color: #333333;
    transition: background-color 0.2s ease;
}

#address-suggestions div:hover {
    background-color: #f0f0f0;
}


@media (max-width: 767px) {
	#step-1 {
    padding: 40px 15px !important;
}
	  #prevBtn mat-icon {
    display: inline !important;
  }

  #prevBtn img {
    display: none !important;
  }
	.solar-simulator-wrapper {
    padding-bottom: 60px; 
    }
	body.page-id-24489 .ekit-template-content-footer {
    display: none;
    }
	body.page-id-24489 .elementor-24489 .elementor-element.elementor-element-f6dcc5b {
	padding-bottom: 0px !important;
	}
	    .pre-btn>.mat-icon>svg {
    width: 14px;
    height: 14px;
    position: relative;
    top: 0px;
    }
	.nav-buttons {
        position: fixed;
        right: 0px !important;
        width: 100% !important;
    }
	button#nextBtn {
    max-width: 767px !important;
    width: 100%;
    border-radius: 0px !important;
}
	    h5 {
        font-size: 30px !important;
        font-weight: bold !important;
    }
	.step-form.active {
		padding-left: 15px !important;
		padding-right: 15px !important;
	} 
	 /*button#nextBtn {
        background-color: unset !important;
        border: unset !important;
		bottom: 24px;
    }
    
    .nav-buttons .next-btn-mobile {
        display: inline-block !important;
    }
    .nav-buttons {
        position: absolute ;
        top: 31px !important;
        width: auto !important;
        right: -20px;
    }
	*/
    .nav-button.top {
        top:0px !important;
		margin-top: 30px !important
    }
    .nav-buttons .nxt-btn img.right-ch, .nxt-btn img.right-hover {
        display: none !important;
    }
	
    button#nextBtn {
        color : #fff !important;
        border: none;
        background: #76b82a;
        box-shadow :unset;
    }
    button#nextBtn:hover {
        background: unset;
        color: unset;
    }
    .step1-container, .step2-container, .step3-container, .step4-container {
        display: block !important;
    }
    #step-1 label.radio-option {
        width: 100% !important;
    }
    .step5-container, .step6-container, .step7-container, .step8-container,
    .step9-container, .step10-container, .step11-container, 
    .step12-container, .step13-container, .step14-container, 
    .step15-container, .step16-container, .step17-container, .step18-container,
    .step19-container {
        display: flex !important;
        flex-direction: column !important;
    }
    .image-inner .left {
        display: contents;
    }


    .radio-inner{
        display: flex;
        flex-direction: column;
        flex-wrap: wrap;
        align-content: center;
        justify-content: center;
        width: 100%;
    }
    .roof-type-options.option-inner label.radio-option {
        width: 100% !important;
        margin: 0px !important;
        text-align: center;
    }
    #step-4 .step4-options label.radio-option {
        justify-content: center !important;
    }

    .step4-options.inner {
        display: flex;
        flex-direction: column;
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 20px;
        align-content: center;
        justify-content: center;
    }

    /* .step5-container {
        display: flex;
        gap: 30px;
        align-items: flex-start;
        margin-top: 20px;
        flex-direction: column;
    } */
    #step-1 .step1-container .roof-type-options label.radio-option {
        margin: 10px auto !important;
    }
    .address-btn {
        width: 100%;
        text-align: center;
    }
    .image-upload-box {
        text-align: center;
    }
    .leaflet-popup-content {
        margin: 10px 0px 10px 20px;
    }

    .nav-button .nxt-btn.mobile {
        display: block ;
    }
    @keyframes slideUp {
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
    #step-2 #address {
        width: 100% !important;
        margin-bottom: 5px;
        margin-left: 0px !important;
        text-align: center;
    }
    #step-2 button.search {
        width: 100% !important;
    }

    /**** south west east north ****/

  
    #confirm-options-1 .radio-option, #confirm-options-2 .radio-option, #confirm-options-3 .radio-option, #confirm-options-4 .radio-option{
        width : 40% !important;
    }
	   #step-1 .step1-container .image-upload-box,  #step-6 .step6-container .step6-image,
    #step-7 .step7-container .step7-image,  #step-9 .step9-container .step9-image,
    #step-10 .step10-container .step10-image, #step-12 .step12-container .step12-image,
    #step-13 .step13-container .step13-image, #step-15 .step15-container .step15-image,
    #step-16 .step16-container .step16-image, #step-17 .step17-container .step17-image,
    #step-18 .step18-container .step18-image
    {
        display: none !important;
    }
    #step-4 .step4-image,  #step-5 .step5-image, #step-8 .step8-image, 
    #step-11 .step11-image, #step-11 .step11-image, #step-14 .step14-image{
        display: flex;
        justify-content: center !important;
        width: 100%;
        margin-top: 20px;
    }
	#step-6 .roof-type-options.option-inner label.radio-option, #step-9 .roof-type-options.option-inner label.radio-option,
	#step-15 .roof-type-options.option-inner label.radio-option, #step-12 .roof-type-options.option-inner label.radio-option{
        margin: auto 72px !important;
    }
	 .submit-data {
        position: fixed !important;
        bottom: 0;
        left: 0;
        width: 100% !important ;
        max-width: 767px !important;
        
    }
	.step1-container .image-inner, .step2-container .image-inner, .step3-container .image-inner, .step4-container .image-inner,
	.step5-container .image-inner, .step6-container .image-inner, .step7-container .image-inner, .step8-container .image-inner,
	.step9-container .image-inner, .step10-container .image-inner, .step10-container .image-inner, .step11-container .image-inner, .step12-container .image-inner, .step13-container .image-inner, .step14-container .image-inner, .step15-container .image-inner, .step16-container .image-inner, .step17-container .image-inner, .step18-container .image-inner{
    margin-top: 0px !important;
	}
	button#nextBtn::before {
		background-color: #76b82a !important; 
		color: #fff !important;
		border-radius: 0px !important;
	}
	  #step-18 .submit-data {
    border-radius: inherit;
  }
}
@media (min-width: 320px) and (max-width: 450px) {


    /**** step 2 search button ****/
    #step-2 #address {
        width: 100% !important;
        margin-bottom: 5px;
        margin-left: 0px !important;
        text-align: center;
    }
    #step-2 button.search {
        width: 100% !important;
    }

    /**** south west east north ****/

  
    #confirm-options-1 .radio-option, #confirm-options-2 .radio-option, #confirm-options-3 .radio-option, #confirm-options-4 .radio-option{
        width : 40% !important;
    }
	.step1-container .image-inner, .step2-container .image-inner, .step3-container .image-inner, .step4-container .image-inner,
	.step5-container .image-inner{
		margin-top:0px !important;
	}
}

@media (min-width: 320px) and (max-width: 550px) {
    #step-4 .step4-image img, #step-5 .step5-image img, #step-6 .step6-image img, #step-7 .step7-image img,
    #step-8 .step8-image img, #step-9 .step9-image img, #step-10 .step10-image img, #step-11 .step11-image img,
    #step-11 .step11-image img, #step-12 .step12-image img, #step-13 .step13-image img, #step-14 .step14-image img,
    #step-15 .step15-image img, #step-16 .step16-image img, #step-17 .step17-image img, #step-18 .step18-image img {
        height:auto !important;
    }
    #step-18 .step18-image img {
        max-width: auto !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
	h5 {
    font-size: 36px !important;
    font-weight: bold !important;
}

#step-1 {
    padding: 80px 0px 0px !important;
}
    .step1-container label.radio-option span {
        font-size: 14px;
    }
    .address-btn {
        width: 100% !important;
    }
   
    #step-2 #address {
        width: 70% !important;
        margin-left: 74px !important;
        margin-bottom: 5px;
        text-align: center;
    }
    button.search {
        margin-left: 74px !important;
        width: 70% !important;
    }
    .image-inner .right {
        width: 75%;
    }
    .nav-buttons {
        position: relative;
        margin-left: 100px;
        margin-top: 25px
    }
	#step-1 label.radio-option {
    width: 88% !important;
	}
	#step-1 .image-upload-box img {
	height: 500px !important;
	}
    .step-form#step-1.active ~ .nav-buttons {
        position: relative; /* Margin for step 1 */
        margin-left: 100px;
    }

    #step-4 .step4-image img, #step-5 .step5-image img, #step-6 .step6-image img, #step-7 .step7-image img, 
    #step-8 .step8-image img, #step-9 .step9-image img, #step-10 .step10-image img,
    #step-11 .step-11-image img, #step-12 .step12-image img, #step-13 .step-13-image img, 
    #step-14 .step14-image img, #step-15 .step15-image img, #step-16 .step16-image img, #step-17 .step17-image img, 
    #step-18 .step18-image img, #step-19 .step19-image img{
        height:auto !important;
    }
    #step-18 .step18-image img {
        max-width:339px !important;
    }
    .step5-options #confirm-options-1, .step8-options #confirm-options-2,
    .step11-options #confirm-options-3, .step14-options #confirm-options-4{
        display: flex !important;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .step5-options #confirm-options-1 label.radio-option, .step8-options #confirm-options-2 label.radio-option,
    .step11-options #confirm-options-3 label.radio-option, .step14-options #confirm-options-4 label.radio-option {
        width: 45% !important;
    }

    #roof-style-options-1 label span, #roof-style-options-2 label span,
    #roof-style-options-3 label span, #roof-style-options-4 label span {
        text-align: center;
    }
    #roof-style-options-1 label, #roof-style-options-2 label,
    #roof-style-options-3 label, #roof-style-options-4 label {
        margin: auto;
    }

    .step18-container #energy-savings-table {
        width: 100%;
    }
    
    .step18-container .total-save {
        margin-top: 20px; 
        margin-left: 0px;
    }

}    

/* @media (min-width: 992px) and (max-width: 1024px) {
      .nav-buttons {
        position: static !important;
        margin-left: 100px;
        margin-top: 10px
    }
} */

@media (min-width: 992px) and (max-width: 1199px) {

	#step-1 {
    padding: 80px 0px 0px !important;
}
    .step-form#step-1.active ~ .nav-buttons {
        position: relative;
        margin-left: 100px;
    }

    .nav-buttons {
        position: relative;
        margin-left: 100px;
        margin-top: 20px;
    }
  
    #step-4 .step4-image img, #step-5 .step5-image img, #step-6 .step6-image img, #step7 .step7-image img, 
    #step-8 .step8-image img, #step-9 .step9-image img, #step-10 .step10-image img,
    #step-11 .step-11-image img, #step-12 .step12-image img, #step-13 .step-13-image img, 
    #step-14 .step14-image img, #step-15 .step15-image img, #step-16 .step16-image img, #step-17 .step17-image img, 
    #step-18 .step18-image img, #step-19 .step19-image img{
        height:auto !important;
    }
    #step-18 .step18-image img {
        max-width:450px !important;
    }
    
}

@media screen and (max-width: 768px) {
    #address-suggestions {
        max-height: 150px; /* Reduce height on smaller screens */
        font-size: 13px;
    }

    #address-suggestions div {
        padding: 8px 12px;
    }
}

@media screen and (max-width: 480px) {
    #address-suggestions {
        max-height: 120px; /* Further reduce height for mobile */
        border-radius: 2px;
        width: calc(100% - 20px); /* Adjust for padding/margins */
        margin-left: 10px;
        margin-right: 10px;
    }

    #address-suggestions div {
        padding: 6px 10px;
        font-size: 12px;
    }
}

/* Ensure suggestions align with input field */
.address-form {
    position: relative; /* Parent container for absolute positioning */
}

/*button#nextBtn {
    background-color: #76b82a;
    color: #fff;
    border: 1px solid #76b82a;
    border-radius: 25px;
    position: relative; 
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    overflow: hidden;
    transition: color 0.3s ease-in-out; 
}
button#nextBtn:hover {
    color: #76b82a;
}
button#nextBtn:hover::before {
    width: 100%;
}
button#nextBtn::before {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    height: 100%;
    width: 0%;
    background-color: #fff;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    z-index: -1;
    border-radius: 50px;
}
*/
  @media (min-width: 1600px) {
	  .nav-buttons {
		  right: 16% !important;
	  }
	  .solar-simulator-wrapper {
	  height:80vh;
	  }
}

@media (min-width: 1200px) and (max-width: 1370px) {

     .solar-simulator-wrapper {
	  /* height:90vh  !important; */
	  }
}