@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,600");
@import url("fontawesome-all.min.css");

.gallery-item.image-missing .gallery-image-container {
    position: relative;
}

.image-missing-badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    z-index: 5;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    background: rgba(251, 191, 36, 0.92);
    color: #1a202c;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}

.gallery-item.image-missing .gallery-image {
    opacity: 0.74;
    filter: grayscale(20%);
}

.gallery-item.image-missing .image-placeholder {
    border: 1px dashed rgba(113, 128, 150, 0.6);
    background: rgba(237, 242, 247, 0.85);
}

/*
	Parallelism by HTML5 UP
	html5up.net | @ajlkn
	Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
*/

html, body, div, span, applet, object,
iframe, h1, h2, h3, h4, h5, h6, p, blockquote,
pre, a, abbr, acronym, address, big, cite,
code, del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, b,
u, i, center, dl, dt, dd, ol, ul, li, fieldset,
form, label, legend, table, caption, tbody,
tfoot, thead, tr, th, td, article, aside,
canvas, details, embed, figure, figcaption,
footer, header, hgroup, menu, nav, output, ruby,
section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;}

body {
	line-height: 1;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

	blockquote:before, blockquote:after, q:before, q:after {
		content: '';
		content: none;
	}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

body {
	-webkit-text-size-adjust: none;
}

mark {
	background-color: transparent;
	color: inherit;
}

input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

input, select, textarea {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
}

/* Basic */

	html {
		box-sizing: border-box;
	}

	*, *:before, *:after {
		box-sizing: inherit;
	}

	body {
		background-image: url("images/overlay.png"), -moz-linear-gradient(top, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0.65)), url("../../images/bg.jpg");
		background-image: url("images/overlay.png"), -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0.65)), url("../../images/bg.jpg");
		background-image: url("images/overlay.png"), -ms-linear-gradient(top, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0.65)), url("../../images/bg.jpg");
		background-image: url("images/overlay.png"), linear-gradient(top, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0.65)), url("../../images/bg.jpg");
		background-position: top left, bottom left, auto;
		background-size: auto, 100% 100%, cover;
		background-attachment: fixed;
		background-repeat: repeat, no-repeat, auto;
		position: relative;
		background-color: #150C07;
		line-height: 1.75em;
		overflow-x: hidden;
		overflow-y: auto;
	}

		body.is-preload *, body.is-preload *:before, body.is-preload *:after {
			-moz-animation: none !important;
			-webkit-animation: none !important;
			-ms-animation: none !important;
			animation: none !important;
			-moz-transition: none !important;
			-webkit-transition: none !important;
			-ms-transition: none !important;
			transition: none !important;
		}

		@media screen and (max-width: 1280px) {

			body {
				background-attachment: scroll;
			}

		}

		@media screen and (max-width: 736px) {

			body {
				background-attachment: scroll;
				background-size: auto, 100% 100%, 250% auto;
				background-repeat: repeat, no-repeat, no-repeat;
				background-position: top left, bottom left, 50% 0%;
			}

		}

	body, input, select, textarea {
		font-family: 'Source Sans Pro';
		font-weight: 400;
		padding: 0;
		font-size: 13pt;
		color: rgba(255, 255, 255, 0.6);
	}

		@media screen and (max-width: 1680px) {

			body, input, select, textarea {
				font-size: 11pt;
			}

		}

		@media screen and (max-width: 1280px) {

			body, input, select, textarea {
				font-size: 10pt;
			}

		}

		@media screen and (max-width: 980px) {

			body, input, select, textarea {
				font-size: 11pt;
			}

		}

	a {
		color: #fff;
		color: rgba(255, 255, 255, 0.85);
		text-decoration: none;
		-moz-transition: color 0.25s ease-in-out;
		-webkit-transition: color 0.25s ease-in-out;
		-ms-transition: color 0.25s ease-in-out;
		transition: color 0.25s ease-in-out;
	}

		a:hover {
			color: #d64760;
		}

	h1, h2, h3, h4, h5, h6 {
		font-weight: 400;
		color: #fff;
		letter-spacing: -0.05em;
	}

	strong, b {
		color: #fff;
		color: rgba(255, 255, 255, 0.85);
		font-weight: 600;
	}

/* List */

	ul.icons {
		cursor: default;
		margin: 0 0 0.5em 0;
	}

		ul.icons li {
			display: inline-block;
			font-size: 1.5em;
			margin-left: 1em;
		}

			ul.icons li span {
				display: none;
			}

			ul.icons li a {
				opacity: 0.35;
				color: #fff;
				-moz-transition: opacity 0.25s ease-in-out;
				-webkit-transition: opacity 0.25s ease-in-out;
				-ms-transition: opacity 0.25s ease-in-out;
				transition: opacity 0.25s ease-in-out;
			}

				ul.icons li a:hover {
					opacity: 1.0;
				}

			ul.icons li:first-child {
				margin-left: 0;
			}

		@media screen and (max-width: 736px) {

			ul.icons {
				margin: 0 0 2em 0;
			}

		}

/* Icons */

	.icon {
		text-decoration: none;
		position: relative;
		text-decoration: none;
	}

		.icon:before {
			-moz-osx-font-smoothing: grayscale;
			-webkit-font-smoothing: antialiased;
			display: inline-block;
			font-style: normal;
			font-variant: normal;
			text-rendering: auto;
			line-height: 1;
			text-transform: none !important;
			font-family: 'Font Awesome 5 Free';
			font-weight: 400;
		}

		.icon:before {
			line-height: inherit;
		}

		.icon > .label {
			display: none;
		}

		.icon.solid:before {
			font-weight: 900;
		}

		.icon.brands:before {
			font-family: 'Font Awesome 5 Brands';
		}

/* Wrapper */

	#wrapper {
		min-height: 100vh;
		display: -moz-flex;
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-moz-flex-direction: column;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		-moz-justify-content: space-between;
		-webkit-justify-content: space-between;
		-ms-justify-content: space-between;
		justify-content: space-between;
		-moz-align-items: center;
		-webkit-align-items: center;
		-ms-align-items: center;
		align-items: center;
		-moz-transition: -moz-filter 0.5s ease-in-out;
		-webkit-transition: -webkit-filter 0.5s ease-in-out;
		transition: filter 0.5s ease-in-out;
	}

		#wrapper:before {
			content: '';
			display: block;
		}

		body.is-poptrox-visible #wrapper {
			-moz-filter: blur(0.25em);
			-webkit-filter: blur(0.25em);
			filter: blur(0.25em);
		}

		@media screen and (max-width: 736px) {

			#wrapper {
				min-height: 0;
			}

		}

/* Scroll Zone */

	.scrollZone {
		position: fixed;
		width: 6rem;
		height: 100vh;
		cursor: -moz-grab;
		cursor: -webkit-grab;
		cursor: -ms-grab;
		cursor: grab;
		z-index: 10001;
	}

		.scrollZone.left {
			left: 0;
		}

		.scrollZone.right {
			right: 0;
		}

		@media screen and (max-width: 736px) {

			.scrollZone {
				display: none;
			}

		}

