/* =======================================================
   VÝPIS BRIGÁD — Fajn Brigády (přebarvená verze)
   WCAG 2.2 AA / EAA 2026 ready
   ======================================================= */

:root {
	--fb-oranz: #ea580c;
	--fb-oranz-tmava: #c2410c;
	--fb-oranz-svetla: #fff3e6;
	--fb-akcent: #FF8C00;
	--fb-akcent-svetla: #ffd9a8;
	--fb-seda-90: #f8fafc;
	--fb-seda-80: #f1f5f9;
	--fb-seda-60: #cbd5e1;
	--fb-seda-40: #94a3b8;
	--fb-seda-20: #475569;
	--fb-seda-10: #1e293b;
}

/* Reset body — vlastní render bez _template.php */
body {
	margin: 0;
	font-family: "Rubik", sans-serif;
	color: var(--fb-seda-10);
	background: #fff;
}

/* =======================================================
   HLAVIČKA (port z fajnprace varianta E, oranžové barvy FB)
   ======================================================= */
.hvb-header {
	background: rgba(255, 255, 255, 0.85);
	backdrop-filter: saturate(180%) blur(12px);
	-webkit-backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--fb-seda-80);
	margin: 0 0 24px;
	padding: 10px 0;
	position: sticky;
	top: 0;
	z-index: 30;
	font-family: "Rubik", sans-serif;
}

.hvb-header__obsah {
	display: flex;
	align-items: center;
	gap: 16px;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 20px;
}

.hvb-header__logo {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}

.hvb-header__logo img {
	height: 36px;
	width: auto;
	display: block;
}

.hvb-header__logo:focus-visible {
	outline: 3px solid var(--fb-oranz);
	outline-offset: 4px;
	border-radius: 4px;
}

.hvb-header__nav {
	flex: 1;
}

.hvb-header__nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 2px;
}

.hvb-header__link {
	position: relative;
	display: inline-block;
	padding: 8px 12px;
	color: var(--fb-seda-10);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	border-radius: 6px;
	transition: color 0.15s ease, background 0.15s ease;
	white-space: nowrap;
}

.hvb-header__link:hover {
	color: var(--fb-oranz);
	background: var(--fb-seda-80);
}

.hvb-header__link:focus-visible {
	outline: 2px solid var(--fb-oranz);
	outline-offset: 2px;
}

.hvb-header__akce {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}

.hvb-header__prihlasit {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	margin-left: 6px;
	color: var(--fb-oranz);
	background: transparent;
	border: 1px solid var(--fb-oranz);
	border-radius: 8px;
	text-decoration: none;
	font-size: 14px;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease;
}

.hvb-header__prihlasit svg {
	width: 16px;
	height: 16px;
}

.hvb-header__prihlasit:hover {
	background: var(--fb-oranz);
	color: #fff;
}

.hvb-header__pro-firmy {
	display: inline-flex;
	align-items: center;
	padding: 8px 12px;
	margin-left: 4px;
	color: var(--fb-seda-20);
	text-decoration: none;
	font-size: 13px;
	font-weight: 500;
	border-left: 1px solid var(--fb-seda-60);
	transition: color 0.15s ease;
}

.hvb-header__pro-firmy:hover {
	color: var(--fb-akcent);
}

/* Hamburger */
.hvb-header__hamburger {
	display: none;
	width: 40px;
	height: 40px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 4px;
	background: transparent;
	border: 1px solid var(--fb-seda-60);
	border-radius: 8px;
	cursor: pointer;
	flex-shrink: 0;
}

.hvb-header__hamburger span {
	display: block;
	width: 20px;
	height: 2px;
	background: var(--fb-seda-10);
	border-radius: 2px;
}

@media (max-width: 1100px) {
	.hvb-header__pro-firmy { display: none; }
}

@media (max-width: 880px) {
	.hvb-header__nav { display: none; }
	.hvb-header__akce {
		display: inline-flex;
		margin-left: auto;
		gap: 4px;
		align-items: center;
	}
	.hvb-header__pro-firmy {
		display: inline-flex;
		padding: 6px 8px;
		font-size: 12px;
		border-left: none;
	}
	.hvb-header__prihlasit {
		padding: 7px 12px;
		font-size: 13px;
		gap: 4px;
	}
	.hvb-header__prihlasit svg {
		width: 14px;
		height: 14px;
	}
	.hvb-header__hamburger { display: inline-flex; }
}

@media (max-width: 480px) {
	.hvb-header__obsah {
		gap: 4px;
		padding: 10px 12px;
	}
	.hvb-header__akce { gap: 2px; }
	.hvb-header__prihlasit span { display: none; }
	.hvb-header__prihlasit {
		width: 36px;
		height: 36px;
		padding: 0;
		justify-content: center;
		border-radius: 50%;
	}
	.hvb-header__pro-firmy { display: none; }
}

/* =======================================================
   LOGIN DROPDOWN
   ======================================================= */
.hvb-login {
	position: relative;
	display: inline-flex;
	align-items: center;
}

.hvb-login__guest {
	position: relative;
	display: inline-flex;
}

.hvb-login__drop {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 320px;
	display: none;
	background: #fff;
	border: 1.5px solid var(--fb-oranz);
	border-radius: 12px;
	padding: 14px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
	z-index: 100;
}

.hvb-login__drop.show {
	display: block;
	animation: hvbLoginDropIn 0.18s ease-out;
}

@keyframes hvbLoginDropIn {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}

.hvb-login__sekce {
	padding: 4px 0;
}

.hvb-login__sekce-nadpis {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 8px;
	font-size: 13px;
	font-weight: 800;
	color: var(--fb-seda-10);
	letter-spacing: 0.01em;
}

.hvb-login__sekce-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 6px;
	flex-shrink: 0;
}

.hvb-login__sekce-badge svg {
	width: 13px;
	height: 13px;
}

.hvb-login__sekce-badge--uchazec {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz);
}

.hvb-login__sekce-badge--firma {
	background: var(--fb-akcent-svetla);
	color: var(--fb-akcent);
}

.hvb-login__sekce-podtitulek {
	margin: 0 0 8px;
	font-size: 12px;
	color: var(--fb-seda-40);
	line-height: 1.4;
}

.hvb-login__divider {
	position: relative;
	margin: 14px 0 12px;
	text-align: center;
	height: 1px;
	background: var(--fb-seda-80);
}

.hvb-login__divider span {
	position: relative;
	top: -10px;
	padding: 0 10px;
	background: #fff;
	font-size: 11px;
	font-weight: 700;
	color: var(--fb-seda-40);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.hvb-login__firma-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 10px 14px;
	background: var(--fb-akcent);
	color: #fff;
	border: none;
	border-radius: 9px;
	font-family: inherit;
	font-size: 13.5px;
	font-weight: 700;
	cursor: pointer;
	transition: all 0.15s;
	box-shadow: 0 4px 10px -4px rgba(255, 140, 0, 0.4);
}

.hvb-login__firma-btn:hover {
	background: #e07800;
	transform: translateY(-1px);
}

.hvb-login__firma-btn svg {
	width: 14px;
	height: 14px;
}

.hvb-login__firma-vse {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	margin-top: 8px;
	padding: 6px;
	font-size: 12px;
	color: var(--fb-seda-20);
	text-decoration: none;
	border-radius: 6px;
	transition: background 0.15s;
}

.hvb-login__firma-vse:hover {
	background: var(--fb-akcent-svetla);
	color: #e07800;
}

.hvb-login__firma-vse strong {
	color: var(--fb-akcent);
	font-weight: 700;
}

.hvb-login__firma-vse svg {
	width: 10px;
	height: 10px;
	color: var(--fb-akcent);
}

.hvb-login__icons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.hvb-login__soc {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px;
	background: var(--fb-seda-90);
	border: 1.5px solid var(--fb-seda-60);
	border-radius: 10px;
	font-size: 13px;
	font-weight: 600;
	color: var(--fb-seda-20);
	font-family: inherit;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s, color 0.15s;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	min-width: 0;
	justify-content: flex-start;
}

.hvb-login__soc:hover,
.hvb-login__soc:focus {
	border-color: var(--fb-oranz);
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz);
	outline: none;
}

.hvb-login__soc-ico {
	display: inline-block;
	width: 20px;
	height: 20px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	flex-shrink: 0;
}

