/* ==========================================================================
   FANG · Mega Menu skin
   Restyles the fang-mega-menu plugin to match the FANG design system.
   Loaded after the plugin's own menu.css so we win on equal specificity.
   ========================================================================== */

/* Token overrides — wired into the plugin's CSS variables */
.fang-mega-menu {
	--fang-bg:            var(--gun);
	--fang-text:          var(--bone);
	--fang-accent:        var(--red);
	--fang-panel-bg:      var(--paper);
	--fang-panel-text:    var(--gun);
	--fang-panel-muted:   var(--fog);
	--fang-panel-heading: var(--gun);
	--fang-panel-border:  rgba(20, 20, 20, 0.08);
	--fang-hover-bg:      var(--gun-2);
	--fang-shadow:        0 16px 40px rgba(0, 0, 0, 0.30);
	--fang-radius:        2px;
	--fang-font:          var(--f-body);
	--fang-bar-height:    52px;
	--fang-max-width:     1320px;
	--fang-z:             45;          /* sits below our header (z=50) */

	border-bottom: 3px solid var(--red);
	border-top: 1px solid #2a2a2a;
}

/* Sticky offset — match the theme header height, accounting for admin bar.
   Header heights: 96 / 84 / 76 / 64px (responsive). */
.fang-mega-menu                         { --fang-sticky-offset: 96px; }
@media (max-width: 980px) { .fang-mega-menu { --fang-sticky-offset: 84px; } }
@media (max-width: 768px) { .fang-mega-menu { --fang-sticky-offset: 76px; } }
@media (max-width: 400px) { .fang-mega-menu { --fang-sticky-offset: 64px; } }

body.admin-bar .fang-mega-menu          { --fang-sticky-offset: 128px; }
@media (max-width: 980px) { body.admin-bar .fang-mega-menu { --fang-sticky-offset: 116px; } }
@media (max-width: 782px) { body.admin-bar .fang-mega-menu { --fang-sticky-offset: 122px; } }
@media (max-width: 768px) { body.admin-bar .fang-mega-menu { --fang-sticky-offset: 122px; } }
@media (max-width: 400px) { body.admin-bar .fang-mega-menu { --fang-sticky-offset: 110px; } }

/* Constrain bar to our container width */
.fang-mega-menu__bar {
	max-width: var(--container, 1320px);
	margin: 0 auto;
	padding: 0 var(--gutter, 32px);
}

/* ----------------------------------------------- Top bar links (FANG type) */
.fang-mega-menu__top-link {
	font-family: var(--f-display);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	padding: 0 18px;
	color: var(--bone);
	transition: background-color 0.15s ease, color 0.15s ease;
}
.fang-mega-menu__top-link:hover,
.fang-mega-menu__top-link:focus-visible {
	background: var(--gun-2);
	color: var(--amber);
}
.fang-mega-menu__top-link[aria-expanded="true"] {
	background: var(--gun-2);
	color: var(--bone);
	box-shadow: inset 0 -3px 0 var(--red);
}

.fang-mega-menu__chevron {
	border-top-color: currentColor;
}

/* ----------------------------------------------- Mega panel */
.fang-mega-menu__panel {
	border-top: 3px solid var(--red);
	box-shadow: var(--fang-shadow);
}
.fang-mega-menu__panel-inner {
	max-width: var(--container, 1320px);
	margin: 0 auto;
	padding: 32px var(--gutter, 32px) 24px;
}

.fang-mega-menu__column-heading {
	font-family: var(--f-display);
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--gun);
	margin-bottom: 12px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--gun);
}

.fang-mega-menu__panel-link {
	font-family: var(--f-body);
	font-size: 14px;
	font-weight: 500;
	color: var(--gun);
	padding: 5px 0;
	transition: color 0.12s ease;
}
.fang-mega-menu__panel-link:hover,
.fang-mega-menu__panel-link:focus-visible {
	color: var(--red);
}

.fang-mega-menu__panel-link--parent {
	font-family: var(--f-display);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	font-size: 13px;
	color: var(--gun);
}

.fang-mega-menu__panel-link--child {
	font-weight: 400;
	font-size: 13px;
}

.fang-mega-menu__panel-count {
	font-family: var(--f-mono);
	font-size: 11px;
	color: var(--fog);
	letter-spacing: 0.04em;
}

.fang-mega-menu__panel-children {
	border-left: 2px solid var(--bone-2);
	margin-left: 0;
	padding-left: 12px;
}

