/*
 * CaseCreator — Header Stylesheet
 *
 * Covers: announcement bar, desktop header, navigation + dropdowns,
 * sticky behaviour, mini-cart, search popup, mobile header, off-canvas menu.
 *
 * Depends on: main.css (custom properties live there).
 */

/* =========================================================================
   Header-specific Custom Properties
   ========================================================================= */
:root {
	--cc-header-height:         76px;
	--cc-header-height-sticky:  60px;
	--cc-announcement-height:   40px;

	/* Header surface & text — dark-mode-friendly defaults */
	--cc-header-bg:      var( --cc-white );
	--cc-header-border:  var( --cc-light-grey );
	--cc-header-text:    var( --cc-text );

	/* Sticky state */
	--cc-header-sticky-bg:      var( --cc-white );
	--cc-header-sticky-shadow:  0 2px 24px rgba( 26, 26, 34, 0.1 );

	/* Announcement bar defaults (overridden by ACF inline style) */
	--cc-ann-bg:   var( --cc-primary );
	--cc-ann-text: var( --cc-white );

	/* Dropdown */
	--cc-dropdown-bg:     var( --cc-white );
	--cc-dropdown-border: var( --cc-light-grey );
	--cc-dropdown-shadow: 0 8px 32px rgba( 26, 26, 34, 0.12 );

	/* Z-index scale */
	--cc-z-header:       200;
	--cc-z-dropdown:     300;
	--cc-z-mobile-menu:  400;
	--cc-z-search:       500;
	--cc-z-overlay:      150;
}

/* =========================================================================
   Shared Overlay Backdrop
   ========================================================================= */
.site-overlay {
	position: fixed;
	inset: 0;
	background: rgba( 0, 0, 0, 0.55 );
	z-index: var( --cc-z-overlay );
	opacity: 0;
	transition: opacity 0.25s ease;
	pointer-events: none;
}

.site-overlay--active {
	opacity: 1;
	pointer-events: auto;
}

/* Search overlay sits above the mobile-menu overlay */
.site-overlay--search {
	z-index: calc( var( --cc-z-search ) - 1 );
}

/* =========================================================================
   Body States
   ========================================================================= */
body.scroll-locked {
	position: fixed;
	width: 100%;
	overflow-y: scroll; /* keep scroll-bar gutter to prevent layout shift */
}

/* =========================================================================
   Announcement Bar
   ========================================================================= */
.announcement-bar {
	position: relative;
	z-index: calc( var( --cc-z-header ) + 1 );
	width: 100%;
	min-height: var( --cc-announcement-height );
}

.announcement-bar__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var( --cc-space-md );
	padding-block: 0.5rem;
	min-height: var( --cc-announcement-height );
}

.announcement-bar__content {
	flex: 1;
	text-align: center;
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0.01em;
	margin: 0;
}

.announcement-bar__content--link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.375rem;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: opacity var( --cc-transition );
}

.announcement-bar__content--link:hover {
	opacity: 0.8;
}

.announcement-bar__arrow {
	flex-shrink: 0;
	transition: transform var( --cc-transition );
}

.announcement-bar__content--link:hover .announcement-bar__arrow {
	transform: translateX( 3px );
}

/* Multi-segment announcement content layout */
.announcement-bar__content {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0 1.5rem;
}

.announcement-bar__primary {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
}

.announcement-bar__primary b {
	display: inline-flex;
	align-items: center;
	padding: 0.1rem 0.45rem;
	background: rgba( 255, 255, 255, 0.2 );
	border-radius: 3px;
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-right: 0.25rem;
}

.announcement-bar__extra {
	font-size: 12.5px;
    font-weight: 600;
	
}

@media ( max-width: 600px ) {
	.announcement-bar__extra {
		display: none;
	}
}

.announcement-bar__dismiss {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	color: inherit;
	opacity: 0.7;
	transition: opacity var( --cc-transition ), background-color var( --cc-transition );
}

