*,*:after,*:before {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	font-synthesis: none !important;
}
@font-face {
	font-family: 'Rubik';
	src: local('Rubik'), url(rubik.ttf) format('truetype');
}
body {
   background: radial-gradient(circle at center, #21346d 0%, #131b2b 100%);
	color: white;
	font-family: 'Rubik', sans-serif;
	width: 100%;
	height: 100%;
}
.color-primary {
	--color: #f26822;
	--color-darker: #db5b1b;
	--color-darkest: #b2440e;
}
.color-secondary-alternative {
	--color: #d8e2e7;
}
.color-roulette-green {
	--color: #30bd13;
}
.color-roulette-black {
	--color: #151515;
}
.color-roulette-blue {
	--color: #2c6bff;
}
.color-text {
	--color: white;
}
.colored {
	color: var(--color); 
}
.semibold {
	font-weight: 600;
}
.bold {
	font-weight: 700;
}
.monero-coin-container {
	width: 10em;
	height: 10em;
	position: relative;
	perspective: 300px;
	transform: translateZ(-0.4em);
	transform-style: preserve-3d;
	margin: auto;
	z-index: 999;
	user-select: none;
}
.monero-coin-colors {
	--face: #f26822;
	--face-two: #151515;
	--sign: #ffffff;
	--side: #cc5114;
	--slide: #f08149;
}
.coin {
	width: 100%;
	height: 100%;
	position: absolute;
	transform-style: preserve-3d;
	will-change: transform;
}
.monero-coin-flip-heads {
	-webkit-animation: land-heads 4s linear forwards;
	animation: land-heads 4s linear forwards;
}
.monero-coin-flip-tails {
	-webkit-animation: land-tails 4s 1 linear forwards;
	animation: land-tails 4s 1 linear forwards;
}
.monero-coin-spin {
	-webkit-animation: spin 18s -3s infinite linear;
	animation: spin 18s -3s infinite linear;
}
.face {
	border-radius: 5em;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background: var(--face);
}
.face-two {
	background: var(--face-two);
}
.front {
	transform: translate3d(0, 0, 0.4em) rotateY(0);
}
.back {
	transform: rotateY(180deg) translate3d(0, 0, 0.4em);
}
.symbol, .symbol-two {
	position: absolute;
	color: var(--sign);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 6em;
}
.symbol {
	padding-top: 0.25em;
}
.symbol-two {
	padding-top: 20px;
}
.side {
	width: 0.8em;
	height: 1.61em;
	background: var(--side);
	position: absolute;
	left: 50%;
	top: 50%;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	border-top: 0.2em solid var(--slide);
	border-bottom: 0.2em solid var(--slide);
}
figure:nth-of-type(1) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(0deg) translateZ(4.9em);
}
figure:nth-of-type(2) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(18deg) translateZ(4.9em);
}
figure:nth-of-type(3) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(36deg) translateZ(4.9em);
}
figure:nth-of-type(4) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(54deg) translateZ(4.9em);
}
figure:nth-of-type(5) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(72deg) translateZ(4.9em);
}
figure:nth-of-type(6) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(90deg) translateZ(4.9em);
}
figure:nth-of-type(7) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(108deg) translateZ(4.9em);
}
figure:nth-of-type(8) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(126deg) translateZ(4.9em);
}
figure:nth-of-type(9) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(144deg) translateZ(4.9em);
}
figure:nth-of-type(10) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(162deg) translateZ(4.9em);
}
figure:nth-of-type(11) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(180deg) translateZ(4.9em);
}
figure:nth-of-type(12) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(198deg) translateZ(4.9em);
}
figure:nth-of-type(13) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(216deg) translateZ(4.9em);
}
figure:nth-of-type(14) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(234deg) translateZ(4.9em);
}
figure:nth-of-type(15) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(252deg) translateZ(4.9em);
}
figure:nth-of-type(16) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(270deg) translateZ(4.9em);
}
figure:nth-of-type(17) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(288deg) translateZ(4.9em);
}
figure:nth-of-type(18) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(306deg) translateZ(4.9em);
}
figure:nth-of-type(19) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(324deg) translateZ(4.9em);
}
figure:nth-of-type(20) {
	transform: translate3d(-50%, -50%, 0) rotateY(90deg) rotateX(342deg) translateZ(4.9em);
}
@keyframes spin {
	0% {
		transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg);
	}
	50% {
		transform: rotateX(1800deg) rotateY(45deg) rotateZ(365deg);
	}
	100% {
		transform: rotateX(3600deg) rotateY(0deg) rotateZ(0deg);
	}
}
@keyframes land-tails {
	0% {
		transform: translateZ(0px) scale(1);
	}
	10% {
		transform: translateZ(-50px) scale(0.9);
	}
	30% {
		transform: translateZ(100px) scale(1.2) rotateX(360deg) rotateY(150deg) rotateZ(90deg);
	}
	50% {
		transform: translateZ(130px) scale(1.5) rotateX(1080deg) rotateY(270deg) rotateZ(270deg);
	}
	70% {
		transform: translateZ(100px) scale(1.2) rotateX(1800deg) rotateY(360deg) rotateZ(450deg);
	}
	90% {
		transform: translateZ(0px) scale(1) rotateX(2420deg) rotateY(700deg) rotateZ(690deg);
		box-shadow: 0 0 0 0;
		border-radius: 100em;
	}
	100% {
		transform: translateZ(-50px) scale(0.9) rotateX(2520deg) rotateY(720deg) rotateZ(720deg);
		box-shadow: 0px 0px 20px 5px rgb(160, 76, 27);
		border-radius: 100em;
	}
}
@keyframes land-heads {
	0% {
		transform: translateZ(0px) scale(1);
	}
	10% {
		transform: translateZ(-50px) scale(0.9);
	}
	30% {
		transform: translateZ(100px) scale(1.2) rotateX(360deg) rotateY(150deg) rotateZ(90deg);
	}
	50% {
		transform: translateZ(130px) scale(1.5) rotateX(1080deg) rotateY(270deg) rotateZ(270deg);
	}
	70% {
		transform: translateZ(100px) scale(1.2) rotateX(1800deg) rotateY(360deg) rotateZ(450deg);
	}
	90% {
		transform: translateZ(0px) scale(1) rotateX(2520deg) rotateY(790deg) rotateZ(840deg);
		box-shadow: 0 0 0 0;
		border-radius: 100em;
	}
	100% {
		transform: translateZ(-50px) scale(0.9) rotateX(2520deg) rotateY(900deg) rotateZ(1080deg);
		box-shadow: 0px 0px 20px 5px rgb(21, 21, 21);
		border-radius: 100em;
	}
}
.loading-ellipsis:after {
	overflow: hidden;
	display: inline-block;
	vertical-align: bottom;
	-webkit-animation: ellipsis steps(4,end) 2700ms infinite;
	animation: ellipsis steps(4,end) 2700ms infinite;
	content: "\2026";
	width: 0px;
}
@keyframes ellipsis {
	to {
		width: 0.8em;
	}
}
.modal {
	padding: 20px;
	border-radius: 10px;
	width: 400px;
	margin: 20px auto;
	background-color: #ffffff;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 9999;
   box-shadow: rgba(0, 0, 0, 0.45) 0px 5px 15px;
}
.modal-backdrop {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.5);
	z-index: 9;
}
.outcome-selector {
	text-align: center;
	margin-top: 2em;
}
.text-center {
	text-align: center;
}
.outcome-selector input {
	margin: 0;
	padding: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.outcome-selector input:active +.selectable-outcome {
	opacity: .9;
}
.outcome-selector input:checked +.selectable-outcome {
	filter: none;
	transform: scale(1.15);
}
.selectable-outcome {
	cursor: pointer;
	background-size: contain;
	background-repeat: no-repeat;
	display: inline-block;
	width: 50px;
	height: 50px;
	margin-left: 10px;
	margin-right: 10px;
	-webkit-transition: all 100ms ease-in;
	-moz-transition: all 100ms ease-in;
	transition: all 100ms ease-in;
	-webkit-filter: brightness(1.8) grayscale(1) opacity(.7);
	-moz-filter: brightness(1.8) grayscale(1) opacity(.7);
	filter: brightness(1.8) grayscale(1) opacity(.7);
}
.selectable-outcome:hover {
	-webkit-filter: brightness(1.2) grayscale(.5) opacity(.9);
	-moz-filter: brightness(1.2) grayscale(.5) opacity(.9);
	filter: brightness(1.2) grayscale(.5) opacity(.9);
}
.form-group {
	position: relative;
	margin-top: 1rem;
	margin-bottom: 1rem;
}
.form-group .control-label {
	position: absolute;
	top: 0.25rem;
	pointer-events: none;
	padding-left: 0.125rem;
	z-index: 1;
	color: #b3b3b3;
	font-size: 1rem;
	font-weight: normal;
	-webkit-transition: all 0.28s ease;
	transition: all 0.28s ease;
}
.form-group .bar {
	position: relative;
	border-bottom: 0.0625rem solid #999;
	display: block;
}
.form-group .bar::before {
	content: '';
	height: 0.125rem;
	width: 0;
	left: 50%;
	bottom: -0.0625rem;
	position: absolute;
	background: var(--color);
	-webkit-transition: left 0.28s ease, width 0.28s ease;
	transition: left 0.28s ease, width 0.28s ease;
	z-index: 2;
}
.form-group input {
	height: 1.9rem;
	display: block;
	background: none;
	padding: 0.125rem 0.125rem 0.0625rem;
	font-size: 1rem;
	border-width: 0;
	border-color: transparent;
	line-height: 1.9;
	width: 100%;
	color: transparent;
	-webkit-transition: all 0.28s ease;
	transition: all 0.28s ease;
	box-shadow: none;
}
.form-group input:focus,.form-group input:valid {
	color: #333;
}
.form-group input:focus ~ .control-label,.form-group input:valid ~ .control-label {
	font-size: 0.8rem;
	color: gray;
	top: -1rem;
	left: 0;
}
.form-group input:focus {
	outline: none;
}
.form-group input:focus ~ .control-label {
	color: var(--color);
}
.form-group input:focus ~ .bar::before {
	width: 100%;
	left: 0;
}
.checkbox label {
	position: relative;
	cursor: pointer;
	padding-left: 2rem;
	text-align: left;
	color: #333;
	display: block;
}
.checkbox input {
	width: auto;
	opacity: 0.00000001;
	position: absolute;
	left: 0;
}
.checkbox .helper {
	color: #999;
	position: absolute;
	top: 0;
	left: 0;
	width: 1rem;
	height: 1rem;
	z-index: 0;
	border: 0.125rem solid currentColor;
	border-radius: 0.0625rem;
	-webkit-transition: border-color 0.28s ease;
	transition: border-color 0.28s ease;
}
.checkbox .helper::before, .checkbox .helper::after {
	position: absolute;
	height: 0;
	width: 0.2rem;
	background-color: #f26822;
	display: block;
	-webkit-transform-origin: left top;
	transform-origin: left top;
	border-radius: 0.25rem;
	content: '';
	-webkit-transition: opacity 0.28s ease, height 0s linear 0.28s;
	transition: opacity 0.28s ease, height 0s linear 0.28s;
	opacity: 0;
}
.checkbox .helper::before {
	top: 0.65rem;
	left: 0.38rem;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
	box-shadow: 0 0 0 0.0625rem #151d30;
}
.checkbox .helper::after {
	top: 0.3rem;
	left: 0;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.checkbox label:hover .helper {
	color: #f26822;
}
.checkbox input:checked ~ .helper {
	color: #f26822;
}
.checkbox input:checked ~ .helper::after, .checkbox input:checked ~ .helper::before {
	opacity: 1;
	-webkit-transition: height 0.28s ease;
	transition: height 0.28s ease;
}
.checkbox input:checked ~ .helper::after {
	height: 0.5rem;
}
.checkbox input:checked ~ .helper::before {
	height: 1.2rem;
	-webkit-transition-delay: 0.28s;
	transition-delay: 0.28s;
}
button, input[type="submit"], input[type="reset"] {
	background: none;
	color: inherit;
	border: none;
	padding: 0;
	font: inherit;
	cursor: pointer;
	outline: inherit;
}
.button {
	position: relative;
	background: currentColor;
	border: 1px solid currentColor;
	font-size: 1.1rem;
	color: var(--color);
	width: 100%;
	padding: 0.75rem 3rem;
	cursor: pointer;
	-webkit-transition: background-color 0.28s ease, color 0.28s ease, box-shadow 0.28s ease;
	transition: background-color 0.28s ease, color 0.28s ease, box-shadow 0.28s ease;
	overflow: hidden;
	border-radius: 5px;
}
.button span {
	color: #fff;
	position: relative;
	z-index: 1;
}
.button::before {
	content: '';
	position: absolute;
	background: #071017;
	border: 50vh solid var(--color-darkest);
	width: 30vh;
	height: 30vh;
	border-radius: 50%;
	display: block;
	top: 50%;
	left: 50%;
	z-index: 0;
	opacity: 1;
	-webkit-transform: translate(-50%, -50%) scale(0);
	transform: translate(-50%, -50%) scale(0);
}
.button:hover {
	color: var(--color-darker);
}
.button:active::before, .button:focus::before {
	-webkit-transition: opacity 0.28s ease 0.364s, -webkit-transform 1.12s ease;
	transition: opacity 0.28s ease 0.364s, -webkit-transform 1.12s ease;
	transition: transform 1.12s ease, opacity 0.28s ease 0.364s;
	transition: transform 1.12s ease, opacity 0.28s ease 0.364s, -webkit-transform 1.12s ease;
	-webkit-transform: translate(-50%, -50%) scale(1);
	transform: translate(-50%, -50%) scale(1);
	opacity: 0;
}
.button:focus {
	outline: none;
}
.grow {
	transition: transform .2s ease-in-out;
}
.grow:hover {
	transform: scale(1.1);
}
.grow-subtle {
	transition: transform .2s ease-in-out;
}
.grow-subtle:hover {
	transform: scale(1.05);
}
@keyframes fade-in-up {
	0% {
		opacity: 0;
		transform: translateY(30px);
	}
	90% {
		opacity: 0;
		transform: translateY(30px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}
.fade-up-element {
	animation: fade-in-up 7s ease-out forwards;
}
.tooltip {
	position: relative;
}
.tooltip .tooltiptext {
	width: 72px;
	bottom: 115%;
	left: 50%;
	margin-left: -36px;
	background-color: white;
	color: black;
	text-align: center;
	padding: 3px;
	border-radius: 5px;
	position: absolute;
	z-index: 1;
	opacity: 0;
	transition: opacity 0.25s;
	font-size: 12px;
	font-weight: 600;
}
.tooltip:hover .tooltiptext {
	opacity: 1;
}
.loader {
	width: 21px;
	aspect-ratio: 1;
	border-radius: 50%;
	border: 4px solid white;
	animation:l20-1 0.8s infinite linear alternate,l20-2 1.6s infinite linear;
	margin: auto;
}
@keyframes l20-1{
	0% {
		clip-path: polygon(50% 50%,0 0, 50% 0%, 50% 0%, 50% 0%, 50% 0%, 50% 0% )
}
	12.5% {
		clip-path: polygon(50% 50%,0 0, 50% 0%, 100% 0%, 100% 0%, 100% 0%, 100% 0% )
}
	25% {
		clip-path: polygon(50% 50%,0 0, 50% 0%, 100% 0%, 100% 100%, 100% 100%, 100% 100% )
}
	50% {
		clip-path: polygon(50% 50%,0 0, 50% 0%, 100% 0%, 100% 100%, 50% 100%, 0% 100% )
}
	62.5% {
		clip-path: polygon(50% 50%,100% 0, 100% 0%, 100% 0%, 100% 100%, 50% 100%, 0% 100% )
}
	75% {
		clip-path: polygon(50% 50%,100% 100%, 100% 100%, 100% 100%, 100% 100%, 50% 100%, 0% 100% )
}
	100% {
		clip-path: polygon(50% 50%,50% 100%, 50% 100%, 50% 100%, 50% 100%, 50% 100%, 0% 100% )
}
}
@keyframes l20-2{
	0% {
		transform:scaleY(1) rotate(0deg)
}
	49.99%{
		transform:scaleY(1) rotate(135deg)
}
	50% {
		transform:scaleY(-1) rotate(0deg)
}
	100% {
		transform:scaleY(-1) rotate(-135deg)
}
}
@keyframes pop-in {
	0% {
		opacity: 0;
		transform: scale(0.1);
	}
	100% {
		opacity: 1;
		transform: scale(1);
	}
}
.pop-in-element {
	animation: pop-in 0.5s;
}
.pop-in-element-fast {
	animation: pop-in 0.25s;
}
.chat-announcement-fade {
	animation: chat-announce-in 0.3s ease;
}
@keyframes chat-announce-in {
	0%   { opacity: 0; transform: translateY(8px); }
	100% { opacity: 1; transform: translateY(0); }
}
.animate-active-element {
	opacity: 1;
	animation: fade 2s infinite;
}
@keyframes fade {
	0%,100% {
		opacity: 0.5 
}
	50% {
		opacity: 1 
}
}
.bubble {
	position: relative;
	display: inline-block;
	padding: 12px;
	background-color: var(--color);
	-webkit-border-radius: 15px;
	-moz-border-radius: 15px;
	border-radius: 10px;
}
.pagination {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px;
	background: rgba(0, 0, 0, 0.25);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 10px;
}
.pagination button, .pagination .ellipsis {
	color: rgba(255, 255, 255, 0.5);
	padding: 6px 12px;
	text-decoration: none;
	border-radius: 6px;
	font-size: 13px;
	transition: all 0.2s ease;
}
.pagination button.active {
	background-color: var(--color);
	color: white;
	font-weight: 600;
}
.pagination button:hover:not(.active) {
	background: rgba(255, 255, 255, 0.1);
	color: white;
}
.font-size-normal {
   font-size: 14px;
}
.font-size-small {
   font-size: 12px;
}
.dynamic-margin {
   margin: 3em;
}
@media (max-width: 666px) {
	.hidden-when-small {
		display: none;
	}
   .dynamic-margin {
      margin: 2em;
   }
}
.social-link {
   width: 1.25em;
   margin-left: 0.75em;
   margin-right: 0.75em;
   color: inherit;
   text-decoration: none;
}
.game-wrapper {
   position: relative;
   overflow-x: clip;
}
.game {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   transition: opacity 0.5s ease, transform 0.5s ease;
   opacity: 0;
   transform: translateX(200px);
   pointer-events: none;
}
.game.active {
   opacity: 1;
   transform: translateX(0);
   pointer-events: auto;
   z-index: 1;
}
.slot-animate {
   animation: winningPulse 7s ease-in-out;
}
.nice-shadow {
   box-shadow: rgba(0, 0, 0, 0.2) 0px 8px 24px;
}
@keyframes winningPulse{
	0% {
      transform: scale(1);
}
	10%{
		transform: scale(1.25);
}
	90% {
		transform: scale(1.25);
}
	100% {
      transform: scale(1);
}}
.expiry-banner {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 12px 20px;
	border-radius: 10px;
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid;
	margin-top: 1em;
	animation: pop-in 0.25s;
	max-width: 400px;
	text-align: left;
}
.expiry-banner--warning {
	border-color: #f5c542;
}
.expiry-banner--expired {
	border-color: #ff4444;
}
.expiry-banner__icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
}
.expiry-banner__text {
	font-size: 13px;
	line-height: 1.4;
}
.expiry-banner__title {
	font-weight: 700;
	margin-bottom: 2px;
}
.expiry-banner--warning .expiry-banner__title {
	color: #f5c542;
}
.expiry-banner--expired .expiry-banner__title {
	color: #ff4444;
}
.expiry-banner__subtitle {
	color: rgba(255, 255, 255, 0.6);
	font-size: 12px;
}
.bet-card {
	position: relative;
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 8px;
	padding: 1.2em;
	padding-left: calc(1.2em + 3px);
	margin-bottom: 0.75em;
	display: flex;
	gap: 0.75em;
	align-items: center;
	overflow: hidden;
	transition: background 0.7s;
}
.bet-card::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	background: var(--indicator-color);
	transition: background 0.7s;
}

/* === DICE GAME === */
.dice-scene {
   width: 100px;
   height: 130px;
   margin: auto;
   perspective: 600px;
   user-select: none;
   display: flex;
   align-items: center;
   justify-content: center;
}
.dice-unit {
   width: 100px;
   height: 100px;
   transform-style: preserve-3d;
}
.dice-face {
   position: absolute;
   width: 100px;
   height: 100px;
   background: #fff;
   border-radius: 9px;
   box-shadow: inset 0 0 9px rgba(0,0,0,0.08);
}
.dice-face--front  { transform: translateZ(50px); }
.dice-face--back   { transform: rotateY(180deg) translateZ(50px); }
.dice-face--right  { transform: rotateY(90deg) translateZ(50px); }
.dice-face--left   { transform: rotateY(-90deg) translateZ(50px); }
.dice-face--top    { transform: rotateX(90deg) translateZ(50px); }
.dice-face--bottom { transform: rotateX(-90deg) translateZ(50px); }
.dice-inner {
   position: absolute;
   width: 100px;
   height: 100px;
   background: #e0e0e0;
   border-radius: 9px;
}
.dice-inner--front  { transform: translateZ(49px); }
.dice-inner--back   { transform: rotateY(180deg) translateZ(49px); }
.dice-inner--right  { transform: rotateY(90deg) translateZ(49px); }
.dice-inner--left   { transform: rotateY(-90deg) translateZ(49px); }
.dice-inner--top    { transform: rotateX(90deg) translateZ(49px); }
.dice-inner--bottom { transform: rotateX(-90deg) translateZ(49px); }
.dice-cover {
   position: absolute;
   width: 100px;
   height: 100px;
   background: #e0e0e0;
}
.dice-cover--x { transform: rotateY(90deg); }
.dice-cover--z { transform: rotateX(90deg); }
.dice-dot {
   position: absolute;
   width: 17px;
   height: 17px;
   background: #444;
   border-radius: 50%;
   box-shadow: inset 2px 0 3px rgba(0,0,0,0.4);
}
.dice-dot--center { top: 41.5px; left: 41.5px; }
.dice-dot--tl     { top: 15px; left: 15px; }
.dice-dot--tr     { top: 15px; left: 68px; }
.dice-dot--bl     { top: 68px; left: 15px; }
.dice-dot--br     { top: 68px; left: 68px; }
.dice-dot--ml     { top: 41.5px; left: 15px; }
.dice-dot--mr     { top: 41.5px; left: 68px; }

/* Idle spin */
.dice-spin {
   animation: dice-tumble 18s -3s infinite linear;
}
@keyframes dice-tumble {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   16%  { transform: rotateX(180deg) rotateY(180deg) rotateZ(0deg); }
   33%  { transform: rotateX(360deg) rotateY(90deg) rotateZ(180deg); }
   50%  { transform: rotateX(360deg) rotateY(360deg) rotateZ(360deg); }
   66%  { transform: rotateX(180deg) rotateY(360deg) rotateZ(270deg); }
   83%  { transform: rotateX(270deg) rotateY(180deg) rotateZ(180deg); }
   100% { transform: rotateX(-60deg) rotateY(360deg) rotateZ(360deg); }
}

/* Landing animations per face — cubic-bezier simulates throw: accelerate then long deceleration */
.dice-land-1 { animation: dice-land-1 4s cubic-bezier(0.09, 0.7, 0.22, 1) forwards; }
.dice-land-2 { animation: dice-land-2 4s cubic-bezier(0.09, 0.7, 0.22, 1) forwards; }
.dice-land-3 { animation: dice-land-3 4s cubic-bezier(0.09, 0.7, 0.22, 1) forwards; }
.dice-land-4 { animation: dice-land-4 4s cubic-bezier(0.09, 0.7, 0.22, 1) forwards; }
.dice-land-5 { animation: dice-land-5 4s cubic-bezier(0.09, 0.7, 0.22, 1) forwards; }
.dice-land-6 { animation: dice-land-6 4s cubic-bezier(0.09, 0.7, 0.22, 1) forwards; }

@keyframes dice-land-1 {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   100% { transform: rotateX(2890deg) rotateY(2170deg) rotateZ(1460deg); }
}
@keyframes dice-land-2 {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   100% { transform: rotateX(2800deg) rotateY(2370deg) rotateZ(1450deg); }
}
@keyframes dice-land-3 {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   100% { transform: rotateX(2880deg) rotateY(2420deg) rotateZ(1430deg); }
}
@keyframes dice-land-4 {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   100% { transform: rotateX(2880deg) rotateY(2260deg) rotateZ(1450deg); }
}
@keyframes dice-land-5 {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   100% { transform: rotateX(2960deg) rotateY(2280deg) rotateZ(1460deg); }
}
@keyframes dice-land-6 {
   0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
   100% { transform: rotateX(2890deg) rotateY(2350deg) rotateZ(1430deg); }
}