/* components.css — c-* component styles. One block per component.
 *
 * Design rules across the file:
 *   • Section backgrounds alternate paper / surface-tint (warm cream). No pink.
 *   • Brand red is reserved for CTAs, links, eyebrows, accents.
 *   • Card shadows are soft and only deepen on hover.
 *   • No animations beyond hover micro-motion (per §19.15).
 *   • Tap targets ≥48px, icons stroked 1.75 weight.
 */

/* === c-header ====================================================== */
.c-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255, 255, 255, .96);
	backdrop-filter: saturate(150%) blur(8px);
	-webkit-backdrop-filter: saturate(150%) blur(8px);
	border-block-end: 1px solid var(--color-ink-200);
	min-height: var(--header-height);
}
.c-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-l);
	min-height: var(--header-height);
}
.c-header__logo { display: inline-flex; align-items: center; }
.c-header__logo img {
	height: 64px;
	width: auto;
}
@media (max-width: 599px) {
	.c-header__logo img { height: 52px; }
}
.c-header__nav { display: none; }
@media (min-width: 1024px) {
	.c-header__nav {
		display: flex;
		gap: var(--space-l);
		align-items: center;
	}
}
.c-header__nav a {
	color: var(--color-ink-900);
	text-decoration: none;
	font-weight: var(--fw-strong);
	font-size: 1rem;
	padding: 0.5rem 0.25rem;
	position: relative;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
}
.c-header__nav a::after {
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: -1px;
	height: 2px;
	background: var(--color-brand-primary);
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur-base) var(--ease-out);
}
.c-header__nav a:hover, .c-header__nav a[aria-current="page"] { color: var(--color-brand-primary); }
.c-header__nav a:hover::after, .c-header__nav a[aria-current="page"]::after { transform: scaleX(1); }

/* Header dropdown ("Dla opiekunek") */
.c-header__nav-item--has-dropdown {
	position: relative;
	display: inline-flex;
	align-items: center;
}
.c-header__nav-trigger {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	color: var(--color-ink-900);
	font-weight: var(--fw-strong);
	font-size: 1rem;
	font-family: inherit;
	padding: 0.5rem 0.25rem;
	min-height: 44px;
	background: none;
	border: 0;
	cursor: pointer;
	position: relative;
}
.c-header__nav-trigger::after {
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: -1px;
	height: 2px;
	background: var(--color-brand-primary);
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur-base) var(--ease-out);
}
.c-header__nav-item--has-dropdown:hover .c-header__nav-trigger,
.c-header__nav-trigger:focus-visible,
.c-header__nav-trigger[aria-expanded="true"] {
	color: var(--color-brand-primary);
}
.c-header__nav-item--has-dropdown:hover .c-header__nav-trigger::after,
.c-header__nav-trigger:focus-visible::after,
.c-header__nav-trigger[aria-expanded="true"]::after {
	transform: scaleX(1);
}
.c-header__nav-trigger .icon {
	transition: transform var(--dur-base) var(--ease-out);
}
.c-header__nav-item--has-dropdown:hover .c-header__nav-trigger .icon,
.c-header__nav-trigger[aria-expanded="true"] .icon {
	transform: rotate(180deg);
}

.c-header__dropdown {
	position: absolute;
	top: 100%;
	left: -1rem;
	min-width: 280px;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-m);
	box-shadow: 0 8px 24px rgba(20,23,26,0.12);
	padding: 0.5rem;
	display: none;
	flex-direction: column;
	gap: 0;
	z-index: 100;
}
.c-header__nav-item--has-dropdown:hover .c-header__dropdown,
.c-header__nav-item--has-dropdown:focus-within .c-header__dropdown {
	display: flex;
}
.c-header__dropdown a {
	padding: 0.625rem 0.875rem;
	min-height: auto;
	font-weight: var(--fw-body);
	font-size: 0.9375rem;
	border-radius: var(--radius-s);
	white-space: nowrap;
}
.c-header__dropdown a::after { display: none; }
.c-header__dropdown a:hover {
	background: var(--color-surface-tint);
	color: var(--color-brand-primary);
}

/* Drawer group (mobile sub-section) */
.c-drawer__group {
	border-top: 1px solid var(--color-ink-200);
	margin-block: var(--space-s);
	padding-top: var(--space-s);
}
.c-drawer__group-h {
	display: block;
	font-size: 0.8125rem;
	font-weight: var(--fw-strong);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-brand-primary);
	margin-block-end: var(--space-xs);
}
.c-drawer__group a {
	display: block;
	padding: 0.5rem 0;
	font-size: 0.9375rem;
	color: var(--color-ink-900);
	text-decoration: none;
}
.c-drawer__group a:hover { color: var(--color-brand-primary); }

.c-header__cta {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}
.c-header__phone {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
	color: var(--color-ink-900);
	font-weight: var(--fw-button);
	font-size: 1rem;
	text-decoration: none;
	min-height: 44px;
	padding: 0.5rem 0.75rem;
	border-radius: var(--radius-m);
}
.c-header__phone .icon { color: var(--color-brand-primary); }
.c-header__phone:hover { background: var(--color-ink-100); color: var(--color-ink-900); }
@media (max-width: 599px) {
	.c-header__phone span { display: none; } /* keep icon, drop number on tiny — phone link still works via tap */
}
@media (min-width: 600px) {
	.c-header__phone span { display: inline; } /* §19.14 — phone visible from 600px up */
}

.c-header__hamburger {
	display: inline-flex;
	width: 48px;
	height: 48px;
	align-items: center;
	justify-content: center;
	color: var(--color-ink-900);
	border-radius: var(--radius-m);
}
@media (min-width: 1024px) { .c-header__hamburger { display: none; } }

/* Mobile drawer */
.c-drawer {
	position: fixed;
	inset: 0;
	background: rgba(20, 23, 26, .55);
	display: none;
	z-index: 60;
}
.c-drawer[aria-hidden="false"] { display: block; }
.c-drawer__panel {
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	width: min(380px, 88vw);
	background: var(--color-paper);
	padding: var(--space-l) var(--space-m);
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
	box-shadow: -8px 0 32px rgba(20, 23, 26, .12);
}
.c-drawer__close {
	align-self: flex-end;
	width: 48px; height: 48px;
	display: inline-flex;
	align-items: center; justify-content: center;
	color: var(--color-ink-900);
	border-radius: var(--radius-m);
}
.c-drawer__close:hover { background: var(--color-ink-100); }
.c-drawer__nav { display: flex; flex-direction: column; gap: 2px; }
.c-drawer__nav a {
	display: block;
	padding: var(--space-s) var(--space-m);
	font-size: var(--fs-body-l);
	color: var(--color-ink-900);
	text-decoration: none;
	border-radius: var(--radius-m);
	font-weight: var(--fw-strong);
	min-height: 48px;
	display: flex;
	align-items: center;
}
.c-drawer__nav a:hover { background: var(--color-ink-100); color: var(--color-brand-primary); }


/* === c-hero (full-bleed image + overlay text — ivydentist style) ====== */
.c-hero {
	position: relative;
	min-height: clamp(560px, 78vh, 760px);
	color: var(--color-paper);
	overflow: hidden;
	isolation: isolate;
	display: flex;
	align-items: center;
}
.c-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	display: block;
}
.c-hero__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: right top;
	display: block;
}
.c-hero__scrim {
	position: absolute;
	inset: 0;
	z-index: -1;
	pointer-events: none;
	/* Strong dark wash on the left fading to clear at ~58% across, plus a
	 * soft bottom darken so the trust badges always read. */
	background:
		linear-gradient(90deg, rgba(20, 23, 26, .82) 0%, rgba(20, 23, 26, .55) 32%, rgba(20, 23, 26, 0) 62%),
		linear-gradient(180deg, rgba(20, 23, 26, 0) 60%, rgba(20, 23, 26, .55) 100%);
}
.c-hero__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	padding-block: clamp(3rem, 7vw, 5rem);
}
.c-hero__content {
	max-width: 600px;
}
.c-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
	padding: 0.5rem 1rem;
	background: rgba(255, 255, 255, .14);
	border: 1px solid rgba(255, 255, 255, .35);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-radius: var(--radius-pill);
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	color: var(--color-paper);
	margin-block-end: var(--space-l);
	letter-spacing: 0.01em;
}
.c-hero__eyebrow .dot {
	display: inline-block;
	width: 8px; height: 8px;
	background: #5BD49F;
	border-radius: 50%;
	box-shadow: 0 0 0 4px rgba(91, 212, 159, .25);
}
.c-hero__h1 {
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: var(--color-paper);
	margin: 0 0 var(--space-m);
	text-shadow: 0 2px 24px rgba(0, 0, 0, .35);
	max-width: 16ch;
}
.c-hero__lede {
	font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
	line-height: 1.55;
	color: rgba(255, 255, 255, .9);
	margin: 0 0 var(--space-l);
	max-width: 44ch;
	text-shadow: 0 1px 12px rgba(0, 0, 0, .35);
}
.c-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-s);
	margin-block-end: var(--space-l);
}
.c-hero__trust {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-m) var(--space-l);
	padding-block-start: var(--space-l);
	border-block-start: 1px solid rgba(255, 255, 255, .25);
	font-size: var(--fs-caption);
	color: rgba(255, 255, 255, .85);
}
.c-hero__trust li { display: inline-flex; align-items: center; gap: var(--space-2xs); }
.c-hero__trust .icon { color: var(--color-paper); opacity: .9; }
.c-hero__trust strong { color: var(--color-paper); font-weight: var(--fw-strong); }

/* Hero ghost CTA — frosted, sits on the dark scrim */
.btn--hero-ghost {
	background: rgba(255, 255, 255, .12);
	color: var(--color-paper);
	border-color: rgba(255, 255, 255, .45);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.btn--hero-ghost:hover {
	background: rgba(255, 255, 255, .2);
	color: var(--color-paper);
	border-color: var(--color-paper);
	transform: translateY(-1px);
}
.btn--hero-ghost .icon { color: var(--color-paper); }

@media (max-width: 819px) {
	.c-hero { min-height: 88dvh; align-items: flex-end; }
	.c-hero__bg img { object-position: 60% top; }
	.c-hero__scrim {
		background:
			linear-gradient(180deg, rgba(20, 23, 26, .25) 0%, rgba(20, 23, 26, .55) 45%, rgba(20, 23, 26, .85) 100%);
	}
	.c-hero__inner { padding-block: clamp(2.5rem, 8vw, 4rem); }
	.c-hero__h1 { font-size: clamp(2rem, 8vw, 3rem); max-width: none; }
	.c-hero__lede { max-width: none; }
	.c-hero__trust { gap: var(--space-s) var(--space-m); }
}


/* === c-latest-offers (replaces c-offer-ribbon) ====================== */
/* Clean grid section, NOT a carousel. Lives in the homepage flow.
 * Sits directly under the hero on white so the cards pop. */
.c-latest-offers {
	background: var(--color-paper);
	padding-block: var(--space-section);
	border-block-end: 1px solid var(--color-ink-200);
}
.c-latest-offers__head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: var(--space-m);
	margin-block-end: var(--space-l);
	flex-wrap: wrap;
}
.c-latest-offers__head h2 { margin: 0; }
.c-latest-offers__head .lede { color: var(--color-ink-700); margin-block-start: var(--space-2xs); margin-block-end: 0; }
.c-latest-offers__head-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
	color: var(--color-brand-primary);
	font-weight: var(--fw-button);
	text-decoration: none;
	min-height: 44px;
}
.c-latest-offers__head-link:hover { color: var(--color-brand-primary-700); }
.c-latest-offers__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-m);
}
@media (max-width: 1023px) { .c-latest-offers__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .c-latest-offers__grid { grid-template-columns: 1fr; } }

