/* OnlineGameParty.net - Modern Norwegian Gaming Design with Vibrant Color Palette */

/* CSS Variables */
:root {
	/* Primary Colors - Vibrant Palette */
	--primary: #ffc400;
	--primary-dark: #e6b000;
	--primary-light: #ffd633;
	--secondary: #ff9100;
	--secondary-dark: #e67f00;
	--secondary-light: #ffa333;

	/* Accent Colors */
	--accent: #ff530f;
	--accent-dark: #e64a0d;
	--accent-light: #ff6b33;
	--accent-2: #e62c6d;
	--accent-2-dark: #d1255f;
	--accent-2-light: #ea4d7a;
	--accent-3: #b25aff;
	--accent-3-dark: #9e4ae6;
	--accent-3-light: #c173ff;

	/* Color Variations */
	--yellow-50: #fffef7;
	--yellow-100: #fffce6;
	--yellow-200: #fff8cc;
	--yellow-300: #fff2b3;
	--yellow-400: #ffec99;
	--yellow-500: #ffc400;
	--yellow-600: #e6b000;
	--yellow-700: #cc9c00;
	--yellow-800: #b38800;
	--yellow-900: #997400;

	--orange-50: #fff7f0;
	--orange-100: #ffede0;
	--orange-200: #ffd9c0;
	--orange-300: #ffc5a0;
	--orange-400: #ffb180;
	--orange-500: #ff9100;
	--orange-600: #e67f00;
	--orange-700: #cc6d00;
	--orange-800: #b35b00;
	--orange-900: #994900;

	--red-50: #fff0f2;
	--red-100: #ffe0e5;
	--red-200: #ffc1cc;
	--red-300: #ffa2b3;
	--red-400: #ff8399;
	--red-500: #ff530f;
	--red-600: #e64a0d;
	--red-700: #cc410b;
	--red-800: #b33809;
	--red-900: #992f07;

	--pink-50: #fdf2f8;
	--pink-100: #fce7f3;
	--pink-200: #fbcfe8;
	--pink-300: #f9a8d4;
	--pink-400: #f472b6;
	--pink-500: #e62c6d;
	--pink-600: #d1255f;
	--pink-700: #b91c51;
	--pink-800: #a01743;
	--pink-900: #871235;

	--purple-50: #faf5ff;
	--purple-100: #f3e8ff;
	--purple-200: #e9d5ff;
	--purple-300: #d8b4fe;
	--purple-400: #c084fc;
	--purple-500: #b25aff;
	--purple-600: #9e4ae6;
	--purple-700: #8a3acc;
	--purple-800: #762ab3;
	--purple-900: #621a99;

	/* Status Colors */
	--success: #10b981;
	--warning: #f59e0b;
	--error: #ef4444;
	--info: #3b82f6;

	/* Neutral Colors */
	--gray-50: #f8fafc;
	--gray-100: #f1f5f9;
	--gray-200: #e2e8f0;
	--gray-300: #cbd5e1;
	--gray-400: #94a3b8;
	--gray-500: #64748b;
	--gray-600: #475569;
	--gray-700: #334155;
	--gray-800: #1e293b;
	--gray-900: #0f172a;

	--white: #ffffff;
	--black: #000000;

	/* Shadows */
	--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	--shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
	--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1),
		0 2px 4px -1px rgba(0, 0, 0, 0.06);
	--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1),
		0 4px 6px -2px rgba(0, 0, 0, 0.05);
	--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1),
		0 10px 10px -5px rgba(0, 0, 0, 0.04);
	--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);

	/* Gradients */
	--gradient-primary: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--secondary) 100%
	);
	--gradient-secondary: linear-gradient(
		135deg,
		var(--secondary) 0%,
		var(--accent) 100%
	);
	--gradient-accent: linear-gradient(
		135deg,
		var(--accent) 0%,
		var(--accent-2) 100%
	);
	--gradient-accent-2: linear-gradient(
		135deg,
		var(--accent-2) 0%,
		var(--accent-3) 100%
	);
	--gradient-accent-3: linear-gradient(
		135deg,
		var(--accent-3) 0%,
		var(--primary) 100%
	);
	--gradient-rainbow: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--secondary) 25%,
		var(--accent) 50%,
		var(--accent-2) 75%,
		var(--accent-3) 100%
	);
	--gradient-hero: linear-gradient(
		135deg,
		var(--primary) 0%,
		var(--secondary) 30%,
		var(--accent) 60%,
		var(--accent-2) 80%,
		var(--accent-3) 100%
	);
	--gradient-card: linear-gradient(
		145deg,
		var(--white) 0%,
		var(--yellow-50) 100%
	);
	--gradient-card-2: linear-gradient(
		145deg,
		var(--white) 0%,
		var(--orange-50) 100%
	);
	--gradient-card-3: linear-gradient(
		145deg,
		var(--white) 0%,
		var(--pink-50) 100%
	);
	--gradient-card-4: linear-gradient(
		145deg,
		var(--white) 0%,
		var(--purple-50) 100%
	);
	--gradient-footer: linear-gradient(
		135deg,
		var(--gray-900) 0%,
		var(--purple-900) 100%
	);

	/* Border Radius */
	--border-radius: 12px;
	--border-radius-lg: 16px;
	--border-radius-xl: 24px;
	--border-radius-2xl: 32px;

	/* Transitions */
	--transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-fast: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-slow: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Reset & Base Styles */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	font-size: 14px !important;
}

body {
	font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		"Helvetica Neue", Arial, sans-serif;
	line-height: 1.6;
	color: var(--gray-800);
	background: linear-gradient(
		135deg,
		var(--yellow-50) 0%,
		var(--orange-50) 25%,
		var(--pink-50) 50%,
		var(--purple-50) 75%,
		var(--red-50) 100%
	);
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	min-height: 100vh;
	position: relative;
}

