/* ============================================================
   Lorbass v2 – Admin-Bereich
   Setzt tokens.css voraus. Kein Tailwind, kein Framework.
   ============================================================ */

/* ── Basis ─────────────────────────────────────────────────── */
.admin-body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: var(--font-sans); font-size: .9375rem;
  min-height: 100vh;
}

/* ── Top Bar ────────────────────────────────────────────────── */
.admin-topbar {
  position: sticky; top: 0; z-index: 30;
  height: 60px; background: var(--bg);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1rem;
}
.admin-topbar-left { display: flex; align-items: center; gap: .75rem; }
.admin-topbar-right { display: flex; align-items: center; gap: .25rem; }

.admin-brand { display: flex; align-items: center; gap: .5rem; text-decoration: none; }
.admin-brand .brand-mark { font-family: var(--font-headline); font-size: 1.2rem; letter-spacing: .1em; color: var(--red); }
.admin-brand-label { font-size: .7rem; text-transform: uppercase; letter-spacing: .15em; color: var(--muted); }

.admin-topbar-btn {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; color: var(--muted); text-decoration: none;
  border-radius: var(--radius-md); transition: color .15s;
}
.admin-topbar-btn:hover { color: var(--accent); }

/* Hamburger */
.admin-hamburger {
  display: none; flex-direction: column; justify-content: space-between;
  width: 44px; height: 44px; padding: 13px 11px;
  background: none; border: none; cursor: pointer;
}
.admin-hamburger span {
  display: block; height: 2px; background: var(--text); border-radius: 1px;
}
@media (max-width: 1023px) { .admin-hamburger { display: flex; } }

/* ── Layout ─────────────────────────────────────────────────── */
.admin-layout { display: flex; min-height: calc(100vh - 60px); }

/* ── Sidebar ────────────────────────────────────────────────── */
.admin-sidebar {
  width: 240px; flex-shrink: 0;
  background: var(--bg); border-right: 1px solid var(--border);
  position: sticky; top: 60px; height: calc(100vh - 60px);
  overflow-y: auto; display: flex; flex-direction: column;
}

@media (max-width: 1023px) {
  .admin-sidebar {
    position: fixed; top: 0; left: 0; height: 100vh; z-index: 40;
    transform: translateX(-100%); transition: transform .25s ease;
    width: 260px; border-right: 1px solid var(--border);
  }
  .admin-sidebar.is-open { transform: translateX(0); }
}

.admin-overlay {
  display: none; position: fixed; inset: 0; z-index: 39;
  background: rgba(0,0,0,.65);
}
.admin-overlay.is-visible { display: block; }

/* ── Nav ────────────────────────────────────────────────────── */
.admin-nav { flex: 1; padding: 1rem 0; display: flex; flex-direction: column; }
.admin-nav-section { padding: 0 .75rem; margin-bottom: 1rem; }
.admin-nav-label {
  font-size: .68rem; text-transform: uppercase; letter-spacing: .1em;
  color: var(--muted); padding: 0 .75rem; margin: 0 0 .25rem;
}
.admin-nav-item {
  display: flex; align-items: center; gap: .75rem;
  padding: .55rem .75rem; border-radius: var(--radius-md);
  color: rgba(232,228,220,.75); text-decoration: none;
  font-size: .875rem; min-height: 44px; transition: color .15s, background .15s;
}
.admin-nav-item:hover { background: var(--surface); color: var(--accent); }
.admin-nav-item.is-active {
  background: rgba(200,169,110,.08); color: var(--accent);
  border-left: 2px solid var(--accent); margin-left: -.75rem;
  padding-left: calc(.75rem - 2px);
}
.admin-nav-bottom { margin-top: auto; padding: .75rem; border-top: 1px solid var(--border); }

/* ── Main ───────────────────────────────────────────────────── */
.admin-main { flex: 1; min-width: 0; }
.admin-content { padding: 1.5rem 1.25rem; max-width: 1100px; }

/* ── Page Header ────────────────────────────────────────────── */
.admin-page-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  flex-wrap: wrap; gap: .5rem; margin-bottom: 1.5rem;
}
.admin-page-title { font-size: 1.5rem; font-weight: 300; color: var(--text); margin: 0; }
.admin-page-sub   { font-size: .85rem; color: var(--muted); margin: .25rem 0 0; }
.admin-page-meta  { font-size: .85rem; color: var(--muted); align-self: center; }
.admin-section-title {
  font-size: .75rem; text-transform: uppercase; letter-spacing: .1em;
  color: var(--accent); margin: 0 0 .75rem;
}
.admin-back-link { font-size: .85rem; color: var(--muted); text-decoration: none; display: block; margin-bottom: .4rem; }
.admin-back-link:hover { color: var(--accent); }

