/*
Theme Name: Twenty Twenty-One Child
Description: Child theme for Twenty Twenty-One — front-page services slider
Author:      Viktor
Template:    twentytwentyone
Version:     1.0.0
Text Domain: twentytwentyone-child
*/

/* --------- Custom styles for services slider --------- */
/* Keep minimal reset here; full styles are in inline CSS of template (you can move them) */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&display=swap');
a:focus, a:checked, button:focus, input:focus {outline: 0px dotted currentColor !important;}
a:hover {
    text-decoration-style: none !important;
    text-decoration-skip-ink: none;
}
.services-slider-block { padding:10px 20px; max-width:1720px; margin:0 auto; font-family: 'Manrope', sans-serif; margin-top: 50px; }
.services-slider-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:18px; gap:20px; }
.services-slider-title .ss-title { margin:0; font-size:58px; }
.services-slider-title .ss-subtitle { margin:6px 0 0; color:#70797D; font-size:18px; }
a[href^="tel"] {
    color: inherit !important;
    text-decoration: none !important;
}
a:focus {
    outline: none !important;
    box-shadow: none !important;
}
a:focus-visible {
    outline: none !important;
}
a:active,
a:focus {
    outline: none !important;
}
.custom-logo-link:focus,
.custom-logo-link:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}
.custom-logo,
.custom-logo:focus,
.custom-logo:active,
.custom-logo:focus-visible {
    outline: none !important;
    border: 0 !important;
    box-shadow: none !important;
}
a:focus,
a:active,
a:focus-visible,
a:focus:not(:focus-visible),
a:visited,
img:focus,
img:active,
img:visited,
img:focus-visible,
img:focus:not(:focus-visible),
.custom-logo-link,
.custom-logo-link:focus,
.custom-logo-link:active,
.custom-logo-link:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
	text-decoration-style: solid !important;
}
*:focus,
*:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}

/* Controls */
.services-slider-controls { display:flex; gap:10px; align-items:center; }
.ss-arrow {
    border: 0;
    background-color: #0e1a2208 !important;
    padding: 16px;
    border-radius: 999px;
    cursor: pointer;
    line-height: 17px;
}
.irs-arrow-img {
    width: 20px; 
    height: 22px;
    color: #80888F; 
    transition: color 0.3s ease;
}
.ss-arrow:hover {
    background-color: #0e1a221a !important;
}
.ss-arrow:hover .irs-arrow-img {
    color: #1A2026; 
}

