/**
 * Shinra Theme – Dark forest at night (almost black-green)
 * Exact tokens: bg-deep, bg-main, bg-panel, border-dim, border-mid
 */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
:root {
	--bg-deep:        #020a02;
	--bg-main:        #060e06;
	--bg-panel:       rgba(8, 20, 8, 0.85);
	--bg-panel-solid: #0a1a0a;
	--border-dim:     #1a3a1a;
	--border-mid:     #2a522a;

	--shinra-bg: var(--bg-deep);
	--shinra-glow: #00ff44;
	--shinra-glow-alt: #39ff14;
	--shinra-panel: var(--bg-panel-solid);
	--shinra-panel-border: var(--border-dim);
	--shinra-text: #e8f0e8;
	--shinra-gold: #d4a017;
	--shinra-gold-alt: #c8962a;
	--shinra-panel-rgba: var(--bg-panel);
}

/* ---- Bootstrap Overrides (Klassen die in index genutzt werden) ---- */
.bg-dark {
	background-color: var(--shinra-panel) !important;
}
.bg-darker {
	background-color: var(--shinra-panel-rgba) !important;
}

/* ---- Body & Hauptbereich ---- */
body {
	margin: 0;
	padding: 0;
	background-color: #020a02;
	background-image:
		radial-gradient(ellipse 70% 50% at 15% 50%, rgba(20,80,20,0.45) 0%, transparent 60%),
		radial-gradient(ellipse 50% 70% at 85% 40%, rgba(10,50,10,0.50) 0%, transparent 55%),
		radial-gradient(ellipse 100% 100% at 50% 50%, #040d04 0%, #020602 100%);
	color: var(--shinra-text) !important;
}

#mainbox {
	background: transparent !important;
}

/* ═══ OPEN LAYOUT – Main content area (no outer box, content on dark bg) ═══ */
.page {
	max-width: 1300px;
	margin: 0 auto;
	padding: 24px 20px 60px;
	background: transparent;
}
.grid {
	display: grid;
	grid-template-columns: 340px 1fr 240px;
	gap: 14px;
	align-items: start;
}
.page .content-inner {
	background: transparent;
	border: none;
	padding: 0;
}

/* Panels: semi-transparent, subtle borders */
.box {
	background: rgba(5, 12, 5, 0.75);
	border: 1px solid rgba(26, 58, 26, 0.6);
	margin-bottom: 10px;
	backdrop-filter: blur(2px);
}
.box:last-child { margin-bottom: 0; }
.box.gt { border-top: 2px solid rgba(212, 160, 23, 0.6); }
.box.gg { border-top: 2px solid rgba(0, 204, 51, 0.4); }

.box-head {
	background: rgba(0, 0, 0, 0.25);
	border-bottom: 1px solid rgba(26, 58, 26, 0.5);
	padding: 6px 11px;
	display: flex;
	align-items: center;
}
.box-head-title {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	color: var(--shinra-gold);
	opacity: 0.95;
}
.box-head-sub {
	font-size: 10px;
	color: var(--text-muted);
	letter-spacing: 1px;
	margin-left: auto;
}
.box-body { padding: 12px 12px; font-size: 13px; }
.box-body form { margin: 0; padding: 0; }

/* Login form (open layout) */
.field-label {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--text-muted);
	margin-bottom: 4px;
	display: block;
}
.field-input {
	width: 100%;
	background: rgba(3, 8, 3, 0.8);
	border: 1px solid rgba(42, 82, 42, 0.6);
	color: var(--shinra-text);
	padding: 7px 10px;
	font-family: 'Rajdhani', sans-serif;
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 8px;
	outline: none;
	transition: border-color .2s, box-shadow .2s;
}
.field-input:focus {
	border-color: rgba(0, 204, 51, 0.5);
	box-shadow: 0 0 8px rgba(0, 204, 51, 0.1);
}
.field-input::placeholder { color: var(--text-muted); }
.rem-row {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: var(--text-secondary);
	margin-bottom: 10px;
	letter-spacing: .5px;
	margin-left: 0;
	padding-left: 0;
}
.rem-row input[type="checkbox"] {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	accent-color: var(--green-bright);
	cursor: pointer;
}
.rem-row label {
	cursor: pointer;
	margin: 0;
}
.rem-row input { accent-color: var(--green-bright); }

/* reCAPTCHA: Standard (länglich), Keys aus config.php – unter Remember, über Login */
.g-recaptcha {
    margin: 0 0 10px 0;
    max-width: 100%;
}
/* User-Panel: reCAPTCHA kleiner, perfekt mittig */
.box.gt .box-body .form-group:has(> .g-recaptcha) {
    overflow: hidden;
    margin-bottom: 10px;
    display: flex;
    justify-content: center;
}
.box.gt .box-body .g-recaptcha {
    transform: scale(0.88);
    transform-origin: center top;
    margin-left: auto;
    margin-right: auto;
    display: block;
}
.box.gt .box-body .g-recaptcha iframe {
    margin-left: 0 !important;
}
.box.gt .box-body {
    overflow: visible;
}
.box.gt .box-body .form-group .g-recaptcha {
    overflow: visible;
}

.page .login-btn {
	width: 100%;
	background: transparent;
	border: 1px solid rgba(42, 82, 42, 0.7);
	color: var(--text-secondary);
	padding: 8px;
	font-family: 'Rajdhani', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	cursor: pointer;
	transition: all .2s;
}
.page .login-btn:hover {
	border-color: var(--green-bright);
	color: var(--green-bright);
	box-shadow: 0 0 10px rgba(0, 204, 51, 0.1);
}
.login-links {
	display: flex;
	justify-content: space-between;
	padding: 7px 11px;
	border-top: 1px solid rgba(26, 58, 26, 0.4);
	background: rgba(0, 0, 0, 0.15);
}
.login-links a {
	font-size: 10px !important;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--text-muted) !important;
}
.login-links a:hover { color: var(--green-bright) !important; }
.box-body-links { display: flex; flex-direction: column; gap: 8px; }
.box-body-links a {
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.03em;
	color: var(--shinra-glow-alt) !important;
	text-decoration: none !important;
	padding: 6px 10px;
	border-radius: 4px;
	transition: color 0.2s, background 0.2s;
}
.box-body-links a:hover { color: var(--green-bright) !important; background: rgba(0, 204, 51, 0.08); }
.box-body-links a.buy-coins-gold {
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%) !important;
	color: #1a1a0a !important;
	border: 1px solid rgba(212, 160, 23, 0.8);
	text-align: center;
	text-shadow: 0 1px 0 rgba(255,255,255,0.3);
}
.box-body-links a.buy-coins-gold:hover {
	background: linear-gradient(180deg, var(--shinra-gold) 0%, #e8b830 100%) !important;
	color: #0d0d00 !important;
	box-shadow: 0 0 12px rgba(212, 160, 23, 0.4);
}
.box-body-links a.list-group-item-danger {
	background: rgba(120, 40, 40, 0.7) !important;
	color: #ffe0e0 !important;
	border: 1px solid rgba(200, 80, 80, 0.5);
	text-align: center;
}
.box-body-links a.list-group-item-danger:hover {
	background: rgba(140, 50, 50, 0.85) !important;
	color: #fff !important;
}

/* Rank rows */
.rank-row, .guild-row {
	display: flex;
	align-items: center;
	gap: 7px;
	padding: 5px 0;
	border-bottom: 1px solid rgba(26, 58, 26, 0.3);
	font-size: 12px;
	font-weight: 600;
}
.rank-row:last-child, .guild-row:last-child { border-bottom: none; }
.rpos, .gpos {
	width: 18px;
	text-align: center;
	font-size: 11px;
	color: var(--text-muted);
	flex-shrink: 0;
}
.rpos.g, .gpos.g { color: var(--shinra-gold); font-size: 14px; }
.rpos.s, .gpos.s { color: #a0a0a0; font-size: 14px; }
.rpos.b, .gpos.b { color: #a06030; font-size: 14px; }
.rname, .gname { flex: 1; color: var(--shinra-text); font-size: 12px; }
.rlvl { color: var(--text-secondary); font-size: 11px; }
.rcls { font-size: 11px; font-weight: 700; }
.rank-more {
	display: block;
	text-align: center;
	padding: 7px;
	border-top: 1px solid rgba(26, 58, 26, 0.4);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--text-muted) !important;
	background: rgba(0, 0, 0, 0.15);
	transition: color .2s;
	text-decoration: none !important;
}
.rank-more:hover { color: var(--green-bright) !important; }

/* Hero (center) */
.hero {
	position: relative;
	background: rgba(4, 10, 4, 0.6);
	border: 1px solid rgba(26, 58, 26, 0.5);
	border-top: 1px solid rgba(212, 160, 23, 0.2);
	overflow: hidden;
	margin-bottom: 10px;
	min-height: 185px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}
.hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle 160px at 10% 50%, rgba(20, 60, 20, 0.3) 0%, transparent 70%),
		radial-gradient(circle 160px at 90% 50%, rgba(20, 60, 20, 0.25) 0%, transparent 70%),
		radial-gradient(ellipse 60% 40% at 50% 100%, rgba(212, 160, 23, 0.06) 0%, transparent 70%);
	pointer-events: none;
}
.hero::after {
	content: '';
	position: absolute;
	top: 6px; left: 6px; right: 6px; bottom: 6px;
	border: 1px solid rgba(212, 160, 23, 0.08);
	pointer-events: none;
}
.hero-inner { position: relative; z-index: 2; padding: 28px 20px; }
.hero-inner .btn-g { display: inline-flex !important; }
.hero-eyebrow {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 4px;
	text-transform: uppercase;
	color: var(--green-bright);
	opacity: 0.7;
	margin-bottom: 10px;
}
.hero-title {
	font-family: 'Cinzel', serif;
	font-size: clamp(20px, 2.5vw, 30px);
	font-weight: 700;
	color: var(--shinra-gold);
	text-shadow: 0 0 24px rgba(212, 160, 23, 0.4), 0 2px 4px rgba(0, 0, 0, 0.8);
	letter-spacing: 5px;
	margin-bottom: 8px;
}
.hero-sub {
	font-size: 12px;
	letter-spacing: 2px;
	color: var(--text-secondary);
	margin-bottom: 18px;
}
.hero-btns {
	display: flex;
	gap: 14px;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.btn-g {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 22px;
	min-height: 40px;
	font-family: 'Rajdhani', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	text-decoration: none !important;
	transition: all .2s;
	cursor: pointer;
	white-space: nowrap;
	box-sizing: border-box;
}
/* Gold-Button: globale .gold aus style.css (Ranking-Icon) hier aufheben */
.btn-g.gold {
	background-image: none !important;
	width: auto !important;
	min-width: 0;
	height: auto !important;
	min-height: 40px;
	display: inline-flex !important;
	margin-left: 0 !important;
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%);
	border: 1px solid var(--shinra-gold);
	color: #fff !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
	box-shadow: 0 0 12px rgba(212, 160, 23, 0.25);
}
.btn-g.gold:hover { filter: brightness(1.15); box-shadow: 0 0 20px rgba(212, 160, 23, 0.45); }
.btn-g.ghost {
	background: transparent;
	border: 1px solid rgba(42, 82, 42, 0.6);
	color: var(--text-secondary) !important;
}
.btn-g.ghost:hover { border-color: var(--green-bright); color: var(--shinra-text) !important; }

/* Hero: Register-Button gut sichtbar (Gold-Rand + heller Text) */
.hero-btns .btn-g.ghost {
	background: rgba(212, 160, 23, 0.12);
	border: 2px solid var(--shinra-gold);
	color: #fff !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
	box-shadow: 0 0 14px rgba(212, 160, 23, 0.2);
}
.hero-btns .btn-g.ghost:hover {
	background: rgba(212, 160, 23, 0.25);
	border-color: #e8b830;
	color: #fff !important;
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.4);
}

/* Action buttons (right column) */
.act-btn {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 11px 13px;
	background: rgba(5, 12, 5, 0.6);
	border: 1px solid rgba(26, 58, 26, 0.5);
	margin-bottom: 5px;
	cursor: pointer;
	transition: all .2s;
	text-decoration: none !important;
	color: inherit;
}
.act-btn:hover {
	border-color: rgba(212, 160, 23, 0.4);
	background: rgba(15, 30, 15, 0.7);
	box-shadow: 0 0 12px rgba(212, 160, 23, 0.08);
	color: var(--shinra-text);
}
.act-btn:last-of-type { margin-bottom: 0; }
.act-label {
	font-family: 'Cinzel', serif;
	font-size: 12px;
	color: var(--shinra-gold);
	letter-spacing: 2px;
	text-shadow: 0 0 8px rgba(212, 160, 23, 0.25);
}
.act-sub {
	display: block;
	font-size: 10px;
	color: var(--text-muted);
	letter-spacing: 1px;
	margin-top: 1px;
	font-family: 'Rajdhani', sans-serif;
}
.act-icon { font-size: 18px; opacity: 0.5; }