.hvb-login__soc-ico--email {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Crect width='48' height='48' rx='8' fill='%23ea580c'/%3E%3Cpath stroke='white' stroke-width='2.5' fill='none' d='M8 14h32v20H8z'/%3E%3Cpath stroke='white' stroke-width='2.5' fill='none' d='M8 14l16 11L40 14'/%3E%3C/svg%3E");
}

.hvb-login__soc-ico--gmail {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%23EA4335' d='M6 40h7V23.1L4 17v20c0 1.7 1.3 3 2 3z'/%3E%3Cpath fill='%2334A853' d='M35 40h7c.7 0 2-1.3 2-3V17l-9 6.1V40z'/%3E%3Cpath fill='%23FBBC05' d='M35 10H13L24 18.1 35 10z'/%3E%3Cpath fill='%234285F4' d='M13 10H6c-.7 0-2 1.3-2 3v4l9 6 9-6V10z'/%3E%3Cpath fill='%23EA4335' d='M44 13v4l-9 6-2-1.4L24 18.1 13 23l-9-6V13c0-1.7 1.3-3 2-3h7l11 8.1L35 10h7c.7 0 2 1.3 2 3z'/%3E%3C/svg%3E");
}

.hvb-login__soc-ico--fb {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%231877F2' d='M44 24c0-11-9-20-20-20S4 13 4 24c0 10 7.3 18.3 17 19.8V30h-5v-6h5v-4.5c0-5 3-7.8 7.6-7.8 2.2 0 4.4.4 4.4.4V17h-2.5c-2.5 0-3.2 1.5-3.2 3.1V24h5.5l-.9 6H27v13.8C36.7 42.3 44 34 44 24z'/%3E%3C/svg%3E");
}

.hvb-login__soc-ico--seznam {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Crect width='48' height='48' rx='8' fill='%23CC0000'/%3E%3Ctext x='50%25' y='55%25' dominant-baseline='middle' text-anchor='middle' fill='white' font-size='22' font-weight='bold' font-family='Arial'%3ES%3C/text%3E%3C/svg%3E");
}

/* Mobilní login popup — dropdown jako modal */
.hvb-login__drop--mobile {
	position: fixed !important;
	top: 50% !important;
	left: 50% !important;
	right: auto !important;
	transform: translate(-50%, -50%);
	width: min(92vw, 360px);
	min-width: 0;
	max-width: none;
	z-index: 2000;
	padding: 22px 18px;
	box-shadow: 0 30px 70px rgba(30, 41, 59, 0.4);
	display: block !important;
	animation: hvbMobLoginIn 0.22s ease-out;
}

@keyframes hvbMobLoginIn {
	from { opacity: 0; transform: translate(-50%, -46%) scale(0.96); }
	to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

.hvb-mob-login-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(30, 41, 59, 0.55);
	backdrop-filter: blur(2px);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.22s ease;
	z-index: 1900;
}

.hvb-mob-login-backdrop.open {
	opacity: 1;
	visibility: visible;
}

@media (max-width: 480px) {
	.hvb-login__drop {
		right: -8px;
		min-width: 240px;
	}
}

/* =======================================================
   MOBILNÍ OFF-CANVAS MENU
   ======================================================= */
.hvb-mob {
	position: fixed;
	inset: 0;
	z-index: 1500;
	pointer-events: none;
	visibility: hidden;
}

.hvb-mob.open {
	pointer-events: auto;
	visibility: visible;
}

.hvb-mob__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(30, 41, 59, 0.55);
	backdrop-filter: blur(2px);
	opacity: 0;
	transition: opacity 0.25s ease;
}

.hvb-mob.open .hvb-mob__backdrop {
	opacity: 1;
}

.hvb-mob__panel {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(86vw, 360px);
	background: #fff;
	box-shadow: -16px 0 40px -10px rgba(30, 41, 59, 0.25);
	transform: translateX(100%);
	transition: transform 0.3s cubic-bezier(.2, .7, .2, 1);
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	padding: 18px;
	gap: 8px;
	font-family: "Rubik", sans-serif;
}

.hvb-mob.open .hvb-mob__panel {
	transform: translateX(0);
}

.hvb-mob__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--fb-seda-80);
}

.hvb-mob__logo img {
	height: 36px;
	display: block;
}

.hvb-mob__close {
	width: 40px;
	height: 40px;
	border-radius: 8px;
	border: 1px solid var(--fb-seda-60);
	background: #fff;
	color: var(--fb-seda-20);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s, color 0.15s;
}

.hvb-mob__close:hover { background: var(--fb-seda-80); color: var(--fb-seda-10); }
.hvb-mob__close svg { width: 18px; height: 18px; }

.hvb-mob__nav {
	margin: 10px 0 4px;
}

.hvb-mob__nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.hvb-mob__link {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 10px;
	border-radius: 10px;
	color: var(--fb-seda-10);
	text-decoration: none;
	font-size: 16px;
	font-weight: 600;
	transition: background 0.15s, color 0.15s;
}

.hvb-mob__link:hover,
.hvb-mob__link:focus {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz);
	outline: none;
}

.hvb-mob__link svg {
	width: 20px;
	height: 20px;
	color: var(--fb-oranz);
	flex-shrink: 0;
}

.hvb-mob__cta {
	margin-top: auto;
	padding-top: 16px;
	border-top: 1px solid var(--fb-seda-80);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
}

.hvb-mob__cta > #hvbMobLoginSlot {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	width: 100%;
}

.hvb-mob__login {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 28px;
	min-width: 220px;
	max-width: 320px;
	margin: 0 auto;
	background: var(--fb-oranz);
	color: #fff;
	border: none;
	border-radius: 10px;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.15s;
}

.hvb-mob__login:hover { background: var(--fb-oranz-tmava); }
.hvb-mob__login svg { width: 18px; height: 18px; }

.hvb-mob__login--firma {
	background: #fff;
	color: var(--fb-akcent);
	border: 1.5px solid var(--fb-akcent);
	margin-top: 8px;
}

.hvb-mob__login--firma:hover {
	background: var(--fb-akcent);
	color: #fff;
}

/* =======================================================
   IKONY ULOŽENÉ + UPOZORNĚNÍ (PC header, jen po přihlášení)
   ======================================================= */
.hvb-header__user-icons {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.hvb-header__user-icons[hidden] {
	display: none;
}

.hvb-header__ikona {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	color: var(--fb-seda-10);
	border-radius: 50%;
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
}

.hvb-header__ikona:hover {
	background: var(--fb-seda-80);
	color: var(--fb-oranz);
}

.hvb-header__ikona:focus-visible {
	outline: 2px solid var(--fb-oranz);
	outline-offset: 2px;
}

.hvb-header__ikona svg {
	width: 20px;
	height: 20px;
}

.hvb-header__odznak {
	position: absolute;
	top: 6px;
	right: 6px;
	min-width: 16px;
	height: 16px;
	padding: 0 4px;
	background: var(--fb-akcent);
	color: #fff;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 700;
	line-height: 16px;
	text-align: center;
	box-shadow: 0 0 0 2px #fff;
}

.hvb-header__odznak--aktivni {
	min-width: 8px;
	height: 8px;
	top: 8px;
	right: 9px;
	padding: 0;
}

/* =======================================================
   USER BADGE (přihlášený stav v PC headeru)
   ======================================================= */
.hvb-login__user {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--fb-oranz-svetla);
	border: 1.5px solid var(--fb-oranz);
	border-radius: 12px;
	padding: 6px 10px 6px 6px;
	margin-left: 6px;
}

.hvb-login__user[hidden] { display: none; }
.hvb-login__guest[hidden] { display: none; }

.hvb-ub {
	position: relative;
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	background: transparent;
	border: none;
	padding: 0;
	cursor: pointer;
	display: block;
	transition: transform 0.15s;
}

.hvb-ub:hover { transform: scale(1.05); }

.hvb-ub__ring {
	position: absolute;
	inset: 0;
	width: 40px;
	height: 40px;
	transform: rotate(-90deg);
}

.hvb-ub__ring-bg {
	fill: none;
	stroke: #fde2cf;
	stroke-width: 3;
}

.hvb-ub__ring-fg {
	fill: none;
	stroke: #22c55e;
	stroke-width: 3;
	stroke-linecap: round;
	transition: stroke-dashoffset 0.4s ease;
}

.hvb-ub__initials {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 13px;
	color: var(--fb-oranz);
	background: #fff;
	border-radius: 50%;
	margin: 4px;
}

