@charset utf-8;
/*
Theme Name: VS Reps
Author: Code by Ricardo Juárez for Phantasia	
Author URI: http://rjvv.com/
Version: 1.0
License: GNU/GPL Version 2 or later. http://www.gnu.org/licenses/gpl.html
Copyright: (c) 2025 Ricardo Juárez
*/





:root 	{
  --sans: 'ROM Compressed', sans-serif;

--big: clamp(40px, 8vw, 180px);
  --medium: 90px;
  --body: 40px;

  --linebig: 0.9;
  --linemedium: 0.9;
  --linebody: 0.9;

  --lsbig: -0.01em;
  --lsmedium: -0.01em;
  --lsbody: 0em;


	--primary:#FFFFFF;
	--contrast: #000000;
	--accent:#FF5000;

	--primaryrgb:255,255,255;
	--contrastrgb:0,0,0;
	
	--pad:20px;
	--padb: 60px;

	 --app-height: var(--real100);
}


.post-content a, .post-content strong{
	display: inline-block;
}


img, .overlay-title,
video {
  user-select: none;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  pointer-events: auto; /* optional, keeps hover/click working */
}

*{
	-webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
     -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;

}
body{
	overflow: hidden;
}

html, body
{
	overscroll-behavior-block: none;
overscroll-behavior: none;
margin:0;
font-size:100%;
width:100%;
     }
     
     	html { margin-top: 0px !important; background-color: var(--contrast);}
	* html body { margin-top: 0px !important; }
	@media screen and ( max-width: 782px ) {
		html { margin-top: 0px !important; }
		* html body { margin-top: 0px !important; }
	}
	



[data-barba="container"] {
  position: relative;
  min-height: 100vh;
  z-index: 1;
  transition: opacity 0.5s ease, filter 0.5s ease;
  opacity: 0;
  filter: blur(5px);
}


body.barba-loading {
  overflow: hidden;
}

body.page-transition {
  pointer-events: none;
}
body.barba-loading {
  overflow: hidden;
}
body.barba-loaded [data-barba="container"] {
  opacity: 1;
  filter: blur(0);
  }
  

  
  .cover-item{
	  cursor: pointer;
  }

.page-template-default{
	background-color: var(--accent);
}
.post-content{
	display: flex;
	flex-direction: column;
	min-height: var(--real100);
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 40px;
	margin: 0px auto;
	max-width: 1920px
}

body {
margin:0;
min-height: 100vh;
-moz-osx-font-smoothing: grayscale; 
text-rendering:geometricPrecision;
-webkit-font-smoothing: antialiased;
color: var(--contrast);
background-color: var(--primary);
    font-style: italic;
transition: background 0.5s ease;
font-family: var(--sans);
  font-size: var(--body);
  line-height: var(--linebody);
  font-weight: 500;
  letter-spacing: var(--lsbody);
}
#main{
}
.post-content strong{
	text-transform: uppercase;
	  font-family: var(--sans);
  font-size: var(--big);
  line-height: 0.9;

}

.logo{
	position: fixed;
	top:0;
	right: 0;
	z-index: 999;
}

.logo img{
	width: auto;
	height: 250px;
}


.big {
  font-family: var(--sans);
  font-size: var(--big);
  line-height: var(--linebig);
  font-weight: 500;
  letter-spacing: var(--lsbig);
}
.body{
  font-size: var(--body);
  line-height: var(--linebody);
  font-weight: 500;
  letter-spacing: var(--lsbody);
}  

.medium {
  font-family: var(--sans);
  font-size: var(--medium);
  line-height: var(--linemedium);
  font-weight: 500;
  letter-spacing: var(--lsmedium);
}

.body {
  font-family: var(--sans);
  font-size: var(--body);
  line-height: var(--linebody);
  font-weight: 500;
  letter-spacing: var(--lsbody);
  text-transform: uppercase;
}



h1, h2, h3, h4, h5, h6{
	margin-bottom: 0;
font-weight: 500;
  all: unset;
display: inline-block;
}
.justify{
	text-align: justify;
}
header{
user-select: none;
-webkit-user-select: none;
-moz-user-select: none;
position: fixed;
top: 0;
padding: var(--pad);
width: 100%;
z-index: 999999999;
	justify-content: space-between;
}

strong, b, i, em{
font-weight: 500;
}

footer{
}

.uppercase{
	text-transform: uppercase;
}
.tright{
	justify-content: flex-end;
	text-align: right;
}
.tcenter{
text-align: center;}

.grid2{
	display: grid;
	      grid-template-columns: repeat(2, 1fr);
}
.wrap{
	flex-wrap: wrap;
}
.padded{
	padding:var(--pad);
}

.full{
	width: 100%;
	height: var(--app-height);
	height: 100vh;
}
.webgallery img, .webgallery video{
	height: 60vh;	
	  transition: all 0.5s ease;
	width: auto;
}
.vimeo-popup{
	position: fixed;
  height: 100%;
  width: 100%;
  background: var(--primary);
  z-index: 9999999999;
  display: flex;
  justify-content: center;
  align-items: center;
}
.close-vimeo{
	position: absolute;
	top:var(--pad);
	left: var(--pad);
}

