/* ===== GS Sammlungsverwaltung – v3 mit CRUD ===== */
.gs-wrap {
    --gs-max-w: 1400px;
    --gs-bg: #f5f7fa;
    --gs-card: #ffffff;
    --gs-text: #1e293b;
    --gs-text-light: #64748b;
    --gs-primary: #2563eb;
    --gs-primary-hover: #1d4ed8;
    --gs-border: #e2e8f0;
    --gs-shadow: 0 2px 8px rgba(0,0,0,.06);
    --gs-radius: 10px;
    --gs-card-scale: 1;
    --gs-success: #16a34a;
    --gs-danger: #dc2626;
    --gs-warning: #f59e0b;
    font-family: 'Segoe UI', system-ui, sans-serif;
    color: var(--gs-text);
}

/* Toolbar */
.gs-toolbar {
    max-width: var(--gs-max-w); margin: 12px auto;
    padding: 10px 20px; display: flex; flex-wrap: wrap;
    gap: 16px; align-items: center;
    background: var(--gs-card); border-radius: var(--gs-radius);
    box-shadow: var(--gs-shadow);
}
.gs-toolbar-group { display:flex; align-items:center; gap:8px; font-size:.85rem; color:var(--gs-text-light); }
.gs-toolbar-group label { white-space:nowrap; font-weight:600; }
.gs-toolbar-group input[type=range] { width:120px; cursor:pointer; }
.gs-toolbar-group span { min-width:40px; text-align:right; font-variant-numeric:tabular-nums; }

