/*
Theme Name: Thanoscheats
Theme URI: https://thanoscheats.cc
Author: Thanoscheats
Description: Custom storefront theme for Thanoscheats.cc.
Version: 0.2.7
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: thanoscheats
*/

:root {
	--bg: #070707;
	--bg-2: #0c0c0e;
	--bg-3: #111114;
	--card: rgba(17, 17, 20, 0.78);
	--card-2: rgba(12, 12, 14, 0.86);
	--text: #f3f3f5;
	--muted: rgba(243, 243, 245, 0.58);
	--soft: rgba(243, 243, 245, 0.36);
	--line: rgba(255, 255, 255, 0.085);
	--line-strong: rgba(255, 255, 255, 0.14);
	--accent: #8550ff;
	--accent-2: #17a2ff;
	--accent-3: #b995ff;
	--accent-soft: rgba(133, 80, 255, 0.16);
	--accent-glow: rgba(133, 80, 255, 0.38);
	--violet: #8550ff;
	--cyan: #17a2ff;
	--gold: #f0b85a;
	--green: #3ed780;
	--shadow: 0 24px 80px rgba(0, 0, 0, 0.44);
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.018), transparent 360px),
		var(--bg);
	color: var(--text);
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 16px;
	line-height: 1.6;
	letter-spacing: 0;
	overflow-x: hidden;
}

body::before {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -2;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.026) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.026) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.78), transparent 92%);
	pointer-events: none;
}

body::after {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -1;
	background:
		radial-gradient(circle at var(--cursor-x, 50%) var(--cursor-y, 18%), rgba(133, 80, 255, 0.16), transparent 22rem),
		linear-gradient(90deg, rgba(0, 0, 0, 0.8), transparent 22%, transparent 78%, rgba(0, 0, 0, 0.82)),
		linear-gradient(180deg, rgba(133, 80, 255, 0.065), transparent 34%, rgba(23, 162, 255, 0.038));
	pointer-events: none;
}

::selection {
	background: var(--accent);
	color: #fff;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	display: block;
	max-width: 100%;
}

h1,
h2,
h3,
p {
	margin-top: 0;
}

h1,
h2,
h3 {
	line-height: 0.94;
	letter-spacing: 0;
}

h1 {
	max-width: 960px;
	margin: 0 auto 1.15rem;
	font-size: 4.8rem;
	font-weight: 920;
	text-transform: uppercase;
}

h1 .hero-title__plain,
h1 .hero-title__accent {
	display: block;
}

h1 .hero-title__plain {
	color: var(--text);
}

h1 .hero-title__accent {
	background: linear-gradient(90deg, var(--accent), var(--accent-2));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

h1 .hero-title__word {
	display: inline;
}

h2 {
	margin-bottom: 1rem;
	font-size: 2.7rem;
	font-weight: 860;
}

h3 {
	margin-bottom: 0.75rem;
	font-size: 1.22rem;
	font-weight: 780;
}

p {
	color: var(--muted);
}

.wrap {
	width: min(1160px, calc(100% - 40px));
	margin-inline: auto;
}

.skip-link,
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.skip-link:focus {
	z-index: 999;
	width: auto;
	height: auto;
	padding: 0.75rem 1rem;
	clip: auto;
	background: var(--text);
	color: var(--bg);
}

.site-header {
	position: fixed;
	z-index: 50;
	top: 0;
	left: 0;
	width: 100%;
	border-bottom: 1px solid var(--line);
	background: linear-gradient(180deg, rgba(10, 10, 13, 0.88), rgba(7, 7, 7, 0.72));
	backdrop-filter: blur(22px);
	transition: background 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.site-header.is-scrolled {
	border-color: rgba(133, 80, 255, 0.18);
	background: rgba(7, 7, 8, 0.9);
	box-shadow: 0 18px 52px rgba(0, 0, 0, 0.32);
}

.site-progress {
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1px;
	height: 2px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.025);
}

.site-progress span {
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, var(--accent), var(--accent-2), var(--gold));
	box-shadow: 0 0 20px rgba(133, 80, 255, 0.5);
	transform: scaleX(var(--scroll-progress, 0));
	transform-origin: left;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: min(1280px, calc(100% - 48px));
	min-height: 70px;
	margin-inline: auto;
	gap: 1rem;
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: 0.72rem;
	position: relative;
	font-weight: 900;
	text-transform: uppercase;
}

