/* ==========================================================================
   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: color-mix(in srgb,#2e7d32 14%,var(--surface)); border-color: color-mix(in srgb,#2e7d32 34%,var(--surface)); }
.flash--error { background: color-mix(in srgb,#c0392b 14%,var(--surface)); border-color: color-mix(in srgb,#c0392b 34%,var(--surface)); }

/* ===================================================================
   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{display:flex;align-items:center;gap:.6rem;color:#cdd3df;text-decoration:none;padding:.55rem .7rem;border-radius:7px;font-size:.95rem}
.admin-nav a svg{width:18px;height:18px;flex:none;opacity:.8}
.admin-nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.admin-nav a:hover svg{opacity:1}
.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:1.2rem;flex-wrap:wrap}
.form-row>div{flex:1;min-width:190px}
.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}
}

/* ===== Kopf-Steuerleiste + Hell/Dunkel ===== */
.admin-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; flex-wrap:wrap; }
.admin-head-tools{ display:flex; gap:.5rem; align-items:center; }
.admin-head-tools .icon-btn{ width:36px; height:36px; border:1px solid var(--line); background:var(--surface); color:var(--ink); border-radius:8px; display:inline-flex; align-items:center; justify-content:center; cursor:pointer; }
.admin-head-tools .icon-btn:hover{ border-color:var(--accent); color:var(--accent); }
.admin-head-tools .lang-switch{ display:inline-flex; align-items:center; gap:.25rem; border:1px solid var(--line); border-radius:8px; height:36px; padding:0 .5rem; }
.admin-head-tools .lang-switch a{ color:var(--muted); font-size:.8rem; padding:.2rem .25rem; text-transform:uppercase; text-decoration:none; }
.admin-head-tools .lang-switch a.is-active{ color:var(--accent); font-weight:700; }
.admin-head-tools .ic{ vertical-align:-.18em; }
.js-theme-toggle .ic-moon{ display:none; }
html[data-theme="dark"] .js-theme-toggle .ic-sun{ display:none; }
html[data-theme="dark"] .js-theme-toggle .ic-moon{ display:inline; }

/* Hauptfläche konsequent über Tokens (für Dunkelmodus) */
.admin-main{ background: var(--bg); }
.panel, .card-block, .stat, .narrow-form, .form-side, .block, .login-box, .table{ background: var(--surface); border-color: var(--line); }
.panel{ color: var(--ink); }
.block-bar{ background: color-mix(in srgb, var(--ink) 4%, var(--surface)); border-color: var(--line); }
.block-ops button{ background: var(--surface); border-color: var(--line); color: var(--ink); }
.table th{ background: color-mix(in srgb, var(--ink) 4%, var(--surface)); }
.title-input{ color: var(--ink); }
.admin-main input, .admin-main textarea, .admin-main select{ background: var(--surface); color: var(--ink); border-color: var(--line); }

