/* ─── Site Header ─── */

/* ── Scoped variables ── */

.op-header {
	--_header-h: 80px;
	--_header-h-compact: 51px;
	--_admin-h: 0px;
}

body.admin-bar .op-header {
	--_admin-h: 32px;
}

@media screen and (max-width: 782px) {
	body.admin-bar .op-header {
		--_admin-h: 46px;
	}
}

@media (max-width: 600px) {
	.op-header {
		--_header-h: 64px;
	}
}

/* Scroll-padding fallback (JS overrides with admin-bar-aware value) */
html {
	scroll-padding-top: 80px;
}

@media (max-width: 600px) {
	html {
		scroll-padding-top: 64px;
	}
}

/* ── Bar (fixed glass strip — frontend only) ── */
/* In the editor the bar stays in normal flow so the template part
   wrapper keeps its height and remains clickable.                  */

.op-header__bar {
	background-color: rgba(var(--op-rgb-parchment), 0.8);
	backdrop-filter: blur(9px);
	-webkit-backdrop-filter: blur(9px);
	transition: box-shadow 0.3s ease;
}

body:not(.block-editor-iframe__body) .op-header__bar {
	position: fixed;
	top: var(--_admin-h);
	left: 0;
	right: 0;
	z-index: 1001;
}

.op-header__bar.is-scrolled {
	box-shadow: 0 1px 8px rgba(var(--op-rgb-deep-ink), 0.06);
}

.op-header__bar-inner {
	max-width: var(--op-container);
	margin: 0 auto;
	padding: 0 var(--op-section-px);
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--_header-h);
}

/* ── Logo ── */

.op-header__logo {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	text-decoration: none;
	outline: none;
}

.op-header__logo:hover {
	text-decoration: none;
}

.op-header__logo:focus,
.op-header__logo:focus-visible {
	outline: none;
	box-shadow: none;
}

.op-header__logo-name {
	font-family: var(--wp--preset--font-family--logo);
	font-weight: 600;
	font-size: var(--wp--preset--font-size--lg);
	letter-spacing: -0.01em;
	color: var(--op-color-deep-ink);
	line-height: 1;
	transition:
		color 0.25s ease,
		transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	display: inline-block;
	transform-origin: left baseline;
}

.op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-dusk);
	transform: scale(1.06);
}

.op-header__logo:active .op-header__logo-name {
	color: var(--op-color-dusk);
	transform: scale(0.94);
}

.op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header__logo-suffix {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--xs);
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--op-color-dusk);
	line-height: 1;
}

/* ── Right-side actions ── */

.op-header__actions {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--sm);
}

/* ── Desktop top nav (flyout used on tablet/mobile) ── */

.op-header__nav {
	display: none;
}

.op-header__nav-list {
	display: flex;
	align-items: center;
	gap: clamp(1.25rem, 2.4vw, 2.25rem);
	margin: 0;
	padding: 0;
	list-style: none;
}

.op-header__nav-list a {
	font-family: var(--wp--preset--font-family--heading);
	font-size: 0.9375rem;
	font-weight: 500;
	letter-spacing: -0.01em;
	color: var(--op-color-deep-ink);
	text-decoration: none;
	transition: color 0.2s ease;
}

.op-header__nav-list a:hover,
.op-header__nav-list li.is-active > a {
	color: var(--op-color-dusk);
}

/* Navy header variant — light nav links */
.op-header.is-style-dusk .op-header__nav-list a {
	color: rgba(var(--op-rgb-parchment), 0.7);
}

.op-header.is-style-dusk .op-header__nav-list a:hover,
.op-header.is-style-dusk .op-header__nav-list li.is-active > a {
	color: var(--op-color-parchment);
}

@media (min-width: 900px) {
	.op-header .op-header__nav {
		display: block;
	}

	.op-header .op-header__burger {
		display: none;
	}
}

/* ── Hamburger ── */

.op-header__burger {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	padding: 10px;
	border: none;
	background: none;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
	outline: none;
}

