/* ==========================================================================
   EC Wiki — rsgdx
   custom-style.css
   All theme styles. Depends on style.css for :root variable definitions.
   ========================================================================== */

/* ==========================================================================
   RESET & BASE
   ========================================================================== */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--rsgdxwiki-font-sans);
	font-size: var(--rsgdxwiki-text-base);
	line-height: 1.6;
	color: var(--rsgdxwiki-color-text);
	background-color: var(--rsgdxwiki-color-bg);
	min-height: 100vh;
}

/* ==========================================================================
   TYPOGRAPHY
   ========================================================================== */

h1, h2, h3, h4, h5, h6 {
	font-weight: 600;
	line-height: 1.3;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: var(--rsgdxwiki-space-4);
}

h1 { font-size: var(--rsgdxwiki-text-3xl); }
h2 { font-size: var(--rsgdxwiki-text-2xl); }
h3 { font-size: var(--rsgdxwiki-text-xl); }
h4 { font-size: var(--rsgdxwiki-text-lg); }
h5 { font-size: var(--rsgdxwiki-text-md); }
h6 { font-size: var(--rsgdxwiki-text-base); }

p {
	margin-bottom: var(--rsgdxwiki-space-4);
	color: var(--rsgdxwiki-color-text);
}

a {
	color: var(--rsgdxwiki-color-blue-light);
	text-decoration: none;
	transition: color var(--rsgdxwiki-transition);
}

a:hover,
a:focus {
	color: var(--rsgdxwiki-color-text);
	text-decoration: underline;
}

strong, b { font-weight: 600; }

small {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-muted);
}

code {
	font-family: var(--rsgdxwiki-font-mono);
	font-size: var(--rsgdxwiki-text-sm);
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-blue-light);
	padding: var(--rsgdxwiki-space-1) var(--rsgdxwiki-space-2);
	border-radius: var(--rsgdxwiki-radius-sm);
	border: 1px solid var(--rsgdxwiki-color-border);
}

pre {
	font-family: var(--rsgdxwiki-font-mono);
	font-size: var(--rsgdxwiki-text-sm);
	background-color: var(--rsgdxwiki-color-surface);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-md);
	padding: var(--rsgdxwiki-space-6);
	overflow-x: auto;
	margin-bottom: var(--rsgdxwiki-space-6);
	line-height: 1.7;
}

pre code {
	background: none;
	border: none;
	padding: 0;
	font-size: inherit;
}

blockquote {
	border-left: 3px solid var(--rsgdxwiki-color-blue);
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-6);
	margin: var(--rsgdxwiki-space-6) 0;
	background-color: var(--rsgdxwiki-color-blue-faint);
	border-radius: 0 var(--rsgdxwiki-radius-md) var(--rsgdxwiki-radius-md) 0;
	color: var(--rsgdxwiki-color-text-muted);
	font-style: italic;
}

blockquote p:last-child { margin-bottom: 0; }

hr {
	border: none;
	border-top: 1px solid var(--rsgdxwiki-color-border);
	margin: var(--rsgdxwiki-space-8) 0;
}

ul, ol {
	padding-left: var(--rsgdxwiki-space-6);
	margin-bottom: var(--rsgdxwiki-space-4);
}

li {
	margin-bottom: var(--rsgdxwiki-space-2);
	color: var(--rsgdxwiki-color-text);
}

/* ==========================================================================
   LAYOUT
   ========================================================================== */

.rsgdxwiki-site-wrapper {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.rsgdxwiki-site-main {
	display: flex;
	flex: 1;
	flex-direction: column;
	width: 100%;
}

/* ==========================================================================
   HEADER
   ========================================================================== */

.rsgdxwiki-site-header {
	background-color: var(--rsgdxwiki-color-surface);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: var(--rsgdxwiki-shadow-sm);
}

.rsgdxwiki-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
	padding: 0 var(--rsgdxwiki-space-6);
	height: var(--rsgdxwiki-header-height);
	gap: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-site-header-logo__inner {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: var(--rsgdxwiki-space-3);
	flex-shrink: 0;
}

/* --- Sidebar toggle --- */
.rsgdxwiki-sidebar-toggle {
	background: none;
	border: none;
	color: var(--rsgdxwiki-color-text-muted);
	cursor: pointer;
	padding: var(--rsgdxwiki-space-2);
	border-radius: var(--rsgdxwiki-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--rsgdxwiki-text-lg);
	transition: background-color var(--rsgdxwiki-transition), color var(--rsgdxwiki-transition);
	flex-shrink: 0;
}

.rsgdxwiki-sidebar-toggle:hover {
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-text);
}

/* --- Logo --- */
.rsgdxwiki-site-logo {
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-3);
	text-decoration: none;
	flex-shrink: 0;
}

.rsgdxwiki-site-logo:hover { text-decoration: none; }

.rsgdxwiki-site-logo__mark {
	width: 32px;
	height: 32px;
	background: var(--rsgdxwiki-color-blue);
	border-radius: var(--rsgdxwiki-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	letter-spacing: -0.5px;
	flex-shrink: 0;
}

.rsgdxwiki-site-logo__name {
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 600;
	color: var(--rsgdxwiki-color-text);
	line-height: 1.2;
}

.rsgdxwiki-site-logo__sub {
	font-size: var(--rsgdxwiki-text-xs);
	color: var(--rsgdxwiki-color-text-muted);
	font-weight: 400;
}

/* --- Header search --- */
.rsgdxwiki-site-search {
	flex: 1;
	max-width: 420px;
}

.rsgdxwiki-site-search__form {
	display: flex;
	align-items: center;
	background-color: var(--rsgdxwiki-color-bg);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-md);
	overflow: hidden;
	transition: border-color var(--rsgdxwiki-transition);
}

