@charset "UTF-8";
/* CSS Document */

@font-face {
  font-family: Montserrat-Medium;
  src: url("../fonts/Montserrat/Montserrat-Medium.ttf");
  /*src: url(data:font/ttf;base64,STRING) format('truetype');*/
}

@font-face {
  font-family: Montserrat-SemiBold;
  src: url("../fonts/Montserrat/Montserrat-SemiBold.ttf");
  /*src: url(data:font/ttf;base64,STRING) format('truetype');*/
}

@font-face {
  font-family: Antipasto-Pro-Medium;
  src: url("../fonts/Antipasto/AntipastoPro-Medium_trial.ttf");
  /*src: url(data:font/ttf;base64,STRING) format('truetype');*/
}

html,body { 
	padding: 0;
	margin: 0;
	color: #000;
	overflow: hidden; /* Hide scrollbars */
}

body { 
	background-color: #000;
}
	
/* Hide scrollbar for Chrome, Safari and Opera */
body::-webkit-scrollbar {
  display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
body {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}

a {
	color: #222;
}

body {
	/*background: linear-gradient(-45deg, #40C8DB, #EB434E, #3AF2D6, #5B67F5);*/
	/*background: linear-gradient(-45deg, #91381d, #8c1241, #066c91, #065e49);*/
	/*background: linear-gradient(-45deg, #ee7752, #e73c7e, #23a6d5, #23d5ab);*/
	background-color: #000; 
	background-size: 400% 400%;
	animation: gradient 30s ease infinite;
	height: 100vh;
}

@keyframes gradient {
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}

.blanketCover{
	width: 100vw;
	height: 100vh;
	display: block;
	opacity: 1;
	box-sizing: border-box;
	overflow: hidden;
	position: fixed;
	left: 0vw;
	bottom: 0vh;
	text-align: center;
	background-color: rgba(0,0,0,0.9);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: all 1.0s ease-in-out;
	z-index: 10;
}

.blanketCover img{
	width: 300px;
	height: 300px;
	display: block;
	position: absolute;
	left: 0; 
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto; 
	opacity: 0.0; 
	transition: all 2.0s ease-in-out;
}

@supports (-webkit-touch-callout: none) {
	/* CSS specific to iOS devices */
	.blanketCover img{ top: 82px; }
}

@supports not (-webkit-touch-callout: none) {
	/* CSS for other than iOS devices */ 
	.blanketCover img{ top: 0; }
}

.starterMenu{
	width: 100vw;
	height: 100vh;
	display: block;
	opacity: 1;
	box-sizing: border-box;
	overflow: hidden;
	position: fixed;
	left: 0vw;
	bottom: 0vh;
	text-align: center;
	background-color: rgba(0,0,0,0.9);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: opacity 0.5s ease-in-out;
	z-index: 10;
	opacity: 0;
}

.theOne {
	animation: growShrink 1s ease-in-out, bounce 3s infinite ease-in-out;
}

.personaMenuButton.largeIt {
	transform: scale(1.8);
}

@keyframes growShrink {
  0%, 100% {
    transform: scale(1.8);
  }
  50% {
    transform: scale(2.4);
  }
}

@keyframes bounce {
  0%, 100% {
    margin-bottom: 0;
  }
  50% {
    margin-bottom: 30px;
  }
}

#starterMenu{
	display: none;
}

#starterMenuX{
	display: none;
}

.personaMenuBoxContainer{
	width: 100vw;
	height: 100svh;
	display: block;
	position: absolute;
	box-sizing: border-box;
	border: 0px solid rgba(255, 255, 255, 0.5);
	
	left: 0;
	top: 0;

	height: 100svh;           /* “small viewport height” on iOS Safari */
	display: flex;            /* flex container to center its child */
	align-items: center;      /* vertical centering */
	justify-content: center;  /* horizontal centering */
}

.personaMenuBoxContainer a{
	text-decoration: none;
	text-align: center;
	color: rgba(255, 255, 255, 0.7);
}

.personaMenuBoxContainerTestBox{
	width: 100vmin;
	height: auto;
	display: block;
	position: absolute;
	box-sizing: border-box;
	border: 0px solid red;
	background-color: rgba(255,0,0,0.0);
}

.personaMenuBox{
	
	
	
	display: block;
	position: absolute;
	left: 0; 
	right: 0;
	top: 0;
	margin-left: auto;
	margin-right: auto;
	opacity: 1.0;
	border: 1px solid blue; 
	z-index: 10;
	padding: 5px;

	display: grid;
	grid-auto-flow: row dense;
 	grid-template-columns: repeat(auto-fill, minmax(120px, 0px));
	gap: 0;
 	align-content: end; /* Stick rows to bottom */
 	justify-content: center; /* Center horizontally */
}