.announcement-bar__dismiss:hover {
	opacity: 1;
	background-color: rgba( 255, 255, 255, 0.15 );
}

/* =========================================================================
   Site Header — Base
   ========================================================================= */
.site-header {
	position: sticky;
	top: 0;
	z-index: var( --cc-z-header );
	background-color: var( --cc-white );
	border-bottom: 1px solid var( --cc-light-grey );
	transition: height 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
	will-change: transform;
}

.site-header--sticky {
	box-shadow: 0 2px 20px rgba( 0, 0, 0, 0.08 );
	border-bottom-color: transparent;
}

/* =========================================================================
   Desktop Header
   ========================================================================= */
.desktop-header {
	display: block;
}

.desktop-header__inner {
	display: flex;
	align-items: center;
	gap: var( --cc-space-lg );
	height: var( --cc-header-height );
	transition: height 0.25s ease;
}

.site-header--sticky .desktop-header__inner {
	height: var( --cc-header-height-sticky );
}

/* -- Logo -- */
.header-logo__link {
	display: flex;
	align-items: center;
}

.header-logo__img {
	max-height: 48px;
	width: auto;
	transition: opacity 0.2s ease;
}

.site-header--sticky .header-logo__img {
	max-height: 36px;
}

/* Sticky logo: hidden until sticky class is added */
.logo--sticky {
	display: none;
	position: absolute;
	top: 0;
	left: 0;
}

.site-header--sticky .logo--desktop {
	display: none;
}

.site-header--sticky .logo--sticky {
	display: block;
	position: static;
}

.header-logo {
	position: relative;
	flex-shrink: 0;
	max-width: 180px;
}

.header-logo__text {
	font-size: 1.25rem;
	font-weight: 700;
	color: var( --cc-primary );
	letter-spacing: -0.03em;
}

/* -- Nav -- */
.desktop-header__nav {
	flex: 1;
	display: flex;
	justify-content: center;
}

/* -- Actions -- */
.desktop-header__actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
}

.header-action {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var( --cc-radius-sm );
	color: var( --cc-text );
	transition: background-color var( --cc-transition ), color var( --cc-transition );
}

.header-action:hover,
.header-action:focus-visible {
	background-color: var( --cc-off-white );
	color: var( --cc-primary );
}

.header-action:focus-visible {
	outline: 2px solid var( --cc-primary );
	outline-offset: 2px;
}

.header-cta-btn {
	margin-left: var( --cc-space-sm );
}

/* =========================================================================
   Primary Navigation
   ========================================================================= */
.primary-menu {
	display: flex;
	align-items: center;
	gap: 0;
	list-style: none;
}

.primary-menu > .menu-item {
	position: relative;
}

.menu-item__link {
	display: flex;
	align-items: center;
	padding: 0.5rem 0.875rem;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var( --cc-text );
	border-radius: var( --cc-radius-sm );
	transition: color var( --cc-transition ), background-color var( --cc-transition );
	white-space: nowrap;
}

.menu-item__link:hover,
.menu-item__link:focus-visible {
	color: var( --cc-primary );
	background-color: var( --cc-off-white );
}

.menu-item__link:focus-visible {
	outline: 2px solid var( --cc-primary );
	outline-offset: 2px;
}

/* Current item */
.current-menu-item > .menu-item__link,
.current-menu-ancestor > .menu-item__link {
	color: var( --cc-primary );
	font-weight: 600;
}

/* Drop-down toggle button (sits beside the anchor) */
.dropdown__toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	margin-left: -4px;
	color: var( --cc-mid-grey );
	border-radius: var( --cc-radius-sm );
	transition: color var( --cc-transition ), transform 0.2s ease;
	flex-shrink: 0;
}

.dropdown__toggle:hover,
.dropdown__toggle:focus-visible {
	color: var( --cc-primary );
	background-color: var( --cc-off-white );
}

.dropdown--open > .dropdown__toggle,
.has-dropdown:hover > .dropdown__toggle {
	transform: rotate( 180deg );
	color: var( --cc-primary );
}