/* Compact card variant inside the homepage section so 3 fit nicely. */
.c-latest-offers .c-offer-card__media { height: 170px; }
.c-latest-offers .c-offer-card__title { font-size: 1rem; padding: 0.45rem 0.75rem; }
.c-latest-offers .c-offer-card__eyebrow { font-size: 0.65rem; padding: 0.25rem 0.6rem; }
.c-latest-offers .c-offer-card__meta { font-size: 1rem; gap: 0.3rem; padding-block: var(--space-s); }
.c-latest-offers .c-offer-card__meta dt { font-size: 0.9375rem; }
.c-latest-offers .c-offer-card__meta dd { font-size: 1.0625rem; }
.c-latest-offers .c-offer-card__meta div { grid-template-columns: minmax(115px, 45%) 1fr; gap: var(--space-2xs); }
.c-latest-offers .c-offer-card__salary-main { font-size: clamp(1.875rem, 2.6vw, 2.25rem); }
.c-latest-offers .c-offer-card__footer .btn { font-size: 1rem; padding: 0.625rem 0.875rem; min-height: 40px; }
.c-latest-offers__footer {
	margin-block-start: var(--space-l);
	display: flex;
	gap: var(--space-m);
	align-items: center;
	flex-wrap: wrap;
	color: var(--color-ink-500);
	font-size: var(--fs-caption);
}
.c-latest-offers__footer > span {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}
.c-latest-offers__footer .icon { color: var(--color-brand-primary); flex: 0 0 auto; }


/* === c-offer-card (live-site mirror layout) ========================== */
.c-offer-card {
	display: flex;
	flex-direction: column;
	color: var(--color-ink-900);
	padding: 0;
	overflow: hidden;
	background: var(--color-paper);
	border: 1.5px solid var(--color-brand-primary);
	border-radius: var(--radius-l);
	transition: background var(--dur-base) var(--ease-out),
				transform var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out);
	position: relative;
}
.c-offer-card:hover {
	background: var(--color-surface-tint);
	transform: translateY(-2px);
	box-shadow: var(--shadow-hover);
}
.c-offer-card > :not(.c-offer-card__media) { padding-inline: var(--space-l); }
.c-offer-card > .c-offer-card__footer { padding-block-end: var(--space-l); }

/* Image hero — fills top 260px of card, dark scrim, location eyebrow + title overlaid. */
.c-offer-card__media {
	position: relative;
	height: 210px;
	background-color: var(--color-ink-900);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	color: var(--color-paper);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: var(--space-s) var(--space-m);
	margin: 0 0 var(--space-s);
	overflow: hidden;
}
.c-offer-card__media::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			180deg,
			rgba(0, 0, 0, .35) 0%,
			rgba(0, 0, 0, 0) 28%,
			rgba(0, 0, 0, 0) 45%,
			rgba(0, 0, 0, .65) 100%
		);
	pointer-events: none;
}
.c-offer-card__media > * { position: relative; z-index: 1; }
.c-offer-card__media-top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--space-2xs);
}
.c-offer-card__media-meta {
	display: inline-flex;
	gap: 0.375rem;
	flex-wrap: wrap;
	justify-content: flex-end;
}

/* Overlay text (eyebrow + title) at bottom of the image — stacked. */
.c-offer-card__overlay {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
	color: var(--color-paper);
	text-decoration: none;
	margin-block-start: auto;
}
.c-offer-card__overlay:hover { color: var(--color-paper); }
.c-offer-card__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background: rgba(255, 255, 255, .92);
	color: var(--color-ink-900);
	padding: 0.32rem 0.7rem;
	border-radius: var(--radius-pill);
	font-size: 0.7rem;
	font-weight: var(--fw-button);
	text-transform: uppercase;
	letter-spacing: 0.09em;
	box-shadow: 0 1px 6px rgba(0, 0, 0, .15);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	text-shadow: none;
}
.c-offer-card__eyebrow .icon { color: var(--color-brand-primary); }
.c-offer-card__overlay:hover .c-offer-card__eyebrow {
	background: var(--color-paper);
	box-shadow: 0 2px 10px rgba(0, 0, 0, .2);
}
.c-offer-card__title {
	display: inline-block;
	max-width: 100%;
	background: rgba(255, 255, 255, .95);
	color: var(--color-ink-900);
	padding: 0.55rem 0.95rem;
	border-radius: var(--radius-m);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	box-shadow: 0 2px 12px rgba(0, 0, 0, .18);
	font-family: var(--font-display);
	font-size: 1.1875rem;
	font-weight: var(--fw-display);
	letter-spacing: -0.005em;
	line-height: 1.3;
	margin: 0;
	text-shadow: none;
}
.c-offer-card__overlay:hover .c-offer-card__title {
	background: var(--color-paper);
	box-shadow: 0 4px 18px rgba(0, 0, 0, .25);
}
.c-offer-card__head {
	/* legacy class — kept for backwards-compat */
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-2xs);
	margin-block-end: var(--space-s);
}
.c-offer-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 0.75rem;
	font-weight: var(--fw-button);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 0.3rem 0.7rem;
	border-radius: var(--radius-pill);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
}
.c-offer-card__badge--nowa {
	background: var(--color-brand-secondary);
	color: var(--color-ink-900);
}
.c-offer-card__badge--wymiana {
	background: var(--color-brand-primary);
	color: var(--color-paper);
}
.c-offer-card__num {
	font-size: var(--fs-caption);
	color: var(--color-ink-900);
	font-family: ui-monospace, 'SF Mono', Menlo, monospace;
	background: rgba(255, 255, 255, .9);
	padding: 0.15rem 0.55rem;
	border-radius: var(--radius-pill);
	box-shadow: 0 1px 4px rgba(0, 0, 0, .08);
}
.c-offer-card__distance {
	margin-inline-start: auto;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	background: var(--color-surface-tint);
	color: var(--color-ink-700);
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	padding: 0.25rem 0.625rem;
	border-radius: var(--radius-pill);
	border: 1px solid var(--color-ink-200);
}

.c-offer-card__meta {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.375rem;
	margin: 0 0 var(--space-s);
	padding-block: var(--space-s);
	border-block: 1px solid rgba(0, 0, 0, .08);
	font-size: 1.125rem;
	line-height: 1.4;
}
.c-offer-card__meta div { display: grid; grid-template-columns: minmax(150px, 45%) 1fr; gap: var(--space-s); }
.c-offer-card__meta dt {
	color: var(--color-ink-500);
	font-weight: var(--fw-body);
	margin: 0;
	font-size: 1.0625rem;
}
.c-offer-card__meta dd {
	color: var(--color-ink-900);
	font-weight: var(--fw-strong);
	margin: 0;
	font-size: 1.1875rem;
}

.c-offer-card__salary-block {
	display: flex;
	align-items: baseline;
	gap: var(--space-s);
	margin-block-end: var(--space-m);
	color: var(--color-brand-primary);
}
.c-offer-card__salary-main {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 4vw, 3rem);
	font-weight: var(--fw-display);
	line-height: 1;
	letter-spacing: -0.025em;
}
.c-offer-card__salary-cur {
	font-size: 0.72em;
	font-weight: var(--fw-display);
	margin-inline-start: 0.2em;
	letter-spacing: 0;
	opacity: 0.9;
	vertical-align: 0.08em;
}
.c-offer-card__salary-sub {
	font-size: 1rem;
	color: var(--color-ink-500);
	font-weight: var(--fw-body);
}

.c-offer-card__footer {
	display: flex;
	gap: var(--space-s);
	margin-block-start: auto;
}
.c-offer-card__footer .btn { flex: 1 1 0; min-height: 44px; padding-inline: var(--space-m); }
.c-offer-card__footer .btn--ghost { background: var(--color-paper); }

@media (max-width: 599px) {
	.c-offer-card__meta div { grid-template-columns: 1fr; gap: 0; }
	.c-offer-card__footer { flex-direction: column; }
}


/* === c-trust-strip ================================================ */
.c-trust-strip {
	background: var(--color-surface-tint);
	padding-block: var(--space-2xl);
}
.c-trust-strip__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--space-l);
}
@media (max-width: 1023px) { .c-trust-strip__grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-m); } }
@media (max-width: 599px)  { .c-trust-strip__grid { grid-template-columns: 1fr; } }
.c-trust-strip__tile {
	display: flex;
	gap: var(--space-s);
	align-items: flex-start;
	padding: var(--space-m);
	border-radius: var(--radius-m);
	color: var(--color-ink-900);
	text-decoration: none;
	transition: background var(--dur-base) var(--ease-out);
}
.c-trust-strip__tile:hover {
	background: var(--color-paper);
	color: var(--color-ink-900);
}
.c-trust-strip__icon {
	flex: 0 0 44px;
	width: 44px; height: 44px;
	display: inline-flex;
	align-items: center; justify-content: center;
	color: var(--color-brand-primary);
	background: var(--color-paper);
	border-radius: var(--radius-m);
	border: 1px solid var(--color-ink-200);
}
.c-trust-strip__title {
	display: block;
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: var(--fw-display);
	margin-block-end: 0.125rem;
}
.c-trust-strip__body {
	display: block;
	font-size: 1rem;
	color: var(--color-ink-700);
	line-height: 1.45;
}


/* === c-service-grid =============================================== */
.c-service-grid__cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-m);
}
@media (max-width: 1023px) { .c-service-grid__cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .c-service-grid__cards { grid-template-columns: 1fr; } }
.c-service-grid__card {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
	background: var(--color-paper);
	padding: var(--space-l);
	border-radius: var(--radius-l);
	border: 1px solid var(--color-ink-200);
	text-decoration: none;
	color: var(--color-ink-900);
	transition: transform var(--dur-base) var(--ease-out),
				border-color var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out);
}
.c-service-grid__card:hover {
	transform: translateY(-2px);
	border-color: transparent;
	box-shadow: var(--shadow-hover);
	color: var(--color-ink-900);
}
.c-service-grid__card-icon {
	width: 48px; height: 48px;
	color: var(--color-brand-primary);
	background: var(--color-surface-tint);
	border-radius: var(--radius-m);
	display: inline-flex; align-items: center; justify-content: center;
	margin-block-end: var(--space-s);
}
.c-service-grid__card h3 {
	font-size: 1.25rem;
	margin-block-end: var(--space-2xs);
	color: var(--color-ink-900);
}
.c-service-grid__card p { color: var(--color-ink-700); }
.c-service-grid__card-link {
	margin-block-start: auto;
	padding-block-start: var(--space-s);
	color: var(--color-brand-primary);
	font-weight: var(--fw-button);
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
}


/* === c-quote-stack ================================================ */
.c-quote-stack__inner {
	display: grid;
	grid-template-columns: 38% 1fr;
	gap: var(--space-2xl);
	align-items: start;
}
@media (max-width: 819px) { .c-quote-stack__inner { grid-template-columns: 1fr; gap: var(--space-l); } }
.c-quote-stack__photo {
	border-radius: var(--radius-l);
	overflow: hidden;
	background: var(--color-paper);
	aspect-ratio: 1 / 1;
	box-shadow: var(--shadow-card);
}
.c-quote-stack__photo img { width: 100%; height: 100%; object-fit: cover; }
.c-quote-stack__quotes {
	padding-inline-start: 0;
}
.c-quote-stack__quotes blockquote {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.25rem;
	color: var(--color-ink-900);
	line-height: 1.5;
	border-left: 0;
	padding-left: 0;
	margin-block: 0;
}
.c-quote-stack__quotes blockquote::before {
	content: "“";
	font-size: 3rem;
	color: var(--color-brand-primary);
	line-height: 0;
	vertical-align: -0.4em;
	margin-inline-end: 0.1em;
	opacity: .35;
}
.c-quote-stack__quotes blockquote + blockquote {
	margin-block-start: var(--space-l);
	padding-block-start: var(--space-l);
	border-block-start: 1px solid var(--color-ink-200);
}