html[data-theme="dark"] body.admin{
  --bg:#16181d; --surface:#1e2127; --ink:#e8e6e1; --muted:#9aa0ab; --line:#2f343d;
}
html[data-theme="dark"] body.admin .badge{ background: color-mix(in srgb, var(--ink) 10%, var(--surface)); color: var(--muted); }
html[data-theme="dark"] body.admin .flash--success{ background: color-mix(in srgb, #2e7d32 18%, var(--surface)); border-color: color-mix(in srgb, #2e7d32 35%, var(--surface)); }
html[data-theme="dark"] body.admin .flash--error{ background: color-mix(in srgb, #c0392b 18%, var(--surface)); border-color: color-mix(in srgb, #c0392b 35%, var(--surface)); }

/* ========================================================================
   Moderne Formular-, Box- & Listen-Politur (tokenbasiert, hell/dunkel)
   Am Dateiende -> gewinnt gegen frühere Regeln; Controls bewusst hoch
   spezifisch (body.admin / body.auth-body), um feste Altfarben zu ersetzen.
   ======================================================================== */

/* Eingabefelder vereinheitlichen */
:is(body.admin,body.net) :is(.form-card,.narrow-form,.side-field,.block-fields,.form-side,.panel) :is(input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],input[type=url],textarea,select),
body.auth-body .auth-box :is(input,textarea,select),
body.admin .login-box :is(input,textarea,select){
  width:100%; box-sizing:border-box; font:inherit; line-height:1.45;
  min-height:2.7rem; padding:.62rem .8rem; border:1px solid var(--line); border-radius:10px;
  background:var(--surface); color:var(--ink); margin-top:6px;
  transition:border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
:is(body.admin,body.net) :is(.form-card,.narrow-form,.side-field,.block-fields,.form-side,.panel) textarea,
body.auth-body .auth-box textarea{ min-height:84px; resize:vertical; }

/* Fokus-Ring */
:is(body.admin,body.net) :is(.form-card,.narrow-form,.side-field,.block-fields,.form-side,.panel) :is(input,textarea,select):focus,
body.auth-body .auth-box :is(input,textarea,select):focus,
body.admin .login-box :is(input,textarea,select):focus{
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}
/* Platzhalter & deaktiviert */
:is(body.admin,body.net) :is(.form-card,.narrow-form,.side-field,.block-fields,.form-side) :is(input,textarea)::placeholder,
body.auth-body .auth-box input::placeholder{ color:var(--muted); opacity:.7; }
:is(body.admin,body.net) :is(.form-card,.narrow-form,.side-field) :is(input,textarea,select):disabled{
  background:color-mix(in srgb, var(--ink) 5%, var(--surface)); color:var(--muted); cursor:not-allowed;
}

/* Eigener Select-Pfeil (kein Plattform-Look) */
:is(body.admin,body.net) :is(.form-card,.narrow-form,.side-field,.block-fields,.form-side,.panel) select{
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238b93a7' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .75rem center; padding-right:2.2rem;
}

/* Checkboxen/Radios mit Akzentfarbe + saubere Zeilen */
:is(body.admin,body.net) :is(.check,.tag-checks) :is(input[type=checkbox],input[type=radio]){ width:1.05em; height:1.05em; margin:0; }
.check{ display:flex; align-items:center; gap:.55rem; font-weight:400; padding:.15rem 0; }
.check.big{ font-weight:600; gap:.6rem; margin:.4rem 0 1rem; }
.tag-checks{ gap:.4rem; padding:.2rem .1rem; }
.tag-checks .check{ padding:.2rem .2rem; border-radius:8px; }
.tag-checks .check:hover{ background:color-mix(in srgb, var(--ink) 4%, var(--surface)); }

/* Labels & Hilfetexte */
.form-card label, .narrow-form label, .auth-box label, .login-box label, .side-field{
  font-weight:600; font-size:.86rem; letter-spacing:.01em; color:var(--ink);
}
.form-card label{ margin:1.1rem 0 0; }
.form-card label:first-of-type{ margin-top:.2rem; }
.hint{ color:var(--muted); font-size:.82rem; margin:.35rem 0 0; }

/* Boxen / Karten / Panels */
.form-card, .narrow-form{ background:var(--surface); border:1px solid var(--line); border-radius:14px;
  padding:1.6rem 1.6rem 1.7rem; box-shadow:var(--shadow); }
.panel{ background:var(--surface); border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); }
.form-side{ border-radius:14px; box-shadow:var(--shadow); }
.auth-box, .login-box{ box-shadow:var(--shadow); border-radius:16px; }
.form-actions{ margin-top:1.4rem; padding-top:1.1rem; border-top:1px solid var(--line); display:flex; gap:.6rem; }

/* Block-Editor */
.block{ border-radius:12px; box-shadow:var(--shadow); }
.block-bar{ border-radius:12px 12px 0 0; }
.block-ops button{ display:inline-flex; align-items:center; justify-content:center; color:var(--muted); }
.block-ops button:hover{ border-color:var(--accent); color:var(--accent); }
.title-input{ border-bottom-width:2px; }

/* Tabellen / Listen */
.data-table, .table{ width:100%; background:var(--surface); border:1px solid var(--line);
  border-radius:12px; overflow:hidden; border-collapse:separate; border-spacing:0; box-shadow:var(--shadow); }
.data-table th, .data-table td, .table th, .table td{ text-align:left; padding:.72rem .9rem;
  border-bottom:1px solid var(--line); font-size:.92rem; vertical-align:middle; }
.data-table th, .table th{ background:color-mix(in srgb, var(--ink) 4%, var(--surface));
  color:var(--muted); font-weight:600; text-transform:uppercase; font-size:.72rem; letter-spacing:.05em; }
.data-table tbody tr:last-child td, .table tbody tr:last-child td{ border-bottom:0; }
.data-table tbody tr:hover, .table tbody tr:hover{ background:color-mix(in srgb, var(--accent) 5%, var(--surface)); }

/* Theme-Picker als ruhiges Raster */
.theme-picker{ display:grid; grid-template-columns:repeat(auto-fill, minmax(150px,1fr)); gap:.6rem; margin-top:.5rem; }
.theme-swatch{ border:2px solid var(--line); border-radius:12px; min-height:56px; padding:.5rem .7rem; transition:border-color .15s, box-shadow .15s; }
.theme-option input:checked + .theme-swatch{ border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent); }
.theme-option:hover .theme-swatch{ border-color:color-mix(in srgb, var(--accent) 55%, var(--line)); }

/* Badges */
.badge{ border-radius:999px; padding:.15rem .65rem; font-size:.74rem; font-weight:600; letter-spacing:.02em; }

/* ===== WYSIWYG-Editor ===== */
.wz{ border:1px solid var(--line); border-radius:12px; overflow:hidden; background:var(--surface); margin-top:6px; box-shadow:var(--shadow); }
.wz-bar{ display:flex; flex-wrap:wrap; gap:.15rem; padding:.4rem; background:color-mix(in srgb, var(--ink) 4%, var(--surface)); border-bottom:1px solid var(--line); }
.wz-btn{ min-width:32px; height:30px; padding:0 .55rem; border:1px solid transparent; background:transparent; color:var(--ink); border-radius:7px; cursor:pointer; font:inherit; font-size:.9rem; line-height:1; display:inline-flex; align-items:center; justify-content:center; }
.wz-btn:hover{ background:var(--surface); border-color:var(--line); color:var(--accent); }
.wz-sep{ width:1px; background:var(--line); margin:.15rem .3rem; align-self:stretch; }
.wz-right{ margin-left:auto; }
.wz-edit{ min-height:220px; padding:.9rem 1.1rem; outline:none; line-height:1.65; }
.wz-edit:focus{ box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--accent) 28%, transparent); }
.wz-edit :is(h2,h3,h4){ font-family:var(--serif); }
.wz-edit blockquote{ border-left:3px solid var(--accent); margin:1em 0; padding:.2em 0 .2em 16px; color:var(--muted); }
textarea[data-wysiwyg]{ font-family:var(--f-mono, ui-monospace, Menlo, Consolas, monospace); font-size:.9rem; min-height:240px; }