.sep {
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(42, 82, 42, 0.4), transparent);
	margin: 8px 0;
}

/* Server status / statistics rows */
.stat-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 6px 0;
	border-bottom: 1px solid rgba(26, 58, 26, 0.3);
	font-size: 12px;
}
.stat-row:last-child { border-bottom: none; }
.skey { color: var(--text-secondary); letter-spacing: 1px; font-weight: 600; }
.sval { color: var(--shinra-text); font-weight: 700; }
.sval.on { color: var(--green-bright); text-shadow: 0 0 6px rgba(0, 204, 51, 0.35); }

/* Events */
.event-item {
	display: flex;
	align-items: flex-start;
	gap: 6px;
	padding: 7px 0;
	border-bottom: 1px solid rgba(26, 58, 26, 0.3);
	font-size: 12px;
}
.event-item:last-child { border-bottom: none; }
.event-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: var(--green-bright);
	flex-shrink: 0;
	margin-top: 3px;
	margin-left: 0;
	box-shadow: 0 0 6px rgba(0, 204, 51, 0.4);
	/* Globale .gold aus style.css (Ranking-Icon) nicht anwenden */
	background-image: none !important;
	min-width: 7px;
}
.event-dot.gold {
	background: var(--shinra-gold) !important;
	background-image: none !important;
	width: 7px !important;
	height: 7px !important;
	box-shadow: 0 0 6px rgba(212, 160, 23, 0.4);
}
.event-name { font-weight: 700; color: var(--shinra-text); display: block; margin-bottom: 1px; }
.event-time { font-size: 10px; color: var(--text-muted); letter-spacing: .5px; display: block; }
.events-empty {
	padding: 14px 0;
	text-align: center;
	font-size: 11px;
	color: var(--text-muted);
	letter-spacing: 1px;
}

/* ---- SHINRA HEADER (Topbar + Navbar) ---- */
header {
	margin-top: 0;
	padding-top: 0;
}
.navbar {
	margin-top: 0;
	padding-top: 0;
}
:root {
	--bg-topbar:    #010701;
	--bg-nav:       #030e03;
	--border-glow:  #2d6b2d;
	--green-bright: #00cc33;
	--gold:         #d4a820;
	--gold-light:   #f5d060;
	--text-primary: #e8f0e8;
	--text-secondary: #8aab8a;
	--text-muted:   #4a6e4a;
}

.topbar.shinra-topbar {
	margin-top: 0;
	background: var(--bg-topbar);
	border-bottom: 1px solid var(--border-dim);
	height: 34px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 32px;
	position: relative;
	z-index: 100;
}
.topbar.shinra-topbar::after {
	content: '';
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(
		0deg, transparent, transparent 2px,
		rgba(57,255,20,0.012) 2px, rgba(57,255,20,0.012) 4px
	);
	pointer-events: none;
}
.topbar-left, .topbar-right { display: flex; align-items: center; }
.topbar-left a {
	font-family: 'Rajdhani', sans-serif;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--text-secondary);
	text-decoration: none;
	padding: 0 14px;
	height: 34px;
	display: flex;
	align-items: center;
	position: relative;
	transition: color 0.2s;
}
.topbar-left a::before {
	content: '';
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 1px;
	background: var(--green-bright);
	transform: scaleX(0);
	transition: transform 0.2s;
}
.topbar-left a:hover { color: var(--green-bright); }
.topbar-left a:hover::before { transform: scaleX(1); }
.topbar-sep { color: var(--border-glow); font-size: 12px; opacity: 0.6; }

.lang-selector-wrap .lang-selector {
	display: flex;
	align-items: center;
	gap: 7px;
	font-family: 'Rajdhani', sans-serif;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1.5px;
	color: var(--text-secondary);
	background: none;
	border: 1px solid transparent;
	padding: 4px 10px;
	cursor: pointer;
	transition: all 0.2s;
}
.lang-selector-wrap .lang-selector:hover { border-color: var(--border-glow); color: var(--text-primary); }
.lang-selector .flag-img { display: block; }
.lang-selector .arrow { font-size: 9px; color: var(--text-muted); margin-left: 2px; }
.lang-selector-wrap .dropdown-menu-lang {
	background: var(--bg-panel-solid);
	border: 1px solid var(--border-mid);
	border-top: 1px solid var(--green-bright);
	box-shadow: 0 8px 32px rgba(0,0,0,0.8);
}
.lang-selector-wrap .dropdown-item { color: var(--shinra-text) !important; }
.lang-selector-wrap .dropdown-item:hover { background: rgba(57,255,20,0.08); color: var(--shinra-glow) !important; }

/* Navbar */
.navbar.shinra-navbar {
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 0;
	background: var(--bg-nav);
	border-bottom: 1px solid var(--border-dim);
	position: relative;
	z-index: 99;
	overflow: visible;
	box-shadow: inset 0 1px 0 rgba(57,255,20,0.04), 0 4px 24px rgba(0,0,0,0.7);
}
.navbar.shinra-navbar::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg,
		transparent 0%, rgba(212,168,32,0.3) 20%,
		rgba(212,168,32,0.6) 50%, rgba(212,168,32,0.3) 80%, transparent 100%
	);
}
.navbar-inner {
	display: flex;
	align-items: stretch;
	justify-content: center;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 32px;
	position: relative;
	overflow: visible;
}
.nav-group {
	display: flex;
	align-items: stretch;
	overflow: visible;
}
.nav-group.left { margin-right: 60px; }
.nav-group.right { margin-left: 60px; }

.navbar.shinra-navbar .nav-link {
	display: flex;
	align-items: center;
	padding: 0 20px;
	height: 54px;
	font-family: 'Rajdhani', sans-serif;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	color: #8aab8a;
	text-decoration: none;
	position: relative;
	transition: color 0.2s;
	white-space: nowrap;
	overflow: visible;
	border-left: 1px solid var(--border-dim);
	text-shadow: none;
	filter: none;
}
.navbar.shinra-navbar .nav-link::before {
	display: none !important;
	content: none !important;
}
/* Nur der allererste Link (NEWS) ohne linken Strich; Presentation behält Strich nach Download */
.nav-group.left > a:first-child { border-left: none; }
.nav-group.right > a:last-child { border-right: 1px solid var(--border-dim); }
.navbar.shinra-navbar .nav-link::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 10px;
	right: 10px;
	height: 2px;
	background: #00cc33;
	transform: scaleX(0);
	transition: transform 0.2s ease;
	transform-origin: center;
}
.navbar.shinra-navbar .nav-link:hover {
	color: #e8f0e8;
	background: none;
}
.navbar.shinra-navbar .nav-link:hover::after { transform: scaleX(1); }
.navbar.shinra-navbar .nav-link.active { color: #00cc33; }
.navbar.shinra-navbar .nav-link.active::after {
	transform: scaleX(1);
	background: #00cc33;
	bottom: 0;
}
.navbar.shinra-navbar .nav-link.gold { color: #d4a820; }
.navbar.shinra-navbar .nav-link.gold:hover { color: #e8f0e8; }
.navbar.shinra-navbar .nav-link.gold::after {
	background: #d4a820;
}

.has-dropdown { position: relative; }
.has-dropdown .nav-dropdown {
	position: absolute;
	top: 100%; left: 0;
	min-width: 180px;
	background: #040f04;
	border: 1px solid var(--border-mid);
	border-top: 1px solid var(--green-bright);
	box-shadow: 0 8px 32px rgba(0,0,0,0.8), 0 0 20px rgba(57,255,20,0.05);
	opacity: 0;
	pointer-events: none;
	transform: translateY(-4px);
	transition: opacity 0.2s, transform 0.2s;
	z-index: 200;
}
.has-dropdown:hover .nav-dropdown {
	opacity: 1;
	pointer-events: all;
	transform: translateY(0);
}
.has-dropdown .nav-dropdown a {
	display: block;
	padding: 10px 18px;
	font-family: 'Rajdhani', sans-serif;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--text-secondary);
	text-decoration: none;
	border-bottom: 1px solid var(--border-dim);
	transition: all 0.15s;
}
.has-dropdown .nav-dropdown a:last-child { border-bottom: none; }
.has-dropdown .nav-dropdown a:hover { color: var(--green-bright); background: rgba(57,255,20,0.04); padding-left: 24px; }

.navbar.shinra-navbar.scrolled { background: rgba(3,14,3,0.97); backdrop-filter: blur(10px); }

/* Legacy (falls noch wo genutzt) */
.navbar-dark .navbar-nav { border-bottom-color: var(--shinra-panel-border) !important; }
.navbar-dark .navbar-toggler { border-color: var(--shinra-panel-border); }

/* ---- Logo: Shinra SVG (zentriert, Cinzel/Rajdhani) ---- */
.shinra-logo-link {
	display: inline-block;
	text-decoration: none !important;
	outline: none;
}
.shinra-logo {
	position: relative;
	filter: drop-shadow(0 0 24px rgba(212, 168, 32, 0.35))
	        drop-shadow(0 0 48px rgba(57, 255, 20, 0.12));
	transition: filter 0.25s ease;
}
.shinra-logo-link:hover .shinra-logo {
	filter: drop-shadow(0 0 28px rgba(212, 168, 32, 0.5))
	        drop-shadow(0 0 56px rgba(57, 255, 20, 0.18));
}
.logo-svg {
	width: clamp(340px, 60vw, 580px);
	height: auto;
	display: block;
	margin: 0 auto;
}

/* ---- Sidebars & Content ---- */
.sidebar.bg-dark,
.content.bg-darker {
	background: var(--shinra-panel-rgba) !important;
	border: 1px solid var(--shinra-panel-border);
	box-shadow: 0 0 30px rgba(0, 0, 0, 0.4), inset 0 0 60px rgba(0, 255, 68, 0.02);
}
.content {
	border-left: 1px solid var(--shinra-panel-border) !important;
}
.wrapper {
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.5), 0 0 40px rgba(0, 255, 68, 0.04);
}

/* ---- Sidebar Action Buttons (Download, Discord, Forum – Shinra-Farben, ohne PNG) ---- */
.sidebar-action-buttons {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-bottom: 1rem;
}
.sidebar-action-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 1rem 1.25rem;
	background: var(--bg-panel-solid);
	border: 1px solid var(--border-dim);
	border-radius: 6px;
	text-decoration: none !important;
	color: var(--shinra-text) !important;
	transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.sidebar-action-btn-title {
	text-align: center;
	font-weight: 700;
	font-size: 1.1rem;
	color: var(--shinra-gold) !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	text-shadow: 0 0 12px rgba(212, 160, 23, 0.35);
}
.sidebar-action-btn:hover {
	border-color: var(--shinra-gold);
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.2), inset 0 0 30px rgba(0, 255, 68, 0.03);
	background: rgba(26, 58, 26, 0.6);
	color: var(--shinra-text) !important;
}
.sidebar-action-btn-icon {
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(26, 58, 26, 0.8);
	border: 1px solid var(--border-dim);
	border-radius: 6px;
	color: var(--shinra-gold);
	font-size: 1.25rem;
	flex-shrink: 0;
	transition: color 0.2s, border-color 0.2s, box-shadow 0.2s;
}
.sidebar-action-btn:hover .sidebar-action-btn-icon {
	color: var(--shinra-glow-alt);
	border-color: var(--shinra-glow-alt);
	box-shadow: 0 0 12px rgba(57, 255, 20, 0.3);
}

/* ---- Cards (Panels) ---- */
.card {
	background: var(--shinra-panel-rgba) !important;
	background-image: none !important;
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
	box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
}
.card-header {
	background: rgba(26, 58, 26, 0.5) !important;
	border-bottom: 1px solid var(--shinra-panel-border);
	color: var(--shinra-text) !important;
}
.card-body,
.card-title {
	color: var(--shinra-text) !important;
}

/* ---- Content-Grid: neue Anordnung + Panel-Design ---- */
.shinra-content-grid.wrapper {
	gap: 0;
	box-shadow: 0 0 24px rgba(0, 0, 0, 0.45), 0 0 48px rgba(0, 255, 68, 0.03);
}
.shinra-content-grid .sidebar {
	padding: 1.25rem 1rem;
}
.shinra-content-grid .sidebar-left {
	border-right: 1px solid var(--shinra-panel-border);
}
.shinra-content-grid .sidebar-right {
	border-left: 1px solid var(--shinra-panel-border);
}
.shinra-content-grid .content {
	padding: 1.5rem 1.75rem;
}

