/* ======================================================
   custom.css – style własne projektu agatanadolna.pl
   Wspólny plik zastępujący bloki <style> ze wszystkich
   stron HTML serwisu.
   ====================================================== */


/* -------------------------------------------------------
   Nawigacja globalna
   ------------------------------------------------------- */

nav.site-nav {
	background: rgba(0,0,0,0.72);
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 1000;
	padding: 0.6em 1.5em;
	box-sizing: border-box;
}
nav.site-nav .nav-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
nav.site-nav > .nav-inner > ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em 1.2em;
	align-items: center;
}
/* Hamburger button — ukryty na desktopie */
nav.site-nav .nav-hamburger {
	/* reset wszystkich stylów z main.css button {} */
	display: none;
	appearance: none;
	-webkit-appearance: none;
	background: none !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	outline: none;
	color: rgba(255,255,255,0.85) !important;
	font-size: 1.5rem;
	font-weight: 400 !important;
	height: auto !important;
	line-height: 1 !important;
	letter-spacing: 0 !important;
	padding: 0.3em 0.4em !important;
	text-transform: none !important;
	white-space: nowrap !important;
	cursor: pointer;
	transition: color 0.2s;
}
nav.site-nav .nav-hamburger:focus-visible {
	outline: 2px solid rgba(255,255,255,0.6) !important;
	border-radius: 3px;
}
nav.site-nav ul li a {
	color: rgba(255,255,255,0.85);
	text-decoration: none;
	font-size: 0.82em;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	transition: color 0.2s;
}
nav.site-nav ul li a:hover,
nav.site-nav ul li a[aria-current="page"] { color: #ffffff; }

nav.site-nav .nav-tel {
	border: 1px solid rgba(255,255,255,0.3);
	padding: 0.2em 0.7em !important;
	border-radius: 3px;
}
nav.site-nav .nav-tel:hover { background: rgba(255,255,255,0.1) !important; }

/* Dropdown */
nav.site-nav .has-dropdown { position: relative; }
nav.site-nav .nav-dropdown-label {
	color: rgba(255,255,255,0.85);
	font-size: 0.82em;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	cursor: default;
	display: inline-flex;
	align-items: center;
	gap: 0.25em;
	user-select: none;
}
nav.site-nav .has-dropdown:hover .nav-dropdown-label,
nav.site-nav .has-dropdown:focus-within .nav-dropdown-label { color: #ffffff; }
nav.site-nav .nav-dropdown-list {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	margin: 0;
	padding: 0.4em 0;
	min-width: 15em;
	list-style: none;
	flex-direction: column;
	align-items: stretch;
	gap: 0;
	background: rgba(0,0,0,0.72);
	box-shadow: 0 0.35em 1em rgba(0,0,0,0.35);
	border-radius: 4px;
	z-index: 1001;
}
nav.site-nav .has-dropdown:hover .nav-dropdown-list,
nav.site-nav .has-dropdown:focus-within .nav-dropdown-list { display: flex; }
nav.site-nav .nav-dropdown-list li a {
	display: block;
	padding: 0.55em 1.1em;
	white-space: nowrap;
}
nav.site-nav .nav-dropdown-list li a:hover { background: rgba(255,255,255,0.08); }

/* -------------------------------------------------------
   Hamburger menu — mobile (< 900px)
   ------------------------------------------------------- */

@media (max-width: 900px) {
	nav.site-nav {
		padding: 0.55em 1.1em;
	}

	nav.site-nav .nav-hamburger {
		display: flex;
		align-items: center;
		justify-content: center;
		order: 3;
		width: 2.4em;
		height: 2.4em !important;
		border-radius: 6px !important;
		transition: background 0.2s, color 0.2s;
	}
	nav.site-nav .nav-hamburger:hover,
	nav.site-nav .nav-hamburger[aria-expanded="true"] {
		background: rgba(140, 209, 168, 0.15) !important;
		color: #8cd1a8 !important;
	}

	/* Panel rozwijany */
	nav.site-nav > .nav-inner > ul {
		display: none;
		position: absolute;
		top: calc(100% + 4px);
		right: 0.75em;
		left: auto;
		width: 270px;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		background: rgba(0,0,0,0.72);
		border-top: 3px solid #8cd1a8;
		border-radius: 0 0 8px 8px;
		padding: 0.6em 0 1em;
		box-shadow: 0 8px 24px rgba(0,0,0,0.45), 0 2px 6px rgba(0,0,0,0.3);
	}
	nav.site-nav > .nav-inner > ul.nav-open {
		display: flex;
	}

	/* Linki w panelu */
	nav.site-nav > .nav-inner > ul li a {
		display: block;
		padding: 0.7em 1.3em;
		font-size: 0.88em;
		letter-spacing: 0.04em;
		border-bottom: 1px solid rgba(140, 209, 168, 0.1);
		transition: background 0.15s, color 0.15s;
	}
	nav.site-nav > .nav-inner > ul li a:hover {
		background: rgba(140, 209, 168, 0.1);
		color: #8cd1a8;
	}
	nav.site-nav > .nav-inner > ul li a[aria-current="page"] {
		color: #8cd1a8;
		border-left: 3px solid #8cd1a8;
		padding-left: calc(1.3em - 3px);
	}

	/* Dropdown wewnętrzny */
	nav.site-nav .has-dropdown { width: 100%; }
	nav.site-nav .nav-dropdown-label {
		display: flex;
		align-items: center;
		padding: 0.7em 1.3em;
		font-size: 0.88em;
		letter-spacing: 0.04em;
		border-bottom: 1px solid rgba(140, 209, 168, 0.1);
		cursor: pointer;
		transition: background 0.15s, color 0.15s;
	}
	nav.site-nav .has-dropdown.dropdown-open .nav-dropdown-label,
	nav.site-nav .nav-dropdown-label:hover {
		background: rgba(140, 209, 168, 0.08);
		color: #8cd1a8;
	}
	nav.site-nav .nav-dropdown-list {
		position: static;
		display: none;
		min-width: 100%;
		box-shadow: none;
		background: rgba(0,0,0,0.25);
		border-left: 3px solid rgba(140, 209, 168, 0.35);
		margin: 0 0 0 1.3em;
		padding: 0.2em 0 0.4em;
		border-radius: 0;
	}
	nav.site-nav .nav-dropdown-list li a {
		padding: 0.55em 1em;
		font-size: 0.85em;
		border-bottom: none;
		color: rgba(255,255,255,0.75);
	}
	nav.site-nav .nav-dropdown-list li a:hover {
		color: #8cd1a8;
		background: rgba(140, 209, 168, 0.08);
	}
	nav.site-nav .has-dropdown:focus-within .nav-dropdown-list,
	nav.site-nav .has-dropdown.dropdown-open .nav-dropdown-list {
		display: flex;
	}

	/* Numer telefonu */
	nav.site-nav .nav-tel {
		margin: 0.8em 1.3em 0;
		padding: 0.6em 1em !important;
		text-align: center;
		border: 1px solid rgba(140, 209, 168, 0.5) !important;
		border-radius: 30px !important;
		color: #8cd1a8 !important;
		font-size: 0.88em;
		letter-spacing: 0.04em;
		transition: background 0.2s, border-color 0.2s;
	}
	nav.site-nav .nav-tel:hover {
		background: rgba(140, 209, 168, 0.15) !important;
		border-color: #8cd1a8 !important;
	}
}

/* Fallback — stary selector (dla stron z index.html#kontakt) */
nav.site-nav > ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em 1.2em;
	align-items: center;
}

/* -------------------------------------------------------
   Floating mobile CTA (przycisk telefoniczny)
   ------------------------------------------------------- */

.floating-mobile-cta {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 999;
}
.floating-cta-button {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	width: 100%;
	padding: 0.85em 1em;
	background: #2e7d32;
	color: #ffffff;
	font-size: 1em;
	font-weight: 700;
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	box-shadow: 0 -2px 8px rgba(0,0,0,0.3);
	transition: background 0.2s;
}
.floating-cta-button:hover,
.floating-cta-button:focus {
	background: #1b5e20;
}
@media (max-width: 1024px) {
	.floating-mobile-cta { display: block; }
}

/* Padding na dole strony, aby stopka nie była zasłonięta przez floating CTA */
@media (max-width: 1024px) {
	.subpage-content {
		padding-bottom: 5em;
	}
	footer {
		padding-bottom: 4.5em !important;
	}
}

/* -------------------------------------------------------
   Kontakt — siatka danych kontaktowych
   ------------------------------------------------------- */

.contact-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5em; margin: 2em 0; text-align: center; }
.contact-info-item { padding: 1em; }
.contact-info-item h3 { margin-top: 0.3em; }
.contact-info-item p { margin-bottom: 0; }

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

