/* =========================================================
   ScapeSociety — Banner-derived Purple/Amber Dark Theme
   ========================================================= */

:root {
  /* Banner-extracted palette */
  --bg-body:       #0a0810;   /* almost black-purple */
  --bg-surface:    #12101c;   /* deep purple surface */
  --bg-card:       #1a1728;   /* card bg */
  --bg-input:      #211e30;   /* input/deeper card */
  --bg-hover:      #272338;   /* hover state */
  --bg-navbar:     rgba(10, 8, 16, 0.94); /* nav with slight transparency */
  --bg-overlay:    rgba(8, 6, 14, 0.82);  /* overlay on hero */

  /* Accents */
  --accent-gold:   #c8aa5a;   /* OSRS gold — complements purple perfectly */
  --gold:          #c8aa5a;
  --accent-light:  #e0c87a;
  --accent-amber:  #c8783a;   /* warm from banner horizon */
  --accent-purple: #7a5fa0;   /* from banner sky */
  --accent-red:    #9b2020;
  --accent-green:  #2a7a3a;

  /* Text */
  --text-primary:  #ddd4c8;   /* warm off-white matching banner warmth */
  --text-muted:    #7a7090;   /* muted purple-grey */
  --text-link:     #c8aa5a;
  --text-bright:   #f0e8d8;

  /* Borders */
  --border:        #2e2a40;
  --border-accent: #3d3458;
  --divider:       #1e1b2c;

  /* Status */
  --success:       #2a7a3a;
  --danger:        #8b2020;
  --warning:       #7a5a10;

  /* Ranks */
  --rank-recruit:   #aaaaaa;
  --rank-corporal:  #c0c0c0;
  --rank-sergeant:  #cd7f32;
  --rank-lieutenant:#a8a9ad;
  --rank-captain:   #ffd700;
  --rank-general:   #e5c100;
  --rank-admin:     #e87d0d;
  --rank-owner:     #ac3232;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 17px; }

/* ── Body: banner as fixed atmospheric background ── */
body {
  font-family: 'Segoe UI', 'Open Sans', system-ui, sans-serif;
  background-color: var(--bg-body);
  background-image: url('/static/img/Background_Large.png');
  background-size: cover;
  background-position: center top;
  background-attachment: fixed;
  background-repeat: no-repeat;
  color: var(--text-primary);
  line-height: 1.7;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Dark overlay applied to body pseudo‑element so the banner
   shows as subtle atmospheric texture behind everything */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--bg-overlay);
  z-index: 0;
  pointer-events: none;
}

/* Everything above the overlay */
body > * { position: relative; z-index: 1; }

a { color: var(--text-link); text-decoration: none; }
a:hover { color: var(--accent-light); text-decoration: none; }

h1, h2, h3, h4, h5 {
  color: var(--text-bright);
  font-weight: 700;
  line-height: 1.25;
}

hr { border: none; border-top: 1px solid var(--divider); margin: 1rem 0; }

/* ── Navbar ── */
.navbar {
  background: var(--bg-navbar);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(200, 170, 90, 0.25);
  position: sticky;
  top: 0;
  z-index: 200;
}

.navbar-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0 32px;
  height: 52px;
}

/* Brand/logo in navbar */
.navbar-brand {
  font-size: 1rem;
  font-weight: 800;
  color: var(--accent-gold);
  letter-spacing: 0.03em;
  margin-right: 12px;
  white-space: nowrap;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
}
.navbar-brand:hover { color: var(--accent-light); text-decoration: none; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  border-radius: 4px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-muted);
  transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.nav-link:hover  { background: rgba(255,255,255,0.06); color: var(--text-primary); }
.nav-link.active { background: rgba(200,170,90,0.12); color: var(--accent-gold); }

.nav-spacer { flex: 1; }

.nav-auth {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: 8px;
}

