:root {
	--page-top: #0F172A;
	--page-mid: #21238C;
	--panel-bg: #0F172B;
	--card: #1E247E;
	--card-border: #4F57AA;
	--plate: #0F172A;
	--rank: #ABB3FF;
	--yellow: #FEFF0B;
	--split: #4749A0;
	--table-head: #0C0E79;
	--table-border: #5556A1;
	--row-a: rgba(255, 255, 255, 0.2);
	--row-b: rgba(255, 255, 255, 0.1);
	--toc: #7275D6;
	--faq: #1E247E;
	--faq-border: #4F57AA;
	--green: #00DA28;
	--red: #FF2727;
	--text: #F5F5F5;
	--white-border: #F5F5F5;
	--footer-link: #EEEEEE;
	--footer-link-text: #5F5F5F;
	--tagline: #D4D4D4;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	scroll-padding-block-start: 100px;
}

body {
	margin: 0;
	padding: 0;
	min-height: 100vh;
	background: linear-gradient(180deg, var(--page-top) 0%, var(--page-mid) 50%, var(--page-top) 100%);
	color: var(--text);
	font-family: 'Roboto', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
	font-size: 16px;
	line-height: 1.4;
	font-weight: 400;
	-webkit-text-size-adjust: none;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
}

a {
	color: var(--text);
	text-decoration: none;
}

p {
	margin: 12px 0 0 0;
}

p:first-child {
	margin-top: 0;
}

svg[class^="icon"],
svg[class*=" icon"] {
	width: 20px;
	height: 20px;
	display: inline-block;
	vertical-align: middle;
	flex: none;
}

.wrap {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 20px;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 30;
}

.site-header > .wrap {
	display: flex;
	align-items: center;
	background: var(--panel-bg);
	border: 1px solid var(--white-border);
	border-top: none;
	border-radius: 0 0 20px 20px;
	padding: 14px 20px;
}

.logo-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: 'Inter', sans-serif;
	font-weight: 600;
	font-size: 32px;
	line-height: 1.2;
	color: var(--text);
}

.logo-emoji {
	font-size: 30px;
}

.logo-link .logo-img {
	display: block;
	height: 44px;
	width: auto;
	max-width: 100%;
}
.site-footer .logo .logo-img {
	display: block;
	height: 44px;
	width: auto;
	max-width: 100%;
}


.site-content {
	padding: 48px 0 64px 0;
}

.site-main {
	display: flex;
	flex-direction: column;
	gap: 48px;
}

.page-section {
	margin: 0;
}

.page-section > header > .label,
h1.label {
	margin: 0 0 15px 0;
	color: var(--text);
	font-family: 'Roboto', sans-serif;
	font-size: 32px;
	font-weight: 600;
	line-height: 1.18;
}

h1.label {
	font-size: 40px;
	font-weight: 700;
}

.page-section .content > .text {
	color: var(--text);
	font-size: 16px;
	line-height: 1.18;
}

.page-section.head .content {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.page-section.head .text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 12px;
}

.hero-more {
	display: none;
}

.head .content.expanded .hero-more {
	display: block;
}

.hero-more > p {
	margin: 12px 0 0 0;
}

.hero-more .table-wrap {
	margin-top: 16px;
}

.hero-more table {
	min-width: 0;
}

.show-more {
	padding: 0;
	background: none;
	border: none;
	color: var(--text);
	font: inherit;
	font-size: 14px;
	font-weight: 500;
	text-decoration: underline;
	cursor: pointer;
}

.byline {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 20px;
}

.byline .updated {
	font-size: 14px;
	color: var(--text);
}

.byline .author {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.byline .avatar {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	overflow: hidden;
	flex: none;
}

.byline .avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.byline .aname {
	font-size: 14px;
	font-weight: 500;
	color: var(--text);
}

.cta-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	border-radius: 10px;
	background: var(--yellow);
	color: #000;
	font-size: 18px;
	font-weight: 400;
	cursor: pointer;
	transition: filter 0.2s ease, box-shadow 0.2s ease, transform 0.05s ease;
}

.cta-btn:hover {
	filter: brightness(1.04);
	box-shadow: 0 0 0 3px rgba(254, 255, 11, 0.18), 0 8px 26px rgba(254, 255, 11, 0.35);
}

.cta-btn:active {
	transform: translateY(1px);
}

.logo-plate {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--plate);
	border: 1px solid var(--card-border);
	border-radius: 15px;
	overflow: hidden;
	text-align: center;
}