/* ── Cards ──────────────────────────────────────────────────── */
.admin-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); overflow: hidden;
}
.admin-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .75rem 1rem; border-bottom: 1px solid var(--border);
}
.admin-card-title { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--accent); margin: 0; }
.admin-card-link  { font-size: .8rem; color: var(--muted); text-decoration: none; }
.admin-card-link:hover { color: var(--accent); }

/* ── Stat Karten ────────────────────────────────────────────── */
.admin-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; }
.admin-stat {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 1rem;
  text-decoration: none; transition: border-color .15s;
  display: flex; flex-direction: column; gap: .25rem;
}
.admin-stat:hover { border-color: rgba(200,169,110,.4); }
.admin-stat svg   { color: var(--accent); flex-shrink: 0; }
.admin-stat-value { font-size: 1.8rem; font-weight: 300; color: var(--text); margin: .25rem 0 0; line-height: 1; }
.admin-stat-label { font-size: .8rem; color: var(--muted); }

@media (max-width: 600px) {
  .admin-stats { grid-template-columns: 1fr 1fr; }
  .admin-stats .admin-stat:last-child { grid-column: 1 / -1; }
}

/* ── Event-Liste (Dashboard) ────────────────────────────────── */
.admin-event-list { list-style: none; margin: 0; padding: 0; }
.admin-event-item {
  display: flex; align-items: center; gap: .75rem;
  padding: .75rem 1rem; border-bottom: 1px solid var(--border);
}
.admin-event-item:last-child { border-bottom: none; }
.admin-event-thumb {
  width: 48px; height: 48px; border-radius: var(--radius-sm);
  object-fit: cover; flex-shrink: 0; background: var(--bg);
}
.admin-event-thumb--empty { background: rgba(200,169,110,.1); }
.admin-event-name  { font-size: .9rem; color: var(--text); margin: 0; }
.admin-event-date  { font-size: .8rem; color: var(--muted); margin: .15rem 0 0; }

/* ── Schnellaktionen ────────────────────────────────────────── */
.admin-quick { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; }
.admin-quick-item {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 1rem;
  text-decoration: none; text-align: center; color: var(--text);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-size: .85rem; transition: border-color .15s, color .15s;
  min-height: 44px;
}
.admin-quick-item:hover { border-color: rgba(200,169,110,.4); color: var(--accent); }
.admin-quick-item svg   { color: var(--accent); }

/* ── Suche ──────────────────────────────────────────────────── */
.admin-search-form { display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem; }
.admin-search-wrap { position: relative; flex: 1; }
.admin-search-icon { position: absolute; left: .75rem; top: 50%; transform: translateY(-50%); color: var(--muted); pointer-events: none; }
.admin-search-input {
  width: 100%; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: .6rem .85rem .6rem 2.4rem;
  color: var(--text); font-size: .9rem; font-family: inherit;
  outline: none; transition: border-color .15s; min-height: 44px;
  box-sizing: border-box;
}
.admin-search-input:focus { border-color: var(--accent); }
.admin-search-clear { font-size: .85rem; color: var(--muted); text-decoration: none; white-space: nowrap; }
.admin-search-clear:hover { color: var(--red); }

/* ── Tabelle ────────────────────────────────────────────────── */
.admin-table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.admin-table thead { background: var(--bg); }
.admin-table th {
  text-align: left; font-size: .7rem; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted); padding: .75rem 1rem;
  font-weight: 400; white-space: nowrap;
}
.admin-table td   { padding: .75rem 1rem; border-bottom: 1px solid var(--border); vertical-align: middle; }
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover { background: rgba(255,255,255,.02); }
.admin-td-muted   { color: var(--muted); font-size: .83rem; }
.admin-td-action  { text-align: right; }

.admin-action-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: var(--radius-sm);
  color: var(--muted); text-decoration: none; transition: color .15s;
}
.admin-action-btn:hover { color: var(--accent); }

/* Mobile-Karten (statt Tabelle) */
.admin-cards-mobile { display: none; }
@media (max-width: 767px) {
  .admin-table-wrap  { display: none; }
  .admin-cards-mobile { display: flex; flex-direction: column; gap: .6rem; }
}

.admin-app-card { display: block; padding: .9rem 1rem; text-decoration: none; color: var(--text); }
.admin-app-card:hover { border-color: rgba(200,169,110,.4); }
.admin-app-card-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: .3rem; }