.nav-user {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.navbar-toggle {
  display: none;
  background: none; border: none;
  color: var(--text-muted); font-size: 1.4rem;
  cursor: pointer; padding: 4px 8px;
  margin-left: auto;
}

/* ── Hero: banner shines through with less overlay ── */
.hero {
  position: relative;
  text-align: center;
  padding: 80px 32px;
  margin-bottom: 0;
  overflow: hidden;
}

/* Lift the body overlay locally so the banner is more visible */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  /* partially cancel the body overlay by adding a lighter counter-layer */
  background: linear-gradient(
    to bottom,
    rgba(8, 6, 14, 0.30) 0%,
    rgba(10, 8, 16, 0.72) 100%
  );
  z-index: 0;
}
.hero > * { position: relative; z-index: 1; }

.hero h1 {
  font-size: clamp(1.8rem, 5vw, 3.2rem);
  color: var(--accent-gold);
  text-shadow: 0 2px 24px rgba(0,0,0,0.9), 0 0 40px rgba(200,170,90,0.3);
  margin-bottom: 10px;
}
.hero p {
  color: var(--text-primary);
  max-width: 500px;
  margin: 0 auto 28px;
  text-shadow: 0 1px 8px rgba(0,0,0,0.8);
}

/* ── Page wrapper ── */
.page-wrap {
  flex: 1;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
  padding: 32px 32px 64px;
}

.container { max-width: 1400px; margin: 0 auto; padding: 0 32px; }
.page-content { padding: 32px 0 64px; }

/* ── Two-col layout ── */
.two-col {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 28px;
  align-items: start;
}
@media (max-width: 960px) { .two-col { grid-template-columns: 1fr; } }

/* ── Cards ── */
.card {
  background: rgba(26, 23, 40, 0.88);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0;
  margin-bottom: 20px;
  overflow: hidden;
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: rgba(0,0,0,0.25);
  border-bottom: 1px solid var(--border);
}
.card-header h2, .card-header h3 {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-gold);
  margin: 0;
}

.card-body { padding: 20px; }

.sidebar-card {
  background: rgba(26, 23, 40, 0.88);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 18px 20px;
  margin-bottom: 14px;
}
.sidebar-card h4 {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-gold);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

/* ── Announcements ── */
.announcement-item {
  padding: 14px 20px;
  border-bottom: 1px solid var(--divider);
}
.announcement-item:last-child { border-bottom: none; }
.announcement-item.pinned {
  border-left: 3px solid var(--accent-gold);
  padding-left: 17px;
  background: rgba(200,170,90,0.04);
}
.announcement-meta { font-size: 0.82rem; color: var(--text-muted); margin-top: 4px; }

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 4px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  text-decoration: none;
  user-select: none;
  white-space: nowrap;
}
.btn:hover { text-decoration: none; }

.btn-primary { background: var(--accent-gold); color: #0a0810; border-color: var(--accent-gold); }
.btn-primary:hover { background: var(--accent-light); border-color: var(--accent-light); color: #0a0810; }

.btn-secondary { background: rgba(255,255,255,0.06); color: var(--text-muted); border-color: var(--border); }
.btn-secondary:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); border-color: var(--text-muted); }