body::before {
	content: "";
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="dots" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1" fill="rgba(255,196,0,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23dots)"/></svg>');
	pointer-events: none;
	z-index: -1;
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 700;
	line-height: 1.2;
	color: var(--gray-900);
	margin-bottom: 1rem;
}

h1 {
	font-size: 3rem;
}

h2 {
	font-size: 2.5rem;
	color: var(--accent-2);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

h3 {
	font-size: 2rem;
	color: var(--accent);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

h4 {
	font-size: 1.5rem;
	color: var(--white);
}

h5 {
	font-size: 1.2rem;
	color: var(--white);
}

h6 {
	font-size: 1rem;
	color: var(--white);
}

p {
	margin-bottom: 1rem;
	color: var(--white);
	line-height: 1.7;
}

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

a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

/* Container */
.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1rem;
}

/* Navigation */
.onlinegameparty-navbar {
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(20px);
	box-shadow: var(--shadow-lg);
	position: sticky;
	top: 0;
	z-index: 1000;
	padding: 1rem 0;
	border-bottom: 4px solid;
	border-image: var(--gradient-rainbow) 1;
}

.onlinegameparty-navbar-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.onlinegameparty-navbar-brand {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 1.75rem;
	font-weight: 800;
	background: var(--gradient-rainbow);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	text-decoration: none;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.onlinegameparty-navbar-brand:hover {
	text-decoration: none;
	transform: scale(1.05);
}

.onlinegameparty-navbar-logo {
	height: 45px;
	width: auto;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.1));
}

.onlinegameparty-navbar-menu {
	display: flex;
	list-style: none;
	gap: 2.5rem;
	align-items: center;
	margin-bottom: 0;
}

.onlinegameparty-navbar-link {
	color: var(--gray-700);
	font-weight: 600;
	text-decoration: none;
	transition: var(--transition);
	padding: 0.75rem 1rem;
	border-radius: var(--border-radius);
	position: relative;
}

.onlinegameparty-navbar-link:hover,
.onlinegameparty-navbar-link.active {
	color: var(--accent-2);
	text-decoration: none;
	background: var(--gradient-card-3);
	transform: translateY(-2px);
	box-shadow: var(--shadow);
}

.onlinegameparty-navbar-cta {
	background: var(--gradient-primary);
	color: var(--white) !important;
	padding: 1rem 2rem;
	border-radius: var(--border-radius-xl);
	font-weight: 700;
	text-decoration: none;
	transition: var(--transition);
	box-shadow: var(--shadow-md);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.onlinegameparty-navbar-cta:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-xl);
	text-decoration: none;
	color: var(--white) !important;
	background: var(--gradient-rainbow);
}

/* Mobile Navigation Toggle */
.onlinegameparty-navbar-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: var(--gradient-primary);
	border: none;
	cursor: pointer;
	padding: 0.75rem;
	border-radius: var(--border-radius);
	transition: var(--transition);
}

.onlinegameparty-navbar-toggle:hover {
	transform: scale(1.1);
}

.onlinegameparty-navbar-toggle-bar {
	width: 28px;
	height: 4px;
	background: var(--white);
	border-radius: 2px;
	transition: var(--transition);
}

.onlinegameparty-navbar-toggle[aria-expanded="true"]
	.onlinegameparty-navbar-toggle-bar:nth-child(1) {
	transform: rotate(45deg) translate(7px, 7px);
}

.onlinegameparty-navbar-toggle[aria-expanded="true"]
	.onlinegameparty-navbar-toggle-bar:nth-child(2) {
	opacity: 0;
}

.onlinegameparty-navbar-toggle[aria-expanded="true"]
	.onlinegameparty-navbar-toggle-bar:nth-child(3) {
	transform: rotate(-45deg) translate(7px, -7px);
}

/* Mobile Menu */
@media (max-width: 768px) {
	.onlinegameparty-navbar-toggle {
		display: flex;
	}

	.onlinegameparty-navbar-menu {
		position: fixed;
		top: 100%;
		left: 0;
		right: 0;
		background: rgba(255, 255, 255, 0.98);
		backdrop-filter: blur(20px);
		flex-direction: column;
		padding: 2rem;
		box-shadow: var(--shadow-xl);
		transform: translateY(-100%);
		opacity: 0;
		visibility: hidden;
		transition: var(--transition);
		gap: 3.5rem;
		border-top: 3px solid var(--secondary);
	}

	.onlinegameparty-navbar-menu.active {
		transform: translateY(0);
		opacity: 1;
		visibility: visible;
	}

	.onlinegameparty-navbar-link {
		/* padding: 1.25rem 0; */
		width: 100%;
		text-align: center;
		border-bottom: 2px solid var(--purple-100);
		font-size: 1.125rem;
	}

	.onlinegameparty-navbar-cta {
		margin-top: 1.5rem;
		width: 100%;
		text-align: center;
		font-size: 1.125rem;
		padding: 1.25rem 2rem;
	}
}

/* Sections */
.section {
	padding: 5rem 0;
}

.section p {
	color: var(--gray-900);
}

.section-sm {
	padding: 3rem 0;
}

/* Hero Section */
.hero {
	background: var(--gradient-hero);
	color: var(--white);
	padding: 8rem 0;
	text-align: center;
	position: relative;
	overflow: hidden;
	animation: gradientShift 8s ease-in-out infinite;
}

@keyframes gradientShift {
	0%,
	100% {
		background: var(--gradient-hero);
	}
	25% {
		background: linear-gradient(
			135deg,
			var(--accent-2) 0%,
			var(--accent-3) 30%,
			var(--primary) 60%,
			var(--secondary) 80%,
			var(--accent) 100%
		);
	}
	50% {
		background: linear-gradient(
			135deg,
			var(--accent-3) 0%,
			var(--primary) 30%,
			var(--secondary) 60%,
			var(--accent) 80%,
			var(--accent-2) 100%
		);
	}
	75% {
		background: linear-gradient(
			135deg,
			var(--primary) 0%,
			var(--secondary) 30%,
			var(--accent) 60%,
			var(--accent-2) 80%,
			var(--accent-3) 100%
		);
	}
}

