@layer reset, base, app, components, utilities, state;

@layer reset {

	* {
		box-sizing: border-box;
		transition-behavior: allow-discrete;
		interpolate-size: allow-keywords;
		margin: 0;
	}

	html,
	body,
	main, section, div, nav, footer {
		padding: 0;
		margin: 0;
		position: relative;
		box-sizing: border-box;
	}

	html,
	body {
		/*scrollbar-gutter: stable;*/
	}

	@view-transition {
		navigation: auto;
	}

	@keyframes page-nav-out {
		from {
			opacity: 1;
			transform: translateX(0);
		}

		to {
			opacity: 0;
			transform: translateX(-100%);
		}
	}

	@keyframes page-nav-in {
		from {
			opacity: 0;
			transform: translateX(10px);
		}
		to {
			opacity: 1;
			transform: translateX(0);
		}
	}

	@media not (prefers-reduced-motion: reduce) {
		html:not(.noViewTransition) {
			##{_g.$ns}_main-nav { 
				view-transition-name: main-banner; 
				view-transition-class: main-banner;
			}
			##{_g.$ns}_main-main { 
				view-transition-name: main-content;
				view-transition-class: main-content; 
			}
		}
		::view-transition-old(.main-content) {
			animation: 0.5s linear both page-nav-out;
		}
		::view-transition-new(.main-content) {
			animation: 0.75s ease both page-nav-in;
		}
	}


}

@font-face  { 
	font-family:Tiempos;
	font-style:normal;
	font-weight:normal;
	src:url(/app/fonts/JPMCTiempos-Regular.ttf) format("truetype"),
	url(/app/fonts/JPMCTiempos-Regular.otf) format("opentype"),
	url(/app/fonts/JPMCTiempos-Regular.woff2) format("woff2");
	font-display: swap;
}
@font-face { 
	font-family:Tiempos;
	font-style:italic;
	font-weight:normal;
	src:url(/app/fonts/JPMCTiempos-Italic.ttf) format("truetype"),
	url(/app/fonts/JPMCTiempos-Italic.otf) format("opentype"),
	url(/app/fonts/JPMCTiempos-Italic.woff2) format("woff2");
	font-display: swap;
}

@layer base {

	:root {

		--fnt: sans;

		--z-base-sub: 5;
		--z-base: 10;
		--z-base-sup: 15;

		--z-content-sub: 900;
		--z-content: 1000;
		--z-content-sup: 1100;

		--z-nav-sub: 4900;
		--z-nav: 5000;
		--z-nav-sup: 5100;

		--z-msg-sub: 9900;
		--z-msg: 10000;
		--z-msg-sup: 10100;

		--z-super-sub: 99900;
		--z-super: 99999;
		--z-super-sup: 199999;

	}

	body {
		font-family: var(--fnt);
	}

}

@layer app {

	:root {

		--fnt: Tiempos,Iowan Old Style,Apple Garamond,Baskerville,Times New Roman,"Droid Serif",Times,"Source Serif Pro",Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,serif;

		--clr-black: hsla(40, 33%, 2%, 1);
		--clr-grey: hsla(0, 0%, 13%, 1);

		--clr-white: hsla(37, 37%, 93%, 1); 

		--clr-brown-dk: hsla(45, 7%, 12%, 1);
		--clr-brown: hsla(23, 43%, 39%, 1);
		--clr-brown-lt: hsla(30, 40%, 56%, 1);

	}

	body {
		background-color: var(--clr-black);
		color: var(--clr-brown-lt);
	}

	a {
		color: var(--clr-brown-lt);
	}

}


@layer state {

	body[data-kiosk-mode="true"] {
		overflow-x: hidden;
		-webkit-user-select: none;
		user-select: none;
	}
	html:has([data-kiosk-mode="true"]),
	html:has([data-kiosk-mode="true"]) *,
	[data-kiosk-mode="true"],
	[data-kiosk-mode="true"] *  {
		-webkit-user-select: none;
		user-select: none;
	}

	/*[data-fullscreen="true"] {

	}*/

}

#main {
	min-height: 100svh;
}