/* === c-step-process =============================================== */
.c-step-process__steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-l);
	position: relative;
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (max-width: 1023px) { .c-step-process__steps { grid-template-columns: 1fr; gap: var(--space-l); } }
.c-step-process__step {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
	position: relative;
}
.c-step-process__step:not(:last-child)::after {
	/* connector line — desktop only */
	content: "";
	position: absolute;
	left: 56px;
	top: 28px;
	right: calc(-1 * var(--space-l));
	height: 1px;
	background: linear-gradient(to right, var(--color-ink-300) 50%, transparent 50%);
	background-size: 12px 1px;
	z-index: 0;
}
@media (max-width: 1023px) { .c-step-process__step::after { display: none; } }
.c-step-process__number {
	width: 56px; height: 56px;
	border-radius: 50%;
	background: var(--color-paper);
	color: var(--color-brand-primary);
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: var(--fw-display);
	display: inline-flex;
	align-items: center; justify-content: center;
	margin-block-end: var(--space-xs);
	border: 2px solid var(--color-brand-primary);
	position: relative;
	z-index: 1;
}
.c-step-process__step h3 { font-size: 1.1875rem; margin-block-end: var(--space-2xs); color: var(--color-ink-900); }
.c-step-process__step p { color: var(--color-ink-700); }
.c-step-process__step a { font-weight: var(--fw-strong); display: inline-flex; align-items: center; gap: 0.25rem; margin-block-start: var(--space-2xs); }


/* === c-team-grid ================================================== */
.c-team-grid__people {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: var(--space-l);
}
@media (max-width: 1023px) { .c-team-grid__people { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 599px)  { .c-team-grid__people { grid-template-columns: repeat(2, 1fr); } }
.c-team-grid__person {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-2xs);
}
.c-team-grid__photo {
	width: 100%;
	max-width: 180px;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	overflow: hidden;
	background: var(--color-surface-tint);
	box-shadow: 0 2px 8px rgba(20, 23, 26, .06);
}
.c-team-grid__photo img { width: 100%; height: 100%; object-fit: cover; }
.c-team-grid__name { font-family: var(--font-display); font-size: 1.125rem; font-weight: var(--fw-display); margin-block-start: var(--space-xs); }
.c-team-grid__role { font-size: var(--fs-caption); color: var(--color-ink-500); }


/* === c-faq-accordion =============================================== */
.c-faq-accordion {
	max-width: 760px;
	margin-inline: auto;
	background: var(--color-paper);
	border-radius: var(--radius-l);
	border: 1px solid var(--color-ink-200);
	overflow: hidden;
}
.c-faq-accordion details {
	border-block-end: 1px solid var(--color-ink-200);
	padding: var(--space-m) var(--space-l);
}
.c-faq-accordion details:last-child { border-block-end: 0; }
.c-faq-accordion summary {
	font-family: var(--font-display);
	font-size: 1.1875rem;
	font-weight: var(--fw-display);
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-m);
	min-height: 48px;
	color: var(--color-ink-900);
}
.c-faq-accordion summary::-webkit-details-marker { display: none; }
.c-faq-accordion summary::after {
	content: "+";
	flex: 0 0 32px;
	width: 32px; height: 32px;
	display: inline-flex; align-items: center; justify-content: center;
	font-family: var(--font-body);
	font-size: 1.5rem;
	font-weight: var(--fw-body);
	color: var(--color-brand-primary);
	background: var(--color-surface-tint);
	border-radius: 50%;
	transition: transform var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out);
}
.c-faq-accordion details[open] summary::after {
	content: "−";
	background: var(--color-brand-primary-100);
}
.c-faq-accordion summary:hover { color: var(--color-brand-primary); }
.c-faq-accordion details > *:not(summary) {
	margin-block-start: var(--space-s);
	color: var(--color-ink-700);
}


/* === c-cta-band =================================================== */
.c-cta-band {
	background: var(--color-surface-deep);
	color: var(--color-paper);
	padding-block: var(--space-2xl);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.c-cta-band::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(60% 80% at 50% 100%, rgba(197, 18, 48, .25) 0%, rgba(197, 18, 48, 0) 60%);
	pointer-events: none;
}
.c-cta-band__inner {
	position: relative;
	max-width: 720px;
	margin-inline: auto;
}
.c-cta-band h2 {
	font-size: var(--fs-display-l);
	color: var(--color-paper);
	margin-block-end: var(--space-s);
}
.c-cta-band p {
	color: rgba(255, 255, 255, .8);
	margin-block-end: var(--space-l);
	font-size: var(--fs-body-l);
}
.c-cta-band__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-s);
	justify-content: center;
}
.c-cta-band .btn--ghost { background: transparent; color: var(--color-paper); border-color: rgba(255, 255, 255, .4); }
.c-cta-band .btn--ghost:hover { background: rgba(255, 255, 255, .1); color: var(--color-paper); border-color: var(--color-paper); }
.c-cta-band .btn--ghost .icon { color: var(--color-paper); }


/* === c-breadcrumb (modern beige chip trail) ========================== */
.c-breadcrumb {
	background: var(--color-surface-tint);
	border-block-end: 1px solid var(--color-ink-200);
	padding-block: 0.625rem;
	font-size: 0.9375rem;
	color: var(--color-ink-700);
}
.c-breadcrumb__trail {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
	list-style: none;
	padding: 0;
	margin: 0;
}
.c-breadcrumb__crumb {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	min-height: 32px;
}
.c-breadcrumb__crumb + .c-breadcrumb__crumb::before {
	content: "";
	width: 6px;
	height: 6px;
	border-top: 1.5px solid var(--color-ink-300);
	border-right: 1.5px solid var(--color-ink-300);
	transform: rotate(45deg);
	margin-inline: 0.1rem;
	flex: 0 0 auto;
}
.c-breadcrumb__crumb a {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.25rem 0.7rem;
	border-radius: var(--radius-pill);
	color: var(--color-ink-700);
	text-decoration: none;
	background: transparent;
	transition: background var(--dur-base), color var(--dur-base);
	min-height: 32px;
}
.c-breadcrumb__crumb a:hover {
	background: var(--color-paper);
	color: var(--color-brand-primary);
}
.c-breadcrumb__crumb a .icon { color: var(--color-brand-primary); flex: 0 0 auto; }
.c-breadcrumb__home-label {
	/* hide visually on small screens — icon alone is enough */
	display: none;
}
@media (min-width: 600px) {
	.c-breadcrumb__home-label { display: inline; }
}
.c-breadcrumb__crumb.is-current span {
	display: inline-flex;
	align-items: center;
	padding: 0.3rem 0.85rem;
	background: var(--color-paper);
	color: var(--color-ink-900);
	font-weight: var(--fw-strong);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-pill);
	box-shadow: 0 1px 3px rgba(20, 23, 26, .04);
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@media (max-width: 599px) {
	.c-breadcrumb__crumb.is-current span { max-width: 22ch; }
}


/* === c-footer ===================================================== */
.c-footer {
	background: var(--color-surface-deep);
	color: var(--color-paper);
	padding-block: var(--space-2xl) var(--space-l);
}
.c-footer a { color: rgba(255, 255, 255, .85); text-decoration: none; }
.c-footer a:hover { color: var(--color-paper); text-decoration: underline; text-underline-offset: 3px; }
.c-footer__cols {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1.2fr 1.2fr 1fr;
	gap: var(--space-xl);
	margin-block-end: var(--space-xl);
}
@media (max-width: 1199px) { .c-footer__cols { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-l); } .c-footer__cols .c-footer__col:nth-child(5) { grid-column: 1 / -1; } }
@media (max-width: 899px)  { .c-footer__cols { grid-template-columns: repeat(2, 1fr); } .c-footer__cols .c-footer__col:nth-child(5) { grid-column: auto; } }
@media (max-width: 599px)  { .c-footer__cols { grid-template-columns: 1fr; gap: var(--space-l); } .c-footer__cols .c-footer__col:nth-child(5) { grid-column: auto; } }
.c-footer__contact-quick { margin-block-start: var(--space-m); }
.c-footer__col h4 {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: var(--fw-strong);
	color: var(--color-paper);
	margin-block-end: var(--space-s);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	opacity: .7;
}
.c-footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2xs); }
.c-footer__col ul li {
	display: flex;
	align-items: center;
	gap: var(--space-2xs);
	padding-block: 0.25rem;
}
.c-footer__col ul li a {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
}
.c-footer__col ul li .icon { color: rgba(255, 255, 255, .85); flex: 0 0 auto; }
.c-footer__brand img {
	width: 140px; height: auto;
	background: var(--color-paper);
	padding: var(--space-s);
	border-radius: var(--radius-m);
}
.c-footer__brand p { margin-block-start: var(--space-m); font-size: 0.9375rem; color: rgba(255, 255, 255, .7); max-width: 36ch; line-height: 1.55; }
.c-footer__legal {
	border-block-start: 1px solid rgba(255, 255, 255, .12);
	padding-block-start: var(--space-l);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-m);
	align-items: center;
	justify-content: space-between;
	font-size: var(--fs-caption);
	color: rgba(255, 255, 255, .65);
}
.c-footer__legal-links { display: flex; flex-wrap: wrap; gap: var(--space-m); }


/* === c-warunki-table (value-prop table on /warunki-pracy/) =========== */
.c-warunki-table {
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: clamp(1.5rem, 3vw, 2.5rem);
	box-shadow: var(--shadow-card);
}
.c-warunki-table__head {
	margin-block-end: var(--space-l);
}
.c-warunki-table__head h2 {
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	margin: 0 0 var(--space-s);
}
.c-warunki-table__head p {
	color: var(--color-ink-700);
	max-width: 60ch;
	margin: 0;
}

.c-warunki-table__grid { display: contents; }

.c-warunki-table__rowhead,
.c-warunki-table__row {
	display: grid;
	grid-template-columns: minmax(180px, 25%) 1fr 1fr;
	gap: var(--space-m);
	padding-block: var(--space-m);
	align-items: start;
	border-block-end: 1px solid var(--color-ink-200);
}
.c-warunki-table__row:last-of-type { border-block-end: 0; }

.c-warunki-table__rowhead {
	border-block-end: 2px solid var(--color-ink-900);
	padding-block-end: var(--space-s);
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.c-warunki-table__topic-h { color: var(--color-ink-700); }
.c-warunki-table__us-h {
	color: var(--color-brand-primary);
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
}
.c-warunki-table__them-h {
	color: var(--color-ink-500);
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
}

.c-warunki-table__topic {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	font-size: 1rem;
}
.c-warunki-table__icon {
	width: 36px;
	height: 36px;
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--color-surface-tint);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-m);
	color: var(--color-brand-primary);
}
.c-warunki-table__us {
	color: var(--color-ink-900);
	font-size: 0.9375rem;
	line-height: 1.55;
	position: relative;
	padding-inline-start: var(--space-l);
}
.c-warunki-table__us::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--color-brand-primary);
	font-weight: var(--fw-strong);
	font-size: 1.125rem;
	line-height: 1.4;
}
.c-warunki-table__us strong {
	color: var(--color-brand-primary);
	font-weight: var(--fw-strong);
}
.c-warunki-table__them {
	color: var(--color-ink-500);
	font-size: 0.9375rem;
	line-height: 1.55;
	position: relative;
	padding-inline-start: var(--space-l);
}
.c-warunki-table__them::before {
	content: "×";
	position: absolute;
	left: 0;
	top: -0.05em;
	color: var(--color-ink-300);
	font-weight: var(--fw-strong);
	font-size: 1.5rem;
	line-height: 1;
}

.c-warunki-table__footer {
	margin-block-start: var(--space-l);
	padding-block-start: var(--space-l);
	border-block-start: 1px solid var(--color-ink-200);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-s);
}