select.form-control,
select {
	width: 100%;
	padding: 0.75em;
	border: 1px solid rgba(0,0,0,0.15);
	border-radius: 4px;
	background: rgba(255,255,255,0.8);
	font-size: 0.95em;
}



/* -------------------------------------------------------
   Podstrony – layout i typografia
   ------------------------------------------------------- */

.subpage-content {
	padding: 6em 2em 4em;
	width: 35em;
	max-width: calc(100% - 4em);
	margin: 0 auto;
	line-height: 1.75;
	background: rgba(255, 255, 255, 0.95);
	box-shadow: inset 0 1px 0 0 #dddddd;
}

@media screen and (max-width: 980px) {
	.subpage-content {
		width: 80% !important;
		max-width: 100% !important;
	}
}

@media screen and (max-width: 480px) {
	.subpage-content {
		width: 100% !important;
	}
}
.subpage-content h1 { margin-bottom: 0.5em; }
.subpage-content h2 { margin: 2em 0 0.5em; }
.subpage-content h3 { margin: 1.5em 0 0.4em; }
.subpage-content p  { margin-bottom: 1.2em; }
.subpage-content ul { margin: 0 0 1.2em 1.5em; list-style: disc; }
.subpage-content ul li { margin-bottom: 0.4em; }

/* Breadcrumb */
.breadcrumb { font-size: 0.85em; margin-bottom: 1.25em; opacity: 0.75; }
.breadcrumb a { color: inherit; }

