@font-face {
    font-family: Perspective;
    src: url('../fonts/persans.ttf');
    src: url('../fonts/persans.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/persans.woff') format('woff'), /* Pretty Modern Browsers */
    url('../fonts/persans.ttf')  format('truetype'); /* Safari, Android, iOS */
}

@font-face {
    font-family: PerspectiveBold;
    src: url('../fonts/persansb.otf');
    src: url('../fonts/persansb.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/persansb.woff') format('woff'), /* Pretty Modern Browsers */
    url('../fonts/persansb.ttf')  format('truetype'); /* Safari, Android, iOS */
}

@font-face {
    font-family: HelveticaNeue;
    src: url('../fonts/HelveticaNeue.otf');
    /*src: url('../fonts/HelveticaNeue.ttf');*/
    /*src: url('../fonts/HelveticaNeue.woff2') format('woff2'), !* Super Modern Browsers *!*/
    /*url('../fonts/HelveticaNeue.woff') format('woff'), !* Pretty Modern Browsers *!*/
    /*url('../fonts/HelveticaNeue.ttf')  format('truetype'); !* Safari, Android, iOS *!*/
}

@font-face {
    font-family: HelveticaNeueLight;
    src: url('../fonts/HelveticaNeue-Light.ttf');
    src: url('../fonts/HelveticaNeue-Light.woff2') format('woff2'), /* Super Modern Browsers */
    url('../fonts/HelveticaNeue-Light.woff') format('woff'), /* Pretty Modern Browsers */
    url('../fonts/HelveticaNeue-Light.ttf')  format('truetype'); /* Safari, Android, iOS */
}

@font-face {
    font-family: HelveticaNeueBold;
    src: url('../fonts/HelveticaNeue-Bold.otf');
    /*src: url('../fonts/HelveticaNeue-Bold.woff2') format('woff2'), !* Super Modern Browsers *!*/
    /*url('../fonts/HelveticaNeue-Bold.woff') format('woff'), !* Pretty Modern Browsers *!*/
    /*url('../fonts/HelveticaNeue-Bold.ttf')  format('truetype'); !* Safari, Android, iOS *!*/
}

body,html{
    min-height: 100%;
    font-family: Perspective !important;
}

img{
    max-width: 100%;
}

.container{
    max-width: 980px;
    margin: auto;
}

.small-container{
    max-width: 80%;
}

.auto{
    margin: auto;
}

p{
    font-family: HelveticaNeue !important;
    font-size: 18px !important;
    line-height: 27px !important;
}

.niche-nav{
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0;
    align-items: center;
    width: 90%;
    margin: auto;
}

.niche-nav li{
    position: relative;
    flex-grow: 1;
    margin: 0 -10px;
    cursor: pointer;
}

.niche-nav li.active{
    pointer-events: none;

    transform: scale(1);
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.7);
    }

    70% {
        transform: scale(1);
        box-shadow: 0 0 0 10px rgba(0, 0, 0, 0);
    }

    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
    }
}

.niche-nav li.active img:nth-child(2),
.niche-nav li:hover img:nth-child(2){
    opacity: 1;
}

.niche-nav li:hover img:nth-child(2){
    top: calc(-5% + -3px);
    left: -5%;
    width: 110%;
    max-width: 110%;
    height: 110%;
}

.niche-nav li.active img:nth-child(1),
.niche-nav li:hover img:nth-child(1){
    opacity: 0;
}

.niche-nav li img{
    transition: 0.3s all;
}

.niche-nav li img:nth-child(2){
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    top: -3px;
    left: 0;
    opacity: 0;
}

.niche-content.active{
    display: block;
    opacity: 1;
}

.niche-content h3{
    font-family: PerspectiveBold !important;
    font-weight: normal !important;
    font-size: 30px !important;
    line-height: 36px !important;
}

.mobile-vertical-pad{
    padding: 70px 0;
}

.niche-content .intro-section h3{
    font-family: PerspectiveBold !important;
}

.niche-content{
    display: none;
    opacity: 0;
    transition: 0.8s all;
}

.pusher{
    min-height: 100%;
    height: 100%;
}

.top-nav{
    background: #DC7D31;
}

h3{
    font-size: 30px !important;
    line-height: 37px !important;
    margin-bottom: 52px ;
    font-family: PerspectiveBold;
    font-weight: normal !important;
}

.mobile{
    display: none;
}

.passion-mobile .content{
    max-width: 240px;
    display: block;
    width: 100%;
    margin: auto !important;
}

.passion-mobile .title{
    position: relative;
}


.passion-mobile .title i{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 20px;
}

.passion-mobile .content .passion-mobile-image{
    max-width: 150px;
    width: 100%;
    display: block;
    margin: auto;
    margin-bottom: 15px;
}

.passion-mobile .content{
    color: #707070;
}