@media (max-width: 819px) {
	.c-warunki-table__rowhead { display: none; }
	.c-warunki-table__row {
		grid-template-columns: 1fr;
		gap: var(--space-xs);
		padding-block: var(--space-l);
	}
	.c-warunki-table__topic { font-size: 1.0625rem; margin-block-end: var(--space-2xs); }
	.c-warunki-table__us,
	.c-warunki-table__them { padding-inline-start: var(--space-l); }
	.c-warunki-table__us::before { content: "✓ Z nami: "; font-size: 0.9375rem; color: var(--color-brand-primary); position: static; display: inline-block; margin-inline-end: 0.25em; padding-inline-start: 0; }
	.c-warunki-table__them::before { content: "× Bez agencji: "; font-size: 0.9375rem; color: var(--color-ink-500); position: static; display: inline-block; margin-inline-end: 0.25em; padding-inline-start: 0; }
	.c-warunki-table__us, .c-warunki-table__them { padding-inline-start: 0; }
}


/* === c-warunki-cards (legacy two-card compare — still used on the
   "Two contract options" section if needed) ========================== */
.c-warunki-cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-l);
}
@media (max-width: 819px) { .c-warunki-cards { grid-template-columns: 1fr; } }
.c-warunki-card {
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: clamp(1.5rem, 3vw, 2.25rem);
}
.c-warunki-card__head {
	display: flex;
	align-items: center;
	gap: var(--space-m);
	padding-block-end: var(--space-m);
	margin-block-end: var(--space-m);
	border-block-end: 1px solid var(--color-ink-200);
}
.c-warunki-card__head > div { min-width: 0; }
.c-warunki-card__flag {
	flex: 0 0 56px;
	width: 56px;
	height: 36px;
	border-radius: var(--radius-s);
	box-shadow: 0 1px 3px rgba(20, 23, 26, .08);
	display: block;
}
.c-warunki-card__country {
	display: block;
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-brand-primary);
	margin-block-end: 0.125rem;
}
.c-warunki-card h3 {
	margin: 0;
	font-size: 1.375rem;
	line-height: 1.25;
	color: var(--color-ink-900);
}
.c-warunki-card__lede {
	color: var(--color-ink-700);
	font-size: 1rem;
	line-height: 1.55;
	margin: 0 0 var(--space-l);
}
.c-warunki-card__features {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
}
.c-warunki-card__feature {
	display: grid;
	grid-template-columns: 44px 1fr;
	gap: var(--space-s);
	align-items: start;
}
.c-warunki-card__feature-icon {
	width: 44px;
	height: 44px;
	border-radius: var(--radius-m);
	background: var(--color-surface-tint);
	border: 1px solid var(--color-ink-200);
	color: var(--color-brand-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 44px;
}
.c-warunki-card__feature h4 {
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	margin: 0 0 0.125rem;
	line-height: 1.35;
}
.c-warunki-card__feature p {
	font-size: 0.9375rem;
	color: var(--color-ink-700);
	margin: 0;
	line-height: 1.5;
}
.c-warunki-card__note {
	margin-block-start: var(--space-l);
	padding: var(--space-s) var(--space-m);
	background: var(--color-surface-tint);
	border-radius: var(--radius-m);
	font-size: 0.9375rem;
	color: var(--color-ink-700);
}
.c-warunki-card__note strong { color: var(--color-ink-900); }


/* === c-bonus-popup (150 € NETTO retention) =========================== */
.c-bonus-popup {
	position: fixed;
	bottom: var(--space-m);
	right: var(--space-m);
	left: var(--space-m);
	max-width: 380px;
	margin-inline: auto;
	background: var(--color-paper);
	border-radius: var(--radius-l);
	padding: var(--space-m);
	box-shadow: 0 12px 40px rgba(20, 23, 26, .15);
	border: 1px solid var(--color-ink-200);
	z-index: 70;
	display: none;
	gap: var(--space-s);
	align-items: center;
}
@media (min-width: 768px) { .c-bonus-popup { left: auto; } }
.c-bonus-popup[data-show="true"] { display: flex; animation: bonusFade 400ms var(--ease-out); }
@keyframes bonusFade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.c-bonus-popup__img { width: 56px; height: auto; flex: 0 0 auto; border-radius: var(--radius-m); }
.c-bonus-popup__body { flex: 1; font-size: 0.9375rem; line-height: 1.45; color: var(--color-ink-700); }
.c-bonus-popup__body strong { color: var(--color-brand-secondary-700); font-size: 1.125rem; display: block; font-family: var(--font-display); font-weight: var(--fw-display); }
.c-bonus-popup__body a { font-weight: var(--fw-strong); color: var(--color-brand-primary); display: inline-block; margin-top: 0.25rem; }
.c-bonus-popup__close {
	width: 32px; height: 32px;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--color-ink-500);
	border-radius: var(--radius-s);
}
.c-bonus-popup__close:hover { background: var(--color-ink-100); color: var(--color-ink-900); }


/* === c-bios (team biographies on /o-nas/) =========================== */
.c-bios {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
	max-width: 1040px;
	margin-inline: auto;
}
.c-bio {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}
.c-bio--flip { grid-template-columns: 1fr 280px; }
.c-bio--flip .c-bio__photo { order: 2; }

.c-bio__photo {
	margin: 0;
	border-radius: var(--radius-l);
	overflow: hidden;
	background: var(--color-paper);
	aspect-ratio: 1 / 1;
	box-shadow: var(--shadow-card);
}
.c-bio__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.c-bio__body { min-width: 0; }
.c-bio__role {
	display: inline-block;
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-brand-primary);
	margin-block-end: var(--space-2xs);
}
.c-bio__name {
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	letter-spacing: -0.01em;
	color: var(--color-ink-900);
	margin: 0 0 var(--space-m);
	line-height: 1.2;
}
.c-bio__text {
	color: var(--color-ink-700);
	font-size: 1.0625rem;
	line-height: 1.65;
}
.c-bio__text p { margin: 0; }
.c-bio__text p + p { margin-block-start: var(--space-s); }

@media (max-width: 819px) {
	.c-bio,
	.c-bio--flip {
		grid-template-columns: 200px 1fr;
		gap: var(--space-l);
	}
	.c-bio--flip .c-bio__photo { order: 0; } /* keep consistent on tablet */
}
@media (max-width: 599px) {
	.c-bio,
	.c-bio--flip {
		grid-template-columns: 1fr;
		text-align: left;
	}
	.c-bio__photo {
		max-width: 220px;
		margin-inline: 0;
	}
}


/* === c-office-card (used on /o-nas/ — Jelenia Góra office block) ===== */
.c-office-card {
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.c-office-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-2px); }
.c-office-card__photo { aspect-ratio: 16 / 11; overflow: hidden; }
.c-office-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.c-office-card__body { padding: var(--space-l); }
.c-office-card__body h3 { margin-block-end: var(--space-xs); }
.c-office-card__address {
	font-style: normal;
	color: var(--color-ink-700);
	line-height: 1.5;
}
.c-office-card__contact {
	margin-block-start: var(--space-m);
	padding-block-start: var(--space-m);
	border-block-start: 1px solid var(--color-ink-200);
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}
.c-office-card__contact a { color: var(--color-ink-900); text-decoration: none; font-weight: var(--fw-strong); display: inline-flex; align-items: center; gap: 0.25rem; }
.c-office-card__contact a:hover { color: var(--color-brand-primary); }
.c-office-card__contact .icon { color: var(--color-brand-primary); }


/* === c-form (hand-rolled apply / contact) ============================ */
.c-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
	max-width: 560px;
}
.c-form--apply { gap: var(--space-m); max-width: none; }

.c-form__field { display: flex; flex-direction: column; gap: 0.5rem; }
.c-form__field label {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	font-size: 1rem;
	line-height: 1.3;
}
.c-form__field .req { color: var(--color-brand-primary); margin-inline-start: 0.2em; }
.c-form__field .req-tag,
.c-form__field .opt-tag {
	display: inline-flex;
	align-items: center;
	font-size: 0.6875rem;
	font-weight: var(--fw-button);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.15rem 0.5rem;
	border-radius: var(--radius-pill);
}
.c-form__field .req-tag {
	background: rgba(197, 18, 48, .1);
	color: var(--color-brand-primary);
}
.c-form__field .opt-tag {
	background: var(--color-ink-100);
	color: var(--color-ink-500);
}
.c-form__field .req-word { font-size: var(--fs-caption); color: var(--color-ink-500); font-weight: var(--fw-body); margin-inline-start: 0.25em; }

/* Two-column row */
.c-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-s) var(--space-m);
}
@media (max-width: 599px) {
	.c-form__row { grid-template-columns: 1fr; }
}

/* Input wrap (used when an icon is present) */
.c-form__input-wrap { position: relative; display: block; }

/* Inputs / selects / textareas */
.c-form__field input,
.c-form__field select,
.c-form__field textarea {
	width: 100%;
	min-height: 56px;
	padding: 1rem 1.125rem;
	border: 1.5px solid var(--color-ink-300);
	border-radius: var(--radius-m);
	background: var(--color-paper);
	font-size: 1.0625rem;
	font-family: var(--font-body);
	color: var(--color-ink-900);
	line-height: 1.3;
	transition: border-color var(--dur-base), box-shadow var(--dur-base), background var(--dur-base);
	-webkit-appearance: none;
	appearance: none;
}
.c-form__field textarea { min-height: 132px; resize: vertical; line-height: 1.5; }
.c-form__field input::placeholder,
.c-form__field textarea::placeholder { color: var(--color-ink-500); opacity: 0.85; }
.c-form__field input:hover,
.c-form__field select:hover,
.c-form__field textarea:hover { border-color: var(--color-ink-500); }
.c-form__field input:focus,
.c-form__field select:focus,
.c-form__field textarea:focus {
	border-color: var(--color-brand-primary);
	outline: none;
	box-shadow: 0 0 0 4px rgba(197, 18, 48, .14);
}

/* Custom select chevron (form context) */
.c-form__field select {
	padding-inline-end: 2.75rem;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C51230' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 1.125rem center;
	cursor: pointer;
}

/* Field icon */
.c-form__field--icon .c-form__icon {
	position: absolute;
	left: 1.125rem;
	top: 50%;
	transform: translateY(-50%);
	color: var(--color-ink-500);
	pointer-events: none;
	z-index: 1;
	transition: color var(--dur-base);
}
.c-form__field--icon input,
.c-form__field--icon select {
	padding-inline-start: 3rem;
}
.c-form__field--icon:focus-within .c-form__icon { color: var(--color-brand-primary); }

/* Help / error */
.c-form__field .help {
	font-size: var(--fs-caption);
	color: var(--color-ink-500);
}
.c-form__field .err {
	font-size: var(--fs-caption);
	color: var(--color-danger);
	font-weight: var(--fw-strong);
	display: none;
}
.c-form__field[aria-invalid="true"] input,
.c-form__field[aria-invalid="true"] textarea,
.c-form__field[aria-invalid="true"] select {
	border-color: var(--color-danger);
	box-shadow: 0 0 0 4px rgba(178, 58, 58, .12);
}
.c-form__field[aria-invalid="true"] .err { display: block; }

/* Consent — custom checkbox */
.c-form__consent {
	display: flex;
	gap: var(--space-s);
	align-items: flex-start;
	font-size: 0.9375rem;
	color: var(--color-ink-700);
	line-height: 1.5;
}
.c-form__consent--custom {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.875rem;
	cursor: pointer;
	padding: var(--space-m) var(--space-l);
	background: var(--color-surface-tint);
	border: 1.5px solid var(--color-ink-200);
	border-radius: var(--radius-m);
	transition: border-color var(--dur-base), background var(--dur-base);
	position: relative;
}
.c-form__consent--custom:hover { border-color: var(--color-ink-500); }
.c-form__consent--custom:has(input:checked) {
	border-color: var(--color-brand-primary);
	background: rgba(197, 18, 48, .04);
}
.c-form__consent--custom input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
	width: 0;
	height: 0;
}
.c-form__consent--custom .c-form__check {
	width: 24px;
	height: 24px;
	background: var(--color-paper);
	border: 1.5px solid var(--color-ink-300);
	border-radius: 6px;
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background var(--dur-base), border-color var(--dur-base);
	margin-top: 1px;
}
.c-form__consent--custom input:checked + .c-form__check {
	background: var(--color-brand-primary);
	border-color: var(--color-brand-primary);
}
.c-form__consent--custom input:checked + .c-form__check::after {
	content: "";
	width: 6px;
	height: 11px;
	border: solid #fff;
	border-width: 0 2.5px 2.5px 0;
	transform: rotate(45deg) translate(-1px, -1px);
}
.c-form__consent--custom input:focus-visible + .c-form__check {
	box-shadow: 0 0 0 4px rgba(197, 18, 48, .25);
}
.c-form__consent-text {
	font-size: 0.9375rem;
	color: var(--color-ink-700);
	line-height: 1.5;
}
.c-form__consent-text a {
	color: var(--color-brand-primary);
	font-weight: var(--fw-strong);
}

