/* Base theme - New Brand Identity */
:root {
	--bg: #ffffff; /* White main background */
	--surface: #ffffff; /* White for clean text areas */
	--surface-secondary: #c8c8e6; /* Light purple for secondary sections */
	--text: #1f193d; /* Deep dark purple for main text */
	--text-light: #ffffff; /* White text for dark backgrounds */
	--text-secondary: #b7b4d3; /* Light purple for secondary text */
	--muted: #b7b4d3; /* Light purple for muted text */
	--primary: #1f193d; /* Deep dark purple for primary elements */
	--primary-600: #b7b4d3; /* Light purple for hover states */
	--border: #c8c8e6; /* Light purple border */
	--shadow: 0 8px 24px rgba(31, 25, 61, 0.15);
	--shadow-soft: 0 4px 12px rgba(31, 25, 61, 0.1);
	--radius: 16px;
	--radius-small: 8px;
	
	/* Mascot Images - Easy to change all at once */
	--mascot-hero: url('../img/mascot-hero.webp');
	--mascot-about: url('../img/mascot-about.webp');
	--mascot-portfolio: url('../img/mascot-portfolio.webp');
	--mascot-contact: url('../img/mascot-work.webp'); /* Using work mascot for contact */
	--mascot-form: url('../img/mascot-work.webp'); /* Using work mascot for form */
	--mascot-work: url('../img/mascot-work.webp');
}

* { box-sizing: border-box; }
html { 
	scroll-behavior: smooth; 
	/* Performance optimizations */
	-webkit-overflow-scrolling: touch;
}
body {
	margin: 0;
	font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
	color: var(--text);
	background: var(--bg);
	line-height: 1.6;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	/* Performance optimizations */
	/* contain: layout style; REMOVED - breaks position: fixed */
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Typography - Poppins font family */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

/* Main content area - flex grow to push footer down */
main {
	flex: 1;
}

/* Rotating Text Animation - Professional Slide Down */
.rotating {
	position: relative;
	display: inline-block;
	min-height: 1.2em;
	overflow: hidden;
}

.rotating-word {
	position: absolute;
	top: -100%;
	left: 0;
	opacity: 0;
	transform: translateY(0);
	transition: all 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	color: var(--primary);
	font-weight: 700;
	white-space: nowrap;
	width: 100%;
}

.rotating-word.is-active {
	opacity: 1;
	transform: translateY(0);
	top: 0;
	position: relative;
}

/* Smooth exit animation for previous word */
.rotating-word:not(.is-active) {
	top: 100%;
	opacity: 0;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	letter-spacing: 0.5px;
	color: var(--text);
}

/* Text contrast fixes for different backgrounds */
.site-footer h1, .site-footer h2, .site-footer h3, .site-footer h4, .site-footer h5, .site-footer h6 {
	color: var(--text-light);
}

h1 { font-size: clamp(2.5rem, 5vw, 4rem); }
h2 { font-size: clamp(2rem, 4vw, 3rem); }
h3 { font-size: clamp(1.5rem, 3vw, 2rem); }

body, p, li, span {
	font-family: 'Poppins', sans-serif;
	font-weight: 400;
	color: var(--text);
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

.container {
	width: min(1100px, 92%);
	margin: 0 auto;
}

/* Accessibility */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	border: 0;
}

/* Header - Clean white theme */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(20px);
	height: 80px;
	padding: 20px 0;
}

/* Add top padding to body to account for fixed header */
body {
	padding-top: 80px;
}

/* Desktop navigation - ensure it works properly */
@media (min-width: 721px) {
	.nav-toggle {
		display: none !important;
	}
	
	.site-header .nav-list {
		display: flex !important;
		position: static !important;
		background: transparent !important;
		backdrop-filter: none !important;
		border: none !important;
		box-shadow: none !important;
		transform: none !important;
		opacity: 1 !important;
		visibility: visible !important;
		flex-direction: row !important;
		gap: 24px !important;
		min-width: auto !important;
		padding: 0 !important;
	}
	
	/* Force header layout on desktop */
	.header-inner {
		display: flex !important;
		align-items: center !important;
		justify-content: space-between !important;
		height: 100% !important;
	}
	
	/* Force teaser layout on desktop */
	.teaser-inner {
		display: grid !important;
		grid-template-columns: 0.9fr 1.1fr !important;
		gap: 24px !important;
		align-items: center !important;
	}
	
	/* Force projects grid layout on desktop */
	.grid--projects {
		grid-template-columns: repeat(3, 1fr) !important;
		gap: 18px !important;
		padding: 24px 0 !important;
		display: grid !important;
	}
	
	/* Force selected work grid layout on desktop */
	.grid--cards {
		grid-template-columns: repeat(3, 1fr) !important;
		gap: 18px !important;
		padding: 24px 0 !important;
		display: grid !important;
	}
}
	border-bottom: 1px solid var(--border);
	box-shadow: var(--shadow-soft);
}
.header-inner { 
	display: flex; 
	align-items: center; 
	justify-content: space-between; 
	height: 100%;
}
.brand { 
	font-family: 'Poppins', sans-serif;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--text);
	letter-spacing: 0.5px;
}

.nav-list { display: flex; gap: 24px; list-style: none; padding: 0; margin: 0; align-items: center; }
.nav a { 
	color: var(--text); 
	font-weight: 600;
	font-family: 'Poppins', sans-serif;
	transition: all 0.3s ease;
	padding: 8px 16px;
	border-radius: var(--radius-small);
}
.nav a[aria-current="page"], .nav a:hover { 
	color: var(--text-secondary); 
	background: rgba(183, 180, 211, 0.1);
	transform: translateY(-2px);
}

.nav-toggle { 
	display: none !important; 
	background: transparent; 
	border: 0; 
	padding: 12px; 
	margin: -8px 0 -8px -8px;
	cursor: pointer;
	z-index: 1000;
	position: relative;
}

.hamburger, .hamburger::before, .hamburger::after {
	width: 24px; 
	height: 3px; 
	background: var(--text); 
	border-radius: 2px; 
	position: relative; 
	display: block; 
	content: '';
	transition: all 0.3s ease;
}

.hamburger::before { 
	position: absolute; 
	top: -8px; 
	left: 0;
}

