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

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

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

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

/* Overlay & Modal */
.pam-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;
}
.pam-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(--pam-shadow) !important;
    z-index:999999 !important; overflow-y:auto !important;
    box-sizing:border-box !important;
}
.pam-modal-inner  { padding:28px; }
.pam-modal-loading { text-align:center; padding:3rem; color:var(--pam-muted); }
.hidden { display:none !important; }

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

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

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

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

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

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

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

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

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

/* ══════════════════════════════════════════════
   v1.4.0 – Ansicht umschalten + Datei-Anhänge
══════════════════════════════════════════════ */

/* View-Toggle */
.pam-view-toggle { display:inline-flex !important; border:1.5px solid var(--pam-border); border-radius:8px; overflow:hidden; }
.pam-vt-btn {
    background:#fff !important; border:none !important; box-shadow:none !important;
    padding:6px 14px !important; margin:0 !important; height:auto !important;
    font-size:13px !important; font-weight:600 !important; line-height:1.2 !important;
    cursor:pointer; color:var(--pam-muted) !important; text-transform:none !important;
    transition:all .15s; border-radius:0 !important; min-width:0 !important; width:auto !important;
}
.pam-vt-btn:hover  { background:#eff6ff !important; color:var(--pam-accent) !important; }
.pam-vt-active     { background:var(--pam-accent) !important; color:#fff !important; }

/* Listenansicht (Tabelle) */
#pam-grid[data-view="list"] { display:block; }
.pam-list-table { width:100% !important; border-collapse:collapse !important; font-size:13px; background:#fff; border:1.5px solid var(--pam-border); border-radius:var(--pam-radius); overflow:hidden; margin:0 !important; }
.pam-list-table thead th { text-align:left; font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--pam-muted); background:#f8fafc !important; padding:9px 12px !important; border:none; border-bottom:1.5px solid var(--pam-border); }
.pam-list-table td { padding:9px 12px !important; border:none; border-bottom:1px solid var(--pam-border); vertical-align:middle; background:transparent; }
.pam-list-table tbody tr:last-child td { border-bottom:none; }
.pam-list-table tbody tr:nth-child(even) { background:transparent !important; }
.pam-row { cursor:pointer; transition:background .12s; }
.pam-row:hover { background:#f8fafc !important; }
.pam-td-name { font-weight:600; }
.pam-td-user { color:var(--pam-muted); }
.pam-td-actions { text-align:left; white-space:nowrap; width:1%; padding-right:14px !important; }
.pam-td-actions button {
    background:#fff !important; border:1.5px solid var(--pam-border) !important; border-radius:6px !important;
    padding:5px 9px !important; cursor:pointer; font-size:14px; margin:0 4px 0 0 !important;
    width:auto !important; min-width:0 !important; box-shadow:none !important; color:var(--pam-primary) !important;
}
.pam-td-actions button:last-child { margin-right:0 !important; }
.pam-td-actions .pam-view-btn { background:var(--pam-accent) !important; color:#fff !important; border-color:var(--pam-accent) !important; }
.pam-td-actions .pam-edit-btn:hover { background:#eff6ff !important; border-color:var(--pam-accent) !important; }
.pam-td-actions .pam-del-btn:hover  { background:#fef2f2 !important; border-color:#dc2626 !important; }
.pam-view-btn-sm { width:auto !important; padding:5px 9px !important; }
.pam-th-act { width:1%; }

@media (max-width:600px) {
    #pam-grid[data-view="list"] { overflow-x:auto; }
    .pam-list-table .pam-th-kat,  .pam-list-table .pam-td-kat,
    .pam-list-table .pam-th-user, .pam-list-table .pam-td-user,
    .pam-list-table .pam-th-url,  .pam-list-table .pam-td-url { display:none !important; }
    .pam-list-table .pam-td-name { max-width:55vw; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
    .pam-td-actions button { padding:6px 10px !important; font-size:15px; }
    .pam-vt-btn { padding:6px 10px !important; }
}

/* Datei-Anhänge */
.pam-files-loading { font-size:13px; color:var(--pam-muted); }
.pam-file-empty    { font-size:13px; color:var(--pam-muted); font-style:italic; margin:0 0 8px; }
.pam-file-ul       { list-style:none; margin:0 0 10px; padding:0; display:flex; flex-direction:column; gap:6px; }
.pam-file-li       { display:flex; align-items:center; gap:8px; background:#f8fafc; border:1px solid var(--pam-border); border-radius:7px; padding:7px 10px; }
.pam-file-icon     { font-size:16px; }
.pam-file-dl       { flex:1; text-align:left; background:none; border:none; color:var(--pam-accent); font-size:13px; font-weight:600; cursor:pointer; text-decoration:none; padding:0; word-break:break-all; }
.pam-file-dl:hover { text-decoration:underline; }
.pam-file-size     { font-size:11px; color:var(--pam-muted); white-space:nowrap; }
.pam-file-del      { background:none; border:none; cursor:pointer; font-size:14px; opacity:.6; }
.pam-file-del:hover { opacity:1; }
.pam-uploader      { display:flex; align-items:center; flex-wrap:wrap; gap:8px; margin-top:6px; }
.pam-file-input    { position:absolute; width:1px; height:1px; opacity:0; overflow:hidden; }
.pam-file-label    { cursor:pointer; display:inline-block; }
.pam-file-hint     { font-size:11px; color:var(--pam-muted); }
.pam-upload-status { font-size:12px; color:var(--pam-green); font-weight:600; width:100%; }

/* ── Vorschau-Lightbox (Bilder / PDF) ── */
.pam-file-prev { background:none; border:none; cursor:pointer; font-size:14px; opacity:.7; }
.pam-file-prev:hover { opacity:1; }
.pam-pv-overlay { position:fixed !important; top:0 !important; left:0 !important; width:100% !important; height:100% !important; background:rgba(0,0,0,.75) !important; z-index:1000000 !important; }
.pam-pv-box {
    position:fixed !important; top:50% !important; left:50% !important;
    transform:translate(-50%,-50%) !important;
    width:90vw !important; max-width:900px !important; height:88vh !important;
    background:#fff !important; border-radius:12px !important;
    box-shadow:var(--pam-shadow) !important; z-index:1000001 !important;
    display:flex !important; flex-direction:column !important; overflow:hidden !important;
}
.pam-pv-bar  { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 16px; border-bottom:1px solid var(--pam-border); }
.pam-pv-name { font-weight:600; font-size:14px; word-break:break-all; }
.pam-pv-dl   { font-size:13px; color:var(--pam-accent); text-decoration:none; font-weight:600; margin-right:12px; white-space:nowrap; }
.pam-pv-dl:hover { text-decoration:underline; }
.pam-pv-close { background:none; border:none; font-size:20px; cursor:pointer; color:var(--pam-muted); }
.pam-pv-body { flex:1; overflow:auto; display:flex; align-items:center; justify-content:center; background:#f1f5f9; }
.pam-pv-loading { color:var(--pam-muted); font-size:14px; padding:2rem; }
.pam-pv-img  { max-width:100%; max-height:100%; object-fit:contain; display:block; }
.pam-pv-frame { width:100%; height:100%; border:none; }

@media (max-width:600px) {
    .pam-pv-box { width:98vw !important; height:92vh !important; }
}
