/**
 * Custom Styles for Krosno Odrzańskie Theme
 * WCAG 2.2 AA Compliant
 * 
 * @package Krosno_Odrzanskie
 */

/* ============================================
   Skip Links (WCAG 2.2 Requirement)
   ============================================ */
.skip-link {
	position: absolute;
	top: -100px;
	left: 0;
	z-index: 100000;
	padding: 1rem 1.5rem;
	background: #000;
	color: #fff;
	text-decoration: none;
	font-weight: 600;
}

.skip-link:focus {
	top: 0;
	outline: 3px solid #fff;
	outline-offset: 2px;
}

/* ============================================
   Primary navbar (WordPress menu) - WCAG 2.2
   ============================================ */
.krosno-navbar {
	background: #fff;
}

.krosno-navbar .navbar-collapse {
	justify-content: center;
}

.krosno-navbar .navbar-nav {
	justify-content: center;
}

.krosno-navbar .custom-logo {
	max-height: 56px;
	width: auto;
}

.krosno-navbar .navbar-nav .nav-link {
	font-weight: 600;
	font-size: 0.8125rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #1f2a37;
	padding: 0.5rem 0.65rem;
	display: inline-flex;
	align-items: center;
}

.krosno-navbar .navbar-nav .nav-link:hover,
.krosno-navbar .navbar-nav .nav-link:focus {
	color: #0b5ed7;
	text-decoration: none;
}

/* Keep link + dropdown button on one line */
.krosno-navbar .navbar-nav > .nav-item {
	display: inline-flex;
	align-items: center;
}

.krosno-navbar .nav-item.dropdown {
	position: relative; /* anchor dropdown menu */
}

/* Split toggles so parent link stays clickable */
.krosno-navbar .krosno-dropdown-toggle,
.krosno-navbar .krosno-submenu-toggle {
	background: transparent;
	border: 0;
	color: #1f2a37;
	font-size: 0.8125rem;
	padding: 0.5rem 0.35rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.krosno-navbar .krosno-dropdown-toggle {
	/* Bring caret closer to the label */
	margin-left: -0.25rem;
}

.krosno-navbar .krosno-dropdown-toggle:focus-visible,
.krosno-navbar .krosno-submenu-toggle:focus-visible {
	outline: 3px solid #0066cc;
	outline-offset: 2px;
	border-radius: 6px;
}

/* Keep caret visible and compact */
.krosno-navbar .krosno-dropdown-toggle::after,
.krosno-navbar .krosno-submenu-toggle::after {
	margin-left: 0;
}

/* Hover/focus opens dropdown on desktop (like old site) */
@media (min-width: 992px) {
	.krosno-navbar .nav-item.dropdown:hover > .dropdown-menu,
	.krosno-navbar .nav-item.dropdown:focus-within > .dropdown-menu {
		display: block;
	}
}

.krosno-navbar .dropdown-menu {
	border: 0;
	border-radius: 0.75rem;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.14);
	padding: 0.5rem;
	min-width: 18rem;
	top: 100%;
	left: 0;
}

.krosno-navbar .dropdown-item {
	border-radius: 0.5rem;
	padding: 0.5rem 0.75rem;
	font-size: 0.8125rem;
	font-weight: 500;
}

.krosno-navbar .dropdown-item:hover,
.krosno-navbar .dropdown-item:focus {
	background: #f1f5f9;
}

/* Multi-level dropdown */
.krosno-navbar .dropdown-submenu {
	position: relative;
}

.krosno-navbar .dropdown-submenu-menu {
	position: absolute;
	top: 0;
	left: 100%;
	margin-left: 0.35rem;
	display: none;
	min-width: 18rem;
	background: #fff;
	border: 0;
	border-radius: 0.75rem;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.14);
	padding: 0.5rem;
}

.krosno-navbar .dropdown-submenu-menu.show {
	display: block;
}

/* Open nested submenu on hover/focus (desktop convenience) */
@media (min-width: 992px) {
	.krosno-navbar .dropdown-submenu:hover > .dropdown-submenu-menu,
	.krosno-navbar .dropdown-submenu:focus-within > .dropdown-submenu-menu {
		display: block;
	}

	/* Mostek między strzałką a submenu – kursor nie traci hover przy ruchu w prawo */
	.krosno-navbar .dropdown-submenu::before {
		content: '';
		position: absolute;
		top: 0;
		left: 100%;
		width: 0.5rem;
		height: 100%;
		z-index: 0;
	}
	.krosno-navbar .dropdown-submenu-menu {
		z-index: 1;
	}
}

/* Align dropdown item + plus toggle */
.krosno-navbar .dropdown-item-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
}

.krosno-navbar .dropdown-item-wrap > a.dropdown-item {
	flex: 1 1 auto;
}

.krosno-navbar .dropdown-item-wrap > .dropdown-header.krosno-menu-heading {
	flex: 1 1 auto;
	margin: 0;
}

/* Feather Icons w przyciskach rozwijania dropdownu */
.krosno-navbar .krosno-submenu-toggle {
	width: auto;
	height: auto;
	border-radius: 6px;
	border: 0;
	background: transparent;
	color: #111827;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.25rem 0.35rem;
	flex: 0 0 auto;
}

.krosno-navbar .krosno-submenu-toggle .krosno-feather-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 0.875rem;
	height: 0.875rem;
}