/* Override WP focus outlines */
.op-header__burger:focus,
.op-header__burger:focus-visible {
	outline: none;
	box-shadow: none;
}

.op-header__burger-line {
	display: block;
	width: 20px;
	height: 2px;
	background-color: var(--op-color-deep-ink);
	border-radius: 1px;
	transition:
		transform 0.3s ease,
		opacity 0.2s ease;
	transform-origin: center;
}

.op-header__burger.is-active .op-header__burger-line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.op-header__burger.is-active .op-header__burger-line:nth-child(2) {
	opacity: 0;
}

.op-header__burger.is-active .op-header__burger-line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ── Off-canvas menu ── */

.op-header__menu {
	pointer-events: none;
	visibility: hidden;
}

body:not(.block-editor-iframe__body) .op-header__menu {
	position: fixed;
	top: var(--_admin-h);
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1000;
}

.op-header__menu.is-open {
	pointer-events: auto;
	visibility: visible;
}

.op-header__menu-overlay {
	position: absolute;
	inset: 0;
	background: rgba(var(--op-rgb-deep-ink), 0.4);
	opacity: 0;
}

.op-header__menu-panel {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(400px, 80vw);
	background-color: rgba(var(--op-rgb-parchment), 0.8);
	backdrop-filter: blur(9px);
	-webkit-backdrop-filter: blur(9px);
	padding: calc(var(--_header-h) + 32px) 40px 20px 40px;
	transform: translateX(100%);
	display: flex;
	flex-direction: column;
}

/* ── Menu list ── */

.op-header__menu-nav {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
}

.op-header__menu-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	flex: 1;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.op-header__menu-list li {
	border-bottom: 1px solid rgba(var(--op-rgb-deep-ink), 0.08);
	flex-shrink: 0;
}

.op-header__menu-list a {
	display: block;
	padding: var(--_menu-item-py, 12px) 0;
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--_menu-item-fs, 1.1rem);
	font-weight: 600;
	color: var(--op-color-deep-ink);
	text-decoration: none;
	transition:
		color 0.2s ease,
		padding-left 0.2s ease;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

/* Featured / XL menu items — larger baseline, shrink less */
.op-header__menu-list li[data-featured='1'] a {
	font-size: var(--_menu-item-xl-fs, 2rem);
	padding-top: var(--_menu-item-xl-py, 22px);
	padding-bottom: var(--_menu-item-xl-py, 22px);
	font-weight: 700;
	letter-spacing: -0.03em;
}

/* Unfeatured items — animated visibility */
.op-header__menu-list li[data-featured='0'] {
	overflow: hidden;
	/* height + opacity managed via JS for animation; visible by default */
}

.op-header__menu-list li.is-active > a {
	color: var(--op-color-dusk);
	padding-left: 8px;
}

.op-header__menu-list a:hover {
	color: var(--op-color-dusk);
	padding-left: 8px;
}

.op-header__menu-list a:focus-visible {
	outline: none;
	border-bottom: 2px solid var(--op-color-dusk);
}

/* ── Header CTA short label on mobile ── */

.op-header .op-btn__text--short {
	display: none;
}

@media (max-width: 600px) {
	.op-header .op-btn__text--full {
		display: none;
	}

	.op-header .op-btn__text--short {
		display: inline;
	}
}

/* ── Responsive ── */

@media (max-width: 600px) {
	.op-header__menu-panel {
		width: min(340px, 85vw);
		padding: calc(var(--_header-h) + 24px) 28px 28px;
	}
}

/* ── Toggle Switch (show all sections) ── */

.op-header__menu-toggle {
	padding: 16px 0 8px;
	flex-shrink: 0;
}

