/* ==========================================================================
   Darkframe Community — Frontend CSS
   Uses the site's design tokens (--df-*) from the Darkframe Studio theme.
   Plugin-specific vars use --dfc- prefix only where no theme token exists.
   ========================================================================== */

/* --- Container ------------------------------------------------------------ */
/* df-wrap provides horizontal padding; we add vertical here. */
.dfc-community {
	padding-top: 2.5rem;
	padding-bottom: 3.5rem;
}

/* --- Community header ----------------------------------------------------- */
.dfc-community__header {
	margin-bottom: 2.5rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--df-border-mid, #2a2a2a);
}
.dfc-community__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--df-text-bright, #f0f0f0);
	margin: 0 0 0.4rem;
}
.dfc-community__title::before {
	content: '> ';
	color: var(--df-accent, #00ff41);
}
.dfc-community__tagline {
	color: var(--df-text-muted, #9a9a9a);
	font-size: 0.9rem;
	margin: 0 0 1.25rem;
}

/* --- Search --------------------------------------------------------------- */
.dfc-search-form {
	display: flex;
	gap: 8px;
	max-width: 520px;
}
.dfc-search-form__input {
	flex: 1;
	padding: 0.55em 0.9em;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text, #d0d0d0);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	transition: border-color var(--df-transition, 0.18s ease);
}
.dfc-search-form__input:focus {
	outline: none;
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
}
.dfc-search-form__input::placeholder {
	color: var(--df-text-dim, #6a6a6a);
}

/* --- Space grid ----------------------------------------------------------- */
.dfc-space-grid {
	display: grid;
	gap: 6px;
}

/* --- Space card ----------------------------------------------------------- */
.dfc-space-card {
	display: flex;
	align-items: flex-start;
	gap: 1.1rem;
	padding: 1.25rem 1.4rem;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	transition: border-color var(--df-transition, 0.18s ease), background var(--df-transition, 0.18s ease);
}
.dfc-space-card:hover:not(.dfc-space-card--locked) {
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	background: var(--df-bg-raised, #141414);
}
.dfc-space-card--locked {
	opacity: 0.6;
	cursor: default;
}
.dfc-space-card--archived {
	opacity: 0.4;
}
.dfc-space-card__icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	background: var(--df-bg, #080808);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	overflow: hidden;
}
.dfc-space-card__thumb {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.dfc-space-card__body {
	flex: 1;
	min-width: 0;
}
.dfc-space-card__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	margin: 0 0 5px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.dfc-space-card__title a {
	color: var(--df-text-bright, #f0f0f0);
	text-decoration: none;
}
.dfc-space-card__title a:hover {
	color: var(--df-accent, #00ff41);
}
.dfc-space-card__description {
	color: var(--df-text-muted, #9a9a9a);
	font-size: 0.875rem;
	line-height: 1.55;
	margin: 0 0 9px;
}
.dfc-space-card__meta {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	font-size: 0.78rem;
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
}
.dfc-space-card__lock {
	flex-shrink: 0;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 12px;
	color: var(--df-text-dim, #6a6a6a);
	font-size: 1rem;
	padding-left: 1rem;
	border-left: 1px solid var(--df-border-mid, #2a2a2a);
	align-self: center;
}

/* --- Breadcrumb ----------------------------------------------------------- */
.dfc-breadcrumb {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.78rem;
	color: var(--df-text-dim, #6a6a6a);
	margin-bottom: 1.5rem;
	display: flex;
	align-items: center;
	gap: 6px;
	letter-spacing: 0.04em;
}
.dfc-breadcrumb a {
	color: var(--df-text-muted, #9a9a9a);
	text-decoration: none;
}
.dfc-breadcrumb a:hover {
	color: var(--df-accent, #00ff41);
}
.dfc-breadcrumb__sep {
	opacity: 0.3;
}

/* --- Space header --------------------------------------------------------- */
.dfc-space__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: 1.75rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--df-border-mid, #2a2a2a);
}
.dfc-space__header-content { flex: 1; }
.dfc-space__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--df-text-bright, #f0f0f0);
	margin: 0 0 8px;
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}
.dfc-space__description {
	color: var(--df-text-muted, #9a9a9a);
	font-size: 0.88rem;
	margin-bottom: 10px;
}
.dfc-space__meta { display: flex; gap: 6px; }
.dfc-space__actions { flex-shrink: 0; }

/* --- Space toolbar (search row) ------------------------------------------ */
.dfc-space-toolbar {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 1rem;
}
.dfc-space-search {
	flex: 1;
	max-width: 480px;
}
.dfc-space-search__input {
	flex: 1;
}
.dfc-search-label {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.8rem;
	color: var(--df-text-muted, #9a9a9a);
	margin: 0 0 0.75rem;
}
.dfc-search-label strong {
	color: var(--df-accent, #00ff41);
	font-weight: 700;
}
.dfc-btn--xs {
	padding: 0.3em 0.75em;
	font-size: 0.72rem;
}
.dfc-btn--ghost {
	background: transparent;
	border-color: transparent;
	color: var(--df-text-dim, #6a6a6a);
	padding-inline: 0.6em;
}
.dfc-btn--ghost:hover {
	color: var(--df-error, #ff3c3c);
	background: transparent;
	border-color: transparent;
}

/* --- Topic list ----------------------------------------------------------- */
.dfc-topic-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}
.dfc-topic-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	transition: border-color var(--df-transition, 0.18s ease), background var(--df-transition, 0.18s ease);
}
.dfc-topic-item:hover {
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	background: var(--df-bg-raised, #141414);
}
.dfc-topic-item--pinned {
	border-left: 2px solid var(--df-accent, #00ff41);
}
.dfc-topic-item--locked { opacity: 0.65; }
.dfc-topic-item__status {
	display: flex;
	gap: 4px;
	font-size: 0.75rem;
	flex-shrink: 0;
}
.dfc-topic-item__main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.dfc-topic-item__title {
	display: block;
	font-family: var(--df-font-mono, monospace);
	font-size: 0.93rem;
	font-weight: 700;
	color: var(--df-text-bright, #f0f0f0);
	text-decoration: none;
	margin-bottom: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.dfc-topic-item__title:hover { color: var(--df-accent, #00ff41); }
.dfc-topic-item__author {
	font-size: 0.78rem;
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
}
.dfc-topic-item__stats {
	flex-shrink: 0;
	text-align: right;
	font-size: 0.78rem;
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	min-width: 64px;
}
.dfc-topic-item__replies { display: block; font-weight: 700; color: var(--df-text-bright, #f0f0f0); }
.dfc-topic-item__last-reply { display: block; font-size: 0.72rem; }

/* --- Single topic --------------------------------------------------------- */
.dfc-topic__header {
	margin-bottom: 1.5rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--df-border-mid, #2a2a2a);
}
.dfc-topic__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: var(--df-text-bright, #f0f0f0);
	margin: 0 0 8px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.dfc-topic__byline {
	font-size: 0.82rem;
	color: var(--df-text-muted, #9a9a9a);
	display: flex;
	gap: 14px;
	font-family: var(--df-font-mono, monospace);
	flex-wrap: wrap;
}
.dfc-topic__body {
	margin-bottom: 2.5rem;
	line-height: 1.85;
	color: var(--df-text, #d0d0d0);
	font-size: 0.95rem;
	padding: 1.25rem 1.5rem;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
}
.dfc-topic__body p { margin: 0 0 1rem; }
.dfc-topic__body p:last-child { margin-bottom: 0; }
.dfc-topic__body code {
	background: var(--df-bg, #080808);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	padding: 2px 6px;
	border-radius: var(--df-radius, 2px);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85em;
	color: var(--df-accent, #00ff41);
}
.dfc-topic__body pre {
	background: var(--df-bg, #080808);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	padding: 1rem;
	border-radius: var(--df-radius, 2px);
	overflow-x: auto;
}
.dfc-topic__body blockquote {
	border-left: 2px solid var(--df-accent, #00ff41);
	margin: 0 0 1rem;
	padding-left: 1rem;
	color: var(--df-text-muted, #9a9a9a);
}

/* --- Replies -------------------------------------------------------------- */
.dfc-replies { margin-top: 2.5rem; }
.dfc-replies__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--df-text-muted, #9a9a9a);
	margin: 0 0 1.25rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--df-border-mid, #2a2a2a);
}
.dfc-reply-list { display: flex; flex-direction: column; gap: 8px; }
.dfc-reply {
	padding: 1.1rem 1.25rem;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	margin-bottom: 0;
}
.dfc-reply:hover {
	border-color: var(--df-border-accent, rgba(0,255,65,0.2));
}
.dfc-reply__meta {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 0.9rem;
}
.dfc-avatar {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--df-accent-glow, rgba(0,255,65,0.12));
	border: 1px solid var(--df-border-accent, rgba(0,255,65,0.3));
	border-radius: var(--df-radius, 2px);
	color: var(--df-accent, #00ff41);
	font-family: var(--df-font-mono, monospace);
	font-weight: 700;
	font-size: 0.95rem;
	letter-spacing: 0;
	user-select: none;
}
.dfc-reply__author-info { flex: 1; }
.dfc-reply__author {
	font-family: var(--df-font-mono, monospace);
	font-weight: 700;
	font-size: 0.82rem;
	color: var(--df-accent, #00ff41);
	display: block;
}
.dfc-reply__date {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.75rem;
	color: var(--df-text-dim, #6a6a6a);
}
.dfc-reply__content {
	line-height: 1.75;
	color: var(--df-text, #d0d0d0);
	font-size: 0.92rem;
}
.dfc-reply__content p { margin: 0 0 0.6rem; }
.dfc-reply__content p:last-child { margin-bottom: 0; }
.dfc-reply__mod-actions { margin-left: auto; }

/* --- Moderation ----------------------------------------------------------- */
.dfc-topic__mod-actions {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-top: 10px;
}
.dfc-mod-btn {
	padding: 3px 10px;
	font-size: 0.72rem;
	font-family: var(--df-font-mono, monospace);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	background: var(--df-bg, #080808);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text-muted, #9a9a9a);
	cursor: pointer;
	transition: all var(--df-transition, 0.18s ease);
}
.dfc-mod-btn:hover {
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	color: var(--df-accent, #00ff41);
}
.dfc-mod-btn--danger { color: var(--df-error, #ff3c3c); border-color: var(--df-error, #ff3c3c); }
.dfc-mod-btn--danger:hover { background: var(--df-error-bg, rgba(255,60,60,0.08)); }

/* --- Locked panel --------------------------------------------------------- */
.dfc-locked-panel {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	padding: 1.5rem;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	margin: 1.5rem 0;
}
.dfc-locked-panel__icon {
	font-size: 1.5rem;
	flex-shrink: 0;
	margin-top: 2px;
	filter: grayscale(0.4);
}
.dfc-locked-panel__content { flex: 1; }
.dfc-locked-panel__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--df-text-bright, #f0f0f0);
	margin: 0 0 6px;
}
.dfc-locked-panel__message {
	color: var(--df-text-muted, #9a9a9a);
	font-size: 0.88rem;
	margin: 0 0 1rem;
}
.dfc-locked-panel__actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* --- Icon spans in topic list --------------------------------------------- */
.dfc-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 5px 0;
	font-size: 0.85rem;
	line-height: 1;
	border-radius: var(--df-radius, 2px);
}

/* --- Badges --------------------------------------------------------------- */
.dfc-badge {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 1px 7px;
	border-radius: var(--df-radius, 2px);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	white-space: nowrap;
}
.dfc-badge--access {
	background: transparent;
	color: var(--df-text-dim, #6a6a6a);
	border: none;
	padding: 0;
	font-size: 0.78rem;
	letter-spacing: 0;
	text-transform: none;
	font-weight: 400;
}
.dfc-badge--pin {
	background: rgba(0,255,65,0.08);
	color: var(--df-accent, #00ff41);
	border: 1px solid rgba(0,255,65,0.25);
}
.dfc-badge--lock {
	background: var(--df-error-bg, rgba(255,60,60,0.08));
	color: var(--df-error, #ff3c3c);
	border: 1px solid rgba(255,60,60,0.3);
}
.dfc-badge--spoiler {
	background: rgba(255,165,0,0.1);
	color: #ffa500;
	border: 1px solid rgba(255,165,0,0.3);
}
.dfc-badge--archived {
	background: transparent;
	color: var(--df-text-dim, #6a6a6a);
	border: 1px solid var(--df-border-mid, #2a2a2a);
}

/* --- Editor toolbar ------------------------------------------------------- */
.dfc-editor {
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	overflow: hidden;
	transition: border-color var(--df-transition, 0.18s ease);
}
.dfc-editor:focus-within {
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	box-shadow: 0 0 0 2px var(--df-accent-glow, rgba(0,255,65,0.1));
}
.dfc-editor-toolbar {
	display: flex;
	align-items: center;
	gap: 2px;
	padding: 6px 8px;
	background: var(--df-bg, #080808);
	border-bottom: 1px solid var(--df-border-mid, #2a2a2a);
	flex-wrap: wrap;
}
.dfc-toolbar-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 28px;
	height: 26px;
	padding: 0 6px;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--df-radius, 2px);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.78rem;
	color: var(--df-text-muted, #9a9a9a);
	cursor: pointer;
	transition: color var(--df-transition, 0.18s ease),
	            background var(--df-transition, 0.18s ease),
	            border-color var(--df-transition, 0.18s ease);
	line-height: 1;
	white-space: nowrap;
}
.dfc-toolbar-btn strong { font-weight: 900; }
.dfc-toolbar-btn em     { font-style: italic; }
.dfc-toolbar-btn u      { text-decoration: underline; }
.dfc-toolbar-btn:hover {
	color: var(--df-accent, #00ff41);
	border-color: var(--df-border-accent, rgba(0,255,65,0.3));
	background: var(--df-accent-glow, rgba(0,255,65,0.07));
}
.dfc-toolbar-btn:active,
.dfc-toolbar-btn.is-active {
	background: var(--df-accent-glow, rgba(0,255,65,0.12));
	border-color: var(--df-border-accent, rgba(0,255,65,0.3));
	color: var(--df-accent, #00ff41);
}
.dfc-toolbar-sep {
	display: inline-block;
	width: 1px;
	height: 16px;
	background: var(--df-border-mid, #2a2a2a);
	margin: 0 4px;
	flex-shrink: 0;
}
/* Colour swatch button */
.dfc-toolbar-color-swatch {
	color: var(--df-accent, #00ff41);
	font-weight: 900;
	font-family: var(--df-font-mono, monospace);
	text-decoration: underline;
	text-decoration-color: var(--df-accent, #00ff41);
	text-decoration-thickness: 2px;
	text-underline-offset: 2px;
}
/* Contenteditable editor area */
.dfc-editor-content {
	width: 100%;
	padding: 0.6em 0.9em;
	background: var(--df-bg, #080808);
	color: var(--df-text, #d0d0d0);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.88rem;
	line-height: 1.65;
	min-height: 120px;
	box-sizing: border-box;
	outline: none;
	cursor: text;
	overflow-y: auto;
	white-space: pre-wrap;
	word-wrap: break-word;
}
/* Taller for topic body */
.dfc-topic-form .dfc-editor-content { min-height: 200px; }
/* Placeholder via CSS */
.dfc-editor-content:empty::before {
	content: attr(data-placeholder);
	color: var(--df-text-dim, #6a6a6a);
	pointer-events: none;
}
/* Rich content styling inside the editor — mirrors frontend render styles */
.dfc-editor-content strong,
.dfc-editor-content b      { font-weight: 700; }
.dfc-editor-content em,
.dfc-editor-content i      { font-style: italic; }
.dfc-editor-content u      { text-decoration: underline; }
.dfc-editor-content code   {
	background: rgba(0,255,65,0.05);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	padding: 1px 5px;
	border-radius: 2px;
	font-size: 0.9em;
	color: var(--df-accent, #00ff41);
}
.dfc-editor-content blockquote {
	border-left: 2px solid var(--df-accent, #00ff41);
	margin: 4px 0;
	padding-left: 10px;
	color: var(--df-text-muted, #9a9a9a);
}
.dfc-editor-content ul,
.dfc-editor-content ol { padding-left: 1.5em; margin: 4px 0; }
.dfc-editor-content a  { color: var(--df-accent, #00ff41); }
/* Error state */
.dfc-editor-content.dfc-editor--error {
	background: rgba(255,60,60,0.04);
}

/* --- Forms ---------------------------------------------------------------- */
.dfc-form-wrap {
	margin-top: 2rem;
	padding: 1.5rem;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
}
.dfc-form-wrap__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--df-text-bright, #f0f0f0);
	margin: 0 0 1.25rem;
}
.dfc-form-wrap__title::before {
	content: '> ';
	color: var(--df-accent, #00ff41);
}
.dfc-form__field { margin-bottom: 1rem; }
.dfc-form__field--inline { display: flex; align-items: center; gap: 8px; }
.dfc-form__label {
	display: block;
	font-family: var(--df-font-mono, monospace);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--df-text-muted, #9a9a9a);
	margin-bottom: 5px;
}
.dfc-form__input,
.dfc-form__textarea {
	width: 100%;
	padding: 0.6em 0.9em;
	background: var(--df-bg, #080808);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text, #d0d0d0);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.88rem;
	box-sizing: border-box;
	transition: border-color var(--df-transition, 0.18s ease);
}
.dfc-form__input:focus,
.dfc-form__textarea:focus {
	outline: none;
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	box-shadow: 0 0 0 2px var(--df-accent-glow, rgba(0,255,65,0.1));
}
.dfc-form__textarea { resize: vertical; min-height: 100px; }
.dfc-required { color: var(--df-error, #ff3c3c); margin-left: 2px; }
.dfc-form__actions { margin-top: 1.25rem; }
.dfc-tag-checkboxes { display: flex; flex-wrap: wrap; gap: 8px; }
.dfc-tag-label {
	display: flex;
	align-items: center;
	gap: 5px;
	font-family: var(--df-font-mono, monospace);
	font-size: 0.78rem;
	color: var(--df-text-muted, #9a9a9a);
	cursor: pointer;
}

/* --- Buttons -------------------------------------------------------------- */
.dfc-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	padding: 0.6em 1.4em;
	border: 1px solid transparent;
	border-radius: var(--df-radius, 2px);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	text-decoration: none;
	transition: color var(--df-transition, 0.18s ease),
	            background var(--df-transition, 0.18s ease),
	            border-color var(--df-transition, 0.18s ease),
	            box-shadow var(--df-transition, 0.18s ease);
	line-height: 1.2;
}
.dfc-btn--primary {
	background: var(--df-accent, #00ff41);
	border-color: var(--df-accent, #00ff41);
	color: #000;
}
.dfc-btn--primary:hover {
	background: var(--df-accent-dim, #00cc33);
	border-color: var(--df-accent-dim, #00cc33);
	color: #000;
	box-shadow: 0 0 12px var(--df-accent-glow2, rgba(0,255,65,0.3));
}
.dfc-btn--secondary {
	background: transparent;
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	color: var(--df-accent, #00ff41);
}
.dfc-btn--secondary:hover {
	background: var(--df-accent-glow, rgba(0,255,65,0.1));
	border-color: var(--df-accent, #00ff41);
}

/* --- Notices -------------------------------------------------------------- */
.dfc-notice {
	padding: 10px 14px;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.82rem;
	margin: 1.25rem 0;
}
.dfc-notice--locked {
	border-color: rgba(255,60,60,0.4);
	color: var(--df-error, #ff3c3c);
	background: var(--df-error-bg, rgba(255,60,60,0.08));
}
.dfc-notice--warning {
	border-color: rgba(255,165,0,0.4);
	color: #ffa500;
}
.dfc-notice a {
	color: var(--df-accent, #00ff41);
	text-decoration: none;
}
.dfc-notice a:hover { text-decoration: underline; }
.dfc-empty {
	text-align: center;
	color: var(--df-text-dim, #6a6a6a);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	padding: 3rem 1.5rem;
}
.dfc-empty::before { content: '// '; }

/* --- Spoiler -------------------------------------------------------------- */
.dfc-spoiler-warning {
	padding: 1.1rem;
	background: rgba(255,165,0,0.05);
	border: 1px solid rgba(255,165,0,0.25);
	border-radius: var(--df-radius, 2px);
	margin-bottom: 1.25rem;
	text-align: center;
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	color: #ffa500;
}

/* --- New topic form toggle ------------------------------------------------ */
.dfc-new-topic-form { margin-bottom: 1.75rem; }

/* --- Access notice on community index ------------------------------------- */
.dfc-access-notice {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.85rem 1.1rem;
	background: var(--df-bg-surface, #0f0f0f);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-left: 3px solid var(--df-border-accent, rgba(0,255,65,0.35));
	border-radius: var(--df-radius, 2px);
	margin-bottom: 1.5rem;
}
.dfc-access-notice__icon {
	flex-shrink: 0;
	font-size: 0.95rem;
	margin-top: 1px;
	opacity: 0.7;
}
.dfc-access-notice__text {
	margin: 0;
	font-family: var(--df-font-mono, monospace);
	font-size: 0.8rem;
	color: var(--df-text-muted, #9a9a9a);
	line-height: 1.55;
}
.dfc-access-notice__text a {
	color: var(--df-accent, #00ff41);
	text-decoration: none;
}
.dfc-access-notice__text a:hover { text-decoration: underline; }

/* --- Search results ------------------------------------------------------- */
.dfc-search-results { margin-top: 1.5rem; }
.dfc-section__title {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--df-text-muted, #9a9a9a);
	margin-bottom: 1rem;
}

/* --- Divider -------------------------------------------------------------- */
.dfc-topic-section { margin-top: 1.25rem; }

/* --- Responsive ----------------------------------------------------------- */
@media (max-width: 640px) {
	.dfc-space-card { flex-direction: column; }
	.dfc-space__header { flex-direction: column; }
	.dfc-topic-item { flex-wrap: wrap; }
	.dfc-topic-item__stats { text-align: left; width: 100%; }
	.dfc-locked-panel { flex-direction: column; }
	.dfc-search-form { max-width: 100%; }
}

/* --- File input & image preview ------------------------------------------- */
.dfc-form__label-hint {
	font-size: 0.72rem;
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	color: var(--df-text-dim, #6a6a6a);
	margin-left: 6px;
}
.dfc-file-input {
	display: block;
	width: 100%;
	padding: 0.5em 0.75em;
	background: var(--df-bg, #080808);
	border: 1px dashed var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.82rem;
	cursor: pointer;
	box-sizing: border-box;
	transition: border-color var(--df-transition, 0.18s ease);
}
.dfc-file-input:hover,
.dfc-file-input:focus {
	outline: none;
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
}
.dfc-image-preview {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 8px;
}
.dfc-image-preview img {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	display: block;
}

/* --- Attachments grid (in posts/replies) ---------------------------------- */
.dfc-attachments {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 1rem;
}
.dfc-attachments a {
	display: block;
	flex-shrink: 0;
	line-height: 0;
}
.dfc-attachments img {
	width: 100px;
	height: 100px;
	object-fit: cover;
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	transition: border-color var(--df-transition, 0.18s ease), opacity var(--df-transition, 0.18s ease);
	cursor: pointer;
}
.dfc-attachments img:hover {
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	opacity: 0.85;
}

/* --- Lightbox ------------------------------------------------------------- */
.dfc-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
	background: rgba(0, 0, 0, 0.93);
	display: flex;
	align-items: center;
	justify-content: center;
	animation: dfc-lb-fade-in 0.18s ease;
}
@keyframes dfc-lb-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}
.dfc-lightbox__img {
	max-width: 92vw;
	max-height: 88vh;
	object-fit: contain;
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	display: block;
}
.dfc-lightbox__caption {
	position: absolute;
	bottom: 1.5rem;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.78rem;
	color: var(--df-text-muted, #9a9a9a);
	white-space: nowrap;
	max-width: 80vw;
	overflow: hidden;
	text-overflow: ellipsis;
}
.dfc-lightbox__close {
	position: absolute;
	top: 1rem;
	right: 1.25rem;
	background: none;
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	font-size: 1rem;
	line-height: 1;
	padding: 4px 10px;
	cursor: pointer;
	transition: color var(--df-transition, 0.18s ease), border-color var(--df-transition, 0.18s ease);
}
.dfc-lightbox__close:hover {
	color: var(--df-accent, #00ff41);
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
}
.dfc-lightbox__prev,
.dfc-lightbox__next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(0, 0, 0, 0.5);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	font-size: 1.1rem;
	padding: 8px 14px;
	cursor: pointer;
	transition: color var(--df-transition, 0.18s ease), border-color var(--df-transition, 0.18s ease);
}
.dfc-lightbox__prev { left: 1rem; }
.dfc-lightbox__next { right: 1rem; }
.dfc-lightbox__prev:hover,
.dfc-lightbox__next:hover {
	color: var(--df-accent, #00ff41);
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
}

/* ==========================================================================
   Poll component
   ========================================================================== */

/* --- Poll display --------------------------------------------------------- */
.dfc-poll {
	background: var(--df-bg-card, #111);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	padding: 1.25rem 1.5rem;
	margin: 0 0 1.5rem;
}

.dfc-poll__header {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}

.dfc-poll__label {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--df-accent, #00ff41);
	border: 1px solid var(--df-border-accent, rgba(0,255,65,0.35));
	padding: 2px 8px;
	border-radius: var(--df-radius, 2px);
}

.dfc-poll__closed {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--df-text-muted, #9a9a9a);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	padding: 2px 8px;
	border-radius: var(--df-radius, 2px);
}

.dfc-poll__closes {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.72rem;
	color: var(--df-text-muted, #9a9a9a);
}

.dfc-poll__question {
	font-size: 1rem;
	font-weight: 600;
	color: var(--df-text-primary, #e8e8e8);
	margin: 0 0 1rem;
}

/* --- Voting form ---------------------------------------------------------- */
.dfc-poll__form {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.dfc-poll__option {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	cursor: pointer;
	transition: border-color var(--df-transition, 0.18s ease), background var(--df-transition, 0.18s ease);
}

.dfc-poll__option:hover {
	border-color: var(--df-border-accent, rgba(0,255,65,0.35));
	background: rgba(0,255,65,0.04);
}

.dfc-poll__option:has(.dfc-poll__input:checked) {
	border-color: var(--df-accent, #00ff41);
	background: rgba(0,255,65,0.06);
}

.dfc-poll__input {
	accent-color: var(--df-accent, #00ff41);
	width: 15px;
	height: 15px;
	flex-shrink: 0;
	cursor: pointer;
}

.dfc-poll__option-label {
	font-size: 0.9rem;
	color: var(--df-text-primary, #e8e8e8);
	line-height: 1.3;
}

.dfc-poll__vote-btn {
	margin-top: 0.5rem;
	align-self: flex-start;
}

.dfc-poll__view-results {
	background: none;
	border: none;
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.78rem;
	cursor: pointer;
	padding: 0;
	margin-top: 0.25rem;
	text-decoration: underline;
	align-self: flex-start;
	transition: color var(--df-transition, 0.18s ease);
}

.dfc-poll__view-results:hover {
	color: var(--df-text-primary, #e8e8e8);
}

/* --- Results view --------------------------------------------------------- */
.dfc-poll__results {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

.dfc-poll__result-row {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	gap: 0.25rem 0.75rem;
	align-items: center;
}

.dfc-poll__result-label {
	grid-column: 1;
	grid-row: 1;
	font-size: 0.88rem;
	color: var(--df-text-primary, #e8e8e8);
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.dfc-poll__result-row--chosen .dfc-poll__result-label {
	color: var(--df-accent, #00ff41);
}

.dfc-poll__checkmark {
	font-size: 0.75rem;
	color: var(--df-accent, #00ff41);
}

.dfc-poll__bar-wrap {
	grid-column: 1;
	grid-row: 2;
	background: var(--df-bg-card, #111);
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: 1px;
	height: 6px;
	overflow: hidden;
}

.dfc-poll__bar {
	height: 100%;
	background: var(--df-accent, #00ff41);
	opacity: 0.7;
	transition: width 0.4s ease;
	min-width: 0;
}

.dfc-poll__result-row--chosen .dfc-poll__bar {
	opacity: 1;
}

.dfc-poll__result-meta {
	grid-column: 2;
	grid-row: 1 / 3;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 1px;
}

.dfc-poll__percent {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--df-text-primary, #e8e8e8);
}

.dfc-poll__result-row--chosen .dfc-poll__percent {
	color: var(--df-accent, #00ff41);
}

.dfc-poll__votes {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.7rem;
	color: var(--df-text-muted, #9a9a9a);
	white-space: nowrap;
}

.dfc-poll__total {
	font-family: var(--df-font-mono, monospace);
	font-size: 0.72rem;
	color: var(--df-text-muted, #9a9a9a);
	margin: 0.25rem 0 0;
	border-top: 1px solid var(--df-border-mid, #2a2a2a);
	padding-top: 0.5rem;
}

.dfc-poll__change-vote {
	background: none;
	border: none;
	color: var(--df-text-muted, #9a9a9a);
	font-family: var(--df-font-mono, monospace);
	font-size: 0.75rem;
	cursor: pointer;
	padding: 0;
	text-decoration: underline;
	transition: color var(--df-transition, 0.18s ease);
}

.dfc-poll__change-vote:hover {
	color: var(--df-text-primary, #e8e8e8);
}

/* --- Poll builder (topic form) -------------------------------------------- */
.dfc-poll-builder {
	margin-top: 0.5rem;
}

.dfc-poll-builder__inner {
	border: 1px solid var(--df-border-accent, rgba(0,255,65,0.2));
	border-radius: var(--df-radius, 2px);
	padding: 1.25rem;
	background: rgba(0,255,65,0.02);
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.dfc-poll-builder__inner .dfc-form__field {
	margin-bottom: 0;
}

.dfc-poll-option-row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.dfc-poll-option-row:last-child {
	margin-bottom: 0;
}

.dfc-poll-option-input {
	flex: 1;
}

.dfc-poll-remove-option {
	background: none;
	border: 1px solid var(--df-border-mid, #2a2a2a);
	border-radius: var(--df-radius, 2px);
	color: var(--df-text-muted, #9a9a9a);
	font-size: 1rem;
	line-height: 1;
	padding: 4px 8px;
	cursor: pointer;
	flex-shrink: 0;
	transition: color var(--df-transition, 0.18s ease), border-color var(--df-transition, 0.18s ease);
}

.dfc-poll-remove-option:hover {
	color: #ff4444;
	border-color: rgba(255,68,68,0.4);
}

.dfc-form__input--datetime {
	color-scheme: dark;
}

/* =====================================================================
   Reply actions bar (likes + report)
   ===================================================================== */

.dfc-reply__actions {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.5rem;
	padding-top: 0.5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.dfc-reply__like-btn,
.dfc-reply__report-btn {
	background: none;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 4px;
	color: var(--dfc-text-muted, #888);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.75rem;
	line-height: 1;
	padding: 0.25rem 0.6rem;
	transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.dfc-reply__like-btn:hover:not(:disabled) {
	border-color: #e05c8a;
	color: #e05c8a;
}

.dfc-reply__like-btn--liked {
	border-color: #e05c8a;
	color: #e05c8a;
}

.dfc-like-icon {
	font-size: 0.85em;
}

.dfc-reply__report-btn {
	margin-left: auto; /* Push report to far right */
	font-size: 0.7rem;
	opacity: 0.45;
}

.dfc-reply__report-btn:hover:not(:disabled) {
	border-color: #d63638;
	color: #d63638;
	opacity: 1;
}

.dfc-reply__report-btn--reported,
.dfc-reply__report-btn[disabled] {
	opacity: 0.35;
	cursor: default;
}
