.tdi-rotation-box-wrapper {
	position: relative;
	width: calc(var(--tdi-size) + (var(--tdi-gap) * 2));
	height: calc(var(--tdi-size) + (var(--tdi-gap) * 2));
	z-index: 9999;
}

.tdi-rotation-box-wrapper.tdi-is-hidden {
	display: none !important;
}

.tdi-reopen-button {
	position: fixed;
	right: 20px;
	bottom: 20px;
	display: none;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	background: rgba(4, 15, 27, 0.88);
	color: #ffffff;
	cursor: pointer;
	z-index: 10000;
	backdrop-filter: blur(8px);
	box-shadow: 0 16px 32px rgba(4, 15, 27, 0.25);
	transition: transform 0.2s ease, background 0.2s ease, opacity 0.2s ease;
}

.tdi-reopen-button.tdi-is-visible {
	display: inline-flex;
}

.tdi-reopen-button:hover,
.tdi-reopen-button:focus {
	background: rgba(4, 15, 27, 0.96);
	transform: translateY(-1px);
}

.tdi-reopen-button:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

.tdi-reopen-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	border-radius: 999px;
	background: rgba(14, 165, 198, 0.2);
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
}

.tdi-reopen-text {
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
}

.tdi-size-small {
	--tdi-size: 140px;
	--tdi-gap: 16px;
	--tdi-font-size: 13px;
}

.tdi-size-medium {
	--tdi-size: 200px;
	--tdi-gap: 22px;
	--tdi-font-size: 15px;
}

.tdi-size-large {
	--tdi-size: 260px;
	--tdi-gap: 28px;
	--tdi-font-size: 17px;
}

.tdi-rotation-180 {
	--tdi-rotate-x-start: 0deg;
	--tdi-rotate-x-end: 0deg;
	--tdi-rotate-y-start: -28deg;
	--tdi-rotate-y-end: 152deg;
}

.tdi-rotation-360 {
	--tdi-rotate-x-start: -22deg;
	--tdi-rotate-x-end: 338deg;
	--tdi-rotate-y-start: -32deg;
	--tdi-rotate-y-end: 328deg;
}
.tdi-is-floating {
	position: fixed;
	bottom: 20px;
}

.tdi-position-left {
	left: 20px;
}

.tdi-position-right {
	right: 20px;
}

.tdi-is-inline {
	position: relative;
	margin: 24px auto;
}

.tdi-close-button {
	position: absolute;
	top: 2px;
	right: 2px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	background: rgba(4, 15, 27, 0.78);
	color: #ffffff;
	cursor: pointer;
	z-index: 3;
	backdrop-filter: blur(6px);
	transition: background 0.2s ease, transform 0.2s ease, opacity 0.2s ease;
}

.tdi-close-button:hover,
.tdi-close-button:focus {
	background: rgba(4, 15, 27, 0.92);
	transform: scale(1.05);
}

.tdi-close-button:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 2px;
}

.tdi-close-button span {
	font-size: 22px;
	line-height: 1;
	transform: translateY(-1px);
}

.tdi-rotation-scene {
	position: relative;
	width: var(--tdi-size);
	height: var(--tdi-size);
	margin: var(--tdi-gap);
	perspective: 1400px;
	perspective-origin: 50% 42%;
	transform-style: preserve-3d;
}

.tdi-rotation-scene::after {
	content: "";
	position: absolute;
	left: 12%;
	right: 12%;
	bottom: -18px;
	height: 26px;
	border-radius: 50%;
	background: rgba(2, 12, 27, 0.28);
	box-shadow: var(--tdi-box-shadow);
	filter: blur(18px);
	opacity: 0.65;
	pointer-events: none;
}

.tdi-cube {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	transform-style: preserve-3d;
	transform: rotateX(var(--tdi-rotate-x-start, -22deg)) rotateY(var(--tdi-rotate-y-start, -32deg));
	animation: tdi-cube-spin 8s linear infinite;
	will-change: transform;
}

.tdi-rotation-box-wrapper:hover .tdi-cube {
	animation-play-state: paused;
}

.tdi-face {
	position: absolute;
	top: 0;
	left: 0;
	width: var(--tdi-size);
	height: var(--tdi-size);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 4px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 0;
	color: var(--tdi-text-color);
	text-align: center;
	backface-visibility: hidden;
	opacity: 0.96;
	background: linear-gradient(to right, var(--tdi-box-color), var(--tdi-box-color-deep));
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), inset 0 -18px 30px rgba(4, 15, 27, 0.12);
}

.tdi-face::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.16), transparent 58%);
	pointer-events: none;
}

.tdi-face-front,
.tdi-cube .s1 {
	transform: translateZ(calc(var(--tdi-size) / 2));
}

.tdi-face-right,
.tdi-cube .s2 {
	transform: rotateY(90deg) translateZ(calc(var(--tdi-size) / 2));
}

.tdi-face-back,
.tdi-cube .s3 {
	transform: rotateY(180deg) translateZ(calc(var(--tdi-size) / 2));
}

.tdi-face-top,
.tdi-cube .s4 {
	transform: rotateX(90deg) translateZ(calc(var(--tdi-size) / 2));
}

.tdi-face-left,
.tdi-cube .s5 {
	transform: rotateY(-90deg) translateZ(calc(var(--tdi-size) / 2));
}

.tdi-face-bottom,
.tdi-cube .s6 {
	transform: rotateX(-90deg) translateZ(calc(var(--tdi-size) / 2)) rotate(180deg);
}

.tdi-cube .s2,
.tdi-cube .s5 {
	background: linear-gradient(to right, var(--tdi-box-color-light), var(--tdi-box-color-dark));
}

.tdi-cube .s3,
.tdi-cube .s6 {
	background: linear-gradient(to right, var(--tdi-box-color-dark), var(--tdi-box-color-deep));
}

.tdi-cube .s4 {
	background: linear-gradient(to right, var(--tdi-box-color-light), var(--tdi-box-color));
}

.tdi-face-text {
	position: relative;
	z-index: 1;
	font-size: var(--tdi-font-size);
	font-weight: 700;
	line-height: 1.45;
	letter-spacing: 0.02em;
	text-wrap: balance;
}

.tdi-face-image {
	position: relative;
	z-index: 1;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: inherit;
}

@keyframes tdi-cube-spin {
	0% {
		transform: rotateX(var(--tdi-rotate-x-start, -22deg)) rotateY(var(--tdi-rotate-y-start, -32deg));
	}
	100% {
		transform: rotateX(var(--tdi-rotate-x-end, 338deg)) rotateY(var(--tdi-rotate-y-end, 328deg));
	}
}

@media (max-width: 782px) {
	.tdi-size-small {
		--tdi-size: 120px;
		--tdi-gap: 12px;
		--tdi-font-size: 11px;
	}

	.tdi-size-medium {
		--tdi-size: 140px;
		--tdi-gap: 14px;
		--tdi-font-size: 12px;
	}

	.tdi-size-large {
		--tdi-size: 180px;
		--tdi-gap: 16px;
		--tdi-font-size: 13px;
	}

	.tdi-is-floating {
		bottom: 14px;
	}

	.tdi-reopen-button {
		right: 14px;
		bottom: 14px;
		padding: 8px 12px;
	}

	.tdi-close-button {
		top: 0;
		right: 0;
		width: 28px;
		height: 28px;
	}

	.tdi-position-left {
		left: 14px;
	}

	.tdi-position-right {
		right: 14px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.tdi-cube {
		animation-duration: 28s;
	}
}
