/**
 * Nützliches Menü – Frontend Mega-Dropdown
 */

/* Wrapper + Hamburger – Desktop: Menü normal sichtbar, Hamburger ausgeblendet */
.nm-mega-menu-wrapper {
	position: relative;
	display: flex;
	align-items: center;
}
.nm-hamburger {
	display: none;
}
.nm-mega-menu-wrapper .w-nav {
	display: block;
}

/* Theme-Pfeile bei Mega-Menü-Items ausblenden */
.w-nav.nm-mega-menu-shortcode .nm-has-mega > .w-nav-anchor .w-nav-arrow {
	display: none !important;
}

/* Desktop: li mit Mega-Menü als inline-flex, damit Button neben Anchor bleibt */
.w-nav.nm-mega-menu-shortcode .w-nav-list.level_1 > .menu-item.nm-has-mega {
	display: inline-flex !important;
	align-items: center;
	position: relative;
}

/* Mega-Arrow Toggle-Button (Desktop: rein visuell, Mobile: klickbar) */
button.nm-mega-arrow {
	background: none;
	border: none;
	padding: 0.25em;
	margin: 0 0 0 -0.3rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 0.75em;
	opacity: 0.9;
	transition: transform 0.2s;
	box-sizing: border-box;
	color: inherit;
	font-family: inherit;
	line-height: 1;
}

.menu-item.nm-has-mega.opened > .nm-mega-arrow,
.menu-item.nm-has-mega.nm-hover > .nm-mega-arrow {
	transform: rotate(180deg);
}

/* Abstände zwischen Top-Level-Menüpunkten (verhindert "Zusammenklatschen") */
.w-nav.nm-mega-menu-shortcode .w-nav-list.level_1 > .menu-item > .w-nav-anchor {
	padding-left: 1rem;
	padding-right: 1rem;
}
.w-nav.nm-mega-menu-shortcode .w-nav-list.level_1 > .menu-item:first-child > .w-nav-anchor {
	padding-left: 0;
}
.w-nav.nm-mega-menu-shortcode .w-nav-list.level_1 > .menu-item:last-child > .w-nav-anchor {
	padding-right: 0;
}

/* Mega-Dropdown: gleiche Sichtbarkeitslogik */
.w-nav.nm-mega-menu-shortcode .nm-mega-dropdown {
	display: none;
	visibility: hidden;
}
.w-nav.nm-mega-menu-shortcode .menu-item.nm-has-mega.nm-hover > .nm-mega-dropdown,
.w-nav.nm-mega-menu-shortcode .menu-item.nm-has-mega.opened > .nm-mega-dropdown {
	display: block;
	visibility: visible;
}

