/**
 * StarRO — Flat Modern White Theme
 * Minimal overrides for inherited Bootstrap views.
 */

body.theme-starro {
	background: #fff;
	color: #111827;
}

body.theme-starro .container {
	background: transparent;
}

/* flux.css sets h3 { text-transform: uppercase; border-bottom: dotted } — keep title case on policy sections */
body.theme-starro .rules-page section h3 {
	text-transform: none;
	border-bottom: none;
	letter-spacing: normal;
}

body.theme-starro .rules-page section h3:first-letter {
	font-weight: inherit;
}

/* Ranking pages (StarRO theme) — OSRO-style tables, no flux uppercase on headings */
body.theme-starro .starro-ranking {
	max-width: 72rem;
}

body.theme-starro .starro-ranking > header h2,
body.theme-starro .starro-ranking h2.starro-ranking__title {
	border-bottom: none;
	text-transform: none;
	letter-spacing: -0.02em;
}

body.theme-starro .starro-ranking .starro-ranking__subtitle {
	text-transform: none;
	border-bottom: none;
	font-weight: 400;
}

body.theme-starro .starro-ranking table.starro-ranking__table {
	width: 100%;
	border-collapse: collapse;
}

body.theme-starro .starro-ranking .starro-ranking__table thead th {
	text-transform: none;
	letter-spacing: normal;
	font-size: 0.7rem;
	font-weight: 600;
	color: #6b7280;
	border: 1px solid #e5e7eb;
}

body.theme-starro .starro-ranking .starro-ranking__table tbody td {
	border: 1px solid #e5e7eb;
	vertical-align: middle;
}

body.theme-starro .starro-ranking .starro-ranking__table tbody tr.top-ranked td {
	border-color: #c7d6f5;
}

body.theme-starro .starro-ranking .starro-ranking__table tbody tr.top-ranked {
	background: linear-gradient(90deg, rgba(65, 112, 232, 0.06), transparent);
}

body.theme-starro .starro-ranking .starro-ranking__table tbody tr.empty-row td {
	height: 2.25rem;
	border-color: #f3f4f6;
}

body.theme-starro .starro-ranking .starro-ranking__table a {
	font-weight: 600;
}

/* Item / monster database (StarRO theme) */
body.theme-starro .starro-db-page .search-form {
	display: block;
}

/* Item DB — primary search row: predictable grid so the name field always stretches */
body.theme-starro .starro-item-search-main {
	display: grid;
	gap: 0.75rem 1rem;
	align-items: end;
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 640px) {
	body.theme-starro .starro-item-search-main {
		grid-template-columns: minmax(9rem, 13rem) minmax(0, 1fr) auto;
	}
}

body.theme-starro .starro-item-search__name {
	min-width: 0;
}

body.theme-starro .starro-item-search-main .starro-item-search__name input[type='text'] {
	width: 100%;
	min-width: 0;
	box-sizing: border-box;
}

body.theme-starro .starro-item-search__actions {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: 0.5rem;
}

@media (max-width: 639px) {
	body.theme-starro .starro-item-search__actions {
		width: 100%;
	}

	body.theme-starro .starro-item-search__actions button[type='submit'] {
		flex: 1 1 auto;
		min-width: 0;
	}
}

body.theme-starro .starro-database__table a {
	font-weight: 600;
}

/* —— Modern database page shell —— */
body.theme-starro .starro-db-page .starro-db-hero {
	position: relative;
	overflow: hidden;
	border-radius: 1rem;
	border: 1px solid #e5e7eb;
	background: linear-gradient(135deg, #f0f5ff 0%, #ffffff 50%, #f8fafc 100%);
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

body.theme-starro .starro-db-page .starro-db-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 60% 80% at 100% 0%, rgba(45, 85, 212, 0.08) 0%, transparent 60%),
		radial-gradient(ellipse 50% 60% at 0% 100%, rgba(148, 163, 184, 0.08) 0%, transparent 50%);
	pointer-events: none;
}

body.theme-starro .starro-db-page .starro-db-hero-blob {
	position: absolute;
	border-radius: 9999px;
	filter: blur(48px);
	pointer-events: none;
	opacity: 0.3;
}