.btn-danger  { background: var(--danger);  color: #fff; border-color: var(--danger); }
.btn-success { background: var(--success); color: #fff; border-color: var(--success); }

.btn-sm { padding: 4px 12px; font-size: 0.8rem; }
.btn-xs { padding: 2px 8px;  font-size: 0.75rem; }

/* ── Forms ── */
.form-wrap {
  max-width: 640px;
  margin: 0 auto;
  background: rgba(26, 23, 40, 0.92);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 28px;
}

.form-group { margin-bottom: 18px; }

label {
  display: block;
  margin-bottom: 5px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="datetime-local"],
textarea,
select {
  width: 100%;
  background: var(--bg-input);
  border: 1px solid var(--border);
  color: var(--text-primary);
  padding: 10px 13px;
  border-radius: 4px;
  font-size: 0.95rem;
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--accent-gold);
  box-shadow: 0 0 0 2px rgba(200,170,90,0.18);
}
textarea { resize: vertical; min-height: 110px; }
select option { background: var(--bg-input); }

.helptext { font-size: 0.8rem; color: var(--text-muted); margin-top: 4px; }
.errorlist { color: #e05555; font-size: 0.82rem; list-style: none; padding: 0; margin: 4px 0 0; }

/* ── Flash messages ── */
.messages-container { max-width: 1400px; margin: 16px auto 0; padding: 0 32px; }
.message {
  padding: 11px 16px;
  border-radius: 6px;
  margin-bottom: 8px;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 9px;
  border-left: 3px solid transparent;
  backdrop-filter: blur(8px);
}
.message.success { background: rgba(42,122,58,0.18);  border-left-color: var(--success); }
.message.error   { background: rgba(139,32,32,0.18);  border-left-color: var(--danger); }
.message.info    { background: rgba(200,170,90,0.12); border-left-color: var(--accent-gold); }
.message.warning { background: rgba(122,90,16,0.25);  border-left-color: var(--warning); }

/* ── Badges ── */
.badge {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.badge-gold    { background: rgba(200,170,90,0.15); color: var(--accent-gold); border: 1px solid rgba(200,170,90,0.3); }
.badge-pinned  { background: rgba(200,170,90,0.1);  color: var(--accent-gold); }
.badge-red     { background: rgba(139,32,32,0.2);   color: #e05555; }
.badge-green   { background: rgba(42,122,58,0.2);   color: #55aa66; }
.badge-grey    { background: rgba(100,100,120,0.2); color: var(--text-muted); }
.badge-blurple { background: rgba(122,95,160,0.2);  color: #b09fd0; }

/* ── Rank badges ── */
.rank {
  font-size: 0.68rem; font-weight: 700;
  padding: 2px 6px; border-radius: 3px;
  text-transform: capitalize; display: inline-block;
}
.rank-recruit    { color: var(--rank-recruit);    background: rgba(170,170,170,0.1); }
.rank-corporal   { color: var(--rank-corporal);   background: rgba(192,192,192,0.1); }
.rank-sergeant   { color: var(--rank-sergeant);   background: rgba(205,127,50,0.1); }
.rank-lieutenant { color: var(--rank-lieutenant); background: rgba(168,169,173,0.1); }
.rank-captain    { color: var(--rank-captain);    background: rgba(255,215,0,0.1); }
.rank-general    { color: var(--rank-general);    background: rgba(229,193,0,0.1); }
.rank-admin      { color: var(--rank-admin);      background: rgba(232,125,13,0.1); }
.rank-owner      { color: var(--rank-owner);      background: rgba(172,50,50,0.1); }

/* ── Forum ── */
.board-row {
  display: grid;
  grid-template-columns: 36px 1fr 80px 160px;
  align-items: center;
  gap: 0 16px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--divider);
  transition: background 0.1s;
}
.board-row:last-child { border-bottom: none; }
.board-row:hover { background: rgba(255,255,255,0.03); }
.board-icon { font-size: 1.5rem; flex-shrink: 0; }
.board-info { flex: 1; }
.board-info h3 { font-size: 0.95rem; margin: 0; }
.board-info p  { font-size: 0.78rem; color: var(--text-muted); margin: 0; }
.board-stats   { text-align: right; font-size: 0.78rem; color: var(--text-muted); }
.board-stats strong { display: block; font-size: 1rem; color: var(--text-primary); }

.thread-list-item {
  padding: 14px 20px;
  border-bottom: 1px solid var(--divider);
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 16px;
  transition: background 0.1s;
}
.thread-list-item:last-child { border-bottom: none; }
.thread-list-item:hover { background: rgba(255,255,255,0.03); }
.thread-meta { font-size: 0.78rem; color: var(--text-muted); margin-top: 2px; }
.thread-stat { text-align: center; color: var(--text-muted); font-size: 0.8rem; }
.thread-stat strong { display: block; font-size: 1rem; color: var(--text-primary); }

.post-wrapper {
  padding: 18px 20px;
  border-bottom: 1px solid var(--divider);
  display: flex;
  gap: 14px;
}
.post-wrapper:last-child { border-bottom: none; }
.post-avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--bg-input);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
  border: 1px solid var(--border);
  overflow: hidden;
}
.post-avatar img { width: 100%; height: 100%; object-fit: cover; }
.post-body { flex: 1; min-width: 0; }
.post-meta { font-size: 0.78rem; color: var(--text-muted); margin-bottom: 5px; }
.post-meta .post-author { font-weight: 600; color: var(--accent-gold); }

.post-reactions { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.reaction-btn {
  background: rgba(200,170,90,0.07);
  border: 1px solid var(--border); border-radius: 4px;
  padding: 3px 8px; cursor: pointer; font-size: 0.82rem;
  color: var(--text-muted);
  transition: background 0.1s, border-color 0.1s;
}
.reaction-btn:hover, .reaction-btn.active {
  background: rgba(200,170,90,0.18);
  border-color: var(--accent-gold); color: var(--accent-gold);
}

/* ── Events ── */
.event-card {
  background: rgba(26, 23, 40, 0.88);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 18px 20px;
  margin-bottom: 12px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
  transition: border-color 0.15s, background 0.15s;
}
.event-card:hover { border-color: rgba(200,170,90,0.5); background: rgba(30,26,50,0.92); }

.event-date-box {
  width: 54px; text-align: center;
  background: rgba(200,170,90,0.08);
  border: 1px solid rgba(200,170,90,0.25);
  border-radius: 6px; padding: 7px 4px; flex-shrink: 0;
}
.event-date-box .month { font-size: 0.62rem; text-transform: uppercase; color: var(--accent-gold); font-weight: 700; }
.event-date-box .day   { font-size: 1.7rem; font-weight: 800; line-height: 1; color: var(--text-bright); }

/* ── Drops ── */
.drops-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; }

.drop-card {
  background: rgba(26, 23, 40, 0.88);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border);
  border-radius: 8px; overflow: hidden;
  transition: border-color 0.15s, transform 0.1s;
}
.drop-card:hover { border-color: rgba(200,170,90,0.5); transform: translateY(-2px); }
.drop-card img   { width: 100%; height: 145px; object-fit: cover; }
.drop-card-body  { padding: 14px 16px; }
.drop-value { font-size: 0.82rem; color: var(--accent-gold); font-weight: 600; }

/* ── Roster ── */
.roster-table { width: 100%; border-collapse: collapse; }
.roster-table th {
  text-align: left; padding: 10px 16px;
  font-size: 0.7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text-muted); border-bottom: 1px solid var(--border);
}
.roster-table td { padding: 13px 16px; font-size: 0.9rem; border-bottom: 1px solid var(--divider); }
.roster-table tr:hover td { background: rgba(255,255,255,0.03); }
.roster-table tr:last-child td { border-bottom: none; }

/* ── Hiscores ── */
.hiscores-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(155px, 1fr)); gap: 8px; }
.skill-cell {
  background: rgba(26, 23, 40, 0.88); border: 1px solid var(--border);
  border-radius: 6px; padding: 9px 13px;
  display: flex; align-items: center; gap: 8px;
}
.skill-name  { font-size: 0.76rem; color: var(--text-muted); text-transform: capitalize; }
.skill-level { font-size: 1.1rem; font-weight: 700; color: var(--accent-gold); margin-left: auto; }