.krosno-navbar .krosno-submenu-toggle .krosno-feather {
	position: absolute;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.krosno-navbar .krosno-submenu-toggle .krosno-feather svg,
.krosno-navbar .krosno-submenu-toggle .krosno-feather-svg {
	width: 0.875rem;
	height: 0.875rem;
	stroke: currentColor;
	stroke-width: 2.5;
	stroke-linecap: round;
	stroke-linejoin: round;
	fill: none;
}

/* Strzałka: chevron-right gdy zwinięte, chevron-down gdy rozwinięte */
.krosno-navbar .krosno-submenu-toggle--arrow[aria-expanded="false"] .krosno-feather-chevron-down,
.krosno-navbar .krosno-submenu-toggle--arrow[aria-expanded="true"] .krosno-feather-chevron-right {
	display: none !important;
}

.krosno-navbar .krosno-submenu-toggle:hover,
.krosno-navbar .krosno-submenu-toggle:focus-visible {
	color: #0b5ed7;
	outline: 3px solid #0066cc;
	outline-offset: 2px;
}

/* Mobile: menu jako overlay fixed od góry, scroll wewnątrz bloku */
@media (max-width: 991.98px) {
	/* Masthead na mobile: niewidoczny wizualnie, ale bez display:none, żeby #primaryNavbar (collapse) mógł się otwierać */
	#masthead,
	.site-header {
		height: 0;
		min-height: 0;
		padding: 0;
		margin: 0;
		border: none;
		overflow: visible;
	}

	#masthead .navbar,
	#masthead .navbar .container {
		min-height: 0;
		padding: 0;
	}

	#masthead .navbar-brand,
	#masthead .navbar-toggler {
		display: none !important;
	}

	/* Overlay: od samej góry (fixed), pełna wysokość, scroll wewnętrzny */
	.krosno-navbar .navbar-collapse {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 100%;
		height: 100vh;
		height: 100dvh;
		z-index: 1040;
		background: #fff;
		overflow-y: auto;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		padding: 0;
		margin: 0;
		border: none;
		box-shadow: none;
		display: none;
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
	}

	.krosno-navbar .navbar-collapse.show {
		display: flex;
	}

	/* Pasek „Zamknij” na górze overlay (zastępuje niewidoczny hamburger) */
	.krosno-navbar .navbar-collapse .krosno-mobile-menu-close {
		flex-shrink: 0;
		padding: 1rem;
		border-bottom: 1px solid #e9ecef;
		background: #fff;
		display: flex;
		align-items: center;
		justify-content: flex-end;
	}

	.krosno-navbar .navbar-collapse .krosno-mobile-menu-close-btn {
		display: inline-flex;
		align-items: center;
		gap: 0.5rem;
		min-height: 48px;
		padding: 0.5rem 1rem;
		font-weight: 600;
	}

	.krosno-navbar .navbar-collapse .navbar-nav {
		width: 100%;
		padding: 0 1rem 2rem;
		flex: 1 1 auto;
		min-height: 0;
		justify-content: flex-start;
	}

	.krosno-navbar .navbar-nav {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.krosno-navbar .navbar-nav > .nav-item {
		width: 100%;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	.krosno-navbar .navbar-nav .nav-link {
		flex: 1 1 auto;
	}

	/* Przyciski rozwijania: na mobile mniejsze, tylko strzałki */
	.krosno-navbar .navbar-collapse .krosno-dropdown-toggle,
	.krosno-navbar .navbar-collapse .krosno-submenu-toggle {
		min-width: 32px;
		min-height: 32px;
		padding: 0.35rem 0.5rem;
		background: #e9ecef;
		border: 1px solid #dee2e6;
		border-radius: 6px;
		font-size: 0.875rem;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		flex-shrink: 0;
	}

	.krosno-navbar .navbar-collapse .krosno-dropdown-toggle::after {
		/* Mniejsza strzałka Bootstrap (caret) na mobile */
		transform: scale(0.7);
	}
	.krosno-navbar .navbar-collapse .nav-item.dropdown.show > .krosno-dropdown-toggle::after {
		transform: scale(0.7) rotate(180deg);
	}

	/* Mniejsze ikony strzałek (feather) w submenu na mobile */
	.krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather-wrap {
		width: 0.75rem;
		height: 0.75rem;
	}
	.krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather svg,
	.krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather-svg {
		width: 0.75rem;
		height: 0.75rem;
	}

	.krosno-navbar .krosno-dropdown-toggle:hover,
	.krosno-navbar .krosno-dropdown-toggle:focus,
	.krosno-navbar .krosno-submenu-toggle:hover,
	.krosno-navbar .krosno-submenu-toggle:focus {
		background: #dee2e6;
		border-color: #adb5bd;
	}

	.krosno-navbar .krosno-dropdown-toggle::after,
	.krosno-navbar .krosno-submenu-toggle::before {
		margin: 0;
	}

	/* Główne dropdown: inline pod pozycją, pełna szerokość */
	.krosno-navbar .nav-item.dropdown {
		position: static;
	}

	.krosno-navbar .nav-item.dropdown > .dropdown-menu {
		position: static !important;
		transform: none !important;
		width: 100%;
		min-width: 100%;
		box-shadow: none;
		margin: 0;
		padding: 0;
		border-radius: 0;
		border: none;
		border-top: 1px solid #e9ecef;
		background: #f8f9fa;
		display: none;
	}

	.krosno-navbar .nav-item.dropdown.show > .dropdown-menu {
		display: block;
	}

	.krosno-navbar .nav-item.dropdown .dropdown-item,
	.krosno-navbar .nav-item.dropdown .dropdown-item-wrap,
	.krosno-navbar .nav-item.dropdown .dropdown-header.krosno-menu-heading {
		padding-left: 1.25rem;
		padding-right: 1rem;
	}

	/* Zagnieżdżone submenu: link + przycisk (+) w jednym wierszu, przycisk po prawej; lista pod spodem */
	.krosno-navbar .dropdown-submenu {
		position: static !important;
		display: flex !important;
		flex-wrap: wrap !important;
		align-items: center;
		justify-content: space-between;
		float: none !important;
		gap: 0.5rem;
	}

	/* Link + przycisk zawsze w jednej linii (link zajmuje resztę miejsca, przycisk nie zawija) */
	.krosno-navbar .dropdown-submenu > a.dropdown-item {
		flex: 1 1 0%;
		min-width: 0;
	}

	.krosno-navbar .dropdown-submenu > .krosno-submenu-toggle {
		flex: 0 0 auto;
		flex-shrink: 0;
	}

	.krosno-navbar .dropdown-submenu > .dropdown-submenu-menu {
		flex: 1 1 100%;
		width: 100%;
		order: 10;
	}

	.krosno-navbar .dropdown-submenu-menu {
		position: static !important;
		left: auto !important;
		top: auto !important;
		float: none !important;
		margin: 0;
		min-width: 100% !important;
		width: 100% !important;
		max-width: 100%;
		box-shadow: none;
		padding: 0 0 0 1rem;
		border-radius: 0;
		background: #f1f3f5;
		border: none;
		border-top: 1px solid #e9ecef;
		display: none;
		list-style: none;
	}

	.krosno-navbar .dropdown-submenu.show > .dropdown-submenu-menu {
		display: block !important;
	}

	.krosno-navbar .dropdown-submenu .dropdown-item,
	.krosno-navbar .dropdown-submenu .dropdown-item-wrap,
	.krosno-navbar .dropdown-submenu .dropdown-header.krosno-menu-heading {
		padding-left: 1rem;
	}

	/* Separator (np. WŁADZE GMINY): tekst + przycisk w jednej linii */
	.krosno-navbar .dropdown-submenu > .dropdown-header.krosno-menu-heading {
		flex: 1 1 0%;
		min-width: 0;
	}

	/* Strzałka w dół gdy submenu otwarte */
	.krosno-navbar .nav-item.dropdown.show > .krosno-dropdown-toggle::after {
		transform: rotate(180deg);
	}
}

/* Separator items (Joomla -> WP) -> render as headings (subnagłówek w dropdownie) */
.krosno-navbar .krosno-menu-heading {
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #6b7280;
	padding: 0.4rem 0.65rem;
	display: block;
	line-height: 1.3;
}

.krosno-navbar .dropdown-header.krosno-menu-heading {
	padding-top: 0.5rem;
	padding-bottom: 0.25rem;
	font-size: 0.6875rem;
}

/* ============================================
   Accessibility Bar (Horizontal)
   ============================================ */
.accessibility-bar {
	background: #fff;
	border-bottom: 1px solid #ddd;
	padding: 0.5rem 0;
	width: 100%;
	z-index: 1000;
	position: relative;
	font-size: 0.8125rem;
}

/* Mobile: rząd „Dostępność” + hamburger (menu) */
.accessibility-bar__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	gap: 0.75rem;
}

.accessibility-bar__row .accessibility-bar-toggle {
	width: auto;
	flex: 1 1 auto;
	min-width: 0;
}

.accessibility-bar__row .krosno-mobile-menu-toggler {
	min-width: 48px;
	min-height: 48px;
	padding: 0.5rem;
	border: 1px solid #dee2e6;
	border-radius: 8px;
	background: #f8f9fa;
	flex-shrink: 0;
	color: #212529;
}

.accessibility-bar__row .krosno-mobile-menu-toggler:hover,
.accessibility-bar__row .krosno-mobile-menu-toggler:focus {
	background: #e9ecef;
	border-color: #adb5bd;
	color: #212529;
}

/* Ikona hamburgera widoczna na jasnym tle (ciemna) */
.accessibility-bar__row .krosno-mobile-menu-toggler .navbar-toggler-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23212529' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Mobile Toggle Button (gdy nie w __row) */
.accessibility-bar-toggle {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.75rem 1rem;
	background: #f8f9fa;
	border: 1px solid #ddd;
	border-radius: 4px;
	cursor: pointer;
	font-size: 0.9rem;
	color: #333;
	transition: all 0.2s ease;
	gap: 0.5rem;
}

