/**
 * DME Community - gemeinsame CSS-Variablen und Basis-Utilities (Guides-Palette, dunkel).
 * Von allen Modul-Stylesheets als Dependency genutzt (Handle: dmc-community).
 *
 * Wrapper-Klasse: .dmc  -> jedes Modul rendert seinen Frontend-Output in einem
 * Element mit class="dmc ..." damit die Variablen/Resets greifen.
 */

.dmc {
	/* Guides-Palette */
	--dmc-accent: #45f882;
	--dmc-accent-dim: rgba(69, 248, 130, 0.18);
	--dmc-gold: #ffbe18;
	--dmc-bg: #0b0e13;
	--dmc-bg2: #0f161b;
	--dmc-card: #22292f;
	--dmc-border: #22292f;
	--dmc-muted: #adb0bc;
	--dmc-red: #ff5050;
	--dmc-blue: #4d8cff;
	--dmc-text: #e8eaed;

	--dmc-radius: 4px;
	--dmc-glow: 0 0 0 1px rgba(69, 248, 130, 0.12), 0 8px 28px rgba(0, 0, 0, 0.45);
	--dmc-gap: 16px;

	color: var(--dmc-text);
	font: inherit;
	line-height: 1.55;
	box-sizing: border-box;
}

.dmc *,
.dmc *::before,
.dmc *::after {
	box-sizing: border-box;
}

/* Layout-Container */
.dmc-wrap {
	background: var(--dmc-bg);
	border: 1px solid var(--dmc-border);
	border-radius: var(--dmc-radius);
	padding: 20px;
	box-shadow: var(--dmc-glow);
}

/* Cards */
.dmc-card {
	background: var(--dmc-bg2);
	border: 1px solid var(--dmc-border);
	border-radius: var(--dmc-radius);
	padding: 16px;
}

.dmc-card + .dmc-card {
	margin-top: 12px;
}

/* Headings / muted text */
.dmc h1,
.dmc h2,
.dmc h3 {
	color: var(--dmc-text);
	margin: 0 0 12px;
	font-weight: 700;
}

.dmc-muted {
	color: var(--dmc-muted);
}

.dmc-accent {
	color: var(--dmc-accent);
}

.dmc-gold {
	color: var(--dmc-gold);
}

.dmc a {
	color: var(--dmc-accent);
	text-decoration: none;
}

.dmc a:hover {
	text-decoration: underline;
}

/* Buttons */
.dmc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 8px 16px;
	border: 1px solid var(--dmc-border);
	border-radius: var(--dmc-radius);
	background: var(--dmc-card);
	/* Textfarbe + kein Unterstrich gegen Theme-Link-Styles erzwingen (Lesbarkeit). */
	color: var(--dmc-text) !important;
	font: inherit;
	font-weight: 600;
	cursor: pointer;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
	text-decoration: none !important;
	line-height: 1.2;
}

.dmc-btn:hover, .dmc-btn:focus {
	border-color: var(--dmc-accent);
	text-decoration: none !important;
}

.dmc-btn-primary,
.dmc-btn-primary:hover,
.dmc-btn-primary:focus {
	background: var(--dmc-accent);
	border-color: var(--dmc-accent);
	color: #06210f !important; /* dunkler Text auf Gruen, immer lesbar */
}

.dmc-btn-primary:hover {
	box-shadow: 0 0 0 3px var(--dmc-accent-dim);
}

.dmc-btn-danger,
.dmc-btn-danger:hover,
.dmc-btn-danger:focus {
	border-color: var(--dmc-red);
	color: var(--dmc-red) !important;
}

.dmc-btn-danger:hover {
	background: rgba(255, 80, 80, 0.12);
}

.dmc-btn[disabled],
.dmc-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Form-Felder */
.dmc-input,
.dmc-textarea,
.dmc-select {
	width: 100%;
	padding: 9px 12px;
	background: var(--dmc-bg);
	border: 1px solid var(--dmc-border);
	border-radius: var(--dmc-radius);
	color: var(--dmc-text);
	font: inherit;
}

.dmc-input:focus,
.dmc-textarea:focus,
.dmc-select:focus {
	outline: none;
	border-color: var(--dmc-accent);
	box-shadow: 0 0 0 3px var(--dmc-accent-dim);
}

.dmc-textarea {
	min-height: 120px;
	resize: vertical;
}

.dmc-field {
	margin-bottom: 14px;
}

.dmc-field label {
	display: block;
	margin-bottom: 6px;
	color: var(--dmc-muted);
	font-weight: 600;
	font-size: 0.9em;
}

/* Status-Pills */
.dmc-pill {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: 0.78em;
	font-weight: 700;
	background: var(--dmc-card);
	color: var(--dmc-muted);
	border: 1px solid var(--dmc-border);
}

.dmc-pill-accent {
	color: var(--dmc-accent);
	border-color: var(--dmc-accent);
}

.dmc-pill-gold {
	color: var(--dmc-gold);
	border-color: var(--dmc-gold);
}

.dmc-pill-red {
	color: var(--dmc-red);
	border-color: var(--dmc-red);
}

.dmc-pill-blue {
	color: var(--dmc-blue);
	border-color: var(--dmc-blue);
}

/* Ungelesen-/Counter-Badge */
.dmc-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 999px;
	background: var(--dmc-red);
	color: #fff;
	font-size: 0.72em;
	font-weight: 700;
	line-height: 1;
}

/* Toast / Inline-Meldungen */
.dmc-toast-host {
	position: fixed;
	right: 18px;
	bottom: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	z-index: 99999;
}

.dmc-toast {
	background: var(--dmc-bg2);
	border: 1px solid var(--dmc-border);
	border-left: 3px solid var(--dmc-accent);
	border-radius: var(--dmc-radius);
	padding: 12px 16px;
	color: var(--dmc-text);
	box-shadow: var(--dmc-glow);
	max-width: 340px;
	animation: dmc-toast-in 0.18s ease;
}

.dmc-toast-error {
	border-left-color: var(--dmc-red);
}

@keyframes dmc-toast-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

.dmc-notice {
	border-radius: var(--dmc-radius);
	padding: 10px 14px;
	margin: 10px 0;
	border: 1px solid var(--dmc-border);
	background: var(--dmc-bg2);
}

.dmc-notice-error {
	border-color: var(--dmc-red);
	color: var(--dmc-red);
}

.dmc-notice-ok {
	border-color: var(--dmc-accent);
	color: var(--dmc-accent);
}

/* Helfer */
.dmc-hidden { display: none !important; }
.dmc-flex { display: flex; gap: var(--dmc-gap); }
.dmc-flex-between { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.dmc-grid { display: grid; gap: var(--dmc-gap); }