.brand__mark {
	position: relative;
	display: grid;
	width: 36px;
	height: 36px;
	place-items: center;
	border-radius: 8px;
	isolation: isolate;
	transition: transform 160ms ease;
}

.brand__mark::before {
	content: "";
	position: absolute;
	inset: -10px;
	z-index: -2;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(133, 80, 255, 0.24), transparent 62%);
	animation: logo-aura 3.2s ease-in-out infinite;
}

.brand__mark-ring {
	position: absolute;
	inset: 0;
	border-radius: 8px;
	background: conic-gradient(from 0deg, var(--accent), var(--accent-2), var(--gold), var(--accent));
	animation: logo-spin 5.5s linear infinite;
}

.brand__mark-ring::after {
	content: "";
	position: absolute;
	inset: 2px;
	border-radius: 6px;
	background: #09090b;
}

.brand__mark-core {
	position: relative;
	z-index: 1;
	display: grid;
	width: 24px;
	height: 24px;
	place-items: center;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 6px;
	background: linear-gradient(135deg, rgba(133, 80, 255, 0.46), rgba(23, 162, 255, 0.24));
	color: #fff;
	font-size: 0.82rem;
	font-weight: 950;
	text-shadow: 0 0 12px rgba(255, 255, 255, 0.45);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 24px rgba(133, 80, 255, 0.38);
	animation: logo-core 2.7s ease-in-out infinite;
}

.brand:hover .brand__mark {
	transform: translateY(-1px);
}

.brand__name {
	position: relative;
	overflow: hidden;
}

.brand__name::after {
	content: "";
	position: absolute;
	top: -20%;
	bottom: -20%;
	left: -40%;
	width: 30%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.7), transparent);
	transform: skewX(-18deg);
	animation: logo-sheen 4.2s ease-in-out infinite;
}

.brand__name {
	font-size: 1rem;
	letter-spacing: 0.08em;
}

.primary-nav,
.header-actions {
	display: flex;
	align-items: center;
	gap: 0.6rem;
}

.primary-nav {
	gap: 1.8rem;
}

.primary-nav a {
	position: relative;
	color: var(--muted);
	font-size: 0.84rem;
	font-weight: 700;
}

.primary-nav a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -0.52rem;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--accent), var(--accent-2));
	opacity: 0;
	transform: scaleX(0.35);
	transition: opacity 160ms ease, transform 160ms ease;
}

.primary-nav a:hover {
	color: var(--text);
}

.primary-nav a.is-active {
	color: var(--text);
}

.primary-nav a.is-active::after,
.primary-nav a:hover::after {
	opacity: 1;
	transform: scaleX(1);
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 0.78rem 1.05rem;
	border: 1px solid transparent;
	border-radius: 8px;
	color: var(--text);
	font-weight: 820;
	line-height: 1;
	position: relative;
	overflow: hidden;
	transform: translate(var(--magnet-x, 0), var(--magnet-y, 0));
	transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.button::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.26), transparent);
	opacity: 0;
	transform: translateX(-120%) skewX(-18deg);
	transition: opacity 180ms ease, transform 520ms ease;
}

.button > span {
	position: relative;
	z-index: 1;
}

.button:hover {
	transform: translate(var(--magnet-x, 0), calc(var(--magnet-y, 0) - 1px));
}

.button:hover::before {
	opacity: 1;
	transform: translateX(120%) skewX(-18deg);
}

.button--primary {
	border-color: rgba(23, 162, 255, 0.42);
	background: linear-gradient(135deg, var(--accent), var(--accent-2));
	box-shadow: 0 14px 34px rgba(133, 80, 255, 0.28), 0 0 36px rgba(23, 162, 255, 0.16);
}

