/**
 * Header Styles for StudioM
 * Scoped to .sm-header to avoid global conflicts
 * Matches studiom.ai header design - Squarespace inset header style
 *
 * Controls:
 * - Logo positioning and sizing (34-38px height)
 * - Navigation typography (Chivo font, 15px, light weight)
 * - Header layout and spacing (111px height, 1200px max-width)
 * - Mobile responsive overlay (dark background, centered white links)
 * - Neutralizes WordPress global padding artifacts
 */

.sm-header {
	background: #ffffff;
	border-bottom: 1px solid #e5e7eb;
	position: sticky;
	top: 0;
	z-index: 100;
	min-height: 111px;
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0;
	font-family: var(--font-chivo, 'Chivo', sans-serif);
}

/* Neutralize WordPress global padding classes within header */
.sm-header.has-global-padding,
.sm-header .has-global-padding {
	padding-left: 0;
	padding-right: 0;
}

/* Container wrapper - exact inset match with reference */
.sm-container {
	max-width: 1200px;
	margin: 0 auto;
	padding-left: 24px;
	padding-right: 24px;
	width: 100%;
}

/* Ensure container controls horizontal spacing inside header */
.sm-header .sm-container {
	padding-left: 24px;
	padding-right: 24px;
}

.sm-header__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 2rem;
	width: 100%;
}

/* Logo - constrain to 34-38px height to match reference */
.sm-header .wp-block-site-logo {
	margin: 0;
	line-height: 1;
}

.sm-header .wp-block-site-logo img {
	max-height: 36px;
	width: auto;
	height: auto;
}

.sm-header .wp-block-site-logo a {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}

.sm-header .wp-block-site-logo a:hover {
	opacity: 0.85;
	transition: opacity 0.2s ease;
}

/* Navigation - Chivo font, light weight, precise spacing */
.sm-nav {
	flex: 1;
	display: flex;
	justify-content: flex-end;
	font-family: var(--font-chivo, 'Chivo', sans-serif);
}

.sm-nav .wp-block-navigation__responsive-container {
	gap: 30px;
}

.sm-nav .wp-block-navigation-item {
	margin: 0;
}

.sm-nav .wp-block-navigation-item a {
	padding: 0.5rem 0;
	font-size: 15px;
	font-weight: 300;
	color: #111111;
	text-decoration: none;
	transition: all 0.15s ease;
	letter-spacing: 0.03em;
	position: relative;
}

.sm-nav .wp-block-navigation-item a:hover,
.sm-nav .wp-block-navigation-item a:focus {
	color: #111111;
	text-decoration: underline;
	text-underline-offset: 6px;
	text-decoration-thickness: 1px;
}

/* Active/current page state */
.sm-nav .wp-block-navigation-item.current-menu-item a,
.sm-nav .wp-block-navigation-item .wp-block-navigation-item__content[aria-current="page"] {
	text-decoration: underline;
	text-underline-offset: 6px;
	text-decoration-thickness: 1px;
}

/* Mobile burger button styling - simple clean lines */
.sm-header .wp-block-navigation__responsive-container-open {
	color: #111111;
	border: none;
	background: transparent;
	padding: 8px;
}

.sm-header .wp-block-navigation__responsive-container-open:hover {
	background: rgba(0, 0, 0, 0.05);
}

.sm-header .wp-block-navigation__responsive-container-close {
	color: #ffffff;
	position: absolute;
	top: 1rem;
	right: 1rem;
	border: none;
	background: transparent;
}

/* Mobile overlay - dark background with white centered links */
.sm-nav .wp-block-navigation__responsive-container.is-menu-open {
	background: #111111;
	padding: 4rem 24px 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
	width: 100%;
	max-width: 400px;
}

/* Strict isolation: hide ALL non-navigation content in mobile overlay */
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content > *:not(.wp-block-navigation__responsive-container-content):not(.wp-block-navigation__container) {
	display: none !important;
}

.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-post-content,
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .entry-content,
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-post-content *,
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .entry-content *,
.sm-nav .wp-block-navigation__responsive-container.is-menu-open p:not(.wp-block-navigation-item):not(.wp-block-navigation-item *),
.sm-nav .wp-block-navigation__responsive-container.is-menu-open h1:not(.wp-block-navigation-item *),
.sm-nav .wp-block-navigation__responsive-container.is-menu-open h2:not(.wp-block-navigation-item *),
.sm-nav .wp-block-navigation__responsive-container.is-menu-open h3:not(.wp-block-navigation-item *),
.sm-nav .wp-block-navigation__responsive-container.is-menu-open blockquote:not(.wp-block-navigation-item *),
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-buttons:not(.wp-block-navigation-item *),
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-button:not(.wp-block-navigation-item *) {
	display: none !important;
}

/* Ensure navigation list is visible */
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	display: flex !important;
	flex-direction: column;
}

/* Mobile overlay link styling - white text, centered, larger */
.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
	color: #ffffff;
	font-size: 18px;
	text-align: center;
	padding: 18px 0;
}

/* Mobile navigation styles */
@media (max-width: 600px) {
	.sm-header {
		min-height: 80px;
	}

	.sm-container {
		padding-left: 16px;
		padding-right: 16px;
	}

	.sm-header .wp-block-site-logo img {
		max-height: 32px;
	}

	.sm-nav .wp-block-navigation__responsive-container:not(.is-menu-open) {
		display: none;
	}

	.sm-nav .wp-block-navigation__responsive-container.is-menu-open {
		padding: 3rem 24px 2rem;
	}

	.sm-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
		padding: 18px 0;
		display: block;
		font-size: 18px;
		text-align: center;
		color: #ffffff;
	}
}

@media (min-width: 601px) and (max-width: 1024px) {
	.sm-header {
		min-height: 90px;
	}

	.sm-container {
		padding-left: 24px;
		padding-right: 24px;
	}

	.sm-nav .wp-block-navigation__responsive-container {
		gap: 28px;
	}

	.sm-nav .wp-block-navigation-item a {
		font-size: 15px;
	}
}

@media (min-width: 1025px) {
	.sm-header {
		min-height: 111px;
	}

	.sm-container {
		padding-left: 24px;
		padding-right: 24px;
	}
}