/* ── Pagination ── */
.pagination { display: flex; gap: 4px; margin-top: 18px; flex-wrap: wrap; }
.page-link {
  padding: 6px 13px; border-radius: 4px; font-size: 0.85rem;
  background: rgba(26,23,40,0.8); border: 1px solid var(--border);
  color: var(--text-muted);
  transition: background 0.1s, border-color 0.1s, color 0.1s;
}
.page-link:hover  { background: var(--bg-hover); color: var(--text-primary); border-color: var(--text-muted); }
.page-link.active { background: rgba(200,170,90,0.15); border-color: var(--accent-gold); color: var(--accent-gold); }

/* ── Main grow (pushes footer to bottom) ── */
.main-grow { flex: 1; }

/* ── Footer ── */
footer {
  background: rgba(8, 6, 14, 0.9);
  backdrop-filter: blur(8px);
  border-top: 1px solid rgba(200,170,90,0.2);
  padding: 22px 32px;
  text-align: center;
  font-size: 0.82rem;
  color: var(--text-muted);
}
footer a { color: var(--text-muted); }
footer a:hover { color: var(--accent-gold); }

/* ── Utility ── */
.embed {
  border-left: 3px solid var(--accent-gold);
  background: rgba(200,170,90,0.05);
  border-radius: 0 4px 4px 0;
  padding: 10px 14px; margin-bottom: 8px;
}
.embed.pinned { border-left-color: var(--accent-red); }

