/* ═══════════════════════════════════════════
   Mod Pages — Viewer, Browser & Editor
   Theme-aware via CSS variables
   ═══════════════════════════════════════════ */

/* ── Loading / States ── */
.mp-loading { text-align: center; padding: 60px 20px; color: var(--text-muted); }
.mp-loading-spinner {
  width: 40px; height: 40px; margin: 0 auto 16px;
  border: 3px solid var(--border); border-top-color: var(--accent-cyan);
  border-radius: 50%; animation: mp-spin 0.8s linear infinite;
}
@keyframes mp-spin { to { transform: rotate(360deg); } }

.mp-not-found, .mp-guest-card, .mp-banned-card {
  text-align: center; padding: 60px 24px;
  background: var(--bg-card); border-radius: 12px;
  border: 1px solid var(--border);
}
.mp-nf-icon, .mp-guest-icon, .mp-banned-icon { font-size: 3rem; margin-bottom: 12px; }
.mp-not-found h2, .mp-guest-card h2, .mp-banned-card h2 { margin-bottom: 8px; color: var(--text-primary); }
.mp-not-found p, .mp-guest-card p, .mp-banned-card p { color: var(--text-muted); margin-bottom: 16px; }
.mp-banned-card { border-color: #e74c3c33; }
.mp-banned-icon { color: #e74c3c; }

/* ═══════════════════════════════════════════
   Mod Page Viewer
   ═══════════════════════════════════════════ */
.mp-article { background: var(--bg-card); border-radius: 12px; overflow: hidden; border: 1px solid var(--border); }

/* ── Page Theme System ── */
.mp-article[data-page-theme="crimson-flame"] {
  --page-accent: #ff4444; --page-accent2: #ff8800; --page-glow: rgba(255,68,68,.15);
  border-color: #ff444433;
}
.mp-article[data-page-theme="neon-green"] {
  --page-accent: #39ff7e; --page-accent2: #00b09b; --page-glow: rgba(57,255,126,.15);
  border-color: #39ff7e33;
}
.mp-article[data-page-theme="midnight-purple"] {
  --page-accent: #7b68ee; --page-accent2: #c084fc; --page-glow: rgba(123,104,238,.15);
  border-color: #7b68ee33;
}
.mp-article[data-page-theme="ocean-blue"] {
  --page-accent: #3178ff; --page-accent2: #00d2ff; --page-glow: rgba(49,120,255,.15);
  border-color: #3178ff33;
}
.mp-article[data-page-theme="sunset-pink"] {
  --page-accent: #ff6b9d; --page-accent2: #c084fc; --page-glow: rgba(255,107,157,.15);
  border-color: #ff6b9d33;
}
.mp-article[data-page-theme="dark-horror"] {
  --page-accent: #8b0000; --page-accent2: #4a0000; --page-glow: rgba(139,0,0,.2);
  border-color: #8b000044; background: #0d0d0d;
}
.mp-article[data-page-theme="golden-funk"] {
  --page-accent: #ffd700; --page-accent2: #ff8c00; --page-glow: rgba(255,215,0,.15);
  border-color: #ffd70033;
}

/* Themed elements pick up page-accent */
.mp-article[data-page-theme] .mp-title { color: var(--page-accent, var(--text-primary)); }
.mp-article[data-page-theme] .mp-author { color: var(--page-accent, var(--accent-cyan)); }
.mp-article[data-page-theme] .mp-body a { color: var(--page-accent, var(--accent-cyan)); }
.mp-article[data-page-theme] .mp-body h2 { border-bottom-color: var(--page-accent, var(--border)); }
.mp-article[data-page-theme] .mp-info-chip { border-color: var(--page-accent, var(--border)); }
.mp-article[data-page-theme] .mp-tag { border-color: var(--page-accent, var(--border)); }

/* Theme glow effect on article */
.mp-article[data-page-theme]:not([data-page-theme="default"]) {
  box-shadow: 0 0 40px var(--page-glow, transparent), 0 2px 8px rgba(0,0,0,.2);
}

/* Custom theme with inline CSS vars */
.mp-article[data-page-theme="custom"] {
  border-color: color-mix(in srgb, var(--page-accent, #4ecdc4) 30%, transparent);
}

/* Cover image */
.mp-cover-wrap { position: relative; width: 100%; height: 280px; overflow: hidden; background: var(--bg-sidebar); }
.mp-cover-img { width: 100%; height: 100%; object-fit: cover; }
.mp-cover-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 16px 24px;
  background: linear-gradient(transparent, rgba(0,0,0,.6));
  display: flex; align-items: flex-end;
}
.mp-category-badge {
  display: inline-block; padding: 4px 12px; border-radius: 20px;
  font-size: .75rem; font-weight: 700; text-transform: uppercase;
  color: #fff; letter-spacing: .04em;
}
.mp-category-badge[data-cat="full-week"] { background: var(--accent-cyan); }
.mp-category-badge[data-cat="oc"] { background: var(--accent-pink); }
.mp-category-badge[data-cat="horror"] { background: #8b5cf6; }
.mp-category-badge[data-cat="oneshot"] { background: var(--accent-orange); }
.mp-category-badge[data-cat="reskin"] { background: var(--accent-blue); }
.mp-category-badge[data-cat="joke"] { background: var(--accent-yellow); color: #333; }
.mp-category-badge[data-cat="other"] { background: var(--text-muted); }

/* Header */
.mp-header { padding: 24px; }
.mp-title { font-family: 'Fredoka One', cursive; font-size: 2rem; color: var(--text-primary); margin-bottom: 8px; }
.mp-description { color: var(--text-secondary); font-size: 1.05rem; margin-bottom: 16px; line-height: 1.5; }

/* Info Badges */
.mp-info-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.mp-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 12px; border-radius: 20px; font-size: .78rem; font-weight: 600;
  border: 1px solid var(--border);
}
.mp-diff-badge[data-diff="easy"] { background: #39ff7e18; color: #39ff7e; border-color: #39ff7e44; }
.mp-diff-badge[data-diff="normal"] { background: #ffe06618; color: #ffe066; border-color: #ffe06644; }
.mp-diff-badge[data-diff="hard"] { background: #ffa94d18; color: #ffa94d; border-color: #ffa94d44; }
.mp-diff-badge[data-diff="expert"] { background: #ff444418; color: #ff4444; border-color: #ff444444; }
.mp-diff-badge[data-diff="impossible"] { background: #ff444418; color: #ff4444; border-color: #ff444444; animation: mp-pulse-red 2s infinite; }
@keyframes mp-pulse-red { 0%, 100% { box-shadow: 0 0 0 0 #ff444444; } 50% { box-shadow: 0 0 12px 2px #ff444433; } }
.mp-engine-badge { background: var(--bg-sidebar); color: var(--text-secondary); }
.mp-reading-badge { background: var(--bg-sidebar); color: var(--text-muted); }

.mp-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; font-size: .85rem; color: var(--text-muted); margin-bottom: 12px; }
.mp-author { display: inline-flex; align-items: center; gap: 6px; text-decoration: none; color: var(--accent-cyan); font-weight: 600; }
.mp-author:hover { text-decoration: underline; }
.mp-author-avatar { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
.mp-author-code { font-family: 'Courier New', monospace; font-size: .8rem; opacity: .7; }
.mp-meta-sep { color: var(--text-muted); }

.mp-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.mp-tag {
  display: inline-block; padding: 3px 10px; border-radius: 12px;
  font-size: .75rem; font-weight: 500;
  background: var(--bg-sidebar); color: var(--text-secondary);
  border: 1px solid var(--border);
}

/* Actions bar */
.mp-actions { padding: 0 24px 16px; display: flex; gap: 8px; }

/* Body content */
.mp-body { padding: 0 24px 32px; line-height: 1.7; color: var(--text-primary); }
.mp-body h2 { font-size: 1.4rem; margin: 24px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--border); }
.mp-body h3 { font-size: 1.15rem; margin: 20px 0 8px; }
.mp-body p { margin-bottom: 12px; }
.mp-body ul, .mp-body ol { margin: 0 0 12px 24px; }
.mp-body li { margin-bottom: 4px; }
.mp-body a { color: var(--accent-cyan); }
.mp-body img { max-width: 100%; border-radius: 8px; margin: 12px 0; cursor: pointer; transition: transform .2s; }
.mp-body img:hover { transform: scale(1.02); }
.mp-body strong { font-weight: 700; }
.mp-body em { font-style: italic; }
.mp-body code { background: var(--bg-sidebar); padding: 2px 6px; border-radius: 4px; font-size: .9em; }

/* Spoiler blocks */
.mp-spoiler {
  background: var(--bg-sidebar); border: 1px solid var(--border); border-radius: 8px;
  padding: 12px 16px; margin: 12px 0; cursor: pointer; position: relative;
}
.mp-spoiler::before {
  content: '👁️ Click to reveal spoiler';
  display: block; font-size: .85rem; color: var(--text-muted); font-weight: 600;
}
.mp-spoiler .mp-spoiler-content { display: none; margin-top: 8px; }
.mp-spoiler.revealed .mp-spoiler-content { display: block; }
.mp-spoiler.revealed::before { content: '👁️ Spoiler'; }

/* Blockquote */
.mp-body blockquote {
  border-left: 4px solid var(--page-accent, var(--accent-cyan));
  padding: 12px 16px; margin: 12px 0;
  background: var(--bg-sidebar); border-radius: 0 8px 8px 0;
  color: var(--text-secondary); font-style: italic;
}

/* Horizontal rule */
.mp-body hr {
  border: none; height: 2px; margin: 24px 0;
  background: linear-gradient(90deg, transparent, var(--page-accent, var(--accent-cyan)), transparent);
}

/* Download */
.mp-download-wrap { padding: 0 24px 32px; }

/* Info sections */
.mp-info-section { padding: 0 24px 32px; }
.mp-info-section h2 { font-size: 1.2rem; margin-bottom: 12px; color: var(--text-primary); }
.mp-info-list { display: flex; flex-wrap: wrap; gap: 8px; }
.mp-info-chip {
  display: inline-block; padding: 6px 14px; border-radius: 20px;
  background: var(--bg-sidebar); color: var(--text-secondary);
  font-size: .85rem; border: 1px solid var(--border);
}

/* ── Credits ── */
.mp-credits-list { display: flex; flex-direction: column; gap: 6px; }
.mp-credit-row {
  display: flex; gap: 8px; align-items: baseline;
  padding: 6px 12px; border-radius: 8px;
  background: var(--bg-sidebar); font-size: .9rem;
}
.mp-credit-role { font-weight: 700; color: var(--page-accent, var(--accent-cyan)); min-width: 100px; }
.mp-credit-name { color: var(--text-primary); }

/* ── Social Links ── */
.mp-social-section { padding: 0 24px 32px; }
.mp-social-section h2 { font-size: 1.2rem; margin-bottom: 12px; color: var(--text-primary); }
.mp-social-links { display: flex; flex-wrap: wrap; gap: 10px; }
.mp-social-link {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 10px;
  background: var(--bg-sidebar); color: var(--text-secondary);
  font-size: .85rem; font-weight: 500; text-decoration: none;
  border: 1px solid var(--border); transition: all .2s;
}
.mp-social-link:hover {
  border-color: var(--page-accent, var(--accent-cyan));
  color: var(--page-accent, var(--accent-cyan));
  transform: translateY(-2px);
}

/* ── Screenshot Gallery ── */
.mp-gallery-section { padding: 0 24px 32px; }
.mp-gallery-section h2 { font-size: 1.2rem; margin-bottom: 12px; color: var(--text-primary); }
.mp-gallery-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
}
.mp-gallery-thumb {
  border-radius: 8px; overflow: hidden; cursor: pointer;
  height: 140px; border: 2px solid transparent;
  transition: all .2s;
}
.mp-gallery-thumb:hover { border-color: var(--page-accent, var(--accent-cyan)); transform: scale(1.03); }
.mp-gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }

/* ── Lightbox ── */
.mp-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.92); display: flex;
  align-items: center; justify-content: center;
  backdrop-filter: blur(8px);
}
.mp-lb-img { max-width: 90vw; max-height: 85vh; object-fit: contain; border-radius: 8px; }
.mp-lb-close, .mp-lb-prev, .mp-lb-next {
  position: absolute; background: rgba(255,255,255,.1);
  border: none; color: #fff; font-size: 1.5rem;
  cursor: pointer; border-radius: 50%; width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.mp-lb-close:hover, .mp-lb-prev:hover, .mp-lb-next:hover { background: rgba(255,255,255,.25); }
.mp-lb-close { top: 20px; right: 20px; }
.mp-lb-prev { left: 20px; top: 50%; transform: translateY(-50%); }
.mp-lb-next { right: 20px; top: 50%; transform: translateY(-50%); }
.mp-lb-counter {
  position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
  color: #fff; font-size: .9rem; opacity: .7;
}

/* ── Reactions ── */
.mp-reactions-section { padding: 24px; border-top: 1px solid var(--border); }
.mp-reactions-section h2 { font-size: 1.1rem; margin-bottom: 12px; color: var(--text-primary); }
.mp-reactions { display: flex; flex-wrap: wrap; gap: 8px; }
.mp-react-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 8px 16px; border-radius: 24px;
  border: 2px solid var(--border); background: var(--bg-sidebar);
  color: var(--text-primary); font-size: .95rem;
  cursor: pointer; transition: all .2s; user-select: none;
}
.mp-react-btn:hover { transform: scale(1.1); border-color: var(--page-accent, var(--accent-cyan)); }
.mp-react-btn.active {
  border-color: var(--page-accent, var(--accent-cyan));
  background: var(--page-glow, var(--border-glow));
  box-shadow: 0 0 12px var(--page-glow, var(--border-glow));
}
.mp-react-count { font-weight: 700; font-size: .85rem; }

/* ── Table of Contents ── */
.mp-toc-list { list-style: none; }
.mp-toc-list li { padding: 0; }
.mp-toc-list li a {
  display: block; padding: 4px 12px; font-size: .82rem;
  color: var(--text-muted); text-decoration: none; border-radius: 4px;
  transition: all .15s;
}
.mp-toc-list li a:hover { color: var(--accent-cyan); background: var(--border-glow); }
.mp-toc-list li a.toc-h3 { padding-left: 24px; font-size: .78rem; }
.mp-toc-list li a.active { color: var(--accent-cyan); font-weight: 600; }

/* ═══════════════════════════════════════════
   Mod Browser (grid)
   ═══════════════════════════════════════════ */
.mb-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-bottom: 24px;
}
.mb-toolbar-left { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; flex: 1; }

.mb-search-wrap {
  position: relative; flex: 1; min-width: 200px; max-width: 350px;
}
.mb-search-wrap .search-icon {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  font-size: .9rem; pointer-events: none;
}
.mb-search-input {
  width: 100%; padding: 8px 12px 8px 32px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--bg-card);
  color: var(--text-primary); font-size: .9rem;
}
.mb-search-input:focus { outline: none; border-color: var(--accent-cyan); }

.mb-filter-select {
  padding: 8px 12px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--bg-card);
  color: var(--text-primary); font-size: .85rem; cursor: pointer;
}

.mb-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}

.mb-card {
  background: var(--bg-card); border-radius: 12px; overflow: hidden;
  border: 1px solid var(--border); transition: transform .2s, box-shadow .2s;
  cursor: pointer; text-decoration: none; color: inherit; display: block;
}
.mb-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.1); }

