html {
	scroll-behavior: smooth;
}

* {
	box-sizing: border-box;
}

html, body {
	margin: 0;
	padding: 0;
	font-family: 'Raleway', sans-serif;
	background: #07070b;
	color: #f3eadb;
}

body {
	background:
		radial-gradient(circle at top, rgba(133, 65, 180, 0.16), transparent 28%),
		radial-gradient(circle at 80% 20%, rgba(227, 150, 27, 0.08), transparent 18%),
		linear-gradient(180deg, #0d0913 0%, #08070c 45%, #060509 100%);
}

/* TOPBAR */
.topbar {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	background: rgba(8, 7, 12, 0.82);
	backdrop-filter: blur(10px);
	border-bottom: 1px solid rgba(240, 201, 121, 0.12);
}

.topbar-inner {
	max-width: 1300px;
	margin: 0 auto;
	padding: 14px 28px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
}

.logo-small {
	font-family: 'Cinzel', serif;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 2px;
	color: #f2cf86;
}

.top-links {
	display: flex;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
}

.top-links a {
	color: #e5dac8;
	text-decoration: none;
	font-size: 14px;
	font-weight: 600;
	transition: 0.2s ease;
}

.top-links a:hover {
	color: #f2cf86;
}

/* HERO */
.hero {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
	padding: 130px 40px 80px;
}

.hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			90deg,
			rgba(5, 5, 8, 0.92) 0%,
			rgba(10, 8, 15, 0.76) 42%,
			rgba(10, 8, 15, 0.86) 100%
		),
		url("background.jpg") center center / cover no-repeat;
	z-index: 0;
}

.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 72% 38%, rgba(240, 181, 77, 0.14), transparent 16%),
		radial-gradient(circle at 68% 26%, rgba(122, 53, 170, 0.18), transparent 24%);
	pointer-events: none;
	z-index: 0;
}

.hero > * {
	position: relative;
	z-index: 1;
}

.hero-inner {
	max-width: 1300px;
	margin: 0 auto;
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 70px;
	flex-wrap: wrap;
}

.hero-left {
	flex: 1 1 700px;
	max-width: 780px;
}

.hero-right {
	flex: 0 1 380px;
	display: flex;
	justify-content: center;
}

.nova-badge {
	display: inline-block;
	padding: 8px 14px;
	margin-bottom: 22px;
	font-size: 12px;
	letter-spacing: 1.8px;
	text-transform: uppercase;
	color: #f0c979;
	border: 1px solid rgba(240, 201, 121, 0.35);
	background: rgba(240, 201, 121, 0.08);
	border-radius: 999px;
	box-shadow: 0 0 20px rgba(240, 201, 121, 0.08);
}

.hero h1 {
	margin: 0 0 18px 0;
	font-size: clamp(54px, 9vw, 96px);
	line-height: 0.92;
	font-family: 'Cinzel', serif;
	font-weight: 800;
	color: #f6d995;
	text-shadow:
		0 0 18px rgba(214, 168, 95, 0.14),
		0 0 50px rgba(214, 168, 95, 0.06);
}

.hero-subtitle {
	font-size: 26px;
	font-weight: 600;
	color: #fff5e2;
	margin-bottom: 20px;
}

.hero-text {
	font-size: 18px;
	line-height: 1.9;
	color: #d8cdbf;
	max-width: 700px;
}

.hero-actions {
	margin-top: 34px;
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.hero-main-btn {
	max-width: 320px;
	margin-bottom: 0;
}

.secondary-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 16px 24px;
	border-radius: 14px;
	border: 1px solid rgba(240, 201, 121, 0.26);
	background: rgba(255, 255, 255, 0.04);
	color: #f3eadb;
	text-decoration: none;
	font-weight: 600;
	transition: 0.2s ease;
}

.secondary-btn:hover {
	text-decoration: none;
	color: #ffffff;
	transform: translateY(-2px);
	background: rgba(255, 255, 255, 0.07);
}

/* PANEL */
.cta-panel {
	width: 100%;
	max-width: 380px;
	background: linear-gradient(180deg, rgba(20, 14, 26, 0.96), rgba(9, 8, 14, 0.96));
	border: 1px solid rgba(214, 168, 95, 0.42);
	border-radius: 22px;
	padding: 28px;
	box-shadow:
		0 18px 50px rgba(0, 0, 0, 0.45),
		inset 0 1px 0 rgba(255,255,255,0.04);
	backdrop-filter: blur(6px);
}

.online-text {
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: #d8b46f;
	margin-bottom: 18px;
	text-align: center;
}

