:root { color-scheme: dark; }
* { box-sizing: border-box; }
body {
  margin: 0; background: #14161a; color: #e6e8eb;
  font: 15px/1.5 system-ui, -apple-system, sans-serif;
}
header {
  display: flex; align-items: center; gap: 1.5rem;
  padding: .7rem 1.2rem; background: #1c1f26; border-bottom: 1px solid #2a2e37;
}
.brand { font-weight: 700; }
nav a { color: #9db4d0; text-decoration: none; margin-right: 1rem; }
nav a:hover { color: #fff; }
.logout { margin-left: auto; display: flex; align-items: center; gap: .6rem; }
.who { color: #8b93a1; }
main { max-width: 1100px; margin: 1.5rem auto; padding: 0 1rem; }

.card {
  background: #1c1f26; border: 1px solid #2a2e37; border-radius: 10px;
  padding: 1.2rem 1.4rem; margin-bottom: 1.5rem;
}
.card.narrow { max-width: 380px; margin: 4rem auto; }
h1 { font-size: 1.25rem; margin: 0 0 .8rem; }
h2 { font-size: 1.05rem; margin: 1.2rem 0 .5rem; }

label { display: block; margin: .6rem 0; color: #c3c9d2; }
input, textarea, select {
  width: 100%; margin-top: .25rem; padding: .45rem .6rem;
  background: #14161a; color: #e6e8eb; border: 1px solid #3a3f4b;
  border-radius: 6px; font: inherit;
}
.row { display: flex; gap: .8rem; flex-wrap: wrap; }
.row label { flex: 1 1 100px; }
.inline { display: flex; gap: .8rem; align-items: end; flex-wrap: wrap; }
.inline label { flex: 0 1 260px; margin: 0; }
.check input { width: auto; }

button {
  padding: .5rem 1.1rem; border: 0; border-radius: 6px; cursor: pointer;
  background: #3b82f6; color: #fff; font: inherit;
}
button:hover { background: #2563eb; }
button:disabled { background: #374151; cursor: wait; }
button.danger { background: #7f1d1d; }
button.danger:hover { background: #991b1b; }
.logout button { background: #374151; padding: .3rem .8rem; }

.error { color: #f87171; }
.hint { color: #8b93a1; font-size: .85em; }
#status { margin-left: .8rem; color: #8b93a1; }

.grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1rem; margin-top: 1rem;
}
.grid img { width: 100%; border-radius: 8px; display: block; }
figure { margin: 0; }
figcaption { font-size: .8rem; color: #8b93a1; margin-top: .3rem; }

table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: .45rem .6rem; border-bottom: 1px solid #2a2e37; }
th { color: #8b93a1; font-weight: 600; font-size: .85em; }
tr.revoked td { color: #565d68; }
.badge {
  background: #92400e; color: #fde68a; border-radius: 4px;
  padding: 0 .4em; font-size: .75em;
}
.newkey {
  background: #052e16; border: 1px solid #166534; border-radius: 8px;
  padding: .8rem 1rem; margin: .8rem 0;
}
.token {
  display: block; margin-top: .4rem; word-break: break-all;
  background: #14161a; padding: .5rem; border-radius: 6px; user-select: all;
}
code { background: #14161a; padding: .1em .35em; border-radius: 4px; }

footer {
  text-align: center; color: #565d68; font-size: .8rem;
  padding: 1.5rem 0 1rem;
}
tr.yours td { color: #93c5fd; }
.jobcard {
  background: #1c1f26; border: 1px solid #2a2e37; border-radius: 8px;
  padding: .6rem;
}
.jobstatus { color: #c3c9d2; font-size: .9rem; margin-bottom: .3rem; }
.success { color: #4ade80; }
button.small { padding: .2rem .6rem; font-size: .8rem; }
.delform { display: inline-block; margin-top: .3rem; }
.filters label { flex: 0 1 170px; }
.bulkbar {
  display: flex; align-items: center; gap: 1rem; margin: .8rem 0;
}
.pick { position: relative; display: block; cursor: pointer; }
.pick input[type=checkbox] {
  position: absolute; top: .5rem; left: .5rem; width: 1.2rem; height: 1.2rem;
  accent-color: #3b82f6; z-index: 1;
}
.pick input[type=checkbox]:checked + img { outline: 3px solid #3b82f6; }

/* ---------- chat ---------- */
.chatwrap {
  display: flex; gap: 1rem;
  height: calc(100vh - 8.5rem); /* header + footer */
}
.sidebar {
  flex: 0 0 230px; display: flex; flex-direction: column; gap: .6rem;
  background: #1c1f26; border: 1px solid #2a2e37; border-radius: 10px;
  padding: .8rem; overflow-y: auto;
}
.sidebar ul { list-style: none; margin: 0; padding: 0; }
.sidebar li {
  display: flex; align-items: center; justify-content: space-between;
  padding: .4rem .55rem; border-radius: 6px; cursor: pointer;
  color: #c3c9d2; font-size: .9rem; gap: .4rem;
}
.sidebar li span {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1;
}
.sidebar li:hover { background: #262b35; }
.sidebar li.active { background: #2c3442; color: #fff; }
.convdel {
  background: none; color: #565d68; padding: 0 .3rem; font-size: 1rem;
  flex: 0 0 auto;
}
.convdel:hover { background: none; color: #f87171; }
.chatmain {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
  background: #1c1f26; border: 1px solid #2a2e37; border-radius: 10px;
}
#transcript { flex: 1; overflow-y: auto; padding: 1rem 1.2rem; }
.msg {
  max-width: 85%; margin: .5rem 0; padding: .6rem .9rem;
  border-radius: 10px; overflow-wrap: break-word;
}
.msg.user { background: #1e3a5f; margin-left: auto; }
.msg.assistant { background: #262b35; margin-right: auto; }
.msg.system { background: #2c2434; margin-right: auto; font-style: italic; }
.msg p { margin: .3rem 0; }
.msg pre {
  background: #14161a; padding: .6rem .8rem; border-radius: 8px;
  overflow-x: auto; font-size: .85em;
}
.msg.streaming::after { content: "▍"; animation: blink 1s step-start infinite; }
@keyframes blink { 50% { opacity: 0; } }
#composer {
  display: flex; gap: .6rem; align-items: end;
  padding: .8rem; border-top: 1px solid #2a2e37;
}
#composer select { flex: 0 0 200px; width: auto; margin: 0; }
#composer textarea { flex: 1; margin: 0; resize: none; }
#composer button { flex: 0 0 auto; }

/* ---------- admin model pull ---------- */
#pullprogress { display: flex; align-items: center; gap: .8rem; margin-top: .8rem; }
#pullbar { flex: 0 0 260px; accent-color: #3b82f6; }

/* ---------- chat status bar + settings ---------- */
.statusbar {
  display: flex; justify-content: space-between; gap: 1rem;
  padding: .35rem .9rem; border-bottom: 1px solid #2a2e37;
  font-size: .78rem; color: #8b93a1; flex-wrap: wrap;
}
.statusbar .ctx-warn { color: #fbbf24; }
.statusbar .ctx-crit { color: #f87171; font-weight: 600; }
#settings {
  padding: .8rem; border-top: 1px solid #2a2e37; background: #181b21;
}
#settings .optrow { display: flex; gap: .8rem; align-items: end; flex-wrap: wrap; }
#settings .optrow label { flex: 0 1 200px; margin: 0; }
#gear {
  flex: 0 0 auto; background: #374151; padding: .5rem .7rem;
}
#gear:hover { background: #4b5563; }

/* ---------- admin registry browser ---------- */
.regresult {
  padding: .55rem .7rem; border-radius: 8px; cursor: pointer;
  border: 1px solid transparent;
}
.regresult:hover { background: #262b35; border-color: #2a2e37; }
.regdesc { color: #8b93a1; font-size: .85em; }
#tagresults { margin-top: 1rem; }
#tagresults h3 { font-size: 1rem; margin: .5rem 0; }
.fit { border-radius: 4px; padding: 0 .4em; font-size: .75em; }
.fit.ok { background: #052e16; color: #4ade80; }
.fit.tight { background: #422006; color: #fbbf24; }
.fit.no { background: #450a0a; color: #f87171; }