.accessibility-bar-toggle:hover,
.accessibility-bar-toggle:focus {
	background: #e9ecef;
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

.accessibility-bar-toggle .toggle-icon {
	transition: transform 0.3s ease;
	font-size: 0.875rem;
}

.accessibility-bar-toggle[aria-expanded="true"] .toggle-icon {
	transform: rotate(180deg);
}

.accessibility-bar-toggle i:first-child {
	font-size: 1.25rem;
	color: #0066cc;
}

.accessibility-bar-content {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	flex-wrap: wrap;
	justify-content: space-between;
}

.accessibility-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.accessibility-label {
	margin: 0;
	font-size: 0.8125rem;
	color: #333;
	font-weight: 400;
	white-space: nowrap;
}

/* Toggle Switch */
.toggle-switch {
	position: relative;
	display: inline-block;
	width: 50px;
	height: 24px;
}

.toggle-switch input {
	opacity: 0;
	width: 0;
	height: 0;
}

.toggle-slider {
	position: absolute;
	cursor: pointer;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #ccc;
	transition: 0.3s;
	border-radius: 24px;
}

.toggle-slider:before {
	position: absolute;
	content: "";
	height: 18px;
	width: 18px;
	left: 3px;
	bottom: 3px;
	background-color: white;
	transition: 0.3s;
	border-radius: 50%;
}

.toggle-switch input:checked + .toggle-slider {
	background-color: #0066cc;
}

.toggle-switch input:focus + .toggle-slider {
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

.toggle-switch input:checked + .toggle-slider:before {
	transform: translateX(26px);
}

/* Font Size Buttons */
.font-size-buttons {
	display: flex;
	gap: 0.25rem;
}

.font-size-btn {
	padding: 0.3rem 0.6rem;
	border: 1px solid #ddd;
	background: #f5f5f5;
	color: #333;
	border-radius: 6px;
	cursor: pointer;
	font-size: 0.8125rem;
	font-weight: 600;
	transition: all 0.2s ease;
	min-width: 40px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.font-size-btn:hover,
.font-size-btn:focus {
	border-color: #0066cc;
	background: #fff;
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

.font-size-btn.active {
	background: #0066cc;
	color: #fff;
	border-color: #0066cc;
}

/* Accessibility Links */
.accessibility-links-group {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-left: auto;
}

.accessibility-link-button {
	background: none;
	border: none;
	padding: 0;
	font: inherit;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.accessibility-link-alt,
.accessibility-link-declaration,
.accessibility-link-button {
	color: #333;
	text-decoration: none;
	font-size: 0.8125rem;
	display: flex;
	align-items: center;
	gap: 0.35rem;
	white-space: nowrap;
	transition: color 0.2s ease;
}

.accessibility-link-alt:hover,
.accessibility-link-alt:focus,
.accessibility-link-declaration:hover,
.accessibility-link-declaration:focus,
.accessibility-link-button:hover,
.accessibility-link-button:focus {
	color: #0066cc;
	text-decoration: underline;
	outline: none;
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

.accessibility-link-alt i,
.accessibility-link-declaration i {
	font-size: 0.95rem;
}

/* ============================================
   Belka z logami (między WCAG a menu)
   ============================================ */
.logos-bar {
	background: #fff;
	border-bottom: 1px solid #e9ecef;
	padding: 0.75rem 0;
	width: 100%;
}

.logos-bar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.logos-bar__item {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1 1 0;
	min-width: 0;
}

.logos-bar__item--left {
	justify-content: flex-start;
}

.logos-bar__item--center {
	justify-content: center;
}

.logos-bar__item--right {
	justify-content: flex-end;
}

.logos-bar__link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.logos-bar__link:hover {
	opacity: 0.9;
}

.logos-bar__img {
	max-height: 56px;
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}

/* Lewy (urzad.png) – lekko mniejszy */
.logos-bar__item--left .logos-bar__img {
	max-height: 48px;
}

/* Środkowy (eu.png) */
.logos-bar__item--center .logos-bar__img {
	max-height: 34px;
}

/* Prawy (logo.png) – lekko mniejszy */
.logos-bar__item--right .logos-bar__img {
	max-height: 48px;
}

@media (max-width: 767.98px) {
	.logos-bar__inner {
		flex-direction: column;
		gap: 0.75rem;
	}
	.logos-bar__item--left,
	.logos-bar__item--center,
	.logos-bar__item--right {
		justify-content: center;
	}
	.logos-bar__img {
		max-height: 48px;
	}
	.logos-bar__item--left .logos-bar__img,
	.logos-bar__item--right .logos-bar__img {
		max-height: 42px;
	}
	.logos-bar__item--center .logos-bar__img {
		max-height: 28px;
	}
}

/* ============================================
   Font Size Controls
   ============================================ */
.font-size-small {
	font-size: 0.875rem;
}

.font-size-normal {
	font-size: 1rem;
}

.font-size-large {
	font-size: 1.25rem;
}

.font-size-extra-large {
	font-size: 1.5rem;
}

/* ============================================
   Contrast Controls
   ============================================ */
.contrast-normal {
	/* Default contrast */
}

.contrast-high {
	--text-color: #000;
	--bg-color: #fff;
	--link-color: #0000ee;
	--border-color: #000;
}

.contrast-high body {
	color: var(--text-color);
	background: var(--bg-color);
}

.contrast-high a {
	color: var(--link-color);
	border-bottom: 2px solid var(--link-color);
}

.contrast-high button,
.contrast-high .btn {
	border: 2px solid var(--border-color);
}

/* ============================================
   Dark Mode (nocny tryb) – cała strona
   ============================================ */
.dark-mode {
	--bg-color: #1a1a1a;
	--text-color: #e5e5e5;
	--link-color: #6eb3ff;
	--border-color: #444;
	--card-bg: #252525;
	--header-bg: #222;
}

.dark-mode body {
	background: var(--bg-color);
	color: var(--text-color);
}

.dark-mode a {
	color: var(--link-color);
}

.dark-mode .card,
.dark-mode .bg-light {
	background: var(--card-bg);
}

.dark-mode .border {
	border-color: var(--border-color);
}

/* Pasek dostępności i belka log w nocnym trybie */
.dark-mode .accessibility-bar {
	background: var(--header-bg);
	border-bottom-color: #444;
	color: var(--text-color);
}

.dark-mode .accessibility-label,
.dark-mode .accessibility-link-alt,
.dark-mode .accessibility-link-declaration,
.dark-mode .accessibility-link-button {
	color: var(--text-color);
}

.dark-mode .accessibility-link-alt:hover,
.dark-mode .accessibility-link-declaration:hover,
.dark-mode .accessibility-link-button:hover {
	color: var(--link-color);
}

.dark-mode .font-size-btn {
	background: #333;
	border-color: #555;
	color: var(--text-color);
}

.dark-mode .font-size-btn.active {
	background: var(--link-color);
	border-color: var(--link-color);
	color: #fff;
}

.dark-mode .toggle-slider {
	background-color: #555;
}

.dark-mode .toggle-switch input:checked + .toggle-slider {
	background-color: var(--link-color);
}

.dark-mode .logos-bar {
	background: var(--header-bg);
	border-bottom-color: #444;
}

.dark-mode .logos-bar__img {
	filter: brightness(0.9);
}

.dark-mode .krosno-navbar {
	background: var(--header-bg);
	border-bottom-color: #444;
}

.dark-mode .krosno-navbar .nav-link,
.dark-mode .krosno-navbar .krosno-dropdown-toggle,
.dark-mode .krosno-navbar .krosno-submenu-toggle {
	color: var(--text-color);
}

.dark-mode .krosno-navbar .nav-link:hover {
	color: var(--link-color);
}

/* Dropdowny menu – ciemne tło i czytelny tekst */
.dark-mode .krosno-navbar .dropdown-menu,
.dark-mode .krosno-navbar .dropdown-submenu-menu {
	background: var(--card-bg) !important;
	border-color: #444 !important;
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.4);
}

.dark-mode .krosno-navbar .dropdown-item {
	color: var(--text-color) !important;
}

.dark-mode .krosno-navbar .dropdown-item:hover,
.dark-mode .krosno-navbar .dropdown-item:focus {
	background: #333 !important;
	color: var(--link-color) !important;
}

.dark-mode .krosno-navbar .krosno-menu-heading,
.dark-mode .krosno-navbar .dropdown-header.krosno-menu-heading {
	color: #aaa !important;
}

/* Przyciski „Dostępność” i hamburger na mobile – ciemne */
.dark-mode .accessibility-bar-toggle,
.dark-mode .accessibility-bar__row .krosno-mobile-menu-toggler {
	background: #333 !important;
	border-color: #555 !important;
	color: var(--text-color) !important;
}

.dark-mode .accessibility-bar-toggle:hover,
.dark-mode .accessibility-bar-toggle:focus,
.dark-mode .accessibility-bar__row .krosno-mobile-menu-toggler:hover,
.dark-mode .accessibility-bar__row .krosno-mobile-menu-toggler:focus {
	background: #444 !important;
	border-color: #666 !important;
	color: #fff !important;
}

.dark-mode .accessibility-bar__row .krosno-mobile-menu-toggler .navbar-toggler-icon {
	filter: invert(1);
}

/* Overlay menu mobilnego – ciemny */
.dark-mode .krosno-navbar .navbar-collapse.show {
	background: var(--header-bg) !important;
	color: var(--text-color);
}

.dark-mode .krosno-navbar .navbar-collapse .nav-link,
.dark-mode .krosno-navbar .navbar-collapse .dropdown-item {
	color: var(--text-color) !important;
}

.dark-mode .krosno-navbar .navbar-collapse .nav-link:hover,
.dark-mode .krosno-navbar .navbar-collapse .dropdown-item:hover {
	color: var(--link-color) !important;
}

/* Pasek „Zamknij menu” w overlay – ciemny, spójny z overlay */
.dark-mode .krosno-navbar .navbar-collapse .krosno-mobile-menu-close {
	background: var(--header-bg) !important;
	border-bottom-color: #444 !important;
}

.dark-mode .krosno-navbar .navbar-collapse .krosno-mobile-menu-close-btn {
	background: #333 !important;
	border-color: #555 !important;
	color: #fff !important;
}

.dark-mode .krosno-navbar .navbar-collapse .dropdown-menu,
.dark-mode .krosno-navbar .navbar-collapse .dropdown-submenu-menu {
	background: #252525 !important;
	border-color: #444;
}

.dark-mode .krosno-navbar .navbar-collapse .dropdown-submenu-menu {
	background: #1f1f1f !important;
}

/* Pierwszy poziom dropdown w mobilnym menu (pod START, AKTUALNOŚCI itd.) */
.dark-mode .krosno-navbar .navbar-collapse .nav-item.dropdown > .dropdown-menu {
	background: #252525 !important;
	border-top-color: #444 !important;
}

/* Przyciski rozwijania (plus / strzałka) w mobilnym menu – ciemne, czytelna ikona */
.dark-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle,
.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle {
	background: #333 !important;
	border-color: #555 !important;
	color: #fff !important;
}

.dark-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle:hover,
.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle:hover,
.dark-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle:focus,
.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle:focus {
	background: #444 !important;
	border-color: #666 !important;
	color: var(--link-color) !important;
}

.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather svg,
.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather-svg,
.dark-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle::after {
	stroke: #fff;
	color: #fff;
}

.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle:hover .krosno-feather svg,
.dark-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle:hover .krosno-feather-svg {
	stroke: var(--link-color);
}

.dark-mode .krosno-navbar .navbar-collapse .dropdown-item-wrap,
.dark-mode .krosno-navbar .navbar-collapse .dropdown-header.krosno-menu-heading {
	color: var(--text-color) !important;
}

/* Treść i karty w nocnym trybie */
.dark-mode .site-main--content {
	background: var(--bg-color);
}

.dark-mode .content-container-inner {
	background: var(--card-bg);
	border-color: #444;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.dark-mode .hero-slider__box {
	background: rgba(0, 0, 0, 0.75);
}

.dark-mode .hero-slider__control {
	background: rgba(0, 0, 0, 0.6);
}

.mourning-mode .hero-slider__box {
	background: rgba(80, 80, 80, 0.75);
}

.mourning-mode .hero-slider__tag {
	background: #555;
}

.dark-mode .popular-pages {
	background: #1f1f1f;
}

.dark-mode .popular-pages__title,
.dark-mode .popular-pages__subtitle {
	color: var(--text-color);
}

.dark-mode .popular-pages__subtitle {
	color: #aaa;
}

.dark-mode .popular-pages__card {
	background: var(--card-bg);
	border-color: #444;
	color: var(--text-color);
}

.dark-mode .popular-pages__card:hover {
	background: #2f2f2f;
	border-color: #555;
}

.dark-mode .popular-pages__icon {
	background: var(--link-color);
	color: #fff;
}

.dark-mode .popular-pages__label {
	color: var(--text-color);
}

/* Tryb ciemny – sekcja Aktualności */
.dark-mode .front-news {
	background: #1a1a1a;
}

.dark-mode .front-news__title {
	color: var(--text-color);
}

.dark-mode .front-news__all {
	color: var(--link-color);
}

.dark-mode .front-news__all:hover,
.dark-mode .front-news__all:focus {
	color: #8ec4ff;
}

.dark-mode .front-news__card {
	background: var(--card-bg);
	border: 1px solid #333;
}

.dark-mode .front-news__thumb-link {
	background: #333;
}

.dark-mode .front-news__thumb-placeholder {
	color: #666;
}

.dark-mode .front-news__card .entry-title a {
	color: var(--text-color);
}

.dark-mode .front-news__card .entry-title a:hover,
.dark-mode .front-news__card .entry-title a:focus {
	color: var(--link-color);
}

.dark-mode .front-news__card .entry-meta {
	color: #aaa;
}

.dark-mode .front-news__card .entry-summary {
	color: #bbb;
}

.dark-mode .front-news__empty {
	color: #888;
}

/* Tryb ciemny – sekcja „Najważniejsze strony” */
.dark-mode .important-pages {
	background: #1f1f1f;
}

.dark-mode .important-pages__title {
	color: var(--text-color);
}

.dark-mode .important-pages__card {
	background: var(--card-bg);
	border-color: #444;
	color: var(--text-color);
}

.dark-mode .important-pages__card:hover,
.dark-mode .important-pages__card:focus {
	background: #2f2f2f;
	border-color: #555;
}

.dark-mode .important-pages__label {
	color: var(--text-color);
}

.dark-mode .important-pages__card .important-pages__icon {
	filter: brightness(0.9);
}

/* Tryb ciemny – widgety po prawej */
.dark-mode .krosno-sidebar-widgets__list {
	background: rgba(30, 30, 30, 0.98);
	border-color: #444;
	box-shadow: -2px 0 12px rgba(0, 0, 0, 0.3);
}

.dark-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link {
	background-color: #3d3d3d !important;
	color: #fff !important;
}
.dark-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link .bi {
	color: #fff !important;
}
.dark-mode .krosno-sidebar-widgets__item:nth-child(2) .krosno-sidebar-widgets__link { background-color: #0a5fd4 !important; }
.dark-mode .krosno-sidebar-widgets__item:nth-child(3) .krosno-sidebar-widgets__link { background-color: #a32828 !important; }
.dark-mode .krosno-sidebar-widgets__item:nth-child(4) .krosno-sidebar-widgets__link { background-color: #1260d4 !important; }

.dark-mode .krosno-divider {
	background: linear-gradient(
		90deg,
		rgba(100, 149, 237, 0) 0%,
		rgba(100, 149, 237, 0.35) 50%,
		rgba(100, 149, 237, 0) 100%
	);
}

.dark-mode .facebook-feed {
	background: #1f1f1f;
}

.dark-mode .facebook-feed__title {
	color: var(--text-color);
}

.dark-mode .facebook-feed__title .bi-facebook {
	color: #6eb3ff;
}

.dark-mode .facebook-feed__link {
	color: var(--link-color);
}

.dark-mode .facebook-feed__link:hover,
.dark-mode .facebook-feed__link:focus {
	color: #8ec4ff;
}

.dark-mode .footer-cards {
	background: var(--card-bg);
	border-color: #444;
}

.dark-mode .footer-card {
	background: #252525;
	border-color: #444;
	color: var(--text-color);
}

.dark-mode .footer-card__title,
.dark-mode .footer-card__name,
.dark-mode .footer-card__text {
	color: var(--text-color);
}

.dark-mode .footer-card__text a {
	color: var(--link-color);
}

.dark-mode .footer-card__icon {
	background: var(--link-color);
}

.dark-mode .footer-card__box {
	background: #333;
	color: #aaa;
}

.dark-mode .footer-card__btn,
.dark-mode .btn-primary {
	background: var(--link-color);
	border-color: var(--link-color);
	color: #fff;
}

.dark-mode .site-footer-bottom {
	background: #111;
	color: #ccc;
}

.dark-mode .site-footer-bottom__credit a {
	color: #6eb3ff;
}

.dark-mode .breadcrumb,
.dark-mode .entry-title {
	color: var(--text-color);
}

.dark-mode .breadcrumb a {
	color: var(--link-color);
}

.dark-mode .entry-meta,
.dark-mode .entry-summary {
	color: #bbb;
}

/* Treść artykułu/strony – czytelny kontrast w nocnym trybie */
.dark-mode .entry-content,
.dark-mode .content-container-inner .entry-content {
	color: #e5e5e5 !important;
}

.dark-mode .entry-content p,
.dark-mode .entry-content li {
	color: #e5e5e5 !important;
}

.dark-mode .entry-content h2,
.dark-mode .entry-content h3 {
	color: #eee !important;
}

.dark-mode .entry-content a {
	color: var(--link-color) !important;
}

.dark-mode .entry-content ul li::before {
	background: var(--link-color);
}

.dark-mode .site-main--blog .entry--teaser {
	background: var(--card-bg);
	border-color: #444;
}

/* Gdy włączony nocny tryb, nie nakładaj żałobnego filtra na treść */
.dark-mode.mourning-mode #page {
	filter: none;
}

/* ============================================
   Mourning Mode (tryb żałoby) – wstążka + stonowana strona
   ============================================ */
.mourning-mode body {
	background: #e8e8e8;
	color: #333;
}

.mourning-mode #page {
	filter: grayscale(1);
}

.mourning-mode a {
	color: #444;
	border-bottom: 1px solid #666;
}

.mourning-mode a:hover,
.mourning-mode a:focus {
	color: #000;
	border-bottom-color: #000;
	outline: 2px solid #333;
	outline-offset: 2px;
}

.mourning-mode button,
.mourning-mode .btn {
	background: #555 !important;
	color: #fff !important;
	border-color: #666 !important;
}

.mourning-mode button:hover,
.mourning-mode .btn:hover {
	background: #666 !important;
}

.mourning-mode .accessibility-bar {
	background: #ddd;
	border-bottom-color: #ccc;
	color: #333;
}

.mourning-mode .logos-bar {
	background: #e0e0e0;
	border-bottom-color: #ccc;
}

.mourning-mode .krosno-navbar {
	background: #e5e5e5;
	border-bottom-color: #ccc;
}

.mourning-mode .krosno-navbar .nav-link,
.mourning-mode .krosno-navbar .krosno-dropdown-toggle {
	color: #333;
}

.mourning-mode .popular-pages {
	background: #d8d8d8;
}

.mourning-mode .popular-pages__title {
	color: #222;
}

.mourning-mode .popular-pages__subtitle {
	color: #555;
}

.mourning-mode .content-container-inner,
.mourning-mode .popular-pages__card,
.mourning-mode .footer-card {
	background: #eee;
	border-color: #ccc;
	color: #333;
}

/* Tryb żałoby – sekcja Aktualności */
.mourning-mode .front-news {
	background: #d8d8d8;
}

.mourning-mode .front-news__title {
	color: #222;
}

.mourning-mode .front-news__all {
	color: #444;
}

.mourning-mode .front-news__all:hover,
.mourning-mode .front-news__all:focus {
	color: #000;
}

.mourning-mode .front-news__card {
	background: #eee;
	border-color: #ccc;
}

.mourning-mode .front-news__thumb-link {
	background: #ddd;
}

.mourning-mode .front-news__thumb-placeholder {
	color: #888;
}

.mourning-mode .front-news__card .entry-title a {
	color: #333;
}

.mourning-mode .front-news__card .entry-title a:hover,
.mourning-mode .front-news__card .entry-title a:focus {
	color: #000;
}

.mourning-mode .front-news__card .entry-meta {
	color: #555;
}

.mourning-mode .front-news__card .entry-summary {
	color: #444;
}

/* Tryb żałoby – sekcja „Najważniejsze strony” */
.mourning-mode .important-pages {
	background: #d8d8d8;
}

.mourning-mode .important-pages__title {
	color: #222;
}

.mourning-mode .important-pages__card {
	background: #eee;
	border-color: #ccc;
	color: #333;
}

.mourning-mode .important-pages__card:hover,
.mourning-mode .important-pages__card:focus {
	background: #e5e5e5;
	border-color: #bbb;
}

.mourning-mode .important-pages__label {
	color: #333;
}

.mourning-mode .important-pages__card .important-pages__icon {
	background: #666 !important;
	filter: grayscale(0.3);
}

/* Tryb żałoby – widgety po prawej (stonowane) */
.mourning-mode .krosno-sidebar-widgets__list {
	background: rgba(230, 230, 230, 0.98);
	border-color: #bbb;
}

.mourning-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link {
	background-color: #555 !important;
	color: #fff !important;
}
.mourning-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link .bi {
	color: #fff !important;
}
.mourning-mode .krosno-sidebar-widgets__item:nth-child(2) .krosno-sidebar-widgets__link,
.mourning-mode .krosno-sidebar-widgets__item:nth-child(3) .krosno-sidebar-widgets__link,
.mourning-mode .krosno-sidebar-widgets__item:nth-child(4) .krosno-sidebar-widgets__link {
	background-color: #555 !important;
	color: #fff !important;
}

.mourning-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:hover,
.mourning-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:focus {
	background-color: #666 !important;
	color: #fff !important;
}
.mourning-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:hover .bi,
.mourning-mode .krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:focus .bi {
	color: #fff !important;
}

.mourning-mode .krosno-divider {
	background: linear-gradient(
		90deg,
		rgba(100, 100, 100, 0) 0%,
		rgba(100, 100, 100, 0.5) 50%,
		rgba(100, 100, 100, 0) 100%
	);
}

.mourning-mode .facebook-feed {
	background: #d8d8d8;
}

.mourning-mode .facebook-feed__title {
	color: #222;
}

.mourning-mode .facebook-feed__link {
	color: #444;
}

.mourning-mode .facebook-feed__link:hover,
.mourning-mode .facebook-feed__link:focus {
	color: #000;
}

.mourning-mode .footer-cards {
	background: #e2e2e2;
	border-color: #ccc;
}

.mourning-mode .site-footer-bottom {
	background: #333 !important;
	color: #ccc;
}

/* Tryb żałoby – dropdowny, przyciski mobilne, overlay menu, treść */
.mourning-mode .krosno-navbar .dropdown-menu,
.mourning-mode .krosno-navbar .dropdown-submenu-menu {
	background: #e8e8e8 !important;
	border-color: #bbb;
	color: #333;
}

.mourning-mode .krosno-navbar .dropdown-item {
	color: #333 !important;
}

.mourning-mode .krosno-navbar .dropdown-item:hover {
	background: #ddd !important;
	color: #111 !important;
}

.mourning-mode .accessibility-bar-toggle,
.mourning-mode .accessibility-bar__row .krosno-mobile-menu-toggler {
	background: #ccc !important;
	border-color: #bbb !important;
	color: #333 !important;
}

.mourning-mode .accessibility-bar-toggle:hover,
.mourning-mode .accessibility-bar__row .krosno-mobile-menu-toggler:hover {
	background: #bbb !important;
}

.mourning-mode .krosno-navbar .navbar-collapse.show {
	background: #e5e5e5 !important;
	color: #333;
}

/* Pasek „Zamknij menu” w overlay – stonowany szary */
.mourning-mode .krosno-navbar .navbar-collapse .krosno-mobile-menu-close {
	background: #e5e5e5 !important;
	border-bottom-color: #ccc !important;
}

.mourning-mode .krosno-navbar .navbar-collapse .nav-link,
.mourning-mode .krosno-navbar .navbar-collapse .dropdown-item {
	color: #333 !important;
}

.mourning-mode .krosno-navbar .navbar-collapse .krosno-mobile-menu-close-btn {
	background: #555 !important;
	border-color: #666 !important;
	color: #fff !important;
}

.mourning-mode .krosno-navbar .navbar-collapse .dropdown-menu,
.mourning-mode .krosno-navbar .navbar-collapse .dropdown-submenu-menu {
	background: #e0e0e0 !important;
	border-color: #ccc;
}

.mourning-mode .krosno-navbar .navbar-collapse .dropdown-submenu-menu {
	background: #d8d8d8 !important;
}

/* Przyciski rozwijania (plus/strzałka) w mobilnym menu – stonowane */
.mourning-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle,
.mourning-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle {
	background: #ccc !important;
	border-color: #bbb !important;
	color: #333 !important;
}

.mourning-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle:hover,
.mourning-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle:hover,
.mourning-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle:focus,
.mourning-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle:focus {
	background: #bbb !important;
	border-color: #aaa !important;
	color: #111 !important;
}

.mourning-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather svg,
.mourning-mode .krosno-navbar .navbar-collapse .krosno-submenu-toggle .krosno-feather-svg,
.mourning-mode .krosno-navbar .navbar-collapse .krosno-dropdown-toggle::after {
	stroke: #333;
	color: #333;
}

.mourning-mode .krosno-navbar .navbar-collapse .dropdown-item-wrap,
.mourning-mode .krosno-navbar .navbar-collapse .dropdown-header.krosno-menu-heading {
	color: #333 !important;
}

.mourning-mode .entry-content,
.mourning-mode .entry-content p,
.mourning-mode .entry-content li {
	color: #333 !important;
}

.mourning-mode .entry-content h2,
.mourning-mode .entry-content h3 {
	color: #222 !important;
}

/* Wstążka żałobna – zawsze pełna widoczność (ponad filtrem) */
.mourning-ribbon {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background: #000;
	color: #fff;
	padding: 0.75rem 1rem;
	text-align: center;
	z-index: 10001;
	transform: translateY(-100%);
	transition: transform 0.3s ease;
	filter: none;
}

.mourning-ribbon.show {
	transform: translateY(0);
}

.mourning-ribbon p {
	margin: 0;
	font-weight: 600;
	font-size: 0.9375rem;
}

/* Odstęp pod wstążką gdy jest widoczna */
body:has(.mourning-ribbon.show) #page {
	padding-top: 52px;
}

/* ============================================
   Social Links
   ============================================ */
.social-links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.social-links li {
	margin: 0;
}

.social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #0066cc;
	color: #fff;
	text-decoration: none;
	transition: all 0.2s ease;
}

.social-link:hover,
.social-link:focus {
	background: #0052a3;
	transform: scale(1.1);
	outline: 2px solid #fff;
	outline-offset: 2px;
}

.social-link i {
	font-size: 1.25rem;
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}

/* ============================================
   Strona główna: Hero slider
   ============================================ */
.hero-slider {
	width: 100%;
	margin-bottom: 0;
}

.hero-slider .carousel,
.hero-slider .carousel-inner,
.hero-slider .carousel-item {
	height: 0;
	padding-bottom: 32%;
	min-height: 260px;
	position: relative;
}

@media (min-width: 768px) {
	.hero-slider .carousel,
	.hero-slider .carousel-inner,
	.hero-slider .carousel-item {
		padding-bottom: 28%;
		min-height: 320px;
	}
}

.hero-slider__slide-link {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	text-decoration: none;
	color: inherit;
	cursor: pointer;
}

.hero-slider__slide-link:hover,
.hero-slider__slide-link:focus {
	color: inherit;
	text-decoration: none;
}

.hero-slider__bg {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.hero-slider__overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	align-items: center;
	padding: 2rem 0;
}

.hero-slider__box {
	background: rgba(0, 0, 0, 0.6);
	border-radius: 16px;
	padding: 1.5rem 2rem;
	max-width: 560px;
}

.hero-slider__box-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.hero-slider__box-link:hover,
.hero-slider__box-link:focus {
	color: inherit;
	text-decoration: none;
}

.hero-slider__tag {
	display: inline-block;
	background: #0066cc;
	color: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 0.35rem 0.75rem;
	border-radius: 6px;
	margin-bottom: 0.75rem;
}

.hero-slider__title {
	color: #fff;
	font-size: 1.75rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	line-height: 1.3;
}

@media (min-width: 768px) {
	.hero-slider__title {
		font-size: 2.25rem;
	}
}

.hero-slider__desc {
	color: rgba(255, 255, 255, 0.95);
	font-size: 1rem;
	line-height: 1.5;
	margin: 0;
}

.hero-slider__control {
	width: 48px;
	height: 48px;
	opacity: 0.9;
	background: rgba(0, 0, 0, 0.5);
	border-radius: 50%;
	top: 50%;
	transform: translateY(-50%);
	bottom: auto;
}

.hero-slider__control:hover {
	opacity: 1;
	background: rgba(0, 0, 0, 0.7);
}

.hero-slider__control .bi {
	font-size: 1.5rem;
}

.hero-slider__indicators {
	bottom: 1.5rem;
}

/* Kropki (koła), nie podłużne paski – nadpisanie domyślnego Bootstrap */
.hero-slider__indicators button,
.hero-slider__indicators [data-bs-slide-to] {
	width: 10px;
	height: 10px;
	min-width: 10px;
	min-height: 10px;
	max-width: 10px;
	max-height: 10px;
	margin: 0 4px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.5);
	border: 0;
	text-indent: 0;
	opacity: 1;
}

.hero-slider__indicators button.active,
.hero-slider__indicators [data-bs-slide-to].active {
	background-color: #fff;
}

/* ============================================
   Strona główna: Najczęściej przeglądane strony
   ============================================ */
.site-main--front {
	padding: 0;
}

.popular-pages {
	background: #e8eef4;
	padding: 2.5rem 0 3rem;
	width: 100%;
}

.popular-pages__header {
	text-align: center;
	margin-bottom: 2rem;
}

.popular-pages__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: #1f2937;
	margin: 0 0 0.5rem;
}

.popular-pages__subtitle {
	font-size: 1rem;
	color: #6b7280;
	margin: 0;
}

.popular-pages__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.25rem;
}

.popular-pages__card {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	padding: 1.5rem 1rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	text-decoration: none;
	color: #1f2937;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	min-height: 140px;
}

.popular-pages__card:hover,
.popular-pages__card:focus {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
	transform: translateY(-2px);
	color: #1f2937;
	text-decoration: none;
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

.popular-pages__icon {
	width: 56px;
	height: 56px;
	background: #0066cc;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0.75rem;
	color: #fff;
	font-size: 1.5rem;
	flex-shrink: 0;
}

.popular-pages__label {
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.35;
}

@media (max-width: 991.98px) {
	.popular-pages__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.popular-pages {
		padding: 1.5rem 0 2rem;
	}
	.popular-pages__title {
		font-size: 1.5rem;
	}
	.popular-pages__grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	.popular-pages__card {
		min-height: 120px;
		padding: 1.25rem 1rem;
	}
}

/* ============================================
   Strona główna: Aktualności (najnowsze wpisy)
   ============================================ */
.front-news {
	background: #f0f4f8;
	padding: 2.5rem 0 3rem;
	width: 100%;
}

.front-news__header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.front-news__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: #1f2937;
	margin: 0;
}

.front-news__all {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: #0066cc;
	font-weight: 500;
	text-decoration: none;
}

.front-news__all:hover,
.front-news__all:focus {
	color: #0052a3;
	text-decoration: underline;
}

.front-news__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

.front-news__card {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.2s ease;
}

.front-news__card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.front-news__thumb-link {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: #e5e7eb;
}

.front-news__thumb-link img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

.front-news__thumb-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #9ca3af;
	font-size: 3rem;
}

