/* The Fish Tank Custom Styles - Blacklight Fish Tank Theme */
:root {
	/* Blacklight Neon Palette - 4 Core Colors */
	--neon-cyan: #00f0ff;        /* Electric cyan - primary glow */
	--neon-magenta: #ff33ff;     /* Bright magenta - secondary pop (softened) */
	--neon-purple: #b845ed;      /* Vibrant purple - accent highlights */
	--deep-ocean: #0a1628;       /* Dark blue-black - main dark */

	/* Supporting Colors */
	--muted-teal: #1a4d5c;       /* Muted blue-green - tank water */
	--glow-green: #39ff14;       /* Neon green - occasional accent */

	/* Neutral Colors */
	--color-white: #ffffff;
	--color-black: #000000;
	--color-text: #1a1a2e;
	--color-text-light: rgba(255, 255, 255, 0.85);
	--color-bg-light: #f0f4f8;

	/* Transparent/Overlay Colors */
	--overlay-dark-light: rgba(10, 22, 40, 0.1);
	--overlay-dark-medium: rgba(10, 22, 40, 0.15);
	--overlay-dark-strong: rgba(10, 22, 40, 0.25);
	--overlay-dark-heavy: rgba(10, 22, 40, 0.4);
	--overlay-white-light: rgba(255, 255, 255, 0.15);
	--overlay-neon-glow: rgba(0, 240, 255, 0.3);

	/* Gradient Backgrounds - Blacklight Inspired */
	--gradient-hero: linear-gradient(135deg, var(--deep-ocean) 0%, var(--muted-teal) 100%);
	--gradient-footer: linear-gradient(135deg, var(--deep-ocean) 0%, #0d2b3d 100%);

	/* Neon Glow Effects */
	--glow-cyan: 0 0 20px var(--neon-cyan), 0 0 40px var(--overlay-neon-glow);
	--glow-magenta: 0 0 20px var(--neon-magenta), 0 0 30px rgba(255, 0, 255, 0.3);
	--glow-text: 0 0 10px var(--neon-cyan), 0 0 20px var(--overlay-neon-glow);

	/* Shadows */
	--shadow-small: 0 2px 10px var(--overlay-dark-light);
	--shadow-medium: 0 4px 16px var(--overlay-dark-light);
	--shadow-large: 0 8px 24px var(--overlay-dark-medium);
	--shadow-xlarge: 0 12px 32px var(--overlay-dark-strong);
	--shadow-button: 0 6px 20px var(--overlay-dark-strong);
	--shadow-graphic: 0 10px 30px var(--overlay-dark-heavy);

	/* Typography */
	--font-display: 'Rock Salt', cursive;
	--font-body: 'Raleway', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	/* Spacing */
	--spacing-section: 5rem;
	--spacing-section-mobile: 3rem;

	/* Border Radius */
	--radius-small: 8px;
	--radius-medium: 12px;
	--radius-large: 50px;

	/* Transitions */
	--transition-fast: 0.3s ease;
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	padding: 0;
	font-family: var(--font-body);
	color: var(--color-white);
	background-color: var(--deep-ocean);
	line-height: 1.6;
	overflow-x: hidden;
}

/* Global Heading Styles */
h2 {
	font-size: 1.5rem;
	color: var(--color-white);
	margin-bottom: 1rem;
	font-family: var(--font-display);
	text-shadow: none;
}

h3 {
	color: var(--color-white);
	font-size: 2rem;
	margin-bottom: 1.5rem;
	font-family: var(--font-display);
	font-weight: 600;
}

.highlight-text {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--neon-cyan);
	background: linear-gradient(90deg, var(--neon-magenta), var(--neon-cyan));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	margin-top: 1.5rem;
}

/* Hide anchor links */
.header-anchor,
a.header-anchor,
a[aria-hidden="true"] {
	display: none;
}

/* Hide Home nav link on home page */
.page-home .nav-left .menu-item:first-child {
	display: none;
}

main {
	padding: 0;
	margin: 0;
	max-width: 100%;
	overflow-x: hidden;
}

.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem;
	overflow-x: hidden;
}

#copyright {
	text-align: center;
}

.copyright {
	margin-top: 2rem;
	font-size: 0.9rem;
	opacity: 0.8;
	background: rgba(10, 22, 40, 0.7);
	padding: 1rem 2rem;
	border-radius: var(--radius-small);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(8px);
	display: inline-block;
}