.hvb-ub__pct {
	position: absolute;
	bottom: -4px;
	right: -4px;
	background: #22c55e;
	color: #fff;
	font-size: 9px;
	font-weight: 800;
	padding: 1px 5px;
	border-radius: 8px;
	border: 1.5px solid #fff;
	line-height: 1.2;
}

.hvb-ub__info {
	min-width: 0;
	line-height: 1.2;
}

.hvb-ub__name {
	font-size: 13px;
	font-weight: 700;
	color: var(--fb-seda-10);
}

.hvb-ub__status {
	font-size: 11px;
	color: var(--fb-seda-20);
	margin-top: 1px;
}

.hvb-ub__logout {
	flex-shrink: 0;
	min-height: 36px;
	padding: 6px 10px;
	border: 1px solid var(--fb-seda-60);
	background: #fff;
	color: var(--fb-seda-20);
	border-radius: 8px;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
	font-family: inherit;
	transition: all 0.15s;
}

.hvb-ub__logout:hover,
.hvb-ub__logout:focus {
	background: #fee2e2;
	color: #dc2626;
	border-color: #fca5a5;
	outline: none;
}

@media (max-width: 1100px) {
	.hvb-ub__info { display: none; }
	.hvb-ub__logout-label { display: none; }
	.hvb-ub__logout {
		min-width: 36px;
		padding: 6px;
		justify-content: center;
	}
	.hvb-login__user {
		padding: 4px 6px 4px 4px;
		gap: 6px;
	}
}

/* Skrýt desktop user-badge na mobilu (máme dedikované __user-mob) */
@media (max-width: 880px) {
	.hvb-login__user { display: none !important; }
}

/* =======================================================
   TOP-HEADER USER (mobil, avatar + odhlásit ikona)
   ======================================================= */
.hvb-header__user-mob {
	display: none;
	align-items: center;
	gap: 8px;
	margin-left: auto;
}

.hvb-header__user-mob[hidden] { display: none; }

@media (max-width: 880px) {
	.hvb-header__user-mob:not([hidden]) {
		display: inline-flex;
	}
	.hvb-header__user-mob:not([hidden]) ~ .hvb-header__hamburger {
		margin-left: 0;
	}
}

.hvb-header__avatar {
	position: relative;
	width: 38px;
	height: 38px;
	flex-shrink: 0;
	background: transparent;
	border: none;
	padding: 0;
	cursor: pointer;
	border-radius: 50%;
	display: inline-flex;
	transition: transform 0.15s;
}

.hvb-header__avatar:hover { transform: scale(1.05); }

.hvb-header__avatar:focus-visible {
	outline: 2px solid var(--fb-oranz);
	outline-offset: 3px;
}

.hvb-header__avatar .hvb-ub__ring {
	position: absolute;
	inset: 0;
	width: 38px;
	height: 38px;
	transform: rotate(-90deg);
}

.hvb-header__avatar .hvb-ub__initials {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 12px;
	color: var(--fb-oranz);
	background: #fff;
	border-radius: 50%;
	margin: 4px;
}

.hvb-header__avatar .hvb-ub__pct {
	position: absolute;
	bottom: -3px;
	right: -4px;
	background: #22c55e;
	color: #fff;
	font-size: 8px;
	font-weight: 800;
	padding: 1px 4px;
	border-radius: 8px;
	border: 1.5px solid #fff;
	line-height: 1.1;
}

.hvb-header__logout {
	width: 38px;
	height: 38px;
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 1px solid var(--fb-seda-60);
	border-radius: 8px;
	color: var(--fb-seda-20);
	cursor: pointer;
	transition: all 0.15s;
	padding: 0;
}

.hvb-header__logout:hover,
.hvb-header__logout:focus {
	background: #fee2e2;
	color: #dc2626;
	border-color: #fca5a5;
	outline: none;
}

.hvb-header__logout svg { width: 18px; height: 18px; }

/* =======================================================
   MOBILE OFF-CANVAS — IKONY (Uložené + Upozornění)
   ======================================================= */
.hvb-mob__divider {
	height: 1px;
	background: var(--fb-seda-80);
	margin: 10px -18px;
}

.hvb-mob__divider[hidden] { display: none; }

.hvb-mob__icons {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.hvb-mob__icons[hidden] { display: none; }

.hvb-mob__icon-link {
	position: relative;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 10px;
	border-radius: 10px;
	color: var(--fb-seda-10);
	text-decoration: none;
	font-size: 15px;
	font-weight: 500;
	transition: background 0.15s;
}

.hvb-mob__icon-link:hover { background: var(--fb-seda-80); }

.hvb-mob__icon-link svg {
	width: 20px;
	height: 20px;
	color: var(--fb-seda-20);
	flex-shrink: 0;
}

.hvb-mob__badge {
	margin-left: auto;
	min-width: 22px;
	height: 22px;
	padding: 0 6px;
	background: var(--fb-akcent);
	color: #fff;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.hvb-mob__dot {
	margin-left: auto;
	width: 8px;
	height: 8px;
	background: var(--fb-akcent);
	border-radius: 50%;
}

/* Mobile user-badge v menu (po přihlášení) */
.hvb-mob__ub {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	background: var(--fb-oranz-svetla);
	border: 1.5px solid var(--fb-oranz);
	border-radius: 12px;
}

.hvb-mob__ub .hvb-ub {
	width: 44px;
	height: 44px;
	flex-shrink: 0;
}

.hvb-mob__ub .hvb-ub__ring { width: 44px; height: 44px; }

.hvb-mob__ub .hvb-ub__initials {
	font-size: 14px;
	margin: 5px;
}

.hvb-mob__ub .hvb-ub__info {
	flex: 1;
	min-width: 0;
	display: block;
	line-height: 1.25;
}

.hvb-mob__ub .hvb-ub__name {
	font-size: 14px;
	font-weight: 700;
	color: var(--fb-seda-10);
}

.hvb-mob__ub .hvb-ub__status {
	font-size: 12px;
	color: var(--fb-seda-20);
}

.hvb-mob__ub .hvb-ub__logout {
	flex-shrink: 0;
	min-height: 38px;
	padding: 6px 10px;
	gap: 4px;
}

.hvb-mob__ub .hvb-ub__logout-label { display: none; }

/* =======================================================
   MODAL ODHLÁŠENÍ
   ======================================================= */
.hvb-ub-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 3500;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.hvb-ub-modal.open { display: flex; }

.hvb-ub-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(30, 41, 59, 0.5);
	backdrop-filter: blur(2px);
}

.hvb-ub-modal__dialog {
	position: relative;
	background: #fff;
	border-radius: 14px;
	padding: 24px;
	max-width: 420px;
	width: 100%;
	box-shadow: 0 20px 60px rgba(30, 41, 59, 0.3);
	animation: hvbUbModalIn 0.2s ease-out;
}