.rsgdxwiki-site-search__form:focus-within {
	border-color: var(--rsgdxwiki-color-blue);
	box-shadow: 0 0 0 1px var(--rsgdxwiki-color-blue);
}

.rsgdxwiki-site-search__input {
	flex: 1;
	background: none;
	border: none;
	outline: none;
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-4);
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text);
	font-family: var(--rsgdxwiki-font-sans);
}

.rsgdxwiki-site-search__input::placeholder {
	color: var(--rsgdxwiki-color-text-subtle);
}

.rsgdxwiki-site-search__btn {
	background: none;
	border: none;
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-3);
	color: var(--rsgdxwiki-color-text-subtle);
	cursor: pointer;
	display: flex;
	align-items: center;
	transition: color var(--rsgdxwiki-transition);
}

.rsgdxwiki-site-search__btn:hover {
	color: var(--rsgdxwiki-color-blue-light);
}

/* --- Header nav --- */
.rsgdxwiki-site-header__nav {
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
	flex-shrink: 0;
}

.rsgdxwiki-site-header__nav a {
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 500;
	color: var(--rsgdxwiki-color-text-muted);
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-3);
	border-radius: var(--rsgdxwiki-radius-md);
	transition: background-color var(--rsgdxwiki-transition), color var(--rsgdxwiki-transition);
	text-decoration: none;
}

.rsgdxwiki-site-header__nav a:hover,
.rsgdxwiki-site-header__nav a.rsgdxwiki-current {
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-text);
}

/* ==========================================================================
   SIDEBAR DRAWER
   ========================================================================== */

.rsgdxwiki-sidebar-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	z-index: 199;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--rsgdxwiki-transition-md);
}

.rsgdxwiki-sidebar-overlay.is-open {
	opacity: 1;
	pointer-events: all;
}

.rsgdxwiki-sidebar-drawer {
	position: fixed;
	top: 0;
	left: 0;
	width: 300px;
	height: 100vh;
	background-color: var(--rsgdxwiki-color-surface);
	border-right: 1px solid var(--rsgdxwiki-color-border);
	z-index: 200;
	transform: translateX(-100%);
	transition: transform var(--rsgdxwiki-transition-md);
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: var(--rsgdxwiki-color-border) transparent;
	display: flex;
	flex-direction: column;
}

.rsgdxwiki-sidebar-drawer::-webkit-scrollbar { width: 4px; }
.rsgdxwiki-sidebar-drawer::-webkit-scrollbar-thumb {
	background: var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-full);
}

.rsgdxwiki-sidebar-drawer.is-open {
	transform: translateX(0);
}

.rsgdxwiki-sidebar-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-5);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
	flex-shrink: 0;
}

.rsgdxwiki-sidebar-drawer__title {
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text-muted);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 0;
}

.rsgdxwiki-sidebar-drawer__close {
	background: none;
	border: none;
	color: var(--rsgdxwiki-color-text-muted);
	cursor: pointer;
	padding: var(--rsgdxwiki-space-2);
	border-radius: var(--rsgdxwiki-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color var(--rsgdxwiki-transition), color var(--rsgdxwiki-transition);
	font-size: var(--rsgdxwiki-text-md);
}

.rsgdxwiki-sidebar-drawer__close:hover {
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-text);
}

.rsgdxwiki-sidebar-drawer__body {
	flex: 1;
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-3);
}

/* --- Sidebar menu inside drawer --- */
.rsgdxwiki-sidebar-menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

.rsgdxwiki-sidebar-menu li { margin: 0; }

.rsgdxwiki-sidebar-menu a {
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-3);
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-muted);
	border-radius: var(--rsgdxwiki-radius-md);
	transition: background-color var(--rsgdxwiki-transition), color var(--rsgdxwiki-transition);
	text-decoration: none;
	line-height: 1.4;
}

.rsgdxwiki-sidebar-menu a:hover,
.rsgdxwiki-sidebar-menu .current-menu-item > a {
	background-color: var(--rsgdxwiki-color-blue-faint);
	color: var(--rsgdxwiki-color-blue-light);
	text-decoration: none;
}

.rsgdxwiki-sidebar-menu .current-menu-item > a {
	font-weight: 600;
	border-left: 2px solid var(--rsgdxwiki-color-blue);
	padding-left: calc(var(--rsgdxwiki-space-3) - 2px);
}

.rsgdxwiki-sidebar-menu .sub-menu {
	list-style: none;
	padding: 0;
	margin: var(--rsgdxwiki-space-1) 0 var(--rsgdxwiki-space-1) var(--rsgdxwiki-space-6);
}

.rsgdxwiki-sidebar-menu .sub-menu a {
	font-size: var(--rsgdxwiki-text-xs);
	padding: var(--rsgdxwiki-space-1) var(--rsgdxwiki-space-3);
}

/* ==========================================================================
   CARDS
   ========================================================================== */

.rsgdxwiki-card {
	background-color: var(--rsgdxwiki-color-surface);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-lg);
	padding: var(--rsgdxwiki-space-6);
	display: flex;
	flex-direction: column;
	gap: var(--rsgdxwiki-space-3);
	transition: border-color var(--rsgdxwiki-transition), box-shadow var(--rsgdxwiki-transition);
}