.passion-mobile h4{
    font-family: PerspectiveBold !important;
    font-weight: normal !important;
    color: #DC7D31;
    font-size: 18px !important;
    line-height: 24px !important;
    margin: 0;
    margin-bottom: 0px;
}

.passion-mobile h5{
    font-family: HelveticaNeueBold;
    font-size: 16px !important;
    line-height: 21px !important;
    margin: 0;
    margin-bottom: 10px !important;
    color: #7D7D7D;
}

.passion-mobile ul{
    /*padding-left: 18px;*/
    padding:0;
    font-size: 18px;
    margin-top: 0;
    list-style: none;
}

.passion-mobile ul li{
    display: flex;
    font-size: 15px;
}

.passion-mobile ul li:before{
    content: '';
    display: inline-block;
    background-image: url('../images/bubble.svg');
    background-repeat: no-repeat;
    width: 15px;
    min-width: 15px;
    height: 15px;
    background-position: center;
    background-size: contain;
    margin-top: 6px;
    margin-right: 15px;
}

.dekstop .passion-mobile ul li.white:before{
    background-image: url('../images/bubble-white.svg');
}


.passion-mobile ul li{
    font-family: HelveticaNeue !important;
    font-size: 15px !important;
    line-height: 21px !important;
    /*padding-left: 8px;*/
    margin-bottom: 10px;
}

@media not all and (min-resolution:.001dpcm)
{ @supports (-webkit-appearance:none) and (stroke-color:transparent) {

    h1,h3,
    .passion-tabs h4{
        /*font-family: PerspectiveBold;*/
        /*font-weight: normal !important;*/
        /*letter-spacing: -1px;*/
    }

}}

h4{
    font-size: 18px !important;
    line-height: 27px !important;
    margin-bottom: 26px ;
    font-family: HelveticaNeue;
    font-weight: normal !important;
}

h2{
}

.primary-text{
    color: #DC7D31;
}

.black-text{
    /*color: #000000 !important;*/
    color: #ffc20e !important;
}

.white-text{
    color: #fff !important;
}

.ui.visible.right.sidebar ~ .fixed, .ui.visible.right.sidebar ~ .pusher {
    -webkit-transform: translate3d(0, 0, 0) !important;
    transform: translate3d(0, 0, 0) !important;
}

nav{
    opacity: 0;
}
.ui.very.wide.sidebar.right.top-nav.visible nav{
    opacity: 1;
}

nav{
    position: absolute;
    right: 0;
    width: 100%;
    max-width: 700px;
    top: 0%;
    /*transform: translateY(-50%);*/
    padding: 40px 40px 40px 50px;
    box-sizing: border-box;
}

nav #close{
    text-align: right;
    padding-left: 0;
    color: #fff;
    /*padding-left: calc(90% - 100px);*/
    margin-bottom: 18px;
}

nav #close img{
    display: inline-block;
    max-height: 30px;
    max-width: 30px;
    cursor: pointer;
    transition: 0.3s all;
}

nav #close img:hover{
    opacity: 0.7;
}

nav ul,
nav ul li{
    list-style: none;
    padding: 0px;
    margin: 0;
}

nav ul li a{
    display: inline-block;
    color: #fff;
    font-size: 24px;
    line-height: 24px;
    margin-bottom: 25px;
    transition: 0.3s all;
    opacity: 0.6;
}

nav ul li.active a{
    color: #fff !important;
    opacity: 1;
}

nav ul li a:hover{
    color: #fff !important;
    opacity: 1;
}

header{
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    background: #fff;
    z-index: 100000;
    -webkit-box-shadow: 0px 10px 8px -8px rgba(0,0,0,0.1);
    -moz-box-shadow: 0px 10px 8px -8px rgba(0,0,0,0.1);
    box-shadow: 0px 10px 8px -8px rgba(0,0,0,0.1);
}
header, footer{
    padding: 25px;
    display: flex;
}

footer{
    align-items: center;
}


header .logo,
footer .footer-logo{
    margin-bottom: -25px;
    margin-top: -4px;
}

header .logo,
header .navigation-toggle,
footer .copyright,
footer .footer-logo{
    width: 50%;
}


footer .copyright{
    font-size: 12px;
}

header .navigation-toggle,
footer .footer-logo{
    text-align: right;
}

header .navigation-toggle img{
    max-width: 50px;
    max-height: 25px;
    height: 25px;
    cursor: pointer;
}

.bubble{
    position: relative;
}

.bubble:before{
    content: '';
    position: absolute;
    background-image: url('../images/bubble.svg');
    background-repeat: no-repeat;
    width: 50px;
    height: 50px;
    background-position: center;
    background-size: contain;
    top: -25px;
    left: -55px;
}

.image.contain.absolute.contact img{
    height: 135% !important;
    bottom: -30%;
}