/* ── Dropdown Menu ───────────────────────────────────────────── */
.dropdown__menu {
	position: absolute;
	top: calc( 100% + 8px );
	left: 50%;
	transform: translateX( -50% ) translateY( -4px );
	min-width: 200px;
	background: var( --cc-white );
	border: 1px solid var( --cc-light-grey );
	border-radius: var( --cc-radius-md );
	box-shadow: 0 8px 32px rgba( 0, 0, 0, 0.1 );
	list-style: none;
	padding: 0.375rem;
	z-index: var( --cc-z-dropdown );
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.18s ease, visibility 0.18s ease, transform 0.18s ease;
}

/* Show via hover (CSS) and via JS class */
.has-dropdown:hover > .dropdown__menu,
.dropdown--open > .dropdown__menu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateX( -50% ) translateY( 0 );
}

/* Left-align dropdowns near the right edge of the viewport */
.primary-menu > .menu-item:last-child > .dropdown__menu,
.primary-menu > .menu-item:nth-last-child(2) > .dropdown__menu {
	left: auto;
	right: 0;
	transform: translateY( -4px );
}

.primary-menu > .menu-item:last-child:hover > .dropdown__menu,
.primary-menu > .menu-item:nth-last-child(2):hover > .dropdown__menu,
.primary-menu > .menu-item:last-child.dropdown--open > .dropdown__menu,
.primary-menu > .menu-item:nth-last-child(2).dropdown--open > .dropdown__menu {
	transform: translateY( 0 );
}

.dropdown__menu .menu-item {
	position: relative;
}

.dropdown__menu .menu-item__link {
	display: flex;
	width: 100%;
	padding: 0.5rem 0.75rem;
	font-size: 0.9rem;
	border-radius: var( --cc-radius-sm );
}

/* Second-level submenu */
.dropdown__submenu {
	position: absolute;
	top: -0.375rem;
	left: calc( 100% + 4px );
	min-width: 180px;
	background: var( --cc-white );
	border: 1px solid var( --cc-light-grey );
	border-radius: var( --cc-radius-md );
	box-shadow: 0 8px 24px rgba( 0, 0, 0, 0.1 );
	list-style: none;
	padding: 0.375rem;
	z-index: calc( var( --cc-z-dropdown ) + 1 );
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.15s ease, visibility 0.15s ease;
}

.has-dropdown:hover > .dropdown__submenu,
.dropdown--open > .dropdown__submenu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

/* =========================================================================
   Mini Cart
   ========================================================================= */
.casecreator-mini-cart {
	position: relative;
}

.mini-cart__trigger {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var( --cc-radius-sm );
	color: var( --cc-text );
	position: relative;
	transition: background-color var( --cc-transition );
}

.mini-cart__trigger:hover,
.mini-cart__trigger:focus-visible {
	background-color: var( --cc-off-white );
	color: var( --cc-primary );
}

.mini-cart__trigger:focus-visible {
	outline: 2px solid var( --cc-primary );
	outline-offset: 2px;
}

.mini-cart__count {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 17px;
	height: 17px;
	background-color: var( --cc-accent );
	color: var( --cc-white );
	font-size: 0.65rem;
	font-weight: 700;
	border-radius: 999px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 3px;
	line-height: 1;
}

/* Dropdown panel */
.mini-cart__dropdown {
	position: absolute;
	top: calc( 100% + 12px );
	right: 0;
	width: 340px;
	background: var( --cc-white );
	border: 1px solid var( --cc-light-grey );
	border-radius: var( --cc-radius-md );
	box-shadow: 0 12px 40px rgba( 0, 0, 0, 0.12 );
	z-index: var( --cc-z-dropdown );
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY( -6px );
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
}

.casecreator-mini-cart:hover .mini-cart__dropdown,
.casecreator-mini-cart:focus-within .mini-cart__dropdown,
.casecreator-mini-cart.mini-cart--open .mini-cart__dropdown {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY( 0 );
}

