:root {
    --blue: #174d7e;
    --blue-dark: #0e365b;
    --cyan: #29a9c8;
    --bg: #f4f8fb;
    --card: #ffffff;
    --text: #1e293b;
    --muted: #64748b;
    --border: #e2e8f0;
    --danger: #b42318;
    --success: #067647;
    --warning: #8a5a00;
    --shadow: 0 18px 45px rgba(15, 23, 42, .08);
    --shadow-soft: 0 10px 30px rgba(15, 23, 42, .06);
    --radius: 22px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(41, 169, 200, .18), transparent 30%),
        linear-gradient(135deg, #eff8ff, #f8fafc 45%, #eef9fb);
    min-height: 100vh;
}
a { color: inherit; text-decoration: none; }

.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}
.login-card {
    width: 100%;
    max-width: 440px;
    background: rgba(255, 255, 255, .94);
    border-radius: 30px;
    padding: 36px;
    box-shadow: 0 28px 80px rgba(15, 52, 89, .16);
    border: 1px solid rgba(255,255,255,.8);
    backdrop-filter: blur(12px);
}
.logo { display: block; max-width: 210px; margin: 0 auto 24px; border-radius: 18px; }
.login-card h1 { text-align: center; margin: 0 0 8px; color: var(--blue-dark); font-size: 28px; letter-spacing: -.02em; }
.subtitle { text-align: center; color: var(--muted); margin: 0 0 26px; line-height: 1.5; }