/* Header with Centered Logo */
#top-menu {
	background: var(--deep-ocean);
	position: sticky;
	top: 0;
	z-index: 1000;
	padding: 1rem 0;
}

/* Solid gradient border line */
#top-menu::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg,
		transparent 0%,
		#ff33ff 15%,
		#b845ed 40%,
		#00f0ff 60%,
		#00f0ff 85%,
		transparent 100%
	);
	pointer-events: none;
}

/* Soft glow underneath */
#top-menu::after {
	content: '';
	position: absolute;
	bottom: -15px;
	left: 0;
	right: 0;
	height: 15px;
	background: linear-gradient(90deg,
		transparent 0%,
		rgba(255, 51, 255, 0.3) 15%,
		rgba(184, 69, 237, 0.3) 40%,
		rgba(0, 240, 255, 0.3) 60%,
		rgba(0, 240, 255, 0.3) 85%,
		transparent 100%
	);
	filter: blur(12px);
	pointer-events: none;
}

.main-nav {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem;
	gap: 2rem;
	overflow-x: hidden;
}

.nav-left,
.nav-right {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 2rem;
}

.nav-left {
	justify-content: flex-start;
}

.nav-right {
	justify-content: flex-end;
}

.logo-center {
	margin: 0;
	justify-self: center;
	max-width: 100%;
}

.logo-center a {
	text-decoration: none;
}

.logo-center img {
	max-width: 100%;
	height: auto;
}

#sitetitle {
	color: var(--neon-cyan);
	font-weight: 700;
	font-size: 1.8rem;
	margin: 0;
	letter-spacing: 1px;
	font-family: var(--font-display);
	text-shadow: 0 0 15px var(--neon-purple), 0 0 30px var(--neon-purple), 0 0 45px rgba(184, 69, 237, 0.4);
}

.menu-item {
	list-style: none;
}

.menu-item a {
	color: var(--color-white);
	text-decoration: none;
	font-weight: 600;
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	transition: color var(--transition-fast);
	padding: 0.5rem 0;
	position: relative;
}

.menu-item a:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--neon-cyan);
	transition: width var(--transition-fast);
}

.menu-item a:hover {
	color: var(--neon-cyan);
}

.menu-item a:hover:after {
	width: 100%;
}

/* Big Logo Hero Section */
.big-logo-hero {
	background: var(--gradient-hero);
	padding: 6rem 2rem;
	text-align: center;
	max-width: 100%;
	overflow-x: hidden;
}

.logo-wordmark h1 {
	font-size: 5rem;
	font-weight: 700;
	margin: 0 0 1rem;
	color: var(--color-white);
	font-family: var(--font-display);
	text-shadow: 3px 3px 6px var(--overlay-dark-strong);
	letter-spacing: 2px;
}

.tagline {
	font-size: 1.5rem;
	color: var(--color-white);
	margin: 0 0 2rem;
	font-weight: 300;
	text-shadow: 2px 2px 4px var(--overlay-dark-strong);
}

.hero-cta-buttons {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 2rem;
}

/* Buttons */
.button {
	background-color: var(--neon-magenta);
	color: var(--color-white);
	padding: 1rem 2.5rem;
	border-radius: var(--radius-large);
	text-decoration: none;
	font-weight: 700;
	font-size: 1.1rem;
	transition: all var(--transition-fast);
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: 1px;
	border: 3px solid var(--neon-magenta);
	box-shadow: var(--glow-magenta);
}

.button:hover {
	background-color: var(--neon-purple);
	border-color: var(--neon-purple);
	transform: translateY(-3px);
	box-shadow: 0 0 30px var(--neon-purple), var(--shadow-button);
}

.button-outline {
	background-color: transparent;
	border: 3px solid var(--neon-cyan);
	color: var(--neon-cyan);
	box-shadow: var(--glow-cyan);
}

.button-outline:hover {
	background-color: var(--neon-cyan);
	color: var(--deep-ocean);
	border-color: var(--neon-cyan);
}

.button-light {
	background-color: var(--neon-cyan);
	color: var(--deep-ocean);
	border-color: var(--neon-cyan);
	box-shadow: var(--glow-cyan);
}

.button-light:hover {
	background-color: var(--neon-magenta);
	border-color: var(--neon-magenta);
	color: var(--color-white);
	box-shadow: var(--glow-magenta);
}

