/* O nas – sections 1–4 + helpers (partners use page-home.css) */

.page-template-o-nas .o-nas-hero {
	background: #fff;
}

.page-template-o-nas .o-nas-hero__row {
	margin-top: var(--sp-m);
	align-items: center;
}

.page-template-o-nas .o-nas-hero__desc p {
	margin: 0 0 0.75em;
}

.page-template-o-nas .o-nas-hero__desc p:last-child {
	margin-bottom: 0;
}

.page-template-o-nas .o-nas-hero__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px 24px;
}

.page-template-o-nas .o-nas-hero__btn-chevron {
	margin-left: 8px;
	flex-shrink: 0;
}

.page-template-o-nas .btn--outline-dark {
	background: #fff;
	color: var(--color-bg--dark);
	border: 1px solid #eceef2;
	font-weight: 600;
}

.page-template-o-nas .btn--outline-dark:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.page-template-o-nas .o-nas-hero__visual {
	position: relative;
	width: 100%;
}

.page-template-o-nas .o-nas-hero__img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	box-shadow: 0 20px 48px rgba(35, 33, 61, 0.08);
}

.page-template-o-nas .o-nas-hero__badge {
	position: absolute;
	left: 24px;
	bottom: -28px;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 14px;
	padding: 16px 22px;
	background: #fff;
	border-radius: 20px;
	box-shadow:
		0 24px 48px rgba(35, 33, 61, 0.18),
		0 8px 16px rgba(35, 33, 61, 0.08);
	max-width: calc(100% - 48px);
	animation: o-nas-badge-float 4.5s ease-in-out infinite;
	will-change: transform;
}

@keyframes o-nas-badge-float {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-6px); }
}

.page-template-o-nas .o-nas-hero__badge-icon-wrap {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--gradient-1);
	background: linear-gradient(135deg, #FF1D6A 0%, #FF6E2E 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	box-shadow: 0 6px 14px rgba(255, 29, 106, 0.28);
}

.page-template-o-nas .o-nas-hero__badge-icon-wrap img {
	width: 22px;
	height: 22px;
	object-fit: contain;
	filter: brightness(0) invert(1);
}

.page-template-o-nas .o-nas-kim {
	position: relative;
	background: var(--color-bg--light);
}

.page-template-o-nas .o-nas-kim::before {
	/* full-bleed: rozciągamy tło na całą szerokość viewportu nawet jeśli sekcja
	   nie jest pełnej szerokości (np. w wąskim layoucie) */
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(50% - 50vw);
	width: 100vw;
	background: inherit;
	z-index: 0;
	pointer-events: none;
}

.page-template-o-nas .o-nas-kim__container {
	position: relative;
	z-index: 1;
	padding-top: var(--sp-xl);
	padding-bottom: var(--sp-xl);
}

.page-template-o-nas .o-nas-kim__title-accent {
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	border-bottom: 2px solid var(--color-primary);
	padding-bottom: 2px;
}

.page-template-o-nas .o-nas-kim__img {
	box-shadow: 0 20px 48px rgba(35, 33, 61, 0.08);
}

.page-template-o-nas .o-nas-kim__card {
	background: #fff;
	box-shadow: 0 12px 40px rgba(35, 33, 61, 0.06);
	border-left: 4px solid var(--color-primary);
}

.page-template-o-nas .o-nas-kim__card-inner {
	padding: var(--sp-ml) var(--sp-m);
}

.page-template-o-nas .o-nas-kim__card-inner p:last-child {
	margin-bottom: 0;
}

.page-template-o-nas .o-nas-stats {
	padding: 0;
	overflow: hidden;
}

.page-template-o-nas .o-nas-stats__inner {
	position: relative;
	background: var(--gradient-1);
	padding: var(--sp-xl) var(--sp-m);
}

.page-template-o-nas .o-nas-stats__inner::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.2) 1px, transparent 1px);
	background-size: 14px 14px;
	pointer-events: none;
	opacity: 0.9;
}

.page-template-o-nas .o-nas-stats__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-m);
	max-width: 1200px;
	margin: 0 auto;
	align-items: start;
}

.page-template-o-nas .o-nas-stats__cell {
	text-align: center;
	padding: var(--sp-s);
	border-right: 1px solid rgba(255, 255, 255, 0.25);
}

