/* 

TemplateMo 562 Space Dynamic

https://templatemo.com/tm-562-space-dynamic

*/

/* ---------------------------------------------
Table of contents
------------------------------------------------
01. font & reset css
02. reset
03. global styles
04. header
05. banner
06. features
07. testimonials
08. contact
09. footer
10. preloader
11. search
12. portfolio

--------------------------------------------- */
/* 
---------------------------------------------
font & reset css
--------------------------------------------- 
*/
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@100;200;300;400;500;600;700;800;900&display=swap');
/* 
---------------------------------------------
reset
--------------------------------------------- 
*/
@import url('reset.css');
/* 
---------------------------------------------
global styles
--------------------------------------------- 
*/

html,
body {
  background: #fff;
  font-family: 'Poppins', sans-serif;
}

::selection {
  background: var(--primary);
  color: #fff;
}

::-moz-selection {
  background: var(--primary);
  color: #fff;
}

.bg-primary ::selection {
  background: var(--secondary);
}

.bg-primary ::-moz-selection {
  background: var(--secondary);
}

@media (max-width: 991px) {
  html, body {
    overflow-x: hidden;
  }
  .mobile-top-fix {
    margin-top: 30px;
    margin-bottom: 0px;
  }
  .mobile-bottom-fix {
    margin-bottom: 30px;
  }
  .mobile-bottom-fix-big {
    margin-bottom: 60px;
  }
}

.page-section {
  margin-top: 120px;
}

.section-heading h2 {
  font-size: 30px;
  text-transform: capitalize;
  color: #2a2a2a;
  font-weight: 700;
  letter-spacing: 0.25px;
  position: relative;
  z-index: 2;
  line-height: 44px;
}

.section-heading h2 i {
  font-style: normal;
  color: var(--primary);
}

.section-heading h2 b {
  color: var(--secondary);
  font-weight: 700;
}

.main-blue-button a {
  display: inline-block;
  background-color: var(--primary);
  font-size: 15px;
  font-weight: 400;
  color: #fff;
  text-transform: capitalize;
  padding: 12px 25px;
  border-radius: 23px;
  letter-spacing: 0.25px;
}

.main-red-button a {
  display: inline-block;
  background-color: var(--secondary);
  font-size: 15px;
  font-weight: 400;
  color: #fff;
  text-transform: capitalize;
  padding: 12px 25px;
  border-radius: 23px;
  letter-spacing: 0.25px;
}

.main-white-button a {
  display: inline-block;
  background-color: #fff;
  font-size: 15px;
  font-weight: 400;
  color: var(--secondary);
  text-transform: capitalize;
  padding: 12px 25px;
  border-radius: 23px;
  letter-spacing: 0.25px;
}

/* 
---------------------------------------------
header
--------------------------------------------- 
*/

.header-area {
  background-color: #fafafa;
  z-index: 100;
  height: 100px;
}

.header-area .main-nav {
  min-height: 80px;
  background: transparent;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

.header-area .main-nav .logo {
  line-height: 100px;
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.header-area .main-nav .logo h4 {
    font-size: 24px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--primary);
    max-width: 400px;
  }

.header-area .main-nav .logo h4.no-space {
    word-spacing: -.5ch;    
}

.logo h4 span {
  color: var(--secondary);
}


.header-area .main-nav .nav {
  margin-right: 0px;
  margin-top: 0;
  align-items: center;
  background-color: transparent;
  position: relative;
  z-index: 999;
}

.header-area .main-nav .nav li:last-child {
  padding-left: 1rem;
}

.header-area .main-nav .nav .nav-link {
  display: block;
  font-weight: 500;
  font-size: 1rem;
  color: #2a2a2a;
  text-transform: capitalize;
  letter-spacing: 1px;
  color: inherit;
}

.header-area .main-nav .nav.toggle {
  transform: scaleY(1);
}

.header-area .main-nav .nav .nav-link:hover,
.header-area .main-nav .nav .nav-link.active {
  color: var(--secondary);
}


.header-area .main-nav .menu-trigger {
  cursor: pointer;
  display: block;
  position: relative;
  width: 32px;
  height: 40px;
  text-indent: -9999em;
  z-index: 99;
  display: none;
}


.header-area .main-nav .menu-trigger span,
.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-color: #1e1e1e;
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 0;
}

.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-color: #1e1e1e;
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 0;
  width: 75%;
}