.hamburger::after { 
	position: absolute; 
	top: 8px; 
	left: 0;
}

/* Hamburger animation when active */
.nav-toggle[aria-expanded="true"] .hamburger {
	background: transparent;
}

.nav-toggle[aria-expanded="true"] .hamburger::before {
	transform: rotate(45deg);
	top: 0;
}

.nav-toggle[aria-expanded="true"] .hamburger::after {
	transform: rotate(-45deg);
	top: 0;
}

/* Buttons - New brand style */
.button { 
	display: inline-flex; 
	align-items: center; 
	gap: 12px; 
	padding: 14px 24px; 
	border-radius: var(--radius); 
	background: transparent; 
	color: var(--text); 
	border: 2px solid var(--text); 
	transition: all 0.3s ease;
	font-family: 'Poppins', sans-serif;
	font-weight: 600;
	font-size: 1rem;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	position: relative;
	overflow: hidden;
	box-shadow: var(--shadow-soft);
}
.button:hover { 
	background: var(--text); 
	border-color: var(--text);
	color: var(--text-light);
	transform: translateY(-3px) scale(1.05);
	box-shadow: var(--shadow);
}
.button--primary { 
	background: var(--text); 
	border-color: var(--text); 
	color: var(--text-light);
	box-shadow: var(--shadow-soft);
}
.button--primary:hover { 
	background: var(--text-secondary); 
	border-color: var(--text-secondary);
	color: var(--text);
	transform: translateY(-3px) scale(1.05);
	box-shadow: var(--shadow);
}
.nav .button--primary, .nav .button--primary:hover { 
	color: var(--text-light); 
	background: var(--text);
}

/* Hero section styling - buttons inherit from main button styles */

/* Hero - Clean white background with subtle pattern */
.hero { 
	padding: 40px 0 80px; 
	background: var(--bg);
	position: relative;
	overflow: hidden;
}
.hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="stars" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1" fill="rgba(255,140,66,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23stars)"/></svg>');
	opacity: 0.3;
	pointer-events: none;
}
.hero-inner { 
	display: grid; 
	grid-template-columns: 1.2fr 1fr; 
	gap: 60px; 
	align-items: center; 
	position: relative;
	z-index: 2;
}
.hero-title { 
	font-size: clamp(2.5rem, 5vw, 4rem); 
	line-height: 1.1; 
	margin: 0 0 24px; 
	color: var(--text);
	font-weight: 700;
}
.hero-subtitle { 
	color: var(--text); 
	margin: 0 0 32px; 
	font-size: 1.2rem;
	line-height: 1.6;
	font-weight: 400;
}
.hero-media { 
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}

.hero-media img { 
	border-radius: var(--radius); 
	filter: drop-shadow(0 0 20px rgba(200, 200, 230, 0.3)) drop-shadow(0 0 40px rgba(200, 200, 230, 0.15));
	border: none !important;
	max-width: 250px;
	width: 250px;
	height: 250px;
	object-fit: contain;
	transition: all 0.4s ease;
	cursor: pointer;
}

.hero-media img:hover {
	filter: drop-shadow(0 0 30px rgba(200, 200, 230, 0.5)) drop-shadow(0 0 60px rgba(200, 200, 230, 0.25)) drop-shadow(0 0 80px rgba(200, 200, 230, 0.1));
	transform: scale(1.02);
}
.hero-cta { 
	display: flex; 
	gap: 20px; 
	flex-wrap: wrap;
}

/* Sections - Light lavender background */
.section-title { 
	font-size: clamp(2rem, 4vw, 3rem); 
	margin: 0 0 24px; 
	color: var(--text);
	text-align: center;
}
.highlights { 
	padding: 80px 0; 
	background: var(--surface-secondary);
}

/* Highlights section text contrast - light background needs dark text */
.highlights h2,
.highlights h3,
.highlights h4,
.highlights h5,
.highlights h6 {
	color: var(--text) !important;
}

.highlights p,
.highlights li,
.highlights span {
	color: var(--text) !important;
}

/* Skills section text contrast - light background needs dark text */
.skills h2,
.skills h3,
.skills h4,
.skills h5,
.skills h6 {
	color: var(--text) !important;
}

.skills p,
.skills li,
.skills span {
	color: var(--text) !important;
}

.skills-list li span {
	color: var(--text) !important;
	font-weight: 600;
}

/* Call-to-action section text contrast - light background needs dark text */
.cta-bottom h2,
.cta-bottom h3,
.cta-bottom h4,
.cta-bottom h5,
.cta-bottom h6 {
	color: var(--text) !important;
}

.cta-bottom p,
.cta-bottom li,
.cta-bottom span {
	color: var(--text) !important;
}

/* Testimonials section text contrast - light background needs dark text */
.testimonials h2,
.testimonials h3,
.testimonials h4,
.testimonials h5,
.testimonials h6 {
	color: var(--text) !important;
}

.testimonials p,
.testimonials li,
.testimonials span,
.testimonials blockquote,
.testimonials figcaption {
	color: var(--text) !important;
}

/* About teaser section text contrast - light background needs dark text */
.about-teaser h2,
.about-teaser h3,
.about-teaser h4,
.about-teaser h5,
.about-teaser h6 {
	color: var(--text) !important;
}

.about-teaser p,
.about-teaser li,
.about-teaser span {
	color: var(--text) !important;
}

/* Grid & Cards - Playful design */
.grid { display: grid; gap: 30px; }
.grid--cards { grid-template-columns: repeat(3, 1fr); }
.card { 
	background: var(--surface-secondary); 
	border: 2px solid var(--border); 
	border-radius: var(--radius); 
	overflow: hidden; 
	box-shadow: var(--shadow-soft);
	transition: all 0.3s ease;
	position: relative;
}
.card:hover {
	transform: translateY(-8px) scale(1.02);
	box-shadow: var(--shadow);
	border-color: var(--text);
}
.card-body { 
	padding: 24px; 
	background: var(--surface-secondary);
}
.card h3 { 
	margin: 0 0 12px; 
	font-size: 1.3rem; 
	color: var(--text) !important;
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
}
.card p { 
	margin: 0 0 16px; 
	color: var(--text-secondary) !important; 
	line-height: 1.6;
	font-weight: 400;
}
.card-link { 
	color: var(--primary); 
	font-weight: 600; 
	text-decoration: none;
}