/* Slides */
.services-swiper { position:relative; padding: 30px 0px !important; }
.swiper-wrapper { align-items:stretch; }
.ss-item { width:auto; }
.ss-card { display:block; border-radius:8px; overflow:hidden; text-decoration:none; color:inherit; }
.ss-thumb { position:relative; height:220px; background-size:cover; background-position:center; transition:transform .35s ease; }
.ss-overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.4) 100%); pointer-events:none; }
.ss-info { position:absolute; left:0; right:0; bottom:0; padding:14px; color:#fff; }
.ss-title-row { display:flex; align-items:center; justify-content:space-between; }
.ss-item-title { margin:0; font-size:16px; font-weight:600; }
.ss-item-arrow { margin-left:12px; font-size:18px; opacity:0.95; }
.ss-excerpt { margin-top:8px; font-size:13px; line-height:1.3; max-height:0; opacity:0; overflow:hidden; transition:all .28s ease; }
.ss-card:hover .ss-thumb,
.ss-card:focus .ss-thumb { transform:scale(1.02); }
.ss-card:hover .ss-excerpt,
.ss-card:focus .ss-excerpt { max-height:120px; opacity:1; }
.ss-card:hover .ss-overlay,
.ss-card:focus .ss-overlay { background:#0067B8; }

/* Progress bar */
.services-progress { height:2px; background:#e6eefb; border-radius:3px; overflow:hidden; margin-top:18px; }
.services-progress-fill { display:block; height:100%; width:0%; background:#0b63ff; transition:width 0.25s linear; }

/* Responsive slides */
@media (min-width: 1280px){ .swiper-slide{width:calc((100% - 60px)/4) !important} }
@media (min-width: 1024px) and (max-width:1279px){ .swiper-slide{width:calc((100% - 40px)/3) !important} }
@media (min-width: 768px) and (max-width:1023px){ .swiper-slide{width:calc((100% - 20px)/2) !important} }
@media (max-width:767px){ .services-slider-block{padding:10px 20px margin-top: 25px;} .ss-thumb{height:320px} .swiper-slide{width:80% !important} }
@media (max-width:500px){
.services-slider-title .ss-title {
    font-size: 36px;
}
.services-slider-title .ss-subtitle {
        font-size: 14px;
        line-height: 18px;
    }
}
/* Reviews */
.isolated-reviews-slider { padding:10px 20px; max-width:1720px; margin:50px auto; font-family:'Manrope',sans-serif; }
.irs-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:18px; gap:20px; }
.irs-title-block .irs-title {
    margin: 0;
    font-size: 58px;
    color: #1A2026;
    font-weight: 600;
    line-height: 58px;
}
.irs-title-block .irs-title span {
    display: block;
    color: #0067B8;
}
.irs-title-block .irs-subtitle {
    margin: 6px 0 0;
    display: block;
    font-size: 14px;
    color: #0067B8;
    text-transform: uppercase;
    font-weight: 500;
}

.irs-controls { display:flex; gap:10px; align-items:center; }
.irs-arrow {
    border: 0;
    background-color: #0e1a2208 !important;
    padding: 16px;
    border-radius: 999px;
    cursor: pointer;
    line-height: 17px;
}
.irs-arrow-img {
    width: 20px; 
    height: 22px;
    color: #80888F; 
    transition: color 0.3s ease;
}
.irs-arrow:hover {
    background-color: #0e1a221a !important;
}
.irs-arrow:hover .irs-arrow-img {
    color: #1A2026; 
}


.irs-swiper { position:relative; padding:30px 0 !important; }
.swiper-wrapper { align-items:stretch; }

.irs-slide { width:auto !important; }
.irs-card { background:#fff; border-radius:12px; padding:20px; box-shadow:0 2px 10px rgba(0,0,0,0.06); height:100%; display:flex; flex-direction:column; }
.irs-card-head { display:flex; gap:14px; align-items:center; margin-bottom:14px; }
.irs-avatar { width:55px; height:55px; border-radius:50%; object-fit:cover; }
.irs-meta { display:flex; flex-direction:column; }
.irs-name { font-size:16px; font-weight:700; }
.irs-date { font-size:13px; color:#70797D; margin:2px 0; }
.irs-stars { color:#FFB400; font-size:15px; }
.irs-text { margin-top:10px; font-size:14px; line-height:1.45; color:#333; }

.irs-progress { height:2px; background:#e6eefb; border-radius:3px; overflow:hidden; margin-top:18px; }
.irs-progress-fill { display:block; height:100%; width:0%; background:#0b63ff; transition:width 0.25s linear; }

/* Responsive */
@media (min-width:1024px){ .irs-slide{width:calc((100% - 40px)/3) !important;} }
@media (min-width:768px) and (max-width:1023px){ .irs-slide{width:calc((100% - 20px)/2) !important;} }
@media (max-width:767px){ .irs-slide{width:80% !important;} .isolated-reviews-slider{padding:10px 20px;margin-top:25px;} }
@media (max-width:600px){ .irs-title-block .irs-title{font-size: 26px;line-height: 31px;} .irs-title-block .irs-subtitle{font-size:14px;line-height:18px;} }


/* header */
.wp-custom-logo .site-header {
    max-width: 1720px;
    padding: 0px 20px;
}
.site-logo {
    margin: 0px !important;
}
.site-main {
    padding: 0px !important;
    margin-top: 5px;
    background: #F5FBFE;
}



/* ===== Hero Block ===== */
.hero-block {
  position: relative;
  width: 100%;
  min-height: 100vh;
  font-family: 'Manrope', sans-serif;
}

.hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('/wp-content/uploads/2025/12/homenew.webp') no-repeat;
  background-size: cover;
  background-position: center;
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 1720px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Text block */
.hero-text-block {
  color: #fff;
  padding-top: 200px;
}

.hero-title {
  font-size: 76px;
  font-weight: 700;
  line-height: 1.2;
  color: #43C2F9;
}

.hero-subtitle {
  font-size: 76px;
  font-weight: 700;
  margin-bottom: 20px;
  line-height: 1.2;
}

.hero-description {
  font-size: 20px;
  font-weight: 400;
  margin-bottom: 30px;
  line-height: 1.5;
}

.hero-btn {
  display: inline-flex;
  align-items: center;
  padding: 14px 30px;
  border-radius: 5px;
  background-color: #43C2F9;
  color: #fff;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.3s ease;
}

.hero-btn img {
  margin-left: 10px;
}

.hero-btn:hover {
  background-color: #084bbf;
}
.hero-text-work {
    position: absolute;
    right: 0px;
}
.hero-text-work1 {
    font-size: 22px;
    text-transform: uppercase;
    font-weight: 500;
	display: block;
	line-height: 27px;
}
.hero-text-work2 {
    font-size: 48px;
    text-transform: uppercase;
    display: block;
    line-height: 42px;
    font-weight: 600;
    letter-spacing: 11px;
}
/* Cards */
.hero-cards {
  display: flex;
  gap: 20px;
  border-top: 1px solid #ffffff3b;
  padding-top: 20px;
  margin-top: 150px;
  padding-bottom: 70px;
}

.hero-card {
  flex: 1;
  padding: 20px;
  display: flex;
  align-items: center;
  text-align: center;
  gap: 16px;
}

.hero-cards > .hero-card:not(:first-child) {
  border-left: 1px solid #ffffff3b;
}

.hero-card img {
  width: 80px;
  height: 80px;
}

.card-text {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  text-transform: uppercase;
}

/* ===== Adaptive ===== */

/* Tablet */
@media (max-width: 1024px) {
  .hero-text-block {
    padding-top: 120px;
    max-width: 100%;
    text-align: left;
  }
  
  .hero-title, .hero-subtitle {
    font-size: 48px;
  }

  .hero-description {
    font-size: 18px;
  }
.hero-text-work {
    display: none;
}
  .hero-cards {
    flex-direction: column;
    gap: 20px;
    margin-top: 50px;
    padding-bottom: 50px;
    border-top: none;
  }

   .hero-card {
    border-left: none !important;
    border-top: 1px solid #ffffff3b;
  }
.hero-content {
    max-width: 700px;
}
}

/* Mobile */
@media (max-width: 767px) {
  .hero-text-block {
    padding-top: 80px;
    text-align: left;
  }

  .hero-title, .hero-subtitle {
    font-size: 32px;
  }

  .hero-description {
    font-size: 16px;
    margin-bottom: 20px;
  }

  .hero-btn {
    width: 100%;
    justify-content: center;
    margin-bottom: 20px;
  }

  .hero-cards {
    gap: 16px;
    padding-bottom: 30px;
  }

  .hero-card img {
    width: 60px;
    height: 60px;
  }

  .card-text {
    font-size: 14px;
  }
}
@media (max-width: 500px) {
.hero-title, .hero-subtitle {
        font-size: 28px;
    }
.card-text {
        font-size: 11px;
        text-align: left;
    }
.hero-cards {
        padding-bottom: 45px;
        margin-top: 20px;
    }
}
/* Awards */
.awards-block {
    font-family: 'Manrope', sans-serif;
    background: #E4EEF4;
    padding: 50px 0px;
    margin-top: 50px;
}
.awards-block-text {
    max-width: 1720px;
    padding: 0px 20px;
    margin: 0 auto;
    margin-bottom: 50px;
}
.awards-block-text span1 {
    display: block;
    color: #0067B8;
    text-transform: uppercase;
    font-size: 14px;
}
.awards-block-text span2 {
    font-size: 58px;
    color: #1A2026;
    font-weight: 600;
    line-height: 58px;
	display: block;
}
.awards-block-wrap {
    display: flex;
    gap: 20px;
    max-width: 1720px;
    margin: 0px auto;
    padding: 0px 20px;
}
.awards-block-wrapcard {
    background: #fff;
    border: 1px solid #DEE4E8;
    border-radius: 12px;
    justify-content: center;
    align-items: center;
    display: flex;
    width: 100%;
    padding: 20px;
}
.awards-block-wrapcard img {
    width: fit-content;
    max-width: 100%;
}
@media (max-width: 600px) {
.awards-block-text span2 {
    font-size: 36px;
    line-height: 36px;
}
.awards-block-wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}
}

/* About */
.about-block {
    font-family: 'Manrope', sans-serif;
    background: #071319;
    color: #fff;
    padding: 100px 0px;
	transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}
.about-content-top {
    max-width: 1720px;
    padding: 0px 20px;
    margin: 0 auto;
    display: flex;
    gap: 100px;
}
.about-content-top-left {
    max-width: 587px;
    width: 100%;
}
.about-content-top-left img {
    width: 100%;
}
.about-content-top-right {
    width: 100%;
}
.about-title {
    font-size: 58px;
    line-height: 58px;
    margin-bottom: 30px;
}
.about-subtitle {
    font-size: 20px;
    text-transform: uppercase;
    max-width: 600px;
    line-height: 29px;
    margin-bottom: 18px;
}
.about-description {
    font-size: 18px;
    line-height: 28px;
}
.about-btn {
    display: block;
    color: #fff !important;
    text-transform: uppercase;
    line-height: 28px;
    font-size: 15px;
    font-weight: bold;
    margin-top: 30px;
}
.about-adv {
    display: flex;
    margin-top: 90px;
	gap: 30px;
}
.about-advcard {
    width: 100%;
}
.about-adv > .about-advcard:not(:first-child) {
    border-left: 1px solid #ffffff3b;
    padding-left: 30px;
}
.about-adv > .about-advcard:not(:first-child) > .about-advcard-num {
    align-items: end;
}
.about-advcard-num {
    display: flex;
    align-items: center;
    gap: 5px;
}
.about-advcard-num span1 {
    font-size: 76px;
    line-height: 70px;
    font-weight: 500;
}
.about-advcard-num span2 {
    font-size: 26px;
    font-weight: 600;
    color: #3EC0F7;
}
.about-content-bottom {
    max-width: 1720px;
    padding: 0px 20px;
    margin: 0 auto;
    display: flex;
    gap: 100px;
    margin-top: 100px;
}
.about-content-bottom-left {
    width: 100%;
    max-width: 587px;
}
.about-content-bottom-right {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.about-lnk {
    color: #43C2F9;
    text-transform: uppercase;
    font-size: 14px;
	text-decoration: none !important;
}
.about-content-bottom-title {
    font-size: 58px;
    line-height: 68px;
    margin-bottom: 20px;
}
.about-content-bottom-subtitle {
    font-size: 18px;
    font-weight: 400;
    margin-bottom: 40px;
}
.about-content-bottom-card {
    display: flex;
    gap: 25px;
    border-bottom: 1px solid #ffffff3b;
    padding-bottom: 30px;
}
.about-content-bottom-cardnb {
    font-size: 16px;
    color: #43C2F9;
    font-weight: bold;
    line-height: 40px;
}
.about-content-bottom-cardtext p {
    font-size: 20px;
    padding-bottom: 10px;
}
.about-content-bottom-cardtext span {
    font-size: 16px;
}
@media (max-width: 1430px) {
.about-subtitle {
    font-size: 16px;
    line-height: 26px;
}
.about-description {
    font-size: 13px;
    line-height: 23px;
}
.about-btn {
    font-size: 12px;
    margin-top: 17px;
}
.about-advcard-num span1 {
    font-size: 50px;
    line-height: 55px;
}
.about-advcard-num span2 {
    font-size: 16px;
}
.about-advsub {
    font-size: 14px;
}
.about-title {
    font-size: 47px;
    line-height: 38px;
    margin-bottom: 25px;
}
.about-content-bottom-title {
    font-size: 40px;
    line-height: 46px;
    margin-bottom: 15px;
}
.about-content-bottom-subtitle {
    font-size: 13px;
}
.about-content-bottom-cardnb {
    font-size: 13px;
    line-height: 28px;
}
.about-content-bottom-cardtext p {
    font-size: 17px;
    padding-bottom: 5px;
}
.about-content-bottom-cardtext span {
    display: block;
    font-size: 12px;
    line-height: 20px;
}
}
@media (max-width: 950px) {
.about-content-top {
    max-width: 560px;
    display: block;
}
.about-content-top-left {
    margin-bottom: 40px;
}
.about-adv {
    margin-top: 35px;
}
.about-content-bottom {
    max-width: 560px;
    display: block;
    margin-top: 40px;
}
.about-content-bottom .hero-btn {
    width: 100%;
    justify-content: center;
    margin-bottom: 30px;
}
}
@media (max-width: 510px) {
.about-advcard-num span1 {
   font-size: 23px;
   line-height: 25px;
}
.about-advcard-num span2 {
        font-size: 10px;
    }
.about-advsub {
        font-size: 10px;
    }
    .about-content-bottom-title {
        font-size: 30px;
        line-height: 34px;
        margin-bottom: 15px;
    }
.about-block {
    padding: 60px 0px;
}
}

/* Offer */
.offer-block {
    background: url(/wp-content/uploads/2025/11/offer.webp) no-repeat;
    background-size: cover;
    background-position: center;
	font-family: 'Manrope', sans-serif;
    color: #fff;
}
.offer-wrap {
    max-width: 1000px;
    margin: 0 auto;
    text-align: center;
    padding: 100px 20px;
}
.offer-wrap-title {
    font-size: 58px;
    font-weight: 500;
    line-height: 68px;
}
.offer-wrap-subtitle {
    font-size: 18px;
    margin: 40px 0px;
}
.offer-wrap-title span {
    display: block;
    color: #43C2F9;
}
@media (max-width: 600px) {
.offer-wrap-title {
    font-size: 31px;
    line-height: 37px;
}
.offer-wrap-subtitle {
    font-size: 15px;
}
}
/* Work */
.recent-works-homepage {
    font-family: 'Manrope', sans-serif;
    max-width: 1720px;
    padding: 60px 20px;
    margin: 0 auto;
}
.recent-works-homepage .our-works-title {
    display: flex;
    margin-bottom: 45px;
	align-items: end;
}
.our-works-titlewrap span {
    display: block;
    font-size: 14px;
    color: #0067B8;
    text-transform: uppercase;
	font-weight: 500;
}
.recent-works-homepage h2 {
    font-size: 58px;
    color: #1A2026;
    font-weight: 600;
    line-height: 58px;
}
.recent-works-homepage .work-btn {
    font-size: 15px;
    color: #0067B8;
    text-decoration: none !important;
    border: 1px solid #0067B8;
    padding: 15px 20px;
    border-radius: 3px;
    margin-left: auto;
}
.recent-works-homepage .work-btn:hover {
    background-color: #e0e0e0 !important;
}
.post-type-archive-our_works .content-area {
    background: #F5FBFE;
}
.our-works-wrapper {
    max-width: 1720px;
    padding: 0px 20px;
    margin: 0px auto;
}
.our-works-wrapper .page-title {
    font-size: 76px;
    font-family: 'Manrope', sans-serif;
}
.our-works-grid {
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin: 30px 0;
}
.work-item { cursor:pointer; user-select:none; }
.work-thumb { 
    position: relative; 
    width:100%; 
    padding-top:100%; 
    overflow:hidden; 
    border-radius:12px; 
    background:#f6f6f6; 
}
.work-thumb .work-title {
    position: absolute;
    z-index: 3;
    bottom: 40px;
    width: 100%;
    font-size: 20px;
    line-height: 27px;
    font-weight: bold;
    color: #fff;
    padding: 10px 10px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #D9D9D933;
}
.work-thumb .work-title img {
    margin-top: 6px;
    margin-left: auto;
}
.thumb-slider {
    position: absolute;
    inset: 0;
    border-radius: 12px;
    overflow: hidden;
}
.thumb-slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
}
.thumb-slide.active {
    opacity: 1;
    z-index: 2;
}

.thumb-pagination {
    position: absolute;
    bottom: 12px;
    gap: 8px;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    z-index: 3;
}
.thumb-pagination .dot { 
    display:inline-block; 
    width:18px; 
    height:1px; 
    border-radius:2px; 
    background-color: rgba(255, 255, 255, 0.85) !important;
    border:none; 
    padding:0; 
    cursor:pointer; 
    transition: width .18s ease, background .18s ease; 
    box-shadow: 0 1px 2px rgba(0,0,0,.15) inset; 
}
.works-breadcrumbs {
    margin-bottom: 15px !important;
    padding-top: 20px !important;
}
.works-breadcrumbs a {
    color: #000000 !important;
}
.thumb-pagination .dot.active { width:34px; background: rgba(255,255,255,0.95); }
@media (max-width: 600px) {
.recent-works-homepage h2 {
    font-size: 36px;
    line-height: 36px;
}
.recent-works-homepage .our-works-title {
    align-items: end;
}
.our-works-wrapper .page-title {
    font-size: 36px;
}
}

/* ===== Modal ===== */
.our-works-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: none;
    background: rgba(0,0,0,0.79);
    backdrop-filter: blur(4px);
    z-index: 99999;
    padding: 20px;
    box-sizing: border-box;
    touch-action: pan-y pinch-zoom;
	margin: 0px;
}
.our-works-modal[aria-hidden="false"] { 
    display: flex;
    flex-direction: column;
}

/* close button */
.modal-close {
    position: absolute;
    top: 20px;
    right: 24px;
    z-index: 1002;
    background-color: rgb(223 215 215 / 19%) !important;
    color: #fff !important;
    border: none;
    width: 44px !important;
    height: 56px !important;
    border-radius: 50%;
    font-size: 22px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    backdrop-filter: blur(6px);
    transition: transform .12s 
ease, background .12s 
ease;
}
.modal-close:hover { transform: scale(1.05); background: rgba(255,255,255,0.12); }

/* stage */
.modal-stage { 
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex: 1;
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    position: relative;
    min-height: 0;
}

/* modal-view */
.modal-view {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 70vh;
    min-height: 400px;
    max-height: 80vh;
    position: relative;
    width: 100%;
}

/* modal-slider */
.modal-slider {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* modal-slide */
.modal-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
    padding: 20px;
    box-sizing: border-box;
}
.modal-slide.active {
    opacity: 1;
    z-index: 2;
}
.modal-slide img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    display: block;
    border-radius: 10px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.6);
    object-fit: contain;
}

/* arrows */
.modal-arrow {
    background-color: rgb(223 215 215 / 19%) !important;
    color: #fff;
    border: none;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex !important; 
    align-items: center;
    justify-content: center;
    cursor: pointer;
    backdrop-filter: blur(10px);
    transition: all 0.3s ease;
    z-index: 1001;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3);
    opacity: 1 !important;
    visibility: visible !important;
}

.modal-arrow:hover {
    background: rgba(255,255,255,0.25);
    transform: scale(1.1);
    box-shadow: 0 6px 25px rgba(0,0,0,0.4);
}

.modal-arrow:active {
    transform: scale(0.95);
}

.modal-arrow svg {
    display: block !important; 
    width: 24px !important; 
    height: 24px !important; 
    min-width: 24px !important; 
    min-height: 24px !important; 
    color: white !important;
    stroke: currentColor !important;
    stroke-width: 2 !important;
    fill: none !important;
    opacity: 1 !important;
    visibility: visible !important;
}
.modal-arrow.hidden {
    display: none !important;
}

/* thumbs carousel */
.modal-thumbs-wrap { 
    width:100%; 
    max-width: 1400px;
    margin: 20px auto 0;
    display:flex; 
    justify-content:center; 
    flex-shrink: 0;
}
.modal-thumbs { 
    display:flex; 
    gap:10px; 
    overflow-x:auto; 
    padding:10px 4px; 
    scroll-behavior:smooth; 
    -webkit-overflow-scrolling:touch; 
    max-width: 100%;
}
.modal-thumbs img { 
    width:86px; 
    height:64px; 
    object-fit:cover; 
    border-radius:6px; 
    cursor:pointer; 
    opacity:0.6; 
    transform-origin:center center; 
    transition: opacity .14s ease, transform .14s ease, box-shadow .14s ease; 
    border:2px solid transparent; 
    flex-shrink: 0;
}
.modal-thumbs img.active { 
    opacity:1; 
    transform: scale(1.03); 
    box-shadow: 0 8px 30px rgba(0,0,0,0.6); 
    border-color: rgba(255,255,255,0.08); 
}

/* responsive */
@media (max-width: 1000px) {
    .our-works-grid { grid-template-columns: repeat(3, 1fr); gap:16px; }
    .modal-stage { gap:15px; }
    .modal-arrow { 
        width: 25px;
        height: 27px;
		padding: 15px;
    }
.modal-arrow svg {
    color: #000000 !important;
    stroke: currentColor !important;
}
    .modal-arrow svg {
        width: 20px !important;
        height: 20px !important;
        min-width: 20px !important;
        min-height: 20px !important;
    }
    .modal-thumbs img { width:72px; height:54px; }
}
@media (max-width: 680px) {
    .our-works-grid { grid-template-columns: repeat(2, 1fr); }
    .modal-stage { 
        gap: 10px;
    }
    .modal-view {
        height: 60vh;
        min-height: 300px;
    }
    .modal-arrow { 
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 25px;
        height: 27px;
		padding: 15px;
    }
    .modal-prev { left: 10px; }
    .modal-next { right: 10px; }
    .modal-arrow svg {
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        min-height: 18px !important;
    }
    .modal-slide {
        padding: 10px;
    }
    .modal-thumbs-wrap {
        margin-top: 15px;
    }
}
@media (max-width: 420px) { 
    .our-works-grid { grid-template-columns: 1fr; } 
    .modal-arrow {
        width: 25px;
        height: 27px;
		padding: 15px;
    }
.modal-arrow svg {
    color: #000000 !important;
    stroke: currentColor !important;
}
    .modal-arrow svg {
        width: 16px !important;
        height: 16px !important;
        min-width: 16px !important;
        min-height: 16px !important;
    }
    .modal-thumbs img { 
        width: 60px; 
        height: 45px; 
    }
    .our-works-modal {
        padding: 15px;
    }
    .modal-view {
        height: 50vh;
        min-height: 250px;
    }
}

/* Footer */
.site-footer {
    margin: 0px !important;
    background: #071319;
    width: 100% !important;
    max-width: 100% !important;
	font-family: 'Manrope', sans-serif;
	transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}
.footer-wrap-top {
    max-width: 1720px;
    margin: 0 auto !important;
    padding: 40px 20px;
    display: flex;
}
.footer-wrap-services {
    margin-left: auto;
    margin-right: auto;
}
.footer-wrap-services .footer-block-title {
    margin-bottom: 20px;
}
.footer-wrap-aboutus .footer-block-title {
    margin-bottom: 20px;
}
.footer-block-title {
    color: #fff;
    text-transform: uppercase;
    font-size: 18px;
    font-weight: bold;
}
.footer-wrap-contactblok {
    display: flex;
    gap: 20px;
    margin-top: 20px;
}
.footer-wrap-contactbloktext span1 {
    font-size: 16px;
    font-weight: 400;
    color: #fff;
}
.footer-wrap-contactbloktext span2 {
    font-size: 16px;
    color: #fff;
    display: block;
    font-weight: bold;
}
.footer-wrap-contactblokico {
    width: 20px;
}
.foot-lnk {
    color: #fff;
    text-decoration: none !important;
    font-size: 15px;
    font-weight: 400;
	line-height: 33px;
	display: block;
}
.footer-wrap-bottom {
    margin: 0 auto !important;
    max-width: 1720px;
    padding: 20px 20px;
    display: flex;
    align-items: center;
    border-top: 1px solid #DDDDDD1A;
}
.footer-wrap-bottom span {
    font-size: 12px;
    color: #fff;
}
.footer-wrap-bottom-lnk {
    font-size: 15px;
    color: #fff;
    text-decoration: underline !important;
    margin-left: auto;
    margin-right: auto;
}
.footer-wrap-bottosoc {
    display: flex;
    gap: 10px;
}
.footer-wrap-contact {
	order: 1;
}
.footer-wrap-services {
	order: 2;
}
.footer-wrap-aboutus {
	order: 3;
}
@media (max-width: 600px) {
.footer-wrap-contact {
    padding: 10px 0px;
	order: 4;
}
.footer-wrap-services {
    padding: 10px 0px;
	order: 1;
	margin-left: unset;
    margin-right: unset;
}
.footer-wrap-aboutus {
    padding: 10px 0px;
	order: 2;
}
.footer-wrap-top {
    padding: 10px 20px;
	flex-direction: column;
	align-items: flex-start;
}
.footer-wrap-bottom {
    flex-direction: column;
    align-items: flex-start;
}
.footer-wrap-bottom-lnk {
    margin-left: unset;
    margin-right: unset;
    width: 100%;
    margin-bottom: 20px;
}
.footer-wrap-bottosoc {
    margin-bottom: 20px;
}
.footer-wrap-bottom span {
	order: 3;
}
.site-footer {
    padding-bottom: 20px;
}
}

/* ====== ХЕДЕР ====== */
.custom-header {
    background: #ffffff;
    position: relative;
    z-index: 10002;
    width: 100%;
	font-family: 'Manrope', sans-serif;
}
.header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0px;
    width: 100%;
}
.custom-header .hero-btn {
    font-size: 14px;
}
.header-wrap-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

/* ====== ДЕСКТОП МЕНЮ ====== */
.desktop-menu { display: flex; align-items: center; }
.desktop-menu ul { display:flex; gap:25px; list-style: none !important; }
.desktop-menu ul li { position: relative; }
.desktop-menu ul li a { font-weight:500; color:#000 !important; text-decoration:none; font-size: 16px; background: none !important; font-family: 'Manrope', sans-serif; }
.desktop-menu ul li:hover {
    text-decoration: none !important;
}

/* выпадающее подменю */
.desktop-menu .menu-item-has-children > a::after {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-right: 2px solid #000000;
    border-bottom: 2px solid #000000;
    transform: rotate(45deg);
    margin-left: 6px;
    position: relative;
    top: -3px;
}
.desktop-menu .sub-menu li:hover {
    text-decoration: none !important;
}
.desktop-menu .sub-menu a {
	display:block;
	padding: 0px 5px;
}
.desktop-menu .sub-menu a:hover {
    color: #0067B8 !important;
    text-decoration: none !important;
}
@media (max-width: 768px) {
    .desktop-menu .menu-item-has-children > a::after {
        display: none;
    }
.header-wrap-right {
    display: none;
}
}
.desktop-menu ul li ul.sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    background: #ffffff;
    padding: 12px 0;
    list-style: none;
    display: none;
    min-width: 180px;
    box-shadow: 0 8px 16px rgba(0,0,0,0.08);
	margin-top: 0px;
}

.desktop-menu ul li:hover > ul.sub-menu {
    display: block;
}

/* ====== БУРГЕР ====== */
.burger-menu {
    width: 36px;
    height: 24px;
    display: none;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    background: transparent !important;
    border: none;
    padding: 0;
    margin: 0;
    cursor: pointer;
    position: relative;
    z-index: 10003;
	overflow: hidden;
}

.burger-menu span {
    display: block;
    width: 100%;
    height: 3px;
    background: #000;
    border-radius: 2px;
    transition: transform .28s ease, opacity .18s ease;
}

.burger-menu.active span:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
}
.burger-menu.active span:nth-child(2) {
    opacity: 0;
}
.burger-menu.active span:nth-child(3) {
    transform: translateY(-9px) rotate(-45deg);
}

/* ====== МОБИЛЬНОЕ МЕНЮ ====== */
.mobile-menu-overlay {
    position: fixed;
    left: 0;
    width: 100%;
    background: #ffffff;
    transform: translateY(-10px);
    opacity: 0;
    transition: transform 0.35s ease, opacity 0.25s ease;
    z-index: 10000;
    display: none;
    flex-direction: column;
}

.mobile-menu-overlay.open {
    transform: translateY(0);
    opacity: 1;
    display: flex;
}

body.menu-open {
    overflow: hidden;
    height: 100%;
}

.mobile-menu-inner {
    padding: 28px;
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow-y: auto;
}
.mobile-nav a {
	font-family: 'Manrope', sans-serif;
}
/* мобильный список */
.mobile-nav ul {
    display: flex;
    flex-direction: column;
    gap: 18px;
    list-style: none;
    padding-left: 0;
}

.mobile-nav .menu-item-has-children {
    position: relative;
}

.menu-parent {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-right: 10px;
}

.menu-parent > a {
    flex: 1;
    display: block;
}

.submenu-toggle {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}
.submenu-toggle .up {
    transform-origin: center;
    transition: transform 0.2s ease;
}

.menu-item-has-children.open .submenu-toggle .up {
    transform: rotate(180deg);
}

/* подменю */
.menu-item-has-children .sub-menu {
    display: none;
    margin-top: 5px;
    padding-left: 0;
}

.menu-item-has-children.open .sub-menu {
    display: block;
}

.submenu-toggle {
    background: none;
    border: none;
    width: 22px;
    height: 22px;
    position: relative;
    right: -5px;
    top: 0px;
    cursor: pointer;
	background-color: transparent !important;
    padding: 0px;
}
.mobile-menu-inner .sub-menu-toggle {
	display:none !important;
}
.header-inner .sub-menu-toggle {
	display:none !important;
}
.submenu-toggle::after {
    content: "";
    display: block;
    width: 12px;
    height: 12px;
    border-right: 2px solid #616161;
    border-bottom: 2px solid #616161;
    transform: rotate(45deg); /* вниз */
    transition: transform .25s ease;
}

.submenu-toggle.active::after {
    transform: rotate(-135deg); /* вверх */
}

/* скрытое подменю */
.mobile-nav ul li ul.sub-menu {
    display: none;
    padding: 10px 0 0 15px;
    flex-direction: column;
    gap: 14px;
}

.mobile-nav ul li ul.sub-menu.open {
    display: flex;
}
.mobile-nav .sub-menu li {
    border: 0px !important;
}

/* нижний блок */
.mobile-bottom-block {
    margin-top: auto;
    padding-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.mobile-cta-button {
    padding: 12px 18px;
    background: #000;
    color: #fff;
    border-radius: 6px;
    text-align: center;
    text-decoration: none;
    font-weight: 600;
}

/* соцсети */
.mobile-socials {
    display: flex;
    gap: 16px;
    justify-content: center;
}
.mobile-socials a { text-decoration:none; color:#000; }

/* ====== АДАПТИВ ====== */
@media (max-width: 768px) {
    .desktop-menu { display: none; }
    .burger-menu { display: flex; }

    .mobile-nav li {
        position: relative;
        border-bottom: 1px solid #EEF1F3;
        padding: 8px 0px;
        padding-right: 24px;
    }
	.mobile-nav a {
    color: #1A2026 !important;
    text-decoration: none !important;
    font-size: 18px;
	background: none !important;
}

    .menu-item-has-children > a {
        padding-right: 28px;
        display: block;
    }
}

/* ====== форма связи ====== */
.contact-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 99999;
}

.contact-modal.active {
    display: flex;
}

.contact-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.6);
}

.contact-modal-content {
    position: relative;
    background: #fff;
    padding: 30px;
    max-width: 450px;
    width: 90%;
    border-radius: 10px;
    font-family: 'Manrope', sans-serif !important;
    z-index: 2;
    font-size: 15px;
}

.contact-modal-content .modal-close {
    position: absolute;
    top: 10px;
    right: 12px;
    cursor: pointer;
    border: none;
    background: none;
    font-size: 34px;
    color: #000 !important;
    background-color: unset !important;
}
#ajax-modal-form input {
    border: 0px;
    border-bottom: 1px solid #1a20266e;
    width: 100%;
    margin: 10px 0px 0px 0px;
}
#ajax-modal-form textarea {
    border: 0px;
    border-bottom: 1px solid #1a20266e;
    width: 100%;
    margin: 10px 0px 10px 0px;
    padding: 10px;
}
.formbtn {
    background: #43C2F9 !important;
    border: none !important;
    font-size: 15px;
    width: 100%;
    margin-top: 20px;
    text-transform: uppercase;
    display: flex;
    gap: 10px;
    justify-content: center;
    border-radius: 4px;
	color:#fff !important;
}
.formbtn:hover {
	background: #084bbf !important;
}
.formtitl {
    font-size: 32px;
    font-weight: bold;
}
.form-block {
    width: 100%;
    background: #071319;
	font-family: 'Manrope', sans-serif;
}
.formwrap {
    display: flex;
}
.formimg {
    width: 100%;
}
.formimg img {
    width: 100%;
}
.custom-contact-formwrap {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.custom-contact-formwrap .custom-contact-form {
    max-width: 629px;
	width: 100%;
}
.form-block .formtitl {
    font-size: 40px;
    font-weight: bold;
    color: #fff;
}
.custom-contact-formwrap .formbtn {
    max-width: 224px;
    margin-left: auto;
}
.form-block input {
    background: none !important;
    color: #fff !important;
    font-size: 15px;
    border: none !important;
    border-bottom: 1px solid #ffffff73 !important;
    width: 100%;
    margin-bottom: 10px !important;
}
.form-block textarea {
    background: none !important;
    color: #fff !important;
    font-size: 15px;
    border: none !important;
    border-bottom: 1px solid #ffffff73 !important;
    width: 100%;
}
.formtextblok {
    width: 100%;
    background: #fff;
}
.contacts-page {
    font-family: 'Manrope', sans-serif;
    margin: 0px !important;
}
.contacts-page .contactpage-block-title {
    font-size: 76px;
}
.contacts-page .contactpage-block-subtitle {
    font-size: 18px;
    color: #70797D;
    margin-bottom: 25px;
    display: block;
}
.contactpage-wrap-contactblok {
    display: flex;
    gap: 15px;
    margin-bottom: 10px;
}
.contactpage-wrap-contactbloktext span1{
    font-size: 16px;
    color: #1A2026;
    line-height: 32px;
    display: block;
}
.contactpage-wrap-contactbloktext span2 {
    font-size: 20px;
    font-weight: bold;
    color: #1A2026;
    line-height: 24px;
    display: block;
}
.contactpage-wrap-contact {
    max-width: 700px;
    padding: 0px 20px 60px 20px;
}
.contacts-page .formtextblok {
    display: flex;
    justify-content: center;
    align-items: center;
}
.contacts-page iframe {
    margin: 0px !important;
}
@media (max-width: 1000px) {
.formimg {
    width: 100%;
    display: none;
}
.custom-contact-formwrap .custom-contact-form {
    padding: 30px 20px;
}
.contacts-page .formwrap {
    display: block;
}
.contactpage-wrap-contact {
    max-width: 629px;
    padding: 0px 20px 30px 20px;
}
.contacts-page .contactpage-block-title {
    font-size: 53px;
    line-height: 72px;
}
.custom-contact-formwrap .formbtn {
    max-width: 100%;
}
}
/* service page */
.our-services-page .services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
    margin-top: 30px;
}

