/*!
Theme Name: Estate Roofing Inc Hello Elementor Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Description: A plain-vanilla & lightweight theme for Elementor page builder
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Template: hello-elementor
Version: 1.0.0
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Text Domain: hello-elementor
*/


.our-service .elementor-image-box-content {
    padding: 20px;
}
.our-service a {
    background: #a0803c;
    padding: 8px 20px 8px 20px;
    color: #fff;
    text-transform: uppercase;
    font-weight: 700;
    display: inline-block;
    margin-top: 20px;
}
.our-service a:hover{
	background: #1d1d1d;
}
.our-service .fin-avl a:hover{
	background:transparent;
}
.our-service .rvw-btn a {
	display:block;
    margin-top: 0;
}
.our-service .elementor-image-box-wrapper {
    height: 430px;
    text-align: left;
}
.footer-sec ul {
	display: grid;
  grid-template-columns: repeat(2, 1fr); /* 6 columns */
  gap: 10px;
  list-style: none;
  padding: 0;
  color: #fff;
}
.footer-sec a{color:#fff;}

.header-sec .menu-item-57 a {
    background: #a0803c !important;
    display: block;
    padding: 16px 20px 16px 20px !important;
    color: #fff !important;
    text-transform: uppercase;
    font-size: 20px;
    font-weight: 600 !important;
}
.header-sec .menu-item-57 a:hover{
	background: #1d1d1d !important;
}
.header-sec li.menu-item.menu-item-type-post_type.menu-item-object-page {
    font-size: 17px;
}
.roofind-sec ul {
    padding-bottom: 15px;
	list-style-type: disc;
} 

.roofind-sec p {
    margin-bottom: 5px;
}

.sub-heading {
    padding-left: 40px;
    position: relative;
}
.sub-heading:before {
    content: "";
    position: absolute;
    height: 10px;
    width: 30px;
    background: #a0803c;
    left: 0;
    border-radius: 20px;
    outline: 1px solid #a0803c;
    outline-offset: 2px;
	top: 5px;
}
.slider-sec .swiper-pagination-bullet {
    content: "";
    height: 10px !important;
    width: 10px !important;
    background: #fff !important;
    border-radius: 20px;
    opacity: 9;
    outline-offset: 6px;
}
.testimonialslider .owl-dots button span{
	height: 10px !important;
    width: 10px !important;
    background: #d1d1d1 !important;
    border-radius: 20px;
    opacity: 1;
    outline-offset: 6px;
}
.testimonialslider .owl-dots {
    margin-top: 30px !important;
}
.testimonialslider .owl-dots button.active span{
    background: #a0803c !important;
	outline: 1px solid #a0803c;
}
.slider-sec .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: #a0803c !important;
	outline: 1px solid #a0803c;
}
.our-service .e-widget-swiper .elementor-swiper-button.elementor-swiper-button-prev {
    right: 60px !important;
}
.our-service .e-widget-swiper .elementor-swiper-button {
    top: -50px !important;
    right: 0 !important;
    width: 50px;
    height: 50px;
    align-items: center;
    justify-content: center;
    left: auto !important;
    border-radius: 50%;
    opacity: 1 !important;
    border: 2px solid #fff !important;
}
.our-service .e-widget-swiper .elementor-swiper-button:hover {
    background-color: #a0803c;
    border: 2px solid #a0803c !important;
}

.logo-sec figure.swiper-slide-inner img {
    border: 1px solid #8B8B8B;
    padding: 6px;
    height: 150px !important;
    object-fit: contain !important;
    width: 150px !important;
}
.home-review-text.elementor-widget.elementor-widget-text-editor {
    height: 200px;
    overflow-y: scroll !important;
}

.review-sec .swiper-pagination-bullet {
    content: "";
    height: 10px !important;
    width: 10px !important;
    background: #8b8b8b !important;
    border-radius: 20px;
    opacity: 9;
    outline-offset: 6px;
}
.review-sec .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: #a0803c !important;
	outline: 1px solid #a0803c;
}

.review-sec .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    margin-top: 30px;
}
.service-sec .elementor-icon-box-wrapper{
    position: relative;
}
.service-sec .elementor-icon-box-icon {
    background: #a0803c;
    height: 80px;
    width: 80px;
    display: inline-flex;
    position: absolute;
    top: -100px;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
}

