#videobanner{
  position: relative;
}
#videobanner .covervid-wrapper{
    width: 100%;
    height: 100svh;
    overflow: hidden;
    position: relative;
    -moz-background-size: cover;
      -o-background-size: cover;
         background-size: cover;
    background-position: center center;
}
#videobanner .covervid-wrapper video{
  width: 100svw;
  height: auto;
}
#videobanner .description{
  position: absolute;
  left: 0;
  bottom: 2.5rem;  
  max-width: 55svw;
}
#videobanner .description .text{
  background-color: rgba(22,22,22,0.2);
  padding: 2rem 2rem 2rem 9rem;
  margin-bottom: 2rem;
}
#videobanner .description h1, #videobanner .description h6, #videobanner .description h5, #videobanner .description h4, #videobanner .description h3, #videobanner .description h2, #videobanner .description p{
  color: #ffffff;
}
#videobanner .description h1{
  font-size: 4rem;
  line-height: 4rem;
  margin-bottom: 1rem;
}
#videobanner .description h6, #videobanner .description h5, #videobanner .description h4, #videobanner .description h3, #videobanner .description h2{
  font-size: 2rem;
  line-height: 2.2rem;
}
#videobanner .description p{
  font-size: 1.071rem;
}
#videobanner .description .butns{
  -webkit-box-pack: end;
  -webkit-justify-content: end;
     -moz-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
-webkit-box-align: center;
-webkit-align-items: center;
   -moz-box-align: center;
    -ms-flex-align: center;
            -ms-grid-row-align: center;
        align-items: center;
padding-left: 7rem;
}
#videobanner .description .butns a, #videobanner .description .butns button{
  padding: 1.2rem 4rem;
  margin-bottom: 0;
  margin-left: 2rem;
}
#videobanner .description .butns a:hover, #videobanner .description .butns button:hover{
     -webkit-box-shadow: 0 0 30px rgba(9,54,245,0.2);
     -moz-box-shadow: 0 0 30px rgba(9,54,245,0.2);
     -ms-box-shadow: 0 0 30px rgba(9,54,245,0.2);
     -o-box-shadow: 0 0 30px rgba(9,54,245,0.2);
     box-shadow: 0 0 30px rgba(9,54,245,0.2);
     background: #0936F5;
background: -moz-linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
background: -webkit-gradient(linear,left bottom,right top,color-stop(0%,#0936F5),color-stop(100%,#2984BD));
background: -webkit-linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
background: -o-linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
background: linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
}
#videobanner .next {
position: absolute;
bottom: -3rem;
left: 0;
right: 0;
margin: auto;
background-color: #ffffff;
width: 6rem;
-webkit-border-radius: 100%;
   -moz-border-radius: 100%;
        border-radius: 100%;
padding: 1rem;
height: 6rem;
text-align: center;
}
#videobanner .next svg{
  width: 1.5rem;
}
#videobanner .next:hover{
  -webkit-box-shadow: 0 0 30px rgba(9,54,245,0.5);
-moz-box-shadow: 0 0 30px rgba(9,54,245,0.5);
-ms-box-shadow: 0 0 30px rgba(9,54,245,0.5);
-o-box-shadow: 0 0 30px rgba(9,54,245,0.5);
box-shadow: 0 0 30px rgba(9,54,245,0.5);
background: -webkit-linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
background: -moz-linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
background: -o-linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
background: linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
width: 8rem;
height: 8rem;
bottom: -4.5rem;
-webkit-transition: all .3s ease;
-o-transition: all .3s ease;
-moz-transition: all .3s ease;
transition: all .3s ease;
}
#videobanner .next:hover svg{
  width: 2rem;
}
#videobanner .next:hover svg path{
  fill: #ffffff;
}
#main1{
  -webkit-box-pack: end;
  -webkit-justify-content: end;
     -moz-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  background-position: top center;
     background-repeat: no-repeat;
     -moz-background-size: cover;
       -o-background-size: cover;
          background-size: cover;
}
#main1 h2 {
font-size: 3.097rem;
line-height: 3.3rem;
color: #ffffff;
background-color: #000;
padding: 1.806rem 3.097rem;
margin: 0;
width: 110%;
margin-left: -10%;
}
#main1 .text{
  width: 45%;
  background-color: #161616;
  margin-top: 50vh;
}
#main1 .text .editor{
  padding: 2.323rem 3.097rem;
}
#main1 .text p{
  color: #ffffff;
}
#portfolio{
  overflow: hidden;
}
#portfolio h2{
  font-size: 3.097rem;