.mb-1 { margin-bottom: 4px; }  .mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 16px; } .mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 16px; }    .text-muted { color: var(--text-muted); }
.text-gold { color: var(--accent-gold); }
.d-flex { display: flex; }     .gap-2 { gap: 8px; }
.align-items-center { align-items: center; }
.justify-content-between { justify-content: space-between; }

/* ── Scrollbars ── */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg-hover); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #3a3458; }

/* ── Mobile ── */
@media (max-width: 768px) {
  .navbar-toggle { display: block; }
  .navbar-inner  { flex-wrap: wrap; padding: 6px 16px; height: auto; }
  .nav-links     { display: none; width: 100%; flex-direction: column; padding-bottom: 8px; }
  .nav-links.open { display: flex; }
  .nav-link      { padding: 9px 10px; }
  .nav-spacer, .nav-auth { display: none; }
  .container { padding: 0 16px; }
  .page-wrap { padding: 20px 16px 48px; }
  .messages-container { padding: 0 16px; }
  .hero { padding: 48px 20px; }
}

/* ── Two-factor / Login form ── */
.tf-focus-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 120px);
  padding: 48px 16px;
}

.tf-focus-card {
  background: var(--bg-card);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 48px 52px;
  width: 100%;
  max-width: 440px;
  box-shadow: 0 8px 48px rgba(0,0,0,0.5);
}

.tf-focus-card h1 {
  font-family: 'Cinzel', 'Georgia', serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--accent-gold);
  text-align: center;
  margin-bottom: 8px;
  letter-spacing: 0.03em;
}

.tf-focus-card > p {
  color: var(--text-muted);
  font-size: 0.9rem;
  text-align: center;
  margin-bottom: 28px;
}

