/* Header Component Styles */
.main-header {
	background-color: var(--bg-header);
	border-bottom: 1px solid var(--border-default);
	position: fixed;
	width: 100%;
	z-index: 32;
	padding: 12px 24px;
	color: var(--fg-default);
	top: 0;
	left: 0;
}

/* Ensure content appears below the fixed header */
body {
	margin-top: 0;
	padding-top: 0;
}

/* When header is present, add top margin to body */
body:has(.main-header) {
	margin-top: 56px; /* Adjust based on header height: 12px padding top + 12px padding bottom + ~32px content height */
}

/* Alternative approach for browsers that don't support :has() */
.main-header + * {
	margin-top: 56px;
}

/* Ensure the first element after header has proper spacing */
body > *:first-child:not(.main-header) {
	margin-top: 56px;
}

.header-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 980px;
	margin: 0 auto;
}

.header-left {
	display: flex;
	align-items: center;
	gap: 16px;
}

.logo-container {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

.brand-title {
	color: var(--fg-default);
	font-size: 28px;
	font-weight: 700;
	font-family: "Mona Sans", MonaSansFallback, -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
	letter-spacing: 1px;
	background: linear-gradient(90deg, var(--accent-fg), rgb(163, 113, 247));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	text-shadow: 0 0 20px rgba(163, 113, 247, 0.3);
	margin: 0;
}

.brand-title a {
	text-decoration: none;
}

.menu-toggle-button {
	background: none;
	border: none;
	color: var(--fg-default);
	cursor: pointer;
	padding: 8px;
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.2s ease;
	position: relative;
	width: 32px;
	height: 32px;
}

.menu-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}

.menu-icon--hamburger {
	opacity: 1;
}