.screenType {

	display: block;
	min-height: 100svh;
	position: relative;
	opacity: 1;
	pointer-events: auto;

	min-width: 100svw;
	max-width: 100svw;

	transition: 
		opacity 0.75s ease,
		display 0.75s allow-discrete;

	transition-behavior: allow-discrete;

	overflow-x: hidden;

	&[aria-hidden="true"] {
		position: absolute;
		top:0;
		opacity: 0;
		display: none;
		pointer-events: none;
		z-index: 10;
	}

	&[aria-hidden="false"] {
		z-index: 100;
	}

}

@starting-style {
	.screenType {
		position: absolute;
		top: 0;
		opacity: 0;
		pointer-events: none;
	}
}

.screenType-inner {
	min-width: 100svw;
	gap: 2rem;
}


.fill {
	min-width: 100%;
	min-height: 100svh;
}

.flxwrap-center {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	align-content: center;
	justify-content: center;
}

.nav-footer {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 1rem 2rem 2rem;
	text-align: center;
}


/**
 * videos
 */
.video_wrap {

}
.video {
	width: 100%;
	object-fit: contain;
}

.jpmc_logo {
	aspect-ratio: 1000 / 141.83;
}
.title_lockup {
	aspect-ratio: 1833 / 138;
}
.curated_by {
	aspect-ratio: 113 / 11;
}


.nav-header {
	
	padding: 1rem;
	position: relative;

	display: flex;

	align-items: center;

	gap: 1rem;

	> a {
		position: absolute;
		left: 1rem;
		top: 50%;
		translate: 0 -50%;
		z-index: var(--z-nav-sup);
	}

	h1 {
		text-align: center;
		flex: 1;
		z-index: var(--z-nav-sub);
	}

}

.nav-back {
	display: inline-flex;
	color: #fff;
	padding: 0.5rem;
}

.wallscreen-wrap,
.wallscreen-wrap > .modules {
/*	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 1rem;*/
}

.wallscreen-wrap {
	padding: 1rem 0px;

	h1 {
		padding-inline: 1rem;
	}

}

.wallscreen-wrap > .modules {
	padding-inline: 10px;
}



.video-wrap {

	position: relative;
	display: flex;
	align-items: center;

	aspect-ratio: 16/9;
	max-width: 100%;
	
	max-height: 80svh;
	min-height: 80svh;

	background-color: black;
	margin: auto;

	.video-wrap-inner {
		position: relative;
		aspect-ratio: 16/9;
		width: 100%;
		height: 100%;

		display: flex;
		align-items: center;
		object-fit: contain;

		video {
			object-fit: contain;
			margin: auto;
		}

	}

}


.video_wrap + .detail-copy {
	padding: 1rem;
	border: 2px dashed hotpink;
}


.screenType-AttractScreen {

}

#welcome_lockup {
	position: fixed;
	top: 50svh;
	left: 50svw;
	translate: -50% -50%;
	width: 100%;
	aspect-ratio: 1780 / 1034;
	max-width: 87.14svw;
	max-height: 70.73svh;
	object-fit: contain;
	pointer-events: none;
	display: flex;
	align-items: center;
}

#attract_img {
	position: absolute;
	top: 50%;
	left: 50%;
	aspect-ratio: 1668 / 1091;
	width: auto;
	height: 100%;
	translate: -50% -50%;
	opacity: 1;
	z-index: var(--z-content-sub);
}
.title_lockup {
	width: 100%;
	aspect-ratio: 1833 / 138;
	color: var(--clr-white);
	z-index: var(--z-content);
}


.screenType-ExploreScreen {

	.page-list {
		container-type: inline-size;
		container-name: pageList;
	}

	h1 {
		text-wrap: balance;
	}
}


/**
 * page list
 */