@keyframes hvbUbModalIn {
	from { opacity: 0; transform: translateY(8px) scale(0.98); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}

.hvb-ub-modal__title {
	font-size: 18px;
	font-weight: 800;
	color: var(--fb-seda-10);
	margin: 0 0 8px;
}

.hvb-ub-modal__text {
	font-size: 14px;
	color: var(--fb-seda-20);
	margin: 0 0 20px;
	line-height: 1.5;
}

.hvb-ub-modal__actions {
	display: flex;
	gap: 8px;
	justify-content: flex-end;
	flex-wrap: wrap;
}

.hvb-ub-modal__btn {
	min-height: 44px;
	padding: 10px 18px;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	border: none;
	transition: all 0.15s;
}

.hvb-ub-modal__btn--cancel {
	background: var(--fb-seda-80);
	color: var(--fb-seda-10);
}

.hvb-ub-modal__btn--cancel:hover { background: var(--fb-seda-60); }

.hvb-ub-modal__btn--confirm {
	background: #dc2626;
	color: #fff;
}

.hvb-ub-modal__btn--confirm:hover { background: #b91c1c; }

@media (max-width: 480px) {
	.hvb-ub-modal__actions { flex-direction: column-reverse; }
	.hvb-ub-modal__btn { width: 100%; }
}

/* =======================================================
   TOAST (status hláška)
   ======================================================= */
.hvb-toast-container {
	position: fixed;
	top: 16px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	gap: 8px;
	z-index: 4000;
	pointer-events: none;
	max-width: calc(100vw - 32px);
}

.hvb-toast {
	pointer-events: auto;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 12px 18px;
	background: #fff;
	border: 1px solid var(--fb-seda-80);
	border-left: 4px solid var(--fb-oranz);
	border-radius: 10px;
	box-shadow: 0 12px 36px -8px rgba(30, 41, 59, 0.25);
	font-family: "Rubik", sans-serif;
	font-size: 14px;
	color: var(--fb-seda-10);
	min-width: 220px;
	max-width: 92vw;
	animation: hvbToastIn 0.28s cubic-bezier(.2, .7, .2, 1);
}

.hvb-toast.is-leaving {
	animation: hvbToastOut 0.32s ease forwards;
}

@keyframes hvbToastIn {
	from { opacity: 0; transform: translateY(-12px) scale(0.96); }
	to   { opacity: 1; transform: translateY(0)     scale(1); }
}

@keyframes hvbToastOut {
	to { opacity: 0; transform: translateY(-12px) scale(0.96); }
}

.hvb-toast__icon {
	display: inline-flex;
	width: 22px;
	height: 22px;
	flex-shrink: 0;
}

.hvb-toast__icon svg {
	width: 100%;
	height: 100%;
}

.hvb-toast__text strong {
	font-weight: 700;
	color: var(--fb-oranz);
}

.hvb-toast--success {
	border-left-color: var(--fb-oranz);
}

.hvb-toast--success .hvb-toast__icon { color: var(--fb-oranz); }

.hvb-toast--info {
	border-left-color: var(--fb-akcent);
}

.hvb-toast--info .hvb-toast__icon { color: var(--fb-akcent); }

@media (prefers-reduced-motion: reduce) {
	.hvb-toast,
	.hvb-toast.is-leaving { animation: none; }
}

/* Skip-link */
.vi-skip-link {
	position: absolute;
	top: -100px;
	left: 8px;
	z-index: 9999;
	padding: 10px 18px;
	background: var(--fb-oranz);
	color: #fff;
	font-family: "Rubik", sans-serif;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	border-radius: 0 0 10px 10px;
	transition: top 0.15s ease;
}

.vi-skip-link:focus {
	top: 0;
	outline: 3px solid var(--fb-akcent);
	outline-offset: 2px;
}

/* Stránkový kontejner */
.vi {
	max-width: 1280px;
	margin: 0 auto;
	padding: 24px 32px 60px;
	font-family: "Rubik", sans-serif;
	color: var(--fb-seda-10);
}

.vi:focus { outline: none; }

/* Focus-visible */
.vi a:focus-visible,
.vi button:focus-visible,
.vi input:focus-visible,
.vi select:focus-visible,
.vi textarea:focus-visible,
.vi summary:focus-visible {
	outline: 3px solid var(--fb-akcent);
	outline-offset: 2px;
	border-radius: 6px;
}

.vi-card__save:focus-visible,
.vi-pagination__btn:focus-visible,
.vi-pagination__num:focus-visible {
	outline-offset: 3px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.vi *,
	.vi *::before,
	.vi *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* Breadcrumb */
.vi-breadcrumb {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--fb-seda-40);
	margin-bottom: 14px;
	flex-wrap: wrap;
}

.vi-breadcrumb a {
	color: var(--fb-seda-20);
	text-decoration: none;
}

.vi-breadcrumb a:hover { color: var(--fb-oranz); }

.vi-breadcrumb__sep {
	color: var(--fb-seda-60);
	font-size: 12px;
}

.vi-breadcrumb [aria-current="page"] {
	color: var(--fb-seda-10);
	font-weight: 600;
}

/* Header sekce */
.vi-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 16px;
	margin-bottom: 22px;
	flex-wrap: wrap;
}

.vi-header__nadpis {
	margin: 0 0 4px;
	font-size: clamp(22px, 3vw, 30px);
	font-weight: 800;
	color: var(--fb-seda-10);
	letter-spacing: -0.02em;
}

.vi-header__perex {
	margin: 0;
	font-size: 14px;
	color: var(--fb-seda-20);
}

.vi-header__perex strong { color: var(--fb-oranz); }

.vi-mobil-filtry {
	display: none;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--fb-oranz);
	color: #fff;
	border: none;
	border-radius: 10px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.15s;
}

.vi-mobil-filtry:hover { background: var(--fb-oranz-tmava); }

.vi-mobil-filtry svg { width: 16px; height: 16px; }

.vi-mobil-filtry__pocet {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	background: var(--fb-akcent);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
}

.vi-mobil-filtry__pocet[hidden] { display: none; }

/* ============= LAYOUT — sidebar + content ============= */
.vi-layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 28px;
	align-items: start;
}

/* ============= FILTRY (sidebar) ============= */
.vi-filters__backdrop { display: none; }

.vi-filters__panel {
	position: sticky;
	top: 16px;
	background: #fff;
	border: 1px solid var(--fb-seda-80);
	border-radius: 14px;
	display: flex;
	flex-direction: column;
}

.vi-filters__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--fb-seda-80);
	background: var(--fb-seda-90);
}

.vi-filters__nadpis {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	font-size: 15px;
	font-weight: 800;
	color: var(--fb-seda-10);
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.vi-filters__nadpis svg {
	width: 14px;
	height: 14px;
	color: var(--fb-oranz);
}

.vi-filters__reset {
	background: transparent;
	border: none;
	color: var(--fb-oranz);
	font-family: inherit;
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	padding: 4px 8px;
	border-radius: 6px;
	transition: background 0.15s, color 0.15s;
}

.vi-filters__reset:hover {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz-tmava);
}

.vi-filters__reset[hidden] { display: none; }

.vi-filters__close {
	display: none;
	width: 32px;
	height: 32px;
	border-radius: 6px;
	border: 1px solid var(--fb-seda-60);
	background: #fff;
	color: var(--fb-seda-20);
	cursor: pointer;
	align-items: center;
	justify-content: center;
}

.vi-filters__close svg { width: 16px; height: 16px; }

.vi-filters__form {
	padding: 8px 16px 16px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

/* Jeden filtr */
.vi-filter {
	border-bottom: 1px solid var(--fb-seda-80);
	padding: 12px 0;
}

.vi-filter:last-of-type { border-bottom: none; }

.vi-filter__label {
	display: block;
	font-size: 13px;
	font-weight: 700;
	color: var(--fb-seda-10);
	margin-bottom: 8px;
	letter-spacing: 0.01em;
}

.vi-filter__input-wrap {
	position: relative;
	display: flex;
	align-items: center;
}

.vi-filter__input-ico {
	position: absolute;
	left: 12px;
	width: 16px;
	height: 16px;
	color: var(--fb-seda-40);
	pointer-events: none;
}

.vi-filter__input {
	width: 100%;
	box-sizing: border-box;
	padding: 10px 12px 10px 36px;
	border: 1.5px solid var(--fb-seda-60);
	border-radius: 8px;
	font-family: inherit;
	font-size: 14px;
	color: var(--fb-seda-10);
	background: var(--fb-seda-90);
	transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.vi-filter__input:focus {
	outline: none;
	border-color: var(--fb-oranz);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(234, 88, 12, 0.15);
}

/* Collapsible sekce */
.vi-filter--collapsible > summary {
	cursor: pointer;
}

.vi-filter--collapsible > summary::-webkit-details-marker { display: none; }
.vi-filter--collapsible > summary::marker { content: ''; }

.vi-filter__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 0;
	user-select: none;
}

.vi-filter__head .vi-filter__label {
	margin: 0;
	flex: 1;
}

.vi-filter__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	background: var(--fb-oranz);
	color: #fff;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
}

.vi-filter__count[hidden] { display: none; }

.vi-filter__chev {
	width: 12px;
	height: 8px;
	color: var(--fb-seda-40);
	transition: transform 0.2s;
	flex-shrink: 0;
}

.vi-filter--collapsible[open] > summary .vi-filter__chev {
	transform: rotate(180deg);
}

