/**
 * BKiAI Translator - Frontend Styles
 *
 * Sprachwechsler-Dropdown.
 */

/* ============================================================
 * v0.8.3: Defensiver Reset gegen Theme-CSS
 * ------------------------------------------------------------
 * Wenn der Switcher als <li> ins Theme-Menue injected wird, erbt
 * er Theme-Regeln wie .nav-menu ul { min-width:12em; border:...; }.
 * Das macht das Dropdown breit, mit Theme-Border, manchmal nebeneinander.
 * Hier neutralisieren wir die wichtigsten Vererbungs-Pfade explizit.
 * ============================================================ */

/* Switcher-Wrapper sauber halten — egal in welchem Container er steckt. */
li.bkiai-lang-switcher-menu-item,
li.menu-item.bkiai-lang-switcher-menu-item {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	background: transparent !important;
	border: 0 !important;
	min-width: 0 !important;
	width: auto !important;
}

/* Trigger-Button: Theme-CSS auf Buttons/Links neutralisieren. */
.bkiai-lang-switcher .bkiai-lang-switcher__trigger {
	box-shadow: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	text-decoration: none !important;
	min-width: 0 !important;
	width: auto !important;
	height: auto !important;
	align-items: center !important;
	line-height: 1 !important;
}

/* v0.8.6: Flag-Emoji vertikal mittig zur Schrift ausrichten. */
.bkiai-lang-switcher .bkiai-lang-flag {
	display: inline-flex !important;
	align-items: center !important;
	line-height: 1 !important;
	transform: translateY(var(--bkiai-switcher-flag-offset-y, 0px)) !important;
}

/* v0.8.7: Trigger-Schrift (DE/EN) Y-Offset. Inline-block damit transform greift. */
.bkiai-lang-switcher__trigger .bkiai-lang-code {
	display: inline-block !important;
	transform: translateY(var(--bkiai-switcher-text-offset-y, 0px)) !important;
}

/* Dropdown-Menue selbst: erzwinge vertikale Liste.
   v0.8.5: Doppelte Klassen-Selektoren erhoehen Specificity (0,4,0) damit
   Theme-CSS wie `.site-header .header-right-wrapper ul { display: flex }`
   (0,2,1) nicht mehr durchschlaegt. */
