*
{
	box-sizing: border-box;
}

body
{
	margin: 0;
	min-height: 100vh;
	background-color: #af1e23;
	/* color: #0c0b0b; */
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	font-family: sans-serif;
	background-image: url('burst.svg');
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
	font: 18pt 'Wood Heinz No4 Regular', sans-serif;
	text-transform: uppercase;
	padding-bottom: 4rem;
}

/* Style the input and button elements. Black with no border. buttons glow red on hover */
input, button
{
	font: 18pt 'Wood Heinz No4 Regular', sans-serif;
	border: none;
	padding: 0.5rem;
	padding-top: 3px;
	color: #fff;
	border-radius: 5px;
}
input
{
	background-color: #0c0b0b;
	/* width: 200px; */
	margin-left: 1em;
	margin-right: 1em;
}
button
{
	background-color: #0c0b0b;
	cursor: pointer;
	transition: box-shadow 0.2s;
}
button:hover
{
	/* box-shadow: 0 0 10px #D11F28; */
	background-color:  #D11F2880;
	transform: translateY(-4px);
	transition: background-color 0.2s ease-in-out, transform 0.2s ease-in-out;
}

article h1
{
	color: #000;
	font-size: 3em;
	margin-bottom: 0px;
	text-align: center;
}

article
{
	width: 100%;
	overflow-y: visible;
	overflow-x: hidden;
	z-index: 1;
	margin-bottom: 0;
	pointer-events: auto;
}

section
{
	padding: 3rem 1rem;
	/* min-height: 100vh; */
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}

section:first-child
{
	min-height: 100vh;
}

section h1
{
	font-size: 3.5em;
	margin-top: 1rem;
	margin-bottom: 1.5rem;
	color: #D11F28;
}
section h2
{
	font-size: 2.5em;
	margin-bottom: 1.5rem;
	color: #D11F28;
}

section p:nth-of-type(1)
{
	margin-top: 0;
}
section p
{
	max-width: 800px;
	line-height: 1.6;
	margin-bottom: 1rem;
	color: #fff;
}

section:nth-child(odd) h2
{
	color: #fff;
}
section:nth-child(odd) p
{
	color: #141212;
}

section
{
	position: relative;
}
section:nth-child(even)
{
	background-color: #0c0b0b;
	background-image: url('burst2.svg');
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
}

section.latest p:nth-of-type(odd)
{
	text-align: left;
	display: flex;
	align-items: flex-start;
	/* border: 1px solid blue; */
}

section.latest p img
{
	/* float: left; */
	margin-right: 1rem;
	border-radius: 10px;
	max-width: 150px;
}


/* remove dots and things from this ul */
section.about > ul
{
	display: flex;
	min-width: 800px;
	list-style-type: none;
	justify-content: center;
	padding: 0;
	/* border: 1px solid blue; */
}
section.about > ul > li
{
	flex: 1;
	text-align: center;
	display: flex;
	flex-direction: column;
}

section.about > ul > li > ul
{
	margin-top: 0.5rem;
	font-size: 0.75em;
	text-align: left;
}

@media (min-width: 761px)
{
	section.about > ul > li:nth-of-type(2) > ul
	{
		text-align: right;
		direction: rtl;
		/* color: yellow; */

	}
}

section.social a
{
	margin: 0 0.5rem;
	color: #edbd87;
	font-size: 2em;
	text-decoration: none;
	transition: color 0.2s, transform 0.2s ease-in-out;
}
section.social a:hover
{
	color: #fff;
	transition: color 0.2s;
	transform: scale(1.1) translateY(-2px);
	transition: transform 0.2s ease-in-out, color 0.2s;
}

section.song h1
{
	margin-bottom: 0;
}
section.song h2
{
	margin-top:   0;
	margin-bottom:0;
	font-size: 1.2em;
	text-align: end;
}
section.song ul
{
	list-style-type: none;
	padding: 0;
	display: flex;
	justify-content: space-between;
	max-width: 400px;
	margin: 0 auto;
	margin-top: 1rem;
}
section.song ul li a
{
	font-size: 1.5em;
	text-decoration: none;
	color: #fff;
}
section.song ul li a:hover
{
	color: #edbd87;
}
section.song ul li:hover
{

	transform: scale(1.1) translateY(-2px);
	transition: transform 0.2s ease-in-out;
}
section.song .split
{
	display: flex;
	flex-direction: row;
	gap: 1.5rem;
}
section.song .split>*
{
	width: 100%;
	max-width: 800px;
}

