#hero_slideshow{
    display: flex;
    flex-direction: column;
    position: relative;
    width: 100vw;
    height: 100vh;
    color:#fff;
    text-align: center;
    overflow: hidden;
}
#hero_slideshow:before{
    opacity: .15;
    position: absolute;
    top:0; left: 0;
    content:"";
    z-index: 1;
    width:100%;
    height:100%;
    background:black;
}
#hero_slideshow:before{
    opacity: 1;
    background:linear-gradient(hsl(0,0%,0%,0.0),hsl(0,0%,0%,0.5))
    
}

#hero_slideshow .logo {
    position: absolute;
    left:0;
    right: 0;
    z-index: 2;
    width: calc(10vw + 5em);
    max-width: 16rem;
    height: auto;
    margin:calc(4vh + 12em) auto 0;
    min-width: 14.5rem;
}

#hero_slideshow .slide {
    opacity: 0;
    visibility: hidden;
    display: flex;
    flex-direction:column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    transition: opacity .75s cubic-bezier(0,0,0.3,1), visibility .75s cubic-bezier(0,0,0.3,1);
}

#hero_slideshow .slide.active {
    opacity: 1;
    visibility: visible;
}

#nextButton, #prevButton {
    position: absolute;
    bottom:0;
    right:6em;
    z-index: 2;
    cursor: url("images/next.svg"), auto;
    width:calc(40vw - 7em);
    height:100vh;
    background:none;
    border:none
}

#prevButton {
	left:6em; right:auto; 
	cursor: url("images/prev.svg"), auto;
}

#hero_slideshow .text-wrapper {
    display: flex;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 3;
    max-width: 30em;
    margin: auto auto clamp(2.5rem, 2rem + 2vw, 3.5rem);
}

#hero_slideshow .text {
    opacity:0;
    visibility: hidden;
    position: absolute;
    bottom: 0;
    padding: 0 calc(.5vw + 1.5em);
}
#hero_slideshow .text.active {
    opacity:1;
    visibility: visible;
}

#hero_slideshow a {
    display: inline-block;
    position: relative;
    color:white;
    text-decoration: none;
}

#hero_slideshow h3 {
    opacity: 0;
    visibility: hidden;
    transform:translate3d(0,-50%,0);
    font-size: 1.5rem;
    font-family: var(--font-header);
    font-weight: 500;
    color:white;
    text-transform: uppercase;
    margin:0 auto .75em;
    letter-spacing: .05em;
    transition: opacity .75s .125s cubic-bezier(0,0,0.3,1), visibility .75s .125s cubic-bezier(0,0,0.3,1), transform 1s cubic-bezier(0,0,0.3,1);
}

#hero_slideshow a:after {
    opacity: 0;
    position: absolute;
    bottom:1em;
    left:0; right:0;
    content: "";
    height: 1px;
    background: var(--gold-color);
    transform:scale(0);
    transition: transform .75s .25s cubic-bezier(0,0,0.3,1), opacity .75s .25s cubic-bezier(0,0,0.3,1), visibility .75s .25s cubic-bezier(0,0,0.3,1);
}
#hero_slideshow .active a:after {
    transform:scale(1);
    opacity: 1;
    visibility: visible;
}
#hero_slideshow p {
    opacity: 0;
    visibility: hidden;
    font-size: .975em;
    font-weight: 300;
    line-height: 1.5;
    margin: 0 auto;
    transition: opacity 1s .35s cubic-bezier(0,0,0.3,1), visibility 1s .35s cubic-bezier(0,0,0.3,1), transform 1s .25s cubic-bezier(0,0,0.3,1);
    transform:translate3d(0,-25%,0);
}
#hero_slideshow .active h3, #hero_slideshow .active p {
    opacity: 1;
    visibility: visible;
    transform:none;
}
#hero_slideshow .bullets {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    z-index: 3;
    position: absolute;
    right:clamp(1.5em,1.5em + 2vw, 3em); 
    top:50%;
    width: 4px;
    transform:translate3d(0,-50%,0);
}

#hero_slideshow .bullets span {
    opacity: .75;
    z-index: 2;
    position: relative;
    height:.5em;
    width:.5em;
    margin:.5em;
    padding:.5em;
    border-radius: 50%;
    border:1px solid transparent;
    cursor: pointer;
    transition: .5s opacity cubic-bezier(0,0,0.3,1), .5s border cubic-bezier(0,0,0.3,1);
}
#hero_slideshow .bullets span:after {
    content:"";
    position: absolute;
    z-index: 1;
    width: .5em;
    height:.5em;
    top:50%;
    left:50%;
    transform:translate3d(-50%,-50%,0);
    background-color: white;
    border-radius: 50%;
    transition: .5s opacity cubic-bezier(0,0,0.3,1)
}

#hero_slideshow .bullets span.active {
    opacity: 1;
    border-color: white;
    cursor:default;
}

#hero_slideshow .counter {
    opacity: .85;
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    bottom:3.5em;
    left: calc(3vw + 1.5em);
    z-index: 2;
    font-weight: 400;
    width: 5.5em;
    height:1em;
    overflow:hidden;
}
#hero_slideshow .counter:after {
    content:"";
    width:2.5em;
    height:1px;
    background:white;
    opacity: .5;
}
#hero_slideshow .counter span {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    left:0;
    font-size: .825em;
}
#hero_slideshow .counter span:not(.last){
    transform:translate3d(0,-1em,0);
    transition: .5s cubic-bezier(0,0,0.3,1);
}
#hero_slideshow .counter span.active {
    opacity: 1;
    visibility: visible;
    transform:none;
}

#hero_slideshow .counter span.last {
    opacity: 1;
    right:0; left:auto;
    visibility: visible;
}





@media only screen and (max-width: 80rem) {
    #hero_slideshow .logo { min-width: 13rem;}
}

@media only screen and (max-width: 64rem) {
    #nextButton, #prevButton {display: none;}
    #hero_slideshow .text{
        font-size: .9375rem;
    }

    #hero_slideshow .logo {
        margin: calc(1vh + 8.5em) auto 0;

    }
    #hero_slideshow .counter, #hero_slideshow .bullets {display:none}

}

@media only screen and (max-width:40rem) {
    #hero_slideshow .logo {
        margin: calc(1vh + 9em) auto 0;
    }

}
@media only screen and (max-width:32rem) {

    #hero_slideshow .logo {
        margin:calc(4vh + 7em) auto 0;
    }
}

