: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; }

/* music-gen additions */
audio { width: 100%; margin-top: .3rem; }
#dicebtn { background: #374151; margin: .2rem 0 .4rem; }
#dicebtn:hover { background: #4b5563; }
.lyrics { white-space: pre-wrap; font-family: inherit; margin: .3rem 0; }
details.recipe { margin-top: .35rem; }
details.recipe summary { cursor: pointer; }
details.recipe dl { margin: .4rem 0 0; }
details.recipe dt { color: #9db4d0; font-size: .78rem; margin-top: .45rem;
  text-transform: uppercase; letter-spacing: .04em; }
details.recipe dd { margin: .1rem 0 0; color: #c3c9d2; white-space: pre-wrap; }
.jobcard details { margin-top: .4rem; }
.jobcard pre.lyrics { font-size: .85rem; color: #c3c9d2; }

/* Jukebox cards: image-gen floated the checkbox over the artwork corner;
   audio cards have no artwork, so it landed on the play button. Keep it
   static above the player, outline the whole card when selected. */
.grid .pick { position: static; display: inline-flex; cursor: pointer; }
.grid .pick input[type=checkbox] {
  position: static; width: 1.05rem; height: 1.05rem; margin: 0;
}
.grid figure:has(.pick input:checked) {
  outline: 2px solid #3b82f6; outline-offset: 5px; border-radius: 4px;
}
#draftbtn { background: #374151; }
#draftbtn:hover { background: #4b5563; }
#draftstatus { margin-left: .6rem; }