.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  content: "";
}

.header-area .main-nav .menu-trigger span {
  top: 16px;
}

.header-area .main-nav .menu-trigger span:before {
  -moz-transform-origin: 33% 100%;
  -ms-transform-origin: 33% 100%;
  -webkit-transform-origin: 33% 100%;
  transform-origin: 33% 100%;
  top: -10px;
  z-index: 10;
}

.header-area .main-nav .menu-trigger span:after {
  -moz-transform-origin: 33% 0;
  -ms-transform-origin: 33% 0;
  -webkit-transform-origin: 33% 0;
  transform-origin: 33% 0;
  top: 10px;
}

.header-area .main-nav .menu-trigger:not(.collapsed) span,
.header-area .main-nav .menu-trigger:not(.collapsed) span:before,
.header-area .main-nav .menu-trigger:not(.collapsed) span:after {
  background-color: transparent;
  width: 100%;
}

.header-area .main-nav .menu-trigger:not(.collapsed) span:before {
  -moz-transform: translateY(6px) translateX(1px) rotate(45deg);
  -ms-transform: translateY(6px) translateX(1px) rotate(45deg);
  -webkit-transform: translateY(6px) translateX(1px) rotate(45deg);
  transform: translateY(6px) translateX(1px) rotate(45deg);
  background-color: #1e1e1e;
}

.header-area .main-nav .menu-trigger:not(.collapsed) span:after {
  -moz-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  -ms-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  -webkit-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  transform: translateY(-6px) translateX(1px) rotate(-45deg);
  background-color: #1e1e1e;
}

.header-area.header-sticky {
  min-height: 80px;
  display: flex;
  align-items: center;
}

.header-area .nav {
  margin-top: 30px;
}

.header-area.header-sticky .nav li a.active {
  color: var(--secondary);
}

@media (min-width: 1400px) {
  .main-nav .collapse {
    display: block;
  }
  .main-nav .nav .nav-link{
    transition: color .3s;
    padding: 0.5rem 1rem;
  }
}
@media (max-width: 1400px) {
  .header-area .main-nav .logo {
    color: #1e1e1e;
  }
  .main-nav .nav .nav-link{
    transition: background-color .3s, color .3s;
    padding: 1rem 2rem;
  }
  .header-area.header-sticky .nav li .nav-link:hover,
  .header-area.header-sticky .nav li .nav-link.active {
    color: var(--secondary)!important;
    opacity: 1;
  }
  .header-area.header-sticky .nav li.search-icon a {
    width: 100%;
  }
  .header-area {
    background-color: #f7f7f7;
    padding: 0px 15px;
    height: 100px;
    box-shadow: none;
  }
  .header-area .container {
    padding: 0px;
  }
  .header-area .menu-trigger {
    display: block !important;
  }
  .header-area .main-nav {
    overflow: hidden;
  }
  .menu-collapse {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
  }
  .header-area .main-nav .nav {
    display: block;
    width: 100%;
    right: 0;
    background-color: white;
    text-align: center;
  }  
  .header-area .main-nav .nav li:first-child {
    border-top: 1px solid #eee;
  }
  .header-area .main-nav .nav li:last-child {
    padding-left: 0;
  }
  .header-area.header-sticky .nav {
    margin-top: 100px;
  }
  .header-area .main-nav .nav li {
    width: 100%;
    background: #fff;
    border-bottom: 1px solid #e7e7e7;
    padding: 0;
  }
  .header-area .main-nav .nav li a {
    padding: 1rem 2rem;
    border: none;
    color: #191a20;
    display: block;
  }
  .header-area .main-nav .nav li a:hover {
    background: #eee !important;
    color: var(--secondary);
  }
  
  .header-area .main-nav .nav li:last-child a {
    background-color: inherit;
    font-size: inherit;
    letter-spacing: 1px;
    font-weight: 500;
    border-radius: 0;
  }
}

/* 
---------------------------------------------
Banner Style
--------------------------------------------- 
*/

.main-banner {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 170px 0px 0px 0px;
  position: relative;
  overflow: hidden;
  z-index: 0;
}

.main-banner .bg {
  position: absolute;
  z-index: -1;
  pointer-events: none;
  opacity: .1;
}
.main-banner .bg-left {
  position: absolute;
  left: 0;
  top: 100px;
  width: 193px;
  height: 467px;
}

.main-banner .bg-right {
  right: 0;
  top: 100px;
  width: 98px;
  height: 290px;
}

