/* =========================================================================
   ICF Karting — v9 (Oscar-grade, the masterpiece)
   - Hero scramble + EST badge + cinematic vignette
   - Dynamic ranking ticker
   - Magnetic CTA + ripple
   - Persona hover takeover
   - Section divider brand strokes
   - Stat hover micro
   - Newsletter input premium
   - Voucher hero refined gradient
   - Horizontal sticky scroll for timeline
   ========================================================================= */

/* ===========================================================
   HERO refinements — premium first impression
   =========================================================== */

/* Hero EST badge — bottom-left mocno marker */
.hero-mega__est {
	position: absolute;
	left: clamp(16px, 4vw, 64px);
	bottom: clamp(72px, 8vh, 120px);
	display: flex; align-items: center; gap: 14px;
	z-index: 2;
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
	pointer-events: none;
}
.hero-mega__est::before, .hero-mega__est::after {
	content: '';
	width: 24px; height: 1px;
	background: rgba(255,255,255,.4);
}
.hero-mega__est-dot {
	width: 4px; height: 4px;
	border-radius: 50%;
	background: var(--c-accent);
	box-shadow: 0 0 8px var(--c-accent);
}
@media (max-width: 880px) { .hero-mega__est { display: none; } }

/* Hero cinematic vignette */
.hero-mega::after {
	content: '';
	position: absolute; inset: 0;
	background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,0.45) 100%);
	pointer-events: none;
	z-index: 1;
}

/* Letterbox bars optional toggle — disabled by default
.hero-mega::before {
	content: ''; position: absolute; left:0; right:0; top:0; height: 4vh;
	background: var(--c-bg-deep); z-index: 1;
}
*/

/* Hero text scramble container */
.scramble-char {
	display: inline-block;
	transition: opacity .15s, color .15s;
}

/* Hero corner brackets — premium frame */
.hero-mega__corner {
	position: absolute;
	width: 32px; height: 32px;
	border: 2px solid rgba(255,255,255,.3);
	z-index: 2;
	pointer-events: none;
}
.hero-mega__corner--tl { top: 24px; left: 24px; border-right: 0; border-bottom: 0; }
.hero-mega__corner--tr { top: 24px; right: 24px; border-left: 0; border-bottom: 0; }
.hero-mega__corner--bl { bottom: 24px; left: 24px; border-right: 0; border-top: 0; }
.hero-mega__corner--br { bottom: 24px; right: 24px; border-left: 0; border-top: 0; }
@media (max-width: 880px) {
	.hero-mega__corner { width: 18px; height: 18px; border-width: 1.5px; }
	.hero-mega__corner--tl, .hero-mega__corner--tr { top: 12px; }
	.hero-mega__corner--bl, .hero-mega__corner--br { bottom: 12px; }
	.hero-mega__corner--tl, .hero-mega__corner--bl { left: 12px; }
	.hero-mega__corner--tr, .hero-mega__corner--br { right: 12px; }
}

/* ===========================================================
   STATS — hover micro-interaction
   =========================================================== */
