/* Responsive */


@media (max-width: 1199px) {}

@media (max-width: 991px) {
	.full-screen-menu 
	{
		display: none; 
	}
	
	.mobile-menu 
	{
		display: block !important; 
	}
  .logo {
    width: 100px;
    display: block;
  }

  .sticky .logo {
    width: 100px;
  }

  .nav_holder {
    padding: 10px 0;
  }

  .hdr_menu {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: 400px;
    transform: translateX(100%);
    background: #fff;
    overflow-y: auto;
    transition: transform 0.5s cubic-bezier(0.07, 0.23, 0.34, 1);
    padding: 10px 15px 20px;
    z-index: 99;
  }

  .hdr_menu ul {
    padding-top: 50px;
  }

  .hdr_menu ul li {
    width: 100%;
    transition: all 0.4s ease-in-out;
  }

  .hdr_menu ul li.menu-item-has-children .sub-menu {
    display: block;
    position: static;
    opacity: 1;
    visibility: visible;
    width: 100%;
    padding: 0px 10px 0;
    background-color: transparent;
    box-shadow: none;
    transform: none;
    transition: initial !important;
    -webkit-transition: initial !important;
  }

  .hdr_menu ul li.menu-item-has-children ul li {
    padding: 5px 0;
    line-height: 1.5;
  }

  .hdr_menu li {
    margin-right: 0;
    padding-right: 0;
    border: 0;
    margin-bottom: 0px;
  }

  .hdr_menu li a {
    font-size: 15px;
    font-weight: 400;
    display: block;
    color: #000000;
    padding: 5px 0;
  }

  .hdr_menu li a:hover {
    color: #688238 !important;
  }

  .hdr_menu li a::before {
    display: none;
  }

  .hdr_menu li:hover a {
    color: #000000 !important;
  }



  .hdr_menu li.menu-item-has-children .sub-menu a {
    color: #000;
    font-size: 15px;
  }

  .hdr_menu li.menu-item-has-children .sub-menu a:hover {
    color: #688238;
    padding-left: 0;
  }

  .hdr_menu li.menu-item-has-children.current-menu-item>a {
    color: #688238;
  }

  .hdr_menu li.menu-item-has-children.current-menu-item>a:hover {
    color: #688238;
  }

  .hdr_menu li>a::after {
    display: none;
  }

  .sticky .hdr_menu li.current-menu-item a {
    color: #688238;
  }

  .sticky .hdr_menu li:hover a {
    color: #688238;
  }

  .sticky .hdr_menu li a {
    color: #000000;
    background-color: transparent;
  }

  .menu_btn {
    width: 30px;
    display: block;
	  cursor: pointer; 
  }

  .menu_btn span {
    height: 2px;
    display: block;
    background: var(--primary-color);
    margin-left: auto;
    transition: 0.4s;
  }

  .menu_btn span:nth-child(2) {
    width: 80%;
  }

  .menu_btn span+span {
    margin-top: 5px;
  }

  .menu_trigger {
    position: absolute;
    right: 0;
    top: 50%;
    z-index: 100;
    transform: translateY(-50%);
  }

  .mobile_menu_active {
    overflow: hidden;
  }

  .mobile_menu_active .menu_trigger {
    right: 15px;
    top: 40px;
    transform: none;
    position: fixed;
  }

  .mobile_menu_active .hdr_menu {
    transform: translateX(0px);
  }

  .mobile_menu_active .overlay {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 30;
  }

  .mobile_menu_active .menu_btn span {
    background: #688238;
  }

  .mobile_menu_active .menu_btn span:first-child {
    transform: rotate(45deg);
  }

  .mobile_menu_active .menu_btn span:last-child {
    transform: rotate(-45deg);
  }

  .mobile_menu_active .menu_btn span:nth-child(2) {
    display: none;
  }

  .mobile_menu_active .menu_btn span+span {
    margin-top: -2px;
    width: 100%;
  }

  .mobile_menu_active .hddr_inr {
    position: static;
  }

  .mobile_menu_active .sticky .nav_holder {
    position: fixed;
  }

  .mobile_menu_active .nav_inr {
    position: static;
  }

  .overlay {
    overflow: hidden;
  }

  .nav_inr {
    position: relative;
  }

  .sub_menu_opener {
    display: block;
    pointer-events: none;
  }

  .responisve-logo {
    display: block;
    width: 270px;
  }

  .header-social-list-outer {
    display: none;
  }

  .header-social-list-outer.responsive-header-social-btn {
    margin-bottom: 15px;
    display: flex;
    justify-content: center;
  }

  .responsive-menu-additional-components {
    position: relative;
    bottom: 0px;
    left: 0px;
    right: 0px;
    justify-content: center;
    flex-direction: column;
    text-align: center;
	 margin-top: 15px; 
  }

  .header-start-project-btn {
    margin-left: 0;
    margin-right: 50px;
  }

  .top-header-logo {
    display: none;
  }

  .header-top-bar-outer .header-top-bar-holder .top-header-right-content {
    margin-left: 0;
    justify-content: space-between;
    width: 100%;
  }

  .contact-btn {
    margin-right: 50px;
  }

  .hdr_menu li.menu-item-has-children .sub-menu li.current-menu-item a {
    padding-left: 0;
  }

  .header-contact-btn {
    margin-right: 60px;
  }

  .responsive-menu-additional-components .header-social-links {
    display: block;
  }



  .our-service-box img {
    width: 100%;
	   
  }

  .roofing-checklist-pic {
    margin-bottom: 30px;
  }

  .roofing-cta-pic {
    display: none;
  }

  .why-hire-us-pic img {
    width: 100%;
  }

  .why-hire-us-wrapper .row:nth-child(even) .why-hire-us-content-list-outer {
    padding-right: 0;
    padding-left: 0;
  }

  .why-hire-us-content-list-outer {
    padding-right: 0;
  }

  .how-to-start-roofing-service-wrapper .row {
    flex-direction: column-reverse;
  }

  .how-to-start-roofing-service-pic {
    margin-bottom: 30px;
  }

  .how-to-start-roofing-service-pic img {
    width: 100%;
  }

  .home-contact-us-form-outer {
    max-width: 100%;
    margin-top: 35px;
  }
	
	.our-service-box .service-data {
	min-height: auto; 
}
	
	.page-template-template-about .mar-top20 
	{
		margin-top: 20px; 
	}
	
	.header-social-links a 
	{
		color: #FFF !important; 
	}
	
	.mobile-phone-number 
	{
		display: block !important;
		margin-top: 10px;
	}
	
	
	.header-social-links ul
	{
		display: flex; 
		padding: 0;
		justify-content: center;
	}
	
	.header-social-links ul li 
	{
		width: auto !important;
		margin:0 5px; 
	}
	.header-social-links ul li a 
	{
		background-color: var(--primary-color) !important;
	}
}