.vi-filter__body {
	margin-top: 10px;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.vi-filter__opt {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 8px;
	border-radius: 6px;
	font-size: 13.5px;
	color: var(--fb-seda-10);
	cursor: pointer;
	transition: background 0.12s;
}

.vi-filter__opt:hover {
	background: var(--fb-oranz-svetla);
}

.vi-filter__opt input[type=checkbox] {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	accent-color: var(--fb-oranz);
	margin: 0;
	cursor: pointer;
}

.vi-filter__opt input[type=checkbox]:checked + span {
	color: var(--fb-oranz);
	font-weight: 600;
}

.vi-filter__more > summary {
	margin-top: 4px;
	padding: 6px 8px;
	font-size: 12.5px;
	font-weight: 600;
	color: var(--fb-oranz);
	cursor: pointer;
	border-radius: 6px;
	list-style: none;
}

.vi-filter__more > summary::-webkit-details-marker { display: none; }
.vi-filter__more > summary:hover { background: var(--fb-oranz-svetla); }
.vi-filter__more[open] > summary::before { content: '↑ Skrýt možnosti'; }
.vi-filter__more:not([open]) > summary::before { content: ''; }
.vi-filter__more[open] > summary { color: var(--fb-seda-20); }
.vi-filter__more[open] > summary .vi-filter__more-label { display: none; }

/* Odměna — range slider */
.vi-mzda {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 10px;
}

.vi-mzda input[type=range] {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	height: 6px;
	border-radius: 3px;
	background: var(--fb-seda-80);
	outline: none;
	margin: 6px 0;
}

.vi-mzda input[type=range]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: #fff;
	border: 3px solid var(--fb-oranz);
	cursor: pointer;
	box-shadow: 0 2px 6px rgba(194, 65, 12, 0.25);
	transition: transform 0.15s;
}

.vi-mzda input[type=range]::-webkit-slider-thumb:hover {
	transform: scale(1.15);
}

.vi-mzda input[type=range]::-moz-range-thumb {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: #fff;
	border: 3px solid var(--fb-oranz);
	cursor: pointer;
	box-shadow: 0 2px 6px rgba(194, 65, 12, 0.25);
}

.vi-mzda__out {
	text-align: center;
	font-size: 13px;
	color: var(--fb-seda-20);
}

.vi-mzda__out strong {
	font-size: 16px;
	color: var(--fb-oranz);
	font-weight: 800;
	display: inline-block;
	margin-right: 4px;
	font-variant-numeric: tabular-nums;
}

.vi-mzda__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
}

.vi-mzda__chip {
	padding: 4px 9px;
	background: var(--fb-seda-90);
	border: 1px solid var(--fb-seda-60);
	border-radius: 999px;
	font-family: inherit;
	font-size: 11.5px;
	font-weight: 600;
	color: var(--fb-seda-20);
	cursor: pointer;
	transition: all 0.15s;
}

.vi-mzda__chip:hover,
.vi-mzda__chip.is-active {
	background: var(--fb-oranz);
	color: #fff;
	border-color: var(--fb-oranz);
}

/* Sticky patička filtru */
.vi-filters__foot {
	padding: 12px 16px;
	border-top: 1px solid var(--fb-seda-80);
	background: #fff;
	flex-shrink: 0;
}

.vi-filters__apply {
	display: inline-flex;
	width: 100%;
	box-sizing: border-box;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 13px 16px;
	background: var(--fb-oranz);
	color: #fff;
	border: none;
	border-radius: 10px;
	font-family: inherit;
	font-size: 15px;
	font-weight: 800;
	cursor: pointer;
	transition: all 0.18s;
	box-shadow: 0 6px 14px -6px rgba(234, 88, 12, 0.5);
}

.vi-filters__apply:hover {
	background: var(--fb-oranz-tmava);
	transform: translateY(-1px);
	box-shadow: 0 10px 18px -6px rgba(234, 88, 12, 0.55);
}

.vi-filters__apply svg { width: 16px; height: 16px; }

/* ============= AKTIVNÍ FILTRY (chips nahoře) ============= */
.vi-active-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 16px;
	padding: 12px 14px;
	background: var(--fb-oranz-svetla);
	border-radius: 10px;
}

.vi-active-filters[hidden] { display: none; }

.vi-active-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 5px 8px 5px 12px;
	background: #fff;
	border: 1.5px solid var(--fb-oranz);
	border-radius: 999px;
	font-family: inherit;
	font-size: 12.5px;
	font-weight: 600;
	color: var(--fb-oranz);
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}

.vi-active-chip:hover {
	background: var(--fb-oranz);
	color: #fff;
}

.vi-active-chip svg {
	width: 11px;
	height: 11px;
}

/* ============= TOP BAR ============= */
.vi-topbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
	padding: 14px 16px;
	background: #fff;
	border: 1px solid var(--fb-seda-80);
	border-radius: 12px;
	flex-wrap: wrap;
}

.vi-topbar__pocet {
	font-size: 14px;
	color: var(--fb-seda-20);
}

.vi-topbar__pocet strong {
	color: var(--fb-seda-10);
	font-weight: 800;
}

.vi-topbar__akce {
	display: flex;
	align-items: center;
	gap: 12px;
}

.vi-sort {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.vi-sort__lbl {
	font-size: 13px;
	color: var(--fb-seda-20);
}

.vi-sort__select {
	padding: 7px 28px 7px 10px;
	border: 1.5px solid var(--fb-seda-60);
	border-radius: 8px;
	font-family: inherit;
	font-size: 13.5px;
	color: var(--fb-seda-10);
	background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23475569' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") no-repeat right 10px center;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
}

.vi-sort__select:focus {
	outline: none;
	border-color: var(--fb-oranz);
}

.vi-view {
	display: inline-flex;
	background: var(--fb-seda-90);
	border-radius: 8px;
	padding: 3px;
	gap: 2px;
}

.vi-view__btn {
	width: 32px;
	height: 32px;
	border: none;
	background: transparent;
	color: var(--fb-seda-20);
	border-radius: 6px;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s, color 0.15s;
}

.vi-view__btn svg { width: 16px; height: 16px; }

.vi-view__btn:hover { color: var(--fb-seda-10); }

.vi-view__btn.is-active {
	background: #fff;
	color: var(--fb-oranz);
	box-shadow: 0 2px 4px rgba(30, 41, 59, 0.08);
}

/* ============= SEZNAM ============= */
.vi-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.vi-list--grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 14px;
}

.vi-card {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 16px;
	padding: 18px 18px 16px;
	background: #fff;
	border: 1px solid var(--fb-seda-80);
	border-radius: 14px;
	transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
	position: relative;
}

.vi-card:hover {
	transform: translateY(-2px);
	border-color: rgba(234, 88, 12, 0.4);
	box-shadow: 0 16px 30px -16px rgba(194, 65, 12, 0.2);
}

.vi-card__logo {
	width: 64px;
	height: 64px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	flex-shrink: 0;
	overflow: hidden;
	box-shadow: 0 4px 10px -4px rgba(30, 41, 59, 0.25);
	transition: transform 0.18s ease;
}

.vi-card__logo:hover {
	transform: scale(1.04);
}

.vi-card__logo svg {
	width: 100%;
	height: 100%;
	display: block;
}

.vi-card__body {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.vi-card__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 12px;
	flex-wrap: wrap;
}

.vi-card__head-text {
	min-width: 0;
	flex: 1;
}