/* Main */

	#main {
		-moz-transition: opacity 1s ease-in-out;
		-webkit-transition: opacity 1s ease-in-out;
		-ms-transition: opacity 1s ease-in-out;
		transition: opacity 1s ease-in-out;
		-moz-transition-delay: 0.5s;
		-webkit-transition-delay: 0.5s;
		-ms-transition-delay: 0.5s;
		transition-delay: 0.5s;
		position: relative;
		z-index: 1;
	.vine-border {
	    display: none !important;
	}
		width: -moz-min-content;
		width: -webkit-min-content;
		width: -ms-min-content;
		width: min-content;
		max-width: 100vw;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		padding: 5px;
	}

		#main .items {
			display: -moz-flex;
			display: -webkit-flex;
			display: -ms-flex;
			display: flex;
		}

			#main .items > :last-child {
				border-right: solid 10px #ffffff;
			}

		#main .item {
			-moz-flex-grow: 0;
			-webkit-flex-grow: 0;
			-ms-flex-grow: 0;
			flex-grow: 0;
			-moz-flex-shrink: 0;
			-webkit-flex-shrink: 0;
			-ms-flex-shrink: 0;
			flex-shrink: 0;
			margin: 5px;
			height: 16em;
			box-shadow: 0 0 0 10px #ffffff;
		}

			#main .item.span-1 {
				width: 20em;
			}

			#main .item.span-2 {
				width: 30em;
			}

			#main .item.span-3 {
				width: 40em;
			}

			#main .item.intro {
				background-color: #d64760;
				background-image: url("images/overlay.png");
				display: -moz-flex;
				display: -webkit-flex;
				display: -ms-flex;
				display: flex;
				-moz-flex-direction: column;
				-webkit-flex-direction: column;
				-ms-flex-direction: column;
				flex-direction: column;
				-moz-justify-content: center;
				-webkit-justify-content: center;
				-ms-justify-content: center;
				justify-content: center;
				padding: 1em 3em;
			}

				#main .item.intro h1 {
					font-size: 3em;
					line-height: 1em;
				}

				#main .item.intro p {
					font-size: 1.25em;
					line-height: 1.5em;
					margin: 0.5em 0 0 0;
					opacity: 0.65;
				}

			#main .item.thumb {
				display: block;
				position: relative;
				background: rgba(255, 255, 255, 0.25);
				cursor: default;
			}

				#main .item.thumb h2 {
					position: absolute;
					bottom: 0;
					left: 0;
					background: rgba(18, 21, 29, 0.85);
					width: 100%;
					padding: 1em;
					font-weight: 400;
					line-height: 1em;
					z-index: 2;
				}

				#main .item.thumb img {
					display: block;
					z-index: 1;
					position: absolute;
					top: 0;
					left: 0;
					width: 100%;
					height: 100%;
					-moz-object-fit: cover;
					-webkit-object-fit: cover;
					-ms-object-fit: cover;
					object-fit: cover;
					-moz-object-position: center;
					-webkit-object-position: center;
					-ms-object-position: center;
					object-position: center;
					-moz-transition: opacity 0.75s ease-in-out;
					-webkit-transition: opacity 0.75s ease-in-out;
					-ms-transition: opacity 0.75s ease-in-out;
					transition: opacity 0.75s ease-in-out;
					-moz-transition-delay: 1.25s;
					-webkit-transition-delay: 1.25s;
					-ms-transition-delay: 1.25s;
					transition-delay: 1.25s;
				}

				#main .item.thumb.delay-1 img {
					-moz-transition-delay: 1.375s;
					-webkit-transition-delay: 1.375s;
					-ms-transition-delay: 1.375s;
					transition-delay: 1.375s;
				}

				#main .item.thumb.delay-2 img {
					-moz-transition-delay: 1.5s;
					-webkit-transition-delay: 1.5s;
					-ms-transition-delay: 1.5s;
					transition-delay: 1.5s;
				}

				#main .item.thumb.delay-3 img {
					-moz-transition-delay: 1.625s;
					-webkit-transition-delay: 1.625s;
					-ms-transition-delay: 1.625s;
					transition-delay: 1.625s;
				}

				#main .item.thumb.delay-4 img {
					-moz-transition-delay: 1.75s;
					-webkit-transition-delay: 1.75s;
					-ms-transition-delay: 1.75s;
					transition-delay: 1.75s;
				}

				#main .item.thumb.delay-5 img {
					-moz-transition-delay: 1.875s;
					-webkit-transition-delay: 1.875s;
					-ms-transition-delay: 1.875s;
					transition-delay: 1.875s;
				}

				#main .item.thumb.delay-6 img {
					-moz-transition-delay: 2s;
					-webkit-transition-delay: 2s;
					-ms-transition-delay: 2s;
					transition-delay: 2s;
				}

		body.is-preload #main {
			opacity: 0;
		}

			body.is-preload #main .item.thumb img {
				opacity: 0;
			}

		@media screen and (max-width: 1680px) {

			#main .item {
				height: 14em;
			}

				#main .item.span-1 {
					width: 17em;
				}

				#main .item.span-2 {
					width: 25.5em;
				}

				#main .item.span-3 {
					width: 34em;
				}

		}

		@media screen and (max-width: 736px) {

			#main {
				width: 100%;
				overflow-x: hidden;
				overflow-y: auto;
				padding: 2.5px;
			}

				#main .items {
					-moz-flex-wrap: wrap;
					-webkit-flex-wrap: wrap;
					-ms-flex-wrap: wrap;
					flex-wrap: wrap;
					-moz-justify-content: center;
					-webkit-justify-content: center;
					-ms-justify-content: center;
					justify-content: center;
				}

					#main .items > :last-child {
						border-right: 0;
					}

				#main .item {
					-moz-flex-grow: 1;
					-webkit-flex-grow: 1;
					-ms-flex-grow: 1;
					flex-grow: 1;
					-moz-flex-shrink: 1;
					-webkit-flex-shrink: 1;
					-ms-flex-shrink: 1;
					flex-shrink: 1;
					width: calc(50vw - 15px) !important;
					margin: 2.5px;
					box-shadow: 0 0 0 5px #ffffff;
				}

					#main .item.intro {
						width: calc(100vw - 20px) !important;
						text-align: center;
						height: auto;
						padding: 3em;
					}

						#main .item.intro h1 {
							font-size: 2em;
						}

						#main .item.intro p {
							font-size: 1em;
						}

					#main .item.thumb h2 {
						display: none;
					}

		}

		@media screen and (max-width: 480px) {

			#main .item {
				height: 10em;
			}

		}

/* Header */

	#footer {
		width: 100%;
		padding: 1.5em;
		display: -moz-flex;
		display: -webkit-flex;
		display: -ms-flex;
		display: flex;
		-moz-justify-content: space-between;
		-webkit-justify-content: space-between;
		-ms-justify-content: space-between;
		justify-content: space-between;
		position: relative;
		z-index: 10002;
	}

		#footer > section:first-child {
			text-align: left;
			max-width: 36em;
			padding-right: 2em;
		}

		#footer > section:last-child {
			text-align: right;
			max-width: 36em;
		}

		#footer h2 {
			font-size: 2.25em;
			margin: 0 0 1em 0;
		}

		#footer .copyright li {
			display: inline-block;
			margin-left: 1em;
			padding-left: 1em;
			border-left: solid 1px rgba(255, 255, 255, 0.25);
			line-height: 1em;
		}

			#footer .copyright li:first-child {
				border-left: 0;
				margin-left: 0;
				padding-left: 0;
			}

		@media screen and (max-width: 980px) {

			#footer {
				-moz-flex-direction: column;
				-webkit-flex-direction: column;
				-ms-flex-direction: column;
				flex-direction: column;
			}

				#footer > section:first-child {
					width: 100%;
					padding-right: 0;
				}

				#footer > section:last-child {
					text-align: left;
					margin: 1.5em 0 0 0;
					width: 100%;
				}

		}

		@media screen and (max-width: 736px) {

			#footer {
				text-align: center;
				padding: 3em;
			}

				#footer > section:first-child {
					text-align: center;
					max-width: 100%;
				}

				#footer > section:last-child {
					text-align: center;
					max-width: 100%;
				}

				#footer .copyright li {
					display: block;
					margin: 0.75em 0 0 0;
					padding-left: 0;
					border-left: 0;
				}

					#footer .copyright li:first-child {
						margin-top: 0;
					}

		}

/* Popup */

	.poptrox-popup {
		background: #1a1f2c;
		background: rgba(18, 21, 29, 0.9);
		box-shadow: 0px 0px 0px 10px #fff, 0px 10px 60px 10px rgba(8, 11, 19, 0.55);
		cursor: default;
	}

		.poptrox-popup .loader {
			display: block;
			width: 48px;
			height: 48px;
			position: absolute;
			top: 50%;
			left: 50%;
			margin: -24px 0 0 -24px;
			background: url("images/loader.gif");
			opacity: 0.25;
		}

		.poptrox-popup .caption {
			position: absolute;
			bottom: 0;
			left: 0;
			background: #1a1f2c;
			background: rgba(18, 21, 29, 0.85);
			display: block;
			width: 100%;
			line-height: 75px;
			text-align: center;
			font-size: 1.25em;
			color: #fff;
		}

		.poptrox-popup .nav-next, .poptrox-popup .nav-previous {
			text-decoration: none;
			font-weight: normal;
			font-style: normal;
			-moz-transition: opacity 0.25s ease-in-out;
			-webkit-transition: opacity 0.25s ease-in-out;
			-ms-transition: opacity 0.25s ease-in-out;
			transition: opacity 0.25s ease-in-out;
			opacity: 0.35;
		}

			.poptrox-popup .nav-next:hover, .poptrox-popup .nav-previous:hover {
				opacity: 1.0;
			}

		.poptrox-popup .nav-next, .poptrox-popup .nav-previous {
			text-decoration: none;
			text-transform: none !important;
			width: 150px;
			height: 75px;
			position: absolute;
			bottom: 0;
			cursor: pointer;
			font-size: 3em;
			line-height: 75px;
		}

			.poptrox-popup .nav-next:before, .poptrox-popup .nav-previous:before {
				-moz-osx-font-smoothing: grayscale;
				-webkit-font-smoothing: antialiased;
				display: inline-block;
				font-style: normal;
				font-variant: normal;
				text-rendering: auto;
				line-height: 1;
				text-transform: none !important;
				font-family: 'Font Awesome 5 Free';
				font-weight: 900;
			}

		.poptrox-popup .nav-next {
			right: 0;
			text-align: right;
			padding-right: 30px;
		}

			.poptrox-popup .nav-next:before {
				content: '\f105';
			}

		.poptrox-popup .nav-previous {
			left: 0;
			text-align: left;
			padding-left: 30px;
		}

			.poptrox-popup .nav-previous:before {
				content: '\f104';
			}

		@media screen and (max-width: 736px) {

			.poptrox-popup {
				background: #0a0f1c;
				box-shadow: 0px 0px 30px 10px rgba(8, 11, 19, 0.85);
				border: solid 2.5px #fff;
				-moz-box-sizing: content-box;
				-webkit-box-sizing: content-box;
				-ms-box-sizing: content-box;
				box-sizing: content-box;
			}

				.poptrox-popup .caption {
					display: none !important;
				}

				.poptrox-popup .nav-next {
					display: none !important;
				}

				.poptrox-popup .nav-previous {
					display: none !important;
				}

		}

/* Artist Bio Styling */
.artist-bio {
	margin-top: 1.5em;
	font-style: italic;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.8);
}
/* Header text high contrast */
header#header h1,
header#header p {
	color: rgba(255, 255, 255, 0.9);
}

.artist-bio p {
	margin-bottom: 1em;
	font-size: 1.1em;
}

.artist-bio p:first-child::first-letter {
    font-size: 2.5em;
    float: left;
    margin-right: 0.1em;
    margin-top: 0.1em;
    line-height: 0.8;
    color: #8fc97a;
}

/* Core Theme Styles */

/* CSS Reset and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

/* Theme Variables */
:root {
    --primary-bg: linear-gradient(135deg, #2d5a4a 0%, #1a3d2e 25%, #0d2818 100%);
    --primary-text: #1a3d2e;
    --secondary-text: #81c784;
    --accent-color: #66bb6a;
    --primary-color: #4caf50;
    --text-color: #c8e6c9;
    --light-accent: #a5d6a7;
    --card-bg: rgba(255, 255, 255, 0.05);
    --card-border: rgba(76, 175, 80, 0.2);
    --footer-bg: rgba(26, 61, 46, 0.9);
    --ambient-glow-1: rgba(46, 125, 50, 0.1);
    --ambient-glow-2: rgba(102, 187, 106, 0.1);
    --ambient-glow-3: rgba(27, 94, 32, 0.1);
}

/* Light Theme */
html.light-theme, body.light-theme {
    --primary-bg: #f4fbf6;
    --primary-text: #1f3a2f;
    --secondary-text: #467465;
    --accent-color: #3f9b79;
    --primary-color: #3f9b79;
    --text-color: #234636;
    --card-bg: rgba(255, 255, 255, 0.92);
    --card-border: rgba(63, 155, 121, 0.18);
    --footer-bg: rgba(228, 242, 236, 0.94);
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    line-height: 1.6;
    color: var(--primary-text) !important;
    background: var(--primary-bg) !important;
    overflow-x: hidden;
    position: relative;
    transition: all 0.6s ease;
}

/* Strong overrides for light theme to ensure visibility over main.css */
body.light-theme {
    background: var(--primary-bg) !important;
    color: var(--primary-text) !important;
}

/* Theme Switcher */
/* Base positioning kept neutral; navbar-specific styles handle placement */
.theme-switcher {
    position: static;
    z-index: 1000;
    display: flex;
    gap: 10px;
}

.theme-toggle {
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 50%;
    border: 1px solid transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(17, 40, 29, 0.65);
    box-shadow: 0 6px 16px -10px rgba(0, 0, 0, 0.65);
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, border-color 0.25s ease;
    position: relative;
}

.theme-toggle:hover,
.theme-toggle:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px -12px rgba(0, 0, 0, 0.55);
}