.mb-card-cover { width: 100%; height: 160px; object-fit: cover; background: var(--bg-sidebar); }
.mb-card-cover-fallback {
  width: 100%; height: 160px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--bg-sidebar), var(--bg-card));
  font-size: 3rem;
}

.mb-card-body { padding: 16px; }
.mb-card-category {
  display: inline-block; padding: 2px 8px; border-radius: 10px;
  font-size: .7rem; font-weight: 700; text-transform: uppercase; margin-bottom: 8px;
}
.mb-card-title { font-family: 'Fredoka One', cursive; font-size: 1.1rem; margin-bottom: 4px; color: var(--text-primary); }
.mb-card-desc { font-size: .85rem; color: var(--text-muted); line-height: 1.4; margin-bottom: 10px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.mb-card-footer { display: flex; align-items: center; justify-content: space-between; font-size: .8rem; color: var(--text-muted); }
.mb-card-author { display: flex; align-items: center; gap: 4px; color: var(--accent-cyan); font-weight: 500; }
.mb-card-author img { width: 20px; height: 20px; border-radius: 50%; }

/* Difficulty badge on browser cards */
.mb-card-diff {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: .72rem; font-weight: 600; padding: 2px 7px; border-radius: 10px;
  background: var(--bg-sidebar);
}

.mb-empty { text-align: center; padding: 40px 20px; }
.mb-empty h3 { margin-bottom: 8px; color: var(--text-primary); }
.mb-empty p { color: var(--text-muted); margin-bottom: 16px; }

/* ═══════════════════════════════════════════
   Mod Editor
   ═══════════════════════════════════════════ */
.me-editor { max-width: 800px; }
.me-heading { font-family: 'Fredoka One', cursive; font-size: 1.8rem; color: var(--text-primary); margin-bottom: 24px; }

/* ── Draft Resume Banner ── */
.me-draft-banner {
  margin-bottom: 20px;
  border-radius: var(--radius-lg, 12px);
  border: 2px solid var(--accent-cyan, #4ecdc4);
  background: rgba(78, 205, 196, .08);
  overflow: hidden;
  animation: draftBannerSlideIn .35s ease;
}
@keyframes draftBannerSlideIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.me-draft-banner-inner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  flex-wrap: wrap;
}
.me-draft-banner-icon {
  font-size: 1.6rem;
  flex-shrink: 0;
}
.me-draft-banner-text {
  flex: 1;
  min-width: 180px;
}
.me-draft-banner-text strong {
  display: block;
  color: var(--text-primary);
  font-size: .95rem;
  margin-bottom: 2px;
}
.me-draft-banner-text span {
  font-size: .82rem;
  color: var(--text-muted);
}
.me-draft-banner-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

/* Edit / Preview mode tabs */
.me-mode-tabs {
  display: flex; gap: 4px; margin-bottom: 20px;
  padding: 4px; background: var(--bg-sidebar); border-radius: 10px;
  border: 1px solid var(--border); width: fit-content;
}
.me-mode-tab {
  padding: 8px 20px; border: none; border-radius: 8px;
  background: transparent; color: var(--text-muted); font-size: .9rem; font-weight: 600;
  cursor: pointer; transition: all .2s;
}
.me-mode-tab:hover { color: var(--text-primary); }
.me-mode-tab.active { background: var(--bg-card); color: var(--accent-cyan); box-shadow: var(--shadow-card); }

.me-form { display: flex; flex-direction: column; gap: 20px; }

.me-field { display: flex; flex-direction: column; gap: 6px; }
.me-field label { font-weight: 600; font-size: .9rem; color: var(--text-primary); }
.me-required { color: #e74c3c; }

.me-input, .me-select {
  padding: 10px 14px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--bg-card);
  color: var(--text-primary); font-size: .95rem; transition: border-color .15s;
}
.me-input:focus, .me-select:focus, .me-textarea:focus {
  outline: none; border-color: var(--accent-cyan);
  box-shadow: 0 0 0 3px var(--border-glow);
}
.me-input.small { width: 120px; font-size: .85rem; padding: 6px 10px; }

.me-textarea {
  padding: 12px 14px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--bg-card);
  color: var(--text-primary); font-size: .9rem; font-family: 'Inter', sans-serif;
  resize: vertical; line-height: 1.6;
}
.me-textarea.small { font-size: .85rem; }

