/* =========================
   Mafia Scene - Forums
   (Index + Single Forum Topic List)
   ========================= */

/* ===== Forum Index (categories/cards) ===== */

.ms-forum-index{
  max-width: 1100px;
  margin: 0 auto;
  padding: 30px 18px 60px;
}

.ms-forum-category{ margin: 0 0 28px; }

.ms-forum-category__head{
  background: var(--ms-maroon);
  color: #fff;
  border-radius: var(--ms-radius);
  padding: 14px 16px;
  box-shadow: var(--ms-shadow);
  margin-bottom: 12px;
}

.ms-forum-category__title{
  margin: 0;
  font-size: 18px;
  letter-spacing: .2px;
}

.ms-forum-category__desc{
  margin: 6px 0 0;
  opacity: .9;
  font-size: 13px;
}

.ms-forum-cards{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 860px){
  .ms-forum-cards{ grid-template-columns: 1fr 1fr; }
}

.ms-forum-card{
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  overflow: hidden;
  box-shadow: var(--ms-shadow);
  display: flex;
  flex-direction: column;
}

.ms-forum-card__top{ padding: 14px 14px 10px; }

.ms-forum-card__title{
  margin: 0 0 6px;
  font-size: 16px;
}

.ms-forum-card__title a{
  color: var(--ms-maroon);
  text-decoration: none;
}
.ms-forum-card__title a:hover{
  text-decoration: underline;
}

.ms-forum-card__desc{
  font-size: 13px;
  opacity: .8;
  margin-bottom: 10px;
}

.ms-forum-card__subs{
  margin-top: 10px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.ms-forum-card__subs-label{
  font-size: 12px;
  opacity: .75;
}

.ms-forum-card__subs-pills{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ms-subforum-pill{
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--ms-border);
  background: rgba(255,255,255,.35);
  font-size: 12px;
  text-decoration: none;
  color: var(--ms-maroon);
}

.ms-subforum-pill:hover{
  background: rgba(112,0,0,.08);
}

.ms-forum-card__meta{
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1.7fr;
  gap: 10px;
  padding: 12px 14px;
  border-top: 1px solid var(--ms-border);
  background: rgba(255,255,255,.28);
}

.ms-forum-stat__num{
  display: block;
  font-weight: 800;
  font-size: 16px;
  color: var(--ms-maroon);
  line-height: 1.1;
}
.ms-forum-stat__label{ font-size: 12px; opacity: .75; }

.ms-forum-last__label{ font-size: 12px; opacity: .75; }
.ms-forum-last__time,
.ms-forum-last__by{ font-size: 12px; }

/* ===== Single Forum (topic list) ===== */

.ms-topic-wrap{
  max-width: 1100px;
  margin: 0 auto;
  padding: 22px 18px 60px;
}

.ms-forum-head{
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  box-shadow: var(--ms-shadow);
  padding: 16px 18px;
  margin-bottom: 12px;
}

.ms-forum-head__title{
  margin: 0 0 6px;
  font-size: 22px;
  font-weight: 900;
  color: var(--ms-maroon);
}

.ms-forum-head__desc{
  margin: 0;
  font-size: 13px;
  color: var(--ms-text);
  opacity: .8;
  line-height: 1.5;
}

/* Toolbar */
.ms-topic-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin: 10px 0 12px;
}

.ms-topic-toolbar__left{
  min-width: 0;
}

.ms-topic-toolbar__right{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

/* Pagination (bbPress default markup) */
.ms-topic-toolbar .bbp-pagination{
  margin: 0;
  padding: 0;
}
.ms-topic-toolbar .bbp-pagination-links a,
.ms-topic-toolbar .bbp-pagination-links span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 34px;
  height: 32px;
  padding: 0 10px;
  border-radius: 10px;
  border: 1px solid var(--ms-border);
  text-decoration: none;
  font-weight: 800;
  font-size: 13px;
  background: rgba(255,255,255,.35);
  color: var(--ms-maroon);
}
.ms-topic-toolbar .bbp-pagination-links span.current{
  background: var(--ms-maroon);
  color: #fff;
  border-color: rgba(0,0,0,.08);
}
.ms-topic-toolbar .bbp-pagination-links a:hover{
  background: rgba(112,0,0,.08);
}

.ms-topic-toolbar--bottom{
  margin-top: 14px;
}

/* Topic list container */
.ms-topic-list{
  display: grid;
  gap: 10px;
}

/* Topic row (modern forum list item) */
.ms-topic-row{
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 12px;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  box-shadow: var(--ms-shadow);
  padding: 14px 14px;
  align-items: center;
}

@media (max-width: 860px){
  .ms-topic-row{
    grid-template-columns: 1fr;
  }
}

.ms-topic-title{
  margin: 0 0 6px;
  font-size: 15px;
  font-weight: 900;
}
.ms-topic-title a{
  color: var(--ms-maroon);
  text-decoration: none;
}
.ms-topic-title a:hover{
  text-decoration: underline;
}

.ms-topic-meta{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: var(--ms-muted);
  align-items: center;
}

.ms-topic-badges{
  display:inline-flex;
  gap: 6px;
  align-items:center;
}

/* Badges */
.ms-badge{
  display:inline-flex;
  align-items:center;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--ms-border);
  background: rgba(255,255,255,.35);
  color: var(--ms-maroon);
  font-weight: 900;
  font-size: 11px;
}

