/********** Hero **********/
.hero-new-wrapper {
  width: 100%;
  height: 100vh;
  position:relative;
  overflow: hidden;
}
.of-cover {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  font-family: 'object-fit: cover;';
}
.of-cover {
  width: 100% !important;
  height: 100% !important;
  -o-object-fit: cover;
     object-fit: cover;
  font-family: "object-fit: cover;";
  -webkit-filter: grayscale(80%);
    filter: grayscale(80%);
}


.slider__circle, .section__circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: auto;
  width: calc(100vw - 80px);
  height: calc(100vw - 60px);
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: 100%;
  z-index: 1;
  pointer-events: none;
}
.bg-hero {
  background: url(../images/homepage/hero.jpg) no-repeat;
  background-size: cover;
  background-position: center;
}
.bg-hero-2 {
  background: url(../images/homepage/ai-hero.jpg) no-repeat;
  background-size: cover;
  background-position: center;
}
.hero-block-height {
  min-height: 100vh;
  overflow: hidden;
}
.hero-overlay{
content: " ";
position: absolute;
left: 0;
top: 0;
height: 100vh;
width: 100%;
background-color: rgba(0,0,0,0);
z-index: 1;
}
.hero-overlay-2 {
content: " ";
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
background: rgb(0,0,0);
background: radial-gradient(circle at center, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.35) 100%);
}
.hero-straplines{
position:absolute;
left:100px;
top:50%;
transform: translateY(-50%);
width: 900px;
z-index: 2;
}
.hero-straplines.lg{
position:absolute;
left:100px;
top:50%;
transform: translateY(-50%);
width: 1000px;
z-index: 2;
}
.hero-straplines h1{
color: #ffffff;
line-height: 1.2;
letter-spacing: 0;
font-size: 50px;
}
.hero-straplines.lg h1{
color: #ffffff;
line-height: 1.2;
letter-spacing: 0;
font-size: 70px;
font-weight: 400;
}
.hero-straplines .subtext {
width:600px;
margin-top:20px;
position: relative;
padding-bottom: 100px;
}
.hero-straplines .subtext p{
color: #ffffff;
}
.hero-straplines .text-btn-normal {
  color: #ffffff;
  font-family: 'GothamPro', sans-serif;
  text-transform:uppercase;
  font-size:12px;
  font-weight: 400;
  letter-spacing:2.5px;
  line-height: 1;
}
.hero-straplines .text-btn-normal:hover {
  color: #ffffff;
  opacity:0.5;
}
.c-scrolldown {
  width: 1px;
  height: 100px;
  position: absolute;
  bottom: 20px;
  right: 12px;
  overflow: hidden;
  z-index: 2;
}
.c-scrolldown .c-line {
  width: 100%;
  height: 100%;
  display: block;
  background: linear-gradient(to bottom, #ffffff 50%, rgba(255, 255, 255, 0) 50%);
  background-position: 0 -100px;
  background-size: 100% 200%;
  animation: scrolldown 2.2s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
}
@keyframes scrolldown {
  0% {
    background-position: 0 -100px;
  }
  75% {
    background-position: 0 0;
  }
  100% {
    background-position: 0 100px;
  }
}
.hero-discover-block {
position:absolute;
right:22px;
bottom:10px;
z-index:2;
}
@media only screen and (max-width: 1620px) {
.hero-straplines{
width:600px;
}
.hero-straplines .subtext {
width:500px;
}
}
@media only screen and (max-width: 1400px) {
.hero-straplines.lg{
width:700px;
}
.hero-straplines.lg h1{
font-size: 50px;
}
}
@media only screen and (max-width: 1100px) {
.hero-straplines{
left:50px
}
}
@media only screen and (max-width: 991px) {
.bg-hero {
  background-position: center right 10%;
}
.hero-straplines{
position:absolute;
left:0;
top:50%;
margin-top: 150px;
transform: translateY(-50%);
width: 100%;
z-index: 2;
text-align: center;
padding-left:120px;
padding-right: 120px;
}
.hero-straplines.lg{
position:absolute;
left:0;
top:50%;
margin-top: 0;
transform: translateY(-50%);
width: 100%;
z-index: 2;
text-align: center;
padding-left:80px;
padding-right: 80px;
}

.hero-straplines .subtext {
width: 100%;
padding-left:80px;
padding-right: 80px;
padding-bottom: 60px;
}
.hero-discover-block {
position:absolute;
right:auto;
left:50%;
transform: translateX(-50%);
}
.c-scrolldown {
 display:none
}

.hero-overlay{
background: rgb(0,0,0);
background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 60%, rgba(0,0,0,0.4) 100%);
}
}
@media only screen and (max-width: 767px) {
.hero-straplines{
padding-left:50px;
padding-right:50px;
}
.hero-straplines.lg{
padding-left:50px;
padding-right:50px;
}
.hero-straplines .subtext {
width: 100%;
padding-left:30px;
padding-right: 30px;
padding-bottom: 60px;
}
}
@media only screen and (max-width: 599px) {
.bg-hero {
  background-position: center right 25%;
}
.subtext-intro{
display: none;
}
.hero-straplines h1{
color: #ffffff;
line-height: 1.2;
letter-spacing: 0;
font-size: 34px;
}
.hero-straplines{
padding-left:15px;
padding-right:15px;
margin-top: 180px;
}
.hero-straplines.lg{
padding-left:15px;
padding-right:15px;
}
.hero-straplines .subtext {
padding-bottom: 30px;
}
.hero-straplines.lg h1{
color: #ffffff;
line-height: 1.2;
letter-spacing: 0;
font-size: 30px;
}
}