.main-banner .left-content {
  margin-right: 45px;
}

.main-banner .left-content .h6 {
  text-transform: uppercase;
  font-size: 18px;
  color: var(--secondary);
  margin-bottom: 15px;
}

.main-banner .left-content h2 {
  font-size: 50px;
  font-weight: 700;
  color: #2a2a2a;
  line-height: 72px;
}

.main-banner .left-content h2 i {
  color: var(--primary);
  font-style: normal;
}

.main-banner .left-content h2 b {
  color: var(--secondary);
}

.main-banner .left-content p {
  margin: 20px 0px;
}

.main-banner .left-content form {
  margin-top: 30px;
  width: 470px;
  height: 66px;
  position: relative;
}

.main-banner .left-content form button {
  position: absolute;
  right: 10px;
  top: 10px;
  display: inline-block;
  background-color: #fff;
  font-size: 15px;
  font-weight: 500;
  color: var(--secondary);
  text-transform: capitalize;
  padding: 12px 25px;
  border-radius: 23px;
  letter-spacing: 0.25px;
  outline: none;
  border: none;
}

.main-banner .left-content form input {
  width: 470px;
  height: 66px;
  background-color: var(--primary);
  border-radius: 33px;
  border: none;
  outline: none;
  padding: 0px 25px;
  color: #fff;
  letter-spacing: 0.25px;
  font-size: 15px;
  font-weight: 300;
}

.main-banner .left-content form input::placeholder {
  color: #fff;
}



/* 
---------------------------------------------
About Us Style
--------------------------------------------- 
*/

#about {
  position: relative;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 140px 0px 120px 0px;
}

#about::before {
  content: ' ';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  mask: url(../images/about-mask.png);
  background-attachment: fixed;
  mask-size: cover;
  mask-position: center center;
}

#about .left-image {
  margin-right: 45px;
  img {
    aspect-ratio: 1/1.5;
    border-radius: 20px;
    object-fit: cover;
    object-position: top right;
  }
}
#about .services {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.about-us .services .item {
  margin-bottom: 30px;
}

.about-us .services .item .icon {
  float: left;
  margin-right: 25px;
}

.about-us .services .item .icon img {
  max-width: 70px;
}

.about-us .services .item h4 {
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 12px;
}

.about-us .services .item p {
  color: #fff;
}

/* 
---------------------------------------------
Services Style
--------------------------------------------- 
*/

.our-services {
  margin-top: 0px;
}

.our-services .left-image {
  content: '';
  margin-right: 45px;
  position: relative;
  aspect-ratio: auto 3 / 4;
  border-radius: 16rem;
  max-height: 600px;
  border: 5px solid var(--secondary);
}

.our-services .left-image img {
  object-fit: cover;
  height: 100%;
  width: 100%;
  border-radius: 16rem;
}

.our-services .left-image::before{
  content: '';
  position: absolute;
  top: -14px;
  left: -13px;
  min-height: 600px;
  aspect-ratio: auto 3 / 4;
  border: 5px solid var(--primary);
  border-radius: 16rem;
  transform: rotate(15deg);
  z-index: -1;
}

.our-services .section-heading h2 {
  margin-right: 100px;
}

.our-services .section-heading p {
  margin: 30px 0;
}

.our-services .progress-skill-bar {
  margin-bottom: 30px;
  position: relative;
  width: 100%;
}

.our-services .progress-skill-bar span {
  position: absolute;
  top: 0;
  font-size: 18px;
  font-weight: 600;
  color: var(--primary);
}

.our-services .first-bar span {
  left: 69%;
}

.our-services .second-bar span {
  left: 81%;
}

.our-services .third-bar span {
  left: 88%;
}

.our-services .progress-skill-bar h4 {
  font-size: 18px;
  font-weight: 700;
  color: #2a2a2a;
  margin-bottom: 14px;
}

.our-services .progress-skill-bar .full-bar {
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background-color: #f7eff1;
  position: relative;
  z-index: 1;
}

.our-services .progress-skill-bar .filled-bar {
  background: rgb(255,77,30);
  background: linear-gradient(105deg, rgba(255,77,30,1) 0%, rgba(255,44,109,1) 100%);
  height: 6px;
  border-radius: 3px;
  margin-bottom: -6px;
  position: relative;
  z-index: 2;
}

.our-services .first-bar .filled-bar {
  width: 71%;
}