/* Section Styles with Different Backgrounds */
section {
	padding: var(--spacing-section) 0;
}

.section-coral {
	background-color: var(--neon-magenta);
	color: var(--color-white);
}

.section-teal {
	background-color: var(--muted-teal);
	color: var(--color-white);
	text-align: center;
}

.section-light {
	background-color: var(--color-black);
	color: var(--color-white);
}

.section-yellow {
	background-color: var(--neon-purple);
	color: var(--color-white);
}

.section-dark {
	background-color: var(--deep-ocean);
	color: var(--color-white);
	text-align: center;
}

.section-title {
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
	font-family: var(--font-display);
	text-shadow: var(--glow-text);
}

.section-subtitle {
	font-size: 1.3rem;
	margin-bottom: 2rem;
	font-weight: 300;
}

.section-content-centered {
	max-width: 800px;
	margin: 0 auto;
	font-size: 1.2rem;
	line-height: 1.8;
}

/* Two Column Layouts */
.two-column {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: center;
}

.two-column.reverse {
	direction: rtl;
}

.two-column.reverse > * {
	direction: ltr;
}

.column-image img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-medium);
	box-shadow: var(--shadow-large);
}

.column-content p {
	font-size: 1.1rem;
	margin-bottom: 1rem;
	line-height: 1.8;
}

.column-content em {
	font-style: italic;
	font-weight: 600;
	font-size: 1.2rem;
}

/* Featured Grid */
.featured-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	margin: 3rem 0;
}

.featured-item {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-medium);
	box-shadow: var(--shadow-medium);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
	aspect-ratio: 1 / 1;
}

.featured-item:hover {
	transform: scale(1.05);
	box-shadow: 0 8px 32px var(--overlay-dark-strong);
}

.featured-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.view-more-center {
	text-align: center;
	margin-top: 2rem;
}

/* Footer with Overlapping Graphic */
#site-footer {
	position: relative;
	background: var(--gradient-footer);
	color: var(--color-white);
	padding: 0;
	margin-top: 0;
}

.footer-graphic-container {
	position: relative;
	width: 100%;
	aspect-ratio: 1000 / 608;
	z-index: 1;
	pointer-events: none;
	background-image: url('../images/tankbottom.png');
	background-size: contain;
	background-position: bottom center;
	background-repeat: no-repeat;
}

@media screen and (max-width: 768px) {
	.footer-graphic-container {
		background-size: cover;
		min-height: 500px;
	}
}

.footer-content {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 10;
}

.social-section {
	text-align: center;
	padding: 2rem 0;
}

.social-buttons {
	display: flex;
	gap: 1.5rem;
	justify-content: center;
	align-items: center;
}

.social-content-box {
	background: rgba(10, 22, 40, 0.5);
	padding: 2rem;
	border-radius: var(--radius-medium);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
	backdrop-filter: blur(8px);
	display: inline-block;
}

.social-buttons a {
	color: var(--color-white);
	transition: all var(--transition-fast);
	display: flex;
	align-items: center;
	justify-content: center;
}

.social-buttons a:hover {
	color: var(--neon-cyan);
	transform: translateY(-5px);
	filter: drop-shadow(var(--glow-cyan));
}

#copyright {
	color: var(--color-text-light);
	text-align: center;
	padding: 2rem 0 1rem;
	font-size: 0.95rem;
	margin-top: 2rem;
}

#copyright a {
	color: var(--neon-cyan);
	text-decoration: none;
	font-weight: 600;
}

#copyright a:hover {
	color: var(--neon-magenta);
	text-decoration: underline;
}

/* Portfolio Page Styles */
.articlebox {
	padding: 4rem 2rem;
	margin: 0 auto;
	max-width: 1200px;
}

.entry-header-single {
	text-align: center;
	margin-bottom: 3rem;
}

.entry-title {
	font-size: 3rem;
	color: var(--neon-cyan);
	font-family: var(--font-display);
	margin-bottom: 1rem;
	text-shadow: var(--glow-text);
}

.entry-content {
	font-size: 1.1rem;
	line-height: 1.8;
	color: var(--color-white);
}

.entry-content a:not(.button) {
	color: var(--neon-cyan);
	text-decoration: none;
	font-weight: 600;
	border-bottom: 2px solid transparent;
	transition: all var(--transition-fast);
}