/* WooCommerce mini-cart inner styles */
.mini-cart__dropdown .woocommerce-mini-cart {
	max-height: 320px;
	overflow-y: auto;
	padding: var( --cc-space-md );
}

.mini-cart__dropdown .woocommerce-mini-cart__empty-message {
	padding: var( --cc-space-md );
	text-align: center;
	color: var( --cc-mid-grey );
	font-size: 0.9rem;
}

.mini-cart__dropdown .mini_cart_item {
	display: flex;
	gap: var( --cc-space-sm );
	padding-block: var( --cc-space-sm );
	border-bottom: 1px solid var( --cc-light-grey );
}

.mini-cart__dropdown .woocommerce-mini-cart__buttons {
	padding: var( --cc-space-md );
	display: flex;
	flex-direction: column;
	gap: var( --cc-space-sm );
	border-top: 1px solid var( --cc-light-grey );
}

.mini-cart__dropdown .woocommerce-mini-cart__total {
	display: flex;
	justify-content: space-between;
	padding: var( --cc-space-sm ) var( --cc-space-md );
	font-weight: 600;
	border-top: 1px solid var( --cc-light-grey );
}

/* =========================================================================
   Search Popup
   ========================================================================= */
.search-popup {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: var( --cc-z-search );
	background: var( --cc-white );
	box-shadow: 0 8px 40px rgba( 0, 0, 0, 0.15 );
	transform: translateY( -100% );
	transition: transform 0.3s cubic-bezier( 0.4, 0, 0.2, 1 );
	will-change: transform;
}

.search-popup--open {
	transform: translateY( 0 );
}

.search-popup__inner {
	padding-block: var( --cc-space-lg );
	max-width: 720px;
	margin-inline: auto;
	padding-inline: var( --cc-container-pad );
}

.search-popup__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var( --cc-space-md );
}

.search-popup__label {
	font-size: 0.875rem;
	color: var( --cc-mid-grey );
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.search-popup__close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	color: var( --cc-text );
	transition: background-color var( --cc-transition );
}

.search-popup__close:hover,
.search-popup__close:focus-visible {
	background-color: var( --cc-off-white );
}

.search-popup__close:focus-visible {
	outline: 2px solid var( --cc-primary );
	outline-offset: 2px;
}

.search-popup__form {
	display: flex;
	gap: var( --cc-space-md );
	align-items: center;
}

.search-popup__field {
	position: relative;
	flex: 1;
}

.search-popup__icon {
	position: absolute;
	top: 50%;
	left: var( --cc-space-md );
	transform: translateY( -50% );
	color: var( --cc-mid-grey );
	pointer-events: none;
}

.search-popup__input {
	width: 100%;
	height: 52px;
	padding-left: calc( 20px + var( --cc-space-md ) + var( --cc-space-sm ) );
	padding-right: var( --cc-space-md );
	border: 2px solid var( --cc-light-grey );
	border-radius: var( --cc-radius-md );
	font-size: 1rem;
	font-family: var( --cc-font-primary );
	color: var( --cc-text );
	background: var( --cc-off-white );
	transition: border-color var( --cc-transition ), background-color var( --cc-transition );
	appearance: none;
	outline: none;
}

.search-popup__input:focus {
	border-color: var( --cc-primary );
	background: var( --cc-white );
}

.search-popup__input::placeholder {
	color: var( --cc-mid-grey );
}

.search-popup__submit {
	flex-shrink: 0;
	height: 52px;
	padding-inline: 1.5rem;
}

.search-popup__results {
	margin-top: var( --cc-space-md );
	min-height: 0;
}

/* =========================================================================
   Mobile Header Bar
   ========================================================================= */
.mobile-header-bar {
	display: none; /* shown only via media query below */
}

.mobile-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var( --cc-header-height );
	transition: height 0.25s ease;
}