.vi-card__pos {
	margin: 0;
	font-size: 16px;
	font-weight: 800;
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.vi-card__pos a {
	color: var(--fb-seda-10);
	text-decoration: none;
}

.vi-card__pos a:hover { color: var(--fb-oranz); }

.vi-card__firma {
	margin: 4px 0 0;
	font-size: 13px;
	color: var(--fb-seda-20);
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.vi-card__firma a {
	color: var(--fb-seda-20);
	text-decoration: none;
	font-weight: 600;
}

.vi-card__firma a:hover {
	color: var(--fb-oranz);
	text-decoration: underline;
}

.vi-card__loc {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--fb-seda-40);
}

.vi-card__loc svg {
	width: 12px;
	height: 12px;
}

.vi-card__head-actions {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
}

.vi-card__badge {
	padding: 3px 9px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.vi-card__badge--top {
	background: linear-gradient(135deg, var(--fb-akcent), #ffb352);
	color: #fff;
	box-shadow: 0 2px 8px rgba(255, 140, 0, 0.35);
}

.vi-card__badge--novinka {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz-tmava);
}

.vi-card__save {
	width: 44px;
	height: 44px;
	background: transparent;
	border: 1.5px solid var(--fb-seda-60);
	border-radius: 50%;
	color: var(--fb-seda-40);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 0.15s;
	flex-shrink: 0;
}

.vi-card__save svg { width: 16px; height: 16px; }

.vi-card__save:hover {
	border-color: var(--fb-oranz);
	color: var(--fb-oranz);
	background: var(--fb-oranz-svetla);
}

.vi-card__save.is-saved {
	border-color: var(--fb-oranz);
	color: #fff;
	background: var(--fb-oranz);
}

.vi-card__save.is-saved svg { fill: #fff; stroke: #fff; }

.vi-card__popis {
	margin: 0;
	font-size: 13.5px;
	color: var(--fb-seda-20);
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.vi-card__tags {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}

.vi-card__tag {
	padding: 3px 9px;
	background: var(--fb-seda-90);
	border-radius: 6px;
	font-size: 11.5px;
	font-weight: 600;
	color: var(--fb-seda-20);
}

.vi-card__tag--uvazek {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz-tmava);
}

.vi-card__foot {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-top: 4px;
	padding-top: 12px;
	border-top: 1px dashed var(--fb-seda-80);
	flex-wrap: wrap;
}

.vi-card__mzda {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
}

.vi-card__mzda-val {
	font-size: 18px;
	font-weight: 800;
	color: var(--fb-oranz);
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.01em;
}

.vi-card__mzda-jed {
	font-size: 12px;
	color: var(--fb-seda-40);
	font-weight: 600;
}

.vi-card__foot-right {
	display: inline-flex;
	align-items: center;
	gap: 14px;
}

.vi-card__datum {
	font-size: 12px;
	color: var(--fb-seda-40);
}

.vi-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	background: var(--fb-oranz);
	color: #fff;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
	transition: all 0.15s;
}

.vi-card__cta:hover {
	background: var(--fb-oranz-tmava);
	transform: translateX(2px);
}

.vi-card__cta svg { width: 14px; height: 14px; }

/* ============= PAGINACE ============= */
.vi-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 4px;
	margin: 28px 0 8px;
}

.vi-pagination__btn,
.vi-pagination__num {
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	background: #fff;
	border: 1.5px solid var(--fb-seda-60);
	border-radius: 10px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	color: var(--fb-seda-20);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 0.15s;
}

.vi-pagination__btn svg { width: 14px; height: 14px; }

.vi-pagination__btn:hover:not(:disabled),
.vi-pagination__num:hover:not(.is-active) {
	background: var(--fb-oranz-svetla);
	border-color: var(--fb-oranz);
	color: var(--fb-oranz);
}

.vi-pagination__btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.vi-pagination__num.is-active {
	background: var(--fb-oranz);
	color: #fff;
	border-color: var(--fb-oranz);
}

.vi-pagination__sep {
	color: var(--fb-seda-40);
	padding: 0 4px;
}

.vi-list__info {
	text-align: center;
	margin: 12px 0 0;
	font-size: 13px;
	color: var(--fb-seda-40);
}

.vi-list__info strong { color: var(--fb-seda-20); }

/* ============= EMPTY STATE ============= */
.vi-empty {
	background: #fff;
	border: 1px solid var(--fb-seda-80);
	border-radius: 16px;
	padding: 48px 32px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.vi-empty[hidden] { display: none; }

.vi-empty__ico {
	width: 72px;
	height: 72px;
	color: var(--fb-oranz);
	opacity: 0.55;
}

.vi-empty__ico svg { width: 100%; height: 100%; }

.vi-empty__nadpis {
	margin: 0;
	font-size: 20px;
	font-weight: 800;
	color: var(--fb-seda-10);
	letter-spacing: -0.01em;
}

.vi-empty__popis {
	margin: 0;
	max-width: 480px;
	font-size: 14px;
	color: var(--fb-seda-20);
	line-height: 1.5;
}

.vi-empty__akce {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 8px;
	justify-content: center;
}

.vi-empty__btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 11px 18px;
	background: var(--fb-oranz);
	color: #fff;
	border: 1.5px solid var(--fb-oranz);
	border-radius: 10px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: all 0.18s;
}

.vi-empty__btn:hover {
	background: var(--fb-oranz-tmava);
	border-color: var(--fb-oranz-tmava);
	transform: translateY(-1px);
}

.vi-empty__btn--sekundarni {
	background: #fff;
	color: var(--fb-oranz);
}

.vi-empty__btn--sekundarni:hover {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz-tmava);
}

.vi-empty__btn svg { width: 14px; height: 14px; }

/* Placeholder kontrast */
.vi-filter__input::placeholder {
	color: var(--fb-seda-40);
	opacity: 1;
}

.vi-sort__select { color: var(--fb-seda-10); }

/* ============= MOBIL ============= */
@media (max-width: 1024px) {
	.vi-layout {
		grid-template-columns: 1fr;
	}

	.vi-mobil-filtry {
		display: inline-flex;
	}

	.vi-filters {
		position: fixed;
		inset: 0;
		z-index: 1400;
		pointer-events: none;
		visibility: hidden;
	}

	.vi-filters.is-open {
		pointer-events: auto;
		visibility: visible;
	}

	.vi-filters__backdrop {
		display: block;
		position: absolute;
		inset: 0;
		background: rgba(30, 41, 59, 0.5);
		opacity: 0;
		transition: opacity 0.25s;
	}

	.vi-filters.is-open .vi-filters__backdrop {
		opacity: 1;
	}

	.vi-filters__panel {
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		width: min(86vw, 360px);
		border-radius: 0;
		overflow: hidden;
		transform: translateX(-100%);
		transition: transform 0.3s cubic-bezier(.2,.7,.2,1);
	}

	.vi-filters__form {
		overflow-y: auto;
		flex: 1;
	}

	.vi-filters.is-open .vi-filters__panel {
		transform: translateX(0);
	}

	.vi-filters__close {
		display: inline-flex;
	}
}

@media (max-width: 768px) {
	.vi {
		padding: 16px 16px 40px;
	}

	.vi-header__nadpis { font-size: 22px; }

	.vi-card {
		grid-template-columns: 48px 1fr;
		gap: 12px;
		padding: 14px 14px 12px;
	}

	.vi-card__logo {
		width: 48px;
		height: 48px;
		font-size: 14px;
		border-radius: 10px;
	}

	.vi-card__pos { font-size: 15px; }

	.vi-card__head {
		flex-wrap: nowrap;
	}

	.vi-card__head-actions {
		flex-direction: column;
		gap: 4px;
		align-items: flex-end;
	}

	.vi-card__save {
		width: 32px;
		height: 32px;
	}

	.vi-card__save svg { width: 14px; height: 14px; }

	.vi-card__popis {
		font-size: 13px;
		-webkit-line-clamp: 3;
	}

	.vi-card__foot {
		flex-wrap: wrap;
	}

	.vi-card__mzda-val { font-size: 16px; }

	.vi-topbar {
		padding: 10px 12px;
	}

	.vi-topbar__akce {
		gap: 8px;
		flex-wrap: wrap;
	}

	.vi-sort__lbl { display: none; }

	.vi-pagination__num:not(.is-active):not(:first-child):not(:last-child) {
		display: none;
	}

	.vi-pagination__num.is-active,
	.vi-pagination__num.is-active + .vi-pagination__num,
	.vi-pagination__num + .vi-pagination__num.is-active {
		display: inline-flex;
	}
}

@media (max-width: 480px) {
	.vi-active-filters {
		padding: 10px 12px;
	}

	.vi-card__foot-right {
		width: 100%;
		justify-content: space-between;
	}
}

/* =======================================================
   PERSONALIZACE — EU AI Act 2026 + GDPR čl. 22 + WCAG 2.2 AA
   ======================================================= */

/* Společný kontejner banneru */
.vi-perso {
	margin-bottom: 18px;
	border-radius: 14px;
	font-family: "Rubik", sans-serif;
}

.vi-perso[hidden] { display: none; }