.hero::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.05)"/><circle cx="10" cy="60" r="0.5" fill="rgba(255,255,255,0.05)"/><circle cx="90" cy="40" r="0.5" fill="rgba(255,255,255,0.05)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');
	opacity: 0.3;
}

.hero-content {
	max-width: 900px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}

.hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	background: rgba(255, 255, 255, 0.2);
	padding: 1rem 2rem;
	border-radius: var(--border-radius-2xl);
	margin-bottom: 2.5rem;
	font-weight: 700;
	backdrop-filter: blur(20px);
	border: 2px solid rgba(255, 255, 255, 0.3);
	text-transform: uppercase;
	letter-spacing: 1px;
}

.hero-title {
	font-size: 4.5rem;
	margin-bottom: 2rem;
	color: var(--white) !important;
	text-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
	line-height: 1.1;
}

.hero-subtitle {
	font-size: 1.5rem;
	margin-bottom: 3rem;
	opacity: 0.95;
	color: var(--white);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
	line-height: 1.6;
}

.hero-cta {
	display: inline-block;
	background: var(--white);
	color: var(--primary);
	padding: 1.5rem 3rem;
	border-radius: var(--border-radius-xl);
	font-weight: 800;
	text-decoration: none;
	transition: var(--transition);
	font-size: 1.25rem;
	text-transform: uppercase;
	letter-spacing: 1px;
	box-shadow: var(--shadow-xl);
}

.hero-cta:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-2xl);
	text-decoration: none;
	color: var(--primary-dark);
	background: var(--purple-50);
}

/* Features Grid */
.features-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 2.5rem;
	margin-top: 4rem;
}

.feature-card {
	background: var(--gradient-card);
	padding: 3rem 2rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	text-align: center;
	transition: var(--transition);
	border: 2px solid transparent;
	position: relative;
	overflow: hidden;
}

.feature-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--gradient-rainbow);
}

.feature-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-2xl);
	border-color: var(--accent-2);
	background: var(--gradient-card-2);
}

.feature-card:nth-child(2n) {
	background: var(--gradient-card-2);
}

.feature-card:nth-child(2n)::before {
	background: var(--gradient-accent);
}

.feature-card:nth-child(3n) {
	background: var(--gradient-card-3);
}

.feature-card:nth-child(3n)::before {
	background: var(--gradient-accent-2);
}

.feature-card:nth-child(4n) {
	background: var(--gradient-card-4);
}

.feature-card:nth-child(4n)::before {
	background: var(--gradient-accent-3);
}

.feature-icon {
	width: 100px;
	height: 100px;
	background: var(--gradient-rainbow);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 2rem;
	font-size: 2.5rem;
	color: var(--white);
	box-shadow: var(--shadow-lg);
	transition: var(--transition);
	animation: pulse 2s ease-in-out infinite;
}

.feature-card:hover .feature-icon {
	transform: scale(1.1) rotate(5deg);
	background: var(--gradient-accent);
	animation: bounce 0.6s ease-in-out;
}

.feature-title {
	font-size: 1.75rem;
	margin-bottom: 1.5rem;
	color: var(--accent-2);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.feature-desc {
	color: var(--gray-600);
	line-height: 1.7;
	font-size: 1.125rem;
}

/* Game Categories */
.game-categories {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.categories-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
	gap: 3rem;
	margin-top: 4rem;
}

.category-card {
	background: var(--white);
	padding: 3rem 2.5rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	text-align: center;
	transition: var(--transition);
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.category-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--gradient-secondary);
}

.category-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-2xl);
	border-color: var(--secondary);
}

.category-icon {
	width: 120px;
	height: 120px;
	background: var(--gradient-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 2rem;
	font-size: 3rem;
	color: var(--white);
	box-shadow: var(--shadow-lg);
	transition: var(--transition);
}

.category-card:hover .category-icon {
	transform: scale(1.1) rotate(-5deg);
	background: var(--gradient-primary);
}

.category-games {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
	margin-top: 1.5rem;
}

.game-tag {
	background: var(--gradient-accent);
	color: var(--white);
	padding: 0.5rem 1rem;
	border-radius: var(--border-radius-xl);
	font-size: 0.875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--shadow);
}

/* Games Grid */
.games-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 2.5rem;
	margin-top: 4rem;
}

.game-card {
	background: var(--white);
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	transition: var(--transition);
	position: relative;
	border: 3px solid transparent;
}

.game-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-2xl);
	border-color: var(--primary);
}

.game-card.featured {
	border-color: var(--primary);
	box-shadow: var(--shadow-xl);
}

.game-card.featured::before {
	content: "POPULÆR";
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: var(--gradient-primary);
	color: var(--white);
	padding: 0.5rem 1rem;
	border-radius: var(--border-radius);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	z-index: 10;
}

.game-badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: var(--gradient-secondary);
	color: var(--white);
	padding: 0.75rem 1.25rem;
	border-radius: var(--border-radius-xl);
	font-size: 0.875rem;
	font-weight: 700;
	z-index: 10;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--shadow);
}

.game-image {
	width: 100%;
	height: 220px;
	overflow: hidden;
	position: relative;
}

.game-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: var(--transition);
}

.game-card:hover .game-image img {
	transform: scale(1.1);
}

.game-content {
	padding: 2rem;
}

.game-title {
	font-size: 1.5rem;
	margin-bottom: 1rem;
	color: var(--purple-800);
	font-weight: 700;
}

.game-desc {
	color: var(--gray-600);
	margin-bottom: 1.5rem;
	line-height: 1.6;
	font-size: 1rem;
}

