/* ============================================
   LA MIDNIGHT - ONLINE TODAY PLUGIN
   Theme: BRUTALIST

   Spacing/Colors via Design-Tokens aus 00-settings.css
   Stil-Vorlage: .lam-idx-online (WOL-Block in index.css)

   Klassen-Strategie:
   - .lam-idx-onlinetoday* → BRUTALIST-spezifisches Layout
     (wird über die Theme-Override-Templates aktiviert)
   - .avatarep_*, .ot_*    → Fallback für nicht-überschriebene Templates,
     damit das Plugin auch ohne Theme-Override sauber rendert

   Theme-Templates (in templates/onlinetoday/):
   - online_today_index           → Container-Box (analog zum WOL-Block)
   - online_today_rows / _nor     → User-Items
   - online_today_bot_row / _nor  → Bot-Items
   - online_today_status_*        → Status-Indikator (kleiner Punkt)
   ============================================ */


/* ============================================
   BRUTALIST-CONTAINER (Theme-Template)
   Renderbox für die Online-Today-Anzeige auf der Index-Seite,
   exakt analog zur ONLINE NOW Box (.lam-idx-online).
   ============================================ */

/* Wrapper-Box: Flex-Layout mit Akzent-Border links */
.lam-idx-onlinetoday {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-md) var(--space-xl);
	padding: var(--space-lg) var(--space-xl);
	background: rgba(255, 68, 34, 0.03);
	border-left: 2px solid var(--accent);
	position: relative;
	z-index: 1;
	margin-top: var(--space-md);
}

/* Mono-Label oben links – ersetzt das fette {$lang->online_title} im Original */
.lam-idx-onlinetoday__label {
	font-family: var(--font-mono);
	font-size: 0.6rem;
	color: var(--accent);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	white-space: nowrap;
}

/* User-Liste – flex-grow, Trennung kommt aus dem Plugin (Komma im profilelink) */
.lam-idx-onlinetoday__users {
	flex: 1;
	min-width: 0;
	font-size: 0.85rem;
	color: var(--text-dim);
	line-height: 1.6;
}

/* User-Profil-Links innerhalb der Liste */
.lam-idx-onlinetoday__users a {
	color: var(--text-dim);
	transition: color 0.2s;
}

.lam-idx-onlinetoday__users a:hover {
	color: var(--accent);
}

/* "View full list"-Link rechts oben */
.lam-idx-onlinetoday__more {
	font-family: var(--font-mono);
	font-size: 0.65rem;
	color: var(--text-dark);
}

.lam-idx-onlinetoday__more a {
	color: inherit;
	border-bottom: 1px solid var(--text-dark);
	transition: all 0.2s;
}

.lam-idx-onlinetoday__more a:hover {
	color: var(--accent);
	border-color: var(--accent);
}

/* Mono-Detail-Zeile mit den Statistiken
   (X users since last 24 hours – Y members – Z guests) */
.lam-idx-onlinetoday__note {
	width: 100%;
	font-family: var(--font-mono);
	font-size: 0.55rem;
	color: var(--text-dim);
	letter-spacing: 0.1em;
	line-height: 1.6;
	margin-top: var(--space-xs);
	padding-top: var(--space-sm);
	border-top: 1px solid var(--text-dark);
}


/* ============================================
   BRUTALIST AVATAR-VARIANTE (Theme-Template)
   Wird gerendert wenn onlinetoday_avatars = 1.
   Avatar-Karten mit Status-Border und Mono-Username.
   ============================================ */

/* Einzelne Avatar-Karte */
.lam-idx-onlinetoday__avatar {
	position: relative;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-xs);
	padding: var(--space-xs);
	transition: var(--transition);
}

.lam-idx-onlinetoday__avatar:hover {
	background: rgba(255, 68, 34, 0.04);
}