/* Farbfelder im Stil-Editor */
.form-card input[type=color]{ width:52px; height:40px; padding:3px; border:1px solid var(--line); border-radius:9px; background:var(--surface); cursor:pointer; vertical-align:middle; margin-top:6px; }

/* ===== Übersetzungs-Editor ===== */
.tr-langs{ display:flex; align-items:center; flex-wrap:wrap; gap:.4rem; margin:.2rem 0 .8rem; }
.tr-stats{ margin-left:auto; color:var(--muted); font-size:.92rem; }
.tr-warn{ color:#c0392b; }

/* Import/Export-Leiste */
.tr-io{ display:flex; align-items:center; flex-wrap:wrap; gap:.5rem; margin:.2rem 0 .8rem; }
.tr-import{ display:flex; align-items:center; gap:.5rem; margin-left:auto; }
.tr-import input[type=file]{ font-size:.85rem; max-width:240px; }

/* Werkzeugleiste bleibt beim Scrollen sichtbar */
.tr-toolbar{
  position:sticky; top:0; z-index:5;
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
  padding:.7rem 0; margin-bottom:.2rem;
  background:var(--bg); border-bottom:1px solid var(--line);
}
.tr-search{
  flex:1; min-width:240px; box-sizing:border-box; font:inherit;
  min-height:2.6rem; padding:.55rem .8rem;
  border:1px solid var(--line); border-radius:10px; background:var(--surface); color:var(--ink);
}
.tr-search:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent); }

/* Liste in einem scrollbaren Bereich – die Seite wird nicht mehr endlos lang */
.tr-list{ border:1px solid var(--line); border-radius:12px; overflow:auto; background:var(--surface); max-height:64vh; }
.tr-row{
  display:grid; grid-template-columns:minmax(220px,32%) 1fr; gap:1.1rem;
  padding:.8rem 1rem; border-bottom:1px solid var(--line); align-items:center;
}
.tr-row:last-child{ border-bottom:none; }
.tr-row:nth-child(even){ background:color-mix(in srgb, var(--ink) 2.5%, var(--surface)); }
.tr-row.is-untranslated{ background:color-mix(in srgb,#c0392b 8%,var(--surface)); }
.tr-key code{ font-family:var(--f-mono, ui-monospace, Menlo, Consolas, monospace); font-size:.84rem; color:var(--muted); word-break:break-word; }
.tr-badge{ display:inline-block; margin-left:.4rem; font-size:.68rem; padding:.06rem .42rem; border-radius:6px; background:color-mix(in srgb,var(--accent) 18%,var(--surface)); color:var(--accent); vertical-align:middle; }
.tr-ref{ display:block; margin-top:.3rem; color:var(--ink); opacity:.7; font-size:.9rem; }

/* Eingabefelder im Editor explizit polieren (liegen nicht in der .form-card-Allowlist) */
.tr-val input, .tr-val textarea{
  width:100%; box-sizing:border-box; font:inherit; line-height:1.45; margin:0;
  min-height:2.6rem; padding:.55rem .75rem;
  border:1px solid var(--line); border-radius:9px; background:var(--surface); color:var(--ink);
  transition:border-color .15s ease, box-shadow .15s ease;
}
.tr-val textarea{ min-height:3.2rem; resize:vertical; }
.tr-val input:focus, .tr-val textarea:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent);
}

/* Speicherleiste bleibt unten sichtbar */
.tr-actions{
  position:sticky; bottom:0; z-index:5; display:flex; align-items:center; gap:1rem;
  background:var(--bg); border-top:1px solid var(--line); margin-top:0; padding:.9rem 0;
}
@media (max-width:640px){
  .tr-row{ grid-template-columns:1fr; gap:.5rem; padding:.75rem .8rem; }
  .tr-import{ margin-left:0; }
}