.game-stats {
	display: flex;
	gap: 1.5rem;
	margin-bottom: 1.5rem;
	font-size: 0.875rem;
	color: var(--gray-500);
}

.game-stats span {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 600;
}

.game-play {
	width: 100%;
	background: var(--gradient-primary);
	color: var(--white);
	border: none;
	padding: 1rem 1.5rem;
	border-radius: var(--border-radius-xl);
	font-weight: 700;
	cursor: pointer;
	transition: var(--transition);
	font-size: 1.125rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--shadow);
}

.game-play:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	background: var(--gradient-secondary);
}

/* Buttons */
.btn {
	display: inline-block;
	padding: 1rem 2rem;
	border-radius: var(--border-radius-xl);
	font-weight: 700;
	text-decoration: none;
	transition: var(--transition);
	border: none;
	cursor: pointer;
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--shadow);
}

.btn-primary {
	background: var(--gradient-rainbow);
	color: var(--white);
	position: relative;
	overflow: hidden;
}

.btn-primary::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.2),
		transparent
	);
	transition: left 0.5s;
}

.btn-primary:hover::before {
	left: 100%;
}

.btn-primary:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-xl);
	text-decoration: none;
	color: var(--white);
	background: var(--gradient-accent);
}

.btn-secondary {
	background: var(--gradient-accent);
	color: var(--white);
	border: 2px solid var(--accent-2);
	position: relative;
	overflow: hidden;
}

.btn-secondary::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.2),
		transparent
	);
	transition: left 0.5s;
}

.btn-secondary:hover::before {
	left: 100%;
}

.btn-secondary:hover {
	background: var(--gradient-rainbow);
	color: var(--white);
	text-decoration: none;
	transform: translateY(-3px);
	box-shadow: var(--shadow-xl);
	border-color: var(--accent-3);
}

/* Footer */
.onlinegameparty-footer {
	background: var(--gradient-footer);
	color: var(--gray-300);
	padding: 4rem 0 2rem;
	position: relative;
}

.onlinegameparty-footer::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--gradient-primary);
}

.onlinegameparty-footer-content {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 3rem;
	margin-bottom: 3rem;
}

.onlinegameparty-footer-section h3 {
	color: var(--white);
	margin-bottom: 1.5rem;
	font-size: 1.5rem;
	font-weight: 700;
}

.onlinegameparty-footer-section p {
	margin-bottom: 0.75rem;
	line-height: 1.7;
}

.onlinegameparty-footer-section a {
	color: var(--gray-400);
	text-decoration: none;
	transition: var(--transition);
	padding: 0.25rem 0;
	display: inline-block;
}

.onlinegameparty-footer-section a:hover {
	color: var(--primary);
	text-decoration: none;
	transform: translateX(5px);
}

.onlinegameparty-disclaimer {
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(20px);
	padding: 2rem;
	border-radius: var(--border-radius-xl);
	margin-bottom: 2rem;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.onlinegameparty-disclaimer p {
	margin-bottom: 1rem;
	font-size: 1rem;
	line-height: 1.6;
}

.onlinegameparty-footer-bottom {
	text-align: center;
	padding-top: 2rem;
	border-top: 2px solid var(--purple-800);
}

/* Cookie Popup */
.onlinegameparty-cookie-popup {
	position: fixed;
	bottom: 2rem;
	left: 2rem;
	right: 2rem;
	background: var(--white);
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-2xl);
	padding: 2rem;
	z-index: 1000;
	display: none;
	max-width: 600px;
	margin: 0 auto;
	border: 3px solid var(--primary);
}

.cookie-content {
	text-align: center;
}

.cookie-title {
	font-size: 1.5rem;
	font-weight: 800;
	margin-bottom: 1rem;
	color: var(--purple-800);
}

.cookie-text {
	color: var(--gray-600);
	margin-bottom: 2rem;
	line-height: 1.6;
	font-size: 1rem;
}

.cookie-buttons {
	display: flex;
	gap: 1.5rem;
	justify-content: center;
	flex-wrap: wrap;
}

.cookie-accept {
	background: var(--gradient-primary);
	color: var(--white);
	border: none;
	padding: 1rem 2rem;
	border-radius: var(--border-radius-xl);
	font-weight: 700;
	cursor: pointer;
	transition: var(--transition);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--shadow);
}

.cookie-accept:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	background: var(--gradient-secondary);
}

.cookie-policy {
	color: var(--primary);
	text-decoration: none;
	padding: 1rem 1.5rem;
	border: 2px solid var(--primary);
	border-radius: var(--border-radius-xl);
	transition: var(--transition);
	font-weight: 600;
}

.cookie-policy:hover {
	background: var(--primary);
	color: var(--white);
	text-decoration: none;
	transform: translateY(-2px);
	box-shadow: var(--shadow);
}

/* Utility Classes */
.text-center {
	text-align: center;
}

.mb-5 {
	margin-bottom: 3rem;
}

.mt-5 {
	margin-top: 3rem;
}

.mt-4 {
	margin-top: 2rem;
}

.mt-3 {
	margin-top: 1rem;
}

/* Responsive Design */
@media (max-width: 768px) {
	.hero-title {
		font-size: 3rem;
	}

	.hero-subtitle {
		font-size: 1.25rem;
	}

	.features-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.categories-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.games-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.onlinegameparty-cookie-popup {
		left: 1rem;
		right: 1rem;
		bottom: 1rem;
		padding: 1.5rem;
	}

	.cookie-buttons {
		flex-direction: column;
		gap: 1rem;
	}

	.cookie-accept,
	.cookie-policy {
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 480px) {
	.hero {
		padding: 6rem 0;
	}

	.hero-title {
		font-size: 2.5rem;
	}

	.section {
		padding: 3rem 0;
	}

	.feature-card,
	.category-card {
		padding: 2rem 1.5rem;
	}

	.game-content {
		padding: 1.5rem;
	}
}

/* Animations */
@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(40px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes bounce {
	0%,
	20%,
	50%,
	80%,
	100% {
		transform: translateY(0);
	}
	40% {
		transform: translateY(-10px);
	}
	60% {
		transform: translateY(-5px);
	}
}

@keyframes pulse {
	0% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.05);
	}
	100% {
		transform: scale(1);
	}
}