.video-wrapper{
	position: relative;
}
.video-overlay{
	display: none;
	position: absolute;
	top: 0;
	justify-content: center;
	align-items: center;
	color: var(--primary);
	width: 100%;
	height: 100%;
	z-index: 9;
}

.vimeo-popup-inner {
  position: relative;
  width: 80vw;
  max-width: 900px;
  aspect-ratio: 16 / 9;
}
.vimeo-popup-inner iframe {
  width: 100%;
  height: 100%;
}
.zoomed-out .video-overlay{
	display: none !important;
}

.single-gallery {
  overflow-x: auto;
  overflow-y: hidden;
  position: absolute;
  top: 20vh;
  width: 100vw;
  height: 60vh;
  display: flex;
  gap: 5px;
  padding: 0 5px;
    scrollbar-width: none;
  -ms-overflow-style: none;
  transition: all 0.6s ease;
  will-change: transform;
}

.single-gallery::-webkit-scrollbar {
  display: none;
}

	.gallery-slide {
		  cursor: zoom-in;
	  flex-shrink: 0;
	  position: relative;
	}
	
.zoomed-out .gallery-slide{
	cursor: pointer;
}


.gallery-slide img, .gallery-slide video {
  height: 60vh;
  display: block;
  transition: all 0.5s ease;
  width: auto;
}

.webgallery{
	overflow: hidden;
	position: absolute;
	top: 20vh;
	width: 100vw;
	height: 60vh;
	display: flex;
	align-items: center;
}

.webgallery .swiper-slide{
	width: fit-content !important;
	position: relative;
}
.artist-swiper .swiper-slide a, .gallery-slide a{
	position: relative;
display: block;	
}

.overlay-title{
	position: absolute;
	width: 100%;
	z-index: 999;
	height: 100%;
	bottom:0;
	left: 0;
	padding: 20%;
	text-align: center;
	background-color: var(--accent);
	display: none;
	justify-content: center;
	align-items: center;
	transition: all 0.3s ease;
}

.single-title{
	position: fixed;
		  user-select: none;
top: calc(var(--pad) / 1);
z-index: 99999999;
	width: 100%;
	left: 0;
	text-align: center;
	
}


.artist-title-single{
	position: fixed;
		  user-select: none;
bottom: calc(var(--pad) / 2);
z-index: 9999998;
	width: 100%;
	left: 0;
	text-align: center;
}
.see-all{
	  user-select: none;
z-index: 9999999999;
	position: fixed;
	top: calc(var(--pad) / 1);
	right: var(--pad);
	cursor:pointer;
}

.more-info{
	  user-select: none;
z-index: 9999999;
	position: fixed;
	bottom: calc(var(--pad) / 1);
	right: var(--pad);
	cursor:pointer;
}

.term-description{
	overflow: hidden;
display: flex;
height: 100vh;
width: 100vw;
background: var(--accent);
position: fixed;
z-index: 99999;
bottom: 0;
left: 0;
justify-content: center;
align-items: center;
height: 0;
transition: all 0.3s ease;
}
.term-description.appear{  height: var(--app-height);

}


video, .cover-img img{
	width: 100%;
	height: 100%;
	object-fit:cover;
}
.news-grid{
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap:var(--padb);
	text-align: center;
	padding: var(--padb);
}

.news-grid .cover-image{
	aspect-ratio:0.75;
	margin-bottom: 15px;
}






/* SLIDER */
.slider{
	position: relative;
	overflow: hidden;
}
.swiper-slide{
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}

.video-caption {
margin-top: 20px;
}
	
/* MENU */

header [id^="menu-main"]{
	display: flex;
	gap:var(--pad);
	width: 100%;
}
header [id^="menu-main"] li a{
}

.icon-menu, .icon-close{
	display: inline-block;
	    font-size: 24px;
	    cursor: pointer;
}
.inverter{
	    mix-blend-mode: difference;
	    color:var(--primary);
position: fixed;
z-index: 99999999
	
}

.mobile-menu.icon-close{
	color: var(--contrast);
}

.icon-close{
	    mix-blend-mode: difference;
	    color:var(--primary);
position: fixed;
z-index: 99999;
top:var(--padm);
right:var(--padb);	
	}

.menu-hover{
	overflow: hidden;
transition: all 0.3s ease;
pointer-events: none;
	position: fixed;
	width: 100%;
	height: 0;
	top: 0;
	background-color: var(--accent);
z-index: 9999999;}
.menu-int{
		    height: var(--app-height);
padding: var(--pad) var(--pad) 0;
    width: 100%;
    display: flex;
    flex-direction: column;
justify-content: flex-end;
  align-items: flex-start;
}
.menu-int [id^="menu-main"]{
	text-transform: uppercase;
}