/* Avatar-Bild – brutalistisch, ohne Rundung */
.lam-idx-onlinetoday__avatar-img {
	display: block;
	width: 64px;
	height: 64px;
	object-fit: cover;
	border: 1px solid var(--text-dark);
	background: var(--bg-card);
	transition: var(--transition);
}

.lam-idx-onlinetoday__avatar:hover .lam-idx-onlinetoday__avatar-img {
	border-color: var(--accent-dim);
}

/* Username unter dem Avatar – Mono, klein, uppercase */
.lam-idx-onlinetoday__avatar-name {
	font-family: var(--font-mono);
	font-size: 0.55rem;
	letter-spacing: 0.08em;
	text-align: center;
	color: var(--text-dim);
	max-width: 80px;
	line-height: 1.4;
	word-break: break-word;
}

.lam-idx-onlinetoday__avatar-name a {
	color: var(--text);
}

.lam-idx-onlinetoday__avatar-name a:hover {
	color: var(--accent);
}

/* Status-Border am Avatar – ot_online/ot_offline werden zusätzlich an
   .lam-idx-onlinetoday__avatar gehängt */
.lam-idx-onlinetoday__avatar.ot_online .lam-idx-onlinetoday__avatar-img {
	border-left: 3px solid var(--success);
}

.lam-idx-onlinetoday__avatar.ot_offline .lam-idx-onlinetoday__avatar-img {
	border-left: 3px solid var(--text-dark);
}


/* ============================================
   STATUS-INDIKATOR (Theme-Template)
   Kleiner Punkt rechts oben am Avatar – ersetzt
   die hässlichen MyBB-Standard-Buddy-Icons.
   ============================================ */

.lam-idx-onlinetoday__status {
	position: absolute;
	top: var(--space-xs);
	right: var(--space-xs);
	width: 6px;
	height: 6px;
	display: inline-block;
}

.lam-idx-onlinetoday__status--on {
	background: var(--success);
	box-shadow: 0 0 6px var(--success);
}

.lam-idx-onlinetoday__status--off {
	background: var(--text-dark);
}


/* ============================================
   FALLBACK: ORIGINAL PLUGIN-KLASSEN
   Werden gerendert wenn KEINE Theme-Override-Templates
   im ACP angelegt sind (also direkt das Master-Template
   aus dem Plugin zum Einsatz kommt). So bleibt die Anzeige
   überall sauber, auch ohne Template-Pflege.
   ============================================ */

/* User-Karte mit Avatar (Fallback) */
.avatarep_online_row {
	text-align: center;
	width: 100px;
	display: inline-block;
	padding: var(--space-xs) var(--space-sm);
	position: relative;
	transition: var(--transition);
}

.avatarep_online_row:hover {
	background: rgba(255, 68, 34, 0.02);
}

/* User-Liste ohne Avatar (Fallback) */
.avatarep_online_row_nor {
	display: inline-block;
	padding: 0 var(--space-xs);
}

/* Avatar-Bild (Fallback) */
.avatarep_image {
	display: block;
	width: 80px;
	height: 60px;
	border: 1px solid var(--text-dark);
	background: var(--bg-card);
	padding: var(--space-sm);
	border-radius: 0;
	transition: var(--transition);
}

.avatarep_online_row:hover .avatarep_image {
	border-color: var(--accent-dim);
}

/* Username unter dem Avatar (Fallback)
   FIX: display:block nur INNERHALB der Avatar-Variante – sonst bricht
   die Komma-Liste der no-avatar-Variante um (Bot-Layout-Bug). */
.avatarep_online_row .avatarep_span {
	text-align: center;
	display: block;
	margin-top: var(--space-xs);
	font-family: var(--font-mono);
	font-size: 0.6rem;
	letter-spacing: 0.1em;
	color: var(--text-dim);
	word-break: break-word;
	line-height: 1.4;
}

.avatarep_span a {
	color: var(--text);
	border-bottom: 1px solid transparent;
	transition: var(--transition);
}

