/* ===== ramkael.pro — forum.css v2.0 ===== */

/* ── Loading / Empty ─────────────────────────────────────── */
.forum-loading{text-align:center;padding:60px;font-size:28px;color:var(--text3)}
.forum-empty{text-align:center;padding:48px;color:var(--text3);font-size:14px}
.forum-login-hint{color:var(--text3);font-size:13px;padding:16px 0;text-align:center}

/* ── Profile prompt banner ───────────────────────────────── */
.forum-profile-prompt{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:rgba(124,92,0,.35);border:1px solid rgba(255,180,0,.3);
  color:#ffe;padding:12px 20px;border-radius:var(--radius);
  margin-bottom:20px;font-size:13px;
}
.forum-profile-prompt span{flex:1}
.fpp-btn-edit{
  background:var(--accent);color:#fff;border:none;
  padding:6px 14px;border-radius:6px;cursor:pointer;font-weight:700;font-size:12px;
}
.fpp-btn-close{background:none;border:none;color:#ffe;cursor:pointer;font-size:16px;padding:2px 6px}

/* ── Topic list ──────────────────────────────────────────── */
.forum-list-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  flex-wrap:wrap;gap:12px;margin-bottom:24px;
}
.forum-new-btn{
  background:var(--accent);color:#fff;border:none;
  padding:10px 20px;border-radius:var(--radius-s);cursor:pointer;
  font-weight:700;font-size:13px;font-family:var(--font);white-space:nowrap;
}
.forum-new-btn:hover{opacity:.85}

.forum-topics{display:flex;flex-direction:column;gap:8px}
.forum-topic-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 20px;cursor:pointer;transition:.2s;
}
.forum-topic-card:hover{border-color:var(--border-h);background:var(--card-h)}
.ftc-header{display:flex;justify-content:space-between;margin-bottom:6px}
.ftc-cat{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase}
.ftc-time{font-size:11px;color:var(--text3)}
.ftc-title{font-size:15px;font-weight:700;margin-bottom:6px;color:var(--text)}
.ftc-meta{font-size:12px;color:var(--text3)}

