*,
*::before,
*::after {
	box-sizing: border-box;
}
* {
	margin: 0;
}
html,
body {
	min-height: 100%;
}
html:focus-within {
	scroll-behavior: smooth;
}
img,
picture,
svg {
	display: block;
	max-width: 100%;
}
button,
input,
select,
textarea {
	font: inherit;
	color: inherit;
}

:root {
	--bg: #0a0a0a;
	--surface-1: #101211;
	--surface-2: #141816;
	--surface-3: #0f0f0f;
	--text-1: #eafff6;
	--text-2: #b7e6d3;
	--muted: #9ad9c3;
	--accent: #00ff99;
	--accent-rgb: 0, 255, 153;
	--border: rgba(255, 255, 255, 0.06);
	--elev-1:
		0 6px 20px rgba(0, 0, 0, 0.35), 0 0 14px rgba(var(--accent-rgb), 0.1);
	--elev-2:
		0 10px 30px rgba(0, 0, 0, 0.45), 0 0 18px rgba(var(--accent-rgb), 0.12);
	--container: min(1120px, 92vw);
	--radius-1: 12px;
	--radius-2: 16px;
	--radius-3: 22px;
	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 24px;
	--space-6: 32px;
	--space-7: 48px;
	--fs-1: clamp(0.9rem, 0.6vw + 0.7rem, 1.05rem);
	--fs-2: clamp(1.05rem, 0.8vw + 0.9rem, 1.25rem);
	--fs-3: clamp(1.25rem, 1.1vw + 1rem, 1.6rem);
	--fs-hero: clamp(1.6rem, 3.2vw + 1rem, 3rem);
}

body {
	background: var(--bg);
	color: var(--text-1);
	font-family:
		"Inter",
		system-ui,
		-apple-system,
		BlinkMacSystemFont,
		"Segoe UI",
		sans-serif;
	-webkit-font-smoothing: antialiased;
	line-height: 1.6;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding: var(--space-7) 0;
}
.element::-webkit-scrollbar {
	display: none;
}

.casino-container {
	width: var(--container);
	margin: 0 auto;
	background: rgba(16, 18, 17, 0.68);
	border: 1px solid var(--border);
	border-radius: var(--radius-2);
	box-shadow: var(--elev-1);
	padding: var(--space-6);
	backdrop-filter: blur(10px) saturate(1.08);
	-webkit-backdrop-filter: blur(10px) saturate(1.08);
	position: relative;
}

.casino-title {
	text-align: center;
	color: var(--accent);
	font-size: var(--fs-hero);
	margin-bottom: var(--space-5);
	font-weight: 800;
	text-shadow: 0 0 20px rgba(var(--accent-rgb), 0.5);
}

.roulette-machine {
	background: var(--surface-2);
	border-radius: var(--radius-2);
	border: 2px solid var(--border);
	box-shadow: var(--elev-2);
	padding: var(--space-5);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-5);
}

.roulette-layout {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-6);
	width: 100%;
}

/* Колесо */
.roulette-wheel-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-4);
	width: 100%;
	margin: 0 auto;
}

.roulette-wheel-shell {
	position: relative;
	width: min(380px, 70vw);
	height: min(380px, 70vw);
}