.avatarep_span a:hover {
	color: var(--accent);
	border-bottom-color: var(--accent);
}

/* Username in no-avatar-Variante (Fallback) */
.avatarep_span_nor {
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.05em;
	color: var(--text);
}

.avatarep_span_nor a {
	color: var(--text);
	border-bottom: 1px solid transparent;
	transition: var(--transition);
}

.avatarep_span_nor a:hover {
	color: var(--accent);
	border-bottom-color: var(--accent);
}

/* Status-Icon (Fallback) – MyBB-Standard-Icon, dezent eingefärbt */
.ot_status_icon {
	position: absolute;
	margin-left: -20px;
	filter: grayscale(100%);
	opacity: 0.6;
	transition: var(--transition);
}

.avatarep_online_row:hover .ot_status_icon {
	opacity: 1;
}

/* Status-Border-Streifen (Fallback) */
.ot_online {
	border-left: 4px solid var(--success);
}

.ot_offline {
	border-left: 4px solid var(--text-dark);
}


/* ============================================
   RESPONSIVE
   ============================================ */

/* Tablet */
@media screen and (max-width: 768px) {
	/* Container kompakter */
	.lam-idx-onlinetoday {
		gap: var(--space-sm) var(--space-md);
		padding: var(--space-md) var(--space-lg);
	}

	/* Avatar-Karten kleiner */
	.lam-idx-onlinetoday__avatar-img {
		width: 48px;
		height: 48px;
	}

	/* Fallback-Avatare */
	.avatarep_online_row {
		width: 80px;
	}
	.avatarep_image {
		width: 64px;
		height: 48px;
		padding: var(--space-xs);
	}
}

/* Mobile */
@media screen and (max-width: 480px) {
	/* Container: alles untereinander */
	.lam-idx-onlinetoday {
		flex-direction: column;
		align-items: flex-start;
		padding: var(--space-md);
	}

	.lam-idx-onlinetoday__more {
		font-size: 0.6rem;
	}

	/* Avatar-Karten Mini-Modus */
	.lam-idx-onlinetoday__avatar-img {
		width: 32px;
		height: 32px;
	}

	.lam-idx-onlinetoday__avatar-name {
		display: none;
	}

	/* Fallback */
	.avatarep_online_row .avatarep_span {
		display: none;
	}
	.avatarep_online_row_nor {
		padding: 0 2px;
	}
	.avatarep_span_nor {
		font-size: 0.6rem;
		letter-spacing: 0.03em;
	}
	.avatarep_image {
		width: 32px;
		height: 24px;
		padding: 2px;
	}
	.avatarep_online_row {
		width: 36px;
		padding: 2px;
	}
	.ot_online,
	.ot_offline {
		border-left-width: 2px;
	}
	.ot_status_icon {
		display: none;
	}
}


/* ============================================
   LIGHT THEME
   ============================================ */

[data-theme="light"] .lam-idx-onlinetoday {
	background: rgba(255, 68, 34, 0.04);
}

[data-theme="light"] .lam-idx-onlinetoday__avatar:hover {
	background: rgba(255, 68, 34, 0.05);
}

[data-theme="light"] .lam-idx-onlinetoday__avatar-img {
	border-color: var(--border);
	background: var(--bg-card);
}

[data-theme="light"] .lam-idx-onlinetoday__avatar.ot_offline .lam-idx-onlinetoday__avatar-img {
	border-left-color: var(--border-light);
}

[data-theme="light"] .lam-idx-onlinetoday__status--off {
	background: var(--border-light);
}

/* Fallback */
[data-theme="light"] .avatarep_image {
	border-color: var(--border);
	background: var(--bg-card);
}

[data-theme="light"] .avatarep_online_row:hover {
	background: rgba(255, 68, 34, 0.03);
}

[data-theme="light"] .ot_offline {
	border-left-color: var(--border-light);
}