/* DRAN – Admin-/Pflegebereich (funktional, ruhiger als die Frontseite) */
:root {
    --bg: #0f1117; --panel: #181b24; --panel-2: #20242f; --ink: #eef0f6; --dim: #99a0b3;
    --pink: #ff2d7e; --cyan: #00c2d6; --line: rgba(255,255,255,.1);
    --ok: #1f8a4c; --err: #c23b4b; --danger: #e0455a;
    --font-display: 'Anton', sans-serif; --font-body: 'Space Grotesk', system-ui, sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--ink); font-family: var(--font-body); line-height: 1.55; }
a { color: var(--cyan); }
.display { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 1px; font-weight: 400; margin: 0 0 1rem; font-size: clamp(1.8rem,4vw,2.6rem); }
.section-sub { font-family: var(--font-display); text-transform: uppercase; margin: 2.5rem 0 1rem; font-size: 1.5rem; }
.muted { color: var(--dim); }

/* Header */
.admin-header {
    display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; justify-content: space-between;
    background: var(--panel); border-bottom: 1px solid var(--line); padding: .8rem 1.5rem; position: sticky; top: 0; z-index: 10;
}
.admin-brand { font-family: var(--font-display); font-size: 1.6rem; color: var(--ink); text-decoration: none; letter-spacing: 1px; }
.admin-brand span { color: var(--pink); }
.admin-nav { display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: center; }
.admin-nav a { color: var(--dim); text-decoration: none; font-weight: 500; }
.admin-nav a:hover { color: var(--ink); }
.admin-nav .admin-logout { color: var(--pink); }

.admin-main { max-width: 980px; margin: 0 auto; padding: 2rem 1.5rem 4rem; }

/* Alerts */
.alert { border-radius: 10px; padding: .8rem 1rem; margin-bottom: 1.2rem; border: 1px solid var(--line); }
.alert-ok { background: rgba(31,138,76,.15); border-color: var(--ok); }
.alert-err { background: rgba(194,59,75,.15); border-color: var(--err); }
.alert ul { margin: 0; padding-left: 1.2rem; }

/* Login */
.login-box { max-width: 380px; margin: 8vh auto; background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 2rem; }
.login-box label { display: block; margin: 1rem 0; }
.login-box input { width: 100%; }

/* Buttons */
.btn { display: inline-block; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 1px;
    border: 1px solid transparent; border-radius: 50px; padding: .6rem 1.3rem; cursor: pointer; font-size: 1rem; text-decoration: none; transition: .15s; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--pink); color: #fff; }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--cyan); }
.btn-danger { background: transparent; color: var(--danger); border-color: var(--danger); }
.btn-danger:hover { background: var(--danger); color: #fff; }
.btn-small { font-size: .82rem; padding: .35rem .8rem; }

/* Forms */
input, textarea, select {
    background: var(--panel-2); border: 1px solid var(--line); color: var(--ink);
    border-radius: 8px; padding: .6rem .7rem; font-family: inherit; font-size: 1rem; width: 100%;
}
input:focus, textarea:focus { outline: 2px solid var(--cyan); border-color: var(--cyan); }
input[type=checkbox] { width: auto; }
.form-grid { max-width: 620px; display: grid; gap: 1.1rem; }
.field label { display: block; font-weight: 700; margin-bottom: .35rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field-checks { display: flex; gap: 1.5rem; }
.field-checks label { display: flex; align-items: center; gap: .5rem; font-weight: 500; }

.page-top { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }

/* Dashboard */
.card-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 1rem; margin: 1.5rem 0; }
.dash-card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 1.5rem; text-align: center; text-decoration: none; color: var(--ink); transition: .15s; }
.dash-card:hover { border-color: var(--pink); transform: translateY(-3px); }
.dash-num { display: block; font-family: var(--font-display); font-size: 2.6rem; color: var(--cyan); }
.dash-label { color: var(--dim); }
.quick-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1rem; }