/* Submit */
.c-form__submit {
	width: 100%;
	margin-block-start: var(--space-s);
	padding-block: 1.125rem;
	font-size: 1.125rem;
	font-weight: var(--fw-button);
	letter-spacing: 0.01em;
	border-radius: var(--radius-pill);
	box-shadow: 0 4px 14px rgba(197, 18, 48, .25);
	transition: transform var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out),
				background var(--dur-base) var(--ease-out);
}
.c-form__submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 22px rgba(197, 18, 48, .35);
}
.c-form__submit:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(197, 18, 48, .25); }
.c-form__submit[disabled] { opacity: 0.7; cursor: progress; transform: none; }

/* Phone fallback below submit */
.c-form__phone-fallback {
	margin: 0;
	padding-top: 0.25rem;
	text-align: center;
	font-size: 0.9375rem;
	color: var(--color-ink-500);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	flex-wrap: wrap;
	width: 100%;
}
.c-form__phone-fallback a {
	color: var(--color-brand-primary);
	font-weight: var(--fw-strong);
	text-decoration: none;
}
.c-form__phone-fallback a:hover { text-decoration: underline; text-underline-offset: 3px; }
.c-form__phone-fallback .icon { color: var(--color-brand-primary); }

/* Notice */
.c-form__notice {
	padding: var(--space-m) var(--space-l);
	border-radius: var(--radius-m);
	background: var(--color-surface-tint);
	border: 1.5px solid var(--color-brand-primary);
	color: var(--color-ink-900);
	font-weight: var(--fw-strong);
	font-size: 1rem;
}
.c-form__notice--error {
	background: #FBE9E9;
	color: var(--color-danger);
	border-color: var(--color-danger);
}

/* Offer pin */
.c-form__offer-pin {
	background: var(--color-surface-tint);
	border: 1px solid var(--color-ink-200);
	border-left: 4px solid var(--color-brand-primary);
	border-radius: var(--radius-m);
	padding: var(--space-s) var(--space-m);
	font-size: 0.9375rem;
}


/* === c-job-list (offer archive / city pages) ========================= */
.c-job-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-l);
}
@media (max-width: 599px) { .c-job-list { grid-template-columns: 1fr; } }


/* === c-offers-filter ================================================= */
.c-offers-filter {
	background: var(--color-surface-tint);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: var(--space-l);
	box-shadow: 0 1px 3px rgba(20, 23, 26, .04);
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
}
.c-offers-filter__row {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--space-m);
}
.c-offers-filter__row--actions {
	grid-template-columns: 1fr auto auto;
	align-items: end;
	border-block-start: 1px solid var(--color-ink-200);
	padding-block-start: var(--space-m);
}
@media (max-width: 1023px) {
	.c-offers-filter__row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.c-offers-filter__row--actions { grid-template-columns: 1fr; }
}
@media (max-width: 599px) {
	.c-offers-filter__row { grid-template-columns: 1fr; }
}
.c-offers-filter__field { display: flex; flex-direction: column; gap: 0.375rem; }
.c-offers-filter__field--wide   { grid-column: span 2; }
.c-offers-filter__field--radius { grid-column: span 2; }
@media (max-width: 599px) {
	.c-offers-filter__field--wide,
	.c-offers-filter__field--radius { grid-column: auto; }
}
.c-offers-filter__field label {
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	color: var(--color-ink-700);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.c-offers-filter__field input[type="text"],
.c-offers-filter__field select {
	min-height: 52px;
	padding: 0.75rem 1rem;
	border: 1.5px solid var(--color-ink-300);
	border-radius: var(--radius-m);
	background: var(--color-paper);
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	line-height: 1.2;
	transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.c-offers-filter__field select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C51230' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-inline-end: 2.75rem;
	cursor: pointer;
}
.c-offers-filter__field input[type="text"]:hover,
.c-offers-filter__field select:hover {
	border-color: var(--color-ink-500);
}
.c-offers-filter__field input[type="text"]:focus,
.c-offers-filter__field select:focus {
	border-color: var(--color-brand-primary);
	outline: none;
	box-shadow: var(--shadow-focus);
}
.c-offers-filter__hint { font-size: var(--fs-caption); color: var(--color-ink-500); }
.c-offers-filter__hint--err { color: var(--color-danger); }

.c-offers-filter__radii {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-300);
	border-radius: var(--radius-pill);
	padding: 4px;
	width: 100%;
}
.c-offers-filter__radius {
	cursor: pointer;
	flex: 1 1 auto;
	display: flex;
}
.c-offers-filter__radius span { width: 100%; }
.c-offers-filter__radius input { position: absolute; opacity: 0; pointer-events: none; }
.c-offers-filter__radius span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 0.4rem 0.85rem;
	border-radius: var(--radius-pill);
	background: transparent;
	color: var(--color-ink-700);
	font-size: 0.9375rem;
	font-weight: var(--fw-strong);
	white-space: nowrap;
	transition: background var(--dur-base), color var(--dur-base);
}
.c-offers-filter__radius:hover span { background: var(--color-surface-tint); color: var(--color-brand-primary); }
.c-offers-filter__radius input:checked + span {
	background: var(--color-brand-primary);
	color: var(--color-paper);
}
.c-offers-filter__radius input:focus-visible + span { box-shadow: var(--shadow-focus); }

.c-offers-filter__check { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.9375rem; }
.c-offers-filter__check input { transform: scale(1.2); accent-color: var(--color-brand-primary); }

.c-offers-filter__sort { display: flex; align-items: center; gap: 0.5rem; }
.c-offers-filter__sort label { font-size: 0.9375rem; color: var(--color-ink-700); font-weight: var(--fw-strong); }
.c-offers-filter__sort select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	min-height: 48px;
	padding: 0.6rem 2.5rem 0.6rem 0.875rem;
	border: 1.5px solid var(--color-ink-300);
	border-radius: var(--radius-m);
	background: var(--color-paper);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C51230' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 0.875rem center;
	font-size: 0.9375rem;
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	cursor: pointer;
}
.c-offers-filter__sort select:focus {
	border-color: var(--color-brand-primary);
	outline: none;
	box-shadow: var(--shadow-focus);
}
.c-offers-filter__buttons { display: flex; gap: var(--space-s); justify-content: end; }
.c-offers-filter__buttons .btn { min-height: 44px; padding-inline: var(--space-m); }
@media (max-width: 1023px) {
	.c-offers-filter__buttons { justify-content: stretch; }
	.c-offers-filter__buttons .btn { flex: 1 1 0; }
}

.c-offers-count {
	margin-block-start: var(--space-l);
	margin-block-end: var(--space-m);
	color: var(--color-ink-700);
	font-size: 1rem;
	transition: opacity var(--dur-base);
}
.c-offers-count strong { color: var(--color-ink-900); }

#dop-offers-result {
	transition: opacity var(--dur-base) var(--ease-out);
	outline: none;
}
#dop-offers-result.is-loading {
	opacity: 0.55;
	pointer-events: none;
}


/* === c-home-seo (long-form SEO section on the homepage) ============== */
.c-home-seo__head {
	max-width: 760px;
	margin-inline: auto;
	margin-block-end: var(--space-xl);
	text-align: center;
}
.c-home-seo__head h2 {
	font-size: clamp(1.75rem, 3.2vw, 2.5rem);
	letter-spacing: -0.02em;
	margin-block-end: var(--space-s);
}
.c-home-seo__head .lede {
	color: var(--color-ink-700);
	margin-inline: auto;
	max-width: 56ch;
	margin-block-end: var(--space-l);
}

/* TOC — chip-style anchors, wraps naturally. */
.c-home-seo__toc {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.4rem;
	max-width: 720px;
	margin-inline: auto;
}
.c-home-seo__toc a {
	display: inline-flex;
	align-items: center;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	color: var(--color-ink-700);
	font-size: 0.8125rem;
	font-weight: var(--fw-strong);
	padding: 0.4rem 0.75rem;
	border-radius: var(--radius-pill);
	text-decoration: none;
	transition: background var(--dur-base), border-color var(--dur-base), color var(--dur-base);
	text-align: left;
	line-height: 1.3;
}
.c-home-seo__toc a:hover {
	background: var(--color-brand-primary);
	border-color: var(--color-brand-primary);
	color: var(--color-paper);
}

/* Body — two-column on desktop so the wall of text doesn't feel endless. */
.c-home-seo__body {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-xl) var(--space-2xl);
	max-width: 1080px;
	margin-inline: auto;
}
@media (max-width: 819px) {
	.c-home-seo__body { grid-template-columns: 1fr; gap: var(--space-l); }
}

.c-home-seo__section {
	scroll-margin-top: calc(var(--header-height) + 1rem);
	padding-block-start: var(--space-m);
	border-block-start: 1px solid var(--color-ink-200);
}
.c-home-seo__section:first-child,
.c-home-seo__section:nth-child(2) {
	padding-block-start: 0;
	border-block-start: 0;
}
@media (max-width: 819px) {
	.c-home-seo__section:nth-child(2) {
		padding-block-start: var(--space-m);
		border-block-start: 1px solid var(--color-ink-200);
	}
}

.c-home-seo__h {
	font-family: var(--font-display);
	font-style: italic;
	font-weight: 600;
	font-size: clamp(1.25rem, 2.2vw, 1.5rem);
	letter-spacing: -0.005em;
	color: var(--color-brand-primary);
	margin: 0 0 var(--space-s);
	line-height: 1.3;
}

.c-home-seo__prose p {
	font-size: 1.0625rem;
	line-height: 1.7;
	color: var(--color-ink-700);
	margin: 0 0 var(--space-s);
}
.c-home-seo__prose p:last-child { margin-block-end: 0; }
.c-home-seo__prose strong {
	color: var(--color-ink-900);
	font-weight: var(--fw-strong);
}
.c-home-seo__prose a {
	color: var(--color-brand-primary);
	font-weight: var(--fw-strong);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}
.c-home-seo__prose a:hover {
	text-decoration-thickness: 2px;
}


/* === c-tldr (Najważniejsze w skrócie) ================================ */
.c-tldr {
	background: var(--color-surface-tint);
	border-radius: var(--radius-l);
	padding: var(--space-l);
	border-left: 4px solid var(--color-brand-primary);
}
.c-tldr h2 { font-size: 1.25rem; margin-block-end: var(--space-s); }
.c-tldr ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-xs); }
.c-tldr li { display: flex; gap: var(--space-s); align-items: flex-start; line-height: 1.55; }
.c-tldr li::before { content: "→"; color: var(--color-brand-primary); font-weight: var(--fw-strong); flex: 0 0 auto; }
.c-tldr li strong { color: var(--color-ink-900); font-weight: var(--fw-strong); }