.service-card {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    transition: transform 0.3s ease;
}

.service-card:hover {
    transform: translateY(-5px);
}

.service-thumb {
    position: relative;
    width: 100%;
    padding-top: 66.66%; /* соотношение 3:2 */
    background-size: cover;
    background-position: center;
}

.ss-overlay {
    position: absolute;
    top:0; left:0; right:0; bottom:0;
    background: rgba(0,0,0,0.3);
    transition: background 0.3s ease;
}

.service-card:hover .ss-overlay {
    background: rgba(0,0,0,0.1);
}

.ss-info {
    position: absolute;
    bottom: 15px;
    left: 15px;
    right: 15px;
    color: #fff;
}

.ss-title-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ss-item-title {
    margin: 0;
    font-size: 1.2rem;
}

.ss-item-arrow img {
    display: block;
}

.ss-excerpt {
    margin-top: 5px;
    font-size: 0.9rem;
}
/* ====== about page ====== */
.about-hero {
    width: 100%;
    background-size: cover;
    background-position: center;
    position: relative;
    padding-top: 20px;
    padding-bottom: 135px;
    color: #fff;
}
.about-page {
    margin: 0px auto;
    max-width: 1720px;
	padding: 0px 20px 70px 20px;
	font-family: 'Manrope', sans-serif;
}
.about-pager-topwrap {
    display: flex;
    gap: 100px;
    margin-bottom: 70px;
}
.about-pager-topwrap-left {
    width: 100%;
}
.about-pager-topwrap-right {
    width: 100%;
}
.about-pager-topwrap-right img {
    width: 100%;
}
.about-pager-title {
    font-size: 52px;
    line-height: 44px;
    font-weight: bold;
    padding-bottom: 30px;
}
.about-pager-text {
    font-size: 16px;
    font-weight: 400;
}
.about-pager-topwrap-left br {
    display: block;
    padding-top: 20px;
}
.about-hero-overlay {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    font-family: 'Manrope', sans-serif;
    max-width: 1720px;
    margin: 0 auto;
    padding: 0px 20px;
}

