/* ============================================================
   Markdown editor component
   ============================================================ */
.mde {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
  position: relative;
}
.mde:focus-within { border-color: var(--cyan); }

/* ---- Toolbar bar ---- */
.mde-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: .35rem .45rem;
  background: rgba(7,6,13,.5);
  border-bottom: 1px solid rgba(255,255,255,.08);
  flex-wrap: wrap;
}
.mde-tools { display: flex; align-items: center; gap: .12rem; flex-wrap: wrap; }
.mde-btn {
  min-width: 30px; height: 30px;
  padding: 0 .5rem;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: none; border-radius: 7px;
  color: var(--txt-dim); font-size: .9rem; font-family: inherit;
  cursor: pointer; transition: background .15s, color .15s;
}
.mde-btn:hover { background: rgba(255,255,255,.1); color: var(--txt); }
.mde-btn:active { background: rgba(255,45,149,.18); }

/* Highlight the image upload button */
.mde-btn[aria-label*="Upload"] { color: var(--cyan); }
.mde-btn[aria-label*="Upload"]:hover { background: rgba(45,226,230,.12); }

.mde-sep { width: 1px; height: 18px; background: rgba(255,255,255,.12); margin: 0 .25rem; }

/* ---- Tabs ---- */
.mde-tabs { display: inline-flex; background: rgba(255,255,255,.05); border-radius: 8px; padding: 2px; }
.mde-tab {
  font: inherit; font-size: .78rem; font-weight: 600;
  padding: .28rem .8rem; border: none; border-radius: 6px;
  background: transparent; color: var(--txt-faint); cursor: pointer;
  transition: background .15s, color .15s;
}
.mde-tab:hover { color: var(--txt-dim); }
.mde-tab.active { background: var(--pink); color: #fff; }

/* ---- Textarea ---- */
.mde-textarea {
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  width: 100%;
  resize: vertical;
  min-height: 200px;
  transition: opacity .15s;
}
.mde-textarea:focus { outline: none; }

/* ---- Preview pane ---- */
.mde-preview {
  padding: 1rem 1.1rem;
  min-height: 200px;
  font-size: .95rem;
}
.mde-preview:empty::before { content: "Nothing to preview."; color: var(--txt-faint); }

/* ---- Hint bar ---- */
.mde-hint {
  padding: .45rem .8rem;
  border-top: 1px solid rgba(255,255,255,.07);
  font-size: .72rem; color: var(--txt-faint);
  background: rgba(7,6,13,.35);
}
.mde-hint strong { color: var(--txt-dim); }

/* ---- Upload status line ---- */
.mde-upload-status {
  padding: .38rem .85rem;
  font-size: .78rem; font-weight: 600;
  border-top: 1px solid rgba(255,255,255,.06);
  animation: mdeStatusIn .15s ease;
}
@keyframes mdeStatusIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }

.mde-upload-uploading {
  background: rgba(45,226,230,.06);
  color: var(--cyan);
}
.mde-upload-ok {
  background: rgba(68,207,108,.08);
  color: #44cf6c;
}
.mde-upload-error {
  background: rgba(255,45,149,.08);
  color: var(--pink);
}

/* ---- Drag & drop state ---- */
.mde-drop-hint {
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: "Archivo Black", sans-serif;
  font-size: 1.1rem; font-style: italic; letter-spacing: .04em;
  color: var(--cyan);
  background: rgba(7,6,13,.82);
  backdrop-filter: blur(6px);
  border: 2px dashed rgba(45,226,230,.5);
  border-radius: 12px;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s;
  z-index: 10;
}

.mde.mde-dragging { border-color: var(--cyan); box-shadow: 0 0 0 3px rgba(45,226,230,.18); }
.mde.mde-dragging .mde-drop-hint { opacity: 1; }
.mde.mde-dragging .mde-textarea  { opacity: .35; }

/* ---- Images rendered in post bodies ---- */
.post-body img,
.mde-preview img {
  max-width: 100%;
  border-radius: 10px;
  margin: .5rem 0;
  display: block;
  border: 1px solid rgba(255,255,255,.08);
}
