/* ==========================================================================
   admin.css – Adminbereich + Login (handgeschrieben, kein Build-Step)
   ========================================================================== */
:root {
  --bg: #f3f4f6; --surface: #fff; --ink: #1f2328; --muted: #6b7280;
  --line: #e3e6ea; --accent: #2f6fb5; --danger: #c0392b; --radius: 9px;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
* { box-sizing: border-box; }
body.admin { margin: 0; display: flex; min-height: 100vh; background: var(--bg);
  color: var(--ink); font-family: var(--sans); font-size: 15px; }

/* Sidebar */
.admin-side {
  width: 230px; background: #1b2430; color: #cdd5e0; flex-shrink: 0;
  display: flex; flex-direction: column; padding: 18px 14px; position: sticky; top: 0; height: 100vh;
}
.admin-logo { color: #fff; font-weight: 700; font-size: 1.2rem; margin-bottom: 20px; text-decoration: none; }
.admin-side nav { display: flex; flex-direction: column; gap: 2px; }
.admin-side nav a { color: #cdd5e0; padding: 9px 12px; border-radius: 7px; text-decoration: none; }
.admin-side nav a:hover { background: rgba(255,255,255,.08); color: #fff; }
.admin-side-foot { margin-top: auto; display: flex; flex-direction: column; gap: 10px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.1); }
.admin-side-foot a { color: #9aa6b5; font-size: .9rem; text-decoration: none; }
.linklike { background: none; border: 0; color: #9aa6b5; cursor: pointer; font: inherit; padding: 0; text-align: left; }
.linklike:hover { color: #fff; }

/* Content */
.admin-content { flex: 1; min-width: 0; }
.admin-top { background: var(--surface); border-bottom: 1px solid var(--line); padding: 16px 28px; }
.admin-top h1 { margin: 0; font-size: 1.3rem; }
.admin-body { padding: 24px 28px; max-width: 1000px; }

.block-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.block-head h2 { margin: 0; font-size: 1.15rem; }

/* Buttons */
.btn { display: inline-block; border: 1px solid var(--line); background: var(--surface);
  border-radius: 7px; padding: 8px 14px; cursor: pointer; font: inherit; color: var(--ink); text-decoration: none; }
.btn:hover { border-color: var(--accent); }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-danger { color: var(--danger); }
.btn-danger:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn-sm { padding: 5px 10px; font-size: .85rem; }
.btn-block { display: block; width: 100%; text-align: center; margin-bottom: 8px; }
.inline { display: inline; }

/* Tabellen */
.table { width: 100%; border-collapse: collapse; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.table th, .table td { padding: 11px 14px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: middle; }
.table th { background: #fafbfc; font-size: .8rem; text-transform: uppercase; letter-spacing: .03em; color: var(--muted); }
.table tr:last-child td { border-bottom: 0; }
.ta-right { text-align: right; }
.badge { display: inline-block; background: #eef1f4; border-radius: 999px; padding: 2px 10px; font-size: .8rem; color: var(--muted); }
.badge.ok { background: #e4f5e7; color: #2e7d3a; }
.swatch { display: inline-block; width: 18px; height: 18px; border-radius: 5px; border: 1px solid var(--line); }

.card-block { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px 20px; margin-top: 20px; }

/* Statistik */
.stat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
@media (max-width: 800px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; text-align: center; }
.stat-num { display: block; font-size: 1.8rem; font-weight: 700; }
.stat-label { color: var(--muted); font-size: .82rem; }

/* Formulare */
.narrow-form { max-width: 620px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; }
.narrow-form label, .side-field { display: block; margin-bottom: 14px; font-weight: 600; font-size: .9rem; }
.narrow-form input[type=text], .narrow-form input[type=email], .narrow-form input[type=password],
.narrow-form input[type=number], .narrow-form textarea, .narrow-form select,
.side-field input, .side-field textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 7px; padding: 9px 11px; font: inherit; font-weight: 400; margin-top: 5px;
}
.mono { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: .9rem; }
.hint { color: var(--muted); font-size: .8rem; font-weight: 400; margin: 4px 0 0; }
.form-actions { display: flex; gap: 10px; margin-top: 8px; }
.check { font-weight: 400; display: flex; align-items: center; gap: 8px; }
.check.big { font-weight: 600; margin: 12px 0; }

/* Beitragseditor */
.post-form { display: grid; grid-template-columns: 1fr 300px; gap: 24px; align-items: start; }
@media (max-width: 900px) { .post-form { grid-template-columns: 1fr; } }
.title-input { width: 100%; font-size: 1.5rem; font-weight: 700; border: 0; border-bottom: 2px solid var(--line); background: none; padding: 8px 2px; margin-bottom: 18px; }
.title-input:focus { outline: none; border-color: var(--accent); }
.blocks { display: flex; flex-direction: column; gap: 12px; }
.block { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); }
.block-bar { display: flex; justify-content: space-between; align-items: center; padding: 7px 12px; border-bottom: 1px solid var(--line); background: #fafbfc; border-radius: var(--radius) var(--radius) 0 0; }
.block-tag { font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.block-ops button { border: 1px solid var(--line); background: #fff; border-radius: 6px; width: 28px; height: 26px; cursor: pointer; margin-left: 4px; }
.block-fields { padding: 12px; display: flex; flex-direction: column; gap: 8px; }
.block-fields input[type=text], .block-fields textarea, .block-fields select {
  width: 100%; border: 1px solid var(--line); border-radius: 7px; padding: 8px 10px; font: inherit;
}
.field-row { display: flex; gap: 8px; }
.field-row select { width: 80px; flex-shrink: 0; }
.img-block { display: flex; flex-direction: column; gap: 8px; }
.img-preview img { max-height: 160px; width: auto; border-radius: 7px; border: 1px solid var(--line); }
.add-block { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.add-block > span { color: var(--muted); font-size: .85rem; }
.form-side { position: sticky; top: 20px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; }
.tag-checks { margin-top: 6px; display: flex; flex-direction: column; gap: 4px; max-height: 220px; overflow: auto; }

/* Login */
.login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: var(--bg); }
.login-box { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 34px; width: 100%; max-width: 380px; }
.login-box h1 { margin: 0 0 18px; font-size: 1.4rem; text-align: center; }
.login-box label { display: block; margin-bottom: 14px; font-size: .9rem; font-weight: 600; }
.login-box input { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; font: inherit; margin-top: 5px; font-weight: 400; }
.login-box .btn { width: 100%; }
.login-back { text-align: center; margin: 16px 0 0; font-size: .9rem; }

.flash { padding: 11px 14px; border-radius: 8px; margin-bottom: 16px; border: 1px solid var(--line); }
.flash--success { background: #e4f5e7; border-color: #bfe3c6; }
.flash--error { background: #fbe4e4; border-color: #efc4c4; }

/* ===================================================================
   Netzwerk-Erweiterungen (Multi-Tenant): Admin-Shell, Panels, Team,
   Gestaltung, Auth-Boxen. Ergänzt die Block-Editor-Styles oben.
   =================================================================== */
.admin-shell{display:flex;min-height:100vh;align-items:stretch}
.admin-side{flex:0 0 240px;background:#1f2430;color:#cdd3df;display:flex;flex-direction:column;padding:1.2rem 0}
.admin-brand{padding:0 1.2rem 1rem;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:.6rem}
.admin-brand a{color:#fff;font-weight:700;text-decoration:none;font-size:1.05rem}
.admin-sub{display:block;font-size:.78rem;color:#8b93a7;margin-top:.2rem;word-break:break-all}
.admin-nav{display:flex;flex-direction:column;gap:.15rem;padding:.4rem .6rem}
.admin-nav a{color:#cdd3df;text-decoration:none;padding:.55rem .7rem;border-radius:7px;font-size:.95rem}
.admin-nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.admin-foot{margin-top:auto;padding:1rem 1.2rem 0;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.5rem}
.admin-foot a{color:#8b93a7;text-decoration:none;font-size:.9rem}
.admin-foot button{background:none;border:1px solid rgba(255,255,255,.18);color:#cdd3df;padding:.4rem .7rem;border-radius:7px;cursor:pointer;font:inherit}
.admin-main{flex:1;padding:1.6rem 2rem;background:#f4f5f7;min-width:0}
.admin-head h1{margin:.2rem 0 1.2rem;font-size:1.5rem}
.panel{background:#fff;border:1px solid #e4e7ec;border-radius:12px;padding:1.2rem 1.4rem;margin-bottom:1.4rem}
.panel h2{margin:.1rem 0 .9rem;font-size:1.15rem}
.page-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin:.4rem 0 1rem}
.page-head h1,.page-head h2{margin:0}
.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden}
.data-table th,.data-table td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid #eceef2;font-size:.93rem;vertical-align:middle}
.data-table th{background:#fafbfc;font-weight:600;color:#555}
.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}
.badge-on{background:#dcfce7;color:#166534}
.stat-lbl{display:block;font-size:.82rem;color:#667;margin-top:.2rem}
.form-card{background:#fff;border:1px solid #e4e7ec;border-radius:12px;padding:1.4rem;margin-bottom:1.4rem;max-width:680px}
.form-card label{display:block;font-weight:600;margin:.9rem 0 .3rem;font-size:.92rem}
.form-card input[type=text],.form-card input[type=email],.form-card input[type=password],
.form-card input[type=number],.form-card textarea,.form-card select{
  width:100%;padding:.55rem .65rem;border:1px solid #cfd4dc;border-radius:8px;font:inherit;box-sizing:border-box}
.form-row{display:flex;gap:1rem;flex-wrap:wrap}
.form-row>div{flex:1;min-width:140px}
.form-actions{margin-top:1.2rem;display:flex;gap:.6rem}
.inline-form{display:inline}
.theme-picker{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:.3rem}
.theme-option input{position:absolute;opacity:0}
.theme-swatch{display:inline-block;padding:.7rem 1.1rem;border:2px solid #cfd4dc;border-radius:10px;cursor:pointer;font-weight:600}
.theme-option input:checked + .theme-swatch{border-color:var(--accent,#b5462f);box-shadow:0 0 0 3px rgba(181,70,47,.15)}
.subdomain-row{display:flex;align-items:center;gap:.2rem}
.subdomain-row input{flex:1}
.subdomain-suffix{color:#667;font-weight:600;white-space:nowrap}
.btn-block{display:block;width:100%;text-align:center}

/* Auth-Seiten */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f4f5f7;margin:0}
.auth-box{background:#fff;border:1px solid #e4e7ec;border-radius:14px;padding:2rem;width:100%;max-width:380px}
.auth-box h1{margin:0 0 1rem;font-size:1.3rem;text-align:center}
.auth-box h1 a{color:inherit;text-decoration:none}
.auth-box label{display:block;font-weight:600;margin:.8rem 0 .3rem;font-size:.9rem}
.auth-box input{width:100%;padding:.55rem .65rem;border:1px solid #cfd4dc;border-radius:8px;font:inherit;box-sizing:border-box}
.auth-box .btn{margin-top:1.2rem}
.auth-alt{text-align:center;margin-top:1rem;font-size:.9rem;color:#667}

@media(max-width:760px){
  .admin-shell{flex-direction:column}
  .admin-side{flex-basis:auto}
  .admin-nav{flex-direction:row;flex-wrap:wrap}
  .admin-main{padding:1.2rem}
}