.tf-field {
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tf-field label {
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.tf-field input,
.tf-field select {
  background: var(--bg-body);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 0.95rem;
  padding: 10px 14px;
  width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
}

.tf-field input:focus,
.tf-field select:focus {
  border-color: var(--accent-gold);
  box-shadow: 0 0 0 3px rgba(200,170,90,0.15);
}

.tf-errors {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.8rem;
  color: #e07070;
}

.tf-help {
  font-size: 0.78rem;
  color: var(--text-muted);
  margin: 0;
}

.tf-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  flex-wrap: wrap;
}

.tf-btn {
  padding: 10px 24px;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  text-decoration: none;
  display: inline-block;
}

.tf-btn-primary {
  background: var(--accent-gold);
  color: #0a0810;
  border-color: var(--accent-gold);
  margin-left: auto;
}
.tf-btn-primary:hover {
  background: #d9bc72;
  border-color: #d9bc72;
}

.tf-btn-ghost {
  background: transparent;
  color: var(--text-muted);
  border-color: var(--border);
}
.tf-btn-ghost:hover {
  color: var(--text-primary);
  border-color: var(--text-muted);
}

@media (max-width: 480px) {
  .tf-focus-card { padding: 36px 24px; }
}

/* ── Quill Rich Text Editor — Dark Theme ── */
.ql-toolbar.ql-snow {
  background: var(--bg-body);
  border: 1px solid var(--border) !important;
  border-bottom: none !important;
  border-radius: 6px 6px 0 0;
}
.ql-container.ql-snow {
  background: var(--bg-body);
  border: 1px solid var(--border) !important;
  border-radius: 0 0 6px 6px;
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  color: var(--text-primary);
  min-height: 180px;
}
.ql-editor {
  min-height: 180px;
  color: var(--text-primary);
  line-height: 1.7;
}
.ql-editor.ql-blank::before {
  color: var(--text-muted);
  font-style: italic;
}
.ql-toolbar .ql-stroke { stroke: var(--text-muted) !important; }
.ql-toolbar .ql-fill  { fill:   var(--text-muted) !important; }
.ql-toolbar .ql-picker-label { color: var(--text-muted) !important; }
.ql-toolbar button:hover .ql-stroke,
.ql-toolbar .ql-active .ql-stroke { stroke: var(--accent-gold) !important; }
.ql-toolbar button:hover .ql-fill,
.ql-toolbar .ql-active .ql-fill   { fill:   var(--accent-gold) !important; }
.ql-toolbar button:hover .ql-picker-label,
.ql-toolbar .ql-active { color: var(--accent-gold) !important; }
.ql-toolbar .ql-picker-options {
  background: var(--bg-card);
  border: 1px solid var(--border) !important;
  border-radius: 4px;
}
.ql-toolbar .ql-picker-item { color: var(--text-primary); }
.ql-toolbar .ql-picker-item:hover { color: var(--accent-gold); }

/* rendered rich content */
.rich-content h1, .rich-content h2, .rich-content h3 {
  color: var(--text-primary);
  margin: 0.75em 0 0.4em;
}
.rich-content ul, .rich-content ol { padding-left: 1.5em; margin: 0.5em 0; }
.rich-content li { margin: 0.2em 0; }
.rich-content blockquote {
  border-left: 3px solid var(--accent-gold);
  margin: 0.75em 0;
  padding: 0.5em 1em;
  color: var(--text-muted);
  background: rgba(200,170,90,0.05);
  border-radius: 0 4px 4px 0;
}
.rich-content pre {
  background: rgba(0,0,0,0.3);
  border-radius: 4px;
  padding: 0.75em 1em;
  overflow-x: auto;
  font-size: 0.85rem;
}
.rich-content a { color: var(--accent-gold); }
.rich-content strong { color: var(--text-primary); }
/* Quill font sizes in viewer */
.rich-content .ql-size-small { font-size: 0.75em; }
.rich-content .ql-size-large { font-size: 1.5em; }
.rich-content .ql-size-huge  { font-size: 2.5em; }

/* ── Post Preview ── */
.preview-toggle-bar {
  display: flex;
  justify-content: flex-end;
  margin-top: 6px;
}
.preview-toggle-btn {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-muted);
  font-size: 0.78rem;
  padding: 4px 12px;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.preview-toggle-btn:hover {
  border-color: var(--accent-gold);
  color: var(--accent-gold);
}
.post-preview {
  display: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-body);
  padding: 14px 16px;
  margin-top: 6px;
  min-height: 60px;
  line-height: 1.7;
  color: var(--text-primary);
}
.post-preview.active { display: block; }
.post-preview:empty::before {
  content: 'Nothing to preview yet...';
  color: var(--text-muted);
  font-style: italic;
}

/* ── Post OP / Reply differentiation ── */
.post-container.is-op {
  border-left: 3px solid var(--accent-gold);
}
.post-container.is-op .post-header {
  background: rgba(200,170,90,0.08);
}
.badge-op {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 4px;
  background: rgba(200,170,90,0.15);
  color: var(--accent-gold);
  border: 1px solid rgba(200,170,90,0.35);
  margin-left: 8px;
}
.replies-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 28px 0 16px;
  color: var(--text-muted);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.replies-divider::before,
.replies-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}
.post-quote-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 0.78rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  transition: color 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.post-quote-btn:hover { color: var(--accent-gold); }
.ql-editor blockquote {
  border-left: 3px solid var(--accent-gold);
  margin: 0 0 12px;
  padding: 6px 12px;
  color: var(--text-muted);
  background: rgba(200,170,90,0.05);
  border-radius: 0 4px 4px 0;
}

/* ── Reddit-style nested posts ── */
.reddit-post {
  display: flex;
  gap: 0;
  margin-bottom: 4px;
}
.reddit-post.is-op > .reddit-post-inner {
  border-left: 3px solid var(--accent-gold);
  border-radius: 8px;
  margin-bottom: 0;
  background: rgba(200,170,90,0.04);
}
.reddit-post.is-op > .reddit-post-inner .reddit-post-meta {
  background: rgba(200,170,90,0.07);
  border-radius: 8px 8px 0 0;
}