@media only screen and (max-width: 380px) {
.bg-hero {
  background-position: center right 15%;
}
.hero-straplines{
margin-top: 150px;
}
}
/********** Hero End **********/
@media only screen and (max-width: 1199px) {
.banner-no-ssc{
display: none;
}
}

.submenu {
    border: 1px solid #000000;
    background-color: #000000;
}
.navigation-menu > ul > li.has-children > a::before {
    border-bottom-color: #000000;
    border-left-color: #000000;
    background-color: #000000;
}

.submenu > li > a{
-webkit-transition: all 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
}

.submenu > li > a:hover {
    color: #dddddd;
}

@media only screen and (max-width: 1080px) {
.navigation-menu > ul > li > a {
  padding: 36px 0!important;
}
}

/********** Scroll Down **********/
@-webkit-keyframes rotating {
from{
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
}
to{
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
}
.rotating {
-webkit-animation: rotating 5s linear infinite;
}
.rotating-text{
width: 100px;
position:absolute;
z-index: 1;
}
.scrolling-circle{
position:absolute;
bottom:180px;
right:180px;
}
.text-arrow{
width: 100px;
position:absolute;
top:0;
z-index: 1;
}
.scroll-down{
position:absolute;
width: 100px;
height: 100px;
bottom:100px;
right:50px;
}
@media only screen and (max-width: 767px) {
.scroll-down{
position:absolute;
bottom:130px;
right:auto;
left: 15px;
}
}
/********** Scroll Down End **********/

/********** Pinned Sections **********/
.sticky-section {
  display: flex;
  flex-direction: column;
  margin-bottom: 80px;
}
.sticky-section > * {
  flex: 1;
}
.sticky-scroll {
  padding: 0 0 0 50px;
}

.sticky-scroll.right-al{
  padding: 0 50px 0 0;
}
.sticky-item {
  align-items: center;
  align-self: flex-start;
  margin: 0;
  width: 100%;
  justify-content: center;
  top: 80px;
}
.pinned-spacer-lg{
clear: both;
height: 300px;
}
.pinned-spacer-md{
clear: both;
height: 200px;
}
.pinned-spacer-sm{
clear: both;
height: 100px;
}
.pinned-spacer-xs{
clear: both;
height: 60px;
}
@media only screen and (max-width: 767px) {
.swap-on-mobile {
display: flex !important;
flex-direction: column-reverse;
}
.sticky-scroll.right-al, .sticky-scroll{
  padding: 50px 30px 0 30px;
}
}
@media only screen and (max-width: 575px) {
.sticky-scroll.right-al, .sticky-scroll{
  padding: 50px 0 0 0;
}
}
@media screen and (min-width: 767px) {
.sticky-section {
flex-direction: row;
}
.sticky-item {
position: sticky;
}
}
/********** Pinned Sections  End **********/

/********** jarrallax stuff **********/
.jarallax {
    position: relative;
    z-index: 0;
}
.jarallax > .jarallax-img {
    position: absolute;
    object-fit: cover;
    /* support for plugin https://github.com/bfred-it/object-fit-images */
    font-family: 'object-fit: cover;';
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}
.j-content-table {
    display: table;
    width: 100%;
    height: 75vh;
    background-color: rgba(0,0,0,0)!important;
    color: #fff;
}
.j-content-table-cell {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}
@media (max-width: 991px){
.j-content-table {
    height: 450px;
}
}
@media (max-width: 767px){
.j-content-table {
    height: 400px;
}
}
@media (max-width: 575px){
.j-content-table {
    height: 300px;
}
}
/********** jarrallax stuff End **********/

/********** Global Paddings and Cleaners **********/

.container-fluid.pad-lr{
padding-left: 200px;
padding-right:200px;
}

@media only screen and (max-width: 1700px){
.container-fluid.pad-lr{
padding-left: 150px;
padding-right:150px;
}
}
@media only screen and (max-width: 1500px){
.container-fluid.pad-lr{
padding-left: 100px;
padding-right:100px;
}
}
@media only screen and (max-width: 1400px){
.container-fluid.pad-lr{
padding-left: 50px;
padding-right:50px;
}
}
@media only screen and (max-width: 1199px){
.container-fluid.pad-lr{
padding-left: 30px;
padding-right:30px;
}
}
/********** Global Paddings and Cleaners End **********/

/********** Ordered and Bulleted Lists **********/
.sticky-scroll ol{
padding-left:20px;	
}

.sticky-scroll ol li{
padding-top:10px;
padding-bottom: 10px;
}
/********** Ordered and Bulleted Lists End **********/

/********** Buttons and Links **********/
.t-btn-primary {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: 14px 14px 13px 24px;
    color: #fff;
    border-radius: 42px;
    text-transform: uppercase;
    font-size:12px;
	font-family: 'GothamPro', sans-serif;
	font-weight: 400;
    letter-spacing: 0.5px;
    border: 1px solid #fff;
    overflow: hidden;
    transition: color 0.6s cubic-bezier(.165,.84,.44,1)!important;
	transform: translateZ(0)
}
.t-btn-primary:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 65px;
    height: 65px;
    border-radius: 30px;
    background: #fff;
    transition: transform 0.6s cubic-bezier(.165,.84,.44,1)!important;
    transform: translate(-150%,50%) translateZ(0);
}
.t-btn-primary--black {
    color: #111;
    border: 1px solid #111;
	
}
.t-btn-primary--black:before {
    background: #111;
}
.t-btn-primary span {
    position: relative;
}
.t-btn-primary span {
  -webkit-transition: color 0.6s cubic-bezier(.165,.84,.44,1)!important;
  -o-transition: color 0.6s cubic-bezier(.165,.84,.44,1)!important;
  transition: color 0.6s cubic-bezier(.165,.84,.44,1)!important;
}

.t-btn-primary-arrow:last-child {
    margin-left: 8px;
}
.t-btn-primary-arrow {
    display: inline-block;
	font-size: 18px;
}
.t-btn-primary:hover {
    color: #111;
}
.t-btn-primary--black:hover {
    color: #fff;
}
.t-btn-primary:hover:before {
    transform: translate(-50%,-50%) scale(4) translateZ(0);
    transition: transform 0.6s cubic-bezier(.165,.84,.44,1)!important;
}
/********** Buttons and Links End **********/