/**
 * Lavender — Mobile menu component
 *
 * BEM pattern blueprint for hand-authored components.
 *
 *   .lavender-<block>                       — root
 *   .lavender-<block>__<element>            — child element
 *   .lavender-<block>__<element>--<modifier> — variant
 *   .lavender-<block>.is-<state>            — runtime state (set by JS)
 *
 * JS contract (do NOT rename):
 *   IDs    : #lav-mobile-toggle, #lav-mobile-menu
 *   State  : .is-open (added/removed by assets/js/mobile-menu.js)
 *
 * Visibility is driven by [hidden] + .is-open, not Tailwind utilities,
 * so the component is fully self-contained.
 */

/* Toggle button (always visible on small screens, hidden on lg+) */
.lavender-mobile-menu__toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem;
	border: 0;
	background: transparent;
	color: var(--lavender-color-text);
	border-radius: var(--lavender-radius-sm);
	cursor: pointer;
	transition: color var(--lavender-transition), background-color var(--lavender-transition);
}
.lavender-mobile-menu__toggle:hover {
	color: var(--lavender-color-primary);
	background: var(--lavender-color-primary-tint);
}
.lavender-mobile-menu__toggle svg {
	width: 1.5rem;
	height: 1.5rem;
}

@media (min-width: 1024px) {
	.lavender-mobile-menu__toggle,
	.lavender-mobile-menu { display: none !important; }
}

/* Panel */
.lavender-mobile-menu {
	border-top: 1px solid var(--lavender-color-border);
	padding: 1rem 0;
}
.lavender-mobile-menu[hidden] { display: none; }

.lavender-mobile-menu__link {
	display: block;
	padding: 0.5rem 1rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--lavender-color-text-muted);
	text-decoration: none;
	transition: color var(--lavender-transition);
}
.lavender-mobile-menu__link:hover,
.lavender-mobile-menu__link.is-active {
	color: var(--lavender-color-primary);
}

/* Non-clickable parent label (when WP menu parent item has no real URL). */
.lavender-mobile-menu__link--label {
	cursor: default;
	opacity: 0.55;
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding-top: 1rem;
}
.lavender-mobile-menu__link--label:hover { color: inherit; }

/* Child items rendered below their parent label. */
.lavender-mobile-menu__sub-link {
	display: block;
	padding: 0.375rem 1rem 0.375rem 2rem;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--lavender-color-text-muted);
	text-decoration: none;
	transition: color var(--lavender-transition);
}
.lavender-mobile-menu__sub-link:hover {
	color: var(--lavender-color-primary);
}

.lavender-mobile-menu__cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	margin: 0.75rem 1rem 0;
	padding: 0.5rem 1rem;
	background: var(--lavender-color-primary);
	color: #fff;
	border-radius: var(--lavender-radius-sm);
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	transition: background-color var(--lavender-transition);
}
.lavender-mobile-menu__cta:hover {
	background: var(--lavender-color-primary-hover);
	color: #fff;
}

.lavender-mobile-menu__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 0.25rem;
	background: #fff;
	color: var(--lavender-color-primary);
	font-size: 0.75rem;
	font-weight: 700;
	border-radius: var(--lavender-radius-pill);
	line-height: 1;
}
.lavender-mobile-menu__badge[hidden] { display: none; }