.about-breadcrumbs {
    font-size: 15px;
    margin-bottom: 55px;
    color: #55C8FA;
}
.about-breadcrumbs a {
    color: #fff;
    text-decoration: none !important;
    font-size: 15px !important;
	background: none !important;
}
.about-hero-title {
    font-size: 76px;
    font-weight: 600;
    margin: 0 0 20px;
}

.about-hero-subtitle {
    font-size: 24px;
    font-weight: 500;
    margin-bottom: 15px;
}

.about-hero-description {
    font-size: 16px;
    line-height: 1.6;
    max-width: 800px;
}
.about-pager-imgmob {
	display:none;
}

/* --- Адаптив --- */
@media (max-width: 1024px) {
    .about-hero {
        padding: 20px 20px 60px 20px;
    }
    .about-hero-title {
        font-size: 36px;
    }
    .about-hero-subtitle {
        font-size: 18px;
    }
    .about-hero-description {
        font-size: 15px;
    }
.about-hero-overlay {
    padding: 0px;
}
}

@media (max-width: 768px) {
.about-pager-imgmob {
        display: block;
        width: 100%;
        margin-bottom: 35px;
    }
.about-pager-imgpc {
	display:none;
}
.about-pager-topwrap {
    display: block;
}
    .about-hero {
        padding: 20px 20px 60px 20px;
    }
    .about-hero-title {
        font-size: 28px;
        text-align: left;
    }
    .about-hero-subtitle,
    .about-hero-description {
        font-size: 14px;
        text-align: left;
    }
    .about-hero-description {
        max-width: 100%;
    }
}

