/*
 * Style strony głównej — StützSkin
 * Mobile-first. Sekcje: hero, marquee, services, why, testimonials, about, cta.
 */

/* ================================================================
 * HERO
 * ================================================================ */

/*
 * Mobile-first: 1 kolumna, zdjęcie nad tekstem.
 * padding-top 100px = 64px (nav) + 36px (oddech).
 * max-width 1440px — treść nie rozciąga się ponad tę szerokość.
 */
.hero {
	display: grid;
	grid-template-columns: 1fr;
	min-height: auto;
	padding: 100px 24px 48px;
	gap: 0;
	align-items: start;
	background: var(--cream);
	max-width: 1440px;
	margin-left: auto;
	margin-right: auto;
}

/* Prawa kolumna — na mobile nad tekstem, 260px */
.hero__right {
	position: relative;
	height: 260px;
	order: -1; /* zdjęcie nad tekstem na mobile */
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	background: var(--cream-dark);
	margin: 0 -24px; /* pełna szerokość poza paddingiem hero */
	width: calc(100% + 48px);
}

.hero__left {
	display: flex;
	flex-direction: column;
	gap: 0;
	padding: 0;
}

.hero__headline {
	margin-top: var(--space-sm);
	color: var(--ink);
}

.hero__headline em {
	font-style: italic;
	color: var(--brick);
}

.hero__sub {
	max-width: 440px;
	font-size: 16px;
	line-height: 1.75;
	color: var(--ink-light);
	margin-top: var(--space-sm);
}

.hero__btns {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
	margin-top: var(--space-md);
}

/* Kredencjały — zawsze renderowane pod przyciskami */
.hero__creds {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
	align-items: baseline;
	margin-top: 24px;
	padding-top: 20px;
	border-top: 0.5px solid var(--cream-dark);
}

.cred__num {
	display: block;
	font-family: var(--serif);
	font-size: 30px;
	font-weight: 300;
	color: var(--gold);
	line-height: 1;
}

/* Kafelek języków — dłuższy tekst, font zmniejszony o ~20% */
.hero__cred--lang .cred__num {
	font-size: 24px;
}

.cred__lbl {
	display: block;
	font-size: 10px;
	font-weight: 400;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-top: 5px;
}

/* Zdjęcie — wypełnia .hero__right przez absolute+inset */
.hero__photo {
	position: absolute;
	inset: 0;
	height: 100%;
	background: var(--cream-dark);
	overflow: hidden;
}

.hero__photo-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
}

/* Cytat-badge w prawej kolumnie */
.hero__badge {
	position: relative;
	z-index: 2;
	margin: var(--space-md);
	background: rgba(253, 252, 251, 0.94);
	padding: var(--space-md);
	border-left: 2px solid var(--brick);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.hero__badge-quote {
	font-family: var(--serif);
	font-size: 16px;
	font-weight: 300;
	font-style: italic;
	color: var(--ink);
	line-height: 1.55;
}

.hero__badge-author {
	display: block;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-top: var(--space-xs);
}

/*
 * Desktop (≥768px): 2 kolumny obok siebie.
 */
@media (min-width: 768px) {
	.hero {
		grid-template-columns: 1fr 1fr;
		padding: 120px 48px 80px;
		align-items: center;
		gap: 0;
	}

	.hero__left {
		padding: 0 56px 0 0;
		justify-content: center;
	}

	.hero__right {
		height: 600px;
		max-height: 600px;
		order: 0;
		margin: 0;
		width: auto;
	}

	.hero__photo {
		height: 100%;
	}

	.hero__creds {
		margin-top: 48px;
		padding-top: 24px;
		gap: var(--space-lg);
	}
}

/* ================================================================
 * MARQUEE
 * ================================================================ */
.marquee-wrap {
	display: flex;
	align-items: center;
	background: var(--ink);
	padding: 0;
	height: 48px;
	overflow: hidden;
}

.marquee-track {
	display: flex;
	align-items: center;
	height: 100%;
	white-space: nowrap;
	/* Animacja translateX(-50%) przesuwa dokładnie pierwszą kopię = płynna pętla */
	animation: marquee-scroll 51s linear infinite;
}

.marquee-track:hover {
	animation-play-state: paused;
}

.marquee-item {
	display: inline-flex;
	align-items: center;
	height: 100%;
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cream);
	padding: 0 var(--space-md);
	flex-shrink: 0;
}

.marquee-dot {
	display: inline-block;
	color: var(--brick);
	flex-shrink: 0;
}

