/* Sunny Island Consent Portal – Admin-Oberfläche */
:root {
  --accent: #0a5ad6;
  --accent-d: #0848aa;
  --text: #2b333a;
  --muted: #6b7680;
  --border: #e2e6ea;
  --bg: #f4f6f8;
  --card: #ffffff;
  --radius: 10px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
}
a { color: var(--accent); }
.muted { color: var(--muted); }
.mono { font-family: ui-monospace, "SFMono-Regular", Consolas, monospace; }
.small { font-size: 12px; }
.nowrap { white-space: nowrap; }

/* Topbar */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--card); border-bottom: 1px solid var(--border);
  padding: 12px 22px;
}
.topbar .brand { display: flex; align-items: center; gap: 10px; font-weight: 600; }
.topbar .brand img { height: 26px; }
.topbar nav a { margin-left: 18px; text-decoration: none; }

.container { max-width: 1100px; margin: 22px auto; padding: 0 18px; }

/* Cards */
.card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px; margin-bottom: 20px;
}
.card h2 { margin: 0 0 14px; font-size: 16px; }
.card h3 { margin: 18px 0 8px; font-size: 14px; }

.cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-bottom: 20px; }
.card.stat { text-align: center; padding: 16px; }
.card.stat .num { display: block; font-size: 26px; font-weight: 700; color: var(--accent); }
.card.stat .lbl { display: block; color: var(--muted); font-size: 12px; margin-top: 4px; }

.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

/* Balken je Kategorie */
.bar-row { display: grid; grid-template-columns: 90px 1fr 90px; align-items: center; gap: 10px; margin: 8px 0; }
.bar { background: #eef1f4; border-radius: 6px; height: 14px; overflow: hidden; }
.bar > span { display: block; height: 100%; background: var(--accent); }
.bar-val { text-align: right; color: var(--muted); font-size: 12px; }

/* Sparkline */
.spark { display: flex; align-items: flex-end; gap: 3px; height: 80px; }
.spark-bar { flex: 1; background: var(--accent); border-radius: 2px 2px 0 0; min-width: 3px; opacity: .85; }

/* Filter */
.filters { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 12px; }
.filters input, .filters select {
  padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; font: inherit; background: #fff;
}
.filters label { color: var(--muted); display: inline-flex; gap: 6px; align-items: center; }

.btn {
  display: inline-block; padding: 8px 14px; border: 1px solid var(--border);
  border-radius: 8px; background: #fff; color: var(--text); cursor: pointer;
  text-decoration: none; font: inherit;
}
.btn:hover { border-color: #c7cdd3; }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent-d); border-color: var(--accent-d); }

/* Tabelle */
.table-scroll { overflow-x: auto; }
table.data { width: 100%; border-collapse: collapse; }
table.data th, table.data td { padding: 8px 10px; border-bottom: 1px solid var(--border); text-align: left; }
table.data th { color: var(--muted); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .03em; }
table.data tr:hover td { background: #fafbfc; }
.link { text-decoration: none; }

.dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; }
.dot-on { background: #1f9c4d; }
.dot-off { background: #d6dbe0; }

.tag { display: inline-block; padding: 2px 8px; border-radius: 20px; font-size: 11px; font-weight: 600; }
.tag-accept_all { background: #e3f4ea; color: #1f7a45; }
.tag-custom { background: #e6effb; color: #1d5fb8; }
.tag-deny { background: #fdecec; color: #b53636; }
.tag-update { background: #fff3e0; color: #a86412; }
.tag-withdraw { background: #f1edf8; color: #6a3fb0; }

/* Pager */
.pager { display: flex; gap: 6px; margin-top: 14px; flex-wrap: wrap; }
.pager a { padding: 6px 11px; border: 1px solid var(--border); border-radius: 8px; text-decoration: none; color: var(--text); }
.pager a.active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* Detail */
table.kv { width: 100%; border-collapse: collapse; }
table.kv th { text-align: left; width: 160px; color: var(--muted); font-weight: 600; padding: 7px 10px; vertical-align: top; }
table.kv td { padding: 7px 10px; border-bottom: 1px solid var(--border); word-break: break-word; }
pre.raw { background: #1e2329; color: #e6edf3; padding: 14px; border-radius: 8px; overflow-x: auto; font-size: 12.5px; }

/* Login */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; }
.card.login { max-width: 360px; width: 100%; margin: 0; }
.card.login h1 { margin: 0 0 4px; font-size: 20px; }
.card.login label { display: block; margin: 16px 0 6px; font-weight: 600; }
.card.login input { width: 100%; padding: 10px 12px; border: 1px solid var(--border); border-radius: 8px; font: inherit; }
.card.login .btn { width: 100%; margin-top: 18px; text-align: center; }
.alert { background: #fdecec; color: #b53636; border: 1px solid #f3c9c9; border-radius: 8px; padding: 10px 12px; margin-top: 12px; }

@media (max-width: 800px) {
  .cards { grid-template-columns: repeat(2, 1fr); }
  .grid2 { grid-template-columns: 1fr; }
}
