body{
	background-color: #000000;
    color: #FFF;
}
header {
    border-top: 5px solid #ffc700;
	
}
.labels-container {
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 20%;
    max-width: 20%;
    pointer-events: none;
    text-align: right;
}

.labels-container .label-4k {
    max-width: 27%;
    display: inline-block;
}
.labels-container .label-exclusive {
    max-width: 67%;
    display: inline-block;
}

.description-text{
	padding: 2px 6px;
	#min-height: 70px;
}
.description-text-title{
	font-size:14px;
	color: #FFF;
}
.description-text-date{
	font-size:14px;
	color: #FFF;
	
			padding-top: 10px;
	padding-bottom: 10px;
}
.description-text-title_18{
	font-size:18px;
	color: #ffc700;
	
}
.update-info-title_clip{
		font-size: 24px;
	}
	.update-info-block{
		    line-height: 1.0;

	}
footer a {
    color: #ffc700;
}
footer a:hover {
    color:#ffc700;
}
.video-duration {
    position: absolute;
    left: 5px;
    bottom: 5px;
    padding: 2px 6px;
    border-radius: 15px;
	color: #fff;
    background-color: #000;
	opacity: 0.5;
    font-size: 12px
}
.midpage-container .midpage-container-text-wrapper {
    position: absolute;
    left: 70px;
    top: 55%;
    transform: translatey(-50%);
    max-width: 37%;
}
.stats-block.join-stats .statbox {
    margin-top:.25em;
    display:block;
    padding-top:.05em;
 }
 .join-offer-icon {
    max-width:200px; 
    position:absolute; 
    top:-50px; 
    left:20px;
 }
  .stats-block {
     text-align:center;
 }
  .stats-block.join-stats {
    float: right;
    font-size: 4em;
    margin-top: 1em;
 }

 .statbox {
     width:2em;
     height:2em;
     color:#fff;
     display:inline-block;
     text-shadow:none;
     vertical-align:middle;
 }
 
 .statbox.green {
     background-color:#2bc75b;
 }
 .statbox.red {
     background-color:#fb5555;
 }
 .statbox.orange {
     background-color:#ff9235;
 }
 .statbox.blue {
     background-color:#4ecbfb;
 }
 .statbox.pink {
     background-color:#ff7db2;
 }
 .statbox .stat.big {
     font-weight:bold;
     font-size:.6em;
     line-height: 1.4em;
     margin-top: .6em;
     letter-spacing: -0.05em;
 }
 .statbox .stat.big.huge {
    font-size:1em;
    margin-top:0;
    line-height:1.2em;
 }
 .statbox .stat.big.huge span{
    font-size: .4em;
    vertical-align: super;
    margin-left: -0.3em;
 }
 .statbox .stat.small {
     font-size: .25em;
     letter-spacing: -0.05em;
     line-height: 1em;
 }
.pagination li {
    float:left;
    font-size: 18px;
}
.pagination a, .pagination span {
    border: 2px solid #3e3e3e;
    display: inline-block;
    color: #656565;
    margin: 0 0.2em 0.5em;
    padding: 0.25em 0.75em;
}
.pagination .current {
    color: #ffffff;
}


@media only screen and (max-width: 970px) {
    .join-page .form {
        padding: 10px;
        margin-top:0;
    }

    .join-page .form .header {
        margin-top:0;
    }

}

@media (min-width:1600px) {
    .col-xlg-6 {
        width:50%;
    }

}

body .container-fluid {
    width:100%;
    max-width:2200px;
	padding-left: 0px;
	padding-right: 0px;
}

header {
    background-color:transparent;
    transition:all .2s linear;
    z-index: 500;
    position:fixed;
    left:0px;
    top:0px;
    right:0px;
	#background-color:#000;
}

header .header-content {
    max-width:2200px;
    margin:0 auto;
    font-size:1vw;
	
	
}

header.scrolled {
	background-color:transparent;
    #background-color:rgba(0,0,0,.333);
    background-color:#000;
	
}

header .logo {
    
	text-align:left;
    padding:0 10px;
    line-height:1.3em;
    font-size:2.2em;
    letter-spacing:-1px;
#background-color:#FFF;
	
}

header .menu {
    text-align:right;
    padding:0 10px;
	
}

header .menu a.menu-item {
    font-weight:bold;
    padding:0 10px;
    transition:all .2s linear;
    text-transform:uppercase;
    letter-spacing:-1px;
    font-size:1.2em;
	color: #FFF;
}
header .menu a.menu-item:hover { 
    color: #52c564;
}


header .menu .button.red, header .menu .button.green {
    letter-spacing:-1px;
    font-size:1.2em;
}

header .logo img {
    max-height:50px;
}



.main-bxslider.static-bxslider li:nth-child(2) video.videobackground {
    position:absolute;
    left:50%;
    transform:translatex(-50%);
}
@media (min-width:1400px) {
    .main-bxslider video.videobackground {
        width:100%;
    }
}
@media(max-width:1199px) and (orientation:portrait) {
    .main-bxslider.static-bxslider video.videobackground {
        width:100%;
    }
	
}
@media (min-width:1980px) {
    header .header-content {
        font-size:0.4vw;
    }

    header .logo {
        font-size: inherit;
    }

    .main-banner .overlay-text.animated {
        font-size:1.5vw;
    }

}

@media (min-width:992px) and (max-width:1199px) {
    header .logo img {
        max-height:30px;
    }
}

@media (max-width:991px) {
    header .logo img {
        
		max-height: 60px;
    max-width: 300px 
    }
}

.button.green {
        border:2px solid #2da340;
    background-color:#2da340;
	color: #FFF;
	transition :all .2s linear;
}
.button.green:hover {
background-color:#117a22;
	border:2px solid #2da340;
	color: #FFF;
	
}
.button {
    background-color:#52c564;
}
.button:hover {
    background-color:#289339;
}
.padding-0 {
    padding:0px;
}

.absolute {
    position:absolute;
    left:0px;
    top:0px;
    width:100%;
    height:100%;
}

.main-banner {
    width:100%;
    height:100%;
    height:calc(100vh - 61px);
    position:relative;
}

.main-banner .discount-icon-container, .video-banner .discount-icon-container {
    position:absolute;
    left:5vw;
    bottom:2vw;
    width:12vw;
    z-index:1;
    pointer-events:none;
}

.midpage-container .discount-icon-container, footer.sinful-footer .discount-icon-container {
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
    width:12vw;
    z-index:1;
    pointer-events:none;
}

.main-banner.video-banner {
    height:calc(100vh - 100px);
}

.main-banner .bx-wrapper {
    height:100%;
}
.main-banner .bx-wrapper img {display:inline;}

.main-banner .bx-wrapper .bx-viewport {
    height:100% !important;
}

.main-banner .bxslider.main-bxslider {
    height: 100%; 
}

.main-banner .bxslider.main-bxslider li.group{
    height:100%;
}
.main-banner .bxslider.main-bxslider .slide {
    height:100%;
    background-size:cover;
    background-position:center center;
}