.button--primary:hover {
	box-shadow: 0 18px 42px rgba(133, 80, 255, 0.38), 0 0 44px rgba(23, 162, 255, 0.22);
}

.button--discord {
	gap: 0.62rem;
	border-color: rgba(88, 101, 242, 0.62);
	background:
		linear-gradient(135deg, rgba(88, 101, 242, 0.98), rgba(133, 80, 255, 0.9) 48%, rgba(23, 162, 255, 0.86)),
		#5865f2;
	box-shadow: 0 16px 40px rgba(88, 101, 242, 0.28), 0 0 48px rgba(133, 80, 255, 0.18);
	isolation: isolate;
}

.button--discord::after {
	content: "";
	position: absolute;
	inset: -32% -18%;
	z-index: 0;
	border-radius: inherit;
	background: linear-gradient(90deg, rgba(88, 101, 242, 0), rgba(23, 162, 255, 0.62), rgba(240, 184, 90, 0.46), rgba(88, 101, 242, 0));
	opacity: 0.34;
	transform: translateX(-68%);
	animation: discord-border-flow 2.8s ease-in-out infinite;
}

.button--discord:hover {
	border-color: rgba(240, 184, 90, 0.48);
	box-shadow: 0 20px 52px rgba(88, 101, 242, 0.4), 0 0 56px rgba(23, 162, 255, 0.24);
}

.discord-button__icon {
	display: inline-grid;
	width: 24px;
	height: 24px;
	place-items: center;
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.14);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 0 20px rgba(255, 255, 255, 0.16);
	animation: discord-icon-float 2.4s ease-in-out infinite;
}

.discord-button__icon span {
	position: relative;
	display: block;
	width: 14px;
	height: 10px;
	border-radius: 5px 5px 7px 7px;
	background: #fff;
}

.discord-button__icon span::before,
.discord-button__icon span::after {
	content: "";
	position: absolute;
	top: 4px;
	width: 3px;
	height: 3px;
	border-radius: 999px;
	background: #5865f2;
}

.discord-button__icon span::before {
	left: 3px;
}

.discord-button__icon span::after {
	right: 3px;
}

.button--ghost {
	border-color: var(--line-strong);
	background: rgba(255, 255, 255, 0.045);
	color: rgba(255, 255, 255, 0.78);
}

.button--dark {
	border-color: var(--line-strong);
	background: rgba(8, 8, 9, 0.82);
}

.button--large {
	min-height: 52px;
	padding-inline: 1.2rem;
}

.button--product {
	width: 100%;
	margin-top: auto;
}

.menu-toggle {
	display: none;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.05);
	color: var(--text);
}

.menu-toggle__line {
	width: 18px;
	height: 2px;
	background: currentColor;
}

.mobile-nav {
	display: none;
	width: min(1280px, calc(100% - 48px));
	margin: 0 auto 1rem;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(12, 12, 14, 0.96);
}

.mobile-nav a {
	display: block;
	padding: 0.9rem 1rem;
	color: var(--muted);
	font-weight: 700;
}

.mobile-nav a + a {
	border-top: 1px solid var(--line);
}

.hero-premium {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 88vh;
	padding: 130px 0 76px;
	overflow: hidden;
	text-align: center;
}

.hero-premium::after {
	content: "";
	position: absolute;
	left: 14%;
	right: 14%;
	bottom: 9%;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(133, 80, 255, 0.42), rgba(23, 162, 255, 0.42), transparent);
	opacity: 0.7;
	animation: hero-scan 5s ease-in-out infinite;
}

.hero-premium__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(180deg, rgba(7, 7, 7, 0.16), rgba(7, 7, 7, 0.92)),
		linear-gradient(90deg, rgba(7, 7, 7, 0.96), rgba(7, 7, 7, 0.42), rgba(7, 7, 7, 0.96)),
		var(--hero-image);
	background-position: center 42%;
	background-size: cover;
	opacity: 0.36;
}