.page-template-o-nas .o-nas-stats__cell:last-child {
	border-right: none;
}

.page-template-o-nas .o-nas-stats__icon {
	height: 40px;
	width: auto;
	margin: 0 auto 12px;
	display: block;
	filter: brightness(0) invert(1);
	object-fit: contain;
}

.page-template-o-nas .o-nas-stats__value {
	margin-bottom: 8px;
	font-weight: 700;
}

.page-template-o-nas .o-nas-stats__label {
	opacity: 0.95;
}

.page-template-o-nas .o-nas-trust__container {
	padding-top: var(--sp-xl);
	padding-bottom: var(--sp-xl);
}

.page-template-o-nas .o-nas-trust__header {
	text-align: center;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.page-template-o-nas .o-nas-trust__lead {
	margin: 0;
}

.page-template-o-nas .o-nas-trust__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-m);
}

.page-template-o-nas .o-nas-trust__box {
	padding: 32px 28px;
	background: #fff;
	border: 1px solid #eceef2;
	box-shadow: 0 1px 2px rgba(35, 33, 61, 0.04);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
	display: flex;
	flex-direction: column;
}

.page-template-o-nas .o-nas-trust__box:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 32px rgba(35, 33, 61, 0.08);
	border-color: #e1e3ec;
}

.page-template-o-nas .o-nas-trust__icon-slot {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: #f3f4f7;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	color: #8a8aa3;
	flex-shrink: 0;
}

.page-template-o-nas .o-nas-trust__icon-slot img,
.page-template-o-nas .o-nas-trust__icon-slot svg {
	width: 24px;
	height: 24px;
	max-width: 24px;
	max-height: 24px;
	object-fit: contain;
	display: block;
}

.page-template-o-nas .o-nas-trust__box-title {
	font-size: 17px;
	line-height: 1.35;
	color: #1f1f3a;
	margin-bottom: 12px;
}

.page-template-o-nas .o-nas-trust__box-desc {
	margin: 0;
	line-height: 1.6;
	color: #6c6c85;
}

.page-template-o-nas .o-nas-trust__cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 36px 28px;
	background: #2b2945;
	min-height: 220px;
	gap: 18px;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.page-template-o-nas .o-nas-trust__cta:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 32px rgba(35, 33, 61, 0.18);
}

.page-template-o-nas .o-nas-trust__cta-title {
	margin: 0;
	font-size: 24px;
	line-height: 1.25;
	color: #fff;
	font-weight: 600;
}

.page-template-o-nas .o-nas-trust__cta-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #ff6e2e;
	text-decoration: none;
	font-weight: 600;
	font-size: 15px;
	transition: color 0.2s, gap 0.2s;
}

.page-template-o-nas .o-nas-trust__cta-link:hover {
	color: #fea066;
	gap: 12px;
}

.page-template-o-nas .o-nas-trust__cta-arrow {
	flex-shrink: 0;
}

@media (max-width: 991px) {
	.page-template-o-nas .o-nas-stats__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.page-template-o-nas .o-nas-stats__cell {
		border-right: none;
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
		padding-bottom: var(--sp-m);
	}

	.page-template-o-nas .o-nas-stats__cell:nth-child(2n) {
		border-left: 1px solid rgba(255, 255, 255, 0.2);
	}

	.page-template-o-nas .o-nas-stats__cell:nth-last-child(-n + 2) {
		border-bottom: none;
		padding-bottom: var(--sp-s);
	}

	.page-template-o-nas .o-nas-trust__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.page-template-o-nas .o-nas-trust__cta {
		grid-column: 1 / -1;
		grid-row: auto;
	}
}

