/* ================================================================
   Die Handschelle V.Alpha-2 — Stylesheet
   Author: Bernd K.R. Dorfmüller | Version: V.01.1
   Mobile-first, volle Bildschirmbreite
================================================================ */
:root {
    --hs-primary:   #1a1a2e;
    --hs-accent:    #c0392b;
    --hs-accent-h:  #e74c3c;
    --hs-gold:      #f39c12;
    --hs-success:   #27ae60;
    --hs-muted:     #7f8c8d;
    --hs-bg:        #f0f0f0;
    --hs-card-bg:   #ffffff;
    --hs-border:    #dee2e6;
    --hs-radius:    8px;
    --hs-shadow:    0 2px 12px rgba(0,0,0,.10);
    --hs-shadow-lg: 0 6px 28px rgba(0,0,0,.16);
    --hs-font:      'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* ── Basis ──────────────────────────────────────────────────── */
.hs-frontend *, .hs-wrap * { box-sizing: border-box; }
.hs-full-width { width: 100%; max-width: 100%; }
.hs-frontend { font-family: var(--hs-font); color: #222; width: 100%; }
.hs-wrap { font-family: var(--hs-font); }
.hs-version { font-size:.65em; opacity:.6; font-weight:400; margin-left:.4rem; }

/* ── Stats Bar (Admin) ──────────────────────────────────────── */
.hs-stats-bar { display:flex; align-items:center; gap:1.2rem; background:var(--hs-primary); color:#fff; padding:.7rem 1.1rem; border-radius:var(--hs-radius); margin-bottom:1rem; flex-wrap:wrap; }
.hs-stats-bar strong { color:#f0f0f0; }
.hs-stats-bar .hs-warn { color:#f39c12; }

/* ── Section Title ──────────────────────────────────────────── */
.hs-section-title { background:linear-gradient(135deg,var(--hs-primary) 0%,var(--hs-accent) 100%); color:#fff; margin:0 0 1.5rem; padding:1rem 1.5rem; border-radius:var(--hs-radius); font-size:1.4rem; letter-spacing:.02em; }

/* ── Formulare ──────────────────────────────────────────────── */
.hs-form { border-radius:var(--hs-radius); overflow:hidden; }
.hs-form-section { padding:1.5rem; border-bottom:1px solid var(--hs-border); }
.hs-form-section:last-child { border-bottom:none; }
.hs-form-section h2, .hs-form-section h3 { margin:0 0 1rem; font-size:1rem; font-weight:700; color:var(--hs-primary); padding-bottom:.45rem; border-bottom:2px solid var(--hs-accent); }
.hs-form-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1rem; }
.hs-field { display:flex; flex-direction:column; gap:.35rem; }
.hs-field-full { grid-column:1/-1; }
.hs-field label { font-weight:600; font-size:.875rem; color:#333; }
.hs-field label span { font-weight:400; font-size:.78rem; color:var(--hs-muted); }
.hs-field input[type="text"],
.hs-field input[type="url"],
.hs-field input[type="date"],
.hs-field select,
.hs-field textarea { width:100%; padding:.55rem .75rem; border:1.5px solid var(--hs-border); border-radius:calc(var(--hs-radius) - 2px); font-size:.9rem; font-family:var(--hs-font); background:#fff; transition:border-color .2s,box-shadow .2s; color:#000; }
.hs-field input:focus, .hs-field select:focus, .hs-field textarea:focus { outline:none; border-color:var(--hs-accent); box-shadow:0 0 0 3px rgba(192,57,43,.12); background:#fff; }
.hs-file-input { padding:.4rem; font-size:.85rem; background:#fff; border:1.5px dashed var(--hs-border); border-radius:calc(var(--hs-radius) - 2px); cursor:pointer; }
.hs-file-preview img { max-height:150px; margin-top:.5rem; border-radius:var(--hs-radius); border:2px solid var(--hs-border); display:block; }
.hs-char-counter { font-size:.78rem; color:var(--hs-muted); text-align:right; transition:color .2s; }
.hs-checkbox-label { display:flex !important; align-items:center; gap:.5rem; font-weight:600 !important; cursor:pointer; }
.hs-current-image { margin-bottom:.6rem; }
.hs-form-actions { padding:1.5rem; display:flex; align-items:center; gap:1rem; flex-wrap:wrap; border-top:1px solid var(--hs-border); }
.hs-note { font-size:.8rem; color:var(--hs-muted); margin:0; }

/* ── Buttons ────────────────────────────────────────────────── */
.hs-btn, .hs-btn-primary { display:inline-flex; align-items:center; justify-content:center; gap:.4rem; background:var(--hs-accent) !important; color:#fff !important; border:none !important; padding:.65rem 1.4rem !important; border-radius:var(--hs-radius) !important; font-size:.9rem !important; font-weight:600 !important; cursor:pointer; text-decoration:none !important; transition:background .2s,transform .15s,box-shadow .2s; box-shadow:0 2px 6px rgba(192,57,43,.25); }
.hs-btn:hover, .hs-btn-primary:hover { background:var(--hs-accent-h) !important; transform:translateY(-1px); box-shadow:0 4px 12px rgba(192,57,43,.35); color:#fff !important; text-decoration:none !important; }
.hs-btn:active { transform:translateY(0); }
.hs-btn-cancel { background:#95a5a6 !important; box-shadow:none !important; }
.hs-btn-cancel:hover { background:#7f8c8d !important; }
.hs-btn-delete { background:#922b21 !important; }
.hs-btn-danger { background:#922b21 !important; color:#fff !important; border:none !important; padding:.65rem 1.4rem !important; border-radius:var(--hs-radius) !important; font-size:.9rem !important; font-weight:600 !important; cursor:pointer; text-decoration:none !important; display:inline-block; }
.hs-btn-danger:hover { background:#7b241c !important; color:#fff !important; }

/* ── Badges ─────────────────────────────────────────────────── */
.hs-badge { display:inline-block; padding:.2rem .65rem; border-radius:20px; font-size:.73rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; white-space:nowrap; }
.hs-badge-aktiv       { background:#d4edda; color:#155724; }
.hs-badge-inaktiv     { background:#f8d7da; color:#721c24; }
.hs-badge-verstorben  { background:#6c757d; color:#fff; }
.hs-badge-pending   { background:#fff3cd; color:#856404; }
.hs-status-verurteilt  { background:#f8d7da; color:#721c24; }
.hs-status-ermittlung  { background:#fff3cd; color:#856404; }
.hs-status-eingestellt { background:#d1ecf1; color:#0c5460; }

/* ── Karten-Raster ──────────────────────────────────────────── */
.hs-cards-grid { display:flex; flex-direction:column; align-items:center; gap:1.5rem; width:100%; }

/* ── Einzelne Karte ─────────────────────────────────────────── */
.hs-card { background:var(--hs-card-bg); border-radius:var(--hs-radius); box-shadow:var(--hs-shadow); border:1px solid var(--hs-border); overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .25s,transform .25s; width:100%; }
.hs-card:hover { box-shadow:var(--hs-shadow-lg); transform:translateY(-3px); }
.hs-card-header { display:flex; gap:1rem; padding:1rem; background:var(--hs-primary); color:#fff; align-items:flex-start; }
.hs-card-img-wrap { flex-shrink:0; width:88px; height:88px; border-radius:50%; overflow:hidden; border:3px solid rgba(255,255,255,.25); display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.08); }
.hs-card-img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.hs-card-img-placeholder { font-size:2.5rem; }
.hs-card-meta { flex:1; min-width:0; }
.hs-card-name { font-size:1.05rem; font-weight:700; margin:0 0 .25rem; color:#fff; }
.hs-card-name-link { color:inherit; text-decoration:none; }
.hs-card-name-link:hover { text-decoration:underline; }
.hs-card-beruf, .hs-card-partei, .hs-card-parlament { font-size:.8rem; margin:.15rem 0; color:rgba(255,255,255,.8); word-break:break-word; }
.hs-card-body { padding:1rem; flex:1; display:flex; flex-direction:column; gap:.5rem; }
.hs-card-section { border:1px solid var(--hs-border); border-radius:var(--hs-radius); padding:.6rem .8rem; display:flex; flex-direction:column; gap:.45rem; }
.hs-card-section-title { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--hs-primary); margin-bottom:.2rem; border-bottom:1px solid var(--hs-border); padding-bottom:.25rem; }
.hs-card-straftat { border-left:3px solid var(--hs-gold); padding:.4rem .6rem; border-radius:0 var(--hs-radius) var(--hs-radius) 0; }
.hs-card-straftat p { margin:.2rem 0 0; font-size:.88rem; color:#000000; line-height:1.5; }
.hs-label { font-weight:700; font-size:.8rem; color:var(--hs-primary); display:block; margin-bottom:.1rem; }
.hs-card-row { font-size:.85rem; color:#444; display:flex; align-items:center; flex-wrap:wrap; gap:.4rem; }
.hs-card-bemerkung { padding:.6rem .8rem; border-radius:var(--hs-radius); font-size:.85rem; }
.hs-card-bemerkung p { margin:.2rem 0 0; color:#555; line-height:1.5; }
.hs-card-bemerkung-person { padding:.6rem .8rem; border-radius:var(--hs-radius); font-size:.85rem; background:#f0f4ff; }
.hs-card-bemerkung-person p { margin:.2rem 0 0; color:#444; line-height:1.5; }
.hs-card-extra-offence { margin-top:.8rem; padding:.8rem; border-left:3px solid var(--hs-accent); background:#fff9f9; border-radius:0 var(--hs-radius) var(--hs-radius) 0; }
.hs-card-extra-offence p { margin:.3rem 0 0; font-size:.88rem; color:#000; line-height:1.5; }
.hs-offence-row { border:1px solid #ddd; border-radius:var(--hs-radius); padding:1rem; margin-bottom:.8rem; background:#fafafa; }
.hs-offence-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:.6rem; }
.hs-offence-remove-btn,
.hs-offence-inline-remove { background:#e74c3c; color:#fff; border:none; border-radius:4px; padding:.25rem .6rem; font-size:.8rem; cursor:pointer; line-height:1.4; transition:background .15s; font-family:var(--hs-font); }
.hs-offence-remove-btn:hover,
.hs-offence-inline-remove:hover { background:#922b21; }
.hs-add-offence-inline-btn { background:#fff; color:var(--hs-primary); border:1.5px solid var(--hs-border); border-radius:var(--hs-radius); padding:.4rem .9rem; font-size:.82rem; font-weight:600; cursor:pointer; font-family:var(--hs-font); transition:background .15s,border-color .15s; margin-top:.5rem; display:inline-block; }
.hs-add-offence-inline-btn:hover { background:#f0f0f0; border-color:#bbb; }
.hs-link { color:var(--hs-accent); font-size:.85rem; font-weight:600; text-decoration:none; transition:color .2s; }
.hs-link:hover { color:var(--hs-accent-h); text-decoration:underline; }
.hs-card-footer { padding:.75rem 1rem; border-top:1px solid var(--hs-border); display:flex; flex-wrap:wrap; gap:.45rem; }
.hs-card-melden { padding:.4rem 1rem; border-top:1px solid var(--hs-border); text-align:right; }
.hs-melden-link { font-size:.75rem; font-weight:700; color:var(--hs-accent); text-decoration:none; letter-spacing:.02em; transition:color .2s,opacity .2s; }
.hs-melden-link:hover { color:var(--hs-accent-h); text-decoration:underline; }
.hs-card-date { padding:.4rem 1rem; font-size:.72rem; color:var(--hs-muted); text-align:right; border-top:1px solid var(--hs-border); }

/* ── Social Media Links ─────────────────────────────────────── */
.hs-sm-link { display:inline-flex; align-items:center; gap:.35rem; font-size:.78rem; font-weight:600; color:#333; text-decoration:none; background:#fff; border:1px solid var(--hs-border); padding:.3rem .7rem .3rem .5rem; border-radius:20px; transition:background .2s,color .2s,border-color .2s,box-shadow .2s; white-space:nowrap; box-shadow:0 1px 3px rgba(0,0,0,.06); }
.hs-sm-link svg { flex-shrink:0; vertical-align:middle; }
.hs-sm-link:hover { background:#f0f0f0; border-color:#bbb; box-shadow:0 2px 6px rgba(0,0,0,.12); color:#111; text-decoration:none; }
.hs-sm-link[data-sm="facebook"]:hover { background:#1877F2; color:#fff; border-color:#1877F2; }
.hs-sm-link[data-sm="facebook"]:hover svg { fill:#fff; }
.hs-sm-link[data-sm="youtube"]:hover  { background:#FF0000; color:#fff; border-color:#FF0000; }
.hs-sm-link[data-sm="youtube"]:hover svg  { fill:#fff; }
.hs-sm-link[data-sm="twitter"]:hover  { background:#000; color:#fff; border-color:#000; }
.hs-sm-link[data-sm="twitter"]:hover svg  { fill:#fff; }
.hs-sm-link[data-sm="wikipedia"]:hover { background:#333; color:#fff; border-color:#333; }
.hs-sm-link[data-sm="wikipedia"]:hover svg { fill:#fff; }

/* ── Suchboxen ──────────────────────────────────────────────── */
.hs-search-box { border-radius:var(--hs-radius); padding:1.5rem; margin-bottom:1.5rem; border:1px solid var(--hs-border); background:#f0f0f0; color:#000; }
.hs-search-title { margin:0 0 .9rem; font-size:1.05rem; font-weight:700; color:#000; }
.hs-search-form { display:flex; gap:.8rem; flex-wrap:wrap; align-items:center; }
.hs-select { padding:.55rem .75rem; border:1.5px solid var(--hs-border); border-radius:var(--hs-radius); font-size:.9rem; font-family:var(--hs-font); background:#fff; color:#000; min-width:220px; cursor:pointer; transition:border-color .2s; }
.hs-select:focus { outline:none; border-color:var(--hs-accent); }
.hs-search-results { margin-top:1.5rem; border-top:2px solid var(--hs-border); padding-top:1.2rem; }
.hs-search-results h4 { font-size:1rem; color:var(--hs-primary); margin:0 0 1rem; display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.hs-count { font-weight:400; font-size:.85rem; color:var(--hs-muted); }

/* ── Meldungen ──────────────────────────────────────────────── */
.hs-alert { padding:.9rem 1.2rem; border-radius:var(--hs-radius); margin-bottom:1rem; font-size:.9rem; font-weight:600; border-left:4px solid transparent; }
.hs-alert-success { background:#d4edda; color:#155724; border-left-color:#28a745; }
.hs-alert-error   { background:#f8d7da; color:#721c24; border-left-color:#dc3545; }
.hs-alert-info    { background:#d1ecf1; color:#0c5460; border-left-color:#17a2b8; display:flex; align-items:center; gap:.8rem; }
.hs-btn-sm        { padding:.25rem .6rem; font-size:.8rem; }
/* ── Read-only / disabled field styling (handschelle-smart locked state) ── */
.hs-field-locked { background:#e0e0e0 !important; color:#000 !important; cursor:default !important; opacity:1 !important; font-weight:bold !important; }
/* ── Personal 2-column layout (handschelle-smart) ─────────────────────── */
.hs-personal-columns { display:flex; gap:1.5rem; align-items:flex-start; }
.hs-personal-left { flex:0 0 180px; min-width:140px; }
.hs-personal-right { flex:1; min-width:0; }
@media (max-width:700px) { .hs-personal-columns { flex-direction:column; } .hs-personal-left { flex:none; width:100%; } }
.hs-sm-link { display:inline-block; margin-left:6px; font-size:14px; vertical-align:middle; text-decoration:none; }
.hs-empty { color:var(--hs-muted); font-style:italic; text-align:center; padding:2.5rem; background:#f8f9fa; border-radius:var(--hs-radius); border:1px dashed var(--hs-border); }

/* ── Admin-Tabelle ──────────────────────────────────────────── */
.hs-admin-table th { background:var(--hs-primary) !important; color:#fff !important; font-weight:600; white-space:nowrap; }
.hs-admin-table td { vertical-align:middle; padding:.6rem .8rem; }
.hs-actions { display:flex; flex-wrap:wrap; gap:.3rem; align-items:center; }

/* ── Datenbank-Karten ───────────────────────────────────────── */
.hs-db-actions { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; margin-top:1.2rem; }
.hs-db-card { background:var(--hs-card-bg); border:1px solid var(--hs-border); border-radius:var(--hs-radius); padding:1.5rem; box-shadow:var(--hs-shadow); }
.hs-db-card h3 { margin:0 0 .5rem; font-size:1rem; }
.hs-db-card p  { font-size:.85rem; color:var(--hs-muted); margin:0 0 1rem; }
.hs-db-card-danger { border-color:var(--hs-accent); background:#fff5f5; }

/* ── Statistik ──────────────────────────────────────────────── */
.hs-statistik { width:100%; }
.hs-stat-total { border:1px solid var(--hs-border); padding:.7rem 1.2rem; border-radius:var(--hs-radius); margin-bottom:1.2rem; font-size:.95rem; }
.hs-stat-total strong { color:var(--hs-accent); font-size:1.1em; }
.hs-stat-table-wrap { overflow-x:auto; border-radius:var(--hs-radius); box-shadow:var(--hs-shadow); border:1px solid var(--hs-border); }
.hs-stat-table { width:100%; border-collapse:collapse; font-family:var(--hs-font); font-size:.9rem; }
.hs-stat-table thead tr { background:var(--hs-primary); color:#fff; }
.hs-stat-table thead th { padding:.75rem 1rem; text-align:left; font-weight:700; font-size:.82rem; text-transform:uppercase; letter-spacing:.05em; white-space:nowrap; }
.hs-stat-table tbody tr { border-bottom:1px solid var(--hs-border); transition:background .15s; }
.hs-stat-table tbody tr:nth-child(even) { background:#f8f9fa; }
.hs-stat-table tbody tr:hover { background:#eef2ff; }
.hs-stat-table tfoot tr { background:#f0f0f0; border-top:2px solid var(--hs-primary); font-weight:700; }
.hs-stat-table td, .hs-stat-table th { padding:.65rem 1rem; }
.hs-stat-rank   { width:40px; color:var(--hs-muted); font-weight:700; text-align:center; }
.hs-stat-partei { font-weight:600; color:var(--hs-primary); }
.hs-stat-count  { text-align:center; font-weight:700; font-size:1rem; color:var(--hs-accent); }
.hs-stat-pct    { text-align:center; color:var(--hs-muted); font-size:.85rem; }
.hs-stat-bar-cell { width:200px; padding-right:1.2rem; }
.hs-stat-bar-wrap { background:#e9ecef; border-radius:20px; height:10px; overflow:hidden; }
.hs-stat-bar { height:100%; background:linear-gradient(90deg,var(--hs-accent) 0%,var(--hs-gold) 100%); border-radius:20px; transition:width .6s ease; min-width:4px; }

/* ── Parlamente Liste ───────────────────────────────────────── */
.hs-parlamente-liste { }
.hs-parlamente-table { margin:0; }
.hs-parlament-cell { font-weight:700; color:var(--hs-primary); vertical-align:middle; border-right:2px solid var(--hs-border); white-space:nowrap; }
.hs-parlament-subtotal td { background:#f0f4ff; border-top:1px solid var(--hs-primary); font-size:.85rem; }
.hs-col-aktiv { text-align:center; }
.hs-col-passiv { text-align:center; }
.hs-badge-aktiv { display:inline-block; background:#27ae60; color:#fff; border-radius:20px; padding:.1em .55em; font-size:.82rem; font-weight:700; }
.hs-badge-passiv { display:inline-block; background:var(--hs-muted); color:#fff; border-radius:20px; padding:.1em .55em; font-size:.82rem; font-weight:700; }

/* ── Statistik OL ───────────────────────────────────────────── */
.hs-statistik-ol { list-style:decimal; padding-left:1.6rem; margin:1rem 0 0; font-family:var(--hs-font); font-size:.95rem; line-height:1.8; }
.hs-statistik-ol-item { padding:.25rem 0; border-bottom:1px solid var(--hs-border); }
.hs-statistik-ol-item:last-child { border-bottom:none; }
.hs-statistik-ol-partei { font-weight:700; color:var(--hs-primary); }
.hs-statistik-ol-sep { color:var(--hs-muted); margin:0 .25rem; }
.hs-statistik-ol-count { color:var(--hs-accent); font-weight:600; }

/* ── Disclaimer ─────────────────────────────────────────────── */
.hs-disclaimer { text-align:center; padding:1.4rem 1.2rem; font-family:var(--hs-font); border-top:2px solid var(--hs-border); margin-top:1rem; }
.hs-disclaimer p { margin:.3rem 0; }
.hs-disclaimer-title { font-size:1rem; font-weight:700; color:var(--hs-primary); letter-spacing:.02em; }
.hs-disclaimer-tagline { font-size:.88rem; color:var(--hs-muted); line-height:1.6; }
.hs-disclaimer-links { font-size:.82rem; color:var(--hs-muted); margin-top:.5rem !important; }
.hs-disclaimer-link { color:var(--hs-accent); text-decoration:none; font-weight:600; transition:color .2s, opacity .2s; }
.hs-disclaimer-link:hover { color:var(--hs-primary); text-decoration:underline; }

/* ── Donate Block ───────────────────────────────────────────── */
.hs-donate { border:2px solid var(--hs-accent); border-radius:var(--hs-radius); padding:1.6rem 1.4rem 0; margin:1.5rem 0; background:var(--hs-card-bg); }
.hs-donate-inner { text-align:center; padding-bottom:1.2rem; }
.hs-donate-heading { font-size:1.2rem; font-weight:700; color:var(--hs-primary); margin:0 0 .6rem; }
.hs-donate-text { font-size:.9rem; color:var(--hs-muted); line-height:1.7; margin:0 0 1rem; }
.hs-donate-btn { display:inline-block; background:var(--hs-accent); color:#fff; font-weight:700; padding:.55rem 1.4rem; border-radius:var(--hs-radius); text-decoration:none; transition:opacity .2s; }
.hs-donate-btn:hover { opacity:.85; color:#fff; text-decoration:none; }
.hs-donate-btc { margin-top:1rem; padding-top:1rem; border-top:1px dashed #ddd; }
.hs-donate-btc-title { margin:0 0 .35rem; font-weight:700; color:var(--hs-primary); }
.hs-donate-btc-address { margin:0 0 .8rem; word-break:break-all; font-family:monospace; font-size:.9rem; color:var(--hs-muted); }

/* ── Admin Page Footer ──────────────────────────────────────── */
.hs-page-footer { margin-top:2rem; padding:.6rem 0; border-top:1px solid var(--hs-border); font-size:.8rem; color:var(--hs-muted); }
.hs-page-footer a { color:var(--hs-muted); text-decoration:none; border-bottom:1px dotted var(--hs-muted); transition:color .2s; }
.hs-page-footer a:hover { color:var(--hs-accent); border-bottom-color:var(--hs-accent); }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 900px) {
}
@media (max-width: 650px) {
    .hs-form-grid { grid-template-columns:1fr; }
    .hs-field-full { grid-column:1; }
.hs-card-header { flex-direction:column; align-items:center; text-align:center; }
    .hs-card-meta { text-align:center; }
    .hs-section-title { font-size:1.1rem; padding:.8rem 1rem; }
    .hs-form-actions { flex-direction:column; align-items:stretch; }
    .hs-btn,.hs-btn-primary { justify-content:center; }
    .hs-search-form { flex-direction:column; }
    .hs-select { min-width:0; width:100%; }
    .hs-db-actions { grid-template-columns:1fr; }
    .hs-stats-bar { flex-direction:column; align-items:flex-start; gap:.5rem; }
    .hs-admin-table { font-size:.78rem; }
    .hs-actions { flex-direction:column; }
    .hs-stat-bar-cell { display:none; }
    .hs-stat-table td,.hs-stat-table th { padding:.5rem .6rem; }
}
@media (max-width: 400px) {
    .hs-card-img-wrap { width:68px; height:68px; }
    .hs-card-name { font-size:.92rem; }
}

/* ================================================================
   Frontend-Bearbeiten-Button & Inline-Edit-Panel
================================================================ */

/* ── Bearbeiten-Button im Karten-Header ─────────────────────── */
.hs-card-header { position: relative; }

.hs-card-edit-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(255,255,255,.15);
    color: #fff;
    border: 1.5px solid rgba(255,255,255,.35);
    padding: .35rem .85rem;
    border-radius: 20px;
    font-size: .75rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, border-color .2s, transform .15s;
    white-space: nowrap;
    font-family: var(--hs-font);
    letter-spacing: .03em;
}
.hs-card-edit-btn:hover {
    background: var(--hs-accent);
    border-color: var(--hs-accent);
    transform: translateY(-1px);
}

/* ── Edit-Panel (ausgeklappt) ───────────────────────────────── */
.hs-card-edit-panel {
    border-top: 3px solid var(--hs-accent);
    background: #fff;
    animation: hsSlideDown .25s ease;
}

@keyframes hsSlideDown {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.hs-card-edit-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--hs-primary);
    color: #fff;
    padding: .75rem 1.2rem;
    font-size: .9rem;
    font-weight: 700;
}

.hs-edit-close {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3);
    color: #fff;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    font-size: .8rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: background .2s;
    padding: 0;
}
.hs-edit-close:hover { background: var(--hs-accent); border-color: var(--hs-accent); }

/* ── Edit-Formular ──────────────────────────────────────────── */
.hs-edit-form { padding: 1.2rem; }

.hs-edit-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: .9rem;
}

.hs-edit-section-title {
    grid-column: 1 / -1;
    font-size: .8rem;
    font-weight: 700;
    color: var(--hs-primary);
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .4rem 0 .3rem;
    border-bottom: 2px solid var(--hs-accent);
    margin-top: .4rem;
}
.hs-edit-section-title:first-child { margin-top: 0; }

.hs-edit-current-img { margin-top: .4rem; display: flex; align-items: center; gap: .6rem; }
.hs-edit-current-img img { height: 52px; border-radius: 4px; border: 2px solid var(--hs-border); }
.hs-edit-current-img small { font-size: .75rem; color: var(--hs-muted); }

.hs-edit-actions {
    display: flex;
    gap: .8rem;
    margin-top: 1.2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--hs-border);
    flex-wrap: wrap;
}

/* Reuse existing .hs-field styles inside edit form */
.hs-edit-form .hs-field label { font-size: .8rem; }
.hs-edit-form input[type="text"],
.hs-edit-form input[type="url"],
.hs-edit-form input[type="date"],
.hs-edit-form select,
.hs-edit-form textarea {
    width: 100%;
    padding: .5rem .7rem;
    border: 1.5px solid var(--hs-border);
    border-radius: 4px;
    font-size: .88rem;
    font-family: var(--hs-font);
    background: #fff;
    color: #000;
    transition: border-color .2s;
}
.hs-edit-form input:focus,
.hs-edit-form select:focus,
.hs-edit-form textarea:focus {
    outline: none;
    border-color: var(--hs-accent);
    box-shadow: 0 0 0 3px rgba(192,57,43,.1);
}

/* ── Mobile ─────────────────────────────────────────────────── */
@media (max-width: 650px) {
    .hs-card-edit-btn { position: static; display: block; margin: .5rem auto 0; width: fit-content; }
    .hs-edit-grid { grid-template-columns: 1fr; }
    .hs-edit-actions { flex-direction: column; }
}

/* ================================================================
   V3.0 – Paginierung
================================================================ */
.hs-pagination { display:flex; gap:.4rem; align-items:center; justify-content:center; margin:1.8rem 0; flex-wrap:wrap; }
.hs-page-link { display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding:0 .85rem; border:1.5px solid var(--hs-border); border-radius:var(--hs-radius); font-size:.88rem; font-weight:600; color:var(--hs-primary); text-decoration:none; transition:background .15s,border-color .15s,color .15s; background:#fff; white-space:nowrap; }
.hs-page-link:hover { background:var(--hs-accent); border-color:var(--hs-accent); color:#fff; text-decoration:none; }
.hs-page-current { background:var(--hs-primary); border-color:var(--hs-primary); color:#fff !important; cursor:default; }
.hs-page-dots { color:var(--hs-muted); font-size:.9rem; padding:0 .3rem; line-height:38px; }

/* ================================================================
   V3.0 – Volltext-Suche
================================================================ */
.hs-search-input { flex:1; min-width:200px; padding:.55rem .75rem; border:1.5px solid var(--hs-border); border-radius:var(--hs-radius); font-size:.9rem; font-family:var(--hs-font); background:#fafafa; color:#222; transition:border-color .2s,box-shadow .2s; }
.hs-search-input:focus { outline:none; border-color:var(--hs-accent); box-shadow:0 0 0 3px rgba(192,57,43,.12); background:#fff; }
.hs-search-info { display:flex; align-items:center; gap:.5rem; background:#fff3cd; border-left:4px solid var(--hs-gold); padding:.65rem 1rem; border-radius:var(--hs-radius); margin-bottom:1rem; font-size:.88rem; flex-wrap:wrap; }
.hs-search-info a { color:var(--hs-accent); text-decoration:none; font-weight:700; }
.hs-search-info a:hover { text-decoration:underline; }

/* ================================================================
   V3.0 – Admin Filter Tabs
================================================================ */
.hs-filter-tabs { display:flex; gap:.4rem; margin-bottom:.9rem; flex-wrap:wrap; }
.hs-filter-tab { display:inline-flex; align-items:center; gap:.35rem; padding:.4rem 1rem; border:1.5px solid var(--hs-border); border-radius:20px; font-size:.82rem; font-weight:600; color:#555; text-decoration:none; background:#fff; transition:background .15s,color .15s,border-color .15s; }
.hs-filter-tab:hover { background:#f0f0f0; color:#333; text-decoration:none; border-color:#bbb; }
.hs-filter-tab.active { background:var(--hs-primary); color:#fff; border-color:var(--hs-primary); }
.hs-filter-count { display:inline-flex; align-items:center; justify-content:center; background:rgba(255,255,255,.25); color:inherit; border-radius:12px; font-size:.72rem; padding:.05rem .45rem; font-weight:700; min-width:20px; }
.hs-filter-tab:not(.active) .hs-filter-count { background:#e9ecef; color:#555; }

/* ================================================================
   V3.0 – Media Library Picker
================================================================ */
.hs-media-picker { display:flex; flex-direction:column; gap:.55rem; }
.hs-media-picker-row { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.hs-media-id { padding:.42rem .65rem; border:1.5px solid var(--hs-border); border-radius:var(--hs-radius); font-size:.88rem; font-family:var(--hs-font); background:#fafafa; color:#222; }
.hs-media-id:focus { outline:none; border-color:var(--hs-accent); box-shadow:0 0 0 3px rgba(192,57,43,.1); }
.hs-media-btn { white-space:nowrap; }
.hs-search-buttons { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.4rem; }
.hs-search-btn { white-space:nowrap; text-decoration:none !important; font-size:.82rem !important; padding:.3rem .65rem !important; }
.hs-ki-btn { background:var(--hs-accent) !important; color:#fff !important; border-color:var(--hs-accent) !important; }
.hs-ki-btn:hover { background:var(--hs-accent-h) !important; border-color:var(--hs-accent-h) !important; }
.hs-ki-name-btn { display:inline-block; margin-top:.4rem; text-decoration:none !important; font-size:.75rem; font-weight:600; padding:.2rem .55rem; border-radius:20px; background:var(--hs-accent); color:#fff; white-space:nowrap; }
.hs-ki-name-btn:hover { background:var(--hs-accent-h); color:#fff; }
.hs-ki-interview-btn { display:inline-block; margin-top:.4rem; margin-left:.3rem; text-decoration:none !important; font-size:.75rem; font-weight:600; padding:.2rem .55rem; border-radius:20px; background:#2980b9; color:#fff; white-space:nowrap; }
.hs-ki-interview-btn:hover { background:#1a6a9a; color:#fff; }
.hs-cards-single { display:flex; flex-direction:column; align-items:center; gap:1.5rem; width:100%; }
.hs-card-img-link { display:block; width:100%; height:100%; }
.hs-card-img-link:hover { opacity:.85; transition:opacity .2s; }
/* Site icon shown to guests instead of person photo */
.hs-card-img-siteicon { object-fit:contain !important; object-position:center center !important; padding:10px; }
.hs-name-search-links { display:flex; gap:.3rem; flex-wrap:wrap; margin-top:.25rem; }
.hs-name-search-link { font-size:.68rem; color:rgba(255,255,255,.75); text-decoration:none !important; background:rgba(255,255,255,.1); border-radius:3px; padding:.1rem .3rem; transition:background .2s,color .2s; }
.hs-name-search-link:hover { background:rgba(255,255,255,.25); color:#fff; }
.hs-media-sep { font-size:.8rem; color:var(--hs-muted); padding:0 .15rem; }
.hs-media-preview img { max-height:100px; border-radius:4px; display:block; margin-bottom:.3rem; }
.hs-media-preview small { display:block; font-size:.75rem; color:var(--hs-muted); }

/* ================================================================
   [handschelle-straftaten-liste] – Alphabetische Straftaten-Textliste
================================================================ */
.hs-straftaten-liste { list-style:none; margin:1rem 0 0; padding:0; columns:2; column-gap:2rem; font-family:var(--hs-font); font-size:.95rem; line-height:1.8; }
.hs-straftaten-liste-item { padding:.25rem 0; border-bottom:1px solid var(--hs-border); break-inside:avoid; color:var(--hs-primary); }
.hs-straftaten-liste-item:last-child { border-bottom:none; }
.hs-straftaten-liste-empty { color:var(--hs-muted); font-style:italic; }
@media(max-width:600px){ .hs-straftaten-liste { columns:1; } }

/* ================================================================
   [handschelle-asc] – Horizontale Parteiliste
================================================================ */
.hs-asc-list { display:flex; flex-wrap:wrap; gap:.3rem .7rem; list-style:none; margin:0; padding:0; justify-content:center; }
.hs-asc-item { font-size:.82em; color:#555; white-space:nowrap; }
.hs-asc-item:not(:last-child)::after { content:'·'; margin-left:.7rem; color:#ccc; }
.hs-asc-partei { font-weight:600; color:var(--hs-primary); }
.hs-asc-count  { color:var(--hs-muted); }

/* ================================================================
   [handschelle-asc-link] – Horizontale Parteiliste mit Links & Hover-Namen
================================================================ */
.hs-asc-link-item { position:relative; font-size:.82em; color:#555; white-space:nowrap; }
.hs-asc-link-item:not(:last-child)::after { content:'·'; margin-left:.7rem; color:#ccc; }
.hs-asc-link { font-weight:600; color:var(--hs-primary); text-decoration:none; transition:color .2s; cursor:pointer; }
.hs-asc-link:hover { color:var(--hs-accent); text-decoration:underline; }
.hs-asc-link-tooltip {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--hs-primary);
    color: #fff;
    padding: 8px 12px;
    border-radius: var(--hs-radius);
    min-width: 160px;
    max-width: 260px;
    text-align: left;
    z-index: 200;
    box-shadow: 0 4px 18px rgba(0,0,0,.45);
    pointer-events: none;
    font-size:.8em;
    line-height: 1.6;
    white-space: normal;
}
.hs-asc-link-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--hs-primary);
}
.hs-asc-link-item:hover .hs-asc-link-tooltip { display:block; }

/* ================================================================
   Bilder-Galerie
================================================================ */
.hs-bilder-grid { display:flex; flex-wrap:wrap; gap:16px; align-items:flex-start; }
.hs-bild-item { text-align:center; max-width:300px; }
.hs-bild-img-wrap { position:relative; display:inline-block; }
.hs-bild-caption { margin:6px 0 2px; font-size:.9em; font-weight:700; color:var(--hs-primary); }
.hs-bild-straftat { margin:2px 0 0; font-size:.78em; color:#000000; line-height:1.35; max-width:300px; }

/* Hover-Tooltip */
.hs-bild-tooltip {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--hs-primary);
    color: #fff;
    padding: 10px 14px;
    border-radius: var(--hs-radius);
    min-width: 200px;
    max-width: 280px;
    text-align: left;
    z-index: 200;
    box-shadow: 0 4px 18px rgba(0,0,0,.45);
    pointer-events: none;
}
.hs-bild-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--hs-primary);
}
.hs-bild-tooltip strong { display:block; margin-bottom:5px; font-size:.92em; }
.hs-bild-tooltip span   { display:block; font-size:.78em; opacity:.9; line-height:1.45; }
.hs-bild-tooltip .hs-bild-tooltip-straftat { color:#000000; margin-top:5px; opacity:1; }

/* ================================================================
   [handschelle-slideshow]
================================================================ */
.hs-slideshow-wrap {
    overflow: hidden;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    background: #fff;
    box-shadow: var(--hs-shadow);
}
.hs-slideshow-track {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    white-space: nowrap;
    will-change: transform;
    animation: hs-slideshow-scroll linear infinite;
    padding: .85rem 1rem;
}
.hs-slide-item {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    border-right: 1px solid #ececec;
    padding-right: 1rem;
}
.hs-slide-image {
    width: auto;
    height: 100px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid #ddd;
    display: block;
}
.hs-slide-text {
    font-size: .9rem;
    color: #111;
    line-height: 1.35;
    white-space: normal;
    min-width: 260px;
    max-width: 560px;
}
@keyframes hs-slideshow-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ================================================================
   V3.0 – Bulk Actions Bar
================================================================ */
.hs-bulk-bar { display:flex; gap:.7rem; align-items:center; padding:.6rem 0 .8rem; flex-wrap:wrap; }
.hs-bulk-select-all { display:inline-flex; align-items:center; gap:.4rem; font-size:.85rem; font-weight:600; color:#444; cursor:pointer; }
.hs-bulk-checkbox { width:16px; height:16px; cursor:pointer; accent-color:var(--hs-accent); }
.hs-bulk-select { padding:.42rem .65rem; border:1.5px solid var(--hs-border); border-radius:var(--hs-radius); font-size:.88rem; font-family:var(--hs-font); background:#fff; color:#000; }

/* ================================================================
   Wordcloud
================================================================ */
.hs-wordcloud { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:.6rem 1.1rem; padding:1.5rem; background:var(--hs-card-bg); border-radius:var(--hs-radius); border:1px solid var(--hs-border); box-shadow:var(--hs-shadow); }
.hs-wordcloud-item { cursor:default; font-weight:700; line-height:1.4; display:inline-block; transition:opacity .2s,transform .15s; }
.hs-wordcloud-item:hover { opacity:.7; transform:scale(1.1); }
.hs-wc-partei { font-size:.72em; font-weight:400; opacity:.65; }
.hs-wordcloud-empty { color:var(--hs-muted); font-style:italic; }

/* ================================================================
   News-Ticker  [handschelle-ticker]
================================================================ */
.hs-ticker-wrap {
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--hs-primary);
    color: #fff;
    border-radius: var(--hs-radius);
    font-family: var(--hs-font);
    font-size: .92rem;
    box-shadow: var(--hs-shadow);
    width: 100%;
}
.hs-ticker-label {
    flex-shrink: 0;
    background: var(--hs-accent);
    color: #fff;
    font-weight: 700;
    font-size: .82rem;
    letter-spacing: .04em;
    padding: .55rem .9rem;
    white-space: nowrap;
}
.hs-ticker-viewport {
    flex: 1;
    overflow: hidden;
    position: relative;
}
.hs-ticker-track {
    display: inline-flex;
    white-space: nowrap;
    animation: hs-ticker-scroll linear infinite;
    will-change: transform;
}
@keyframes hs-ticker-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.hs-ticker-item {
    display: inline-block;
    padding: .55rem 2.2rem;
    border-right: 1px solid rgba(255,255,255,.12);
}
.hs-ticker-name {
    font-weight: 700;
    color: #fff;
}
.hs-ticker-partei {
    font-size: .85em;
    opacity: .75;
    margin-left: .2em;
}
.hs-ticker-straftat {
    font-size: .87em;
    color: #000000;
}
.hs-ticker-empty { color: var(--hs-muted); font-style: italic; }

/* ================================================================
   Straftat-Ticker  [handschelle-straftat]
================================================================ */
.hs-st-wrap {
    display: flex;
    align-items: center;
    overflow: hidden;
    background: #ffffff;
    border: 2px solid #000000;
    border-radius: var(--hs-radius);
    font-family: var(--hs-font);
    font-size: .92rem;
    box-shadow: var(--hs-shadow);
    width: 100%;
}
.hs-st-viewport {
    flex: 1;
    overflow: hidden;
    position: relative;
}
.hs-st-track {
    display: inline-flex;
    white-space: nowrap;
    animation: hs-st-scroll linear infinite;
    will-change: transform;
}
@keyframes hs-st-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.hs-st-item {
    display: inline-block;
    padding: .55rem 2rem;
    border-right: 1px solid #000000;
    color: #000000;
}
.hs-st-partei {
    font-weight: 700;
    color: #cc0000;
}
.hs-st-name {
    font-weight: 700;
    color: #000000;
}
.hs-st-straftat {
    color: #000000;
}
.hs-st-status {
    font-weight: 700;
    color: #cc0000;
}
.hs-st-empty { color: var(--hs-muted); font-style: italic; }
.hs-st-link { color: inherit; text-decoration: none; }
.hs-st-link:hover { opacity: .75; }
a.hs-st-item { display: inline-block; }
.hs-ti-icon {
    display: inline-block;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover;
    vertical-align: middle;
    margin-right: .45rem;
    flex-shrink: 0;
}
.hs-ti-initial {
    background: #1a1a2e;
    color: #fff;
    font-size: .75rem;
    font-weight: 700;
    line-height: 28px;
    text-align: center;
}

/* ================================================================
   Login-Formular  [handschelle-login]
================================================================ */
.hs-login-wrap {
    margin: 0 auto;
    font-family: var(--hs-font);
    color: #222;
}
.hs-login-form {
    background: var(--hs-card-bg);
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: 1.8rem 2rem;
    box-shadow: var(--hs-shadow);
}
.hs-login-form .hs-form-group {
    margin-bottom: 1.1rem;
}
.hs-login-form .hs-label {
    display: block;
    font-weight: 600;
    font-size: .875rem;
    color: #333;
    margin-bottom: .35rem;
}
.hs-login-form .hs-input {
    width: 100%;
    padding: .55rem .85rem;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    font-size: .95rem;
    font-family: var(--hs-font);
    color: #222;
    background: #fff;
    transition: border-color .15s;
    box-sizing: border-box;
}
.hs-login-form .hs-input:focus {
    outline: none;
    border-color: var(--hs-accent);
    box-shadow: 0 0 0 3px rgba(192,57,43,.12);
}
.hs-login-remember .hs-checkbox-label {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .875rem;
    cursor: pointer;
    color: #555;
}
.hs-btn-submit {
    width: 100%;
    background: var(--hs-accent);
    color: #fff;
    border: none;
    border-radius: var(--hs-radius);
    padding: .65rem 1.2rem;
    font-size: 1rem;
    font-weight: 700;
    font-family: var(--hs-font);
    cursor: pointer;
    transition: background .18s;
}
.hs-btn-submit:hover { background: var(--hs-accent-h); }
.hs-login-links {
    text-align: center;
    margin: .6rem 0 0;
    font-size: .85rem;
    color: var(--hs-muted);
}
.hs-login-links a { color: var(--hs-accent); text-decoration: none; }
.hs-login-links a:hover { text-decoration: underline; }
.hs-login-loggedin {
    background: var(--hs-card-bg);
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: 1.4rem 1.8rem;
    box-shadow: var(--hs-shadow);
    text-align: center;
}
.hs-login-welcome {
    margin: 0 0 1rem;
    font-size: 1rem;
    color: #333;
}
.hs-btn-logout {
    display: inline-block;
    background: var(--hs-primary);
    color: #fff;
    border-radius: var(--hs-radius);
    padding: .5rem 1.2rem;
    font-size: .9rem;
    font-weight: 600;
    font-family: var(--hs-font);
    text-decoration: none;
    transition: opacity .18s;
}
.hs-btn-logout:hover { opacity: .85; color: #fff; }

/* ================================================================
   Registrierungs-Formular  [handschelle-register]
================================================================ */
.hs-register-wrap {
    margin: 0 auto;
    font-family: var(--hs-font);
    color: #222;
}
.hs-register-form {
    background: var(--hs-card-bg);
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: 1.8rem 2rem;
    box-shadow: var(--hs-shadow);
}
.hs-register-form .hs-form-group {
    margin-bottom: 1.1rem;
}
.hs-register-form .hs-label {
    display: block;
    font-weight: 600;
    font-size: .875rem;
    color: #333;
    margin-bottom: .35rem;
}
.hs-register-form .hs-input {
    width: 100%;
    padding: .55rem .85rem;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    font-size: .95rem;
    font-family: var(--hs-font);
    color: #222;
    background: #fff;
    transition: border-color .15s;
    box-sizing: border-box;
}
.hs-register-form .hs-input:focus {
    outline: none;
    border-color: var(--hs-accent);
    box-shadow: 0 0 0 3px rgba(192,57,43,.12);
}
.hs-required { color: var(--hs-accent); }
.hs-register-hint { font-size: .8rem; color: var(--hs-muted); margin: -.4rem 0 .8rem; }
.hs-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1rem; }
@media (max-width: 480px) { .hs-form-row { grid-template-columns: 1fr; } }
.hs-register-loggedin {
    background: var(--hs-card-bg);
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: 1.4rem 1.8rem;
    box-shadow: var(--hs-shadow);
    text-align: center;
}
.hs-register-info { margin: 0; font-size: 1rem; color: #333; }

/* ================================================================
   [handschelle-privacy] – Datenschutz / Privacy
================================================================ */
.hs-privacy { font-family:var(--hs-font); color:#222; display:flex; flex-direction:column; gap:1.2rem; }
.hs-privacy-section { padding:1.4rem 1.6rem; background:var(--hs-card-bg); border:1px solid var(--hs-border); border-radius:var(--hs-radius); box-shadow:var(--hs-shadow); }
.hs-privacy-heading { font-size:1.1rem; font-weight:700; color:var(--hs-primary); margin:0 0 1rem; padding-bottom:.5rem; border-bottom:2px solid var(--hs-accent); }
.hs-privacy-section p { font-size:.9rem; line-height:1.65; margin:.6rem 0; color:#333; }
.hs-privacy-section ul { margin:.3rem 0 .6rem 1.4rem; padding:0; }
.hs-privacy-section ul li { font-size:.88rem; line-height:1.6; color:#444; margin-bottom:.2rem; }
.hs-privacy-section code { background:#f0f0f0; padding:.1rem .35rem; border-radius:3px; font-family:monospace; font-size:.9em; color:#333; letter-spacing:.02em; }
.hs-privacy-divider { border:none; border-top:1px solid var(--hs-border); margin:0; }

/* ================================================================
   [handschelle-wanted] – Fahndungsplakat (digital)
================================================================ */
/* ============================================================
   [handschelle-wanted] – RAF/BKA Fahndungsplakat Design
   ============================================================ */
.hs-wanted-wrap {
    font-family: 'Arial Narrow', Arial, Helvetica, sans-serif;
    padding: 1.5rem 0;
}
.hs-wanted-card {
    background: #f5f0e8;
    border: 3px solid #1a1a1a;
    border-radius: 0;
    overflow: hidden;
    box-shadow: 6px 6px 0 #1a1a1a, 0 0 0 1px #1a1a1a;
}

/* Header */
.hs-wanted-header {
    background: #cc0000;
    color: #fff;
    text-align: center;
    padding: .6rem 1rem .5rem;
    border-bottom: 4px solid #1a1a1a;
}
.hs-wanted-header-authority {
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .35em;
    text-transform: uppercase;
    opacity: .85;
    margin-bottom: .15rem;
}
.hs-wanted-header-title {
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: .25em;
    text-transform: uppercase;
    line-height: 1;
}
.hs-wanted-header-gesucht {
    font-size: 2.4rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    line-height: 1;
    margin-top: .1rem;
    text-shadow: 2px 2px 0 rgba(0,0,0,.35);
}

/* Body */
.hs-wanted-body {
    display: flex;
    gap: 0;
    border-bottom: 3px solid #1a1a1a;
}

/* Photo column */
.hs-wanted-photo-col {
    flex-shrink: 0;
    width: 170px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #ddd8cc;
    border-right: 3px solid #1a1a1a;
    padding: 1rem .8rem;
}
.hs-wanted-photo {
    width: 140px;
    height: 175px;
    object-fit: cover;
    object-position: top center;
    border: 3px solid #1a1a1a;
    display: block;
    filter: grayscale(20%) contrast(1.05);
}
.hs-wanted-photo-placeholder {
    width: 140px;
    height: 175px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4.5rem;
    font-weight: 900;
    color: #999;
    background: #c8c3b8;
    border: 3px solid #1a1a1a;
    font-family: serif;
}

/* Info column */
.hs-wanted-info-col {
    flex: 1;
    padding: 1rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: .55rem;
    min-width: 0;
    background: #f5f0e8;
}
.hs-wanted-name {
    font-size: 1.3rem;
    font-weight: 900;
    color: #1a1a1a;
    line-height: 1.15;
    word-break: break-word;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding-bottom: .5rem;
    border-bottom: 2px solid #cc0000;
    margin-bottom: .1rem;
}
.hs-wanted-row {
    display: flex;
    align-items: baseline;
    gap: .4rem;
    flex-wrap: wrap;
}
.hs-wanted-row--block {
    flex-direction: column;
    gap: .1rem;
}
.hs-wanted-label {
    font-size: .68rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #cc0000;
    white-space: nowrap;
    flex-shrink: 0;
}
.hs-wanted-value {
    font-size: .85rem;
    color: #1a1a1a;
    line-height: 1.45;
    word-break: break-word;
    font-weight: 500;
}
.hs-wanted-value--urteil {
    color: #cc0000;
    font-weight: 700;
}

/* Footer */
.hs-wanted-footer {
    background: #1a1a1a;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .55rem 1rem;
    gap: 1rem;
    flex-wrap: wrap;
}
.hs-wanted-status {
    font-size: .62rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .1em;
    padding: .28rem .7rem;
    border: 2px solid;
}
.hs-wanted-status--verurteilt  { background: #cc0000; color: #fff; border-color: #ff4444; }
.hs-wanted-status--ermittlung  { background: #b36200; color: #fff; border-color: #ffa000; }
.hs-wanted-status--eingestellt { background: #1a5c2a; color: #fff; border-color: #4caf50; }
.hs-wanted-footer-hinweis {
    font-size: .6rem;
    color: #aaa;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-style: italic;
    text-align: center;
}

@media (max-width: 520px) {
    .hs-wanted-body { flex-direction: column; }
    .hs-wanted-photo-col {
        width: 100%;
        flex-direction: row;
        padding: .8rem 1rem;
        border-right: none;
        border-bottom: 3px solid #1a1a1a;
        justify-content: flex-start;
        gap: 1rem;
    }
    .hs-wanted-photo,
    .hs-wanted-photo-placeholder { width: 90px; height: 110px; }
    .hs-wanted-header-gesucht { font-size: 1.8rem; }
    .hs-wanted-footer { flex-direction: column; align-items: flex-start; }
}

/* ================================================================
   [handschelle-chat] – Ollama Chatbot Widget
================================================================ */
.hs-chat-widget {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    box-shadow: var(--hs-shadow);
    overflow: hidden;
    font-family: var(--hs-font);
    background: var(--hs-card-bg);
    max-width: 720px;
    width: 100%;
    margin: 0 auto;
}

.hs-chat-dropdown-heading {
    background: var(--hs-accent, #c0392b);
    color: #fff;
    font-size: .95rem;
    font-weight: 700;
    padding: .6rem 1rem;
    letter-spacing: .02em;
}

.hs-chat-dropdown-top {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--hs-border);
    background: #f6f7f9;
}
.hs-chat-dropdown-label {
    font-size: .78rem;
    font-weight: 700;
    color: var(--hs-primary);
}
.hs-chat-name-select {
    width: 100%;
    max-width: 100%;
    border: 1.5px solid var(--hs-border);
    border-radius: 8px;
    padding: .5rem .7rem;
    font-size: .86rem;
    font-family: var(--hs-font);
    background: #fff;
    color: #000;
}
.hs-chat-name-select:focus {
    outline: none;
    border-color: var(--hs-accent);
    box-shadow: 0 0 0 3px rgba(192,57,43,.12);
}

.hs-chat-header {
    display: flex;
    align-items: center;
    gap: .6rem;
    background: linear-gradient(135deg, var(--hs-primary) 0%, var(--hs-accent) 100%);
    color: #fff;
    padding: .75rem 1rem;
}
.hs-chat-title {
    font-weight: 700;
    font-size: .95rem;
    flex: 1;
}
.hs-chat-model-select {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 20px;
    color: #fff;
    font-family: var(--hs-font);
    font-size: .75rem;
    padding: .2rem .65rem;
    cursor: pointer;
    max-width: 180px;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(255,255,255,.7)'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .5rem center;
    padding-right: 1.6rem;
    transition: background-color .2s;
}
.hs-chat-model-select:focus {
    outline: none;
    background-color: rgba(255,255,255,.25);
}
.hs-chat-model-select option {
    background: var(--hs-primary);
    color: #fff;
}
.hs-chat-model-select:disabled {
    opacity: .5;
    cursor: default;
}
.hs-chat-settings-btn,
.hs-chat-clear-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,.7);
    cursor: pointer;
    padding: 0 .25rem;
    line-height: 1;
    transition: color .2s;
    display: flex;
    align-items: center;
}
.hs-chat-settings-btn:hover,
.hs-chat-clear-btn:hover { color: #fff; }
.hs-chat-settings-btn.is-open { color: #fff; }
.hs-chat-multi-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,.7);
    cursor: pointer;
    padding: .2rem .3rem;
    line-height: 1;
    transition: color .2s, background .2s;
    display: flex;
    align-items: center;
    border-radius: 4px;
}
.hs-chat-multi-btn:hover  { color: #fff; }
.hs-chat-multi-btn.is-active {
    background: rgba(255,255,255,.25);
    color: #fff;
}
.hs-chat-clear-btn { font-size: .85rem; }

/* Settings panel */
.hs-chat-settings-panel {
    background: #f7f7f9;
    border-bottom: 1px solid var(--hs-border);
    padding: .75rem 1rem;
}
.hs-chat-settings-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: .75rem;
    align-items: start;
}
.hs-chat-settings-label {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    font-size: .78rem;
    font-weight: 600;
    color: #444;
}
.hs-chat-settings-system {
    resize: vertical;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: .4rem .6rem;
    font-family: var(--hs-font);
    font-size: .82rem;
    line-height: 1.45;
    min-height: 58px;
}
.hs-chat-settings-system:focus {
    outline: none;
    border-color: var(--hs-accent);
}
.hs-chat-settings-temp {
    width: 120px;
    accent-color: var(--hs-accent);
    cursor: pointer;
}
.hs-chat-temp-value {
    font-weight: 400;
    color: var(--hs-accent);
    font-size: .78rem;
    margin-left: .25rem;
}
.hs-chat-settings-url-row {
    grid-column: 1 / -1;
}
.hs-chat-settings-url-wrap {
    display: flex;
    gap: .35rem;
}
.hs-chat-settings-url {
    flex: 1;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: .35rem .6rem;
    font-family: monospace;
    font-size: .8rem;
}
.hs-chat-settings-url:focus {
    outline: none;
    border-color: var(--hs-accent);
}
.hs-chat-settings-url-apply {
    background: var(--hs-primary);
    color: #fff;
    border: none;
    border-radius: var(--hs-radius);
    padding: .35rem .65rem;
    cursor: pointer;
    font-size: .85rem;
    transition: background .2s;
}
.hs-chat-settings-url-apply:hover { background: var(--hs-accent); }
.hs-chat-settings-url-hint {
    font-size: .7rem;
    color: var(--hs-muted);
    font-weight: 400;
}
@media (max-width: 480px) {
    .hs-chat-settings-grid { grid-template-columns: 1fr; }
}

/* Multi-model settings row */
.hs-chat-settings-multi-row {
    grid-column: 1 / -1;
    margin-top: .25rem;
    padding-top: .6rem;
    border-top: 1px solid var(--hs-border);
}
.hs-chat-multi-models {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .75rem;
    margin-top: .4rem;
}
.hs-chat-multi-model-label {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .8rem;
    font-weight: 400;
    cursor: pointer;
    white-space: nowrap;
}
.hs-chat-multi-model-label input[type="checkbox"] {
    accent-color: var(--hs-accent);
    cursor: pointer;
    width: 14px;
    height: 14px;
}
.hs-chat-multi-size {
    color: var(--hs-muted);
    font-size: .7rem;
}
.hs-chat-multi-hint {
    font-size: .75rem;
    color: var(--hs-muted);
    font-style: normal;
}
.hs-chat-multi-group-label {
    display: block;
    width: 100%;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--hs-muted);
    margin-top: .4rem;
    padding-bottom: .15rem;
    border-bottom: 1px solid var(--hs-border);
}
.hs-chat-multi-group-label:first-child { margin-top: 0; }
.hs-chat-multi-group-openai {
    color: #10a37f; /* OpenAI brand green */
    border-color: #10a37f;
}

/* Multi-model response columns */
.hs-chat-multi-group {
    display: flex;
    gap: .75rem;
    align-items: flex-start;
    width: 100%;
}
.hs-chat-multi-col {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: .4rem;
}
.hs-chat-multi-label {
    font-size: .7rem;
    font-weight: 700;
    color: var(--hs-accent);
    text-align: center;
    padding: .15rem .5rem;
    background: color-mix(in srgb, var(--hs-accent) 12%, transparent);
    border-radius: var(--hs-radius);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.hs-chat-multi-col .hs-chat-bubble {
    max-width: 100%;
    font-size: .82rem;
}
@media (max-width: 600px) {
    .hs-chat-multi-group { flex-direction: column; }
}

.hs-chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    min-height: 300px;
    max-height: 480px;
    background: var(--hs-bg);
}

.hs-chat-bubble {
    max-width: 80%;
    padding: .6rem .9rem;
    border-radius: 12px;
    line-height: 1.55;
    font-size: .9rem;
    word-break: break-word;
    white-space: pre-wrap;
}
.hs-chat-bubble-user {
    background: var(--hs-primary);
    color: #fff;
    align-self: flex-end;
    border-bottom-right-radius: 3px;
}
.hs-chat-bubble-assistant {
    background: var(--hs-card-bg);
    border: 1px solid var(--hs-border);
    color: #222;
    align-self: flex-start;
    border-bottom-left-radius: 3px;
    box-shadow: var(--hs-shadow);
}
.hs-chat-bubble-error {
    background: #fdecea;
    border: 1px solid #e74c3c;
    color: #c0392b;
    align-self: flex-start;
    border-bottom-left-radius: 3px;
}

/* Typing indicator */
.hs-chat-typing {
    align-self: flex-start;
    display: flex;
    align-items: center;
    gap: 4px;
    padding: .5rem .9rem;
    background: var(--hs-card-bg);
    border: 1px solid var(--hs-border);
    border-radius: 12px;
    border-bottom-left-radius: 3px;
}
.hs-chat-typing span {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--hs-muted);
    animation: hs-chat-bounce .9s infinite;
    display: inline-block;
}
.hs-chat-typing span:nth-child(2) { animation-delay: .15s; }
.hs-chat-typing span:nth-child(3) { animation-delay: .30s; }

@keyframes hs-chat-bounce {
    0%, 60%, 100% { transform: translateY(0); opacity: .5; }
    30%            { transform: translateY(-6px); opacity: 1; }
}

.hs-chat-input-row {
    display: flex;
    align-items: flex-end;
    gap: .5rem;
    padding: .75rem 1rem;
    border-top: 1px solid var(--hs-border);
    background: var(--hs-card-bg);
}
.hs-chat-input {
    flex: 1;
    resize: none;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: .55rem .8rem;
    font-family: var(--hs-font);
    font-size: .9rem;
    line-height: 1.5;
    max-height: 140px;
    overflow-y: auto;
    transition: border-color .2s;
}
.hs-chat-input:focus {
    outline: none;
    border-color: var(--hs-accent);
}
.hs-chat-send-btn {
    background: var(--hs-accent);
    color: #fff;
    border: none;
    border-radius: var(--hs-radius);
    padding: .55rem .8rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
    flex-shrink: 0;
}
.hs-chat-send-btn:hover   { background: var(--hs-accent-h); }
.hs-chat-send-btn:disabled { background: var(--hs-muted); cursor: default; }

/* Empty state placeholder */
.hs-chat-empty {
    text-align: center;
    color: var(--hs-muted);
    font-size: .85rem;
    margin: auto;
    padding: 2rem 1rem;
}

/* Message status line */
.hs-chat-status {
    align-self: flex-start;
    font-size: .7rem;
    color: var(--hs-muted);
    display: flex;
    gap: .4rem;
    align-items: center;
    padding: 0 .2rem;
    margin-top: -.35rem;
}
.hs-chat-status-sep {
    opacity: .4;
}
.hs-chat-repost-btn {
    background: var(--hs-accent);
    border: none;
    border-radius: 20px;
    color: #fff;
    cursor: pointer;
    font-size: .68rem;
    font-weight: 600;
    padding: .15rem .55rem;
    line-height: 1.4;
    transition: background .2s, transform .1s;
    white-space: nowrap;
}
.hs-chat-repost-btn:hover {
    background: var(--hs-accent-h);
    transform: scale(1.05);
}
.hs-chat-repost-controls {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    margin-left: .2rem;
}
.hs-chat-repost-select {
    font-size: .7rem;
    border: 1px solid var(--hs-border);
    border-radius: var(--hs-radius);
    padding: .1rem .4rem;
    background: var(--hs-card-bg);
    color: #333;
    cursor: pointer;
    max-width: 160px;
}
.hs-chat-repost-go,
.hs-chat-repost-cancel {
    border: none;
    border-radius: var(--hs-radius);
    cursor: pointer;
    font-size: .7rem;
    font-weight: 600;
    padding: .15rem .45rem;
    line-height: 1.4;
    transition: background .2s;
}
.hs-chat-repost-go     { background: var(--hs-accent); color: #fff; }
.hs-chat-repost-cancel { background: #e0e0e0; color: #555; }
.hs-chat-repost-go:hover     { background: var(--hs-accent-h); }
.hs-chat-repost-cancel:hover { background: #c8c8c8; }
.hs-chat-bubble-repost {
    border-left: 3px solid var(--hs-accent);
}
.hs-chat-status-repost {
    margin-left: .5rem;
}

@media (max-width: 480px) {
    .hs-chat-messages { min-height: 240px; max-height: 360px; }
    .hs-chat-bubble   { max-width: 95%; }
}

/* ================================================================
   AI-Profil Modal
================================================================ */
#hs-profile-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.hs-profile-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.55);
}
.hs-profile-modal-box {
    position: relative;
    z-index: 1;
    background: var(--hs-card-bg, #fff);
    border-radius: var(--hs-radius, 8px);
    box-shadow: 0 8px 40px rgba(0,0,0,.35);
    width: min(680px, 94vw);
    max-height: 82vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.hs-profile-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--hs-primary, #1a1a2e);
    color: #fff;
    padding: .75rem 1rem;
    gap: .5rem;
    flex-shrink: 0;
}
.hs-profile-modal-title {
    font-weight: 700;
    font-size: .95rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.hs-profile-modal-close {
    background: none;
    border: none;
    color: #fff;
    font-size: 1.1rem;
    cursor: pointer;
    line-height: 1;
    padding: .2rem .4rem;
    border-radius: 4px;
    flex-shrink: 0;
}
.hs-profile-modal-close:hover { background: rgba(255,255,255,.15); }
.hs-profile-modal-body {
    overflow-y: auto;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.hs-profile-qa {
    border-left: 3px solid var(--hs-accent, #c0392b);
    padding-left: .75rem;
}
.hs-profile-question {
    font-weight: 600;
    font-size: .88rem;
    color: var(--hs-primary, #1a1a2e);
    margin-bottom: .35rem;
}
.hs-profile-answer {
    font-size: .9rem;
    line-height: 1.6;
    color: #333;
    white-space: pre-wrap;
}
.hs-profile-loading {
    display: inline-block;
    color: var(--hs-muted, #7f8c8d);
    animation: hs-profile-pulse 1s ease-in-out infinite;
}
@keyframes hs-profile-pulse {
    0%,100% { opacity: 1; }
    50%      { opacity: .3; }
}
.hs-profile-error { color: var(--hs-accent, #c0392b); font-style: italic; }
.hs-profile-done  { text-align: center; font-size: .85rem; color: var(--hs-success, #27ae60); font-weight: 600; }

/* ── [handschelle-profil-tabelle] ───────────────────────────────────── */
.hs-profil-tabelle {
    border-collapse: collapse;
    width: 100%;
    max-width: 560px;
    font-size: .9rem;
}
.hs-profil-row:not(:last-child) td {
    border-bottom: 1px solid var(--hs-border, #e0e0e0);
}
.hs-profil-row td {
    padding: .45rem .5rem;
    vertical-align: top;
}
.hs-profil-label {
    font-weight: 600;
    white-space: nowrap;
    color: var(--hs-muted, #555);
    width: 1%;
}
.hs-profil-sep {
    padding-left: .35rem !important;
    padding-right: .35rem !important;
    color: var(--hs-muted, #999);
    width: 1%;
}
.hs-profil-value {
    color: var(--hs-text, #222);
}