.rsgdxwiki-card:hover {
	border-color: var(--rsgdxwiki-color-border-light);
	box-shadow: var(--rsgdxwiki-shadow-md);
}

.rsgdxwiki-card--link {
	text-decoration: none;
	cursor: pointer;
}

.rsgdxwiki-card--link:hover {
	border-color: var(--rsgdxwiki-color-blue);
	text-decoration: none;
}

.rsgdxwiki-card__eyebrow {
	font-size: var(--rsgdxwiki-text-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--rsgdxwiki-color-blue-light);
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
}

.rsgdxwiki-card__title {
	font-size: var(--rsgdxwiki-text-md);
	font-weight: 600;
	color: var(--rsgdxwiki-color-text);
	line-height: 1.3;
	margin-bottom: 0;
}

.rsgdxwiki-card__desc {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-muted);
	line-height: 1.6;
	margin-bottom: 0;
	flex: 1;
}

.rsgdxwiki-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--rsgdxwiki-space-2);
	padding-top: var(--rsgdxwiki-space-3);
	border-top: 1px solid var(--rsgdxwiki-color-border);
	margin-top: auto;
}

/* --- Card grid --- */
.rsgdxwiki-card-grid {
	display: grid;
	gap: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-card-grid--2 { grid-template-columns: repeat(2, 1fr); }
.rsgdxwiki-card-grid--3 { grid-template-columns: repeat(3, 1fr); }
.rsgdxwiki-card-grid--4 { grid-template-columns: repeat(4, 1fr); }

/* ==========================================================================
   BUTTONS
   ========================================================================== */

.rsgdxwiki-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--rsgdxwiki-space-2);
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-5);
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 600;
	font-family: var(--rsgdxwiki-font-sans);
	border-radius: var(--rsgdxwiki-radius-md);
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--rsgdxwiki-transition), border-color var(--rsgdxwiki-transition), color var(--rsgdxwiki-transition);
	line-height: 1.5;
	white-space: nowrap;
}

.rsgdxwiki-btn:focus-visible {
	outline: 2px solid var(--rsgdxwiki-color-blue);
	outline-offset: 2px;
}

.rsgdxwiki-btn--primary {
	background-color: var(--rsgdxwiki-color-blue);
	color: var(--rsgdxwiki-color-text);
	border-color: var(--rsgdxwiki-color-blue);
}

.rsgdxwiki-btn--primary:hover {
	background-color: var(--rsgdxwiki-color-blue-hover);
	border-color: var(--rsgdxwiki-color-blue-hover);
	color: var(--rsgdxwiki-color-text);
	text-decoration: none;
}

.rsgdxwiki-btn--secondary {
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-text);
	border-color: var(--rsgdxwiki-color-border);
}

.rsgdxwiki-btn--secondary:hover {
	background-color: var(--rsgdxwiki-color-surface-alt);
	border-color: var(--rsgdxwiki-color-border-light);
	color: var(--rsgdxwiki-color-text);
	text-decoration: none;
}

.rsgdxwiki-btn--ghost {
	background-color: transparent;
	color: var(--rsgdxwiki-color-text-muted);
	border-color: var(--rsgdxwiki-color-border);
}

.rsgdxwiki-btn--ghost:hover {
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-text);
	text-decoration: none;
}

.rsgdxwiki-btn--accent {
	background-color: var(--rsgdxwiki-color-accent);
	color: #fff;
	border-color: var(--rsgdxwiki-color-accent);
}

.rsgdxwiki-btn--accent:hover {
	background-color: var(--rsgdxwiki-color-accent-hover);
	border-color: var(--rsgdxwiki-color-accent-hover);
	color: #fff;
	text-decoration: none;
}

.rsgdxwiki-btn--sm {
	padding: var(--rsgdxwiki-space-1) var(--rsgdxwiki-space-3);
	font-size: var(--rsgdxwiki-text-xs);
}

.rsgdxwiki-btn--lg {
	padding: var(--rsgdxwiki-space-3) var(--rsgdxwiki-space-8);
	font-size: var(--rsgdxwiki-text-md);
}

/* ==========================================================================
   BADGES
   ========================================================================== */

.rsgdxwiki-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-1);
	padding: var(--rsgdxwiki-space-1) var(--rsgdxwiki-space-3);
	font-size: var(--rsgdxwiki-text-xs);
	font-weight: 600;
	border-radius: var(--rsgdxwiki-radius-full);
	line-height: 1;
}

.rsgdxwiki-badge--blue {
	background-color: var(--rsgdxwiki-color-blue-faint);
	color: var(--rsgdxwiki-color-blue-light);
	border: 1px solid rgba(114, 174, 230, 0.2);
}

.rsgdxwiki-badge--accent {
	background-color: var(--rsgdxwiki-color-accent-faint);
	color: var(--rsgdxwiki-color-accent);
	border: 1px solid rgba(255, 122, 89, 0.2);
}

.rsgdxwiki-badge--success {
	background-color: rgba(0, 163, 42, 0.1);
	color: #68de7c;
	border: 1px solid rgba(0, 163, 42, 0.2);
}

.rsgdxwiki-badge--muted {
	background-color: var(--rsgdxwiki-color-surface-high);
	color: var(--rsgdxwiki-color-text-muted);
	border: 1px solid var(--rsgdxwiki-color-border);
}