.front-news__body {
	padding: 1.25rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.front-news__card .entry-title {
	font-size: 1.0625rem;
	margin: 0 0 0.5rem;
	line-height: 1.35;
}

.front-news__card .entry-title a {
	color: #1f2937;
	text-decoration: none;
}

.front-news__card .entry-title a:hover,
.front-news__card .entry-title a:focus {
	color: #0066cc;
}

.front-news__card .entry-meta {
	font-size: 0.8125rem;
	color: #6b7280;
	margin-bottom: 0.5rem;
}

.front-news__card .entry-meta time {
	text-decoration: none;
}

.front-news__card .entry-summary {
	font-size: 0.9375rem;
	color: #4b5563;
	line-height: 1.5;
	margin: 0 0 1rem;
	flex: 1;
}

.front-news__card .entry-more {
	margin: 0.75rem 0 0;
}

.front-news__empty {
	margin: 0;
	color: #6b7280;
}

@media (max-width: 991.98px) {
	.front-news__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.front-news {
		padding: 1.5rem 0 2rem;
	}
	.front-news__title {
		font-size: 1.5rem;
	}
	.front-news__grid {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}
	.front-news__body {
		padding: 1rem;
	}
}

/* Sekcja „Aktualności z Facebooka” – tylko nagłówek i link */
.facebook-feed {
	background: #e8eef4;
	padding: 2rem 0;
	width: 100%;
}

.facebook-feed__header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.facebook-feed__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: #1f2937;
	margin: 0;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.facebook-feed__title .bi-facebook {
	color: #1877f2;
}

.facebook-feed__link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: #1877f2;
	font-weight: 500;
	text-decoration: none;
}

