/* Admin-Styles — bewusst funktional, klare Kontraste, viel Weißraum. */
:root {
  --admin-bg: #f6f4ef;
  --card: #ffffff;
  --ink: #1f1d1a;
  --ink-soft: #5a564f;
  --rule: #d9d3c5;
  --accent: #7a6a4a;
  --danger: #a8332e;
  --ok: #2e7a4a;
}

body.admin {
  background: var(--admin-bg);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  margin: 0;
}

.admin-header {
  background: #2a2723;
  color: #f6f1e6;
  padding: 12px 0;
  position: sticky; top: 0;
  z-index: 20;
}
.admin-header .wrap {
  max-width: 1100px; margin: 0 auto; padding: 0 24px;
  display: flex; gap: 24px; align-items: center; flex-wrap: wrap;
}
.admin-header .brand { color: #f6f1e6; font-weight: 600; text-decoration: none; }
.admin-header nav { display: flex; gap: 18px; flex: 1; }
.admin-header nav a { color: #d9d3c5; text-decoration: none; font-size: 14px; }
.admin-header nav a:hover { color: #fff; }
.admin-header .user { font-size: 12px; color: #d9d3c5; }
.admin-header .user a { color: #f6f1e6; }

.admin-main { padding: 32px 0 64px; }
.admin-main .wrap { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

h1 { font-size: 28px; margin: 0 0 18px; font-weight: 500; }
h2 { font-size: 20px; margin: 24px 0 12px; font-weight: 500; }
h3 { font-size: 16px; margin: 18px 0 8px; }

.card {
  background: var(--card);
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 20px;
  margin: 14px 0;
}
.card header { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 1px solid var(--rule); padding-bottom: 10px; margin-bottom: 12px; }
.card header h2 { margin: 0; }
.card header small { color: var(--ink-soft); }

label { display: block; margin: 12px 0; font-size: 14px; color: var(--ink-soft); }
label input, label textarea, label select, input[type="text"], input[type="email"], textarea, select {
  display: block; width: 100%; max-width: 640px;
  padding: 8px 10px; border: 1px solid var(--rule); border-radius: 4px;
  font: inherit; background: #fcfaf5; color: var(--ink); margin-top: 4px;
}
textarea { font-family: ui-monospace, SF Mono, Menlo, monospace; font-size: 13px; }
label.check { display: flex; align-items: center; gap: 8px; }
label.check input { width: auto; margin: 0; }

button, .btn {
  display: inline-block;
  padding: 9px 18px; border: 1px solid var(--accent); background: var(--accent); color: #fff;
  border-radius: 4px; cursor: pointer; font: inherit; text-decoration: none; margin: 6px 6px 6px 0;
}
button.danger, .btn.danger { background: var(--danger); border-color: var(--danger); }
button.small, .btn.small { padding: 4px 8px; font-size: 12px; }
button:hover, .btn:hover { filter: brightness(.95); }

.flash { padding: 10px 14px; border-radius: 4px; margin: 12px 0; }
.flash.ok { background: #eaf4ec; color: var(--ok); border: 1px solid #c8e0cf; }
.flash.err, .err { background: #f7e6e5; color: var(--danger); padding: 10px 14px; border-radius: 4px; }

.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; margin: 16px 0 28px; }
.stat { background: var(--card); border: 1px solid var(--rule); border-radius: 6px; padding: 18px; text-align: center; }
.stat .n { display: block; font-size: 36px; font-weight: 600; color: var(--accent); }
.stat .lbl { display: block; font-size: 12px; color: var(--ink-soft); letter-spacing: .1em; text-transform: uppercase; margin-top: 4px; }

.recent { list-style: none; padding: 0; }
.recent li { padding: 8px 0; border-bottom: 1px dashed var(--rule); display: flex; justify-content: space-between; }
.recent li .ts { color: var(--ink-soft); font-size: 12px; }

.arbeiten { list-style: none; padding: 0; margin: 0; }
.arbeiten li {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--rule);
}
.arbeiten li .title { flex: 1; min-width: 0; }
.arbeiten li .yr { color: var(--ink-soft); font-size: 12px; margin-left: 8px; }
.arbeiten li .badge { display: inline-block; padding: 2px 6px; background: #eee2c4; color: #6a4a1a; border-radius: 3px; font-size: 11px; margin-left: 8px; }

.row-actions { display: flex; gap: 4px; align-items: center; }
.row-actions form { margin: 0; display: inline; }
.row-actions .icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  padding: 0; margin: 0;
  border: 1px solid var(--rule);
  background: #fcfaf5;
  color: var(--ink);
  border-radius: 4px;
  cursor: pointer;
  font-size: 15px;
  text-decoration: none;
}
.row-actions .icon:hover { background: #f3efe7; }
.row-actions .icon[disabled] { opacity: .3; cursor: not-allowed; background: #fcfaf5; }
.row-actions .icon.danger { color: var(--danger); border-color: #e3c8c6; }
.row-actions .icon.danger:hover { background: #f7e6e5; }
.row-actions .icon.edit { color: var(--accent); }

.img-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 14px; }
.img-grid figure { background: #fcfaf5; border: 1px solid var(--rule); border-radius: 4px; padding: 8px; margin: 0; }
.img-grid img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 3px; }
.img-grid .caption-form { display: flex; gap: 4px; margin-top: 6px; }
.img-grid .caption-form input { flex: 1; padding: 4px 6px; font-size: 12px; }
.img-grid .caption-form button { padding: 4px 8px; margin: 0; }
.img-grid figure { position: relative; }
.img-grid figure.is-header { outline: 2px solid var(--accent); }
.img-grid .badge-header {
  position: absolute; top: 12px; left: 12px;
  background: var(--accent); color: #fff;
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 3px;
}
.img-grid .img-row { display: flex; gap: 4px; margin: 6px 0 4px; }
.img-grid .img-row button { padding: 4px 8px; margin: 0; font-size: 12px; }
.img-grid .img-row button[disabled] { opacity: .35; cursor: not-allowed; }

/* Image-Picker (Coming Soon) */
.pick-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; margin: 6px 0 14px; }
.pick { position: relative; cursor: pointer; display: block; border: 2px solid transparent; border-radius: 4px; overflow: hidden; }
.pick input { position: absolute; top: 6px; left: 6px; z-index: 2; }
.pick img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; transition: filter .2s; }
.pick.selected { border-color: var(--accent); }
.pick.selected img { filter: brightness(.92) saturate(.9); }
.pick:hover img { filter: brightness(.95); }
details > summary { padding: 10px 0; }

/* Backup-Tabelle */
.bak-list { width: 100%; border-collapse: collapse; margin: 10px 0; font-size: 14px; }
.bak-list th, .bak-list td { padding: 8px 10px; text-align: left; border-bottom: 1px dashed var(--rule); }
.bak-list th { font-weight: 500; color: var(--ink-soft); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }
.bak-list td a { color: var(--accent); }
.bak-list td:last-child { text-align: right; }

.login-card {
  max-width: 380px; margin: 80px auto; background: var(--card);
  border: 1px solid var(--rule); border-radius: 8px; padding: 32px;
}
.login-card h1 { margin: 0 0 16px; font-size: 22px; }
.login-card .hint { color: var(--ink-soft); font-size: 12px; margin-top: 12px; }
.login-card .ok { color: var(--ok); }

details > summary { cursor: pointer; padding: 8px 0; color: var(--accent); }
.hint { color: var(--ink-soft); font-size: 13px; }