.op-header__toggle {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.op-header__toggle-label {
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.8125rem;
	font-weight: 500;
	color: rgba(var(--op-rgb-deep-ink), 0.5);
	letter-spacing: 0.02em;
}

.op-header__toggle-switch {
	position: relative;
	display: flex;
	align-items: center;
}

.op-header__toggle-input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

.op-header__toggle-track {
	display: block;
	width: 40px;
	height: 22px;
	border-radius: 11px;
	background-color: rgba(var(--op-rgb-deep-ink), 0.12);
	position: relative;
	transition: background-color 0.25s ease;
}

.op-header__toggle-input:checked + .op-header__toggle-track {
	background-color: var(--op-color-dusk);
}

.op-header__toggle-thumb {
	display: block;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--op-color-white);
	position: absolute;
	top: 2px;
	left: 2px;
	box-shadow: 0 1px 3px rgba(var(--op-rgb-black), 0.15);
	transition: transform 0.25s ease;
}

.op-header__toggle-input:checked
	+ .op-header__toggle-track
	.op-header__toggle-thumb {
	transform: translateX(18px);
}

.op-header__toggle-input:focus-visible + .op-header__toggle-track {
	outline: 2px solid var(--op-color-dusk);
	outline-offset: 2px;
}

/* -------------------------------------------------------
   Style Variations
   ------------------------------------------------------- */

/*
  Each variant needs:
  1. Bar background
  2. Logo name + suffix colors, hover/active/focus states
  3. Burger line color
  4. CTA button bg/color + hover/active/focus
  5. Menu panel background + text/link/border colors
  6. Toggle label + track colors
*/

/* ---- Dusk ---- */

/* Bar */
.op-header.is-style-dusk .op-header__bar {
	background-color: rgba(var(--op-rgb-deep-ink), 0.85);
}

/* Logo */
.op-header.is-style-dusk .op-header__logo-name {
	color: var(--op-color-parchment);
}

.op-header.is-style-dusk .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-dusk .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-dusk .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-dusk .op-header__logo-suffix {
	color: rgba(var(--op-rgb-parchment), 0.5);
}

/* Burger */
.op-header.is-style-dusk .op-header__burger-line {
	background-color: var(--op-color-parchment);
}

/* CTA button */
.op-header.is-style-dusk .op-btn--header {
	background-color: var(--op-color-dusk);
	color: var(--op-color-parchment);
}

.op-header.is-style-dusk .op-btn--header:hover {
	background-color: var(--op-color-dusk-light);
	color: var(--op-color-parchment);
}

.op-header.is-style-dusk .op-btn--header:active .op-btn__text {
	transform: scale(1.06);
}

.op-header.is-style-dusk .op-btn--header:focus-visible {
	outline-color: var(--op-color-faded-gold);
}

/* Menu panel */
.op-header.is-style-dusk .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-deep-ink), 0.92);
}

.op-header.is-style-dusk .op-header__menu-list li {
	border-bottom-color: rgba(var(--op-rgb-parchment), 0.08);
}

.op-header.is-style-dusk .op-header__menu-list a {
	color: var(--op-color-parchment);
}

.op-header.is-style-dusk .op-header__menu-list li.is-active > a,
.op-header.is-style-dusk .op-header__menu-list a:hover {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-dusk .op-header__menu-list a:focus-visible {
	border-bottom-color: var(--op-color-faded-gold);
}

.op-header.is-style-dusk .op-header__toggle-label {
	color: rgba(var(--op-rgb-parchment), 0.5);
}

.op-header.is-style-dusk .op-header__toggle-track {
	background-color: rgba(var(--op-rgb-parchment), 0.15);
}

/* ---- Rose ---- */

/* Bar */
.op-header.is-style-rose .op-header__bar {
	background-color: rgba(var(--op-rgb-dusty-rose), 0.85);
}

/* Logo */
.op-header.is-style-rose .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header.is-style-rose .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header.is-style-rose .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-dusk);
}

/* Menu panel */
.op-header.is-style-rose .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-dusty-rose), 0.92);
}

/* ---- Gold ---- */

/* Bar */
.op-header.is-style-gold .op-header__bar {
	background-color: rgba(var(--op-rgb-faded-gold), 0.85);
}

/* Logo */
.op-header.is-style-gold .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header.is-style-gold .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header.is-style-gold .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-dusk);
}

