/* =========================================================
   MODUŁ: Pasek Promo (ticker / marquee / static / pulse)
   ========================================================= */

.sp-promo {
	--sppr-font:        'Inter', sans-serif;
	--sppr-font-size:   14px;
	--sppr-font-weight: 700;
	--sppr-ls:          .02em;
	--sppr-max-width:   1400px;
	--sppr-pad-y:       12px;
	--sppr-pad-x:       24px;
	--sppr-radius:      0px;
	--sppr-predkosc:    25s;
	--sppr-tlo-od:      #1A2540;
	--sppr-tlo-do:      #264360;
	--sppr-tekst:       #FFFFFF;
	--sppr-akcent:      #D4A017;
	--sppr-close:       #FFFFFF;

	font-family: var(--sppr-font);
	color: var(--sppr-tekst);
	position: relative;
	z-index: 95;
	border-radius: var(--sppr-radius);
	overflow: hidden;
	border-top: 1px solid rgba(212,160,23,.20);
	border-bottom: 1px solid rgba(212,160,23,.15);
}
.sp-promo * { box-sizing: border-box; }

/* ===== TŁA ===== */
.sp-promo--tlo-gradient {
	background: linear-gradient(135deg, var(--sppr-tlo-od), var(--sppr-tlo-do));
}
.sp-promo--tlo-solid {
	background: var(--sppr-tlo-od);
}
.sp-promo--tlo-gold {
	background: linear-gradient(135deg, var(--sppr-akcent), color-mix(in srgb, var(--sppr-akcent) 75%, #FFF));
	color: var(--sppr-tlo-od);
	--sppr-tekst: var(--sppr-tlo-od);
}
.sp-promo--tlo-gold .sp-promo__dot { background: var(--sppr-tlo-od); box-shadow: 0 0 0 4px rgba(26,37,64,.20); }
.sp-promo--tlo-gold .sp-promo__close { color: var(--sppr-tlo-od); }

/* Subtelny glow w tle (jak na Strefie Klienta) */
.sp-promo::before {
	content: "";
	position: absolute;
	top: -50%; left: 10%;
	width: 220px; height: 220px;
	background: radial-gradient(circle, var(--sppr-akcent) 0%, transparent 65%);
	opacity: .08;
	pointer-events: none;
	border-radius: 50%;
}

/* ===== POZYCJA ===== */
.sp-promo--pos-sticky-top {
	position: sticky;
	top: 0;
	z-index: 99;
	box-shadow: 0 4px 14px rgba(0,0,0,.18);
}
.sp-promo--pos-sticky-menu {
	position: sticky;
	top: 0;
	z-index: 95;
}

/* ===== SZEROKOŚĆ ===== */
.sp-promo--w-full {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}
.sp-promo--w-container {
	width: 100%;
	max-width: var(--sppr-max-width);
	margin-left: auto;
	margin-right: auto;
}

/* ===== INNER (clickable wrapper) ===== */
.sp-promo__inner {
	display: flex;
	align-items: center;
	width: 100%;
	padding: var(--sppr-pad-y) var(--sppr-pad-x);
	color: inherit;
	text-decoration: none;
	overflow: hidden;
	position: relative;
	z-index: 2;
	min-height: calc(var(--sppr-pad-y) * 2 + var(--sppr-font-size) + 6px);
}
.sp-promo--link .sp-promo__inner {
	cursor: pointer;
	transition: filter .2s ease;
}
.sp-promo--link .sp-promo__inner:hover {
	filter: brightness(1.08);
}

/* ===== TRACK ===== */
.sp-promo__track {
	width: 100%;
	overflow: hidden;
	position: relative;
}

/* ===== ITEM (jednostka tekst + dot + separator) ===== */
.sp-promo__item {
	display: inline-flex;
	align-items: center;
	gap: .75em;
	color: var(--sppr-tekst);
	font-size: var(--sppr-font-size);
	font-weight: var(--sppr-font-weight);
	letter-spacing: var(--sppr-ls);
	line-height: 1.4;
	white-space: nowrap;
	padding-right: 1em;
}
.sp-promo__item--center {
	display: flex;
	justify-content: center;
	width: 100%;
}
.sp-promo--uppercase .sp-promo__item {
	text-transform: uppercase;
	letter-spacing: .12em;
}

.sp-promo__dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--sppr-akcent);
	box-shadow: 0 0 0 4px rgba(212,160,23,.22);
	animation: sp-promo-pulse 2.2s ease-in-out infinite;
	flex-shrink: 0;
}
@keyframes sp-promo-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(212,160,23,.22); transform: scale(1); }
	50%      { box-shadow: 0 0 0 9px rgba(212,160,23,.04); transform: scale(1.1); }
}