/* === c-key-facts (definition list — AI-extractable) =================== */
.c-key-facts { background: var(--color-paper); border: 1px solid var(--color-ink-200); border-radius: var(--radius-l); padding: var(--space-l); }
.c-key-facts__title { font-size: 1.25rem; margin-block-end: var(--space-m); }
.c-key-facts__list { display: grid; gap: var(--space-s); margin: 0; }
.c-key-facts__row {
	display: grid;
	grid-template-columns: minmax(140px, 30%) 1fr;
	gap: var(--space-m);
	padding-block: var(--space-s);
	border-block-end: 1px solid var(--color-ink-200);
	align-items: baseline;
}
.c-key-facts__row:last-child { border-block-end: 0; padding-block-end: 0; }
.c-key-facts dt { font-weight: var(--fw-strong); color: var(--color-ink-700); margin: 0; font-size: 0.9375rem; text-transform: uppercase; letter-spacing: 0.05em; }
.c-key-facts dd { margin: 0; color: var(--color-ink-900); font-size: var(--fs-body-m); }
@media (max-width: 599px) {
	.c-key-facts__row { grid-template-columns: 1fr; gap: var(--space-2xs); }
}


/* === c-page-hero (smaller hero for pillar pages) ===================== */
.c-page-hero {
	background: var(--color-surface-tint);
	padding-block: clamp(2.5rem, 6vw, 4rem);
	border-block-end: 1px solid var(--color-ink-200);
}
.c-page-hero__inner { max-width: 760px; }
.c-page-hero h1 { margin-block-end: var(--space-m); letter-spacing: -0.02em; }
.c-page-hero .lede { color: var(--color-ink-700); }
.c-page-hero .section__eyebrow { margin-block-end: var(--space-2xs); }
.c-page-hero__salary {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: clamp(1.375rem, 2.2vw, 1.75rem);
	color: var(--color-brand-primary);
	font-weight: var(--fw-strong);
	font-family: var(--font-display);
	margin: var(--space-m) 0 0;
}
.c-page-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-s);
	margin-block-start: var(--space-l);
}
.c-page-hero--image .c-page-hero__salary {
	color: var(--color-brand-secondary);
	text-shadow: 0 1px 12px rgba(0, 0, 0, .4);
}


/* === c-page-hero--image (full-bleed image hero — used on /oferty-pracy/,
   /dla-opiekunek/, /poradnik-opiekunki/) =====
   Left-aligned text over a left-strong horizontal scrim that fades into the
   image on the right. Bolder text-shadows + capped widths keep the H1/lede
   inside the darker zone so they read crisply even on bright photos. */
.c-page-hero--image {
	position: relative;
	isolation: isolate;
	background: var(--color-ink-900);
	background-image: var(--hero-image);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: clamp(520px, 72vh, 680px);
	padding-block: clamp(3.5rem, 7vw, 6rem);
	border-block-end: 0;
	color: var(--color-paper);
	display: flex;
	align-items: center;
	text-align: left;
}
.c-page-hero--image::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(
			90deg,
			rgba(20, 23, 26, .78) 0%,
			rgba(20, 23, 26, .55) 35%,
			rgba(20, 23, 26, .15) 70%,
			rgba(20, 23, 26, 0) 100%
		),
		linear-gradient(
			180deg,
			rgba(20, 23, 26, 0) 65%,
			rgba(20, 23, 26, .3) 100%
		);
	pointer-events: none;
}
.c-page-hero--image .c-page-hero__inner {
	max-width: 920px;
	width: 100%;
	text-align: left;
}
.c-page-hero--image .section__eyebrow {
	display: inline-flex;
	align-items: center;
	padding: 0.4rem 0.875rem;
	background: rgba(255, 255, 255, .14);
	border: 1px solid rgba(255, 255, 255, .35);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-radius: var(--radius-pill);
	font-size: var(--fs-caption);
	font-weight: var(--fw-strong);
	letter-spacing: 0.05em;
	color: var(--color-paper);
	margin-block-end: var(--space-m);
	text-transform: uppercase;
}
.c-page-hero--image h1 {
	font-size: clamp(2.5rem, 6vw, 4.25rem);
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: var(--color-paper);
	text-shadow:
		0 2px 24px rgba(0, 0, 0, .5),
		0 1px 4px rgba(0, 0, 0, .35);
	margin: 0 0 var(--space-l);
	max-width: 18ch;
}
.c-page-hero--image .lede {
	color: var(--color-paper);
	max-width: 50ch;
	margin: 0;
	font-size: clamp(1.125rem, 1.6vw, 1.375rem);
	line-height: 1.55;
	text-shadow:
		0 1px 14px rgba(0, 0, 0, .5),
		0 1px 4px rgba(0, 0, 0, .35);
}
.c-page-hero--image .c-page-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-s);
	margin-block-start: var(--space-l);
}

/* Meta strip overlaid on an image hero (used by pillar pages with a hero image
   like /jak-to-dziala/). Frosted-white pill with backdrop blur, ink text,
   brand-red icons. Sits directly under the lede so the article still
   announces read time + chapters. */
.c-pillar__meta.c-pillar__meta--on-image {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0;
	margin: var(--space-l) 0 0;
	padding: 0.5rem 1rem;
	background: rgba(255, 255, 255, .85);
	border: 1px solid rgba(255, 255, 255, .6);
	backdrop-filter: blur(10px) saturate(140%);
	-webkit-backdrop-filter: blur(10px) saturate(140%);
	border-radius: var(--radius-pill);
	color: var(--color-ink-900);
	font-size: 0.8125rem;
	font-weight: var(--fw-strong);
	letter-spacing: 0.02em;
	list-style: none;
	box-shadow: 0 6px 20px rgba(0, 0, 0, .18);
}
.c-pillar__meta.c-pillar__meta--on-image li {
	display: inline-flex;
	align-items: center;
	gap: 0.4375rem;
	padding-inline: 0.625rem;
	color: var(--color-ink-900);
}
.c-pillar__meta.c-pillar__meta--on-image li + li {
	border-inline-start: 1px solid rgba(20, 23, 26, .12);
}
.c-pillar__meta.c-pillar__meta--on-image .icon {
	color: var(--color-brand-primary);
	opacity: 1;
}

/* When the pillar has an image hero, drop the editorial card's top padding
   so the body content sits closer under the hero. */
.c-pillar--has-image .c-pillar__facts { padding-block-start: var(--space-2xl); }
.c-page-hero__stats {
	margin-block-start: var(--space-xl);
	padding-block-start: var(--space-l);
	border-block-start: 1px solid rgba(255, 255, 255, .25);
	display: flex;
	flex-wrap: nowrap;
	align-items: baseline;
	gap: clamp(1.5rem, 4vw, 3rem);
}
.c-page-hero__stats > div {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	flex: 0 1 auto;
	min-width: 0;
}
.c-page-hero__stats strong {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.8vw, 2.25rem);
	font-weight: var(--fw-display);
	line-height: 1;
	color: var(--color-paper);
	letter-spacing: -0.015em;
	white-space: nowrap;
}
.c-page-hero__stats span {
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, .85);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	white-space: nowrap;
}

@media (max-width: 819px) {
	.c-page-hero--image {
		align-items: flex-end;
		min-height: 70vh;
	}
	.c-page-hero--image::before {
		background:
			linear-gradient(180deg, rgba(20, 23, 26, .25) 0%, rgba(20, 23, 26, .55) 50%, rgba(20, 23, 26, .85) 100%);
	}
	.c-page-hero--image h1 { max-width: none; }
	.c-page-hero__stats {
		flex-wrap: wrap;
		gap: var(--space-m);
	}
	.c-page-hero__stats strong { font-size: 1.5rem; }
}


/* === c-offer-intro / c-offer-related / c-offer-hashtags ============== */
.c-offer-intro {
	font-size: 1.0625rem;
	line-height: 1.55;
	color: var(--color-ink-700);
	border-left: 4px solid var(--color-brand-primary);
	padding-inline-start: var(--space-m);
	margin-block: 0 var(--space-l);
}
.c-offer-intro strong { color: var(--color-ink-900); font-weight: var(--fw-strong); }

.c-offer-related {
	background: var(--color-surface-tint);
	border-radius: var(--radius-l);
	border: 1px solid var(--color-ink-200);
	padding: var(--space-m) var(--space-l);
	margin-block-start: var(--space-m);
}
.c-offer-related h2 {
	font-size: clamp(1.625rem, 2.4vw, 2rem);
	font-weight: 600;
	font-style: italic;
	letter-spacing: -0.01em;
	color: var(--color-brand-primary);
	margin: 0 0 var(--space-s);
}
.c-offer-related ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2xs); }
.c-offer-related li { padding-inline-start: 1.25em; position: relative; }
.c-offer-related li::before { content: "→"; position: absolute; left: 0; color: var(--color-brand-primary); font-weight: var(--fw-strong); }
.c-offer-related a { color: var(--color-ink-900); text-decoration: none; font-weight: var(--fw-strong); }
.c-offer-related a:hover { color: var(--color-brand-primary); text-decoration: underline; text-underline-offset: 3px; }

.c-offer-hashtags {
	margin-block-start: var(--space-xl);
	padding-block-start: var(--space-m);
	border-block-start: 1px dashed var(--color-ink-300);
	font-size: 0.9375rem;
	color: var(--color-ink-500);
	word-break: break-word;
}
.c-offer-hashtags span {
	display: inline-block;
	margin-inline-end: 0.25rem;
}


/* === c-offer-detail-hero (contained banner on /oferta/.../{id}/) ====== */
.c-offer-detail-hero {
	margin: 0;
}
.c-offer-detail-hero__media {
	position: relative;
	aspect-ratio: 21 / 9;
	min-height: 320px;
	max-height: 520px;
	background-color: var(--color-ink-900);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	border-radius: var(--radius-l);
	overflow: hidden;
	color: var(--color-paper);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: var(--space-m) var(--space-l);
	box-shadow: var(--shadow-card);
}
.c-offer-detail-hero__media::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, .55) 100%);
	pointer-events: none;
}
.c-offer-detail-hero__media > * { position: relative; z-index: 1; }
.c-offer-detail-hero__top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--space-2xs);
}
.c-offer-detail-hero__overlay {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
}
/* Title pill stays the offer-card style but slightly larger for detail-page weight. */
.c-offer-detail-hero__title {
	font-size: clamp(1.25rem, 2.4vw, 1.5rem);
	padding: 0.6rem 1rem;
	max-width: 100%;
}

/* Strip below the image — salary on the left, CTAs on the right. */
.c-offer-detail-hero__strip {
	margin-block-start: var(--space-m);
	padding: var(--space-m) var(--space-l);
	background: var(--color-surface-tint);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	display: flex;
	gap: var(--space-m);
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}
.c-offer-detail-hero__salary {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.6vw, 1.875rem);
	font-weight: var(--fw-display);
	color: var(--color-brand-primary);
	letter-spacing: -0.015em;
}
.c-offer-detail-hero__salary .icon { color: var(--color-brand-primary); }
.c-offer-detail-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-s);
}

@media (max-width: 599px) {
	.c-offer-detail-hero__media {
		aspect-ratio: 4 / 5;
		max-height: 460px;
		padding: var(--space-s) var(--space-m);
	}
	.c-offer-detail-hero__strip { padding: var(--space-m); }
	.c-offer-detail-hero__cta .btn { flex: 1 1 0; }
}


/* === c-aplikuj-banner (contained image above the apply form) ========== */
.c-aplikuj-banner {
	margin: 0 0 var(--space-l);
	border-radius: var(--radius-l);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	aspect-ratio: 12 / 5;
	background: var(--color-surface-tint);
}
.c-aplikuj-banner img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 40%;
	display: block;
}
@media (max-width: 599px) {
	.c-aplikuj-banner { aspect-ratio: 16 / 9; }
}