.site-header--sticky .mobile-header__inner {
	height: var( --cc-header-height-sticky );
}

.mobile-header__logo {
	display: flex;
	align-items: center;
}

.mobile-header__logo-img {
	max-height: 40px;
	width: auto;
}

.mobile-header__logo-text {
	font-size: 1.125rem;
	font-weight: 700;
	color: var( --cc-primary );
}

.mobile-header__actions {
	display: flex;
	align-items: center;
	gap: var( --cc-space-xs );
}

/* Mobile cart link — plain link version */
.mobile-cart-link {
	position: relative;
}

/* Hamburger button */
.site-header__mobile-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var( --cc-radius-sm );
	color: var( --cc-text );
	transition: background-color var( --cc-transition );
}

.site-header__mobile-toggle:hover,
.site-header__mobile-toggle:focus-visible {
	background-color: var( --cc-off-white );
}

.site-header__mobile-toggle:focus-visible {
	outline: 2px solid var( --cc-primary );
	outline-offset: 2px;
}

.hamburger {
	display: flex;
	flex-direction: column;
	gap: 5px;
	width: 22px;
}

.hamburger__line {
	display: block;
	height: 2px;
	background-color: currentColor;
	border-radius: 1px;
	transition: transform 0.25s ease, opacity 0.25s ease, width 0.25s ease;
	transform-origin: center;
}

/* Active (open) state — animated X */
.site-header__mobile-toggle.is-active .hamburger__line:nth-child(1) {
	transform: translateY( 7px ) rotate( 45deg );
}

.site-header__mobile-toggle.is-active .hamburger__line:nth-child(2) {
	opacity: 0;
	transform: scaleX( 0 );
}

.site-header__mobile-toggle.is-active .hamburger__line:nth-child(3) {
	transform: translateY( -7px ) rotate( -45deg );
}

/* =========================================================================
   Off-Canvas Mobile Menu
   ========================================================================= */
.mobile-menu {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	width: min( 360px, 90vw );
	background: var( --cc-white );
	z-index: var( --cc-z-mobile-menu );
	overflow: hidden;
	transform: translateX( -100% );
	transition: transform 0.35s cubic-bezier( 0.4, 0, 0.2, 1 );
	will-change: transform;
}

.mobile-menu--open {
	transform: translateX( 0 );
}

.mobile-menu__inner {
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

/* Menu header */
.mobile-menu__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var( --cc-space-md ) var( --cc-space-lg );
	border-bottom: 1px solid var( --cc-light-grey );
	flex-shrink: 0;
}

.mobile-menu__brand {
	display: flex;
	align-items: center;
}

.mobile-menu__brand-img {
	max-height: 36px;
	width: auto;
}

.mobile-menu__close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	color: var( --cc-text );
	transition: background-color var( --cc-transition );
}

.mobile-menu__close:hover,
.mobile-menu__close:focus-visible {
	background-color: var( --cc-off-white );
}

/* Menu navigation list */
.mobile-menu__nav {
	flex: 1;
	padding: var( --cc-space-sm ) 0;
}

.mobile-nav-menu {
	list-style: none;
}

.mobile-nav-menu .menu-item {
	position: relative;
}

.mobile-nav-menu .menu-item__link {
	display: flex;
	align-items: center;
	padding: 0.875rem var( --cc-space-lg );
	font-size: 1rem;
	font-weight: 500;
	color: var( --cc-text );
	border-bottom: 1px solid var( --cc-light-grey );
	transition: background-color var( --cc-transition );
}

.mobile-nav-menu .menu-item__link:hover,
.mobile-nav-menu .menu-item__link:focus-visible {
	background-color: var( --cc-off-white );
	color: var( --cc-primary );
}

.mobile-nav-menu .current-menu-item > .menu-item__link {
	color: var( --cc-primary );
	font-weight: 600;
}

/* Expand button for parent items */
.mobile-menu__expand {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var( --cc-mid-grey );
	border-left: 1px solid var( --cc-light-grey );
	transition: background-color var( --cc-transition ), color var( --cc-transition );
}