.hero-premium__grid {
	position: absolute;
	inset: 0;
	z-index: -1;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
	background-size: 76px 76px;
	mask-image: linear-gradient(180deg, transparent, #000 18%, #000 76%, transparent);
}

.hero-premium__inner {
	position: relative;
}

.status-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin-bottom: 1.35rem;
	padding: 0.5rem 0.9rem;
	border: 1px solid rgba(133, 80, 255, 0.34);
	border-radius: 999px;
	background: rgba(133, 80, 255, 0.12);
	color: #cdbdff;
	font-size: 0.78rem;
	font-weight: 850;
}

.status-badge span {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 14px rgba(62, 215, 128, 0.88);
}

.hero-premium__lead {
	max-width: 700px;
	margin: 0 auto 1.75rem;
	color: rgba(243, 243, 245, 0.66);
	font-size: 1.08rem;
	overflow-wrap: break-word;
}

.hero-premium__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.75rem;
	margin-bottom: 3rem;
}

.hero-stats {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	max-width: 760px;
	margin: 0 auto;
	overflow: hidden;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: rgba(17, 17, 20, 0.7);
	box-shadow: var(--shadow);
	backdrop-filter: blur(18px);
	position: relative;
}

.hero-stats::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	padding: 1px;
	background: linear-gradient(90deg, transparent, rgba(133, 80, 255, 0.6), rgba(23, 162, 255, 0.52), transparent);
	opacity: 0.58;
	pointer-events: none;
	mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	mask-composite: exclude;
}

.hero-stats div {
	min-height: 92px;
	display: grid;
	place-items: center;
	align-content: center;
	padding: 1rem;
	border-left: 1px solid var(--line);
	transition: background 180ms ease, transform 180ms ease;
}

.hero-stats div:first-child {
	border-left: 0;
}

.hero-stats div:hover {
	background: rgba(133, 80, 255, 0.08);
	transform: translateY(-2px);
}

.hero-stats strong,
.hero-stats span {
	display: block;
}

.hero-stats strong {
	font-size: 1.2rem;
	font-weight: 920;
	text-transform: uppercase;
}

.hero-stats span {
	color: var(--soft);
	font-size: 0.75rem;
	font-weight: 760;
	text-transform: uppercase;
}

.section {
	padding: 86px 0;
}

.section[id] {
	scroll-margin-top: 94px;
}

.section--visual {
	padding-top: 26px;
}

.visual-shell {
	position: relative;
}

.visual-stage {
	position: relative;
	min-height: 540px;
	overflow: hidden;
	border-radius: 8px;
	background:
		linear-gradient(90deg, rgba(7, 7, 7, 0.96), rgba(7, 7, 7, 0.3), rgba(7, 7, 7, 0.82)),
		var(--hero-image);
	background-position: center;
	background-size: cover;
	box-shadow: var(--shadow);
	transform-style: preserve-3d;
}

.visual-stage::before {
	content: "";
	position: absolute;
	inset: 0;
	border: 1px solid var(--line-strong);
	border-radius: inherit;
	pointer-events: none;
}

.visual-stage__image {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(7, 7, 7, 0.18), rgba(7, 7, 7, 0.72)),
		linear-gradient(90deg, rgba(133, 80, 255, 0.16), transparent 45%),
		linear-gradient(315deg, rgba(23, 162, 255, 0.12), transparent 38%);
}

.section-heading {
	margin-bottom: 2.1rem;
}

.section-heading--center {
	max-width: 760px;
	margin-inline: auto;
	text-align: center;
}

.section-heading p:last-child {
	margin-inline: auto;
	max-width: 650px;
}

.eyebrow {
	display: inline-flex;
	align-items: center;
	margin-bottom: 0.9rem;
	color: var(--accent-2);
	font-size: 0.75rem;
	font-weight: 900;
	text-transform: uppercase;
}

.premium-product {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 1rem;
	align-items: stretch;
}

.product-card,
.feature-card,
.faq-item,
.support-panel,
.step-card,
.product-panel {
	position: relative;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02));
	box-shadow: var(--shadow);
	transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
	will-change: transform;
	overflow: hidden;
}

