:root {
  --bg:           #1a1b26;
  --bg-alt:       #16161e;
  --bg-card:      #24283b;
  --bg-hover:     #2a2d45;
  --border:       #2f3549;
  --text:         #c0caf5;
  --text-muted:   #565f89;
  --accent:       #7aa2f7;
  --accent-hover: #89b4fa;
  --green:        #9ece6a;
  --yellow:       #e0af68;
  --red:          #f7768e;
  --purple:       #bb9af7;
  --cyan:         #7dcfff;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
}

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

/* ── Nav ── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; height: 52px;
  background: var(--bg-alt); border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 24px; z-index: 100;
}
.nav-logo { font-weight: 600; font-size: 1rem; color: var(--text); letter-spacing: .02em; }
.nav-logo:hover { color: var(--accent); text-decoration: none; }
.nav-admin {
  font-size: .8rem; color: var(--text-muted);
  padding: 4px 10px; border: 1px solid var(--border); border-radius: 4px;
}
.nav-admin:hover { color: var(--text); text-decoration: none; border-color: var(--text-muted); }

/* ── Content ── */
.content { max-width: 1100px; margin: 0 auto; padding: 80px 24px 48px; }

/* ── Breadcrumb ── */
.breadcrumb {
  font-size: .85rem; color: var(--text-muted);
  margin-bottom: 20px; display: flex; align-items: center; gap: 6px;
}
.breadcrumb a { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--accent); text-decoration: none; }
.breadcrumb .sep { color: var(--border); }

/* ── Badges ── */
.badge {
  display: inline-block; font-size: .72rem; font-weight: 600;
  padding: 2px 8px; border-radius: 20px; letter-spacing: .03em; text-transform: uppercase;
}
.badge-ongoing   { background: rgba(158,206,106,.15); color: var(--green); }
.badge-completed { background: rgba(122,162,247,.15); color: var(--accent); }
.badge-hiatus    { background: rgba(224,175,104,.15); color: var(--yellow); }
.badge-dropped   { background: rgba(247,118,142,.15); color: var(--red); }
.badge-draft     { background: rgba(224,175,104,.12); color: var(--yellow); }
.badge-published { background: rgba(158,206,106,.12); color: var(--green); }
.badge-hidden    { background: rgba(86,95,137,.2);    color: var(--text-muted); }

/* ── Shared ── */
.empty { color: var(--text-muted); font-size: .95rem; padding: 24px 0; }
.cdn-warn {
  background: rgba(224,175,104,.08); border: 1px solid rgba(224,175,104,.3);
  color: var(--yellow); padding: 12px 16px; border-radius: 6px;
  margin-bottom: 24px; font-size: .85rem; line-height: 1.65;
}
.cdn-warn code {
  background: rgba(255,255,255,.08); padding: 1px 5px; border-radius: 3px; font-size: .82rem;
}

/* ── Comic grid (index, genre, tag, author pages) ── */
.comics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}
.comic-card {
  display: flex; gap: 14px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 14px; color: var(--text);
  transition: background .15s, transform .15s, border-color .15s;
}
.comic-card:hover {
  background: var(--bg-hover); border-color: var(--accent);
  transform: translateY(-2px); text-decoration: none; color: var(--text);
}
.comic-cover {
  flex-shrink: 0; width: 80px; height: 114px;
  border-radius: 4px; overflow: hidden;
  background: var(--bg-alt); border: 1px solid var(--border);
}
.comic-cover img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  opacity: 0; transition: opacity .25s ease;
}
.comic-cover img.img-loaded { opacity: 1; }
.cover-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); font-size: 1.5rem;
}
.comic-info { display: flex; flex-direction: column; gap: 7px; min-width: 0; padding-top: 2px; }
.comic-name { font-size: .95rem; font-weight: 600; line-height: 1.3; color: var(--text); }
.comic-meta { display: flex; align-items: center; gap: 8px; }
.comic-chapters { color: var(--text-muted); font-size: .8rem; }
.comic-slug { font-size: .75rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.comic-role { font-size: .75rem; color: var(--cyan); }

/* ── Related Comics ── */
.related-section { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--border); }
.related-heading { font-size: 1rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 16px; }