/* Page header - Business card style */
.page-header { 
	padding: 40px 0 80px; 
	background: linear-gradient(135deg, var(--surface-secondary) 0%, rgba(255, 255, 255, 0.8) 100%);
	position: relative;
	overflow: hidden;
}
.page-header::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="dots" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1" fill="rgba(255,140,66,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23dots)"/></svg>');
	opacity: 0.5;
	pointer-events: none;
}
.page-header .container {
	position: relative;
	z-index: 2;
}
.page-header h1 { 
	margin: 0 0 16px; 
	color: var(--text);
	text-align: center;
}
.page-header p { 
	margin: 0 0 32px; 
	color: var(--muted); 
	text-align: center;
	font-size: 1.1rem;
}

/* Cases */
.case { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; padding: 32px 0; border-bottom: 1px solid var(--border); }
.case:last-child { border-bottom: 0; padding-bottom: 64px; }
.case-media img { border-radius: var(--radius); border: 1px solid var(--border); }
.case-body h2 { margin: 0 0 6px; color: var(--text) !important; }
.case-meta { margin: 0 0 12px; color: var(--text) !important; }
.case-gallery { list-style: none; margin: 16px 0 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.case-gallery img { border-radius: 8px; border: 1px solid var(--border); }

/* Case section text contrast */
.case h1, .case h2, .case h3, .case h4, .case h5, .case h6 {
	color: var(--text) !important;
}
.case p, .case li, .case span {
	color: var(--text) !important;
}

/* About */
.about { padding: 0; }
.about.container { padding: 40px 0; }
.about-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 28px; align-items: start; }
.about-media img { border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow); }
.about-list { list-style: none; padding: 0; margin: 16px 0; color: var(--text) !important; }
.about-list li { margin: 6px 0; color: var(--text) !important; }
.about-cta { display: flex; gap: 12px; margin-top: 8px; }

/* About section text contrast */
.about h1, .about h2, .about h3, .about h4, .about h5, .about h6 {
	color: var(--text) !important;
}
.about p, .about li, .about span {
	color: var(--text) !important;
}

/* Contact */
.contact { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 28px; padding: 0 0 80px; }
.form { background: var(--surface); border: 1px solid var(--border); padding: 20px; border-radius: var(--radius); box-shadow: var(--shadow); }
.form-row { display: grid; gap: 8px; margin: 12px 0; }
label { font-weight: 600; }
input, textarea { 
	background: #ffffff; 
	color: var(--text); 
	border: 2px solid var(--border); 
	border-radius: var(--radius-small); 
	padding: 14px; 
	font: inherit;
	transition: all 0.3s ease;
}

/* Phone input specific styling */
input[type="tel"] {
	/* Mobile keyboards will show numeric keypad */
	-webkit-appearance: none;
	-moz-appearance: textfield;
}

/* Hide number input spinners on webkit browsers */
input[type="tel"]::-webkit-outer-spin-button,
input[type="tel"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
input:focus, textarea:focus { 
	outline: none;
	border-color: var(--primary); 
	box-shadow: 0 0 0 3px rgba(255, 140, 66, 0.1);
}
.form-actions { display: flex; align-items: center; gap: 12px; margin-top: 8px; flex-wrap: wrap; }
.form-note { color: var(--text) !important; }
.form-status { margin-top: 8px; color: var(--text) !important; }

/* Form validation styles */
.form input.error,
.form textarea.error {
	border-color: #e74c3c;
	box-shadow: 0 0 0 2px rgba(231, 76, 60, 0.1);
}

.field-error {
	display: block;
	color: #e74c3c;
	font-size: 0.875rem;
	margin-top: 0.25rem;
	font-weight: 500;
}

/* Form status messages */
.form-status {
	padding: 1rem;
	border-radius: var(--radius-small);
	font-weight: 500;
	margin-top: 1rem;
	transition: all 0.3s ease;
}

.form-status--loading {
	background: #e3f2fd;
	color: #1976d2;
	border: 1px solid #bbdefb;
}

.form-status--success {
	background: #e8f5e8;
	color: #2e7d32;
	border: 1px solid #c8e6c9;
}

.form-status--error {
	background: #ffebee;
	color: #c62828;
	border: 1px solid #ffcdd2;
}

.form-status--network-error {
	background: #fff3e0;
	color: #ef6c00;
	border: 1px solid #ffcc02;
}

.form-status--opening-email {
	background: #f3e5f5;
	color: #7b1fa2;
	border: 1px solid #e1bee7;
}

/* Contact section text contrast */
.contact h1, .contact h2, .contact h3, .contact h4, .contact h5, .contact h6 {
	color: var(--text) !important;
}
.contact p, .contact li, .contact span {
	color: var(--text) !important;
}

/* Form labels */
label {
	color: var(--text);
	font-weight: 600;
}

/* Footer Standardizzato - Dark theme */
.site-footer { 
	border-top: 1px solid rgba(255, 255, 255, 0.1); 
	padding: 40px 0; 
	background: rgba(45, 27, 78, 0.9);
	backdrop-filter: blur(20px);
	margin-top: auto; /* Spinge il footer in basso */
}

.footer-content { 
	display: flex; 
	align-items: center; 
	justify-content: space-between; 
	gap: 24px; 
	flex-direction: row; /* Desktop: copyright a sinistra, social a destra */
}
.social { 
	list-style: none; 
	display: flex; 
	gap: 20px; 
	padding: 0; 
	margin: 0; 
}
.social a {
	color: rgba(255, 255, 255, 0.8);
	transition: all 0.3s ease;
	padding: 8px 12px;
	border-radius: var(--radius-small);
}
.social a:hover {
	color: var(--primary);
	background: rgba(255, 140, 66, 0.1);
	transform: translateY(-2px);
}
.footer-copyright,
.footer-email {
	color: white !important;
	margin: 0; /* Rimuove margini default */
}

.footer-social {
	display: flex;
	gap: 16px;
}

.footer-social a {
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	transition: color 0.3s ease;
}

.footer-social a:hover {
	color: white;
}

.footer-email a {
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	transition: color 0.3s ease;
}

.footer-email a:hover {
	color: white;
}

/* Footer Standardizzato - Layout e Posizionamento */
.footer-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	flex-direction: row;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

.footer-copyright {
	flex: 1;
	text-align: left;
}

.footer-social {
	display: flex;
	gap: 16px;
	align-items: center;
}

.footer-email {
	flex: 1;
	text-align: right;
}

/* Fix specifico per About - Footer */
.about .footer-copyright,
.about .footer-email {
	color: white !important;
}

.about .footer-social a {
	color: rgba(255, 255, 255, 0.8) !important;
}

.about .footer-social a:hover {
	color: white !important;
}

/* Email Link Standard - mailto: */
.footer-email a {
	cursor: pointer;
	transition: all 0.3s ease;
	color: white !important;
	text-decoration: none;
}

.footer-email a:hover {
	color: #FFA500 !important;
	text-decoration: underline;
}

/* Responsive - Business card style */
@media (max-width: 960px) {
	.hero-inner { 
		grid-template-columns: 1fr; 
		gap: 40px;
		text-align: center;
	}
	.hero-media {
		order: -1;
	}
	.hero-media img {
		width: 200px;
		height: 200px;
		max-width: 200px;
		filter: drop-shadow(0 0 15px rgba(200, 200, 230, 0.3)) drop-shadow(0 0 30px rgba(200, 200, 230, 0.15));
	}
	
	.hero-media img:hover {
		filter: drop-shadow(0 0 25px rgba(200, 200, 230, 0.5)) drop-shadow(0 0 45px rgba(200, 200, 230, 0.25)) drop-shadow(0 0 65px rgba(200, 200, 230, 0.1));
		transform: scale(1.02);
	}
}
	.title-with-mascot { 
		flex-direction: column; 
		align-items: center; 
		text-align: center; 
		gap: 16px; 
	}
	.mascot--greeting { 
		width: 64px; 
		height: 64px; 
	}
	.grid--cards { grid-template-columns: repeat(2, 1fr); }
	.case, .about-grid, .contact { grid-template-columns: 1fr; }
	.mascot {
		width: 80px !important;
		height: 80px !important;
	}
}
/* Mobile Footer Standardizzato */
@media (max-width: 480px) {
	.footer-content { 
		flex-direction: column; 
		align-items: flex-start; 
		gap: 16px;
	}
	
	.footer-copyright,
	.footer-email {
		text-align: left;
		flex: none;
	}
	
	.footer-social {
		flex-direction: column;
		gap: 8px;
	}
}

