/* 
   FireFly Team Cognitive Distortion Matrix
   Core Design System and Stylesheet - Retro CRT Edition
*/

:root {
	--color-bg: #030303;
	--color-text: #f3f3f7;
	--color-text-dim: #9ca3af;
	--color-primary: #d946ef; /* Bright Psychedelic Pink-Purple */
	--color-accent: #22d3ee; /* Electric Cyan */
	--color-neon-green: #4ade80; /* Toxic Lime */
	--color-neon-purple: #a855f7; /* LSD Purple */
	
	/* Glassmorphism Styles */
	--glass-bg: rgba(8, 8, 12, 0.5);
	--glass-border: rgba(255, 255, 255, 0.07);
	--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.6);
	
	/* Fonts */
	--font-heading: 'Syne', sans-serif;
	--font-body: 'Outfit', sans-serif;
	--font-mono: 'Space Grotesk', monospace;
}

/* Base Resets & Structure */
* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	user-select: none;
}

body {
	background-color: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body);
	overflow: hidden;
	height: 100vh;
	width: 100vw;
	position: relative;
}

/* -------------------------------------------------------------
   CRT TV Screen Power Overlay
   ------------------------------------------------------------- */
#tv-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: #000;
	z-index: 99999; /* Higher than everything else */
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	overflow: hidden;
	transition: visibility 0.8s, opacity 0.8s;
}

.tv-prompt-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.2rem;
	text-align: center;
	z-index: 2;
	transition: opacity 0.25s ease;
}

.tv-dot {
	width: 10px;
	height: 10px;
	background-color: #fff;
	border-radius: 50%;
	box-shadow: 0 0 15px #fff, 0 0 30px var(--color-accent);
	animation: tv-dot-glow 1.2s infinite alternate ease-in-out;
}

.tv-prompt {
	font-family: var(--font-mono);
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.15em;
	color: #fff;
	text-shadow: 0 0 10px rgba(255, 255, 255, 0.4), 0 0 25px var(--color-accent);
	animation: tv-text-pulse 2.2s infinite alternate ease-in-out;
}

.tv-subprompt {
	font-family: var(--font-mono);
	font-size: 0.65rem;
	letter-spacing: 0.22em;
	color: var(--color-text-dim);
	text-transform: uppercase;
	opacity: 0.8;
}

#crt-line {
	position: absolute;
	top: 50%;
	left: 5%;
	width: 90%;
	height: 3px;
	background-color: #fff;
	box-shadow: 0 0 15px #fff, 0 0 40px var(--color-accent);
	transform: scaleX(0) scaleY(1);
	transform-origin: center;
	opacity: 0;
	z-index: 3;
	pointer-events: none;
}

/* Touch Me text breathing pulse animation */
@keyframes tv-text-pulse {
	0% {
		opacity: 0.35;
		transform: scale(0.97);
		text-shadow: 0 0 8px rgba(255, 255, 255, 0.3), 0 0 15px var(--color-primary);
	}
	100% {
		opacity: 0.9;
		transform: scale(1.03);
		text-shadow: 0 0 15px rgba(255, 255, 255, 0.7), 0 0 35px var(--color-accent);
	}
}

/* CRT Screen Turn-On Sequence Animation triggers */
.tv-turning-on .tv-prompt-wrapper {
	opacity: 0;
	pointer-events: none;
}

.tv-turning-on #crt-line {
	animation: crt-line-flash 0.75s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

.tv-turning-on #tv-overlay {
	animation: crt-bg-reveal 0.75s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

@keyframes crt-line-flash {
	0% {
		transform: scaleX(0) scaleY(1);
		opacity: 0;
	}
	10% {
		transform: scaleX(0.01) scaleY(1);
		opacity: 1;
	}
	35% {
		transform: scaleX(1.05) scaleY(1);
		opacity: 1;
	}
	55% {
		transform: scaleX(1.0) scaleY(400); /* vertical sweep expansion */
		opacity: 1;
		background-color: #fff;
	}
	100% {
		transform: scaleX(1.0) scaleY(600);
		opacity: 0;
		background-color: transparent;
	}
}

@keyframes crt-bg-reveal {
	0%, 45% {
		background-color: #000;
	}
	55% {
		background-color: #fff; /* power flash */
	}
	100% {
		background-color: transparent;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}
}