/* Neue Panels: linker Gold-Akzent, abgerundet, klare Köpfe */
.card.shinra-panel {
	background: rgba(8, 22, 8, 0.92) !important;
	border: 1px solid var(--border-dim);
	border-left: 4px solid var(--shinra-gold);
	border-radius: 10px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(57, 255, 20, 0.04);
	overflow: hidden;
}
.card.shinra-panel .card-header.shinra-panel-head {
	background: rgba(15, 35, 15, 0.85) !important;
	border-bottom: 1px solid var(--border-dim);
	padding: 0.65rem 1rem;
	min-height: auto;
}
.card.shinra-panel .shinra-panel-label {
	font-family: 'Rajdhani', sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--shinra-gold);
	opacity: 0.95;
}
.card.shinra-panel .card-body {
	padding: 1rem 1.1rem;
}
.card.shinra-panel .shinra-panel-title {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--shinra-text) !important;
	margin-bottom: 0.75rem;
	border-bottom: 1px solid var(--border-dim);
	padding-bottom: 0.5rem;
}
.card.shinra-panel .card-footer.bg-transparent {
	padding-top: 0.25rem;
}

/* Kompakte Tabellen in Panels */
.table-compact td,
.table-compact th {
	padding: 0.4rem 0.5rem;
	font-size: 0.9rem;
}
.table-compact .gold,
.table-compact .silver,
.table-compact .bronze {
	width: 1.8rem;
	text-align: center;
}

/* Buttons in Content-Grid */
.shinra-btn,
.shinra-content-grid .login-btn,
.shinra-content-grid .custom-btn {
	display: inline-block;
	padding: 0.5rem 1.25rem;
	border-radius: 8px;
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-decoration: none !important;
	transition: box-shadow 0.2s, filter 0.2s;
}
.shinra-content-grid .login-btn {
	margin-left: 0;
	width: 100%;
	max-width: 200px;
	text-align: center;
}

/* Hero in Mitte: etwas reduzierter */
.content-hero.shinra-hero {
	min-height: 120px;
	border-radius: 10px;
	box-shadow: inset 0 0 50px rgba(0, 255, 68, 0.03), 0 4px 18px rgba(0, 0, 0, 0.25);
}
.content-hero.shinra-hero .content-hero-title {
	font-size: 1.35rem;
}

/* Flache List-Groups in Panels */
.list-group-flat .list-group-item {
	border-left: 0;
	border-right: 0;
	border-color: var(--border-dim);
	border-radius: 0;
}
.list-group-events .list-group-item {
	padding: 0.5rem 0.25rem;
}

/* ---- Typografie (Font-Special) ---- */
.font-special-red {
	color: var(--shinra-gold) !important;
	background-image: none !important;
	-webkit-text-fill-color: var(--shinra-gold);
	text-shadow: 0 0 12px rgba(212, 160, 23, 0.4);
}
.font-special-light-gray {
	color: var(--shinra-text) !important;
	-webkit-text-fill-color: var(--shinra-text);
	background-image: none !important;
	opacity: 0.95;
}

/* ---- Tabellen ---- */
.table {
	color: var(--shinra-text);
	border-color: var(--shinra-panel-border);
}
.table td,
.table th {
	border-color: var(--shinra-panel-border);
}
.table-striped tbody tr:nth-of-type(odd) {
	background-color: rgba(13, 31, 13, 0.6);
}
.table-striped tbody tr:hover {
	background-color: rgba(26, 58, 26, 0.5);
}
.table-dark {
	background-color: transparent;
	color: var(--shinra-text);
}

/* ---- Buttons ---- */
.login-btn,
.custom-btn {
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%) !important;
	background-image: none !important;
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold) !important;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
	box-shadow: 0 0 15px rgba(212, 160, 23, 0.4);
}
.login-btn:hover,
.custom-btn:hover {
	filter: brightness(1.15);
	box-shadow: 0 0 25px rgba(212, 160, 23, 0.6);
	color: var(--shinra-text) !important;
}
.big-btn {
	filter: none;
}
.btn-hover:hover img {
	filter: drop-shadow(0 0 8px var(--shinra-glow));
}

/* ---- Links ---- */
a {
	color: var(--shinra-glow-alt) !important;
}
a:hover {
	color: var(--shinra-glow) !important;
	text-shadow: 0 0 8px rgba(57, 255, 20, 0.4);
}

/* ---- Formulare ---- */
.form-control {
	background: rgba(10, 26, 10, 0.9) !important;
	border: 1px solid var(--shinra-panel-border);
	color: var(--shinra-text) !important;
}
.form-control::placeholder {
	color: rgba(232, 240, 232, 0.5);
}
.form-control:focus {
	border-color: var(--shinra-glow);
	box-shadow: 0 0 12px rgba(57, 255, 20, 0.25);
}
label {
	color: var(--shinra-text) !important;
}
.custom-control-label {
	color: var(--shinra-text) !important;
}

/* ---- List Group (User-Panel, Links) ---- */
.list-group-item {
	background: rgba(13, 31, 13, 0.8) !important;
	border-color: var(--shinra-panel-border) !important;
	color: var(--shinra-text) !important;
}
.list-group-item:hover {
	background: rgba(26, 58, 26, 0.6) !important;
	border-color: var(--shinra-glow-alt);
	box-shadow: 0 0 12px rgba(57, 255, 20, 0.1);
}
.list-group-item-action:focus {
	background: rgba(26, 58, 26, 0.8);
	color: var(--shinra-text);
}
.list-group-item.list-group-item-danger {
	background: rgba(58, 26, 26, 0.6) !important;
	border-color: #3a1a1a;
}
.list-group-item.list-group-item-danger:hover {
	background: rgba(80, 40, 40, 0.7) !important;
}
.list-group-item.active {
	background: rgba(26, 58, 26, 0.9) !important;
	border-color: var(--shinra-gold);
	color: var(--shinra-gold) !important;
}

/* ---- Buy Coins Button (Gold) ---- */
.buy-coins-gold {
	background: var(--shinra-gold) !important;
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold-alt) !important;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.buy-coins-gold:hover {
	background: var(--shinra-gold-alt) !important;
	color: var(--shinra-text) !important;
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.5);
}

/* ---- Ranking (Gold/Silver/Bronze) ---- */
.gold {
	color: var(--shinra-gold) !important;
	text-shadow: 0 0 10px rgba(212, 160, 23, 0.5);
}
.silver {
	color: #c0c0c0;
	text-shadow: 0 0 8px rgba(192, 192, 192, 0.3);
}
.bronze {
	color: #cd7f32;
	text-shadow: 0 0 8px rgba(205, 127, 50, 0.3);
}
.jinno { color: #5eb8ff; }
.chunjo { color: var(--shinra-gold-alt); }
.shinsoo { color: #e85a5a; }

/* ---- Social / Topbar Icon ---- */
a.social_link {
	background-color: var(--shinra-panel) !important;
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-panel-border);
}
a.social_link:hover {
	background-color: var(--shinra-panel-border) !important;
	color: var(--shinra-glow) !important;
	box-shadow: 0 0 12px rgba(57, 255, 20, 0.3);
}

/* ---- Dropdown ---- */
.dropdown-menu {
	background: var(--shinra-panel) !important;
	border: 1px solid var(--shinra-panel-border);
}
.dropdown-item {
	color: var(--shinra-text) !important;
}
.dropdown-item:hover {
	background: rgba(26, 58, 26, 0.8);
	color: var(--shinra-glow) !important;
}
.btn-link {
	color: var(--shinra-text) !important;
}
.btn-link:hover {
	color: var(--shinra-gold) !important;
}

/* ---- Pagination ---- */
.pagination > li > a,
.pagination > li > span {
	background-color: var(--shinra-panel) !important;
	border-color: var(--shinra-panel-border) !important;
	color: var(--shinra-text) !important;
}
.pagination > li > a:hover,
.pagination > li > span:hover {
	background-color: var(--shinra-panel-border) !important;
	color: var(--shinra-glow) !important;
}
.pagination > .active > a,
.pagination > .active > span {
	background-color: var(--shinra-gold) !important;
	border-color: var(--shinra-gold) !important;
	color: var(--shinra-text) !important;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.pagination > .disabled > span,
.pagination > .disabled > a {
	background-color: rgba(13, 31, 13, 0.5) !important;
	color: rgba(232, 240, 232, 0.5) !important;
}

/* ---- Tags/Badges ---- */
.tag {
	background: var(--shinra-panel-border);
	color: var(--shinra-glow);
	border: 1px solid var(--shinra-glow-alt);
}

/* ---- Footer (volle Breite bis zum Rand) ---- */
footer.site-footer {
	width: 100%;
	max-width: none;
	box-sizing: border-box;
	background: var(--shinra-panel) !important;
	border-top: 1px solid var(--shinra-panel-border);
	padding: 0.6rem 0 0.5rem !important;
	padding-bottom: 0.5rem !important;
	margin-top: 1rem !important;
	min-height: 0 !important;
	height: auto !important;
	box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.2);
}
footer.site-footer,
footer.site-footer a {
	color: var(--shinra-text) !important;
}
footer.site-footer a:hover {
	color: var(--shinra-gold) !important;
	text-decoration: none;
}
.footer-partners {
	text-align: center;
	margin-bottom: 0.35rem;
}
.footer-partners-label {
	display: inline-block;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: rgba(232, 240, 232, 0.6);
	margin-right: 0.5rem;
	margin-bottom: 0;
	vertical-align: middle;
}
.footer-links {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 0.15rem 0.35rem;
	font-size: 0.8rem;
	vertical-align: middle;
}
.footer-links a {
	white-space: nowrap;
	padding: 0.1em 0.25em;
	border-radius: 3px;
	transition: color 0.2s, background 0.2s;
}
.footer-links a:hover {
	background: rgba(212, 160, 23, 0.1);
}
.footer-links img {
	vertical-align: middle;
	margin-right: 0.2em;
	opacity: 0.9;
	width: 14px;
	height: 14px;
}
.footer-sep {
	color: var(--shinra-panel-border);
	user-select: none;
	font-weight: 700;
	font-size: 0.7rem;
}
.footer-copy {
	text-align: center;
	font-size: 0.75rem;
	color: rgba(232, 240, 232, 0.75);
	border-top: 1px solid var(--shinra-panel-border);
	padding-top: 0.4rem;
	margin-top: 0.4rem;
}
.footer-copy a {
	color: var(--shinra-gold) !important;
}
.footer-copy a:hover {
	color: var(--shinra-glow) !important;
}
.footer-link {
	color: var(--shinra-text) !important;
}
.footer-link:hover {
	color: var(--shinra-glow) !important;
}
.blue-c {
	color: var(--shinra-gold) !important;
}

/* ═══ Admin Dashboard (eigene Seite, WOW-Effekt) ═══ */
.admin-dashboard {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	background: linear-gradient(180deg, #020a02 0%, #041004 50%, #020a02 100%);
	box-shadow: inset 0 0 120px rgba(0, 255, 68, 0.03);
}
.admin-dashboard-header {
	background: rgba(4, 14, 4, 0.98);
	border-bottom: 1px solid rgba(212, 160, 23, 0.25);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.5), 0 0 40px rgba(57, 255, 20, 0.04);
	position: sticky;
	top: 0;
	z-index: 100;
}
.admin-dashboard-header-inner {
	max-width: 1600px;
	margin: 0 auto;
	padding: 0.75rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.admin-dashboard-logo {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none !important;
	color: var(--shinra-text) !important;
	transition: color 0.2s, text-shadow 0.2s;
}
.admin-dashboard-logo:hover { color: var(--shinra-gold) !important; text-shadow: 0 0 20px rgba(212, 160, 23, 0.4); }
.admin-dashboard-logo-icon {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(212, 160, 23, 0.2) 0%, rgba(0, 204, 51, 0.1) 100%);
	border: 1px solid rgba(212, 160, 23, 0.4);
	border-radius: 10px;
	font-size: 1.25rem;
	color: var(--shinra-gold);
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.15);
}
.admin-dashboard-logo-text {
	font-family: 'Cinzel', serif;
	font-size: 1.35rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.admin-dashboard-nav {
	display: flex;
	align-items: center;
	gap: 1.25rem;
}
.admin-dashboard-nav a {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--text-secondary) !important;
	text-decoration: none !important;
	transition: color 0.2s;
}
.admin-dashboard-nav a:hover { color: var(--green-bright) !important; }
.admin-dashboard-logout:hover { color: #e85a5a !important; }

.admin-dashboard-body {
	display: flex;
	flex: 1;
	max-width: 1600px;
	margin: 0 auto;
	width: 100%;
}

.admin-dashboard-sidebar {
	width: 260px;
	flex-shrink: 0;
	background: rgba(5, 18, 5, 0.9);
	border-right: 1px solid rgba(26, 58, 26, 0.6);
	padding: 1.25rem 0;
	box-shadow: 4px 0 24px rgba(0, 0, 0, 0.3);
}
.admin-dashboard-sidebar-nav {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.admin-dash-group-label {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--shinra-gold);
	opacity: 0.85;
	padding: 1rem 1.25rem 0.35rem;
	margin-top: 0.5rem;
	border-top: 1px solid rgba(26, 58, 26, 0.5);
}
.admin-dash-group-label:first-child { border-top: none; margin-top: 0; padding-top: 0; }
.admin-dash-link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.65rem 1.25rem;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--text-secondary) !important;
	text-decoration: none !important;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
	border-left: 3px solid transparent;
}
.admin-dash-link:hover {
	background: rgba(26, 58, 26, 0.4);
	color: var(--shinra-text) !important;
	border-left-color: var(--green-bright);
}
.admin-dash-link.active {
	background: rgba(0, 204, 51, 0.08);
	color: var(--shinra-gold) !important;
	border-left-color: var(--shinra-gold);
	box-shadow: inset 0 0 20px rgba(212, 160, 23, 0.06);
}
.admin-dash-link i {
	width: 1.25rem;
	text-align: center;
	opacity: 0.9;
}