.facebook-feed__link:hover,
.facebook-feed__link:focus {
	color: #0d6efd;
	text-decoration: underline;
}

.facebook-feed__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	margin-top: 1.5rem;
}

.facebook-feed__card {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	overflow: hidden;
	transition: box-shadow 0.2s ease;
}

.facebook-feed__card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.facebook-feed__card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.facebook-feed__card-link:hover,
.facebook-feed__card-link:focus {
	color: inherit;
	text-decoration: none;
}

.facebook-feed__thumb {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: #e5e7eb;
}

.facebook-feed__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.facebook-feed__body {
	padding: 1.25rem;
}

.facebook-feed__message {
	margin: 0 0 0.5rem;
	font-size: 0.9375rem;
	line-height: 1.45;
	color: #374151;
}

.facebook-feed__date {
	display: block;
	font-size: 0.8125rem;
	color: #6b7280;
	margin-bottom: 0.5rem;
}

.facebook-feed__read-more {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: #1877f2;
}

.facebook-feed__card-link:hover .facebook-feed__read-more,
.facebook-feed__card-link:focus .facebook-feed__read-more {
	color: #0d6efd;
}

@media (max-width: 991.98px) {
	.facebook-feed__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.facebook-feed {
		padding: 1.5rem 0;
	}
	.facebook-feed__title {
		font-size: 1.5rem;
	}
	.facebook-feed__header {
		flex-direction: column;
		align-items: flex-start;
	}
	.facebook-feed__grid {
		grid-template-columns: 1fr;
		margin-top: 1rem;
	}
	.facebook-feed__body {
		padding: 1rem;
	}
}