/* ==========================================================================
   NOTICES
   ========================================================================== */

.rsgdxwiki-notice {
	display: flex;
	gap: var(--rsgdxwiki-space-4);
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-5);
	border-radius: var(--rsgdxwiki-radius-md);
	margin-bottom: var(--rsgdxwiki-space-6);
	border: 1px solid transparent;
}

.rsgdxwiki-notice__icon {
	font-size: var(--rsgdxwiki-text-lg);
	flex-shrink: 0;
	line-height: 1.5;
}

.rsgdxwiki-notice__content { flex: 1; }

.rsgdxwiki-notice__title {
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 700;
	margin-bottom: var(--rsgdxwiki-space-1);
}

.rsgdxwiki-notice__text {
	font-size: var(--rsgdxwiki-text-sm);
	line-height: 1.6;
	margin-bottom: 0;
}

.rsgdxwiki-notice--info {
	background-color: var(--rsgdxwiki-color-blue-faint);
	border-color: rgba(114, 174, 230, 0.2);
	color: var(--rsgdxwiki-color-blue-light);
}

.rsgdxwiki-notice--warning {
	background-color: rgba(219, 166, 23, 0.08);
	border-color: rgba(219, 166, 23, 0.2);
	color: #f0c33c;
}

.rsgdxwiki-notice--success {
	background-color: rgba(0, 163, 42, 0.08);
	border-color: rgba(0, 163, 42, 0.2);
	color: #68de7c;
}

.rsgdxwiki-notice--error {
	background-color: rgba(214, 54, 56, 0.08);
	border-color: rgba(214, 54, 56, 0.2);
	color: #f86368;
}

/* ==========================================================================
   BREADCRUMB
   ========================================================================== */

.rsgdxwiki-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--rsgdxwiki-space-2);
	margin-bottom: var(--rsgdxwiki-space-6);
	font-size: var(--rsgdxwiki-text-sm);
}

.rsgdxwiki-breadcrumb__item { color: var(--rsgdxwiki-color-text-muted); }

.rsgdxwiki-breadcrumb__item a {
	color: var(--rsgdxwiki-color-text-muted);
	text-decoration: none;
	transition: color var(--rsgdxwiki-transition);
}

.rsgdxwiki-breadcrumb__item a:hover { color: var(--rsgdxwiki-color-blue-light); }

.rsgdxwiki-breadcrumb__separator {
	color: var(--rsgdxwiki-color-text-subtle);
	font-size: var(--rsgdxwiki-text-xs);
}

.rsgdxwiki-breadcrumb__item--current { color: var(--rsgdxwiki-color-text); }

/* ==========================================================================
   TABLE OF CONTENTS
   ========================================================================== */

.rsgdxwiki-toc {
	background-color: var(--rsgdxwiki-color-surface);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-lg);
	padding: var(--rsgdxwiki-space-5);
}

.rsgdxwiki-toc__title {
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text-muted);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: var(--rsgdxwiki-space-4);
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
}

.rsgdxwiki-toc__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.rsgdxwiki-toc__list li { margin-bottom: var(--rsgdxwiki-space-2); }

.rsgdxwiki-toc__list a {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-muted);
	text-decoration: none;
	transition: color var(--rsgdxwiki-transition);
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
}

.rsgdxwiki-toc__list a:hover { color: var(--rsgdxwiki-color-blue-light); }

.rsgdxwiki-toc__list a::before {
	content: '';
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--rsgdxwiki-color-border-light);
	flex-shrink: 0;
	transition: background var(--rsgdxwiki-transition);
}

.rsgdxwiki-toc__list a:hover::before { background: var(--rsgdxwiki-color-blue-light); }

/* ==========================================================================
   ENTRY CONTENT
   ========================================================================== */

.rsgdxwiki-entry-header {
	margin-bottom: var(--rsgdxwiki-space-8);
	padding-bottom: var(--rsgdxwiki-space-8);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-entry-header__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--rsgdxwiki-space-3);
	margin-bottom: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-entry-title {
	font-size: var(--rsgdxwiki-text-3xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	line-height: 1.2;
	margin-bottom: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-entry-excerpt {
	font-size: var(--rsgdxwiki-text-md);
	color: var(--rsgdxwiki-color-text-muted);
	line-height: 1.7;
	margin-bottom: 0;
}

.rsgdxwiki-entry-content {
	font-size: var(--rsgdxwiki-text-base);
	line-height: 1.8;
	color: var(--rsgdxwiki-color-text);
}

.rsgdxwiki-entry-content h2 {
	font-size: var(--rsgdxwiki-text-2xl);
	margin-top: var(--rsgdxwiki-space-12);
	margin-bottom: var(--rsgdxwiki-space-4);
	padding-bottom: var(--rsgdxwiki-space-3);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-entry-content h3 {
	font-size: var(--rsgdxwiki-text-xl);
	margin-top: var(--rsgdxwiki-space-8);
	margin-bottom: var(--rsgdxwiki-space-3);
}

.rsgdxwiki-entry-content h4 {
	font-size: var(--rsgdxwiki-text-lg);
	margin-top: var(--rsgdxwiki-space-6);
	margin-bottom: var(--rsgdxwiki-space-3);
}

.rsgdxwiki-entry-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--rsgdxwiki-radius-md);
	border: 1px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-entry-content table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--rsgdxwiki-space-6);
	font-size: var(--rsgdxwiki-text-sm);
}