/* -------------------------------------------------------
   Etapy wizyty – siatka ikon (przebieg-wizyty.html)
   Resetuje float/width z main.css ul.icons-grid li
   ------------------------------------------------------- */

.subpage-content ul.icons-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5em;
	margin: 2em 0;
	padding: 0;
	list-style: none;
}

.subpage-content ul.icons-grid::after {
	display: none;
}

.subpage-content ul.icons-grid li {
	float: none;
	width: auto;
	padding: 1.5em 0.75em;
	text-align: center;
	box-shadow: none !important;
	margin-bottom: 0;
}

.subpage-content ul.icons-grid li:nth-child(2n+1) {
	box-shadow: none !important;
}

.subpage-content ul.icons-grid li:nth-child(2n+3)::before {
	display: none;
}

.subpage-content ul.icons-grid h3 {
	margin: 0.5em 0 0.4em;
	font-size: 0.85em;
	letter-spacing: 0.05em;
}

@media (max-width: 600px) {
	.subpage-content ul.icons-grid {
		grid-template-columns: repeat(1, 1fr);
	}
}

/* Tabela (artykuły bazy wiedzy) */
.subpage-content table { width: 100%; border-collapse: collapse; margin: 1.5em 0; font-size: 0.9em; }
.subpage-content th,
.subpage-content td { padding: 0.7em 1em; border: 1px solid rgba(0,0,0,0.12); text-align: left; }
.subpage-content th  { background: rgba(0,0,0,0.04); }


/* -------------------------------------------------------
   FAQ – akordeon <details>/<summary>
   Domyślnie: jasne tło (podstrony).
   Na stronie głównej (.main section) override poniżej.
   ------------------------------------------------------- */

.faq-list details {
	border-bottom: 1px solid rgba(0,0,0,0.1);
	margin-bottom: 0.5em;
}
.faq-list details[open] { margin-bottom: 1em; }
.faq-list summary {
	cursor: pointer;
	padding: 0.8em 0;
	list-style: none;
	font-size: 1em;
}
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::before {
	content: "+ ";
	font-weight: bold;
	margin-right: 0.3em;
}
.faq-list details[open] summary::before { content: "– "; }
.faq-list div p { padding: 0 0 0.8em 1.2em; line-height: 1.6; }