.product-card::before,
.feature-card::before,
.step-card::before,
.support-panel::before,
.product-panel::before,
.faq-item::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at var(--spot-x, 50%) var(--spot-y, 0%), rgba(133, 80, 255, 0.18), transparent 34%),
		linear-gradient(135deg, rgba(23, 162, 255, 0.06), transparent 42%);
	opacity: 0;
	transition: opacity 180ms ease;
	pointer-events: none;
}

.product-card > *,
.feature-card > *,
.step-card > *,
.support-panel > *,
.product-panel > *,
.faq-item > * {
	position: relative;
	z-index: 1;
}

.product-card:hover,
.feature-card:hover,
.step-card:hover,
.product-panel:hover,
.support-panel:hover {
	border-color: rgba(133, 80, 255, 0.26);
	box-shadow: 0 30px 90px rgba(0, 0, 0, 0.54), 0 0 44px rgba(133, 80, 255, 0.08);
}

.product-card:hover::before,
.feature-card:hover::before,
.step-card:hover::before,
.support-panel:hover::before,
.product-panel:hover::before,
.faq-item:hover::before {
	opacity: 1;
}

.product-card {
	display: flex;
	min-height: 390px;
	flex-direction: column;
	padding: 1.35rem;
}

.product-card--premium {
	background:
		linear-gradient(135deg, rgba(133, 80, 255, 0.14), transparent 42%),
		linear-gradient(315deg, rgba(23, 162, 255, 0.08), transparent 38%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.018));
}

.product-card__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.2rem;
}

.product-card__kicker {
	margin-bottom: 0.5rem;
	color: var(--accent-2);
	font-size: 0.76rem;
	font-weight: 880;
	text-transform: uppercase;
}

.product-card h3 {
	margin-bottom: 0;
	font-size: 2rem;
}

.status-pill {
	flex: 0 0 auto;
	padding: 0.48rem 0.65rem;
	border: 1px solid rgba(133, 80, 255, 0.34);
	border-radius: 999px;
	background: var(--accent-soft);
	color: #d7c9ff;
	font-size: 0.72rem;
	font-weight: 880;
	line-height: 1;
	text-transform: uppercase;
}

.detail-list {
	display: grid;
	gap: 0.7rem;
	margin: 1.35rem 0 1.6rem;
	padding: 0;
	list-style: none;
}

.detail-list li {
	position: relative;
	min-height: 24px;
	padding-left: 1.35rem;
	color: rgba(243, 243, 245, 0.78);
	font-size: 0.96rem;
}

.detail-list li::before {
	content: "";
	position: absolute;
	top: 0.67rem;
	left: 0;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--accent-2);
	box-shadow: 0 0 16px rgba(23, 162, 255, 0.74);
}

.product-panel {
	display: grid;
	align-content: stretch;
	overflow: hidden;
}

.product-panel div {
	display: grid;
	gap: 0.4rem;
	align-content: center;
	min-height: 130px;
	padding: 1.25rem;
	border-top: 1px solid var(--line);
}

.product-panel div:first-child {
	border-top: 0;
}

.product-panel span {
	color: var(--soft);
	font-size: 0.78rem;
	font-weight: 820;
	text-transform: uppercase;
}

.product-panel strong {
	font-size: 1.15rem;
}

.muted {
	max-width: 560px;
	color: var(--muted);
}

.section--split,
.section--features {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.018), transparent);
}

.split-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.75fr) minmax(0, 1.25fr);
	gap: 3rem;
	align-items: center;
}

.split-grid--menu {
	grid-template-columns: minmax(0, 0.68fr) minmax(520px, 1.32fr);
}

.steps-grid,
.feature-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.step-card,
.feature-card {
	min-height: 235px;
	padding: 1.3rem;
}

.step-card span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 32px;
	margin-bottom: 1.1rem;
	border: 1px solid rgba(133, 80, 255, 0.34);
	border-radius: 8px;
	background: var(--accent-soft);
	color: #d7c9ff;
	font-weight: 900;
}