/* === c-aplikuj-grid (form + sidebar on /aplikuj/) ===================== */
.c-aplikuj-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.5fr) minmax(280px, 1fr);
	gap: clamp(1.5rem, 3vw, 2.5rem);
	align-items: start;
}
@media (max-width: 819px) {
	.c-aplikuj-grid { grid-template-columns: 1fr; }
}
.c-aplikuj-form-card {
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: clamp(1.5rem, 3vw, 2.25rem);
	box-shadow: var(--shadow-card);
}
.c-aplikuj-form-card__head { margin-block-end: var(--space-l); padding-block-end: var(--space-m); border-block-end: 1px solid var(--color-ink-200); }
.c-aplikuj-form-card__head h2 { margin: 0 0 var(--space-2xs); font-size: 1.5rem; }
.c-aplikuj-form-card__head p { margin: 0; color: var(--color-ink-700); font-size: 1rem; }
.c-aplikuj-form-card .c-form { max-width: none; }

/* Sidebar */
.c-aplikuj-grid__side {
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
	position: sticky;
	top: calc(var(--header-height) + var(--space-m));
}
@media (max-width: 819px) { .c-aplikuj-grid__side { position: static; } }

.c-aplikuj-side__panel {
	background: var(--color-surface-tint);
	border-radius: var(--radius-l);
	padding: var(--space-l);
	border: 1px solid var(--color-ink-200);
}
.c-aplikuj-side__panel h2 {
	font-size: 1.25rem;
	margin: var(--space-2xs) 0 var(--space-m);
	letter-spacing: -0.01em;
}

.c-aplikuj-steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
}
.c-aplikuj-steps li {
	display: grid;
	grid-template-columns: 36px 1fr;
	gap: var(--space-s);
	align-items: start;
}
.c-aplikuj-steps__num {
	width: 36px;
	height: 36px;
	flex: 0 0 auto;
	background: var(--color-paper);
	border: 1.5px solid var(--color-brand-primary);
	color: var(--color-brand-primary);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	font-size: 1.0625rem;
	line-height: 1;
}
.c-aplikuj-steps li > div { display: flex; flex-direction: column; gap: 0.125rem; }
.c-aplikuj-steps strong { color: var(--color-ink-900); font-weight: var(--fw-strong); font-size: 1rem; }
.c-aplikuj-steps span { color: var(--color-ink-700); font-size: 0.9375rem; line-height: 1.45; }

/* Phone panel */
.c-aplikuj-side__phone {
	display: flex;
	gap: var(--space-s);
	align-items: center;
	background: var(--color-paper);
	border: 1.5px solid var(--color-brand-primary);
}
.c-aplikuj-side__phone img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; }
.c-aplikuj-side__phone .section__eyebrow { display: block; margin: 0 0 0.125rem; }
.c-aplikuj-side__phone-num {
	display: inline-block;
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: var(--fw-display);
	color: var(--color-brand-primary);
	text-decoration: none;
	letter-spacing: -0.01em;
	margin-block-end: 0.125rem;
}
.c-aplikuj-side__phone-num:hover { color: var(--color-brand-primary-700); }
.c-aplikuj-side__phone p { margin: 0; font-size: 0.875rem; color: var(--color-ink-500); }

/* Trust list */
.c-aplikuj-side__trust {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	font-size: 0.9375rem;
	color: var(--color-ink-700);
}
.c-aplikuj-side__trust li { display: flex; gap: 0.625rem; align-items: center; }
.c-aplikuj-side__trust .icon { color: var(--color-brand-primary); flex: 0 0 auto; }

/* Quote */
.c-aplikuj-quote {
	margin: 0;
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(1.25rem, 2.2vw, 1.625rem);
	line-height: 1.45;
	color: var(--color-ink-900);
	max-width: 60ch;
	margin-inline: auto;
}
.c-aplikuj-quote p { margin: 0 0 var(--space-s); }
.c-aplikuj-quote p::before { content: "\201E"; color: var(--color-brand-primary); font-size: 1.5em; line-height: 0; vertical-align: -.4em; margin-inline-end: 0.05em; opacity: .6; }
.c-aplikuj-quote footer {
	font-family: var(--font-body);
	font-style: normal;
	font-size: 0.9375rem;
	color: var(--color-ink-500);
	font-weight: var(--fw-strong);
	letter-spacing: 0.04em;
}


/* Edit-stub admin notice — used by content-seeder for not-yet-pasted blocks */
.c-edit-stub {
	background: #FFF8E1;
	border: 1px dashed #C97A14;
	border-radius: var(--radius-m);
	padding: var(--space-m);
	color: #8A5A0E;
	font-size: 0.9375rem;
}
.c-edit-stub strong { color: #8A5A0E; }

/* === c-pillar (cornerstone article — editorial layout) ============== */

.c-pillar {
	background: var(--color-paper);
}

/* Hero — beige card with brand-red left accent, pill eyebrow, meta card */
.c-pillar__hero {
	padding-block: var(--space-2xl) var(--space-l);
}
.c-pillar__hero-card {
	position: relative;
	max-width: 920px;
	margin-inline: auto;
	background: var(--color-surface-tint);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: clamp(var(--space-l), 4vw, var(--space-2xl));
	overflow: hidden;
}
.c-pillar__hero-card::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 4px;
	background: var(--color-brand-primary);
}

/* Eyebrow — pill with brand-red dot indicator */
.c-pillar__hero-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.4375rem 0.875rem;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: var(--fw-strong);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-brand-primary);
	margin-block-end: var(--space-l);
}
.c-pillar__hero-eyebrow-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	background: var(--color-brand-primary);
	border-radius: 50%;
	box-shadow: 0 0 0 4px rgba(197, 18, 48, 0.16);
	flex: 0 0 auto;
}

.c-pillar__h1 {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 4.5vw, 3.5rem);
	line-height: 1.05;
	letter-spacing: -0.025em;
	margin-block: 0 var(--space-m);
	max-width: 22ch;
	color: var(--color-ink-900);
}
.c-pillar__lede {
	font-size: clamp(1.125rem, 1.5vw, 1.375rem);
	line-height: 1.55;
	color: var(--color-ink-700);
	max-width: 56ch;
	margin-block-end: var(--space-l);
}

/* Reading meta — inset card with thin separators between items */
.c-pillar__meta {
	list-style: none;
	margin: 0; padding: 0;
	display: inline-flex;
	flex-wrap: wrap;
	align-items: stretch;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-m);
	font-size: 0.875rem;
	font-weight: var(--fw-strong);
	letter-spacing: 0.01em;
	color: var(--color-ink-700);
	overflow: hidden;
}
.c-pillar__meta li {
	display: inline-flex;
	align-items: center;
	gap: 0.4375rem;
	padding: 0.625rem var(--space-m);
}
.c-pillar__meta li + li {
	border-inline-start: 1px solid var(--color-ink-200);
}
.c-pillar__meta .icon {
	color: var(--color-brand-primary);
	flex: 0 0 auto;
}
@media (max-width: 599px) {
	.c-pillar__meta { display: flex; flex-direction: column; align-items: stretch; }
	.c-pillar__meta li + li {
		border-inline-start: 0;
		border-block-start: 1px solid var(--color-ink-200);
	}
}

/* Key facts — light cards inside the article rhythm, not a separate section */
.c-pillar__facts {
	padding-block: var(--space-xl);
}
.c-pillar__facts > .container {
	max-width: 920px;
}
.c-pillar__facts > .container > .section__eyebrow {
	display: block;
	margin-block-end: var(--space-m);
}
.c-pillar-facts__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-s);
}
@media (max-width: 899px) { .c-pillar-facts__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px) { .c-pillar-facts__grid { grid-template-columns: 1fr; } }
.c-pillar-facts__card {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
	padding: var(--space-m);
	background: var(--color-surface-tint);
	border-radius: var(--radius-m);
	border: 1px solid transparent;
	transition: border-color var(--dur-base) var(--ease-out);
}
.c-pillar-facts__card:hover { border-color: var(--color-ink-300); }
.c-pillar-facts__key {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: var(--fw-display);
	line-height: 1.1;
	color: var(--color-brand-primary);
	letter-spacing: -0.01em;
}
.c-pillar-facts__body {
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--color-ink-700);
}
.c-pillar-facts__card:not(:has(.c-pillar-facts__key)) .c-pillar-facts__body {
	color: var(--color-ink-900);
	font-size: 1rem;
	font-weight: var(--fw-strong);
}

/* TOC — inline, two-column, no separate section background */
.c-pillar__toc {
	padding-block: var(--space-l) var(--space-xl);
}
.c-pillar__toc > .container {
	max-width: 920px;
}
.c-pillar__toc .section__eyebrow {
	display: block;
	margin-block-end: var(--space-s);
}
.c-pillar-toc__list {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0 var(--space-l);
}
@media (max-width: 720px) { .c-pillar-toc__list { grid-template-columns: 1fr; } }
.c-pillar-toc__list li { margin: 0; }
.c-pillar-toc__list a {
	display: flex;
	align-items: baseline;
	gap: var(--space-s);
	padding: 0.875rem 0;
	border-block-end: 1px solid var(--color-ink-200);
	color: var(--color-ink-900);
	text-decoration: none;
	transition: color var(--dur-base) var(--ease-out);
}
.c-pillar-toc__list a:hover {
	color: var(--color-brand-primary);
}
.c-pillar-toc__num {
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	color: var(--color-ink-500);
	font-size: 0.8125rem;
	letter-spacing: 0.06em;
	flex: 0 0 auto;
	min-width: 1.75rem;
}
.c-pillar-toc__list a:hover .c-pillar-toc__num { color: var(--color-brand-primary); }
.c-pillar-toc__label {
	font-size: 1rem;
	font-weight: var(--fw-strong);
	line-height: 1.4;
}

/* Body sections — wider frame, prose constrained inside for readability */
.c-pillar__body {
	padding-block-start: var(--space-l);
}
.c-pillar-section {
	padding-block: var(--space-xl);
	scroll-margin-top: var(--space-l);
}
.c-pillar-section + .c-pillar-section {
	border-block-start: 1px solid var(--color-ink-200);
}
.c-pillar-section > .container {
	max-width: 920px;
}
.c-pillar-section__h {
	font-family: var(--font-display);
	font-size: clamp(1.625rem, 3vw, 2.25rem);
	line-height: 1.2;
	letter-spacing: -0.01em;
	margin-block: 0 var(--space-m);
	display: flex;
	align-items: baseline;
	gap: var(--space-s);
	flex-wrap: wrap;
}
.c-pillar-section__num {
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	font-size: 0.875rem;
	letter-spacing: 0.06em;
	color: var(--color-brand-primary);
	flex: 0 0 auto;
}
.c-pillar-section__num::after { content: "."; }
.c-pillar-section__body {
	font-size: 1.0625rem;
	line-height: 1.7;
	max-width: 70ch;
}
.c-pillar-section__body > :first-child { margin-block-start: 0; }
.c-pillar-section__body h3 {
	font-size: 1.25rem;
	margin-block: var(--space-l) var(--space-s);
	color: var(--color-ink-900);
	letter-spacing: -0.005em;
}
.c-pillar-section__body p {
	margin-block-end: var(--space-s);
	color: var(--color-ink-800, var(--color-ink-700));
}
.c-pillar-section__body ul,
.c-pillar-section__body ol {
	margin-block: var(--space-s);
	padding-inline-start: var(--space-l);
}
.c-pillar-section__body li {
	margin-block-end: var(--space-2xs);
	padding-inline-start: var(--space-2xs);
}
.c-pillar-section__body li::marker { color: var(--color-brand-primary); }
.c-pillar-section__body strong { color: var(--color-ink-900); font-weight: var(--fw-strong); }
.c-pillar-section__body em { color: var(--color-ink-900); font-style: italic; }
.c-pillar-section__body a {
	color: var(--color-brand-primary);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}
.c-pillar-section__body a:hover { text-decoration-thickness: 2px; }