/* FAQ na ciemnym tle (sekcje strony głównej) */
.main .faq-list details {
	border-bottom-color: rgba(255,255,255,0.15);
}


/* -------------------------------------------------------
   Strona główna – kafelki "W czym pomagam"
   ------------------------------------------------------- */

.tiles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.5em;
	margin-top: 2em;
	text-align: left;
}
.tile-card {
	background: rgba(255,255,255,0.08);
	border-radius: 6px;
	padding: 1.5em;
	transition: background 0.2s;
}
.tile-card:hover { background: rgba(255,255,255,0.14); }
.tile-card h3 { margin-bottom: 0.6em; font-size: 1em; }
.tile-card p  { font-size: 0.9em; line-height: 1.55; margin-bottom: 1em; }
.tile-card a.button { font-size: 0.8em; padding: 0.5em 1em; }


/* -------------------------------------------------------
   Galeria certyfikatów
   Domyślnie: ciemne tło (strona główna).
   W .subpage-content: jasne tło.
   ------------------------------------------------------- */

.cert-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1em;
	margin-top: 1.5em;
}
.cert-gallery figure { margin: 0; text-align: center; }
.cert-gallery .cert-lightbox-trigger {
	display: block;
	text-decoration: none;
	color: inherit;
	cursor: zoom-in;
}
.cert-gallery .cert-thumb {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
	object-fit: contain;
	border-radius: 4px;
	border: 1px solid rgba(255,255,255,0.2);
}
.cert-gallery figcaption { font-size: 0.8em; margin-top: 0.4em; opacity: 0.8; }

/* Galeria certyfikatów – jasne tło (o-mnie.html) */
.subpage-content .cert-gallery .cert-thumb {
	border-color: #ddd;
}
.subpage-content .cert-gallery figcaption {
	opacity: 1;
	color: #666;
	font-size: 0.78em;
}

/* Placeholder gdy obraz certyfikatu niedostępny */
.cert-placeholder {
	padding: 2em;
	background: #f7f5f0;
	border-radius: 4px;
	border: 1px solid #ddd;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 0.5em;
	color: #999;
	font-size: 0.85em;
}

/* Podgląd pełnoekranowy certyfikatu (klik w miniaturę) */
html.cert-lightbox-lock,
body.cert-lightbox-lock {
	overflow: hidden;
	scrollbar-gutter: stable;
}
body.cert-lightbox-lock #wrapper {
	overflow: hidden;
}
.cert-lightbox-backdrop {
	position: fixed;
	inset: 0;
	z-index: 10000;
	background: rgba(0, 0, 0, 0.88);
	display: grid;
	place-items: center;
	width: 100vw;
	height: 100vh;
	height: 100dvh;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	cursor: zoom-out;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateZ(0);
	transition: opacity 0.3s ease, visibility 0s linear 0.3s;
}
.cert-lightbox-backdrop.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transition-delay: 0s;
}
.cert-lightbox-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding: 3.25rem 1rem 1rem;
	box-sizing: border-box;
	pointer-events: none;
}
.cert-lightbox-img {
	max-width: min(95vw, 1400px);
	max-height: calc(100dvh - 4.25rem);
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: 4px;
	box-shadow: 0 8px 40px rgba(0, 0, 0, 0.45);
	cursor: default;
	pointer-events: auto;
	transform: translate3d(0, 14px, 0) scale(0.94);
	transform-origin: center center;
	opacity: 0;
	transition: transform 0.34s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.26s ease;
}
.cert-lightbox-backdrop.is-open .cert-lightbox-img {
	transform: translate3d(0, 0, 0) scale(1);
	opacity: 1;
}
.cert-lightbox-close {
	position: absolute;
	top: 0.5rem;
	right: 0.75rem;
	z-index: 10001;
	padding: 0.25rem 0.6rem;
	font-size: 2rem;
	line-height: 1;
	color: #fff;
	background: transparent;
	border: none;
	cursor: pointer;
	border-radius: 4px;
	pointer-events: auto;
}
.cert-lightbox-close:hover,
.cert-lightbox-close:focus {
	background: rgba(255, 255, 255, 0.12);
	outline: none;
}

