:root {
	--color-primary: #070441;
	--color-secondary: #FF5532;
	--font-heading: Lato;
}

body {
	font-family: var(--e-global-typography-text-font-family);
}

a {
	color: #333;
}

.roof-widget-heading .roof-heading-title {
	font-family: var(--font-heading);
}

.roof-heading-title h2 {
	margin: 0;
	font-size: inherit;
	font-weight: inherit;
	line-height: inherit;
}

.header-button {
	display: inline-block;
	padding: 10px 25px 10px 15px;
	border-radius: 40px;
	background-color: var(--color-secondary);
	color: #fff;
	font-family: var(--font-heading);
	text-transform: uppercase;
	transition: .2s;
}
.header-button i {
	display: inline-block;
	float: left;
	margin-top: 5px;
	margin-right: 5px;
	padding: 7px;
	border: 2px solid #fff;
	border-radius: 50%;
	font-size: 20px;
}
.header-button-text {
	display: inline-block;
	vertical-align: top;
	font-size: 20px;
	line-height: 24px;
	font-weight: 700;
	text-align: center;
}
.header-phone-number {
	font-size: 30px;
}
.header-button:hover {
	background-color: var(--color-primary);
	color: #fff;
}
.button-in-blue:hover {
	background-color: #333;
}

.roof-location-header .header-button {
	padding: 8px 22px 8px 12px;
}
.roof-location-header .header-button i {
	font-size: 16px;
}
.roof-location-header .header-button-text {
	font-size: 16px;
	line-height: 20px;
}
.roof-location-header .header-phone-number {
	font-size: 24px;
}

.elementskit-commentor-content ul.elementskit-stars {
	padding-left: 0;
}

.service-area {
	display: flex;
	flex-wrap: wrap;
	font-size: 16px;
}
.service-area ul {
	width: 16.66%;
	padding-left: 20px;
	font-weight: 500;
}
.service-area a {
	font-weight: 700;
}
.service-area a[href=""] {
	font-weight: 500;
}
@media (max-width: 1300px) and (min-width: 768px) {
	.service-area ul {
		width: 33.33%;
	}
	.service-col-1 {
		order: 1;
	}
	.service-col-2 {
		order: 4;
	}
	.service-col-3 {
		order: 2;
	}
	.service-col-4 {
		order: 5;
	}
	.service-col-5 {
		order: 3;
	}
	.service-col-6 {
		order: 6;
	}
}
@media (max-width: 767px) {
	.service-area ul {
		width: 100%;
	}
}

@media (max-width: 480px) {
	.slider-city {
		display: block;
	}
}

.step-ul {
	margin-bottom: 15px;
}
.step-ul:after {
	content: "";
	display: block;
	clear: both;
}
.step-ul li {
	float: left;
	width: 33.33%;
}

.service-ul {
	margin: 0 auto 15px;
	max-width: 950px;
}
.service-ul:after {
	content: "";
	display: block;
	clear: both;
}
.service-ul li {
	float: left;
	width: 50%;
}
@media (max-width: 991px) {
	.service-ul {
		max-width: 480px;
	}
	.service-ul li {
		width: 100%;
	}
}
@media (max-width: 480px) {
	.service-ul {
		font-size: 12px;
	}
}

#related-tag-list {
	list-style: none;
	padding-left: 0;
}
#related-tag-list li {
	display: inline-block;
}
#related-tag-list li a {
	display: block;
	padding: 0 10px;
	border: 1px solid #e6e6e6;
	border-radius: 5px;
	background-color: #f7f8f9;
}

.form-wrap {
	margin-left: auto;
	max-width: 480px;
	padding: 30px 20px;
	border-radius: 10px;
	box-shadow: 0 10px 20px rgb(0 0 0 / 20%);
	background-color: #fff;
	font-family: var(--font-heading);
}
.form-title {
	margin-bottom: 25px;
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 28px;
	font-weight: 700;
	line-height: 1;
	text-align: center;
}
.form-title:not(:first-child) {
	font-size: 32px;
}
.form-subtitle {
	margin-bottom: 15px;
	font-size: 16px;
	text-align: center;
}
.form-subtitle a {
	color: #333;
	font-size: 30px;
	font-weight: 700;
}
.roof .form-wrap hr {
	margin: 25px auto;
	width: 50%;
	height: 1px;
	border: none;
	background-color: #999;
}
.form-field:not(:last-child) {
	margin-bottom: 15px;
}
.form-field input,
.form-field textarea,
.form-field select {
	padding: 10px 10px !important;
	border-color: #ededed !important;
	background-color: #f7f8f9;
	color: #777;
	font-family: var(--font-heading);
	font-weight: 400 !important;
}
.form-field textarea {
	height: 60px;
}
.form-field select {
	padding-left: 5px !important;
	padding-right: 5px !important;
}
form input[type=button]{
	padding: 5px 30px !important;
	border: none;
	border-radius: 40px;
	background-color: transparent;
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 24px;
	font-weight: 700 !important;
}
form input[type=button]:focus {
	outline: none;
	background-color: transparent;
	color: var(--color-secondary);
}
form input[type=button]:hover {
	background-color: transparent;
	color: var(--color-secondary);
}
form input[type=submit] {
	padding: 5px 30px !important;
	border: none;
	border-radius: 40px;
	background-color: var(--color-secondary);
	color: #fff;
	font-family: var(--font-heading);
	font-size: 24px;
	font-weight: 700 !important;
}
form input[type=submit]:focus {
	outline: none;
	background-color: var(--color-primary);
}
form input[type=submit]:hover {
	background-color: var(--color-primary) !important;
}

