/* 
 * Global Styles
 * Theme: Mehndi Universe (Mehndi Muse Exact Redesign)
 */

:root {
	/* Colors exactly matching Mehndi Muse screenshots */
	--mu-primary: #a56f5a; /* Terracotta/Brown */
	--mu-primary-hover: #8f5c49;
	--mu-bg: #fdfaf6; /* Warm cream background */
	--mu-surface: #ffffff;
	--mu-text-main: #3d3d3d; /* Dark grey, almost black */
	--mu-text-light: #737373; /* Subtle grey for meta */
	--mu-border: #eee9e0; /* Soft warm border */
	
	/* Typography */
	--mu-font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--mu-font-heading: 'Playfair Display', serif; /* Elegant heading font */
	
	/* Spacing & Layout */
	--mu-container-max: 1200px;
	--mu-spacing-xs: 0.5rem;
	--mu-spacing-sm: 1rem;
	--mu-spacing-md: 2rem;
	--mu-spacing-lg: 3rem;
	--mu-spacing-xl: 5rem;
	
	/* Shadows & Radii */
	--mu-radius: 12px; /* Slightly softer corners */
	--mu-transition: all 0.3s ease;
}

/* Reset & Basics */
*, *::before, *::after { box-sizing: border-box; }
body {
	margin: 0;
	font-family: var(--mu-font-family);
	background-color: var(--mu-bg);
	color: var(--mu-text-main);
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--mu-primary); text-decoration: none; transition: var(--mu-transition); }
a:hover { color: var(--mu-primary-hover); }
h1, h2, h3, h4, h5, h6 {
	font-family: var(--mu-font-heading);
	margin-top: 0;
	font-weight: 600;
	line-height: 1.2;
	color: var(--mu-text-main);
}
.container {
	max-width: var(--mu-container-max);
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* Skip link for accessibility */
.skip-link {
	position: absolute;
	top: -100px;
	left: 0;
	background: var(--mu-primary);
	color: #fff;
	padding: 8px;
	z-index: 9999;
}
.skip-link:focus { top: 0; }

/* -----------------------------------------
   Header & Top Bar
----------------------------------------- */
.top-bar {
	background-color: var(--mu-primary);
	color: #fff;
	text-align: center;
	padding: 0.5rem;
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.5px;
}
.top-bar a {
	color: #fff;
	text-decoration: underline;
}

.site-header {
	background-color: var(--mu-bg);
	border-bottom: 1px solid var(--mu-border);
	position: sticky;
	top: 0;
	z-index: 100;
}
.header-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 70px;
}

.site-branding .site-title {
	font-family: var(--mu-font-heading);
	font-size: 1.8rem;
	font-weight: 700;
	color: var(--mu-primary);
	text-decoration: none;
}

.header-nav-wrap {
	display: flex;
	align-items: center;
}

/* Navigation */
.main-nav {
	display: none; /* Mobile first */
}
@media (min-width: 992px) {
	.menu-toggle { display: none !important; }
	.main-nav {
		display: block;
	}
	.main-nav ul {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		gap: 2rem;
	}
	.main-nav a {
		color: var(--mu-text-main);
		font-weight: 500;
		font-size: 0.95rem;
		padding: 0.5rem 0;
		position: relative;
	}
	.main-nav a::after {
		content: '';
		position: absolute;
		width: 0;
		height: 2px;
		bottom: 0;
		left: 0;
		background-color: var(--mu-primary);
		transition: width 0.3s ease;
	}
	.main-nav a:hover { color: var(--mu-primary); }
	.main-nav a:hover::after { width: 100%; }
}

/* Mobile Menu Toggle */
.menu-toggle {
	display: block;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
	margin-left: 1rem;
}
.menu-toggle-icon, .menu-toggle-icon::before, .menu-toggle-icon::after {
	display: block;
	width: 24px;
	height: 2px;
	background-color: var(--mu-primary);
	transition: var(--mu-transition);
}
.menu-toggle-icon::before { content: ''; transform: translateY(-6px); }
.menu-toggle-icon::after { content: ''; transform: translateY(4px); }

/* Mobile Menu Open State */
body.menu-is-open .main-nav {
	display: block;
	position: absolute;
	top: 70px;
	left: 0;
	right: 0;
	background: var(--mu-bg);
	border-bottom: 1px solid var(--mu-border);
	padding: var(--mu-spacing-md);
	box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}
body.menu-is-open .main-nav ul {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin: 0;
	padding: 0;
	list-style: none;
}
body.menu-is-open .main-nav a {
	font-size: 1.1rem;
	font-weight: 500;
	color: var(--mu-text-main);
}
body.menu-is-open .menu-toggle-icon { background: transparent; }
body.menu-is-open .menu-toggle-icon::before { transform: rotate(45deg) translate(2px, 2px); background-color: var(--mu-primary); }
body.menu-is-open .menu-toggle-icon::after { transform: rotate(-45deg) translate(2px, -2px); background-color: var(--mu-primary); }

/* -----------------------------------------
   Footer
----------------------------------------- */
.site-footer {
	background-color: #f6efe6; /* Match screenshot footer */
	padding: var(--mu-spacing-xl) 0 var(--mu-spacing-md);
	margin-top: var(--mu-spacing-xl);
}
.footer-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--mu-spacing-lg);
	margin-bottom: var(--mu-spacing-lg);
}
@media (min-width: 768px) {
	.footer-inner { grid-template-columns: 2fr 1fr 1fr 1fr; }
}

.footer-brand h3 { 
	color: var(--mu-primary);
	font-size: 1.5rem;
	margin-bottom: 1rem;
}
.footer-brand p { 
	color: var(--mu-text-main);
	font-size: 0.85rem;
	line-height: 1.6;
}
.footer-links h4 { 
	margin-bottom: 1.2rem;
	font-size: 1rem;
	font-family: var(--mu-font-family); /* Sans-serif for footer headers in screenshot */
	font-weight: 600;
}
.footer-links ul { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 0.8rem; }
.footer-links a { 
	color: var(--mu-text-main);
	font-size: 0.85rem;
}
.footer-links a:hover { color: var(--mu-primary); }

.footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: var(--mu-spacing-md);
	border-top: 1px solid rgba(0,0,0,0.05);
	color: var(--mu-text-light);
	font-size: 0.75rem;
}

/* -----------------------------------------
   Utilities
----------------------------------------- */
.btn {
	display: inline-block;
	background-color: var(--mu-primary);
	color: #fff;
	padding: 0.85rem 2rem;
	border-radius: 4px; /* Harder corners like screenshot */
	font-weight: 600;
	font-size: 0.9rem;
	border: none;
	cursor: pointer;
	text-align: center;
	letter-spacing: 0.5px;
}
.btn:hover { background-color: var(--mu-primary-hover); color: #fff; }

.btn-block {
	display: block;
	width: 100%;
}

.btn-outline {
	background-color: transparent;
	color: var(--mu-text-main);
	border: 1px solid var(--mu-border);
}
.btn-outline:hover {
	background-color: var(--mu-bg);
	color: var(--mu-primary);
}

.btn-clear-search {
	margin-top: 1rem;
	padding: 0.5rem 1rem;
	font-size: 0.8rem;
}

.search-status-msg {
	padding: 2rem;
	grid-column: 1/-1;
	text-align: center;
}
.search-status-error {
	color: red;
}

.section-title {
	text-align: center;
	margin-bottom: var(--mu-spacing-lg);
}
.section-title h2 { 
	font-size: 2.2rem;
	margin-bottom: 0.5rem;
	color: var(--mu-text-main);
}

.hidden { display: none !important; }