.admin-dashboard-main {
	flex: 1;
	min-width: 0;
	padding: 1.5rem 2rem 3rem;
	overflow-auto;
}
.admin-dashboard-content {
	animation: adminFadeIn 0.35s ease;
}
@keyframes adminFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}

.admin-panel-wrap {
	max-width: 100%;
	padding: 0;
}
.admin-panel-head {
	background: linear-gradient(135deg, rgba(10, 26, 10, 0.95) 0%, rgba(6, 14, 6, 0.98) 100%);
	border: 1px solid rgba(26, 58, 26, 0.6);
	border-radius: 12px;
	margin-bottom: 1.5rem;
	padding: 1rem 1.5rem;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(57, 255, 20, 0.06);
}
.admin-panel-title {
	font-family: 'Cinzel', serif;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--shinra-gold);
	margin: 0;
	letter-spacing: 0.05em;
	text-shadow: 0 0 24px rgba(212, 160, 23, 0.3);
}
.admin-panel-body {
	background: rgba(8, 22, 8, 0.85);
	border: 1px solid rgba(26, 58, 26, 0.5);
	border-radius: 12px;
	padding: 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}
.admin-home-welcome {
	text-align: center;
	padding: 2rem 1.5rem;
}
.admin-home-welcome-text {
	font-size: 1.1rem;
	color: var(--shinra-text);
	margin-bottom: 0.75rem;
}
.admin-home-welcome-hint {
	font-size: 0.95rem;
	color: var(--text-secondary);
	margin: 0;
}