@supports (-webkit-touch-callout: none) {
	/* CSS specific to iOS devices */
	.personaMenuBox { }
	.personaMenuBoxContainer{ top: 82px; }
}

@supports not (-webkit-touch-callout: none) {
	/* CSS for other than iOS devices */ 
	.personaMenuBox { }
	.personaMenuBoxContainer{ top: 0px; }
}

@media (max-width: 480px) {
  	/* Styles for most phones */
	.personaMenuBoxContainer{ top: 82px; }
}

.personaMenuButton{
	width: 25vw;
	height: 25vw;
	box-sizing: border-box;
	background-color: rgba(255, 255, 255, 0.0);
	padding: 5px;
	border-radius: 50%;
	display: inline-block;
	margin: 5px;
	transition: all 0.2s ease-in-out;
	border: 1px solid rgba(255, 255, 255, 0.1);
	/*filter: drop-shadow(0 0 0.40rem rgba(0, 0, 0, 0.5));*/
}

@media (orientation: landscape) {
	
	.personaMenuBox{

	}

	.personaMenuButton {
		width: 18vh;
		height: 18vh;
	}
	
	.personaMenuBoxContainerTestBox{
		height: auto;
	}
}

@media (orientation: portrait) {
	
	.personaMenuButton {
		width: 25vw;
		height: 25vw;
	}
	
	.personaMenuBoxContainerTestBox{
		height: auto;
	}
}

.button_explore{
	width: 262px;
	height: 44px;
	font-size: 15px;
	border: 0;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
	margin-bottom: 30px;
	background-color: #222;
	color: #fff;
	border-radius: 40px;
	box-sizing: border-box;
	text-transform: uppercase;
	position: relative;
	top: 15px;
	overflow: hidden;
}

.button_explore a{
	text-decoration: none;
	color: rgba(255, 255, 255, 0.8);
	line-height: 48px;
	display: block;
}

.personaMenuButton.selected{
	/*filter: drop-shadow(0 0 0.40rem rgba(255, 255, 255, 0.5));*/
	/*filter: drop-shadow(0 0 1.00rem crimson);*/
	/*filter: drop-shadow(0 0 1.00rem rgba(255, 255, 255, 0.8));*/
	border: 2px solid rgba(255, 255, 255, 0.8);
}

.personaMenuButton.egg{
	/*filter: drop-shadow(0 0 0.40rem rgba(255, 255, 255, 0.5));*/
	/*filter: drop-shadow(0 0 1.00rem crimson);*/
	/*filter: drop-shadow(0 0 1.00rem rgba(255, 255, 255, 0.8));*/
	border: 2px solid rgba(255, 255, 255, 0.0);
}

.personaMenuButton.egg:before {
	content: '';
	position: absolute;
	width: calc(100% + 4px);
	height: calc(100% + 4px);
	border-radius: 50%;
	top: -2px;
	left: -2px;
	z-index: 0;
	animation: spin 5s linear infinite;
	pointer-events: none;
	background: linear-gradient(90deg,rgba(42, 123, 155, 1) 0%, rgba(87, 199, 133, 1) 50%, rgba(237, 221, 83, 1) 100%);
	opacity: 0.7;
	
	box-shadow: 0 0 20px rgba(255,255,255,0.25),
    0 0 40px rgba(255,255,255,0.25),
    0 0 60px rgba(255,255,255,0.25),
    0 0 80px rgba(255,255,255,0.25);
}

.cont_c{
	width: calc(100% - 14px);
	height: calc(30%);
	display: block;
	border: 0px solid red;
	opacity: 0;
	text-align: center;
	margin: auto;
	font-size: 1.3vh;
	text-transform: uppercase;
	position: absolute;
	box-sizing: border-box;
	bottom: 0;
	text-shadow: #000 4px 0 6px;
	letter-spacing: 1px;
}

@keyframes  spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.personaMenuButton.hideIt{
	display: none;
}

.personaMenuButton a{
	width: 100%;
	height: 100%;
	display: block;
	border-radius: 50%;
	overflow: hidden;
	box-sizing: border-box;
	border: 2px solid #222;
}