.rsgdxwiki-entry-content table th {
	background-color: var(--rsgdxwiki-color-surface-high);
	padding: var(--rsgdxwiki-space-3) var(--rsgdxwiki-space-4);
	text-align: left;
	font-weight: 600;
	color: var(--rsgdxwiki-color-text);
	border-bottom: 2px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-entry-content table td {
	padding: var(--rsgdxwiki-space-3) var(--rsgdxwiki-space-4);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
	color: var(--rsgdxwiki-color-text-muted);
	vertical-align: top;
}

.rsgdxwiki-entry-content table tr:hover td {
	background-color: var(--rsgdxwiki-color-surface);
}

/* --- Procedure steps --- */
.rsgdxwiki-procedure-steps {
	list-style: none;
	padding: 0;
	margin: var(--rsgdxwiki-space-6) 0;
	counter-reset: rsgdxwiki-steps;
}

.rsgdxwiki-procedure-steps li {
	display: flex;
	gap: var(--rsgdxwiki-space-4);
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-5);
	background-color: var(--rsgdxwiki-color-surface);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-md);
	margin-bottom: var(--rsgdxwiki-space-3);
	counter-increment: rsgdxwiki-steps;
	align-items: flex-start;
}

.rsgdxwiki-procedure-steps li::before {
	content: counter(rsgdxwiki-steps);
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background-color: var(--rsgdxwiki-color-blue);
	color: var(--rsgdxwiki-color-text);
	font-size: var(--rsgdxwiki-text-xs);
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 2px;
}

/* ==========================================================================
   VIDEO EMBED
   ========================================================================== */

.rsgdxwiki-video-embed {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: var(--rsgdxwiki-radius-lg);
	border: 1px solid var(--rsgdxwiki-color-border);
	background-color: var(--rsgdxwiki-color-surface);
	margin-bottom: var(--rsgdxwiki-space-6);
}

.rsgdxwiki-video-embed iframe,
.rsgdxwiki-video-embed video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

.rsgdxwiki-video-embed__caption {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-muted);
	margin-top: var(--rsgdxwiki-space-2);
	text-align: center;
}

/* ==========================================================================
   FORMS
   ========================================================================== */

.rsgdxwiki-input,
input[type="text"],
input[type="email"],
input[type="search"],
input[type="url"],
textarea,
select {
	width: 100%;
	background-color: var(--rsgdxwiki-color-bg);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-md);
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-4);
	font-size: var(--rsgdxwiki-text-sm);
	font-family: var(--rsgdxwiki-font-sans);
	color: var(--rsgdxwiki-color-text);
	transition: border-color var(--rsgdxwiki-transition), box-shadow var(--rsgdxwiki-transition);
	outline: none;
}

.rsgdxwiki-input:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus {
	border-color: var(--rsgdxwiki-color-blue);
	box-shadow: 0 0 0 1px var(--rsgdxwiki-color-blue);
}

input::placeholder,
textarea::placeholder {
	color: var(--rsgdxwiki-color-text-subtle);
}

.rsgdxwiki-label,
label {
	display: block;
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 600;
	color: var(--rsgdxwiki-color-text-muted);
	margin-bottom: var(--rsgdxwiki-space-2);
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.rsgdxwiki-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--rsgdxwiki-space-2);
	margin-top: var(--rsgdxwiki-space-10);
	padding-top: var(--rsgdxwiki-space-8);
	border-top: 1px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-pagination a,
.rsgdxwiki-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 var(--rsgdxwiki-space-2);
	border-radius: var(--rsgdxwiki-radius-md);
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 600;
	text-decoration: none;
	transition: background-color var(--rsgdxwiki-transition), color var(--rsgdxwiki-transition);
}

.rsgdxwiki-pagination a {
	color: var(--rsgdxwiki-color-text-muted);
	background-color: var(--rsgdxwiki-color-surface);
	border: 1px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-pagination a:hover {
	background-color: var(--rsgdxwiki-color-blue);
	color: var(--rsgdxwiki-color-text);
	border-color: var(--rsgdxwiki-color-blue);
}

.rsgdxwiki-pagination .current {
	background-color: var(--rsgdxwiki-color-blue);
	color: var(--rsgdxwiki-color-text);
	border: 1px solid var(--rsgdxwiki-color-blue);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

.rsgdxwiki-site-footer {
	background-color: var(--rsgdxwiki-color-surface);
	border-top: 1px solid var(--rsgdxwiki-color-border);
	padding: var(--rsgdxwiki-space-8) var(--rsgdxwiki-space-6);
	margin-top: auto;
}

.rsgdxwiki-site-footer__inner {
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--rsgdxwiki-space-6);
	flex-wrap: wrap;
}

.rsgdxwiki-site-footer__copy {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-subtle);
}

.rsgdxwiki-site-footer__copy a {
	color: var(--rsgdxwiki-color-text-muted);
	text-decoration: none;
}

.rsgdxwiki-site-footer__copy a:hover { color: var(--rsgdxwiki-color-blue-light); }

.rsgdxwiki-site-footer__links {
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-site-footer__links a {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-subtle);
	text-decoration: none;
	transition: color var(--rsgdxwiki-transition);
}

.rsgdxwiki-site-footer__links a:hover { color: var(--rsgdxwiki-color-blue-light); }