.menu-icon--close {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

.menu-toggle-button[aria-expanded="true"] .menu-icon--hamburger {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

.menu-toggle-button[aria-expanded="true"] .menu-icon--close {
	opacity: 1;
	transform: translate(-50%, -50%) rotate(0);
}

.menu-toggle-button:hover {
	background-color: var(--btn-default-hover-bg);
}

/* .menu-toggle-button:focus {
	outline: 2px solid rgb(121, 192, 255);
	outline-offset: 2px;
} */

/* Fullscreen Toggle Button Styles */
.fullscreen-toggle-button {
	background: none;
	border: none;
	color: var(--fg-default);
	cursor: pointer;
	padding: 8px;
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.2s ease;
	position: relative;
	width: 32px;
	height: 32px;
}

.fullscreen-toggle-button:hover {
	background-color: var(--btn-default-hover-bg);
}

.fullscreen-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fullscreen-icon--enter {
	opacity: 1;
}

.fullscreen-icon--exit {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

.fullscreen-toggle-button[data-fullscreen="true"] .fullscreen-icon--enter {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

.fullscreen-toggle-button[data-fullscreen="true"] .fullscreen-icon--exit {
	opacity: 1;
	transform: translate(-50%, -50%) rotate(0);
}

.brand-image {
	aspect-ratio: 1;
	object-fit: cover;
	object-position: center;
	width: 100%;
	/* height: 32px; */
	overflow: hidden;
	border-radius: 4px;
}

.header-right {
	position: relative;
	display: flex;
	align-items: center;
	gap: 12px;
}

/* Theme Toggle Styles */
.theme-toggle-container {
	position: relative;
}

.theme-toggle-button {
	background: none;
	border: 1px solid var(--border-default);
	border-radius: 6px;
	cursor: pointer;
	padding: 6px;
	transition: border-color 0.2s ease, background-color 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	position: relative;
}

.theme-toggle-button:hover {
	border-color: var(--accent-fg);
	background-color: var(--btn-default-hover-bg);
}

.theme-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
	color: var(--fg-muted);
}

.theme-toggle-button:hover .theme-icon {
	color: var(--accent-fg);
}

/* Show sun icon in light mode, moon icon in dark mode */
[data-color-mode="light"] .theme-icon--sun,
[data-color-mode="auto"][data-light-theme="light"] .theme-icon--sun {
	opacity: 1;
}

[data-color-mode="light"] .theme-icon--moon,
[data-color-mode="auto"][data-light-theme="light"] .theme-icon--moon {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

[data-color-mode="dark"] .theme-icon--moon,
[data-color-mode="auto"][data-light-theme="dark"] .theme-icon--moon {
	opacity: 1;
}

[data-color-mode="dark"] .theme-icon--sun,
[data-color-mode="auto"][data-light-theme="dark"] .theme-icon--sun {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(-90deg);
}

.theme-dropdown-menu {
	position: absolute;
	top: 100%;
	right: 0;
	margin-top: 8px;
	background-color: var(--bg-overlay);
	border: 1px solid var(--border-default);
	border-radius: 6px;
	padding: 8px 0;
	min-width: 160px;
	box-shadow: var(--shadow-large);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
	z-index: 50;
}

.theme-dropdown-menu.show {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.theme-option {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	padding: 8px 16px;
	background: none;
	border: none;
	color: var(--fg-default);
	text-decoration: none;
	transition: background-color 0.2s ease;
	font-size: 14px;
	line-height: 1.5;
	cursor: pointer;
	text-align: left;
}

.theme-option:hover {
	background-color: var(--btn-default-hover-bg);
}

.theme-option:focus {
	background-color: var(--accent-subtle);
	outline: none;
}

.theme-option.active {
	background-color: var(--accent-subtle);
	color: var(--accent-fg);
}

.theme-option svg {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
}

.user-menu-container {
	position: relative;
}

.user-avatar-button {
	background: none;
	border: 1px solid var(--border-default);
	border-radius: 50%;
	cursor: pointer;
	padding: 2px;
	transition: border-color 0.2s ease;
}

.user-avatar-button:hover {
	border-color: var(--accent-fg);
}

/*
.user-avatar-button:focus {
	outline: 2px solid rgb(121, 192, 255);
	outline-offset: 2px;
} */

.user-avatar-image {
	aspect-ratio: 1;
	object-fit: cover;
	object-position: center;
	width: 32px;
	border-radius: 50%;
	height: 32px;
	overflow: hidden;
	display: block;
}

.user-glyph-icon {
	width: 24px;
	height: 24px;
	color: var(--fg-muted);
	display: block;
}

.user-avatar-button:hover .user-glyph-icon {
	color: var(--accent-fg);
}

.user-dropdown-menu {
	position: absolute;
	top: 100%;
	right: 0;
	margin-top: 8px;
	background-color: var(--bg-overlay);
	border: 1px solid var(--border-default);
	border-radius: 6px;
	padding: 8px 0;
	min-width: 180px;
	box-shadow: var(--shadow-large);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
}

.user-dropdown-menu.show {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.dropdown-link {
	display: block;
	padding: 8px 16px;
	color: var(--fg-default);
	text-decoration: none;
	transition: background-color 0.2s ease;
	font-size: 14px;
	line-height: 1.5;
}

.dropdown-link:hover {
	background-color: var(--btn-default-hover-bg);
}

.dropdown-link:focus {
	background-color: var(--accent-subtle);
	outline: none;
}

.dropdown-separator {
	border: none;
	border-top: 1px solid var(--border-default);
	margin: 8px 0;
}

.sign-out-link {
	color: rgb(248, 81, 73);
}

.sign-out-link:hover {
	background-color: rgba(248, 81, 73, 0.1);
}

/* Responsive Design */
@media (max-width: 640px) {
	.brand-title {
		font-size: 24px;
	}

	.main-header {
		padding: 8px 16px;
	}

	.header-left {
		gap: 12px;
	}

	.user-dropdown-menu {
		min-width: 160px;
		right: -8px;
	}
}

/* High contrast mode support */
@media (prefers-contrast: high) {
	.main-header {
		border-bottom-width: 2px;
	}

	.user-avatar-button {
		border-width: 2px;
	}

	.user-dropdown-menu {
		border-width: 2px;
	}
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {

	.user-dropdown-menu,
	.menu-toggle-button,
	.user-avatar-button,
	.dropdown-link {
		transition: none;
	}
}

/* Focus visible for better accessibility */
.menu-toggle-button:focus-visible,
.user-avatar-button:focus-visible,
.dropdown-link:focus-visible,
.theme-toggle-button:focus-visible,
.theme-option:focus-visible {
	outline: 2px solid var(--accent-fg);
	outline-offset: 2px;
}


/* Sidebar Navigation Menu */
.sidebar-menu {
	position: fixed;
	top: 0;
	left: 0;
	width: 300px;
	height: 100%;
	background-color: var(--bg-sidebar);
	border-right: 1px solid var(--border-default);
	transition: transform 0.3s ease;
	z-index: 31;
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 24px;
	transform: translateX(-100%);
	will-change: transform;
	overflow-y: auto;
}

.sidebar-menu.open {
	transform: translateX(0);
	box-shadow: 2px 0 10px rgba(0, 0, 0, 0.2);
}

/* Overlay styles */
.sidebar-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	z-index: 30;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Prevent body scroll when menu is open */
body.menu-open {
	overflow: hidden;
	position: fixed;
	width: 100%;
	height: 100%;
}

.sidebar-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-shrink: 0;
}

.sidebar-title {
	color: var(--fg-default);
	font-size: 20px;
	font-weight: 600;
	margin: 0;
}

.close-button {
	background: none;
	border: none;
	color: var(--fg-muted);
	cursor: pointer;
	padding: 8px;
	border-radius: 4px;
	transition: color 0.2s ease;
}

.close-button:hover,
.close-button:focus {
	color: var(--fg-default);
	outline: 2px solid var(--fg-muted);
	outline-offset: 2px;
}

.close-button:active {
	transform: scale(0.95);
}

.sidebar-nav {
	flex: 1;
}

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

.nav-item {
	margin: 0;
}

.nav-link {
	color: var(--fg-default);
	text-decoration: none;
	font-size: 16px;
	display: block;
	padding: 8px 12px;
	border-radius: 4px;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.nav-link:hover,
.nav-link:focus {
	background-color: var(--btn-default-hover-bg);
	outline: 2px solid var(--fg-muted);
	outline-offset: 2px;
}

.nav-link:active {
	background-color: var(--btn-default-active-bg);
}

/* Sidebar Footer */
.sidebar-footer {
	flex-shrink: 0;
	margin-top: auto;
	padding-top: 24px;
	border-top: 1px solid var(--border-default);
}

.nav-list--footer {
	gap: 8px;
}

.nav-item--footer {
	margin: 0;
}

.nav-link--footer {
	color: var(--fg-muted);
	text-decoration: none;
	font-size: 12px;
	display: block;
	padding: 6px 12px;
	border-radius: 4px;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.nav-link--footer:hover,
.nav-link--footer:focus {
	background-color: var(--btn-default-hover-bg);
	color: var(--fg-default);
	outline: 2px solid var(--fg-muted);
	outline-offset: 2px;
}

.nav-link--footer:active {
	background-color: var(--btn-default-active-bg);
}

/* Demo toggle button for testing */
.demo-toggle {
	position: fixed;
	top: 20px;
	right: 20px;
	background-color: rgb(13, 17, 23);
	color: rgb(255, 255, 255);
	border: 1px solid rgb(33, 38, 45);
	padding: 12px 16px;
	border-radius: 4px;
	cursor: pointer;
	z-index: 32;
}

.demo-toggle:hover,
.demo-toggle:focus {
	background-color: rgb(33, 38, 45);
	outline: 2px solid rgb(139, 148, 158);
	outline-offset: 2px;
}

/* Overlay for mobile */
.sidebar-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	z-index: 30;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.sidebar-overlay.active {
	opacity: 1;
	visibility: visible;
}

/* Screen reader only text */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

@media (max-width: 768px) {
	.sidebar-menu {
		width: 280px;
	}
}

@media (max-width: 480px) {
	.sidebar-menu {
		width: 100%;
		max-width: 320px;
	}
}

/* Games Section Styles */
.nav-section {
	margin: 16px 0;
}

.nav-section-title {
	color: var(--fg-muted);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin: 0 0 8px 0;
	padding: 0 16px;
}

.nav-list--games {
	margin: 0;
	padding: 0;
}

.nav-item--game {
	margin: 0;
}

.nav-link--game {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding: 12px 16px;
	gap: 4px;
	transition: background-color 0.2s ease;
}

.nav-link--game:hover {
	background-color: var(--accent-subtle);
}

.nav-link--game:active {
	background-color: var(--accent-muted);
}

.game-icon {
	font-size: 16px;
	margin-right: 8px;
}

.game-name {
	font-weight: 600;
	font-size: 14px;
	color: var(--fg-default);
}

.game-description {
	font-size: 12px;
	color: var(--fg-muted);
	margin-left: 24px;
}

.demo-toggle {
	background: none;
	border: none;
	color: var(--fg-default);
	cursor: pointer;
	padding: 12px 16px;
	width: 100%;
	text-align: left;
	font-size: 14px;
	transition: background-color 0.2s ease;
	display: flex;
	align-items: center;
	gap: 8px;
}