/* Screen zoom squeeze-twitch glitch during startup */
.tv-power-twitch {
	animation: tv-power-shake 0.65s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes tv-power-shake {
	0% {
		transform: scaleY(0.01) scaleX(1.08) skewX(12deg);
		filter: brightness(3.5) contrast(2.5);
	}
	40% {
		transform: scaleY(0.08) scaleX(1.03) skewX(-8deg);
		filter: brightness(2) contrast(1.5);
	}
	55% {
		transform: scaleY(0.72) scaleX(0.98) skewX(4deg);
		filter: brightness(1.5) contrast(1.2);
	}
	70% {
		transform: scaleY(1.02) scaleX(1.01) skewX(-1deg);
		filter: brightness(1.1);
	}
	100% {
		transform: scale(1) skewX(0);
		filter: brightness(1);
	}
}

/* Background canvas spanning full screen */
#gl-canvas {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	display: block;
}

/* Trippy Chromatic CRT scanlines overlay */
.scanlines {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		rgba(18, 16, 16, 0) 50%, 
		rgba(0, 0, 0, 0.25) 50%
	);
	background-size: 100% 4px;
	z-index: 3;
	pointer-events: none;
}

.chromatic-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(
		circle at center,
		rgba(217, 70, 239, 0.03) 0%,
		rgba(34, 211, 238, 0.03) 50%,
		rgba(0, 0, 0, 0.5) 100%
	);
	z-index: 2;
	pointer-events: none;
}

/* App Container Layout */
.app-container {
	position: relative;
	z-index: 4;
	width: 100vw;
	height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	pointer-events: none; /* Make overlay pass clicks down */
	padding: 2rem;
}



/* Main Hero section (The Title Emblem) */
.hero-section {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.hero-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	pointer-events: auto;
}


/* Melting and morphing FireFly Team Typography */
.brand-title {
	font-family: var(--font-heading);
	font-size: 6rem;
	font-weight: 800;
	line-height: 0.95;
	text-transform: uppercase;
	margin-bottom: 2rem;
	cursor: pointer;
	position: relative;
}

.brand-title .text-layer {
	color: #fff;
	position: relative;
	text-shadow: 
		0 0 10px rgba(255, 255, 255, 0.8),
		-2px -2px 0 var(--color-primary),
		2px 2px 0 var(--color-accent);
	animation: chromatic-wobble 3s infinite ease-in-out;
}

.brand-title:hover .text-layer {
	animation: text-dissolve 0.5s infinite linear;
}

@keyframes chromatic-wobble {
	0%, 100% {
		text-shadow: 
			0 0 10px rgba(255, 255, 255, 0.8),
			-2px -2px 0 var(--color-primary),
			2px 2px 0 var(--color-accent);
	}
	33% {
		text-shadow: 
			0 0 15px rgba(255, 255, 255, 0.9),
			-4px 2px 0 var(--color-neon-green),
			3px -3px 0 var(--color-neon-purple);
	}
	66% {
		text-shadow: 
			0 0 12px rgba(255, 255, 255, 0.85),
			3px 3px 0 var(--color-accent),
			-3px -1px 0 var(--color-primary);
	}
}

@keyframes text-dissolve {
	0% {
		transform: translate(0px, 0px) skewX(0deg);
		filter: hue-rotate(0deg);
	}
	10% {
		transform: translate(-2px, 1px) skewX(-3deg);
	}
	20% {
		transform: translate(1px, -2px) skewX(5deg);
	}
	30% {
		transform: translate(-1px, 2px) skewX(-7deg);
		filter: hue-rotate(90deg);
	}
	40% {
		transform: translate(2px, -1px) skewX(2deg);
	}
	50% {
		transform: translate(-2px, -2px) skewX(0deg);
		filter: hue-rotate(180deg);
	}
	60% {
		transform: translate(1px, 2px) skewX(-4deg);
	}
	70% {
		transform: translate(-1px, -1px) skewX(6deg);
		filter: hue-rotate(270deg);
	}
	80% {
		transform: translate(2px, 1px) skewX(-2deg);
	}
	90% {
		transform: translate(-2px, -1px) skewX(3deg);
	}
	100% {
		transform: translate(0px, 0px) skewX(0deg);
		filter: hue-rotate(360deg);
	}
}