.bkiai-lang-switcher.bkiai-lang-switcher .bkiai-lang-switcher__menu.bkiai-lang-switcher__menu {
	list-style: none !important;
	margin: 0 !important;
	padding: 6px !important;
	min-width: 140px !important;
	width: auto !important;
	max-width: none !important;
	background: var(--bkiai-switcher-menu-bg-color, #ffffff) !important;
	margin-top: var(--bkiai-switcher-menu-offset-top, 4px) !important;
	display: none !important;
	box-sizing: border-box !important;
	flex-direction: column !important;
}

.bkiai-lang-switcher.bkiai-lang-switcher.is-open .bkiai-lang-switcher__menu.bkiai-lang-switcher__menu {
	display: block !important;
}

/* Items im Dropdown: untereinander, volle Breite, kein Theme-Float. */
.bkiai-lang-switcher .bkiai-lang-switcher__menu .bkiai-lang-switcher__item {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	list-style: none !important;
	background: transparent !important;
	border: 0 !important;
}

/* Item-Links: volle Breite, kein Theme-Underline, kein Theme-Padding-Reset. */
.bkiai-lang-switcher .bkiai-lang-switcher__menu .bkiai-lang-switcher__item > a,
.bkiai-lang-switcher .bkiai-lang-switcher__menu .bkiai-lang-switcher__unavailable {
	display: flex !important;
	width: 100% !important;
	box-sizing: border-box !important;
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	line-height: 1.4 !important;
	box-shadow: none !important;
	border: 0 !important;
	/* v0.10.1: Border-Radius am Item-Link selbst, damit Hover/Active-State als
	   abgerundete "Pille" innerhalb des Panels erscheinen — analog zum Mega-Menue. */
	border-radius: var(--bkiai-switcher-menu-item-radius, 6px) !important;
}

/* ============================================================
 * Sprachwechsler - Dropdown (Basis-Styles)
 * ============================================================ */

.bkiai-lang-switcher {
	position: relative;
	display: inline-block;
	font-size: var(--bkiai-switcher-font-size, 14px);
	line-height: 1.4;
	margin: 0 4px;
	z-index: 100;
	color: var(--bkiai-switcher-text-color, #1a1a1a);
}

.bkiai-lang-switcher__trigger {
	background: var(--bkiai-switcher-bg-color, transparent);
	border: 1px solid var(--bkiai-switcher-border-color, rgba(0, 0, 0, 0.15));
	border-radius: var(--bkiai-switcher-border-radius, 6px);
	color: inherit;
	font-size: inherit;
	font-family: inherit;
	cursor: pointer;
	padding: 6px 10px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: background 0.2s, border-color 0.2s;
}

.bkiai-lang-switcher__trigger:hover {
	background: var(--bkiai-switcher-bg-hover-color, rgba(0, 0, 0, 0.05));
	border-color: var(--bkiai-switcher-border-color, rgba(0, 0, 0, 0.3));
}

.bkiai-lang-switcher__trigger:focus {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* Trigger-Flagge: nutzt die Trigger-Flaggen-Variable. */
.bkiai-lang-switcher__current .bkiai-lang-flag {
	font-size: var(--bkiai-switcher-flag-size, 16px);
	line-height: 1;
	transform: translateY(var(--bkiai-switcher-flag-offset-y, 0px));
}

/* Fallback: Flaggen ausserhalb von __current/__menu (sollte nicht vorkommen, aber defensiv). */
.bkiai-lang-flag {
	font-size: var(--bkiai-switcher-flag-size, 16px);
	line-height: 1;
}

.bkiai-lang-switcher__current .bkiai-lang-code {
	font-weight: 600;
	letter-spacing: 0.5px;
	font-size: inherit;
	transform: translateY(var(--bkiai-switcher-text-offset-y, 0px));
}

.bkiai-lang-code {
	font-weight: 600;
	letter-spacing: 0.5px;
	font-size: inherit;
}

.bkiai-lang-switcher__caret {
	font-size: 12px;
	opacity: 0.7;
	transition: transform 0.2s;
}

.bkiai-lang-switcher.is-open .bkiai-lang-switcher__caret {
	transform: rotate(180deg);
}

/* Dropdown-Menü — v0.8.1: separate Schrift-/Flaggen-Werte */

.bkiai-lang-switcher__menu {
	position: absolute;
	top: calc(100% + var(--bkiai-switcher-menu-offset-top, 4px));
	right: 0;
	min-width: 140px;
	background: var(--bkiai-switcher-menu-bg-color, #ffffff);
	border: 1px solid var(--bkiai-switcher-menu-border-color, var(--bkiai-switcher-border-color, #e0e0e0));
	border-radius: var(--bkiai-switcher-border-radius, 6px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	list-style: none;
	margin: 0;
	padding: 4px 0;
	display: none;
	color: var(--bkiai-switcher-menu-text-color, #1a1a1a);
	font-size: var(--bkiai-switcher-menu-font-size, 14px);
}

.bkiai-lang-switcher.is-open .bkiai-lang-switcher__menu {
	display: block;
}

.bkiai-lang-switcher__item {
	margin: 0;
	padding: 0;
	display: block;
}

/* v0.8.2: Variablen direkt auf den Items setzen, damit Theme-CSS sie nicht
   leicht ueberschreiben kann (hoehere Spezifitaet als reine Vererbung). */
.bkiai-lang-switcher__menu .bkiai-lang-switcher__item a,
.bkiai-lang-switcher__menu .bkiai-lang-switcher__unavailable {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	color: var(--bkiai-switcher-menu-text-color, #1a1a1a);
	text-decoration: none;
	font-size: var(--bkiai-switcher-menu-font-size, 14px);
	transition: background 0.15s, color 0.15s;
}

.bkiai-lang-switcher__menu .bkiai-lang-switcher__item a:hover {
	background: var(--bkiai-switcher-menu-bg-hover-color, var(--bkiai-switcher-bg-hover-color, #f5f5f5));
	color: var(--bkiai-switcher-menu-text-hover-color, var(--bkiai-switcher-menu-text-color, #1a1a1a));
	text-decoration: none;
}

.bkiai-lang-switcher__menu .bkiai-lang-switcher__item.is-current a {
	background: var(--bkiai-switcher-menu-bg-hover-color, var(--bkiai-switcher-bg-hover-color, #f0f6ff));
	font-weight: 600;
}

/* Menue-Flagge: eigene Groesse separat vom Trigger steuerbar. */
.bkiai-lang-switcher__menu .bkiai-lang-flag {
	font-size: var(--bkiai-switcher-menu-flag-size, 16px);
	line-height: 1;
	transform: translateY(var(--bkiai-switcher-menu-flag-offset-y, 0px)) !important;
}

/* v0.8.7: Menu-Schrift Y-Offset. transform braucht inline-block. */
.bkiai-lang-switcher__menu .bkiai-lang-code {
	display: inline-block !important;
	transform: translateY(var(--bkiai-switcher-menu-text-offset-y, 0px)) !important;
}

.bkiai-lang-switcher__item.is-unavailable {
	cursor: not-allowed;
}

.bkiai-lang-switcher__unavailable {
	color: #999;
	opacity: 0.55;
	filter: grayscale(40%);
	cursor: not-allowed;
	user-select: none;
}

.bkiai-lang-switcher__unavailable-marker {
	margin-left: auto;
	font-size: 12px;
	color: #d8a800;
	opacity: 0.8;
}

/* ============================================================
 * Mobile Anpassung (Hamburger-Menü)
 * ============================================================ */

@media (max-width: 768px) {
	.bkiai-lang-switcher-menu-item {
		width: 100%;
	}

	.bkiai-lang-switcher {
		display: block;
		margin: 4px 0;
	}

	.bkiai-lang-switcher__trigger {
		width: 100%;
		justify-content: space-between;
	}

	.bkiai-lang-switcher__menu {
		position: static;
		box-shadow: none;
		border: 0;
		background: rgba(0, 0, 0, 0.04);
		margin-top: 4px;
		min-width: 0;
		width: 100%;
	}
}

/* ============================================================
 * Inline-Style (alternativ)
 * ============================================================ */

.bkiai-lang-switcher--inline .bkiai-lang-switcher__trigger {
	display: none;
}

.bkiai-lang-switcher--inline .bkiai-lang-switcher__menu {
	position: static;
	display: flex;
	gap: 4px;
	box-shadow: none;
	border: 0;
	background: transparent;
	padding: 0;
}

.bkiai-lang-switcher--inline .bkiai-lang-switcher__item a,
.bkiai-lang-switcher--inline .bkiai-lang-switcher__unavailable {
	border: 1px solid #e0e0e0;
	border-radius: 4px;
	padding: 4px 10px;
}

.bkiai-lang-switcher--inline .bkiai-lang-switcher__item.is-current a {
	background: #2271b1;
	color: #fff;
	border-color: #2271b1;
}

/* ============================================================
 * PHASE 5.1: Floating-Switcher
 * ============================================================ */

.bkiai-floating-switcher {
	position: fixed;
	z-index: 9999;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 8px;
	padding: 4px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: #1a1a1a;
}

.bkiai-floating-switcher .bkiai-lang-switcher {
	margin: 0;
}

.bkiai-floating-switcher .bkiai-lang-switcher__trigger {
	border-color: rgba(0, 0, 0, 0.1);
	color: #1a1a1a;
}

.bkiai-floating-switcher .bkiai-lang-switcher__trigger:hover {
	background: rgba(0, 0, 0, 0.04);
}

/* Position-Varianten */

.bkiai-floating--top-right {
	top: 20px;
	right: 20px;
}

.bkiai-floating--top-left {
	top: 20px;
	left: 20px;
}

.bkiai-floating--bottom-right {
	bottom: 20px;
	right: 20px;
}

.bkiai-floating--bottom-left {
	bottom: 20px;
	left: 20px;
}

/* Bei Bottom-Position öffnet das Dropdown nach OBEN */

.bkiai-floating--bottom-right .bkiai-lang-switcher__menu,
.bkiai-floating--bottom-left .bkiai-lang-switcher__menu {
	top: auto;
	bottom: calc(100% + 4px);
}

/* Bei Left-Position öffnet das Dropdown nach RECHTS */

.bkiai-floating--top-left .bkiai-lang-switcher__menu,
.bkiai-floating--bottom-left .bkiai-lang-switcher__menu {
	right: auto;
	left: 0;
}

/* Mobile: Floating-Switcher kleiner */

@media (max-width: 768px) {
	.bkiai-floating-switcher {
		padding: 2px;
	}

	.bkiai-floating-switcher .bkiai-lang-switcher__trigger {
		padding: 4px 8px;
		font-size: 13px;
	}

	.bkiai-floating--top-right,
	.bkiai-floating--top-left {
		top: 12px;
	}

	.bkiai-floating--bottom-right,
	.bkiai-floating--bottom-left {
		bottom: 12px;
	}

	.bkiai-floating--top-right,
	.bkiai-floating--bottom-right {
		right: 12px;
	}

	.bkiai-floating--top-left,
	.bkiai-floating--bottom-left {
		left: 12px;
	}
}

/* Bei Admin-Bar oben Floating leicht nach unten verschieben */

.admin-bar .bkiai-floating--top-right,
.admin-bar .bkiai-floating--top-left {
	top: 52px;
}

@media (max-width: 782px) {
	.admin-bar .bkiai-floating--top-right,
	.admin-bar .bkiai-floating--top-left {
		top: 60px;
	}
}