/* --- Footer menu list reset --- */
.rsgdxwiki-footer-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-footer-menu li { margin: 0; }

.rsgdxwiki-footer-menu a {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-subtle);
	text-decoration: none;
	transition: color var(--rsgdxwiki-transition);
}

.rsgdxwiki-footer-menu a:hover { color: var(--rsgdxwiki-color-blue-light); }

/* ==========================================================================
   FRONT PAGE
   ========================================================================== */

.rsgdxwiki-frontpage {
	width: 100%;
	display: flex;
	flex-direction: column;
}

.rsgdxwiki-frontpage__hero {
	padding: var(--rsgdxwiki-space-12) var(--rsgdxwiki-space-6);
	text-align: center;
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
	background-color: var(--rsgdxwiki-color-surface);
}

.rsgdxwiki-frontpage__hero-eyebrow {
	font-size: var(--rsgdxwiki-text-xs);
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--rsgdxwiki-color-blue-light);
	margin-bottom: var(--rsgdxwiki-space-3);
}

.rsgdxwiki-frontpage__hero-title {
	font-size: var(--rsgdxwiki-text-4xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: var(--rsgdxwiki-space-4);
	line-height: 1.2;
}

.rsgdxwiki-frontpage__hero-title span {
	color: var(--rsgdxwiki-color-blue-light);
}

.rsgdxwiki-frontpage__hero-sub {
	font-size: var(--rsgdxwiki-text-md);
	color: var(--rsgdxwiki-color-text-muted);
	max-width: 540px;
	margin: 0 auto var(--rsgdxwiki-space-8);
	line-height: 1.7;
}

/* Hero search */
.rsgdxwiki-frontpage__search {
	max-width: 560px;
	margin: 0 auto;
}

.rsgdxwiki-frontpage__search-form {
	display: flex;
	align-items: center;
	background-color: var(--rsgdxwiki-color-bg);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-lg);
	overflow: hidden;
	transition: border-color var(--rsgdxwiki-transition);
	box-shadow: var(--rsgdxwiki-shadow-md);
}

.rsgdxwiki-frontpage__search-form:focus-within {
	border-color: var(--rsgdxwiki-color-blue);
	box-shadow: 0 0 0 2px var(--rsgdxwiki-color-blue);
}

.rsgdxwiki-frontpage__search-form .rsgdxwiki-frontpage__search-input {
	flex: 1;
	background: none;
	border: none;
	outline: none;
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-5);
	font-size: var(--rsgdxwiki-text-base);
	color: var(--rsgdxwiki-color-text);
	font-family: var(--rsgdxwiki-font-sans);
}

.rsgdxwiki-frontpage__search-form .rsgdxwiki-frontpage__search-input::placeholder {
	color: var(--rsgdxwiki-color-text-subtle);
}

.rsgdxwiki-frontpage__search-btn {
	background: var(--rsgdxwiki-color-blue);
	border: none;
	padding: var(--rsgdxwiki-space-4) var(--rsgdxwiki-space-5);
	color: var(--rsgdxwiki-color-text);
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 600;
	font-family: var(--rsgdxwiki-font-sans);
	transition: background-color var(--rsgdxwiki-transition);
	white-space: nowrap;
}

.rsgdxwiki-frontpage__search-btn:hover {
	background-color: var(--rsgdxwiki-color-blue-hover);
}

/* Sections */
.rsgdxwiki-frontpage__section {
	padding: var(--rsgdxwiki-space-10) var(--rsgdxwiki-space-6);
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
	width: 100%;
}

.rsgdxwiki-frontpage__section + .rsgdxwiki-frontpage__section {
	border-top: 1px solid var(--rsgdxwiki-color-border);
}

.rsgdxwiki-frontpage__section-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--rsgdxwiki-space-6);
	flex-wrap: wrap;
	gap: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-frontpage__section-title {
	font-size: var(--rsgdxwiki-text-xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: 0;
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-3);
}

.rsgdxwiki-frontpage__section-title i {
	color: var(--rsgdxwiki-color-blue-light);
	font-size: var(--rsgdxwiki-text-lg);
}

.rsgdxwiki-frontpage__section-link {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-blue-light);
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
	transition: color var(--rsgdxwiki-transition);
}

.rsgdxwiki-frontpage__section-link:hover {
	color: var(--rsgdxwiki-color-text);
	text-decoration: none;
}

/* Stats */
.rsgdxwiki-stats-row {
	display: flex;
	gap: var(--rsgdxwiki-space-4);
	flex-wrap: wrap;
}

.rsgdxwiki-stat-card {
	flex: 1;
	min-width: 160px;
	background-color: var(--rsgdxwiki-color-surface);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-lg);
	padding: var(--rsgdxwiki-space-5) var(--rsgdxwiki-space-6);
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-stat-card__icon {
	width: 44px;
	height: 44px;
	border-radius: var(--rsgdxwiki-radius-md);
	background-color: var(--rsgdxwiki-color-blue-faint);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--rsgdxwiki-text-lg);
	color: var(--rsgdxwiki-color-blue-light);
	flex-shrink: 0;
}

