:root {
	--primary: #f03d93;
	--primary-foreground: #ffffff;
	--background: #ffffff;
	--foreground: #0f172a;
	--card: #fdfdfd;
	--border: #f1f5f9;
}

.dark {
	--background: #0a0a0c;
	--foreground: #f8fafc;
	--card: #141417;
	--border: #1f1f23;
}

body {
	font-family: 'Inter', sans-serif;
	background-color: var(--background);
	color: var(--foreground);
	transition: background-color 0.4s ease, color 0.4s ease;
}

h1, h2, h3 { font-family: 'Poppins', sans-serif; }

.bg-primary { background-color: var(--primary); }
.text-primary { color: var(--primary); }
.border-primary { border-color: var(--primary); }
.btn-primary { 
	background-color: var(--primary); 
	color: var(--primary-foreground);
	box-shadow: 0 4px 14px 0 rgba(240, 61, 147, 0.3);
}

.gradient-bg {
	background: linear-gradient(135deg, var(--primary) 0%, #ff7eb3 100%);
}

/* Mobile Menu Animation */
#mobile-menu-container {
	transition: transform 0.3s ease-in-out;
	transform: translateX(100%);
}
#mobile-menu-container.open {
	transform: translateX(0);
}
#menu-backdrop {
	transition: opacity 0.3s ease;
	opacity: 0;
	pointer-events: none;
}
#menu-backdrop.open {
	opacity: 1;
	pointer-events: auto;
}

#theme-controller {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 40;
}