section.song-about
{
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: 1.5rem;
	max-width: 880px;
	margin: 0 auto;
}
section.song-about h3
{
	margin-top: 0;
	margin-bottom: 0;
	font-size: 1.25em;
}
section.song-about>div:first-child
{
	width: 250px;
	border-radius: 10px;
	font-size: 0.6em;
}
section.song-about>div
{
	/* border: 1px solid yellow; */
	display: flex;
	flex-direction: column;
	text-align: start;
}
section.song-about>div p
{
	margin-top: 0;
	text-align: justify;
	/* margin-left: 1rem; */
}
section.song-about>div p.lyrics
{
	font-size: 0.8em;
	line-height: 1.4;
	font-style: italic;
}
section.song-about>div .divider
{
	margin: 0 auto;
	margin-bottom: 1rem;
}
section.song-about img.cover-art
{
	border-radius: 10px;
	box-shadow: 0 1px 10px rgba(0, 0, 0, 0.25);
}

section ul.facts
{
	/* list-style-type: disc; */
	padding: 0;
	/* color: #141212; */
	font-size: 0.8em;
	flex-direction: column;
	max-width: 800px;
	/* text-align: left; */
}
section ul.facts:hover li
{
	/* opacity: 0.5; */
	transition: opacity 0.2s ease-in-out;
}
section ul.facts li:hover
{
	opacity: 1;
	transition: opacity 0.2s ease-in-out;
}
section ul.facts li
{
	/* display: flex;
	flex-direction: column;
	align-items: center; */
	margin-bottom: 1rem;
	/* margin-right: 2.5rem; */
	/* text-align: justify; */
}
section ul.facts li span
{
	/* position: absolute; */
	/* margin-top: 1rem; */
	font-size: 1.5em;
	opacity: 0;
	transition: opacity 0.2s ease-in-out;
}
section ul.facts li span i
{
	margin-right: 0.5rem;
}

/* Fact or Fiction: 2-column grid (statement | reveal) */
section.facts ul.facts {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px 20px;
	list-style: none;
	padding: 0;
	margin: 18px 0 0;
}

section.facts ul.facts > li {
	margin: 0;
}

/* Right-hand cells (answers) start hidden */
section.facts ul.facts > li:nth-child(even) {
	position: relative;
	color: transparent;
	transform: translateY(2px);
	transition: color 160ms ease, transform 160ms ease;
	pointer-events: none;
	text-align: right;
}

/* Big centered question mark placeholder (right side only) */
section.facts ul.facts > li:nth-child(even)::after {
	content: "?";
	position: absolute;
	left: 50%;
	top: 50%;
	translate: -50% -50%;
	color: #444;
	opacity: 0.35;
	font-weight: 800;
	font-size: clamp(32px, 4vw, 56px);
	line-height: 1;
	pointer-events: none;
	transform-origin: 50% 60%;
	transition: opacity 160ms ease;
}
section.facts:nth-child(odd) ul.facts > li:nth-child(even)::after
{
	color: #bbb;
}

@keyframes qm-rock {
	0% { transform: rotate(-5deg); }
	100% { transform: rotate(5deg); }
}

/* Gently rock when NOT hovered/focused */
section.facts ul.facts > li:nth-child(even):not(:hover):not(:focus):not(:focus-within)::after {
	animation: qm-rock 2.4s ease-in-out infinite alternate;
}

@media (prefers-reduced-motion: reduce) {
	section.facts ul.facts > li:nth-child(even)::after {
		animation: none !important;
	}
}

/* Left-hand cells (statements) are hover/focus targets */
section.facts ul.facts > li:nth-child(odd) {
	cursor: help;
	outline: none;
	text-align: left;
}

