/* =========================================================================
   Kludružba – Bočné upozornenie (plávajúci pútač)
   Fixne prilepené na okraji obrazovky. Zladené s dizajnom kludruzba.sk.

   DÔLEŽITÉ: štýly sú zámerne "zabetónované" (#kdFab + !important), aby ich
   téma webu (Elementor / Hello téma) nevedela prepísať.
   ========================================================================= */

#kdFab.kd-fab {
	--kd-zlata: #caa953;
	--kd-zlata-tmava: #b8943f;
	--kd-modra: #1f3f75;
	--kd-modra-tlmena: rgba(31, 63, 117, 0.72);
	--kd-krem: #fbfaf2;
	--kd-modra-svetla: #e3e8f2;
	--kd-ramik: #ece7d8;
	--kd-font-nadpis: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--kd-font-text: "Lora", Georgia, serif;

	position: fixed !important;
	top: 50% !important;
	left: 0 !important;
	right: auto !important;
	transform: translateY(-50%) !important;
	z-index: 99990 !important;
	display: flex !important;
	align-items: center !important;
	margin: 0 !important;
	padding: 0 !important;
	font-family: var(--kd-font-text) !important;
}
#kdFab.kd-fab-right { left: auto !important; right: 0 !important; flex-direction: row-reverse !important; }

/* Reset prípadných štýlov témy vo vnútri pútača */
#kdFab, #kdFab * { box-sizing: border-box; }
#kdFab button {
	-webkit-appearance: none !important;
	appearance: none !important;
	margin: 0;
	font-family: var(--kd-font-text) !important;
	text-shadow: none !important;
	min-height: 0 !important;
	width: auto;
}

/* ------------------------------- Záložka (tab) ------------------------ */
#kdFab .kd-fab-tab {
	position: relative !important;
	z-index: 2;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	gap: 8px !important;
	border: none !important;
	cursor: pointer !important;
	background: var(--kd-zlata) !important;
	color: var(--kd-modra) !important;
	padding: 13px 9px !important;
	border-radius: 0 12px 12px 0 !important;
	box-shadow: 0 4px 14px rgba(31, 63, 117, 0.2) !important;
	width: auto !important;
	height: auto !important;
	transition: background .2s ease;
	animation: kd-fab-pulz 2.4s ease-in-out infinite;
}
#kdFab.kd-fab-right .kd-fab-tab { border-radius: 12px 0 0 12px !important; }
#kdFab .kd-fab-tab:hover { background: var(--kd-zlata-tmava) !important; }
#kdFab.kd-open .kd-fab-tab { animation: none; }

/* Text lišty = dva zvislé stĺpce (slová) vedľa seba, čitateľné */
#kdFab .kd-fab-tab-text {
	display: flex !important;
	flex-direction: row !important;
	align-items: stretch !important;
	justify-content: center !important;
	gap: 5px !important;
	writing-mode: horizontal-tb !important;
	direction: ltr !important;        /* poistka: slová vždy zľava doprava */
	unicode-bidi: isolate !important;
	background: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
#kdFab .kd-fab-slovo {
	writing-mode: vertical-rl !important;
	text-orientation: mixed !important;
	color: var(--kd-modra) !important;
	font-family: var(--kd-font-text) !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: .1em !important;
	line-height: 1 !important;
	white-space: nowrap !important;
	background: none !important;
}

#kdFab .kd-fab-pocet {
	writing-mode: horizontal-tb !important;
	min-width: 17px !important;
	height: 17px !important;
	padding: 0 4px !important;
	border-radius: 999px !important;
	background: var(--kd-modra) !important;
	color: #fff !important;
	font-size: 10px !important;
	font-weight: 700 !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	letter-spacing: 0 !important;
}

@keyframes kd-fab-pulz {
	0%, 100% { box-shadow: 0 4px 14px rgba(31, 63, 117, 0.2); }
	50%      { box-shadow: 0 4px 14px rgba(31, 63, 117, 0.2), 0 0 0 6px rgba(202, 169, 83, 0.16); }
}

/* ------------------------------- Panel -------------------------------- */
#kdFab .kd-fab-panel {
	position: absolute !important;
	left: 100% !important;
	right: auto !important;
	top: 50% !important;
	margin: 0 0 0 10px !important;
	width: 270px !important;
	max-width: calc(100vw - 56px) !important;
	max-height: calc(100vh - 32px) !important;
	overflow-y: auto !important;
	background: #fff !important;
	border: 1px solid var(--kd-ramik) !important;
	border-radius: 14px !important;
	box-shadow: 0 14px 36px rgba(31, 63, 117, 0.18) !important;
	padding: 14px !important;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(-50%) translateX(-12px);
	transition: opacity .25s ease, transform .25s ease, visibility .25s;
}
#kdFab.kd-fab-right .kd-fab-panel {
	left: auto !important;
	right: 100% !important;
	margin: 0 10px 0 0 !important;
	transform: translateY(-50%) translateX(12px);
}
#kdFab.kd-open .kd-fab-panel {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(-50%) translateX(0);
}