/* --------- Guest banner --------- */
.vi-perso--guest {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px 20px;
	background: linear-gradient(135deg, var(--fb-oranz-svetla) 0%, #fff 100%);
	border: 1px solid var(--fb-oranz-svetla);
	box-shadow: 0 4px 14px -8px rgba(234, 88, 12, 0.15);
}

.vi-perso__ico {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 12px;
	background: var(--fb-oranz);
	color: #fff;
}

.vi-perso__ico svg {
	width: 24px;
	height: 24px;
}

.vi-perso__text {
	flex: 1;
	min-width: 0;
}

.vi-perso__nadpis {
	margin: 0 0 2px;
	font-size: 15px;
	font-weight: 800;
	color: var(--fb-seda-10);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.vi-perso__nadpis-ico {
	width: 14px;
	height: 14px;
	color: var(--fb-oranz);
	flex-shrink: 0;
}

.vi-perso__popis {
	margin: 0;
	font-size: 13.5px;
	color: var(--fb-seda-20);
	line-height: 1.5;
}

.vi-perso__akce {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.vi-perso__btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 16px;
	background: var(--fb-oranz);
	color: #fff;
	border: none;
	border-radius: 9px;
	font-family: inherit;
	font-size: 13.5px;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.15s, transform 0.15s;
	box-shadow: 0 4px 10px -4px rgba(234, 88, 12, 0.4);
}

.vi-perso__btn:hover {
	background: var(--fb-oranz-tmava);
	transform: translateY(-1px);
}

.vi-perso__btn svg {
	width: 15px;
	height: 15px;
}

.vi-perso__close {
	width: 32px;
	height: 32px;
	border-radius: 8px;
	border: 1px solid transparent;
	background: transparent;
	color: var(--fb-seda-40);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.vi-perso__close:hover {
	background: #fff;
	color: var(--fb-seda-10);
	border-color: var(--fb-seda-60);
}

.vi-perso__close svg {
	width: 14px;
	height: 14px;
}

/* --------- User banner (přihlášený) --------- */
.vi-perso--user {
	padding: 16px 20px;
	background: #fff;
	border: 1px solid var(--fb-seda-80);
}

.vi-perso--user.is-active {
	border-color: var(--fb-oranz);
	box-shadow: 0 4px 14px -8px rgba(234, 88, 12, 0.25);
	background: linear-gradient(135deg, var(--fb-oranz-svetla) 0%, #fff 60%);
}

.vi-perso__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}

.vi-perso__head-text {
	flex: 1;
	min-width: 200px;
}

.vi-perso__how {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin-left: 6px;
	padding: 2px 6px;
	background: transparent;
	border: none;
	color: var(--fb-oranz);
	font-family: inherit;
	font-size: 12.5px;
	font-weight: 600;
	cursor: pointer;
	border-radius: 4px;
	text-decoration: underline;
	text-decoration-style: dotted;
	text-underline-offset: 3px;
}

.vi-perso__how:hover {
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz-tmava);
}

.vi-perso__how svg {
	width: 12px;
	height: 12px;
}

/* --------- Toggle switch (WCAG 2.2 AA, role=switch) --------- */
.vi-perso__toggle {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
}

.vi-perso__toggle-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--fb-seda-20);
}

.vi-perso__switch {
	position: relative;
	width: 52px;
	height: 30px;
	padding: 0;
	background: transparent;
	border: none;
	cursor: pointer;
	flex-shrink: 0;
}

.vi-perso__switch-track {
	position: absolute;
	inset: 0;
	background: var(--fb-seda-60);
	border-radius: 999px;
	transition: background 0.2s;
}

.vi-perso__switch-thumb {
	position: absolute;
	top: 3px;
	left: 3px;
	width: 24px;
	height: 24px;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 2px 6px rgba(30, 41, 59, 0.25);
	transition: transform 0.2s cubic-bezier(.2, .7, .2, 1);
}

.vi-perso__switch[aria-checked="true"] .vi-perso__switch-track {
	background: var(--fb-oranz);
}

.vi-perso__switch[aria-checked="true"] .vi-perso__switch-thumb {
	transform: translateX(22px);
}

.vi-perso__switch:focus-visible {
	outline: 3px solid var(--fb-akcent);
	outline-offset: 3px;
	border-radius: 999px;
}

/* --------- Aktivní stav — chips s kritérii --------- */
.vi-perso__active {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px dashed var(--fb-seda-80);
}

.vi-perso__active[hidden] { display: none; }

.vi-perso__chips-label {
	margin: 0 0 8px;
	font-size: 12px;
	font-weight: 700;
	color: var(--fb-seda-20);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.vi-perso__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.vi-perso__chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px 6px 12px;
	background: #fff;
	border: 1.5px solid var(--fb-oranz);
	border-radius: 999px;
	color: var(--fb-oranz);
	font-family: inherit;
	font-size: 12.5px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}

.vi-perso__chip:hover {
	background: var(--fb-oranz);
	color: #fff;
}

.vi-perso__chip svg {
	width: 11px;
	height: 11px;
}

.vi-perso__settings {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 10px;
	font-size: 12.5px;
	color: var(--fb-seda-20);
	text-decoration: none;
	border-bottom: 1px dotted var(--fb-seda-40);
	padding-bottom: 1px;
}

.vi-perso__settings:hover {
	color: var(--fb-oranz);
	border-bottom-color: var(--fb-oranz);
}

.vi-perso__settings svg {
	width: 13px;
	height: 13px;
}

/* --------- Filter bubble warning --------- */
.vi-perso__bubble-warning {
	margin-top: 14px;
	padding: 12px 14px;
	background: #fffbeb;
	border: 1px solid #fde68a;
	border-radius: 10px;
	display: flex;
	align-items: center;
	gap: 12px;
	color: #92400e;
	font-size: 13.5px;
}

.vi-perso__bubble-warning[hidden] { display: none; }

.vi-perso__bubble-warning > svg {
	width: 22px;
	height: 22px;
	flex-shrink: 0;
	color: #d97706;
}

.vi-perso__bubble-warning strong {
	font-weight: 700;
	margin-right: 8px;
}

.vi-perso__bubble-btn {
	background: #fff;
	border: 1.5px solid #d97706;
	color: #92400e;
	padding: 5px 12px;
	border-radius: 8px;
	font-family: inherit;
	font-size: 12.5px;
	font-weight: 700;
	cursor: pointer;
	transition: all 0.15s;
}

.vi-perso__bubble-btn:hover {
	background: #d97706;
	color: #fff;
}

/* --------- Modal (Jak to funguje + Proč zrovna tahle) --------- */
.vi-perso-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 3600;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.vi-perso-modal.open { display: flex; }

.vi-perso-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(30, 41, 59, 0.55);
	backdrop-filter: blur(3px);
}

.vi-perso-modal__dialog {
	position: relative;
	background: #fff;
	border-radius: 16px;
	padding: 28px 24px 22px;
	max-width: 520px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 24px 60px rgba(30, 41, 59, 0.32);
	animation: viPersoModalIn 0.22s ease-out;
}

@keyframes viPersoModalIn {
	from { opacity: 0; transform: translateY(8px) scale(0.97); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}

.vi-perso-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	border: 1px solid var(--fb-seda-60);
	background: #fff;
	color: var(--fb-seda-20);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s, color 0.15s;
}

.vi-perso-modal__close:hover {
	background: var(--fb-seda-80);
	color: var(--fb-seda-10);
}

.vi-perso-modal__close svg {
	width: 14px;
	height: 14px;
}

.vi-perso-modal__title {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 12px;
	font-size: 19px;
	font-weight: 800;
	color: var(--fb-seda-10);
	padding-right: 36px;
}

.vi-perso-modal__title > svg {
	width: 22px;
	height: 22px;
	color: var(--fb-oranz);
	flex-shrink: 0;
}

.vi-perso-modal__text {
	margin: 0 0 14px;
	font-size: 14px;
	color: var(--fb-seda-20);
	line-height: 1.55;
}

.vi-perso-modal__list {
	margin: 0 0 18px;
	padding-left: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.vi-perso-modal__list li {
	padding: 10px 12px;
	background: var(--fb-seda-90);
	border-radius: 8px;
	font-size: 13.5px;
	color: var(--fb-seda-20);
	line-height: 1.5;
}

.vi-perso-modal__list strong {
	display: block;
	color: var(--fb-seda-10);
	font-weight: 700;
	margin-bottom: 2px;
}

.vi-perso-modal__pravo {
	display: flex;
	gap: 12px;
	padding: 14px;
	background: var(--fb-oranz-svetla);
	border: 1px solid var(--fb-oranz);
	border-radius: 10px;
	margin-bottom: 16px;
}

.vi-perso-modal__pravo > svg {
	width: 22px;
	height: 22px;
	color: var(--fb-oranz);
	flex-shrink: 0;
	margin-top: 1px;
}

.vi-perso-modal__pravo strong {
	display: block;
	font-size: 13px;
	font-weight: 800;
	color: var(--fb-oranz-tmava);
	margin-bottom: 4px;
}

.vi-perso-modal__pravo p {
	margin: 0;
	font-size: 12.5px;
	color: var(--fb-seda-20);
	line-height: 1.5;
}

.vi-perso-modal__actions {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	flex-wrap: wrap;
}

.vi-perso-modal__link {
	background: transparent;
	border: none;
	color: var(--fb-oranz);
	font-family: inherit;
	font-size: 13.5px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 3px;
	padding: 8px 0;
}

.vi-perso-modal__link:hover {
	color: var(--fb-oranz-tmava);
}

.vi-perso-modal__btn {
	padding: 10px 22px;
	background: var(--fb-oranz);
	color: #fff;
	border: none;
	border-radius: 9px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.15s;
}

.vi-perso-modal__btn:hover {
	background: var(--fb-oranz-tmava);
}

/* --------- Match modal — breakdown řádků --------- */
.vi-match-modal__pct {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 56px;
	padding: 4px 10px;
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz);
	border-radius: 999px;
	font-size: 15px;
	font-weight: 800;
}

