/* KitaMusik — admin, token sama dengan app.css */
:root {
  --bg: #0A0A0F; --surface: #14141B; --surface-2: #1C1C25; --line: #26262F;
  --text: #F4F4F6; --muted: #8B8B98;
  --lime: #CDF463; --lime-ink: #0A0A0F; --lav: #D9B8F0; --pink: #F0BBD4;
  --danger: #F08BAF;
  --r-card: 24px; --r-pill: 999px;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  min-height: 100dvh;
}
.bg-blob {
  position: fixed; top: -220px; right: -160px; width: 520px; height: 520px;
  background: radial-gradient(circle at 40% 40%, rgba(217,184,240,.35), transparent 60%),
              radial-gradient(circle at 60% 60%, rgba(240,187,212,.25), transparent 65%);
  filter: blur(60px); pointer-events: none;
}
a { color: var(--text); }

/* Topbar */
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px; border-bottom: 1px solid var(--line);
  background: rgba(10,10,15,.8); backdrop-filter: blur(14px);
}
.logo { font-family: 'Unbounded', sans-serif; font-weight: 700; text-decoration: none; font-size: 16px; }
.logo span { color: var(--lime); }
.logo em { font-style: normal; color: var(--muted); font-family: 'Plus Jakarta Sans'; font-size: 12px; margin-left: 6px; }
.topbar nav { display: flex; gap: 18px; }
.topbar nav a { color: var(--muted); text-decoration: none; font-size: 13px; font-weight: 600; }
.topbar nav a:hover { color: var(--lime); }

.wrap { max-width: 880px; margin: 0 auto; padding: 24px 18px 80px; position: relative; }

.flash { border-radius: 16px; padding: 12px 18px; font-size: 14px; margin-bottom: 18px; }
.flash.ok { background: rgba(205,244,99,.12); color: var(--lime); border: 1px solid rgba(205,244,99,.3); }
.flash.err { background: rgba(240,139,175,.1); color: var(--danger); border: 1px solid rgba(240,139,175,.3); }

.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 20px; }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-card); padding: 18px; }
.stat strong { display: block; font-family: 'Unbounded', sans-serif; font-size: 24px; }
.stat span { color: var(--muted); font-size: 12px; }

.panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-card); padding: 22px; margin-bottom: 20px; }
.panel h2 { margin: 0 0 16px; font-size: 17px; font-weight: 800; }
.panel h2 .count { color: var(--muted); font-weight: 600; font-size: 13px; }
.muted { color: var(--muted); font-size: 13px; }
.hint { color: var(--muted); font-size: 12px; margin-left: 12px; }

label { display: flex; flex-direction: column; gap: 6px; font-size: 12px; color: var(--muted); font-weight: 600; }
input, select {
  background: var(--surface-2); border: 1px solid var(--line); color: var(--text);
  border-radius: 14px; padding: 11px 14px; font-size: 14px; font-family: inherit;
}
input[type=file] { padding: 9px; font-size: 12px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 16px; }
@media (max-width: 640px) { .grid2 { grid-template-columns: 1fr; } .stats { grid-template-columns: 1fr; } }

.btn-solid { background: var(--lime); color: var(--lime-ink); border: 0; border-radius: var(--r-pill); padding: 12px 26px; font-weight: 800; font-size: 14px; cursor: pointer; }
.btn-ghost { background: var(--surface-2); color: var(--text); border: 1px solid var(--line); border-radius: var(--r-pill); padding: 10px 18px; font-weight: 700; font-size: 13px; cursor: pointer; }
.btn-danger { background: transparent; color: var(--danger); border: 1px solid rgba(240,139,175,.35); border-radius: var(--r-pill); padding: 10px 18px; font-weight: 700; font-size: 13px; cursor: pointer; }
.sm { padding: 8px 14px; font-size: 12px; }
.inline { display: inline; }

/* Track table */
.track-item {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 12px 0; border-bottom: 1px solid var(--line);
}
.track-item:last-child { border-bottom: 0; }
.track-item img, .track-item .ph {
  width: 48px; height: 48px; border-radius: 12px; object-fit: cover; flex: none;
  display: grid; place-items: center; font-family: 'Unbounded'; color: rgba(10,10,15,.6);
  background: linear-gradient(135deg, var(--lav), var(--pink));
}
.track-meta { flex: 1; min-width: 180px; }
.track-meta strong { display: block; font-size: 14px; }
.track-meta span { color: var(--muted); font-size: 12px; }
.track-actions { display: flex; gap: 8px; align-items: center; }
.track-actions select { padding: 8px 10px; font-size: 12px; border-radius: var(--r-pill); }
.edit-form { width: 100%; display: flex; gap: 8px; flex-wrap: wrap; padding: 10px 0 4px; }
.edit-form input { flex: 1; min-width: 130px; }

/* Playlist */
.pl-create { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.pl-create input[name=name], .pl-create input[name=description], .pl-create input[type=password] { flex: 1; min-width: 160px; }
.pl-item { border: 1px solid var(--line); border-radius: 18px; padding: 14px; margin-bottom: 12px; background: var(--surface-2); }
.pl-head { display: flex; align-items: center; gap: 12px; }
.pl-head strong { flex: 1; }
.pl-track { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 8px 0; border-top: 1px solid var(--line); font-size: 13px; margin-top: 8px; }

/* Login */
.login-body { display: grid; place-items: center; }
.login-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-card);
  padding: 34px; width: min(400px, 90vw); display: flex; flex-direction: column; gap: 10px;
  position: relative;
}
.login-card h1 { font-family: 'Unbounded', sans-serif; font-size: 22px; margin: 0; }
.login-card h1 span { color: var(--lime); }
.login-card p { color: var(--muted); font-size: 13px; margin: 0 0 8px; }
.login-card .err { color: var(--danger); }
.login-card .back { color: var(--muted); font-size: 12px; text-decoration: none; margin-top: 10px; }

button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible {
  outline: 2px solid var(--lime); outline-offset: 2px;
}