@media (max-width: 720px) {
	.nav-toggle { 
		display: inline-block !important; 
		position: relative;
		z-index: 1001;
	}
	
	/* Force hamburger visibility on mobile */
	.site-header .nav .nav-toggle {
		display: inline-block !important;
	}
	
	/* Hide normal nav on mobile */
	.site-header .nav-list {
		display: none !important;
	}
	
	.nav-list { 
		position: fixed; 
		right: 4%; 
		top: 70px; 
		background: rgba(255, 255, 255, 0.98); 
		backdrop-filter: blur(10px);
		border: 1px solid var(--border); 
		border-radius: var(--radius); 
		padding: 20px; 
		flex-direction: column; 
		gap: 16px;
		box-shadow: var(--shadow);
		transform: translateY(-10px);
		opacity: 0;
		visibility: hidden;
		transition: all 0.3s ease;
		z-index: 1000;
		min-width: 200px;
		display: none;
	}
	
	.nav-list.active {
		display: flex;
		transform: translateY(0);
		opacity: 1;
		visibility: visible;
	}
	
	.nav-list li {
		width: 100%;
	}
	
	.nav-list a {
		display: block;
		padding: 12px 16px;
		border-radius: var(--radius);
		transition: all 0.3s ease;
	}
	
	.nav-list a:hover {
		background: rgba(31, 25, 61, 0.1);
		color: var(--text);
	} 
		box-shadow: var(--shadow); 
		display: none;
		backdrop-filter: blur(20px);
	}
	.hero-media img {
		width: 180px;
		height: 180px;
		max-width: 180px;
		filter: drop-shadow(0 0 12px rgba(200, 200, 230, 0.3)) drop-shadow(0 0 24px rgba(200, 200, 230, 0.15));
	}
	
	.hero-media img:hover {
		filter: drop-shadow(0 0 20px rgba(200, 200, 230, 0.5)) drop-shadow(0 0 40px rgba(200, 200, 230, 0.25)) drop-shadow(0 0 60px rgba(200, 200, 230, 0.1));
		transform: scale(1.02);
	}
	.nav-list a {
		color: var(--text);
		text-align: center;
	}
	.nav-list a:hover {
		color: var(--text-secondary);
		background: rgba(183, 180, 211, 0.1);
	}
	.nav-list.is-open { display: flex; }
	.grid--cards { grid-template-columns: 1fr; }
	.hero-cta {
		justify-content: center;
	}
	.button {
		padding: 12px 20px;
		font-size: 0.9rem;
	}
} 

/* Hero background animation */
.hero { position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(800px 200px at 20% -20%, rgba(59,130,246,0.18), rgba(0,0,0,0)), radial-gradient(900px 240px at 80% -30%, rgba(99,102,241,0.12), rgba(0,0,0,0)); filter: blur(0.5px); pointer-events: none; animation: floatBg 18s ease-in-out infinite alternate; }
@keyframes floatBg { from { transform: translateY(-6px); } to { transform: translateY(6px); } }

/* Rotating headline */
.rotating { display: inline-grid; position: relative; width: 8.5ch; }
.rotating-word { grid-area: 1/1; opacity: 0; transform: translateY(8px); transition: opacity 400ms ease !important, transform 400ms ease !important; color: var(--text-secondary); font-style: italic; }
.rotating-word.is-active { opacity: 1 !important; transform: translateY(0) !important; }

/* Hero rotating words - secondary color */
.hero .rotating-word {
	color: var(--text-secondary);
}