/* Last post box */
.ms-topic-last{
  justify-self: end;
  text-align: left;
  width: 100%;
  border: 1px solid var(--ms-border);
  background: rgba(255,255,255,.28);
  border-radius: 12px;
  padding: 10px 10px;
  font-size: 12px;
  color: var(--ms-muted);
}

@media (max-width: 860px){
  .ms-topic-last{
    justify-self: start;
  }
}

.ms-topic-last strong{
  display:block;
  margin-bottom: 4px;
  color: rgba(0,0,0,.72);
  font-weight: 900;
}

/* Compose button (used on forum topic list) */
.ms-compose-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 9px 14px;
  border-radius: 12px;
  font-weight: 900;
  text-decoration:none;
  background: var(--ms-maroon);
  color: #fff;
  border: 1px solid rgba(0,0,0,.08);
}
.ms-compose-btn:hover{ opacity:.92; }

/* Floating compose FAB (from forums.js) */
.ms-compose-fab{
  position: fixed;
  left: auto;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 14px;
  background: var(--ms-maroon);
  color: #fff;
  text-decoration: none;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
  border: 1px solid rgba(0,0,0,.08);
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}

.ms-compose-fab.is-visible{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.ms-compose-fab:hover{
  opacity: .92;
}

/* Keep bbPress headers/footers from showing in single forum list */
#bbpress-forums .bbp-header,
#bbpress-forums .bbp-footer{
  display: none;
}

/* Fully hide collapsed bbPress forms (prevents "half form" showing) */
#bbpress-forums .bbp-topic-form.ms-form-collapsed,
#bbpress-forums .bbp-reply-form.ms-form-collapsed{
  display: none;
}

.ms-topic-filters{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}

.ms-topic-filter,
.ms-topic-mark-read{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding: 4px 12px;
  border: 1px solid var(--ms-border);
  border-radius: 999px;
  text-decoration:none;
  font-size:12px;
  font-weight:800;
  color: var(--ms-maroon);
  background: rgba(255,255,255,.45);
}

.ms-topic-filter:hover,
.ms-topic-mark-read:hover{
  background: rgba(112,0,0,.08);
}

.ms-topic-filter.is-active{
  background: var(--ms-maroon);
  border-color: var(--ms-maroon);
  color: #fff;
}

.ms-forum-archive-layout{
  width: min(1320px, 100%);
  margin: 0 auto;
  padding: 0 12px 36px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 20px;
}

@media (min-width: 1080px){
  .ms-forum-archive-layout{
    grid-template-columns: minmax(0, 1fr) 310px;
    align-items: start;
  }
}

.ms-forum-archive-layout .ms-forum-index{
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}

.ms-forum-archive-sidebar{
  display: grid;
  gap: 14px;
  position: sticky;
  top: 18px;
}

.ms-forum-widget{
  padding: 12px;
}

.ms-forum-stat-list,
.ms-online-list{
  list-style: none;
  margin: 0;
  padding: 0;
}

.ms-forum-stat-list li,
.ms-online-list li{
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--ms-border);
}

.ms-online-list li:last-child,
.ms-forum-stat-list li:last-child{
  border-bottom: 0;
}

.ms-online-empty,
.ms-forum-widget-note{
  margin: 0;
  color: var(--ms-muted);
  font-size: 12px;
}

.ms-stat-value{
  font-weight: 800;
  color: var(--ms-maroon);
}

.ms-latest-topics-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.ms-latest-topic-item{
  padding-bottom: 10px;
  border-bottom: 1px solid var(--ms-border);
}

.ms-latest-topic-item:last-child{
  border-bottom: 0;
  padding-bottom: 0;
}

.ms-latest-topic-link{
  color: var(--ms-maroon);
  text-decoration: none;
  font-weight: 700;
  line-height: 1.35;
}

.ms-latest-topic-link:hover{
  text-decoration: underline;
}

.ms-latest-topic-meta{
  display: block;
  margin-top: 3px;
  font-size: 12px;
  color: var(--ms-muted);
}

.ms-rpg-widget__title{
  margin: 0;
  font-size: 14px;
  font-weight: 900;
  color: var(--ms-maroon);
}

.ms-rpg-widget__renown{
  margin: 6px 0 8px;
  font-size: 12px;
}

.ms-rpg-widget__bar{
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: rgba(0,0,0,.08);
  overflow: hidden;
  margin-bottom: 10px;
}

.ms-rpg-widget__bar > span{
  display: block;
  height: 100%;
  background: var(--ms-maroon);
}

.ms-rpg-widget__stats{
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  display: grid;
  gap: 6px;
}

.ms-rpg-widget__stats li{
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.ms-rpg-widget__actions{
  margin: 0;
  font-size: 12px;
}

.ms-rpg-widget__actions a{
  color: var(--ms-maroon);
  text-decoration: none;
}

.ms-rpg-widget__actions a:hover{
  text-decoration: underline;
}


/* Who's Online pills */
.ms-online-list{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ms-online-list li{
  border: 0;
  padding: 0;
  display: block;
}

.ms-online-list a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border: 1px solid var(--ms-border);
  border-radius: 10px;
  background: rgba(255,255,255,.5);
  color: var(--ms-maroon);
  text-decoration: none;
  font-weight: 800;
  line-height: 1.1;
}

.ms-online-list a:hover{
  background: rgba(112,0,0,.08);
  text-decoration: none;
}

.ms-forum-widget-note + .ms-online-list{
  margin-top: 8px;
}