.fade-in-up {
	animation: fadeInUp 0.8s ease-out;
}

.bounce {
	animation: bounce 2s infinite;
}

.pulse {
	animation: pulse 2s infinite;
}

/* Loading States */
.btn-loading {
	opacity: 0.7;
	pointer-events: none;
}

.btn-loading .fa-spinner {
	animation: spin 1s linear infinite;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

/* Alert Messages */
.alert {
	padding: 1.5rem;
	border-radius: var(--border-radius-xl);
	margin-bottom: 1.5rem;
	font-weight: 600;
	box-shadow: var(--shadow);
}

.alert p,
.alert h4 {
	color: var(--gray-900);
}

.alert-success {
	background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
	color: #065f46;
	border: 2px solid #10b981;
}

.alert-danger {
	background: linear-gradient(135deg, #fee2e2 0%, #fca5a5 100%);
	color: #991b1b;
	border: 2px solid #ef4444;
}

.alert-info {
	background: linear-gradient(135deg, #dbeafe 0%, #93c5fd 100%);
	color: #1e40af;
	border: 2px solid #3b82f6;
}

/* Form Styles */
.form-group {
	margin-bottom: 2rem;
}

.form-label {
	display: block;
	margin-bottom: 0.75rem;
	font-weight: 700;
	color: var(--purple-800);
	font-size: 1.125rem;
}

.form-control {
	width: 100%;
	padding: 1rem 1.25rem;
	border: 2px solid var(--gray-300);
	border-radius: var(--border-radius-xl);
	font-size: 1rem;
	transition: var(--transition);
	background: var(--white);
}

.form-control:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 4px rgba(255, 107, 53, 0.1);
	background: var(--purple-50);
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
}

@media (max-width: 768px) {
	.form-row {
		grid-template-columns: 1fr;
	}
}

/* Page-Specific Hero Sections */
.about-hero,
.games-hero,
.contact-hero,
.terms-hero,
.cookies-hero,
.privacy-hero {
	background: var(--gradient-hero);
	color: var(--white);
	padding: 6rem 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}

.about-hero::before,
.games-hero::before,
.contact-hero::before,
.terms-hero::before,
.cookies-hero::before,
.privacy-hero::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.05)"/><circle cx="10" cy="60" r="0.5" fill="rgba(255,255,255,0.05)"/><circle cx="90" cy="40" r="0.5" fill="rgba(255,255,255,0.05)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');
	opacity: 0.3;
}

.about-hero-content,
.games-hero-content,
.contact-hero-content,
.terms-hero-content,
.cookies-hero-content,
.privacy-hero-content {
	position: relative;
	z-index: 2;
}

.about-hero-content h1,
.games-hero-content h1,
.contact-hero-content h1,
.terms-hero-content h1,
.cookies-hero-content h1,
.privacy-hero-content h1 {
	color: var(--white);
}

.about-hero-icon,
.games-hero-icon,
.contact-hero-icon,
.terms-hero-icon,
.cookies-hero-icon,
.privacy-hero-icon {
	width: 120px;
	height: 120px;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 2rem;
	font-size: 3rem;
	color: var(--white);
	backdrop-filter: blur(20px);
	border: 3px solid rgba(255, 255, 255, 0.3);
	box-shadow: var(--shadow-xl);
}

.about-hero-subtitle,
.games-hero-subtitle,
.contact-hero-subtitle,
.terms-hero-subtitle,
.cookies-hero-subtitle,
.privacy-hero-subtitle {
	font-size: 1.5rem;
	margin-bottom: 1rem;
	opacity: 0.95;
	color: var(--white);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

.contact-hero-date,
.cookies-hero-date,
.privacy-hero-date {
	font-size: 1rem;
	opacity: 0.8;
	color: var(--white);
}

/* Games Page Specific Styles */
.games-stats {
	display: flex;
	justify-content: center;
	gap: 3rem;
	margin-top: 2rem;
}

.stat-item {
	text-align: center;
}

.stat-number {
	display: block;
	font-size: 2.5rem;
	font-weight: 800;
	color: var(--white);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.stat-label {
	display: block;
	font-size: 1rem;
	opacity: 0.9;
	color: var(--white);
	margin-top: 0.5rem;
}

.popular-games,
.all-games,
.game-stats,
.community-features {
	background: var(--gray-50);
}

.disclaimer-section {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

/* About Page Specific Styles */
.about-mission {
	background: var(--white);
}

.about-mission-text p {
	color: var(--gray-900);
}

.about-mission-content {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 4rem;
	align-items: center;
}

.about-mission-visual {
	display: flex;
	justify-content: center;
}

.about-mission-card {
	width: 200px;
	height: 200px;
	background: var(--gradient-primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 4rem;
	color: var(--white);
	box-shadow: var(--shadow-xl);
	animation: pulse 3s infinite;
}

.about-stats {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
	margin-top: 3rem;
}

.stat-card {
	background: var(--white);
	padding: 2.5rem 2rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	text-align: center;
	transition: var(--transition);
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.stat-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--gradient-primary);
}

.stat-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-2xl);
	border-color: var(--primary);
}

.stat-number {
	font-size: 3rem;
	font-weight: 800;
	color: var(--yellow-500);
	margin-bottom: 1rem;
}

.stat-label {
	font-size: 1.125rem;
	color: var(--gray-900);
	font-weight: 600;
	margin-bottom: 1.5rem;
}

.stat-icon {
	width: 80px;
	height: 80px;
	background: var(--gradient-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	font-size: 2rem;
	color: var(--white);
	box-shadow: var(--shadow);
}

.about-features {
	background: var(--white);
}

.about-team {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.team-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2.5rem;
	margin-top: 3rem;
}

.team-card {
	background: var(--white);
	padding: 2.5rem 2rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	text-align: center;
	transition: var(--transition);
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.team-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--gradient-secondary);
}

.team-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-2xl);
	border-color: var(--secondary);
}