/* Divider – gradient (mocniejszy środek, zanik na brzegach) */
.krosno-divider {
	height: 4px;
	width: 100%;
	background: linear-gradient(
		90deg,
		rgba(0, 102, 204, 0) 0%,
		rgba(0, 102, 204, 0.4) 15%,
		rgba(0, 102, 204, 0.9) 50%,
		rgba(0, 102, 204, 0.4) 85%,
		rgba(0, 102, 204, 0) 100%
	);
	margin: 0;
}

/* Sekcja „Najważniejsze strony” przed stopką – białe tło, divider pod sekcją */
.important-pages {
	background: #fff;
	padding: 2.5rem 0 0;
	width: 100%;
}

.important-pages__header {
	text-align: center;
	margin-bottom: 2rem;
}

.important-pages__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: #1f2937;
	margin: 0;
}

/* 6 linków w jednej linii na desktop */
.important-pages__grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 1rem;
	padding-bottom: 2.5rem;
}

.important-pages__card {
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	padding: 1.5rem 1rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	text-decoration: none;
	color: #1f2937;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	min-height: 140px;
}

.important-pages__card:hover,
.important-pages__card:focus {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
	transform: translateY(-2px);
	color: #1f2937;
	text-decoration: none;
	outline: 2px solid #0066cc;
	outline-offset: 2px;
}