.roulette-wheel {
	position: absolute;
	inset: 0;
	margin: auto;
	border-radius: 50%;
	background:
		radial-gradient(
			circle at center,
			#151b17 0,
			#151b17 45%,
			#0a0d0b 46%,
			#0a0d0b 54%,
			transparent 55%
		),
		var(
			--wheel-gradient,
			conic-gradient(
				from 0deg,
				#b00020 0deg 10deg,
				#111 10deg 20deg,
				#b00020 20deg 30deg,
				#111 30deg 40deg,
				#b00020 40deg 50deg,
				#111 50deg 60deg,
				#b00020 60deg 70deg,
				#111 70deg 80deg,
				#b00020 80deg 90deg,
				#111 90deg 100deg,
				#b00020 100deg 110deg,
				#111 110deg 120deg,
				#b00020 120deg 130deg,
				#111 130deg 140deg,
				#b00020 140deg 150deg,
				#111 150deg 160deg,
				#b00020 160deg 170deg,
				#111 170deg 180deg,
				#b00020 180deg 190deg,
				#111 190deg 200deg,
				#b00020 200deg 210deg,
				#111 210deg 220deg,
				#b00020 220deg 230deg,
				#111 230deg 240deg,
				#b00020 240deg 250deg,
				#111 250deg 260deg,
				#b00020 260deg 270deg,
				#111 270deg 280deg,
				#b00020 280deg 290deg,
				#111 290deg 300deg,
				#b00020 300deg 310deg,
				#111 310deg 320deg,
				#b00020 320deg 330deg,
				#111 330deg 340deg,
				#b00020 340deg 350deg,
				#111 350deg 360deg
			)
		);
	transition: transform 3.5s cubic-bezier(0.22, 0.61, 0.31, 1);
}

.roulette-wheel-inner {
	position: absolute;
	inset: 20%;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 0.12);
	box-shadow: inset 0 0 18px rgba(0, 0, 0, 0.8);
}

.roulette-wheel-center {
	position: absolute;
	inset: 42%;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, #282f2b, #060807);
	box-shadow:
		0 0 8px rgba(0, 0, 0, 0.8),
		0 0 18px rgba(var(--accent-rgb), 0.25);
}

.roulette-pointer {
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-bottom: 18px solid var(--accent);
	filter: drop-shadow(0 0 6px rgba(var(--accent-rgb), 0.8));
	z-index: 3;
}

.roulette-numbers-ring {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	pointer-events: none;
	color: var(--text-1);
	opacity: 0.9;
}

.wheel-label {
	position: absolute;
	top: 50%;
	left: 50%;
	transform-origin: center center;
	will-change: transform;
	text-align: center;
	width: clamp(18px, 4vw, 32px);
	padding: 2px 0;
	font-size: clamp(0.55rem, 0.45vw + 0.45rem, 0.78rem);
	font-weight: 700;
	letter-spacing: 0.06em;
	text-shadow: 0 0 6px rgba(0, 0, 0, 0.85);
	border-left: 1px solid rgba(0, 0, 0, 0.7);
	border-right: 1px solid rgba(0, 0, 0, 0.7);
	background: rgba(0, 0, 0, 0.8);
	border-radius: 2px;
	box-shadow: inset 0 0 4px rgba(255, 255, 255, 0.08);
	z-index: 2;
}

.wheel-label.red {
	color: #ffbabf;
}
.wheel-label.black {
	color: #f4f4f4;
}
.wheel-label.green {
	color: #9fffd3;
}

.roulette-number-display {
	text-align: center;
	font-size: var(--fs-2);
	color: var(--text-2);
}

.roulette-number-display span {
	font-weight: 700;
	color: var(--accent);
}

/* Стол */
.roulette-table {
	background: radial-gradient(circle at top, #1b211d, #0b0e0c);
	border-radius: var(--radius-2);
	border: 1px solid var(--border);
	padding: var(--space-4);
	position: relative;
	overflow: hidden;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}

.table-title {
	font-size: var(--fs-2);
	margin-bottom: var(--space-3);
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.numbers-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 2px;
	margin-bottom: var(--space-3);
}

.numbers-row-zero {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	margin-bottom: 4px;
}

.bet-cell {
	position: relative;
	padding: 8px 4px;
	text-align: center;
	font-size: var(--fs-1);
	border-radius: 6px;
	border: 1px solid rgba(255, 255, 255, 0.06);
	cursor: pointer;
	user-select: none;
	overflow: hidden;
	transition:
		background 0.18s ease,
		transform 0.1s ease,
		box-shadow 0.18s ease,
		border-color 0.18s ease;
}

.bet-cell:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
	border-color: rgba(var(--accent-rgb), 0.55);
}