.roof-post__read-more {
	display: inline-block;
	padding: 5px 20px;
	border-radius: 5px;
	background-color: var(--color-primary);
	transition: .2s;
}
.roof-post__read-more:hover {
	background-color: var(--color-secondary);
}

.text-section-1 {
	text-align: center;
}

.wpcf7 form.sent .wpcf7-response-output {
	margin-left: auto;
	margin-right: auto;
	max-width: 480px;
	border: none;
	background-color: var(--color-secondary);
	color: #fff;
	text-align: center;
}

.wpcf7 .ajax-loader {
	position: absolute;
}

.compare-form {
	border-radius: 8px;
	/*box-shadow: 0 4px 12px 0 rgb(0 0 0 / 10%);*/
	/*background-color: #fff;*/
	font-family: var(--font-heading);
	text-align: center;
}
.compare-form-title {
	margin-top: 0;
	margin-bottom: 0;
	color: #fff;
	font-size: 40px;
	font-weight: 700;
}
.compare-form-text {
	color: #fff;
	font-size: 18px;
}
#compare-form {
	position: relative;
	margin: 0 auto;
	max-width: 534px;
}
.compare-form input[type=text] {
	width: 100%;
	padding: 20px 20px 20px 60px;
	border-radius: 40px;
	font-size: 16px;
	line-height: 26px;
}
.compare-form input[type=submit] {
	position: absolute;
    top: 8px;
    right: 8px;
    padding: 0 24px !important;
    border-radius: 40px;
    background-color: var(--color-secondary);
    font-size: 16px;
    line-height: 52px !important;
}
.compare-form input[type=submit]:hover {
	background-color: var(--color-primary);
}
.search-icon {
	position: absolute;
	top: 20px;
	left: 30px;
	color: #2e2e2e;
}

.quote-form {
	color: #fff;
	font-family: var(--font-heading);
	text-align: center;
}
.quote-title {
	margin-bottom: 0;
	font-size: 40px;
	font-weight: 700;
}
.quote-subtitle {
	font-size: 40px;
}

.header-address {
	color: var(--color-primary);
	font-size: 24px;
	font-weight: 700;
	text-align: center;
}

.step-form-page {
	min-height: calc(100vh - 143px);
}
.step-form-wrap {
	margin-top: 80px;
	padding: 40px 10px;
	border-radius: 8px;
	box-shadow: 0 4px 12px 0 rgb(0 0 0 / 10%);
	background-color: #fff;
}
.step-form-title {
	margin-bottom: 40px;
	font-size: 28px;
	font-weight: 700;
	text-align: center;
	transition: .4s;
}
.form-icon-wrap {
	display: flex;
	justify-content: center;
	transition: .4s;
}
.form-icon {
	width: 200px;
	text-align: center;
}
.form-radio-wrap {
	transition: .4s;
}
.form-radio-wrap .wpcf7-radio {
	display: flex;
	justify-content: center;
}
.form-radio-wrap .wpcf7-radio .wpcf7-list-item {
	margin-left: 0;
	width: 200px;
	text-align: center;
}
.step-form-textarea textarea {
	height: 150px;
}
.step-form-field {
	margin: 20px auto 0;
	max-width: 320px;
}
.step-form-button {
	margin-top: 40px;
	text-align: center;
}
/*modify by Jfrost*/
input[type=date], input[type=email], input[type=number], input[type=password], input[type=search], input[type=tel], input[type=text], input[type=url], select, textarea {
    width: 100%;
    border: 1px solid #666;
    border-radius: 3px;
    padding: .5rem 1rem;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
[type=button]:focus, [type=button]:hover, [type=submit]:focus, [type=submit]:hover, button:focus, button:hover {
    color: #fff !important;
    background-color: #c36 !important;
    text-decoration: none !important;
}
@media (max-width: 768px){

}
@media (max-width: 422px){
    form input[type=submit] {
        font-size: 18px;
        padding: 5px 20px;
    }
    .header-button-text {
    	font-size: 16px;
    }
    .header-phone-number {
        font-size: 22px;
    }
    .form-title {
        font-size: 20px !important;
    }
}