@keyframes marquee-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* ================================================================
 * SERVICES
 * ================================================================ */
.services {
	background: var(--white);
	padding: 64px var(--space-sm) var(--space-2xl);
	max-width: 1440px;
	margin-left: auto;
	margin-right: auto;
}

.services__header {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
	margin-bottom: var(--space-xl);
}

.services__header-right {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	justify-content: flex-end;
}

/* Link "Wszystkie usługi →" — wyróżniony kolor brick */
.services__all-link {
	display: inline-block;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--brick);
	text-decoration: none;
	border-bottom: 1px solid var(--brick);
	padding-bottom: 2px;
	transition: opacity 0.2s;
}

.services__all-link:hover {
	opacity: 0.7;
	color: var(--brick);
}

/* Siatka kart — 1 kolumna na mobile */
.services__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2px;
}

/* Karta usługi — flex column żeby link CTA był zawsze na dole */
.svc-card {
	background: var(--cream);
	padding: 40px 32px;
	position: relative;
	overflow: hidden;
	transition: background 0.3s;
	display: flex;
	flex-direction: column;
}

.svc-card:hover {
	background: var(--cream-dark);
}

/* Animowana krawędź dolna na hover */
.svc-card::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--brick);
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.4s ease;
}

.svc-card:hover::after {
	transform: scaleX(1);
}

/* Strzałka w prawym górnym rogu */
.svc-card__arrow {
	position: absolute;
	top: 24px;
	right: 24px;
	font-size: 20px;
	line-height: 1;
	color: var(--ink-muted);
	transition: color 0.2s, transform 0.2s;
}

.svc-card:hover .svc-card__arrow {
	color: var(--brick);
	transform: translate(3px, -3px);
}

.svc-card__num {
	font-family: var(--serif);
	font-size: 13px;
	font-weight: 300;
	letter-spacing: 0.12em;
	color: var(--ink-muted);
	margin-bottom: var(--space-md);
}

.svc-card__name {
	font-family: var(--serif);
	font-size: 26px;
	font-weight: 300;
	line-height: 1.2;
	color: var(--ink);
	margin-bottom: var(--space-sm);
}

.svc-card__desc {
	font-size: 15px;
	line-height: 1.7;
	color: var(--ink-light);
	margin-bottom: var(--space-md);
}

.svc-card__price {
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.08em;
	color: var(--gold);
	text-transform: uppercase;
	margin-bottom: var(--space-md);
}

/* Link CTA — zawsze na dole karty dzięki flex column i margin-top: auto */
.svc-card__link {
	display: inline-block;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.08em;
	color: var(--plum);
	text-decoration: none;
	border-bottom: 0.5px solid var(--plum);
	padding-bottom: 1px;
	margin-top: auto;
	transition: opacity 0.2s;
	align-self: flex-start;
}

.svc-card__link:hover {
	opacity: 0.7;
	color: var(--plum-dark);
}

@media (min-width: 768px) {
	.services {
		padding: var(--space-2xl) 48px;
	}

	.services__header {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-lg);
		align-items: start;
	}

	.services__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ================================================================
 * WHY
 * ================================================================ */

/* Sekcja treści — jasne kremowe tło */
.why {
	background: var(--brick-pale);
	padding: 0 0 var(--space-2xl);
}

/* ----------------------------------------------------------------
 * Pasek statystyk — ciemne tło #532933, pełna szerokość
 * ---------------------------------------------------------------- */
.why__stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	width: 100%;
	background: #793545;
	border-top: none;
	border-bottom: none;
	margin-bottom: 0;
}

.stat-item {
	padding: 40px 24px;
	border-right: 0.5px solid rgba(247, 243, 238, 0.12);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.stat-item:last-child {
	border-right: none;
}

.stat-item .num {
	display: block;
	font-family: var(--serif);
	font-size: clamp(32px, 3.5vw, 52px);
	font-weight: 300;
	color: #FDFCFB;
	line-height: 1;
	margin-bottom: 10px;
}

.stat-item .lbl {
	display: block;
	font-size: 11px;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #FDFCFB !important;
	text-align: center;
}

.why__stats .stat-item .lbl {
	color: #FDFCFB !important;
}

/* Kafelek języków — dłuższy tekst, font zmniejszony o ~20% */
.stat-item--lang .num {
	font-size: clamp(26px, 2.8vw, 42px);
}

/* ----------------------------------------------------------------
 * Treść sekcji — kremowe tło, ciemny tekst
 * ---------------------------------------------------------------- */
.why__inner {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 var(--space-sm);
}

.why__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	padding-top: 64px;
	border-top: none;
	margin-top: 0;
}