.mobile-menu__expand:hover,
.mobile-menu__expand:focus-visible {
	background-color: var( --cc-off-white );
	color: var( --cc-primary );
}

/* Sub-menus hidden on mobile — shown via JS panels */
.mobile-nav-menu .dropdown__menu,
.mobile-nav-menu .dropdown__submenu {
	display: none;
}

/* Mobile account + social */
.mobile-menu__account {
	padding: var( --cc-space-md ) var( --cc-space-lg );
	border-top: 1px solid var( --cc-light-grey );
}

.mobile-menu__account-link {
	width: 100%;
	justify-content: center;
}

.mobile-menu__social {
	padding: var( --cc-space-md ) var( --cc-space-lg );
	border-top: 1px solid var( --cc-light-grey );
}

/* ── Sliding Sub-Panels ───────────────────────────────────────── */
.mobile-menu__panel {
	position: absolute;
	inset: 0;
	background: var( --cc-white );
	transform: translateX( 100% );
	transition: transform 0.3s cubic-bezier( 0.4, 0, 0.2, 1 );
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	z-index: 10;
}

.mobile-menu__panel--active {
	transform: translateX( 0 );
}

.mobile-menu__panel-header {
	display: flex;
	align-items: center;
	gap: var( --cc-space-sm );
	padding: var( --cc-space-md ) var( --cc-space-lg );
	border-bottom: 1px solid var( --cc-light-grey );
	position: sticky;
	top: 0;
	background: var( --cc-white );
	z-index: 1;
}

.mobile-menu__back {
	display: flex;
	align-items: center;
	gap: var( --cc-space-xs );
	font-size: 0.875rem;
	font-weight: 500;
	color: var( --cc-mid-grey );
	padding: 0.375rem 0.625rem;
	border-radius: var( --cc-radius-sm );
	transition: background-color var( --cc-transition ), color var( --cc-transition );
}

.mobile-menu__back:hover,
.mobile-menu__back:focus-visible {
	background-color: var( --cc-off-white );
	color: var( --cc-primary );
}

.mobile-menu__panel-title {
	font-size: 1rem;
	font-weight: 600;
	color: var( --cc-text );
}

.mobile-menu__panel-list {
	list-style: none;
}

.mobile-menu__panel-list .menu-item {
	position: relative;
}

.mobile-menu__panel-list .menu-item__link {
	display: flex;
	align-items: center;
	padding: 0.875rem var( --cc-space-lg );
	font-size: 1rem;
	color: var( --cc-text );
	border-bottom: 1px solid var( --cc-light-grey );
	transition: background-color var( --cc-transition );
}

.mobile-menu__panel-list .menu-item__link:hover {
	background-color: var( --cc-off-white );
}

/* =========================================================================
   Responsive Breakpoints
   ========================================================================= */

/* ── Tablet: hide desktop nav text but keep icons ────────────── */
@media ( max-width: 1024px ) {
	.primary-menu > .menu-item > .menu-item__link {
		padding-inline: 0.5rem;
		font-size: 0.875rem;
	}

	.header-cta-btn {
		display: none;
	}
}

/* ── Mobile: switch to mobile header ─────────────────────────── */
@media ( max-width: 768px ) {
	.desktop-header {
		display: none;
	}

	.mobile-header-bar {
		display: block;
	}
}

/* ── Ensure desktop header shows above 768px ─────────────────── */
@media ( min-width: 769px ) {
	.mobile-header-bar {
		display: none;
	}

	.mobile-menu {
		display: none !important; /* Safety: prevent opening via JS on desktop */
	}
}

/* ── Small mobile adjustments ────────────────────────────────── */
@media ( max-width: 480px ) {
	.mobile-menu {
		width: 100vw;
	}

	.search-popup__form {
		flex-direction: column;
	}

	.search-popup__submit {
		width: 100%;
	}
}