@media (prefers-reduced-motion: reduce) {
	.cert-lightbox-backdrop,
	.cert-lightbox-img {
		transition-duration: 0.01ms !important;
	}
	.cert-lightbox-backdrop .cert-lightbox-img {
		transform: none;
	}
	.cert-lightbox-backdrop.is-open .cert-lightbox-img {
		transform: none;
		opacity: 1;
	}
}


/* -------------------------------------------------------
   Strona główna – linki do źródeł naukowych
   ------------------------------------------------------- */

.science-links {
	display: flex;
	flex-wrap: wrap;
	gap: 1em;
	margin-top: 1.5em;
	justify-content: center;
}


/* -------------------------------------------------------
   Strona główna – odstępy sekcji
   ------------------------------------------------------- */

.main .container {
	padding-top: 4em;
	padding-bottom: 4em;
}

.main .container:before {
	min-height: 0;
	display: none;
}

@media screen and (max-width: 736px) {
	.main .container {
		padding-top: 2.5em;
		padding-bottom: 2.5em;
	}
}


/* -------------------------------------------------------
   Strona główna – lokalna nawigacja sekcyjna
   ------------------------------------------------------- */

#home-local-nav .container {
	padding-top: 3em;
	padding-bottom: 3em;
}

@media screen and (max-width: 736px) {
	#home-local-nav .container {
		padding-top: 2em;
		padding-bottom: 2em;
	}
}

#home-local-nav .content { text-align: center; }
.home-local-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em 0.75em;
	justify-content: center;
	align-items: center;
}
.home-local-nav-list a {
	color: inherit;
	text-decoration: none;
	font-size: 0.85em;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-bottom: 1px solid rgba(0,0,0,0.2);
	padding-bottom: 0.1em;
}
.home-local-nav-list a:hover { border-bottom-color: rgba(0,0,0,0.5); }


/* -------------------------------------------------------
   Strona główna – sekcja kontaktu
   ------------------------------------------------------- */

#kontakt .container {
	padding-top: 3em;
	padding-bottom: 4em;
}

@media screen and (max-width: 736px) {
	#kontakt .container {
		padding-top: 2em;
		padding-bottom: 2.5em;
	}
}


/* -------------------------------------------------------
   Mapa Google
   ------------------------------------------------------- */

.map-wrapper {
	margin: 1.5em 0;
	border-radius: 6px;
	overflow: hidden;
}
.map-wrapper iframe {
	width: 100%;
	height: 320px;
	border: 0;
}


/* -------------------------------------------------------
   Footer – pełna szerokość na stronie głównej
   ------------------------------------------------------- */

#footer > .row > div p,
#footer > .row > div ul.links {
	max-width: none;
}

/* Kolumny footera na mobile – pełna szerokość */
@media screen and (max-width: 980px) {

	#footer {
		text-align: left;
	}

	#footer .col-4,
	#footer .col-12-medium {
		width: 100% !important;
		margin-left: 0 !important;
		margin-bottom: 1.5em;
	}

	#footer .row > .col-4:last-child,
	#footer .row > .col-12-medium:last-child {
		margin-bottom: 0;
	}

	#footer .links,
	#footer p {
		max-width: 100%;
	}

}

#footer .links {
	list-style: none;
	padding-left: 0;
}

#footer .links li {
	padding-left: 0;
}

/* -------------------------------------------------------
   Listy – estetyczny wygląd na mobile
   Kropki nie przyklejają się do krawędzi ekranu
   ------------------------------------------------------- */

@media screen and (max-width: 736px) {

	.main .container section ul:not(.icons-grid):not(.actions):not(.icons):not(.home-local-nav-list):not(.links):not(.copyright),
	.subpage-content ul:not(.actions):not(.icons):not(.links) {
		list-style-position: inside;
		padding-left: 0;
	}

	.main .container section ul:not(.icons-grid):not(.actions):not(.icons):not(.home-local-nav-list):not(.links):not(.copyright) li,
	.subpage-content ul:not(.actions):not(.icons):not(.links) li {
		padding-left: 0;
		padding-bottom: 0.35em;
		line-height: 1.6;
	}

}

/* -------------------------------------------------------
   Ikona UEP Alumni (stopka strony głównej)
   ------------------------------------------------------- */