/* ── Thread view ─────────────────────────────────────────── */
.forum-back-bar{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.forum-back-btn{
  background:none;border:1px solid var(--border);color:var(--text2);
  padding:6px 14px;border-radius:var(--radius-s);cursor:pointer;font-size:13px;
  font-family:var(--font);
}
.forum-back-btn:hover{border-color:var(--accent);color:var(--accent)}
.forum-thread{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}

/* ── Back bar ────────────────────────────────────────────── */
.forum-back-bar{
  display:flex;align-items:center;gap:12px;margin-bottom:8px;
}
.forum-back-btn{
  background:var(--bg2);border:1px solid var(--border);color:var(--text2);
  padding:6px 14px;border-radius:var(--radius-s);cursor:pointer;
  font-family:var(--font);font-size:13px;font-weight:600;
  transition:.2s;white-space:nowrap;
}
.forum-back-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── Topic title header ──────────────────────────────────── */
.forum-topic-header{
  display:flex;align-items:flex-start;gap:10px;
  margin-bottom:16px;padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.forum-topic-title{
  flex:1;margin:0;font-size:18px;font-weight:700;
  color:var(--text);line-height:1.35;
}
.forum-collapse-btn{
  flex-shrink:0;background:var(--bg2);border:1px solid var(--border);
  color:var(--text3);width:32px;height:32px;border-radius:var(--radius-s);
  cursor:pointer;font-size:12px;display:flex;align-items:center;
  justify-content:center;transition:.2s;margin-top:2px;
}
.forum-collapse-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── Thread ──────────────────────────────────────────────── */
.forum-thread{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}

/* ── Post card ───────────────────────────────────────────── */
.forum-post{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 20px;position:relative;transition:.2s;
}
.forum-post:target{border-color:var(--accent);box-shadow:0 0 0 2px rgba(255,102,0,.2)}

/* Header */
.fp-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;position:relative}
.fp-avatar{flex-shrink:0}
.fp-avatar-img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.fp-avatar-letter{
  width:40px;height:40px;border-radius:50%;
  background:var(--accent);color:#fff;font-weight:800;font-size:16px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.fp-author{flex:1;min-width:0}
.fp-name-line{display:block}
.fp-name{display:block;font-weight:700;font-size:14px;color:var(--text)}
.fp-meta{display:block;font-size:11px;color:var(--text3);font-style:italic;margin-top:1px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.fp-time{font-size:11px;color:var(--text3);margin-top:2px;white-space:nowrap}

/* Actions — absolutely positioned so they don't compress fp-author */
.fp-actions{display:flex;gap:4px;align-items:center;opacity:0;transition:.2s;position:absolute;right:0;top:0}
.forum-post:hover .fp-actions{opacity:1}
.fp-link-btn,.fp-quote-btn,.fp-del-btn{
  background:none;border:none;color:var(--text3);cursor:pointer;
  font-size:13px;padding:4px 8px;border-radius:4px;transition:.15s;line-height:1;
}
.fp-link-btn:hover,.fp-quote-btn:hover{background:var(--accent-bg);color:var(--accent)}
.fp-del-btn:hover{background:rgba(229,62,62,.15);color:#e53e3e}

/* Quote block */
.fp-quote{
  border-left:3px solid var(--accent);background:var(--accent-bg);
  padding:8px 14px;border-radius:0 var(--radius-s) var(--radius-s) 0;
  margin-bottom:12px;font-size:13px;
}
.fp-quote-author{font-weight:700;color:var(--accent);margin-right:6px}
.fp-quote-text{color:var(--text2)}

/* Body */
.fp-body{font-size:14px;color:var(--text2);line-height:1.7}
.fp-body a{color:var(--accent);text-decoration:underline}
.fp-body ul,.fp-body ol{padding-left:20px;margin:6px 0}
.fp-body li{margin-bottom:2px}
.fp-body p{margin-bottom:8px}
.fp-body strong,.fp-body b{font-weight:700;color:var(--text)}
.fp-body em,.fp-body i{font-style:italic}

/* Spoiler */
.fp-spoiler{margin-top:12px}
.fp-spoiler-btn{
  background:var(--accent-bg);color:var(--accent);border:none;
  padding:6px 14px;border-radius:var(--radius-s);cursor:pointer;font-size:13px;
  font-family:var(--font);
}
.fp-spoiler-btn:hover{opacity:.8}
.fp-spoiler-body{
  margin-top:8px;font-size:14px;color:var(--text2);line-height:1.7;
  padding:10px 14px;background:var(--accent-bg);border-radius:var(--radius-s);
}

/* Attachments */
.fp-attachments{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}
.fp-img-thumb img{
  max-width:220px;max-height:180px;border-radius:var(--radius-s);
  object-fit:cover;cursor:pointer;transition:.2s;
}
.fp-img-thumb img:hover{opacity:.85}
.fp-pdf-block{display:flex;flex-direction:column;gap:6px}
.fp-pdf-btn{font-size:13px;cursor:pointer}
.fp-pdf-frame{border-radius:var(--radius-s);border:none}
.fp-video-embed{width:100%;margin-top:4px}
.fp-video-embed iframe{width:100%;height:300px;border-radius:var(--radius-s);border:none}
.fp-video-link a{color:var(--accent);font-size:14px;text-decoration:underline}

/* ── Compose form ────────────────────────────────────────── */
.forum-compose-wrap{
  margin-top:32px;border-top:1px solid var(--border);padding-top:24px;
}
.forum-compose{display:flex;flex-direction:column;gap:10px}

.fc-quote-preview{
  display:flex;align-items:center;gap:10px;
  background:var(--accent-bg);border-left:3px solid var(--accent);
  padding:8px 14px;border-radius:0 var(--radius-s) var(--radius-s) 0;
  font-size:13px;
}
.fc-qp-text{flex:1;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#fc-qp-clear{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;flex-shrink:0}

.fc-toolbar{
  display:flex;gap:3px;flex-wrap:wrap;align-items:center;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-s);
  padding:4px 8px;
}
.fc-tb,.fc-tb-spoiler,.fc-tb-video,.fc-tb-file{
  background:none;border:none;color:var(--text2);cursor:pointer;
  padding:4px 8px;border-radius:4px;font-size:13px;transition:.15s;
  font-family:var(--font);line-height:1.4;
}
.fc-tb:hover,.fc-tb-spoiler:hover,.fc-tb-video:hover,.fc-tb-file:hover{
  background:var(--accent-bg);color:var(--accent);
}
.fc-sep{width:1px;height:18px;background:var(--border);margin:0 3px;flex-shrink:0}

.fc-body{
  min-height:100px;padding:12px 16px;
  border:1px solid var(--border);border-radius:var(--radius-s);
  font-size:14px;color:var(--text);line-height:1.7;
  background:var(--card);
}
.fc-body:focus{border-color:var(--accent);outline:none}
.fc-body:empty::before{content:attr(data-ph);color:var(--text3);pointer-events:none}

.fc-attachments-preview{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.fc-ap-item{
  display:flex;align-items:center;gap:6px;
  background:var(--accent-bg);padding:4px 10px;border-radius:var(--radius-s);
  font-size:12px;color:var(--text2);
}
.fc-ap-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:13px}
.fc-ap-del:hover{color:#e53e3e}

.fc-submit{align-self:flex-start;margin-top:4px}

/* Modal overlay */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.55);
  align-items:center;justify-content:center;padding:20px;
}
.modal-overlay.active{display:flex}
.modal{
  background:var(--card);border-radius:var(--radius);
  width:100%;max-width:620px;max-height:90vh;
  overflow-y:auto;box-shadow:0 8px 40px rgba(0,0,0,.4);
}

/* Modal additions for New Topic form */
.fm-modal-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px 0;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:4px;
}
.fm-modal-header h2{font-size:18px;font-weight:700;color:var(--text)}
.fm-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text3)}
.fm-modal-body{padding:20px 24px 24px}

/* Pinned topic cards */
.ftc-pinned{border-left:3px solid var(--accent)}
.ftc-pin-badge{font-size:13px;margin:0 4px}
.ftc-pin-btn{
  background:none;border:none;cursor:pointer;font-size:14px;
  padding:2px 4px;border-radius:4px;opacity:.5;transition:.2s;
  flex-shrink:0;margin-left:auto;
}
.ftc-pin-btn:hover{opacity:1}
.ftc-pinned .ftc-pin-btn{opacity:1}

/* Admin-only action buttons — visible only when SAVE & EXIT active */
.fp-admin-action{display:none!important}
body.edit-mode .fp-admin-action{display:inline-flex!important}

/* Own-post action buttons — always visible */
.fp-own-action{display:inline-flex}

/* Edited mark */
.fp-edited{font-size:11px;color:var(--text3);font-style:italic}

/* Inline post editor */
.fp-body.fp-editing{
  outline:2px solid var(--accent);border-radius:var(--radius-s);
  padding:8px;min-height:60px;
}
.fp-edit-bar{margin-bottom:6px}
.fp-edit-actions{display:flex;gap:8px;margin-top:8px;padding-bottom:8px}

/* Spoiler in compose (visual hint) */
.spoiler-compose{
  background:rgba(255,102,0,.15);color:var(--accent);
  border-radius:3px;padding:0 4px;cursor:default;
  outline:1px dashed var(--accent);
}