.main-banner .bxslider.main-bxslider .slide.slide-1 {
    background-image:url('https://cdnstatic.imctransfer.com/static_01/grandmams/sept01.jpg');
}
.main-banner .bxslider.main-bxslider .slide.slide-2 {
    background-image:url('https://cdnstatic.imctransfer.com/static_01/grandmams/sept02.jpg');
}
.main-banner .bxslider.main-bxslider .slide.slide-3 {
    background-image:url('https://cdnstatic.imctransfer.com/static_01/grandmams/sept03.jpg');
}
.main-banner .bxslider.main-bxslider .slide.slide-4 {
    background-image:url('https://cdnstatic.imctransfer.com/static_01/grandmams/sept04.jpg');
}



.main-banner .bxslider.main-bxslider .slide .scene-description, .small-banner .scene-description {
    position:absolute;
    top:100px;
    left:50px;
    opacity:.8;
    text-align:right;
    transition: opacity .2s linear;

}
.small-banner .scene-description.model-description:hover { 
    opacity:1;
}
.main-banner .bxslider.main-bxslider li.group .slide .scene-description .animation { 
    opacity:0;
    transition: all 1.2s linear;
} 
.main-banner .bxslider.main-bxslider li.group.active-slide .slide .scene-description .animation, .small-banner .scene-description .animation { 
    opacity:1;
} 
.main-banner .bxslider.main-bxslider .slide .scene-description .scene-title, .small-banner .scene-description .scene-title{ 
    font-size:24px;
    line-height:18px;
    font-weight:bold;
	color: #FFF;
    text-shadow: 1px 1px 3px #000;
}
.main-banner .bxslider.main-bxslider .slide .scene-description .scene-tag, .small-banner .scene-description .scene-tag{ 
    font-size:18px;
    line-height:16px;
	color: #FFF;
    text-shadow: 1px 1px 3px #000;
} 
.main-banner .bxslider.main-bxslider .slide .scene-description .header-banner-4k-icon, .small-banner .scene-description .header-banner-4k-icon { 
    position:absolute;
    right:-52px;
    top:0px;
    width:46px;
}
.small-banner .scene-description .header-banner-female-icon { 
    position:absolute;
    right:-30px;
    top:0px;
    font-size:2.4em;
}


.main-banner .overlay-text, .small-banner .overlay-text{
    opacity:1;
    letter-spacing:-0.1em;
    font-size:3vw;
    line-height:1em;
    width:100%;
	color: #FFF;
    text-align:center;
    position:absolute;
    left:0px;
    bottom:0.5em;
    pointer-events:none;
    z-index:1;
	color: #FFF;
    text-shadow: 1px 1px 3px #000;
}


.overlay-text .join-overlay {
    pointer-events:auto;
    margin-bottom:.5em;
    letter-spacing:-0.05em;
    text-shadow:none;
    font-size:.5em;
}

@media(max-width:767px) {
    .overlay-text .join-overlay {
        font-size:1em;
    }
}
.small-banner {
    position:relative;
    background-position: center center;
    background-size: cover;
}




.bx-wrapper .bx-controls-direction a {
    text-indent:0;
    width:40px;
    height:100px;
    padding:10px;
    text-align:center;
}


.bx-wrapper .bx-controls-direction a .slider-arrow {
    max-width:100%;
    transition:all .2s linear;
}