/* Reveal only the answer paired with the hovered/focused statement */
section.facts ul.facts > li:nth-child(odd):hover + li,
section.facts ul.facts > li:nth-child(odd):focus + li,
section.facts ul.facts > li:nth-child(odd):focus-visible + li,
section.facts ul.facts > li:nth-child(even):hover,
section.facts ul.facts > li:nth-child(even):focus,
section.facts ul.facts > li:nth-child(even):focus-visible {
	color: #D11F28;
	transform: none;
	pointer-events: auto;
}
section.facts:nth-child(odd) ul.facts > li:nth-child(odd):hover + li,
section.facts:nth-child(odd) ul.facts > li:nth-child(odd):focus + li,
section.facts:nth-child(odd) ul.facts > li:nth-child(odd):focus-visible + li,
section.facts:nth-child(odd) ul.facts > li:nth-child(even):hover,
section.facts:nth-child(odd) ul.facts > li:nth-child(even):focus,
section.facts:nth-child(odd) ul.facts > li:nth-child(even):focus-visible {
	color: #0c0b0b;
	transform: none;
	pointer-events: auto;
}

section.facts ul.facts > li:nth-child(odd):hover + li::after,
section.facts ul.facts > li:nth-child(odd):focus + li::after,
section.facts ul.facts > li:nth-child(odd):focus-visible + li::after,
section.facts ul.facts > li:nth-child(even):hover::after,
section.facts ul.facts > li:nth-child(even):focus::after,
section.facts ul.facts > li:nth-child(even):focus-visible::after {
	opacity: 0;
	animation: none;
}

/* Optional: a subtle focus ring for keyboard/tap */
section.facts ul.facts > li:nth-child(odd):focus-visible {
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.35);
	border-radius: 6px;
}

/*When width less than 800px, make single column*/
@media (max-width: 800px)
{
	section.facts ul.facts
	{
		grid-template-columns: 1fr;
	}
	section ul.facts li
	{
		text-align: center !important;
	}

	section.song .split
	{
		display: flex;
		flex-direction: column;
	}
}

.container
{
	position: relative;
	display: flex;
	flex-direction: column;
	/* border: 1px solid green; */

	gap: 1.5rem;
	align-items: center;
	justify-content: flex-start;
	/* margin-bottom: 4rem; */
	/* flex-wrap: wrap; */
	flex-grow: 0;
	padding-top: 2rem;
	padding-bottom: 2rem;
}

.container .schpeel
{
	max-width: 840px;
	text-align: justify;
	line-height: 1.4;
	/* color: #edbd87; */
	color: #fff;
	text-shadow: 0px 2px 4px #00000044;
	/* text-shadow: 0px 0px 2px #0c0b0b; */
}

footer
{
	/* border: 1px solid yellow; */
	width: 100vw;
	background-color: rgba(12, 11, 11,0.66);
	display: flex;
	justify-content: center;
	gap: 1.5rem;
	padding-top: 0.66rem;
	/* height: 3rem; */
	position: fixed;
	bottom: 0rem;
	z-index: 2;

	flex-wrap: wrap;
	height: auto;
	padding: 0.75rem 0.4rem;
	min-width: 250px;
}

.socials a
{
	color: #fff;
	text-decoration: none;
	font-size: 18pt;
	transition: color 0.2s;
}


.socials i
{
	/* box-shadow: #af1e23 0px 0px 3px 3px; */
}

.socials a:hover
{
	color: #edbd87;
	transform: scale(1.1) translateY(-2px);
	transition: transform 0.2s ease-in-out, color 0.2s;
}

.releases
{
	/* border: 1px solid blue; */
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 1rem;
	align-items:center;
	justify-content: space-between;
	margin-top: 1rem;
	max-width: 800px;
	min-width: 350px;
	width: 800px;
}

section.music .releases
{
	flex-wrap: nowrap;
	overflow-x: hidden;
	min-width: 95vw;
	padding-left: 30vw;
	padding-right: 30vw;
	padding-bottom: 2rem;
	padding-top: 1rem;
	gap: 3rem;
}