.banner-video{
    position: relative;
    z-index: -1;
    width: 100%;
    height: calc(100%);
    max-height: 600px;
    background: #ebebeb;
    overflow: hidden;
}

.banner-video h1{
    font-family: PerspectiveBold;
    font-weight: normal;
    position: absolute;
    top: 50%;
    left: 15%;
    transform: translateY(-50%);
    color: #fff;
    font-size: 55px ;
    line-height: 55px;
    z-index: 1;
}

.vertical-center{
    display: flex;
    align-items: center;
}

#intro-video{
    transform: translate(-50%, -50%);
    position: absolute;
    left: 50%;
    top: 50%;
    min-width: 100%;
    min-height: 100%;
}

.intro-section{
    display: flex;
    align-items: stretch;
    flex-wrap: wrap;
}

.square{
    width: 100%;
    padding-top: 100%; /* 1:1 Aspect Ratio */
    position: relative; /* If you want text inside of it */
    border-radius: 40px;
    background: #808080;
    cursor: pointer;
    transition: background 0.3s;
}

.w50-hub{
    width: 33.33%;
}

.ui.sidebar{
    z-index: 99999999999 !important;
}
.square.orange{
    background: #dd7e30 !important;
}
.square.yellow{
    background: #ffc20e !important;
}
.square.gray{
}

.square:hover{
    background: #f4f4f4 !important;
}

.square:hover .context h3{
    color: #000 !important;
}

.square:hover .logo img:nth-child(2){
    display: inline
}
.square:hover .logo img:nth-child(1){
    display: none
}

.read-more{
    margin: 25px 0;
    border-radius: 30px;
    border: 1px #fff solid;
    padding: 8px 35px;
    display: inline-block;
    cursor: pointer;
}

.image{
    position: relative;
}

.padded-all.vertical-padding{
    padding-top: 80px;
    padding-bottom: 80px;
}

.padded-all.vertical-padding-none{
    padding-top: 0px;
    padding-bottom: 0px;

}

.image.contain.padded.absolute.custom img{
    height: 150% !important;
}

.image.absolute img{
    position: absolute;
    height: 125% !important;
    width: 100% !important;
    left: 0;
    right: 0;
    bottom: -20%;
    object-position: bottom !important;
}

.read-more-text{
    height: 0;
    overflow: hidden;
    transition: height 0.3s;
}

.read-more:hover{
    color: #dc7d31;
    background: #fff;
}

.square .logo img:nth-child(2){
    display: none;
}
.square:hover .context h3 strong{
    color: #DC7D31 !important;
}

.square .context{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    padding: 35px;
}

.square .context h3 {
    font-family: Perspective;
    font-weight: normal !important;
    font-size: 18px !important;
    line-height: 21px !important;
    color: #fff !important;
}

.square .context h3 p{
    font-size: 18px !important;
    line-height: 21px !important;
}

.square .context h3 strong{
    font-family: PerspectiveBold;
    font-weight: normal !important;
}

.square .logo{
    position: absolute;
    bottom: 20px;
    left: 35px;
}

.square .logo img{
    max-height: 35px ;
}

.fluid{
    width: 100%;
}

.cbl{
    -webkit-border-bottom-left-radius: 200px;
    -moz-border-radius-bottomleft: 200px;
    border-bottom-left-radius: 200px;
    overflow: hidden;
}

.ctr{
    -webkit-border-top-right-radius: 200px;
    -moz-border-radius-topright: 200px;
    border-top-right-radius: 200px;
    overflow: hidden;
}

.ctl{
    -webkit-border-top-left-radius: 200px;
    -moz-border-radius-topleft: 200px;
    border-top-left-radius: 200px;
    overflow: hidden;
}

.pusher{
    padding-top: 80px !important;
}

.col-3{
    width: 30%;
}

.w10{
    width: 10%;
}

.w20{
    width: 20%;
}
.w30{
    width: 30%;
}
.w40{
    width: 35%;
}
.w50{
    width: 50%;
}
.w60{
    width: 65%;
}
.w70{
    width: 70%;
}
.w80{
    width: 80%;
}
.w90{
    width: 90%;
}
.w100{
    width: 100%;
}

.form-group{
    margin-bottom: 25px;
}

.form-group input{
    border: 0;
    border-bottom: 1px #000 solid;
    -webkit-border-bottom-right-radius: 5px;
    -webkit-border-bottom-left-radius: 5px;
    -moz-border-radius-bottomright: 5px;
    -moz-border-radius-bottomleft: 5px;
    border-bottom-right-radius: 5px;
    border-bottom-left-radius: 5px;
    background: none;
    padding: 15px 20px ;
    width: 100%;
    outline: none;
}