.service-sec p {
    padding: 0;
    margin: 0;
}
a.read-more {
    font-weight: 600;
    font-size: 18px;
}
a.read-more:hover{
	color:#1d1d1d;
}
.e-n-accordion-item {
    border-radius: 10px;
    border: 1px solid #e5e2e2;
}
.call-us-sec .elementor-icon-box-icon {
    background: #a0803c !important;
    padding: 20px;
    border-radius: 100px;
}
.call-us-sec a {
    color: #1d1d1d !important;
    font-weight: 600;
}
.service-item li {
    border-radius: 20px;
    border: 1px solid #CCC4C4 !important;
    margin-bottom: 10px !important;
}



#header.sticky {
    position: fixed!Important;
    width: 100%;
    top: 0;
    background: #fff;
	animation: smoothHeader 1s forwards;
    z-index: 999;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
}
#header.sticky img{
	width: 70%;
}
#header.sticky ul li a{
	font-size:17px;
}

.about-sec span.elementor-icon-list-icon {
    margin-bottom: 10px;
    color: #fff !important;
    border-radius: 100px;
    height: 30px;
    width: 30px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #000;
}

.roofing-item .elementor-icon {
    height: 80px;
    width: 80px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
    border: 1px solid #fff;
}
.contact-us .elementor-icon {
    height: 60px;
    width: 60px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
    border: 1px solid #a0803c;
}
.contact-us a {
    color: #4a4a4a !important;
}
.service-item li:hover {
    background: #a0803c;
	color:#fff !important;
}
.service-item li a:hover {
	color:#fff !important;
}
.latest-post article {
    border-bottom: 1px solid #dfe1e7;
    padding-bottom: 10px !important;
}
.hm-fr-qt {
    position: relative;
    z-index: 9;
}
.hm-fr-qt:before {
    content: '';
    width: 12%;
    height: 110%;
    background-color: #ffffff;
    position: absolute;
    left: -30px;
    transform: rotate(10deg);
    z-index: 0;
    top: 2px;
    border-left: 10px solid #a0803c;
}
.overflow-hidden{
overflow:hidden;
}

.fin-avl::before {
    width: 65%;
    left: 20%;
    transform: skew(60deg, -15deg);
    height: 150%;
    top: -110px;
}

.form-sec .gform_legacy_markup_wrapper h3.gform_title {
    letter-spacing: normal!important;
    margin: 10px 0 6px 0;
    text-align: center;
    font-size: 40px;
}

.form-sec .gform_legacy_markup_wrapper label.gfield_label, .form-sec .gform_legacy_markup_wrapper legend.gfield_label, .form-sec label {
    font-weight: 700;
    font-size: inherit;
}