.our-services .second-bar .filled-bar {
  width: 83%;
}

.our-services .third-bar .filled-bar {
  width: 90%;
}

.our-services ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-flow: row;
}


/* 
---------------------------------------------
contact
--------------------------------------------- 
*/

.phone-info {
  margin-top: 40px;
}

.phone-info h4 {
  font-size: 20px;
  font-weight: 700;
  color: #fff;
}

.phone-info h4 span i {
  width: 46px;
  height: 46px;
  display: inline-block;
  text-align: center;
  line-height: 46px;
  background-color: #fff;
  border-radius: 50%;
  color: #ff3b2c;
  font-size: 22px;
  margin-left: 30px;
  margin-right: 15px;
}

.phone-info h4 span a {
  color: #fff;
  font-size: 15px;
  font-weight: 400;
}

#contact {
  position: relative;
  padding-top: 130px;
}

#contact > div {
  padding-bottom: 2rem;
}

#contact .container .map {
  position: relative;
  z-index: 0;
}

#contact .container iframe {
  border-radius: 0 20px 20px 0;
  @media screen and (max-width: 992px) {
    border-radius: 20px;    
  }
}

#contact .container .info {
  @media screen and (max-width: 992px) {
    width: 100%;
    justify-content: space-around;    
  }
}

#contact .container .info {
  margin-left: 1rem;
  position: relative;
  display: inline-flex;
  color: #FFF;
}


#contact .container .info span {
  opacity: 1;
  display: inline-flex;
  margin-right: 30px;
}


#contact .container .info span i {
  width: 46px;
  height: 46px;
  display: inline-block;
  text-align: center;
  line-height: 46px;
  background: #FFF;
  border-radius: 50%;
  font-size: 22px;
  margin-left: 30px;
  margin-right: 15px;
}


#contact .container .info span a {
  font-size: 14px;
  font-weight: 400;
  line-height: 25px;
  text-transform: none;
  white-space: nowrap;
}


#contact .container .contact-form {
  position: relative;
  z-index: 1;
  display: grid;
  width: 100%;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto auto;
  @media screen and (max-width: 992px) {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    gap: 1rem;
  }
}

#contact .container .contact-form .section-title {
  @media screen and (max-width: 992px) {
    margin-bottom: 30px;
    grid-row-start: 1;
    grid-row-end: 2;
  }
}

#contact .container .contact-form #contact-form_wrapper {
  grid-row-start: 1;
  grid-row-end: 4;
  z-index: 1;
  @media screen and (max-width: 992px) {
    grid-row-start: 2;
    grid-row-end: 3;
    z-index: 0;    
  }
}

#contact > div::after {
  content: '';
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  position: absolute;
  mask: url(../images/mask-clouds.svg);
  background-color: #FFF;
  mask-position: bottom center;
  mask-size: 100% 100px;
  mask-repeat: no-repeat;
  pointer-events: none;
}

#contact_form .contact-dec {
  position: absolute;
  right: -166px;
  bottom: 0;
}

#contact_form #abouttextarea1 {
  height: 160px
}

#contact_form .contact-dec img {
  max-width: 178px;
}

#contact-form_wrapper, form#transfer-form, #refill-form_wrapper {
  position: relative;
  background-color: #fff;
  padding: 60px 30px;
  border-radius: 20px;
}

@media screen and (min-width: 1200px) {
  #refill-form_wrapper {
    min-height: 700px;
  }
}

#contact_form input,
form#transfer-form input,
form#webrefill--form input,
form#frmRegistration input,
form#contact_form select,
form#webrefill--form select,
form#transfer-form select,
form#frmRegistration select {
  border-radius: 33px;
  background-color: #d1f3ff;
  border: 1px solid transparent;
  color: #2a2a2a;
  min-height: 55px;
}

.phone {
  .input-group-text {
    border: 0;
    background-color: transparent;
  }
}
form#frmRegistration p {
  margin-bottom: 1.5rem;
}

#frmRegistration .form-group {
  margin-bottom: 1rem;
}

#contact_form .row,
#webrefill--form .row {
  row-gap: 1rem;
}

form#contact_form input::placeholder,
form#transfer-form input::placeholder
form#webrefill--form input::placeholder {
  color: #2a2a2a;
}