.team-card p {
	color: var(--gray-900);
}

.team-icon {
	width: 100px;
	height: 100px;
	background: var(--gradient-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 2rem;
	font-size: 2.5rem;
	color: var(--white);
	box-shadow: var(--shadow-lg);
	transition: var(--transition);
}

.team-card:hover .team-icon {
	transform: scale(1.1) rotate(5deg);
	background: var(--gradient-primary);
}

.about-community {
	background: var(--white);
}

.community-content {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.community-content p {
	color: var(--gray-600);
}

.community-cta {
	display: flex;
	gap: 2rem;
	justify-content: center;
	margin-top: 3rem;
	flex-wrap: wrap;
}

.about-disclaimer {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

/* Contact Page Specific Styles */
.contact-overview {
	background: var(--white);
}

.overview-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2.5rem;
	margin-top: 3rem;
}

.overview-card {
	background: var(--gradient-card);
	padding: 2.5rem 2rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	text-align: center;
	transition: var(--transition);
	border: 2px solid transparent;
	position: relative;
	overflow: hidden;
}

.overview-card h3 {
	word-break: break-word;
}

.overview-card p {
	color: var(--gray-900);
}

.overview-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--gradient-primary);
}

.overview-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-2xl);
	border-color: var(--primary);
}

.overview-card ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.overview-icon {
	width: 100px;
	height: 100px;
	background: var(--gradient-primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 2rem;
	font-size: 2.5rem;
	color: var(--white);
	box-shadow: var(--shadow-lg);
	transition: var(--transition);
}

.overview-card:hover .overview-icon {
	transform: scale(1.1) rotate(5deg);
	background: var(--gradient-secondary);
}

.contact-main {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.contact-content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: start;
}

.contact-info-card,
.contact-form-card {
	background: var(--white);
	padding: 3rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-xl);
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.contact-info-card::before,
.contact-form-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--gradient-primary);
}

.contact-info-card h3,
.contact-form-card h3 {
	color: var(--purple-800);
	margin-bottom: 2rem;
	font-size: 1.5rem;
	font-weight: 700;
}

