/* ── Reset & base ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #0f0f14;
  --bg-panel:    #17171f;
  --bg-hover:    #1e1e28;
  --border:      #2a2a38;
  --accent:      #c8a96e;
  --accent-dim:  #8a7040;
  --text:        #e2ddd5;
  --text-mid:    #a09888;
  --text-dim:    #5a5550;
  --red:         #c0392b;
  --sidebar-w:   200px;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 15px;
  line-height: 1.6;
  min-height: 100vh;
}

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

.muted { color: var(--text-dim); font-size: .88rem; }

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.layout {
  display: flex;
  min-height: 100vh;
}

/* ── Sidebar ────────────────────────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: var(--bg-panel);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 1.5rem 0;
  position: fixed;
  top: 0; left: 0; bottom: 0;
}

.sidebar-brand {
  font-size: 1.3rem;
  font-weight: bold;
  letter-spacing: .1em;
  color: var(--accent);
  padding: 0 1.2rem .25rem;
}

.sidebar-player {
  font-size: .78rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 0 1.2rem .75rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: .5rem;
}

.sidebar-nav {
  list-style: none;
  flex: 1;
}

.sidebar-nav li a {
  display: block;
  padding: .45rem 1.2rem;
  color: var(--text-mid);
  font-size: .88rem;
  transition: background .15s, color .15s;
}

.sidebar-nav li a:hover,
.sidebar-nav li a.active {
  background: var(--bg-hover);
  color: var(--accent);
  text-decoration: none;
}

.sidebar-footer {
  padding: .75rem 1.2rem 0;
  border-top: 1px solid var(--border);
  font-size: .8rem;
}

/* ── Main content ───────────────────────────────────────────────────────────── */
.main-content {
  margin-left: var(--sidebar-w);
  padding: 2rem 2.5rem;
  flex: 1;
  max-width: 900px;
}

.page-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--border);
}

.page-header h1 {
  font-size: 1.4rem;
  color: var(--accent);
  font-weight: normal;
  letter-spacing: .04em;
}

/* ── Dashboard ──────────────────────────────────────────────────────────────── */
.dashboard-section { margin-bottom: 2rem; }

.dashboard-section h2 {
  font-size: 1rem;
  font-weight: normal;
  color: var(--text-mid);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .75rem;
}

.notification-list { list-style: none; }

.notification-item {
  display: flex;
  align-items: baseline;
  gap: .75rem;
  padding: .5rem 0;
  border-bottom: 1px solid var(--border);
  font-size: .9rem;
}

.notification-new .notification-title { color: var(--accent); }

.notification-category {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-dim);
  flex-shrink: 0;
  width: 90px;
}

.notification-title { flex: 1; color: var(--text); }

.notification-date {
  font-size: .75rem;
  color: var(--text-dim);
  flex-shrink: 0;
}

.badge {
  background: var(--accent);
  color: #000;
  font-size: .7rem;
  font-weight: bold;
  padding: .1rem .45rem;
  border-radius: 10px;
}

/* ── Flash ──────────────────────────────────────────────────────────────────── */
.flash {
  background: #2a1a1a;
  border: 1px solid var(--red);
  color: #e07070;
  padding: .5rem .85rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  font-size: .88rem;
}

/* ── Login ──────────────────────────────────────────────────────────────────── */
.login-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
}

.login-box {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 2.5rem 2rem;
  width: 320px;
}

.login-title {
  font-size: 1.8rem;
  color: var(--accent);
  letter-spacing: .1em;
  text-align: center;
  margin-bottom: .25rem;
}

.login-subtitle {
  font-size: .8rem;
  color: var(--text-dim);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 1.75rem;
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  font-size: .78rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .3rem;
}

.form-group input {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text);
  font-size: .95rem;
  padding: .45rem .65rem;
}

.form-group input:focus {
  outline: 1px solid var(--accent-dim);
}