.icon.uep-logo {
	width: 4.5em;
	height: 4.5em;
	display: inline-block;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	vertical-align: middle;
	position: relative;
	top: -0.30em;
}


/* -------------------------------------------------------
   O mnie – zdjęcie portretowe
   ------------------------------------------------------- */

.portrait {
	float: right;
	margin: 0 0 1.5em 2em;
	max-width: 260px;
	border-radius: 6px;
	overflow: hidden;
}
.portrait img { width: 100%; display: block; }
@media (max-width: 600px) {
	.portrait { float: none; margin: 0 0 1.5em; max-width: 100%; }
}


/* -------------------------------------------------------
   O mnie – oś czasu edukacji
   ------------------------------------------------------- */

.edu-timeline { margin: 0 0 1.5em; padding-left: 0; list-style: none; }
.edu-timeline li {
	padding: 0.8em 0 0.8em 2.5em;
	border-left: 2px solid #ddd;
	list-style: none;
	position: relative;
	margin-bottom: 0;
}
.edu-timeline li::before {
	content: '';
	width: 8px;
	height: 8px;
	background: #888;
	border-radius: 50%;
	position: absolute;
	left: -5px;
	top: 1.15em;
}
.edu-timeline .year {
	font-size: 0.8em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #888;
	display: block;
	margin-bottom: 0.15em;
}


/* -------------------------------------------------------
   Baza wiedzy – siatka artykułów
   ------------------------------------------------------- */

.articles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5em;
	margin-bottom: 2em;
}
.article-card {
	background: rgba(255,255,255,0.08);
	border-radius: 6px;
	padding: 1.5em;
	transition: background 0.2s;
}
.article-card:hover { background: rgba(255,255,255,0.14); }
.article-card h2   { font-size: 1.05em; margin-bottom: 0.5em; }
.article-card p    { font-size: 0.9em; line-height: 1.55; margin-bottom: 1em; }
.article-card a.button { font-size: 0.8em; padding: 0.45em 1em; }

/* -------------------------------------------------------
   Buttony – globalne estetyczne poprawki (override main.css)
   ------------------------------------------------------- */