@media (max-width: 480px) {
    .about-hero {
        padding: 20px 20px 60px 20px;
    }
    .about-title {
        font-size: 36px;
    }
    .about-subtitle {
        font-size: 13px;
    }
    .about-description {
        font-size: 12px;
    }
}

/* ====== service page ====== */
.service-hero {
    width: 100%;
    background-size: cover;
    background-position: center;
    position: relative;
    padding-top: 20px;
    padding-bottom: 135px;
    color: #fff;
}
.service-page {
    max-width: 1720px;
    margin: 0px auto !important;
    padding: 0px 20px 70px 20px;
}
.service-hero-overlay {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    font-family: 'Manrope', sans-serif;
    max-width: 1720px;
    margin: 0 auto;
    padding: 0px 20px;
}

.service-breadcrumbs {
    font-size: 15px;
    margin-bottom: 55px;
    color: #55C8FA;
}
.service-breadcrumbs a {
    color: #fff;
    text-decoration: none !important;
    font-size: 15px !important;
    background: none !important;
}

.service-hero-title {
    font-size: 76px;
    font-weight: 600;
    margin: 0 0 20px;
}

.service-hero-description {
    font-size: 16px;
    line-height: 1.6;
    max-width: 800px;
}

/* --- Адаптив --- */
@media (max-width: 1024px) {
    .service-hero {
        padding: 100px 0 60px;
    }
    .service-hero-title {
        font-size: 36px;
    }
    .service-hero-description {
        font-size: 15px;
    }
}