.bx-wrapper .bx-controls-direction a:hover .slider-arrow {
    filter: drop-shadow(0px 0px 5px #fff);
}

.bx-wrapper .bx-controls-direction a.bx-prev {
    left:10px;
}

.bx-wrapper .bx-controls-direction a.bx-next {
    right:10px;
}
.main-banner .overlay-text.animated, .small-banner .overlay-text.animated { 
    animation: appear 3s linear;
}

.main-banner .overlay-text .big, .small-banner .overlay-text .big {
    font-weight:bold;
    font-size:1.3em;
}

.main-banner .overlay-text .icons {
    margin-top:0.3em;
}

.main-banner .overlay-text .icons img{ 
    max-width:30vw;
    
}
.play-icon {
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
    font-size:3em;
    opacity:0;
    transition:all .2s linear;
    pointer-events:none;
    z-index:1;
}

.thumbnail-play-icon {
    position:absolute; 
    left:50%; 
    top:50%; 
    transform:translate(-50%,-50%);
    color:rgba(255,255,255,.8);
}

@media(max-width:767px) {
    .thumbnail-play-icon {
        font-size:2em;
    }
}

.row-separator {
    height:1px;
    width:100%;
    background-color:#FFF;
    margin:30px 0;
}

.row-separator-text {
    position:absolute;
    top:50%;
    left:50%;
    font-weight:bold;
    transform:translate(-50%, -50%);
    background-color:#000000;
    padding:0 30px;
    font-size:1.5em;
    white-space:nowrap;
    text-align:center;
    text-transform:uppercase;
}
.row-separator-text-video {
    font-weight: bold;
    transform:none;
    text-align:left;
    display: inline-block;
    vertical-align: middle;
    line-height: 1.5em;
    font-size: 2.3em;
    margin:0;
}

.benefits-container {
     position:absolute;
     right:100px;
     top:50%;
     transform:translatey(-50%);
     font-size:1.5em;
     letter-spacing:-1px;
 }
 @media(max-width:1199px) {
    .benefits-container {
        display:none;
    }
	.row-separator {
    height:1px;
    width:100%;
    background-color:#000000;
    margin:30px 0;
}
 }
 .benefits-container .benefit-wrapper{
     background-color: rgba(0,0,0,0.4);
     border-radius: 50%;
     border: 5px solid #fff;
     text-align: center;
     width: 150px;
     height: 150px;
     margin: 15px 0;
     line-height: 1em;
     pointer-events: auto;
     padding: 30% 0;
     display: block;
 }

 .benefit-wrapper .main-stat {
     line-height: 1.2em;
     font-size:1.5em;
     pointer-events:none;
 }
 .benefit-wrapper .secondary-stat {
     font-size: 0.8em;
     line-height: 1em;
     font-weight: normal;
     pointer-events:none;
 }

 .benefit-wrapper:hover {
     animation: ripple .75s linear infinite;
 }

.mt-5 {
    margin-top:5px;
}

.mt-0 {
    margin-top:0px;
}

.mb-0 {
    margin-bottom:0px;
}

.mt-10 {
    margin-top:10px;
}
.mt-20 {
    margin-top:20px;
}


.letter-space-1 {
    letter-spacing:-1px;
}

.letter-space-2 {
    letter-spacing:-2px;
}



.row.gutter-10 {
    margin-right:-5px;
    margin-left:-5px;
}
.row.gutter-10 > [class*='col-'] {
  padding-right:5px;
  padding-left:5px;
}

.ratio-16-9::before {
    padding-top:56.25%;
    content: '';
    display: block;
}

.ratio-1-2::before {
    padding-top:150%;
    content:'';
    display:block;
}
.ratio-1-2-new::before {
    padding-top:114.75%;
    content:'';
    display:block;
}
.ratio-1-3::before {
    padding-top:200%;
    content:'';
    display:block;
}


.ratio-3-1::before {
    padding-top:33.33%;
    content:'';
    display:block;
}

.ratio-4-1::before {
    padding-top:25%;
    content:'';
    display:block;
}
.video-item {
    background-size:cover;
    background-repeat:no-repeat;
    background-position:center center;
}

.video-wrapper {
    position:relative;
    overflow:hidden;
}

.video-preview {
    position:absolute; 
    left:0px;
    top:0px;
    width:112%;
    height:112%;
}

.video-preview video {
    opacity:0;
    transition:all .2s linear;
    width:100%;
    height:100%;
}

.video-wrapper:hover .video-preview video {
    opacity:1;
}

body .progressive-load {
    opacity:0;
    transition:opacity 0 linear;
}
body .progressive-load2 {
    opacity:1;

}
body .progressive-load.loaded {
    opacity:1;
}

.video-wrapper .video-item.static-item {
    transition:all .2s linear;
}
.video-wrapper:hover .video-item:not(.noHover), .video-wrapper:hover .video-preview:not(.noHover) {
	filter:brightness(50%);
}


.top-rated-row .video-wrapper:hover .video-item, 
.top-rated-row .video-wrapper:hover .video-preview {
    filter: blur(30px);
}
.video-wrapper:hover .play-icon, .main-banner:hover .play-icon {
    opacity:1;
}

.video-wrapper:hover .video-description, .video-wrapper:focus .video-description {
    opacity:1;
}

.static-video-wrapper .video-description, .video-wrapper .video-description {
    pointer-events:none;
    z-index:1;
    height:100%;
}
.access-button2 {
    font-size:1.8em;;
    padding:.6em 1.2em;
    font-weight:bold;
    border:2px solid #2da340;
    background-color:#2da340;
	color: #FFF;
    transition :all .2s linear;
    display:inline-block;
    margin: 15px 0;
    border-radius: 25px;

}

.access-button2:hover {
        background-color:#117a22;
	border:2px solid #2da340;
	color: #FFF;
}

.access-button3 {
    font-size:1.8em;
    padding:.6em 1.2em;
    font-weight:bold;
    border:2px solid #2da340;
    background-color:#2da340;
	color: #FFF;
    transition :all .2s linear;
    display:inline-block;
    margin: 15px 0;
    border-radius: 25px;

}
.access-button3:hover {
        background-color:#117a22;
	border:2px solid #2da340;
	color: #FFF;
}
.access-button4 {
      font-size:1.5em;
    padding:.6em 1.2em;
    font-weight:bold;
    border:2px solid #2da340;
    background-color:#2da340;
	color: #FFF;
    transition :all .2s linear;
    display:inline-block;
    margin: 15px 0;
    border-radius: 25px;

}
.access-button4:hover {
    background-color:#117a22;
	border:2px solid #2da340;
	color: #FFF;
}

.pos-relative {
    position:relative;
    width:100%;
    height:100%;
}
.static-video-wrapper .video-description .thumbnail-btn, .video-wrapper .video-description .thumbnail-btn {
    pointer-events:auto;
    position: absolute;
    left: 50%;
    top:50%;
    transform: translate(-50%, -50%);
    margin-top:0;
    white-space:nowrap;
} 
.static-video-wrapper .video-description .btn-wrapper {
    position:relative;
}
.video-wrapper .video-description {
    position:absolute;
    left:0px;
    top:0px;
    padding:10px;
    margin:0;
    text-transform:uppercase;
    line-height:26px;
    line-height:1.5vw;
    font-size:1.5vw;
    letter-spacing:-2px;
    opacity:0;
    transition:all .2s linear;
    width:100%;
	color:#FFF;
}
.video-wrapper .video-description .featuring { 
    font-weight:bold;
    font-size:12px;
    font-size:0.7em;
	
}
.video-wrapper .video-description .featuring3 { 
    font-weight:regular;
    font-size:10px;
    font-size:0.7em;
	line-height:1.0vw;
	text-align:center;
}

.midpage-container {
    position:relative;
    background-size:cover;
    background-repeat:no-repeat;
    background-position:center center;
    overflow:hidden;
    #font-size:1vw;
}

.midpage-container .top-overlay {
    position: absolute;
    top: 2em;
    left:0px;
    white-space: nowrap;
    width:100%; 
    display:flex;
    flex-direction:row;
    justify-content:center;
    opacity:0;
    transition: opacity 2s linear 1s;
}

.midpage-container .top-overlay.visible {
    opacity:1;
}

.midpage-container .top-overlay .top-overlay-element {
    margin: 0 15px;
}

.midpage-container .top-overlay .top-overlay-bullet {
    display: inline-block;
    width: 2em;
    height: 2em;
    background: #FFF;
    border-radius: 50%;
    opacity: .7;
}

.big{
	color:#FFF;
}
 .small{
	color:#FFF;
}

.midpage-container .top-overlay .top-overlay-text {
    display: inline-block;
    line-height: 1.1em;
    text-shadow: 1px 1px 3px #000;
}
.midpage-container .top-overlay .top-overlay-text .big { 
    font-size:1.5em;
    font-weight: bold;
}
.midpage-container .top-overlay .top-overlay-text .small { 
    font-size:1.2em;
}

.midpage-container .quote {
    font-style: italic;
    display: none;
    text-transform:uppercase;
    font-weight:bold;
    line-height:1em;
    font-size:1.4em;
    position: absolute;
    bottom:10px;
    display: block;
    width:75%;
    width:max-content;
    max-width:75%;
    animation-name:text-slide;
    animation-duration: 12s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    text-shadow:1px 1px 3px #000;
    letter-spacing:-0.05em;
} 

.midpage-container .quote span{
    display: block;
    font-size: .8em;
    font-style: normal;
    font-weight:normal;
}

.paginator {
    margin:0 auto;
    width:100%;
    text-align:center;
    max-width:100%;
}

.paginator a.page {
    display:inline-block;
    border-radius:50%;
    border:2px solid #FFF;
	color:#FFF;
    text-align:center;
    font-weight:bold;
    transition:all .1s linear;
    width: 40px;
    height: 40px;
    line-height: 26px;
    font-size: 20px;
    padding:5px;
    margin:0 3px;
}

.paginator span {
    font-size:2.2em;
    text-align:center;
}

.paginator a.page:hover, .paginator a.page.active { 
    color:#ffc700;
    border-color:#ffc700;
}

@keyframes text-slide {
    0% { right: -100%; opacity: 0; }
    20%,80% { right: 50%; opacity: 1; transform:translatex(50%);}
    100% { right: 110%; opacity: 0; }
}
@-webkit-keyframes text-slide {
    0% { right: -100%; opacity: 0; }
    20%,80% { right: 50%; opacity: 1; transform:translatex(50%);}
    100% { right: 110%; opacity: 0; }
}

.model-wrapper {
    position:relative;
    background-size:contain;
    background-repeat:no-repeat;
	
}

.model-wrapper a.absolute {
    transition:all .2s linear;
}
.model-wrapper:hover a.absolute{
    background-color:rgba(0,0,0,.5);
}
.model-wrapper .model-name {
    position:absolute;
    color:#fff;
    left:0px;
    width:100%;
    top:50%;
    transform:translatey(-50%);
    transition:all .2s linear;
    text-align:center;
    opacity:0;
    font-size:2vw;
    line-height:1em;
    letter-spacing:-2px;
    backface-visibility:hidden;
	
}

.model-wrapper .model-name .thumbnail-btn { 
    font-size:.5em;
}
.model-wrapper:hover .model-name {
    opacity:1;
    pointer-events:none;
}

.thumbnail-btn {
    border:2px solid #fff;
    padding:.5em 1em;
    background-color:rgba(255,255,255,0);
    transition:all .2s linear;
    display:inline-block;
    font-size:1.1em;
    letter-spacing:-1px;
    margin-top:20px;
    pointer-events:auto;
}

.thumbnail-btn:hover {
    background-color:rgba(255,255,255,.1);
}

@media (min-width:1200px) {
    .col-lg-1-8 {
        width:12.5%;
    }
	.hidden-lg {
    display: none !important;
	}
}

.vertical-middle {
    vertical-align:middle;
}

@-webkit-keyframes appear {
  0% {
    opacity: 0;
  }
  25% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes appear {
  0% {
    opacity: 0;
  }
  25% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}



/*FOOTER*/

footer .footer-content {
    position:relative;
}

.footer-content a {
    display:inline-block;
}

.footer-content .about-text {
    position:absolute;
    z-index:1;
    width:30%;
    left:30px;
    color:#fff;
    font-weight:normal;
    top:30px;
}

.footer-content .footer-info a {
    display:inline;
    color:#52c564;
}
      
.footer-content .footer-info a:hover {
    color:#cd2526;
}
.footer-content .description-link {
    color:#52c564;
}
.footer-content .description-link:hover {
    color:#cd2526;
}

footer.sinful-footer {
    padding:0;
    padding-top:20px;
    margin:0 -10px;
    
}

.footer-mobile-content {
    padding: 0 10px;
}


.dvd-content-wrapper {
    display:flex;
    flex-direction:row;
}
.dvd-content-wrapper .dvd-image-container {
    min-width:300px;
    max-width:300px;
    margin:0 auto;
}
.dvd-content-wrapper .dvd-info {
    padding-left:20px;
    display:inline-flex;
    flex:1;
    flex-direction:column;
    justify-content:space-around;
}


.dvd-title {
    font-weight:bold;
    letter-spacing:-2px;
}

.gallery-image {
    transition:all .2s linear;
}
.gallery-image:hover {
    filter:brightness(80%)
}

.video-banner {
    overflow:hidden;
    background-size:cover;
    background-position:center center;
    opacity:0;
    transition: opacity 1s linear;
}

.video-banner.loaded {
    opacity:1;
}

.video-loader {
    max-width:100px; 
    position:absolute;
    left:50%; 
    top:50%; 
    transform:translate(-50%, -50%);
    transition:opacity 1s linear;
    opacity:1;
    z-index:1;
}
@media(max-width:767px) {
    .video-loader {
        max-width:50px;
    }
}
.video-loader.invisible {
    opacity:0;
}

.video-loader img {
    animation:loader-spin 1.2s infinite;
}

@-webkit-keyframes loader-spin {
    0% {transform:rotate(0deg);}
    100% {transform:rotate(360deg);}
}

.video-banner .big-inline-video {
    position:absolute;  
    left:0px;
    top:50%;
    transform:translatey(-50%);
    z-index:1;
    transition:all .2s linear;
    width:100%;
    pointer-events:none;
    z-index:0;
    opacity:0;
}

.video-banner .big-inline-video.loaded{
    opacity:1;
}


.video-banner .video-end-overlay {
    position:absolute;
    left:0px;
    top:0px;
    width:100%;
    height:100%;
    background-color:rgba(0,0,0,.7);
    z-index:2;
}

.video-banner .video-end-overlay .video-end-content {
    position:relative;
    width:100%;
    height:100%;
}

.video-banner .video-end-overlay .video-end-content .text {
    position:absolute;
    text-align:center;
    left:0px;
    top:50%;
    width:100%;
    font-size:1vw;
    transform:translatey(-50%);
}

.video-banner .video-end-overlay .video-end-content .text .big { 
    line-height:0.8em;
    font-size:6.5em;
    letter-spacing:-0.09em;
}
.video-banner .video-end-overlay .video-end-content .text .medium { 
    line-height:58px;
    font-size:68px;
    letter-spacing:-3px;
}
.video-banner .video-end-overlay .video-end-content .text .small { 
    font-size:2.6em;
    line-height:1em;
    letter-spacing:-0.05em;
}

.video-banner .video-end-overlay .video-end-content .button.join { 
    font-size:2em;
    font-weight:normal;
}

.join-page form .options li {
    padding-left:40px;
}


input[type="radio"] {
    margin-top:0;
    vertical-align:middle;
}
.join-page form .options li input[type="radio"] {
    position:absolute;
    left:15px;
    top:50%;
    transform:translatey(-50%);
}
.join-page form.form .options label {
    color:#616161;
    width:100%;
    padding-right:10px;
    letter-spacing:-1px;
}
.join-page form .options label .joinoption-title { 
    font-size:24px;
    letter-spacing:-2px;
}
.join-page form .options label .price { 
    font-size:20px; 
    position:absolute;
    top:10px;
    right:10px;
    letter-spacing:-2px;
}


@media (max-width:767px) {
    .join-page form .options label .joinoption-title { 
        font-size:18px;
    } 
    .join-page form .options label .price {
        font-size:16px;
        top:14px;
    }  
}
.join-page .container-fluid {
    min-height:100vh;
    background-color:inherit;
    background-image: url(https://cdnstatic.imctransfer.com/static_01/grandmams/backjoin.jpg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}
@media(max-width:991px) {
    .join-page .container-fluid {
        background-image:none;
    }
		.joinsnips{
		display:none;
	}
		.green{
		display:none;
	}
}
@media(max-width:1199px) {
    .main-banner.video-banner {
        height:auto;
    }
    .main-banner.video-banner:before { 
        padding-top:56.25%;
        content: '';
        display:block;
    }
		.joinsnips{
		display:none;
	}
	.green{
		display:none;
	}
}

@media(max-width:991px) {
    .video-wrapper .video-description {
        font-size:2vw;
        line-height:2vw;
    }
    
    .thumbnail-btn {
        display:none;
    }
	.green{
		display:none;
	}
    
    .model-wrapper .model-name {
        font-size:4vw;
		display:none;
    }

    header .header-content {
        font-size:1.5vw;
    }


    
}


@media(max-width:767px) {
		.ratio-1-2-new::before {
    padding-top:118%;
    content:'';
    display:block;
}
    .video-wrapper .video-description {
        line-height:2.2vw;
        letter-spacing:-1px;
    }   
    .model-wrapper .model-name {
        font-size:5vw;
		display:none;
    }

    .access-button {
        font-size:1.3em;
    }

    .main-banner .overlay-text, .small-banner .overlay-text {
        font-size:5vw;
    }
    .main-banner .overlay-text .icons img {
        max-width:50vw;
    }

    .main-banner .bxslider.main-bxslider .slide .scene-description, .small-banner .scene-description {
        top:20px;
        left:auto;
        right:60px;
    }

    .bx-wrapper .bx-controls-direction a {
        padding:5px;
        width:20px;
        height:50px;
    }

    .video-banner .video-end-overlay .video-end-content .text {
        font-size:2vw;
    }
}

@media(max-width:767px) and (orientation:portrait) {
    .dvd-content-wrapper {
        display:block;
    }

    .scene-description {
        display:none;
    }
}
@media(max-width:1199px) and (orientation:portrait) {
    .main-banner {
        height:40vh;
    }
}

.navbar-collapse {
    transition:all .2s linear;
    overflow:hidden;    
}

.hamburger-menu-btn {
    background-color:transparent;
    border-color:transparent;
    box-shadow:none;
    outline:none;
    font-size:26px;
    line-height:28px;
    margin-right:-15px;
	margin-top: 14px
}


@media(min-width:992px) {
    .hamburger-menu-btn {
        display:none;
    }

    .navbar-collapse .navbar-nav li {
        display:inline;
    }  
    .navbar-collapse .navbar-nav {
        margin:0;
    }
}

@media(max-width:991px) {
    .navbar-collapse {
        background-color:#000;
        margin-right:-10px;
        display:inline-block;
        padding:0 10px;
    }
    .navbar-collapse .navbar-nav li {
        padding:5px 0;
        font-size:14px;
    }
    header .menu .button.red {
        margin-right:10px;
    }

    header {
        background-color:#000;
        height:60px;
	
    }
    body {
        padding-top:34px;
    }

    .navbar-collapse.collapse:not(.in) {    
        height:0px;
    }
    header .logo {
        font-size: 22px;
        margin-top: 3px;
		color: #000;
    }

}



.best-deal-ribbon {
    position:absolute;
    bottom:7px;
    right:-10px;
}

@media(max-width:767px) {
    .best-deal-ribbon {
        display:none;
    }
}
.ribbon-wrapper {
    position: relative;
    z-index:2;
}
.ribbon-wrapper .ribbon-front {
    background-color: #6cc240;  
    height: 30px;
    width: 140px;
    line-height:30px;
    font-size:18px;
    font-weight:Bold;
    position: relative;
    left:0px;
    z-index: 2; 
    color:#fff; 
    text-align:center;
    box-shadow: 0px 1px 3px #FFF;
}

.ribbon-wrapper .ribbon-edge-bottomright {
    position: absolute;
    z-index: 1;
    border-style:solid;
    height:0px;
    width:0px;
    top: 30px;
    left: 130px;
    border-color: transparent transparent transparent #5aa535;
    border-width: 0 0 5px 10px;
}
.ribbon-wrapper .ribbon-front {
    background-color: #FB5555;  
    height: 30px;
    width: 140px;
    line-height:30px;
    font-size:14px;
    font-weight:Bold;
    position: relative;
    left:0px;
    z-index: 2; 
    color:#fff; 
    text-align:center;
    box-shadow: 0px 1px 3px #000;
}

.ribbon-front2 {
    background-color: #ff9235;
    height: 30px;
    width: 140px;
    line-height:30px;
    font-size:20px;
    font-weight:Bold;
    position: relative;
    left:0px;
    z-index: 2;
    color:#fff;
    text-align:center;
    box-shadow: 0px 1px 3px #000;
}

.ribbon-front3 {
     background-color: #fc0;
     height: 30px;
     width: 140px;
     line-height:30px;
     font-size:20px;
     font-weight:Bold;
     position: relative;
     left:0px;
     z-index: 2;
     color:#000;
     text-align:center;
     box-shadow: 0px 1px 3px #000;
 }

@-webkit-keyframes flow {
    0% { left:-20px;opacity: 0;}
    50% {left:40px;opacity: 0.4;}
    100%{ left:100px;opacity: 0;}
}
@keyframes flow {
    0% { left:-20px;opacity: 0;}
    50% {left:40px;opacity: 0.4;}
    100%{ left:100px;opacity: 0;}
}

.ribbon-wrapper .glow{ 
    background: rgb(255,255,255); 
    width:40px; 
    height:100%; 
    z-index:3; 
    position:absolute;
    -webkit-animation: flow 1.5s linear infinite;
    -moz-animation: flow 1.5s linear infinite;
    -webkit-transform: skew(20deg);
       -moz-transform: skew(20deg);
         -o-transform: skew(20deg);
    background: -moz-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 1%, rgba(255,255,255,1) 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(255,255,255,0)), color-stop(1%,rgba(255,255,255,0)), color-stop(100%,rgba(255,255,255,1))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0) 1%,rgba(255,255,255,1) 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0) 1%,rgba(255,255,255,1) 100%); /* Opera 11.10+ */
    background: -ms-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0) 1%,rgba(255,255,255,1) 100%); /* IE10+ */
    background: linear-gradient(to right, rgba(255,255,255,0) 0%,rgba(255,255,255,0) 1%,rgba(255,255,255,1) 100%); /* W3C */
}


