:root{
  --bg: #f6f7fb;
  --panel: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --line: #e2e8f0;

  --primary: #2563eb;      /* kannst später entsättigen */
  --primary-2: #1d4ed8;

  --input-bg: #ffffff;
  --input-text: #0f172a;
  --input-line: #cbd5e1;
  --input-focus: #93c5fd;
}

* {
    box-sizing: border-box;
    font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
}

body{
  background: var(--bg);
  color: var(--text);
}

.topbar{
  background: #ffffffcc;
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}

.title {
    font-weight: 800;
    letter-spacing: .2px;
}

.sub {
    color: var(--mut);
    font-size: 12px;
    margin-top: 2px;
}

.top-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.wrap {
    padding: 16px;
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.panel{
  background: var(--panel);
  border: 1px solid var(--line);
}

.panel-head {
    padding: 10px 12px;
    border-bottom: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.h {
    font-weight: 700;
}

.btn {
    border: 1px solid var(--line);
    background: transparent;
    color: var(--txt);
    padding: 8px 10px;
    border-radius: 10px;
    cursor: pointer;
}

.btn.primary{
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
.btn.primary:hover{ background: var(--primary-2); }

.muted {
    color: var(--muted);
}

.btn.ghost {
    background: transparent;
}

input, select, textarea{
  background: var(--input-bg);
  color: var(--input-text);
  border: 1px solid var(--input-line);
  border-radius: 10px;
  padding: 10px 12px;
}

input:focus, select:focus, textarea:focus{
  outline: 3px solid color-mix(in srgb, var(--input-focus) 60%, transparent);
  border-color: var(--input-focus);
}

.hint {
    color: var(--mut);
    font-size: 12px;
}
.hint.muted{ color: var(--muted); }

.login {
    padding: 12px;
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

#table {
    padding: 12px;
    overflow: auto;
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

th,
td {
    border-bottom: 1px solid var(--line);
    padding: 8px;
    text-align: left;
    white-space: nowrap;
}

.badge {
    padding: 4px 8px;
    border-radius: 999px;
    border: 1px solid var(--line);
    font-size: 12px;
}

.grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    padding: 12px;
}

label {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 12px;
    color: var(--mut);
}

label.full {
    grid-column: 1/-1;
}

textarea {
    min-height: 90px;
    resize: vertical;
}

.dlg {
    width: min(920px, 96vw);
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    color: var(--txt);
}

.dlg-title {
    font-weight: 800;
    margin-bottom: 10px;
}

.dlg-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    padding: 0 12px 12px;
}

dialog::backdrop {
    background: rgba(0, 0, 0, 0.221);
}

.panel-actions { display:flex; gap:8px; align-items:center; }
.inp { padding:10px 12px; border-radius:10px; border:1px solid rgba(0,0,0,.15); background:#fff; color:#111; }

.token-list { display:flex; flex-direction:column; gap:8px; padding:12px; }

.token-row {
  display:grid;
  grid-template-columns: 160px 1fr 90px 90px;
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
}

.token-id { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size:12px; color:#555; }
.token-name { width:100%; }
.token-actions { display:flex; gap:8px; justify-content:flex-end; }
