:root{
  --bg:#0e1016;--bg-soft:#12151d;--panel:#171a23;--panel-2:#1d2130;--border:#272c3a;
  --text:#e8eaf0;--muted:#8b93a7;--brass:#d8a657;--brass-soft:rgba(216,166,87,.14);
  --have:#34d399;--missing:#e2685c;--unreleased:#5b6478;--radius:11px;
  --serif:ui-serif,Georgia,"Iowan Old Style","Times New Roman",serif;
  --sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(1100px 540px at 82% -12%,rgba(216,166,87,.06),transparent 60%),var(--bg);
  color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--brass);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:var(--mono);font-size:.85em;color:#cdd3e0;background:var(--panel-2);padding:.1em .4em;border-radius:5px}
.topbar{display:flex;align-items:center;gap:1.4rem;padding:.85rem 1.4rem;
  background:linear-gradient(180deg,var(--panel),var(--bg-soft));border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.topbar .brand{font-family:var(--serif);font-size:1.45rem;font-weight:600;color:var(--brass);letter-spacing:.02em}
.topbar .brand::before{content:"";display:inline-block;width:.5rem;height:1.1rem;background:var(--brass);
  border-radius:2px;margin-right:.55rem;vertical-align:-2px;box-shadow:3px 0 0 rgba(216,166,87,.45),6px 0 0 rgba(216,166,87,.2)}
.topbar nav{display:flex;gap:.35rem;margin-right:auto}
.topbar nav a{color:var(--muted);padding:.35rem .7rem;border-radius:7px;font-size:.92rem;transition:color .15s,background .15s}
.topbar nav a:hover{color:var(--text);background:var(--panel-2);text-decoration:none}
.topbar nav a.active{color:var(--brass);background:var(--brass-soft)}
.topbar form{margin:0}
main{max-width:1080px;margin:0 auto;padding:1.6rem 1.4rem;animation:rise .3s ease both}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}
h1{font-family:var(--serif);font-weight:600;font-size:1.6rem;margin:0}
h2{font-family:var(--serif);font-weight:600;font-size:1.2rem}
.actions{display:flex;gap:.6rem}
.btn{display:inline-block;background:var(--brass);color:#241a08;font-weight:600;font-size:.9rem;border:none;
  border-radius:8px;padding:.5rem .9rem;cursor:pointer;transition:transform .12s,box-shadow .12s,filter .12s;text-decoration:none}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 6px 16px -8px rgba(216,166,87,.6);text-decoration:none}
button.link{background:none;border:1px solid var(--border);color:var(--muted);padding:.25rem .6rem;border-radius:7px;cursor:pointer;font-size:.85rem;transition:.15s}
button.link:hover{color:var(--text);border-color:var(--brass)}
.card,table{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:0 8px 24px -14px rgba(0,0,0,.6)}
table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden}
th,td{padding:.7rem .9rem;text-align:left;vertical-align:middle}
thead th{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;
  background:var(--bg-soft);border-bottom:1px solid var(--border)}
tbody tr{border-top:1px solid var(--border)}
tbody tr:first-child{border-top:none}
tbody tr:hover{background:var(--panel-2)}
td form{margin:0}
.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.12rem .55rem;border-radius:999px;font-size:.78rem;font-weight:600;line-height:1.6}
.badge::before{content:"";width:.45rem;height:.45rem;border-radius:50%;background:currentColor}
.badge.have{color:var(--have);background:rgba(52,211,153,.12)}
.badge.missing{color:var(--missing);background:rgba(226,104,92,.13)}
.badge.unreleased{color:var(--unreleased);background:rgba(91,100,120,.16)}
.progress{display:flex;align-items:center;gap:.6rem}
.progress .bar{flex:1;height:6px;min-width:80px;background:var(--panel-2);border-radius:999px;overflow:hidden}
.progress .bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--brass),#f0c989)}
.progress .count{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.85rem}
.shelf{display:flex;gap:3px;flex-wrap:wrap;margin:.4rem 0 1.2rem}
.shelf i{width:9px;height:30px;border-radius:2px;background:var(--unreleased);opacity:.4}
.shelf i.have{background:var(--have);opacity:1}
.shelf i.missing{background:var(--missing);opacity:1}
.shelf i.unreleased{background:var(--unreleased);opacity:.35}
.meta{color:var(--muted);font-size:.9rem;margin:.1rem 0 1rem}
body.login{display:grid;place-items:center;min-height:100vh}
.card.auth{width:340px;padding:2.2rem 2rem;display:flex;flex-direction:column;gap:.8rem}
.card.auth h1{text-align:center;color:var(--brass);margin:.2rem 0 .5rem}
.card input,input,select,textarea{background:var(--bg-soft);border:1px solid var(--border);color:var(--text);
  border-radius:8px;padding:.55rem .65rem;font-size:.92rem;font-family:inherit}
input:focus,select:focus{outline:2px solid var(--brass-soft);border-color:var(--brass)}
.error{color:var(--missing);font-size:.88rem;text-align:center}
fieldset{border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;margin:1rem 0}
legend{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;padding:0 .4rem}
.addform label{display:block;margin:.55rem 0;font-size:.85rem;color:var(--muted)}
.addform label input,.addform label{width:100%}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
@media (max-width:640px){main{padding:1rem}.topbar{flex-wrap:wrap;gap:.7rem}}