.model-info-row .model-info-wrapper{
    padding:10px 20px;
    position:absolute;
    top:0px;
    left:5%;
    height:100%;
    text-shadow:1px 1px 3px #FFF;
    background:rgba(0,0,0,.4);
    width:350px;
    max-width:100%;
    display:flex;
    flex-direction:column;
    justify-content:center;
    pointer-events:none;
}

@media(max-width:767px) {
    .model-info-row .model-info-wrapper {
        font-size:2vw;
        width:50%;
    }
}

.model-info-row .model-info {
    margin:0;
    letter-spacing:-0.05em;
    width:100%;
    margin-top:20px;
    font-size:1.1em;
}

.model-info-row .model-info span {
    display:block;
}

.model-info-row .model-info .description { 
    margin-top:20px;
    font-weight:bold;
}
.model-info-row .model-name {
    font-size:2.4em;
    width:100%;
    letter-spacing:-0.08em;
    line-height:.8em;
    padding-bottom:10px;
    border-bottom:1px solid rgba(255,255,255,.6);
}

.model-info-row .model-name span {
    font-size:1.2em;
    display:block;
    font-weight:bold;
    line-height:.8em;
}

.parallax {
    background-attachment: fixed;
    background-size:cover;
    background-position: center center;
    background-repeat: no-repeat;
}