.gs-btn-tool {
    padding:6px 14px; background:var(--gs-primary); color:#fff;
    border:none; border-radius:6px; font-size:.85rem; cursor:pointer;
    transition: background .2s;
}
.gs-btn-tool:hover { background:var(--gs-primary-hover); }
.gs-btn-danger { background:var(--gs-danger)!important; }
.gs-btn-danger:hover { background:#b91c1c!important; }
.gs-btn-save { background:var(--gs-success)!important; }
.gs-btn-save:hover { background:#15803d!important; }

/* Container */
.gs-container {
    max-width: var(--gs-max-w); margin: 16px auto; padding: 0 16px;
    transition: max-width .3s ease;
}

/* Suche + Neu-Button */
.gs-search-row { display:flex; gap:10px; margin-bottom:14px; align-items:stretch; }
.gs-search { flex:1; }
.gs-search input {
    width:100%; padding:12px 16px; border:2px solid var(--gs-border);
    border-radius:var(--gs-radius); font-size:1rem; box-sizing:border-box;
    line-height:1.4;
}
.gs-search input:focus { outline:none; border-color:var(--gs-primary); }
.gs-btn-add {
    padding:12px 20px; background:var(--gs-success); color:#fff;
    border:none; border-radius:var(--gs-radius); font-size:1rem;
    font-weight:600; cursor:pointer; white-space:nowrap; transition:background .2s;
}
.gs-btn-add:hover { background:#15803d; }

/* Filter */
.gs-filter-row {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
    gap:10px; margin-bottom:14px;
}
.gs-filter-row select {
    width:100%; padding:9px 12px; border:2px solid var(--gs-border);
    border-radius:8px; font-size:.88rem; background:var(--gs-card);
    line-height:1.4; height:auto; min-height:40px;
}
.gs-filter-row .gs-btn-reset {
    padding:9px 16px; background:#ef4444; color:#fff;
    border:none; border-radius:8px; cursor:pointer; font-size:.88rem;
}

/* Controls */
.gs-controls { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; flex-wrap:wrap; gap:10px; }
.gs-results { font-size:.88rem; color:var(--gs-text-light); }
.gs-view-controls { display:flex; align-items:center; gap:8px; }
.gs-view-controls select { padding:7px 10px; border:2px solid var(--gs-border); border-radius:8px; font-size:.85rem; line-height:1.4; height:auto; min-height:36px; }
.gs-btn-view {
    width:36px; height:36px; border:2px solid var(--gs-border);
    border-radius:8px; background:var(--gs-card); font-size:1.1rem;
    cursor:pointer; display:flex; align-items:center; justify-content:center;
}
.gs-btn-view.active { border-color:var(--gs-primary); background:#eff6ff; color:var(--gs-primary); }

/* Kategorien */
.gs-cat-nav { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }
.gs-cat-pill {
    padding:5px 14px; background:var(--gs-card); border:1px solid var(--gs-border);
    border-radius:20px; font-size:.8rem; cursor:pointer;
}
.gs-cat-pill:hover, .gs-cat-pill.active { background:var(--gs-primary); color:#fff; border-color:var(--gs-primary); }

/* Grid */
.gs-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(calc(200px * var(--gs-card-scale)),1fr));
    gap:16px;
}

/* Card */
.gs-card {
    background:var(--gs-card); border-radius:var(--gs-radius);
    box-shadow:var(--gs-shadow); overflow:hidden; cursor:pointer;
    transition:transform .2s,box-shadow .2s; position:relative;
}
.gs-card:hover { transform:translateY(-3px); box-shadow:0 6px 20px rgba(0,0,0,.1); }
.gs-card-image {
    width:100%; aspect-ratio:1/1; background:#f1f5f9;
    display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.gs-card-image img { width:100%; height:100%; object-fit:contain; }
.gs-card-no-image { font-size:2.5rem; color:#cbd5e1; }
.gs-card-body { padding:10px 12px 14px; text-align:center; }
.gs-card-body h3 {
    font-size:.9rem; font-weight:600; line-height:1.3;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
    margin:0;
}

/* Card Quick-Actions (nur für Admins sichtbar) */
.gs-card-actions {
    position:absolute; top:6px; right:6px; display:flex; gap:4px;
    opacity:0; transition:opacity .2s;
}
.gs-card:hover .gs-card-actions { opacity:1; }
.gs-card-action-btn {
    width:30px; height:30px; border-radius:50%; border:none;
    display:flex; align-items:center; justify-content:center;
    font-size:.8rem; cursor:pointer; box-shadow:0 2px 6px rgba(0,0,0,.15);
    transition:transform .15s;
}
.gs-card-action-btn:hover { transform:scale(1.15); }
.gs-card-action-btn.edit { background:#fff; color:var(--gs-primary); }
.gs-card-action-btn.delete { background:#fff; color:var(--gs-danger); }

/* List */
.gs-list { display:flex; flex-direction:column; gap:8px; }
.gs-list .gs-card { display:flex; flex-direction:row; align-items:center; }
.gs-list .gs-card-image { width:80px; height:80px; min-width:80px; aspect-ratio:auto; }
.gs-list .gs-card-body { text-align:left; flex:1; }
.gs-list .gs-card-actions { opacity:1; position:static; padding-right:12px; }

/* Pagination */
.gs-pagination { display:flex; justify-content:center; gap:6px; margin:24px 0 40px; flex-wrap:wrap; }
.gs-page-btn {
    padding:8px 14px; border:2px solid var(--gs-border); border-radius:8px;
    background:var(--gs-card); cursor:pointer; font-size:.88rem;
}
.gs-page-btn:hover { border-color:var(--gs-primary); color:var(--gs-primary); }
.gs-page-btn.active { background:var(--gs-primary); color:#fff; border-color:var(--gs-primary); }
.gs-page-btn:disabled { opacity:.4; cursor:default; }

/* ===== Modals ===== */
.gs-modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.55);
    display:none; align-items:center; justify-content:center;
    z-index:100000; padding:20px;
}
.gs-modal-overlay.open { display:flex; }
.gs-modal {
    background:var(--gs-card); border-radius:14px;
    max-width:800px; width:100%; max-height:85vh; overflow:hidden;
    box-shadow:0 20px 60px rgba(0,0,0,.2); display:flex; flex-direction:column;
    transition:max-width .3s,max-height .3s;
}
.gs-modal-toolbar {
    display:flex; flex-wrap:wrap; align-items:center; gap:12px;
    padding:12px 20px; background:#f8fafc; border-bottom:1px solid var(--gs-border);
    border-radius:14px 14px 0 0; flex-shrink:0;
}
.gs-modal-right { margin-left:auto; display:flex; align-items:center; gap:8px; }
.gs-modal-close {
    background:none; border:none; font-size:1.4rem; cursor:pointer;
    color:var(--gs-text-light); padding:2px 6px; border-radius:6px;
}
.gs-modal-close:hover { color:var(--gs-text); background:#e2e8f0; }
.gs-modal-body { padding:24px 28px 28px; overflow-y:auto; flex:1; }
.gs-modal-body h2 { margin:0 0 16px; font-size:1.3rem; }

/* Detail Modal */
.gs-modal-image { text-align:center; margin-bottom:20px; }
.gs-modal-image img { max-width:100%; max-height:400px; border-radius:8px; object-fit:contain; }
.gs-modal-fields { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:12px; }
.gs-modal-field { padding:10px; background:#f8fafc; border-radius:8px; }
.gs-modal-field-label { font-size:.75rem; text-transform:uppercase; color:var(--gs-text-light); font-weight:600; letter-spacing:.5px; }
.gs-modal-field-value { font-size:.95rem; margin-top:3px; word-break:break-word; }
.gs-modal-field.full-width { grid-column:1/-1; }

/* Formular-Modal */
.gs-form-modal { max-width:700px; }
.gs-form-footer {
    padding:14px 20px; background:#f8fafc; border-top:1px solid var(--gs-border);
    display:flex; justify-content:flex-end; gap:10px;
    border-radius:0 0 14px 14px; flex-shrink:0;
}
.gs-form-grid {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:14px;
}
.gs-form-group { display:flex; flex-direction:column; gap:4px; }
.gs-form-group.full-width { grid-column:1/-1; }
.gs-form-group label {
    font-size:.78rem; font-weight:600; text-transform:uppercase;
    color:var(--gs-text-light); letter-spacing:.5px;
}
.gs-form-group input,
.gs-form-group textarea {
    padding:10px 12px; border:2px solid var(--gs-border); border-radius:8px;
    font-size:.92rem; font-family:inherit; resize:vertical; transition:border-color .2s;
}
.gs-form-group input:focus,
.gs-form-group textarea:focus {
    outline:none; border-color:var(--gs-primary);
}

/* Formular-Verbesserungen */
.gs-form-hint {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 16px;
    font-size: .88rem;
    color: #1e40af;
    line-height: 1.5;
}
.gs-required-star {
    color: var(--gs-danger);
    font-weight: 700;
}
.gs-field-error {
    border-color: var(--gs-danger) !important;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, .15) !important;
    animation: gsShake .4s ease;
}
@keyframes gsShake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-4px); }
    40%, 80% { transform: translateX(4px); }
}
.gs-form-img-preview {
    margin-top: 6px;
    border-radius: 8px;
    background: #f8fafc;
    border: 1px dashed var(--gs-border);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60px;
    max-height: 160px;
}
.gs-form-img-preview img {
    max-width: 100%;
    max-height: 160px;
    object-fit: contain;
}
.gs-form-img-placeholder {
    color: #94a3b8;
    font-size: .82rem;
    padding: 16px;
}

/* Auto-ID Feld */
.gs-field-auto-id {
    background: #f0fdf4 !important;
    border-color: #86efac !important;
    color: #166534 !important;
    font-weight: 600;
    cursor: default;
}
.gs-field-auto-id:focus {
    box-shadow: 0 0 0 3px rgba(22, 163, 74, .15) !important;
}
.gs-auto-id-badge {
    display: inline-block;
    background: #16a34a;
    color: #fff;
    font-size: .65rem;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: .3px;
    vertical-align: middle;
    margin-left: 4px;
}

/* Tabelle: Neuer-Eintrag-Zeile */
.gs-table-td-addrow {
    padding: 0 !important;
    border-top: 2px solid var(--gs-border);
}
.gs-table-add-btn {
    width: 100%;
    padding: 10px 16px;
    background: none;
    border: none;
    color: var(--gs-success);
    font-size: .88rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, color .15s;
    text-align: center;
}
.gs-table-add-btn:hover {
    background: #f0fdf4;
    color: #15803d;
}

/* Loesch-Modal */
.gs-delete-modal { max-width:440px; }

/* Toast-Benachrichtigungen */
.gs-toast {
    position:fixed; top:20px; right:20px; z-index:200000;
    padding:14px 22px; border-radius:10px; color:#fff;
    font-size:.92rem; font-weight:500;
    box-shadow:0 8px 30px rgba(0,0,0,.2);
    animation:gsToastIn .3s ease, gsToastOut .3s ease 2.7s forwards;
}
.gs-toast.success { background:var(--gs-success); }
.gs-toast.error { background:var(--gs-danger); }
.gs-toast.info { background:var(--gs-primary); }

@keyframes gsToastIn { from { opacity:0; transform:translateY(-20px); } to { opacity:1; transform:translateY(0); } }
@keyframes gsToastOut { from { opacity:1; } to { opacity:0; transform:translateY(-20px); } }

/* Scroll Top */
.gs-scroll-top {
    position:fixed; bottom:24px; right:24px; width:44px; height:44px;
    border-radius:50%; background:var(--gs-primary); color:#fff; border:none;
    font-size:1.2rem; cursor:pointer; display:none; align-items:center;
    justify-content:center; box-shadow:0 4px 14px rgba(37,99,235,.35); z-index:99999;
}
.gs-scroll-top.show { display:flex; }

/* Notice */
.gs-notice {
    padding:20px; background:#fef3c7; border:1px solid #fcd34d;
    border-radius:8px; color:#92400e; text-align:center;
}

/* ===== Tabellenansicht ===== */
.gs-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0;
}
.gs-data-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--gs-card);
    border-radius: var(--gs-radius);
    overflow: hidden;
    box-shadow: var(--gs-shadow);
    font-size: .88rem;
}

/* Thead */
.gs-data-table thead {
    position: sticky;
    top: 0;
    z-index: 10;
}
.gs-data-table thead th {
    background: #f1f5f9;
    color: #475569;
    font-weight: 700;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .4px;
    padding: 11px 14px;
    text-align: left;
    white-space: nowrap;
    border-bottom: 2px solid var(--gs-border);
    user-select: none;
}

/* Sortierbare Spaltenköpfe */
.gs-table-th-sortable {
    cursor: pointer;
    transition: background .15s, color .15s;
    position: relative;
    padding-right: 24px !important;
}
.gs-table-th-sortable:hover {
    background: #e2e8f0 !important;
    color: var(--gs-primary);
}
.gs-table-th-sortable::after {
    content: '⇅';
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: .7rem;
    opacity: .4;
}
.gs-table-th-sortable.sorted::after {
    opacity: 1;
    color: var(--gs-primary);
}
.gs-table-th-sortable.sorted.asc::after {
    content: '▲';
}
.gs-table-th-sortable.sorted.desc::after {
    content: '▼';
}

/* Bild-Spalte Header */
.gs-table-th-img {
    width: 60px;
    min-width: 60px;
    text-align: center;
}

/* Aktionen-Spalte Header */
.gs-table-th-actions {
    width: 90px;
    min-width: 90px;
    text-align: center;
}

/* Tbody */
.gs-data-table tbody tr {
    transition: background .15s;
    border-bottom: 1px solid #f1f5f9;
}
.gs-data-table tbody tr:hover {
    background: #f8fafc;
}
.gs-data-table tbody tr:active {
    background: #eff6ff;
}
.gs-data-table tbody td {
    padding: 9px 14px;
    color: var(--gs-text);
    vertical-align: middle;
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.gs-data-table tbody td a {
    color: var(--gs-primary);
    text-decoration: none;
    word-break: break-all;
}
.gs-data-table tbody td a:hover {
    text-decoration: underline;
}

/* Bild-Zelle */
.gs-table-td-img {
    width: 60px;
    min-width: 60px;
    padding: 4px 8px !important;
    text-align: center;
}
.gs-table-td-img img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    border-radius: 6px;
    background: #f8fafc;
    vertical-align: middle;
}
.gs-table-no-img {
    font-size: 1.2rem;
    color: #cbd5e1;
}

/* Titel-Spalte */
.gs-table-td-name {
    font-weight: 600;
    color: var(--gs-text) !important;
}

/* Aktionen-Zelle */
.gs-table-td-actions {
    text-align: center;
    white-space: nowrap;
    width: 90px;
    min-width: 90px;
}
.gs-table-action {
    background: none;
    border: 1px solid var(--gs-border);
    border-radius: 6px;
    width: 30px;
    height: 30px;
    font-size: .75rem;
    cursor: pointer;
    margin: 0 2px;
    transition: background .15s, border-color .15s, transform .1s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.gs-table-action:hover {
    transform: scale(1.1);
}
.gs-table-action.edit:hover {
    background: #eff6ff;
    border-color: var(--gs-primary);
}
.gs-table-action.delete:hover {
    background: #fef2f2;
    border-color: var(--gs-danger);
}

/* Zebra-Stripes */
.gs-data-table tbody tr:nth-child(even) {
    background: #fafbfc;
}
.gs-data-table tbody tr:nth-child(even):hover {
    background: #f1f5f9;
}

/* Print */
@media print {
    .gs-toolbar, .gs-search-row, .gs-filter-row, .gs-controls,
    .gs-cat-nav, .gs-pagination, .gs-scroll-top, .gs-card-actions,
    .gs-btn-add, .gs-table-td-actions, .gs-table-th-actions { display:none!important; }
    .gs-data-table { box-shadow:none; font-size:.8rem; }
    .gs-data-table thead th { background:#f1f5f9 !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
}

@media (max-width:768px) {
    .gs-toolbar { gap:10px; padding:10px 12px; }
    .gs-filter-row { grid-template-columns:1fr 1fr; }
    .gs-grid { grid-template-columns:repeat(auto-fill,minmax(calc(150px * var(--gs-card-scale)),1fr)); }
    .gs-modal { max-width:95vw!important; }
    .gs-form-grid { grid-template-columns:1fr; }
    .gs-search-row { flex-direction:column; }
    .gs-data-table { font-size:.8rem; }
    .gs-data-table thead th { padding:8px 10px; font-size:.72rem; }
    .gs-data-table tbody td { padding:7px 10px; max-width:180px; }
    .gs-table-td-img img { width:36px; height:36px; }
}
@media (max-width:480px) {
    .gs-filter-row { grid-template-columns:1fr; }
    .gs-grid { grid-template-columns:repeat(auto-fill,minmax(calc(130px * var(--gs-card-scale)),1fr)); }
    .gs-data-table { font-size:.75rem; }
    .gs-data-table thead th { padding:6px 8px; }
    .gs-data-table tbody td { padding:5px 8px; max-width:140px; }
}
/* ★ Kategorie-Navigation: Scrollbar bei zu vielen Pills */
.gs-cat-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
    max-height: 120px;
    overflow-y: auto;
    padding: 4px 0;
}
.gs-cat-nav::-webkit-scrollbar { width: 6px; }
.gs-cat-nav::-webkit-scrollbar-thumb { background: var(--gs-border); border-radius: 3px; }

/* ★ Filter-Dropdowns: Bei zu vielen Optionen scrollbar */
.gs-filter-row select option {
    padding:4px 8px;
}

/* ===== Mehrbild-Galerie ===== */

/* Karten-Bildanzahl-Badge */
.gs-card-img-count {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,.65);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 10px;
    pointer-events: none;
    backdrop-filter: blur(4px);
}

/* Listenansicht: Bildanzahl */
.gs-list .gs-card-img-count {
    bottom: 4px;
    right: 4px;
    font-size: .6rem;
    padding: 1px 6px;
}

/* Tabellen-Zelle: Bildanzahl */
.gs-table-img-count {
    display: block;
    font-size: .6rem;
    color: var(--gs-text-light);
    margin-top: 2px;
    line-height: 1;
}

/* ===== Detail-Galerie ===== */
.gs-gallery {
    text-align: center;
    margin-bottom: 20px;
    position: relative;
}
.gs-gallery-main {
    position: relative;
    display: inline-block;
    width: 100%;
    max-width: 600px;
}
.gs-gallery-main img {
    width: 100%;
    max-height: 400px;
    object-fit: contain;
    border-radius: 8px;
    background: #f8fafc;
}
.gs-gallery-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.9);
    color: var(--gs-text);
    font-size: 1.1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
    transition: background .15s, transform .1s;
    z-index: 2;
}
.gs-gallery-nav:hover {
    background: #fff;
    transform: translateY(-50%) scale(1.08);
}
.gs-gallery-nav.prev { left: 8px; }
.gs-gallery-nav.next { right: 8px; }
.gs-gallery-nav:disabled {
    opacity: .3;
    cursor: default;
    transform: translateY(-50%);
}
.gs-gallery-counter {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.55);
    color: #fff;
    font-size: .75rem;
    font-weight: 600;
    padding: 3px 12px;
    border-radius: 10px;
    pointer-events: none;
    backdrop-filter: blur(4px);
}