form#contact_form textarea,
form#transfer-form textarea,
form#webrefill--form textarea {
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  max-height: 180px;
  min-height: 140px;
  height: 140px;
  border-radius: 20px;
  background-color: #d1f3ff;
  border: none;
  outline: none;
  font-size: 15px;
  font-weight: 300;
  color: #2a2a2a;
  padding: 15px 20px;
}

form#contact_form textarea::placeholder,
form#transfer-form textarea::placeholder,
form#webrefill--form textarea::placeholder {
  color: #2a2a2a;
}

.transfer .item {
  border-radius: 10px;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.15);
  padding: 35px 30px;
  background-color: #fff;
  display: inline-block;
  min-width: 360px;
}

.btn {
  display: inline-block;
  font-size: 15px;
  font-weight: 400;
  text-transform: capitalize;
  padding: 12px 25px;
  border-radius: 23px;
  letter-spacing: 0.25px;
  border: none;
  outline: none;
  transition: all .3s;
}

.btn-primary {
  background-color: var(--primary);
  color: var(--primary-contrast);
}

.btn-primary:hover {
  background-color: var(--secondary);
  color: var(--secondary-contrast);
  border-color: var(--secondary);
}

.btn-secondary {
  background-color: var(--secondary);
  color: var(--secondary-contrast);
}

.btn-secondary:hover {
  background-color: var(--primary);
  color: var(--primary-contrast) !important;
}

.btn-square {
  aspect-ratio: 1/1;
  align-items: center;
}

/* 
---------------------------------------------
responsive
--------------------------------------------- 
*/

@media (max-width: 1645px) {
  form#contact .contact-dec {
    display: none;
  }
}

@media (max-width: 992px) {
  #contact_form, form#transfer-form, form#webrefill--form {
    margin-left: 0;
  }
  .main-banner {
    padding-top: 196px;
  }
  .main-banner .left-content {
    margin-right: 0px;
    text-align: center;
    margin-bottom: 45px;
  }
  .main-banner:after {
    top: 76px;
    z-index: -1;
  }
  .main-banner .left-content form,
  .main-banner .left-content form input {
    width: 100%!important;
  }
  #about {
    margin-top: 0px;
  }
  .about-us {
    position: relative;
    background-image: none;
    padding: 0px;
  }
  
  .about-us .left-image {
    margin-left: 45px;
    position: absolute;
    bottom: -220px;
    right: 0;
  }
  .about-us .services {
    padding-top: 2rem;
    padding-bottom: 2rem;
    text-align: center;
  }
  .about-us .services .item  {
    background: rgb(255,77,30);
    background: linear-gradient(105deg, var(--primary) 0%, var(--secondary) 100%);
    padding: 30px;
    border-radius: 20px;
    display: inline-block;
  }
  .wave .services .item h4 {
    color: var(--primary-contrast) !important;
    text-align: left;
  }
  .wave .services .item p {
    color: var(--primary-contrast) !important;
    text-align: left;
  }
  .our-services {
    padding-top: 0;
  }
  .our-services .left-image {
    margin-right: 0px;
    margin-bottom: 45px;
    max-height: 300px;
  }

  .our-services .left-image::before {
    min-height: 300px;
  }

  .our-services .section-heading h2,
  .our-services .section-heading p {
    margin-right: 0px;
    text-align: center;
  }
  .our-portfolio .section-heading h2 {
    margin: 0px 0px 80px 0px;
  }
  .our-portfolio .item {
    margin-bottom: 15px;
  }
  .our-blog {
    margin-top: 0px;
  }
  .our-blog .top-dec {
    display: none;
  }
  .our-blog .section-heading h2 {
    margin-right: 0px;
    text-align: center;
    margin-bottom: 45px;
  }
  .our-blog .left-image .info .inner-content {
    position: relative;
    margin-right: 0px;
  }
  .our-blog .left-image .info .main-blue-button {
    position: relative;
    bottom: 0px;
    margin-top: 30px;
  }
  .our-blog .left-image {
    margin-bottom: 45px;
  }
  .contact-us {
    margin-top: 60px;
    padding: 120px 0px;
  }
  .contact-us .section-heading {
    text-align: center;
  }
  form#contact {
    margin-left: 0px;
    margin-top: 30px;
  }
  form#contact .contact-dec {
    display: none;
  }
  footer p {
    margin: 15px 0px 30px 0px;
  }
  .copyright {
    background-color: #fafafa;
  }

  .wave::before {
    margin-top: 100px;
    mask-image: linear-gradient(black 30%, transparent 50%), url(../images/about-mask.svg) !important;
    padding: 20px 0px 120px 0px;
  }
  
  .about-us .left-image {
    display: none;
  }
}