@media(max-width:991px) {
    .parallax {
        background-attachment:initial;
    }
}

.model-info-row .ratio-3-1.parallax {
    min-height:500px;
}

@media(max-width:767px) {
    .model-info-row .ratio-3-1.parallax {
        min-height:300px;
    }
	.update-info-title{
		line-height: 1.0;
	}
}


.webcam-icon {
    max-width:1em;
    margin-top:-5px;
}



.main-banner {
    height:65vh;
}
@media (min-width:1200px) {
    .content-wrapper {
        padding:30px 50px;
    }
}
@media (max-width:1366px) and (orientation:portrait) {
    .main-banner {
        height:40vh;
    }
}
@media (max-width:767px) and (orientation:portrait) {
    .main-banner {
        height:25vh;
    }
}
@media (max-width:821px) and (orientation:landscape){
    .main-banner {
        display:none;
    }
    .membership-text {
        display:none;
    }
			.ratio-1-2-new::before {
    padding-top:115%;
    content:'';
    display:block;
}
}

@media (max-width:767px) {
    .main-banner {
        display:none;
    }
    .row-separator-text {
        font-size:1.2em;
    }
}
.button,.access-button {
    border-radius:10px;
}
.thumbnail-btn {
    border-radius:10px;
    font-size:0.9em;
}
.video-wrapper {
    border-radius:10px;
}
.bx-wrapper .bx-controls-direction a {
    transform:translatey(-50%);
}