.sp-promo__sep {
	display: inline-block;
	color: var(--sppr-akcent);
	opacity: .55;
	font-weight: 800;
	margin: 0 .35em;
	flex-shrink: 0;
}

/* =========================================================
   TRYB: MARQUEE (ruchomy)
   ========================================================= */
.sp-promo--tryb-marquee .sp-promo__track {
	display: flex;
	flex-wrap: nowrap;
}
.sp-promo--tryb-marquee .sp-promo__marquee {
	display: inline-flex;
	flex-shrink: 0;
	min-width: 100%;
	animation: sp-promo-scroll var(--sppr-predkosc) linear infinite;
	will-change: transform;
}
.sp-promo[data-sp-pause-hover="1"]:hover .sp-promo__marquee {
	animation-play-state: paused;
}
@keyframes sp-promo-scroll {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-100%); }
}

/* Fade out na krawędziach (mask) — premium look */
.sp-promo--tryb-marquee .sp-promo__track {
	-webkit-mask-image: linear-gradient(90deg, transparent 0, #000 40px, #000 calc(100% - 40px), transparent 100%);
	mask-image: linear-gradient(90deg, transparent 0, #000 40px, #000 calc(100% - 40px), transparent 100%);
}

/* =========================================================
   TRYB: STATIC
   ========================================================= */
.sp-promo--tryb-static .sp-promo__track {
	display: flex;
	justify-content: center;
}

/* =========================================================
   TRYB: PULSE
   ========================================================= */
.sp-promo--tryb-pulse .sp-promo__track {
	display: flex;
	justify-content: center;
}
.sp-promo--tryb-pulse .sp-promo__item {
	animation: sp-promo-text-pulse 2.4s ease-in-out infinite;
}
@keyframes sp-promo-text-pulse {
	0%, 100% { transform: scale(1); opacity: .92; }
	50%      { transform: scale(1.02); opacity: 1; }
}

/* =========================================================
   PRZYCISK ZAMKNIJ
   ========================================================= */
.sp-promo__close {
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	background: rgba(255,255,255,.10);
	border: 1px solid rgba(255,255,255,.15);
	border-radius: 8px;
	color: var(--sppr-close);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 5;
	transition: background .2s ease, transform .2s ease, opacity .2s ease;
	opacity: .65;
	padding: 0;
}
.sp-promo__close:hover {
	opacity: 1;
	background: rgba(255,255,255,.18);
	transform: translateY(-50%) scale(1.1);
}
.sp-promo__close svg {
	width: 14px;
	height: 14px;
}
.sp-promo--closeable .sp-promo__inner {
	padding-right: calc(var(--sppr-pad-x) + 40px);
}

/* =========================================================
   MOBILE
   ========================================================= */
@media (max-width: 600px) {
	.sp-promo {
		--sppr-pad-y: 10px;
		--sppr-pad-x: 16px;
		--sppr-font-size: 12px;
	}
	.sp-promo__close { width: 24px; height: 24px; right: 8px; }
	.sp-promo__close svg { width: 12px; height: 12px; }
}

/* Schowany przez JS */
.sp-promo.is-hidden {
	display: none !important;
}
