:root {
  --bg: #0e1320;
  --panel: #161c2c;
  --panel-2: #1d2538;
  --line: #28304a;
  --text: #e8ecf3;
  --muted: #8c95a8;
  --accent: #6aa2ff;
  --pending: #ffb454;
  --confirmed: #4ad08c;
  --rejected: #ff6b6b;
  --resubmit: #c389ff;
}
* { box-sizing: border-box; }
html, body { background: var(--bg); color: var(--text); margin: 0; }
body { font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex; align-items: center; gap: 1.5rem;
  padding: .8rem 1.25rem;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
  position: sticky; top: 0; z-index: 5;
}
.brand a { font-weight: 700; color: var(--text); }
.navlinks { display: flex; gap: 1rem; flex-wrap: wrap; }
.navlinks a { color: var(--muted); }
.navlinks a:hover { color: var(--text); text-decoration: none; }
.logout { margin-left: auto; }
.logout button {
  background: transparent; color: var(--muted); border: 1px solid var(--line);
  padding: .35rem .8rem; border-radius: .4rem; cursor: pointer;
}
.logout button:hover { color: var(--text); }

.content { padding: 1.5rem; max-width: 1100px; margin: 0 auto; }
.content.centered { display: grid; place-items: center; min-height: calc(100vh - 0px); }

h1 { font-size: 1.45rem; margin: .25rem 0 1rem; }
h2 { font-size: 1.05rem; margin: 0 0 .75rem; }
.muted { color: var(--muted); }
.small { font-size: .85em; }

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: .6rem;
  padding: 1rem 1.1rem;
  margin: 1rem 0;
}

.grid { display: grid; gap: 1rem; }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.stat {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: .6rem;
  padding: 1rem;
  display: flex; flex-direction: column; gap: .25rem;
  color: var(--text);
}
.stat:hover { border-color: var(--accent); text-decoration: none; }
.stat .n { font-size: 1.6rem; font-weight: 700; }
.stat .lbl { color: var(--muted); }
.stat-pending .n { color: var(--pending); }
.stat-confirmed .n { color: var(--confirmed); }
.stat-rejected .n { color: var(--rejected); }
.stat-resubmit .n { color: var(--resubmit); }