.play-btn,
button,
.btn {
	display: block;
	width: 100%;
	padding: 18px 20px;
	margin-bottom: 20px;
	text-align: center;
	font-family: 'Cinzel', serif;
	font-size: 24px;
	font-weight: 700;
	color: #3a2100 !important;
	background: linear-gradient(180deg, #f5d792 0%, #d9a44a 100%);
	border: 1px solid #efcf85 !important;
	border-radius: 14px;
	box-shadow:
		inset 0 2px 0 rgba(255,255,255,0.30),
		0 8px 22px rgba(0,0,0,0.35);
	text-decoration: none;
	transition: 0.2s ease;
}

.play-btn:hover,
button:hover,
.btn:hover {
	transform: translateY(-2px);
	filter: brightness(1.05);
	text-decoration: none;
}

.ip-line {
	font-size: 17px;
	color: #f3eadb;
	text-align: center;
	line-height: 1.7;
}

.ip-clickable {
	color: #f0bf63;
	font-weight: 700;
	text-decoration: underline;
	cursor: pointer;
	transition: 0.2s;
}

.ip-clickable:hover {
	color: #ffffff;
}

.copy-feedback {
	margin-top: 10px;
	font-size: 14px;
	color: #9bf7b1;
	text-align: center;
	opacity: 0;
	transition: 0.25s;
	min-height: 20px;
}

.copy-feedback.show {
	opacity: 1;
}

/* MAIN NAV */
.main-nav-wrapper {
	position: sticky;
	top: 61px;
	z-index: 900;
	background: rgba(8, 7, 12, 0.88);
	backdrop-filter: blur(10px);
	border-top: 1px solid rgba(255,255,255,0.03);
	border-bottom: 1px solid rgba(240, 201, 121, 0.08);
}

.main-nav {
	max-width: 1300px;
	margin: 0 auto;
	padding: 14px 24px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
}

.nav-item {
	color: #e8dcc7;
	text-decoration: none;
	padding: 10px 16px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 600;
	transition: 0.2s ease;
}

.nav-item:hover {
	color: #fff;
	text-decoration: none;
	background: rgba(240, 201, 121, 0.08);
}

/* SECTIONS */
.section {
	padding: 110px 24px;
	position: relative;
}

.container-box {
	max-width: 1300px;
	margin: 0 auto;
}

.container-box.narrow {
	max-width: 950px;
}

.section-title {
	font-family: 'Cinzel', serif;
	color: #f2cf86;
	text-align: center;
	font-size: clamp(34px, 5vw, 48px);
	margin-bottom: 18px;
}

.section-subtitle {
	text-align: center;
	color: #d7cbbb;
	font-size: 18px;
	line-height: 1.8;
	max-width: 820px;
	margin: 0 auto 42px auto;
}

/* CARDS */
.lore-box,
.feature-card {
	background: linear-gradient(180deg, rgba(18, 13, 24, 0.96), rgba(9, 8, 14, 0.96));
	color: #f3eadb;
	border: 1px solid rgba(214, 168, 95, 0.24);
	border-radius: 22px;
	box-shadow: 0 10px 28px rgba(0,0,0,0.22);
}

.lore-box {
	padding: 32px;
	margin: 0 auto 38px auto;
	line-height: 1.9;
	font-size: 17px;
	color: #ddd2c3;
}

.lore-box p {
	margin: 0;
}

.features-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 22px;
}

.feature-card {
	padding: 26px;
	transition: 0.22s ease;
	height: 100%;
}

.feature-card:hover {
	transform: translateY(-4px);
	border-color: rgba(240, 201, 121, 0.38);
	box-shadow: 0 18px 35px rgba(0,0,0,0.26);
}

.feature-title {
	font-family: 'Cinzel', serif;
	font-size: 24px;
	color: #f3cf8c;
	margin-bottom: 12px;
}

.feature-text {
	font-size: 16px;
	line-height: 1.8;
	color: #d7cbbb;
}

/* FINAL CTA */
.final-cta {
	text-align: center;
}

.final-btn {
	max-width: 420px;
	margin: 0 auto 24px auto;
}

.discord-btn {
	display: inline-block;
	margin-top: 22px;
	padding: 15px 24px;
	border-radius: 14px;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(240, 201, 121, 0.18);
	color: #f3eadb;
	text-decoration: none;
	font-weight: 600;
	transition: 0.2s ease;
}

.discord-btn:hover {
	text-decoration: none;
	color: #fff;
	transform: translateY(-2px);
	background: rgba(255,255,255,0.08);
}

/* FOOTER */
.footer {
	border-top: 1px solid rgba(240, 201, 121, 0.08);
	padding: 26px 20px;
	text-align: center;
	font-size: 14px;
	color: #a89d8d;
	background: rgba(0,0,0,0.18);
}

/* RESPONSIVE */
@media (max-width: 992px) {
	.hero {
		padding: 120px 24px 70px;
		min-height: auto;
	}

	.hero-inner {
		gap: 40px;
	}

	.hero-left,
	.hero-right {
		flex: 1 1 100%;
		max-width: 100%;
	}

	.hero-right {
		justify-content: flex-start;
	}

	.cta-panel {
		max-width: 100%;
	}

	.main-nav-wrapper {
		top: 57px;
	}
}

@media (max-width: 768px) {
	.topbar-inner {
		padding: 12px 18px;
		flex-direction: column;
		align-items: flex-start;
	}

	.top-links {
		gap: 14px;
	}

	.hero {
		padding: 140px 20px 60px;
	}

	.hero-subtitle {
		font-size: 20px;
	}

	.hero-text {
		font-size: 16px;
		line-height: 1.8;
	}

	.hero-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.hero-main-btn,
	.secondary-btn {
		max-width: 100%;
		width: 100%;
	}

	.play-btn,
	button,
	.btn {
		font-size: 20px;
		padding: 16px 18px;
	}

	.lore-box,
	.feature-card {
		padding: 24px;
	}

	.main-nav-wrapper {
		top: 88px;
	}
}