/**
 * Главная — единые отступы и заголовки блоков (SDK).
 */
body.home,
body.page-template-template-sdk-home {
	--twirion-home-block-max: var(--twirion-content-max, 1400px);
	--twirion-home-section-gap: var(--twirion-section-gap);
	--twirion-home-section-margin: var(--twirion-section-margin);
	--twirion-home-section-pad-x: 20px;
	--twirion-home-section-head-mb: 40px;
	--twirion-home-block-pad-x: 0;
	--twirion-home-block-pad-top: var(--twirion-home-section-gap);
	--twirion-home-block-head-gap: 24px;
	--twirion-home-content-width: var(--twirion-content-width, min(1400px, calc(100vw - 40px)));
}

/* Обёртки секций — одна ширина, без боковых padding */
body.home .twirion-home-latest-products,
body.home .twirion-home-reviews,
body.home .twirion-home-why-choose,
body.home .twirion-home-certifiers,
body.home .home__top-categories--wrapper,
body.home .sdk-cats.twirion-home-explore-categories,
body.page-template-template-sdk-home .twirion-home-latest-products,
body.page-template-template-sdk-home .twirion-home-reviews,
body.page-template-template-sdk-home .twirion-home-why-choose,
body.page-template-template-sdk-home .twirion-home-certifiers,
body.page-template-template-sdk-home .home__top-categories--wrapper,
body.page-template-template-sdk-home .sdk-cats.twirion-home-explore-categories {
	box-sizing: border-box;
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

body.home .twirion-home-trust-bar.sdk-trust,
body.page-template-template-sdk-home .twirion-home-trust-bar.sdk-trust {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

body.home .twirion-home-roster.sdk-roster-block,
body.page-template-template-sdk-home .twirion-home-roster.sdk-roster-block,
body.home .twirion-home-athletes-showcase.sdk-roster-block,
body.page-template-template-sdk-home .twirion-home-athletes-showcase.sdk-roster-block {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

.twirion-home-reviews,
.twirion-product-reviews {
	padding-bottom: 0;
}

body.single-product .twirion-product-reviews {
	width: 100%;
	max-width: 100%;
	margin-top: 0;
	padding-top: var(--twirion-section-margin);
	padding-bottom: var(--twirion-section-margin);
}

/* Строка заголовка блока (New arrivals, Reviews, Trending, Why Choose) */
.twirion-home-section-head,
.twirion-home-reviews__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 0 0 var(--twirion-home-block-head-gap);
	padding: 0;
}

/* Текст заголовка — один стиль (перебивает inline style у WPBakery) */
.twirion-home-section-title,
body.home h1.vc_custom_heading.vc_do_custom_heading,
body.home h2.vc_custom_heading.vc_do_custom_heading,
body.home .vc_custom_heading.vc_do_custom_heading,
body.page-template-template-sdk-home h1.vc_custom_heading.vc_do_custom_heading,
body.page-template-template-sdk-home h2.vc_custom_heading.vc_do_custom_heading,
body.page-template-template-sdk-home .vc_custom_heading.vc_do_custom_heading {
	margin: 0 !important;
	padding: 0 !important;
	border: 0;
	font-family: var(--sdk-global-font, "Kanit", sans-serif) !important;
	font-size: clamp(28px, 3.2vw, 46px) !important;
	font-weight: 600 !important;
	line-height: 1.1 !important;
	letter-spacing: 0 !important;
	color: #11132a !important;
	text-align: left !important;
	text-transform: none !important;
}

/* New Arrivals — sdk-cats-header (06-header-new-arrivals.html) */
.twirion-home-latest-products .sdk-cats-header {
	text-align: center;
	margin-bottom: var(--twirion-home-section-head-mb);
}

.twirion-home-latest-products .sdk-cats-label {
	display: inline-block;
	font-family: "DM Sans", sans-serif;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: #6a2fff;
	background: rgba(106, 47, 255, 0.08);
	padding: 8px 22px;
	border-radius: 99px;
	margin-bottom: 18px;
}

.twirion-home-latest-products .sdk-cats-title {
	margin: 0 !important;
	padding: 0 !important;
	border: 0;
	font-family: var(--sdk-global-font, "Kanit", sans-serif) !important;
	font-size: 42px !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	letter-spacing: 0 !important;
	color: #0a0a0a !important;
	text-align: center !important;
	text-transform: none !important;
}

.twirion-home-latest-products .sdk-cats-header .sdk-roster-subtitle {
	margin: 12px auto 0;
}

@media (max-width: 768px) {
	.twirion-home-latest-products .sdk-cats-title {
		font-size: 32px !important;
	}

	.twirion-home-latest-products .sdk-cats-header .sdk-roster-subtitle {
		font-size: 16px;
	}
}

/* Catalog row: заголовок внутри section-head (разметка как у New arrivals) */
body.home .twirion-home-teams-heading .twirion-home-section-head,
body.page-template-template-sdk-home .twirion-home-teams-heading .twirion-home-section-head,
body.home .vc_row.dt-default .twirion-home-section-head,
body.page-template-template-sdk-home .vc_row.dt-default .twirion-home-section-head {
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin-left: auto;
	margin-right: auto;
	padding: 0;
}

body.home .twirion-home-teams-heading,
body.page-template-template-sdk-home .twirion-home-teams-heading {
	box-sizing: border-box;
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.twirion-home-certifiers__row {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 28px;
	flex-wrap: nowrap;
}

.twirion-home-certifiers__item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	background: #ffffff;
	border: 1px solid #ece7fb;
	border-radius: 999px;
}

.twirion-home-certifiers__item img {
	width: 22px;
	height: 22px;
	object-fit: contain;
}

.twirion-home-certifiers__item span {
	font-size: 14px;
	font-weight: 600;
	color: #1d2130;
	letter-spacing: 0.03em;
}

.twirion-home-hero-mrg__section--countries {
	margin-top: 8px;
	padding-top: 4px;
}

a.twirion-mrg-gallery--catalog-link {
	display: block;
	color: inherit;
	text-decoration: none;
	cursor: pointer;
}

a.twirion-mrg-gallery--catalog-link:focus-visible {
	outline: 2px solid var(--sdk-accent, #6a2fff);
	outline-offset: 4px;
	border-radius: 8px;
}

.twirion-home-hero-mrg .mrg-row {
	margin: 10px 0;
}

.twirion-home-hero-mrg .mrg-item {
	border-radius: 50%;
	overflow: hidden;
}

.twirion-home-hero-mrg .mrg-item img {
	border-radius: 50%;
}

/* Trust Block (P1) — под hero */
.sdk-trust.twirion-home-trust-bar {
	background: #f9f8ff;
	border-bottom: 1px solid rgba(106, 47, 255, 0.08);
	padding: 0 var(--twirion-home-section-pad-x);
	overflow: hidden;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-certifiers {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin: 0 auto;
	padding: 16px 0 0;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-certifiers img {
	width: 32px;
	height: 32px;
	object-fit: contain;
	opacity: 0.9;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-inner {
	display: flex;
	justify-content: center;
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin: 0 auto;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-item {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	padding: 22px 20px;
	border-right: 1px solid rgba(106, 47, 255, 0.06);
	transition: background 0.3s ease;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-item:last-child {
	border-right: none;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-item:hover {
	background: rgba(106, 47, 255, 0.04);
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-icon {
	width: 44px;
	height: 44px;
	background: var(--sdk-accent, #6a2fff);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	flex-shrink: 0;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-text h4 {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 14px;
	font-weight: 600;
	color: #0a0a0a;
	line-height: 1.2;
	margin: 0;
}

.sdk-trust.twirion-home-trust-bar .sdk-trust-text p {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 12px;
	color: #888;
	line-height: 1.3;
	margin: 2px 0 0;
}

/* Header trust bar on home: keep catalog/header compact styles (home-sections must not leak). */
body.home .sdk-header-trust-bar .sdk-trust-item,
body.page-template-template-sdk-home .sdk-header-trust-bar .sdk-trust-item {
	flex: none;
	display: inline-flex;
	align-items: center;
	gap: 0;
	padding: 0;
	border: none;
	background: transparent;
	white-space: nowrap;
}

body.home .sdk-header-trust-bar .sdk-trust-item:hover,
body.page-template-template-sdk-home .sdk-header-trust-bar .sdk-trust-item:hover {
	background: transparent;
}

@media (max-width: 900px) {
	.sdk-trust.twirion-home-trust-bar .sdk-trust-inner {
		flex-wrap: wrap;
	}

	.sdk-trust.twirion-home-trust-bar .sdk-trust-item {
		flex: 1 1 45%;
		border-right: none;
		border-bottom: 1px solid rgba(106, 47, 255, 0.06);
	}
}

@media (max-width: 520px) {
	.sdk-trust.twirion-home-trust-bar .sdk-trust-item {
		flex: 1 1 100%;
	}
}

/* Athletes showcase (sdk-roster-block) */
.sdk-roster-block {
	padding: 0;
	position: relative;
	overflow: visible;
}

body.home .sdk-roster-block .sdk-roster-header,
body.home .sdk-roster-block .sdk-roster-tabs,
body.page-template-template-sdk-home .sdk-roster-block .sdk-roster-header,
body.page-template-template-sdk-home .sdk-roster-block .sdk-roster-tabs {
	box-sizing: border-box;
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin-left: auto;
	margin-right: auto;
}

.sdk-roster-block:not(.twirion-home-athletes-showcase)::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background:
		radial-gradient(ellipse 600px 400px at 10% 20%, rgba(106, 47, 255, 0.06) 0%, transparent 70%),
		radial-gradient(ellipse 500px 300px at 90% 80%, rgba(27, 195, 101, 0.05) 0%, transparent 70%);
	pointer-events: none;
	z-index: 0;
}

.sdk-roster-block > * {
	position: relative;
	z-index: 1;
}

.sdk-roster-header {
	text-align: center;
	margin-bottom: var(--twirion-home-section-head-mb);
}

.sdk-roster-label {
	display: inline-block;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--sdk-accent, #6a2fff);
	background: rgba(106, 47, 255, 0.08);
	padding: 8px 24px;
	border-radius: 99px;
	margin-bottom: 20px;
}

.sdk-roster-title {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 52px;
	font-weight: 800;
	color: #0a0a0a;
	line-height: 1.1;
	margin: 0 0 18px;
	letter-spacing: -1px;
}

.sdk-roster-subtitle {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 18px;
	color: #555;
	max-width: 550px;
	margin: 0 auto;
	line-height: 1.6;
}

/* Карусель игроков — на всю ширину экрана */
body.home .sdk-roster-block:has(.twirion-home-players-carousel),
body.page-template-template-sdk-home .sdk-roster-block:has(.twirion-home-players-carousel),
body.home #main > .wf-wrap:has(.twirion-home-players-carousel),
body.page-template-template-sdk-home #main > .wf-wrap:has(.twirion-home-players-carousel),
.vc_row:has(.twirion-home-players-carousel) .vc_column-inner,
.vc_row:has(.twirion-home-players-carousel) .wpb_wrapper,
.vc_row:has(.twirion-home-players-carousel) .wpb_text_column {
	overflow: visible;
}

.twirion-home-players-carousel {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-bottom: var(--twirion-home-section-head-mb);
	overflow: visible;
	box-sizing: border-box;
}

.twirion-home-players-carousel .mrg-gallery-container {
	width: 100%;
	max-width: 100%;
	margin-left: 0;
	margin-right: 0;
	overflow: hidden;
	box-sizing: border-box;
}

.twirion-home-players-carousel .mrg-row {
	overflow: hidden;
	width: 100%;
	margin: 0;
}

.twirion-home-players-carousel__title {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 22px;
	font-weight: 700;
	text-align: center;
	color: #0a0a0a;
	margin: 0 0 24px;
}

.twirion-home-players-carousel__gallery.mrg-gallery-container {
	margin-bottom: 0;
}

.twirion-home-players-carousel__gallery .mrg-row {
	margin: 0;
}

.twirion-home-players-carousel__gallery .mrg-track {
	display: flex;
	align-items: flex-start;
	gap: 18px;
}

.twirion-home-trending-player.twirion-player-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	flex: 0 0 auto;
	width: 132px;
	max-width: none;
	margin: 0;
	text-decoration: none;
	color: inherit;
}

.twirion-home-trending-player__photo,
.twirion-home-trending-player__placeholder {
	width: 120px;
	height: 120px;
	border-radius: 999px;
	object-fit: cover;
	background: #e8e9ef;
	border: none;
	box-sizing: border-box;
}

.twirion-home-trending-player__placeholder {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 14px;
	font-weight: 500;
	color: #9a9eb0;
}

.twirion-home-trending-player .twirion-player-item__name {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 15px;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
	color: #202536;
}

.twirion-home-trending-player .twirion-player-item__sport {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 13px;
	font-weight: 400;
	line-height: 1.35;
	text-align: center;
	color: #6b7085;
}

.sdk-roster-latest {
	margin-top: 8px;
}

.sdk-roster-latest__title {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 22px;
	font-weight: 700;
	text-align: center;
	color: #0a0a0a;
	margin: 0 0 28px;
}

.sdk-roster-tabs--latest {
	margin-bottom: 28px;
}

.sdk-roster-grid.sdk-roster-grid--latest {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin: 0 auto 40px;
}

.sdk-roster-tabs {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin-bottom: var(--twirion-home-section-head-mb);
	flex-wrap: wrap;
	padding: 0 10px;
}

.sdk-roster-tab {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	border: 2px solid var(--sdk-border);
	border-radius: 99px;
	background: #fff;
	cursor: pointer;
	transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 15px;
	font-weight: 600;
	color: #333;
}

.sdk-roster-tab:hover {
	border-color: var(--sdk-accent, #6a2fff);
	background: rgba(106, 47, 255, 0.04);
	transform: translateY(-2px);
}

.sdk-roster-tab.active {
	background: var(--sdk-accent, #6a2fff);
	border-color: var(--sdk-accent, #6a2fff);
	color: #fff;
	box-shadow: 0 8px 25px rgba(106, 47, 255, 0.3);
}

.sdk-roster-tab-icon {
	font-size: 20px;
	line-height: 1;
}

.sdk-roster-tab-text {
	font-weight: 600;
	letter-spacing: 0.3px;
}

.sdk-roster-grid {
	display: none;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--tw-product-grid-gap, 16px);
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin: 0 auto;
	animation: twirion-roster-fade-in 0.5s ease;
}

.sdk-roster-grid.active {
	display: grid;
}

@keyframes twirion-roster-fade-in {
	from {
		opacity: 0;
		transform: translateY(15px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.sdk-roster-grid.sdk-roster-grid--latest.sdk-roster-grid--collapsible:not(.is-expanded) .sdk-roster-card:nth-child(n + 7) {
	display: none;
}

.sdk-roster-grid.sdk-roster-grid--collapsible:not(.is-expanded):not(.sdk-roster-grid--latest) .sdk-roster-card:nth-child(n + 9) {
	display: none;
}

.sdk-roster-expand {
	grid-column: 1 / -1;
	justify-self: center;
	margin-top: 8px;
	padding: 0;
	border: none;
	background: none;
	cursor: pointer;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 15px;
	font-weight: 600;
	color: var(--sdk-accent, #6a2fff) !important;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: opacity 0.2s ease;
}

.sdk-roster-expand:hover {
	opacity: 0.85;
}

.sdk-roster-expand__less {
	display: none;
}

.sdk-roster-grid.is-expanded .sdk-roster-expand__more {
	display: none;
}

.sdk-roster-grid.is-expanded .sdk-roster-expand__less {
	display: inline;
}

.sdk-roster-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 20px;
	overflow: hidden;
	text-decoration: none;
	border: 1px solid var(--sdk-border);
	transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	position: relative;
}

.sdk-roster-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 60px rgba(106, 47, 255, 0.15);
	border-color: rgba(106, 47, 255, 0.2);
}

.sdk-roster-visual {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	isolation: isolate;
}

.sdk-roster-visual__photo {
	position: absolute;
	inset: 0;
	z-index: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 18%;
	display: block;
	pointer-events: none;
}

.sdk-roster-visual--has-photo::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
}

.sdk-roster-card[data-sport-color="basketball"] .sdk-roster-visual:not(.sdk-roster-visual--has-photo) {
	background: linear-gradient(135deg, #7b2d26 0%, #c9482c 40%, #e8744c 100%);
}

.sdk-roster-card[data-sport-color="football"] .sdk-roster-visual:not(.sdk-roster-visual--has-photo) {
	background: linear-gradient(135deg, #1a2040 0%, #2d1854 40%, #4a2d8a 100%);
}

.sdk-roster-card[data-sport-color="baseball"] .sdk-roster-visual:not(.sdk-roster-visual--has-photo) {
	background: linear-gradient(135deg, #0d2137 0%, #1a3a5c 40%, #2a5a8c 100%);
}

.sdk-roster-card[data-sport-color="hockey"] .sdk-roster-visual:not(.sdk-roster-visual--has-photo) {
	background: linear-gradient(135deg, #0a2e3d 0%, #145068 40%, #1e7a9c 100%);
}

.sdk-roster-card[data-sport-color="soccer"] .sdk-roster-visual:not(.sdk-roster-visual--has-photo) {
	background: linear-gradient(135deg, #062a19 0%, #0d4a2e 40%, #1a7a4e 100%);
}

.sdk-roster-card[data-sport-color="mma"] .sdk-roster-visual:not(.sdk-roster-visual--has-photo) {
	background: linear-gradient(135deg, #2a0e06 0%, #4a1a0d 40%, #7a2e15 100%);
}

.sdk-roster-card[data-sport-color="basketball"] .sdk-roster-visual--has-photo::after {
	background: linear-gradient(180deg, rgba(123, 45, 38, 0.15) 0%, rgba(201, 72, 44, 0.55) 45%, rgba(40, 12, 8, 0.88) 100%),
		linear-gradient(135deg, rgba(123, 45, 38, 0.45) 0%, rgba(232, 116, 76, 0.2) 100%);
}

.sdk-roster-card[data-sport-color="football"] .sdk-roster-visual--has-photo::after {
	background: linear-gradient(180deg, rgba(26, 32, 64, 0.2) 0%, rgba(45, 24, 84, 0.55) 45%, rgba(12, 8, 28, 0.9) 100%),
		linear-gradient(135deg, rgba(26, 32, 64, 0.5) 0%, rgba(74, 45, 138, 0.25) 100%);
}

.sdk-roster-card[data-sport-color="baseball"] .sdk-roster-visual--has-photo::after {
	background: linear-gradient(180deg, rgba(13, 33, 55, 0.15) 0%, rgba(26, 58, 92, 0.55) 45%, rgba(6, 16, 32, 0.9) 100%),
		linear-gradient(135deg, rgba(13, 33, 55, 0.48) 0%, rgba(42, 90, 140, 0.22) 100%);
}

.sdk-roster-card[data-sport-color="hockey"] .sdk-roster-visual--has-photo::after {
	background: linear-gradient(180deg, rgba(10, 46, 61, 0.15) 0%, rgba(20, 80, 104, 0.55) 45%, rgba(4, 18, 28, 0.9) 100%),
		linear-gradient(135deg, rgba(10, 46, 61, 0.48) 0%, rgba(30, 122, 156, 0.22) 100%);
}

.sdk-roster-card[data-sport-color="soccer"] .sdk-roster-visual--has-photo::after {
	background: linear-gradient(180deg, rgba(6, 42, 25, 0.15) 0%, rgba(13, 74, 46, 0.55) 45%, rgba(4, 22, 14, 0.9) 100%),
		linear-gradient(135deg, rgba(6, 42, 25, 0.48) 0%, rgba(26, 122, 78, 0.22) 100%);
}

.sdk-roster-card[data-sport-color="mma"] .sdk-roster-visual--has-photo::after {
	background: linear-gradient(180deg, rgba(42, 14, 6, 0.2) 0%, rgba(74, 26, 13, 0.55) 45%, rgba(18, 6, 2, 0.9) 100%),
		linear-gradient(135deg, rgba(42, 14, 6, 0.5) 0%, rgba(122, 46, 21, 0.25) 100%);
}

.sdk-roster-number {
	position: relative;
	z-index: 2;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 88px;
	font-weight: 900;
	color: rgba(255, 255, 255, 0.12);
	line-height: 1;
	letter-spacing: -4px;
	user-select: none;
	transition: all 0.5s;
}

.sdk-roster-card:hover .sdk-roster-number {
	color: rgba(255, 255, 255, 0.2);
	transform: scale(1.08);
}

.sdk-roster-badge-auth {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 2;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 1px;
	color: #fff;
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(8px);
	padding: 5px 14px;
	border-radius: 99px;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.sdk-roster-sport-icon {
	position: absolute;
	bottom: 12px;
	left: 14px;
	z-index: 2;
	font-size: 22px;
	opacity: 0.4;
}

.sdk-roster-visual--has-photo .sdk-roster-number {
	color: rgba(255, 255, 255, 0.18);
}

.sdk-roster-visual--has-photo .sdk-roster-sport-icon {
	opacity: 0.55;
}

.sdk-roster-info {
	padding: 18px 20px 22px;
	display: flex;
	flex-direction: column;
	gap: 3px;
	flex-grow: 1;
}

.sdk-roster-name {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 18px;
	font-weight: 700;
	color: #0a0a0a;
	margin: 0;
	line-height: 1.2;
}

.sdk-roster-team {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 13px;
	font-weight: 500;
	color: var(--sdk-accent, #6a2fff);
	opacity: 0.85;
}

.sdk-roster-item-type {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 12px;
	color: #999;
	font-weight: 500;
	margin-top: 2px;
}

.sdk-roster-cta {
	text-align: center;
	margin-top: var(--twirion-home-section-head-mb);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}

.sdk-roster-btn {
	display: inline-block;
	padding: 16px 50px;
	background: var(--sdk-accent, #6a2fff);
	color: #fff !important;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 16px;
	font-weight: 600;
	text-decoration: none;
	border-radius: 99px;
	transition: all 0.35s ease;
	letter-spacing: 0.5px;
	box-shadow: 0 8px 30px rgba(106, 47, 255, 0.25);
}

.sdk-roster-btn:hover {
	background: #5720e0;
	transform: translateY(-3px);
	box-shadow: 0 12px 40px rgba(106, 47, 255, 0.35);
	color: #fff !important;
}

.sdk-roster-count {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 14px;
	color: #999;
	font-weight: 500;
}

@media (max-width: 480px) {
	.sdk-roster-title {
		font-size: 30px;
	}

	.sdk-roster-tab-text {
		display: none;
	}

	.sdk-roster-tab {
		padding: 10px 14px;
	}

	.sdk-roster-tab-icon {
		font-size: 22px;
	}

	.sdk-roster-number {
		font-size: 48px;
	}

	.sdk-roster-grid.sdk-roster-grid--latest {
		grid-template-columns: 1fr;
	}

	.sdk-cats-grid {
		grid-template-columns: 1fr;
	}
}

.twirion-home-why-choose {
	padding-top: 0;
	padding-bottom: 0;
}

.twirion-home-why-choose__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 20px;
}

.twirion-home-why-choose__item {
	text-align: center;
	padding: 12px 8px;
}

.twirion-home-why-choose__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	margin-bottom: 12px;
	border-radius: 999px;
	background: linear-gradient(180deg, #7d43ff 0%, #6a2fff 100%);
	color: #ffffff;
	font-size: 22px;
	box-shadow: 0 8px 20px rgba(106, 47, 255, 0.28);
}

.twirion-home-why-choose__title {
	margin: 0 0 6px;
	font-size: 23px;
	line-height: 1.2;
	font-weight: 600;
	color: #11132a;
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
}

.twirion-home-why-choose__text {
	margin: 0;
	font-size: 16px;
	line-height: 1.45;
	color: #555b6c;
}

.twirion-home-latest-products .twirion-new-arrivals {
	margin: 0;
}

body.home .home__product-items,
body.page-template-template-sdk-home .home__product-items,
body.home .home__product-items .woo-hover.products.loading-effect-none,
body.page-template-template-sdk-home .home__product-items .woo-hover.products.loading-effect-none {
	width: 100% !important;
	max-width: 100% !important;
}

.twirion-home-latest-products .twirion-new-arrivals {
	width: 100% !important;
	max-width: 100% !important;
}

/* New arrivals — та же сетка и карточки, что в каталоге (wc-grid + wf-cell, twirion-wc-catalog-layout.css) */
body.home .twirion-home-latest-products .twirion-home-product-grid,
body.page-template-template-sdk-home .twirion-home-latest-products .twirion-home-product-grid {
	width: 100%;
	max-width: 100%;
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}

body.home .twirion-home-latest-products .twirion-home-product-grid .woo-hover.products.loading-effect-none,
body.home .twirion-home-latest-products .twirion-home-product-grid .wc-grid.dt-products,
body.home .twirion-home-latest-products .twirion-home-product-grid .wc-grid .dt-css-grid,
body.page-template-template-sdk-home .twirion-home-latest-products .twirion-home-product-grid .woo-hover.products.loading-effect-none,
body.page-template-template-sdk-home .twirion-home-latest-products .twirion-home-product-grid .wc-grid .dt-css-grid {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* Перебить зелёную цену legacy .twirion-new-arrivals */
body.home .twirion-home-product-grid .woo-hover .price-whole,
body.page-template-template-sdk-home .twirion-home-product-grid .woo-hover .price-whole {
	color: #000;
}

body.home .twirion-home-latest-products .twirion-new-arrivals .woocommerce ul.products li.twirion-loop-item > .product-block {
	border: none;
	padding: 0;
}

/* Главная и single product related: 4 карточки в ряд на десктопе (каталог — 3) */
@media (min-width: 1100px) {
	body.home .home__product-items.twirion-new-arrivals .twirion-home-product-grid .woo-hover.products.loading-effect-none,
	body.home .home__product-items.twirion-new-arrivals .twirion-home-product-grid .wc-grid.dt-products,
	body.home .home__product-items.twirion-new-arrivals .twirion-home-product-grid .wc-grid .dt-css-grid,
	body.page-template-template-sdk-home .home__product-items.twirion-new-arrivals .twirion-home-product-grid .woo-hover.products.loading-effect-none,
	body.page-template-template-sdk-home .home__product-items.twirion-new-arrivals .twirion-home-product-grid .wc-grid.dt-products,
	body.page-template-template-sdk-home .home__product-items.twirion-new-arrivals .twirion-home-product-grid .wc-grid .dt-css-grid {
		--tw-product-grid-cols: 4;
	}
}

/*
 * Homepage category hero — design base 1450px viewport (1400×770 block).
 * From 1450px down: fluid scale in vw; ::after tracks the container.
 */
.home .home__top-categories--wrapper {
	width: 100% !important;
	max-width: 100%;
	margin: 0;
	overflow-x: hidden;
	box-sizing: border-box;
}

.home .home__top-categories {
	position: relative;
	width: 100%;
	max-width: 100%;
	height: 770px;
	margin-left: 0;
	margin-right: 0;
	overflow: hidden;
	box-sizing: border-box;
	border-radius: 0;
}

.home .home__top-categories::after {
	width: 100% !important;
	height: 100% !important;
	left: 0 !important;
	top: 0 !important;
	right: auto;
	bottom: auto;
	background-size: cover !important;
	border-radius: inherit;
}

/* ≥1001px: desktop — title on image, column categories */
@media (min-width: 1001px) {
	.home .home__top-categories .links__categories.links__categories-mobile {
		display: none !important;
	}

	.home .home__top-categories h2.twirion-home-section-title,
	.home .home__top-categories h4 {
		position: absolute;
		top: 0.6207vw !important;
		left: 0;
		z-index: 10;
		margin: 0 !important;
		padding: 0 0 0 0.6897vw !important;
		font-weight: 500 !important;
		color: #000000e5 !important;
		text-align: left !important;
	}

	.home .home__top-categories .links__categories:not(.links__categories-mobile) {
		display: flex;
		flex-direction: column;
		align-items: flex-end;
		max-width: min(320px, 48%);
	}

	.home .home__top-categories .links__categories:not(.links__categories-mobile) a {
		max-width: 100%;
		box-sizing: border-box;
	}
}

@media (min-width: 1451px) {
	.home .home__top-categories h2.twirion-home-section-title,
	.home .home__top-categories h4 {
		top: 9px !important;
		font-size: 40px !important;
		line-height: 24px !important;
	}
}

@media (min-width: 1451px) {
	.home .home__top-categories .links__categories:not(.links__categories-mobile) a {
		min-width: 150px;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-1 {
		min-width: 230px;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-2 {
		min-width: 214px;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-3 {
		min-width: 199px;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-4 {
		min-width: 184px;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-5 {
		min-width: 169px;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-6 {
		min-width: 154px;
	}
}

/* ≤1450px desktop/tablet only — vw scale (px / 1450 * 100) */
@media (max-width: 1450px) and (min-width: 1001px) {
	.home .home__top-categories {
		width: 100%;
		max-width: 100%;
		height: 53.1034vw;
	}

	.home .home__top-categories h2.twirion-home-section-title,
	.home .home__top-categories h4 {
		top: 0.6207vw !important;
		font-size: 2.7586vw !important;
		line-height: 1.6552vw !important;
	}

	.home .home__top-categories .links__categories:not(.links__categories-mobile) {
		top: 2.7586vw;
		right: 2.069vw;
		max-width: 22.069vw;
	}

	.home .home__top-categories .button__categories,
	.home .home__top-categories a.button__categories {
		width: 12.6897vw;
		padding: 0.8276vw 0;
		font-size: 1.0345vw;
		line-height: 1.6552vw;
		border-radius: 1.0345vw;
		color: #fff !important;
		-webkit-text-fill-color: #fff;
		background: #6a2fff;
		text-decoration: none;
	}

	.home .home__top-categories .links__categories:not(.links__categories-mobile) a {
		padding: 0.4828vw 1.5172vw;
		font-size: 0.8276vw;
		line-height: 1.6552vw;
		margin-top: 0.3448vw;
		min-width: 10.3448vw;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-1 {
		min-width: 15.8621vw;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-2 {
		min-width: 14.7586vw;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-3 {
		min-width: 13.7241vw;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-4 {
		min-width: 12.6897vw;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-5 {
		min-width: 11.6552vw;
	}

	.home .home__top-categories .links__categories a.tw-home-cat-lvl-6 {
		min-width: 10.6207vw;
	}
}

/*
 * Phone (≤1000px): title (section style) → image 550px; categories on image (px, not vw).
 */
@media (max-width: 1000px) {
	.home .home__top-categories--wrapper {
		padding-top: 0 !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
		box-sizing: border-box;
	}

	.home .home__top-categories .wpb_text_column > .wpb_wrapper {
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: stretch;
	}

	.home .home__top-categories {
		width: 100%;
		max-width: 100%;
		height: auto;
		min-height: 0;
		margin: 0;
		padding: 0;
		overflow: visible;
		border-radius: 0;
		background-image: none;
	}

	.home .home__top-categories::after {
		display: none !important;
	}

	.home .home__top-categories h2.twirion-home-section-title,
	.home .home__top-categories h4.twirion-home-section-title {
		position: static;
		top: 0 !important;
		order: 1;
		flex: 0 0 auto;
		margin: 0 0 var(--twirion-home-block-head-gap) !important;
		padding: 0 !important;
	}

	.home .home__top-categories .links__categories:not(.links__categories-mobile) {
		display: none !important;
	}

	.home .home__top-categories p:has(.button__categories) {
		order: 2;
		position: relative;
		display: block;
		height: 550px;
		margin: 0;
		padding: 0;
		overflow: hidden;
		border-radius: 30px;
		background-image: url(../images/d11cb00cdbcb4a63bcb57ea186768ea5.jpeg) !important;
		background-size: cover !important;
		background-repeat: no-repeat !important;
		background-position: bottom !important;
	}

	/* Категории колонкой на картинке справа (фикс. px) */
	.home .home__top-categories .links__categories.links__categories-mobile {
		display: flex !important;
		flex-direction: column;
		align-items: flex-end;
		order: 2;
		position: absolute !important;
		left: auto !important;
		right: 12px;
		top: calc(100% - 550px + 40px) !important;
		bottom: auto !important;
		width: auto !important;
		max-width: calc(100% - 24px);
		margin: 0;
		padding: 0;
		overflow: visible;
		z-index: 10;
		box-sizing: border-box;
	}

	.home .home__top-categories .links__categories-mobile .links__categories-track {
		display: flex;
		flex-direction: column;
		align-items: flex-end;
		gap: 5px;
		padding: 0;
		overflow: visible;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a {
		display: block;
		width: max-content;
		min-width: max-content;
		margin-top: 0;
		padding: 7px 22px;
		font-size: 12px;
		line-height: 24px;
		border: 1px solid #6a2fff;
		border-radius: 99px;
		background: #ffffffd9;
		color: #000;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a.tw-home-cat-lvl-1 {
		min-width: 230px;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a.tw-home-cat-lvl-2 {
		min-width: 214px;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a.tw-home-cat-lvl-3 {
		min-width: 199px;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a.tw-home-cat-lvl-4 {
		min-width: 184px;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a.tw-home-cat-lvl-5 {
		min-width: 169px;
	}

	.home .home__top-categories .links__categories.links__categories-mobile a.tw-home-cat-lvl-6 {
		min-width: 154px;
	}

	.home .home__top-categories p:has(.button__categories)::after {
		content: "";
		position: absolute;
		left: 50%;
		bottom: 0;
		width: 204px;
		height: 58px;
		transform: translateX(-50%);
		background-color: #fff;
		border-radius: 20px 20px 0 0;
		pointer-events: none;
	}

	.home .home__top-categories .button__categories,
	.home .home__top-categories a.button__categories {
		position: absolute;
		left: 50%;
		bottom: 0;
		width: 184px;
		padding: 12px 0;
		font-size: 15px;
		line-height: 24px;
		border-radius: 15px;
		transform: translateX(-50%);
		z-index: 12;
		color: #fff !important;
		-webkit-text-fill-color: #fff;
		background: #6a2fff;
		text-decoration: none;
	}

	.home .home__top-categories .button__categories:hover,
	.home .home__top-categories .button__categories:focus,
	.home .home__top-categories a.button__categories:hover,
	.home .home__top-categories a.button__categories:focus {
		color: #fff !important;
		-webkit-text-fill-color: #fff;
	}
}

/* Check category CTA — white label on purple button */
body.home .home__top-categories .button__categories,
body.home .home__top-categories a.button__categories,
body.page-template-template-sdk-home .home__top-categories .button__categories,
body.page-template-template-sdk-home .home__top-categories a.button__categories {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	background: #6a2fff;
	text-decoration: none;
}

/* Hero «Shop now» — white label on purple pill */
body.home .home__top-containers a,
body.home .home__top-containers p > a,
body.page-template-template-sdk-home .home__top-containers a,
body.page-template-template-sdk-home .home__top-containers p > a {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	background: #6a2fff;
	text-decoration: none;
}

body.home .home__top-containers a:hover,
body.home .home__top-containers a:focus,
body.page-template-template-sdk-home .home__top-containers a:hover,
body.page-template-template-sdk-home .home__top-containers a:focus {
	color: #fff !important;
	-webkit-text-fill-color: #fff;
}

.twirion-home-reviews__controls {
	display: inline-flex;
	gap: 8px;
}

.twirion-home-reviews__arrow {
	width: 42px;
	height: 42px;
	border: 1px solid #6a2fff;
	border-radius: 999px;
	background: #ffffff;
	color: #6a2fff;
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
	transition: all 0.2s ease;
}

.twirion-home-reviews__arrow:hover {
	background: #6a2fff;
	color: #ffffff;
}

.twirion-home-reviews__arrow:disabled {
	opacity: 0.35;
	cursor: default;
}

.twirion-home-reviews__viewport {
	overflow: hidden;
	padding-bottom: 5px;
}

.twirion-home-reviews__track {
	display: flex;
	gap: 10px;
	transition: transform 0.35s ease;
	will-change: transform;
}

.twirion-home-review-card {
	flex: 0 0 calc((100% - 20px) / 3);
	padding: 14px;
	box-sizing: border-box;
	background: #ffffff;
	border: 1px solid #ebe8f3;
	border-radius: 14px;
}

.twirion-home-review-card__stars {
	color: #f5b301;
	font-size: 18px;
	letter-spacing: 2px;
	margin-bottom: 10px;
}

.twirion-home-review-card__text {
	margin: 0 0 10px;
	color: #2b2f3d;
	font-size: 15px;
	line-height: 1.55;
}

.twirion-home-review-card__author {
	margin: 0;
	color: #676b79;
	font-size: 14px;
}

@media (max-width: 1024px) {
	.twirion-home-why-choose__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.twirion-home-review-card {
		flex-basis: calc((100% - 10px) / 2);
	}
}

@media (max-width: 1000px) {
	body.home .twirion-home-section-title,
	body.page-template-template-sdk-home .twirion-home-section-title {
		margin: 0 0 var(--twirion-home-block-head-gap) !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	/* Отступ даёт .twirion-home-section-head — не дублируем */
	body.home .twirion-home-section-head .twirion-home-section-title,
	body.page-template-template-sdk-home .twirion-home-section-head .twirion-home-section-title {
		margin: 0 !important;
	}

	body.home .twirion-home-section-head,
	body.page-template-template-sdk-home .twirion-home-section-head,
	body.home .vc_row.dt-default .twirion-home-section-head,
	body.page-template-template-sdk-home .vc_row.dt-default .twirion-home-section-head,
	body.home .vc_row.dt-default:has(.twirion-home-section-head) .wpb_wrapper,
	body.page-template-template-sdk-home .vc_row.dt-default:has(.twirion-home-section-head) .wpb_wrapper {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	body.home .home__top-categories h2.twirion-home-section-title,
	body.home .home__top-categories h4.twirion-home-section-title,
	body.page-template-template-sdk-home .home__top-categories h2.twirion-home-section-title,
	body.page-template-template-sdk-home .home__top-categories h4.twirion-home-section-title {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}
}

/* Why Collectors Trust Us (sdk-why) */
.sdk-why {
	padding-inline: 0 !important;
	background: transparent;
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

.sdk-why-inner {
	box-sizing: border-box;
	width: var(--twirion-home-content-width);
	max-width: var(--twirion-home-block-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: 0;
	padding-right: 0;
}

.sdk-why-header {
	text-align: center;
	margin-bottom: var(--twirion-home-section-head-mb);
}

.sdk-why-label {
	display: inline-block;
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--sdk-accent, #6a2fff);
	background: rgba(106, 47, 255, 0.08);
	padding: 8px 22px;
	border-radius: 99px;
	margin-bottom: 18px;
}

.sdk-why-title {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 42px;
	font-weight: 700;
	color: #0a0a0a;
	margin: 0 0 14px;
}

.sdk-why-subtitle {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 17px;
	color: #666;
	max-width: 550px;
	margin: 0 auto;
}

.sdk-why-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--tw-product-grid-gap, 16px);
	width: 100%;
	max-width: 100%;
}

.sdk-why-card {
	background: #fff;
	border: 1px solid var(--sdk-border);
	border-radius: 22px;
	padding: 40px 32px;
	text-align: center;
	transition: all 0.4s;
	position: relative;
	overflow: hidden;
}

.sdk-why-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--sdk-accent, #6a2fff);
	transform: scaleX(0);
	transition: transform 0.4s;
}

.sdk-why-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 50px rgba(106, 47, 255, 0.1);
	border-color: rgba(106, 47, 255, 0.15);
}

.sdk-why-card:hover::before {
	transform: scaleX(1);
}

.sdk-why-icon {
	width: 70px;
	height: 70px;
	background: linear-gradient(135deg, #6a2fff, #8b5cf6);
	border-radius: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 22px;
	font-size: 30px;
	box-shadow: 0 8px 25px rgba(106, 47, 255, 0.2);
}

.sdk-why-card h3 {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 20px;
	font-weight: 600;
	color: #0a0a0a;
	margin-bottom: 12px;
}

.sdk-why-card p {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 14px;
	color: #777;
	line-height: 1.7;
}

/* Explore Categories (sdk-cats) — ширина как у home__product-items / columns-4 */
.sdk-cats.twirion-home-explore-categories {
	padding-inline: 0 !important;
}

body.home .sdk-cats.twirion-home-explore-categories .sdk-cats-inner,
body.page-template-template-sdk-home .sdk-cats.twirion-home-explore-categories .sdk-cats-inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding-left: 0;
	padding-right: 0;
}

body.home .sdk-cats.twirion-home-explore-categories .sdk-cats-grid,
body.page-template-template-sdk-home .sdk-cats.twirion-home-explore-categories .sdk-cats-grid {
	--tw-home-cats-gap: var(--tw-product-grid-gap, 16px);
	width: 100%;
	max-width: 100%;
	gap: var(--tw-home-cats-gap);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sdk-cats.twirion-home-explore-categories .sdk-cats-header {
	text-align: center;
	margin-bottom: var(--twirion-home-section-head-mb);
}

.sdk-cats.twirion-home-explore-categories .sdk-cats-label {
	display: inline-block;
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--sdk-accent, #6a2fff);
	background: rgba(106, 47, 255, 0.08);
	padding: 8px 22px;
	border-radius: 99px;
	margin-bottom: 18px;
}

.sdk-cats.twirion-home-explore-categories .sdk-cats-title {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 42px;
	font-weight: 700;
	color: #0a0a0a;
	margin: 0;
}

.sdk-cats-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

.sdk-cats-card {
	position: relative;
	border-radius: 22px;
	overflow: hidden;
	aspect-ratio: 1 / 0.7;
	cursor: pointer;
	transition: all 0.4s;
	text-decoration: none;
}

.sdk-cats-card:hover {
	transform: translateY(-6px);
}

.sdk-cats-card-bg {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.sdk-cats-card-strips {
	display: flex;
	position: absolute;
	inset: 0;
	z-index: 1;
	gap: 2px;
	overflow: hidden;
	transition: gap 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.sdk-cats-card--has-strips[data-active-strip] .sdk-cats-card-strips {
	gap: 0;
}

.sdk-cats-card-strip {
	flex: 1 1 0;
	min-width: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transition: flex 0.5s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.45s ease, min-width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.sdk-cats-card--has-strips[data-active-strip="0"] .sdk-cats-card-strip:nth-child(1),
.sdk-cats-card--has-strips[data-active-strip="1"] .sdk-cats-card-strip:nth-child(2),
.sdk-cats-card--has-strips[data-active-strip="2"] .sdk-cats-card-strip:nth-child(3),
.sdk-cats-card--has-strips[data-active-strip="3"] .sdk-cats-card-strip:nth-child(4),
.sdk-cats-card--has-strips[data-active-strip="4"] .sdk-cats-card-strip:nth-child(5) {
	flex: 1 1 100%;
	min-width: 100%;
}

.sdk-cats-card--has-strips[data-active-strip="0"] .sdk-cats-card-strip:not(:nth-child(1)),
.sdk-cats-card--has-strips[data-active-strip="1"] .sdk-cats-card-strip:not(:nth-child(2)),
.sdk-cats-card--has-strips[data-active-strip="2"] .sdk-cats-card-strip:not(:nth-child(3)),
.sdk-cats-card--has-strips[data-active-strip="3"] .sdk-cats-card-strip:not(:nth-child(4)),
.sdk-cats-card--has-strips[data-active-strip="4"] .sdk-cats-card-strip:not(:nth-child(5)) {
	flex: 0 0 0;
	min-width: 0;
	opacity: 0;
}

.sdk-cats-card--has-strips[data-active-strip] .sdk-cats-card-overlay {
	background: linear-gradient(to top, rgba(0, 0, 0, 0.88) 0%, rgba(0, 0, 0, 0.2) 55%, transparent 100%);
}

.sdk-cats-card[data-cat="basketball"] .sdk-cats-card-bg {
	background: linear-gradient(145deg, #5c1a1a, #370d0d);
}

.sdk-cats-card[data-cat="football"] .sdk-cats-card-bg {
	background: linear-gradient(145deg, #2d1854, #1a0e33);
}

.sdk-cats-card[data-cat="baseball"] .sdk-cats-card-bg {
	background: linear-gradient(145deg, #1a3a5c, #0d2137);
}

.sdk-cats-card[data-cat="soccer"] .sdk-cats-card-bg {
	background: linear-gradient(145deg, #0d4a2e, #062a19);
}

.sdk-cats-card[data-cat="hockey"] .sdk-cats-card-bg {
	background: linear-gradient(145deg, #0a2e3d, #061e28);
}

.sdk-cats-card[data-cat="mma"] .sdk-cats-card-bg,
.sdk-cats-card[data-cat="other"] .sdk-cats-card-bg {
	background: linear-gradient(145deg, #4a1a0d, #2a0e06);
}

.sdk-cats-card-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, transparent 60%);
	z-index: 2;
	pointer-events: none;
}

.sdk-cats-card-content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 24px;
	z-index: 3;
	pointer-events: none;
}

.sdk-cats-card-emoji {
	font-size: 36px;
	margin-bottom: 10px;
	display: block;
}

.sdk-cats-card-name {
	font-family: var(--sdk-global-font, "Kanit", sans-serif);
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	margin-bottom: 4px;
}

.sdk-cats-card-count {
	font-family: "Libre Franklin", Helvetica, Arial, sans-serif;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.6);
}

.sdk-cats-card-arrow {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 38px;
	height: 38px;
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(8px);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 16px;
	z-index: 3;
	pointer-events: none;
	opacity: 0;
	transform: translateX(-8px);
	transition: all 0.35s;
}

.sdk-cats-card:hover .sdk-cats-card-arrow {
	opacity: 1;
	transform: translateX(0);
	background: var(--sdk-accent, #6a2fff);
}

@media (max-width: 992px) {
	.sdk-why-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.sdk-why-title {
		font-size: 32px;
	}

	.sdk-why-grid {
		grid-template-columns: 1fr;
	}

	.sdk-cats.twirion-home-explore-categories .sdk-cats-title {
		font-size: 32px;
	}

	.sdk-cats-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	body.home,
	body.page-template-template-sdk-home {
		--twirion-home-section-pad-x: 15px;
		--twirion-home-section-head-mb: 32px;
		--twirion-home-block-head-gap: 20px;
	}

	body.home .sdk-cats.twirion-home-explore-categories .sdk-cats-grid,
	body.page-template-template-sdk-home .sdk-cats.twirion-home-explore-categories .sdk-cats-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.twirion-home-why-choose__grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.sdk-roster-title {
		font-size: 36px;
	}

	.sdk-roster-subtitle {
		font-size: 16px;
	}

	.sdk-roster-grid,
	.sdk-roster-grid.sdk-roster-grid--latest {
		grid-template-columns: repeat(2, 1fr);
		gap: 14px;
	}

	.twirion-home-trending-player__photo,
	.twirion-home-trending-player__placeholder {
		width: 100px;
		height: 100px;
	}

	.sdk-roster-tabs {
		gap: 8px;
	}

	.sdk-roster-tab {
		padding: 10px 16px;
		font-size: 13px;
	}

	.sdk-roster-tab-icon {
		font-size: 16px;
	}

	.sdk-roster-name {
		font-size: 15px;
	}

	.sdk-roster-info {
		padding: 14px 14px 16px;
	}

	.sdk-roster-number {
		font-size: 60px;
	}

	.twirion-home-why-choose__title {
		font-size: 20px;
	}

	.twirion-home-review-card {
		flex-basis: 100%;
	}
}