/* Universal Fixed Mascot - All Pages */
.mascot { 
	position: fixed !important; 
	bottom: 25px !important;
	right: 25px !important;
	width: 120px !important; 
	height: 120px !important; 
	/* Background set by JavaScript based on page */
	filter: drop-shadow(0 4px 12px rgba(45,27,78,0.15)) !important; 
	transform-origin: center !important; 
	transition: opacity 0.4s ease !important;
	z-index: 9999 !important;
	cursor: pointer !important;
	animation: gentleFloat 4s ease-in-out infinite !important;
	/* Hardware acceleration for smooth animations */
	will-change: transform, opacity !important;
	/* Ensure visibility */
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
	/* Force all positioning */
	top: auto !important;
	left: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	outline: none !important;
}

/* Mascot Work State (Hover) - Pseudo-element for smooth transition */
/* Second mascot on hover removed - keeping only main mascot */
.mascot.is-wave { animation: wave 900ms ease; }
.mascot.is-bounce { animation: bounce 600ms ease; }
.mascot.is-sparkle { animation: sparkle 1.2s ease; }

/* Page-specific mascot images - Set via JavaScript */

/* Gentle floating animation */
@keyframes gentleFloat {
	0%, 100% { transform: translateY(0px) rotate(0deg); }
	25% { transform: translateY(-8px) rotate(1deg); }
	50% { transform: translateY(-4px) rotate(0deg); }
	75% { transform: translateY(-12px) rotate(-1deg); }
}


/* Smooth image transition on hover - ONLY ONE IMAGE VISIBLE */
/* Mascot hover effect removed - keeping main mascot visible */

/* Speech Bubble System */
.speech-bubble {
	position: absolute;
	bottom: 100%;
	right: 0;
	background: #ffffff;
	border: 2px solid var(--text);
	border-radius: 12px;
	padding: 12px 16px;
	font-size: 14px;
	font-weight: 600;
	color: var(--text);
	white-space: nowrap;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px) scale(0.8);
	transition: opacity 0.2s, transform 0.2s;
	pointer-events: none;
	z-index: 10000 !important;
	box-shadow: 0 4px 12px rgba(31, 25, 61, 0.15);
	max-width: 200px;
	white-space: normal;
	text-align: center;
	line-height: 1.3;
}


/* Speech bubble tail */
.speech-bubble::after {
	content: '';
	position: absolute;
	top: 100%;
	right: 20px;
	width: 0;
	height: 0;
	border-left: 8px solid transparent;
	border-right: 8px solid transparent;
	border-top: 8px solid var(--text);
}

.speech-bubble::before {
	content: '';
	position: absolute;
	top: 100%;
	right: 22px;
	width: 0;
	height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #ffffff;
}

/* Speech bubble show state */
.speech-bubble.visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
}

/* Speech bubble animation */
@keyframes speechBubblePop {
	0% { transform: translateY(10px) scale(0.8); opacity: 0; }
	50% { transform: translateY(-2px) scale(1.05); opacity: 1; }
	100% { transform: translateY(0) scale(1); opacity: 1; }
}
@keyframes bubbleExplode {
	0% { transform: scale(1); opacity: 1; visibility: visible; }
	50% { transform: scale(1.3) rotate(3deg); opacity: 0.5; }
	100% { transform: scale(0); opacity: 0; visibility: hidden; }
}

.speech-bubble.is-popping {
	animation: speechBubblePop 0.4s ease-out;
}
.speech-bubble.exploding {
	animation: bubbleExplode 0.3s forwards;
	opacity: 0;
	visibility: hidden;
}

.mascot.is-celebrating {
	animation: celebrate 0.8s ease-in-out;
}

/* Celebration animation */
@keyframes celebrate {
	0% { transform: scale(1) rotate(0deg); }
	25% { transform: scale(1.2) rotate(-10deg); }
	50% { transform: scale(1.3) rotate(10deg); }
	75% { transform: scale(1.1) rotate(-5deg); }
	100% { transform: scale(1) rotate(0deg); }
}


@keyframes wave { 
	0%,100% { transform: rotate(0deg) scale(1); } 
	20% { transform: rotate(12deg) scale(1.02); } 
	40% { transform: rotate(-8deg) } 
	60% { transform: rotate(8deg) } 
	80% { transform: rotate(-4deg) } 
}

@keyframes bounce { 
	0%,100% { transform: translateY(0) scale(1); } 
	50% { transform: translateY(-10px) scale(1.05); } 
}

@keyframes sparkle { 
	0%,100% { transform: scale(1) rotate(0deg); } 
	25% { transform: scale(1.1) rotate(5deg); } 
	50% { transform: scale(1.05) rotate(-3deg); } 
	75% { transform: scale(1.08) rotate(2deg); } 
}

/* About teaser */
.about-teaser { padding: 28px 0 12px; }
.teaser-inner { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 24px; align-items: center; }
.teaser-media img { border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow); }
.teaser-copy p { color: var(--muted); }

/* Card hover overlay */
.card--hover .card-media { position: relative; }
.card--hover .card-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.0), rgba(0,0,0,0.7)); display: grid; align-content: end; gap: 10px; padding: 14px; opacity: 0; transform: translateY(6px); transition: opacity 220ms ease, transform 220ms ease; border-radius: calc(var(--radius) - 1px); color: white !important; }
.card--hover .card-overlay p { color: white !important; }
.card--hover .card-overlay .button { color: white !important; }
.card--hover:hover .card-overlay { opacity: 1; transform: translateY(0); }
.button--sm { padding: 8px 12px; font-size: 14px; }