.guest-promo-container {
    background: -webkit-gradient(linear, left top, right top, from(#ee1f51), to(#fa9d24));
    background: linear-gradient(90deg, #ee1f51 0%, #fa9d24 100%);
    color: #fff;
    position: fixed;
    bottom: 0px;
    left: 0px;
    width: 100%;
    padding: 15px 10px;
    font-size: 22px;
    z-index: 99;
}

@media(max-width:767px) {
    .guest-promo-container {
        font-size:16px;
    }
}

.guest-promo-container .promo-square {
    width: 14px;
    height: 14px;
    background-color: #fff;
    display: inline-block;
    vertical-align: middle;
    margin: 0 3px;
}
.guest-promo-container a.promo-close {
    color: #fff;
    font-weight: bold;
    float: right;
}
.guest-promo-container a.promo-close:hover {
    color:#ee1f51;
}
.guest-promo-container .promo-title {
    font-weight:bold;
}
.guest-promo-container .promo-timer {
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    margin-left: 10px;
}

.guest-promo-container .promo-timer .promo-timer-info {
    color: #000;
    font-size: 10px;
    line-height: 14px;
    font-weight: bold;
}
.guest-promo-container .promo-timer .promo-timer-countdown {
    font-size: 16px;
    line-height: 16px;
}
.guest-promo-container span, .guest-promo-container a {
    display:inline-block;
    vertical-align:middle;
}
.guest-promo-container .promo-btn {
    margin-left:10px;
}



/*CONFIRMATION MODAL*/

#confirmationModal .confirmation-modal-title {
    font-size: 58px;
    font-weight: bold
}

@media (max-width: 767px) {
    #confirmationModal .confirmation-modal-title {
        font-size: 42px
    }
    .modal-open {
        position: relative
    }
}

#confirmationModal .btn {
    border-radius: 2px
}

#confirmationModal .btn.btn-success {
    background-color: #00b73d
}

#confirmationModal .btn.btn-success:hover {
    background-color: #009432
}

#confirmationModal .modal-dialog {
    margin-top: 20vh
}

body.adultprime-body.phone .modal.modal-menu.left .modal-dialog {
    width: calc(100vw - 60px)
}

body.adultprime-body.phone .modal.modal-menu .modal-menu-close {
    left: initial;
    right: -45px
}

body.adultprime-body.phone .modal.modal-menu .modal-menu-link {
    font-weight: normal;
    text-align: center;
    text-transform: uppercase;
    color: #cecece;
    font-size: 12px
}

body.adultprime-body.phone .modal.modal-menu .modal-menu-link i.fa {
    font-size: 3em
}

body.adultprime-body.phone.modal-open {
    max-width: 100vw
}

.modal-open {
    overflow: hidden
}

.modal-open .modal {
    overflow-x: hidden;
    overflow-y: auto
}

.modal-dialog {
    position: relative;
    width: auto;
    margin: 10px auto 10px auto;
}

.modal {
    display: none;
    overflow: hidden;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1050;
    -webkit-overflow-scrolling: touch;
    outline: 0
}

.modal.fade .modal-dialog {
    -webkit-transform: translate(0, -25%);
    transform: translate(0, -25%);
    -webkit-transition: -webkit-transform 0.3s ease-out;
    transition: -webkit-transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out
}

.modal.in .modal-dialog {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0)
}

.modal-content {
    position: relative;
    background-color: #fff;
    border: 1px solid #999;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 6px;
    -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
    box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
    background-clip: padding-box;
    outline: 0
}

.modal-backdrop {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1040;
    background-color: #000
}

.modal-backdrop.fade {
    opacity: 0;
    filter: alpha(opacity=0)
}

.modal-backdrop.in {
    opacity: .8;
    filter: alpha(opacity=70)
}

.modal-header {
    padding: 15px;
    border-bottom: 1px solid #e5e5e5
}

.modal-header:before, .modal-header:after {
    content: " ";
    display: table
}

.modal-header:after {
    clear: both
}

.modal-header .close {
    margin-top: -2px
}

.modal-title {
    margin: 0;
    line-height: 1.42857
}

.modal-body {
    position: relative;
    padding: 15px
}

.modal-footer {
    padding: 15px;
    text-align: right;
    border-top: 1px solid #e5e5e5
}

.modal-footer:before, .modal-footer:after {
    content: " ";
    display: table
}

.modal-footer:after {
    clear: both
}

.modal-footer .btn + .btn {
    margin-left: 5px;
    margin-bottom: 0
}

.modal-footer .btn-group .btn + .btn {
    margin-left: -1px
}

.modal-footer .btn-block + .btn-block {
    margin-left: 0
}

.modal-scrollbar-measure {
    position: absolute;
    top: -9999px;
    width: 50px;
    height: 50px;
    overflow: scroll
}


@media (min-width: 768px) {
    .modal-dialog {
        width: 600px;
        margin: 30px auto
    }

    .modal-content {
        -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
        box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5)
    }

    .modal-sm {
        width: 300px
    }
}

@media (min-width: 992px) {
    .modal-lg {
        width: 900px
    }
}

.modal-content, .event-wrapper .description {
    background-color: #333
}

#registration .modal-dialog {
    width: auto;
    max-width: 900px;
    margin: 10px auto
}
.bx-wrapper .bx-controls-direction a {
    z-index:1000;
}

.mobile-join-btn-container {
    position:absolute;
    z-index:3;
    left:5%;   
    top:50%;
    width:25%;
    transform:translatey(-50%);
    max-width:150px;
}