@media (max-width: 767px) {
  body {
    font-size: 16px;
    line-height: 26px;
  }

  .input-field {
    margin-bottom: 15px;
  }

  .banner-wrapper {
    padding: 150px 0 60px;
  }

  .banner-wrapper .banner-text {
    position: relative;
    z-index: 2;
  }

  .banner-wrapper .banner-text h1 {
    font-size: 32px;
    color: #fff;
  }

  .banner-wrapper .banner-text p {
    color: #fff;
    font-size: 16px;
  }


  .section-padding {
    padding: 50px 0;
  }

  .section-heading h2 {
    font-size: 28px;
    margin-bottom: 15px;
  }

  .header-contact-btn .btn-primary {
    display: block;
	      padding: 10px 6px;
    font-size: 15px;
  }

  .header-contact-btn .btn-secondary {
    font-size: 15px;
    padding: 7px 12px;
	  display: none; 
  }

  .responisve-logo img {
    -webkit-filter: brightness(0);
    filter: brightness(0);
  }

  .banner-wrapper .banner-content-outer {
    display: block;
  }

  .banner-quick-links-outer {
    margin-top: 30px;
    display: flex;
    justify-content: center;
    gap: 12px;
  }

  .banner-quick-links-outer .quick-links-block {
    width: 50%;
    max-width: 100%;
  }

  .our-service-box .service-data {
    left: 0;
    max-width: 100%;
    right: 0;
    padding: 0 20px;
  }

  .our-services-wrapper .action-btn {
    margin-top: 0;
  }

  .cta-content h2 {
    font-size: 28px;
  }

  .roofing-cta-wrapper {
    padding: 30px 0;
    background-color: #e5ecf4;
    background-image: none;
  }

  .why-hire-us-content-list-outer .list-item h3 {
    font-size: 21px;
    padding-left: 38px;
  }

  .why-hire-us-content-list-outer .list-item .number p {
    font-size: 24px;
  }

  .why-hire-us-content-list-outer .list-item .number {
    top: 2px;
  }

  .home-contact-us-form-outer {
    padding: 25px 15px;
  }

  .footer-bottom-row .holder {
    flex-direction: column;
    text-align: center;
  }

  .copyright-text {
    margin-top: 20px;
  }

  .types-of-service-wrapper {
    padding: 40px 0;
  }

  .service-types-list-outer .list-item h3 {
    font-size: 19px;
  }

  .service-cta-wrapper {
    margin: 50px 0 0 0;
  }

  .when-service-required-row [class*=col-]:nth-child(4),
  .when-service-required-row [class*=col-]:nth-child(5) {
    flex: 0 0 auto;
    width: 100%;
  }

  .service-we-offer-wrapper .section-heading h2 {
    font-size: 28px;
  }

  .faq_acrdn .accordion-item .accordion-header .accordion-button {
    font-size: 17px;
  }

  .related-servie-list ul {
    -moz-column-count: 2;
    column-count: 2;
  }

  .related-servie-list li {
    width: 100%;
    display: block;
    margin-right: 0;
    margin-bottom: 10px;
  }

  .related-servie-list li a {
    display: block;
    font-size: 16px;
    padding: 10px 12px;
  }

  .related-servie-list li a::before {
    display: none;
  }

  .recent-post-list a {
    margin-bottom: 15px;
    width: 100%;
  }

  .recent-post-wrapper {
    padding-bottom: 30px;
  }

  .recent-post-wrapper .title p,
  .related-service-wrapper .title p {
    font-size: 27px;
    margin-bottom: 25px;
  }

  .footer-top-row {
    padding: 40px 0 20px;
  }
	
	.table 
	{
		display: block;
		overflow-x: auto;
	}
	
	.our-service-box 
	{
		margin-bottom: 30px; 
	}
	
	 .our-service-box figure {
 
    min-height: 550px;
}
	
	.our-service-box img {
     
	  height: 550px; 
  }
	
	
	.table tr td 
	{
		padding:5px; 
		font-size: 14px; 
	}
	
	
}


@media (max-width: 575.98px) { 
	
.related-servie-list ul {
    -moz-column-count: 1;
    column-count: 1;
}
	
	.table tr td {
    padding: 3px;
    font-size: 10px;
}
	
	.service-two-row 
{
	column-count: 1;
}
	
	.floting-phone {
    display: flex !important;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
    background: #000;
    padding: 13px 10px;
    color: #FFF;
    z-index: 9;
    align-items: center;
    justify-content: center;
}
	
	.floting-phone i {
    color: #fff!important;
    background: #d62e2e;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    margin-right: 14px;
    border-radius: 3px;
}
	
	footer {
    margin-bottom: 50px;
}
	
	
	
}

@media (max-width: 359.98px) { 
	
	.header-contact-btn .btn-primary {
     
	      padding: 10px 0px;
    font-size: 12px;
  }
	
	.service-details-content table tr th, .service-details-content table tr td {
    padding: 5px;
    border: 1px solid #e5e5e5;
    line-height: 22px;
    font-size: 11px;
}
	
	
}