.page-list-list {
	list-style-type: none;
	margin: 0;
	padding:0;
	display: grid;
	grid-template-columns: repeat( auto-fit, minmax(300px, 1fr) );
	grid-column-gap: 2.75cqi; /* 60 / 2180 landscape */
	grid-row-gap: 2.20cqi; /* 48 / 2180 landscape */

	li {

		container-type: inline-size;
		container-name: wall;

		will-change: opacity, scale;
		transition: opacity 0.3s ease, 
			scale 0.15s ease-out;

		transition-delay: 0.25s;

		&:nth-child(2) { transition-delay: 0.26s; }
		&:nth-child(3) { transition-delay: 0.27s; }
		&:nth-child(4) { transition-delay: 0.28s; }
		&:nth-child(5) { transition-delay: 0.29s; }
		&:nth-child(6) { transition-delay: 0.3s; }
		&:nth-child(7) { transition-delay: 0.31s; }
		&:nth-child(8) { transition-delay: 0.32s; }
		&:nth-child(9) { transition-delay: 0.33s; }
		&:nth-child(10) { transition-delay: 0.34s; }
		&:nth-child(11) { transition-delay: 0.35s; }

		opacity: 1;
		scale: none;

		@starting-style {
			opacity: 0;
			scale: 0.5;
		}

		a {
			position: relative;
			display: flex;
			flex-direction: column;
			gap: 4px; /* 8px */
			aspect-ratio: 5/3.33;
			align-items: start;
			justify-content: center;
			transition: scale 0.15s ease-out;
			text-align: center;
			text-wrap: balance;			

			text-decoration: none;
			&:visited {
				text-decoration: none;
			}

			&:active {
				scale: 0.99;
			}

			span {
				font-size: clamp(12px, 5cqi, 26px);
				line-height: 1.15385;
				width: 100%;
			}

			img {
				width: 100%;
				aspect-ratio: 5/3.33;
				object-fit: cover;
			}

		}

	}

}
@media only screen and (min-width: 720px) {
	.page-list-list {
		grid-template-columns: repeat( auto-fit, minmax(230px, 1fr) );
	}
}


#explorescreen-wrap {
	min-height: 100svh;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;

	> * {
		flex: 0;
		width: 100%;
	}

}

#modules-ExploreID-000001 {
	/*flex: 1;*/
	min-height: 90svh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: min(45px, 1cqmin) 4.13cqi;

	> * {
		flex: 0;
		width: 100%;
	}
}


.footer_logo-wrap {
	position: fixed;
	bottom: 44px; /* 87px; */
	left: 0;
	width: 100%;
	display: flex;
	justify-content: center;
	padding-inline: 10px;
}


.main_footer {
	position: fixed;
	bottom: 0px;
	left: 0px;
	width: 100%;
	padding: 26px 30px; /* 52px 60px; */
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	z-index: var(--z-nav);

	color: var(--clr-brown-lt);

	.title_lockup-wrap {
		display: flex;
		align-items: baseline;
		gap: 1rem;
	}

	svg {
		height: 28px;
		width: auto;
		color: var(--clr-brown-lt);
	}

	.curated_by {
		height: 12px;
		translate: 0 -33%;
	}

}










/**
 *  screensaver fun
 */ 
@keyframes screenSaverTextSwell {
  from {
    opacity: var(--kiosky-ss-minop);
  }
  to {
    opacity: var(--kiosky-ss-maxop);
  }
}
@keyframes screenSaverTextOutWater {
  0% {
    opacity: 1;
    filter: none;
    transform: translateY(0%);
  }
  0.01% {
    opacity: 1;
    filter: url(#screensaver-distort-once-focus-out) blur(0px); 
    transform: translateY(0%);
  }
  100% {
    opacity: 0;
    filter: url(#screensaver-distort-once-focus-out) blur(3px); 
    transform: translateY(-100%);
  }
}
@keyframes screenSaverTextOut {
  0% {
    opacity: 1;
    filter: none;
    transform: translateY(0%);
  }
  100% {
    opacity: 0;
    filter: blur(calc((20 * 100vw) / 1080));
    transform: translateY(-100%);
  }
}
@keyframes screenSaverTextIn {
  0% {
    opacity: 0;
    filter: blur(calc((20 * 100vw) / 1080));
    transform: translateY(-100%);
  }
  100% {
    opacity: 1;
    filter: none;
    transform: translateY(0%);
  }
}

#screenSaver {
  position: absolute;
  inset: 0;
  background-color: rgba(0,0,0,1);
  z-index: var(--z-super);
  transition: opacity 0.3s ease;
  overflow: hidden;
  pointer-events: auto;
}
#screenSaver[aria-hidden="true"] {
  pointer-events: none;
  opacity: 0;
}
#screenSaver * {
  pointer-events: none;
}
#screenSaver-svgFilter-container {
  display: none;
}
#screenSaver-video {
}
#screenSaver-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.screenSaver-cta {
  --kiosky-ss-oploop-dur: 3.5s;
  --kiosky-ss-out-dur: 4s;
  --kiosky-ss-in-dur: 4s;
  --kiosky-ss-maxop: 0.75;
  --kiosky-ss-minop: 0.33;
  position: absolute;
  white-space: nowrap;
  font-size: calc((28 * 100vw) / 1080);
  letter-spacing: -0.015em;
  text-align: center;
  color: var(--color-white);
  animation: screenSaverTextOut var(--kiosky-ss-out-dur) forwards;
  animation-delay: 0s;
}