/* ---- Admin: Itemshop Redeem Stats Dashboard ---- */
.admin-redeem-stats {
	max-width: 1200px;
	margin: 0 auto;
	color: var(--shinra-text);
}
.redeem-stats-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1.5rem;
	flex-wrap: wrap;
	gap: 0.75rem;
}
.redeem-stats-title {
	font-family: 'Cinzel', serif;
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--shinra-gold);
	margin: 0;
	letter-spacing: 0.04em;
}
.redeem-stats-live {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--shinra-glow-alt);
	background: rgba(57, 255, 20, 0.12);
	border: 1px solid rgba(57, 255, 20, 0.35);
	padding: 0.35rem 0.75rem;
	border-radius: 6px;
}
.redeem-stats-kpis {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1rem;
	margin-bottom: 1.75rem;
}
.redeem-kpi-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	text-align: center;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.redeem-kpi-value {
	font-size: 2rem;
	font-weight: 800;
	color: var(--shinra-gold);
	line-height: 1.2;
	margin-bottom: 0.25rem;
	text-shadow: 0 0 20px rgba(212, 160, 23, 0.25);
}
.redeem-kpi-label {
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--shinra-text);
}
.redeem-kpi-sublabel {
	font-size: 0.8rem;
	color: var(--text-secondary);
	margin-top: 0.2rem;
}
.redeem-stats-charts {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	margin-bottom: 1.75rem;
}
@media (max-width: 900px) {
	.redeem-stats-charts { grid-template-columns: 1fr; }
}
.redeem-chart-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.redeem-chart-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--shinra-text);
	margin: 0 0 0.75rem 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.redeem-chart-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
	font-size: 0.8rem;
}
.redeem-legend-item.low { color: #36a2eb; }
.redeem-legend-item.mid { color: #4bc0c0; }
.redeem-legend-item.top { color: #ff9f40; }
.redeem-chart-wrap {
	position: relative;
	min-height: 200px;
}
.redeem-chart-donut-wrap { max-width: 260px; margin: 0 auto; }
.redeem-donut-legend {
	margin-top: 0.75rem;
	font-size: 0.85rem;
	color: var(--text-secondary);
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	justify-content: center;
}
.redeem-donut-legend-item {
	display: inline-block;
}
.redeem-stats-leaderboard-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	margin-bottom: 1.75rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.redeem-leaderboard-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1rem;
}
.redeem-leaderboard-title {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--shinra-text);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.redeem-leaderboard-sort {
	font-size: 0.8rem;
	color: var(--text-secondary);
}
.redeem-leaderboard-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.redeem-leaderboard-row {
	display: grid;
	grid-template-columns: 40px 44px 1fr auto 120px 100px;
	align-items: center;
	gap: 0.75rem;
	padding: 0.6rem 0;
	border-bottom: 1px solid rgba(26, 58, 26, 0.5);
	font-size: 0.9rem;
}
@media (max-width: 640px) {
	.redeem-leaderboard-list { overflow-x: auto; }
	.redeem-leaderboard-row {
		grid-template-columns: 36px 36px minmax(80px, 1fr) auto 80px 75px;
		min-width: 420px;
	}
}
.redeem-leaderboard-row:last-child { border-bottom: none; }
.redeem-lb-rank {
	font-weight: 800;
	color: var(--shinra-gold);
	font-size: 1.1rem;
}
.redeem-lb-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.02em;
}
.redeem-lb-avatar-low { background: rgba(54, 162, 235, 0.35); color: #7ec8f0; }
.redeem-lb-avatar-mid { background: rgba(75, 192, 192, 0.35); color: #6ee7e7; }
.redeem-lb-avatar-top { background: rgba(255, 159, 64, 0.35); color: #fbbf24; }
.redeem-lb-name { font-weight: 600; color: var(--shinra-text); }
.redeem-lb-id { font-size: 0.8rem; color: var(--text-secondary); }
.redeem-lb-bar-wrap {
	height: 8px;
	background: rgba(26, 58, 26, 0.6);
	border-radius: 4px;
	overflow: hidden;
	min-width: 60px;
}
.redeem-lb-bar {
	display: block;
	height: 100%;
	border-radius: 4px;
	transition: width 0.35s ease;
}
.redeem-lb-bar-low { background: linear-gradient(90deg, #36a2eb, #5ab8f5); }
.redeem-lb-bar-mid { background: linear-gradient(90deg, #4bc0c0, #6ee7e7); }
.redeem-lb-bar-top { background: linear-gradient(90deg, #ff9f40, #fbbf24); }
.redeem-lb-coins {
	font-weight: 700;
	color: var(--shinra-gold);
	text-align: right;
}
.redeem-leaderboard-empty {
	padding: 1.5rem;
	text-align: center;
	color: var(--text-secondary);
}
.redeem-stats-table-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.redeem-table-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--shinra-text);
	margin: 0 0 1rem 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.redeem-stats-table-wrap { overflow-x: auto; }
.redeem-stats-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}
.redeem-stats-table th,
.redeem-stats-table td {
	padding: 0.5rem 0.75rem;
	text-align: left;
	border-bottom: 1px solid rgba(26, 58, 26, 0.5);
}
.redeem-stats-table th {
	font-weight: 700;
	color: var(--shinra-gold);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.redeem-stats-table td { color: var(--shinra-text); }

/* ---- Admin: Redeem Codes (Itemshop-Keys) – hochwertiges Dashboard-Design ---- */
.admin-redeem-codes {
	max-width: 1200px;
	margin: 0 auto;
	color: var(--shinra-text);
}
.redeem-codes-head { margin-bottom: 1.5rem; }
.redeem-codes-title {
	font-family: 'Cinzel', serif;
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--shinra-gold);
	margin: 0 0 0.25rem 0;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.redeem-codes-subtitle {
	font-size: 0.9rem;
	color: var(--text-secondary);
	margin: 0;
}
.redeem-codes-alert {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	background: rgba(0, 80, 40, 0.25);
	border: 1px solid rgba(57, 255, 20, 0.3);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	margin-bottom: 1.5rem;
}
.redeem-codes-alert-icon { color: var(--shinra-glow-alt); font-size: 1.5rem; }
.redeem-codes-copy-wrap {
	display: flex;
	gap: 0.5rem;
	margin-top: 0.75rem;
	max-width: 420px;
}
.redeem-codes-copy-input {
	flex: 1;
	background: rgba(0, 0, 0, 0.3);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 6px;
	padding: 0.5rem 0.75rem;
	color: var(--shinra-text);
	font-family: monospace;
	font-size: 0.9rem;
}
.redeem-codes-copy-btn {
	background: var(--shinra-gold);
	color: #1a1a0a;
	border: none;
	border-radius: 6px;
	padding: 0.5rem 1rem;
	font-weight: 700;
	cursor: pointer;
	white-space: nowrap;
}
.redeem-codes-copy-btn:hover { filter: brightness(1.1); }
.redeem-codes-all { margin-top: 0.75rem; }
.redeem-codes-all summary { cursor: pointer; color: var(--shinra-glow-alt); font-size: 0.9rem; }
.redeem-codes-list { font-size: 0.8rem; background: rgba(0,0,0,0.3); padding: 0.75rem; border-radius: 6px; overflow-x: auto; margin-top: 0.5rem; white-space: pre-wrap; }

.redeem-codes-form-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.5rem;
	margin-bottom: 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.redeem-codes-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr 120px;
	gap: 1rem;
	align-items: end;
	margin-bottom: 1rem;
}
@media (max-width: 640px) {
	.redeem-codes-form-row { grid-template-columns: 1fr; }
}
.redeem-codes-field label {
	display: block;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--text-secondary);
	margin-bottom: 0.35rem;
}
.redeem-codes-input {
	width: 100%;
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 8px;
	padding: 0.6rem 0.75rem;
	color: var(--shinra-text);
	font-size: 1rem;
}
.redeem-codes-input:focus {
	outline: none;
	border-color: var(--shinra-gold);
	box-shadow: 0 0 0 2px rgba(212, 160, 23, 0.2);
}
.redeem-codes-submit {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%);
	color: #1a1a0a;
	border: 1px solid var(--shinra-gold);
	border-radius: 8px;
	padding: 0.65rem 1.25rem;
	font-weight: 700;
	cursor: pointer;
	transition: filter 0.2s, box-shadow 0.2s;
}
.redeem-codes-submit:hover { filter: brightness(1.1); box-shadow: 0 0 16px rgba(212, 160, 23, 0.35); }

.redeem-codes-kpis {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	margin-bottom: 1.5rem;
}
@media (max-width: 700px) {
	.redeem-codes-kpis { grid-template-columns: repeat(2, 1fr); }
}
.redeem-codes-kpis .redeem-kpi-card { padding: 1rem 1.25rem; }
.redeem-codes-kpis .redeem-kpi-value { font-size: 1.75rem; }
.redeem-kpi-active .redeem-kpi-value { color: #39ff14; }
.redeem-kpi-redeemed .redeem-kpi-value { color: #36a2eb; }

.redeem-codes-table-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	margin-bottom: 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.redeem-codes-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}
.redeem-codes-tabs {
	display: flex;
	gap: 0.25rem;
}
.redeem-tab {
	display: inline-block;
	padding: 0.5rem 1rem;
	border-radius: 8px;
	font-size: 0.85rem;
	font-weight: 600;
	text-decoration: none !important;
	color: var(--text-secondary) !important;
	transition: background 0.2s, color 0.2s;
}
.redeem-tab:hover { background: rgba(26, 58, 26, 0.5); color: var(--shinra-text) !important; }
.redeem-tab.active {
	background: rgba(57, 255, 20, 0.15);
	color: var(--shinra-gold) !important;
	border: 1px solid rgba(57, 255, 20, 0.35);
}
.redeem-codes-search {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}
.redeem-codes-search-input {
	width: 200px;
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 8px;
	padding: 0.5rem 0.75rem;
	color: var(--shinra-text);
	font-size: 0.9rem;
}
.redeem-codes-search-input::placeholder { color: var(--text-secondary); opacity: 0.8; }
.redeem-codes-search-btn {
	background: rgba(57, 255, 20, 0.2);
	border: 1px solid rgba(57, 255, 20, 0.4);
	border-radius: 8px;
	padding: 0.5rem 0.75rem;
	color: var(--shinra-glow-alt);
	cursor: pointer;
}
.redeem-codes-search-btn:hover { background: rgba(57, 255, 20, 0.3); }
.redeem-codes-download-form {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}
.redeem-codes-download-coins {
	width: 90px;
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 8px;
	padding: 0.5rem 0.75rem;
	color: var(--shinra-text);
	font-size: 0.9rem;
}
.redeem-codes-download-coins::placeholder { color: var(--text-secondary); opacity: 0.8; }
.redeem-codes-download-btn {
	background: rgba(212, 160, 23, 0.25);
	border: 1px solid rgba(212, 160, 23, 0.5);
	border-radius: 8px;
	padding: 0.5rem 0.9rem;
	color: var(--shinra-gold);
	font-size: 0.9rem;
	cursor: pointer;
	white-space: nowrap;
	transition: background 0.2s;
}
.redeem-codes-download-btn:hover { background: rgba(212, 160, 23, 0.4); color: #e8d090; }
.redeem-codes-table-wrap {
	overflow-x: auto;
	max-height: 420px;
	overflow-y: auto;
	border-radius: 8px;
	border: 1px solid rgba(26, 58, 26, 0.5);
}
.redeem-codes-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}
.redeem-codes-table th,
.redeem-codes-table td {
	padding: 0.6rem 0.75rem;
	text-align: left;
	border-bottom: 1px solid rgba(26, 58, 26, 0.5);
}
.redeem-codes-table th {
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--shinra-gold);
	background: var(--shinra-panel);
	position: sticky;
	top: 0;
	z-index: 2;
	box-shadow: 0 2px 0 0 rgba(26, 58, 26, 0.6);
}
.redeem-codes-table thead {
	position: relative;
	z-index: 2;
}
.redeem-codes-table td { color: var(--shinra-text); }
.redeem-code-cell { font-family: monospace; font-size: 0.85rem; color: var(--shinra-glow-alt); }
.redeem-badge {
	display: inline-block;
	padding: 0.25rem 0.6rem;
	border-radius: 6px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
}
.redeem-badge-active { background: rgba(57, 255, 20, 0.25); color: #39ff14; border: 1px solid rgba(57, 255, 20, 0.5); }
.redeem-badge-redeemed { background: rgba(54, 162, 235, 0.25); color: #5ab8f5; border: 1px solid rgba(54, 162, 235, 0.5); }
.redeem-btn-deactivate {
	background: rgba(255, 159, 64, 0.2);
	border: 1px solid rgba(255, 159, 64, 0.5);
	border-radius: 6px;
	padding: 0.35rem 0.65rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: #fbbf24;
	cursor: pointer;
	transition: background 0.2s;
}
.redeem-btn-deactivate:hover { background: rgba(255, 159, 64, 0.35); }
.redeem-deactivate-form { display: inline; }
.redeem-codes-empty {
	text-align: center;
	padding: 2rem !important;
	color: var(--text-secondary);
}
.redeem-codes-sqlite-section {
	background: rgba(12, 28, 12, 0.6);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}
.redeem-codes-sqlite-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--shinra-text);
	margin: 0 0 1rem 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.redeem-codes-sqlite-hint { font-size: 0.85rem; color: var(--text-secondary); font-weight: 400; }
.redeem-codes-legacy-table { margin-bottom: 0; }
.redeem-codes-legacy-table th,
.redeem-codes-legacy-table td { color: var(--shinra-text); border-color: rgba(26, 58, 26, 0.5); }
.redeem-codes-legacy-table thead th { background: rgba(0,0,0,0.3); color: var(--shinra-gold); }

/* Admin: Player Management (neues Design) */
.admin-players-mgmt { padding: 0 0 2rem 0; }
.players-mgmt-head { margin-bottom: 1.5rem; }
.players-mgmt-title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--shinra-gold);
	margin: 0 0 0.25rem 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.players-mgmt-subtitle { margin: 0; color: var(--shinra-text); opacity: 0.9; font-size: 0.9rem; }
.players-mgmt-kpis {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	margin-bottom: 1.5rem;
}
.players-kpi-card {
	background: rgba(12, 28, 12, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 10px;
	padding: 1rem 1.25rem;
	text-align: center;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
}
.players-kpi-value {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--shinra-text);
	line-height: 1.2;
}
.players-kpi-ok .players-kpi-value { color: #39ff14; }
.players-kpi-blocked .players-kpi-value { color: #ef4444; }
.players-kpi-label {
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--shinra-text);
	opacity: 0.85;
	margin-top: 0.25rem;
}
.players-mgmt-table-card {
	background: rgba(12, 28, 12, 0.6);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
	margin-bottom: 1.5rem;
}
.players-mgmt-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}
.players-mgmt-tabs {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}
.players-tab {
	display: inline-block;
	padding: 0.5rem 1rem;
	border-radius: 8px;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	color: var(--shinra-text);
	background: rgba(26, 58, 26, 0.4);
	border: 1px solid transparent;
	transition: background 0.2s, color 0.2s;
}
.players-tab:hover { background: rgba(26, 58, 26, 0.6); color: var(--shinra-text); }
.players-tab.active {
	background: rgba(26, 58, 26, 0.8);
	color: var(--shinra-gold);
	border-color: rgba(212, 160, 23, 0.4);
}
.players-mgmt-search {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}
.players-mgmt-search-input {
	width: 220px;
	padding: 0.5rem 0.75rem;
	border-radius: 8px;
	border: 1px solid var(--shinra-panel-border);
	background: rgba(0, 0, 0, 0.3);
	color: var(--shinra-text);
	font-size: 0.9rem;
}
.players-mgmt-search-input::placeholder { color: var(--shinra-text); opacity: 0.5; }
.players-mgmt-search-btn {
	padding: 0.5rem 1rem;
	border-radius: 8px;
	border: 1px solid var(--shinra-glow-alt);
	background: rgba(57, 255, 20, 0.15);
	color: var(--shinra-glow-alt);
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s;
}
.players-mgmt-search-btn:hover { background: rgba(57, 255, 20, 0.3); }
.players-mgmt-hwid-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.4rem 0.65rem;
	border-radius: 6px;
	background: rgba(168, 85, 247, 0.2);
	border: 1px solid rgba(168, 85, 247, 0.4);
	color: #c084fc;
	font-size: 0.8rem;
	font-weight: 600;
}
.players-mgmt-hwid-inactive {
	margin-bottom: 1rem;
	padding: 0.6rem 1rem;
	background: rgba(120, 120, 120, 0.15);
	border: 1px solid rgba(120, 120, 120, 0.3);
	border-radius: 8px;
	font-size: 0.9rem;
	color: var(--shinra-text);
	opacity: 0.9;
}
.players-mgmt-table-wrap {
	overflow-x: auto;
	max-height: 420px;
	overflow-y: auto;
	border-radius: 8px;
	border: 1px solid rgba(26, 58, 26, 0.5);
}
.players-mgmt-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}
.players-mgmt-table th,
.players-mgmt-table td {
	padding: 0.6rem 0.75rem;
	text-align: left;
	border-bottom: 1px solid rgba(26, 58, 26, 0.5);
}
.players-mgmt-table th {
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--shinra-gold);
	background: var(--shinra-panel);
	position: sticky;
	top: 0;
	z-index: 2;
	box-shadow: 0 2px 0 0 rgba(26, 58, 26, 0.6);
}
.players-mgmt-table thead { position: relative; z-index: 2; }
.players-mgmt-table td { color: var(--shinra-text); }
.players-name-cell { color: var(--shinra-glow-alt); }
.player-tag {
	display: inline-block;
	padding: 0.1rem 0.35rem;
	border-radius: 4px;
	font-size: 0.75rem;
	font-weight: 700;
	margin-right: 0.25rem;
}
.player-tag-sa { background: rgba(239, 68, 68, 0.25); color: #fca5a5; border: 1px solid rgba(239, 68, 68, 0.5); }
.player-tag-tgm { background: rgba(239, 68, 68, 0.2); color: #fca5a5; border: 1px solid rgba(239, 68, 68, 0.4); }
.player-tag-sgm { background: rgba(57, 255, 20, 0.2); color: #86efac; border: 1px solid rgba(57, 255, 20, 0.4); }
.player-tag-ga { background: rgba(156, 163, 175, 0.3); color: #e5e7eb; border: 1px solid rgba(156, 163, 175, 0.5); }
.players-badge {
	display: inline-block;
	padding: 0.25rem 0.6rem;
	border-radius: 6px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
}
.players-badge-ok { background: rgba(57, 255, 20, 0.25); color: #39ff14; border: 1px solid rgba(57, 255, 20, 0.5); }
.players-badge-blocked { background: rgba(239, 68, 68, 0.25); color: #f87171; border: 1px solid rgba(239, 68, 68, 0.5); }
.players-actions-cell { white-space: nowrap; }
.players-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 6px;
	margin: 0 0.15rem;
	text-decoration: none;
	color: var(--shinra-text);
	transition: background 0.2s, color 0.2s;
}
.players-btn-block { background: rgba(239, 68, 68, 0.2); color: #f87171; }
.players-btn-block:hover { background: rgba(239, 68, 68, 0.4); color: #fff; }
.players-btn-unblock { background: rgba(57, 255, 20, 0.2); color: #39ff14; }
.players-btn-unblock:hover { background: rgba(57, 255, 20, 0.4); color: #fff; }
.players-btn-edit { background: rgba(54, 162, 235, 0.2); color: #5ab8f5; }
.players-btn-edit:hover { background: rgba(54, 162, 235, 0.4); color: #fff; }
.players-btn-hwid-ban { background: rgba(168, 85, 247, 0.25); color: #c084fc; }
.players-btn-hwid-ban:hover { background: rgba(168, 85, 247, 0.45); color: #fff; }
.players-btn-hwid-ban.players-btn-disabled { opacity: 0.7; cursor: help; }
.players-btn-hwid-ban:disabled { opacity: 0.5; cursor: not-allowed; }
.players-btn-hwid-unban { padding: 0.35rem 0.65rem; font-size: 0.8rem; background: rgba(57, 255, 20, 0.2); color: var(--shinra-glow-alt); border: 1px solid rgba(57, 255, 20, 0.4); border-radius: 6px; }
.players-btn-hwid-unban:hover { background: rgba(57, 255, 20, 0.35); }
.players-hwid-ban-form { display: inline-block; vertical-align: middle; }
.players-hwid-ban-form button[type="submit"] { cursor: pointer; }
.players-hwid-cell { font-family: monospace; font-size: 0.8rem; color: var(--shinra-text); max-width: 140px; overflow: hidden; text-overflow: ellipsis; }
.players-mgmt-empty { text-align: center; padding: 2rem !important; color: var(--shinra-text); opacity: 0.8; }
.players-mgmt-hwid-unban-card {
	background: rgba(12, 28, 12, 0.6);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 12px;
	padding: 1.25rem 1.5rem;
	margin-top: 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}
.players-mgmt-hwid-unban-title { font-size: 1rem; font-weight: 700; color: var(--shinra-gold); margin: 0 0 1rem 0; text-transform: uppercase; letter-spacing: 0.05em; }
.players-mgmt-hwid-unban-wrap { overflow-x: auto; max-height: 280px; overflow-y: auto; border-radius: 8px; border: 1px solid rgba(26, 58, 26, 0.5); }
.players-hwid-unban-table { font-size: 0.9rem; }
.players-hwid-unban-table th { background: var(--shinra-panel); color: var(--shinra-gold); }
.players-hwid-code { font-size: 0.8rem; color: var(--shinra-glow-alt); word-break: break-all; }

/* HWID-Detail-Panel – aufgeräumtes Design */
.players-hwid-detail-modal .modal-dialog { max-width: 520px; }
.players-hwid-detail-content {
	background: #0c1410;
	border: 1px solid rgba(42, 82, 42, 0.5);
	border-radius: 12px;
	box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}
.players-hwid-detail-content .modal-header {
	border-bottom: 1px solid rgba(42, 82, 42, 0.4);
	padding: 1rem 1.25rem;
	background: rgba(0,0,0,0.2);
}
.players-hwid-detail-content .modal-title {
	font-size: 1rem;
	font-weight: 600;
	color: #b8c8b8;
	letter-spacing: 0.02em;
}
.players-hwid-detail-content .modal-title .fa-fingerprint { opacity: 0.7; margin-right: 0.4rem; }
.players-hwid-detail-content .modal-body { padding: 1.25rem 1.5rem; }
.players-hwid-detail-info {
	background: rgba(0,0,0,0.25);
	border-radius: 8px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.25rem;
	border: 1px solid rgba(26, 58, 26, 0.35);
}
.players-hwid-detail-dl {
	display: grid;
	grid-template-columns: 90px 1fr;
	gap: 0.5rem 1rem;
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.5;
}
.players-hwid-detail-dl dt {
	color: #7a8a7a;
	font-weight: 500;
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.players-hwid-detail-dl dd {
	margin: 0;
	color: #d0e0d0;
	word-break: break-all;
	font-family: inherit;
}
.players-hwid-detail-list-wrap {
	background: rgba(0,0,0,0.2);
	border: 1px solid rgba(26, 58, 26, 0.35);
	border-radius: 8px;
	padding: 1rem 1.25rem;
}
.players-hwid-detail-list-title {
	margin: 0 0 0.75rem 0;
	font-size: 0.75rem;
	font-weight: 600;
	color: #7a8a7a;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.players-hwid-detail-list { min-height: 2rem; }
.players-hwid-detail-no-hwid {
	margin: 0;
	color: #8a9a8a;
	font-size: 0.85rem;
	line-height: 1.5;
}
.players-hwid-detail-ul { margin: 0; padding: 0; list-style: none; }
.players-hwid-detail-ul li { margin-bottom: 0.75rem; }
.players-hwid-detail-ul li:last-child { margin-bottom: 0; }
.players-hwid-detail-li {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
	padding: 0.6rem 0.85rem;
	background: rgba(10, 22, 10, 0.6);
	border-radius: 6px;
	border: 1px solid rgba(26, 58, 26, 0.3);
}
.players-hwid-detail-li .players-hwid-code {
	flex: 1 1 100%;
	font-size: 0.78rem;
	color: #9cb89c;
	font-family: ui-monospace, monospace;
	word-break: break-all;
	background: transparent;
	padding: 0;
	border: none;
}
.players-hwid-detail-status {
	font-size: 0.7rem;
	padding: 0.25rem 0.6rem;
	border-radius: 20px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.players-hwid-status-ok {
	background: rgba(48, 120, 48, 0.35);
	color: #6bc96b;
	border: 1px solid rgba(48, 120, 48, 0.4);
}
.players-hwid-status-banned {
	background: rgba(120, 48, 48, 0.35);
	color: #d88;
	border: 1px solid rgba(120, 48, 48, 0.4);
}
.players-hwid-detail-unban-inline { display: inline-block; margin: 0; }
.players-hwid-detail-footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
	justify-content: space-between;
	padding: 1rem 1.5rem;
	border-top: 1px solid rgba(42, 82, 42, 0.4);
	background: rgba(0,0,0,0.15);
}
.players-hwid-detail-ban-form { margin: 0; }
/* Wie Close-Button: Text sauber auf einer Zeile, genug Platz */
.players-btn-hwid-ban-submit,
.players-hwid-detail-content .players-btn-hwid-unban {
	white-space: nowrap;
	padding: 0.5rem 1.25rem;
	min-width: 6.5rem;
	border-radius: 8px;
	font-size: 0.9rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, color 0.2s;
	text-align: center;
	box-sizing: border-box;
}
.players-btn-hwid-ban-submit {
	background: rgba(100, 60, 140, 0.25);
	color: #b8a0d8;
	border: 1px solid rgba(100, 60, 140, 0.45);
}
.players-btn-hwid-ban-submit:hover {
	background: rgba(100, 60, 140, 0.4);
	border-color: rgba(140, 100, 180, 0.5);
	color: #e0d0f0;
}
.players-hwid-detail-footer .players-btn-close {
	white-space: nowrap;
	background: rgba(26, 58, 26, 0.4);
	color: #b0c0b0;
	border: 1px solid rgba(42, 82, 42, 0.5);
	padding: 0.5rem 1.25rem;
	min-width: 5rem;
	border-radius: 8px;
	font-size: 0.9rem;
	text-align: center;
	box-sizing: border-box;
}
.players-hwid-detail-footer .players-btn-close:hover {
	background: rgba(26, 58, 26, 0.6);
	color: #fff;
}
.players-hwid-detail-content .players-modal-close {
	color: #8a9a8a;
	opacity: 0.9;
}
.players-hwid-detail-content .players-modal-close:hover { color: #fff; }
.players-hwid-detail-content .players-btn-hwid-unban {
	background: rgba(48, 100, 48, 0.35);
	color: #8bdc8b;
	border: 1px solid rgba(48, 120, 48, 0.5);
}
.players-hwid-detail-content .players-btn-hwid-unban:hover {
	background: rgba(48, 120, 48, 0.5);
	border-color: rgba(60, 140, 60, 0.55);
	color: #a8f0a8;
}

.players-mgmt-pagination {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(26, 58, 26, 0.5);
}
.players-mgmt-pagination-info { font-size: 0.9rem; color: var(--shinra-text); }
.players-mgmt-pagination-links { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.players-page-link {
	display: inline-block;
	padding: 0.4rem 0.75rem;
	border-radius: 6px;
	background: rgba(26, 58, 26, 0.5);
	border: 1px solid var(--shinra-panel-border);
	color: var(--shinra-text);
	text-decoration: none;
	font-size: 0.9rem;
	transition: background 0.2s;
}
.players-page-link:hover { background: rgba(26, 58, 26, 0.8); color: var(--shinra-gold); }
.players-page-link.active {
	background: rgba(212, 160, 23, 0.2);
	border-color: var(--shinra-gold);
	color: var(--shinra-gold);
}
.players-mgmt-features {
	background: rgba(12, 28, 12, 0.5);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 10px;
	padding: 1rem 1.25rem;
}
.players-mgmt-features-title { margin: 0 0 0.5rem 0; font-weight: 600; color: var(--shinra-gold); font-size: 0.95rem; }
.players-mgmt-features ul { margin: 0; padding-left: 1.25rem; color: var(--shinra-text); font-size: 0.85rem; line-height: 1.6; }
.players-modal-content { background: var(--shinra-panel); border: 1px solid var(--shinra-panel-border); border-radius: 10px; color: var(--shinra-text); }
.players-modal-header { border-bottom-color: var(--shinra-panel-border); }
.players-modal-header .modal-title { color: var(--shinra-gold); }
.players-modal-close { color: var(--shinra-text); opacity: 0.8; }
.players-modal-body { border-bottom-color: var(--shinra-panel-border); }
.players-modal-body .nav-tabs .nav-link { color: var(--shinra-text); }
.players-modal-body .nav-tabs .nav-link.active { color: var(--shinra-gold); background: rgba(26, 58, 26, 0.5); border-color: var(--shinra-panel-border); }
.players-modal-body .form-group label { color: var(--shinra-text); }
.players-input { background: rgba(0,0,0,0.3); border-color: var(--shinra-panel-border); color: var(--shinra-text); }
.players-modal-footer { border-top-color: var(--shinra-panel-border); }
.players-btn-submit { background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%); color: var(--shinra-text); border: 1px solid var(--shinra-gold); }
.players-btn-close { background: rgba(26, 58, 26, 0.6); color: var(--shinra-text); border: 1px solid var(--shinra-panel-border); }
@media (max-width: 768px) {
	.players-mgmt-kpis { grid-template-columns: repeat(2, 1fr); }
	.players-mgmt-toolbar { flex-direction: column; align-items: stretch; }
	.players-mgmt-search { width: 100%; }
	.players-mgmt-search-input { flex: 1; width: auto; }
}

/* Admin-Inhalt: Listen & Links (kompatibel mit bestehenden admin/*.php) */
.admin-dashboard-main .list-group-item {
	background: rgba(12, 28, 12, 0.8) !important;
	border-color: rgba(26, 58, 26, 0.5);
	color: var(--shinra-text);
}
.admin-dashboard-main .list-group-item.active {
	background: rgba(212, 160, 23, 0.15) !important;
	border-color: rgba(212, 160, 23, 0.4);
	color: var(--shinra-gold);
}
.admin-dashboard-main .list-group-item-action:hover {
	background: rgba(26, 58, 26, 0.6) !important;
}
.admin-dashboard-main .list-group-item-heading {
	font-size: 1rem;
	font-weight: 700;
	color: var(--shinra-text);
}
.admin-dashboard-main .list-group-item-text {
	font-size: 0.9rem;
	color: var(--text-secondary);
	margin-top: 0.25rem;
}

/* ---- Content / Carousel ---- */
.content::before {
	background: linear-gradient(to right, rgba(0,0,0,0.3) 0%, transparent 100%);
}
/* ---- Content Hero (ersetzt Slider – Shinra-Farben) ---- */
.content-hero {
	background: linear-gradient(135deg, rgba(10, 26, 10, 0.95) 0%, rgba(6, 14, 6, 0.98) 50%, rgba(20, 50, 20, 0.3) 100%);
	border: 1px solid var(--border-dim);
	border-radius: 6px;
	margin-bottom: 1.5rem;
	min-height: 140px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: inset 0 0 60px rgba(0, 255, 68, 0.04), 0 0 20px rgba(0, 0, 0, 0.2);
}
.content-hero-inner {
	text-align: center;
	padding: 1.5rem 2rem;
}
.content-hero-title {
	color: var(--shinra-gold);
	font-family: 'Cinzel', serif;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0 0 0.5rem 0;
	text-transform: uppercase;
	text-shadow: 0 0 20px rgba(212, 160, 23, 0.4);
}
.content-hero-desc {
	color: rgba(232, 240, 232, 0.85);
	font-size: 0.95rem;
	margin: 0 0 1rem 0;
	max-width: 420px;
	margin-left: auto;
	margin-right: auto;
}
.content-hero-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1.25rem;
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%);
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold);
	border-radius: 4px;
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none !important;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
	box-shadow: 0 0 15px rgba(212, 160, 23, 0.3);
	transition: box-shadow 0.2s, filter 0.2s;
}
.content-hero-btn:hover {
	color: var(--shinra-text) !important;
	box-shadow: 0 0 22px rgba(212, 160, 23, 0.5);
	filter: brightness(1.05);
}

/* ---- Stats (Statistiken) ---- */
.stats {
	background-image: none;
}
.stats .list-group-item {
	background: transparent !important;
	border: none;
}

/* ---- Alerts / Muted ---- */
.text-muted {
	color: rgba(232, 240, 232, 0.6) !important;
}
.alert {
	background: var(--shinra-panel);
	border-color: var(--shinra-panel-border);
	color: var(--shinra-text);
}
.alert-danger {
	background: rgba(58, 26, 26, 0.5);
	border-color: #4a2020;
}
.alert-info {
	background: rgba(13, 31, 26, 0.6);
	border-color: var(--shinra-panel-border);
}
.text-info { color: var(--shinra-glow-alt) !important; }
.text-success { color: var(--shinra-glow) !important; }
.text-warning { color: var(--shinra-gold) !important; }

/* ---- Lost / Create Account Links ---- */
.lost,
.create-acc {
	background-color: var(--shinra-panel) !important;
	border: 1px solid var(--shinra-panel-border);
	color: var(--shinra-text);
}

/* ---- Green-A Buttons (Read More etc.) ---- */
.green-a {
	background: linear-gradient(180deg, var(--shinra-glow-alt) 0%, var(--shinra-glow) 100%) !important;
	background-image: none !important;
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-glow);
	box-shadow: 0 0 15px rgba(57, 255, 20, 0.4);
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.green-a:before,
.green-a:after {
	display: none;
}
.green-a:hover {
	box-shadow: 0 0 25px rgba(57, 255, 20, 0.6);
	color: var(--shinra-text) !important;
}

/* ---- Pager ---- */
.pager li > a,
.pager li > span {
	background-color: var(--shinra-panel);
	border-color: var(--shinra-panel-border);
	color: var(--shinra-text);
}
.pager li > a:hover {
	background-color: var(--shinra-glow);
	color: var(--shinra-text);
	border-color: var(--shinra-glow);
	text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

/* ---- Modal / Jumbotron ---- */
.modal-content {
	background: var(--shinra-panel) !important;
	border: 1px solid var(--shinra-panel-border);
	color: var(--shinra-text);
}
.jumbotron {
	background: var(--shinra-panel) !important;
	border: 1px solid var(--shinra-panel-border);
	color: var(--shinra-text);
}
.page-hd {
	background: linear-gradient(180deg, rgba(26, 58, 26, 0.4) 0%, transparent 100%) !important;
	border-bottom: 1px solid var(--shinra-panel-border);
}

/* ---- Account Page (hochwertig) ---- */
.account-page {
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}
.account-header {
	text-align: center;
	margin-bottom: 1.5rem;
}
.account-title {
	color: var(--shinra-gold);
	font-family: 'Cinzel', serif;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin: 0 0 0.25rem 0;
	text-shadow: 0 0 20px rgba(212, 160, 23, 0.35);
}
.account-username {
	color: var(--shinra-text);
	font-size: 1rem;
	opacity: 0.9;
	margin: 0 0 0.75rem 0;
}
.account-title-line {
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--shinra-panel-border) 20%, var(--shinra-gold) 50%, var(--shinra-panel-border) 80%, transparent 100%);
	opacity: 0.8;
	max-width: 280px;
	margin: 0 auto;
}
.account-page .card.account-card {
	margin-bottom: 1.25rem;
}
.account-page .card-header {
	font-weight: 600;
	letter-spacing: 0.03em;
}
.account-details {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.35rem 1.5rem;
	margin: 0;
	color: var(--shinra-text);
}
.account-details dt {
	grid-column: 1;
	color: rgba(232, 240, 232, 0.75);
	font-size: 0.9rem;
	font-weight: 500;
}
.account-details dd {
	grid-column: 2;
	margin: 0;
	font-size: 0.95rem;
}
.account-code {
	display: inline-block;
	padding: 0.2em 0.5em;
	background: rgba(26, 58, 26, 0.6);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
	color: var(--shinra-glow-alt);
	font-size: 0.9em;
}
.account-actions {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}
.account-action {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.account-action-form {
	display: inline;
	margin: 0;
}
.account-action-desc {
	color: var(--shinra-text);
	font-size: 0.95rem;
	opacity: 0.95;
}
.account-action--disabled .account-action-desc {
	opacity: 0.7;
}
.account-badge-disabled {
	display: inline-block;
	margin-left: 0.35rem;
	padding: 0.15em 0.5em;
	font-size: 0.75rem;
	font-weight: 600;
	color: rgba(200, 120, 100, 0.95);
	background: rgba(80, 40, 35, 0.4);
	border: 1px solid rgba(120, 60, 50, 0.5);
	border-radius: 4px;
}
.btn-account {
	display: inline-block;
	padding: 0.4rem 1rem;
	font-size: 0.9rem;
	font-weight: 600;
	border-radius: 4px;
	text-decoration: none !important;
	text-align: center;
	min-width: 140px;
	transition: box-shadow 0.2s, filter 0.2s;
	cursor: pointer;
	border: 1px solid transparent;
}
.btn-account--primary {
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%);
	color: var(--shinra-text) !important;
	border-color: var(--shinra-gold);
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
	box-shadow: 0 0 12px rgba(212, 160, 23, 0.25);
}
.btn-account--primary:hover {
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.5);
	filter: brightness(1.05);
}
.btn-account--disabled {
	background: var(--border-dim) !important;
	color: rgba(232, 240, 232, 0.5) !important;
	border-color: var(--shinra-panel-border);
	cursor: not-allowed;
}
.btn-account--danger {
	background: rgba(120, 40, 40, 0.9) !important;
	color: var(--shinra-text) !important;
	border: 1px solid rgba(180, 60, 60, 0.8);
}
.btn-account--danger:hover {
	box-shadow: 0 0 14px rgba(180, 60, 60, 0.4);
}
.btn-account--warning {
	background: rgba(120, 90, 40, 0.9) !important;
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold-alt);
}
.btn-account--warning:hover {
	box-shadow: 0 0 14px rgba(212, 160, 23, 0.3);
}
.account-page .alert {
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
	margin-bottom: 1rem;
}
.account-page .alert-success {
	background: rgba(26, 58, 26, 0.8) !important;
	color: var(--shinra-glow-alt) !important;
	border-color: var(--border-mid);
}
.account-page .alert-danger {
	background: rgba(58, 26, 26, 0.6) !important;
	color: #e8a0a0 !important;
	border-color: rgba(120, 60, 60, 0.6);
}

/* ---- Characters Page (Character list – hochwertig) ---- */
.characters-page {
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}
.characters-header {
	text-align: center;
	margin-bottom: 1.5rem;
}
.characters-title {
	color: var(--shinra-gold);
	font-family: 'Cinzel', serif;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin: 0 0 0.25rem 0;
	text-shadow: 0 0 20px rgba(212, 160, 23, 0.35);
}
.characters-username {
	color: var(--shinra-text);
	font-size: 1rem;
	opacity: 0.9;
	margin: 0 0 0.75rem 0;
}
.characters-title-line {
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--shinra-panel-border) 20%, var(--shinra-gold) 50%, var(--shinra-panel-border) 80%, transparent 100%);
	opacity: 0.8;
	max-width: 280px;
	margin: 0 auto;
}
.characters-page .card.characters-card {
	margin-bottom: 1.5rem;
	overflow: hidden;
}
.characters-page .characters-card-header {
	font-weight: 600;
	letter-spacing: 0.03em;
	color: var(--shinra-gold) !important;
}
/* Kompakte Listen-Ansicht – kein horizontales Scrollen */
.characters-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.character-row {
	display: flex;
	align-items: center;
	gap: 0.75rem 1rem;
	padding: 0.65rem 1rem;
	border-bottom: 1px solid var(--shinra-panel-border);
	flex-wrap: wrap;
	min-width: 0;
}
.character-row:last-child {
	border-bottom: none;
}
.character-row:hover {
	background: rgba(26, 58, 26, 0.4);
}
.character-row-rank {
	flex-shrink: 0;
	width: 2.25rem;
	text-align: center;
	color: var(--shinra-gold);
	font-size: 0.9rem;
}
.character-row-rank i {
	font-size: 1rem;
	opacity: 0.9;
}
.character-row-class {
	flex-shrink: 0;
}
.character-job-icon {
	border-radius: 4px;
	display: block;
	vertical-align: middle;
}
.character-row-name {
	flex: 1 1 auto;
	min-width: 0;
	font-weight: 600;
	color: var(--shinra-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.character-row-level,
.character-row-exp {
	flex-shrink: 0;
	font-size: 0.9rem;
	color: rgba(232, 240, 232, 0.9);
}
.char-label {
	display: inline-block;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: rgba(232, 240, 232, 0.6);
	margin-right: 0.25rem;
}
.character-row-debug {
	flex-shrink: 0;
}
.characters-empty {
	padding: 2.5rem 1.5rem;
	text-align: center;
}
.characters-empty-text {
	margin: 0;
	color: rgba(232, 240, 232, 0.8);
	font-size: 1rem;
}
.characters-page .alert {
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
	margin-bottom: 1rem;
}
.characters-page .alert-success {
	background: rgba(26, 58, 26, 0.8) !important;
	color: var(--shinra-glow-alt) !important;
	border-color: var(--border-mid);
}

/* ---- Discord Widget Card (Sidebar) ---- */
.card.mt-3 .card-body {
	background: transparent;
}

/* ---- Discord Slide-Out (rechts, ein-/ausklappbar) ---- */
.discord-slide-tab {
	position: fixed;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 9998;
	width: 44px;
	height: 120px;
	padding: 0.5rem 0.35rem;
	background: var(--bg-panel-solid);
	border: 1px solid var(--border-dim);
	border-right: none;
	border-radius: 8px 0 0 8px;
	color: var(--shinra-text);
	font-size: 1.25rem;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	box-shadow: -4px 0 20px rgba(0, 0, 0, 0.3);
	transition: background 0.2s, color 0.2s, box-shadow 0.2s;
	text-decoration: none;
}
.discord-slide-tab:hover {
	background: var(--border-dim);
	color: var(--shinra-glow);
	box-shadow: -4px 0 24px rgba(57, 255, 20, 0.15);
}
.discord-slide-tab-text {
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	writing-mode: vertical-rl;
	text-orientation: mixed;
}
.discord-slide-out {
	position: fixed;
	right: 0;
	top: 0;
	bottom: 0;
	width: 0;
	overflow: hidden;
	z-index: 9999;
	background: var(--bg-panel-solid);
	border-left: 1px solid var(--border-dim);
	box-shadow: -8px 0 30px rgba(0, 0, 0, 0.4);
	transition: width 0.3s ease;
}
.discord-slide-out.is-open {
	width: 370px;
}
.discord-slide-out[aria-hidden="false"] {
	width: 370px;
}
.discord-slide-out-inner {
	width: 370px;
	height: 100%;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}
.discord-slide-out-header {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem;
	background: rgba(26, 58, 26, 0.5);
	border-bottom: 1px solid var(--border-dim);
	flex-shrink: 0;
}
.discord-slide-out-title {
	font-weight: 600;
	color: var(--shinra-gold);
	font-size: 1rem;
}
.discord-slide-out-join {
	margin-left: auto;
	padding: 0.35rem 0.75rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--shinra-text) !important;
	background: var(--shinra-gold);
	border: 1px solid var(--shinra-gold-alt);
	border-radius: 4px;
	text-decoration: none !important;
	transition: box-shadow 0.2s, filter 0.2s;
}
.discord-slide-out-join:hover {
	color: var(--shinra-text) !important;
	box-shadow: 0 0 14px rgba(212, 160, 23, 0.5);
	filter: brightness(1.05);
}
.discord-slide-out-close {
	width: 2rem;
	height: 2rem;
	padding: 0;
	background: transparent;
	border: 1px solid var(--border-dim);
	border-radius: 4px;
	color: var(--shinra-text);
	font-size: 1.25rem;
	line-height: 1;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}
.discord-slide-out-close:hover {
	background: var(--border-dim);
	color: var(--shinra-gold);
}
.discord-slide-out-body {
	flex: 1;
	min-height: 0;
	padding: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
.discord-slide-out-body iframe {
	width: 350px;
	height: 500px;
	max-width: 100%;
	border-radius: 8px;
	display: block;
}

/* Discord auf Mobile: kein Überlappen, kleiner FAB unten rechts */
@media (max-width: 768px) {
	#mainbox,
	.page { padding-right: 52px; }
	.discord-slide-tab {
		top: auto;
		bottom: 1.25rem;
		right: 0.5rem;
		transform: none;
		width: 48px;
		height: 48px;
		border-radius: 50%;
		border: 1px solid var(--border-dim);
		box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
		padding: 0;
	}
	.discord-slide-tab-text { display: none; }
	.discord-slide-tab i { font-size: 1.4rem; }
	.discord-slide-out.is-open,
	.discord-slide-out[aria-hidden="false"] { width: 100%; max-width: 100%; }
	.discord-slide-out-inner { width: 100%; }
	.discord-slide-out-body iframe { width: 100%; height: 70vh; max-height: 500px; }
}
@media (max-width: 576px) {
	#mainbox,
	.page { padding-right: 0; }
	.discord-slide-tab {
		bottom: 1rem;
		right: 1rem;
		width: 48px;
		height: 48px;
	}
}

/* ---- Download Page (hochwertig) ---- */
.download-page {
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}
.download-page .page-hd {
	margin-bottom: 1.5rem;
}
.download-title {
	color: var(--shinra-gold);
	font-size: 1.75rem;
	font-weight: 700;
	margin: 0 0 0.5rem 0;
	letter-spacing: 0.05em;
}
.download-title-line {
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--shinra-panel-border) 20%, var(--shinra-gold) 50%, var(--shinra-panel-border) 80%, transparent 100%);
	opacity: 0.8;
}
.download-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-bottom: 2rem;
}
.download-item {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	padding: 1rem 1.25rem;
	background: var(--shinra-panel-rgba);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 6px;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.download-item:hover {
	border-color: var(--shinra-gold);
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.15);
}
.download-item-num {
	width: 2.25rem;
	height: 2.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(26, 58, 26, 0.6);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
	color: var(--shinra-gold);
	font-weight: 700;
	font-size: 0.9rem;
	flex-shrink: 0;
}
.download-item-name {
	flex: 1;
	color: var(--shinra-text);
	font-size: 1.05rem;
}
.download-item-action {
	flex-shrink: 0;
}
.download-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1.25rem;
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%);
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold);
	border-radius: 4px;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none !important;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
	box-shadow: 0 0 12px rgba(212, 160, 23, 0.3);
	transition: filter 0.2s, box-shadow 0.2s;
}
.download-btn:hover {
	filter: brightness(1.12);
}

/* ---- Buy Coins Page (Vorher-Seite vor Redirect zum Item Shop) ---- */
.buy-coins-page {
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
}
.buy-coins-header {
	text-align: center;
	margin-bottom: 1.5rem;
}
.buy-coins-title {
	color: var(--shinra-gold);
	font-family: 'Cinzel', serif;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin: 0 0 0.5rem 0;
	text-shadow: 0 0 20px rgba(212, 160, 23, 0.35);
}
.buy-coins-title-line {
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--shinra-panel-border) 20%, var(--shinra-gold) 50%, var(--shinra-panel-border) 80%, transparent 100%);
	opacity: 0.8;
	max-width: 240px;
	margin: 0 auto;
}
.buy-coins-page .buy-coins-card {
	margin-bottom: 1.5rem;
}
.buy-coins-page .buy-coins-card-header {
	font-weight: 600;
	color: var(--shinra-gold) !important;
}
.buy-coins-instruction {
	color: var(--shinra-text);
	font-size: 0.95rem;
	margin-bottom: 1.5rem;
}
.buy-coins-instruction ol {
	margin: 0.75rem 0 1rem 1.25rem;
	padding: 0;
}
.buy-coins-instruction li {
	margin-bottom: 0.5rem;
}
.buy-coins-confirm-wrap {
	margin: 1.25rem 0 1.5rem;
	padding: 1rem 1.25rem;
	background: rgba(26, 58, 26, 0.4);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
}
.buy-coins-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	cursor: pointer;
	color: var(--shinra-text);
	font-size: 0.95rem;
	margin: 0 0 0.75rem 0;
}
.buy-coins-checkbox-label input {
	margin-top: 0.25rem;
	flex-shrink: 0;
}
.buy-coins-checkbox-label span {
	flex: 1;
}
.buy-coins-countdown {
	margin: 0;
	font-size: 0.9rem;
	color: rgba(232, 240, 232, 0.85);
}
.buy-coins-btn-locked {
	pointer-events: none !important;
	opacity: 0.6 !important;
	cursor: not-allowed !important;
}
.buy-coins-action {
	text-align: center;
}
.buy-coins-continue-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.5rem;
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%) !important;
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold) !important;
	border-radius: 4px;
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none !important;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
	box-shadow: 0 0 18px rgba(212, 160, 23, 0.35);
	transition: filter 0.2s, box-shadow 0.2s;
}
.buy-coins-continue-btn:hover {
	color: var(--shinra-text) !important;
	filter: brightness(1.08);
	box-shadow: 0 0 24px rgba(212, 160, 23, 0.5);
	box-shadow: 0 0 20px rgba(212, 160, 23, 0.45);
	color: var(--shinra-text) !important;
}
.download-empty {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 2rem;
	border-radius: 6px;
}
.download-help.card {
	border-radius: 6px;
	overflow: hidden;
}
.download-help .card-header {
	padding: 0.75rem 1.25rem;
	font-size: 0.95rem;
}
.download-help-step {
	margin-bottom: 1.25rem;
}
.download-help-step:last-of-type {
	margin-bottom: 0;
}
.download-help-text {
	color: var(--shinra-text);
	margin: 0 0 0.5rem 0;
	font-size: 0.95rem;
	line-height: 1.5;
}
.download-help-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--shinra-glow-alt) !important;
	font-weight: 600;
	text-decoration: none !important;
	transition: color 0.2s, text-shadow 0.2s;
}
.download-help-link:hover {
	color: var(--shinra-glow) !important;
	text-shadow: 0 0 10px rgba(57, 255, 20, 0.4);
}
.download-help-note {
	color: rgba(232, 240, 232, 0.85);
	font-size: 0.9rem;
	margin: 1rem 0 0 0;
	padding-top: 1rem;
	border-top: 1px solid var(--shinra-panel-border);
}
.download-help-note i {
	color: var(--shinra-gold);
	margin-right: 0.35rem;
}