.contact-details {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.contact-detail-item {
	display: flex;
	align-items: flex-start;
	gap: 1.5rem;
}

.contact-detail-icon {
	width: 60px;
	height: 60px;
	background: var(--gradient-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	color: var(--white);
	box-shadow: var(--shadow);
	flex-shrink: 0;
}

.contact-detail-content h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.contact-detail-content p {
	color: var(--gray-600);
	margin: 0;
}

.contact-detail-content a {
	color: var(--primary);
	text-decoration: none;
	font-weight: 600;
}

.contact-detail-content a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

.form-description {
	color: var(--gray-600);
	margin-bottom: 2rem;
	font-size: 1rem;
	line-height: 1.6;
}

.contact-cta {
	background: var(--white);
}

.cta-content {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.cta-actions {
	display: flex;
	gap: 2rem;
	justify-content: center;
	margin-top: 3rem;
	flex-wrap: wrap;
}

/* Terms Page Specific Styles */
.terms-overview {
	background: var(--white);
}

.terms-detailed {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.terms-content {
	max-width: 1000px;
	margin: 0 auto;
}

.terms-section {
	background: var(--white);
	padding: 3rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	margin-bottom: 3rem;
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.terms-section::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--gradient-primary);
}

.terms-section h2 {
	color: var(--purple-800);
	margin-bottom: 2rem;
	font-size: 1.75rem;
	font-weight: 700;
}

.terms-section p {
	color: var(--gray-900);
}

.commitment-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.commitment-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.5rem;
	background: var(--purple-50);
	border-radius: var(--border-radius-lg);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.commitment-item:hover {
	background: var(--purple-100);
	border-color: var(--purple-300);
	transform: translateY(-2px);
}

.commitment-item i {
	font-size: 1.5rem;
	color: var(--purple-600);
	flex-shrink: 0;
}

.commitment-item span {
	color: var(--gray-700);
	font-weight: 500;
}

.responsibilities-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.responsibility-card {
	background: var(--gradient-card);
	padding: 2rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.responsibility-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.responsibility-card h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.responsibility-card p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.6;
}

.privacy-highlights {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.privacy-highlight {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.5rem;
	background: var(--purple-50);
	border-radius: var(--border-radius-lg);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.privacy-highlight:hover {
	background: var(--purple-100);
	border-color: var(--purple-300);
	transform: translateY(-2px);
}

.privacy-highlight i {
	font-size: 1.5rem;
	color: var(--purple-600);
	flex-shrink: 0;
	margin-top: 0.25rem;
}

.privacy-highlight h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.privacy-highlight p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.5;
}

.update-process {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 2rem;
}

.update-step {
	display: flex;
	align-items: center;
	gap: 2rem;
	padding: 2rem;
	background: var(--gradient-card);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.update-step:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.step-number {
	width: 60px;
	height: 60px;
	background: var(--gradient-primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--white);
	box-shadow: var(--shadow);
	flex-shrink: 0;
}

.step-content h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.step-content p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.5;
}

.contact-methods {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.contact-method {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.5rem;
	background: var(--purple-50);
	border-radius: var(--border-radius-lg);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.contact-method:hover {
	background: var(--purple-100);
	border-color: var(--purple-300);
	transform: translateY(-2px);
}

.contact-method i {
	font-size: 1.5rem;
	color: var(--purple-600);
	flex-shrink: 0;
}

.contact-method h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.contact-method p {
	color: var(--gray-600);
	margin: 0;
}

.contact-method a {
	color: var(--primary);
	text-decoration: none;
	font-weight: 600;
}

.contact-method a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

.terms-cta {
	background: var(--white);
}

.cta-buttons {
	display: flex;
	gap: 2rem;
	justify-content: center;
	margin-top: 3rem;
	flex-wrap: wrap;
}

.terms-disclaimer {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

/* Cookies Page Specific Styles */
.cookies-overview {
	background: var(--white);
}

.cookies-detailed {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.cookies-content {
	max-width: 1000px;
	margin: 0 auto;
}

.cookies-section {
	background: var(--white);
	padding: 3rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	margin-bottom: 3rem;
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.cookies-section::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--gradient-secondary);
}

.cookies-section h2 {
	color: var(--purple-800);
	margin-bottom: 2rem;
	font-size: 1.75rem;
	font-weight: 700;
}

.cookies-section p {
	color: var(--gray-900);
}

.cookie-types-detailed {
	display: flex;
	flex-direction: column;
	gap: 3rem;
	margin-top: 2rem;
}

.cookie-type-detailed {
	background: var(--gradient-card);
	padding: 2.5rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.cookie-type-detailed:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.cookie-type-detailed h3 {
	color: var(--purple-800);
	margin-bottom: 1.5rem;
	font-size: 1.5rem;
	font-weight: 600;
}

.cookie-type-detailed p {
	color: var(--gray-600);
	margin-bottom: 1.5rem;
	line-height: 1.6;
}

.cookie-examples {
	background: var(--purple-50);
	padding: 1.5rem;
	border-radius: var(--border-radius);
	border: 2px solid var(--purple-200);
}

.cookie-examples h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.cookie-examples ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cookie-examples li {
	padding: 0.5rem 0;
	color: var(--gray-600);
	border-bottom: 1px solid var(--purple-200);
}

.cookie-examples li:last-child {
	border-bottom: none;
}

.cookie-controls {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 2rem;
}

.control-method {
	background: var(--gradient-card);
	padding: 2rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.control-method:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.control-method h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.control-method p {
	color: var(--gray-600);
	margin-bottom: 1rem;
	line-height: 1.6;
}

.control-method ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.control-method li {
	padding: 0.5rem 0;
	color: var(--gray-600);
	border-bottom: 1px solid var(--purple-200);
}

.control-method li:last-child {
	border-bottom: none;
}

.cookie-duration {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.duration-type {
	background: var(--gradient-card);
	padding: 2rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.duration-type:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.duration-type h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.duration-type p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.6;
}

.third-party-cookies {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 2rem;
}

.third-party-service {
	background: var(--gradient-card);
	padding: 2rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.third-party-service:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.third-party-service h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.third-party-service p {
	color: var(--gray-600);
	margin-bottom: 1rem;
	line-height: 1.6;
}

.third-party-service a {
	color: var(--primary);
	text-decoration: none;
	font-weight: 600;
}

.third-party-service a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

.cookie-management {
	background: var(--white);
}

.management-content {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.cookie-buttons {
	display: flex;
	gap: 2rem;
	justify-content: center;
	margin-top: 3rem;
	flex-wrap: wrap;
}

.cookies-disclaimer {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

/* Privacy Page Specific Styles */
.privacy-overview {
	background: var(--white);
}

.privacy-detailed {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

.privacy-content {
	max-width: 1000px;
	margin: 0 auto;
}

.privacy-section {
	background: var(--white);
	padding: 3rem;
	border-radius: var(--border-radius-xl);
	box-shadow: var(--shadow-lg);
	margin-bottom: 3rem;
	border: 3px solid transparent;
	position: relative;
	overflow: hidden;
}

.privacy-section p {
	color: var(--gray-900);
}

.privacy-section::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--gradient-primary);
}

.privacy-section h2 {
	color: var(--purple-800);
	margin-bottom: 2rem;
	font-size: 1.75rem;
	font-weight: 700;
}

.info-collection-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
	gap: 3rem;
	margin-top: 2rem;
}

.info-type {
	background: var(--gradient-card);
	padding: 2.5rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.info-type:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.info-type h3 {
	color: var(--purple-800);
	margin-bottom: 2rem;
	font-size: 1.5rem;
	font-weight: 600;
}

.info-details {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.info-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem;
	background: var(--purple-50);
	border-radius: var(--border-radius);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.info-item:hover {
	background: var(--purple-100);
	border-color: var(--purple-300);
	transform: translateY(-2px);
}

.info-item i {
	font-size: 1.25rem;
	color: var(--purple-600);
	flex-shrink: 0;
}

.info-item span {
	color: var(--gray-600);
	font-weight: 500;
}

.usage-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.usage-card {
	background: var(--gradient-card);
	padding: 2rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	text-align: center;
	transition: var(--transition);
}

.usage-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.usage-icon {
	width: 80px;
	height: 80px;
	background: var(--gradient-primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.5rem;
	font-size: 2rem;
	color: var(--white);
	box-shadow: var(--shadow);
}

.usage-card h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.usage-card p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.5;
}

.cookie-types {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 2rem;
}

.cookie-type {
	background: var(--gradient-card);
	padding: 2rem;
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.cookie-type:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.cookie-type h4 {
	color: var(--purple-800);
	margin-bottom: 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.cookie-type p {
	color: var(--gray-600);
	margin-bottom: 1rem;
	line-height: 1.6;
}

.cookie-type ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cookie-type li {
	padding: 0.5rem 0;
	color: var(--gray-600);
	border-bottom: 1px solid var(--purple-200);
}

.cookie-type li:last-child {
	border-bottom: none;
}

.sharing-reasons {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 1.5rem;
	margin-top: 2rem;
}

.sharing-reason {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.5rem;
	background: var(--purple-50);
	border-radius: var(--border-radius-lg);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.sharing-reason:hover {
	background: var(--purple-100);
	border-color: var(--purple-300);
	transform: translateY(-2px);
}

.sharing-reason i {
	font-size: 1.25rem;
	color: var(--purple-600);
	flex-shrink: 0;
}

.sharing-reason span {
	color: var(--gray-700);
	font-weight: 500;
}

.security-features {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.security-feature {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 2rem;
	background: var(--gradient-card);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.security-feature:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.security-feature i {
	font-size: 1.5rem;
	color: var(--purple-600);
	flex-shrink: 0;
	margin-top: 0.25rem;
}

.security-feature h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.security-feature p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.5;
}

.retention-timeline {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	margin-top: 2rem;
}

.timeline-item {
	display: flex;
	align-items: center;
	gap: 2rem;
	padding: 2rem;
	background: var(--gradient-card);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.timeline-item:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.timeline-dot {
	width: 20px;
	height: 20px;
	background: var(--gradient-primary);
	border-radius: 50%;
	flex-shrink: 0;
	box-shadow: var(--shadow);
}

.timeline-content h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.timeline-content p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.5;
}

.user-rights {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.right-item {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 2rem;
	background: var(--gradient-card);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow);
	border: 2px solid var(--purple-200);
	transition: var(--transition);
}

.right-item:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--purple-300);
}

.right-item i {
	font-size: 1.5rem;
	color: var(--purple-600);
	flex-shrink: 0;
	margin-top: 0.25rem;
}

.right-item h4 {
	color: var(--purple-800);
	margin-bottom: 0.5rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.right-item p {
	color: var(--gray-600);
	margin: 0;
	line-height: 1.5;
}

.privacy-commitment {
	background: var(--white);
	padding: 4rem 0;
}

.commitment-content {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.commitment-content h2 {
	color: var(--purple-800);
	margin-bottom: 2rem;
	font-size: 2.5rem;
	font-weight: 700;
}

.commitment-content p {
	color: var(--gray-600);
	margin-bottom: 3rem;
	font-size: 1.125rem;
	line-height: 1.6;
}

.grid-200 {
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.grid-250 {
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.grid-300 {
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid-400 {
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
}

.privacy-disclaimer {
	background: linear-gradient(
		135deg,
		var(--purple-100) 0%,
		var(--orange-100) 100%
	);
}

/* Responsive Design for Page-Specific Styles */
@media (max-width: 768px) {
	.about-mission-content,
	.contact-content {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.community-cta,
	.cta-actions,
	.cta-buttons,
	.cookie-buttons {
		flex-direction: column;
		align-items: center;
	}

	.games-stats {
		flex-direction: column;
		gap: 2rem;
	}

	.update-step {
		flex-direction: column;
		text-align: center;
		gap: 1rem;
	}

	.timeline-item {
		flex-direction: column;
		text-align: center;
		gap: 1rem;
	}
}

/* Modal Styles */
.modal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.8);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2000;
	padding: 2rem;
	backdrop-filter: blur(10px);
}

.modal-content {
	background: var(--white);
	border-radius: var(--border-radius-xl);
	width: 100%;
	max-width: 1000px;
	max-height: 90vh;
	overflow: hidden;
	box-shadow: var(--shadow-2xl);
	border: 3px solid var(--primary);
}

.modal-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 2rem;
	border-bottom: 3px solid var(--purple-100);
	background: var(--gradient-card);
}

.modal-title {
	margin: 0;
	color: var(--purple-800);
	font-size: 1.75rem;
	font-weight: 800;
}

.modal-close {
	background: var(--gradient-primary);
	color: var(--white);
	border: none;
	font-size: 1.5rem;
	cursor: pointer;
	padding: 0.75rem;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: var(--transition);
}

.modal-close:hover {
	background: var(--gradient-secondary);
	transform: scale(1.1);
}

.modal-body {
	padding: 0;
}

.modal-iframe {
	width: 100%;
	height: 70vh;
	border: none;
}

@media (max-width: 768px) {
	.modal {
		padding: 1rem;
	}

	.modal-iframe {
		height: 60vh;
	}

	.modal-header {
		padding: 1.5rem;
	}

	.modal-title {
		font-size: 1.5rem;
	}
}

/* Additional Animations */
@keyframes shimmer {
	0% {
		background-position: -200% 0;
	}
	100% {
		background-position: 200% 0;
	}
}

@keyframes rotate {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

@keyframes slideInLeft {
	from {
		opacity: 0;
		transform: translateX(-50px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(50px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes zoomIn {
	from {
		opacity: 0;
		transform: scale(0.5);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

/* Enhanced Visual Effects */
.hero-content {
	animation: fadeInUp 1s ease-out;
}

.hero-badge {
	animation: float 3s ease-in-out infinite, pulse 2s ease-in-out infinite;
}

.feature-card {
	animation: fadeInUp 0.6s ease-out;
}

.feature-card:nth-child(1) {
	animation-delay: 0.1s;
}
.feature-card:nth-child(2) {
	animation-delay: 0.2s;
}
.feature-card:nth-child(3) {
	animation-delay: 0.3s;
}
.feature-card:nth-child(4) {
	animation-delay: 0.4s;
}
.feature-card:nth-child(5) {
	animation-delay: 0.5s;
}
.feature-card:nth-child(6) {
	animation-delay: 0.6s;
}

/* Scroll Animations */
.scroll-animate {
	opacity: 0;
	transform: translateY(30px);
	transition: all 0.6s ease-out;
}

.scroll-animate.visible {
	opacity: 1;
	transform: translateY(0);
}

/* Hover Effects */
.hover-lift {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.hover-lift:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

/* Gradient Text Effects */
.gradient-text {
	background: var(--gradient-rainbow);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	animation: shimmer 3s ease-in-out infinite;
}

/* Loading States */
.loading {
	position: relative;
	overflow: hidden;
}

.loading::after {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.4),
		transparent
	);
	animation: shimmer 1.5s infinite;
}