.screenSaver-cta.showMe {
  animation: screenSaverTextIn var(--kiosky-ss-in-dur) forwards;
  animation-delay: 0s;
}
  
  .screenSaver-cta span {
    color: var(--color-white);
    transition: opacity 0.3s ease;
    animation: screenSaverTextSwell var(--kiosky-ss-oploop-dur) ease alternate infinite;
  }
  .screenSaver-cta.showMe span {
    animation: screenSaverTextSwell var(--kiosky-ss-oploop-dur) ease alternate infinite;
  }
  .screenSaver-cta.resetMe span {
    opacity: var(--kiosky-ss-maxop);
    animation: none;
  }



dialog {
	top:0;
	left:0;
	padding: 0;
	margin: auto;
	border:0;
	width: 100%;
	height: 100%;
	background-color: transparent;
	align-content: center;
	justify-content: center;

  opacity: 0;
  transform: scale(0);
  pointer-events: none;
  /* list of properties we will transition */
  transition:
    opacity 0.7s ease-out,
    transform 0.7s ease-out,
    overlay 0.7s ease-out allow-discrete,
    display 0.7s ease-out allow-discrete;
}

.dialog_content {
	padding: 1rem;
	background-color: hsla(0deg, 0%, 100%, 0.75);
	display: flex;
	margin: auto;
	max-width: 100%;
	justify-content: center;
	text-align: center;
	box-shadow: 0 3px 7px hsla(0deg, 0%, 0%, 0.5);
	pointer-events: auto;
}

dialog:open {
  opacity: 1;
  transform: scale(1);
  display: flex;
 	pointer-events: auto;
}
@starting-style {
  dialog:open {
    opacity: 0;
    transform: scale(0);
  }
}
dialog::backdrop {
  background-color: transparent;
  transition:
    display 0.7s allow-discrete,
    overlay 0.7s allow-discrete,
    background-color 0.7s;
  /* Equivalent to transition: all 0.7s allow-discrete; */
  backdrop-filter: blur(4px);
  pointer-events: none;
}

dialog:open::backdrop {
  background-color: rgb(0 0 0 / 25%);
  pointer-events: auto;
}

@starting-style {
  dialog:open::backdrop {
    background-color: transparent;
  }
}





@keyframes rainbowloop {
  0%, 100% { background-color: hsl(0, 100%, 50%); }
  16.67% { background-color: hsl(60, 100%, 50%); }
  33.33% { background-color: hsl(120, 100%, 50%); }
  50% { background-color: hsl(180, 100%, 50%); }
  66.67% { background-color: hsl(240, 100%, 50%); }
  83.33% { background-color: hsl(300, 100%, 50%); }
}
@keyframes alphaloop-half {
  0%   {opacity: 1;}
  50%  {opacity: 0.5;}
  100% {opacity: 1;}
}
.rainbowBG {
  animation:
    rainbowloop 15s linear infinite,
    alphaloop-half 7s linear infinite ;
}


#attract-wrap {
	display: flex;
	/* width: 100%; */
	min-width: 100svw;
	align-items: center;
	justify-content: center;
}