/* Disable hover animation on mobile for better performance */
@media (max-width: 768px) {
    .theme-toggle:hover {
        transform: none;
    }
}

.theme-toggle:focus-visible {
    outline: 2px solid rgba(188, 255, 222, 0.85);
    outline-offset: 4px;
}

.theme-toggle.active {
    background: rgba(30, 84, 58, 0.78);
    border-color: rgba(143, 227, 173, 0.5);
    box-shadow: 0 16px 30px -18px rgba(37, 196, 122, 0.6);
}

.theme-circle {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    position: relative;
    display: block;
}

.dark-circle,
.light-circle {
    background: transparent;
    border: none;
}

/* Update existing color references to use CSS variables */

/* Animated Background Elements (reserved for future use) */

/* Container */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 5;
}

/* Navigation */
.navbar {
    position: fixed;
    top: 0;
    width: 100%;
    background: rgba(26, 61, 46, 0.95);
    backdrop-filter: blur(15px);
    border-bottom: 1px solid rgba(76, 175, 80, 0.3);
    z-index: 1000;
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px rgba(27, 94, 32, 0.3);
}

.nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 80px;
}

.nav-logo h2 {
    font-size: 1.8rem;
    font-weight: 700;
    background: linear-gradient(135deg, #66bb6a 0%, #4caf50 50%, #2e7d32 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: 0 2px 10px rgba(76, 175, 80, 0.3);
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 2rem;
}

.nav-link {
    text-decoration: none;
    color: #c8e6c9;
    font-weight: 500;
    transition: all 0.3s ease;
    position: relative;
}

.nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: -5px;
    left: 0;
    background: linear-gradient(135deg, #66bb6a 0%, #4caf50 100%);
    transition: width 0.3s ease;
    box-shadow: 0 0 10px rgba(76, 175, 80, 0.5);
}

.nav-link:hover::after,
.nav-link.active::after {
    width: 100%;
}

.nav-link:hover {
    color: #81c784;
    text-shadow: 0 0 10px rgba(129, 199, 132, 0.5);
}

/* Language Switcher */
.nav-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.language-switcher {
    display: flex;
    background: rgba(76, 175, 80, 0.1);
    border-radius: 20px;
    padding: 2px;
    border: 1px solid rgba(76, 175, 80, 0.3);
}

.lang-btn {
    background: none;
    border: none;
    padding: 8px 16px;
    border-radius: 18px;
    color: #c8e6c9;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
}

.lang-btn.active {
    background: linear-gradient(135deg, #4caf50 0%, #2e7d32 100%);
    color: white;
    box-shadow: 0 4px 15px rgba(76, 175, 80, 0.3);
}

.lang-btn:hover:not(.active) {
    background: rgba(76, 175, 80, 0.2);
    color: #81c784;
}

/* Hamburger Menu */
.hamburger {
    display: none;
    flex-direction: column;
    cursor: pointer;
    gap: 4px;
}

.hamburger span {
    width: 25px;
    height: 3px;
    background: linear-gradient(135deg, #66bb6a 0%, #4caf50 100%);
    border-radius: 2px;
    transition: all 0.3s ease;
}

/* Hero Section */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 100px 0 50px;
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(ellipse at center, rgba(76, 175, 80, 0.1) 0%, transparent 70%);
    animation: heroGlow 6s ease-in-out infinite alternate;
}

@keyframes heroGlow {
    0% { transform: scale(0.8); opacity: 0.3; }
    100% { transform: scale(1.2); opacity: 0.6; }
}

.hero-content {
    position: relative;
    z-index: 2;
    max-width: 800px;
    margin: 0 auto;
    padding: 0 20px;
}

.hero h1 {
    font-size: 3.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
    background: linear-gradient(135deg, #e8f5e8 0%, #c8e6c9 50%, #81c784 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: 2px 2px 20px rgba(76, 175, 80, 0.3);
    animation: titleFloat 4s ease-in-out infinite alternate;
}

@keyframes titleFloat {
    0% { transform: translateY(0px); }
    100% { transform: translateY(-10px); }
}

.hero .subtitle {
    font-size: 1.4rem;
    color: #c8e6c9;
    margin-bottom: 2rem;
    font-weight: 300;
    text-shadow: 1px 1px 10px rgba(76, 175, 80, 0.2);
}

.artist-photo {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    margin: 2rem auto;
    border: 4px solid transparent;
    background: linear-gradient(135deg, #4caf50, #2e7d32) padding-box,
                linear-gradient(135deg, #66bb6a, #4caf50, #2e7d32) border-box;
    box-shadow: 0 10px 30px rgba(76, 175, 80, 0.3),
                0 0 20px rgba(76, 175, 80, 0.2);
    transition: all 0.3s ease;
    animation: photoGlow 3s ease-in-out infinite alternate;
}

@keyframes photoGlow {
    0% { box-shadow: 0 10px 30px rgba(76, 175, 80, 0.3), 0 0 20px rgba(76, 175, 80, 0.2); }
    100% { box-shadow: 0 15px 40px rgba(76, 175, 80, 0.5), 0 0 30px rgba(76, 175, 80, 0.4); }
}

.artist-photo:hover {
    transform: scale(1.05);
    box-shadow: 0 20px 50px rgba(76, 175, 80, 0.5),
                0 0 40px rgba(76, 175, 80, 0.4);
}

/* Featured Artwork in Hero */
.featured-artwork {
    margin: 2rem auto;
    max-width: 250px;
    text-align: center;
}

.hero-artwork {
    width: 280px;
    height: 280px;
    border-radius: 50%;
    border: 5px solid transparent;
    background: linear-gradient(135deg, #1a3d2e, #2d5a4a) padding-box,
                linear-gradient(135deg, #66bb6a, #4caf50, #2e7d32) border-box;
    box-shadow: 0 20px 50px rgba(76, 175, 80, 0.4),
                0 0 30px rgba(76, 175, 80, 0.3),
                inset 0 0 20px rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
    animation: artworkFloat 4s ease-in-out infinite alternate;
    object-fit: cover;
}

/* Theme-aware hero artwork switching */
.hero-artwork.logo-dark {
    display: block;
}

.hero-artwork.logo-light {
    display: none;
}

body.light-theme .hero-artwork.logo-dark {
    display: none;
}

body.light-theme .hero-artwork.logo-light {
    display: block;
}

@keyframes artworkFloat {
    0% { transform: translateY(0px); }
    100% { transform: translateY(-8px); }
}

.hero-artwork:hover {
    transform: translateY(-8px) scale(1.05);
    box-shadow: 0 25px 60px rgba(76, 175, 80, 0.4),
                0 0 40px rgba(76, 175, 80, 0.3);
}

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

.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 12px 24px;
    border-radius: 30px;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.btn-primary {
    background: linear-gradient(135deg, #4caf50 0%, #2e7d32 100%);
    color: white;
    box-shadow: 0 8px 25px rgba(76, 175, 80, 0.3);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px rgba(76, 175, 80, 0.4);
}

.btn-secondary {
    background: rgba(76, 175, 80, 0.1);
    color: var(--accent-color);
    border: 2px solid var(--card-border);
}

.btn-secondary:hover {
    background: rgba(76, 175, 80, 0.2);
    border-color: rgba(76, 175, 80, 0.5);
    color: #81c784;
    transform: translateY(-2px);
}

/* Paint Splash Animation */
.paint-splash {
    position: absolute;
    width: 300px;
    height: 300px;
    opacity: 0.1;
    animation: splash 8s ease-in-out infinite;
}

.paint-splash:nth-child(1) {
    top: 10%;
    left: 10%;
    background: radial-gradient(circle, #4caf50 0%, transparent 70%);
    animation-delay: 0s;
}

.paint-splash:nth-child(2) {
    top: 60%;
    right: 10%;
    background: radial-gradient(circle, #66bb6a 0%, transparent 70%);
    animation-delay: 2s;
}

.paint-splash:nth-child(3) {
    bottom: 20%;
    left: 30%;
    background: radial-gradient(circle, #2e7d32 0%, transparent 70%);
    animation-delay: 4s;
}

@keyframes splash {
    0%, 100% { transform: scale(0.8) rotate(0deg); opacity: 0.1; }
    50% { transform: scale(1.2) rotate(180deg); opacity: 0.3; }
}

/* Section Styling */
.section {
    padding: 100px 0;
    position: relative;
}

.section-title {
    font-size: 2.5rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 1rem;
    background: linear-gradient(135deg, #e8f5e8 0%, #c8e6c9 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.section-subtitle {
    text-align: center;
    font-size: 1.1rem;
    color: #a5d6a7;
    margin-bottom: 3rem;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* Gallery Styles */
.gallery {
    padding: 100px 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.gallery .container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
    justify-items: center;
    justify-content: center;
    max-width: 1200px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding: 0 20px;
}

/* Large screens - 4 items per row */
@media (min-width: 1400px) {
    .gallery-grid {
        grid-template-columns: repeat(4, 1fr);
        max-width: 1600px;
        justify-content: center;
    }
}

/* Medium-large screens - 3 items per row */
@media (min-width: 1100px) and (max-width: 1399px) {
    .gallery-grid {
        grid-template-columns: repeat(3, 1fr);
        max-width: 1200px;
        justify-content: center;
    }
}

/* Medium screens - 2 items per row */
@media (min-width: 769px) and (max-width: 1099px) {
    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        max-width: 800px;
        justify-content: center;
    }
}

.gallery-item {
    background: var(--card-bg);
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 
        0 4px 20px rgba(0, 0, 0, 0.1),
        0 1px 4px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    position: relative;
    backdrop-filter: blur(5px);
    border: 1px solid var(--card-border);
    min-height: 420px;
}

/* Image container to prevent overflow */
.gallery-image-container {
    width: 100%;
    height: 280px;
    overflow: hidden;
    border-radius: 8px 8px 0 0;
    background: var(--card-bg);
    position: relative;
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.3s ease;
}

/* Gallery Loading and Error States */
.gallery-loading,
.gallery-error {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
}

/* Scroll Reveal Animation */
.scroll-reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
}
.revealed {
    opacity: 1;
    transform: translateY(0);
}

.gallery-loading::before {
    content: '';
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(76, 175, 80, 0.3);
    border-radius: 50%;
    border-top-color: var(--primary-color);
    animation: spin 1s ease-in-out infinite;
    margin-right: 10px;
}

.gallery-error {
    background: rgba(255, 87, 51, 0.05);
    border: 1px solid rgba(255, 87, 51, 0.1);
    color: #ff5733;
}

.retry-button {
    background: var(--primary-color);
    color: white;
    border: none;
    padding: 0.5rem 1rem;
    border-radius: 5px;
    cursor: pointer;
    margin-top: 1rem;
    font-size: 0.9rem;
    transition: background-color 0.3s ease;
}

.retry-button:hover {
    background: #45a049;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Image Placeholder Styles */
.image-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 200px;
    background: rgba(76, 175, 80, 0.05);
    color: var(--text-color);
    text-align: center;
    padding: 1rem;
    border-radius: 10px;
}

.image-placeholder i {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
    color: rgba(76, 175, 80, 0.5);
}

.image-placeholder span {
    font-weight: 500;
    margin-bottom: 0.25rem;
}

.image-placeholder small {
    opacity: 0.7;
    font-size: 0.8rem;
}

/* Pricing Information Styles */
.pricing-info {
    margin: 1rem 0;
    padding: 1rem;
    background: rgba(76, 175, 80, 0.08);
    border-radius: 10px;
    border: 1px solid rgba(76, 175, 80, 0.15);
}

.price-display {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.price-amount {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--primary-color);
}

.shipping-included {
    color: #666;
    font-style: italic;
}

.canvas-note {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    color: #555;
    font-size: 0.85rem;
}

.canvas-note i {
    color: var(--primary-color);
}

.gallery-item:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 40px rgba(27, 94, 32, 0.2);
    border-color: rgba(76, 175, 80, 0.3);
}

.gallery-item img {
    width: 100%;
    height: 280px;
    object-fit: contain;
    object-position: center;
    background: var(--card-bg);
    border-radius: 8px 8px 0 0;
    transition: all 0.3s ease;
    padding: 8px;
    box-sizing: border-box;
}

.gallery-item:hover img {
    transform: scale(1.02);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.gallery-item-info {
    padding: 1.5rem;
}

.gallery-item h3 {
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--text-color);
}

.gallery-item p {
    color: var(--secondary-text);
    margin-bottom: 1rem;
}

.price-tag {
    display: inline-block;
    background: linear-gradient(135deg, #4caf50 0%, #2e7d32 100%);
    color: white;
    padding: 5px 12px;
    border-radius: 15px;
    font-size: 0.9rem;
    font-weight: 600;
}

/* Responsive Design */
@media (max-width: 768px) {
    .hamburger {
        display: flex;
    }
    
    .nav-menu {
        display: none;
    }
    

/* Dualism theme overlays ------------------------------------------------- */

body[data-dualism-theme] .navbar {
    background: linear-gradient(135deg, rgba(6, 10, 26, 0.72), rgba(6, 12, 24, 0.58));
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

body[data-dualism-theme="light"] .navbar {
    background: linear-gradient(135deg, rgba(246, 247, 255, 0.84), rgba(226, 230, 244, 0.76));
    border-bottom: 1px solid rgba(41, 43, 62, 0.12);
}

body[data-dualism-theme] .section {
    position: relative;
    z-index: 4;
}

body[data-dualism-theme] .hero-content,
body[data-dualism-theme] .gallery-item,
body[data-dualism-theme] .contact-content,
body[data-dualism-theme] .about-content {
    background: linear-gradient(165deg, rgba(10, 14, 30, 0.38), rgba(6, 8, 18, 0.58));
    border-radius: 24px;
    box-shadow: 0 34px 70px rgba(4, 6, 16, 0.36);
    backdrop-filter: blur(22px) saturate(1.05);
    padding: 2.4rem;
}

body[data-dualism-theme="light"] .hero-content,
body[data-dualism-theme="light"] .gallery-item,
body[data-dualism-theme="light"] .contact-content,
body[data-dualism-theme="light"] .about-content {
    background: linear-gradient(165deg, rgba(250, 251, 255, 0.62), rgba(234, 238, 250, 0.76));
    box-shadow: 0 32px 80px rgba(32, 38, 64, 0.16);
}

body[data-dualism-theme] .gallery-item h3,
body[data-dualism-theme] .section-title,
body[data-dualism-theme] .hero-title {
    color: rgba(255, 244, 218, 0.92);
}

body[data-dualism-theme="light"] .gallery-item h3,
body[data-dualism-theme="light"] .section-title,
body[data-dualism-theme="light"] .hero-title {
    color: rgba(32, 36, 54, 0.92);
}

body[data-dualism-theme] .gallery-item p,
body[data-dualism-theme] .subtitle,
body[data-dualism-theme] .about-text p,
body[data-dualism-theme] .lead {
    color: rgba(223, 229, 255, 0.78);
}

body[data-dualism-theme="light"] .gallery-item p,
body[data-dualism-theme="light"] .subtitle,
body[data-dualism-theme="light"] .about-text p,
body[data-dualism-theme="light"] .lead {
    color: rgba(24, 28, 42, 0.78);
}

body[data-dualism-theme] .btn-primary {
    background: linear-gradient(135deg, rgba(226, 179, 84, 0.92), rgba(255, 222, 156, 0.85));
    color: #1d1307;
    box-shadow: 0 18px 40px rgba(194, 148, 73, 0.45);
}

body[data-dualism-theme] .btn-secondary {
    background: linear-gradient(135deg, rgba(226, 179, 84, 0.92), rgba(255, 222, 156, 0.85));
    color: #1d1307;
    border: 1px solid rgba(255, 222, 156, 0.3);
    box-shadow: 0 18px 40px rgba(194, 148, 73, 0.45);
}

body[data-dualism-theme] .btn-secondary:hover {
    background: linear-gradient(135deg, rgba(255, 200, 100, 0.98), rgba(255, 230, 170, 0.95));
    box-shadow: 0 20px 45px rgba(194, 148, 73, 0.6);
    transform: translateY(-2px);
}

body[data-dualism-theme="light"] .btn-secondary {
    background: rgba(28, 32, 56, 0.12);
    color: rgba(24, 26, 42, 0.86);
    border: 1px solid rgba(24, 26, 42, 0.18);
}

body[data-dualism-theme] .footer,
body[data-dualism-theme] .nav-container,
body[data-dualism-theme] .contact-info,
body[data-dualism-theme] .contact-form {
    background: transparent;
    box-shadow: none;
}
    .hero h1 {
        font-size: 2.5rem;
    }
    
    .hero .subtitle {
        font-size: 1.1rem;
    }
    
    .gallery-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        gap: 1.5rem;
        padding: 0 10px;
    }
    
    .gallery-item {
        max-width: 100%;
    }
    
    .featured-artwork {
        max-width: 180px;
    }
    
    .hero-artwork {
        width: 150px;
        height: 150px;
    }
    
    .artist-photo {
        width: 150px;
        height: 150px;
    }
    
    .cta-buttons {
        flex-direction: column;
        align-items: center;
    }
    
    .btn {
        width: 200px;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .hero h1 {
        font-size: 2rem;
    }
    
    .section-title {
        font-size: 2rem;
    }
    
    .gallery-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
        padding: 0 10px;
    }
    
    .gallery-item {
        max-width: 100%;
    }
    
    .featured-artwork {
        max-width: 150px;
    }
    
    .hero-artwork {
        width: 120px;
        height: 120px;
    }
}

/* Contact Section */
.contact {
    background: rgba(76, 175, 80, 0.05);
    border-top: 1px solid rgba(76, 175, 80, 0.1);
}

.contact-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
}

.contact-info h2 {
    color: #c8e6c9;
    font-size: 2.5rem;
    margin-bottom: 1rem;
    background: linear-gradient(135deg, #e8f5e8 0%, #c8e6c9 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.contact-info p {
    color: #a5d6a7;
    font-size: 1.1rem;
    margin-bottom: 2rem;
}

.contact-methods {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.contact-method {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: rgba(76, 175, 80, 0.08);
    border-radius: 10px;
    border: 1px solid rgba(76, 175, 80, 0.1);
    transition: all 0.3s ease;
}

.contact-method:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(27, 94, 32, 0.1);
    border-color: rgba(76, 175, 80, 0.3);
}

.contact-method i {
    font-size: 1.5rem;
    color: #4caf50;
    width: 30px;
    text-align: center;
}

.contact-method h4 {
    color: #c8e6c9;
    margin-bottom: 0.2rem;
    font-weight: 600;
}

.contact-method p {
    color: #a5d6a7;
    margin: 0;
}

.contact-method a {
    color: #81c784;
    text-decoration: none;
    transition: color 0.3s ease;
}

.contact-method a:hover {
    color: #66bb6a;
}

.social-links {
    display: flex;
    gap: 1rem;
    justify-content: center;
    margin-top: 2rem;
}

.social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: rgba(76, 175, 80, 0.1);
    border: 2px solid rgba(76, 175, 80, 0.2);
    border-radius: 50%;
    color: #4caf50;
    font-size: 1.2rem;
    text-decoration: none;
    transition: all 0.3s ease;
}

.social-link:hover {
    background: rgba(76, 175, 80, 0.2);
    border-color: rgba(76, 175, 80, 0.4);
    color: #66bb6a;
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(76, 175, 80, 0.2);
}

.contact-form {
    background: rgba(76, 175, 80, 0.05);
    padding: 2rem;
    border-radius: 15px;
    border: 1px solid rgba(76, 175, 80, 0.1);
}

.contact-form h3 {
    color: #c8e6c9;
    margin-bottom: 1.5rem;
    font-size: 1.5rem;
    font-weight: 600;
}

.form-group {
    margin-bottom: 1.5rem;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid rgba(76, 175, 80, 0.2);
    border-radius: 8px;
    background: rgba(76, 175, 80, 0.05);
    color: #c8e6c9;
    font-family: inherit;
    font-size: 1rem;
    transition: all 0.3s ease;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #81c784;
    opacity: 0.7;
}

.form-group input:focus,
.form-group textarea:focus {
    outline: none;
    border-color: rgba(76, 175, 80, 0.5);
    background: rgba(76, 175, 80, 0.08);
    box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.1);
}

.form-group textarea {
    resize: vertical;
    min-height: 120px;
}

/* About Section */
.about-content {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 4rem;
    align-items: center;
    margin-top: 3rem;
}

.about-text h3 {
    color: var(--accent-color);
    font-size: 1.8rem;
    margin-bottom: 1rem;
    font-weight: 600;
}

.about-text .lead {
    font-size: 1.2rem;
    color: #81c784;
    margin-bottom: 1.5rem;
    font-weight: 500;
    line-height: 1.7;
}

.about-text p {
    color: #a5d6a7;
    line-height: 1.7;
    margin-bottom: 1rem;
    font-size: 1rem;
}

.about-image {
    text-align: center;
}

.about-image .artist-photo {
    width: 300px;
    height: 400px;
    border-radius: 15px;
    border: 4px solid transparent;
    background: linear-gradient(135deg, #4caf50, #2e7d32) padding-box,
                linear-gradient(135deg, #66bb6a, #4caf50, #2e7d32) border-box;
    box-shadow: 0 15px 40px rgba(76, 175, 80, 0.3);
    transition: all 0.3s ease;
    object-fit: cover;
}

.about-image .artist-photo:hover {
    transform: scale(1.02);
    box-shadow: 0 20px 50px rgba(76, 175, 80, 0.4);
}

/* Footer */
.footer {
    background: var(--footer-bg);
    border-top: 1px solid var(--card-border);
    padding: 2rem 0;
    margin-top: 4rem;
}

.footer-content {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2rem;
    align-items: start;
}

.footer-info h3 {
    color: var(--accent-color);
    margin-bottom: 0.5rem;
    font-size: 1.3rem;
}

.footer-info p {
    color: var(--secondary-text);
    font-size: 0.9rem;
    margin-bottom: 1rem;
}

.shipping-partner {
    margin-top: 1rem;
}

.shipping-partner p {
    color: var(--light-accent);
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
}

.dhl-logo {
    height: 30px;
    width: auto;
    filter: brightness(1.2);
    transition: transform 0.3s ease;
}

.dhl-logo:hover {
    transform: scale(1.05);
}

.footer-legal {
    text-align: center;
}

.legal-links {
    margin-bottom: 1rem;
}

.legal-links a {
    color: var(--accent-color);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.3s ease;
}

.legal-links a:hover {
    color: var(--secondary-text);
}

.separator {
    color: var(--light-accent);
    margin: 0 0.5rem;
}

.important-notice p {
    color: #ffcc02;
    font-size: 0.8rem;
    margin: 0.2rem 0;
    font-weight: bold;
    text-shadow: 0 0 4px rgba(0, 0, 0, 0.5);
}

.important-notice small {
    color: var(--light-accent);
}

/* Light theme footer improvements */
body.light-theme .important-notice p {
    color: #d97706;
    background: rgba(251, 146, 60, 0.1);
    padding: 0.5rem 1rem;
    border-radius: 6px;
    border: 1px solid rgba(251, 146, 60, 0.3);
    text-shadow: none;
    display: inline-block;
}

body.light-theme .important-notice small {
    color: #374151;
    font-weight: 500;
}

body.light-theme .footer-legal .legal-links a {
    color: #059669;
    font-weight: 500;
}

body.light-theme .footer-legal .legal-links a:hover {
    color: #047857;
}

body.light-theme .footer-legal .separator {
    color: #6b7280;
}

body.light-theme .footer-links p {
    color: #4b5563;
}

body.light-theme .footer-links a {
    color: #059669;
    font-weight: 500;
}

body.light-theme .footer-links a:hover {
    color: #047857;
}

.footer-links {
    text-align: right;
}

.footer-links p {
    color: var(--light-accent);
    font-size: 0.9rem;
    margin: 0.2rem 0;
}

.footer-links a {
    color: var(--accent-color);
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-links a:hover {
    color: var(--secondary-text);
}

/* Responsive Design Updates */
@media (max-width: 768px) {
    .contact-content {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    
    .about-content {
        grid-template-columns: 1fr;
        gap: 2rem;
        text-align: center;
    }
    
    .about-image .artist-photo {
        width: 250px;
        height: 300px;
    }
    
    .footer-content {
        grid-template-columns: 1fr;
        gap: 2rem;
        text-align: center;
    }
    
    .footer-legal,
    .footer-links {
        text-align: center;
    }
    
    .legal-links {
        margin-bottom: 1.5rem;
    }
    
    .legal-links a {
        display: inline-block;
        margin: 0.2rem 0.5rem;
    }
    
    .separator {
        display: none;
    }
    
    .social-links {
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .contact-form {
        padding: 1.5rem;
    }
    
    .about-image .artist-photo {
        width: 200px;
        height: 250px;
    }
    
    .contact-info h2 {
        font-size: 2rem;
    }
}/* Theme Improvements for Aracelis Entebi Art Gallery */
/* This file contains fixes for image cropping and enhanced light/dark theme support */

/* ===============================================
   GALLERY IMAGE FIX - Prevent Top/Bottom Cropping
   =============================================== */

/* Fix the main gallery image cropping issue */
.gallery-item img {
    width: 100%;
    height: 280px;
    object-fit: cover !important;
    object-position: center;
    background: var(--card-bg);
    border-radius: 8px 8px 0 0;
    transition: all 0.3s ease;
    padding: 0;
    box-sizing: border-box;
}

/* Adjust gallery item to accommodate the new image sizing */
.gallery-item {
    background: var(--card-bg);
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 
        0 4px 20px rgba(0, 0, 0, 0.1),
        0 1px 4px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    position: relative;
    backdrop-filter: blur(5px);
    border: 1px solid var(--card-border);
    min-height: 420px; /* Ensure consistent card heights */
}

/* Ensure hover effects work properly with the new image sizing */
.gallery-item:hover img {
    transform: scale(1.02); /* Reduced scale to prevent overflow issues */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* ===============================================
   ENHANCED LIGHT THEME
   =============================================== */

/* Light theme variables with better contrast and readability */
html.light-theme, 
body.light-theme {
    --primary-bg: linear-gradient(135deg, #f4fbf6 0%, #eff8f3 30%, #e2f2ea 100%);
    --primary-text: #1f3a2f;
    --secondary-text: #3f6f5c;
    --accent-color: #3f9b79;
    --primary-color: #3f9b79;
    --text-color: #234636;
    --light-accent: #6ec9a7;
    --card-bg: rgba(255, 255, 255, 0.92);
    --card-border: rgba(63, 155, 121, 0.18);
    --footer-bg: rgba(228, 242, 236, 0.96);
    --ambient-glow-1: rgba(114, 199, 167, 0.08);
    --ambient-glow-2: rgba(149, 219, 197, 0.08);
    --ambient-glow-3: rgba(186, 236, 214, 0.08);
}

/* Light theme body styles */
body.light-theme {
    background: var(--primary-bg) !important;
    color: var(--primary-text) !important;
}

/* Light theme navigation */
body.light-theme .navbar {
    background: rgba(239, 248, 243, 0.95);
    border-bottom: 1px solid rgba(63, 155, 121, 0.2);
    box-shadow: 0 2px 12px rgba(36, 94, 75, 0.08);
}

body.light-theme .nav-link {
    color: var(--secondary-text);
}

body.light-theme .nav-link:hover {
    color: var(--accent-color);
    text-shadow: none;
}

/* Light theme gallery cards */
body.light-theme .gallery-item {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    box-shadow: 
        0 2px 15px rgba(0, 0, 0, 0.08),
        0 1px 4px rgba(0, 0, 0, 0.04);
}

body.light-theme .gallery-item:hover {
    box-shadow: 
        0 8px 26px rgba(33, 87, 68, 0.12),
        0 4px 8px rgba(33, 87, 68, 0.08);
    border-color: rgba(63, 155, 121, 0.32);
}

body.light-theme .gallery-item h3 {
    color: var(--primary-text);
}

body.light-theme .gallery-item p {
    color: var(--text-color);
}

/* Light theme price tags */
body.light-theme .price-tag {
    background: linear-gradient(135deg, #3f9b79 0%, #2b7a5e 100%);
    color: #f5fffb;
}

/* Light theme buttons */
body.light-theme .btn {
    background: linear-gradient(135deg, #3f9b79 0%, #2d8363 100%);
    color: #f6fffb;
    border: none;
}

body.light-theme .btn:hover {
    background: linear-gradient(135deg, #2d8363 0%, #226850 100%);
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(47, 121, 93, 0.24);
}

body.light-theme h1,
body.light-theme h2,
body.light-theme h3,
body.light-theme h4,
body.light-theme h5,
body.light-theme h6 {
    color: var(--primary-text);
    letter-spacing: -0.035em;
}

body.light-theme p,
body.light-theme li,
body.light-theme label,
body.light-theme span {
    color: var(--text-color);
}

body.light-theme .image-placeholder {
    background: rgba(180, 224, 208, 0.32);
    color: var(--text-color);
    border: 1px dashed rgba(63, 155, 121, 0.35);
}

body.light-theme .gallery-item.image-missing .image-placeholder {
    background: rgba(180, 224, 208, 0.4);
    border-color: rgba(63, 155, 121, 0.45);
}

body.light-theme .image-placeholder i {
    color: rgba(63, 155, 121, 0.55);
}

body.light-theme .image-placeholder small {
    color: rgba(36, 86, 69, 0.6);
}

body.light-theme .form-group input,
body.light-theme .form-group textarea {
    border-color: rgba(63, 155, 121, 0.26);
    background: rgba(196, 233, 218, 0.3);
    color: var(--primary-text);
    box-shadow: inset 0 0 0 1px rgba(63, 155, 121, 0.12);
}

body.light-theme .form-group input::placeholder,
body.light-theme .form-group textarea::placeholder {
    color: rgba(47, 98, 80, 0.6);
}

body.light-theme .form-group input:focus,
body.light-theme .form-group textarea:focus {
    border-color: rgba(63, 155, 121, 0.45);
    background: rgba(204, 236, 223, 0.46);
    box-shadow: 0 0 0 3px rgba(144, 225, 196, 0.35);
}

body.light-theme .contact-form h3 {
    color: var(--accent-color);
}

body.light-theme #main .item.intro h1 {
    color: var(--primary-text);
    text-shadow: none;
}

body.light-theme #main .item.intro p {
    color: var(--secondary-text);
    opacity: 0.82;
}

body.light-theme #main .item.thumb {
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(63, 155, 121, 0.2);
    box-shadow: 0 10px 35px rgba(37, 102, 80, 0.14);
}

body.light-theme #main .item.thumb h2 {
    background: linear-gradient(135deg, rgba(142, 216, 191, 0.92) 0%, rgba(107, 187, 162, 0.88) 100%);
    color: var(--primary-text);
    text-shadow: none;
}

body.light-theme #footer h2,
body.light-theme .nav-logo h2,
body.light-theme .contact-info h2,
body.light-theme #main .item.thumb h2,
body.light-theme .gallery-item h3 {
    color: var(--primary-text);
}

/* Remove generic emoji pseudo-icons to prevent visual conflicts; navbar-specific icons are used */
.theme-toggle::after,
.dark-theme::after,
.light-theme::after {
    content: none !important;
}

/* ===============================================
   RESPONSIVE IMPROVEMENTS
   =============================================== */

@media (max-width: 768px) {
    .theme-switcher {
        top: 15px;
        right: 15px;
        gap: 4px;
        padding: 3px;
    }
    
    .theme-toggle {
        width: 24px;
        height: 24px;
    }
    
    .theme-circle {
        width: 14px;
        height: 14px;
    }
    
    .gallery-item img {
        height: 220px; /* Adjust for mobile */
    }
    
    .gallery-item {
        min-height: 360px;
    }
}

@media (max-width: 480px) {
    .theme-switcher {
        right: 10px;
        top: 10px;
    }
    
    .gallery-item img {
        height: 200px;
        padding: 6px;
    }
    
    .gallery-item {
        min-height: 340px;
    }
}

/* ===============================================
   ACCESSIBILITY IMPROVEMENTS
   =============================================== */

/* Focus states for keyboard navigation */
.theme-toggle:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

.gallery-item:focus-within {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .gallery-item img,
    .theme-toggle,
    .theme-circle {
        transition: none;
    }
    
    .gallery-item:hover img {
        transform: none;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    body.light-theme .gallery-item {
        border: 2px solid var(--primary-text);
    }
    
    body.light-theme .theme-toggle {
        border: 2px solid var(--primary-text);
    }
}

/* ===============================================
   PERFORMANCE OPTIMIZATIONS
   =============================================== */

/* GPU acceleration for smooth animations - optimized */
.gallery-item:hover,
.theme-toggle:active {
    will-change: transform;
    backface-visibility: hidden;
}

/* Optimize repaints */
.gallery-item:hover {
    contain: layout style paint;
}/* UI fixes for language switcher, theme toggle, and gallery cards */

:root {
    --lang-switcher-bg: rgba(12, 40, 25, 0.68);
    --lang-switcher-border: rgba(210, 255, 225, 0.35);
    --lang-switcher-text: #f6fff8;
    --lang-switcher-hover-bg: rgba(255, 255, 255, 0.18);
    --lang-switcher-active-bg: rgba(255, 255, 255, 0.92);
    --lang-switcher-active-text: #0f2d1e;
    --theme-switcher-bg: rgba(11, 34, 22, 0.7);
    --theme-switcher-border: rgba(210, 255, 225, 0.28);
    --theme-toggle-bg: rgba(255, 255, 255, 0.08);
    --theme-toggle-active-bg: rgba(108, 143, 184, 0.28);
    --theme-toggle-icon-color: rgba(255, 255, 255, 0.9);
    --gallery-card-bg: rgba(18, 50, 36, 0.7);
    --gallery-card-border: rgba(255, 255, 255, 0.08);
    --gallery-card-shadow: 0 25px 45px -25px rgba(0, 0, 0, 0.65);
    --gallery-card-shadow-hover: 0 28px 60px -25px rgba(0, 0, 0, 0.7), 0 20px 45px -30px rgba(46, 202, 138, 0.35);
    --gallery-card-accent: rgba(90, 255, 195, 0.16);
    --gallery-info-bg: rgba(7, 30, 19, 0.7);
    --gallery-info-border: rgba(152, 230, 187, 0.18);
    --gallery-info-shadow: 0 18px 45px -30px rgba(0, 0, 0, 0.75), inset 0 0 0 1px rgba(255, 255, 255, 0.04);
    --gallery-heading-color: #f6fff8;
    --gallery-body-color: #e6f9ef;
    --gallery-small-color: rgba(218, 241, 229, 0.78);
    --gallery-pricing-bg: rgba(8, 26, 18, 0.55);
    --gallery-pricing-border: rgba(124, 202, 160, 0.18);
    --gallery-price-amount-color: #b6ffe0;
    --gallery-price-secondary-color: rgba(214, 246, 230, 0.88);
    --gallery-price-tag-bg: linear-gradient(135deg, rgba(45, 255, 183, 0.92), rgba(25, 167, 95, 0.92));
    --gallery-price-tag-color: #052816;
    --gallery-whatsapp-bg: linear-gradient(135deg, rgba(54, 205, 112, 0.95), rgba(30, 171, 96, 0.95));
    --gallery-whatsapp-bg-hover: linear-gradient(135deg, rgba(68, 225, 132, 0.98), rgba(27, 184, 102, 0.98));
    --gallery-whatsapp-text: #041b10;
    --hero-title-color: #f6fff2;
    --hero-subtitle-color: rgba(230, 250, 239, 0.92);
    --content-heading-color: #f0fff6;
    --content-body-color: rgba(225, 245, 234, 0.92);
    --content-muted-color: rgba(208, 235, 221, 0.85);
    --contact-heading-color: #edfff5;
    --contact-body-color: rgba(222, 245, 232, 0.92);
    --contact-link-color: #b3f7b0;
}

html.light-theme,
body.light-theme {
    --lang-switcher-bg: rgba(255, 255, 255, 0.96);
    --lang-switcher-border: rgba(46, 125, 50, 0.25);
    --lang-switcher-text: #1f3b28;
    --lang-switcher-hover-bg: rgba(76, 175, 80, 0.12);
    --lang-switcher-active-bg: rgba(76, 175, 80, 0.2);
    --lang-switcher-active-text: #0f2418;
    --theme-switcher-bg: rgba(255, 255, 255, 0.92);
    --theme-switcher-border: rgba(46, 125, 50, 0.22);
    --theme-toggle-bg: rgba(255, 238, 173, 0.18);
    --theme-toggle-active-bg: rgba(255, 202, 70, 0.28);
    --theme-toggle-icon-color: rgba(184, 108, 15, 0.9);
    --gallery-card-bg: rgba(255, 255, 255, 0.99);
    --gallery-card-border: rgba(46, 125, 50, 0.18);
    --gallery-card-shadow: 0 18px 32px -22px rgba(46, 125, 50, 0.22);
    --gallery-card-shadow-hover: 0 26px 42px -20px rgba(46, 125, 50, 0.26);
    --gallery-card-accent: rgba(96, 191, 119, 0.15);
    --gallery-info-bg: rgba(255, 255, 255, 0.99);
    --gallery-info-border: rgba(46, 125, 50, 0.15);
    --gallery-info-shadow: 0 16px 32px -24px rgba(46, 125, 50, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.75);
    --gallery-heading-color: #123522;
    --gallery-body-color: rgba(38, 76, 52, 0.9);
    --gallery-small-color: rgba(38, 76, 52, 0.7);
    --gallery-pricing-bg: rgba(46, 125, 50, 0.08);
    --gallery-pricing-border: rgba(46, 125, 50, 0.18);
    --gallery-price-amount-color: #1f6f37;
    --gallery-price-secondary-color: rgba(38, 76, 52, 0.75);
    --gallery-price-tag-bg: linear-gradient(135deg, #2e7d32 0%, #1b5e20 100%);
    --gallery-price-tag-color: #ffffff;
    --gallery-whatsapp-bg: linear-gradient(135deg, #4caf50 0%, #2e7d32 100%);
    --gallery-whatsapp-bg-hover: linear-gradient(135deg, #2e7d32 0%, #1b5e20 100%);
    --gallery-whatsapp-text: #ffffff;
    --hero-title-color: #123825;
    --hero-subtitle-color: rgba(34, 84, 57, 0.96);
    --content-heading-color: #184b31;
    --content-body-color: rgba(28, 62, 43, 0.92);
    --content-muted-color: rgba(34, 68, 50, 0.82);
    --contact-heading-color: #174832;
    --contact-body-color: rgba(32, 66, 48, 0.9);
    --contact-link-color: #1f6f3f;
}

.navbar .nav-actions {
    display: flex;
    align-items: center;
    gap: clamp(0.65rem, 1.5vw, 1rem);
}

.navbar .theme-switcher {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    background: var(--theme-switcher-bg);
    border: 1px solid var(--theme-switcher-border);
    border-radius: 999px;
    padding: 3px;
    position: static;
    box-shadow: 0 18px 32px -24px rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(12px);
    height: 40px;
}

.navbar .theme-toggle {
    background: var(--theme-toggle-bg, rgba(15, 40, 27, 0.6));
    border-color: rgba(141, 214, 171, 0.25);
    width: 32px;
    height: 32px;
}

.navbar .theme-toggle.active {
    background: var(--theme-toggle-active-bg, rgba(46, 125, 50, 0.35));
    box-shadow: 0 14px 24px -18px rgba(42, 196, 122, 0.55);
}

.navbar .theme-toggle.light-theme.active {
    border-color: rgba(255, 209, 102, 0.7);
}

/* Light theme button backgrounds */
body.light-theme .navbar .theme-toggle {
    background: rgba(245, 245, 245, 0.7);
    border-color: rgba(200, 200, 200, 0.4);
}

body.light-theme .navbar .theme-toggle.active {
    background: rgba(255, 235, 180, 0.8);
    border-color: rgba(255, 209, 102, 0.6);
    box-shadow: 0 14px 24px -18px rgba(255, 193, 7, 0.4);
}

/* Crescent Moon Icon - Dark Theme (in dark mode) & Light Theme (inactive in light mode) */
.navbar .theme-toggle.dark-theme .theme-circle {
    background: transparent;
}

.navbar .theme-toggle.dark-theme .theme-circle::before {
    content: '';
    position: absolute;
    width: 15px;
    height: 15px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: #f5f7fb;
    box-shadow: 0 0 6px rgba(245, 247, 251, 0.5);
    transition: none;
}

.navbar .theme-toggle.dark-theme .theme-circle::after {
    content: '';
    position: absolute;
    width: 13px;
    height: 13px;
    top: 50%;
    left: calc(50% + 1px);
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: rgba(17, 40, 29, 0.98);
    box-shadow: inset -1px -1px 3px rgba(245, 247, 251, 0.15);
    transition: none;
}

/* Light theme crescent moon - darker for better visibility */
body.light-theme .navbar .theme-toggle.dark-theme .theme-circle::before {
    background: #2d5a4a;
    box-shadow: 0 0 4px rgba(45, 90, 74, 0.3);
}

body.light-theme .navbar .theme-toggle.dark-theme .theme-circle::after {
    background: rgba(245, 245, 245, 0.95);
    box-shadow: inset -1px -1px 2px rgba(45, 90, 74, 0.1);
}

/* Sun Icon - Light Theme */
.navbar .theme-toggle.light-theme .theme-circle {
    background: transparent;
}

.navbar .theme-toggle.light-theme .theme-circle::before {
    content: '';
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #ffd463;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 8px rgba(255, 212, 99, 0.6);
}

.navbar .theme-toggle.light-theme .theme-circle::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    box-shadow:
        0 -8px 0 -6px #ffd463,
        6px -6px 0 -6px #ffd463,
        8px 0 0 -6px #ffd463,
        6px 6px 0 -6px #ffd463,
        0 8px 0 -6px #ffd463,
        -6px 6px 0 -6px #ffd463,
        -8px 0 0 -6px #ffd463,
        -6px -6px 0 -6px #ffd463;
    pointer-events: none;
}

.hero-title {
    background: none !important;
    color: var(--hero-title-color) !important;
    -webkit-text-fill-color: var(--hero-title-color) !important;
    text-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
}

.hero .subtitle,
.hero-subtitle,
.hero p.subtitle {
    color: var(--hero-subtitle-color) !important;
    text-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

.section-title {
    background: none !important;
    color: var(--content-heading-color) !important;
    -webkit-text-fill-color: var(--content-heading-color) !important;
    text-shadow: 0 10px 30px rgba(0, 0, 0, 0.42);
}

.section-subtitle {
    color: var(--content-body-color) !important;
    text-shadow: 0 8px 20px rgba(0, 0, 0, 0.35);
}

.about-text h3 {
    color: var(--content-heading-color) !important;
}

.about-text .lead {
    color: var(--content-body-color) !important;
}

.about-text p {
    color: var(--content-muted-color) !important;
}

.contact-info h2,
.contact-form h3 {
    background: none !important;
    color: var(--contact-heading-color) !important;
    -webkit-text-fill-color: var(--contact-heading-color) !important;
    text-shadow: 0 10px 28px rgba(0, 0, 0, 0.4);
}

.contact-info p,
.contact-method p {
    color: var(--contact-body-color) !important;
}

.contact-method h4 {
    color: var(--contact-heading-color) !important;
}

.contact-method a {
    color: var(--contact-link-color) !important;
}

.contact-method a:hover {
    color: var(--hero-highlight-color) !important;
}

.navbar .language-switcher {
    display: flex;
    align-items: center;
    gap: 2px;
    background: var(--lang-switcher-bg);
    border: 1px solid var(--lang-switcher-border);
    border-radius: 999px;
    padding: 3px;
    box-shadow: 0 18px 32px -24px rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(12px);
    position: relative;
    height: 40px;
}

.navbar .language-switcher:focus-within {
    box-shadow: 0 0 0 2px rgba(76, 175, 80, 0.28), inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.navbar .lang-btn {
    background: transparent;
    border: none;
    border-radius: 999px;
    color: var(--lang-switcher-text);
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 44px;
    height: 32px;
    padding: 0 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.navbar .lang-btn:hover {
    background: var(--lang-switcher-hover-bg);
    color: var(--lang-switcher-active-text);
}

.navbar .lang-btn.active {
    background: var(--lang-switcher-active-bg);
    color: var(--lang-switcher-active-text);
    box-shadow: 0 10px 22px -15px rgba(46, 125, 50, 0.35);
}

.navbar .lang-btn:focus-visible {
    outline: 2px solid rgba(188, 255, 222, 0.8);
    outline-offset: 2px;
}

.gallery-item {
    background: var(--gallery-card-bg);
    border: 1px solid var(--gallery-card-border);
    border-radius: 24px;
    box-shadow: var(--gallery-card-shadow);
    backdrop-filter: blur(12px);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
    position: relative;
    overflow: hidden;
}

.gallery-item::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top, var(--gallery-card-accent), transparent 60%);
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
}

.gallery-item:hover {
    transform: translateY(-8px);
    box-shadow: var(--gallery-card-shadow-hover);
}

.gallery-item:hover::before {
    opacity: 1;
}

.gallery-item .gallery-item-info {
    background: var(--gallery-info-bg);
    border: 1px solid var(--gallery-info-border);
    border-radius: 18px;
    padding: 1.15rem 1.25rem 1.35rem;
    box-shadow: var(--gallery-info-shadow);
    backdrop-filter: blur(8px);
}

.gallery-item .gallery-item-info h3 {
    color: var(--gallery-heading-color);
}

.gallery-item .gallery-item-info p {
    color: var(--gallery-body-color);
}

.gallery-item .gallery-item-info small {
    color: var(--gallery-small-color);
}

.gallery-item .painting-size {
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.95rem;
    margin-top: 0.5rem;
    margin-bottom: 0.75rem;
}

body.light-theme .gallery-item .gallery-item-info {
    background: var(--gallery-info-bg);
    border: 1px solid var(--gallery-info-border);
    box-shadow: var(--gallery-info-shadow);
}

body.light-theme .gallery-item .gallery-item-info h3 {
    color: var(--gallery-heading-color);
}

body.light-theme .gallery-item .gallery-item-info small,
body.light-theme .canvas-note,
body.light-theme .shipping-included {
    color: var(--gallery-price-secondary-color);
}

body.light-theme .gallery-item .painting-size {
    color: rgba(24, 28, 42, 0.85);
}

body.light-theme .canvas-note small {
    color: var(--gallery-small-color);
}

body.light-theme .price-display {
    color: var(--gallery-body-color);
}

body.light-theme .pricing-info {
    background: var(--gallery-pricing-bg);
    border: 1px solid var(--gallery-pricing-border);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.65);
}

body.light-theme .price-amount {
    color: var(--gallery-price-amount-color);
}

/* Light theme readability refinements */
body.light-theme .gallery-item {
    background: #ffffff !important;
    border-color: rgba(46, 125, 50, 0.15);
    box-shadow: 0 14px 32px -24px rgba(46, 125, 50, 0.28), 0 10px 22px -26px rgba(0, 0, 0, 0.25);
}

body.light-theme .gallery-item::before {
    background: radial-gradient(circle at top, rgba(125, 200, 150, 0.12), transparent 60%);
}

body.light-theme .gallery-item .gallery-item-info {
    background: #f7fbf8 !important;
    border: 1px solid rgba(46, 125, 50, 0.12);
    box-shadow: 0 12px 26px -20px rgba(46, 125, 50, 0.2), inset 0 0 0 1px rgba(255, 255, 255, 0.9);
}

body.light-theme .gallery-item .gallery-item-info h3 {
    color: #184631 !important;
    text-shadow: none;
}

body.light-theme .gallery-item .gallery-item-info p,
body.light-theme .price-display,
body.light-theme .canvas-note,
body.light-theme .shipping-included {
    color: rgba(28, 74, 51, 0.85) !important;
    text-shadow: none;
}

body.light-theme .gallery-item .gallery-item-info small,
body.light-theme .canvas-note small {
    color: rgba(28, 74, 51, 0.68) !important;
}

body.light-theme .pricing-info {
    background: #f2f9f4 !important;
    border: 1px solid rgba(46, 125, 50, 0.14) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.85);
}

body.light-theme .price-amount {
    color: #1f6f37 !important;
}

body.light-theme .gallery-item-actions .whatsapp-inquiry {
    box-shadow: 0 16px 26px -18px rgba(33, 150, 83, 0.45);
}

body.light-theme .gallery-item-actions .whatsapp-inquiry:focus-visible {
    box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.28);
}

body.light-theme .about-text h3 {
    color: #1d4d32;
}

body.light-theme .about-text .lead,
body.light-theme .about-text p {
    color: rgba(24, 68, 47, 0.88);
}

/* Sold state visuals */
.gallery-item.out-of-stock .gallery-image {
    filter: grayscale(0.25) saturate(0.65) brightness(0.82);
}

.gallery-item.out-of-stock .gallery-item-info,
.gallery-item.out-of-stock .pricing-info {
    opacity: 0.92;
}

.gallery-item.out-of-stock .price-amount,
.gallery-item.out-of-stock .shipping-included,
.gallery-item.out-of-stock .canvas-note,
.gallery-item.out-of-stock .gallery-item-info h3,
.gallery-item.out-of-stock .gallery-item-info p {
    color: #2b3f33;
}

.gallery-item .sold-status {
    display: inline-block;
    margin-top: 0.35rem;
    font-weight: 600;
    color: #2b3f33;
}

.out-of-stock-overlay {
    position: absolute;
    inset: 12px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(27, 41, 35, 0.65), rgba(27, 41, 35, 0.4));
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    text-transform: uppercase;
    letter-spacing: 0.45rem;
    color: rgba(245, 255, 247, 0.92);
    font-weight: 700;
    font-size: clamp(1.2rem, 3vw, 1.6rem);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.out-of-stock-overlay span {
    text-shadow: 0 12px 28px rgba(0, 0, 0, 0.45);
}

.whatsapp-inquiry.out-of-stock {
    background: rgba(76, 91, 83, 0.45) !important;
    color: rgba(232, 241, 236, 0.85) !important;
    cursor: not-allowed;
    box-shadow: none !important;
    pointer-events: none;
}

.whatsapp-inquiry.out-of-stock i {
    opacity: 0.6;
}

.pricing-info {
    background: var(--gallery-pricing-bg);
    border: 1px solid var(--gallery-pricing-border);
    border-radius: 16px;
    padding: 0.85rem 1.1rem;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.price-display {
    color: var(--gallery-body-color);
}

.price-amount {
    color: var(--gallery-price-amount-color);
}

.shipping-included,
.canvas-note {
    color: var(--gallery-price-secondary-color);
}

.canvas-note small {
    color: var(--gallery-small-color);
}

.price-tag {
    background: var(--gallery-price-tag-bg);
    color: var(--gallery-price-tag-color);
    box-shadow: 0 10px 25px -15px rgba(18, 187, 110, 0.85);
}

.gallery-item-actions .whatsapp-inquiry {
    background: var(--gallery-whatsapp-bg);
    color: var(--gallery-whatsapp-text);
}

.gallery-item-actions .whatsapp-inquiry:hover {
    background: var(--gallery-whatsapp-bg-hover);
}

@media (max-width: 900px) {
    .navbar .theme-switcher {
        padding: 3px 5px;
    }
    
    .navbar .lang-btn {
        padding: 6px 12px;
    }
}

@media (max-width: 768px) {
    .navbar .theme-toggle {
        --toggle-size: 30px;
        --icon-size: 17px;
        --ring-thickness: 2.5px;
        --crescent-shift: calc(var(--icon-size) * 0.16);
        --crescent-cut: calc(var(--icon-size) * 0.42);
        --sun-core-inset: calc(var(--icon-size) * 0.22);
        --sun-ray-offset: calc(var(--icon-size) * 0.42);
        --sun-ray-spread: calc(var(--icon-size) * -0.20);
    }
}

@media (max-width: 640px) {
    .navbar .nav-actions {
        gap: 0.55rem;
    }
    
    .navbar .theme-switcher,
    .navbar .language-switcher {
        transform: none;
        transform-origin: right center;
    }

    .navbar .theme-switcher {
        gap: 0.4rem;
    }
}

@media (max-width: 480px) {
    .navbar .theme-toggle {
        --toggle-size: 28px;
        --icon-size: 16px;
        --ring-thickness: 2px;
        --crescent-shift: calc(var(--icon-size) * 0.15);
        --crescent-cut: calc(var(--icon-size) * 0.40);
        --sun-core-inset: calc(var(--icon-size) * 0.22);
        --sun-ray-offset: calc(var(--icon-size) * 0.38);
        --sun-ray-spread: calc(var(--icon-size) * -0.18);
    }
}
/* Instagram Feed Styles */
.instagram-feed[data-instagram-autohide="true"] {
    display: none;
}

.instagram-feed[data-instagram-autohide="true"].is-visible {
    display: block;
}

.instagram-feed {
    margin-top: 60px;
    padding: 40px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.instagram-title {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 28px;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 12px;
    text-align: center;
    justify-content: center;
}

.instagram-title i {
    font-size: 32px;
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.instagram-subtitle {
    text-align: center;
    color: var(--text-secondary);
    font-size: 16px;
    margin-bottom: 32px;
}

.instagram-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 32px;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

.instagram-post {
    position: relative;
    aspect-ratio: 1;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.3s ease;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.instagram-post:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.3);
}

.instagram-post img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.instagram-post:hover img {
    transform: scale(1.05);
}

.instagram-post-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(240, 148, 51, 0.9), rgba(188, 24, 136, 0.9));
    opacity: 0;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 24px;
    backdrop-filter: blur(2px);
}

.instagram-overlay-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-align: center;
}

.instagram-overlay-text {
    font-size: 14px;
    font-weight: 600;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.instagram-post:hover .instagram-post-overlay {
    opacity: 1;
}

.instagram-post-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
    color: white;
    padding: 20px 12px 12px;
    font-size: 12px;
    line-height: 1.3;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.instagram-loading {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 20px;
    color: var(--text-secondary);
}

.spinner {
    border: 3px solid rgba(255, 255, 255, 0.1);
    border-left: 3px solid #e6683c;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    margin: 0 auto 16px;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.instagram-follow-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    color: white;
    text-decoration: none;
    padding: 16px 32px;
    border-radius: 50px;
    font-weight: 600;
    font-size: 16px;
    transition: all 0.3s ease;
    max-width: 280px;
    margin: 0 auto;
    box-shadow: 0 4px 16px rgba(240, 148, 51, 0.3);
}

.instagram-follow-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(240, 148, 51, 0.4);
    text-decoration: none;
    color: white;
}

.instagram-follow-btn i {
    font-size: 20px;
}

.instagram-error {
    grid-column: 1 / -1;
    text-align: center;
    padding: 40px 20px;
    color: var(--text-secondary);
    background: rgba(255, 87, 87, 0.1);
    border: 1px solid rgba(255, 87, 87, 0.2);
    border-radius: 12px;
}

/* Light theme adjustments */
body.light-theme .instagram-feed {
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

body.light-theme .instagram-post {
    background: rgba(0, 0, 0, 0.05);
    border: 1px solid rgba(0, 0, 0, 0.1);
}

body.light-theme .instagram-post:hover {
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

body.light-theme .spinner {
    border: 3px solid rgba(0, 0, 0, 0.1);
    border-left: 3px solid #e6683c;
}

/* Responsive design */
@media (max-width: 768px) {
    .instagram-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
    
    .instagram-title {
        font-size: 24px;
    }
    
    .instagram-follow-btn {
        padding: 14px 28px;
        font-size: 15px;
    }
    
    .instagram-feed {
        margin-top: 40px;
        padding: 30px 0;
    }
}

@media (max-width: 480px) {
    .instagram-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
    
    .instagram-title {
        font-size: 22px;
        flex-direction: column;
        gap: 8px;
    }
    
    .instagram-subtitle {
        font-size: 14px;
    }
}

/* Status Indicator */
.instagram-status-indicator {
    text-align: center;
    margin-top: 16px;
    padding: 8px 0;
}

.instagram-status-indicator small {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text-secondary);
    font-size: 0.85em;
    opacity: 0.7;
}

.instagram-status-indicator i {
    color: #4299e1;
}/* Moral Dualism Animation Styles */

#moral-dualism-canvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    pointer-events: none;
    opacity: 0.85;
    transition: opacity 0.5s ease;
}

/* Ensure canvas doesn't interfere with content */
.main-content {
    position: relative;
    z-index: 2;
}

/* Subtle canvas fade during theme transitions */
body.theme-transitioning #moral-dualism-canvas {
    opacity: 0.6;
    transition: opacity 0.3s ease;
}

/* Performance optimizations - will-change removed to reduce memory */
#moral-dualism-canvas {
    transform: translateZ(0); /* Force GPU acceleration */
}

/* Hide canvas on very small screens to preserve performance */
@media (max-width: 480px) and (max-height: 600px) {
    #moral-dualism-canvas {
        display: none;
    }
}

/* Reduce opacity on mobile for better readability */
@media (max-width: 768px) {
    #moral-dualism-canvas {
        opacity: 0.6;
    }
}

/* Enhanced visibility during dark theme */
body:not(.light-theme) #moral-dualism-canvas {
    opacity: 0.9;
}

/* Subtle presence during light theme */
body.light-theme #moral-dualism-canvas {
    opacity: 0.7;
}

/* Legal Pages Styling */
.legal-content {
    padding: 120px 20px 60px;
    max-width: 900px;
    margin: 0 auto;
}

.legal-content .inner {
    background: rgba(255, 255, 255, 0.95);
    padding: 40px;
    border-radius: 8px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1);
}

body.light-theme .legal-content .inner {
    background: rgba(255, 255, 255, 0.98);
    color: #2c3e50;
}

body:not(.light-theme) .legal-content .inner {
    background: rgba(30, 30, 40, 0.95);
    color: #f5f7fb;
}

.legal-content h2 {
    color: var(--hero-title-color);
    margin-bottom: 24px;
    font-size: 2em;
}

.legal-content h3 {
    color: var(--hero-title-color);
    margin-top: 32px;
    margin-bottom: 16px;
    font-size: 1.4em;
}

.legal-content p {
    margin-bottom: 16px;
    line-height: 1.8;
}

.legal-content ul {
    margin: 16px 0;
    padding-left: 24px;
}

.legal-content li {
    margin-bottom: 8px;
    line-height: 1.6;
}

@media (max-width: 768px) {
    .legal-content {
        padding: 100px 15px 40px;
    }
    
    .legal-content .inner {
        padding: 24px;
    }
}