/* Related cornerstones grid */
.c-pillar-related {
	background: var(--color-paper);
	padding-block: var(--space-2xl);
}
.c-pillar-related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-m);
}
@media (max-width: 1023px) { .c-pillar-related__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .c-pillar-related__grid { grid-template-columns: 1fr; } }
.c-pillar-related__card {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: var(--space-l);
	color: var(--color-ink-900);
	text-decoration: none;
	transition: transform var(--dur-base) var(--ease-out),
				border-color var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out);
}
.c-pillar-related__card:hover {
	transform: translateY(-2px);
	border-color: transparent;
	box-shadow: var(--shadow-hover);
	color: var(--color-ink-900);
}
.c-pillar-related__h {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: var(--fw-display);
	line-height: 1.25;
	color: var(--color-ink-900);
}
.c-pillar-related__desc {
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--color-ink-700);
}
.c-pillar-related__cta {
	margin-block-start: var(--space-s);
	color: var(--color-brand-primary);
	font-weight: var(--fw-button);
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
}

/* === c-hub-toc (table-of-contents grid on /dla-opiekunek/) ============ */
.c-hub-toc__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-l);
}
@media (max-width: 1023px) { .c-hub-toc__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .c-hub-toc__grid { grid-template-columns: 1fr; } }
.c-hub-toc__card {
	display: grid;
	grid-template-rows: auto auto auto 1fr auto;
	gap: var(--space-2xs);
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	padding: var(--space-l);
	color: var(--color-ink-900);
	text-decoration: none;
	transition: transform var(--dur-base) var(--ease-out),
				border-color var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out);
	position: relative;
}
.c-hub-toc__card:hover {
	transform: translateY(-3px);
	border-color: transparent;
	box-shadow: var(--shadow-hover);
	color: var(--color-ink-900);
}
.c-hub-toc__num {
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	font-size: 0.875rem;
	letter-spacing: 0.06em;
	color: var(--color-brand-primary);
	margin-block-end: var(--space-2xs);
}
.c-hub-toc__eyebrow {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: var(--fw-strong);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-ink-500);
	margin-block-end: var(--space-2xs);
}
.c-hub-toc__h {
	font-family: var(--font-display);
	font-size: 1.375rem;
	font-weight: var(--fw-display);
	line-height: 1.2;
	letter-spacing: -0.01em;
	color: var(--color-ink-900);
	margin-block: 0 var(--space-xs);
}
.c-hub-toc__p {
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--color-ink-700);
	margin: 0;
}
.c-hub-toc__foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-s);
	margin-block-start: var(--space-m);
	padding-block-start: var(--space-s);
	border-block-start: 1px solid var(--color-ink-200);
}
.c-hub-toc__pill {
	display: inline-flex;
	align-items: center;
	padding: 0.25rem 0.625rem;
	background: var(--color-surface-tint);
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	letter-spacing: 0.01em;
}
.c-hub-toc__cta {
	color: var(--color-brand-primary);
	font-weight: var(--fw-button);
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 0.9375rem;
}
.c-hub-toc__card:hover .c-hub-toc__cta { gap: 0.5rem; transition: gap var(--dur-base) var(--ease-out); }

/* === c-city-offers (offer strip on /praca-opiekunka-{city}/) ========= */
.c-city-offers { background: var(--color-surface-tint); }
.c-city-offers .c-offer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: var(--space-m);
}
@media (min-width: 768px) {
	.c-city-offers .c-offer-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px) {
	.c-city-offers .c-offer-grid { grid-template-columns: repeat(3, 1fr); }
}

/* === c-form--rekrutacja (long-form recruitment funnel) ============== */

/* Tone down inline req/opt tags — small caps text, no pill background.
   Default = optional, so we hide opt-tag entirely; only the red asterisk
   (req-tag) signals required fields. */
.c-form--rekrutacja .req-tag {
	background: transparent;
	color: var(--color-brand-primary);
	padding: 0;
	font-size: 0.6875rem;
	letter-spacing: 0.04em;
	text-transform: lowercase;
	font-weight: var(--fw-strong);
	margin-inline-start: 0.25em;
}
.c-form--rekrutacja .opt-tag { display: none; }

/* Numbered section dividers — premium, alternating tints, decorative badge */
.c-form__group {
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
	padding-block: var(--space-xl);
	margin-inline: calc( -1 * var(--space-l) );
	padding-inline: var(--space-l);
	border-radius: var(--radius-l);
}
.c-form--rekrutacja > .c-form__group:first-of-type { padding-block-start: var(--space-l); }
.c-form--rekrutacja > .c-form__group:nth-child(even) {
	background: var(--color-surface-tint);
}
.c-form__group + .c-form__group {
	margin-block-start: var(--space-2xs);
}

/* Section header — numbered badge on the left, eyebrow + h3 + intro on the right */
.c-form__group-head {
	display: flex;
	align-items: flex-start;
	gap: var(--space-m);
	margin-block-end: var(--space-s);
}
.c-form__group-head > div {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	flex: 1 1 auto;
	min-width: 0;
}
.c-form__group-num {
	flex: 0 0 auto;
	width: 2.5rem;
	height: 2.5rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	font-weight: var(--fw-display);
	font-size: 0.9375rem;
	letter-spacing: 0.04em;
	color: var(--color-paper);
	background: var(--color-brand-primary);
	border-radius: 50%;
	box-shadow: 0 0 0 4px rgba(197, 18, 48, 0.12);
	margin-block-start: 0.125rem;
}
.c-form__group-head h3 {
	font-family: var(--font-display);
	font-size: 1.375rem;
	font-weight: var(--fw-display);
	line-height: 1.2;
	letter-spacing: -0.01em;
	margin: 0;
	color: var(--color-ink-900);
}
.c-form__group-head p {
	margin: 0;
	font-size: 0.9375rem;
	color: var(--color-ink-700);
	line-height: 1.5;
}
.c-form__group-head .section__eyebrow {
	margin-block-end: 0;
	color: var(--color-brand-primary);
}

/* 3-col row variant + safer alignment for multi-column rows.
   When labels wrap to 2 lines on one column, all inputs in the row stay
   on the same baseline by aligning each field's content to the bottom. */
.c-form__row--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 720px) {
	.c-form__row--3 { grid-template-columns: 1fr; }
}
.c-form__row .c-form__field {
	display: flex;
	flex-direction: column;
	justify-content: flex-end; /* push input to bottom — labels can wrap freely */
}

/* Field-level label for radio/checkbox groups */
.c-form__field-label {
	display: block;
	font-size: 0.9375rem;
	font-weight: var(--fw-strong);
	color: var(--color-ink-900);
	margin-block-end: var(--space-xs);
	line-height: 1.4;
}

/* Pill row — premium inline pills with depth on selected state */
.c-form__field--pills .c-form__pill-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.c-form__pill {
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 1rem;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-300);
	border-radius: 999px;
	cursor: pointer;
	font-size: 0.9375rem;
	color: var(--color-ink-700);
	transition: border-color var(--dur-base) var(--ease-out),
				background var(--dur-base) var(--ease-out),
				color var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out),
				transform var(--dur-base) var(--ease-out);
	user-select: none;
	line-height: 1.3;
	min-height: 40px;
}
.c-form__pill input {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.c-form__pill:hover {
	border-color: var(--color-brand-primary);
	color: var(--color-brand-primary);
	background: var(--color-paper);
}
.c-form__pill:has(input:checked) {
	background: var(--color-brand-primary);
	border-color: var(--color-brand-primary);
	color: var(--color-paper);
	font-weight: var(--fw-strong);
	box-shadow: 0 4px 12px rgba(197, 18, 48, 0.22);
	transform: translateY(-1px);
}
.c-form__pill:focus-within {
	outline: 3px solid var(--color-brand-primary);
	outline-offset: 2px;
}

/* Form-card chrome — brand accent + slightly tighter form-card head for the
   rekrutacja layout (the form-card already has shadow + border from the
   apply layout; we only add the brand accents). */
.c-aplikuj-form-card:has(.c-form--rekrutacja) {
	position: relative;
	overflow: hidden;
	padding-block-start: clamp(2rem, 4vw, 2.75rem);
}
.c-aplikuj-form-card:has(.c-form--rekrutacja)::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-brand-primary) 0%, #E14159 60%, var(--color-brand-primary) 100%);
}
.c-aplikuj-form-card:has(.c-form--rekrutacja) .c-aplikuj-form-card__head .section__eyebrow {
	color: var(--color-brand-primary);
	margin-block-end: var(--space-s);
}

/* Long form needs a touch more vertical breathing room in the card */
.c-form--rekrutacja {
	display: flex;
	flex-direction: column;
	gap: var(--space-s);
}


/* === c-blog-card (poradnik archive cards — mirrors c-offer-card) ====== */
.c-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-l);
}
@media (max-width: 1023px) { .c-blog-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-m); } }
@media (max-width: 599px)  { .c-blog-grid { grid-template-columns: 1fr; } }

.c-blog-card {
	display: flex;
	flex-direction: column;
	background: var(--color-paper);
	border: 1px solid var(--color-ink-200);
	border-radius: var(--radius-l);
	overflow: hidden;
	transition: transform var(--dur-base) var(--ease-out),
				border-color var(--dur-base) var(--ease-out),
				box-shadow var(--dur-base) var(--ease-out);
}
.c-blog-card:hover {
	transform: translateY(-2px);
	border-color: transparent;
	box-shadow: var(--shadow-hover);
}

/* Media (top) — full-bleed image with date eyebrow + title overlaid like c-offer-card */
.c-blog-card__media {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: var(--space-s) var(--space-m);
	min-height: 220px;
	background-color: var(--color-ink-900);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	color: var(--color-paper);
	text-decoration: none;
	overflow: hidden;
}
.c-blog-card__media::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			180deg,
			rgba(0, 0, 0, .35) 0%,
			rgba(0, 0, 0, 0) 28%,
			rgba(0, 0, 0, 0) 45%,
			rgba(0, 0, 0, .65) 100%
		);
	pointer-events: none;
}
.c-blog-card__media > * { position: relative; z-index: 1; }

/* Top-right category badge (Poradnik opiekunki) */
.c-blog-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	align-self: flex-end;
	background: var(--color-brand-primary);
	color: var(--color-paper);
	padding: 0.3rem 0.7rem;
	border-radius: var(--radius-pill);
	font-size: 0.6875rem;
	font-weight: var(--fw-button);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	box-shadow: 0 1px 6px rgba(0, 0, 0, .25);
}
.c-blog-card__badge .icon { color: var(--color-paper); }

/* Bottom overlay — date pill + title pill */
.c-blog-card__overlay {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
	margin-block-start: auto;
}
.c-blog-card__date {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background: rgba(255, 255, 255, .92);
	color: var(--color-ink-900);
	padding: 0.32rem 0.7rem;
	border-radius: var(--radius-pill);
	font-size: 0.7rem;
	font-weight: var(--fw-button);
	text-transform: uppercase;
	letter-spacing: 0.09em;
	box-shadow: 0 1px 6px rgba(0, 0, 0, .15);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.c-blog-card__date .icon { color: var(--color-brand-primary); }
.c-blog-card__title {
	display: inline-block;
	max-width: 100%;
	background: rgba(255, 255, 255, .95);
	color: var(--color-ink-900);
	padding: 0.55rem 0.95rem;
	border-radius: var(--radius-m);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	box-shadow: 0 2px 12px rgba(0, 0, 0, .18);
	font-family: var(--font-display);
	font-size: 1.1875rem;
	font-weight: var(--fw-display);
	letter-spacing: -0.005em;
	line-height: 1.3;
	margin: 0;
}
.c-blog-card:hover .c-blog-card__title {
	background: var(--color-paper);
	box-shadow: 0 4px 18px rgba(0, 0, 0, .25);
}

/* Body (excerpt + read-more CTA) */
.c-blog-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-s);
	padding: var(--space-m) var(--space-l) var(--space-l);
	flex: 1;
}
.c-blog-card__excerpt {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--color-ink-700);
}
.c-blog-card__cta {
	margin-block-start: auto;
	color: var(--color-brand-primary);
	font-weight: var(--fw-button);
	font-size: 0.9375rem;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
}
.c-blog-card:hover .c-blog-card__cta { gap: 0.5rem; transition: gap var(--dur-base) var(--ease-out); }