/* Tables */
.data-table { width: 100%; border-collapse: collapse; margin-top: 1.5rem; }
.data-table th, .data-table td { text-align: left; padding: .7rem .6rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
.data-table th { color: var(--dim); text-transform: uppercase; font-size: .8rem; letter-spacing: 1px; }
.data-table tr.is-dim { opacity: .55; }
.row-actions { display: flex; gap: .5rem; align-items: center; }
.row-actions form { margin: 0; }

.badge { display: inline-block; font-size: .75rem; padding: .25rem .6rem; border-radius: 50px; text-transform: uppercase; letter-spacing: .5px; }
.badge-soldout { background: var(--pink); color: #fff; }
.badge-cancel { background: #555; color: #fff; }
.badge-free { background: transparent; color: var(--dim); border: 1px solid var(--line); }

.empty-state { text-align: center; color: var(--dim); border: 2px dashed var(--line); border-radius: 12px; padding: 2.5rem; margin-top: 1.5rem; }

/* Upload cards */
.upload-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1.2rem; margin: 1.5rem 0; }
.upload-card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 1.3rem; display: grid; gap: .8rem; align-content: start; }
.upload-card h3 { margin: 0; font-family: var(--font-display); text-transform: uppercase; }
.upload-card label { display: grid; gap: .3rem; font-size: .9rem; color: var(--dim); }
.upload-card .status { margin: 0; font-size: .9rem; }

/* Media grid */
.media-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 1rem; }
.media-tile { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.media-preview { aspect-ratio: 16/10; background: #000; display: grid; place-items: center; }
.media-preview img { width: 100%; height: 100%; object-fit: cover; }
.media-badge { font-family: var(--font-display); color: var(--cyan); font-size: 1.2rem; }
.media-meta { padding: .6rem .8rem; display: grid; gap: .1rem; }
.media-meta span { font-size: .8rem; }
.media-actions { display: flex; gap: .5rem; padding: 0 .8rem .8rem; align-items: center; }
.media-actions form { margin: 0; }
.inline-sort { display: flex; gap: .3rem; }
.inline-sort input { width: 64px; }

/* Besetzung */
.member-admin-list { display: grid; gap: .8rem; margin-top: 1.5rem; }
.member-admin-row {
    display: grid; grid-template-columns: 64px 1fr auto; gap: 1rem; align-items: center;
    background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: .8rem 1rem;
}
.member-admin-pic img, .member-admin-noimg {
    width: 64px; height: 64px; border-radius: 50%; object-fit: cover; object-position: center top; display: block;
}
.member-admin-noimg {
    display: grid; place-items: center; font-family: var(--font-display); font-size: 1.8rem; color: #000;
    background: radial-gradient(circle at 30% 30%, var(--cyan), var(--pink));
}
.member-admin-meta { display: grid; gap: .15rem; min-width: 0; }
.member-admin-meta span { font-size: .85rem; }
.member-admin-actions { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.member-admin-actions form { margin: 0; }
.current-photo { display: flex; align-items: center; gap: .8rem; margin-bottom: .6rem; }
.current-photo img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; object-position: center top; }

@media (max-width: 560px) {
    .member-admin-row { grid-template-columns: 52px 1fr; }
    .member-admin-pic img, .member-admin-noimg { width: 52px; height: 52px; }
    .member-admin-actions { grid-column: 1 / -1; justify-content: flex-start; }
}

/* Editor (Datenschutz pflegen) */
.form-wide { max-width: 820px; }
.editor-help {
    background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
    padding: .8rem 1rem; margin: 1rem 0; font-size: .9rem; color: var(--dim); line-height: 1.8;
}
.editor-help code { background: #000; color: var(--cyan); padding: .1rem .4rem; border-radius: 4px; }
textarea.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: .92rem; line-height: 1.5; }
.editor-actions { display: flex; gap: 1rem; flex-wrap: wrap; }

@media (max-width: 560px) {
    .field-row { grid-template-columns: 1fr; }
    .data-table th:nth-child(3), .data-table td:nth-child(3) { display: none; }
}