.me-hint { font-size: .8rem; color: var(--text-muted); }

.me-toolbar {
  display: flex; gap: 4px; padding: 6px; background: var(--bg-sidebar);
  border: 1px solid var(--border); border-bottom: none; border-radius: 8px 8px 0 0;
  flex-wrap: wrap;
}
.me-tb-btn {
  padding: 4px 10px; border: none; background: transparent;
  color: var(--text-primary); cursor: pointer; border-radius: 4px; font-size: .85rem;
}
.me-tb-btn:hover { background: var(--bg-card-hover); }
.me-tb-sep { width: 1px; background: var(--border); margin: 0 4px; }
.me-tb-upload { color: var(--accent-cyan); font-weight: 600; }
.me-toolbar + .me-textarea { border-radius: 0 0 8px 8px; }

.me-cover-preview {
  margin-top: 8px; border-radius: 8px; overflow: hidden; max-height: 180px;
  border: 1px solid var(--border); position: relative;
}
.me-cover-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
.me-cover-remove-btn {
  position: absolute; top: 8px; right: 8px;
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(0,0,0,.6); color: #fff; border: none;
  font-size: 1rem; cursor: pointer; display: flex;
  align-items: center; justify-content: center;
  transition: background .2s;
}
.me-cover-remove-btn:hover { background: #e74c3c; }

/* ── Drag & Drop Zones ── */
.me-dropzone {
  border: 2px dashed var(--border); border-radius: 12px;
  padding: 32px 20px; text-align: center; cursor: pointer;
  transition: all .25s; background: var(--bg-sidebar);
  position: relative;
}
.me-dropzone:hover, .me-dropzone.drag-over {
  border-color: var(--accent-cyan);
  background: var(--border-glow);
  box-shadow: 0 0 20px var(--border-glow);
}
.me-dropzone.drag-over { transform: scale(1.01); }
.me-dropzone-icon { font-size: 2.5rem; margin-bottom: 8px; }
.me-dropzone-text { font-size: 1rem; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; }
.me-dropzone-subtext { font-size: .82rem; color: var(--text-muted); }
.me-dropzone-browse {
  background: none; border: none; color: var(--accent-cyan);
  cursor: pointer; font-weight: 600; text-decoration: underline; font-size: inherit;
}
.me-dropzone-or {
  text-align: center; font-size: .8rem; color: var(--text-muted); margin: 8px 0;
}
.me-dropzone-uploading {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 10px;
  background: var(--bg-sidebar); border-radius: 12px;
}
.me-upload-progress-bar {
  width: 60%; height: 6px; border-radius: 3px; background: var(--border); overflow: hidden;
}
.me-upload-progress-fill {
  height: 100%; width: 0%; border-radius: 3px;
  background: linear-gradient(90deg, var(--accent-cyan), var(--accent-magenta));
  transition: width .3s;
}
.me-upload-label { font-size: .85rem; color: var(--text-muted); }

/* Content area drag hint */
.me-content-drop-hint {
  position: absolute; inset: 0; display: flex;
  align-items: center; justify-content: center;
  background: rgba(78, 205, 196, .1); border: 2px dashed var(--accent-cyan);
  border-radius: 8px; z-index: 10;
}
.me-content-drop-hint span { font-size: 1rem; font-weight: 600; color: var(--accent-cyan); }
.me-field { position: relative; }

/* ── Theme Presets ── */
.me-theme-presets {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 8px;
}
.me-theme-btn {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 10px 8px; border: 2px solid var(--border); border-radius: 10px;
  background: var(--bg-card); cursor: pointer; transition: all .2s;
  font-size: .78rem; font-weight: 600; color: var(--text-secondary);
}
.me-theme-btn:hover { border-color: var(--text-muted); transform: translateY(-2px); }
.me-theme-btn.active {
  border-color: var(--accent-cyan); box-shadow: 0 0 12px var(--border-glow);
  color: var(--accent-cyan);
}
.me-theme-swatch { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; }

/* Custom color pickers */
.me-custom-colors {
  display: flex; gap: 16px; flex-wrap: wrap; margin-top: 12px;
  padding: 16px; background: var(--bg-sidebar); border-radius: 10px;
  border: 1px solid var(--border);
}
.me-color-field { display: flex; flex-direction: column; gap: 4px; }
.me-color-field label { font-size: .8rem; color: var(--text-muted); font-weight: 600; }
.me-color-input-wrap { display: flex; align-items: center; gap: 6px; }
.me-color-input-wrap input[type="color"] {
  width: 38px; height: 38px; border: 2px solid var(--border); border-radius: 8px;
  cursor: pointer; padding: 2px; background: var(--bg-card);
}

/* ── Difficulty Picker ── */
.me-difficulty-picker { display: flex; flex-wrap: wrap; gap: 6px; }
.me-diff-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 6px 14px; border: 2px solid var(--border); border-radius: 20px;
  background: var(--bg-card); color: var(--text-secondary); font-size: .85rem;
  font-weight: 600; cursor: pointer; transition: all .2s;
}
.me-diff-btn:hover { border-color: var(--text-muted); }
.me-diff-btn.active { border-color: var(--accent-cyan); color: var(--accent-cyan); background: var(--border-glow); }
.me-diff-icon { font-size: 1rem; }