.button,
input[type="submit"],
input[type="reset"],
input[type="button"],
button:not(.nav-hamburger):not(.cert-lightbox-close) {
	border-radius: 30px !important;
	text-transform: none !important;
	font-weight: 600 !important;
	letter-spacing: 0 !important;
	box-shadow: inset 0 0 0 1.5px rgba(0,0,0,0.15) !important;
	transition: all 0.25s ease-in-out !important;
	color: #4a5255 !important;
	background-color: transparent !important;
	white-space: normal !important;
	height: auto !important;
	line-height: 1.4 !important;
	padding: 0.85em 2em !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover,
button:not(.nav-hamburger):not(.cert-lightbox-close):hover {
	background-color: rgba(140, 209, 168, 0.1) !important;
	box-shadow: inset 0 0 0 1.5px #8cd1a8 !important;
	color: #2e7d32 !important;
}

.button.primary,
input[type="submit"].primary,
input[type="reset"].primary,
input[type="button"].primary,
button.primary:not(.nav-hamburger) {
	background-color: #8cd1a8 !important;
	box-shadow: 0 4px 12px rgba(140, 209, 168, 0.3) !important;
	color: #ffffff !important;
	border: none !important;
}

.button.primary:hover,
input[type="submit"].primary:hover,
input[type="reset"].primary:hover,
input[type="button"].primary:hover,
button.primary:not(.nav-hamburger):hover {
	background-color: #7bc298 !important;
	box-shadow: 0 6px 16px rgba(140, 209, 168, 0.4) !important;
}

.button.primary:active,
input[type="submit"].primary:active,
input[type="reset"].primary:active,
input[type="button"].primary:active,
button.primary:not(.nav-hamburger):active {
	box-shadow: 0 2px 8px rgba(140, 209, 168, 0.3) !important;
}

/* Grupy CTA w treści podstron (jak „Powiązane metody…” na leczenie-bolu.html) */
.subpage-content .button-group,
.subpage-content p:has(> a.button),
.subpage-content div:has(> a.button):not(:has(> p)) {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 0.85em;
	justify-content: center;
	margin-top: 1.6em;
}

/* Blok: wstęp w <p>, potem przyciski — akapit na pełną szerokość, potem ten sam układ co wyżej */
.subpage-content div:has(> p):has(> a.button) {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 0.85em;
	justify-content: center;
}

.subpage-content div:has(> p):has(> a.button) > p {
	flex: 1 0 100%;
	text-align: center;
	margin-bottom: 0;
}

.subpage-content .button-group {
	max-width: 42em;
	margin-left: auto;
	margin-right: auto;
	row-gap: 1.25em;
}

.subpage-content .button-group .button {
	flex: 1 1 15em;
}

.subpage-content .button-group .button:nth-child(3):last-child {
	flex: 0 1 20em;
}

.subpage-content .button-group .button,
.subpage-content p:has(> a.button) .button,
.subpage-content div:has(> a.button):not(:has(> p)) .button,
.subpage-content div:has(> p):has(> a.button) > a.button {
	margin: 0 !important;
	min-height: 3.2em;
	min-width: 12.5em;
	padding: 0.8em 1.35em !important;
	background-color: rgba(255,255,255,0.72) !important;
	box-shadow: inset 0 0 0 1.5px rgba(76, 91, 86, 0.18), 0 0.45em 1.2em rgba(60, 70, 66, 0.06) !important;
}

@media screen and (min-width: 737px) {
	.subpage-content .button-group .button:nth-child(3):last-child {
		margin-top: 0.45em !important;
	}
}

.subpage-content .button-group .button:hover,
.subpage-content .button-group .button:focus-visible,
.subpage-content p:has(> a.button) .button:hover,
.subpage-content p:has(> a.button) .button:focus-visible,
.subpage-content div:has(> a.button):not(:has(> p)) .button:hover,
.subpage-content div:has(> a.button):not(:has(> p)) .button:focus-visible,
.subpage-content div:has(> p):has(> a.button) > a.button:hover,
.subpage-content div:has(> p):has(> a.button) > a.button:focus-visible {
	transform: translateY(-1px);
	background-color: rgba(140, 209, 168, 0.14) !important;
	box-shadow: inset 0 0 0 1.5px #8cd1a8, 0 0.7em 1.4em rgba(60, 70, 66, 0.1) !important;
	outline: none;
}

.subpage-content .button-group .button.primary,
.subpage-content p:has(> a.button) .button.primary,
.subpage-content div:has(> a.button):not(:has(> p)) .button.primary,
.subpage-content div:has(> p):has(> a.button) > a.button.primary {
	background: linear-gradient(135deg, #8cd1a8 0%, #74c293 100%) !important;
	box-shadow: 0 0.55em 1.4em rgba(96, 176, 128, 0.28) !important;
}

.subpage-content .button-group .button.primary:hover,
.subpage-content .button-group .button.primary:focus-visible,
.subpage-content p:has(> a.button) .button.primary:hover,
.subpage-content p:has(> a.button) .button.primary:focus-visible,
.subpage-content div:has(> a.button):not(:has(> p)) .button.primary:hover,
.subpage-content div:has(> a.button):not(:has(> p)) .button.primary:focus-visible,
.subpage-content div:has(> p):has(> a.button) > a.button.primary:hover,
.subpage-content div:has(> p):has(> a.button) > a.button.primary:focus-visible {
	background: linear-gradient(135deg, #97d9b3 0%, #75c394 100%) !important;
	box-shadow: 0 0.8em 1.6em rgba(96, 176, 128, 0.36) !important;
	color: #ffffff !important;
}

@media screen and (max-width: 736px) {
	.subpage-content .button-group,
	.subpage-content p:has(> a.button),
	.subpage-content div:has(> a.button):not(:has(> p)),
	.subpage-content div:has(> p):has(> a.button) {
		gap: 0.65em;
	}

	.subpage-content .button-group .button,
	.subpage-content p:has(> a.button) .button,
	.subpage-content div:has(> a.button):not(:has(> p)) .button,
	.subpage-content div:has(> p):has(> a.button) > a.button {
		width: 100%;
		min-width: 0;
	}
}

/* -------------------------------------------------------
   Typografia – zakaz łamania
   ------------------------------------------------------- */

.nobr,
span.year,
a[href^="tel:"] {
	white-space: nowrap;
}