/* Menu panel */
.op-header.is-style-gold .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-faded-gold), 0.92);
}

/* ---- Terracotta ---- */

/* Bar */
.op-header.is-style-terracotta .op-header__bar {
	background-color: rgba(var(--op-rgb-terracotta), 0.9);
}

/* Logo */
.op-header.is-style-terracotta .op-header__logo-name {
	color: rgba(var(--op-rgb-parchment), 0.85);
}

.op-header.is-style-terracotta .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-terracotta .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-terracotta
	.op-header__logo:focus-visible
	.op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-terracotta .op-header__logo-suffix {
	color: rgba(var(--op-rgb-parchment), 0.5);
}

/* Burger */
.op-header.is-style-terracotta .op-header__burger-line {
	background-color: var(--op-color-parchment);
}

/* CTA button */
.op-header.is-style-terracotta .op-btn--header {
	background-color: var(--op-color-parchment);
	color: var(--op-color-terracotta);
}

.op-header.is-style-terracotta .op-btn--header:hover {
	background-color: var(--op-color-faded-gold);
	color: var(--op-color-deep-ink);
	box-shadow: 0 2px 8px rgba(var(--op-rgb-black), 0.18);
}

.op-header.is-style-terracotta .op-btn--header:focus-visible {
	outline-color: var(--op-color-parchment);
}

/* Menu panel */
.op-header.is-style-terracotta .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-terracotta), 0.95);
}

.op-header.is-style-terracotta .op-header__menu-list li {
	border-bottom-color: rgba(var(--op-rgb-parchment), 0.08);
}

.op-header.is-style-terracotta .op-header__menu-list a {
	color: rgba(var(--op-rgb-parchment), 0.85);
}

.op-header.is-style-terracotta .op-header__menu-list li.is-active > a,
.op-header.is-style-terracotta .op-header__menu-list a:hover {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-terracotta .op-header__menu-list a:focus-visible {
	border-bottom-color: var(--op-color-faded-gold);
}

.op-header.is-style-terracotta .op-header__toggle-label {
	color: rgba(var(--op-rgb-parchment), 0.5);
}

.op-header.is-style-terracotta .op-header__toggle-track {
	background-color: rgba(var(--op-rgb-parchment), 0.15);
}

.op-header.is-style-terracotta
	.op-header__toggle-input:checked
	+ .op-header__toggle-track {
	background-color: var(--op-color-faded-gold);
}

/* ---- Moon ---- */

/* Bar */
.op-header.is-style-moon .op-header__bar {
	background-color: rgba(var(--op-rgb-moon-glow), 0.85);
}

/* Logo */
.op-header.is-style-moon .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header.is-style-moon .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-dusk);
}

.op-header.is-style-moon .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-dusk);
}

/* Menu panel */
.op-header.is-style-moon .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-moon-glow), 0.92);
}

/* ---- Ink ---- */

/* Bar */
.op-header.is-style-ink .op-header__bar {
	background-color: rgba(var(--op-rgb-deep-ink), 0.88);
}

/* Logo */
.op-header.is-style-ink .op-header__logo-name {
	color: var(--op-color-parchment);
}

.op-header.is-style-ink .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-ink .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-ink .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-ink .op-header__logo-suffix {
	color: rgba(var(--op-rgb-moon-glow), 0.5);
}

/* Burger */
.op-header.is-style-ink .op-header__burger-line {
	background-color: var(--op-color-moon-glow);
}

/* CTA button */
.op-header.is-style-ink .op-btn--header {
	background-color: var(--op-color-faded-gold);
	color: var(--op-color-deep-ink);
}

.op-header.is-style-ink .op-btn--header:hover {
	background-color: var(--op-color-parchment);
	color: var(--op-color-deep-ink);
}

.op-header.is-style-ink .op-btn--header:active .op-btn__text {
	transform: scale(1.06);
}

.op-header.is-style-ink .op-btn--header:focus-visible {
	outline-color: var(--op-color-faded-gold);
}

/* Menu panel */
.op-header.is-style-ink .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-deep-ink), 0.94);
}