.bet-number {
	background: rgba(0, 0, 0, 0.55);
}
.bet-number.red {
	background: linear-gradient(180deg, #4a0008, #250004);
}
.bet-number.black {
	background: linear-gradient(180deg, #151515, #070707);
}
.bet-number.zero {
	background: linear-gradient(180deg, #004b2d, #021811);
}

.bet-outside-row {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 4px;
	margin-bottom: 4px;
}

.bet-outside-row.wide {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.bet-cell.outside {
	background: rgba(7, 10, 8, 0.9);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.bet-cell.outside.highlight {
	border-color: rgba(var(--accent-rgb), 0.7);
	box-shadow: 0 0 16px rgba(var(--accent-rgb), 0.45);
}

.bet-cell-label-small {
	font-size: 0.75rem;
	opacity: 0.75;
}

/* Монетки */
.bet-chip {
	position: absolute;
	width: 18px;
	height: 18px;
	border-radius: 999px;
	border: 2px solid rgba(0, 0, 0, 0.9);
	background:
		radial-gradient(
			circle at 30% 30%,
			rgba(255, 255, 255, 0.3),
			transparent 40%
		),
		radial-gradient(
			circle at center,
			rgba(var(--accent-rgb), 0.9),
			rgba(var(--accent-rgb), 0.55)
		);
	box-shadow:
		0 0 6px rgba(var(--accent-rgb), 0.65),
		0 0 0 1px rgba(0, 0, 0, 0.75);
	bottom: 4px;
	right: 4px;
	transform-origin: center;
	pointer-events: none;
}

.bet-chip:nth-child(2) {
	right: 22px;
	bottom: 4px;
}
.bet-chip:nth-child(3) {
	right: 4px;
	bottom: 22px;
}
.bet-chip:nth-child(4) {
	right: 22px;
	bottom: 22px;
}
.bet-chip:nth-child(5) {
	right: 13px;
	bottom: 13px;
}

.bet-chip-count {
	position: absolute;
	top: 2px;
	left: 2px;
	right: 2px;
	bottom: 2px;
	border-radius: inherit;
	border: 1px solid rgba(0, 0, 0, 0.7);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.6rem;
	font-weight: 700;
	color: #020403;
	text-shadow: 0 0 4px rgba(255, 255, 255, 0.7);
}

@keyframes chip-win {
	0% {
		transform: translateY(0) scale(1);
		opacity: 1;
	}
	100% {
		transform: translateY(42px) scale(0.7);
		opacity: 0;
	}
}
@keyframes chip-lose {
	0% {
		transform: translateY(0) scale(1);
		opacity: 1;
	}
	100% {
		transform: translateY(-42px) scale(0.7);
		opacity: 0;
	}
}

.chip-win {
	animation: chip-win 0.7s ease-out forwards;
}
.chip-lose {
	animation: chip-lose 0.7s ease-out forwards;
}

/* Нижняя панель: кнопка и сообщения */
.controls-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	margin-top: var(--space-4);
	border-top: 1px solid var(--border);
	padding-top: var(--space-3);
}

.spin-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-3) var(--space-5);
	background: linear-gradient(
		180deg,
		rgba(var(--accent-rgb), 0.24) 0%,
		rgba(var(--accent-rgb), 0.12) 100%
	);
	border: 1px solid rgba(var(--accent-rgb), 0.5);
	border-radius: var(--radius-2);
	color: var(--accent);
	font-size: var(--fs-2);
	font-weight: 600;
	cursor: pointer;
	transition: all 0.22s ease;
	box-shadow: var(--elev-1);
	position: relative;
	overflow: hidden;
	white-space: nowrap;
	text-decoration: none;
	gap: 8px;
}

.spin-button:hover:not(:disabled) {
	transform: translateY(-2px);
	box-shadow:
		0 8px 24px rgba(0, 0, 0, 0.5),
		0 0 12px rgba(var(--accent-rgb), 0.35);
	border-color: rgba(var(--accent-rgb), 0.85);
}

.spin-button:active:not(:disabled) {
	transform: translateY(0);
}

.spin-button:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.result-panel {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-height: 52px;
}

.result-main {
	font-size: var(--fs-2);
}

.result-main.win {
	color: var(--accent);
	font-weight: 700;
	text-shadow: 0 0 10px rgba(var(--accent-rgb), 0.7);
}

.result-main.lose {
	color: var(--muted);
}

.result-sub {
	font-size: 0.85rem;
	color: var(--text-2);
}

.result-number-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 34px;
	padding: 2px 8px;
	border-radius: 999px;
	font-weight: 700;
	margin-right: 6px;
	border: 1px solid rgba(255, 255, 255, 0.25);
}

.badge-red {
	background: #75000f;
}
.badge-black {
	background: #050505;
}
.badge-green {
	background: #005c34;
}

/* Меню игр */
.menu-hero {
	text-align: center;
	margin-bottom: var(--space-6);
}
.hero-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: 999px;
	border: 1px solid rgba(var(--accent-rgb), 0.4);
	color: var(--accent);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
}
.menu-hero h1 {
	font-size: var(--fs-hero);
	margin: var(--space-3) 0 var(--space-2);
}
.menu-hero p {
	color: var(--text-2);
	max-width: 640px;
	margin: 0 auto;
}
.hero-actions {
	display: flex;
	justify-content: center;
	gap: var(--space-3);
	margin-top: var(--space-4);
	flex-wrap: wrap;
}
.ghost-link {
	color: var(--text-2);
	text-decoration: none;
	padding: 12px 18px;
	border-radius: var(--radius-2);
	border: 1px solid rgba(255, 255, 255, 0.12);
	transition:
		border-color 0.2s ease,
		color 0.2s ease;
}
.ghost-link:hover {
	border-color: rgba(var(--accent-rgb), 0.5);
	color: var(--accent);
}
.games-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--space-4);
}
.game-card {
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.05),
		rgba(0, 0, 0, 0.35)
	);
	border-radius: var(--radius-2);
	border: 1px solid rgba(255, 255, 255, 0.1);
	padding: var(--space-4);
	box-shadow: var(--elev-1);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	position: relative;
	overflow: hidden;
}
.game-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		circle at top right,
		rgba(var(--accent-rgb), 0.15),
		transparent 55%
	);
	pointer-events: none;
}
.game-card-tag {
	align-self: flex-start;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: rgba(0, 0, 0, 0.45);
	border: 1px solid rgba(255, 255, 255, 0.12);
}
.game-card h3 {
	font-size: var(--fs-3);
	margin: 0;
}
.game-card-meta {
	font-size: 0.9rem;
	color: var(--muted);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.game-card-body {
	flex: 1;
	color: var(--text-2);
	font-size: var(--fs-1);
}
.game-card-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	align-items: center;
}
.game-card-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border-radius: var(--radius-2);
	border: 1px solid rgba(var(--accent-rgb), 0.6);
	color: var(--accent);
	text-decoration: none;
	font-weight: 600;
	transition: all 0.2s ease;
}
.game-card-cta:hover {
	border-color: rgba(var(--accent-rgb), 1);
	box-shadow: 0 0 16px rgba(var(--accent-rgb), 0.4);
}
.game-card-cta.secondary {
	border-color: rgba(255, 255, 255, 0.25);
	color: var(--text-1);
}
.game-card-cta.secondary:hover {
	border-color: rgba(var(--accent-rgb), 0.6);
	color: var(--accent);
}

.casino-footer {
	text-align: center;
	margin-top: var(--space-5);
	padding-top: var(--space-3);
	border-top: 1px solid var(--border);
	color: var(--text-2);
	font-size: 0.9rem;
}

@media (max-width: 880px) {
	.controls-row {
		flex-direction: column;
		align-items: stretch;
	}
	.spin-button {
		width: 100%;
	}
}