.rsgdxwiki-stat-card__value {
	font-size: var(--rsgdxwiki-text-2xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	line-height: 1;
	margin-bottom: var(--rsgdxwiki-space-1);
}

.rsgdxwiki-stat-card__label {
	font-size: var(--rsgdxwiki-text-xs);
	color: var(--rsgdxwiki-color-text-muted);
	font-weight: 500;
}

/* ==========================================================================
   ARCHIVE
   ========================================================================== */

.rsgdxwiki-archive__header {
	padding: var(--rsgdxwiki-space-10) var(--rsgdxwiki-space-6) var(--rsgdxwiki-space-6);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
	background-color: var(--rsgdxwiki-color-surface);
}

.rsgdxwiki-archive__header-inner {
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
}

.rsgdxwiki-archive__eyebrow {
	font-size: var(--rsgdxwiki-text-xs);
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--rsgdxwiki-color-blue-light);
	margin-bottom: var(--rsgdxwiki-space-2);
}

.rsgdxwiki-archive__title {
	font-size: var(--rsgdxwiki-text-3xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: var(--rsgdxwiki-space-2);
}

.rsgdxwiki-archive__desc {
	font-size: var(--rsgdxwiki-text-md);
	color: var(--rsgdxwiki-color-text-muted);
	margin-bottom: 0;
}

.rsgdxwiki-archive__body {
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
	padding: var(--rsgdxwiki-space-8) var(--rsgdxwiki-space-6);
}

/* ==========================================================================
   SINGLE / PAGE
   ========================================================================== */

.rsgdxwiki-single__body {
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
	padding: var(--rsgdxwiki-space-8) var(--rsgdxwiki-space-6);
	display: flex;
	gap: var(--rsgdxwiki-space-10);
	align-items: flex-start;
	width: 100%;
}

.rsgdxwiki-single__content {
	flex: 1;
	min-width: 0;
}

.rsgdxwiki-single__toc {
	width: 240px;
	flex-shrink: 0;
	position: sticky;
	top: calc(var(--rsgdxwiki-header-height) + var(--rsgdxwiki-space-8));
}

/* ==========================================================================
   SEARCH
   ========================================================================== */

.rsgdxwiki-search__header {
	padding: var(--rsgdxwiki-space-10) var(--rsgdxwiki-space-6) var(--rsgdxwiki-space-6);
	border-bottom: 1px solid var(--rsgdxwiki-color-border);
	background-color: var(--rsgdxwiki-color-surface);
}

.rsgdxwiki-search__header-inner {
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
}

.rsgdxwiki-search__title {
	font-size: var(--rsgdxwiki-text-2xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-search__form {
	display: flex;
	align-items: center;
	background-color: var(--rsgdxwiki-color-bg);
	border: 1px solid var(--rsgdxwiki-color-border);
	border-radius: var(--rsgdxwiki-radius-md);
	overflow: hidden;
	max-width: 560px;
	transition: border-color var(--rsgdxwiki-transition);
}

.rsgdxwiki-search__form:focus-within {
	border-color: var(--rsgdxwiki-color-blue);
	box-shadow: 0 0 0 1px var(--rsgdxwiki-color-blue);
}

.rsgdxwiki-search__input {
	flex: 1;
	background: none;
	border: none;
	outline: none;
	padding: var(--rsgdxwiki-space-3) var(--rsgdxwiki-space-4);
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text);
	font-family: var(--rsgdxwiki-font-sans);
}

.rsgdxwiki-search__btn {
	background: var(--rsgdxwiki-color-blue);
	border: none;
	padding: var(--rsgdxwiki-space-3) var(--rsgdxwiki-space-4);
	color: var(--rsgdxwiki-color-text);
	cursor: pointer;
	font-size: var(--rsgdxwiki-text-sm);
	transition: background-color var(--rsgdxwiki-transition);
}

.rsgdxwiki-search__btn:hover {
	background-color: var(--rsgdxwiki-color-blue-hover);
}

.rsgdxwiki-search__body {
	max-width: var(--rsgdxwiki-max-width-wide);
	margin: 0 auto;
	padding: var(--rsgdxwiki-space-8) var(--rsgdxwiki-space-6);
}

.rsgdxwiki-search__count {
	font-size: var(--rsgdxwiki-text-sm);
	color: var(--rsgdxwiki-color-text-muted);
	margin-bottom: var(--rsgdxwiki-space-6);
}

/* ==========================================================================
   404
   ========================================================================== */

.rsgdxwiki-404 {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: var(--rsgdxwiki-space-20) var(--rsgdxwiki-space-6);
	min-height: calc(100vh - var(--rsgdxwiki-header-height) - 80px);
	width: 100%;
}

.rsgdxwiki-404__code {
	font-size: 120px;
	font-weight: 800;
	color: var(--rsgdxwiki-color-surface-high);
	line-height: 1;
	margin-bottom: var(--rsgdxwiki-space-4);
	letter-spacing: -4px;
}

.rsgdxwiki-404__title {
	font-size: var(--rsgdxwiki-text-2xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-404__desc {
	font-size: var(--rsgdxwiki-text-md);
	color: var(--rsgdxwiki-color-text-muted);
	max-width: 440px;
	margin-bottom: var(--rsgdxwiki-space-8);
	line-height: 1.7;
}

.rsgdxwiki-404__actions {
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-4);
	flex-wrap: wrap;
	justify-content: center;
}

/* ==========================================================================
   NO RESULTS
   ========================================================================== */

.rsgdxwiki-no-results {
	text-align: center;
	padding: var(--rsgdxwiki-space-16) var(--rsgdxwiki-space-6);
}

.rsgdxwiki-no-results__icon {
	font-size: 48px;
	color: var(--rsgdxwiki-color-surface-high);
	margin-bottom: var(--rsgdxwiki-space-4);
}

.rsgdxwiki-no-results__title {
	font-size: var(--rsgdxwiki-text-xl);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text);
	margin-bottom: var(--rsgdxwiki-space-3);
}

.rsgdxwiki-no-results__desc {
	font-size: var(--rsgdxwiki-text-base);
	color: var(--rsgdxwiki-color-text-muted);
	margin-bottom: var(--rsgdxwiki-space-6);
}

/* ==========================================================================
   UTILITIES
   ========================================================================== */

.rsgdxwiki-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;
}

.rsgdxwiki-text-muted    { color: var(--rsgdxwiki-color-text-muted); }
.rsgdxwiki-text-subtle   { color: var(--rsgdxwiki-color-text-subtle); }
.rsgdxwiki-text-blue     { color: var(--rsgdxwiki-color-blue-light); }
.rsgdxwiki-text-accent   { color: var(--rsgdxwiki-color-accent); }
.rsgdxwiki-text-sm       { font-size: var(--rsgdxwiki-text-sm); }
.rsgdxwiki-text-xs       { font-size: var(--rsgdxwiki-text-xs); }

.rsgdxwiki-flex            { display: flex; }
.rsgdxwiki-flex-col        { flex-direction: column; }
.rsgdxwiki-flex-wrap       { flex-wrap: wrap; }
.rsgdxwiki-items-center    { align-items: center; }
.rsgdxwiki-justify-between { justify-content: space-between; }
.rsgdxwiki-justify-center  { justify-content: center; }
.rsgdxwiki-gap-2           { gap: var(--rsgdxwiki-space-2); }
.rsgdxwiki-gap-4           { gap: var(--rsgdxwiki-space-4); }
.rsgdxwiki-hidden          { display: none; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

/* 4-col → 3-col at 1200px */
@media (max-width: 1200px) {
	.rsgdxwiki-card-grid--4 { grid-template-columns: repeat(3, 1fr); }
}

/* 3-col and 4-col → 2-col at 767px */
@media (max-width: 767px) {
	.rsgdxwiki-card-grid--3,
	.rsgdxwiki-card-grid--4 { grid-template-columns: repeat(2, 1fr); }

	.rsgdxwiki-site-search { display: none; }

	.rsgdxwiki-site-header__inner {
		padding: 0 var(--rsgdxwiki-space-4);
	}

	.rsgdxwiki-single__body {
		flex-direction: column;
	}

	.rsgdxwiki-single__toc {
		width: 100%;
		position: static;
	}

	.rsgdxwiki-frontpage__hero-title {
		font-size: var(--rsgdxwiki-text-3xl);
	}

	.rsgdxwiki-stats-row {
		flex-wrap: wrap;
	}

	.rsgdxwiki-stat-card {
		min-width: calc(50% - var(--rsgdxwiki-space-2));
	}

	.rsgdxwiki-site-footer__inner {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--rsgdxwiki-space-4);
	}
}

/* All → 1-col below 480px */
@media (max-width: 480px) {
	.rsgdxwiki-card-grid--2,
	.rsgdxwiki-card-grid--3,
	.rsgdxwiki-card-grid--4 { grid-template-columns: 1fr; }

	.rsgdxwiki-stat-card { min-width: 100%; }

	.rsgdxwiki-frontpage__hero-title {
		font-size: var(--rsgdxwiki-text-2xl);
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
	}
}

/* ==========================================================================
   FRONT PAGE — ONBOARDING CTA
   ========================================================================== */

.rsgdxwiki-frontpage__onboarding-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-3);
	margin-top: var(--rsgdxwiki-space-5);
	padding: var(--rsgdxwiki-space-2) var(--rsgdxwiki-space-4);
	background-color: var(--rsgdxwiki-color-blue-faint);
	border: 1px solid rgba(114, 174, 230, 0.2);
	border-radius: var(--rsgdxwiki-radius-full);
	flex-wrap: wrap;
	justify-content: center;
}