.brand-actions {
	display: flex;
	gap: 1.5rem;
	width: 100%;
	justify-content: center;
	margin-bottom: 2rem;
}

/* Highly interactive glassmorphic HTML/CSS capsule button */
.btn-github {
	position: relative;
	background: rgba(12, 12, 18, 0.45);
	border: 1px solid rgba(255, 255, 255, 0.08);
	color: var(--color-text);
	padding: 0.8rem 2rem;
	font-family: var(--font-mono);
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.12em;
	border-radius: 30px;
	cursor: pointer;
	backdrop-filter: blur(16px) saturate(140%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.65rem;
	transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
	box-shadow: var(--glass-shadow);
	text-decoration: none;
	overflow: hidden;
	pointer-events: auto;
}

.btn-github:hover {
	border-color: rgba(34, 211, 238, 0.35);
	color: #fff;
	transform: translateY(-2px) scale(1.02);
	box-shadow: 
		0 12px 36px rgba(0, 0, 0, 0.7),
		0 0 15px rgba(34, 211, 238, 0.15),
		0 0 25px rgba(219, 70, 239, 0.05);
}

.btn-github:active {
	transform: translateY(0) scale(0.98);
}

.icon-github {
	transition: transform 0.3s ease, color 0.3s;
}

.btn-github:hover .icon-github {
	transform: rotate(12deg) scale(1.1);
	color: var(--color-accent);
}

.btn-text {
	text-transform: lowercase;
}



/* Mute Button Styles */
.top-bar-controls {
	position: absolute;
	top: 2rem;
	right: 2rem;
	z-index: 10;
	pointer-events: auto;
}

.btn-mute {
	background: rgba(12, 12, 18, 0.45);
	border: 1px solid rgba(255, 255, 255, 0.08);
	color: var(--color-text-dim);
	padding: 0.6rem 1.2rem;
	font-family: var(--font-mono);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	border-radius: 20px;
	cursor: pointer;
	backdrop-filter: blur(12px) saturate(140%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
	box-shadow: var(--glass-shadow);
	text-transform: lowercase;
}

.btn-mute:hover {
	border-color: rgba(217, 70, 239, 0.35);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 
		0 6px 20px rgba(0, 0, 0, 0.5),
		0 0 10px rgba(217, 70, 239, 0.15);
}

.btn-mute:active {
	transform: translateY(0);
}

.btn-mute.muted {
	border-color: rgba(239, 68, 68, 0.3);
	color: rgba(239, 68, 68, 0.85);
}

.btn-mute.muted:hover {
	border-color: rgba(239, 68, 68, 0.50);
	color: #ef4444;
	box-shadow: 
		0 6px 20px rgba(0, 0, 0, 0.5),
		0 0 10px rgba(239, 68, 68, 0.15);
}

.btn-mute svg {
	transition: transform 0.2s ease;
}

.btn-mute:hover svg {
	transform: scale(1.1);
}

/* Ticker Marquee Styles */
.ticker-wrap {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	overflow: hidden;
	height: 3rem;
	background: rgba(3, 3, 3, 0.45);
	backdrop-filter: blur(8px) saturate(130%);
	border-top: 1px solid rgba(255, 255, 255, 0.05);
	display: flex;
	align-items: center;
	z-index: 10;
	pointer-events: auto;
}

.ticker {
	display: inline-flex;
	white-space: nowrap;
	animation: ticker-scroll 32s linear infinite;
}

.ticker span {
	font-family: var(--font-mono);
	font-size: 0.72rem;
	color: var(--color-text-dim);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	opacity: 0.45;
	display: inline-block;
	padding-right: 0.5rem;
}

@keyframes ticker-scroll {
	0% {
		transform: translate3d(0, 0, 0);
	}
	100% {
		transform: translate3d(-50%, 0, 0);
	}
}

/* Responsive adjustments */
@media (max-width: 768px) {
	.app-container {
		padding: 1rem;
	}
	.brand-title {
		font-size: 4rem;
	}
}

@media (max-width: 480px) {
	.brand-title {
		font-size: 3rem;
	}
	.btn-github {
		width: 100%;
		padding: 0.8rem 1.5rem;
	}
}