.feature-card__bar {
	display: block;
	width: 44px;
	height: 4px;
	margin-bottom: 1.25rem;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--accent), var(--cyan), var(--gold));
}

.menu-showcase {
	display: grid;
	grid-template-columns: 150px minmax(0, 1fr);
	min-width: 0;
	overflow: hidden;
	border: 1px solid rgba(126, 82, 217, 0.42);
	border-radius: 8px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 58px),
		linear-gradient(90deg, rgba(133, 80, 255, 0.08), transparent 54%),
		rgba(6, 7, 13, 0.94);
	box-shadow: 0 24px 72px rgba(0, 0, 0, 0.58), inset 0 1px 0 rgba(255, 255, 255, 0.06);
	transition: transform 220ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.menu-showcase:hover {
	border-color: rgba(23, 162, 255, 0.42);
	box-shadow: 0 30px 84px rgba(0, 0, 0, 0.64), 0 0 50px rgba(133, 80, 255, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.menu-showcase--hero {
	position: absolute;
	right: min(42px, 4vw);
	bottom: min(42px, 4vw);
	width: min(740px, calc(100% - 56px));
	transform: perspective(1200px) rotateY(-4deg) rotateX(1deg);
	transform-origin: center;
}

.menu-showcase--section {
	transform: none;
}

.menu-showcase__aside {
	padding: 14px 12px;
	border-right: 1px solid rgba(126, 82, 217, 0.42);
	background: rgba(4, 5, 10, 0.96);
}

.menu-showcase__brand {
	display: grid;
	gap: 5px;
	margin-bottom: 18px;
}

.menu-showcase__brand strong {
	font-size: 1.25rem;
	line-height: 1;
	font-weight: 920;
}

.menu-showcase__brand span {
	color: var(--cyan);
	font-size: 0.74rem;
	font-weight: 820;
}

.menu-showcase__nav {
	display: grid;
	gap: 7px;
}

.menu-showcase__nav span {
	min-height: 32px;
	padding: 0.48rem 0.55rem;
	border-radius: 8px;
	color: rgba(170, 176, 205, 0.86);
	font-size: 0.78rem;
	font-weight: 760;
	cursor: pointer;
	transition: background 160ms ease, color 160ms ease, transform 160ms ease;
}

.menu-showcase__nav span:hover {
	background: rgba(255, 255, 255, 0.045);
	color: var(--text);
	transform: translateX(2px);
}

.menu-showcase__nav .is-active {
	background: rgba(133, 80, 255, 0.17);
	color: var(--text);
	outline: 1px solid rgba(133, 80, 255, 0.2);
}

.menu-showcase__main {
	min-width: 0;
}

.menu-showcase__top {
	display: grid;
	gap: 5px;
	padding: 18px 18px 12px;
}

.menu-showcase__top strong {
	font-size: 1rem;
	line-height: 1;
}

.menu-showcase__top span {
	color: rgba(170, 176, 205, 0.86);
	font-size: 0.74rem;
	font-weight: 650;
}

.menu-showcase__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.7rem;
	padding: 0 14px 16px 18px;
}

.menu-showcase__grid section {
	min-width: 0;
	padding: 0.65rem;
	border: 1px solid rgba(92, 94, 124, 0.32);
	border-radius: 8px;
	background: rgba(5, 6, 12, 0.35);
}

.menu-showcase__grid h2 {
	display: grid;
	grid-template-columns: max-content minmax(30px, 1fr);
	align-items: center;
	gap: 10px;
	margin: 0 0 0.45rem;
	color: var(--cyan);
	font-size: 0.75rem;
	font-weight: 850;
	line-height: 1;
}

.menu-showcase__grid h2::after {
	content: "";
	height: 1px;
	background: rgba(92, 94, 124, 0.32);
}

.showcase-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 104px;
	align-items: center;
	gap: 0.55rem;
	min-height: 27px;
	padding: 0.1rem 0.2rem 0.1rem 0.45rem;
	border-radius: 8px;
	color: var(--text);
	transition: background 160ms ease, opacity 180ms ease, transform 180ms ease;
}

.showcase-row:hover {
	background: rgba(133, 80, 255, 0.12);
}