body.theme-starro .starro-db-page .starro-db-panel {
	border-radius: 0.75rem;
	border: 1px solid #e5e7eb;
	background: #ffffff;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

body.theme-starro .starro-db-page .starro-db-table-shell {
	border-radius: 1rem;
	border: 1px solid #e8ecf4;
	background: #fff;
	box-shadow:
		0 1px 3px rgba(15, 23, 42, 0.06),
		0 8px 24px -8px rgba(15, 23, 42, 0.1);
}

body.theme-starro .starro-db-page table.starro-database__table thead th {
	position: sticky;
	top: 0;
	z-index: 2;
	background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
	border-bottom: 1px solid #e2e8f0;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

body.theme-starro .starro-db-page table.starro-database__table tbody tr:nth-child(even) {
	background: rgba(248, 250, 252, 0.65);
}

body.theme-starro .starro-db-page table.starro-database__table tbody tr:hover {
	background: rgba(224, 231, 255, 0.45);
}

body.theme-starro .starro-db-page .starro-db-advanced > summary {
	list-style: none;
	cursor: pointer;
	user-select: none;
}

body.theme-starro .starro-db-page .starro-db-advanced > summary::-webkit-details-marker {
	display: none;
}

body.theme-starro .starro-db-page .starro-db-advanced > summary .starro-db-advanced-chevron {
	transition: transform 0.2s ease;
}

body.theme-starro .starro-db-page .starro-db-advanced[open] > summary .starro-db-advanced-chevron {
	transform: rotate(180deg);
}

body.theme-starro .starro-db-page .pagination {
	margin-top: 1.25rem;
}

body.theme-starro table.starro-database__detail-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.875rem;
}

body.theme-starro table.starro-database__detail-table tr > th,
body.theme-starro table.starro-database__detail-table thead tr > th {
	width: 1%;
	white-space: nowrap;
	padding: 0.65rem 0.85rem;
	text-align: left;
	font-weight: 600;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #64748b;
	background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
	border: 1px solid #e8ecf4;
	vertical-align: top;
}

body.theme-starro table.starro-database__detail-table tr > td {
	padding: 0.65rem 0.85rem;
	border: 1px solid #eef2f7;
	vertical-align: top;
	color: #334155;
}

body.theme-starro .starro-db-page .starro-db-detail-hero {
	position: relative;
	overflow: hidden;
	border-radius: 1rem;
	border: 1px solid #e5e7eb;
	background: linear-gradient(135deg, #f0f5ff 0%, #ffffff 50%, #f8fafc 100%);
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

body.theme-starro .starro-db-page .starro-db-detail-hero::after {
	content: '';
	position: absolute;
	right: -20%;
	top: -40%;
	width: 55%;
	height: 140%;
	background: radial-gradient(circle, rgba(45, 85, 212, 0.06) 0%, transparent 65%);
	pointer-events: none;
}

body.theme-starro table.starro-database__detail-table ul.monster-mode {
	margin: 0;
	padding-left: 1.1rem;
}

body.theme-starro table.starro-database__detail-table pre,
body.theme-starro table.starro-database__detail-table code {
	font-size: 0.75rem;
}

body.theme-starro .starro-database__sprite {
	display: inline-block;
	max-width: 120px;
	max-height: 120px;
	object-fit: contain;
}

body.theme-starro table.character-stats {
	margin: 0;
	border-radius: 0.75rem;
	overflow: hidden;
	background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
	border: 1px solid #e8ecf4;
}

body.theme-starro .starro-db-page table.character-stats td {
	padding: 0.5rem 0.75rem;
	border: none;
}

body.theme-starro .starro-db-page table.character-stats .stat-name {
	display: inline-block;
	min-width: 1.75rem;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	color: #64748b;
	text-transform: uppercase;
}

body.theme-starro .starro-db-page table.character-stats .stat-value {
	font-weight: 700;
	font-variant-numeric: tabular-nums;
	color: #1e293b;
}

body.theme-starro a {
	color: #2d55d4;
	text-decoration: none;
}

body.theme-starro a:hover {
	color: #2544ab;
}

/* Primary / outline CTAs use Tailwind text-* on <a>; global link color above wins over .text-white and hides labels on blue fills */
body.theme-starro a.bg-brand-600,
body.theme-starro a.bg-brand-600:hover {
	color: #ffffff;
}
body.theme-starro a.bg-white.text-gray-800,
body.theme-starro a.bg-white.text-gray-800:hover {
	color: #1f2937;
}
body.theme-starro a.bg-white.text-gray-700,
body.theme-starro a.bg-white.text-gray-700:hover {
	color: #374151;
}
body.theme-starro a.bg-white.text-brand-800,
body.theme-starro a.bg-white.text-brand-800:hover {
	color: #233a8a;
}
body.theme-starro a.bg-white\/10.text-white,
body.theme-starro a.bg-white\/10.text-white:hover {
	color: #ffffff;
}

/* ── Main nav (escapes global theme blue on default state; hover uses brand blue) ── */
body.theme-starro nav.starro-nav a.starro-nav__brand {
	color: #111827;
}
body.theme-starro nav.starro-nav a.starro-nav__brand:hover {
	color: #2d55d4;
}

body.theme-starro nav.starro-nav a.starro-nav__link {
	color: #6b7280;
	transition: color 0.2s ease, background-color 0.2s ease;
}

body.theme-starro nav.starro-nav a.starro-nav__link:hover {
	color: #2d55d4;
	background: rgba(65, 112, 232, 0.08);
}

/* ============================================================
   Nav dropdown — minimal & elegant
   ============================================================ */
body.theme-starro nav.starro-nav .starro-nav__trigger-caret {
	opacity: 0.45;
	transition: transform 0.2s ease, opacity 0.2s ease;
}
body.theme-starro nav.starro-nav .starro-nav__trigger:hover .starro-nav__trigger-caret,
body.theme-starro nav.starro-nav .starro-nav__trigger-caret.is-open {
	opacity: 0.85;
}
body.theme-starro nav.starro-nav .starro-nav__trigger-caret.is-open {
	transform: rotate(180deg);
}

body.theme-starro nav.starro-nav .starro-nav__dd {
	margin-top: 0.5rem;
	min-width: 12rem;
	max-width: 18rem;
	padding: 0.3125rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.06);
	border-radius: 0.875rem;
	box-shadow:
		0 1px 2px rgba(15, 23, 42, 0.04),
		0 12px 32px -14px rgba(15, 23, 42, 0.18);
	backdrop-filter: saturate(1.1);
}

body.theme-starro nav.starro-nav .starro-nav__dd::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: -0.5rem;
	height: 0.5rem;
}

body.theme-starro nav.starro-nav a.starro-nav__dd-link {
	display: block;
	padding: 0.5rem 0.75rem;
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.25;
	color: #475569;
	white-space: nowrap;
	border-radius: 0.5rem;
	transition: color 0.15s ease, background-color 0.15s ease;
}

body.theme-starro nav.starro-nav a.starro-nav__dd-link + a.starro-nav__dd-link {
	margin-top: 1px;
}

body.theme-starro nav.starro-nav a.starro-nav__dd-link:hover {
	color: #0f172a;
	background: #f1f5f9;
}

/* ============================================================
   Themed date picker — used on the register modal birthdate
   ============================================================ */
.starro-datefield .date-field {
	display: flex;
	align-items: stretch;
	gap: 0.4rem;
	font-size: 0;
}

.starro-datefield .date-field > select {
	flex: 1 1 0;
	min-width: 0;
	width: 100%;
	box-sizing: border-box;
	padding: 0.875rem 1.75rem 0.875rem 1rem;
	border: 1px solid #e5e7eb;
	border-radius: 0.75rem;
	background-color: #ffffff;
	background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.6rem center;
	background-size: 14px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	color: #0f172a;
	font-size: 1rem;
	font-family: inherit;
	line-height: 1.5;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
	cursor: pointer;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.starro-datefield select:hover {
	border-color: #c7d2fe;
}

.starro-datefield select:focus {
	outline: none;
	border-color: #2d55d4;
	box-shadow: 0 0 0 3px rgba(45, 85, 212, 0.12);
}

body.theme-starro nav.starro-nav button.starro-nav__trigger {
	color: #6b7280;
	transition: color 0.2s ease;
}

body.theme-starro nav.starro-nav button.starro-nav__trigger:hover {
	color: #2d55d4;
}

body.theme-starro nav.starro-nav a.starro-nav__icon {
	color: #6b7280;
	transition: color 0.2s ease, background-color 0.2s ease;
}

body.theme-starro nav.starro-nav a.starro-nav__icon:hover {
	color: #2d55d4;
	background: rgba(65, 112, 232, 0.08);
}

body.theme-starro nav.starro-nav a.starro-nav__icon::after {
	display: none;
}

body.theme-starro nav.starro-nav a.starro-nav__mob-acct {
	color: #374151;
	transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

body.theme-starro nav.starro-nav a.starro-nav__mob-acct:hover {
	color: #2d55d4;
}

body.theme-starro nav.starro-nav a.starro-nav__mob-acct::after {
	display: none;
}

/* Gradient underline (brand blues only) */
body.theme-starro nav.starro-nav .starro-nav__link,
body.theme-starro nav.starro-nav .starro-nav__trigger {
	position: relative;
}

body.theme-starro nav.starro-nav .starro-nav__link::after,
body.theme-starro nav.starro-nav .starro-nav__trigger::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 6px;
	height: 2px;
	border-radius: 1px;
	background: linear-gradient(90deg, #93b4fd 0%, #6690f4 45%, #4170e8 72%, #2d55d4 100%);
	opacity: 0;
	transform: scaleX(0.35);
	transform-origin: left center;
	transition: opacity 0.2s ease, transform 0.22s ease;
	pointer-events: none;
}

body.theme-starro nav.starro-nav .starro-nav__link:hover::after,
body.theme-starro nav.starro-nav .starro-nav__trigger:hover::after {
	opacity: 1;
	transform: scaleX(1);
}

body.theme-starro nav.starro-nav a.starro-nav__dd-link::after {
	display: none;
}

/* ============================================================
   Player menu — minimal & elegant (matches nav dropdown)
   ============================================================ */
body.theme-starro nav.starro-nav .starro-nav__player-menu-trigger {
	color: #334155;
	border-color: rgba(15, 23, 42, 0.08) !important;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
	transition: color 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
}
body.theme-starro nav.starro-nav .starro-nav__player-menu-trigger:hover {
	color: #0f172a;
	border-color: rgba(15, 23, 42, 0.16) !important;
	background: #f8fafc;
}
body.theme-starro nav.starro-nav .starro-nav__player-menu-trigger::after,
body.theme-starro nav.starro-nav .starro-nav__player-menu-trigger-mob.starro-nav__trigger::after {
	display: none;
}
body.theme-starro nav.starro-nav .starro-nav__player-menu-trigger-mob.starro-nav__trigger {
	color: #334155;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-panel {
	overflow: visible;
	margin-top: 0.5rem;
	padding: 0.3125rem !important;
	border: 1px solid rgba(15, 23, 42, 0.06) !important;
	border-radius: 0.875rem !important;
	background: #ffffff;
	box-shadow:
		0 1px 2px rgba(15, 23, 42, 0.04),
		0 12px 32px -14px rgba(15, 23, 42, 0.18) !important;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-panel::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: -0.5rem;
	height: 0.5rem;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	padding: 0.5rem 0.625rem !important;
	margin: 0 !important;
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.25;
	color: #475569;
	border-radius: 0.5rem !important;
	transition: color 0.15s ease, background-color 0.15s ease;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-link + .starro-nav__player-menu-link,
body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout-wrap + .starro-nav__player-menu-flyout-wrap,
body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout-wrap + .starro-nav__player-menu-link,
body.theme-starro nav.starro-nav .starro-nav__player-menu-link + .starro-nav__player-menu-flyout-wrap {
	margin-top: 1px !important;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-link:hover {
	color: #0f172a;
	background: #f1f5f9;
}

body.theme-starro nav.starro-nav a.starro-nav__player-menu-link.is-current {
	color: #0f172a;
	background: #e2e8f0;
	font-weight: 600;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-chevron {
	width: 0.625rem;
	height: 0.625rem;
	flex: 0 0 0.625rem;
	color: #94a3b8;
	transition: color 0.15s ease;
}
body.theme-starro nav.starro-nav .starro-nav__player-menu-link:hover .starro-nav__player-menu-chevron {
	color: #475569;
}

body.theme-starro nav.starro-nav button.starro-nav__player-menu-toggle {
	font: inherit;
	border: none;
	background: transparent;
	cursor: pointer;
	text-align: left;
	width: 100%;
}
body.theme-starro nav.starro-nav button.starro-nav__player-menu-toggle:focus-visible {
	outline: 2px solid rgba(15, 23, 42, 0.18);
	outline-offset: 2px;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-divider {
	border-top: 1px solid rgba(15, 23, 42, 0.06);
	margin: 0.3125rem 0.25rem !important;
}

/* Nested submenu flyout */
body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout-wrap {
	position: relative;
	z-index: 1;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout {
	position: absolute;
	left: 100%;
	top: -0.3125rem;
	margin-left: 0.5rem;
	min-width: 12rem;
	max-width: min(14rem, calc(100vw - 2rem - 14rem));
	z-index: 130;
	padding: 0.3125rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.06);
	border-radius: 0.875rem;
	box-shadow:
		0 1px 2px rgba(15, 23, 42, 0.04),
		0 12px 32px -14px rgba(15, 23, 42, 0.18);
	max-height: min(70vh, 22rem);
	overflow-y: auto;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout::before {
	content: '';
	position: absolute;
	left: -0.5rem;
	top: 0;
	bottom: 0;
	width: 0.5rem;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout .starro-nav__player-menu-link--nested {
	justify-content: flex-start;
	font-size: 0.78125rem;
	padding: 0.4375rem 0.625rem !important;
	margin: 0 !important;
	border-radius: 0.5rem !important;
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout .starro-nav__player-menu-link--nested + .starro-nav__player-menu-link--nested {
	margin-top: 1px !important;
}

/* Mobile: stack the flyout below the parent row instead of flying right */
@media (max-width: 767.98px) {
	body.theme-starro nav.starro-nav .starro-nav__player-menu-flyout {
		position: static;
		left: auto;
		top: auto;
		margin-left: 0;
		margin-top: 0.3125rem;
		min-width: 0;
		max-width: none;
		width: 100%;
		padding: 0.25rem 0 0.25rem 0.5rem;
		border: none;
		border-left: 1px solid rgba(15, 23, 42, 0.08);
		border-radius: 0;
		box-shadow: none;
	}
}

body.theme-starro nav.starro-nav .starro-nav__player-menu-panel > .starro-nav__player-menu-group-label:first-child {
	padding-top: 0.2rem;
}

/* ── Panels ── */
body.theme-starro .panel {
	background: #fff;
	border: 1px solid #f0f0f0;
	border-radius: 0.5rem;
	box-shadow: none;
}

body.theme-starro .panel-default > .panel-heading {
	background: #fafafa;
	border-color: #f0f0f0;
	border-radius: 0.5rem 0.5rem 0 0;
	color: #111827;
	font-weight: 600;
}

/* ── Tables ── */
body.theme-starro .table > thead > tr > th {
	border-color: #f0f0f0;
	color: #9ca3af;
	font-weight: 500;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

body.theme-starro .table > tbody > tr > td {
	border-color: #f5f5f5;
}

body.theme-starro .table-striped > tbody > tr:nth-of-type(odd) {
	background-color: #fafafa;
}

/* ── Forms ── */
body.theme-starro .form-control {
	background: #fafafa;
	border: 1px solid #e5e5e5;
	border-radius: 0.5rem;
	color: #111827;
	padding: 0.5rem 0.75rem;
	box-shadow: none;
	transition: border-color 0.15s;
}

body.theme-starro .form-control:focus {
	border-color: #2d55d4;
	box-shadow: none;
	outline: none;
	background: #fff;
}

/* ── Buttons ── */
body.theme-starro .btn-primary {
	background: #2d55d4;
	border-color: #2d55d4;
	border-radius: 0.5rem;
	font-weight: 500;
	box-shadow: none;
}

body.theme-starro .btn-primary:hover {
	background: #2544ab;
	border-color: #2544ab;
}

/* ── Footer ── */
body.theme-starro #footer {
	background: #fff;
	border-top: 1px solid #f0f0f0;
}

body.theme-starro #footer .text-muted {
	color: #9ca3af !important;
}

/* ── Messages ── */
body.theme-starro .message,
body.theme-starro .notice {
	background: #f0f5ff;
	border: none;
	color: #2544ab;
	padding: 12px 16px;
	border-radius: 0.5rem;
	font-size: 0.875rem;
}

/* ── Pagination ── */
body.theme-starro .pagination > li > a,
body.theme-starro .pagination > li > span {
	border-color: #f0f0f0;
	color: #2d55d4;
	border-radius: 0.375rem;
	margin: 0 1px;
	box-shadow: none;
}

body.theme-starro .pagination > .active > a,
body.theme-starro .pagination > .active > span {
	background: #2d55d4;
	border-color: #2d55d4;
}

/* ── Downloads page (StarRO) — override flux heading styles ── */
body.theme-starro .starro-downloads-light h2,
body.theme-starro .starro-downloads-light h3 {
	text-transform: none;
	border-bottom: none;
	letter-spacing: -0.02em;
	font-weight: inherit;
}

body.theme-starro .starro-downloads-light h2 {
	font-weight: 900;
}

body.theme-starro .starro-downloads-light h3 {
	font-weight: 600;
}

/* ── Server events (themes/StarRO/events/index.php) ── */
body.theme-starro .starro-events h2.starro-events__title,
body.theme-starro .starro-events p.starro-events__subtitle {
	text-transform: none;
	border-bottom: none;
	letter-spacing: -0.02em;
}

body.theme-starro .starro-events p.starro-events__subtitle {
	letter-spacing: normal;
}

/* ── Referral addon (StarRO theme views: addons/referral/themes/StarRO/) ── */
body.theme-starro .starro-referral h2.starro-referral__title,
body.theme-starro .starro-referral h3.starro-referral__section-title {
	text-transform: none;
	border-bottom: none;
	letter-spacing: -0.02em;
}

body.theme-starro .starro-referral .starro-referral__subtitle {
	text-transform: none;
	border-bottom: none;
}

body.theme-starro .starro-referral table.starro-referral__table thead th {
	text-transform: none;
	letter-spacing: normal;
	font-size: 0.7rem;
	font-weight: 600;
	color: #6b7280;
	vertical-align: middle;
	border: 1px solid #e5e7eb;
}

body.theme-starro .starro-referral table.starro-referral__table thead th a {
	color: #4b5563;
	font-weight: 600;
	text-decoration: none;
}

body.theme-starro .starro-referral table.starro-referral__table thead th a:hover {
	color: #2d55d4;
}

body.theme-starro .starro-referral table.starro-referral__table tbody td {
	border: 1px solid #f3f4f6;
	vertical-align: middle;
}

body.theme-starro .starro-referral details.starro-referral__search > summary {
	list-style: none;
}

body.theme-starro .starro-referral details.starro-referral__search > summary::-webkit-details-marker {
	display: none;
}

/* ── Marketplace addon — submodule nav (themes/StarRO/main/submenu.php) ── */
body.theme-starro .starro-mp-subnav {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin: 0 0 1.25rem;
	padding: 0.75rem 1rem;
	background: #f8fafc;
	border: 1px solid #e5e7eb;
	border-radius: 0.75rem;
}

body.theme-starro .starro-mp-subnav__section {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	flex-wrap: wrap;
}

body.theme-starro .starro-mp-subnav__section--admin {
	padding-top: 0.65rem;
	border-top: 1px dashed #e2e8f0;
}

body.theme-starro .starro-mp-subnav__label {
	flex-shrink: 0;
	min-width: 3.25rem;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #6b7280;
}

body.theme-starro .starro-mp-subnav__section--admin .starro-mp-subnav__label {
	color: #b45309;
}

body.theme-starro .starro-mp-subnav__list {
	flex: 1 1 0;
	min-width: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
	gap: 0.4rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

body.theme-starro .starro-mp-subnav__list > li {
	display: flex;
	min-width: 0;
}

body.theme-starro .starro-mp-subnav__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-width: 0;
	padding: 0.45rem 0.75rem;
	font-size: 0.8125rem;
	font-weight: 500;
	text-align: center;
	color: #4b5563;
	text-decoration: none;
	border: 1px solid #e5e7eb;
	border-radius: 0.625rem;
	background: #fff;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

body.theme-starro .starro-mp-subnav__link:hover {
	color: #2563eb;
	border-color: #bfdbfe;
	background: #eff6ff;
}

body.theme-starro .starro-mp-subnav__link.is-current {
	color: #fff;
	background: #2563eb;
	border-color: #2563eb;
	font-weight: 600;
}

body.theme-starro .starro-mp-subnav__section--admin .starro-mp-subnav__link.is-current {
	background: #d97706;
	border-color: #d97706;
}

body.theme-starro .starro-mp-subnav__section--admin .starro-mp-subnav__link:hover {
	color: #b45309;
	border-color: #fcd34d;
	background: #fffbeb;
}

@media (max-width: 767.98px) {
	body.theme-starro .starro-mp-subnav__section {
		flex-direction: column;
		align-items: stretch;
		gap: 0.4rem;
	}
	body.theme-starro .starro-mp-subnav__list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ── Topup addon — submodule nav (themes/StarRO/main/submenu.php) ── */
body.theme-starro .starro-topup-subnav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.65rem 1rem;
	margin: 0 0 1.25rem;
	padding: 0.65rem 1rem;
	background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
	border: 1px solid #e5e7eb;
	border-radius: 0.75rem;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

body.theme-starro .starro-topup-subnav__label {
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #6b7280;
	flex-shrink: 0;
}

body.theme-starro .starro-topup-subnav__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

body.theme-starro .starro-topup-subnav__link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.4rem 0.85rem;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #4b5563;
	text-decoration: none;
	border: 1px solid #e5e7eb;
	border-radius: 999px;
	background: #fff;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

body.theme-starro .starro-topup-subnav__link .bi {
	font-size: 0.95rem;
	opacity: 0.85;
}

body.theme-starro .starro-topup-subnav__link:hover {
	color: #2d55d4;
	border-color: #93b4fd;
	background: #eff6ff;
	box-shadow: 0 1px 3px rgba(45, 85, 212, 0.12);
}

body.theme-starro .starro-topup-subnav__link.is-current {
	color: #fff;
	background: #2d55d4;
	border-color: #2d55d4;
	font-weight: 600;
	box-shadow: 0 2px 8px rgba(45, 85, 212, 0.28);
}

body.theme-starro .starro-topup-subnav__link.is-current .bi {
	opacity: 1;
}

body.theme-starro .mp-wallet-shell__title {
	text-transform: none;
	border-bottom: none;
	letter-spacing: -0.03em;
	font-size: 1.2rem;
	font-weight: 800;
}

body.theme-starro .mp-wallet-shell__hint {
	text-transform: none;
	border-bottom: none;
}

/* ── Rankings hub (themes/StarRO/rankings/) — tabs + paginator + WoE table ── */
body.theme-starro .starro-rankings__tab:focus-visible {
	outline: 2px solid #2563eb;
	outline-offset: -2px;
}

body.theme-starro .starro-rankings__pages .pages {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.25rem 0.35rem;
	font-size: 0.875rem;
}

body.theme-starro .starro-rankings__pages .page-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.25rem;
	padding: 0.35rem 0.6rem;
	color: #374151;
	text-decoration: none;
	border-radius: 0.375rem;
	border: 1px solid #e5e7eb;
	background: #fff;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

body.theme-starro .starro-rankings__pages .page-num:hover:not(.current-page) {
	background: #f3f4f6;
	border-color: #d1d5db;
	color: #111827;
}

body.theme-starro .starro-rankings__pages .page-num.current-page {
	color: #fff;
	font-weight: 600;
	background: #2563eb;
	border-color: #2563eb;
	cursor: default;
}

body.theme-starro .starro-rankings__pages .page-prev,
body.theme-starro .starro-rankings__pages .page-next {
	color: #2563eb;
	text-decoration: none;
	font-weight: 500;
	padding: 0.35rem 0.5rem;
	border-radius: 0.375rem;
}

body.theme-starro .starro-rankings__pages .page-prev:hover,
body.theme-starro .starro-rankings__pages .page-next:hover {
	background: #eff6ff;
	text-decoration: none;
}

body.theme-starro .starro-rankings-woe__table thead a.sortable {
	color: #4b5563;
	font-weight: 600;
	text-decoration: none;
}

body.theme-starro .starro-rankings-woe__table thead a.sortable:hover {
	color: #2563eb;
}

/* ── Submodule nav — default branch (themes/StarRO/main/submenu.php) ── */
body.theme-starro .starro-subnav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.65rem 1rem;
	margin: 0 0 1.25rem;
	padding: 0.7rem 1.05rem;
	background: linear-gradient(145deg, #fdfcfa 0%, #f4f6fb 45%, #f0f4ff 100%);
	border: 1px solid #e8e0d4;
	border-radius: 0.75rem;
	box-shadow: 0 1px 3px rgba(45, 85, 212, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

body.theme-starro .starro-subnav__label {
	font-size: 0.65rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #78716c;
	flex-shrink: 0;
}

body.theme-starro .starro-subnav__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

body.theme-starro .starro-subnav__link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.4rem 0.85rem;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #44403c;
	text-decoration: none;
	border: 1px solid #e7e5e4;
	border-radius: 999px;
	background: #fff;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

body.theme-starro .starro-subnav__link .bi {
	font-size: 0.95rem;
	opacity: 0.88;
	color: #57534e;
}

body.theme-starro .starro-subnav__link:hover {
	color: #1e3a5f;
	border-color: #93b4fd;
	background: linear-gradient(180deg, #fff 0%, #eff6ff 100%);
	box-shadow: 0 1px 4px rgba(45, 85, 212, 0.12);
}

body.theme-starro .starro-subnav__link:hover .bi {
	color: #2d55d4;
	opacity: 1;
}

body.theme-starro .starro-subnav__link.is-current {
	color: #fff;
	background: linear-gradient(180deg, #3d6ae0 0%, #2d55d4 100%);
	border-color: #2544ab;
	font-weight: 600;
	box-shadow: 0 2px 10px rgba(45, 85, 212, 0.35);
}

body.theme-starro .starro-subnav__link.is-current .bi {
	color: #fff;
	opacity: 1;
}

/* ── Page-level actions (themes/StarRO/main/pagemenu.php) ── */
body.theme-starro .starro-pagemenu {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.55rem 0.9rem;
	margin: 0 0 1.5rem;
	padding: 0.55rem 0.95rem;
	background: rgba(255, 251, 245, 0.9);
	border: 1px solid #e8e0d4;
	border-radius: 0.65rem;
	border-left: 3px solid #d4a574;
}

body.theme-starro .starro-pagemenu__label {
	font-size: 0.75rem;
	font-weight: 700;
	color: #78716c;
	flex-shrink: 0;
}

body.theme-starro .starro-pagemenu__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

body.theme-starro .starro-pagemenu__link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.35rem 0.75rem;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #1e3a5f;
	text-decoration: none;
	border: 1px solid #c7d2f0;
	border-radius: 0.5rem;
	background: linear-gradient(180deg, #fff 0%, #f0f5ff 100%);
	transition: border-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
}

body.theme-starro .starro-pagemenu__link .bi {
	font-size: 0.9rem;
	opacity: 0.9;
}

body.theme-starro .starro-pagemenu__link:hover {
	color: #2d55d4;
	border-color: #2d55d4;
	box-shadow: 0 2px 8px rgba(45, 85, 212, 0.18);
}

/* ── Account list (admin search + sortable columns) ── */
body.theme-starro .starro-account-index-table thead th {
	vertical-align: bottom;
}

body.theme-starro .starro-account-index-table thead th a.sortable {
	color: inherit;
	font-weight: 700;
	text-decoration: none;
}

body.theme-starro .starro-account-index-table thead th a.sortable:hover {
	color: #2d55d4;
	text-decoration: underline;
}

body.theme-starro .starro-account-index__dates select,
body.theme-starro .starro-account-index__dates input[type='text'] {
	margin: 0.2rem 0.35rem 0.2rem 0;
	border-radius: 0.375rem;
	border: 1px solid #e5e7eb;
	padding: 0.25rem 0.4rem;
	font-size: 0.8125rem;
	background: #fff;
}

body.theme-starro .starro-account-index__dates select:focus,
body.theme-starro .starro-account-index__dates input[type='text']:focus {
	outline: none;
	border-color: #2d55d4;
	box-shadow: 0 0 0 2px rgba(45, 85, 212, 0.2);
}

/* ── Service desk (module builds <tr> rows; tables use .starro-sd-table) ── */
body.theme-starro .starro-sd-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
}

body.theme-starro .starro-sd-table > tbody > tr:first-child th {
	text-align: left;
	padding: 0.75rem 1rem;
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #6b7280;
	background: linear-gradient(90deg, #f9fafb, rgba(240, 245, 255, 0.6));
	border-bottom: 1px solid #e5e7eb;
	white-space: nowrap;
}

body.theme-starro .starro-sd-table > tbody > tr:not(:first-child) td {
	padding: 0.65rem 1rem;
	vertical-align: middle;
	border-bottom: 1px solid #f3f4f6;
	color: #374151;
	font-size: 0.8125rem;
}

body.theme-starro .starro-sd-table > tbody > tr:not(:first-child):hover td {
	background: rgba(240, 245, 255, 0.35);
}

body.theme-starro .starro-sd-table a {
	font-weight: 600;
	color: #2d55d4;
	text-decoration: none;
}

body.theme-starro .starro-sd-table a:hover {
	text-decoration: underline;
	color: #2544ab;
}

body.theme-starro .starro-sd-table font strong {
	font-weight: 700;
}

/* ── Alpine cloak ── */
[x-cloak] { display: none !important; }

/* ── Modal auth iframe (navbar) — height set via postMessage from embed page ── */
.starro-auth-iframe {
	display: block;
	width: 100%;
	border: 0;
	vertical-align: top;
}

/* ── Embed layout (login/register inside modal iframe) ── */
body.starro-embed {
	min-height: auto;
	margin: 0;
}
body.starro-embed .starro-embed-inner {
	width: 100%;
}
