/* DieSchule Daten-Tresor – Frontend CSS */
:root {
    --kgds-primary: #0f172a;
    --kgds-accent:  #1e40af;
    --kgds-border:  #e2e8f0;
    --kgds-muted:   #64748b;
    --kgds-green:   #166534;
    --kgds-radius:  10px;
    --kgds-shadow:  0 8px 40px rgba(0,0,0,.18);
}
.kgds-wrap { font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; color:var(--kgds-primary); width:100%; box-sizing:border-box; }

/* Header */
.kgds-header { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.kgds-title  { margin:0; font-size:20px; font-weight:700; color:var(--kgds-accent); }
.kgds-count  { font-size:12px; background:#eff6ff; color:var(--kgds-accent); padding:3px 10px; border-radius:20px; font-weight:600; }

/* Toolbar */
.kgds-toolbar     { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; margin-bottom:16px; }
.kgds-tabs        { display:flex; gap:4px; flex-wrap:wrap; }
.kgds-tab         { background:none; border:1.5px solid var(--kgds-border); border-radius:20px; padding:5px 14px; font-size:13px; cursor:pointer; color:var(--kgds-muted); transition:all .15s; }
.kgds-tab:hover   { border-color:var(--kgds-accent); color:var(--kgds-accent); }
.kgds-tab-active  { background:var(--kgds-accent); color:#fff !important; border-color:var(--kgds-accent) !important; }
#kgds-search      { border:1.5px solid var(--kgds-border); border-radius:8px; padding:7px 14px; font-size:13px; min-width:200px; }
#kgds-search:focus { border-color:var(--kgds-accent); outline:none; }

/* Grid */
#kgds-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px; }
.kgds-card-item {
    background:#fff; border:1.5px solid var(--kgds-border);
    border-radius:var(--kgds-radius); padding:16px;
    cursor:pointer; transition:all .15s;
}
.kgds-card-item:hover { border-color:var(--kgds-accent); box-shadow:0 2px 12px rgba(30,64,175,.10); transform:translateY(-1px); }
.kgds-card-header { display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px; }
.kgds-card-name   { font-weight:700; font-size:14px; }
.kgds-kat-badge   { display:inline-block; padding:2px 8px; border-radius:20px; font-size:10px; font-weight:700; background:#eff6ff; color:var(--kgds-accent); white-space:nowrap; }
.kgds-card-url    { font-size:12px; color:var(--kgds-accent); text-decoration:none; display:block; margin-bottom:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.kgds-card-url:hover { text-decoration:underline; }
.kgds-card-user   { font-size:12px; color:var(--kgds-muted); margin-bottom:10px; }
.kgds-view-btn    { width:100%; background:var(--kgds-accent); color:#fff; border:none; border-radius:7px; padding:7px; font-size:12px; font-weight:600; cursor:pointer; transition:background .15s; }
.kgds-view-btn:hover { background:#1e3a8a; }
.kgds-empty { grid-column:1/-1; text-align:center; padding:3rem; color:var(--kgds-muted); font-style:italic; }

/* Overlay & Modal */
.kgds-overlay {
    position:fixed !important; top:0 !important; left:0 !important;
    width:100% !important; height:100% !important;
    background:rgba(0,0,0,.55) !important; z-index:999990 !important;
}
.kgds-modal {
    position:fixed !important;
    top:50% !important; left:50% !important;
    transform:translate(-50%,-50%) !important;
    width:560px !important; max-width:95vw !important; max-height:88vh !important;
    background:#fff !important; border-radius:14px !important;
    box-shadow:var(--kgds-shadow) !important;
    z-index:999999 !important; overflow-y:auto !important;
    box-sizing:border-box !important;
}
.kgds-modal-inner  { padding:28px; }
.kgds-modal-loading { text-align:center; padding:3rem; color:var(--kgds-muted); }
.hidden { display:none !important; }

/* Modal Inhalt */
.kgds-modal-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--kgds-border); }
.kgds-modal-title  { font-size:18px; font-weight:700; margin:0 0 4px; }
.kgds-modal-close  { background:none; border:none; font-size:20px; cursor:pointer; color:var(--kgds-muted); padding:0; flex-shrink:0; }

.kgds-section       { margin-bottom:18px; }
.kgds-section-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--kgds-accent); margin:0 0 10px; padding-bottom:5px; border-bottom:1px solid var(--kgds-border); }

.kgds-field-list    { display:grid; grid-template-columns:110px 1fr; gap:6px 12px; font-size:13px; }
.kgds-fl-label      { color:var(--kgds-muted); font-weight:500; align-self:center; }
.kgds-fl-value      { display:flex; align-items:center; gap:8px; font-weight:500; min-width:0; word-break:break-all; }
.kgds-pw-value      { font-family:monospace; background:#fffbeb; padding:3px 8px; border-radius:5px; font-size:13px; flex:1; }
.kgds-copy-btn      { background:none; border:1px solid var(--kgds-border); border-radius:5px; padding:3px 7px; cursor:pointer; font-size:13px; color:var(--kgds-muted); transition:all .15s; white-space:nowrap; }
.kgds-copy-btn:hover { background:#eff6ff; border-color:var(--kgds-accent); color:var(--kgds-accent); }
.kgds-open-btn      { background:var(--kgds-accent); color:#fff; border:none; border-radius:7px; padding:8px 16px; font-size:13px; font-weight:600; cursor:pointer; text-decoration:none; display:inline-block; }
.kgds-open-btn:hover { background:#1e3a8a; }
.kgds-notiz         { font-size:13px; color:#475569; white-space:pre-wrap; background:#f8fafc; border-radius:7px; padding:10px 12px; border:1px solid var(--kgds-border); }

@media (max-width:600px) {
    #kgds-grid { grid-template-columns:1fr; }
    .kgds-modal { width:98vw !important; max-height:94vh !important; }
    .kgds-toolbar { flex-direction:column; align-items:flex-start; }
    #kgds-search { width:100%; box-sizing:border-box; }
}

/* ── Neu-Button ── */
.kgds-btn-new { background:var(--kgds-accent); color:#fff; border:none; border-radius:8px; padding:8px 16px; font-size:13px; font-weight:600; cursor:pointer; }
.kgds-btn-new:hover { background:#1e3a8a; }

/* ── Card-Aktionen ── */
.kgds-card-actions { display:flex; gap:6px; margin-top:8px; }
.kgds-card-actions .kgds-view-btn { flex:1; }
.kgds-card-actions .kgds-edit-btn,
.kgds-card-actions .kgds-del-btn  { background:none; border:1.5px solid var(--kgds-border); border-radius:7px; padding:6px 10px; cursor:pointer; font-size:14px; transition:background .15s; }
.kgds-card-actions .kgds-edit-btn:hover { background:#eff6ff; border-color:var(--kgds-accent); }
.kgds-card-actions .kgds-del-btn:hover  { background:#fef2f2; border-color:#dc2626; }

/* ── Modal Toolbar ── */
.kgds-modal-toolbar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.kgds-btn-secondary { background:none; border:1.5px solid var(--kgds-accent); color:var(--kgds-accent); border-radius:7px; padding:7px 14px; font-size:13px; font-weight:600; cursor:pointer; }
.kgds-btn-secondary:hover { background:#eff6ff; }
.kgds-btn-danger    { background:none; border:1.5px solid #dc2626; color:#dc2626; border-radius:7px; padding:7px 14px; font-size:13px; font-weight:600; cursor:pointer; }
.kgds-btn-danger:hover { background:#fef2f2; }
.kgds-btn-primary   { background:var(--kgds-accent); color:#fff; border:none; border-radius:8px; padding:9px 20px; font-size:14px; font-weight:600; cursor:pointer; }
.kgds-btn-primary:hover { background:#1e3a8a; }
.kgds-btn-ghost     { background:none; border:1.5px solid var(--kgds-border); color:#475569; border-radius:8px; padding:9px 16px; font-size:14px; cursor:pointer; }

/* ── Formular im Modal ── */
.kgds-form-section-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--kgds-accent); margin:14px 0 8px; padding-bottom:5px; border-bottom:1px solid var(--kgds-border); }
.kgds-form-grid   { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.kgds-form-group  { margin-bottom:10px; min-width:0; }
.kgds-form-group label { display:block; font-size:12px; font-weight:600; color:#475569; margin-bottom:4px; }
.kgds-form-group input,
.kgds-form-group select,
.kgds-form-group textarea { width:100%; box-sizing:border-box; border:1.5px solid var(--kgds-border); border-radius:6px; padding:7px 10px; font-size:13px; }
.kgds-form-group input:focus,
.kgds-form-group textarea:focus { border-color:var(--kgds-accent); outline:none; }
.kgds-user-list { max-height:220px; overflow-y:auto; border:1.5px solid var(--kgds-border); border-radius:8px; margin-bottom:4px; }
.kgds-user-row  { display:flex; align-items:center; gap:8px; padding:8px 10px; border-bottom:1px solid #f8fafc; cursor:pointer; }
.kgds-user-row:last-child { border-bottom:none; }
.kgds-user-row:hover { background:#f8fafc; }
.kgds-user-admin { background:#f0fdf4; }
.kgds-user-info  { display:flex; flex-direction:column; }
.kgds-user-info strong { font-size:13px; }
.kgds-user-email { font-size:11px; color:#94a3b8; }
.kgds-admin-label { font-size:10px; background:#dcfce7; color:#166534; padding:1px 5px; border-radius:10px; font-weight:700; display:inline-block; margin-left:4px; }
@media (max-width:600px) { .kgds-form-grid { grid-template-columns:1fr; } }

/* ── Owner Badge ── */
.kgds-owner-badge { display:inline-block; font-size:10px; font-weight:700; background:#dbeafe; color:#1e40af; padding:2px 7px; border-radius:10px; margin-bottom:5px; }
