/**
 * Custom site header — template-parts/header-site.php
 * Loaded after style.css (design tokens).
 */
:root {
	--tls-ink: var(--ls-primary, #0d2b45);
	--tls-muted: var(--ls-on-surface-variant, #4a4e55);
	--tls-accent-bar: var(--ls-tertiary-fixed-dim, #c5a059);
	--tls-nav-active-underline: 2px;
	--tls-search-border: var(--ls-outline-variant, #c0c4cc);
}

.kadence-search-icon-wrap {
	display: none;
}

/* --- Accessibility --- */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background: #fff;
	clip: auto !important;
	clip-path: none;
	color: #000;
	display: block;
	height: auto;
	left: 5px;
	padding: 0.5rem 1rem;
	top: 5px;
	width: auto;
	z-index: 100000;
}

.tls-skip-link:focus {
	clip: auto !important;
	clip-path: none;
	height: auto;
	width: auto;
	padding: 0.75rem 1.25rem;
	background: var(--tls-ink);
	color: #fff;
	text-decoration: none;
	z-index: 100001;
}

/* --- Custom header shell --- */
.tls-site-header {
	position: sticky;
	top: 0;
	z-index: 200;
	background: #fff;
	transition: background-color 0.25s ease;
}

.tls-accent-bar {
	height: 3px;
	background: var(--tls-accent-bar);
}

.tls-header-shell {
	background-color: #fff;
	box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
	transition: background-color 0.25s ease, box-shadow 0.25s ease;
}

.tls-site-header.tls-header--scrolled .tls-header-shell {
	background-color: #fcfaf5;
	box-shadow: 0 8px 22px rgba(0, 0, 0, 0.08);
}

.tls-header-shell .tls-header-row {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding: 0.85rem var(--ls-page-gutter);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1rem;
}

@media (min-width: 901px) {
	.tls-header-shell .tls-header-row {
		padding-left: clamp(1.5rem, 5vw, 3rem);
		padding-right: clamp(1.5rem, 5vw, 3rem);
	}
}

/* Logo / title */
.tls-logo-wrap {
	flex: 0 1 auto;
	min-width: 0;
}

.tls-logo-wrap .custom-logo-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	max-width: 100%;
}

.tls-logo-wrap .custom-logo {
	max-height: clamp(36px, 10vw, 48px);
	width: auto;
	height: auto;
}

.tls-site-title-link {
	text-decoration: none;
	color: var(--tls-ink);
}

.tls-site-title {
	font-family: var(--ls-font-headline), Georgia, "Times New Roman", serif;
	font-size: clamp(1.05rem, 2vw, 1.35rem);
	font-weight: 700;
	font-style: italic;
	letter-spacing: -0.02em;
	margin: 0;
	line-height: 1.2;
}

.tls-site-title-link:hover .tls-site-title {
	opacity: 0.85;
}

/* Primary nav (desktop) */
.tls-nav {
	flex: 1 1 auto;
	display: flex;
	justify-content: center;
	min-width: 0;
}

.tls-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0 0.25rem;
}

.tls-nav-list > li {
	position: relative;
	margin: 0;
}

.tls-nav-list > li > a {
	display: block;
	position: relative;
	font-family: var(--ls-font-headline), Georgia, serif;
	font-size: 1rem;
	font-weight: 400;
	color: var(--tls-muted);
	text-decoration: none;
	padding: 0.35rem 0.85rem;
	margin: 0;
	border-bottom: var(--tls-nav-active-underline) solid transparent;
	transition: color 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}

.tls-nav-list > li > a::after {
	content: "";
	position: absolute;
	left: 0.85rem;
	right: 0.85rem;
	bottom: calc(-1 * var(--tls-nav-active-underline));
	height: var(--tls-nav-active-underline);
	background: currentColor;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
	opacity: 0.95;
}

.tls-nav-list > li > a:hover,
.tls-nav-list > li:hover > a {
	color: var(--ls-tertiary);
	border-bottom-color: var(--ls-tertiary);
	transform: translateY(-1px);
}

.tls-nav-list > li.current-menu-item > a,
.tls-nav-list > li.current-menu-ancestor > a,
.tls-nav-list > li.current_page_item > a {
	color: var(--tls-ink);
	font-weight: 600;
	border-bottom-color: var(--tls-ink);
}

.tls-nav-list > li > a:hover::after,
.tls-nav-list > li:hover > a::after,
.tls-nav-list > li.current-menu-item > a::after,
.tls-nav-list > li.current-menu-ancestor > a::after,
.tls-nav-list > li.current_page_item > a::after {
	transform: scaleX(1);
}

.tls-nav-list .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0.35rem 0;
	min-width: 12rem;
	position: absolute;
	left: 0;
	top: 100%;
	background: #fff;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
	border: 1px solid var(--tls-search-border);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease, visibility 0.2s ease;
	z-index: 50;
}

.tls-nav-list li:hover > .sub-menu,
.tls-nav-list li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
}