@keyframes smoothHeader {
	0% {
		transform: translateY(-40px);
	}
	100% {
		transform: translateY(0px);
	}
}
@-webkit-keyframes smoothHeader {
	0% {
		transform: translateY(-40px);
	}
	100% {
		transform: translateY(0px);
	}
}
@-moz-keyframes smoothHeader {
	0% {
		transform: translateY(-40px);
	}
	100% {
		transform: translateY(0px);
	}
}
@-o-keyframes smoothHeader {
	0% {
		transform: translateY(-40px);
	}
	100% {
		transform: translateY(0px);
	}
}
.foot-serv .elementor-item {
    position: relative;
}
.foot-serv .elementor-item:before {
    position: absolute;
    content: '';
    width: 12px;
    height: 12px;
    background-image: url('images/hail-damage-roof-repair-nj.svg');
    background-size: contain;
    left: 0;
    background-repeat: no-repeat;
    top: 5px;
	opacity:1 !important;
}
.rafq-form .gform_title {
    margin-top: 0;
    font-size: 30px;
    font-weight: 700;
    text-align: center;
}
.rafq-form .gform-theme--foundation .gform_fields {
    column-gap: 15px;
	row-gap: 0px;
}
.rafq-form input[type="text"],
.rafq-form input[type="tel"],
.rafq-form input[type="email"],
.rafq-form textarea {
    padding: 15px !important;
    border: 1px solid #1d1d1d !important;
    outline: 0 !important;
    height: 45px !important;
    border-radius: 0 !important;
}
.form-sec input[type="text"],
.form-sec input[type="email"],
.form-sec input[type="tel"],
.form-sec input[type="number"],
.form-sec select,
.form-sec input[type="file"],
.form-sec textarea{
    border: 1px solid #1d1d1d !important;
    outline: 0 !important;
    border-radius: 0 !important;
	background-color:#fff !important;
}
.form-sec input[type="text"],
.form-sec input[type="email"],
.form-sec input[type="tel"],
.form-sec input[type="number"],
.form-sec select,
.form-sec input[type="file"]{
    height: 45px !important;
}
.form-sec input[type="text"],
.form-sec input[type="email"],
.form-sec input[type="tel"],
.form-sec input[type="number"],
.form-sec textarea{
	padding: 15px !important;
}
.form-sec input[type="file"]{
	padding:7px !important;
}
.rafq-form input[type="text"]:focus,
.rafq-form input[type="tel"]:focus,
.rafq-form input[type="email"]:focus,
.rafq-form textarea:focus,
.form-sec input[type="text"]:focus,
.form-sec input[type="email"]:focus,
.form-sec input[type="tel"]:focus,
.form-sec input[type="number"]:focus,
.form-sec select:focus,
.form-sec input[type="file"]:focus,
.form-sec textarea:focus{
    border-color: #a0803c !important;
}
.gfield_error input[type="text"],
.gfield_error input[type="tel"],
.gfield_error input[type="email"],
.gfield_error textarea:focus,
.gfield_error input[type="text"],
.gfield_error input[type="email"],
.gfield_error input[type="tel"],
.gfield_error input[type="number"],
.gfield_error select:focus,
.gfield_error input[type="file"],
.gfield_error textarea{
	border-color:red !important;
}
.rafq-form .gform-footer input[type="submit"],
.form-sec input[type="submit"] {
    background-color: #a0803c !important;
    border-radius: 0 !important;
    font-size: 18px !Important;
    outline: 0 !important;
	border: 0 !important;
    height: auto !important;
    padding: 10px 20px !important;
    text-transform: uppercase !important;
}
.rafq-form .gform-footer input[type="submit"]:hover,
.form-sec input[type="submit"]:hover{
    background-color: #1d1d1d !important;
}
.rafq-form .gfield_label {
    display: inline-block !important;
    margin-bottom: 0 !important;
    position: relative;
    bottom: -10px !important;
    left: 15px;
    background-color: #fff;
    padding: 0 4px;
}
.rafq-form .gfield_required .gfield_required_text {
    display: none;
}
.rafq-form .gfield_required:after {
    content: '*';
    margin-left: 3px;
}
.rafq-form .gform-footer {
    justify-content: center;
}
.validation_message,
.gform_validation_errors{
    display: none !important;
}
.gform_legacy_markup_wrapper li.gfield.gfield_error,
.gform_legacy_markup_wrapper li.gfield.gfield_error.gfield_contains_required.gfield_creditcard_warning {
    background-color: transparent !important;
    margin-bottom: 0px !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
}
.elementor-element.elementor-element-4b4e954.e-con-full.e-flex.e-con.e-child {
    border: 2px solid #a0803c;
}
.elementor-element-4b4e954 .gform_confirmation_message_1.gform_confirmation_message {
    font-weight: 700;
}
.fin-logo img {
    background-color: #fff;
    padding: 5px;
}
.our-service .fin-avl a {
    margin-top: 0;
}
.our-service .fin-avl p {
    margin: 0;
}
.our-service .fin-avl .elementor-icon-box-icon a,
.our-service .fin-avl .elementor-icon-box-title a{
	padding:0;
}
.review-page-grid .review-grid {
    background-color: #f7f7f7;
    padding: 20px;
    display: block;
    margin-bottom: 10px;
    position: relative;
    border: 2px solid #eee;
	border-radius: 10px;
}
.review-page-grid .review-grid:before {
    content: '';
    position: absolute;
    width: 100px;
    height: 100px;
    right: 20px;
    top: 20px;
    background-image: url('images/start-quote.png');
    background-color: #f3f3f3;
    border-radius: 50%;
	transition: 0.5s ease-in-out;
	background-size: contain;
}

.review-page-grid .review-grid:hover:before {
    transform:rotate(360deg);
}