.why__points {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	margin: var(--space-sm) 0;
}

.why-point {
	display: flex;
	gap: var(--space-sm);
	align-items: flex-start;
}

.why-dot {
	display: block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--brick);
	flex-shrink: 0;
	margin-top: 8px;
}

.why-point__text {
	font-size: 15px;
	line-height: 1.7;
	color: var(--ink-light);
}

/* Tagi towarzystw naukowych — pełne nazwy, zawijają się naturalnie */
.why__memberships {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.membership-tag {
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--rose);
	border: 0.5px solid var(--rose);
	padding: 6px 14px;
	border-radius: var(--radius);
}

@media (min-width: 768px) {
	.why__inner {
		padding: 0 48px;
	}
}

@media (min-width: 1024px) {
	.why__content {
		max-width: 760px;
	}
}

/* ================================================================
 * TESTIMONIALS
 * ================================================================ */
.testimonials {
	background: var(--ink);
	padding: var(--space-2xl) var(--space-sm);
}

/* Wewnętrzny kontener z max-width — tło sekcji rozciąga się na pełną szerokość */
.testimonials__inner {
	max-width: 1440px;
	margin: 0 auto;
}

/* Nagłówek sekcji */
.testimonials__header {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	margin-bottom: var(--space-xl);
}

.testimonials__eyebrow {
	color: rgba(180, 107, 96, 0.8);
}

.testimonials__eyebrow::before {
	background: rgba(180, 107, 96, 0.6);
}

.testimonials__title {
	color: var(--cream);
}

.testimonials__title em {
	font-style: italic;
	color: var(--brick);
}

.testimonials__link {
	font-size: 13px;
	font-weight: 300;
	letter-spacing: 0.04em;
	color: var(--ink-muted);
	transition: color 0.2s;
	align-self: flex-start;
}

.testimonials__link:hover {
	color: var(--brick);
}

/* Siatka opinii */
.testimonials__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
}

.testi-card {
	padding: var(--space-lg) 0;
	border-top: 1px solid rgba(180, 107, 96, 0.25);
}

.testi-stars {
	font-size: 14px;
	letter-spacing: 2px;
	color: var(--brick);
	margin-bottom: var(--space-sm);
}

.testi-quote {
	font-family: var(--serif);
	font-size: 18px;
	font-weight: 300;
	font-style: italic;
	color: var(--cream);
	line-height: 1.65;
	margin-bottom: var(--space-md);
}

.testi-author {
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

@media (min-width: 768px) {
	.testimonials {
		padding: var(--space-2xl) 48px;
	}

	.testimonials__header {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
	}

	.testimonials__link {
		align-self: auto;
	}
}

@media (min-width: 1024px) {
	.testimonials__grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.testi-card {
		padding: var(--space-lg) var(--space-lg) var(--space-lg) 0;
	}

	/* Pionowe linie między kartami */
	.testi-card + .testi-card {
		padding-left: var(--space-lg);
		border-left: 1px solid rgba(180, 107, 96, 0.12);
	}
}

/* ================================================================
 * ABOUT SNIPPET
 * ================================================================ */
.about {
	background: var(--cream);
	padding: var(--space-2xl) var(--space-sm);
}

.about__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	align-items: center;
	max-width: 1440px;
	margin: 0 auto;
}

/* Zdjęcie z gradientowym tagiem lokalizacji */
.about__photo-wrap {
	position: relative;
	overflow: hidden;
}

.about__photo {
	aspect-ratio: 4 / 5;
	background: var(--cream-dark);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	letter-spacing: 0.06em;
	color: var(--ink-muted);
}

/* Tag lokalizacji — gradient overlay na dole zdjęcia (nie wychodzi poza ramkę) */
.about__location-tag {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(to top, rgba(28, 25, 23, 0.7) 0%, transparent 100%);
	color: var(--white);
	padding: 24px 20px 16px;
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-align: left;
}

/* Treść biogramu */
.about__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.about__bio {
	font-size: 16px;
	line-height: 1.75;
	color: var(--ink-light);
	margin-top: var(--space-xs);
}

.about__societies {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.about__societies li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
	font-size: 14px;
	line-height: 1.5;
	color: var(--ink-light);
}

/* Kropka przed każdą pozycją */
.about__societies li::before {
	content: '';
	display: block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--rose);
	flex-shrink: 0;
	margin-top: 5px;
}

/* Usuń border-bottom z btn-ghost w sekcji about */
.about .btn-ghost {
	border-bottom: none;
	padding-bottom: 0;
}