label { font-weight: 800; display: block; margin: 14px 0 7px; color: var(--blue-dark); }
input, select, textarea {
    width: 100%;
    padding: 13px 14px;
    border-radius: 15px;
    border: 1px solid var(--border);
    font-size: 15px;
    background: #fff;
    color: var(--text);
    outline: none;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
textarea { min-height: 110px; resize: vertical; }
input:focus, select:focus, textarea:focus {
    border-color: var(--cyan);
    box-shadow: 0 0 0 4px rgba(41, 169, 200, .16);
}
input[type="checkbox"], input[type="radio"] { accent-color: var(--blue); }
button, .btn, .small-btn {
    border: 0;
    border-radius: 15px;
    padding: 13px 18px;
    font-weight: 800;
    background: linear-gradient(135deg, var(--blue), var(--cyan));
    color: white;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    line-height: 1.2;
    box-shadow: 0 8px 18px rgba(23, 77, 126, .16);
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
button:hover, .btn:hover, .small-btn:hover { filter: brightness(.98); transform: translateY(-1px); box-shadow: 0 12px 24px rgba(23, 77, 126, .2); }
button:disabled { opacity: .55; cursor: not-allowed; transform: none; }
.small-btn { padding: 8px 12px; border-radius: 12px; font-size: 13px; }
.danger-btn { background: linear-gradient(135deg, #b42318, #e5483f); }
.error, .success {
    padding: 13px 15px;
    border-radius: 16px;
    margin-bottom: 16px;
    font-weight: 700;
    border: 1px solid transparent;
}
.error { background: #fff1f0; color: var(--danger); border-color: #ffd1cc; }
.success { background: #ecfdf3; color: var(--success); border-color: #b7ebc6; }

.topbar {
    background: rgba(255, 255, 255, .92);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 10;
    backdrop-filter: blur(14px);
}
.topbar-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 12px 20px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 18px;
}
.brand { display: flex; align-items: center; gap: 12px; font-weight: 900; color: var(--blue-dark); white-space: nowrap; }
.brand img { width: 86px; height: auto; border-radius: 14px; }
.nav {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}
.nav a {
    padding: 9px 12px;
    border-radius: 999px;
    color: var(--blue-dark);
    font-weight: 800;
    font-size: 14px;
    border: 1px solid transparent;
}
.nav a.active, .nav a:hover { background: #e8f7fb; color: var(--blue); border-color: #cceff7; }
.user-menu { display:flex; gap:12px; align-items:center; justify-content:flex-end; }
.logout { color: var(--danger); font-weight: 900; padding: 8px 0; }
.container { max-width: 1280px; margin: 0 auto; padding: 30px 20px 42px; }

.hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--blue-dark), var(--blue), var(--cyan));
    color: white;
    border-radius: 30px;
    padding: 32px;
    margin-bottom: 24px;
    box-shadow: 0 20px 45px rgba(23,77,126,.18);
}
.hero:after {
    content: "";
    position: absolute;
    right: -70px;
    top: -70px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .13);
}
.hero h1 { margin: 0 0 8px; font-size: clamp(26px, 4vw, 38px); letter-spacing: -.03em; }
.hero p { margin: 0; opacity: .94; line-height: 1.55; max-width: 850px; }
.grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.card {
    background: rgba(255, 255, 255, .95);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 22px;
    box-shadow: var(--shadow-soft);
    overflow: hidden;
}
.card h2, .card h3 { margin-top: 0; color: var(--blue-dark); letter-spacing: -.02em; }
.card h2 { font-size: 22px; }
.card h3 { font-size: 18px; }
.stat { font-size: 36px; font-weight: 900; color: var(--blue); line-height: 1; margin: 8px 0 10px; }
.table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    background: white;
}
.table th, .table td { text-align: left; padding: 13px; border-bottom: 1px solid var(--border); vertical-align: top; }
.table tr:last-child td { border-bottom: 0; }
.table th { background: #f1f7fb; color: var(--blue-dark); font-size: 14px; }
.table tr:hover td { background: #fbfdff; }
.span-2 { grid-column: span 2; }
.span-4 { grid-column: span 4; }
.badge, .pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #eef8fb;
    color: var(--blue);
    font-weight: 800;
    font-size: 13px;
    line-height: 1.2;
}
.muted { color: var(--muted); }


.card-link {
    display: block;
    position: relative;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card-link:hover {
    transform: translateY(-3px);
    border-color: #bfeaf4;
    box-shadow: var(--shadow);
}
.card-link:focus-visible {
    outline: 4px solid rgba(41, 169, 200, .22);
    outline-offset: 3px;
}
.section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
}
.section-head h2,
.section-head p { margin-bottom: 0; }
.menu-grid .menu-card {
    min-height: 190px;
}
.menu-card p {
    color: var(--muted);
    line-height: 1.5;
    margin-bottom: 0;
}
.menu-icon {
    display: inline-flex;
    width: 46px;
    height: 46px;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: #e8f7fb;
    color: var(--blue);
    font-weight: 900;
    font-size: 22px;
    margin-bottom: 12px;
}
.back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: white;
    background: rgba(255, 255, 255, .16);
    border: 1px solid rgba(255, 255, 255, .28);
    border-radius: 999px;
    padding: 8px 13px;
    font-weight: 900;
    margin-bottom: 16px;
}
.back-link:hover { background: rgba(255, 255, 255, .24); }

/* Wunschplan */
.toolbar { display:flex; gap:12px; align-items:end; flex-wrap:wrap; margin-bottom:16px; }
.toolbar .field { min-width:160px; flex: 1 1 160px; }
.legend { display:grid; grid-template-columns: repeat(5, minmax(130px, 1fr)); gap:10px; margin:12px 0 18px; }
.legend-item { padding:12px 14px; border-radius:16px; text-align:center; font-weight:900; border:1px solid var(--border); box-shadow: var(--shadow-soft); }
.td { background:#c6efce !important; color:#14532d; }
.nd { background:#d8b4fe !important; color:#4c1d95; }
.wf { background:#fff2c2 !important; color:#7a4c00; }
.we, .holiday { background:#e8e8e8 !important; color:#334155; }
.holiday { background:#f4c7c7 !important; color:#7f1d1d; }
.plan-wrap { overflow-x:auto; padding-bottom:10px; }
.plan-table { border-collapse:separate; border-spacing:6px; min-width:1100px; width:max-content; }
.plan-table th, .plan-table td { min-width:58px; height:58px; border-radius:15px; text-align:center; border:1px solid var(--border); background:white; font-weight:900; }
.plan-table th { background:#dceefa; color:#111; height:48px; font-size: 13px; }
.plan-table .name-col { min-width:130px; background:#edf5fb; position:sticky; left:0; z-index:2; box-shadow: 8px 0 18px rgba(15, 23, 42, .06); }
.plan-cell { cursor:pointer; user-select:none; font-size:20px; transition: transform .12s ease, box-shadow .12s ease; }
.plan-cell:hover { transform: scale(1.03); box-shadow: 0 8px 18px rgba(15, 23, 42, .10); }
.plan-cell.empty { color:#94a3b8; }
.notice { background:#fff7ed; color:#1f2937; border-radius:22px; padding:22px; line-height:1.6; margin:18px 0; border: 1px solid #fed7aa; }
.savebar { position:sticky; bottom:12px; display:flex; justify-content:flex-end; gap:12px; align-items:center; z-index: 5; }
.unsaved, .saved { padding:12px 18px; border-radius:999px; font-weight:900; box-shadow: var(--shadow-soft); }
.unsaved { background:#fff3cd; color:var(--warning); border:1px solid #ffd966; }
.saved { background:#dcfce7; color:#166534; border:1px solid #86efac; }
.actions { display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

/* Zusatzfunktionen */
.kpi-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; margin-bottom:18px; }
.kpi { background:#fff; border:1px solid var(--border); border-radius:20px; padding:18px; box-shadow: var(--shadow-soft); }
.kpi b { display:block; font-size:30px; color:var(--blue); }
.inline-form { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.inline-form input, .inline-form select { width:auto; min-width:130px; padding:9px; }
.status-pending, .status-open { background:#fff3cd; color:#8a5a00; }
.status-approved, .status-done { background:#dcfce7; color:#166534; }
.status-rejected { background:#fee2e2; color:#991b1b; }
.status-team_approved { background:#dbeafe; color:#1d4ed8; }

@media (max-width: 1100px) {
    .topbar-inner { grid-template-columns: 1fr; align-items: flex-start; }
    .nav { justify-content: flex-start; }
    .user-menu { justify-content: flex-start; }
}
@media (max-width: 900px) {
    .grid { grid-template-columns: repeat(2, 1fr); }
    .span-4 { grid-column: span 2; }
    .legend { grid-template-columns: repeat(2,1fr); }
    .kpi-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 700px) {
    .container { padding: 20px 14px 34px; }
    .hero { padding: 24px; border-radius: 24px; }
    .grid { grid-template-columns: 1fr; }
    .span-2, .span-4 { grid-column: span 1; }
    .topbar-inner { padding: 10px 14px; }
    .brand { white-space: normal; }
    .brand img { width: 72px; }
    .nav { width: 100%; flex-wrap: nowrap; justify-content: flex-start; overflow-x: auto; padding-bottom: 6px; }
    .nav a { white-space: nowrap; }
    .card { padding: 18px; border-radius: 20px; }
    .table { display: block; overflow-x: auto; white-space: nowrap; }
    .inline-form input, .inline-form select, .inline-form button { width: 100%; }
    .section-head { flex-direction: column; }
    .savebar { align-items: stretch; flex-direction: column; }
    .savebar button { width: 100%; }
}

/* Neue Wunschfrei und Freigabe Ansichten */
.selected-day {
    outline: 4px solid rgba(37, 99, 235, .35) !important;
    outline-offset: 2px;
    box-shadow: 0 0 0 6px rgba(37, 99, 235, .10) !important;
}
.subtle-notice {
    background: #eef6ff;
    border-color: #bfdbfe;
}
.approval-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
}
.approval-row {
    display: grid;
    grid-template-columns: minmax(140px, 1fr) auto minmax(160px, 1fr) minmax(140px, 1fr) minmax(140px, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: #fff;
}
.status-offen { background:#fff3cd; color:#8a5a00; }
.status-bestaetigt { background:#dcfce7; color:#166534; }
.status-abgelehnt { background:#fee2e2; color:#991b1b; }
.poll-box {
    border-bottom: 1px solid var(--border);
    padding: 16px 0;
}
.poll-box:last-child { border-bottom: 0; }
.poll-box details {
    margin-top: 12px;
    background: #f8fafc;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 12px;
}
.poll-box summary { cursor: pointer; font-weight: 900; }
@media (max-width: 900px) {
    .approval-row { grid-template-columns: 1fr; }
}
.login-help { text-align:center; margin:18px 0 0; }
.login-help a { color: var(--blue-dark); font-weight: 800; }
.danger-pill { background:#fee2e2; color:#991b1b; border-color:#fecaca; }
.report-box { border:1px solid var(--border); border-radius:18px; padding:16px; margin:14px 0; background:#fff; }
@media print {
  .topbar, .no-print, .back-link, .logout { display:none !important; }
  body { background:#fff; }
  .container { max-width:none; padding:0; }
  .card { box-shadow:none; border:1px solid #ddd; break-inside:avoid; }
  .table th, .table td { font-size:12px; padding:8px; }
}
.ng { background:#fecaca !important; color:#7f1d1d; }
.wb { background:#bfdbfe !important; color:#1e3a8a; }
.task-box { border:1px solid var(--border); border-radius:18px; padding:16px; margin:14px 0; background:#fff; box-shadow: var(--shadow-soft); }
.task-box h3 { margin-top:0; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.subtle-notice { background:#f8fafc; border-color:#e2e8f0; }

/* Runde: Dashboard, Feed, Modal und dezentere Auswahl */
.icon-link {
    width: 40px;
    height: 40px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #eef8fb;
    color: var(--blue-dark);
    font-weight: 900;
    border: 1px solid #d6eef5;
}
.icon-link.logout { color: var(--danger); background:#fff1f0; border-color:#ffd1cc; }
.dashboard-group .section-head { align-items:center; }
.quick-links { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
.quick-links a {
    padding: 13px 14px;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: #f8fafc;
    font-weight: 900;
    color: var(--blue-dark);
}
.quick-links a:hover { background:#e8f7fb; border-color:#cceff7; }
.feed-item { border-bottom:1px solid var(--border); padding:14px 0; }
.feed-item:last-child { border-bottom:0; }
.feed-item.compact p { margin:8px 0; }
.feed-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.feed-head h3 { margin:0; }
.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 50;
    background: rgba(15, 23, 42, .38);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.modal-backdrop[hidden] { display:none; }
.modal-card {
    width: min(440px, 100%);
    background: #fff;
    border-radius: 24px;
    padding: 26px;
    border: 1px solid var(--border);
    box-shadow: 0 28px 80px rgba(15, 23, 42, .22);
}
.modal-card h2 { margin-top:0; color:var(--blue-dark); }
.modal-card p { line-height:1.6; color:var(--text); }
.plan-table .selected-day {
    outline: 2px solid rgba(23, 77, 126, .28) !important;
    outline-offset: 1px;
    box-shadow: 0 0 0 3px rgba(41, 169, 200, .10) !important;
}
.plan-table th.selected-day { background:#eef8fb !important; }
@media (max-width:700px){ .quick-links { grid-template-columns:1fr; } }

/* Mobile Bedienung, Auto Layout und Benutzername Builder */
.nav-toggle {
    display: none;
    width: 44px;
    height: 44px;
    border-radius: 14px;
    padding: 0;
    font-size: 24px;
    box-shadow: none;
}
.username-builder {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: #fff;
    overflow: hidden;
}
.username-builder span {
    align-self: stretch;
    display: inline-flex;
    align-items: center;
    padding: 0 14px;
    background: #eef8fb;
    color: var(--blue-dark);
    font-weight: 900;
    border-right: 1px solid var(--border);
    min-width: 76px;
    justify-content: center;
}
.username-builder input {
    border: 0;
    border-radius: 0;
    box-shadow: none !important;
}
.table-wrap { width: 100%; overflow-x: auto; }
@media (hover: none) and (pointer: coarse) {
    button, .btn, .small-btn, .quick-links a, .nav a, .icon-link { min-height: 44px; }
    input, select, textarea { font-size: 16px; min-height: 46px; }
    .plan-cell:hover { transform: none; }
}
@media (max-width: 820px) {
    .topbar-inner {
        grid-template-columns: 1fr auto auto;
        gap: 10px;
        align-items: center;
    }
    .brand span { font-size: 15px; line-height: 1.2; }
    .brand img { width: 58px; }
    .nav-toggle { display: inline-flex; }
    .nav {
        display: none;
        grid-column: 1 / -1;
        width: 100%;
        max-height: 70vh;
        overflow-y: auto;
        padding: 8px 0 2px;
        border-top: 1px solid var(--border);
        margin-top: 4px;
    }
    .nav.is-open { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
    .nav a {
        border-radius: 14px;
        background: #f8fafc;
        border-color: var(--border);
        text-align: center;
        padding: 12px 10px;
    }
    .user-menu { gap: 8px; }
    .user-menu .badge { display: none; }
    .icon-link { width: 44px; height: 44px; }
    .login-card { padding: 26px 20px; border-radius: 24px; }
    .logo { max-width: 170px; }
    .hero { margin-bottom: 16px; }
    .card { box-shadow: 0 8px 20px rgba(15, 23, 42, .06); }
    .toolbar { align-items: stretch; }
    .toolbar .field, .toolbar button, .toolbar .small-btn { flex: 1 1 100%; width: 100%; }
    .actions, .inline-form { display: grid; grid-template-columns: 1fr; width: 100%; }
    .actions form, .inline-form input, .inline-form select, .inline-form button { width: 100%; }
    .kpi-grid { grid-template-columns: 1fr; }
    .feed-head { flex-direction: column; }
    .plan-wrap { margin-left: -8px; margin-right: -8px; padding: 0 8px 10px; }
    .plan-table { border-spacing: 4px; min-width: 980px; }
    .plan-table th, .plan-table td { min-width: 52px; height: 52px; border-radius: 13px; }
    .plan-table .name-col { min-width: 112px; }
}
@media (max-width: 420px) {
    .nav.is-open { grid-template-columns: 1fr; }
    .brand img { width: 48px; }
    .brand span { max-width: 145px; }
    .container { padding-left: 10px; padding-right: 10px; }
    .hero { padding: 20px; }
    .card { padding: 16px; }
    .username-builder { grid-template-columns: 1fr; }
    .username-builder span { border-right: 0; border-bottom: 1px solid var(--border); min-height: 42px; }
}
@media (max-width: 820px) {
    .brand { order: 1; }
    .user-menu { order: 2; }
    .nav-toggle { order: 3; }
    .nav { order: 4; }
}

.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:12px}.dash-tile{display:flex;flex-direction:column;gap:6px;padding:16px;border:1px solid var(--border);border-radius:18px;background:var(--card-soft);text-decoration:none;color:var(--text);min-height:130px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.dash-tile:hover,.dash-tile:focus{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--primary);outline:none}.dash-tile strong{font-size:1.05rem}.dash-tile small{color:var(--muted);line-height:1.4}.dash-tile em{margin-top:auto;font-style:normal;font-size:.85rem;color:var(--primary);font-weight:700}.tile-icon{width:36px;height:36px;border-radius:12px;background:var(--primary-soft);display:inline-flex;align-items:center;justify-content:center;font-weight:800}.compact-dashboard .kpi small{display:block;margin-top:6px;color:var(--muted)}
@media (max-width: 720px){.tile-grid{grid-template-columns:1fr 1fr}.dash-tile{min-height:120px;padding:14px}.dashboard-hero h1{font-size:1.55rem}}
@media (max-width: 480px){.tile-grid{grid-template-columns:1fr}.dash-tile{min-height:auto}.kpi-grid{grid-template-columns:1fr}}

/* Dashboard Update: klare Kategorien und News oben */
.feed-top-card { border: 1px solid var(--primary-soft); }
.feed-top-list { display: grid; gap: 10px; }
.category-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-top: 12px; }
.category-card { display: flex; flex-direction: column; gap: 8px; padding: 18px; border: 1px solid var(--border); border-radius: 20px; background: var(--card-soft); text-decoration: none; color: var(--text); min-height: 145px; transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.category-card:hover, .category-card:focus { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--primary); outline: none; }
.category-card strong { font-size: 1.12rem; }
.category-card small { color: var(--muted); line-height: 1.4; }
.category-card em { margin-top: auto; font-style: normal; font-weight: 700; color: var(--primary); }
.kpi-link { text-decoration: none; color: inherit; display: block; }
.checkbox-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 8px; margin: 8px 0 12px; }
.checkbox-list label { padding: 10px 12px; border: 1px solid var(--border); border-radius: 14px; background: #fff; }
@media (max-width: 720px) { .category-grid { grid-template-columns: 1fr; } .feed-top-card { order: -2; } }


.feed-images { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; margin: 12px 0; }
.feed-images img { width: 100%; max-height: 320px; object-fit: cover; border-radius: 16px; border: 1px solid var(--border); background: #fff; }
.feed-thumb { width: 100%; max-height: 220px; object-fit: cover; border-radius: 14px; border: 1px solid var(--border); margin: 8px 0; }
.reaction-row { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.reaction-form { margin: 0; }
.reaction-btn { border: 1px solid var(--border); background: #fff; color: var(--text); border-radius: 999px; padding: 7px 11px; min-height: 38px; box-shadow: none; font-size: 1rem; display: inline-flex; align-items: center; gap: 5px; }
.reaction-btn:hover, .reaction-btn.active { border-color: var(--primary); background: var(--primary-soft); color: var(--primary); transform: none; }
.reaction-btn span { font-weight: 700; font-size: .9rem; }
@media (max-width: 720px) { .feed-images { grid-template-columns: 1fr; } .reaction-btn { min-height: 44px; padding: 9px 13px; } }

/* Verwaltung: Versorgung per Dropdown als Markierung zuordnen */
.team-picker { display: grid; gap: 10px; margin: 8px 0 12px; }
.team-picker-row { display: grid; grid-template-columns: minmax(180px, 1fr) auto; gap: 10px; align-items: end; }
.team-chip-box { min-height: 54px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; padding: 10px; border: 1px dashed var(--border); border-radius: 16px; background: var(--card-soft); }
.team-chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 10px 8px 12px; border: 1px solid var(--primary-soft); border-radius: 999px; background: #fff; font-weight: 700; color: var(--text); box-shadow: 0 4px 12px rgba(15, 23, 42, .05); }
.team-chip button { width: 26px; height: 26px; min-height: 26px; padding: 0; border-radius: 999px; border: 1px solid var(--border); background: var(--card-soft); color: var(--muted); box-shadow: none; line-height: 1; display: inline-flex; align-items: center; justify-content: center; font-size: 18px; }
.team-chip button:hover, .team-chip button:focus { background: #fee2e2; color: #991b1b; border-color: #fecaca; transform: none; }
.team-assign-form { border-bottom: 1px solid var(--border); padding: 14px 0; }
.team-assign-form:last-child { border-bottom: 0; }
@media (max-width: 640px) {
    .team-picker-row { grid-template-columns: 1fr; }
    .team-picker-row .small-btn { width: 100%; }
    .team-chip { width: 100%; justify-content: space-between; }
}

/* Ausstehend-Center & Admin-Hinweis */
.alert-link { position: relative; background:#fff7ed; color:#9a3412; border-color:#fed7aa; }
.alert-link.has-alert { background:#ffedd5; }
.alert-count { position:absolute; top:-7px; right:-7px; min-width:20px; height:20px; padding:0 5px; border-radius:999px; background:#dc2626; color:#fff; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:900; border:2px solid #fff; }
.pending-toolbar { align-items:end; }
.pending-kpis { margin-top:16px; }
.pending-list { display:grid; gap:16px; margin-top:18px; }
.pending-card { display:grid; gap:14px; }
.pending-head { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.pending-head h2 { margin:0; }
.pending-type { background:#fff7ed; color:#9a3412; border-color:#fed7aa; }
.pending-details { display:grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap:10px; padding:12px; border:1px solid var(--border); border-radius:16px; background:#f8fafc; }
.pending-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.pending-actions input { flex:1; min-width:220px; }
.danger-btn { background:#fee2e2 !important; color:#991b1b !important; border-color:#fecaca !important; }
.secondary-btn { background:#f8fafc; color:var(--blue-dark); border:1px solid var(--border); text-decoration:none; display:inline-flex; align-items:center; justify-content:center; }

/* Feed Rich-Text Editor und robuste Bilddarstellung */
.rich-editor { border: 1px solid var(--border); border-radius: 18px; background: #fff; overflow: hidden; margin-bottom: 12px; }
.editor-toolbar { display: flex; flex-wrap: wrap; gap: 6px; padding: 10px; background: var(--card-soft); border-bottom: 1px solid var(--border); }
.editor-toolbar button, .editor-color { min-height: 36px; border: 1px solid var(--border); border-radius: 10px; background: #fff; color: var(--text); box-shadow: none; padding: 7px 10px; font-weight: 800; display: inline-flex; align-items: center; gap: 6px; }
.editor-toolbar button:hover { border-color: var(--primary); background: var(--primary-soft); transform: none; }
.editor-color input { width: 34px; min-height: 28px; height: 28px; padding: 0; border: 0; background: transparent; }
.editor-area { min-height: 190px; padding: 14px; outline: none; line-height: 1.6; }
.editor-area:empty:before { content: attr(data-placeholder); color: var(--muted); }
.feed-body { line-height: 1.65; overflow-wrap: anywhere; }
.feed-body h2, .feed-body h3 { color: var(--blue-dark); margin: 12px 0 8px; }
.feed-body blockquote { margin: 12px 0; padding: 10px 14px; border-left: 4px solid var(--primary); background: var(--card-soft); border-radius: 12px; }
.feed-body ul, .feed-body ol { padding-left: 24px; }
.feed-body a { color: var(--primary); font-weight: 800; text-decoration: underline; }
.image-upload-box { border: 1px dashed var(--border); border-radius: 16px; padding: 12px; background: var(--card-soft); margin: 6px 0 14px; }
.image-preview { margin-top: 10px; display: grid; gap: 8px; }
.image-preview img { width: 100%; max-height: 240px; object-fit: contain; border-radius: 14px; border: 1px solid var(--border); background: #fff; }
.feed-images { align-items: start; }
.feed-images a { display: block; border-radius: 16px; overflow: hidden; background: #fff; border: 1px solid var(--border); }
.feed-images img { width: 100%; max-height: 420px; object-fit: contain; border: 0; border-radius: 0; background: #fff; display: block; }
@media (max-width: 720px) { .editor-toolbar { display: grid; grid-template-columns: 1fr 1fr; } .editor-toolbar button, .editor-color { width: 100%; justify-content: center; } }

.editor-toolbar button.is-active { border-color: var(--primary); background: var(--primary); color: #fff; box-shadow: 0 8px 18px rgba(23,77,126,.18); }
.editor-toolbar button.is-active:hover { background: var(--primary); color: #fff; }
.publish-btn { min-width: 170px; }

/* Benachrichtigungs-Dropdown am Ausrufezeichen */
.alert-menu { position: relative; display: inline-flex; }
.alert-menu .alert-link { cursor: pointer; }
.alert-dropdown { display: none; position: absolute; right: 0; top: calc(100% + 10px); width: 300px; max-width: calc(100vw - 24px); background: #fff; border: 1px solid var(--border); border-radius: 18px; box-shadow: var(--shadow); padding: 10px; z-index: 50; }
.alert-menu.is-open .alert-dropdown { display: grid; gap: 6px; }
.alert-dropdown:before { content: ''; position: absolute; right: 18px; top: -8px; width: 14px; height: 14px; background: #fff; border-left: 1px solid var(--border); border-top: 1px solid var(--border); transform: rotate(45deg); }
.alert-dropdown-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 8px 10px 10px; border-bottom: 1px solid var(--border); margin-bottom: 4px; }
.alert-dropdown-head a { color: var(--primary); font-size: .88rem; font-weight: 800; text-decoration: none; }
.alert-dropdown > a:not(.alert-all) { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 12px; border-radius: 12px; text-decoration: none; color: var(--text); background: var(--card-soft); border: 1px solid transparent; }
.alert-dropdown > a:not(.alert-all):hover, .alert-dropdown > a:not(.alert-all):focus { border-color: var(--primary); background: var(--primary-soft); outline: none; }
.alert-dropdown > a b { min-width: 30px; height: 30px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--border); color: var(--primary); }
.alert-all { display: flex; align-items: center; justify-content: center; margin-top: 4px; padding: 10px 12px; border-radius: 12px; text-decoration: none; font-weight: 900; background: var(--primary); color: #fff; }
.alert-dropdown .muted { margin: 6px 10px 4px; font-size: .9rem; }
.settings-form { display: grid; gap: 12px; }
@media (max-width: 720px) { .alert-dropdown { right: -54px; width: 280px; } .alert-dropdown:before { right: 72px; } }

/* Update: Spiegel-ähnliche News, Kategorien, Autor und Profilbild */
.avatar { width: 36px; height: 36px; border-radius: 999px; object-fit: cover; display: inline-block; border: 2px solid #fff; box-shadow: 0 4px 12px rgba(15,23,42,.12); background: #fff; }
.avatar.tiny { width: 28px; height: 28px; box-shadow: none; border: 1px solid var(--border); }
.top-avatar { width: 34px; height: 34px; }
.profile-avatar { width: 96px; height: 96px; margin: 6px 0 12px; }
.profile-image-form { margin-top: 14px; display: grid; gap: 10px; padding-top: 14px; border-top: 1px solid var(--border); }
.editor-font { min-height: 36px; border: 1px solid var(--border); border-radius: 10px; background: #fff; color: var(--text); padding: 7px 10px; font-weight: 800; }
.news-feed-card { background: #101010; color: #fff; border-color: #262626; }
.news-feed-card h2 { color: #fff; }
.news-list { display: grid; gap: 18px; }
.news-card { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(220px, .9fr); gap: 22px; padding: 22px; background: #1d1b19; border: 1px solid #2c2925; border-radius: 0; align-items: stretch; }
.news-card h3 { margin: 6px 0 12px; color: #fff; font-size: clamp(1.45rem, 2.2vw, 2.2rem); line-height: 1.08; letter-spacing: -.02em; }
.news-category { color: #d6d3d1; font-size: .92rem; margin-bottom: 4px; }
.news-body { color: #f5f5f4; font-size: 1rem; max-height: 8.5em; overflow: hidden; }
.news-body h2, .news-body h3 { color: #fff; }
.news-body a { color: #93c5fd; }
.news-image { display: block; background: #000; overflow: hidden; min-height: 220px; }
.news-image img { width: 100%; height: 100%; min-height: 220px; max-height: 360px; object-fit: cover; display: block; }
.news-meta { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; color: #d6d3d1; font-size: .92rem; margin: 14px 0 8px; }
.news-card .reaction-btn { background: #27231f; color: #fff; border-color: #3b3732; }
.news-card .reaction-btn:hover, .news-card .reaction-btn.active { background: #fff7ed; color: #9a3412; }
@media (max-width: 860px) { .news-card { grid-template-columns: 1fr; padding: 16px; } .news-image { min-height: 180px; order: -1; } .news-image img { min-height: 180px; } }

/* Dashboard-News: an Spiegel-Anordnung angelehnt, aber bewusst im bestehenden Design gehalten */
.dashboard-news-card { border: 1px solid var(--border); background: var(--card); }
.dashboard-news-list { display: grid; gap: 14px; }
.dashboard-news-item { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(220px, .8fr); gap: 18px; padding: 16px; border: 1px solid var(--border); border-radius: 18px; background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,248,244,.96)); align-items: stretch; }
.dashboard-news-text { min-width: 0; display: flex; flex-direction: column; }
.dashboard-news-category { color: var(--primary); font-size: .82rem; font-weight: 800; margin-bottom: 8px; letter-spacing: .01em; }
.dashboard-news-item h3 { margin: 0 0 10px; font-size: clamp(1.25rem, 2vw, 1.85rem); line-height: 1.08; color: var(--text); letter-spacing: -.02em; }
.dashboard-news-item p { margin: 0 0 14px; color: var(--muted); font-size: .98rem; line-height: 1.5; }
.dashboard-news-meta { margin-top: auto; display: flex; align-items: center; flex-wrap: wrap; gap: 7px; color: var(--muted); font-size: .86rem; }
.dashboard-news-image { display: block; overflow: hidden; border-radius: 16px; min-height: 170px; background: var(--primary-soft); }
.dashboard-news-image img { width: 100%; height: 100%; min-height: 170px; object-fit: cover; display: block; }
@media (max-width: 860px) { .dashboard-news-item { grid-template-columns: 1fr; } .dashboard-news-image { order: -1; min-height: 190px; } .dashboard-news-image img { min-height: 190px; } }

/* Profilbild-Editor wie bei Social Media: Kreis zeigt den später sichtbaren Ausschnitt */
.profile-cropper { margin-top: 12px; display: grid; gap: 10px; }
.crop-stage { position: relative; width: min(360px, 100%); aspect-ratio: 1/1; border-radius: 18px; overflow: hidden; background: #f4f6f8; border: 1px solid var(--border); touch-action: none; }
.crop-stage canvas { width: 100%; height: 100%; display: block; cursor: move; }
.crop-shade { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at center, transparent 0 36%, rgba(0,0,0,.62) 36.4% 100%); box-shadow: inset 0 0 0 9999px rgba(0,0,0,.04); }
.crop-shade::after { content: ''; position: absolute; left: 14%; top: 14%; width: 72%; height: 72%; border-radius: 50%; border: 2px solid rgba(255,255,255,.92); box-shadow: 0 0 0 1px rgba(0,0,0,.25); }
.crop-controls { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.crop-controls label { display: inline-flex; gap: 8px; align-items: center; margin: 0; color: var(--muted); }
.crop-controls input[type=range] { width: 150px; }

/* Update: Profilbild-Popup und Feed-Layout */
.modal-open { overflow: hidden; }
.modal-backdrop { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 18px; background: rgba(15,23,42,.55); backdrop-filter: blur(6px); }
.modal-backdrop[hidden] { display: none !important; }
.modal-card { width: min(760px, 96vw); max-height: 92vh; overflow: auto; background: var(--card); color: var(--text); border: 1px solid var(--border); border-radius: 24px; box-shadow: 0 24px 80px rgba(15,23,42,.28); padding: 22px; }
.modal-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
.modal-head h2 { margin: 0; }
.modal-close { width: 38px; height: 38px; border-radius: 999px; border: 1px solid var(--border); background: #fff; color: var(--text); font-size: 1.4rem; line-height: 1; cursor: pointer; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.profile-crop-modal { width: min(620px, 96vw); }
.profile-crop-modal .crop-stage { width: min(420px, 100%); margin: 0 auto; border-radius: 20px; }
.crop-shade { background: radial-gradient(circle at center, transparent 0 var(--profile-crop-radius, 151px), rgba(0,0,0,.68) calc(var(--profile-crop-radius, 151px) + 1px) 100%); box-shadow: none; }
.crop-shade::after { content: ''; display: block; position: absolute; left: calc(50% - var(--profile-crop-radius, 151px)); top: calc(50% - var(--profile-crop-radius, 151px)); width: calc(var(--profile-crop-radius, 151px) * 2); height: calc(var(--profile-crop-radius, 151px) * 2); border-radius: 50%; border: 2px solid rgba(255,255,255,.96); box-shadow: 0 0 0 1px rgba(0,0,0,.28); }
.crop-controls input[type=range] { width: 220px; }

.feed-hero { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.primary-btn { background: var(--primary); color: #fff; border-color: var(--primary); }
.feed-layout { display: grid; gap: 18px; }
.news-lead-card, .news-history-card { background: var(--card); border: 1px solid var(--border); border-radius: 24px; box-shadow: var(--shadow); overflow: hidden; }
.news-lead-card { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); align-items: stretch; }
.news-lead-image { min-height: 310px; background: var(--primary-soft); display: block; }
.news-lead-image img { width: 100%; height: 100%; min-height: 310px; object-fit: contain; display: block; background: var(--primary-soft); }
.news-lead-content { padding: clamp(18px, 3vw, 32px); }
.news-lead-content h2 { font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1.05; margin: 6px 0 12px; color: var(--text); letter-spacing: -.03em; }
.news-category { color: var(--primary); font-weight: 800; font-size: .85rem; letter-spacing: .04em; text-transform: uppercase; }
.news-body-full { color: var(--text); font-size: 1.02rem; line-height: 1.65; margin-top: 16px; }
.news-body-full a, .news-history-text a { color: var(--primary); font-weight: 700; }
.news-meta { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; color: var(--muted); font-size: .9rem; margin: 12px 0; }
.news-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-top: 18px; }
.news-actions.compact { margin-top: 10px; }
.news-history-card { padding: 20px; }
.news-history-list { display: grid; gap: 14px; }
.news-history-item { display: grid; grid-template-columns: 180px minmax(0, 1fr); gap: 16px; padding: 14px; border: 1px solid var(--border); border-radius: 18px; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,248,244,.98)); }
.news-history-thumb { border-radius: 14px; overflow: hidden; background: var(--primary-soft); display: block; min-height: 118px; }
.news-history-thumb img { width: 100%; height: 100%; min-height: 118px; object-fit: contain; display: block; }
.news-history-text h3 { margin: 4px 0 8px; font-size: 1.2rem; color: var(--text); }
.news-history-text p { margin: 0 0 8px; color: var(--muted); line-height: 1.45; }
.news-modal-card { width: min(880px, 96vw); }
.reaction-row { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.reaction-form { margin: 0; }
.reaction-btn { border: 1px solid var(--border); background: #fff; color: var(--text); border-radius: 999px; padding: 7px 10px; cursor: pointer; }
.reaction-btn.active, .reaction-btn:hover { background: var(--primary-soft); border-color: var(--primary); color: var(--primary); }
.editor-toolbar button.is-active { background: var(--primary); color: #fff; border-color: var(--primary); }
.dashboard-news-list { gap: 10px; }
.dashboard-news-item { grid-template-columns: minmax(0, 1fr) 150px; gap: 12px; padding: 12px; border-radius: 16px; }
.dashboard-news-item h3 { font-size: clamp(1.05rem, 1.6vw, 1.35rem); margin-bottom: 6px; }
.dashboard-news-item p { font-size: .9rem; line-height: 1.4; margin-bottom: 10px; }
.dashboard-news-image { min-height: 108px; border-radius: 12px; }
.dashboard-news-image img { min-height: 108px; object-fit: contain; background: var(--primary-soft); }
.dashboard-readmore { margin-top: 10px; align-self: flex-start; }
@media (max-width: 860px) {
  .feed-hero { align-items: flex-start; flex-direction: column; }
  .news-lead-card { grid-template-columns: 1fr; }
  .news-lead-image { min-height: 220px; }
  .news-lead-image img { min-height: 220px; }
  .news-history-item { grid-template-columns: 1fr; }
  .dashboard-news-item { grid-template-columns: 1fr; }
  .dashboard-news-image { order: -1; min-height: 130px; }
  .dashboard-news-image img { min-height: 130px; }
}

/* Feed Update: aktuelle News groß, Verlauf rechts, Dashboard kleiner */
.feed-page-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px;align-items:start}
.feed-main-news{padding:28px;border-radius:24px;overflow:hidden}
.feed-main-news h2{font-size:clamp(2rem,4vw,3.3rem);line-height:1.05;margin:8px 0 12px;color:#133b5c}
.news-body-full{font-size:1.06rem;line-height:1.75;color:#1f2d3d}
.news-body-full img{max-width:100%;height:auto;border-radius:18px;display:block;margin:14px 0}
.news-body-full.feed-body{position:relative;min-height:0;overflow:visible}
.news-body-full.feed-body figure.news-inline-image img{margin:0;border-radius:inherit}
.news-inline-image{margin:18px 0}.news-inline-image figcaption{font-size:.85rem;color:#667;margin-top:6px}
.news-history-card{position:sticky;top:90px}.news-history-list{display:grid;gap:10px}.news-history-link{display:block;padding:14px;border-radius:18px;text-decoration:none;color:inherit;background:#f7fafc;border:1px solid rgba(23,77,126,.08)}.news-history-link:hover{background:#eef6fb;transform:translateY(-1px)}.news-history-link strong{display:block;color:#143d5d;margin:4px 0}.news-history-link small{color:#64748b}.news-history-link p{margin:6px 0 0;color:#475569;font-size:.92rem}.news-category{display:inline-flex;align-items:center;border-radius:999px;background:#e7f2f8;color:#174d7e;padding:5px 10px;font-size:.8rem;font-weight:700}.news-meta{display:flex;align-items:center;gap:8px;color:#64748b;font-size:.9rem;margin:10px 0 18px}.news-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:20px}.reaction-row{display:flex;gap:6px;flex-wrap:wrap}.reaction-form{display:inline}.reaction-btn{border:1px solid rgba(23,77,126,.14);background:#fff;border-radius:999px;padding:7px 10px;cursor:pointer}.reaction-btn.active{background:#174d7e;color:#fff}.news-modal-card{max-width:980px;width:min(96vw,980px);max-height:min(92vh,100dvh);overflow:auto}.editor-preview-box{margin:18px 0;padding:14px;border:1px dashed rgba(23,77,126,.25);border-radius:18px;background:#fbfdff}.preview-canvas{background:#fff;border-radius:14px;padding:14px;min-height:80px}.rich-editor .editor-toolbar-shell{background:#f3f7fa;border:1px solid rgba(23,77,126,.12);border-bottom:1px solid rgba(23,77,126,.12);border-radius:16px 16px 0 0}.rich-editor .editor-toolbar-shell .editor-toolbar{display:flex;flex-wrap:wrap;gap:8px;padding:8px 10px 10px;background:transparent}.rich-editor .editor-toolbar-shell .editor-toolbar button,.rich-editor .editor-toolbar-shell .editor-toolbar select,.rich-editor .editor-toolbar-shell .editor-color{border:1px solid rgba(23,77,126,.15);background:#fff;border-radius:10px;padding:7px 9px;cursor:pointer}.rich-editor .editor-area{min-height:260px;padding:16px;border:1px solid rgba(23,77,126,.12);border-top:0;border-radius:0 0 16px 16px;background:#fff;outline:none}.rich-editor .editor-area:empty:before{content:attr(data-placeholder);color:#94a3b8}.image-preview{margin-top:10px;display:flex;gap:10px;align-items:center}.image-preview img{width:120px;height:68px;object-fit:cover;border-radius:12px}.dashboard-news-card{max-width:100%}.dashboard-news-item{padding:14px;border-radius:18px}.dashboard-news-item h3{font-size:1.05rem}.dashboard-news-item p{font-size:.92rem}.dashboard-news-image img{max-height:110px;object-fit:cover;border-radius:14px}.dashboard-readmore{margin-top:8px}
@media(max-width:900px){.feed-page-grid{grid-template-columns:1fr}.news-history-card{position:static}.feed-main-news{padding:18px}}

/* Feed Fix: News erstellen, Upload, Kommentare */
#openNewsModal{position:relative;z-index:5;pointer-events:auto}.modal-open{overflow:hidden}.news-comments{margin-top:26px;border-top:1px solid rgba(23,77,126,.12);padding-top:18px}.news-comments h3{margin:0 0 12px;color:#143d5d}.comment-form{display:grid;gap:10px;margin:10px 0 16px}.comment-form textarea{width:100%;border:1px solid rgba(23,77,126,.16);border-radius:16px;padding:12px;resize:vertical;background:#fff}.comment-card{display:flex;gap:12px;padding:14px;border:1px solid rgba(23,77,126,.10);border-radius:18px;background:#fbfdff;margin:10px 0}.comment-avatar{width:38px;height:38px;object-fit:cover;border-radius:50%;flex:0 0 auto}.comment-main{flex:1;min-width:0}.comment-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:#64748b;font-size:.9rem}.comment-meta strong{color:#153d5c}.comment-main p{margin:7px 0 10px;white-space:normal}.comment-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.comment-like-form{display:inline}.comment-like-btn{border:1px solid rgba(23,77,126,.14);background:#fff;border-radius:999px;padding:5px 9px;cursor:pointer}.comment-like-btn.active{background:#174d7e;color:#fff}.link-btn{border:0;background:transparent;color:#174d7e;font-weight:700;cursor:pointer;padding:4px 0}.reply-area{margin-top:10px;padding-left:14px;border-left:3px solid rgba(23,77,126,.12)}.reply-card{background:#fff;margin-top:10px}.comments-off{margin-top:20px}.news-inline-image img,.feed-body img{max-width:100%;height:auto;object-fit:contain;border-radius:18px}.news-inline-image{margin:18px 0}.news-inline-image figcaption{color:#64748b;font-size:.9rem;margin-top:6px}.news-modal-card{z-index:10000}.modal-backdrop{z-index:9999}

/* Update: Dashboard News Slider + Feed Bildeditor */
.dashboard-news-slider-card .dashboard-news-slider{position:relative;min-height:250px}.dashboard-news-slide{display:none;grid-template-columns:minmax(230px,.9fr) minmax(0,1.1fr);gap:18px;align-items:stretch;padding:16px;border:1px solid var(--border);border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(250,248,244,.98));}.dashboard-news-slide.active{display:grid}.dashboard-news-slide .dashboard-news-image{order:0;min-height:190px;height:100%;border-radius:18px;background:var(--primary-soft)}.dashboard-news-slide .dashboard-news-image img{width:100%;height:100%;min-height:190px;object-fit:cover;display:block}.dashboard-news-slide .dashboard-news-text{padding:2px 0}.dashboard-news-slide h3{font-size:clamp(1.25rem,2vw,1.75rem);line-height:1.12}.dashboard-news-dots{display:flex;justify-content:center;gap:8px;margin-top:14px}.dashboard-news-dot{width:10px;height:10px;border-radius:999px;border:0;background:rgba(23,77,126,.25);cursor:pointer;padding:0}.dashboard-news-dot.active{width:26px;background:var(--primary)}@media(max-width:760px){.dashboard-news-slide{grid-template-columns:1fr}.dashboard-news-slide .dashboard-news-image{min-height:180px}.dashboard-news-slide .dashboard-news-image img{min-height:180px}}
.image-tool-group{display:inline-flex;gap:6px;flex-wrap:wrap;padding:6px;border-radius:12px;background:rgba(23,77,126,.08);align-items:center}.image-tool-group[hidden]{display:none!important}.rich-editor .editor-area figure.editable-image{border:1px dashed rgba(23,77,126,.28);padding:8px;background:#fff;border-radius:18px;box-sizing:border-box}.rich-editor .editor-area figure.editable-image.selected{outline:3px solid rgba(23,77,126,.25);box-shadow:0 0 0 5px rgba(23,77,126,.08)}.rich-editor .editor-area figure.editable-image.has-shadow img{box-shadow:0 18px 38px rgba(15,23,42,.22)}.rich-editor .editor-area figure.editable-image.more-rounded img{border-radius:30px!important}.rich-editor .editor-area figure.editable-image figcaption{font-size:.85rem;color:#64748b;margin-top:7px;outline:none}.feed-body:not(.news-body-full) figure.news-inline-image{max-width:100%;}.feed-body:not(.news-body-full) figure.news-inline-image img{max-width:100%;height:auto}.mini-success{font-size:.88rem;padding:8px 10px;margin:4px 0 0;border-radius:12px}.comment-form .primary-btn,.comment-form button{background:var(--primary);color:#fff;border:0;border-radius:14px;box-shadow:0 8px 20px rgba(23,77,126,.18)}.comment-card{background:linear-gradient(180deg,#fff,#f8fbfd);box-shadow:0 8px 24px rgba(15,23,42,.04)}.comment-like-btn{background:#f4f8fb}.comment-like-btn.active{background:var(--primary);color:#fff}


/* Final dashboard/feed fixes */
.dashboard-news-slider-card .dashboard-news-slider{min-height:230px!important}
.dashboard-news-slide{grid-template-columns:minmax(0,1.08fr) minmax(220px,.92fr)!important;align-items:stretch!important;min-height:210px!important}
.dashboard-news-slide .dashboard-news-text{order:0!important;min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:10px 0!important}
.dashboard-news-slide .dashboard-news-image{order:1!important;height:auto!important;min-height:210px!important;display:flex!important;align-items:center!important;justify-content:center!important;background:linear-gradient(135deg,rgba(23,77,126,.08),rgba(255,255,255,.75))!important}
.dashboard-news-slide .dashboard-news-image img{width:100%!important;height:100%!important;min-height:210px!important;object-fit:contain!important;display:block!important;background:transparent!important}
@media(max-width:760px){.dashboard-news-slide{grid-template-columns:1fr!important}.dashboard-news-slide .dashboard-news-image{order:0!important;min-height:180px!important}.dashboard-news-slide .dashboard-news-image img{min-height:180px!important}.dashboard-news-slide .dashboard-news-text{order:1!important}}
.rich-editor .editor-area figure.editable-image{transition:box-shadow .18s ease, outline-color .18s ease; user-select:none; touch-action:none; will-change:transform,width; resize:horizontal!important; overflow:visible!important}
.rich-editor .editor-area figure.editable-image img{pointer-events:none; user-select:none}
.rich-editor .editor-area figure.editable-image figcaption{pointer-events:auto; user-select:text}
.rich-editor .editor-area figure.editable-image.selected{outline:3px solid rgba(23,77,126,.35); box-shadow:0 18px 44px rgba(15,23,42,.12)}


/* Image editor restore + dashboard auto-slider polish */
.image-tool-group{display:inline-flex!important;align-items:center;gap:6px;flex-wrap:wrap;background:rgba(23,77,126,.08);border:1px solid rgba(23,77,126,.12);border-radius:12px;padding:4px}
.image-tool-group[hidden]{display:none!important}
.news-inline-image{position:relative;display:block;transition:box-shadow .15s ease, outline-color .15s ease;user-select:none}
.news-inline-image.is-selected{outline:2px solid var(--primary);outline-offset:5px;box-shadow:0 12px 30px rgba(23,77,126,.18)}
.news-inline-image img{pointer-events:none;display:block;width:100%;height:auto;border-radius:inherit}
.news-inline-image.has-shadow img{box-shadow:0 16px 36px rgba(15,23,42,.22)}
.news-inline-image.more-rounded img{border-radius:28px!important}
.news-body-full .news-inline-image{max-width:100%}
.dashboard-news-slider-card .dashboard-news-slide{transition:opacity .25s ease}


/* Dashboard News: weicher dynamischer Übergang statt hartem Umschalten */
.dashboard-news-slider-card .dashboard-news-slider{
  position:relative!important;
  overflow:hidden!important;
  min-height:240px!important;
}
.dashboard-news-slider-card .dashboard-news-slide{
  display:grid!important;
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
  transform:translateY(14px) scale(.985)!important;
  filter:blur(2px)!important;
  transition:opacity .65s ease, transform .65s cubic-bezier(.2,.8,.2,1), filter .65s ease, visibility .65s ease!important;
  will-change:opacity, transform, filter;
}
.dashboard-news-slider-card .dashboard-news-slide.active{
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  transform:translateY(0) scale(1)!important;
  filter:blur(0)!important;
  z-index:2!important;
}
.dashboard-news-slider-card .dashboard-news-slide.leaving{
  opacity:0!important;
  visibility:visible!important;
  transform:translateY(-12px) scale(.985)!important;
  filter:blur(2px)!important;
  z-index:1!important;
}
.dashboard-news-slider-card .dashboard-news-slide.entering{
  animation:dashboardNewsSoftIn .72s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes dashboardNewsSoftIn{
  0%{opacity:0;transform:translateY(18px) scale(.985);filter:blur(3px)}
  55%{opacity:1;filter:blur(.5px)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
.dashboard-news-dot{transition:width .25s ease, background .25s ease, transform .25s ease!important}
.dashboard-news-dot.active{transform:scale(1.04)}

/* News editor: absolute image canvas, undo/redo, selectable existing images */
.rich-editor .editor-area{position:relative;min-height:360px;overflow:auto;}
.rich-editor .editor-area figure.news-inline-image{position:absolute;margin:0!important;max-width:95%;z-index:2;}
.feed-body:not(.news-body-full){position:relative;min-height:360px;overflow:hidden;}
.feed-body:not(.news-body-full) figure.news-inline-image{position:absolute;margin:0!important;max-width:95%;}
.image-tool-group button,[data-editor-undo],[data-editor-redo]{background:#eef5f9;border:1px solid rgba(23,77,126,.18);border-radius:10px;padding:7px 10px;color:#174d7e;font-weight:700;cursor:pointer;}
.image-tool-group button:hover,[data-editor-undo]:hover,[data-editor-redo]:hover{background:#dfeef6;}
.rich-editor .editor-area figure.news-inline-image.is-selected{outline:3px solid rgba(23,77,126,.45);outline-offset:5px;box-shadow:0 18px 44px rgba(15,23,42,.16);}


/* Final dashboard/news editor fixes */
.dashboard-news-slider-card .dashboard-news-slide{
  filter:none!important;
  transition:opacity .38s ease, transform .38s ease, visibility .38s ease!important;
  transform:translateY(10px)!important;
}
.dashboard-news-slider-card .dashboard-news-slide.active{
  filter:none!important;
  opacity:1!important;
  transform:translateY(0)!important;
  visibility:visible!important;
  pointer-events:auto!important;
}
.dashboard-news-slider-card .dashboard-news-slide.leaving{
  filter:none!important;
  opacity:0!important;
  transform:translateY(-8px)!important;
  visibility:visible!important;
}
.dashboard-news-slider-card .dashboard-news-slide.entering{animation:none!important;}
@keyframes dashboardNewsSoftIn{0%{opacity:0;transform:translateY(10px)}100%{opacity:1;transform:translateY(0)}}
.rich-editor .editor-area{position:relative;}
.rich-editor .editor-area figure.news-inline-image,
.rich-editor .editor-area figure.editable-image{
  position:absolute;
  margin:0!important;
  max-width:90%;
  z-index:2;
  cursor:grab;
  touch-action:none;
  user-select:none;
  border:1px dashed rgba(23,77,126,.28);
  padding:8px;
  background:#fff;
  border-radius:18px;
  box-sizing:border-box;
}
.rich-editor .editor-area figure.news-inline-image.is-selected,
.rich-editor .editor-area figure.editable-image.is-selected{
  outline:3px solid rgba(23,77,126,.45)!important;
  outline-offset:5px;
  box-shadow:0 18px 44px rgba(15,23,42,.16)!important;
}
.rich-editor .editor-area figure.news-inline-image img,
.rich-editor .editor-area figure.editable-image img{pointer-events:none;user-select:none;width:100%;height:auto;display:block;}
.feed-body:not(.news-body-full){position:relative;min-height:260px;}
.feed-body:not(.news-body-full) figure.news-inline-image{position:absolute;margin:0!important;max-width:90%;}
.feed-body:not(.news-body-full) figure.news-inline-image img{width:100%;height:auto;display:block;}


/* Feed-Kommentare: schöner und besser lesbar */
.news-comments{background:linear-gradient(180deg,#ffffff,#f7fbff);border:1px solid rgba(23,77,126,.10);border-radius:24px;padding:20px;margin-top:28px;box-shadow:0 14px 34px rgba(15,23,42,.06)}
.news-comments h3{font-size:1.35rem;margin-bottom:14px;color:#143d5d;display:flex;align-items:center;gap:8px}.news-comments h3:before{content:'💬';font-size:1.1rem}
.comment-form{background:#fff;border:1px solid rgba(23,77,126,.10);border-radius:20px;padding:14px;box-shadow:0 8px 22px rgba(15,23,42,.04)}
.comment-form textarea{background:#f9fcff;border:1px solid rgba(23,77,126,.18);border-radius:18px;transition:border-color .15s ease,box-shadow .15s ease}.comment-form textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 4px rgba(23,77,126,.10)}
.comment-form .primary-btn,.comment-form button{justify-self:end;background:linear-gradient(135deg,var(--primary),#0f3554);color:#fff;border:0;border-radius:999px;padding:10px 18px;font-weight:800;box-shadow:0 10px 22px rgba(23,77,126,.22)}
.comment-card{border:1px solid rgba(23,77,126,.10);background:#fff;border-radius:22px;padding:14px 16px;box-shadow:0 10px 26px rgba(15,23,42,.055)}
.reply-card{background:#f8fbfe;border-style:solid;margin-left:8px}.comment-avatar{box-shadow:0 0 0 3px #fff,0 4px 12px rgba(15,23,42,.12)}
.comment-meta{font-size:.86rem;color:#64748b}.comment-meta strong{font-size:.96rem;color:#123d5c}.comment-main p{line-height:1.55;color:#223548}
.comment-actions{gap:8px;margin-top:8px}.comment-like-btn,.reply-toggle{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(23,77,126,.14);background:#eef5fb;color:#174d7e;border-radius:999px;padding:7px 12px;font-weight:800;line-height:1;cursor:pointer;transition:transform .12s ease,background .12s ease,color .12s ease,border-color .12s ease}.comment-like-btn:hover,.reply-toggle:hover{transform:translateY(-1px);background:#e3eef8}.comment-like-btn span{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:#fff;color:#174d7e;font-size:.78rem;font-weight:900;padding:0 6px;box-shadow:inset 0 0 0 1px rgba(23,77,126,.08)}.comment-like-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.comment-like-btn.active span{background:#fff;color:var(--primary)}
.reply-toggle{border:0;background:transparent;color:#174d7e;padding:7px 10px}.reply-toggle:before{content:'↩';font-weight:900}.reply-area{border-left:3px solid rgba(23,77,126,.18);padding-left:16px;margin-top:12px}.mini-success{background:#e9f8ef;color:#17623c;border:1px solid rgba(23,100,60,.14)}
.current-preview-hint{margin-top:8px!important;padding:8px 10px;border-radius:12px;background:#f0f7fd;border:1px solid rgba(23,77,126,.10)}
.image-preview{display:flex;align-items:center;gap:12px;border:1px solid rgba(23,77,126,.10);border-radius:16px;padding:10px;background:#fff}.image-preview img{width:120px;height:68px;object-fit:contain;border-radius:12px;background:#f4f7fb}.image-preview span{color:#38556c;font-weight:700;font-size:.9rem}

/* Finaler Kommentar-Fix: dezente Buttons, sichtbare Likes, kleinere Antworten */
.news-comments{background:linear-gradient(180deg,#ffffff,#f8fbfd);border:1px solid rgba(23,77,126,.08);border-radius:24px;padding:20px;margin-top:28px;box-shadow:0 14px 34px rgba(15,23,42,.05)}
.news-comments h3{font-size:1.15rem;margin-bottom:14px}.comment-form{background:#fff;border:1px solid rgba(23,77,126,.10);border-radius:18px;padding:12px;box-shadow:0 8px 22px rgba(15,23,42,.035)}
.comment-form textarea{min-height:82px;line-height:1.45}.reply-form{padding:10px;margin-top:10px;border-radius:16px;background:#f8fbfe}.reply-form textarea{min-height:58px;font-size:.92rem}
.comment-form button,.comment-form .primary-btn,.reply-form button{background:linear-gradient(135deg,var(--primary),#0f3554)!important;color:#fff!important;border:0!important;border-radius:999px!important;padding:9px 16px!important;font-weight:800!important;box-shadow:0 8px 18px rgba(23,77,126,.18)!important;justify-self:end}.reply-form button{font-size:.88rem;padding:8px 14px!important}
.comment-card{position:relative;border-radius:20px;background:#fff;border:1px solid rgba(23,77,126,.10);box-shadow:0 9px 24px rgba(15,23,42,.045)}.comment-card.reply-card{transform:scale(.98);transform-origin:top left;background:#f7fbff;border-radius:16px;padding:10px 12px;margin:8px 0 8px 4px;box-shadow:0 5px 14px rgba(15,23,42,.035)}
.reply-card .comment-avatar{width:30px;height:30px}.reply-card .comment-meta{font-size:.78rem}.reply-card .comment-meta strong{font-size:.86rem}.reply-card .comment-main p{font-size:.9rem;line-height:1.45;margin:5px 0 8px}.reply-area{border-left:2px solid rgba(23,77,126,.12);padding-left:12px;margin-top:10px}
.comment-actions{gap:6px}.comment-like-form,.comment-delete-form{display:inline-flex;margin:0}.comment-like-btn,.reply-toggle,.comment-delete-btn{display:inline-flex;align-items:center;gap:5px;border:1px solid rgba(23,77,126,.13)!important;background:#f4f8fb!important;color:#174d7e!important;border-radius:999px!important;padding:5px 9px!important;font-size:.82rem!important;font-weight:750!important;line-height:1!important;box-shadow:none!important;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease,transform .12s ease}.comment-like-btn:hover,.reply-toggle:hover,.comment-delete-btn:hover{background:#e9f2fa!important;transform:translateY(-1px)}
.comment-like-btn{padding:4px 8px!important;min-width:auto}.comment-like-btn span{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#dbeafe!important;color:#174d7e!important;font-size:.72rem;font-weight:900;box-shadow:none!important}.comment-like-btn.active{background:#eaf3fb!important;color:#174d7e!important;border-color:rgba(23,77,126,.22)!important}.comment-like-btn.active span{background:#174d7e!important;color:#fff!important}.comment-delete-btn{color:#9f1239!important;background:#fff5f7!important;border-color:rgba(159,18,57,.12)!important}.comment-delete-btn:hover{background:#ffe4e9!important}

/* Kommentar-Buttons Finalfix */
.news-comments .comment-form button,
.news-comments .comment-form .primary-btn,
.news-comments .reply-form button{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:auto!important;
  justify-self:end!important;
  border:1px solid rgba(23,77,126,.13)!important;
  background:#f4f8fb!important;
  color:#174d7e!important;
  border-radius:999px!important;
  padding:6px 12px!important;
  font-size:.84rem!important;
  font-weight:800!important;
  line-height:1!important;
  box-shadow:none!important;
  cursor:pointer!important;
}
.news-comments .comment-form button:hover,
.news-comments .comment-form .primary-btn:hover,
.news-comments .reply-form button:hover{
  background:#e9f2fa!important;
  transform:translateY(-1px)!important;
}
.news-comments .comment-like-btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:4px!important;
  width:auto!important;
  min-width:0!important;
  height:auto!important;
  border:1px solid rgba(23,77,126,.12)!important;
  background:#ffffff!important;
  color:#174d7e!important;
  border-radius:999px!important;
  padding:4px 7px!important;
  font-size:.78rem!important;
  font-weight:800!important;
  line-height:1!important;
  box-shadow:none!important;
  cursor:pointer!important;
}
.news-comments .comment-like-btn:hover{
  background:#eef5fb!important;
  transform:translateY(-1px)!important;
}
.news-comments .comment-like-btn.active{
  background:#e8f2fb!important;
  color:#174d7e!important;
  border-color:rgba(23,77,126,.22)!important;
}
.news-comments .comment-like-btn span,
.news-comments .comment-like-btn.active span{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:16px!important;
  height:16px!important;
  padding:0 4px!important;
  border-radius:999px!important;
  background:#174d7e!important;
  color:#ffffff!important;
  font-size:.68rem!important;
  font-weight:900!important;
  line-height:1!important;
  box-shadow:none!important;
}
.news-comments .comment-delete-btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:auto!important;
  min-width:0!important;
  border:1px solid rgba(159,18,57,.12)!important;
  background:#fff5f7!important;
  color:#9f1239!important;
  border-radius:999px!important;
  padding:3px 7px!important;
  font-size:.72rem!important;
  font-weight:750!important;
  line-height:1!important;
  box-shadow:none!important;
  cursor:pointer!important;
}
.news-comments .comment-delete-btn:hover{background:#ffe4e9!important;transform:translateY(-1px)!important;}
.news-comments .comment-actions{gap:5px!important;}
.news-comments .reply-card .comment-like-btn{font-size:.72rem!important;padding:3px 6px!important;}
.news-comments .reply-card .comment-delete-btn{font-size:.68rem!important;padding:2px 6px!important;}


/* Feed image layout final fix: images reserve space instead of covering text */
.rich-editor .editor-area figure.news-inline-image,
.rich-editor .editor-area figure.editable-image,
.feed-body:not(.news-body-full) figure.news-inline-image{
  position:relative!important;
  left:auto!important;
  top:auto!important;
  display:block!important;
  max-width:90%!important;
  z-index:auto!important;
}
.feed-body{
  position:relative;
  overflow:visible;
}
.feed-body:not(.news-body-full) figure.news-inline-image{
  margin-bottom:18px!important;
  clear:both;
}
.feed-body:not(.news-body-full) figure.news-inline-image img,
.rich-editor .editor-area figure.news-inline-image img,
.rich-editor .editor-area figure.editable-image img{
  width:100%!important;
  height:auto!important;
  display:block!important;
  object-fit:contain!important;
}
.rich-editor .editor-area{
  overflow:auto;
}

/* Final dashboard/news refinements */
.dashboard-news-slider-card{
  padding:22px!important;
  border-radius:26px!important;
  box-shadow:0 18px 42px rgba(15,23,42,.07)!important;
}
.dashboard-news-slider-card .dashboard-news-slider{min-height:250px!important;}
.dashboard-news-slider-card .dashboard-news-slide{min-height:235px!important;gap:24px!important;}
.dashboard-news-slider-card .dashboard-news-text h3{font-size:1.45rem!important;line-height:1.18!important;margin-bottom:10px!important;}
.dashboard-news-slider-card .dashboard-news-text p{font-size:1rem!important;line-height:1.5!important;}
.dashboard-news-slider-card .dashboard-news-image{min-height:230px!important;border-radius:22px!important;overflow:hidden!important;}
.dashboard-news-slider-card .dashboard-news-image img{min-height:230px!important;object-fit:contain!important;}
.dashboard-news-dot{height:9px!important;width:9px!important;opacity:.75!important;}
.dashboard-news-dot.active{width:30px!important;opacity:1!important;}

/* Final editor image behaviour: movable block images that keep document flow */
.rich-editor .editor-area{
  position:relative!important;
  overflow:auto!important;
  min-height:390px!important;
}
.rich-editor .editor-area figure.news-inline-image,
.rich-editor .editor-area figure.editable-image{
  position:relative!important;
  left:auto!important;
  top:auto!important;
  display:block!important;
  max-width:90%!important;
  z-index:2!important;
  cursor:grab!important;
  user-select:none!important;
  touch-action:none!important;
}
.rich-editor .editor-area figure.news-inline-image:active,
.rich-editor .editor-area figure.editable-image:active{cursor:grabbing!important;}
.rich-editor .editor-area figure.news-inline-image img,
.rich-editor .editor-area figure.editable-image img{pointer-events:none!important;user-select:none!important;}
.feed-body:not(.news-body-full) figure.news-inline-image{
  position:relative!important;
  left:auto!important;
  top:auto!important;
  display:block!important;
  clear:both!important;
  max-width:90%!important;
  z-index:auto!important;
}

/* Fix: News-Bilder im Editor wieder sauber frei bewegbar */
.rich-editor .editor-area figure.news-inline-image,
.rich-editor .editor-area figure.editable-image {
  cursor: grab;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  position: relative;
}
.rich-editor .editor-area figure.news-inline-image:active,
.rich-editor .editor-area figure.editable-image:active { cursor: grabbing; }
.rich-editor .editor-area figure.news-inline-image img,
.rich-editor .editor-area figure.editable-image img {
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}
.news-body figure.news-inline-image,
.news-body figure.editable-image {
  display: block;
  position: relative;
}

/* Final fix: News-Bilder im Bearbeiten-Modus zuverlässig per Maus/Finger bewegbar */
.rich-editor .editor-area figure.news-inline-image,
.rich-editor .editor-area figure.editable-image{
  position:relative!important;
  left:auto!important;
  top:auto!important;
  display:block!important;
  cursor:grab!important;
  touch-action:none!important;
  user-select:none!important;
  -webkit-user-select:none!important;
  pointer-events:auto!important;
  max-width:90%!important;
}
.rich-editor .editor-area figure.news-inline-image:active,
.rich-editor .editor-area figure.editable-image:active{cursor:grabbing!important;}
.rich-editor .editor-area figure.news-inline-image img,
.rich-editor .editor-area figure.editable-image img{
  pointer-events:none!important;
  user-select:none!important;
  -webkit-user-drag:none!important;
  width:100%!important;
  height:auto!important;
  display:block!important;
}

/* Dashboard News Highlight Update */
.dashboard-news-slider-card{
  padding:26px!important;
  border-radius:30px!important;
  background:linear-gradient(135deg,#ffffff 0%,#f7fbfd 52%,#eef6fb 100%)!important;
  border:1px solid rgba(23,77,126,.12)!important;
  box-shadow:0 24px 55px rgba(15,23,42,.10)!important;
  position:relative;
  overflow:hidden;
}
.dashboard-news-slider-card:before{
  content:'';
  position:absolute;
  inset:-90px auto auto -90px;
  width:210px;
  height:210px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(23,77,126,.16),rgba(23,77,126,0) 68%);
  pointer-events:none;
}
.dashboard-news-slider-card .section-head{
  position:relative;
  z-index:2;
  margin-bottom:16px!important;
}
.dashboard-news-slider-card .section-head h2{
  font-size:1.55rem!important;
  letter-spacing:-.02em;
  color:#123d5c!important;
}
.dashboard-news-slider-card .section-head p{
  font-size:.98rem!important;
}
.dashboard-news-slider-card .dashboard-news-slider{
  min-height:315px!important;
}
.dashboard-news-slider-card .dashboard-news-slide{
  min-height:300px!important;
  grid-template-columns:minmax(0,1.06fr) minmax(300px,.94fr)!important;
  gap:26px!important;
  padding:26px!important;
  border-radius:28px!important;
  background:linear-gradient(135deg,#ffffff 0%,#fbf8f2 100%)!important;
  border:1px solid rgba(23,77,126,.12)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75),0 16px 35px rgba(15,23,42,.075)!important;
}
.dashboard-news-slider-card .dashboard-news-text{
  padding:8px 4px!important;
  gap:10px;
}
.dashboard-news-slider-card .dashboard-news-category{
  width:max-content;
  background:rgba(23,77,126,.10)!important;
  color:#174d7e!important;
  border:1px solid rgba(23,77,126,.10);
  border-radius:999px;
  padding:7px 12px;
  font-weight:900;
  font-size:.78rem;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.dashboard-news-slider-card .dashboard-news-slide h3{
  font-size:clamp(1.65rem,3vw,2.35rem)!important;
  line-height:1.03!important;
  margin:4px 0 8px!important;
  color:#102f48!important;
  letter-spacing:-.035em;
}
.dashboard-news-slider-card .dashboard-news-slide p{
  font-size:1.05rem!important;
  line-height:1.55!important;
  color:#38556c!important;
  max-width:68ch;
}
.dashboard-news-slider-card .dashboard-news-meta{
  margin-top:4px;
  color:#60758a!important;
  font-size:.92rem!important;
}
.dashboard-news-slider-card .dashboard-readmore{
  width:max-content;
  margin-top:14px!important;
  padding:10px 16px!important;
  border-radius:999px!important;
  background:linear-gradient(135deg,var(--primary),#0f3554)!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 10px 22px rgba(23,77,126,.22)!important;
}
.dashboard-news-slider-card .dashboard-news-image{
  min-height:260px!important;
  border-radius:26px!important;
  overflow:hidden!important;
  background:linear-gradient(135deg,rgba(23,77,126,.08),rgba(255,255,255,.6))!important;
  box-shadow:0 14px 30px rgba(15,23,42,.10)!important;
}
.dashboard-news-slider-card .dashboard-news-image img{
  min-height:260px!important;
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  padding:8px!important;
}
.dashboard-news-slider-card .dashboard-news-dots{
  margin-top:18px!important;
}
.dashboard-news-slider-card .dashboard-news-dot{
  width:11px!important;
  height:11px!important;
  background:rgba(23,77,126,.24)!important;
}
.dashboard-news-slider-card .dashboard-news-dot.active{
  width:34px!important;
  background:#174d7e!important;
}
@media(max-width:760px){
  .dashboard-news-slider-card{padding:18px!important;border-radius:24px!important}
  .dashboard-news-slider-card .dashboard-news-slider{min-height:520px!important}
  .dashboard-news-slider-card .dashboard-news-slide{grid-template-columns:1fr!important;min-height:500px!important;padding:18px!important;gap:18px!important}
  .dashboard-news-slider-card .dashboard-news-image{min-height:220px!important;order:0!important}
  .dashboard-news-slider-card .dashboard-news-image img{min-height:220px!important}
  .dashboard-news-slider-card .dashboard-news-slide h3{font-size:1.55rem!important}
}

/* Dashboard Weiterlesen Button: gleiches Design wie „Alle anzeigen“, sauber unten im Textbereich */
.dashboard-news-slider-card .dashboard-news-text{
  display:flex!important;
  flex-direction:column!important;
}
.dashboard-news-slider-card .dashboard-news-meta{
  margin-top:auto!important;
  margin-bottom:10px!important;
}
.dashboard-news-slider-card .dashboard-readmore{
  align-self:flex-start!important;
  width:auto!important;
  margin-top:0!important;
  padding:8px 12px!important;
  border-radius:12px!important;
  font-size:13px!important;
  font-weight:800!important;
  background:linear-gradient(135deg,var(--blue),var(--cyan))!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 8px 18px rgba(23,77,126,.16)!important;
  text-decoration:none!important;
}
.dashboard-news-slider-card .dashboard-readmore:hover{
  filter:brightness(.98)!important;
  transform:translateY(-1px)!important;
  box-shadow:0 12px 24px rgba(23,77,126,.2)!important;
}
@media(max-width:760px){
  .dashboard-news-slider-card .dashboard-readmore{width:100%!important;}
}

/* Fix: Dashboard-News darf keine Inhalte wie Kategorie/Weiterlesen abschneiden */
.dashboard-news-slider-card{
  overflow:visible!important;
}
.dashboard-news-slider-card .dashboard-news-slider{
  overflow:visible!important;
  min-height:350px!important;
  padding-top:4px!important;
  padding-bottom:10px!important;
}
.dashboard-news-slider-card .dashboard-news-slide{
  overflow:visible!important;
  min-height:325px!important;
  padding:34px 26px 26px!important;
}
.dashboard-news-slider-card .dashboard-news-category{
  margin-top:0!important;
  flex-shrink:0!important;
}
.dashboard-news-slider-card .dashboard-readmore{
  flex-shrink:0!important;
  position:relative!important;
  z-index:3!important;
}
.dashboard-news-slider-card .dashboard-news-image,
.dashboard-news-slider-card .dashboard-news-image img{
  max-width:100%!important;
}
@media(max-width:760px){
  .dashboard-news-slider-card .dashboard-news-slider{min-height:560px!important;}
  .dashboard-news-slider-card .dashboard-news-slide{min-height:535px!important;padding:26px 18px!important;}
}

/* Patch: Kommentare einklappbar und Bild-Drag im News-Editor stabil */
.news-comments h3{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
}
.comments-collapse-btn{
  border:1px solid rgba(23,77,126,.14)!important;
  background:linear-gradient(135deg,#ffffff,#eef7fc)!important;
  color:#174d7e!important;
  border-radius:999px!important;
  padding:7px 12px!important;
  font-size:.82rem!important;
  font-weight:800!important;
  cursor:pointer!important;
  box-shadow:0 6px 16px rgba(15,23,42,.06)!important;
}
.comments-collapse-btn:hover{background:#e9f4fb!important;transform:translateY(-1px)!important;}
.comments-collapsible-body[hidden]{display:none!important;}
.rich-editor .editor-area figure.news-inline-image,
.rich-editor .editor-area figure.editable-image{
  position:relative!important;
  left:auto!important;
  top:auto!important;
  right:auto!important;
  bottom:auto!important;
  display:block!important;
  cursor:grab!important;
  touch-action:none!important;
  user-select:none!important;
  -webkit-user-select:none!important;
  pointer-events:auto!important;
  max-width:90%!important;
  clear:both!important;
}
.rich-editor .editor-area figure.news-inline-image.is-selected,
.rich-editor .editor-area figure.editable-image.is-selected{
  outline:3px solid rgba(23,77,126,.38)!important;
  outline-offset:5px!important;
}
.rich-editor .editor-area figure.news-inline-image img,
.rich-editor .editor-area figure.editable-image img{
  pointer-events:none!important;
  user-select:none!important;
  -webkit-user-drag:none!important;
}
.rich-editor .editor-area{position:relative!important;overflow:auto!important;}


.preview-label-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.preview-counter{font-size:12px;font-weight:800;color:#5d7086;background:#eef7fb;border:1px solid #d8edf5;border-radius:999px;padding:5px 10px;white-space:nowrap;}
.preview-counter.near-limit{background:#fff6df;border-color:#f4d89b;color:#8a5b00;}
#newsPreview{resize:vertical;min-height:84px;}
.dashboard-news-text p{white-space:normal;overflow:visible;display:block;}

/* Persönliche Rückmeldungen für Mitarbeiter/Springer */
.personal-alert-dropdown { width: 340px; }
.personal-alert-item span { display: grid; gap: 3px; min-width: 0; }
.personal-alert-item strong { color: var(--blue-dark); font-size: .94rem; }
.personal-alert-item small { color: var(--muted); font-size: .82rem; line-height: 1.35; }
.personal-alert-link { background: #eef6ff; color: var(--primary); border-color: #cfe4fb; }
.personal-alert-link.has-alert { background: #dff0ff; }

.personal-alert-row{display:grid;grid-template-columns:1fr auto;align-items:stretch;border-bottom:1px solid rgba(15,23,42,.06)}
.personal-alert-row .personal-alert-item{border-bottom:0!important}
.personal-alert-x{display:flex;align-items:center;justify-content:center;width:34px;color:#64748b;text-decoration:none;font-weight:900;font-size:18px;border-radius:10px;margin:6px 6px 6px 0}
.personal-alert-x:hover{background:#fee2e2;color:#b91c1c}

/* Update: bessere Versorgung-Zuordnung */
.assignment-card-wrap .assignment-list { display:grid; gap:12px; }
.assignment-card { border:1px solid var(--border); border-radius:18px; padding:14px; background:#fff; }
.assignment-summary { display:grid; grid-template-columns: minmax(0, 1fr) auto; gap:14px; align-items:start; }
.assignment-summary b { color:var(--blue-dark); }
.assignment-summary .team-chip-box.compact { min-height:auto; padding:8px; margin-top:8px; border-style:solid; }
.assignment-summary .team-chip.read-only { padding-right:12px; }
.assignment-editor { margin-top:14px; padding-top:14px; border-top:1px solid var(--border); }
.assignment-actions { display:flex; justify-content:flex-end; gap:10px; flex-wrap:wrap; }
.assignment-filter { margin-top:12px; }
.inline-approval-form { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin:0; }
.inline-approval-form input { min-width:220px; }
.approval-buttons { min-width:220px; }
.approval-buttons .small-btn { margin:2px; }
@media (max-width: 720px) {
  .assignment-summary { grid-template-columns:1fr; }
  .assignment-summary .small-btn, .assignment-actions .small-btn { width:100%; }
  .inline-approval-form input, .approval-buttons .small-btn { width:100%; }
}
@media print {
  .no-print { display:none !important; }
}

/* Update: Entscheidungen Wunschfrei übersichtlicher */
.decision-form { align-items:flex-start; gap:14px!important; }
.decision-form .approval-buttons { display:flex; gap:14px; align-items:center; flex-wrap:wrap; min-width:260px; }
.decision-form .approval-buttons .small-btn { margin:0; min-width:112px; justify-content:center; }
.decision-form input[name="admin_note"] { min-width:260px; }
.accept-btn { background:#166534!important; border-color:#166534!important; color:#fff!important; }
.archive-filter { align-items:end; }
.status-bestaetigt { background:#dcfce7!important; color:#166534!important; border-color:#bbf7d0!important; }
.status-abgelehnt { background:#fee2e2!important; color:#991b1b!important; border-color:#fecaca!important; }
@media (max-width: 720px) {
  .decision-form .approval-buttons { width:100%; gap:10px; }
  .decision-form .approval-buttons .small-btn { flex:1; min-width:0; }
  .decision-form input[name="admin_note"] { min-width:100%; }
}

/* Update: Changelog und Pflicht-Hinweise */
.decision-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:9999;display:flex;align-items:center;justify-content:center;padding:18px}
.decision-modal{max-width:560px;width:min(560px,100%);box-shadow:0 24px 80px rgba(15,23,42,.28)}
.decision-modal h2{margin-top:0;color:var(--blue-dark)}
.decision-modal-list{display:grid;gap:10px;margin:16px 0}
.decision-modal-item{border:1px solid var(--border);border-radius:16px;padding:12px;background:#f8fafc;display:grid;gap:4px}
.decision-modal-item span{color:#475569}
.changelog-list{display:grid;gap:12px}
.changelog-entry{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff}
.changelog-entry input{margin-top:5px}
.changelog-entry span{display:grid;gap:5px}
.changelog-entry small{color:#64748b}
.changelog-entry em{font-style:normal;color:#334155;line-height:1.45}

/* Nutzerverwaltung: kompakte Bearbeitung über Zahnrad */
.check-row { display:flex; flex-wrap:wrap; gap:12px; align-items:center; padding:8px 0; }
.check-row label { display:inline-flex; gap:6px; align-items:center; font-weight:700; }
.gear-btn { width:38px; height:38px; min-height:38px; padding:0; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; font-size:18px; line-height:1; }
.gear-btn[aria-expanded="true"] { box-shadow:0 0 0 3px rgba(23,77,126,.14); }
.account-edit-row td { background:#f8fbfd; border-top:0; }
.account-edit-panel { display:grid; gap:14px; padding:14px; border:1px solid rgba(23,77,126,.10); border-radius:18px; background:#fff; }
.account-edit-grid { display:grid; grid-template-columns:repeat(3, minmax(180px, 1fr)); gap:12px; }
.account-edit-panel .field label { margin-top:0; }
.account-edit-actions { display:flex; justify-content:flex-end; gap:10px; flex-wrap:wrap; }
.account-team-editor .team-picker[hidden] { display:none; }
.global-access-hint { padding:10px 12px; border-radius:14px; background:#f3f7fa; border:1px solid rgba(23,77,126,.10); }
@media (max-width: 780px) {
  .account-edit-grid { grid-template-columns:1fr; }
  .account-edit-actions .small-btn { width:100%; }
}

/* Aufgaben: Zuordnung und Kommentare */
.task-create-form { display:grid; gap:12px; }
.task-assignment-mode { display:flex; gap:10px; flex-wrap:wrap; padding:10px; border:1px solid var(--border); border-radius:16px; background:#f8fbfd; }
.task-assignment-mode label { display:inline-flex; align-items:center; gap:6px; margin:0; font-weight:700; }
.task-assignment-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; }
.check-list { border:1px solid var(--border); border-radius:16px; padding:10px; background:#fff; max-height:260px; overflow:auto; }
.compact-check-list label { display:block; padding:7px 8px; border-radius:10px; margin:2px 0; }
.compact-check-list label:hover { background:#f1f6fb; }
.task-user-filter { margin-bottom:8px; }
.inline-form { display:inline-flex; margin:4px 6px 4px 0; }
.task-comments { margin-top:16px; padding-top:12px; border-top:1px solid var(--border); }
.task-comments h4 { margin:0 0 8px; color:var(--blue-dark); }
.task-comment { background:#f8fbfd; border:1px solid rgba(23,77,126,.10); border-radius:14px; padding:10px 12px; margin:8px 0; }
.task-comment p { margin:6px 0 0; }
.task-comment-form { margin-top:10px; }
.task-comment-form textarea { min-height:70px; }

/* Organisations-Update: offene Punkte, Ampel und Aufgabenpriorität */
.open-points-list{display:grid;gap:10px;margin:12px 0 16px}
.open-point{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid rgba(15,23,42,.10);border-radius:14px;background:#fff;text-decoration:none;color:inherit;box-shadow:0 6px 18px rgba(15,23,42,.06)}
.open-point strong{display:block;margin-bottom:3px}.open-point small{display:block;color:#64748b}.open-point b{font-size:24px;color:#64748b}
.open-point-warnung{border-left:6px solid #f59e0b}.open-point-entscheidung{border-left:6px solid #2563eb}.open-point-aufgabe{border-left:6px solid #7c3aed}.open-point-urlaub{border-left:6px solid #0ea5e9}.open-point-info{border-left:6px solid #10b981}
.mini-kpi-grid{margin-top:10px}.badge.status-bestaetigt,.status-bestaetigt{background:#dcfce7;color:#166534}.badge.status-abgelehnt,.status-abgelehnt{background:#fee2e2;color:#991b1b}
.priority-badge{margin-left:8px}.priority-normal{background:#e5e7eb;color:#374151}.priority-wichtig{background:#fef3c7;color:#92400e}.priority-dringend{background:#fee2e2;color:#991b1b}
.task-box{border-left:6px solid #e5e7eb}.task-priority-wichtig{border-left-color:#f59e0b}.task-priority-dringend{border-left-color:#dc2626}
.archive-filter{align-items:end}.archive-filter .field{min-width:160px}
@media (max-width: 760px){.open-point{align-items:flex-start}.archive-filter .field{min-width:100%}}

/* Nutzerverwaltung: kompakte Klick-Bearbeitung */
.account-click-table .cell-edit-button {
    width: 100%;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: left;
    padding: 8px 10px;
    border-radius: 12px;
    cursor: pointer;
}
.account-click-table .cell-edit-button:hover,
.account-click-table .cell-edit-button:focus {
    background: rgba(15, 23, 42, 0.06);
    outline: none;
}
.compact-account-editor {
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 18px;
    padding: 16px;
    background: rgba(248, 250, 252, 0.9);
}
.edit-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}
.account-edit-section[hidden] {
    display: none !important;
}
.account-edit-section {
    max-width: 760px;
}
.account-edit-actions {
    margin-top: 14px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
/* Mitarbeiterportal: Dokumente, Wissen und kompakte Nachweise */
.docs-grid .docs-search-card{background:linear-gradient(135deg,#f8fbfd,#eef8fc)}
.docs-filter{display:grid;grid-template-columns:minmax(220px,1.5fr) minmax(220px,1fr) auto auto;gap:10px;align-items:end}
.stack-form{display:grid;gap:10px}.stack-form label{font-weight:800;color:var(--text)}.compact-form{margin-top:10px;padding:12px;border-radius:16px;background:#f8fbfd;border:1px solid #e4edf5}
.doc-list{display:grid;gap:13px}.doc-item{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;border:1px solid #e4edf5;border-radius:20px;padding:16px;background:#fff;box-shadow:0 10px 22px rgba(15,23,42,.045)}.doc-item h3{margin:0 0 4px}.doc-actions{display:flex;gap:8px;align-items:center}.doc-edit{grid-column:1 / -1}.doc-edit summary{cursor:pointer;font-weight:900;color:var(--blue);padding:8px 0}.quick-actions{display:flex;gap:8px;flex-wrap:wrap}.big-number{font-size:44px;font-weight:950;margin:0;color:var(--blue)}.guided-decision{gap:12px}.guided-decision .inline-form{margin:0}@media(max-width:760px){.docs-filter{grid-template-columns:1fr}.doc-item{grid-template-columns:1fr}.doc-actions{justify-content:flex-start}}

/* News-Editor: Toolbar-Shell, Mobil-first (überschreibt ältere .editor-toolbar-Grid-Regeln ab 720px) */
.news-modal-card.news-modal-card {
    width: min(980px, calc(100vw - 16px));
    max-width: 100%;
    max-height: min(92vh, 100dvh);
    max-height: min(92vh, 100svh);
    padding-bottom: max(22px, env(safe-area-inset-bottom, 0px));
    padding-left: max(22px, env(safe-area-inset-left, 0px));
    padding-right: max(22px, env(safe-area-inset-right, 0px));
    -webkit-overflow-scrolling: touch;
}
.news-modal-card .modal-head {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--card);
    padding-bottom: 8px;
    margin-bottom: 8px;
    border-bottom: 1px solid var(--border);
}
.news-modal-card .modal-close {
    min-width: 44px;
    min-height: 44px;
}
.modal-backdrop:has(.news-modal-card) {
    padding: max(12px, env(safe-area-inset-top, 0px)) max(14px, env(safe-area-inset-right, 0px)) max(14px, env(safe-area-inset-bottom, 0px)) max(14px, env(safe-area-inset-left, 0px));
    align-items: flex-end;
}
@media (min-width: 540px) {
    .modal-backdrop:has(.news-modal-card) {
        align-items: center;
    }
}
.news-editor-form {
    display: grid;
    gap: 12px;
}
.news-editor-form > label,
.news-body-label {
    margin-top: 4px;
}
.news-visibility-heading {
    margin: 14px 0 6px;
    font-size: 1rem;
    color: var(--blue-dark);
}
.news-visibility-box {
    display: grid;
    gap: 8px;
}
.news-editor-form .news-team-checkboxes {
    margin-top: 4px;
}
.news-checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: #fff;
    margin: 0;
    font-weight: 700;
}
.news-checkbox-row input {
    margin-top: 4px;
    flex-shrink: 0;
}
.rich-editor .editor-toolbar-shell {
    background: var(--card-soft);
    border: 1px solid var(--border);
    border-radius: 16px 16px 0 0;
    overflow: hidden;
}
.rich-editor .editor-toolbar-shell .editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 12px 16px;
    padding: 10px 12px;
    background: transparent;
    border: 0;
}
.rich-editor .editor-tool-section {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
    flex: 1 1 auto;
}
.rich-editor .editor-tool-section-title {
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--muted);
    line-height: 1.2;
    margin: 0;
}
.rich-editor .editor-tool-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.rich-editor .editor-tool-buttons--style {
    align-items: stretch;
}
.rich-editor .editor-tool-section--align .editor-tool-buttons {
    flex-wrap: nowrap;
}
.rich-editor .editor-tool-section-image-tools {
    flex: 1 1 100%;
    width: 100%;
    padding-top: 4px;
    border-top: 1px dashed rgba(23, 77, 126, 0.2);
    margin-top: 4px;
}
.rich-editor .editor-tool-section-image-tools[hidden] {
    display: none !important;
}
.rich-editor .editor-tool-section-image-tools .image-tool-group {
    width: 100%;
    box-sizing: border-box;
}
.rich-editor .editor-toolbar-shell .editor-toolbar button,
.rich-editor .editor-toolbar-shell .editor-color,
.rich-editor .editor-toolbar-shell .editor-font-select {
    box-shadow: none;
    font-weight: 800;
}
.rich-editor .editor-toolbar-shell .editor-font-select {
    min-width: 140px;
    flex: 1 1 140px;
}
.rich-editor .editor-toolbar-shell .editor-color {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
}
.rich-editor .editor-area {
    font-size: 16px;
}
@media (max-width: 720px) {
    .rich-editor .editor-toolbar-shell .editor-toolbar {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 14px !important;
    }
    .feed-main-news {
        padding: 16px 14px !important;
    }
    .feed-main-news h2 {
        font-size: clamp(1.45rem, 6vw, 2.2rem) !important;
        word-break: break-word;
    }
    .feed-hero .primary-btn,
    .feed-hero .small-btn.primary-btn,
    .feed-hero #openNewsModal {
        width: 100%;
        justify-content: center;
        min-height: 48px;
    }
    .news-history-link {
        padding: 12px;
    }
    .rich-editor .editor-tool-section {
        padding-bottom: 12px;
        margin-bottom: 2px;
        border-bottom: 1px solid var(--border);
        flex: 1 1 auto !important;
        width: 100% !important;
    }
    .rich-editor .editor-tool-section:last-of-type {
        border-bottom: 0;
        padding-bottom: 0;
        margin-bottom: 0;
    }
    .rich-editor .editor-tool-section-image-tools {
        border-top: 0;
        margin-top: 0;
        padding-top: 0;
    }
    .rich-editor .editor-tool-buttons,
    .rich-editor .editor-tool-buttons--style,
    .rich-editor .editor-tool-buttons--media {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        width: 100% !important;
    }
    .rich-editor .editor-tool-section--align .editor-tool-buttons {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
    .rich-editor .editor-tool-buttons--style .editor-font-select {
        grid-column: 1 / -1 !important;
        width: 100% !important;
        min-height: 46px;
    }
    .rich-editor .editor-tool-section-image-tools .image-tool-group {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        padding: 8px !important;
    }
    .rich-editor .editor-tool-section-image-tools .image-tool-group button {
        width: 100%;
        justify-content: center;
    }
}
@media (max-width: 480px) {
    .news-modal-card.news-modal-card {
        width: 100%;
        max-width: none;
        border-radius: 20px 20px 0 0;
        max-height: 100dvh;
        max-height: 100svh;
    }
    .feed-page-grid {
        gap: 14px;
    }
    .feed-main-news {
        padding: 14px 12px !important;
    }
    .feed-hero {
        gap: 12px;
    }
    .feed-hero .small-btn,
    .feed-hero .primary-btn {
        width: 100%;
    }
    .news-history-card {
        padding: 14px 12px;
    }
    .news-history-link {
        padding: 12px;
    }
    .image-upload-hint {
        font-size: 0.82rem;
        line-height: 1.35;
    }
}
@media (max-width: 380px) {
    .image-upload-hint {
        display: none;
    }
}
@media (hover: none) and (pointer: coarse) {
    .rich-editor .editor-toolbar-shell .editor-toolbar button,
    .rich-editor .editor-toolbar-shell .editor-color,
    .rich-editor .editor-toolbar-shell .editor-font-select,
    .rich-editor .editor-tool-section-image-tools .image-tool-group button {
        min-height: 44px;
        min-width: 44px;
    }
    .rich-editor .editor-font-select {
        min-height: 48px;
    }
}
.news-editor-form .publish-btn {
    margin-top: 8px;
}
@media (max-width: 720px) {
    .news-editor-form .publish-btn {
        width: 100%;
        min-width: 0;
        min-height: 48px;
    }
}
@media (max-width: 900px) {
    .feed-page-grid {
        padding-left: 0;
        padding-right: 0;
    }
    .news-history-link p {
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
}

/* Dateien (Teamdateien) */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.file-library-hero { margin-bottom: 0.75rem; }
.file-library-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 6px;
    font-size: 0.9rem;
    margin: 0 0 1.25rem;
    padding: 10px 14px;
    border-radius: 12px;
    background: rgba(23, 77, 126, 0.05);
    border: 1px solid var(--border, rgba(23, 77, 126, 0.1));
    color: var(--muted, #64748b);
}
.file-library-breadcrumb a {
    color: var(--primary, #174d7e);
    font-weight: 700;
    text-decoration: none;
    border-radius: 6px;
    padding: 2px 4px;
    margin: -2px -4px;
}
.file-library-breadcrumb a:hover {
    text-decoration: underline;
    background: rgba(23, 77, 126, 0.08);
}
.file-library-bc-current { font-weight: 800; color: var(--text, #1f2d3d); }
.file-library-bc-sep { opacity: 0.45; padding: 0 2px; }
.file-library-bc-current-wrap {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.file-library-bc-gear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 8px;
    font-size: 1.1rem;
    line-height: 1;
    text-decoration: none;
    color: var(--primary, #174d7e);
    background: rgba(23, 77, 126, 0.08);
    border: 1px solid rgba(23, 77, 126, 0.15);
}
.file-library-bc-gear:hover { background: rgba(23, 77, 126, 0.14); }
.file-library-bc-back {
    width: auto;
    height: auto;
    padding: 0.35rem 0.65rem;
    font-size: 0.8rem;
    font-weight: 700;
}
.file-library-finder-intro {
    font-size: 0.88rem;
    margin: 0 0 14px;
    line-height: 1.5;
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(23, 77, 126, 0.05);
    border: 1px solid rgba(23, 77, 126, 0.08);
}
.file-library-finder {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 4px 0 8px;
}
.file-library-finder-nested { margin-bottom: 18px; }
.file-library-finder-line {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 4px;
}
.file-library-finder-folder {
    flex: 1;
    min-width: 0;
    border-radius: 12px;
    border: 1px solid rgba(23, 77, 126, 0.1);
    background: #fbfdff;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.file-library-finder-folder:hover {
    border-color: rgba(23, 77, 126, 0.18);
    box-shadow: 0 1px 6px rgba(23, 77, 126, 0.06);
}
.file-library-finder-folder[open] {
    border-color: rgba(23, 77, 126, 0.22);
    background: #fff;
    box-shadow: 0 4px 16px rgba(23, 77, 126, 0.08);
}
.file-library-finder-summary {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    cursor: pointer;
    list-style: none;
    font-weight: 600;
    border-radius: 12px 12px 0 0;
}
.file-library-finder-folder:not([open]) > .file-library-finder-summary {
    border-radius: 12px;
}
.file-library-finder-summary::-webkit-details-marker { display: none; }
.file-library-finder-summary::marker { content: ''; }
.file-library-finder-disclosure {
    flex-shrink: 0;
    width: 0;
    height: 0;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 7px solid #94a3b8;
    transition: transform 0.15s ease, border-left-color 0.15s;
    margin-left: 2px;
}
.file-library-finder-folder[open] > .file-library-finder-summary .file-library-finder-disclosure {
    transform: rotate(90deg);
    border-left-color: var(--primary, #174d7e);
}
.file-library-finder-name {
    flex: 1;
    min-width: 0;
    font-weight: 800;
    font-size: 1.02rem;
    color: #143d5d;
    text-decoration: none;
    letter-spacing: -0.02em;
}
.file-library-finder-name:hover { text-decoration: underline; color: var(--primary, #174d7e); }
.file-library-finder-badges {
    font-size: 0.72rem;
    font-weight: 700;
    color: #475569;
    white-space: nowrap;
    flex-shrink: 0;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(23, 77, 126, 0.08);
}
.file-library-finder-body {
    margin: 0;
    padding: 0 10px 12px 12px;
    border-left: 3px solid rgba(23, 77, 126, 0.12);
    margin-left: 14px;
    padding-left: 14px;
}
.file-library-finder-meta {
    padding: 8px 10px 10px;
    margin-bottom: 8px;
    border-radius: 8px;
    background: rgba(241, 247, 251, 0.9);
    border: 1px solid rgba(23, 77, 126, 0.08);
}
.file-library-finder-hint,
.file-library-finder-roles { margin: 0; font-size: 0.8rem; line-height: 1.45; }
.file-library-finder-roles { margin-top: 6px; }
.file-library-finder-section-label {
    margin: 0 0 6px;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #64748b;
}
.file-library-finder-branch-wrap {
    margin-top: 4px;
    margin-bottom: 10px;
}
.file-library-finder-children {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-top: 2px;
}
.file-library-finder-files-wrap {
    margin-top: 6px;
    padding-top: 8px;
    border-top: 1px dashed rgba(23, 77, 126, 0.15);
}
.file-library-finder-files {
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 0.9rem;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.file-library-finder-file {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    flex-wrap: wrap;
    border-radius: 8px;
    background: #f8fafc;
    border: 1px solid rgba(23, 77, 126, 0.07);
    transition: background 0.12s ease, border-color 0.12s ease;
}
.file-library-finder-file:hover {
    background: #f1f7fb;
    border-color: rgba(23, 77, 126, 0.14);
}
.file-library-finder-file-ico {
    width: 14px;
    height: 14px;
    border-radius: 3px;
    background: linear-gradient(135deg, #94a3b8, #cbd5e1);
    flex-shrink: 0;
}
.file-library-finder-file a { font-weight: 600; color: var(--primary, #174d7e); text-decoration: none; flex: 1; min-width: 0; }
.file-library-finder-file a:hover { text-decoration: underline; }
.file-library-finder-empty-files { margin: 8px 0 0; font-size: 0.86rem; padding: 8px 10px; border-radius: 8px; background: rgba(248, 250, 252, 0.9); }
.file-library-gear {
    flex-shrink: 0;
    position: relative;
    margin-top: 2px;
    z-index: 2;
}
.file-library-gear-btn {
    list-style: none;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    background: rgba(23, 77, 126, 0.06);
    border: 1px solid rgba(23, 77, 126, 0.12);
    color: var(--primary, #174d7e);
}
.file-library-gear-btn::-webkit-details-marker { display: none; }
.file-library-gear-btn::marker { content: ''; }
.file-library-gear-btn::before { content: '⚙'; font-size: 1.05rem; line-height: 1; }
.file-library-gear-btn:hover { background: rgba(23, 77, 126, 0.12); }
.file-library-gear[open] > .file-library-gear-btn { background: rgba(23, 77, 126, 0.16); }
.file-library-gear[open] { z-index: 50; }
.file-library-gear-panel {
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    z-index: 400;
    min-width: min(320px, calc(100vw - 32px));
    max-width: min(400px, calc(100vw - 24px));
    padding: 10px 12px 12px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid rgba(23, 77, 126, 0.22);
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
}
.file-library-gear-scroll {
    max-height: min(72vh, 560px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 4px 4px 2px 0;
    -webkit-overflow-scrolling: touch;
}
.file-library-gear-panel-title {
    margin: 0 0 8px;
    font-size: 0.95rem;
    font-weight: 800;
    color: #143d5d;
    flex-shrink: 0;
}
.file-library-gear-links { margin: 0 0 10px; font-size: 0.86rem; }
.file-library-gear-links a { font-weight: 700; }
.file-library-gear-hint { font-size: 0.82rem; margin: 10px 0 0; line-height: 1.45; }
.file-library-gear-delete-form {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(23, 77, 126, 0.12);
}
.file-library-gear-move {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(23, 77, 126, 0.12);
}
.file-library-btn-delete {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.file-library-del-ico::before {
    content: '\1F5D1';
    margin-right: 4px;
    font-size: 1.05rem;
    line-height: 1;
    vertical-align: middle;
}
.file-library-settings-bearbeiten { margin-bottom: 1.5rem; }
.file-library-grid > .card,
.file-library-grid > details.card {
    overflow: visible;
}
.file-library-list-card {
    overflow: visible;
}
.file-library-finder-line,
.file-library-finder-folder,
.file-library-finder-body {
    overflow: visible;
}
.file-library-create-folder {
    overflow: visible;
    align-self: start;
}
.file-library-create-folder > summary.file-library-create-summary {
    list-style: none;
    cursor: pointer;
    padding: 14px 18px;
    margin: 0;
    font-size: 1.05rem;
    font-weight: 800;
    color: #143d5d;
    border-radius: var(--radius);
    background: linear-gradient(180deg, #f6fafc 0%, #eef6fb 100%);
    border: 1px solid rgba(23, 77, 126, 0.14);
}
.file-library-create-folder > summary.file-library-create-summary::-webkit-details-marker { display: none; }
.file-library-create-folder > summary.file-library-create-summary::marker { content: ''; }
.file-library-create-folder > summary.file-library-create-summary::before {
    content: '+';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.5rem;
    height: 1.5rem;
    margin-right: 10px;
    border-radius: 8px;
    background: rgba(23, 77, 126, 0.12);
    color: var(--primary, #174d7e);
    font-weight: 900;
}
.file-library-create-folder[open] > summary.file-library-create-summary::before {
    content: '−';
    line-height: 1;
}
.file-library-create-folder[open] > summary.file-library-create-summary {
    border-radius: var(--radius) var(--radius) 0 0;
    border-bottom: 1px solid rgba(23, 77, 126, 0.1);
}
.file-library-create-inner {
    padding: 18px 18px 22px;
    border-top: none;
}
.file-library-grid { align-items: start; gap: 1.25rem; }
.file-library-card h2 { margin-top: 0; font-size: 1.15rem; }
.file-library-settings-card {
    max-width: 100%;
    margin-bottom: 1.25rem;
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(23, 77, 126, 0.06);
}
.file-library-form .file-library-hint { font-size: 0.88rem; line-height: 1.45; }
.file-library-team-pick { margin-top: 8px; }
.file-library-root-hint {
    font-size: 0.88rem;
    margin: 0 0 14px;
    line-height: 1.45;
}
.file-library-root-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.file-library-root-details {
    border-radius: 14px;
    border: 1px solid var(--border, rgba(23, 77, 126, 0.14));
    background: linear-gradient(165deg, #fff 0%, #f6fafc 100%);
    overflow: hidden;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.file-library-root-details:hover {
    border-color: rgba(23, 77, 126, 0.28);
    box-shadow: 0 4px 18px rgba(23, 77, 126, 0.08);
}
.file-library-root-details[open] {
    border-color: rgba(23, 77, 126, 0.32);
    box-shadow: 0 6px 22px rgba(23, 77, 126, 0.1);
}
.file-library-root-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px 14px;
    padding: 14px 16px;
    cursor: pointer;
    list-style: none;
    font-weight: 600;
}
.file-library-root-summary::-webkit-details-marker { display: none; }
.file-library-root-summary::marker { content: ''; }
.file-library-root-summary-main {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}
.file-library-root-chevron {
    display: inline-block;
    width: 0.5em;
    height: 0.5em;
    border-right: 2px solid var(--primary, #174d7e);
    border-bottom: 2px solid var(--primary, #174d7e);
    transform: rotate(-45deg);
    transition: transform 0.2s ease;
    flex-shrink: 0;
    opacity: 0.75;
}
.file-library-root-details[open] .file-library-root-chevron {
    transform: rotate(45deg);
    margin-top: -2px;
}
.file-library-root-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: #143d5d;
    text-decoration: none;
    border-radius: 6px;
    padding: 2px 4px;
    margin: -2px -4px;
}
.file-library-root-title:hover {
    color: var(--primary, #174d7e);
    text-decoration: underline;
}
.file-library-root-badges {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--muted, #64748b);
    background: rgba(23, 77, 126, 0.07);
    padding: 4px 10px;
    border-radius: 999px;
    white-space: nowrap;
}
.file-library-root-body {
    padding: 0 16px 16px;
    border-top: 1px solid rgba(23, 77, 126, 0.08);
}
.file-library-root-meta { margin: 12px 0 8px; }
.file-library-role-readout {
    font-size: 0.86rem;
    color: #334155;
    margin: 0 0 12px;
    line-height: 1.5;
}
.file-library-role-readout-label {
    font-weight: 700;
    color: #143d5d;
    margin-right: 4px;
}
.file-library-preview-label {
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #64748b;
    margin: 0 0 6px;
}
.file-library-preview-subs {
    margin: 0 0 12px;
    padding-left: 1.1rem;
    font-size: 0.92rem;
}
.file-library-preview-subs li { margin: 4px 0; }
.file-library-preview-subs a {
    color: var(--primary, #174d7e);
    font-weight: 600;
    text-decoration: none;
}
.file-library-preview-subs a:hover { text-decoration: underline; }
.file-library-preview-empty { margin: 0 0 12px; font-size: 0.9rem; }
.file-library-preview-foot { margin: 0 0 12px; }
.file-library-nested-details {
    margin: 12px 0;
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.85);
    border: 1px dashed rgba(23, 77, 126, 0.2);
}
.file-library-nested-details > summary {
    cursor: pointer;
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--primary, #174d7e);
    list-style: none;
}
.file-library-nested-details > summary::-webkit-details-marker { display: none; }
.file-library-nested-form label { font-size: 0.88rem; }
.file-library-nested-form select { margin-bottom: 8px; }
.file-library-folder-ops {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-end;
    margin-top: 8px;
}
.file-library-move-folder-form {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin: 0;
}
.file-library-move-folder-form select {
    min-width: 180px;
    max-width: 100%;
    font-size: 0.88rem;
}
.file-library-folder-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}
.file-library-folder-tile {
    display: block;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--border, rgba(23, 77, 126, 0.12));
    background: linear-gradient(180deg, #fff, #f8fbfd);
    text-decoration: none;
    color: inherit;
    transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
}
.file-library-folder-tile:hover {
    border-color: rgba(23, 77, 126, 0.28);
    box-shadow: 0 6px 20px rgba(23, 77, 126, 0.1);
    transform: translateY(-1px);
}
.file-library-folder-tile strong { display: block; color: #143d5d; margin-bottom: 6px; }
.file-library-access-line { font-size: 0.82rem; color: #64748b; line-height: 1.45; }
.file-library-subh { font-size: 1.02rem; margin: 4px 0 12px; color: #143d5d; font-weight: 800; }
.file-library-subfolder-rich {
    list-style: none;
    margin: 0 0 20px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.file-library-subrow {
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid rgba(23, 77, 126, 0.12);
    background: #fafcfe;
    transition: border-color 0.15s ease, background 0.15s ease;
}
.file-library-subrow:hover {
    border-color: rgba(23, 77, 126, 0.22);
    background: #fff;
}
.file-library-subrow-main {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px 12px;
    margin-bottom: 6px;
}
.file-library-subrow-name {
    font-weight: 800;
    font-size: 1rem;
    color: #143d5d;
    text-decoration: none;
}
.file-library-subrow-name:hover { color: var(--primary, #174d7e); text-decoration: underline; }
.file-library-subrow-counts {
    font-size: 0.8rem;
    font-weight: 600;
    color: #64748b;
    background: rgba(23, 77, 126, 0.06);
    padding: 3px 10px;
    border-radius: 999px;
}
.file-library-subrow-meta { margin: 0 0 6px; }
.file-library-subrow-roles { margin: 0 0 8px; }
.file-library-subfolder-list { margin: 0 0 16px; padding-left: 18px; }
.file-library-subfolder-list li { margin: 6px 0; }
.file-library-toolbar { display: flex; justify-content: flex-end; margin-bottom: 10px; }
.file-library-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 12px;
    border: 1px solid rgba(23, 77, 126, 0.08);
}
.file-library-table { min-width: 640px; }
.file-library-table tbody tr:hover { background: rgba(23, 77, 126, 0.03); }
.file-library-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.file-library-inline-form, .file-library-move-form {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    margin: 0;
}
.file-library-move-form select { max-width: 200px; }
.file-library-move-label { font-size: 0.78rem; margin-right: 2px; }
@media (max-width: 720px) {
    .file-library-finder-summary { flex-wrap: wrap; row-gap: 4px; }
    .file-library-finder-badges { flex-basis: 100%; margin-left: 22px; }
    .file-library-gear-panel {
        left: 0;
        right: 0;
        max-width: none;
        width: max(280px, 100%);
        min-width: 0;
    }
    .file-library-gear-scroll { max-height: min(80vh, 620px); }
    .file-library-root-summary {
        flex-direction: column;
        align-items: flex-start;
    }
    .file-library-root-badges { align-self: flex-start; }
    .file-library-table { min-width: 0; }
    .file-library-table thead { display: none; }
    .file-library-table tr {
        display: grid;
        grid-template-columns: 1fr;
        gap: 4px;
        padding: 12px 0;
        border-bottom: 1px solid rgba(23, 77, 126, 0.1);
    }
    .file-library-table td {
        display: flex;
        gap: 8px;
        align-items: baseline;
        padding: 4px 0;
        border: 0;
    }
    .file-library-table td::before {
        content: attr(data-label);
        flex: 0 0 38%;
        font-size: 0.78rem;
        font-weight: 800;
        color: #64748b;
        text-align: left;
    }
    .file-library-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .file-library-move-form select { max-width: 100%; width: 100%; }
    .file-library-move-folder-form { flex-direction: column; align-items: stretch; }
    .file-library-move-folder-form select { width: 100%; max-width: none; }
}