/* Testimonials slider */
.testimonials { padding: 28px 0 8px; }
.slider { position: relative; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.slides { display: grid; grid-auto-flow: column; grid-auto-columns: 100%; transition: transform 400ms ease; }
.slide { padding: 22px; display: grid; gap: 8px; opacity: 0.6; }
.slide.is-active { opacity: 1; }
.slide blockquote { margin: 0; font-size: 18px; line-height: 1.5; }
.slide figcaption { color: var(--muted); }
.slider-nav { position: absolute; top: 50%; transform: translateY(-50%); background: #ffffff; border: 1px solid var(--border); width: 36px; height: 36px; border-radius: 999px; display: grid; place-items: center; cursor: pointer; box-shadow: var(--shadow); }
.slider-nav.prev { left: 8px; }
.slider-nav.next { right: 8px; }

/* Skills */
.skills { padding: 20px 0 8px; }
.skills-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.skills-list li { display: grid; grid-template-columns: 160px 1fr; gap: 14px; align-items: center; }
.skills .bar { background: #eef2ff; border: 1px solid var(--border); border-radius: 999px; height: 10px; overflow: hidden; }
.skills .bar-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--primary) 0%, #60a5fa 100%); border-radius: 999px; transition: width 900ms ease; }

/* Bottom CTA */
.cta-bottom { padding: 32px 0 64px; }
.cta-inner { background: linear-gradient(0deg, rgba(59,130,246,0.08), rgba(59,130,246,0.08)); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; display: grid; gap: 10px; place-items: center; text-align: center; }

/* Responsive tweaks */
@media (max-width: 720px) {
	.teaser-inner { grid-template-columns: 1fr; }
	.skills-list li { grid-template-columns: 1fr; gap: 8px; }
} 

/* Portfolio grid */
.grid--projects { 
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important; 
	gap: 18px !important; 
	padding: 24px 0 !important; 
}

/* Selected work grid */
.grid--cards { 
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important; 
	gap: 18px !important; 
	padding: 24px 0 !important; 
}
.project-item { display: block; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); background: var(--surface); box-shadow: var(--shadow); }
.project-media { position: relative; }
.project-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 280ms ease, filter 280ms ease; }
.project-overlay { position: absolute; inset: 0; display: grid; place-content: end start; gap: 8px; padding: 14px; background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(15,23,42,0.18)); color: #fff; opacity: 0; transition: opacity 220ms ease; }
.project-item:hover .project-overlay { opacity: 1; }
.project-item:hover img { transform: scale(1.04); filter: saturate(1.05); }

/* Case study enhancements */
.case-heading { margin: 14px 0 6px; font-size: 15px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }
.reveal { opacity: 0; transform: translateY(10px); transition: opacity 500ms ease, transform 500ms ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* Responsive grid - tablet */
@media (max-width: 960px) and (min-width: 721px) {
	.grid--projects { 
		grid-template-columns: repeat(2, 1fr) !important; 
		display: grid !important;
	}
	.grid--cards { 
		grid-template-columns: repeat(2, 1fr) !important; 
		display: grid !important;
	}
}

/* Responsive grid - mobile */
@media (max-width: 720px) {
	.grid--projects { 
		grid-template-columns: 1fr !important; 
		display: grid !important;
	}
	.grid--cards { 
		grid-template-columns: 1fr !important; 
		display: grid !important;
	}
} 

/* About hero */
.about-hero { padding: 40px 0 80px; padding-top: 120px; }
.about-hero-inner { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 28px; align-items: center; }
.about-hero-media { position: relative; }
.about-hero-media img { border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow); max-width: 80%; height: auto; }

/* Title with greeting mascot */
.title-with-mascot { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 10px; }
.title-with-mascot h1 { margin: 0; line-height: 1.2; flex: 1; }
.mascot--greeting { 
	width: 64px; 
	height: 64px; 
	background: var(--mascot-about) center/contain no-repeat; 
	filter: drop-shadow(0 4px 8px rgba(15,23,42,0.1)); 
	flex-shrink: 0;
	transform-origin: bottom center;
	transition: transform 0.3s ease;
}

/* About mascot hover animation */
.title-with-mascot:hover .mascot--greeting,
.about-cta:hover .mascot--greeting {
	animation: wave 0.6s ease-in-out;
}

/* Wave animation */
@keyframes wave {
	0%, 100% { transform: rotate(0deg); }
	10%, 30% { transform: rotate(-10deg); }
	20% { transform: rotate(10deg); }
	40%, 60% { transform: rotate(0deg); }
	70%, 90% { transform: rotate(-5deg); }
	80% { transform: rotate(5deg); }
}
.lead { color: var(--muted); font-size: 18px; }

/* About layout refinements */
.about .about-grid { grid-template-columns: 1.2fr 0.8fr; }
.icon-grid { list-style: none; padding: 0; margin: 10px 0 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 18px; align-items: center; }
.icon-grid .icon { width: 28px; height: 28px; display: grid; place-items: center; background: #eef2ff; color: var(--primary-600); border-radius: 8px; border: 1px solid var(--border); font-size: 16px; }
.icon-grid span { align-self: center; }

@media (max-width: 960px) {
	.about-hero-inner { grid-template-columns: 1fr; }
	.about .about-grid { grid-template-columns: 1fr; }
	.title-with-mascot { flex-direction: column; align-items: center; text-align: center; gap: 12px; }
	.mascot--greeting { width: 56px; height: 56px; }
} 

/* Contact extras */
.form-mascot { width: 72px; height: 72px; background: var(--mascot-form) center/contain no-repeat; margin-top: 8px; filter: drop-shadow(0 6px 12px rgba(15,23,42,0.08)); opacity: 0; transform: translateY(6px); transition: opacity 300ms ease, transform 300ms ease; }
.form-mascot.is-happy { opacity: 1; transform: translateY(0); animation: bounce 800ms ease; }
@keyframes bounce { 0%,100% { transform: translateY(0); } 30% { transform: translateY(-10px); } 60% { transform: translateY(0); } }

.social--detailed { display: grid; gap: 12px; }
.social--detailed li a { display: grid; grid-template-columns: 32px 1fr; gap: 10px; align-items: center; padding: 10px; border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface); box-shadow: var(--shadow); }
.social-icon { width: 32px; height: 32px; display: grid; place-items: center; background: #eef2ff; color: var(--primary-600); border-radius: 8px; border: 1px solid var(--border); font-weight: 700; }
.social-text { display: grid; line-height: 1.3; }
.social-text span { color: var(--muted); font-size: 14px; } 
/* Language Switcher */
.lang-switcher {
  position: relative;
  display: inline-block;
}

.lang-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 180ms ease;
}

.lang-toggle:hover {
  border-color: var(--text-secondary);
  color: var(--text-secondary);
  background: rgba(183, 180, 211, 0.1);
}

.lang-current {
  font-size: 12px;
  letter-spacing: 0.5px;
}

.lang-arrow {
  font-size: 10px;
  transition: transform 180ms ease;
}

.lang-switcher:hover .lang-arrow {
  transform: rotate(180deg);
}

