/*
	Homepage-only enhancements.
	Shared homepage layout, spacing, and breakpoint logic live in style.css.
	This file intentionally stays small so the front page doesn't run a second
	responsive system on top of the main theme.
*/

.rxfloor-page-home .rxfloor-logo-ribbon {
	--rxfloor-logo-ribbon-gap: clamp(0.85rem, 1.6vw, 1.1rem);
	position: relative;
	z-index: 3;
	width: auto;
	margin-top: 0;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding:
		clamp(0.9rem, 1.7vw, 1.15rem)
		max(1.25rem, calc((100vw - var(--rx-home-hero-inner-width)) / 2 + 0.75rem));
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: center;
	gap: clamp(0.75rem, 1.5vw, 1.1rem);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	background: linear-gradient(180deg, rgba(8, 12, 18, 0.94) 0%, rgba(14, 19, 25, 0.98) 100%);
	overflow: hidden;
	user-select: none;
	-webkit-user-select: none;
}

.rxfloor-page-home .rxfloor-logo-ribbon::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			90deg,
			rgba(164, 213, 0, 0.08) 0%,
			rgba(164, 213, 0, 0) 18%,
			rgba(164, 213, 0, 0) 82%,
			rgba(164, 213, 0, 0.08) 100%
		);
	pointer-events: none;
}

.rxfloor-page-home .rxfloor-logo-ribbon > * {
	position: relative;
	z-index: 1;
}

.rxfloor-page-home .rxfloor-logo-ribbon-arrow {
	width: 3rem;
	height: 3rem;
	padding: 0;
	display: grid;
	place-items: center;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 999px;
	background: rgba(10, 15, 20, 0.82);
	color: rgba(255, 255, 255, 0.94);
	cursor: pointer;
	transition:
		transform 180ms ease,
		border-color 180ms ease,
		background-color 180ms ease,
		color 180ms ease;
}

.rxfloor-page-home .rxfloor-logo-ribbon-arrow:hover,
.rxfloor-page-home .rxfloor-logo-ribbon-arrow:focus-visible {
	transform: translateY(-1px);
	border-color: rgba(164, 213, 0, 0.34);
	background: rgba(164, 213, 0, 0.12);
	color: var(--rx-color-accent-on-dark);
}

.rxfloor-page-home .rxfloor-logo-ribbon-arrow:focus-visible {
	outline: 2px solid rgba(164, 213, 0, 0.42);
	outline-offset: 2px;
}

.rxfloor-page-home .rxfloor-logo-ribbon-arrow svg {
	width: 1.1rem;
	height: 1.1rem;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
	fill: none;
}

.rxfloor-page-home .rxfloor-logo-ribbon-viewport {
	min-width: 0;
	overflow: hidden;
	mask-image: linear-gradient(90deg, transparent 0, #000 4rem, #000 calc(100% - 4rem), transparent 100%);
	-webkit-mask-image:
		linear-gradient(90deg, transparent 0, #000 4rem, #000 calc(100% - 4rem), transparent 100%);
	touch-action: pan-y pinch-zoom;
	cursor: grab;
}

.rxfloor-page-home .rxfloor-logo-ribbon-track {
	display: flex;
	align-items: stretch;
	gap: var(--rxfloor-logo-ribbon-gap);
	width: max-content;
	will-change: transform;
	transform: translate3d(0, 0, 0);
}

.rxfloor-page-home .rxfloor-logo-ribbon.is-dragging .rxfloor-logo-ribbon-viewport {
	cursor: grabbing;
}

.rxfloor-page-home .rxfloor-logo-ribbon-group {
	display: flex;
	align-items: stretch;
	gap: var(--rxfloor-logo-ribbon-gap);
}

.rxfloor-page-home .rxfloor-logo-ribbon-item {
	flex: 0 0 clamp(10.75rem, 13vw, 12.75rem);
	min-height: clamp(5rem, 6vw, 5.8rem);
	padding: clamp(0.75rem, 1.4vw, 0.95rem);
	display: grid;
	align-content: center;
	justify-items: center;
	gap: 0.55rem;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 0.95rem;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
		rgba(8, 12, 18, 0.4);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
	transition:
		transform 220ms ease,
		border-color 220ms ease,
		background-color 220ms ease,
		opacity 220ms ease;
}

.rxfloor-page-home .rxfloor-logo-ribbon-item:hover {
	transform: translateY(-2px);
	border-color: rgba(164, 213, 0, 0.28);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03)),
		rgba(8, 12, 18, 0.52);
}

.rxfloor-page-home .rxfloor-logo-ribbon-item img {
	width: clamp(6.6rem, 8.4vw, 7.75rem);
	height: 2.2rem;
	display: block;
	object-fit: contain;
	filter: none;
	opacity: 1;
}

.rxfloor-page-home .rxfloor-logo-ribbon-item span {
	color: rgba(255, 255, 255, 0.72);
	font-family: var(--rx-font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}

@media (min-width: 641px) {
	.rxfloor-page-home .rxfloor-logo-ribbon {
		margin-top: calc(var(--rx-home-stack-gap) * -1);
	}
}

@media (max-width: 1024px) {
	.rxfloor-page-home .rxfloor-logo-ribbon {
		padding-inline: max(1rem, calc((100vw - var(--rx-width)) / 2 + 0.75rem));
		gap: 0.7rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-arrow {
		width: 2.75rem;
		height: 2.75rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-item {
		flex-basis: clamp(9.75rem, 34vw, 11rem);
		min-height: 4.9rem;
	}
}

@media (max-width: 640px) {
	.rxfloor-page-home .rxfloor-logo-ribbon {
		--rxfloor-logo-ribbon-gap: 0.6rem;
		grid-template-columns: minmax(0, 1fr);
		margin-top: 0;
		padding-block: 0.7rem;
		padding-inline: 3.35rem;
		gap: 0;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-viewport {
		mask-image: linear-gradient(90deg, transparent 0, #000 1.15rem, #000 calc(100% - 1.15rem), transparent 100%);
		-webkit-mask-image:
			linear-gradient(90deg, transparent 0, #000 1.15rem, #000 calc(100% - 1.15rem), transparent 100%);
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-arrow {
		position: absolute;
		inset-block-start: 50%;
		width: 2.3rem;
		height: 2.3rem;
		margin-top: -1.15rem;
		background: rgba(7, 11, 16, 0.9);
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-arrow.is-prev {
		inset-inline-start: 0.55rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-arrow.is-next {
		inset-inline-end: 0.55rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-item {
		flex-basis: clamp(7.75rem, 35vw, 8.6rem);
		min-height: 4.2rem;
		padding: 0.58rem 0.45rem;
		gap: 0.38rem;
		border-radius: 0.78rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-item img {
		width: 4.6rem;
		height: 1.45rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-item span {
		font-size: 0.56rem;
		letter-spacing: 0.08em;
	}
}

@media (max-width: 420px) {
	.rxfloor-page-home .rxfloor-logo-ribbon {
		padding-inline: 3rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-arrow {
		width: 2.1rem;
		height: 2.1rem;
		margin-top: -1.05rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-item {
		flex-basis: clamp(7rem, 38vw, 7.7rem);
		min-height: 3.95rem;
		padding: 0.52rem 0.38rem;
	}

	.rxfloor-page-home .rxfloor-logo-ribbon-item img {
		width: 4.1rem;
		height: 1.3rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.rxfloor-page-home .rxfloor-logo-ribbon-arrow,
	.rxfloor-page-home .rxfloor-logo-ribbon-item {
		transition: none;
	}
}