.p0{
	background-image: url("../olibs/ai_avatar/personas/mon_t.jpg?v=4");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p1{
	background-image: url("../olibs/ai_avatar/personas/calm_t.jpg");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p2{
	background-image: url("../olibs/ai_avatar/personas/omega_t.jpg");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p3{
	background-image: url("../olibs/ai_avatar/personas/zen_t.jpg");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p4{
	background-image: url("../olibs/ai_avatar/personas/lea_t.jpg");
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p5{
	background-image: url("../olibs/ai_avatar/personas/dan_t.jpg"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p6{
	background-image: url("../olibs/ai_avatar/personas/m_t.jpg"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p7{
	background-image: url("../olibs/ai_avatar/personas/elle_t.jpg?v=2"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p8{
	background-image: url("../olibs/ai_avatar/personas/clara_t.jpg"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p9{
	background-image: url("../olibs/ai_avatar/personas/kai_t.jpg"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p10{
	background-image: url("../olibs/ai_avatar/personas/droid_t.jpg?v=3"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.p11{
	background-image: url("../olibs/ai_avatar/personas/kay_t.jpg"); 
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.starterMenuBox{
	width: 320px;
	height: 160px;
	display: block;
	position: absolute;
	left: 0; 
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto; 
	opacity: 1.0;
	border: 1px solid red;
	display: none;
}

@supports (-webkit-touch-callout: none) {
	/* CSS specific to iOS devices */
	.starterMenuBox { top: 82px; }
}

@supports not (-webkit-touch-callout: none) {
	/* CSS for other than iOS devices */ 
	.starterMenuBox { top: 0; }
}

.starterMenuButton{
	width: 120px;
	height: 120px;
	display: inline-block;
	color: #222;
	background-color: rgba(255,255,255,0.0);
	margin: 20px;
	line-height: 120px;
	opacity: 1.0;
	z-index: 12;
}

.starterMenuButton:hover{
	opacity: 1.0;
}

.starterMenuButton.A{
	filter: drop-shadow(0 0 0.75rem crimson);
}

.starterMenuButton.B{
	filter: drop-shadow(0 0 0.75rem rgb(160, 0, 210));
}

.starterMenuButton.A:hover{
	filter: drop-shadow(0 0 0.50rem #fff);
}

.starterMenuButton.B:hover{
	filter: drop-shadow(0 0 0.50rem #fff);
}

.optionType_f{
	width: 25%;
	height: 25%;
	display: block;
	background-color: rgba(255, 0, 0, 0.0);
	border: 1px solid rgba(255, 0, 0, 0.0);
	box-sizing: border-box;
	border-radius: 50%;
	overflow: hidden;
	float: right;
	margin-right: 10%;
	margin-top: 10%;
}

.optionType_m{
	width: 25%;
	height: 25%;
	display: block;
	background-color: rgba(0, 0, 255, 0.0);
	border: 1px solid rgba(0, 0, 255, 0.0);
	box-sizing: border-box;
	border-radius: 50%;
	overflow: hidden;
	float: right;
	margin-right: 10%;
	margin-top: 10%;
	background-image: url("../images/members_lock.png?v=3");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	opacity: 0.3;
	transition: all 0.2s ease-in-out;
}

.logo{
	width: 110px;
	height: 54px;
	display: block;
	position: absolute;
	left: calc(50vw - 55px);
	/*top: 20px;*/
	bottom: 2vmin;
	border: 0px solid red;
	opacity: 0.7;
	z-index: 12;
}

@supports (-webkit-touch-callout: none) {
	/* CSS specific to iOS devices */
	.logo { /*top: 102px;*/ bottom: 34px; top: 17vh; }
}

@supports not (-webkit-touch-callout: none) {
	/* CSS for other than iOS devices */ 
	.logo { /*top: 20px;*/ bottom: 34px; top: 10vh; }
}

@media (max-width: 480px) {
  	/* Styles for most phones */
	.logo { /*top: 102px;*/ bottom: 34px; top: 17vh; }
}

.splashNav{
	border: 0px solid red;
	width: 100%;
	height: 40px;
	box-sizing: border-box;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}

@supports (-webkit-touch-callout: none) {
	/* CSS specific to iOS devices */
	.splashNav { top: 82px; }
}

@supports not (-webkit-touch-callout: none) {
	/* CSS for other than iOS devices */ 
	.splashNav { top: 0; }
}

@media (max-width: 480px) {
  /* Styles for most phones */
	.splashNav { top: 82px; }
}

.splashNavButton{
	border: 0px solid red;
	width: 200px;
	height: 60px;
	box-sizing: border-box;
	text-align: center;
	font-size: 16px;
	line-height: 60px;
	display: inline-block;
	color: #ededed;
	font-family: Antipasto-Pro-Medium;
}

.splashNavButton a{
	width: 100%;
	height: 100%;
	display: block;
	text-decoration: none;
	color: #777;
	font-family: Antipasto-Pro-Medium;
	transition: all 0.2s ease-in-out;
}

.splashNavButton a:hover{
	width: 100%;
	height: 100%;
	display: block;
	text-decoration: none;
	color: #ededed;
	font-family: Antipasto-Pro-Medium;
}



.starterMenuButton a{
	text-decoration: none;
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	display: block;
	width: 100%;
	height: 100%;
	text-align: center;
}

.note{
	width: 300px;
	height: 70px;
	line-height: 16px;
	padding: 10px;
	box-sizing: border-box;
	border: 1px solid rgba(255, 255, 255, 0.1);
	position: absolute;
	bottom: 20px;
	left: calc(50vw - 150px);
	font-size: 0.6em;
	color: rgba(255, 255, 255, 0.3);
	border-radius: 10px;
	display: none;
}

.splash_message{
	font-family: Antipasto-Pro-Medium;
	width: 100%;
	height: auto;
	line-height: 16px;
	padding: 10px;
	box-sizing: border-box;
	border: 1px solid rgba(255, 255, 255, 0.0);
	position: absolute;
	bottom: 6vmin;
	font-size: 0.8em;
	color: rgba(255, 255, 255, 0.8);
	border-radius: 10px;
}

.splash_line_1{
	font-size: 2.8em;
	line-height: 1.0em;
	margin-bottom: 4px;
	color: #ededed;
	transition: all 0.2s ease-in-out;
}

.splash_line_2{
	font-size: 1.2em;
	line-height: 1.0em;
	color: #777;
	transition: all 0.2s ease-in-out;
}

@media (orientation: landscape) {
	
	.splash_line_1{
		font-size: 2.8em;
	}

	.splash_line_2{
		font-size: 1.2em;
	}
}

@media (orientation: portrait) {
	
	.splash_line_1{
		font-size: 2.4em;
	}

	.splash_line_2{
		font-size: 1.0em;
	}
}

.splashAudioButton{
	width: 60px;
	height: 60px;
	box-sizing: border-box;
	text-align: center;
	display: block;
	position: absolute;
	bottom: 180px;
	bottom: calc(6vmin + 90px);
	left: calc(50vw - 30px);
	z-index: 10;
	opacity: 0;
	overflow: hidden;
	border-radius: 50%;
}

.splashAudioButton a{
	width: 60px;
	height: 60px;
	box-sizing: border-box;
	text-align: center;
	display: block;
	transition: all 0.2s ease-in-out;
	padding: 5px;
}

.splashAudioButton img{
	width: 50px;
	height: 50px;
	box-sizing: border-box;
	text-align: center;
	display: block;
	transition: all 0.2s ease-in-out;
	opacity: 0.4;
}

.splashAudioButton img:hover{
	width: 50px;
	height: 50px;
	box-sizing: border-box;
	text-align: center;
	display: block;
	transition: all 0.2s ease-in-out;
	opacity: 0.8;
}

.glowing {
  position: relative;
  min-width: 400px;
  height: 250px;
  margin: -50px;
  transform-origin: right;
  animation: colorChange 5s linear infinite;
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
  z-index: 10;
  pointer-events: none;
}

.glowing:nth-child(even) {
  transform-origin: left;
}

@keyframes colorChange {
  0% {
    filter: hue-rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    filter: hue-rotate(360deg);
    transform: rotate(360deg);
  }
}

.glowing span {
  position: absolute;
  top: calc(80px * var(--i));
  left: calc(80px * var(--i));
  bottom: calc(80px * var(--i));
  right: calc(80px * var(--i));
}

.glowing span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -8px;
  width: 15px;
  height: 15px;
  background: #f00;
  border-radius: 50%;
}

.glowing span:nth-child(3n + 1)::before {
  background: rgba(134,255,0,1);
  box-shadow: 0 0 20px rgba(134,255,0,1),
    0 0 40px rgba(134,255,0,1),
    0 0 60px rgba(134,255,0,1),
    0 0 80px rgba(134,255,0,1),
    0 0 0 8px rgba(134,255,0,.1);
}

.glowing span:nth-child(3n + 2)::before {
  background: rgba(255,214,0,1);
  box-shadow: 0 0 20px rgba(255,214,0,1),
    0 0 40px rgba(255,214,0,1),
    0 0 60px rgba(255,214,0,1),
    0 0 80px rgba(255,214,0,1),
    0 0 0 8px rgba(255,214,0,.1);
}

.glowing span:nth-child(3n + 3)::before {
  background: rgba(0,226,255,1);
  box-shadow: 0 0 20px rgba(0,226,255,1),
    0 0 40px rgba(0,226,255,1),
    0 0 60px rgba(0,226,255,1),
    0 0 80px rgba(0,226,255,1),
    0 0 0 8px rgba(0,226,255,.1);
}

.glowing span:nth-child(3n + 1) {
  animation: animate 10s alternate infinite;
}

.glowing span:nth-child(3n + 2) {
  animation: animate-reverse 3s alternate infinite;
}

.glowing span:nth-child(3n + 3) {
  animation: animate 8s alternate infinite; 
}

@keyframes animate {
  0% {
    transform: rotate(180deg);
  }
  50% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes animate-reverse {
  0% {
    transform: rotate(360deg);
  }
  
  50% {
    transform: rotate(180deg);
  }
  
  100% {
    transform: rotate(0deg);
  }
}

a {
  -webkit-tap-highlight-color: transparent;
  outline: none;
}

a:focus, a:active {
  outline: none;
}