.btn-login {
  width: 100%;
  margin-top: .5rem;
  background: var(--accent-dim);
  color: var(--text);
  border: none;
  border-radius: 4px;
  padding: .6rem;
  font-size: .95rem;
  cursor: pointer;
  letter-spacing: .05em;
  transition: background .15s;
}

.btn-login:hover { background: var(--accent); color: #000; }

/* ── Character Sheet ────────────────────────────────────────────────────────── */
.char-layout {
  display: flex;
  gap: 1.5rem;
  height: calc(100vh - 120px);
}

.char-sections {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  flex-shrink: 0;
  width: 160px;
  overflow-y: auto;
}

.char-section-link {
  display: block;
  padding: .4rem .65rem;
  font-size: .82rem;
  color: var(--text-mid);
  border-radius: 4px;
  transition: background .15s, color .15s;
}

.char-section-link:hover,
.char-section-link.active {
  background: var(--bg-hover);
  color: var(--accent);
  text-decoration: none;
}

.char-content {
  flex: 1;
  overflow-y: auto;
  padding-right: .5rem;
}

/* ── Markdown body ──────────────────────────────────────────────────────────── */
.markdown-body h1, .markdown-body h2, .markdown-body h3 {
  color: var(--accent);
  font-weight: normal;
  margin: 1.2rem 0 .5rem;
}
.markdown-body h1 { font-size: 1.3rem; }
.markdown-body h2 { font-size: 1.1rem; }
.markdown-body h3 { font-size: 1rem; }
.markdown-body p  { margin-bottom: .75rem; color: var(--text-mid); }
.markdown-body ul, .markdown-body ol { margin: .5rem 0 .75rem 1.4rem; color: var(--text-mid); }
.markdown-body li { margin-bottom: .2rem; }
.markdown-body strong { color: var(--text); }
.markdown-body table { border-collapse: collapse; width: 100%; margin-bottom: 1rem; }
.markdown-body th { background: var(--bg-hover); color: var(--text-dim); font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; padding: .35rem .6rem; text-align: left; }
.markdown-body td { padding: .35rem .6rem; border-bottom: 1px solid var(--border); color: var(--text-mid); font-size: .88rem; }
.markdown-body hr { border: none; border-top: 1px solid var(--border); margin: 1rem 0; }

/* ── Category content layout ────────────────────────────────────────────────── */
.content-layout {
  display: flex;
  gap: 1.5rem;
  height: calc(100vh - 120px);
}

.entry-list {
  flex-shrink: 0;
  width: 200px;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  overflow-y: auto;
}

.entry-search {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text);
  font-size: .82rem;
  padding: .3rem .5rem;
  width: 100%;
}
.entry-search:focus { outline: 1px solid var(--accent-dim); }

.entry-list ul { list-style: none; display: flex; flex-direction: column; gap: .1rem; }

.entry-link {
  display: block;
  padding: .35rem .6rem;
  font-size: .83rem;
  color: var(--text-mid);
  border-radius: 3px;
  transition: background .12s, color .12s;
}
.entry-link:hover, .entry-link.active {
  background: var(--bg-hover);
  color: var(--accent);
  text-decoration: none;
}

.entry-detail {
  flex: 1;
  overflow-y: auto;
  padding-right: .5rem;
}

.entry-title  { font-size: 1.2rem; font-weight: normal; color: var(--accent); margin-bottom: .25rem; }
.entry-meta   { font-size: .75rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .75rem; }
.entry-summary { color: var(--text-mid); font-size: .92rem; margin-bottom: 1rem; line-height: 1.7; }

.entry-fields { display: grid; grid-template-columns: 140px 1fr; gap: .25rem .75rem; font-size: .88rem; margin-bottom: .75rem; }
.entry-fields dt { color: var(--text-dim); font-size: .75rem; text-transform: uppercase; letter-spacing: .04em; padding-top: .15rem; }
.entry-fields dd { color: var(--text-mid); }

.entry-image { float: right; max-width: 160px; max-height: 200px; object-fit: cover; border-radius: 4px; border: 1px solid var(--border); margin: 0 0 .75rem .75rem; }