#kdFab .kd-fab-hlavicka {
	display: flex !important;
	align-items: flex-start !important;
	justify-content: space-between !important;
	gap: 8px !important;
	margin: 0 0 10px !important;
	padding: 0 !important;
	border: 0 !important;
}
#kdFab .kd-fab-nadpis {
	font-family: var(--kd-font-nadpis) !important;
	font-weight: 700 !important;
	color: var(--kd-modra) !important;
	font-size: 17px !important;
	line-height: 1.15 !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
#kdFab .kd-fab-zatvor {
	flex: 0 0 auto !important;
	border: none !important;
	background: var(--kd-modra-svetla) !important;
	color: var(--kd-modra) !important;
	width: 24px !important;
	height: 24px !important;
	min-width: 0 !important;
	border-radius: 50% !important;
	cursor: pointer !important;
	font-size: 16px !important;
	line-height: 1 !important;
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	transition: background .2s ease;
}
#kdFab .kd-fab-zatvor:hover { background: #d4ddef !important; }

#kdFab .kd-fab-zoznam {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
}
#kdFab .kd-fab-zoznam li { margin: 0 !important; padding: 0 !important; list-style: none !important; }
#kdFab .kd-fab-zoznam li:before { content: none !important; }

#kdFab .kd-fab-item {
	display: block !important;
	text-decoration: none !important;
	padding: 9px 11px !important;
	border: 1px solid var(--kd-ramik) !important;
	border-radius: 10px !important;
	background: var(--kd-krem) !important;
	transition: border-color .2s ease, transform .15s ease;
}
#kdFab a.kd-fab-item:hover { border-color: var(--kd-zlata) !important; transform: translateY(-1px); }

#kdFab .kd-fab-item-top {
	display: flex !important;
	align-items: baseline !important;
	justify-content: space-between !important;
	gap: 8px !important;
}
#kdFab .kd-fab-item-nazov {
	font-family: var(--kd-font-nadpis) !important;
	font-weight: 700 !important;
	color: var(--kd-modra) !important;
	font-size: 15px !important;
	line-height: 1.2 !important;
	letter-spacing: normal !important;
}
#kdFab .kd-fab-item-cena {
	flex: 0 0 auto !important;
	font-family: var(--kd-font-nadpis) !important;
	font-weight: 700 !important;
	color: var(--kd-zlata-tmava) !important;
	font-size: 14px !important;
	white-space: nowrap !important;
}
#kdFab .kd-fab-item-meta {
	display: block !important;
	margin: 2px 0 0 !important;
	font-size: 12px !important;
	color: var(--kd-modra-tlmena) !important;
	font-family: var(--kd-font-text) !important;
}
#kdFab .kd-fab-odznak-sez {
	display: inline-block !important;
	margin: 5px 0 0 !important;
	font-size: 9px !important;
	font-weight: 600 !important;
	letter-spacing: .05em !important;
	text-transform: uppercase !important;
	padding: 2px 8px !important;
	border-radius: 50px !important;
	background: var(--kd-zlata) !important;
	color: var(--kd-modra) !important;
	font-family: var(--kd-font-text) !important;
}

#kdFab .kd-fab-cta {
	display: block !important;
	text-align: center !important;
	margin: 12px 0 0 !important;
	padding: 9px 14px !important;
	border-radius: 50px !important;
	background: var(--kd-zlata) !important;
	color: var(--kd-modra) !important;
	text-decoration: none !important;
	font-weight: 600 !important;
	font-size: 12px !important;
	line-height: 1.3 !important;
	text-transform: uppercase !important;
	letter-spacing: .03em !important;
	font-family: var(--kd-font-text) !important;
	transition: background .2s ease;
}
#kdFab .kd-fab-cta:hover { background: var(--kd-zlata-tmava) !important; }

/* ------------------------- Responzívne / mobil ------------------------ */
/* Tablet a menej – ešte trochu menší panel */
@media (max-width: 768px) {
	#kdFab .kd-fab-panel { width: 250px !important; }
}

/* Mobil – lišta dospodu, panel sa vysunie NAD lištu cez šírku obrazovky */
@media (max-width: 600px) {
	#kdFab.kd-fab { top: auto !important; bottom: 12px !important; transform: none !important; }
	#kdFab.kd-fab-right { transform: none !important; }
	#kdFab .kd-fab-tab { padding: 11px 7px !important; }
	#kdFab .kd-fab-slovo { font-size: 11px !important; letter-spacing: .08em !important; }
	#kdFab .kd-fab-panel {
		position: absolute !important;
		left: 12px !important;
		right: auto !important;
		top: auto !important;
		bottom: calc(100% + 8px) !important;
		margin: 0 !important;
		width: calc(100vw - 24px) !important;
		max-width: none !important;
		max-height: calc(100vh - 90px) !important;
		transform: translateY(8px) !important;
	}
	#kdFab.kd-fab-right .kd-fab-panel {
		left: auto !important;
		right: 12px !important;
		transform: translateY(8px) !important;
	}
	#kdFab.kd-open .kd-fab-panel { transform: translateY(0) !important; }
}

@media (prefers-reduced-motion: reduce) {
	#kdFab .kd-fab-tab { animation: none; }
}