.lang-menu {
  position: absolute;
  top: 100%;
  right: 0;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 8px 0;
  margin-top: 4px;
  min-width: 120px;
  z-index: 1000;
  list-style: none;
  backdrop-filter: blur(20px);
}

.lang-option {
  display: block;
  width: 100%;
  padding: 8px 16px;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: 14px;
  text-align: left;
  cursor: pointer;
  transition: all 150ms ease;
}

.lang-option:hover {
  background: rgba(183, 180, 211, 0.1);
  color: var(--text-secondary);
}

.lang-option[data-lang="en"] {
  font-weight: 600;
}

.lang-option[data-lang="it"] {
  font-style: italic;
}

/* Mobile language switcher */
@media (max-width: 720px) {
  .lang-menu {
    right: auto;
    left: 0;
    min-width: 100px;
  }
  
  .lang-toggle {
    padding: 6px 10px;
    font-size: 13px;
  }
}

/* ========================================
   PORTFOLIO CLEAN & ELEGANT STYLES
   ======================================== */

/* Portfolio Main Layout */
.portfolio-main {
  overflow-x: hidden;
}

/* Portfolio Header */
.portfolio-header {
  padding: 100px 0 60px;
  background: var(--bg);
  text-align: center;
  position: relative;
}

.portfolio-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  margin: 0 0 16px;
  color: var(--text);
  font-weight: 700;
}

.portfolio-subtitle {
  font-size: 1.2rem;
  color: var(--text-secondary);
  margin: 0 0 40px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* Project Sections */
.project-section {
  padding: 80px 0;
  background: var(--bg);
}

.project-section:nth-child(even) {
  background: var(--surface-secondary);
}

/* Darker purple text on purple background for even projects */
.project-section:nth-child(even) .project-description {
  color: var(--text);
  opacity: 0.8;
}

/* Same purple color for CTA text on purple background */
.project-section:nth-child(even) .cta-content p {
  color: var(--text);
  opacity: 0.8;
}


/* Project Header - Clean Layout */
.project-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  margin-bottom: 60px;
}

.project-intro {
  padding-right: 20px;
}

.project-title {
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  margin: 0 0 20px;
  color: var(--text);
  font-weight: 700;
  line-height: 1.2;
}

.project-description {
  font-size: 1.1rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}

.project-hero-image {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  background: var(--surface);
}

.project-hero-image img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.3s ease;
  background: var(--surface-secondary);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.project-hero-image img.loaded {
  opacity: 1;
}

.project-hero-image:hover img {
  transform: scale(1.02);
}

/* Case Study Section */
.case-study {
  margin-bottom: 60px;
}

.case-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  max-width: 1000px;
  margin: 0 auto;
}

.case-column {
  padding: 0 20px;
}

.case-heading {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 16px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.case-column p {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--text);
  margin: 0;
}

/* Project Gallery - Clean Grid */
.project-gallery {
  margin-top: 40px;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}

.gallery-item {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transition: all 0.3s ease;
  background: var(--surface);
  /* Hardware acceleration for smooth hover effects */
  will-change: transform;
  transform: translateZ(0);
}

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

.gallery-item img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transition: transform 0.3s ease;
  background: var(--surface-secondary);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.gallery-item img.loaded {
  opacity: 1;
}

.gallery-item:hover img {
  transform: scale(1.03);
}

/* Portfolio CTA */
.portfolio-cta {
  padding: 80px 0;
  background: var(--surface-secondary);
  text-align: center;
}

.cta-content h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  margin: 0 0 16px;
  color: var(--text);
}

.portfolio-cta .cta-content p {
  color: var(--text);
  opacity: 0.8;
}