.menu-int [id^="menu-main"] a{
display: inline-block;
}

.menu-hover.appear{
	    height: var(--app-height);
pointer-events: all;}



.blocks{
	display: flex;
	flex-direction: column;
	gap:90px;
	padding: var(--padb);
}
s
.post-content p,
.post-content h2,
.post-content h3,
.post-content ul,
.post-content ol,
.post-content blockquote {
	break-inside: avoid;
}
.post-content p{
margin-bottom: 40px;
width: 100%;
}
.post-content *:last-child{
	margin-bottom: 0;
}


.current-menu-item {
}
.artists.padded{
	padding: var(--pad) var(--pad) 0;
}
.artists{
	position: fixed;
	bottom: -0.02em;
	z-index: 2;
}
.fs-cont {
  position: fixed;
  z-index: 9999999999;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(255, 255, 255, 0);
  display: none;
  box-sizing: border-box;
  cursor: zoom-out;
  overflow: hidden;
  transition: background 0.3s ease;}
.fs-cont.bged {
  background: rgba(255, 255, 255, 1);
}
.fs-cont.show {
  display: block;
}

.fs-cont > img,
.fs-cont > video {
  position: absolute;
  will-change: top, left, width, height, transform;
}

.no-scroll {
  overflow: hidden;
  height: 100vh;
}


body.no-scroll {
  overflow: hidden;
}


.covers{
	margin-top: -10vh;
	position: fixed;
	width: 100vw;
	height: 100vh;
	top: 0;
	left: 0;
	z-index: 1;
}

.cover-hover.hidden {
  display: none;
}
.cover-artist{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	height: 100vh;
	width: 100vw;
}
.cover-artist.media-2{
		grid-template-columns: 2fr 1fr;
}
.cover-artist.media-2 .vertical:first-child{
	width: 32%;
}
.cover-artist.media-2 .horizontal:first-child{
	width: 50%;
}

.cover-artist *:nth-of-type(1){
margin-right: auto;		
}
.cover-artist *:nth-of-type(2){
margin: 0px auto;		
}
.cover-artist *:nth-of-type(3){
margin-left: auto;		
}

.cover-artist *:nth-of-type(3).yaxis1{
	object-position:0 calc(125px + var(--pad));
}

.custom-swiper{
	position: relative;
	overflow: hidden;
}
.custom-swiper .swiper-slide{
	width: 100vw;
	height: 100vh;
}
.custom-swiper .swiper-slide img, .custom-swiper .swiper-slide video{
	object-fit:cover;
	height: 100%;
}
.page-template-home header{
	color: var(--primary);
}

/*
.xaxys1{
margin-right: auto;	
}
.xaxys2{
margin: 0px auto;	
}
.xaxys3{
margin-left: auto;	
}
*/
.yaxis1{
	object-position:top;
}
.yaxis2{
	object-position:center;
}
.yaxis3{
	object-position:bottom;
}

.cover-artist *:nth-of-type(1).yaxis3{
	object-position:0 25%;
}


.cover-artist.media-2 *:first-child{
object-position:top;
margin: 0 0 0 auto !important;
}
.cover-artist.media-2 *:last-child{
object-position:bottom;
margin: 0 0 0 auto !important;
}


.artist-item a{
	display: inline-block;
}

.cover-artist video, .cover-artist img{
	height: 100%;
	object-fit: contain;
}
.cover-artist .horizontal{
	width: 90%;
}

.cover-artist .vertical{
	width: 64%;
}


/* INPUTS */
input[type="checkbox"]
{
     -webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
     display: inline-block;
     position: relative;
     height: 0px;
     border-radius: 0;
     width: 0px;
     cursor: pointer;     
     outline: none;
     border: none;
     margin: 0;
}

input[type="checkbox"]:checked + label{
	color: #444444;
}
input[type="checkbox"]:hover
{
     background-color: var(--contrast);
}
input[type="checkbox"]:checked
{
background-color: var(--contrast);
}

input[type="submit"]{
	  font-size: var(--body);
	 -webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
     display: inline-block;
     font-family: var(--sans);
     text-transform: uppercase;
     border: none;
     cursor: pointer;
     cursor: pointer;
     outline: none;
padding: 8px 22px;
background: #E5E5E5;
border-radius: 30px;
margin-left: 20px;
}


input[type="text"],
input[type="tel"], 
input[type="email"], 
input[type="password"],
select,
textarea{
	flex: 1;
	  font-size: var(--body);
	padding: 10px 0px 5px;
	 -webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
     display: inline-block;
     position: relative;
     background-color: transparent;
     font-family: var(--sans);
     text-transform: uppercase;
     color: var(--primary);
     border: none;
     border-bottom: 1px solid var(--primary);
     border-radius: 0px;
     outline: none;
}
input[type="text"]:focus,
input[type="tel"]:focus, 
input[type="email"]:focus,
input[type="password"]:focus,
select:focus,
textarea:focus{
} 



@media all and (-ms-high-contrast:none){}