/* ---- Register Page (hochwertig, wie Download) ---- */
.register-page {
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}
.register-page .page-hd {
	margin-bottom: 1.5rem;
}
.register-title {
	color: var(--shinra-gold);
	font-size: 1.75rem;
	font-weight: 700;
	margin: 0 0 0.5rem 0;
	letter-spacing: 0.05em;
}
.register-title-line {
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--shinra-panel-border) 20%, var(--shinra-gold) 50%, var(--shinra-panel-border) 80%, transparent 100%);
	opacity: 0.8;
}
.register-card.card {
	border-radius: 8px;
	overflow: hidden;
}
.register-form {
	padding: 0;
}
.register-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem 1.5rem;
	margin-bottom: 1.5rem;
}
@media (max-width: 576px) {
	.register-form-grid {
		grid-template-columns: 1fr;
	}
}
.register-field label {
	display: block;
	color: var(--shinra-text);
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 0.4rem;
}
.register-field .form-control {
	width: 100%;
	color: var(--shinra-text);
	background: rgba(10, 26, 10, 0.9);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 4px;
	padding: 0.6rem 0.75rem;
}
.register-field .form-control::placeholder {
	color: rgba(232, 240, 232, 0.45);
}
.register-field .form-control:focus {
	border-color: var(--shinra-gold);
	box-shadow: 0 0 0 2px rgba(212, 160, 23, 0.2);
	outline: none;
}
.register-field .form-feedback {
	margin: 0.35rem 0 0 0;
	font-size: 0.85rem;
}
.register-field .form-feedback.text-danger {
	color: #e57373 !important;
}
.register-captcha {
	margin-bottom: 1.5rem;
	padding: 1rem 0;
	border-top: 1px solid var(--shinra-panel-border);
}
.register-captcha-label {
	display: block;
	color: var(--shinra-text);
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 0.5rem;
}
.register-captcha-row {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.register-captcha-image img {
	display: block;
	border-radius: 4px;
	border: 1px solid var(--shinra-panel-border);
	max-height: 50px;
}
.register-captcha-input {
	flex: 1;
	min-width: 120px;
	max-width: 180px;
	font-size: 1.25rem;
	letter-spacing: 0.15em;
	text-align: center;
}
.register-captcha-unavailable {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem;
	background: rgba(26, 58, 26, 0.5);
	border: 1px solid var(--shinra-panel-border);
	border-radius: 6px;
	color: rgba(232, 240, 232, 0.85);
	font-size: 0.9rem;
	margin-bottom: 1rem;
}
.register-captcha-unavailable i {
	color: var(--shinra-gold);
	flex-shrink: 0;
}
.register-dev-hint {
	display: block;
	margin-top: 0.35rem;
	color: var(--shinra-glow-alt);
	opacity: 0.9;
}
.register-submit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	padding: 0.75rem 1.5rem;
	background: linear-gradient(180deg, var(--shinra-gold-alt) 0%, var(--shinra-gold) 100%);
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-gold);
	border-radius: 6px;
	font-size: 1rem;
	font-weight: 600;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
	box-shadow: 0 0 15px rgba(212, 160, 23, 0.35);
	transition: filter 0.2s, box-shadow 0.2s;
	cursor: pointer;
}
.register-submit-btn:hover {
	filter: brightness(1.12);
	box-shadow: 0 0 22px rgba(212, 160, 23, 0.5);
	color: var(--shinra-text) !important;
}
.register-empty {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 6px;
}
.register-download-credentials-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	background: linear-gradient(180deg, var(--shinra-glow-alt) 0%, var(--shinra-glow) 100%);
	color: var(--shinra-text) !important;
	border: 1px solid var(--shinra-glow);
	border-radius: 6px;
	font-weight: 600;
	text-decoration: none !important;
	box-shadow: 0 0 12px rgba(57, 255, 20, 0.3);
	transition: box-shadow 0.2s, filter 0.2s;
}
.register-download-credentials-btn:hover {
	box-shadow: 0 0 20px rgba(57, 255, 20, 0.5);
	filter: brightness(1.08);
	color: var(--shinra-text) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE / RESPONSIVE – iPhone, Samsung, Tablets
   ═══════════════════════════════════════════════════════════════════════════ */
html { overflow-x: hidden; -webkit-text-size-adjust: 100%; }
body { overflow-x: hidden; min-width: 0; -webkit-tap-highlight-color: rgba(57, 255, 20, 0.15); }
/* Safe Area für Notch (iPhone X+, Samsung mit Loch) */
@supports (padding: env(safe-area-inset-top)) {
	.admin-dashboard-header { padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); }
	.admin-dashboard-header-inner { padding-left: max(1rem, env(safe-area-inset-left)); }
	.page { padding-left: max(12px, env(safe-area-inset-left)); padding-right: max(12px, env(safe-area-inset-right)); }
}