.entry-content a:not(.button):hover {
	color: var(--neon-magenta);
	border-bottom-color: var(--neon-magenta);
}

/* Portfolio Sections */
.portfolio-intro-section,
.portfolio-latest-section,
.portfolio-gallery-section {
	margin-bottom: 4rem;
	padding-bottom: 3rem;
	border-bottom: 1px solid var(--muted-teal);
}

.portfolio-gallery-section {
	border-bottom: none;
}

.portfolio-intro-section p {
	font-size: 1.1rem;
	line-height: 1.8;
	margin-bottom: 1.5rem;
}

/* Latest Work Grid */
.latest-work-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	margin: 2rem 0;
}

.latest-item {
	display: block;
	overflow: hidden;
	border-radius: var(--radius-medium);
	border: 2px solid var(--muted-teal);
	transition: all var(--transition-fast);
	aspect-ratio: 1 / 1;
	position: relative;
}

.latest-item::after {
	content: attr(data-title);
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.75rem;
	background: rgba(0, 0, 0, 0.75);
	color: var(--color-white);
	font-size: 0.95rem;
	font-weight: 600;
	text-align: center;
	transform: translateY(100%);
	transition: transform var(--transition-fast);
	pointer-events: none;
	border-radius: 0 0 var(--radius-medium) var(--radius-medium);
}

.latest-item:hover::after {
	transform: translateY(0);
}

.latest-item:hover {
	border-color: var(--neon-cyan);
	box-shadow: 0 0 20px var(--neon-cyan);
	transform: scale(1.02);
	z-index: 10;
}

.latest-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Tight Gallery - No Labels */
.gallery-tight {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 0.5rem;
	margin: 2rem 0;
}

.gallery-tight a {
	display: block;
	overflow: hidden;
	transition: all var(--transition-fast);
	position: relative;
}

.gallery-tight a::after {
	content: attr(data-title);
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.75rem;
	background: rgba(0, 0, 0, 0.75);
	color: var(--color-white);
	font-size: 0.95rem;
	font-weight: 600;
	text-align: center;
	transform: translateY(100%);
	transition: transform var(--transition-fast);
	pointer-events: none;
}

.gallery-tight a:hover::after {
	transform: translateY(0);
}

.gallery-tight a:hover {
	z-index: 10;
	transform: scale(1.05);
}

.gallery-tight img {
	width: 100%;
	height: 250px;
	object-fit: cover;
	display: block;
	border: 2px solid transparent;
	transition: border-color var(--transition-fast);
}

.gallery-tight a:hover img {
	border-color: var(--neon-cyan);
}

/* Responsive Design */
@media screen and (max-width: 1024px) {
	.two-column {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.featured-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.logo-wordmark h1 {
		font-size: 3.5rem;
	}

	.latest-work-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.gallery-tight {
		grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	}
}

@media screen and (max-width: 768px) {
	.main-nav {
		flex-direction: column;
		gap: 1rem;
	}

	.nav-left,
	.nav-right {
		gap: 1rem;
	}

	.logo-center {
		margin: 0.5rem 0;
	}

	#sitetitle {
		text-align: center;
	}

	.logo-wordmark h1 {
		font-size: 2.5rem;
	}

	.tagline {
		font-size: 1.2rem;
	}

	.featured-grid {
		grid-template-columns: 1fr;
	}

	section {
		padding: var(--spacing-section-mobile) 0;
	}

	.section-title {
		font-size: 2rem;
	}

	.footer-graphic-container {
		aspect-ratio: 1000 / 608;
	}

	.latest-work-grid {
		grid-template-columns: 1fr;
	}

	.gallery-tight {
		grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	}
}

@media screen and (max-width: 480px) {
	.hero-cta-buttons {
		flex-direction: column;
		align-items: stretch;
	}

	.button {
		width: 100%;
		text-align: center;
	}

	.main-nav {
		padding: 0 1rem;
	}

	.container {
		padding: 0 1rem;
	}

	#sitetitle {
		font-size: 1.5rem;
	}

	.big-logo-hero {
		padding: 4rem 1rem;
	}

	.logo-center {
		max-width: 90%;
		margin: 0.5rem auto;
	}
}

@media screen and (max-width: 390px) {
	.main-nav {
		padding: 0 0.75rem;
	}

	.container {
		padding: 0 0.75rem;
	}

	#sitetitle {
		font-size: 1.3rem;
	}
}