/* collapse line */
.thread-line {
  flex-shrink: 0;
  width: 20px;
  background: transparent;
  border: none;
  border-left: 2px solid var(--border);
  margin-right: 8px;
  cursor: pointer;
  align-self: stretch;
  transition: border-color 0.15s;
  padding: 0;
}
.thread-line:hover { border-color: var(--accent-gold); }

.reddit-post-inner {
  flex: 1;
  min-width: 0;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 8px;
  overflow: hidden;
}

.reddit-post-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(0,0,0,0.15);
  font-size: 0.82rem;
  flex-wrap: wrap;
}
.reddit-post-time { color: var(--text-muted); }

.reddit-post-content {
  padding: 12px 16px;
  line-height: 1.75;
}

.reddit-post-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 14px 10px;
  font-size: 0.8rem;
}
.reaction-group { display: flex; gap: 6px; }
.reddit-action-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 0.8rem;
  cursor: pointer;
  padding: 3px 8px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: background 0.15s, color 0.15s;
}
.reddit-action-btn:hover {
  background: rgba(200,170,90,0.1);
  color: var(--accent-gold);
}

/* Children indentation */
.reddit-children {
  padding: 8px 0 2px 16px;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}

/* Inline reply form */
.inline-reply {
  display: none;
  padding: 10px 14px 12px;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.1);
}
.inline-reply.open { display: block; }
.inline-quill-editor {
  min-height: 100px;
}
.inline-quill-editor .ql-toolbar.ql-snow { border-radius: 6px 6px 0 0; }
.inline-quill-editor .ql-container.ql-snow { min-height: 100px; border-radius: 0 0 6px 6px; }
.inline-reply-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 8px;
}
.btn-sm { padding: 5px 16px; font-size: 0.8rem; }

/* Collapsed state */
.reddit-post.collapsed > .reddit-post-inner > .reddit-post-content,
.reddit-post.collapsed > .reddit-post-inner > .reddit-post-actions,
.reddit-post.collapsed > .reddit-post-inner > .inline-reply,
.reddit-post.collapsed > .reddit-post-inner > .reddit-children {
  display: none;
}
.reddit-post.collapsed > .thread-line { border-color: var(--accent-gold); }

/* ── Vote buttons ── */
.vote-group {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(0,0,0,0.15);
  border-radius: 20px;
  padding: 2px 8px;
}
.vote-btn {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  color: var(--text-muted);
  font-size: 1rem;
  line-height: 1;
  transition: color 0.15s, transform 0.1s;
}
.vote-btn:hover { transform: scale(1.2); }
.upvote-btn:hover  { color: #e8a838; }
.downvote-btn:hover { color: #7b8ec8; }
.upvote-btn.active  { color: #e8a838; }
.downvote-btn.active { color: #7b8ec8; }
.vote-score {
  font-weight: 700;
  font-size: 0.85rem;
  color: var(--text-main);
  min-width: 20px;
  text-align: center;
}

/* ── Board thread vote score column ── */
.thread-vote-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: 0.75rem;
  color: var(--text-muted);
  line-height: 1;
}
.thread-vote-score span {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-muted);
}
.thread-vote-score.score-pos span { color: var(--accent-gold); }
.thread-vote-score.score-neg span { color: #7b8fa1; }
.thread-vote-score i { font-size: 0.7rem; opacity: 0.5; }

/* ── Staff post removal ── */
.reddit-post.is-removed > .reddit-post-inner {
  opacity: 0.6;
  border-color: rgba(255,255,255,0.06);
}
.removed-label {
  font-size: 0.8rem;
  color: var(--text-muted);
  font-style: italic;
}
.removed-content {
  color: var(--text-muted);
  font-style: italic;
  margin: 0;
}
.staff-remove-btn {
  color: #e05555 !important;
}
.staff-remove-btn:hover {
  background: rgba(224,85,85,0.1) !important;
  color: #e05555 !important;
}

/* ── Boss kills grid ── */
.bosses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
  margin-bottom: 2rem;
}
.boss-cell {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.boss-name {
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.3;
}
.boss-kc {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--accent-gold);
}

/* ── Username RSN display ── */
.user-rsn {
  font-weight: 400;
  color: var(--text-muted);
  font-size: 0.85em;
}

@keyframes spin { to { transform: rotate(360deg); } }