line-height: 3.3rem;
color: #ffffff;
background-color: #000;
padding: 1.806rem 3.097rem;
margin: 0;
width: 66%;
}
#portfolio .masonry {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  margin: 2.323rem 2.097rem 2.323rem 3.097rem;
  /* min-height: 100svh; */
}
#gridimages{
  display: block;
  position: relative;
  width: 100%;
  /* animation-name: fadeInUp;
  animation-duration: 1.2s;
    transition-duration: 1.2s; */
}
#portfolio .masonry .grid-sizer, #portfolio .masonry .grid-item, #gridimages .gridimages-sizer, #gridimages .gridimages-item{
  width: -webkit-calc(25% - 1rem);
  width: -moz-calc(25% - 1rem);
  width: calc(25% - 1rem)
}
#portfolio .masonry .grid-item, #gridimages .gridimages-item {
  margin-bottom: 1rem;
}
#portfolio .masonry .grid-item .playvideo, #portfolio .masonry .grid-item .playgallery, #gridimages .gridimages-item{
  position: relative;
  cursor: pointer;
  /* opacity: 0; */
  /* visibility: hidden; */
}
#portfolio .masonry .grid-item .playvideo div, #portfolio .masonry .grid-item .playgallery div{
  position: absolute;
  margin: auto;
  left: 0;
  right: 0;
  bottom: 0;
}
#portfolio .masonry .grid-item .playvideo div{top: 0;}
#portfolio .masonry .grid-item .playgallery div{bottom: 4px;}
/* #gridimages .gridimages-item img{
  animation-name: fadeIn;
  animation-duration: 1.1s;
    transition-duration: 1.1s;
} */
#portfolio .masonry .grid-item .playvideo div span {
     width: auto;
     -webkit-border-radius: 100%;
     -moz-border-radius: 100%;
     border-radius: 100%;
     background: -webkit-linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
     background: -moz-linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
     background: -o-linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
     background: linear-gradient(45deg,#2984BD 0%,#0936F5 100%);
     display: -webkit-inline-box;
     display: -webkit-inline-flex;
     display: -moz-inline-box;
     display: -ms-inline-flexbox;
     display: inline-flex;
     -webkit-box-align: center;
     -webkit-align-items: center;
     -moz-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: center;
     -webkit-justify-content: center;
     -moz-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     padding: .4rem;
     vertical-align: middle;
     position: absolute;
     top:0;
     right: 0;
     bottom: 0;
     left: 0;
     margin: auto;
     width: 3rem;
     height: 3rem;
     z-index: 12;
}
#portfolio .masonry .grid-item .playgallery div h6{
  text-align: center;
  padding: .3rem;
  background-color: rgba(22, 22, 22, 0.75);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  color: #ffffff;
  margin: 0;
}
#portfolio .masonry .grid-item .playgallery:hover div h6{
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  -webkit-transition: opacity 1s ease;
     -o-transition: opacity 1s ease;
     -moz-transition: opacity 1s ease;
     transition: opacity 1s ease;
}
#portfolio .masonry .grid-item .playvideo div span svg {
     float: left;
     width: 1.5rem;
     height: 1.5rem;
     z-index: 2;
     position: relative;
}
#portfolio .masonry .grid-item .playvideo div span svg path{
     fill: #ffffff;
}
#portfolio .masonry .grid-item .playvideo div i{
     content: '';
     position: absolute;
     top: 50%;
     left: 50%;
     -webkit-transform: translate(-50%, -50%);
        -moz-transform: translate(-50%, -50%);
         -ms-transform: translate(-50%, -50%);
          -o-transform: translate(-50%, -50%);
             transform: translate(-50%, -50%);
     width: 10rem;
     height: 10rem;
     background-color: rgba(255,255,255,0.13);
     -webkit-border-radius: 100%;
        -moz-border-radius: 100%;
             border-radius: 100%;
     z-index: 10;
     opacity: 0;
     -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
     pointer-events: none;
     -webkit-transition: opacity 1s ease, width 1s ease, height 1s ease;
     -o-transition: opacity 1s ease, width 1s ease, height 1s ease;
     -moz-transition: opacity 1s ease, width 1s ease, height 1s ease;
     transition: opacity 1s ease, width 1s ease, height 1s ease;
}
#portfolio .masonry .grid-item .playvideo div i:before{
     content: '';
     position: absolute;
     top: 50%;
     left: 50%;
     -webkit-transform: translate(-50%, -50%);
        -moz-transform: translate(-50%, -50%);
         -ms-transform: translate(-50%, -50%);
          -o-transform: translate(-50%, -50%);
             transform: translate(-50%, -50%);
     width: 6rem;
     height: 6rem;
     background-color: rgba(255,255,255,0.23);
     z-index: 10;
     opacity: 0;
     -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
     pointer-events: none;
     -webkit-transition: opacity 0.3s ease, width 0.3s ease, height 0.3s ease;
     -o-transition: opacity 0.3s ease, width 0.3s ease, height 0.3s ease;
     -moz-transition: opacity 0.3s ease, width 0.3s ease, height 0.3s ease;
     transition: opacity 0.3s ease, width 0.3s ease, height 0.3s ease;
     -webkit-border-radius: 100%;
        -moz-border-radius: 100%;
             border-radius: 100%;
}
#portfolio .masonry .grid-item .playvideo div:hover i, #portfolio .masonry .grid-item .playvideo div:hover i:before {
     opacity: 1;
     -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}