.vi-match-modal__pct.is-high { background: #dcfce7; color: #166534; }
.vi-match-modal__pct.is-mid  { background: #fef3c7; color: #92400e; }
.vi-match-modal__pct.is-low  { background: #fee2e2; color: #991b1b; }

.vi-match-modal__breakdown {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-bottom: 18px;
}

.vi-match-modal__row {
	display: flex;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 8px;
	font-size: 13.5px;
	line-height: 1.45;
}

.vi-match-modal__row--ok {
	background: #f0fdf4;
	color: #166534;
}

.vi-match-modal__row--nok {
	background: #fef2f2;
	color: #991b1b;
}

.vi-match-modal__row svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	margin-top: 2px;
}

.vi-match-modal__row strong {
	display: block;
	font-weight: 700;
}

.vi-match-modal__row span {
	display: block;
	font-size: 12.5px;
	opacity: 0.85;
	margin-top: 2px;
}

/* --------- Match badge na kartě --------- */
.vi-card__match {
	position: absolute;
	top: 12px;
	right: 56px;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	background: var(--fb-oranz-svetla);
	color: var(--fb-oranz);
	border: 1.5px solid var(--fb-oranz);
	border-radius: 999px;
	font-family: inherit;
	font-size: 12px;
	font-weight: 800;
	cursor: pointer;
	transition: transform 0.15s, box-shadow 0.15s;
	z-index: 2;
	letter-spacing: 0.01em;
}

.vi-card__match[hidden] { display: none; }

.vi-card__match:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 14px -6px rgba(234, 88, 12, 0.4);
}

.vi-card__match svg {
	width: 11px;
	height: 11px;
}

.vi-card__match-label {
	font-weight: 600;
	opacity: 0.9;
	margin-left: 2px;
	letter-spacing: 0;
}

/* Vizuální varianty match */
.vi-card__match.is-high {
	background: #dcfce7;
	color: #166534;
	border-color: #86efac;
}

.vi-card__match.is-mid {
	background: #fef3c7;
	color: #92400e;
	border-color: #fcd34d;
}

.vi-card__match.is-low {
	background: #fee2e2;
	color: #991b1b;
	border-color: #fca5a5;
}

/* Když je match badge viditelný, posunout pomník TOP/Novinka */
.vi-card:has(.vi-card__match:not([hidden])) .vi-card__head-actions {
	margin-top: 28px;
}

/* --------- Responsive --------- */
@media (max-width: 768px) {
	.vi-perso--guest {
		flex-wrap: wrap;
		padding: 14px 16px;
	}
	.vi-perso__ico { width: 36px; height: 36px; }
	.vi-perso__ico svg { width: 20px; height: 20px; }
	.vi-perso__akce {
		width: 100%;
		justify-content: space-between;
	}

	.vi-perso--user { padding: 14px 16px; }

	.vi-perso__head {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
	}

	.vi-perso__toggle {
		justify-content: space-between;
		padding: 8px 12px;
		background: var(--fb-seda-90);
		border-radius: 10px;
	}

	.vi-card__match {
		top: 10px;
		right: 44px;
		font-size: 11px;
		padding: 3px 8px;
	}

	.vi-card__match-label { display: none; }

	.vi-perso-modal__dialog {
		padding: 22px 18px 18px;
	}

	.vi-perso-modal__actions {
		flex-direction: column-reverse;
	}

	.vi-perso-modal__btn,
	.vi-perso-modal__link {
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 480px) {
	.vi-card__match {
		right: 40px;
	}
}

/* =======================================================
   REKLAMNÍ BANNER — pro klienty/inzerenty
   DSA čl. 26 — viditelně označeno jako reklama
   ======================================================= */
.vi-ad {
	position: relative;
	margin: 0;
}

.vi-ad__label {
	position: absolute;
	top: 10px;
	right: 14px;
	z-index: 2;
	padding: 3px 9px;
	background: rgba(255, 255, 255, 0.95);
	color: var(--fb-seda-20);
	border-radius: 999px;
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	box-shadow: 0 2px 6px rgba(30, 41, 59, 0.12);
}

.vi-ad__plocha {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 22px 26px;
	border-radius: 14px;
	text-decoration: none;
	transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
	overflow: hidden;
	position: relative;
	min-height: 96px;
}

/* Pozice 1 — top — oranžový gradient */
.vi-ad__plocha--top {
	background: linear-gradient(135deg, var(--fb-oranz) 0%, var(--fb-akcent) 100%);
	color: #fff;
	box-shadow: 0 8px 24px -10px rgba(234, 88, 12, 0.4);
}

.vi-ad__plocha--top::before {
	content: "";
	position: absolute;
	top: -40%;
	right: -10%;
	width: 220px;
	height: 220px;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.18) 0%, transparent 60%);
	pointer-events: none;
}

/* Pozice 2 — mid — tmavší, kontrastní variace */
.vi-ad__plocha--mid {
	background: linear-gradient(135deg, #1e293b 0%, #334155 60%, var(--fb-oranz-tmava) 100%);
	color: #fff;
	box-shadow: 0 8px 24px -10px rgba(30, 41, 59, 0.45);
}

.vi-ad__plocha--mid::before {
	content: "";
	position: absolute;
	bottom: -30%;
	left: -8%;
	width: 200px;
	height: 200px;
	background: radial-gradient(circle, rgba(234, 88, 12, 0.25) 0%, transparent 65%);
	pointer-events: none;
}

.vi-ad__plocha:hover {
	transform: translateY(-2px);
	filter: brightness(1.05);
	box-shadow: 0 14px 30px -10px rgba(234, 88, 12, 0.5);
}

.vi-ad__plocha:focus-visible {
	outline: 3px solid var(--fb-akcent);
	outline-offset: 3px;
}

.vi-ad__obsah {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
	position: relative;
	z-index: 1;
}

.vi-ad__nadpis {
	font-size: 19px;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.01em;
}

.vi-ad__popis {
	font-size: 14px;
	font-weight: 500;
	opacity: 0.92;
	line-height: 1.45;
}

.vi-ad__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
	padding: 11px 20px;
	background: #fff;
	color: var(--fb-oranz-tmava);
	border-radius: 10px;
	font-size: 14px;
	font-weight: 700;
	position: relative;
	z-index: 1;
	transition: transform 0.15s;
}

.vi-ad__plocha:hover .vi-ad__cta {
	transform: translateX(3px);
}

.vi-ad__plocha--mid .vi-ad__cta {
	background: var(--fb-akcent);
	color: #fff;
}

.vi-ad__cta svg {
	width: 16px;
	height: 16px;
}

/* Responsive */
@media (max-width: 768px) {
	.vi-ad__plocha {
		flex-direction: column;
		align-items: flex-start;
		gap: 14px;
		padding: 18px 18px 20px;
	}

	.vi-ad__nadpis { font-size: 17px; }
	.vi-ad__popis  { font-size: 13.5px; }

	.vi-ad__cta {
		width: 100%;
		justify-content: center;
		padding: 12px 16px;
	}

	.vi-ad__label {
		top: 8px;
		right: 10px;
		font-size: 10px;
	}
}

/* Grid view — banner přes celou šířku gridu */
.vi-list--grid .vi-ad {
	grid-column: 1 / -1;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.vi-ad__plocha,
	.vi-ad__cta {
		transition: none;
	}
	.vi-ad__plocha:hover {
		transform: none;
	}
}