.rsgdxwiki-frontpage__onboarding-cta__label {
	display: flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
	font-size: var(--rsgdxwiki-text-xs);
	font-weight: 700;
	color: var(--rsgdxwiki-color-text-subtle);
	text-transform: uppercase;
	letter-spacing: 1px;
	white-space: nowrap;
}

.rsgdxwiki-frontpage__onboarding-cta__label i {
	color: var(--rsgdxwiki-color-accent);
	font-size: var(--rsgdxwiki-text-xs);
}

.rsgdxwiki-frontpage__onboarding-cta__link {
	display: inline-flex;
	align-items: center;
	gap: var(--rsgdxwiki-space-2);
	font-size: var(--rsgdxwiki-text-sm);
	font-weight: 600;
	color: var(--rsgdxwiki-color-blue-light);
	text-decoration: none;
	transition: color var(--rsgdxwiki-transition), gap var(--rsgdxwiki-transition);
}

.rsgdxwiki-frontpage__onboarding-cta__link:hover {
	color: var(--rsgdxwiki-color-text);
	gap: var(--rsgdxwiki-space-3);
	text-decoration: none;
}

.rsgdxwiki-frontpage__onboarding-cta__link i {
	font-size: var(--rsgdxwiki-text-xs);
	transition: transform var(--rsgdxwiki-transition);
}

.rsgdxwiki-frontpage__onboarding-cta__link:hover i {
	transform: translateX(3px);
}