#portfolio .masonry .grid-item .playvideo div:hover span{
     background: #0936F5;
     background: -moz-linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
     background: -webkit-gradient(linear,left bottom,right top,color-stop(0%,#0936F5),color-stop(100%,#2984BD));
     background: -webkit-linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
     background: -o-linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
     background: linear-gradient(45deg,#0936F5 0%,#2984BD 100%);
}
#gallerycarousel .swiper-slide img{
  max-height: -webkit-calc(100svh - 4.797rem);
  max-height: -moz-calc(100svh - 4.797rem);
  max-height: calc(100svh - 4.797rem);
  margin: auto;
  display: block;
}
#gallerycarousel .swiper-button-next, #gallerycarousel .swiper-button-prev {
  color: #ffffff;
}
#gallerycarousel .swiper-button-next:hover, #gallerycarousel .swiper-button-prev:hover {
  color: #0936F5;
}
#gallerycarousel .swiper-button-next:after, #gallerycarousel .swiper-button-prev:after {
  font-size: 2rem;
}

.loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #ffffff;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
     -moz-box-orient: vertical;
     -moz-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
     -moz-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
     -moz-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 9999;
}

.loader .spinner {
  border: 2px solid #F2F2F2;
  border-top: 2px solid #000000;
  -webkit-border-radius: 50%;
     -moz-border-radius: 50%;
          border-radius: 50%;
  width: 4rem;
  height: 4rem;
  -webkit-animation: spin 1s linear infinite;
     -moz-animation: spin 1s linear infinite;
       -o-animation: spin 1s linear infinite;
          animation: spin 1s linear infinite;
}




@media only screen and (max-width: 1400px) {
    #portfolio .masonry .grid-sizer, #portfolio .masonry .grid-item, #gridimages .gridimages-sizer, #gridimages .gridimages-item {
      width: -webkit-calc(33.33% - 1rem);
      width: -moz-calc(33.33% - 1rem);
      width: calc(33.33% - 1rem);
    }

}