.tls-nav-list .sub-menu a {
	display: block;
	padding: 0.45rem 0.85rem;
	color: var(--tls-ink);
	text-decoration: none;
	font-family: var(--ls-font-headline), Georgia, serif;
	font-size: 0.95rem;
}

.tls-nav-list .sub-menu a:hover {
	background: rgba(0, 0, 0, 0.04);
	color: var(--ls-tertiary);
}

/* Groups nav + search on mobile drawer; on desktop children sit in the header row */
.tls-header-drawer {
	display: contents;
}

/* Search (sibling of nav + util for full-width mobile row) */
.tls-search-wrap {
	flex: 0 1 auto;
	min-width: 0;
	display: flex;
	align-items: center;
}

/* Cart + account icons */
.tls-header-util {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: 0.35rem 0.5rem;
	flex-shrink: 0;
}

.tls-search-form {
	display: flex;
	align-items: stretch;
	border: 1px solid var(--tls-search-border);
	border-radius: 0px;
	background: #fff;
	overflow: hidden;
	width: 100%;
	min-width: min(200px, 100%);
	max-width: min(280px, 100%);
}

.tls-search-form input {
	border-radius: 0px !important;
}

.tls-search-field {
	border: 0;
	margin: 0;
	padding: 0.45rem 0.65rem;
	font-family: var(--ls-font-headline), Georgia, serif;
	font-size: 0.9rem;
	color: var(--tls-ink);
	background: transparent;
	flex: 1;
	min-width: 0;
}

.tls-search-field::placeholder {
	color: var(--tls-muted);
}

.tls-search-field:focus {
	outline: none;
}

.tls-search-submit {
	border: 0;
	margin: 0;
	padding: 0 0.65rem;
	background: var(--ls-background);
	color: var(--tls-ink);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	opacity: 0.85;
	border-radius: 0px !important;
}

.tls-search-submit:hover {
	opacity: 1;
}

.tls-icon-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--tls-ink);
	text-decoration: none;
	padding: 0.35rem;
	line-height: 0;
}

.tls-icon-link:hover {
	opacity: 0.8;
}

.tls-icon svg {
	display: block;
}

.tls-cart-count-badge {
	position: absolute;
	top: 0;
	right: 0;
	min-width: 1rem;
	height: 1rem;
	padding: 0 0.2rem;
	font-size: 0.65rem;
	font-weight: 600;
	line-height: 1rem;
	text-align: center;
	background: var(--tls-accent-bar);
	color: #fff;
	border-radius: 999px;
	transform: translate(25%, -25%);
}

/* Mobile menu button */
.tls-menu-button {
	display: none;
	margin-left: auto;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	padding: 0;
	border: 1px solid var(--tls-search-border);
	border-radius: 2px;
	background: transparent;
	cursor: pointer;
	color: var(--tls-ink);
}

.tls-menu-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	font-size: 1.125rem;
}

.tls-menu-icon-close {
	display: none;
}

body.tls-nav-open .tls-menu-icon-bars {
	display: none;
}

body.tls-nav-open .tls-menu-icon-close {
	display: inline-flex;
}

@media screen and (max-width: 900px) {
	.tls-menu-button {
		display: inline-flex;
		order: 3;
		flex-shrink: 0;
	}

	.tls-logo-wrap {
		order: 1;
		flex: 1 1 auto;
		min-width: 0;
	}

	.tls-header-util {
		order: 2;
		margin-left: auto;
	}

	.tls-header-drawer {
		display: none;
		flex-direction: column;
		align-items: stretch;
		gap: 0.75rem;
		order: 4;
		flex: 1 1 100%;
		width: 100%;
		max-width: 100%;
		padding: 0.75rem 0 0.5rem;
		margin-top: 0;
		border-top: 1px solid rgba(0, 0, 0, 0.06);
	}

	body.tls-nav-open .tls-header-drawer {
		display: flex;
	}

	.tls-header-drawer .tls-search-wrap {
		order: -1;
		flex: 0 0 auto;
		width: 100%;
		max-width: 100%;
	}

	.tls-search-form {
		min-width: 0;
		max-width: none;
	}

	.tls-header-drawer .tls-nav {
		flex: 0 0 auto;
		width: 100%;
		display: block;
		padding: 0;
		border-top: 0;
		margin-top: 0;
	}

	.tls-nav-list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.tls-nav-list > li > a {
		padding: 0.65rem 0;
		border-bottom-width: 2px;
	}

	.tls-nav-list .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		display: block;
		box-shadow: none;
		border: 0;
		padding-left: 1rem;
	}
}

@media screen and (max-width: 380px) {
	.tls-header-shell .tls-header-row {
		gap: 0.5rem 0.65rem;
		padding-top: 0.65rem;
		padding-bottom: 0.65rem;
	}

	.tls-menu-button {
		width: 2.35rem;
		height: 2.35rem;
	}

	.tls-icon-link {
		padding: 0.3rem;
	}

	.tls-icon-link svg {
		width: 20px;
		height: 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.tls-nav-list > li > a,
	.tls-nav-list > li > a::after {
		transition: none !important;
	}
}