/* Galerie-Thumbnails */
.gs-gallery-thumbs {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 10px;
    flex-wrap: wrap;
}
.gs-gallery-thumb {
    width: 52px;
    height: 52px;
    border-radius: 6px;
    object-fit: cover;
    cursor: pointer;
    border: 2px solid transparent;
    opacity: .6;
    transition: opacity .15s, border-color .15s;
    background: #f1f5f9;
}
.gs-gallery-thumb:hover {
    opacity: .85;
}
.gs-gallery-thumb.active {
    border-color: var(--gs-primary);
    opacity: 1;
}

/* ===== Mehrbild-Formular ===== */
.gs-form-img-hint {
    font-size: .75rem;
    color: var(--gs-text-light);
    margin-top: 4px;
    line-height: 1.4;
}

/* Mehrbild-Vorschau Grid */
.gs-form-img-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 8px;
    margin-top: 8px;
}
.gs-form-img-grid-item {
    position: relative;
    aspect-ratio: 1/1;
    border-radius: 8px;
    overflow: hidden;
    background: #f8fafc;
    border: 1px solid var(--gs-border);
}
.gs-form-img-grid-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.gs-form-img-grid-item .gs-form-img-remove {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: none;
    background: rgba(220,38,38,.85);
    color: #fff;
    font-size: .65rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .15s;
    line-height: 1;
}
.gs-form-img-grid-item:hover .gs-form-img-remove {
    opacity: 1;
}

/* Lightbox-Overlay für Großansicht */
.gs-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.9);
    z-index: 300000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    cursor: zoom-out;
}
.gs-lightbox.open {
    display: flex;
}
.gs-lightbox img {
    max-width: 95vw;
    max-height: 95vh;
    object-fit: contain;
    border-radius: 4px;
    cursor: default;
}
.gs-lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.15);
    color: #fff;
    font-size: 1.4rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
}
.gs-lightbox-nav:hover { background: rgba(255,255,255,.3); }
.gs-lightbox-nav.prev { left: 16px; }
.gs-lightbox-nav.next { right: 16px; }
.gs-lightbox-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.15);
    color: #fff;
    font-size: 1.3rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
}
.gs-lightbox-close:hover { background: rgba(255,255,255,.3); }
.gs-lightbox-counter {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    color: rgba(255,255,255,.7);
    font-size: .85rem;
    font-weight: 500;
}

/* Drucken: Galerie als alle Bilder untereinander */
@media print {
    .gs-gallery-nav,
    .gs-gallery-thumbs,
    .gs-gallery-counter,
    .gs-card-img-count { display: none !important; }
    .gs-gallery-main img { max-height: none; }
}