.mobile-join-btn {
    display:inline-block;
    width:100%;
    animation-name:knock;
    animation-duration:3s;
    animation-timing-function:linear;
    animation-iteration-count:infinite;
    visibility: visible !important;
}
@keyframes knock {
    0% {
        transform:rotate(0deg) scale(1);
    }
    5% {
        transform:rotate(15deg) scale(1.3);
    }
    10% {
        transform:rotate(0deg) scale(1);
    }
    15% {
        transform:rotate(15deg) scale(1.3);
    }
    20% {
        transform:rotate(0deg) scale(1);
    }
    100% {
        transform:rotate(0deg) scale(1);
    }
}


.update-video-wrapper svg path {
    -webkit-transition: all .1s linear;
    transition: all .1s linear
}

.update-video-wrapper:hover path.play-circle, .studio-player-wrapper:hover path.play-circle {
    fill: rgba(0, 0, 0, 0.2)
}

.update-video-wrapper:hover path.play-triangle, .studio-player-wrapper:hover path.play-triangle {
    fill: #ee1f51
}

.player-wrapper.studio-player-wrapper {
    padding-bottom: 0px
}

.player-wrapper.studio-player-wrapper .video-js .vjs-control-bar {
    bottom: 0px
}

.player-wrapper.studio-player-wrapper .watermark-initial {
    bottom: 0px
}

.player-wrapper {
    position: relative;
    padding-bottom: 30px;
    overflow: hidden
}

.player-wrapper .video-js {
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    padding-top: 56.25% !important;
    height: 0px;
    position: relative;
    background: transparent
}

.player-wrapper .video-js .vjs-menu-button-popup .vjs-menu {
    right: 0px;
    left: initial;
    z-index: 2
}

.player-wrapper .video-js .vjs-mute-control, .player-wrapper .video-js .vjs-quality-selector .vjs-menu-button, .player-wrapper .video-js .vjs-control {
    outline: 0
}

.player-wrapper .video-js .vjs-poster {
    background-size: cover;
}

.player-wrapper .video-js .vjs-control-bar {
    bottom: -30px;
    z-index: 2
}

.player-wrapper .watermark-initial {
    position: absolute;
    bottom: 30px;
    left: 0;
    right: 0;
    width: 100%;
    display: block;
    z-index: 1;
    pointer-events: none
}

.player-wrapper .watermark-full {
    position: absolute;
    bottom: 0px;
    left: 0;
    right: 0;
    width: 100%;
    display: none;
    z-index: 1
}

.player-wrapper .preview-overlay {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    height: calc(100% - 30px);
    text-align: center;
    background-color: rgba(0, 0, 0, 0.8);
    color: #fff;
    padding-bottom: 30px;
    pointer-events: none;
    z-index: 1
}

.player-wrapper .preview-overlay .text-wrapper {
    position: relative;
    width: 100%;
    height: 100%
}

.player-wrapper .preview-overlay .text-wrapper .text-holder {
    position: absolute;
    top: 50%;
    -webkit-transform: translatey(-50%);
    transform: translatey(-50%);
    left: 0;
    width: 100%;
    color: #fff
}

.player-wrapper .preview-overlay .text-wrapper .text-holder h1, .player-wrapper .preview-overlay .text-wrapper .text-holder h2, .player-wrapper .preview-overlay .text-wrapper .text-holder h3, .player-wrapper .preview-overlay .text-wrapper .text-holder h4, .player-wrapper .preview-overlay .text-wrapper .text-holder h5 {
    font-weight: bold
}

.portalbody.desktop-live .player-wrapper .video-js .vjs-control-bar {
    bottom: 0px
}
.player-wrapper.studio-player-wrapper {
    padding-bottom: 0px
}

.player-wrapper.studio-player-wrapper .video-js .vjs-control-bar {
    bottom: 0px
}

.player-wrapper.studio-player-wrapper .watermark-initial {
    bottom: 0px
}

.studio-player-wrapper .video-js video:hover {
    cursor: pointer
}

.studio-player-wrapper .video-js .vjs-big-play-button {
    display: none
}

.studio-player-wrapper .clip-pause-overlay {
    position: absolute;
    left: 50%;
    bottom: 30%;
    -webkit-transform: translatex(-50%);
    transform: translatex(-50%);
    z-index: 1;
    pointer-events: none
}



.studio-player-wrapper .clip-pause-overlay .clip-info {
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4)
}

.studio-player-wrapper .clip-pause-overlay .clip-info .clip-info-title {
    font-size: 24px
}

.studio-player-wrapper .clip-pause-overlay .clip-info .clip-info-description {
    font-size: 18px
}

.studio-player-wrapper .clip-pause-overlay .clip-overlay-btn {
    padding: 0.5em;
    font-size: 18px;
    width: 200px;
    margin: 0 auto;
    pointer-events: auto
}

.update-video-wrapper:hover path.play-circle, .studio-player-wrapper:hover path.play-circle {
    fill: rgba(0, 0, 0, 0.2)
}

.update-video-wrapper:hover path.play-triangle, .studio-player-wrapper:hover path.play-triangle {
    fill: #ee1f51
}
.large-carousel-item-wrapper .custom-play-icon {
    opacity: 0;
    -webkit-transition: all .2s linear;
    transition: all .2s linear
}
.custom-play-icon, .video-wrapper .play {
    pointer-events: none;
    z-index: 1;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}
.upper{
	text-transform: uppercase;
}



.parent-container {
    position: absolute;
    margin-top: -100px; /* Adjust margin to position it correctly */
    width: 95%; /* Adjust width as needed */
    z-index: 10; /* Ensure it's above other content if needed */
    text-align: center; /* Center the content inside */
}

.page-title-featured{
	 color: #FFF;
    font-style: normal;
    line-height: 100%;
    text-transform: uppercase;
    font-family: Raleway;
    font-size: clamp(24px,7vw,90px);
    font-weight: 900;
    #padding: 0!important
	
}

.page-title-section{
	color: #ffc700;
	font-style: normal;
    line-height: 100%;
    text-transform: uppercase;
    font-family: Raleway;
    font-size: clamp(24px,7vw,90px);
    font-weight: 900;
   #padding: 0!important
	
}



.page-title-section_WHITE{
	color: #FFF;
	font-style: normal;
    line-height: 100%;
    text-transform: uppercase;
    font-family: Raleway;
    font-size: clamp(28px,5vw,65px);
    font-weight: 900;
   #padding: 0!important
	
}

h1 {
  font-size: clamp(22px,5vw,40px);
  font-weight: bold;
  color: #FFF;
  margin-top: 26px;
	margin-bottom: 36px;
	line-height: 0;
	font-family: Raleway;
    text-transform: uppercase;
}
h2 {
  font-size: clamp(22px,5vw,40px);
  font-weight: bold;
  color: #FFF;
  margin-top: 26px;
	margin-bottom: 36px;
	line-height: 0;
	font-family: Raleway;
    text-transform: uppercase;  
}

@media only screen and (max-width: 970px) {
    h1 {
  font-size: clamp(22px,5vw,40px);
  font-weight: bold;
  color: #FFF;
  margin-top: 12px;
	margin-bottom: 36px;
	line-height: 0;
	font-family: Raleway;
    text-transform: uppercase;
}
h2 {
  font-size: clamp(22px,5vw,40px);
  font-weight: bold;
  color: #FFF;
  margin-top: 12px;
	margin-bottom: 36px;
	line-height: 0;
	font-family: Raleway;
    text-transform: uppercase;  
}

}