/* Tablet & kleiner */
@media (max-width: 992px) {
	.page { padding: 16px 12px 40px; max-width: 100%; }
	.grid { grid-template-columns: 1fr; gap: 12px; }
	.navbar-inner { padding: 0 16px; flex-wrap: wrap; justify-content: center; }
	.nav-group.left { margin-right: 20px; }
	.nav-group.right { margin-left: 20px; }
	.navbar.shinra-navbar .nav-link { padding: 0 12px; font-size: 11px; letter-spacing: 1.5px; height: 48px; }
	.shinra-logo .logo-svg { max-width: 280px; height: auto; }
	.admin-dashboard-body { flex-direction: column; }
	.admin-dashboard-sidebar {
		width: 100%;
		border-right: none;
		border-bottom: 1px solid rgba(26, 58, 26, 0.6);
		padding: 0.75rem 1rem;
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		gap: 0.25rem;
	}
	.admin-dashboard-sidebar-nav { flex-direction: row; flex-wrap: wrap; gap: 0.25rem; }
	.admin-dash-group-label { width: 100%; margin-top: 0.5rem; padding: 0.5rem 0.75rem 0.25rem; font-size: 0.65rem; }
	.admin-dash-link { padding: 0.5rem 0.75rem; font-size: 0.85rem; border-left: none; border-bottom: 2px solid transparent; }
	.admin-dash-link.active { border-left: none; border-bottom-color: var(--shinra-gold); }
	.admin-dash-link:hover { border-left: none; border-bottom-color: var(--green-bright); }
	.admin-dashboard-main { padding: 1rem 1rem 2rem; }
}