.important-pages__icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0.75rem;
	color: #fff;
	font-size: 1.5rem;
	flex-shrink: 0;
}

/* Różne kolory tła ikon (kafelek 1–12) */
.important-pages__card:nth-child(1) .important-pages__icon { background: #0066cc; }
.important-pages__card:nth-child(2) .important-pages__icon { background: #0d6efd; }
.important-pages__card:nth-child(3) .important-pages__icon { background: #198754; }
.important-pages__card:nth-child(4) .important-pages__icon { background: #6f42c1; }
.important-pages__card:nth-child(5) .important-pages__icon { background: #fd7e14; }
.important-pages__card:nth-child(6) .important-pages__icon { background: #20c997; }
.important-pages__card:nth-child(7) .important-pages__icon { background: #d63384; }
.important-pages__card:nth-child(8) .important-pages__icon { background: #0dcaf0; }
.important-pages__card:nth-child(9) .important-pages__icon { background: #ffc107; }
.important-pages__card:nth-child(10) .important-pages__icon { background: #6c757d; }
.important-pages__card:nth-child(11) .important-pages__icon { background: #0d9488; }
.important-pages__card:nth-child(12) .important-pages__icon { background: #dc3545; }

.important-pages__label {
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.35;
}

@media (max-width: 991.98px) {
	.important-pages__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.important-pages {
		padding: 1.5rem 0 0;
	}
	.important-pages__title {
		font-size: 1.5rem;
	}
	.important-pages__grid {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
		grid-auto-flow: row;
		gap: 1rem;
		padding-bottom: 1.5rem;
	}
	.important-pages__card {
		min-height: 120px;
		padding: 1.25rem 1rem;
	}
}

/* ============================================
   Content area: single page, single post, blog
   ============================================ */
.site-main--content {
	background: #f5f5f5;
	padding: 2rem 0 3rem;
}

/* Zgodna szerokość z headerem (panel dostępności + menu): .container = 1200px, padding 1rem */
.content-container,
.content-container--blog {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 1rem;
	padding-right: 1rem;
}

.content-container-inner {
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	padding: 1rem 2.5rem 2rem 2.5rem;
}

/* Długie linki/URL-e łamią się, nie rozwalają szerokości */
.content-container-inner a,
.entry-summary a,
.site-footer a,
.site-footer-bottom a,
.footer-cards a,
.popular-pages a {
	overflow-wrap: break-word;
	word-break: break-word;
}

/* Sekcja kart nad banerem: Burmistrz, Adres, Kontakt, Godziny */
.footer-cards {
	background: #fff;
	border-bottom: none;
	box-shadow: none;
	padding: 2rem 0;
	overflow-x: hidden;
	width: 100%;
}

.footer-cards .container {
	overflow-x: hidden;
}

.footer-cards__inner {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
	min-width: 0;
}

.footer-cards__inner > * {
	min-width: 0;
}

.footer-card {
	background: #fff;
	border: 1px solid #e9ecef;
	border-radius: 8px;
	padding: 1.25rem;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	box-shadow: none;
}

/* Żadnej kreski/cienia między sekcją kart a banerem */
.footer-cards::after,
.footer-cards .container::after {
	display: none !important;
}
.footer-cards + .site-footer-banner {
	border-top: none !important;
	box-shadow: none !important;
}

.footer-card__thumb {
	width: 120px;
	height: 120px;
	margin-bottom: 0.75rem;
	overflow: hidden;
}

.footer-card__thumb--round {
	border-radius: 8px;
}

.footer-card__thumb img {
    width: 100%;
    height: auto;
    display: block;
}

.footer-card__icon {
	width: 48px;
	height: 48px;
	background: #0066cc;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0.75rem;
	color: #fff;
	font-size: 1.25rem;
}

.footer-card__title {
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 0.35rem;
	color: #1f2937;
}

.footer-card__name {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: #1f2937;
}

.footer-card__label {
	font-size: 0.875rem;
	color: #6b7280;
	margin: 0.25rem 0 0;
	text-align: center;
	width: 100%;
}

.footer-card__text {
	font-size: 0.875rem;
	margin: 0.25rem 0 0;
	color: #374151;
	text-align: center;
	width: 100%;
}

.footer-card__text--bold {
	font-weight: 700;
}

.footer-card__text a {
	color: #0066cc;
	text-decoration: underline;
}

.footer-card__text a:hover {
	text-decoration: none;
}

.footer-card__box {
	background: #f1f3f5;
	border-radius: 6px;
	padding: 0.5rem 0.75rem;
	font-size: 0.875rem;
	margin-top: 0.5rem;
	width: 100%;
	text-align: center;
}

.footer-card__box--note {
	text-align: left;
	margin-top: 0.75rem;
	font-size: 0.8125rem;
	color: #6b7280;
}

.footer-card__hours {
	margin: 0.5rem 0 0;
	padding: 0;
	width: 100%;
	font-size: 0.875rem;
}

.footer-card__hours-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 0.25rem;
}

.footer-card__hours-row dt {
	margin: 0;
	font-weight: 400;
	color: #374151;
}

.footer-card__hours-row dd {
	margin: 0;
	color: #1f2937;
}

.footer-card__btn {
	margin-top: 1rem;
	width: 100%;
	max-width: 220px;
}

@media (max-width: 991.98px) {
	.footer-cards__inner {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.footer-cards__inner {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	.footer-cards {
		padding: 1.5rem 0;
	}
}

/* Banner full width nad stopką */
.site-footer-banner {
	width: 100%;
	overflow: hidden;
	line-height: 0;
	border-top: none;
	box-shadow: none;
}

.site-footer-banner__img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	object-position: center;
}

/* Dolny footer: niebieski pasek */
.site-footer-bottom {
	background: #0066cc;
	color: #fff;
	padding: 1rem 0;
	width: 100%;
}

.site-footer-bottom__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem;
	font-size: 0.8125rem;
}

.site-footer-bottom__copyright {
	margin: 0;
}

.site-footer-bottom__credit {
	margin: 0;
}

.site-footer-bottom__credit a {
	color: #fff;
	text-decoration: underline;
}

.site-footer-bottom__credit a:hover {
	color: rgba(255, 255, 255, 0.9);
	text-decoration: none;
}

@media (max-width: 575.98px) {
	.site-footer-bottom__inner {
		flex-direction: column;
		text-align: center;
	}
}

/* Kontakt w modalu Dostępność alternatywna */
.alternative-accessibility-contact a {
	text-decoration: underline;
}
.alternative-accessibility-contact a:hover {
	text-decoration: none;
}

@media (max-width: 575.98px) {
	.content-container-inner {
		padding: 0.75rem 1rem 1.25rem 1rem;
	}
	.entry-title {
		font-size: 1.5rem;
	}
}

/* Breadcrumb – wyraźne, zawsze widoczne */
.breadcrumb {
	margin-bottom: 1.5rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid #e5e7eb;
}

.breadcrumb-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0.25rem;
	font-size: 0.95rem;
}

.breadcrumb-item {
	display: inline-flex;
	align-items: center;
}

/* Tylko jeden separator (Bootstrap 5 dodaje ::before – wyłączamy, używamy ::after) */
.breadcrumb-item + .breadcrumb-item::before {
	display: none;
}

.breadcrumb-item:not(:last-child)::after {
	content: "/";
	margin-left: 0.35rem;
	margin-right: 0.15rem;
	color: #6b7280;
	font-weight: 400;
}

.breadcrumb-item a {
	color: #0066cc;
	text-decoration: none;
}

.breadcrumb-item a:hover,
.breadcrumb-item a:focus {
	text-decoration: underline;
}

.breadcrumb-item span[aria-current="page"] {
	color: #1f2937;
	font-weight: 500;
}

/* Obrazek wyróżniający w pojedynczym wpisie */
.entry-featured-image {
	margin-bottom: 1.5rem;
	border-radius: 8px;
	overflow: hidden;
	background: #e5e7eb;
}

.entry-featured-img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: middle;
}

/* Entry: single page / single post */
.entry-header {
	margin-bottom: 1.5rem;
}

.entry-title {
	font-size: 1.75rem;
	font-weight: 700;
	color: #0066cc;
	line-height: 1.3;
	margin: 0 0 0.5rem;
}

.entry-meta {
	font-size: 0.875rem;
	color: #6b7280;
}

.entry-meta time + .entry-author::before {
	content: " · ";
}

.entry-content {
	font-size: 1rem;
	line-height: 1.7;
	color: #1f2937;
}

.entry-content p {
	margin: 0 0 1rem;
}

.entry-content p:last-child {
	margin-bottom: 0;
}

.entry-content h2 {
	font-size: 1.35rem;
	font-weight: 700;
	color: #1f2937;
	margin: 2rem 0 0.75rem;
}

.entry-content h3 {
	font-size: 1.15rem;
	font-weight: 600;
	margin: 1.5rem 0 0.5rem;
}

.entry-content ul,
.entry-content ol {
	margin: 1rem 0;
	padding-left: 1.5rem;
}

.entry-content ul {
	list-style: none;
	padding-left: 0;
}

.entry-content ul li {
	position: relative;
	padding-left: 1.25rem;
	margin-bottom: 0.5rem;
}

.entry-content ul li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.5rem;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #0066cc;
}

.entry-content ol {
	list-style: decimal;
}

.entry-content a {
	color: #0066cc;
	text-decoration: underline;
	overflow-wrap: break-word;
	word-break: break-word;
}

.entry-content a:hover,
.entry-content a:focus {
	text-decoration: none;
}

.entry-content strong {
	font-weight: 700;
}

/* Tabele: overflow + bordery + striped */
.krosno-table-wrap {
	width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin: 1.5rem 0;
}

.entry-content table,
.content-container-inner table {
	width: 100%;
	min-width: 100%;
	border-collapse: collapse;
	border: 1px solid #dee2e6;
	font-size: 0.95rem;
}

.entry-content table th,
.entry-content table td,
.content-container-inner table th,
.content-container-inner table td {
	border: 1px solid #dee2e6;
	padding: 0.5rem 0.75rem;
	text-align: left;
	vertical-align: top;
}

.entry-content table thead th,
.content-container-inner table thead th {
	background: #e9ecef;
	font-weight: 600;
	color: #1f2937;
}

.entry-content table tbody tr:nth-child(odd),
.content-container-inner table tbody tr:nth-child(odd) {
	background: #f8f9fa;
}

.entry-content table tbody tr:nth-child(even),
.content-container-inner table tbody tr:nth-child(even) {
	background: #fff;
}

.entry-content table tbody tr:hover,
.content-container-inner table tbody tr:hover {
	background: #f1f3f5;
}

.entry-content table a,
.content-container-inner table a {
	color: #0066cc;
	text-decoration: underline;
}

.entry-content table a:hover,
.content-container-inner table a:focus,
.content-container-inner table a:hover,
.content-container-inner table a:focus {
	text-decoration: none;
}

/* Blog listing */
.page-header {
	margin-bottom: 1.5rem;
}

.page-title {
	font-size: 1.75rem;
	font-weight: 700;
	color: #0066cc;
	margin: 0;
}

/* Blog: siatka 3 boksy w rzędzie (index + szablon strony Blog) */
.site-main--blog .posts-list--grid,
.posts-list--grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

@media (max-width: 991.98px) {
	.site-main--blog .posts-list--grid,
	.posts-list--grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.site-main--blog .posts-list--grid,
	.posts-list--grid {
		grid-template-columns: 1fr;
	}
}

.site-main--blog .entry--teaser,
.entry--teaser {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.2s ease;
	overflow: hidden;
}

/* Miniatura wpisu w listach (blog, archiwum) */
.entry-thumbnail-link {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #e5e7eb;
	border-radius: 8px 8px 0 0;
}

.entry-thumbnail-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	vertical-align: middle;
}

/* Placeholder gdy wpis nie ma miniatury (strona Aktualności) */
.entry-thumbnail-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #9ca3af;
	font-size: 3rem;
	text-decoration: none;
}

.entry-thumbnail-placeholder:hover,
.entry-thumbnail-placeholder:focus {
	color: #6b7280;
}

.entry--teaser .entry-header {
	padding: 0 1.5rem;
	padding-top: 1.5rem;
}

.site-main--blog .entry--teaser:hover,
.entry--teaser:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.site-main--blog .entry--teaser .entry-header,
.entry--teaser .entry-header {
	margin-bottom: 0.75rem;
}

.site-main--blog .entry--teaser .entry-title,
.entry--teaser .entry-title {
	font-size: 1.1rem;
	margin: 0 0 0.5rem;
	line-height: 1.35;
}

.site-main--blog .entry--teaser .entry-title a,
.entry--teaser .entry-title a {
	color: #0066cc;
	text-decoration: none;
}

.site-main--blog .entry--teaser .entry-title a:hover,
.site-main--blog .entry--teaser .entry-title a:focus,
.entry--teaser .entry-title a:hover,
.entry--teaser .entry-title a:focus {
	text-decoration: underline;
}

.site-main--blog .entry--teaser .entry-meta,
.entry--teaser .entry-meta {
	margin-bottom: 0;
}

.entry--teaser .entry-summary {
	padding: 0 1.5rem;
}

.entry-summary {
	margin: 0.5rem 0 1rem;
	color: #4b5563;
	font-size: 0.9rem;
	line-height: 1.55;
	flex: 1 1 auto;
}

.entry--teaser .entry-more {
	padding: 0 1.5rem 1.5rem;
}

.entry-more {
	margin: 0;
	margin-top: auto;
	padding-top: 1rem;
}

.entry-more .btn {
	display: inline-block;
	padding: 0.5rem 1rem;
	background: #0066cc;
	color: #fff;
	border-radius: 6px;
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
}

.entry-more .btn:hover,
.entry-more .btn:focus {
	background: #0052a3;
	color: #fff;
}

/* Pagination */
.pagination,
.nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 2rem;
	justify-content: center;
}

.pagination a,
.pagination span,
.nav-links a,
.nav-links span {
	display: inline-block;
	padding: 0.5rem 0.75rem;
	background: #f3f4f6;
	color: #1f2937;
	text-decoration: none;
	border-radius: 6px;
}

.pagination a:hover,
.nav-links a:hover {
	background: #0066cc;
	color: #fff;
}

.pagination .current,
.nav-links .current {
	background: #0066cc;
	color: #fff;
}

/* ============================================
   Focus Styles (WCAG 2.2)
   ============================================ */
*:focus-visible {
	outline: 3px solid #0066cc;
	outline-offset: 2px;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 3px solid #0066cc;
	outline-offset: 2px;
}

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 767.98px) {
	.accessibility-bar-content {
		display: none;
		gap: 1rem;
		flex-direction: column;
		align-items: flex-start;
		padding-top: 1rem;
	}

	.accessibility-bar-content.show {
		display: flex !important;
	}

	.accessibility-item {
		width: 100%;
		justify-content: space-between;
	}

	.font-size-buttons {
		margin-left: auto;
	}

	.accessibility-links-group {
		margin-left: 0;
		width: 100%;
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
		padding-top: 0.5rem;
		border-top: 1px solid #eee;
	}
}

@media (min-width: 768px) {
	.accessibility-bar-toggle {
		display: none;
	}
}

/* Widgety po prawej – kolorowe kafelki (nadpisanie, żeby kolory się stosowały) */
/* Domyślny ciemny kolor – żaden przycisk nie może być biały (5. i kolejne) */
.krosno-sidebar-widgets__item .krosno-sidebar-widgets__link {
	background-color: #495057 !important;
	color: #fff !important;
}
.krosno-sidebar-widgets__item .krosno-sidebar-widgets__link .bi {
	color: #fff !important;
}
.krosno-sidebar-widgets__item:nth-child(2) .krosno-sidebar-widgets__link {
	background-color: #0d6efd !important;
	color: #fff !important;
}
.krosno-sidebar-widgets__item:nth-child(3) .krosno-sidebar-widgets__link {
	background-color: #c4302b !important;
	color: #fff !important;
}
.krosno-sidebar-widgets__item:nth-child(4) .krosno-sidebar-widgets__link {
	background-color: #1877f2 !important;
	color: #fff !important;
}
.krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:hover,
.krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:focus {
	color: #fff !important;
}
.krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:hover .bi,
.krosno-sidebar-widgets__item .krosno-sidebar-widgets__link:focus .bi {
	color: #fff !important;
}