.name-with-desg h4 {
    margin: 0;
	font-weight:700;
	font-size:22px;
}
.name-with-desg h6{
	margin: 0;
}
.name-with-desg p {
    font-size: 15px;
    margin: 0;
}
.review-from img {
    width: 60px;
    height: 60px;
    background-color: #fff;
    padding: 5px;
    border-radius: 50%;
	box-shadow: 1px 1px 5px -1px #000;
}
.item .review-from img{
	width: 50px !important;
    height: 50px;
	padding: 3px;
}
.testimonial-user {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 10px;
    padding-bottom: 40px;
    background-image: url('images/metal-roofing-nj.png');
    background-repeat: no-repeat;
    background-size: 130px;
    background-position: 5px 90%;
}
.item .testimonial-user {
    background-size: 110px;
    background-position: 5px 95%;
}
.item .testimonial-review .right_sec {
    height: 200px;
    overflow-y: scroll;
}
.item .testimonial-review .right_sec p{
	padding-right:10px;
}
.item .testimonial-review .right_sec::-webkit-scrollbar {
  width: 5px;
}
.item .testimonial-review .right_sec::-webkit-scrollbar-track {
  background-color:#d9d9d9;
  border-radius: 50px;
}
.item .testimonial-review .right_sec::-webkit-scrollbar-thumb {
  background: #a0803c; 
  border-radius: 50px;
}
.item .testimonial-review .right_sec::-webkit-scrollbar-thumb:hover {
  background: #1d1d1d; 
}
.testimonialslider .item {
    padding: 4px;
}
.item .testimonial-review {
    box-shadow: 1px 1px 11px -5px #000;
    padding: 10px 0 0 10px;
    background-color: #fff;
}
.srv-pg-bx .elementor-icon-box-description .read-more {
    display: block;
    margin-top: 24px;
    width: max-content;
    position: relative;
}
.srv-pg-bx .elementor-icon-box-description .read-more:after {
    content: '';
    background-image: url('images/arrow-right.svg');
    width: 20px;
    height: 12px;
    display: inline-block;
    background-repeat: no-repeat;
    background-size: contain;
    top: 1px;
    position: relative;
    left: 8px;
}
.srv-pg-bx .elementor-icon-box-description .read-more:hover:after{
	filter: brightness(0);
}
.srv-pg-bx .elementor-icon svg {
    transition: 0.3s ease-in-out;
}
.srv-pg-bx:hover .elementor-icon svg {
    transform:scaleX(-1);
}
.our-service .elementor-image-box-wrapper {
    position: relative;
}
.our-service  .elementor-image-box-description a {
    position: absolute;
    bottom: 20px;
    left: 20px;
}
.job-bx .elementor-widget-icon-box .elementor-widget-container .elementor-icon-box-title {
    min-height: 53px;
}



@media(max-width:1199px){
	.our-service .elementor-image-box-content {
    padding: 5px 20px 20px 20px;
}
	.fin-avl::before {
    width: 80%;
    left: 14%;
    transform: skew(21deg, -15deg);
	height: 206%;
}
}
@media(max-width:1024px){
	.srv-pg-bx .elementor-icon-box-description .read-more:after {
    height: 10px;
}
	a.read-more {
    font-size: 16px;
}
.hm-fr-qt:before {
    width: 15%;
    left: -27px;
    top: -2px;
}
}
@media(max-width:1023px){
	.our-service .elementor-image-box-img img {
    width: 100%;
}
.our-service .elementor-image-box-wrapper {
    height: 450px;
}
}




@media(max-width:767px){
	
	
	.job-bx .elementor-widget-icon-box .elementor-widget-container .elementor-icon-box-title {
    min-height: auto;
}
	.sub-heading p {
    margin: 0;
}
	.review-page-grid .review-grid:before {
    width: 60px;
    height: 60px;    
}
	.testimonialslider .owl-dots {
    display: none;
}
	.call-us-sec .elementor-icon-box-icon {
	background: #a0803c !important;
	padding: 15px;
	border-radius: 50%;
	height: 60px;
	width: 60px;
}
	.hm-fr-qt:before{
		display:none;
	}
	.fin-avl::before {
    width: 100%;
    left: 0;
    transform: skew(0deg, 0deg);
    height: 150vh;
}
	.footer-sec ul {
    grid-template-columns: repeat(1, 1fr);
}
.hm-fr-qt:before {
    display:none;
}
.our-service .e-widget-swiper .elementor-swiper-button {
	right: 0 !important;
	width: 35px;
	height: 35px;
	top: -30px !important;
}
.our-service .e-widget-swiper .elementor-swiper-button.elementor-swiper-button-prev {
    right: 40px !important;
}
.our-service .e-widget-swiper .elementor-swiper-button svg {
    width: 8px;
}

.our-service .elementor-image-box-img img {
	width: 100% !important;
}
.our-service .elementor-image-box-wrapper {
	height: auto !important;
}
}

@media(max-width:766px){
	.our-service .elementor-image-box-content {
    height: 180px;
}
}
@media(max-width:575px){
	.our-service .elementor-image-box-content .elementor-image-box-title {
    margin: 0 0 5px 0 !important;
}
	.our-service  .elementor-image-box-description a {
    bottom: 10px;
    left: 10px;
}
	.our-service .elementor-image-box-content {
    padding: 0px 10px 0px 10px;
}
}