@media (max-width: 540px) {
	.page-template-o-nas .o-nas-stats__grid {
		grid-template-columns: 1fr;
	}

	.page-template-o-nas .o-nas-stats__cell {
		border-left: none !important;
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
	}

	.page-template-o-nas .o-nas-stats__cell:last-child {
		border-bottom: none;
	}

	.page-template-o-nas .o-nas-trust__grid {
		grid-template-columns: 1fr;
	}

	.page-template-o-nas .o-nas-hero__badge {
		position: relative;
		left: auto;
		bottom: auto;
		margin-top: 16px;
		max-width: 100%;
		animation: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.page-template-o-nas .o-nas-hero__badge {
		animation: none;
	}
}

/* Reset animacji GSAP, której hook nie istnieje na O nas (page-home.js nieładowane) */
.page-template-o-nas .anim-fade--up,
.page-template-o-nas .anim-fade {
	opacity: 1 !important;
	visibility: visible !important;
	transform: none !important;
}

/* O nas — własna sekcja opinii (CSS scroll-snap, full-bleed, 3 pełne + boki obcięte) */
.page-template-o-nas .o-nas-reviews {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-top: var(--sp-xl);
	padding-bottom: var(--sp-xl);
	overflow: hidden;
}

.page-template-o-nas .o-nas-reviews__head {
	text-align: center;
	margin-bottom: 40px;
	padding-inline: 16px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

.page-template-o-nas .o-nas-reviews__rating {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}

.page-template-o-nas .o-nas-reviews__stars svg {
	transform: scale(1.4);
	transform-origin: center;
	margin: 6px 0;
}

.page-template-o-nas .o-nas-reviews__rating-inner {
	display: flex;
	flex-direction: row;
	gap: 8px;
	align-items: center;
	justify-content: center;
}

.page-template-o-nas .o-nas-reviews__google {
	height: 20px;
	width: auto;
}

.page-template-o-nas .o-nas-reviews__viewport {
	position: relative;
	/* card width and side padding share these vars so margins line up */
	--rcw: clamp(280px, calc((100vw - 256px) / 3), 460px);
	--rsp: calc((100vw - var(--rcw)) / 2);
}

.page-template-o-nas .o-nas-reviews__track {
	display: flex;
	gap: 24px;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scrollbar-width: none;
	-ms-overflow-style: none;
	-webkit-overflow-scrolling: touch;
	padding: 8px 0 8px;
	align-items: stretch;
}

.page-template-o-nas .o-nas-reviews__track::-webkit-scrollbar {
	display: none;
}

.page-template-o-nas .o-nas-reviews__card {
	flex: 0 0 var(--rcw);
	scroll-snap-align: center;
	background: #FFFAF9;
	border-radius: 16px;
	padding: 28px 28px 32px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	box-shadow: 0 4px 16px rgba(35, 33, 61, 0.04);
}

/* margin so first/last card może się wyśrodkować w viewporcie i nie kotwiczyć przy krawędzi */
.page-template-o-nas .o-nas-reviews__card:first-child {
	margin-left: var(--rsp);
}

.page-template-o-nas .o-nas-reviews__card:last-child {
	margin-right: var(--rsp);
}

.page-template-o-nas .o-nas-reviews__card-head {
	display: flex;
	flex-direction: row;
	gap: 14px;
	align-items: center;
}

.page-template-o-nas .o-nas-reviews__avatar {
	width: 44px;
	height: 44px;
	min-width: 44px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 600;
	font-size: 18px;
	line-height: 1;
}

.page-template-o-nas .o-nas-reviews__meta {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
}

.page-template-o-nas .o-nas-reviews__author {
	font-weight: 600;
	font-size: 15px;
	line-height: 1.3;
	color: #1f1f3a;
}

.page-template-o-nas .o-nas-reviews__date {
	font-size: 13px;
	color: #8d8da8;
}

.page-template-o-nas .o-nas-reviews__stars-sm {
	display: flex;
	align-items: center;
}

.page-template-o-nas .o-nas-reviews__stars-sm svg {
	transform: scale(1.1);
	transform-origin: left center;
}

.page-template-o-nas .o-nas-reviews__text {
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
	color: #2b2945;
}

.page-template-o-nas .o-nas-reviews__dots {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 28px;
}

.page-template-o-nas .o-nas-reviews__dot {
	width: 8px;
	height: 8px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: #d8d8e3;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
}

.page-template-o-nas .o-nas-reviews__dot:hover {
	background: #b6b6c5;
}

.page-template-o-nas .o-nas-reviews__dot.is-active {
	background: #ff6e2e;
	transform: scale(1.15);
}

@media (max-width: 1100px) {
	.page-template-o-nas .o-nas-reviews__viewport {
		--rcw: clamp(260px, calc((100vw - 160px) / 2), 480px);
	}
}

@media (max-width: 768px) {
	.page-template-o-nas .o-nas-reviews__track {
		gap: 16px;
	}
	.page-template-o-nas .o-nas-reviews__viewport {
		--rcw: 78vw;
	}
}