.access-button {
    position: relative;
    font-size: 2.8em;
    padding: .6em 1.2em;
    font-weight: bold;
    color: #FFF;
    border: 2px solid #2da340;
    background-color: #2da340;
    transition: all .2s linear;
    display: inline-block;
    margin: 15px 0;
    border-radius: 25px;
    overflow: hidden;
    z-index: 0;
}

.access-button::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 100%;
    border-radius: 25px;
    box-sizing: border-box;
    border: 2px solid white;
    z-index: 1;
    pointer-events: none;
    transform: rotate(0deg);
    opacity: 0;
}

.access-button:hover::before {
    animation: borderSweep 0.8s linear forwards;
    opacity: 1;
}

@keyframes borderSweep {
    0% {
        clip-path: inset(0 100% 100% 0);
        transform: rotate(0deg);
    }
    25% {
        clip-path: inset(0 0 100% 0);
    }
    50% {
        clip-path: inset(0 0 0 0);
    }
    75% {
        clip-path: inset(0 0 0 0);
    }
    100% {
        clip-path: inset(0 0 0 0);
        transform: rotate(360deg);
    }
}

.access-button {
    font-size: 2.8em;
    padding: .6em 1.2em;
    font-weight: bold;
    color: #FFF;
    border: 2px solid #2da340;
    background-color: #2da340;
    transition: all .2s linear;
    display: inline-block;
    margin: 15px 0;
    border-radius: 25px;
}

.access-button:hover {
    background-color: #059a42;
}

@media(max-width:967px) {
	.access-button {
    font-size: 1.3em;
    padding: .6em 1.2em;
    font-weight: bold;
    color: #FFF;
    border: 2px solid #2da340;
    background-color: #2da340;
    transition: all .2s linear;
    display: inline-block;
    margin: 15px 0;
    border-radius: 25px;
}

.access-button:hover {
    background-color: #2da340;
}
}
/* ---------------------------------------------
   1. Basisstyling voor de knop (.access-button)
   --------------------------------------------- */
.access-button-border {
  position: relative;
  display: inline-block;
  margin: 15px 0;
  padding: 0.6em 1.2em;
  font-family: Raleway;
  font-size: 2.8em;
  font-weight: 900;
  color: #fff;
  background-color: #2da340;    /* purperen achtergrond */
  border: 2px solid #2da340;    /* purperen border */
  border-radius: 0px;
  overflow: hidden;             /* zorgt dat spans niet buiten de knop treden */
  cursor: pointer;
  transition: background-color 0.2s linear;
}

/* ---------------------------------------------
   2. Algemene styling voor elk border-span
   --------------------------------------------- */
.access-button-border .border-side {
  position: absolute;
  background-color: #fff;       /* witte borderkleur */
  z-index: 2;                   /* bovenop de purperen achtergrond */
}

/* ---------------------------------------------
   3. Positionering en beginwaarden per zijde
   --------------------------------------------- */
/* 3a. Bovenkant: hoogte = 2px, startbreedte = 0 */
.access-button-border .border-top {
  top: 0;
  left: 0;
  height: 2px;
  width: 0;
}

/* 3b. Rechterkant: breedte = 2px, starthoogte = 0 */
.access-button-border .border-right {
  top: 0;
  right: 0;
  width: 2px;
  height: 0;
}

/* 3c. Onderkant: hoogte = 2px, startbreedte = 0, positioneer onderaan */
.access-button-border .border-bottom {
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0;
}

/* 3d. Linkerkant: breedte = 2px, starthoogte = 0, positioneer linkerkant */
.access-button-border .border-left {
  top: 0;
  left: 0;
  width: 2px;
  height: 0;
}

/* ---------------------------------------------
   4. Hover-trigger: start keyframes voor elke zijde
   --------------------------------------------- */
/* 4a. Bovenkant: groeit in 0.2s van links naar rechts */
.access-button-border:hover .border-top {
  animation: sweep-top 0.2s linear forwards;
}

/* 4b. Rechterkant: na 0.2s delay, groeit van boven naar onder in 0.2s */
.access-button-border:hover .border-right {
  animation: sweep-right 0.2s linear forwards;
  animation-delay: 0.2s;
}

/* 4c. Onderkant: na 0.4s delay, groeit van links naar rechts in 0.2s */
.access-button-border:hover .border-bottom {
  animation: sweep-bottom 0.2s linear forwards;
  animation-delay: 0.4s;
}

/* 4d. Linkerkant: na 0.6s delay, groeit van onder naar boven in 0.2s */
.access-button-border:hover .border-left {
  animation: sweep-left 0.2s linear forwards;
  animation-delay: 0.6s;
}

/* ---------------------------------------------
   5. Keyframes voor elke zijde
   --------------------------------------------- */
/* 5a. Top: breedte van 0 → 100% */
@keyframes sweep-top {
  from { width: 0; }
  to   { width: 100%; }
}

/* 5b. Recht: hoogte van 0 → 100% */
@keyframes sweep-right {
  from { height: 0; }
  to   { height: 100%; }
}

/* 5c. Onder: breedte van 0 → 100% */
@keyframes sweep-bottom {
  from { width: 0; }
  to   { width: 100%; }
}

/* 5d. Links: hoogte van 0 → 100% */
@keyframes sweep-left {
  from { height: 0; }
  to   { height: 100%; }
}

/* ---------------------------------------------
   6. Hover-achtergrond-verandering
   --------------------------------------------- */
.access-button-border:hover {
  background-color: #059a42;    /* lichtere purper bij hover */
}

/* ---------------------------------------------
   7. Responsief (< 967px)
   --------------------------------------------- */
@media (max-width: 967px) {
  .access-button-border {
    font-size: 2.0em;
    padding: 0.6em 1.2em;
  }
}
/* ───────────────────────────────────────────────────
   1. Basis-CSS voor .access-button blijft hetzelfde
   (spans, keyframes, hover-regels buiten de media-query)
   ─────────────────────────────────────────────────── */

/* ▼ onder 967px breedte: geen border-animatie op mobiel/tablet ▼ */
@media (max-width: 967px) {
  /* Verberg de pseudo‐elementen die de geanimeerde border tekenen */
  .access-button-border::before,
  .access-button-border .border-top,
  .access-button-border .border-right,
  .access-button-border .border-bottom,
  .access-button-border .border-left {
    display: none;
  }

  /* Optioneel: behoud wel de hover-achtergrondkleur, of haal die weg */
  .access-button-border:hover {
    /* Je kunt dit weglaten als je ook geen background-change wilt */
    background-color: #059a42;
  }

  /* Pas de font-size / padding aan zoals je had */
  .access-button-border {
    font-size: 2.0em;
    padding: 0.6em 1.2em;
  }
}