.releases a
{
	margin-top: 0.4em;
	position: relative;
}

.latest a
{
	position: relative;
}

.releases a i
{
	color: #fff;
	position: absolute;
	z-index: 2;
	top: -0.4em;
	right: -0.4em;
	filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.5));
	/* border: 1px solid blue; */
}

.latest a i
{
	color: #fff;
	position: absolute;
	font-size: 0.8em;
	z-index: 2;
	top: -0.3em;
	right: 0.3em;
	filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.5));
	/* border: 1px solid blue; */
}

.cover
{
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.75);
	max-width: 160px;
	opacity: 0;
}
body:not(.loading) .cover
{
	animation: popIn 0.5s ease-out forwards;
}
.releases a
{
	transition: transform 0.2s ease-in-out;
}
.releases a:hover
{
	transform: translateY(-5px) scale(1.05);
	transition: transform 0.2s ease-in-out;
}

section.music .cover
{
	max-width: 230px;
}

.releases a:nth-child(1) .cover { animation-delay: 0.1s; }
.releases a:nth-child(2) .cover { animation-delay: 0.2s; }
.releases a:nth-child(3) .cover { animation-delay: 0.3s; }
.releases a:nth-child(4) .cover { animation-delay: 0.4s; }
.releases a:nth-child(5) .cover { animation-delay: 0.5s; }
.releases a:nth-child(6) .cover { animation-delay: 0.6s; }
.releases a:nth-child(7) .cover { animation-delay: 0.7s; }
.releases a:nth-child(8) .cover { animation-delay: 0.8s; }

/* repeat every 8 */
.releases a:nth-child(8n+1) .cover { transform: rotate(-2deg)		;}
.releases a:nth-child(8n+2) .cover { transform: rotate(3deg)		;}
.releases a:nth-child(8n+3) .cover { transform: rotate(-1.5deg)	;}
.releases a:nth-child(8n+4) .cover { transform: rotate(2.5deg)		;}
.releases a:nth-child(8n+5) .cover { transform: rotate(-3deg)		;}
.releases a:nth-child(8n+6) .cover { transform: rotate(1.5deg)		;}
.releases a:nth-child(8n+7) .cover { transform: rotate(-2.5deg)	;}
.releases a:nth-child(8n+8) .cover { transform: rotate(2deg)		;}

.logo
{
	/* border: 1px solid blue; */
	max-width: 100vw;
	min-width: 350px;
}

.fa-tidal
{
	background-image: url('tidal.svg');
	background-size: cover;
	background-position: center;
	display: inline-block;
	width: 1em;
	height: 1em;
}

.gloom
{
	position: fixed;
	top: 0;
	left: 0;
	width: 40%;
	height: 100vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	overflow: hidden;
	pointer-events: none;
}

.gloom .body
{
	background-image: url('res/Gloom2.png');
	width: 818px;
	height: 1111px;
	left: -380px;
	position: absolute;
	top: 0;
	transition: left 0.2s ease-in-out;
	animation: slideInLeft 0.8s ease-out, opacity 0.2s ease-in-out;
}

body.left .gloom .body
{
	left: -200px;
	transition: left 0.2s ease-in-out, opacity 0.2s ease-in-out;
	/* opacity: 0.66; */
}

.gloom .hand
{
	background-image: url('res/GloomHand.png');
	width: 53px;
	height: 136px;
	left: -10px;
	top: 30px;
	position: absolute;
	z-index: 1;
	transition: left 0.2s ease-in-out;
}

.doom
{
	position: fixed;
	top: 0;
	right: 0;
	width: 40%;
	height: 100vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	overflow: hidden;
	pointer-events: none;
}

.doom .body
{
	background-image: url('res/Doom.png');
	width: 753px;
	height: 1021px;
	right: -360px;
	position: absolute;
	top: 0;
	transition: right 0.2s ease-in-out;
	animation: slideInRight 0.8s ease-in-out, opacity 0.2s ease-in-out;
}

body.right .doom .body
{
	right: -140px;
	transition: right 0.2s ease-in-out, opacity 0.2s ease-in-out;
	/* opacity: 0.66; */
}