.showcase-row.is-refreshing {
	opacity: 0.35;
	transform: translateX(5px);
}

.showcase-label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: 0.72rem;
	font-weight: 720;
}

.showcase-control {
	display: flex;
	justify-content: flex-end;
	min-width: 0;
}

.showcase-toggle {
	width: 30px;
	height: 14px;
	padding: 3px;
	border-radius: 999px;
	background: rgba(92, 94, 124, 0.45);
	cursor: pointer;
	transition: background 160ms ease;
}

.showcase-toggle::after {
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: rgba(170, 176, 205, 0.86);
	transition: transform 160ms ease, background 160ms ease;
}

.showcase-toggle.is-on {
	background: var(--violet);
}

.showcase-toggle.is-on::after {
	transform: translateX(16px);
	background: #fff;
}

.showcase-slider {
	position: relative;
	width: 94px;
	height: 18px;
	display: block;
	cursor: pointer;
}

.showcase-slider::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	height: 3px;
	border-radius: 999px;
	background: rgba(92, 94, 124, 0.45);
	transform: translateY(-50%);
}

.showcase-slider::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: var(--value);
	height: 3px;
	border-radius: 999px;
	background: var(--cyan);
	transform: translateY(-50%);
}

.showcase-slider span {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: var(--value);
	width: 6px;
	height: 10px;
	border-radius: 999px;
	background: #fff;
	transform: translate(-50%, -50%);
}

.showcase-select,
.showcase-color {
	display: inline-flex;
	align-items: center;
	min-width: 96px;
	min-height: 24px;
	padding: 0 0.45rem;
	border: 1px solid rgba(92, 94, 124, 0.48);
	border-radius: 8px;
	background: rgba(11, 12, 22, 0.88);
	color: rgba(170, 176, 205, 0.9);
	font-size: 0.68rem;
	font-weight: 750;
	transition: border-color 160ms ease, color 160ms ease, background 160ms ease;
}

.showcase-select:hover,
.showcase-color:hover {
	border-color: rgba(23, 162, 255, 0.44);
	background: rgba(23, 162, 255, 0.08);
	color: #fff;
}

.showcase-color {
	gap: 0.45rem;
}

.showcase-color span {
	width: 18px;
	height: 13px;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	background: var(--swatch);
}

.section--support {
	padding-bottom: 76px;
}

.support-panel {
	display: grid;
	grid-template-columns: minmax(0, 1fr) max-content;
	gap: 2rem;
	align-items: center;
	padding: 2rem;
	background:
		linear-gradient(135deg, rgba(133, 80, 255, 0.14), transparent 42%),
		linear-gradient(315deg, rgba(23, 162, 255, 0.08), transparent 38%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018));
}

.support-panel p {
	max-width: 650px;
	margin-bottom: 0;
}

.support-panel__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.75rem;
}

.faq-list {
	display: grid;
	max-width: 820px;
	gap: 0.75rem;
}

.faq-item {
	padding: 0;
	overflow: hidden;
}

.faq-item summary {
	cursor: pointer;
	padding: 1.1rem 1.25rem;
	font-weight: 800;
	transition: color 160ms ease, background 160ms ease;
}

.faq-item summary:hover {
	background: rgba(133, 80, 255, 0.06);
	color: #fff;
}

[data-reveal] {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 560ms ease, transform 560ms ease;
}

[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}

@keyframes logo-spin {
	to {
		transform: rotate(360deg);
	}
}

@keyframes logo-aura {
	0%,
	100% {
		opacity: 0.55;
		transform: scale(0.92);
	}

	50% {
		opacity: 1;
		transform: scale(1.1);
	}
}

@keyframes logo-core {
	0%,
	100% {
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 20px rgba(133, 80, 255, 0.32);
	}

	50% {
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 30px rgba(23, 162, 255, 0.42);
	}
}

@keyframes logo-sheen {
	0%,
	54% {
		left: -45%;
		opacity: 0;
	}

	64% {
		opacity: 0.65;
	}

	78%,
	100% {
		left: 115%;
		opacity: 0;
	}
}