/* Mega-Dropdown: feste Position, volle Content-Breite nutzen */
.nm-mega-menu-shortcode .nm-mega-dropdown {
	position: fixed;
	top: var(--nm-dropdown-top, 80px);
	left: 50%;
	transform: translateX(-50%);
	z-index: 99;
	width: var(--site-content-width, 1140px);
	max-width: calc(100vw - 2rem);
	box-shadow: var(--box-shadow, 0 4px 20px rgba(0,0,0,0.15));
	background: var(--nm-menu-bg, #fff);
	padding: 2rem 2.5rem;
	text-align: left;
	box-sizing: border-box;
	color: var(--nm-menu-text, #000);
}

/* Spalten-Layout – gleich groß, volle Breite füllen */
.nm-mega-columns {
	display: grid;
	grid-template-rows: auto 1fr;
	column-gap: 2.5rem;
	row-gap: 0;
	padding: 0;
	width: 100%;
	max-width: 100%;
	min-width: 0;
}

.nm-mega-column {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 2;
	min-width: 0;
}

.nm-mega-col-header {
	min-height: 0;
}

.nm-mega-col-body {
	min-height: 0;
}

/* Untermenü-Liste */
.nm-mega-submenu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.nm-mega-submenu .w-nav-item {
	display: block;
	margin: 0;
}

.nm-mega-submenu .w-nav-anchor {
	display: block;
	padding: 0.5em 0;
	line-height: 1.4;
	white-space: nowrap;
	transition: opacity 0.2s;
	color: var(--nm-menu-link, var(--nm-menu-text, #000));
	text-decoration: var(--nm-menu-link-td, none);
}

.nm-mega-submenu .w-nav-anchor:hover {
	opacity: 0.8;
}

/* Blöcke */
.nm-mega-block {
	margin-bottom: 0.75rem;
}

/* Überschrift + Subline: direkt untereinander, nur Zeilenhöhe (via <br>) */
.nm-mega-block-heading .nm-mega-heading-wrap,
.nm-mega-block-heading .nm-mega-heading-link {
	display: block;
	line-height: 1.25;
}
.nm-mega-block-heading .nm-mega-heading {
	font-weight: var(--nm-bold-font-weight, 700);
	font-size: 1.15rem;
	margin: 0;
	padding: 0;
	color: var(--nm-menu-text, #000);
}
.nm-mega-block-heading .nm-mega-heading-subline {
	font-size: 0.85em;
	margin: 0;
	padding: 0;
	opacity: 0.85;
	white-space: normal;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
.nm-mega-heading-link {
	text-decoration: none;
	color: inherit;
	transition: opacity 0.2s;
}
.nm-mega-heading-link:hover {
	opacity: 0.85;
}

.nm-mega-text {
	display: block;
	font-size: 0.9em;
	line-height: 1.4;
	color: var(--nm-menu-text, #000);
}

/* Link mit Icon + Subline */
.nm-mega-link {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
	text-decoration: var(--nm-menu-link-td, none);
	color: var(--nm-menu-link, var(--nm-menu-text, #000));
	transition: opacity 0.2s;
}
.nm-mega-link:hover,
.nm-mega-link:hover .nm-mega-link-title,
.nm-mega-link:hover .nm-mega-link-subline {
	color: var(--nm-menu-link, var(--color-content-primary, var(--color-primary, var(--nm-menu-text, #000)))) !important;
}
.nm-mega-link-icon {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	min-width: 32px;
	min-height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.nm-mega-link-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.nm-mega-link-content {
	display: flex;
	flex-direction: column;
	gap: 0;
	line-height: 1.25;
	min-width: 0;
}
.nm-mega-link-title {
	font-weight: var(--nm-font-weight, 400);
	margin: 0;
	padding: 0;
}
.nm-mega-link-subline {
	font-size: 0.85em;
	opacity: 0.8;
	margin: 0;
	padding: 0;
	white-space: normal;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

/* Bild-Block */
.nm-mega-image-link {
	display: block;
	text-decoration: none;
	color: inherit;
	transition: opacity 0.2s;
}
.nm-mega-image-link:hover {
	opacity: 0.85;
}
.nm-mega-image-wrap {
	display: block;
	overflow: hidden;
	border-radius: 6px;
}
.nm-mega-image-wrap img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}
.nm-mega-image-subline {
	display: block;
	font-size: 0.85em;
	margin-top: 0.35rem;
	opacity: 0.8;
	color: var(--nm-menu-text, #000);
}

/* Formular */
.nm-mega-block-form {
	width: 100%;
}
.nm-mega-form-wrap {
	color: var(--nm-menu-text, #000);
}
.nm-mega-form-wrap .wpcf7 {
	width: 100%;
}
.nm-mega-form-wrap .wpcf7 input:not([type="submit"]),
.nm-mega-form-wrap .wpcf7 textarea,
.nm-mega-form-wrap .wpcf7 select {
	width: 100%;
	box-sizing: border-box;
}
.nm-mega-form-wrap .wpcf7 label {
	color: var(--nm-menu-text, #000);
	margin-bottom: 0;
	line-height: 1.3;
}
.nm-mega-form-wrap .wpcf7 p {
	margin: 0 0 0.5em 0;
}
.nm-mega-form-wrap .wpcf7 br {
	display: none;
}
.nm-mega-form-wrap .wpcf7 .wpcf7-form-control {
	margin: 2px 0 0 0 !important;
}
.nm-mega-form-wrap .wpcf7-form-control-wrap {
	display: block !important;
	margin: 2px 0 0 0 !important;
	padding: 0 !important;
}
.nm-mega-form-wrap .wpcf7 input:not([type="submit"]),
.nm-mega-form-wrap .wpcf7 textarea {
	margin-top: 0 !important;
}

/* Button */
.nm-mega-btn {
	display: inline-block;
	margin-top: 0.5rem;
}

/* Beiträge */
.nm-mega-posts {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.nm-mega-post {
	display: flex;
	gap: 0.75rem;
	align-items: flex-start;
}
.nm-mega-post-thumb {
	flex-shrink: 0;
	width: 60px;
	height: 60px;
	overflow: hidden;
	border-radius: 4px;
}
.nm-mega-post-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.nm-mega-post-content {
	flex: 1;
	min-width: 0;
	line-height: 1.25;
}
.nm-mega-post-title {
	font-weight: var(--nm-font-weight, 400);
	font-size: 1em;
	display: block;
	margin: 0;
	padding: 0;
	color: var(--nm-menu-text, #000) !important;
	transition: color 0.2s;
}
.nm-mega-post-title:hover {
	color: var(--nm-menu-link, var(--color-content-primary, var(--color-primary, var(--nm-menu-text, #000)))) !important;
}
.nm-mega-post-excerpt {
	font-size: 0.85em;
	line-height: 1.25;
	margin: 0;
	padding: 0;
	opacity: 0.8;
	color: var(--nm-menu-text, #000);
	white-space: normal;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
.nm-mega-post-link {
	display: inline-block;
	font-size: 0.85em;
	color: var(--nm-menu-link, var(--nm-menu-text, #000));
	text-decoration: underline;
	transition: color 0.2s;
	margin-top: 0.25rem;
}
.nm-mega-post-link:hover {
	color: var(--nm-menu-link, var(--color-content-primary, var(--color-primary, var(--nm-menu-text, #000)))) !important;
}