@media (max-width: 767px) {
  .our-blog .right-list {
    margin-left: 0px;
  }
  .our-blog .right-list ul li {
    display: inline-block;
    margin-top: 0px;
    padding-top: 30px;
    border-top: 1px solid #eee;
  }
  .our-blog .right-list .left-content {
    margin-right: 0px;
    width: 100%;
    margin-bottom: 15px;
  }
  .our-blog .right-list .right-image,
  .our-blog .right-list .right-image img {
    width: 100%;
  }
  .phone-info h4 span {
    display: block;
    margin-top: 15px;
  }
  .phone-info h4 span i {
    margin-left: 0px;
  }    
  .our-services ul {
    grid-template-columns: 1fr;
  }
}

#banner-right {
  height: 622px;
  mask-image: var(--hero-overlay);
  -webkit-mask-position-x: center;
  -webkit-mask-position-y: center;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-origin: border-box;
  mask-clip: border-box;
  mask-composite: add;


  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  img.no-mask {
    object-fit:contain;
  }
}

.wave::before {
  content: ' ';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #00000050;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  mask: url(../images/about-mask.svg);
  background-attachment: fixed;
  mask-size: cover;
  mask-position: center center;
}

.wave {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 140px 0px 120px 0px;
  position: relative;
}

.wave .left-image {
  margin-right: 45px;
  img {
    aspect-ratio: 1/1.5;
    border-radius: 20px;
    object-fit: cover;
    object-position: top right;
  }
}

.wave .services .item {
  margin-bottom: 30px;
}

.wave .services .item .icon {
  aspect-ratio: 1/1;
  width: 86px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 !important;
}

.wave .services .item h4 {
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 12px;
}

.wave .services .item p {
  color: #fff;
}

.refill::before {
  background-image: linear-gradient(#00000070, #00000070), var(--refill-overlay);
}

.refill p{
  color: #FFFFFF;
}

.refill form div {
  margin: 0;
}

/* page banner */

#page-banner {
  background-position: 0 center;
  background-size: cover;
  background-attachment: fixed;
  background-repeat: no-repeat;
  position: relative;
}

#page-banner .bottom {
  transform:rotate(180deg);
  bottom: -1px;
  position: relative;
  pointer-events: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: #FFF;
}

.icon-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  border-radius: 0.25rem;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  height: 2.5rem;
  width: 2.5rem;
}

a {
  color: var(--primary);
}
a:hover {
  color: var(--secondary);
}

.text-primary-contrast {
  color: var(--primary-contrast);
}

.text-secondary-contrast {
  color: var(--secondary-contrast);
}

p {
  font-size: inherit;
}

.text-large {
  font-size: 1.25rem;
}


.contact-grid {
  width: 100% !important;
  display: grid;
  grid-template-columns: [left-start] 1fr [left-end right-start] 1fr [right-end];
  grid-template-rows: [top-start] auto [top-end bottom-start] auto [bottom-end];
  gap: 1.5rem;
  width: 100%;
  font-size: 1.25rem;
}


.contact-grid .headline {
  grid-area: top / left;
}

.contact-grid .map {
  grid-area: top / right /bottom;
}

.contact-grid .map div {
  height: 100%;
}


.contact-grid #contact_us {
  grid-area: bottom / left;
}

.contact-form .map div {
  height: 300px;
}

.map .info {
  height: auto !important;
}

.contact-form iframe {
  height: 340px;
}

.contact-form .headline {
  margin-bottom: 1.5rem;
}

.contact-grid.no-map {
  grid-template-columns: 1fr;;
}

.map-placeholder {
  background-color: #00000070;
  top:0;
  bottom:0;
  right: 0;
  left: 0;
}

.placeholder-img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .contact-grid {
      grid-template-columns: 1fr;
      grid-template-rows: auto auto auto;
  }
  .contact-grid .headline {
      grid-area: 1 / 1;
  }
  .contact-grid .map {
      grid-area: 2 / 1;
  }
  .contact-grid #contact_us {
      grid-area: 3 /1 ;
  }
}

.copyright {
  background-color: #fafafa;
}

div.date-pill-header {
  background-color: var(--primary);
  color: var(--primary-contrast);
}