@keyframes hero-scan {
	0%,
	100% {
		opacity: 0.22;
		transform: scaleX(0.62);
	}

	50% {
		opacity: 0.86;
		transform: scaleX(1);
	}
}

@keyframes discord-border-flow {
	0%,
	100% {
		opacity: 0.34;
		transform: translateX(-72%);
	}

	48%,
	60% {
		opacity: 0.9;
		transform: translateX(72%);
	}
}

@keyframes discord-icon-float {
	0%,
	100% {
		transform: translateY(0) scale(1);
	}

	50% {
		transform: translateY(-1px) scale(1.04);
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.001ms !important;
	}
}

.faq-item p {
	margin: 0;
	padding: 0 1.25rem 1.25rem;
}

.content-area {
	max-width: 820px;
}

.site-footer {
	border-top: 1px solid var(--line);
	background: rgba(5, 5, 6, 0.98);
}

.site-footer__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: min(1280px, calc(100% - 48px));
	min-height: 112px;
	margin-inline: auto;
	gap: 1.5rem;
}

.site-footer__meta {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.75rem 1.2rem;
	color: var(--soft);
	font-size: 0.9rem;
}

@media (max-width: 1080px) {
	h1 {
		font-size: 3.7rem;
	}

	h2 {
		font-size: 2.2rem;
	}

	.premium-product,
	.split-grid,
	.split-grid--menu,
	.support-panel {
		grid-template-columns: 1fr;
	}

	.menu-showcase--hero {
		position: relative;
		right: auto;
		bottom: auto;
		width: calc(100% - 32px);
		margin: 180px auto 24px;
		transform: none;
	}

	.visual-stage {
		min-height: auto;
	}
}

@media (max-width: 860px) {
	.primary-nav,
	.header-actions {
		display: none;
	}

	.menu-toggle {
		display: inline-flex;
	}

	.site-header.is-open .mobile-nav {
		display: block;
	}

	.hero-premium {
		min-height: auto;
		padding-top: 116px;
		padding-bottom: 58px;
	}

	.hero-stats,
	.steps-grid,
	.feature-grid {
		grid-template-columns: 1fr;
	}

	.hero-stats div {
		border-top: 1px solid var(--line);
		border-left: 0;
	}

	.hero-stats div:first-child {
		border-top: 0;
	}

	.menu-showcase {
		grid-template-columns: 132px minmax(0, 1fr);
	}

	.menu-showcase__grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.wrap,
	.site-header__inner,
	.mobile-nav,
	.site-footer__inner {
		width: min(100% - 28px, 1160px);
	}

	h1 {
		max-width: 100%;
		font-size: clamp(1.95rem, 8.6vw, 2.12rem);
	}

	h1 .hero-title__word {
		display: block;
	}

	h2 {
		font-size: 1.85rem;
	}

	.brand__name {
		font-size: 0.86rem;
	}

	.hero-premium__actions {
		display: grid;
	}

	.hero-premium__lead {
		max-width: 32ch;
		font-size: 0.98rem;
	}

	.product-card__top {
		flex-direction: column;
	}

	.product-card h3 {
		font-size: 1.65rem;
	}

	.menu-showcase {
		grid-template-columns: 1fr;
	}

	.menu-showcase__aside {
		border-right: 0;
		border-bottom: 1px solid rgba(126, 82, 217, 0.42);
	}

	.menu-showcase__nav {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.showcase-row {
		grid-template-columns: minmax(0, 1fr) 96px;
	}

	.product-panel div {
		min-height: 104px;
	}

	.section {
		padding: 64px 0;
	}

	.section--visual {
		padding-top: 0;
	}

	.support-panel {
		padding: 1.2rem;
	}

	.support-panel__actions {
		display: grid;
		justify-content: stretch;
	}

	.site-footer__inner {
		align-items: flex-start;
		flex-direction: column;
		justify-content: center;
		padding: 1.4rem 0;
	}

	.site-footer__meta {
		justify-content: flex-start;
	}
}