.op-header.is-style-ink .op-header__menu-list li {
	border-bottom-color: rgba(var(--op-rgb-parchment), 0.07);
}

.op-header.is-style-ink .op-header__menu-list a {
	color: rgba(var(--op-rgb-moon-glow), 0.85);
}

.op-header.is-style-ink .op-header__menu-list li.is-active > a,
.op-header.is-style-ink .op-header__menu-list a:hover {
	color: var(--op-color-faded-gold);
}

.op-header.is-style-ink .op-header__menu-list a:focus-visible {
	border-bottom-color: var(--op-color-faded-gold);
}

.op-header.is-style-ink .op-header__toggle-label {
	color: rgba(var(--op-rgb-moon-glow), 0.5);
}

.op-header.is-style-ink .op-header__toggle-track {
	background-color: rgba(var(--op-rgb-moon-glow), 0.15);
}

.op-header.is-style-ink
	.op-header__toggle-input:checked
	+ .op-header__toggle-track {
	background-color: var(--op-color-faded-gold);
}

/* ---- Dawn ---- */

/* Bar */
.op-header.is-style-dawn .op-header__bar {
	background-color: rgba(var(--op-rgb-parchment), 0.85);
}

/* Logo */
.op-header.is-style-dawn .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-terracotta);
}

.op-header.is-style-dawn .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-terracotta);
}

.op-header.is-style-dawn .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-terracotta);
}

.op-header.is-style-dawn .op-header__logo-suffix {
	color: var(--op-color-terracotta);
}

/* CTA button */
.op-header.is-style-dawn .op-btn--header {
	background-color: var(--op-color-terracotta);
	color: var(--op-color-parchment);
}

.op-header.is-style-dawn .op-btn--header:hover {
	background-color: var(--op-color-dusk);
	color: var(--op-color-parchment);
}

.op-header.is-style-dawn .op-btn--header:focus-visible {
	outline-color: var(--op-color-terracotta);
}

/* Menu panel */
.op-header.is-style-dawn .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-parchment), 0.94);
}

.op-header.is-style-dawn .op-header__menu-list li.is-active > a,
.op-header.is-style-dawn .op-header__menu-list a:hover {
	color: var(--op-color-terracotta);
}

.op-header.is-style-dawn .op-header__menu-list a:focus-visible {
	border-bottom-color: var(--op-color-terracotta);
}

/* ─── Earth variant ─── */

.op-header.is-style-earth .op-header__bar {
	background-color: rgba(var(--op-rgb-sand), 0.88);
}

/* Logo */
.op-header.is-style-earth .op-header__logo:hover .op-header__logo-name {
	color: var(--op-color-earth);
}

.op-header.is-style-earth .op-header__logo:active .op-header__logo-name {
	color: var(--op-color-earth);
}

.op-header.is-style-earth .op-header__logo:focus-visible .op-header__logo-name {
	color: var(--op-color-earth);
}

.op-header.is-style-earth .op-header__logo-suffix {
	color: var(--op-color-earth);
}

/* CTA button */
.op-header.is-style-earth .op-btn--header {
	background-color: var(--op-color-clay);
	color: var(--op-color-deep-ink);
}

.op-header.is-style-earth .op-btn--header:hover {
	background-color: var(--op-color-earth);
	color: var(--op-color-parchment);
}

.op-header.is-style-earth .op-btn--header:focus-visible {
	outline-color: var(--op-color-earth);
}

/* Burger lines */
.op-header.is-style-earth .op-header__burger-line {
	background-color: var(--op-color-earth);
}

/* Menu panel */
.op-header.is-style-earth .op-header__menu-panel {
	background-color: rgba(var(--op-rgb-sand), 0.96);
}

.op-header.is-style-earth .op-header__menu-list li.is-active > a,
.op-header.is-style-earth .op-header__menu-list a:hover {
	color: var(--op-color-earth);
}

.op-header.is-style-earth .op-header__menu-list a:focus-visible {
	border-bottom-color: var(--op-color-earth);
}