.doom .hand
{
	background-image: url('res/DoomHand.png');
	width: 61px;
	height: 147px;
	right: -15px;
	top: 30px;
	position: absolute;
	z-index: 1;
	transition: right 0.2s ease-in-out;
}

/*character should not appear < 800px width*/
/*animate it*/
.character
{
	opacity: 100%;
	transition: opacity 0.5s ease-in-out;
	z-index: 2;
}

.character.hidden
{
	opacity: 0%;
	transition: opacity 0.5s ease-in-out;
}

@media (max-width: 1600px)
{
	.doom .body	 {right: -450px;}
	.gloom .body {left: -500px;}

	body.right .doom .body {right: -300px;}
	body.left .gloom .body {left: -350px;}

	/* .character .hand {opacity: 0; transition: opacity 0.5s ease-in-out;} */
	.doom .hand {right: -60px; transition: right 0.2s ease-in-out;}
	.gloom .hand {left: -60px; transition: left 0.2s ease-in-out;}
}

@media (max-width: 1400px)
{
	.character {opacity:  0.66; transition: opacity 0.5s ease-in-out;}
}

@media (max-width: 1250px)
{
	.character
	{
		opacity: 0%;
		transition: opacity 0.5s ease-in-out;
	}
}

@media (max-width: 760px)
{
	article h1
	{
		padding-left: 1em;
		padding-right: 1em;
		font-size: 2.6em;
	}
}

@media (min-width: 761px)
{
	section.song-about .divider.small
	{
		display: none;
	}
}

@media (max-width: 760px)
{
	section.about > ul
	{
		flex-direction: column;
		min-width: unset;
	}

	section.about > ul > li:nth-child(1)
	{
		margin-bottom: 2rem;
	}

	section.about > ul > li ul
	{
		font-size: unset;
	}

	section:nth-of-type(1)
	{
		min-height: 90vh;
	}

	section.latest p:nth-of-type(1)
	{
		flex-direction: column;
		text-align: center;
	}

	section.latest p img
	{
		margin-bottom: 1rem;
		margin-right: 0;
		max-width: unset;
		width: 90vw;
	}

	section.latest p:nth-of-type(2)
	{
		display: flex;
		flex-direction: column;
	}

	section.song-about
	{
		flex-direction: column-reverse;
	}
	section.song-about>div:first-child
	{
		width: 100%;
		font-size: unset;
	}
	section.song-about>div:first-child ul
	{
		list-style-type: none;
		padding: 0;
		color: #141212;
	}
	section.song-about>div p.lyrics
	{
		font-size: unset;
		/* margin-left: 1.5em; */
	}
	section.song-about img:not(:first-child):not(.divider)
	{
		display: none;
	}
	section.song-about iframe
	{
		display: none;
	}
	section.song-about
	{
		/* border: 1px solid blue; */
		flex-direction: column;
	}
}


@media (max-width: 850px)
{
	.releases, .logo
	{
		max-width: 75vw;
	}
}

@media (max-width: 520px)
{
	footer
	{
		gap: 0.5rem;
		justify-content: space-between;
	}
}



/* Loading state styles */
body.loading
{
	pointer-events: none;
}

body.loading::before
{
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: 999;
}

.spinner
{
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1000;
	display: none;
}

body.loading .spinner
{
	display: block;
}