.logo-plate > span {
	font-weight: 800;
	letter-spacing: 0.5px;
	color: #fff;
	padding: 8px;
	font-size: 22px;
}

.logo-plate > img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: inherit;
}


.logo-freshbet > span { color: #F4C20D; }
.logo-vipluck > span { font-style: italic; font-family: Georgia, "Times New Roman", serif; }
.logo-ritzo > span { color: #E8773A; font-family: Georgia, "Times New Roman", serif; letter-spacing: 1px; }
.logo-newlucky > span { color: #19D27B; }
.logo-wildtokyo > span { color: #F2F2F2; }
.logo-winzter > span { color: #C9C6FF; }
.logo-slotsquad > span { color: #FF5BA3; }

.toplist .content {
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.toplist .content > .text {
	margin: 0;
}

.top-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	align-items: stretch;
}

.top-card {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 14px 20px;
	background: var(--card);
	border: 1px solid var(--card-border);
	border-radius: 15px;
}

.top-card .logo-plate {
	aspect-ratio: 3 / 2;
	height: auto;
	padding: 0;
}

.top-card .name {
	margin: 0;
	text-align: center;
	font-size: 20px;
	font-weight: 600;
	text-transform: none;
	color: var(--text);
	min-height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.check-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}

.check-list li {
	display: flex;
	gap: 8px;
	font-size: 14px;
	line-height: 1.14;
	color: var(--text);

	align-items: flex-start;
	min-height: 32px;}

.check-list .icon-check {
	width: 16px;
	height: 16px;
	color: var(--text);
	margin-top: 1px;
}

.toc-box {
	border-radius: 10px;
	overflow: hidden;
	background: var(--toc);
}

.toc-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	padding: 12px 20px;
	border: none;
	background: none;
	color: #fff;
	font-family: 'Roboto', sans-serif;
	font-weight: 400;
	font-size: 18px;
	cursor: pointer;
}

.toc-toggle .icon-chevron {
	transition: transform 0.25s ease;
}

.toc-toggle[aria-expanded="true"] .icon-chevron {
	transform: rotate(180deg);
}

.toc-wrap {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
}

.toc {
	list-style: decimal;
	margin: 0;
	padding: 8px 28px 22px 46px;
	border-top: 1px solid rgba(255, 255, 255, 0.25);
}

.toc li {
	padding: 7px 0;
	color: #fff;
	font-weight: 400;
}

.toc li::marker {
	color: rgba(255, 255, 255, 0.7);
}

.review-list {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.review-item {
	display: flex;
	gap: 20px;
	padding: 20px;
	border: 1px solid var(--card-border);
	border-radius: 15px;
}

.review-item .logo-plate {
	flex: none;
	width: 295px;
	align-self: stretch;
	min-height: 176px;
	background: linear-gradient(160deg, #2B2766 0%, #161240 100%);
}

.review-item .logo-plate img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: inherit;
}

.review-item .info {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.review-item .info .title {
	margin: 0;
	font-size: 20px;
	font-weight: 600;
	color: var(--text);
}

.review-item .desc {
	font-size: 16px;
	line-height: 1.18;
	color: var(--text);
}

.tx-block .content,
.reviews .content {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.tx-block .bar-list {
	margin-top: 20px;
}

.table-wrap {
	margin: 0;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: 15px;
	border: 1px solid var(--table-border);
}

table {
	width: 100%;
	min-width: 640px;
	border-collapse: collapse;
	font-size: 14px;
	text-align: left;
}

table thead th {
	background: var(--table-head);
	color: #fff;
	font-weight: 700;
	padding: 12px;
	white-space: nowrap;
}

table tbody td {
	padding: 12px;
	color: #fff;
	font-weight: 500;
}

table tbody tr:nth-child(odd) {
	background: var(--row-a);
}

table tbody tr:nth-child(even) {
	background: var(--row-b);
}

table th + th,
table td + td {
	border-left: 1px solid var(--table-border);
}

table tbody tr + tr td {
	border-top: 1px solid var(--table-border);
}

.bar-list {
	list-style: none;
	margin: 0;
	padding: 0;
	overflow: hidden;
	border-radius: 15px;
}

.bar-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 16px;
	font-size: 14px;
	color: #fff;
}

.bar-list li:nth-child(odd) {
	background: var(--row-a);
}

.bar-list li:nth-child(even) {
	background: var(--row-b);
}

.bar-list .dot {
	flex: none;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #fff;
	margin: 0 5px;
}

.split-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.split-card {
	padding: 20px;
	background: var(--split);
	border: 1px solid var(--card-border);
	border-radius: 15px;
}

.split-title {
	margin: 0 0 13px 0;
	font-size: 20px;
	font-weight: 600;
	color: var(--text);
}

.pros-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.pros-list li {
	display: flex;
	gap: 10px;
}

.pros-list .icon {
	width: 20px;
	height: 20px;
	margin-top: 1px;
}

.split-card.pros .icon-plus {
	color: var(--green);
}

.split-card.cons .icon-minus {
	color: var(--red);
}

.pros-list li > div {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.pros-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--text);
	line-height: 1.14;
}

.pros-desc {
	font-size: 14px;
	font-weight: 400;
	color: var(--text);
	line-height: 1.14;
}

.faq-list {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.faq-item {
	overflow: hidden;
	background: var(--faq);
	border: 1px solid var(--faq-border);
	border-radius: 10px;
}

.faq-q {
	margin: 0;
	padding: 0;
	font: inherit;
}

.faq-item .label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	width: 100%;
	margin: 0;
	padding: 16px 20px;
	background: none;
	border: none;
	text-align: left;
	cursor: pointer;
	color: #fff;
	font-family: 'Roboto', sans-serif;
}

.faq-item .label .name {
	margin: 0;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.16;
}

.faq-item .label .open-icon {
	flex: none;
	color: #fff;
}

.faq-item .label .icon-chevron {
	width: 24px;
	height: 24px;
	transition: transform 0.25s ease;
}

.faq-item .label[aria-expanded="true"] .icon-chevron {
	transform: rotate(180deg);
}

.faq-item > .value {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
}

.faq-item > .value > div {
	padding: 0 20px 18px 20px;
	font-size: 15px;
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.92);
}

.site-footer {
	margin-top: 48px;
}

.site-footer > .wrap {
	display: flex;
	flex-direction: column;
	gap: 24px;
	background: var(--panel-bg);
	border: 1px solid var(--white-border);
	border-bottom: none;
	border-radius: 20px 20px 0 0;
	padding: 20px;
}

.footer-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px;
}

.site-footer .logo {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: 'Inter', sans-serif;
	font-weight: 600;
	font-size: 42px;
	line-height: 1.2;
	color: var(--text);
}

.site-footer .logo .logo-emoji {
	font-size: 38px;
}

.footer-top .info .tagline {
	margin: 12px 0 0 0;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 500;
	color: var(--tagline);
}

.footer-links {
	display: flex;
	gap: 20px;
}

.footer-links .flink {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 24px;
	border-radius: 20px;
	background: var(--footer-link);
	color: var(--footer-link-text);
	font-family: 'Inter', sans-serif;
	font-size: 18px;
	font-weight: 700;
}

.footer-links .flink .icon-link {
	width: 24px;
	height: 24px;
	color: #333538;
}

.footer-bottom {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	text-align: center;
}

.footer-bottom p {
	margin: 0;
	font-family: 'Inter', sans-serif;
	font-size: 16px;
}

.footer-bottom .responsible {
	font-weight: 600;
	color: var(--red);
}

.footer-bottom .copyright {
	font-weight: 500;
	color: #fff;
}

.scroll-top {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 40;
	width: 70px;
	height: 70px;
	border: none;
	border-radius: 50%;
	background: var(--toc);
	color: #fff;
	cursor: pointer;
	box-shadow: 0 8px 22px rgba(114, 117, 214, 0.4);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s ease, visibility 0.25s ease;
}

.scroll-top .icon-chevron {
	width: 28px;
	height: 28px;
	transform: rotate(180deg);
}

.scroll-top.show {
	opacity: 1;
	visibility: visible;
}

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

@media (max-width: 768px) {
	.page-section > header > .label {
		font-size: 26px;
	}

	h1.label {
		font-size: 32px;
	}

	.review-item {
		flex-direction: column;
		gap: 16px;
	}

	.review-item .logo-plate {
		width: 100%;
		min-height: 150px;
	}

	.split-grid {
		grid-template-columns: 1fr;
	}

	.site-footer .logo {
		font-size: 34px;
	}

	.scroll-top {
		width: 48px;
		height: 48px;
		right: 14px;
		bottom: 14px;
	}

	.scroll-top .icon-chevron {
		width: 22px;
		height: 22px;
	}
}

@media (max-width: 520px) {
	.site-header > .wrap {
		padding: 10px 14px;
	}

	.logo-link .logo-img {
		height: 36px;
	}

	.top-grid {
		grid-template-columns: 1fr;
	}

	.footer-top {
		flex-direction: column;
		align-items: flex-start;
	}

	.footer-links {
		width: 100%;
	}
}