@media (min-width: 768px) {
	.about {
		padding: var(--space-2xl) 48px;
	}
}

@media (min-width: 1024px) {
	.about__inner {
		grid-template-columns: 5fr 7fr;
	}

	.about__content {
		padding-left: var(--space-lg);
	}
}

/* CTA SECTION — style przeniesione do base.css (globalne) */

/* ================================================================
 * NUMEREK USŁUGI — widoczny, kolor rose
 * ================================================================ */
.svc-num {
	display: none;
}

/* ================================================================
 * MOBILE OVERRIDES (max-width: 767px)
 * ================================================================ */
@media (max-width: 767px) {

	/* Hero — brak białego paska nad zdjęciem; nav jest fixed więc wychodzi z flow */
	.hero {
		padding-top: 0;
	}

	/* Hero — pionowy format zdjęcia na mobile */
	.hero__right {
		height: 520px;
	}

	/* Badge — absolute nad zdjęciem */
	.hero__badge {
		position: absolute;
		bottom: 16px;
		left: 16px;
		right: 16px;
		max-width: calc(100% - 32px);
		padding: 14px 16px;
		margin: 0;
	}

	.hero__badge-quote,
	.badge-quote {
		font-size: 12px;
	}

	/* Kredencjały — 3 kafelki w rzędzie, bez kolorowych teł */
	.hero__creds {
		display: flex;
		flex-wrap: wrap;
		gap: 16px;
		border-top: 0.5px solid var(--cream-dark);
		padding-top: 16px;
		margin-top: 24px;
		align-items: baseline;
	}

	/* Kredencjały — mniejsza typografia na mobile */
	.cred__num {
		font-size: 22px;
	}

	.hero__cred--lang .cred__num {
		font-size: 18px;
	}

	.cred__lbl {
		font-size: 9px;
	}

	/* Sekcja usług — mniejszy whitespace */
	.services {
		padding: 48px 24px;
		margin-bottom: 0;
	}

	.services__header {
		margin-bottom: 32px;
	}

	/* Statystyki — grid 2×2 z kolorami na mobile */
	.why__stats {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 2px;
		background: var(--cream-dark);
	}

	.stat-item {
		padding: 24px 20px;
		border-right: none;
		border-bottom: none;
		box-sizing: border-box;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		text-align: center;
		background: #793545;
	}

	/* kafelek 1 (2000+) — jasne tło */
	.stat-item:nth-child(1) {
		background: var(--cream);
	}

	/* kafelek 2 (PL·DE·EN·FR) — rose */
	.stat-item:nth-child(2) {
		background: var(--rose);
	}

	/* kafelek 3 (Charité) — brick */
	.stat-item:nth-child(3) {
		background: var(--brick);
	}

	/* kafelek 4 (4 towarzystwa) — jasne tło */
	.stat-item:nth-child(4) {
		background: var(--cream);
	}

	/* kolorowe kafelki — biały tekst */
	.stat-item:nth-child(2) .num,
	.stat-item:nth-child(3) .num {
		color: var(--white);
	}

	.stat-item:nth-child(2) .lbl,
	.stat-item:nth-child(3) .lbl {
		color: rgba(255, 255, 255, 0.65) !important;
	}

	/* jasne kafelki — ciemny tekst */
	.stat-item:nth-child(1) .num,
	.stat-item:nth-child(4) .num {
		color: var(--gold);
	}

	.stat-item:nth-child(1) .lbl,
	.stat-item:nth-child(4) .lbl {
		color: var(--ink-muted) !important;
	}

	.stat-item--lang .num {
		font-size: 24px;
	}

	.stat-item .num {
		font-size: 30px;
	}

	/* Sekcja "Dlaczego warto" — kremowe tło, stats oddzielnie na górze */
	.why,
	.why-section {
		padding: 0 0 48px;
	}

	.why__inner {
		padding: 0 24px;
	}

	.why__content,
	.why__grid {
		padding-top: 40px;
		border-top: none;
		gap: 32px;
	}

	/* Karty usług — mniejszy padding na 430px */
	.svc-card {
		padding: 28px 20px;
	}

	.svc-card__name {
		font-size: 22px;
	}

	/* Towarzystwa naukowe — zawijanie na wąskich ekranach */
	.mem-item {
		font-size: 12px;
	}

	.why__memberships {
		gap: 8px;
	}

	/* Sekcja why — bez poziomego overflow */
	.why,
	.why-section {
		overflow: hidden;
	}
}