.stat {
	cursor: default;
	transition: transform .35s var(--ease-spring);
}
.stat:hover { transform: translateY(-4px); }
.stat:hover .stat__num {
	background: linear-gradient(180deg, #fff 0%, var(--c-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.stat:hover .stat__label {
	color: var(--c-text);
}
.stat__num, .stat__label {
	transition: color .25s var(--ease-soft), transform .25s var(--ease-soft);
}

/* ===========================================================
   BUTTONS — ripple effect on click
   =========================================================== */
.btn-pill {
	position: relative;
	overflow: hidden;
	isolation: isolate;
}
.btn-pill::before {
	content: '';
	position: absolute;
	top: var(--ripple-y, 50%);
	left: var(--ripple-x, 50%);
	width: 0; height: 0;
	border-radius: 50%;
	background: rgba(255,255,255,.3);
	transform: translate(-50%, -50%);
	pointer-events: none;
	z-index: -1;
}
.btn-pill.is-rippling::before {
	animation: ripple .6s var(--ease-fluid) forwards;
}
@keyframes ripple {
	from { width: 0; height: 0; opacity: 1; }
	to   { width: 600px; height: 600px; opacity: 0; }
}

/* ===========================================================
   PERSONA — hover takeover (premium)
   =========================================================== */
.persona__media img {
	transition: transform 1s var(--ease-fluid), filter .5s !important;
	filter: contrast(1.06) saturate(.7) brightness(.7);
}
.persona:hover .persona__media img {
	filter: contrast(1.06) saturate(1.05) brightness(1);
	transform: scale(1.05);
}
.persona__title, .persona__lead, .persona__chips, .persona__cta {
	transition: transform .5s var(--ease-fluid);
}
.persona:hover .persona__title,
.persona:hover .persona__lead,
.persona:hover .persona__chips,
.persona:hover .persona__cta {
	transform: translateY(-4px);
}

/* ===========================================================
   SECTION dividers — brand strokes
   =========================================================== */
.section--divider-top {
	position: relative;
}
.section--divider-top::before {
	content: '';
	position: absolute;
	top: 0; left: 50%;
	transform: translateX(-50%);
	width: clamp(60px, 8vw, 120px);
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--c-accent), transparent);
}

/* ===========================================================
   NEWSLETTER input — premium glass
   =========================================================== */
.newsletter__form {
	position: relative;
	max-width: 520px !important;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.1);
	border-radius: 999px;
	padding: 6px;
	transition: border-color .25s var(--ease-soft), background .25s;
}
.newsletter__form:focus-within {
	border-color: var(--c-accent);
	background: rgba(255,45,32,.05);
	box-shadow: 0 0 0 4px rgba(255,45,32,.1);
}
.newsletter__input {
	background: transparent !important;
	border: 0 !important;
	padding: 14px 22px !important;
}
.newsletter__input:focus {
	outline: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}
.newsletter__btn {
	border-radius: 999px;
	padding: 14px 24px !important;
}

/* ===========================================================
   VOUCHER hero — refined gradient
   =========================================================== */