.fang-mega-menu__panel-footer {
	border-top: 1px solid var(--fang-panel-border);
	padding-top: 16px;
	margin-top: 22px;
	text-align: right;
}

.fang-mega-menu__view-all-link {
	font-family: var(--f-mono);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--red);
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.fang-mega-menu__view-all-link::after {
	content: "→";
	font-family: var(--f-display);
	font-size: 14px;
}
.fang-mega-menu__view-all-link:hover {
	color: var(--red-deep);
	text-decoration: none;
}

/* ----------------------------------------------- Mobile toggle (in-bar) */
.fang-mega-menu__mobile-toggle {
	font-family: var(--f-display);
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0 18px;
	color: var(--bone);
}

.fang-mega-menu__hamburger span {
	background: var(--bone);
}

/* ----------------------------------------------- Mobile drawer */
.fang-mega-menu__mobile-header {
	background: var(--gun);
	color: var(--bone);
	border-bottom: 3px solid var(--red);
	padding: 14px 18px;
}

.fang-mega-menu__mobile-close {
	color: var(--bone);
}
.fang-mega-menu__mobile-close:hover {
	color: var(--amber);
}

.fang-mega-menu__mobile-search {
	background: var(--bone);
	border-bottom: 1px solid var(--fang-panel-border);
	padding: 14px 18px;
}

.fang-mega-menu__search-input {
	font-family: var(--f-body);
	font-size: 15px;
	color: var(--gun);
	background: var(--paper);
	border: 1px solid var(--gun);
	border-radius: var(--radius);
	padding: 12px 14px;
}
.fang-mega-menu__search-input::placeholder {
	color: var(--fog);
	font-family: var(--f-mono);
	font-size: 12px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
}
.fang-mega-menu__search-input:focus {
	outline: 2px solid var(--red);
	outline-offset: -1px;
	border-color: var(--red);
}

.fang-mega-menu__search-results .fang-mega-menu__search-name {
	font-family: var(--f-display);
	font-weight: 600;
	font-size: 15px;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--gun);
}
.fang-mega-menu__search-results .fang-mega-menu__search-path {
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.10em;
	color: var(--fog);
	text-transform: uppercase;
}

.fang-mega-menu__mobile-link {
	font-family: var(--f-display);
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--gun);
	padding: 16px 18px;
}
.fang-mega-menu__mobile-link:hover,
.fang-mega-menu__mobile-link:focus-visible {
	background: var(--bone-2);
	color: var(--red);
}

.fang-mega-menu__mobile-count {
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.10em;
	color: var(--fog);
}

.fang-mega-menu__mobile-chevron {
	color: var(--red);
	font-size: 22px;
}

.fang-mega-menu__mobile-back {
	background: var(--bone-2);
	color: var(--gun);
	font-family: var(--f-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	padding: 14px 18px;
	border-bottom: 1px solid var(--fang-panel-border);
}
.fang-mega-menu__mobile-back::before {
	color: var(--red);
}

.fang-mega-menu__mobile-view-all {
	background: var(--gun);
	color: var(--bone);
	font-family: var(--f-display);
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 16px 18px;
	border-top: 3px solid var(--red);
}
.fang-mega-menu__mobile-view-all:hover {
	background: var(--gun-2);
	color: var(--amber);
}

.fang-mega-menu__mobile-no-results {
	font-family: var(--f-mono);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--fog);
	padding: 32px 20px;
}

/* ----------------------------------------------- Active state stripe */
.fang-mega-menu__item.is-active .fang-mega-menu__top-link {
	box-shadow: inset 0 -3px 0 var(--red);
}

/* ----------------------------------------------- Responsive ergonomics */
@media (max-width: 1023px) {
	/* Plugin's own breakpoint switches to mobile drawer here. Just polish. */
	.fang-mega-menu__bar { padding: 0 var(--gutter, 24px); justify-content: flex-end; }
	.fang-mega-menu__mobile-toggle { padding: 0; }
}
@media (max-width: 560px) {
	.fang-mega-menu                  { --fang-bar-height: 48px; }
	.fang-mega-menu__top-link        { font-size: 13px; padding: 0 12px; }
	.fang-mega-menu__panel-inner     { padding: 24px var(--gutter, 20px) 18px; }
	.fang-mega-menu__mobile-header   { padding: 12px 16px; }
	.fang-mega-menu__mobile-link     { padding: 14px 16px; font-size: 15px; }
}

/* When the theme's old nav is hidden in favor of the mega menu, the
   menu-toggle button hides too. */
body.fang-has-mega-menu .menu-toggle,
body.fang-has-mega-menu .nav { display: none !important; }