/* ── Pagination ─────────────────────────────────────────────── */
.admin-pagination { display: flex; align-items: center; gap: .75rem; justify-content: center; margin-top: 1.25rem; }
.admin-page-btn { color: var(--accent); text-decoration: none; font-size: .875rem; }
.admin-page-info { font-size: .85rem; color: var(--muted); }

/* ── Empty State ────────────────────────────────────────────── */
.admin-empty { text-align: center; color: var(--muted); padding: 3rem 1rem; font-size: .9rem; }

/* ── Detail-Layout ──────────────────────────────────────────── */
.admin-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 767px) { .admin-detail-grid { grid-template-columns: 1fr; } }
.admin-detail-col { display: flex; flex-direction: column; }

.admin-dl { margin: 0; padding: 1rem; display: grid; grid-template-columns: auto 1fr; gap: .4rem 1rem; font-size: .875rem; }
.admin-dl dt { color: var(--muted); white-space: nowrap; }
.admin-dl dd { margin: 0; color: var(--text); word-break: break-word; }

/* ── Buttons (dupliziert aus app.css für admin/login ohne app.css) ─── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: .65rem 1.5rem; border-radius: var(--radius-md);
  font-family: inherit; font-size: .95rem; font-weight: 500;
  border: none; cursor: pointer; text-decoration: none;
  transition: background .15s, color .15s; min-height: 44px;
}
.btn-primary { background: var(--accent); color: var(--bg); }
.btn-primary:hover { background: #e0c080; }

/* ── Login ──────────────────────────────────────────────────── */
.login-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.login-wrap { width: 100%; max-width: 360px; padding: 1rem; }
.login-brand { display: block; text-align: center; margin-bottom: 1.5rem; text-decoration: none; }
.login-brand .brand-mark { font-family: var(--font-headline); font-size: 1.8rem; letter-spacing: .15em; color: var(--red); }
.login-card  { padding: 1.5rem; }
.login-title { font-size: 1.2rem; font-weight: 400; color: var(--text); margin: 0 0 1.25rem; text-align: center; }
.login-form  { display: flex; flex-direction: column; gap: .75rem; }
.login-form .field { display: flex; flex-direction: column; gap: .3rem; }
.login-form label { font-size: .85rem; color: var(--text); }
.login-form input {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md);
  padding: .65rem .85rem; color: var(--text); font-family: inherit; font-size: .95rem;
  outline: none; transition: border-color .15s; min-height: 44px;
}
.login-form input:focus { border-color: var(--accent); }
.login-error  { color: #ffb3b3; font-size: .875rem; margin: 0 0 .75rem; text-align: center; }
.login-locked { color: var(--muted); font-size: .875rem; text-align: center; }

/* ── Flash-Meldung ──────────────────────────────────────────── */
.admin-flash {
  padding: .75rem 1rem; border-radius: var(--radius-md);
  font-size: .875rem; margin-bottom: 1.25rem;
}
.admin-flash--success { background: rgba(100,200,120,.12); color: #6dcf8a; border: 1px solid rgba(100,200,120,.25); }
.admin-flash--error   { background: rgba(204,  0,  0,.12); color: #ff8080; border: 1px solid rgba(204,  0,  0,.25); }

/* ── Badges ─────────────────────────────────────────────────── */
.admin-badge {
  display: inline-block; padding: .2rem .55rem; border-radius: 99px;
  font-size: .72rem; font-weight: 500; letter-spacing: .04em; white-space: nowrap;
}
.admin-badge--green { background: rgba(100,200,120,.15); color: #6dcf8a; }
.admin-badge--gray  { background: rgba(150,150,150,.15); color: var(--muted); }
.admin-badge--amber { background: rgba(220,160, 50,.15); color: #dcb040; }

/* ── Page-Layout ────────────────────────────────────────────── */
.admin-page { max-width: 1100px; }
.admin-page--narrow { max-width: 720px; }
.admin-page-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  flex-wrap: wrap; gap: .75rem; margin-bottom: 1.5rem;
}

/* ── Buttons (ergänzend) ────────────────────────────────────── */
.btn-outline {
  background: transparent; color: var(--text);
  border: 1px solid var(--border); gap: .4rem;
}
.btn-outline:hover { border-color: var(--accent); color: var(--accent); }
.btn-sm { min-height: 36px; padding: .4rem .85rem; font-size: .85rem; gap: .35rem; }

/* ── Tabellen-Utilities (Events-Admin) ──────────────────────── */
.admin-td-thumb   { width: 52px; padding-right: 0; }
.admin-td-actions { text-align: right; white-space: nowrap; }
.admin-table-name { font-size: .875rem; color: var(--text); }
.admin-table-slug { font-size: .75rem; color: var(--muted); font-family: monospace; }
.admin-table-date { font-size: .83rem; color: var(--muted); white-space: nowrap; }

/* ── Thumbnails ─────────────────────────────────────────────── */
.admin-thumb-sm {
  width: 40px; height: 40px; border-radius: var(--radius-sm);
  object-fit: cover; display: block; flex-shrink: 0;
}
.admin-thumb-placeholder {
  background: rgba(200,169,110,.08); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; color: var(--border);
}

/* ── Aktions-Icons ──────────────────────────────────────────── */
.admin-action-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: var(--radius-sm);
  color: var(--muted); text-decoration: none; cursor: pointer;
  background: none; border: none; transition: color .15s;
}
.admin-action-icon:hover           { color: var(--accent); }
.admin-action-icon--danger:hover   { color: var(--red); }

/* ── Mobile-Karten (Events-Admin) ──────────────────────────── */
.admin-cards { display: none; }
@media (max-width: 767px) {
  .admin-table-wrap { display: none; }
  .admin-cards      { display: flex; flex-direction: column; gap: .6rem; }
}
.admin-card-row {
  display: flex; align-items: flex-start; gap: .75rem;
  padding: .85rem; border-bottom: 1px solid var(--border);
}
.admin-card-thumb {
  width: 64px; height: 64px; border-radius: var(--radius-sm);
  object-fit: cover; flex-shrink: 0;
}
.admin-card-body  { flex: 1; min-width: 0; }
.admin-card-name  { font-size: .875rem; color: var(--text); margin: 0 0 .2rem; }
.admin-card-date  { font-size: .8rem; color: var(--muted); margin: .2rem 0 0; }
.admin-card-badge { flex-shrink: 0; }
.admin-card-actions {
  display: flex; flex-wrap: wrap; gap: .5rem;
  padding: .65rem .85rem;
}

/* ── Event-Formular ─────────────────────────────────────────── */
.admin-form { display: flex; flex-direction: column; gap: 1rem; }
.admin-field { display: flex; flex-direction: column; gap: .3rem; }
.admin-field label {
  font-size: .82rem; color: var(--muted); letter-spacing: .03em;
}
.admin-field input,
.admin-field select,
.admin-field textarea {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: .6rem .85rem;
  color: var(--text); font-family: inherit; font-size: .9rem;
  outline: none; transition: border-color .15s; min-height: 44px;
}
.admin-field input:focus,
.admin-field select:focus,
.admin-field textarea:focus { border-color: var(--accent); }
.admin-field textarea { resize: vertical; min-height: 100px; }
.admin-field select { appearance: auto; cursor: pointer; }
.admin-field-hint { font-size: .78rem; color: var(--muted); margin: 0; }
.admin-required   { color: var(--accent); }
.admin-form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 599px) { .admin-form-row { grid-template-columns: 1fr; } }
.admin-form-actions { display: flex; flex-wrap: wrap; gap: .75rem; padding-top: .5rem; }

/* Slug-Feld mit /events/-Präfix */
.admin-field-prefix-wrap {
  display: flex; align-items: stretch;
  border: 1px solid var(--border); border-radius: var(--radius-md);
  overflow: hidden; transition: border-color .15s;
}
.admin-field-prefix-wrap:focus-within { border-color: var(--accent); }
.admin-field-prefix {
  padding: .6rem .75rem; background: var(--bg);
  font-size: .8rem; color: var(--muted); white-space: nowrap;
  border-right: 1px solid var(--border); display: flex; align-items: center;
}
.admin-field-prefix-input {
  border: none !important; border-radius: 0 !important; flex: 1;
  min-width: 0; outline: none;
}
.admin-field-prefix-input:focus { border-color: transparent !important; }

/* Aktuelles Bild Vorschau */
.admin-current-img {
  display: flex; align-items: center; gap: .75rem;
  padding: .65rem; background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-md); margin-bottom: .25rem;
}


/* ── Settings-Seite ─────────────────────────────────────────── */
.admin-settings-section {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 2rem;
}
.admin-settings-heading {
  font-size: 1rem; font-weight: 600; margin: 0 0 .35rem;
}
.admin-settings-hint {
  font-size: .8rem; color: var(--muted); margin: 0 0 1.25rem;
}
.admin-settings-hint code {
  font-family: var(--font-mono, monospace); background: var(--bg);
  padding: .1em .35em; border-radius: 3px; font-size: .78rem;
}