@media (max-width: 768px) {
    .service-hero {
        padding: 80px 15px 50px;
    }
	.service-hero-overlay {
    padding: 0px;
}
    .service-hero-title {
        font-size: 28px;
        text-align: left;
    }
    .service-hero-description {
        font-size: 14px;
        text-align: left;
        max-width: 100%;
    }
}

@media (max-width: 480px) {
    .service-hero {
        padding: 20px 20px 60px 20px;
    }
    .service-hero-title {
        font-size: 32px;
    }
    .service-hero-description {
        font-size: 12px;
    }
}

/* Roofing Services */
.roofing_service-grid,
.roofing_service-latest {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    max-width: 1720px;
    margin: 0 auto;
    padding: 0px 20px;
}
.roofing_service-item h3 {
    font-size: 22px;
    line-height: 28px;
    font-weight: 700;
    font-family: 'Manrope', sans-serif;
	color: #000 !important;
}
.roofing_service-item p {
    font-size: 18px;
    color: #70797D !important;
    font-weight: 500;
	line-height: 25px;
}
.roofing_service-item a {
    display: block;
    text-decoration: none !important;
    background-color: unset !important;
}
.roofing_service-item {
    width: calc(33.73% - 20px);
    box-sizing: border-box;
	background: #fff;
    border-radius: 12px;
}
.roofing_service-itemtext {
    padding: 15px;
}
.roofing_service-item img {
    width: 100% !important;
    height: 100% !important;
}
.roofing_service-block {
    font-family: 'Manrope', sans-serif;
    background: #E4EEF4;
    padding: 50px 0px;
}
.roofing_service-title-block {
    max-width: 1720px;
    padding: 0px 20px 50px 20px;
    margin: 0 auto;
}
.roofing_service-title {
    margin: 0;
    font-size: 58px;
    color: #1A2026;
    font-weight: 600;
    line-height: 58px;
}
.roofing_service-title span {
    display: block;
    color: #0067B8;
}
.roofing_service-subtitle {
    margin: 6px 0 0;
    display: block;
    font-size: 14px;
    color: #0067B8;
    text-transform: uppercase;
    font-weight: 500;
}
.roofing-service-single {
    max-width: 1720px;
    margin: 0 auto !important;
    padding: 0px 20px 40px 20px;
}
.roofing_service-archive h1 {
    font-size: 76px;
    font-weight: 600;
    max-width: 1720px;
    padding: 0px 20px;
    margin: 0 auto;
    margin-bottom: 35px;
	font-family: 'Manrope', sans-serif;
}
.roofing_service-breadcrumbs {
    font-family: 'Manrope', sans-serif;
    max-width: 1720px;
    padding: 20px;
    margin: 0 auto !important;
    font-size: 15px;
    color: #55C8FA;
}
.roofing_service-breadcrumbs a {
    text-decoration: none !important;
}
@media (max-width: 768px) {
    .roofing_service-item {
        width: calc(51.4% - 20px);
    }
}
@media (max-width: 600px) {
.roofing_service-title {
    font-size: 36px;
    line-height: 36px;
}
}
@media (max-width: 520px) {
    .roofing_service-item {
        width: 100%;
    }
}