.contact-submit{
    display: block;
    color: #FFC20E;
    background: #000;
    border-radius: 50px;
    border: 0;
    padding: 15px 30px;
    width: 100%;
    max-width: 220px;
    text-align: center;
    margin: 0 auto;
}


.form-group input::placeholder{
    text-align: center;
    font-family: Perspective !important;
    font-size: 18px;
    color: #000;
}


.image.contain,
.image.cover{
    width: 100%;
    height: 100%;
    max-height: 100%;
    max-width: 100%;
}

.padded-all{
    padding: 140px;
}

.image.contain img{
    object-fit: contain;
    object-position: center;
    /*width: 100%;*/
    width: auto;
    height: 100%;
    margin-bottom: -5px;
}

.image.cover img{
    object-fit: cover;
    object-position: center;
    width: 100%;
    height: 100%;
    margin-bottom: -5px;
}


.image-cover{
    object-fit: cover;
    object-position: center;
    min-width: 100%;
    max-width: 100%;
    min-height: 100%;
    max-height: 100%;
    height: 100%;
    width: 100%;
}

.pad-bottom-mobile{
    padding-bottom: 100px !important;
}

.padded{
    padding: 50px;
}
.very.padded{
    padding: 50px 250px;
}

.super.padded{
    padding: 150px 250px;
}
.pad-right-0{
    padding-right: 0 !important;
}

.pad-right-s{
    padding-right: 50px !important;
}
.pad-left-s{
    padding-left: 50px !important;
}

.pad-left-0{
    padding-left: 0 !important;
}
.pad-bottom-0{
    padding-bottom: 0 !important;
}

.pad-top-0{
    padding-top: 20px !important;
}


.padding-right-small{
    padding-right: 150px !important;
}

.quote{
    position: relative;
    padding-left: 130px;
    width: 95%;
    box-sizing: border-box;
}

.quote:before{
    content: '';
    position: absolute;
    top: 14px;
    left: 0;
    width: 120px;
    height: 3px;
    background: #DC7D31;
}

.quote.black:before{
    /*background: #000;*/
    background: #ffc20e;
}

.quote.white:before{
    background: #fff;
}


.quote.inverted:before{
    background: #FFC20E;
}

.col-3:nth-child(2){
    width: 40%;
    padding: 0 5%;
}

.passion-tabs{
    margin-top: 50px;
}

.yellow-bg{
    background: #ffc20e;
}

.orange-bg{
    background: #dc7d31;
}

.gray-bg{
    background: #DFE0E1;
}

.col-3:nth-child(2) .passion-tabs{
}

.passion-tabs h4{
    font-family: PerspectiveBold !important;
    font-weight: normal !important;
    color: #DC7D31;
    font-size: 21px !important;
    line-height: 28px !important;
    margin: 0;
    font-weight: bold !important;
    margin-bottom: 10px;
}

.passion-tabs h5{
    font-family: HelveticaNeueBold;
    font-weight: normal;
    font-size: 18px !important;
    line-height: 24px !important;
    margin: 0;
    margin-bottom: 10px !important;
    color: #7D7D7D;
}

.passion-tabs ul{
    /*padding-left: 18px;*/
    padding:0;
    font-size: 18px;
    margin-top: 0;
    list-style: none;
}

.passion-tabs ul li{
    display: flex;
}

.passion-tabs ul li:before{
    content: '';
    display: inline-block;
    background-image: url('../images/bubble.svg');
    background-repeat: no-repeat;
    width: 15px;
    min-width: 15px;
    height: 15px;
    background-position: center;
    background-size: contain;
    margin-top: 6px;
    margin-right: 15px;
}

.passion-tabs ul li.white:before{
    background-image: url('../images/bubble-white.svg');
}

.orange-bg .col-3 .passion-tabs .title span,
.orange-bg .col-3 .passion-tabs .content h5
{
    color: #fff;
}

.passion-tabs ul li{
    font-family: HelveticaNeue !important;
    font-size: 18px !important;
    line-height: 24px !important;
    /*padding-left: 8px;*/
    margin-bottom: 10px;
}

.passion-tabs .image{
    max-height: 300px;
    margin-bottom: 20px;
}

.passion-tabs .title span{
    font-family: HelveticaNeue;
    font-size: 15px;
    color: #808080;
}

.passion-tabs .image img{
    max-height: 250px;
}

.brand-logo{
    width: calc(20% - 40px) !important;
    position: relative;
    cursor: pointer;
    margin: 20px;
}

.brand-logo:hover img:nth-child(2n){
    opacity: 1;
}
.brand-logo img:nth-child(2n){
    position: absolute;
    top: calc(50% - 2px);
    left: 0;
    width: 100%;
    max-width: 100%;
    opacity: 0;
    transition: opacity 0.5s;
    transform: translateY(-50%);
    background: #000;
    /*opacity: 0;*/
}


.pad-top-none{
    padding-top: 0 !important;
}