/* Kleines Tablet / großes Handy */
@media (max-width: 768px) {
	.page { padding: 12px 10px 32px; }
	.navbar-inner { padding: 0 10px; }
	.nav-group { flex-wrap: wrap; justify-content: center; }
	.nav-group.left { margin-right: 8px; }
	.nav-group.right { margin-left: 8px; }
	.navbar.shinra-navbar .nav-link { padding: 0 10px; font-size: 10px; letter-spacing: 1px; height: 44px; min-height: 44px; }
	.admin-dashboard-header-inner { padding: 0.5rem 1rem; flex-wrap: wrap; gap: 0.5rem; }
	.admin-dashboard-logo-text { font-size: 1rem; }
	.admin-dashboard-logo-icon { width: 36px; height: 36px; font-size: 1rem; }
	.admin-dashboard-nav { gap: 0.75rem; font-size: 0.85rem; }
	.redeem-codes-toolbar { flex-direction: column; align-items: stretch; gap: 0.75rem; }
	.redeem-codes-search { width: 100%; }
	.redeem-codes-search-input { width: 100%; }
	.redeem-codes-download-form { flex-wrap: wrap; }
	.redeem-codes-download-coins { width: 100%; }
	.players-mgmt-toolbar { flex-direction: column; align-items: stretch; }
	.players-mgmt-search { width: 100%; }
	.players-mgmt-search-input { width: 100%; }
	.modal-dialog { margin: 0.5rem; max-width: calc(100% - 1rem); }
	.players-hwid-detail-modal .modal-dialog { max-width: calc(100% - 1rem); }
}

/* Handy */
@media (max-width: 576px) {
	.page { padding: 10px 8px 24px; }
	.navbar-inner { flex-direction: column; padding: 8px; gap: 4px; }
	.nav-group { justify-content: center; width: 100%; }
	.nav-group.left, .nav-group.right { margin: 0; }
	.navbar.shinra-navbar .nav-link {
		height: 42px; min-height: 42px;
		padding: 0 8px; font-size: 9px; letter-spacing: 0.5px;
		border-left: none;
		flex: 1; min-width: 0; justify-content: center;
	}
	.nav-group.right > a:last-child { border-right: none; }
	.shinra-logo .logo-svg { max-width: 220px; }
	.row.mb-6.py-4 { padding-top: 1rem !important; padding-bottom: 1rem !important; }
	/* User Panel / Login auf Mobile lesbar und gut tippbar */
	.box-body { padding: 1rem; font-size: 14px; }
	.field-input { min-height: 44px; padding: 0.6rem 0.75rem; font-size: 16px; }
	.page .login-btn { min-height: 44px; padding: 0.65rem 1rem; font-size: 1rem; width: 100%; }
	.box-body-links a { min-height: 44px; padding: 0.6rem 0.75rem; display: flex; align-items: center; }
	.admin-dashboard-sidebar-nav { justify-content: center; }
	.admin-dash-link { padding: 0.5rem 0.65rem; font-size: 0.8rem; }
	.admin-dash-link i { margin: 0; }
	.redeem-codes-title { font-size: 1.25rem; }
	.redeem-codes-form-row { grid-template-columns: 1fr; }
	.redeem-codes-kpis { grid-template-columns: 1fr 1fr; gap: 0.5rem; }
	.redeem-kpi-card { padding: 0.75rem 0.5rem; }
	.redeem-kpi-value { font-size: 1.1rem; }
	.redeem-kpi-label { font-size: 0.7rem; }
	.players-mgmt-title { font-size: 1.25rem; }
	.players-mgmt-kpis { grid-template-columns: 1fr 1fr; gap: 0.5rem; }
	.players-kpi-card { padding: 0.75rem 0.5rem; }
	.players-kpi-value { font-size: 1.1rem; }
	.players-kpi-label { font-size: 0.7rem; }
	.players-mgmt-table-wrap { max-height: 360px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
	.players-mgmt-table { font-size: 0.8rem; min-width: 520px; }
	.players-actions-cell .players-btn { min-width: 36px; min-height: 36px; padding: 0.4rem; }
	.redeem-codes-table-wrap { max-height: 360px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
	.redeem-codes-table { font-size: 0.8rem; min-width: 480px; }
	.players-mgmt-pagination { flex-direction: column; align-items: stretch; text-align: center; }
	.players-mgmt-pagination-links { justify-content: center; }
	.players-hwid-detail-dl { grid-template-columns: 80px 1fr; font-size: 0.85rem; }
	.players-hwid-detail-footer { flex-direction: column; align-items: stretch; }
	.players-hwid-detail-footer .players-btn-close { width: 100%; }
}

/* Sehr kleines Handy */
@media (max-width: 400px) {
	.page { padding: 8px 6px 20px; }
	.navbar.shinra-navbar .nav-link { font-size: 8px; padding: 0 6px; }
	.shinra-logo .logo-svg { max-width: 180px; }
	.admin-dashboard-logo-text { font-size: 0.9rem; }
	.redeem-codes-submit { width: 100%; }
	.players-mgmt-search-btn { width: 100%; }
	.redeem-codes-download-btn { width: 100%; }
}