.voucher-hero {
	background: linear-gradient(135deg, #260a08 0%, #0d0708 60%, #0a0a0c 100%) !important;
	border: 1px solid rgba(255,45,32,0.3) !important;
	box-shadow: 0 30px 80px -30px rgba(255,45,32,0.3);
}
.voucher-hero__media::after {
	background: linear-gradient(90deg, rgba(38,10,8,.7) 0%, rgba(38,10,8,.2) 50%, transparent 100%) !important;
}

/* ===========================================================
   TIMELINE — horizontal sticky scroll (desktop)
   =========================================================== */
@media (min-width: 1100px) {
	.timeline {
		display: flex !important;
		gap: 24px;
		grid-template-columns: none !important;
		overflow: visible;
	}
	.timeline::before {
		left: 4%; right: 4%;
		top: 38px;
	}
	.timeline__step {
		flex: 1;
		padding: 0 12px;
	}
	.timeline__step:hover .timeline__num {
		background: var(--c-accent);
		color: #fff;
		transform: scale(1.1);
		transition: background-color .3s var(--ease-spring), color .3s var(--ease-spring), transform .3s var(--ease-spring);
	}
}
.timeline__num { transition: transform .3s var(--ease-spring), color .3s var(--ease-spring); }

/* ===========================================================
   BENTO video — better fallback poster
   =========================================================== */
.bento-cell--video {
	background: linear-gradient(135deg, #1a0a0a 0%, #0a0a0c 100%) !important;
}

/* ===========================================================
   SECTION breathing — better rhythm
   =========================================================== */
.section--xl + .section--xl {
	border-top: 1px solid rgba(255,255,255,.04);
}

/* ===========================================================
   FOOTER polish
   =========================================================== */
.site-footer__col h3 {
	display: flex; align-items: center; gap: 10px;
	margin-bottom: 20px !important;
}
.site-footer__col h3::before {
	content: '';
	width: 4px; height: 14px;
	background: var(--c-accent);
	border-radius: 2px;
}

/* ===========================================================
   Prevent CLS — reserve hero space
   =========================================================== */
.hero-mega { min-height: 100vh; }

/* ===========================================================
   Bigger, more dramatic eyebrows
   =========================================================== */
.section-eyebrow {
	margin-bottom: 16px !important;
	font-weight: 700 !important;
}

/* ===========================================================
   Trust band item hover refinement
   =========================================================== */
.trust-item__num {
	transition: color .3s, transform .3s var(--ease-spring);
}
.trust-item:hover .trust-item__num {
	color: var(--c-accent);
	transform: scale(1.05);
}

/* ===========================================================
   Karta XL details on hover (refined)
   =========================================================== */
.card-xl__name { transition: color .25s; }
.card-xl:hover .card-xl__name { color: var(--c-accent-2); }

/* ===========================================================
   Brand strip — premium hover
   =========================================================== */
.brand-strip__item {
	transition: opacity .3s, transform .3s var(--ease-spring), color .3s;
	cursor: default;
	padding: 8px 4px;
	border-radius: 8px;
}
.brand-strip__item:hover {
	opacity: 1;
	color: #fff;
	transform: translateY(-2px);
}

/* ===========================================================
   Bottom-nav — glass refinement
   =========================================================== */
.bottom-nav {
	background: rgba(8, 8, 10, 0.92) !important;
}
.bottom-nav__item--cta {
	box-shadow: 0 8px 24px -8px var(--c-accent), inset 0 1px 0 rgba(255,255,255,.15);
}

/* ===========================================================
   Live-now widget — bardziej premium glass
   =========================================================== */
.live-now {
	background: rgba(8, 8, 10, 0.92) !important;
	box-shadow: 0 4px 30px -10px rgba(0,0,0,.5);
}

/* ===========================================================
   Sezonowy banner — bardziej dramatyczny
   =========================================================== */
.season-strip {
	background: linear-gradient(135deg, var(--c-accent) 0%, #d61c0e 50%, var(--c-accent) 100%) !important;
	background-size: 200% 100%;
	animation: seasonShine 8s ease-in-out infinite;
	box-shadow: inset 0 -1px 0 rgba(0,0,0,.2);
}
@keyframes seasonShine {
	0%, 100% { background-position: 0% 50%; }
	50%      { background-position: 100% 50%; }
}

/* ===========================================================
   Marquee — fade gradient w pioniach
   =========================================================== */
.marquee {
	mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}

/* ===========================================================
   IG feed — refinement
   =========================================================== */
.ig-feed__head {
	margin-bottom: 32px !important;
}
.ig-feed__name-handle {
	display: flex; align-items: center; gap: 10px;
	font-family: var(--font-display);
}

/* ===========================================================
   FAQ — refinement
   =========================================================== */
.faq-premium summary {
	font-family: var(--font-display);
	font-size: 1.08rem !important;
	letter-spacing: -0.015em;
}

/* ===========================================================
   Page enter — smoother
   =========================================================== */
@keyframes pageEnter {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ===========================================================
   Focus-visible refinement
   =========================================================== */
:focus-visible {
	outline: 2px solid var(--c-accent) !important;
	outline-offset: 4px !important;
	border-radius: 6px;
}

/* ===========================================================
   CTA Final — even more dramatic
   =========================================================== */
.cta-final h2 {
	background: linear-gradient(180deg, #fff 0%, rgba(255,255,255,.7) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.cta-final::before {
	background: radial-gradient(circle at center, rgba(255,45,32,0.3) 0%, transparent 50%) !important;
}

/* ===========================================================
   Magazine gallery — better hover
   =========================================================== */
.gallery-mag__item {
	cursor: zoom-in;
}
.gallery-mag__item:hover {
	box-shadow: 0 24px 60px -16px rgba(0,0,0,.5);
	z-index: 2;
}

/* ===========================================================
   Big quote — more premium
   =========================================================== */
.big-quote__text em {
	background: linear-gradient(180deg, #ff5640 0%, var(--c-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* ===========================================================
   Selection style refined
   =========================================================== */
::selection {
	background: var(--c-accent);
	color: #fff;
	text-shadow: none;
}