.spinner::after
{
	content: '';
	display: block;
	width: 50px;
	height: 50px;
	border: 8px solid rgba(232, 180, 130, 0.3);
	border-top-color: #e8b482;
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

@keyframes spin
{
	to {
	transform: rotate(360deg);
	}
}
@keyframes slideInLeft {
	from {
		left: -550px;
	}
}

@keyframes slideInRight {
	from {
		right: -530px;
	}
}

@keyframes popIn {
	from {
		opacity: 0;
		transform: scale(0.6);
	}
	to {
		opacity: 1;
		/* transform: scale(1); */
	}
}
article
{
	opacity: 1;
	transition: opacity 0.8s ease-in;
}

body.loading article
{
	opacity: 0;
	pointer-events: none;
}

::-webkit-scrollbar
{
	width: 8px;
	transition: width 0.5s ease-in-out;
}
::-webkit-scrollbar:hover
{
	width: 16px;
	transition: width 0.5s ease-in-out;
}

::-webkit-scrollbar-track
{
	background: rgba(0, 0, 0, 0.2);
	/* border-radius: 5px; */
	box-shadow: 4px 0 0 0 rgba(0, 0, 0, 0.25);
}

::-webkit-scrollbar-thumb {
	background: #D11F28;
	border-radius: 5px;
	margin-top: 4px;
	margin-bottom: 4px;
}

::-webkit-scrollbar-thumb:hover {
	background: #E13139;
}


.subscribe
{
	background-color: #0c0b0b;
	padding: 1rem;
	/* border: 1px solid #fff; */
	border-radius: 10px;
	display: flex;
	gap: 0.5rem;
	margin-bottom: 0.25em;
}

.break
{
	top: 0px;
}
.break, .break2
{
	position: absolute;
	width: 100%;
	height: 10px;
	background-image: url('res/Break.png');
	background-size: 100% 100%;
	background-repeat:no-repeat;
}

.break2
{
	bottom: 0px;
	transform: rotate(180deg);
}

.scroll-indicator
{
	position: absolute;
	bottom: 4rem;
	left: 50%;
	transform: translateX(-50%);
	font-size: 2em;
	color: #edbd87;
	animation: bounce 2s infinite;
	cursor: pointer;
}

body.scrolled .scroll-indicator
{
	display: none;
}

@keyframes bounce
{
	0%, 100%
	{
		transform: translateX(-50%) translateY(0);
	}
	50%
	{
		transform: translateX(-50%) translateY(15px);
	}
}

/* Popup Image Overlay */
.popup-overlay
{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 9999;
	transition: background-color 0.3s ease;
	backdrop-filter: blur(0px);
}

.popup-overlay.active
{
	background-color: rgba(0, 0, 0, 0.85);
	backdrop-filter: blur(5px);
}

.popup-container
{
	position: relative;
	max-width: 90vw;
	max-height: 90vh;
	opacity: 0;
	transform: scale(0.8);
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.popup-overlay.active .popup-container
{
	opacity: 1;
	transform: scale(1);
}

.popup-image
{
	max-width: 100%;
	max-height: 90vh;
	object-fit: contain;
	display: block;
	border-radius: 8px;
	/* box-shadow: 0 10px 50px rgba(0, 0, 0, 0.5); */
}

.popup-close
{
	position: absolute;
	top: -15px;
	right: -30px;
	background-color: #af1e23;
	color: #fff;
	border: 2px solid #edbd87;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s ease;
	padding: 0;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
}

.popup-close:hover
{
	background-color: #edbd87;
	color: #413c3c;
	transform: rotate(90deg);
	box-shadow: 0 6px 10px rgba(237, 189, 135, 0.4);
}

/* Make secret clickable letters subtle but discoverable */
[data-popup-image]
{
	transition: color 0.2s ease, text-shadow 0.2s ease, transform 1.5s ease;
}

[data-popup-image]:hover
{
	/* color: #edbd87; */
	display: inline-block;
	text-shadow: 0 0 10px rgba(237, 189, 135, 0.75);
	transform: rotate(359deg);
	transition: color 0.2s ease, text-shadow 0.2s ease, transform 1.5s ease;
}
[data-popup-image].found
{
	/* color: #edbd87; */
	text-shadow: 0 0 8px rgba(255, 255, 255, 0.5);
	cursor: pointer;
	transition: text-shadow 5s ease;
}

/* Popup Grid for Map View */
.popup-grid
{
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
	justify-items: center;
	gap: 1rem;
	max-width: 1500px;
	max-height: 90vh;
	overflow-y: auto;
	overflow-x: hidden;
	padding: 1rem;
}

.popup-thumb
{
	width: 200px;
	position: relative;
	cursor: pointer;
	transition: transform 0.2s ease;
	/* border: 2px solid #edbd87; */
	/* border-radius: 8px; */
	/* overflow: hidden; */
	/* background: #0c0b0b; */
}

.popup-thumb:hover
{
	transform: scale(1.05);
	/* box-shadow: 0 0 15px rgba(237, 189, 135, 0.6); */
}

.popup-thumb img
{
	width: 100%;
	height: auto;
	display: block;
	/* aspect-ratio: 1; */
	object-fit: cover;
}

.popup-thumb-label
{
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: rgba(175, 30, 35, 0.9);
	color: #edbd87;
	text-align: center;
	padding: 0.5rem;
	font-size: 1rem;
	font-weight: bold;
}

.gloomnomicon
{
	position: relative;
}
.gloomnomicon img
{
	height: 20px;
}
.gloomnomicon:not(.found)
{
	display: none;
}
@keyframes appear
{
	from {
		opacity: 0;
		height: 0px;
	}
	to {
		opacity: 1;
		height: 20px;
	}
}
.gloomnomicon.found img
{
	animation: appear 0.5s ease-out forwards;
}
.gloomnomicon.notallfound img
{
	animation: twinkle 1.5s infinite;
}
@keyframes twinkle
{
	0%, 100%
	{
		/* opacity: 1; */
		transform: scale(1);
		/* filter: drop-shadow(-1px -1px 0 #af1e23) drop-shadow(1px -1px 0 #af1e23) drop-shadow(-1px 1px 0 #af1e23) drop-shadow(1px 1px 0 #af1e23); */
	}
	50%
	{
		/* opacity: 0.5; */
		transform: scale(1.2);
		filter: drop-shadow(0px 0px 4px #af1e23) drop-shadow(0px 0px 4px #af1e23);
	}
}

/* Share Buttons */
.popup-share
{
	position: absolute;
	top: 40px;
	right: -30px;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	z-index: 1001;
}

.share-btn
{
	width: 42px;
	height: 42px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border-radius: 50%;
	transition: all 0.2s ease;
	background-color: rgba(12, 11, 11, 0.8);
	color: #fff;
	border: 2px solid rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(4px);
}

.share-btn span
{
	display: none;
}

.share-btn i
{
	font-size: 1.1rem;
}

.share-btn:hover
{
	transform: scale(1.1);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
	border-color: currentColor;
}

.share-btn-twitter:hover
{
	background-color: #af1e23;
	color: #fff;
}

.share-btn-bluesky:hover
{
	background-color: #af1e23;
	color: #fff;
}

.share-btn-facebook:hover
{
	background-color: #af1e23;
	color: #fff;
}

.share-btn-threads:hover
{
	background-color: #af1e23;
	color: #fff;
}

/* Mobile responsive */
@media (max-width: 600px)
{
	.popup-close
	{
		right: 10px;
		top: -2.65rem;
	}
	.popup-share
	{
		top: -2.5rem;
		left: 0px;
		flex-direction: row;
	}

	.share-btn
	{
		width: 36px;
		height: 36px;
	}

	.share-btn i
	{
		font-size: 0.9rem;
	}
}

/* Share notification when unlocking via URL */
.share-notification
{
	position: fixed;
	top: 2rem;
	left: 50%;
	transform: translateX(-50%);
	background: #0c0b0b;
	color: #edbd87;
	padding: 1rem 2rem;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
	z-index: 10001;
	font-size: 1.2rem;
	animation: slideDown 0.3s ease-out;
}

.share-notification.fade-out
{
	opacity: 0;
	transform: translateX(-50%) translateY(-20px);
	transition: all 0.5s ease;
}

@keyframes slideDown
{
	from {
		opacity: 0;
		transform: translateX(-50%) translateY(-30px);
	}
	to {
		opacity: 1;
		transform: translateX(-50%) translateY(0);
	}
}

/* Copy notification for clipboard fallback */
.copy-notification
{
	position: absolute;
	bottom: 5rem;
	left: 50%;
	transform: translateX(-50%);
	background: rgba(237, 189, 135, 0.95);
	color: #0c0b0b;
	padding: 0.75rem 1.5rem;
	border-radius: 6px;
	z-index: 10002;
	font-size: 0.9rem;
	animation: fadeIn 0.3s ease;
}

.copy-notification.error
{
	background: rgba(209, 31, 40, 0.95);
	color: #fff;
}

.copy-notification.fade-out
{
	opacity: 0;
	transition: opacity 0.5s ease;
}

@keyframes fadeIn
{
	from { opacity: 0; }
	to { opacity: 1; }
}

.scrollable.tabs
{
	white-space: pre;
	font-family: monospace, 'Courier New';
	overflow-x: hidden;
	max-width: 95vw;
	padding-left: 30vw;
	padding-right: 30vw;
	margin-bottom: 3rem;
}
section.tabs a
{
	color: #fff;
	text-decoration: none;
}
section.tabs a:hover
{
	color: rgba(237, 189, 135, 0.95);
	transform: scale(1.05);
	transition: color 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.interview
{
	display: flex;
	flex-direction: column;
	/* gap: 2rem; */
	max-width: 800px;
	padding: 0;
	list-style-type: none;
}
.interview li
{
	gap: 0.5rem;
	padding: 1rem;
	border-radius: 8px;
	text-align: left;
}
.interview li:nth-child(even)
{
	display: flex;
	flex-direction: column;
}
.interview li .blake, .interview li .gloomterview
{
	text-align: right;
}
.interview li .blake
{
	position: relative;
	color: #D11F28;
}
.interview li .gloomterview
{
	position: relative;
	color: #edbd87;
}
.interview li .blake::after
{
	content: "(Blake)";
	position: absolute;
	opacity: 0.4;
	margin-left: 1.6rem;
	left: 100%;
}
.interview li .gloomterview::after
{
	content: "(Gloom)";
	position: absolute;
	opacity: 0.4;
	margin-left: 1rem;
	left: 100%;
}
@media (max-width: 1000px)
{
	.interview li .blake::after,
	.interview li .gloomterview::after
	{
		display: none;
	}

	.interview li .blake::before
	{
		content: "Blake: ";
		/* font-weight: bold; */
		opacity: 0.4;
	}
	.interview li .gloomterview::before
	{
		content: "Gloom: ";
		/* font-weight: bold; */
		opacity: 0.33;
	}
}

section .divider
{
	max-width: 800px;
}

/* Sparkle/wiggle animation */
span.hint
{
	display: inline-block;
	animation: sparkle 0.4s ease-in-out 3;
}

span.censor
{
	position: relative;
}
span.censor::before
{
	content: ''; position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url('res/Divider.svg');
	background-size: 2000%;
	background-position: center;
	animation: sparkle 0.4s ease-in-out 3;
	pointer-events: none;
	transition: opacity 0.5s ease-in-out, transform 0.2s ease-in-out;
}
span.censor:hover::before
{
	transform: translateY(-15px) rotate(5deg);
	transition: opacity 0.5s ease-in-out, transform 0.2s ease-in-out;
}
span.censor:nth-of-type(3n + 2)::before { transform: rotate(5deg);}
span.censor:nth-of-type(3n + 3)::before { transform: rotate(-6deg);}
span.censor:nth-of-type(3n + 2):hover::before { transform: translateY(15px) rotate(-3deg);}
span.censor:nth-of-type(3n + 3):hover::before { transform: translateY(-15px) rotate(-6deg);}

/* Make it sparkle AND giggle left/right */
@keyframes sparkle
{
	0% 		{ transform: translateX(0) rotate(0); }
	12.5% 	{ transform: translateY(-0.5px) rotate(-7deg); }
	25% 	{ transform: translateX(0) rotate(0); }
	37.5% 	{ transform: translateY(0.5px) rotate( 7deg); }
	50% 	{ transform: translateX(0) rotate(0); }
	62.5% 	{ transform: translateY(-0.2px) rotate(-3deg); }
	75% 	{ transform: translateX(0) rotate(0); }
	87.5% 	{ transform: translateY(0.2px) rotate( 37deg); }
	100% 	{ transform: translateX(0) rotate(0); }
}