@media only screen and (max-width: 1274px){
    #videobanner .covervid-wrapper video {
        width: auto;
        height: 100svh;
    }
    #videobanner .description {
        max-width: -webkit-calc(100% - 2rem);
        max-width: -moz-calc(100% - 2rem);
        max-width: calc(100% - 2rem);
    }
    #videobanner .description .butns {
      -webkit-box-pack: start;
      -webkit-justify-content: start;
         -moz-box-pack: start;
          -ms-flex-pack: start;
              justify-content: start;
    }
    #main1 .text {
        width: 85%;
    }
}

@media only screen and (max-height: 630px), only screen and (max-width: 830px) {
    #videobanner {
        background-position: top center;
        background-repeat: no-repeat;
        -moz-background-size: cover;
       -o-background-size: cover;
          background-size: cover;
    }
    #videobanner .covervid-wrapper {
        min-height: 25rem;  
    }
    #videobanner.mobiletoo .covervid-wrapper {
        visibility: hidden;
        opacity: 0;
    }
    #videobanner .next{
        display: none;
    }
    #videobanner .covervid-wrapper video {
        height: auto;
        min-height: 100svh;
    }
    #videobanner .description{
        left: 1.3rem;
        right: 2rem;
    }
    #videobanner .description .butns{
        padding-left: 0;
    }
    #videobanner .description .butns a{
        margin-left: 0;
    }
    #videobanner .description .text{
        padding: 1.3rem;
        margin-bottom: 1rem;
    }
    #videobanner .description h1{
        font-size: 2.63rem;
        line-height: 3rem;
    }
    #videobanner .description h6, #videobanner .description h5, #videobanner .description h4, #videobanner .description h3, #videobanner .description h2 {
        font-size: 1.75rem;
        line-height: 2rem;
    }
    #videobanner .description p {
        font-size: 1rem;
        line-height: 1.2;
    }
    #main1 .text{
        width: 100%;
        margin-bottom: inherit;
        margin-top: 0;
        background-color: transparent;
        position: relative;
        height: 100%;
    }
    #main1 .text .editor {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        background-color: #161616;
    }
    #main1 h2 {
        width: 100%;
        margin-left: 0;
        font-size: 1.5rem;
    }
    #main2 .image{
        -webkit-box-ordinal-group: 2;
        -webkit-order: 1;
           -moz-box-ordinal-group: 2;
            -ms-flex-order: 1;
                order: 1;
     }
     #main2 .text{
        -webkit-box-ordinal-group: 3;
        -webkit-order: 2;
           -moz-box-ordinal-group: 3;
            -ms-flex-order: 2;
                order: 2;
     }
    #main2 .image, #main3 .image, #main4 .image, #main2 .text, #main3 .text, #portfolio h2{
        width: 100%;
    }
    #main2 .text h2, #main3 .text h2, #main4 .text h2, #world .info h3, #portfolio h2{
        font-size: 1.571rem;
    }
    #portfolio .masonry .grid-sizer, #portfolio .masonry .grid-item, #gridimages .gridimages-sizer, #gridimages .gridimages-item {
      width: -webkit-calc(50% - 1rem);
      width: -moz-calc(50% - 1rem);
      width: calc(50% - 1rem);
    }
    #portfolio .masonry .grid-item .playvideo div i:before{
      width: 4rem;
      height: 4rem;
    }
    #portfolio .masonry .grid-item .playvideo div i{
      width: 3rem;
      height: 3rem;
    }
    #portfolio .masonry .grid-item .playvideo div span{
      width: 2rem;
      height: 2rem;
    }
    #portfolio .masonry .grid-item .playvideo div span svg {
      width: 1rem;
      height: 1rem;
    }
}
@media only screen and (max-width: 700px){
#videobanner .description .butns button:nth-child(2){
        display: none;
    }
}
@media only screen and (max-width: 500px){
  #main1 .text .editor {
    padding: 1.323rem 1.097rem;
  }
  #main1 h2, #portfolio h2 {
    padding: 0.806rem 1.097rem;
  }
  #portfolio .masonry{
    margin:  1.323rem 0.097rem 1.323rem 1.097rem;
  }
}


@media (orientation: portrait) {
  #main1 {
        aspect-ratio: 9/16;
    }
}
@media (orientation: landscape) {
  #main1 {
        aspect-ratio: 16/9;
    }
}