.cta-content p {
  font-size: 1.1rem;
  color: var(--text-secondary);
  margin: 0 0 32px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* Fade-in Animation - Subtle */
.fade-in {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease, transform 0.4s ease;
  will-change: opacity, transform;
}

.fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Image loading states */
.gallery-item img {
  transition: opacity 0.3s ease;
}

.gallery-item img.loaded {
  opacity: 1;
}

.gallery-item img.load-error {
  opacity: 0.3;
  filter: grayscale(100%);
}

/* Responsive Design */
@media (max-width: 960px) {
  .project-header {
    grid-template-columns: 1fr;
    gap: 40px;
    text-align: center;
  }
  
  .project-intro {
    padding-right: 0;
  }
  
  .case-columns {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  
  .gallery-grid {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
  }
  
  .project-section {
    padding: 60px 0;
  }
}

@media (max-width: 720px) {
  .portfolio-header {
    padding: 80px 0 40px;
  }
  
  .project-section {
    padding: 50px 0;
  }
  
  .project-header {
    gap: 30px;
    margin-bottom: 40px;
  }
  
  .case-study {
    margin-bottom: 40px;
  }
  
  .gallery-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .gallery-item img {
    height: 180px;
  }
  
  .portfolio-cta {
    padding: 60px 0;
  }
  
  .case-column {
    padding: 0 10px;
  }
}

/* Mobile hamburger menu - properly styled */
@media (max-width: 720px) {
	/* Hide normal navigation on mobile */
	.site-header .nav-list {
		display: none !important;
	}
	
	/* Make header bigger and sticky */
	.site-header {
		position: fixed !important;
		top: 0;
		left: 0;
		right: 0;
		z-index: 1000;
		height: 80px !important;
		padding: 20px 0 !important;
		background: rgba(255, 255, 255, 0.95) !important;
		backdrop-filter: blur(10px) !important;
		border-bottom: 1px solid rgba(31, 25, 61, 0.1) !important;
	}
	
	/* Remove duplicate padding since it's already set globally */
	
	/* Show hamburger menu */
	.nav-toggle {
		display: inline-block !important;
		background: transparent;
		border: none;
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
		z-index: 1001;
	}
	
	/* Mobile menu positioning */
	.nav-list {
		position: fixed !important;
		right: 20px !important;
		top: 70px !important;
		background: rgba(255, 255, 255, 0.98) !important;
		backdrop-filter: blur(10px) !important;
		border: 1px solid var(--border) !important;
		border-radius: var(--radius) !important;
		padding: 20px !important;
		flex-direction: column !important;
		gap: 16px !important;
		box-shadow: var(--shadow) !important;
		transform: translateY(-10px) !important;
		opacity: 0 !important;
		visibility: hidden !important;
		transition: all 0.3s ease !important;
		z-index: 1000 !important;
		min-width: 200px !important;
		display: none !important;
	}
	
	.nav-list.active {
		display: flex !important;
		transform: translateY(0) !important;
		opacity: 1 !important;
		visibility: visible !important;
	}
	
	.nav-list li {
		width: 100%;
	}
	
	.nav-list a {
		display: block;
		padding: 12px 16px;
		border-radius: var(--radius);
		transition: all 0.3s ease;
	}
	
	.nav-list a:hover {
		background: rgba(31, 25, 61, 0.1);
		color: var(--text);
	}
}

/* CRITICAL: Force mascot visibility - highest specificity */
body .mascot,
html body .mascot,
html body div.mascot {
	position: fixed !important;
	bottom: 25px !important;
	right: 25px !important;
	width: 120px !important;
	height: 120px !important;
	/* Background will be set by page-specific rules below */
	z-index: 9999 !important;
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
	top: auto !important;
	left: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	outline: none !important;
}

/* Contact Page Layout - Two Column Grid */
.contact-grid {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 3rem;
	align-items: start;
}

.contact-aside {
	background: var(--surface-secondary);
	padding: 2rem;
	border-radius: var(--radius);
	position: sticky;
	top: 2rem;
}

.contact-aside h2 {
	margin: 0 0 1.5rem 0;
	color: var(--primary);
	font-size: 1.25rem;
	font-weight: 600;
}

.social--detailed {
	list-style: none;
	padding: 0;
	margin: 0;
}

.social--detailed li {
	margin-bottom: 1rem;
}

.social--detailed li:last-child {
	margin-bottom: 0;
}

.social--detailed a {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0.75rem;
	border-radius: var(--radius-small);
	text-decoration: none;
	color: var(--text);
	transition: all 0.2s ease;
}

.social--detailed a:hover {
	background: rgba(255, 255, 255, 0.5);
	transform: translateY(-2px);
}

.social-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	background: var(--primary);
	color: var(--text-light);
	border-radius: 50%;
	font-weight: 600;
	font-size: 0.875rem;
}

/* LinkedIn Icon */
.social-icon[aria-hidden="true"]:has(svg) {
	background: #0077B5;
}

.social-icon svg {
	width: 1.25rem;
	height: 1.25rem;
	fill: currentColor;
}

/* Instagram Icon */
.social-icon[aria-hidden="true"]:has(.instagram-icon) {
	background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}

.social-text {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.social-text strong {
	font-weight: 600;
	color: var(--primary);
}

.social-text span {
	font-size: 0.875rem;
	color: var(--text-secondary);
}

/* Responsive Design for Contact */
@media (max-width: 960px) {
	.contact-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	
	.contact-aside {
		position: static;
		order: -1;
	}
}

/* Mobile-specific responsive rules */
@media (max-width: 720px) {
	.container {
		padding: 0 16px;
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
	}
	
	/* Ensure body doesn't overflow */
	body {
		overflow-x: hidden;
		width: 100%;
		position: relative;
	}
	
	/* Prevent horizontal scroll completely */
	html {
		overflow-x: hidden;
		width: 100%;
	}
	
	/* Ensure all containers fit within viewport */
	.container, .header-inner, .hero-inner {
		max-width: 100vw;
		overflow-x: hidden;
	}
	
	/* Fix header positioning */
	.site-header {
		width: 100%;
		left: 0;
		right: 0;
		box-sizing: border-box;
	}
	
	/* Ensure all elements fit within viewport */
	* {
		box-sizing: border-box;
	}
	
	/* Fix mascot positioning for mobile */
	.mascot {
		position: fixed !important;
		bottom: 15px !important;
		right: 15px !important;
		width: 80px !important;
		height: 80px !important;
		max-width: 100%;
		z-index: 999;
	}
	
	/* Ensure hamburger menu is properly positioned */
	.nav-toggle {
		position: absolute;
		right: 15px;
		top: 50%;
		transform: translateY(-50%);
		z-index: 1001;
	}
	
	.nav-toggle {
		display: inline-block !important;
	}
	
	/* Force mascot to stay within viewport */
	.mascot {
		position: fixed !important;
		bottom: 15px !important;
		right: 15px !important;
		width: 80px !important;
		height: 80px !important;
		z-index: 999 !important;
	}
	
	/* Ensure no element can cause horizontal scroll */
	* {
		max-width: 100%;
	}
	
	/* Ensure images are responsive */
	img {
		max-width: 100%;
		height: auto;
	}
	
	/* Improve text readability on small screens */
	body {
		font-size: 14px;
		line-height: 1.5;
	}
	
	.hero-inner {
		padding: 40px 0;
	}
	
	.hero h1 {
		font-size: clamp(2rem, 8vw, 2.5rem);
		line-height: 1.2;
	}
	
	.hero p {
		font-size: 1rem;
		margin: 16px 0 24px;
	}
	
	.button {
		padding: 12px 20px;
		font-size: 0.9rem;
	}
	
	.site-header {
		padding: 16px 0;
	}
	
	.nav-list {
		right: 2%;
		top: 60px;
		padding: 16px;
	}
	
	.portfolio-header {
		padding: 60px 0 30px;
	}
	
	.project-section {
		padding: 40px 0;
	}
	
	.project-header {
		gap: 24px;
	}
	
	.gallery-item img {
		height: 200px;
	}
	
	.about-hero {
		padding: 30px 0 60px;
	}
	
	.contact-grid {
		gap: 1rem;
	}
	
	.contact-aside {
		padding: 20px;
	}
	
	.footer-inner {
		flex-direction: column;
		text-align: center;
		gap: 16px;
	}
}

/* Tablet responsive rules */
@media (max-width: 768px) {
	.container {
		padding: 0 24px;
	}
	
	.hero-inner {
		padding: 60px 0;
	}
	
	.project-section {
		padding: 60px 0;
	}
	
	.gallery-item img {
		height: 250px;
	}
}

@media (max-width: 720px) {
	.contact-grid {
		gap: 1.5rem;
	}
	
	.contact-aside {
		padding: 1.5rem;
	}
}