/* ── Gallery Preview (editor) ── */
.me-gallery-preview {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px; margin-top: 10px;
}
.me-gallery-item {
  position: relative; border-radius: 8px; overflow: hidden;
  height: 100px; border: 1px solid var(--border);
}
.me-gallery-item img { width: 100%; height: 100%; object-fit: cover; }
.me-gallery-item .me-gallery-remove {
  position: absolute; top: 4px; right: 4px;
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(0,0,0,.6); color: #fff; border: none;
  font-size: .7rem; cursor: pointer; display: flex;
  align-items: center; justify-content: center;
}
.me-gallery-item .me-gallery-remove:hover { background: #e74c3c; }

/* ── Social Link Fields (editor) ── */
.me-social-fields { display: flex; flex-direction: column; gap: 6px; }
.me-social-row { display: flex; align-items: center; gap: 8px; }
.me-social-icon { font-size: 1.2rem; width: 28px; text-align: center; flex-shrink: 0; }
.me-social-row .me-input { flex: 1; }

/* ── Preview Panel ── */
.me-preview-panel { }
.me-preview-note {
  padding: 10px 16px; margin-bottom: 16px; border-radius: 8px;
  background: var(--accent-cyan); color: #fff; font-size: .85rem; font-weight: 600;
  text-align: center;
}
.me-preview-article { pointer-events: none; }

.me-actions { display: flex; gap: 12px; padding-top: 8px; }

.me-status {
  padding: 10px 16px; border-radius: 8px; font-size: .9rem; display: none;
}
.me-status.success { display: block; background: #27ae6022; color: #27ae60; border: 1px solid #27ae6044; }
.me-status.error { display: block; background: #e74c3c22; color: #e74c3c; border: 1px solid #e74c3c44; }

.sidebar-tip {
  font-size: .82rem; color: var(--text-muted); padding: 4px 0;
  list-style: none;
}

/* ═══════════════════════════════════════════
   Responsive
   ═══════════════════════════════════════════ */
@media (max-width: 720px) {
  .mp-cover-wrap { height: 180px; }
  .mp-title { font-size: 1.5rem; }
  .mp-header { padding: 16px; }
  .mp-body { padding: 0 16px 24px; }
  .mp-actions { padding: 0 16px 12px; }
  .mb-grid { grid-template-columns: 1fr; }
  .mb-toolbar { flex-direction: column; align-items: stretch; }
  .mb-toolbar-left { flex-direction: column; }
  .mb-search-wrap { max-width: none; }
  .me-actions { flex-direction: column; }
  .me-theme-presets { grid-template-columns: repeat(3, 1fr); }
  .me-difficulty-picker { flex-direction: column; }
  .me-custom-colors { flex-direction: column; }
  .mp-gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .mp-reactions { justify-content: center; }
}

/* ═══════════════════════════════════════════
   Dark Mode Overrides
   ═══════════════════════════════════════════ */
[data-theme="dark"] .mp-cover-overlay {
  background: linear-gradient(transparent, rgba(0,0,0,.8));
}
[data-theme="dark"] .mb-card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
}
[data-theme="dark"] .me-tb-btn:hover { background: var(--bg-card); }
[data-theme="dark"] .me-dropzone { border-color: var(--border); }
[data-theme="dark"] .me-dropzone:hover,
[data-theme="dark"] .me-dropzone.drag-over { border-color: var(--accent-cyan); }

/* Dark horror theme special styling */
[data-theme="dark"] .mp-article[data-page-theme="dark-horror"] {
  background: #0a0a0a; color: #ccc;
}
[data-theme="dark"] .mp-article[data-page-theme="dark-horror"] .mp-body {
  color: #bbb;
}
[data-theme="dark"] .mp-article[data-page-theme="dark-horror"] .mp-cover-overlay {
  background: linear-gradient(transparent, rgba(139,0,0,.4), rgba(0,0,0,.9));
}

/* ═══════════════════════════════════════════
   Custom Background Image
   ═══════════════════════════════════════════ */
.mp-article.mp-has-custom-bg {
  position: relative;
}
.mp-article.mp-has-custom-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--page-bg-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.12;
  pointer-events: none;
  z-index: 0;
}
.mp-article.mp-has-custom-bg > * {
  position: relative;
  z-index: 1;
}

/* ═══════════════════════════════════════════
   Song Audio Showcase — Viewer
   ═══════════════════════════════════════════ */
.mp-songs-showcase {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mp-song-card {
  background: var(--bg-sidebar, #1a1a2e);
  border: 1px solid var(--border, #ffffff12);
  border-radius: 10px;
  padding: 14px 18px;
  transition: border-color .2s;
}
.mp-song-card:hover {
  border-color: var(--page-accent, var(--accent-cyan, #4ecdc4));
}

.mp-song-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.mp-song-name {
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary, #eee);
}

.mp-song-badge {
  font-size: .72rem;
  padding: 2px 8px;
  border-radius: 12px;
  font-weight: 600;
  white-space: nowrap;
}
.mp-song-fm {
  background: #4ecdc422;
  color: #4ecdc4;
  border: 1px solid #4ecdc444;
}
.mp-song-ogg {
  background: #f39c1222;
  color: #f0a050;
  border: 1px solid #f39c1244;
}

.mp-song-player {
  width: 100%;
  height: 36px;
  border-radius: 8px;
  outline: none;
}
/* Style audio controls for dark theme */
.mp-song-player::-webkit-media-controls-panel {
  background: var(--bg-card, #16162a);
}

/* ═══════════════════════════════════════════
   Editor — Font Preview
   ═══════════════════════════════════════════ */
.me-font-preview {
  margin-top: 10px;
  padding: 14px 18px;
  background: var(--bg-sidebar, #1a1a2e);
  border: 1px solid var(--border, #ffffff12);
  border-radius: 8px;
  color: var(--text-primary, #eee);
  font-size: 1rem;
  line-height: 1.5;
}

/* ═══════════════════════════════════════════
   Editor — Background Image Preview
   ═══════════════════════════════════════════ */
.me-bg-preview {
  position: relative;
  margin-top: 10px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--border, #ffffff12);
  max-height: 200px;
}
.me-bg-preview img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}

/* ═══════════════════════════════════════════
   Editor — Song Entry Cards
   ═══════════════════════════════════════════ */
.me-songs-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.me-song-entry {
  background: var(--bg-sidebar, #1a1a2e);
  border: 1px solid var(--border, #ffffff12);
  border-radius: 10px;
  padding: 14px 16px;
}

.me-song-entry-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.me-song-number {
  font-weight: 700;
  font-size: .85rem;
  color: var(--accent-cyan, #4ecdc4);
}

.me-song-remove {
  background: none;
  border: none;
  color: var(--text-muted, #888);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background .15s, color .15s;
}
.me-song-remove:hover {
  background: #e74c3c22;
  color: #e74c3c;
}

.me-song-fields {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.me-song-audio-zone {
  position: relative;
}

.me-song-audio-dropzone {
  border: 2px dashed var(--border, #ffffff15);
  border-radius: 8px;
  padding: 12px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
}
.me-song-audio-dropzone:hover,
.me-song-audio-dropzone.drag-over {
  border-color: var(--accent-cyan, #4ecdc4);
  background: rgba(78,205,196,.05);
}

.me-song-audio-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  background: var(--bg-card, #16162a);
  border-radius: 8px;
  padding: 10px 12px;
  border: 1px solid var(--border, #ffffff12);
}

.me-song-audio-player {
  flex: 1;
  min-width: 200px;
  height: 32px;
}

.me-song-audio-info {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.me-song-filename {
  font-size: .8rem;
  color: var(--text-muted, #888);
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.me-song-fm-badge {
  font-size: .7rem;
  padding: 2px 8px;
  border-radius: 12px;
  background: #4ecdc422;
  color: #4ecdc4;
  border: 1px solid #4ecdc444;
  font-weight: 600;
}

.me-song-ogg-badge {
  font-size: .7rem;
  padding: 2px 8px;
  border-radius: 12px;
  background: #f39c1222;
  color: #f0a050;
  border: 1px solid #f39c1244;
  font-weight: 600;
}

.me-song-audio-remove {
  background: none;
  border: none;
  color: var(--text-muted, #888);
  cursor: pointer;
  font-size: 1rem;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background .15s, color .15s;
}
.me-song-audio-remove:hover {
  background: #e74c3c22;
  color: #e74c3c;
}

/* Responsive tweaks for song entries */
@media (max-width: 720px) {
  .me-song-audio-preview { flex-direction: column; align-items: stretch; }
  .me-song-audio-player { min-width: 0; width: 100%; }
  .mp-song-card-header { flex-direction: column; align-items: flex-start; }
}


/* ═══════════════════════════════════════════
   Star Rating Widget (mod-page.html)
   ═══════════════════════════════════════════ */
.mp-rating-section {
  padding: 0 24px 32px;
}
.mp-rating-section h2 {
  font-size: 1.2rem;
  margin-bottom: 16px;
  color: var(--text-primary);
}
.mp-rating-widget {
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
}
.mp-rating-stars-display {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.mp-avg-stars { font-size: 1.5rem; letter-spacing: 2px; }
.mp-avg-num {
  font-size: 1.8rem;
  font-weight: 700;
  font-family: 'Fredoka One', cursive;
  color: var(--text-primary);
}
.mp-rating-count {
  font-size: .85rem;
  color: var(--text-muted);
}
.mp-star.filled { color: #ffd700; }
.mp-star.half { color: #ffd700; opacity: .6; }
.mp-star.empty { color: var(--text-muted); opacity: .4; }

.mp-rating-input {
  border-top: 1px solid var(--border);
  padding-top: 16px;
}
.mp-rating-prompt {
  font-size: .85rem;
  color: var(--text-muted);
  margin-bottom: 8px;
}
.mp-stars-input {
  display: flex;
  gap: 4px;
}
.mp-star-btn {
  background: none;
  border: none;
  font-size: 2rem;
  cursor: pointer;
  color: var(--text-muted);
  opacity: .4;
  transition: color .15s, opacity .15s, transform .15s;
  padding: 2px;
}
.mp-star-btn:hover, .mp-star-btn.hover {
  color: #ffd700;
  opacity: .7;
  transform: scale(1.15);
}
.mp-star-btn.active {
  color: #ffd700;
  opacity: 1;
}
.mp-your-rating {
  display: inline-block;
  margin-top: 8px;
  font-size: .85rem;
  color: var(--accent-cyan);
  font-weight: 600;
}


/* ═══════════════════════════════════════════
   Mod Category Grid (category pages)
   ═══════════════════════════════════════════ */
.mc-toolbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 20px;
}
.mc-select {
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: .85rem;
  cursor: pointer;
}
.mc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  margin-bottom: 32px;
}
.mc-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: border-color .2s, transform .15s, box-shadow .2s;
}
.mc-card:hover {
  border-color: var(--accent-cyan);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.mc-card-cover {
  width: 100%;
  height: 160px;
  object-fit: cover;
  background: var(--bg-sidebar);
}
.mc-card-cover-fallback {
  width: 100%;
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  background: var(--bg-sidebar);
}
.mc-card-body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.mc-card-title {
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mc-card-desc {
  font-size: .85rem;
  color: var(--text-secondary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mc-card-rating {
  font-size: .85rem;
  display: flex;
  align-items: center;
  gap: 4px;
}
.mc-star.filled { color: #ffd700; }
.mc-star.half { color: #ffd700; opacity: .6; }
.mc-star.empty { color: var(--text-muted); opacity: .4; }
.mc-card-rating-num { font-weight: 700; color: var(--text-primary); }
.mc-card-rating-count { color: var(--text-muted); font-size: .8rem; }
.mc-no-ratings { color: var(--text-muted); opacity: .6; }
.mc-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .78rem;
  color: var(--text-muted);
  margin-top: auto;
}
.mc-card-author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.mc-card-author img {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
}

@media (max-width: 600px) {
  .mc-grid { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════
   Trophy Room
   ═══════════════════════════════════════════ */
.tr-loading {
  text-align: center;
  padding: 60px 20px;
  color: var(--text-muted);
}
.tr-empty {
  text-align: center;
  padding: 60px 24px;
  background: var(--bg-card);
  border-radius: 12px;
  border: 1px solid var(--border);
}
.tr-empty-icon { font-size: 3rem; margin-bottom: 12px; }
.tr-empty h3 { margin-bottom: 8px; color: var(--text-primary); }
.tr-empty p { color: var(--text-muted); margin-bottom: 16px; }

.tr-stats-bar {
  display: flex;
  justify-content: center;
  gap: 40px;
  padding: 24px;
  margin-bottom: 32px;
  background: var(--bg-card);
  border-radius: 12px;
  border: 1px solid var(--border);
}
.tr-stat { text-align: center; }
.tr-stat-val {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  font-family: 'Fredoka One', cursive;
  color: var(--text-primary);
}
.tr-stat-lbl {
  font-size: .8rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.tr-tier { margin-bottom: 40px; }
.tr-tier-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  padding-left: 16px;
  border-left: 4px solid #ffd700;
}
.tr-tier-icon { font-size: 1.5rem; }
.tr-tier-title {
  font-family: 'Fredoka One', cursive;
  font-size: 1.3rem;
  color: var(--text-primary);
  margin: 0;
}
.tr-tier-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 700;
}

.tr-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
}
.tr-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: border-color .2s, transform .15s, box-shadow .2s;
}
.tr-card:hover {
  border-color: var(--accent-cyan);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.tr-card--medal {
  border-color: #ffd70044;
}
.tr-medal {
  position: absolute;
  top: 8px;
  left: 8px;
  font-size: 1.5rem;
  z-index: 2;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.5));
}
.tr-card-cover {
  position: relative;
  width: 100%;
  height: 150px;
  overflow: hidden;
  background: var(--bg-sidebar);
}
.tr-card-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.tr-card-cover-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  background: var(--bg-sidebar);
}
.tr-card-body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.tr-card-cat {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 20px;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  width: fit-content;
}
.tr-card-title {
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tr-card-rating {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: .85rem;
}
.tr-star.filled { color: #ffd700; }
.tr-star.half { color: #ffd700; opacity: .6; }
.tr-star.empty { color: var(--text-muted); opacity: .4; }
.tr-card-avg { font-weight: 700; color: var(--text-primary); }
.tr-card-count { color: var(--text-muted); font-size: .8rem; }
.tr-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .78rem;
  color: var(--text-muted);
  margin-top: auto;
  padding-top: 6px;
}
.tr-card-author {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.tr-card-author img {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
}

@media (max-width: 600px) {
  .tr-stats-bar { flex-direction: column; gap: 16px; }
  .tr-grid { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════
   NEW — Mod Status Badge
   ═══════════════════════════════════════════ */
.mp-mod-status-badge { font-weight: 700; }
.mp-mod-status-badge[data-mod-status="in-development"] { background: #3178ff18; color: #5b9aff; border-color: #3178ff44; }
.mp-mod-status-badge[data-mod-status="complete"]       { background: #39ff7e18; color: #39ff7e; border-color: #39ff7e44; }
.mp-mod-status-badge[data-mod-status="on-hold"]        { background: #ffa94d18; color: #ffa94d; border-color: #ffa94d44; }
.mp-mod-status-badge[data-mod-status="abandoned"]      { background: #ff444418; color: #ff6666; border-color: #ff444444; }
.mp-mod-status-badge[data-mod-status="cancelled"]      { background: #88888818; color: #999; border-color: #88888844; }


/* ═══════════════════════════════════════════
   NEW — Content Warnings Banner
   ═══════════════════════════════════════════ */
.mp-warnings-banner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 24px 16px;
  padding: 12px 16px;
  border-radius: 10px;
  background: #e74c3c15;
  border: 1px solid #e74c3c33;
}

.mp-warnings-icon {
  font-size: 1.3rem;
  flex-shrink: 0;
}

.mp-warnings-label {
  font-weight: 700;
  font-size: .85rem;
  color: #ff6b6b;
  white-space: nowrap;
}

.mp-warnings-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.mp-warning-tag {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 12px;
  font-size: .75rem;
  font-weight: 600;
  background: #e74c3c22;
  color: #ff8888;
  border: 1px solid #e74c3c33;
}


/* ═══════════════════════════════════════════
   NEW — Extra Meta (Release Date + Platforms)
   ═══════════════════════════════════════════ */
.mp-extra-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin: 0 24px 14px;
  font-size: .85rem;
  color: var(--text-muted);
}

.mp-extra-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}


/* ═══════════════════════════════════════════
   NEW — Song BPM Badge
   ═══════════════════════════════════════════ */
.mp-song-bpm {
  background: #7b68ee22;
  color: #a78bfa;
  border: 1px solid #7b68ee44;
}

/* Song Composer Label */
.mp-song-composer {
  font-size: .8rem;
  font-weight: 500;
  color: var(--text-muted, #aaa);
  font-style: italic;
  margin-left: 4px;
}


/* ═══════════════════════════════════════════
   NEW — Changelog / Version History Timeline
   ═══════════════════════════════════════════ */
.mp-changelog-timeline {
  position: relative;
  padding-left: 24px;
}

.mp-changelog-timeline::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: var(--border, #ffffff15);
  border-radius: 1px;
}

.mp-changelog-item {
  position: relative;
  margin-bottom: 20px;
}

.mp-changelog-item:last-child {
  margin-bottom: 0;
}

.mp-changelog-dot {
  position: absolute;
  left: -20px;
  top: 6px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--border, #ffffff20);
  border: 2px solid var(--bg-card, #16162a);
}

.mp-changelog-latest .mp-changelog-dot {
  background: var(--page-accent, var(--accent-cyan, #4ecdc4));
  box-shadow: 0 0 8px var(--page-accent, var(--accent-cyan, #4ecdc4));
}

.mp-changelog-content {
  background: var(--bg-sidebar, #1a1a2e);
  border: 1px solid var(--border, #ffffff12);
  border-radius: 10px;
  padding: 14px 16px;
}

.mp-changelog-latest .mp-changelog-content {
  border-color: var(--page-accent, var(--accent-cyan, #4ecdc4))44;
}

.mp-changelog-header {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.mp-changelog-version {
  font-weight: 700;
  font-size: .95rem;
  color: var(--page-accent, var(--accent-cyan, #4ecdc4));
}

.mp-changelog-date {
  font-size: .78rem;
  color: var(--text-muted, #888);
}

.mp-changelog-latest-tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: .7rem;
  font-weight: 700;
  background: var(--page-accent, var(--accent-cyan, #4ecdc4));
  color: #000;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.mp-changelog-changes {
  font-size: .88rem;
  line-height: 1.5;
  color: var(--text-secondary, #bbb);
  margin: 0;
  white-space: pre-line;
}


/* ═══════════════════════════════════════════
   NEW — Trivia & Fun Facts
   ═══════════════════════════════════════════ */
.mp-trivia-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mp-trivia-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  background: var(--bg-sidebar, #1a1a2e);
  border: 1px solid var(--border, #ffffff12);
  border-radius: 10px;
  font-size: .9rem;
  color: var(--text-secondary, #bbb);
  line-height: 1.5;
  transition: border-color .2s;
}

.mp-trivia-card:hover {
  border-color: var(--page-accent, var(--accent-cyan, #4ecdc4));
}

.mp-trivia-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 1px;
}


/* ═══════════════════════════════════════════
   NEW — Known Issues
   ═══════════════════════════════════════════ */
.mp-issues-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mp-issue-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 14px;
  background: #f39c1210;
  border: 1px solid #f39c1225;
  border-radius: 8px;
  font-size: .88rem;
  color: var(--text-secondary, #bbb);
  line-height: 1.4;
}

.mp-issue-icon {
  flex-shrink: 0;
  font-size: 1rem;
}


/* ═══════════════════════════════════════════
   EDITOR — Mod Status Picker
   ═══════════════════════════════════════════ */
.me-status-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.me-status-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  border: 2px solid var(--border, #ffffff15);
  border-radius: 20px;
  background: var(--bg-card, #16162a);
  color: var(--text-secondary, #bbb);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
}

.me-status-btn:hover {
  border-color: var(--text-muted, #888);
}

.me-status-btn.active {
  border-color: var(--accent-cyan, #4ecdc4);
  color: var(--accent-cyan, #4ecdc4);
  background: var(--border-glow, rgba(78,205,196,.08));
}

.me-status-icon { font-size: 1rem; }


/* ═══════════════════════════════════════════
   EDITOR — Platform Compatibility Checkboxes
   ═══════════════════════════════════════════ */
.me-platform-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.me-platform-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--border, #ffffff15);
  border-radius: 10px;
  background: var(--bg-card, #16162a);
  font-size: .85rem;
  color: var(--text-secondary, #bbb);
  cursor: pointer;
  transition: all .2s;
  user-select: none;
}

.me-platform-check input { display: none; }

.me-platform-check:has(input:checked) {
  border-color: var(--accent-cyan, #4ecdc4);
  color: var(--accent-cyan, #4ecdc4);
  background: var(--border-glow, rgba(78,205,196,.08));
}

.me-platform-icon { font-size: 1rem; }


/* ═══════════════════════════════════════════
   EDITOR — Content Warnings Checkboxes
   ═══════════════════════════════════════════ */
.me-warnings-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.me-warning-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--border, #ffffff15);
  border-radius: 10px;
  background: var(--bg-card, #16162a);
  font-size: .85rem;
  color: var(--text-secondary, #bbb);
  cursor: pointer;
  transition: all .2s;
  user-select: none;
}

.me-warning-check input { display: none; }

.me-warning-check:has(input:checked) {
  border-color: #e74c3c;
  color: #ff6b6b;
  background: #e74c3c15;
}

.me-warning-icon { font-size: 1rem; }


/* ═══════════════════════════════════════════
   EDITOR — Changelog Entries
   ═══════════════════════════════════════════ */
.me-changelog-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.me-changelog-entry {
  background: var(--bg-sidebar, #1a1a2e);
  border: 1px solid var(--border, #ffffff12);
  border-radius: 10px;
  padding: 14px 16px;
}

.me-changelog-entry-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.me-changelog-number {
  font-weight: 700;
  font-size: .85rem;
  color: var(--accent-cyan, #4ecdc4);
}

.me-changelog-remove {
  background: none;
  border: none;
  color: var(--text-muted, #888);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background .15s, color .15s;
}

.me-changelog-remove:hover {
  background: #e74c3c22;
  color: #e74c3c;
}

.me-changelog-fields {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.me-changelog-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.me-changelog-row .me-input {
  flex: 1;
  min-width: 120px;
}


/* ═══════════════════════════════════════════
   EDITOR — Song name + composer + BPM row
   ═══════════════════════════════════════════ */
.me-song-name-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.me-song-name-row .me-song-name {
  flex: 1;
}

.me-song-name-row .me-song-composer {
  flex: 1;
}

.me-song-bpm {
  flex-shrink: 0;
}


/* ═══════════════════════════════════════
   Responsive for new sections
   ═══════════════════════════════════════ */
@media (max-width: 720px) {
  .mp-warnings-banner { margin: 0 16px 12px; }
  .mp-extra-meta { margin: 0 16px 12px; flex-direction: column; gap: 6px; }
  .me-status-picker { flex-direction: column; }
  .me-platform-picker { flex-direction: column; }
  .me-warnings-picker { flex-direction: column; }
  .me-changelog-row { flex-direction: column; }
  .me-song-name-row { flex-direction: column; }
  .mp-char-card { flex-direction: row !important; width: 100% !important; }
  .mp-char-img { width: 80px !important; height: 80px !important; }
  .me-checkbox-grid { grid-template-columns: 1fr !important; }
  .me-char-entry { flex-direction: column; }
  .me-char-img-dropzone { min-height: 100px; }
}

/* ═══════════════════════════════════════
   VIEWER — Multi-Category Badges
   ═══════════════════════════════════════ */
.mp-category-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 0 0 16px;
}

/* ═══════════════════════════════════════
   VIEWER — Visual Character Showcase
   ═══════════════════════════════════════ */
.mp-chars-showcase {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.mp-char-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 160px;
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 12px;
  text-align: center;
  transition: transform .15s, box-shadow .15s;
}
.mp-char-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}

.mp-char-img {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--page-accent, var(--accent-cyan));
  margin-bottom: 10px;
}

.mp-char-placeholder {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  margin-bottom: 10px;
  color: var(--text-muted);
}

.mp-char-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mp-char-name {
  font-weight: 700;
  font-size: .95rem;
  color: var(--text-primary);
}

.mp-char-role {
  font-size: .78rem;
  color: var(--page-accent, var(--accent-cyan));
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.mp-char-desc {
  font-size: .8rem;
  color: var(--text-muted);
  margin-top: 4px;
  line-height: 1.4;
}

/* ═══════════════════════════════════════
   VIEWER — Collaborators
   ═══════════════════════════════════════ */
.mp-collabs-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.mp-collab-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 10px;
  text-decoration: none;
  transition: border-color .15s, box-shadow .15s;
}
.mp-collab-card:hover {
  border-color: var(--accent-cyan);
  box-shadow: 0 2px 10px rgba(78,205,196,.15);
}

.mp-collab-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
}

.mp-collab-name {
  font-weight: 600;
  color: var(--text-primary);
  font-size: .9rem;
}

.mp-collab-code {
  font-size: .78rem;
  color: var(--text-muted);
}

/* ═══════════════════════════════════════
   EDITOR — Multi-Category Checkbox Grid
   ═══════════════════════════════════════ */
.me-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 8px;
}

.me-check-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.me-check-item:hover {
  border-color: var(--accent-cyan);
}
.me-check-item input[type="checkbox"] {
  accent-color: var(--accent-cyan);
  width: 16px;
  height: 16px;
  cursor: pointer;
}
.me-check-item:has(input:checked) {
  border-color: var(--accent-cyan);
  background: rgba(78, 205, 196, .08);
}

/* ═══════════════════════════════════════
   EDITOR — Character Showcase Entries
   ═══════════════════════════════════════ */
.me-char-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.me-char-entry {
  display: flex;
  gap: 16px;
  padding: 16px;
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 10px;
  position: relative;
}

.me-char-entry-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.me-char-number {
  font-weight: 700;
  font-size: .85rem;
  color: var(--accent-cyan);
}

.me-char-remove {
  padding: 4px 8px;
  background: rgba(231, 76, 60, .12);
  color: #e74c3c;
  border: 1px solid rgba(231, 76, 60, .2);
  border-radius: 6px;
  font-size: .78rem;
  cursor: pointer;
  transition: background .15s;
}
.me-char-remove:hover {
  background: rgba(231, 76, 60, .25);
}

.me-char-fields {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.me-char-img-dropzone {
  width: 120px;
  min-height: 120px;
  border: 2px dashed var(--border);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  transition: border-color .15s;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.me-char-img-dropzone:hover,
.me-char-img-dropzone.dragover {
  border-color: var(--accent-cyan);
}
.me-char-img-dropzone.uploading {
  pointer-events: none;
  opacity: .7;
}

.me-char-img-dropzone .me-char-img-icon {
  font-size: 1.8rem;
  color: var(--text-muted);
}
.me-char-img-dropzone .me-char-img-label {
  font-size: .72rem;
  color: var(--text-muted);
  text-align: center;
}

.me-char-img-uploading {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  width: 100%;
  padding: 0 8px;
}

.me-char-img-bar {
  width: 100%;
  height: 4px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}

.me-char-img-progress {
  height: 100%;
  width: 0;
  background: var(--accent-cyan);
  transition: width .2s;
  border-radius: 4px;
}

.me-char-img-preview {
  display: none;
  width: 120px;
  position: relative;
  flex-shrink: 0;
}

.me-char-img-thumb {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 10px;
  border: 2px solid var(--border);
}

.me-char-img-remove {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(0,0,0,.7);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: .7rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.me-add-char-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: transparent;
  color: var(--accent-cyan);
  border: 1px dashed var(--accent-cyan);
  border-radius: 8px;
  cursor: pointer;
  font-size: .85rem;
  font-weight: 600;
  transition: background .15s;
  margin-top: 8px;
}
.me-add-char-btn:hover {
  background: rgba(78, 205, 196, .08);
}

/* ═══════════════════════════════════════
   EDITOR — Collaborators
   ═══════════════════════════════════════ */
.me-collab-search-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.me-collab-search-row input {
  flex: 1;
}

.me-collab-add {
  padding: 8px 16px;
  background: var(--accent-cyan);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  font-size: .85rem;
  white-space: nowrap;
  transition: opacity .15s;
}
.me-collab-add:hover { opacity: .85; }
.me-collab-add:disabled { opacity: .5; cursor: not-allowed; }

.me-collab-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}

.me-collab-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 8px;
}

.me-collab-name {
  font-weight: 600;
  color: var(--text-primary);
  font-size: .88rem;
}

.me-collab-code {
  font-size: .78rem;
  color: var(--text-muted);
  margin-right: auto;
}

.me-collab-remove {
  padding: 4px 8px;
  background: transparent;
  color: #e74c3c;
  border: 1px solid rgba(231, 76, 60, .2);
  border-radius: 6px;
  font-size: .85rem;
  cursor: pointer;
  transition: background .15s;
}
.me-collab-remove:hover {
  background: rgba(231, 76, 60, .12);
}

.me-hint {
  font-size: .82rem;
  color: var(--text-muted);
}

/* ═══════════════════════════════════════
   BROWSER — My Drafts Section
   ═══════════════════════════════════════ */
.mb-drafts-section {
  margin-bottom: 28px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  border-left: 4px solid var(--accent-orange, #f39c12);
}

.mb-drafts-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.mb-drafts-header h2 {
  font-family: 'Fredoka One', cursive;
  font-size: 1.2rem;
  color: var(--text-primary);
  margin: 0;
}

.mb-drafts-count {
  font-size: .82rem;
  color: var(--text-muted);
  background: var(--bg-sidebar);
  padding: 2px 10px;
  border-radius: 12px;
}

.mb-drafts-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mb-draft-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 16px;
  background: var(--bg-sidebar);
  border: 1px solid var(--border);
  border-radius: 10px;
  transition: border-color .15s;
}
.mb-draft-card:hover {
  border-color: var(--accent-cyan);
}

.mb-draft-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  flex: 1;
}

.mb-draft-title {
  font-weight: 700;
  font-size: .95rem;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mb-draft-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.mb-draft-cat {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.mb-draft-time {
  font-size: .78rem;
  color: var(--text-muted);
}

.mb-draft-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

@media (max-width: 600px) {
  .mb-draft-card {
    flex-direction: column;
    align-items: flex-start;
  }
  .mb-draft-actions {
    width: 100%;
  }
  .mb-draft-actions .fnf-btn {
    flex: 1;
    text-align: center;
  }
}