table.data { width: 100%; border-collapse: collapse; }
table.data th, table.data td {
  text-align: left; padding: .5rem .6rem;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
table.data th { color: var(--muted); font-weight: 600; font-size: .8rem; text-transform: uppercase; letter-spacing: .04em; }
table.data tr:hover td { background: var(--panel-2); }
table.data .fail { color: var(--rejected); font-weight: 600; }

.rowlist { list-style: none; padding: 0; margin: 0; }
.rowlist li { padding: .45rem 0; border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.rowlist li:last-child { border: 0; }

.pill {
  font-size: .75rem; padding: .15rem .55rem;
  border-radius: 1rem; background: var(--panel-2); color: var(--muted);
  text-transform: uppercase; letter-spacing: .04em;
}
.pill-pending { color: var(--pending); }
.pill-confirmed { color: var(--confirmed); }
.pill-rejected { color: var(--rejected); }
.pill-resubmit { color: var(--resubmit); }

.badge {
  display: inline-block; min-width: 1.1rem; padding: 0 .4rem;
  background: var(--accent); color: #0e1320;
  border-radius: 1rem; font-size: .75rem; font-weight: 700; text-align: center;
}
.badge.ok { background: var(--confirmed); }
.badge.warn { background: var(--resubmit); }

.tag { display: inline-block; padding: .1rem .55rem; margin: 0 .25rem .25rem 0;
       background: var(--panel-2); color: var(--muted); border-radius: 1rem; font-size: .75rem; }

form label { display: block; margin: .65rem 0; color: var(--muted); }
form input[type="text"], form input[type="password"], form input[type="number"], form input:not([type]), form textarea, form select {
  display: block; width: 100%; margin-top: .25rem;
  background: var(--panel-2); color: var(--text);
  border: 1px solid var(--line); border-radius: .4rem;
  padding: .55rem .7rem; font: inherit;
}
form textarea { resize: vertical; }
button {
  background: var(--accent); color: #0e1320;
  border: 0; border-radius: .4rem;
  padding: .6rem 1.1rem; font-weight: 600; cursor: pointer;
}
button:hover { filter: brightness(1.05); }
button.danger { background: var(--rejected); color: #fff; }

.alert { background: rgba(255,107,107,0.12); color: var(--rejected); border: 1px solid var(--rejected); padding: .55rem .8rem; border-radius: .4rem; margin: .5rem 0; }

.login-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: .8rem;
  padding: 2rem; width: min(380px, 92vw);
}
.login-card h1 { margin-top: 0; }

.filterbar { display: flex; gap: .35rem; margin: .25rem 0 1rem; flex-wrap: wrap; }
.tab {
  padding: .4rem .9rem; border-radius: .35rem;
  background: var(--panel); color: var(--muted); border: 1px solid var(--line);
}
.tab:hover { color: var(--text); text-decoration: none; }
.tab.active { background: var(--panel-2); color: var(--text); border-color: var(--accent); }
.tab .badge { margin-left: .35rem; }

.pager { display: flex; gap: .25rem; margin: 1rem 0; flex-wrap: wrap; }
.pg {
  padding: .3rem .65rem; border: 1px solid var(--line); border-radius: .35rem;
  color: var(--muted); background: var(--panel);
}
.pg.active { color: var(--text); border-color: var(--accent); }

.back { color: var(--muted); }
.back:hover { color: var(--text); text-decoration: none; }

.status-group { border: 1px solid var(--line); border-radius: .4rem; padding: .65rem .9rem; }
.status-group legend { padding: 0 .35rem; color: var(--muted); }
.radio { display: inline-flex; align-items: center; gap: .35rem; margin-right: .9rem; color: var(--text); }
.radio input { margin: 0; }
.status-pending { color: var(--pending); }
.status-confirmed { color: var(--confirmed); }
.status-rejected { color: var(--rejected); }
.status-resubmit { color: var(--resubmit); }

article.md { line-height: 1.65; word-wrap: break-word; }
article.md h1, article.md h2, article.md h3 { color: var(--text); }
article.md h1 { font-size: 1.25rem; margin-top: 1.25rem; }
article.md h2 { font-size: 1.05rem; margin-top: 1rem; }
article.md h3 { font-size: .95rem; margin-top: .85rem; }
article.md code { background: var(--panel-2); padding: .1rem .35rem; border-radius: .3rem; font-size: .9em; }
article.md pre { background: var(--panel-2); padding: .8rem; border-radius: .5rem; overflow-x: auto; }
article.md pre code { background: transparent; padding: 0; }
article.md a { color: var(--accent); text-decoration: underline; }
article.md ul, article.md ol { padding-left: 1.25rem; }
article.md blockquote { border-left: 3px solid var(--line); padding-left: .8rem; color: var(--muted); }

.idea-row { background: var(--panel-2); border: 1px solid var(--line); border-radius: .5rem; padding: .55rem .75rem; margin: .5rem 0; }
.idea-row.archived { opacity: .55; }
.idea-row > summary { cursor: pointer; display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; }
.idea-row .prio { display: inline-block; width: 1.7rem; text-align: center; padding: .1rem .25rem; border-radius: .35rem; background: var(--panel); color: var(--muted); font-weight: 700; font-size: .75rem; }
.idea-row .prio-1, .idea-row .prio-2 { color: var(--pending); }
.idea-row .prio-3 { color: var(--accent); }
.idea-row .title { flex: 1; }
.idea-edit { margin-top: .85rem; padding-top: .6rem; border-top: 1px solid var(--line); }
.idea-edit .row-inline { display: flex; gap: .8rem; align-items: center; flex-wrap: wrap; }
.idea-edit .row-inline label { margin: 0; }
.idea-edit .checkbox { display: inline-flex; align-items: center; gap: .35rem; }
.idea-edit .checkbox input { width: auto; margin: 0; display: inline-block; }
.idea-delete { display: inline-block; margin-top: .35rem; }

@media (max-width: 720px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .topbar { flex-wrap: wrap; }
  .navlinks { width: 100%; order: 3; }
  .logout { margin-left: 0; }
}
