/* Parta Security — Stylesheet v2.0 */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --oranje:   #f49110;
  --oranje-d: #d97c0a;
  --blauw:    #3871c0;
  --blauw-d:  #2d5fa3;
  --donker:   #111827;
  --tekst:    #1f2937;
  --muted:    #6b7280;
  --rand:     #e5e7eb;
  --bg:       #f9fafb;
  --wit:      #ffffff;
  --groen:    #059669;
  --radius:   10px;
  --shadow:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
}

.ps-wrap { font-family: 'Inter', -apple-system, sans-serif; color: var(--tekst); min-height: 100vh; background: var(--bg); }

/* ── HEADER ── */
.ps-header { background: var(--donker); display: flex; align-items: center; padding: 0 28px; height: 62px; gap: 20px; border-bottom: 3px solid var(--oranje); }
.ps-logo-img { height: 36px; width: auto; object-fit: contain; }
.ps-header-midden { flex: 1; font-size: 14px; font-weight: 500; color: rgba(255,255,255,.6); padding-left: 20px; border-left: 1px solid rgba(255,255,255,.1); }
.ps-header-user { font-size: 13px; color: rgba(255,255,255,.65); white-space: nowrap; }
.ps-header-user a { color: var(--oranje); text-decoration: none; margin-left: 6px; }
.ps-header-user a:hover { text-decoration: underline; }

/* ── NAV ── */
.ps-nav { display: flex; background: var(--wit); border-bottom: 1px solid var(--rand); padding: 0 28px; gap: 2px; }
.ps-nav-item { display: inline-block; padding: 14px 18px; font-size: 14px; font-weight: 500; color: var(--muted); text-decoration: none; border-bottom: 3px solid transparent; margin-bottom: -1px; transition: all .15s; }
.ps-nav-item:hover { color: var(--blauw); }
.ps-nav-actief { color: var(--blauw); border-bottom-color: var(--blauw); }

/* ── INHOUD ── */
.ps-inhoud { max-width: 1100px; margin: 0 auto; padding: 32px 28px 64px; }

/* ── MELDINGEN ── */
.ps-melding { padding: 12px 18px; border-radius: var(--radius); margin-bottom: 20px; font-size: 14px; font-weight: 500; }
.ps-melding-ok { background: #d1fae5; color: #065f46; border: 1px solid #a7f3d0; }

/* ── SECTIE HEADER ── */
.ps-sectie-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.ps-sectie-header h2 { font-size: 20px; font-weight: 700; color: var(--donker); }
.ps-welkom { font-size: 16px; margin-bottom: 24px; color: var(--muted); }
.ps-welkom strong { color: var(--tekst); }
.ps-project-titel { font-size: 22px; font-weight: 700; color: var(--donker); margin-bottom: 20px; }
.ps-sectie-kop { font-size: 14px; font-weight: 700; color: var(--blauw); text-transform: uppercase; letter-spacing: .4px; margin-bottom: 18px; padding-bottom: 10px; border-bottom: 2px solid var(--oranje); }
.ps-subtitel { font-size: 14px; font-weight: 600; color: var(--donker); margin: 16px 0 10px; }
.ps-uitleg { font-size: 13px; color: var(--muted); margin-bottom: 16px; line-height: 1.6; }
.ps-terug { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); text-decoration: none; margin-bottom: 16px; }
.ps-terug:hover { color: var(--blauw); }

/* ── KAARTEN ── */
.ps-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 18px; margin-bottom: 24px; }
.ps-kaart { background: var(--wit); border: 1px solid var(--rand); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow); margin-bottom: 20px; }
.ps-kaart:last-child { margin-bottom: 0; }
.ps-kaart-nieuw { background: var(--wit); border: 1.5px dashed var(--blauw); }
.ps-kaart-archief { opacity: .75; }
.ps-kaart-top { margin-bottom: 10px; }
.ps-kaart-naam { font-size: 17px; font-weight: 700; color: var(--donker); margin-bottom: 10px; }
.ps-kaart-meta { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; font-size: 13px; color: var(--muted); }
.ps-indienen-kaart { border-left: 4px solid var(--oranje); }
.ps-rapport-blok { border-left: 4px solid var(--blauw); margin-bottom: 12px; }
.ps-rapport-tijd { font-size: 11px; font-weight: 700; color: var(--oranje); text-transform: uppercase; letter-spacing: .4px; margin-bottom: 6px; }
.ps-rapport-tekst { font-size: 14px; line-height: 1.7; white-space: pre-wrap; }
.ps-uren-totaal { color: var(--oranje); font-weight: 700; font-size: 14px; }
.ps-mw-aantal { color: var(--muted); font-size: 13px; font-weight: 400; }

/* ── BADGES ── */
.ps-badge { display: inline-block; font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 20px; }
.ps-badge-groen { background: #d1fae5; color: #065f46; }
.ps-badge-blauw { background: #dbeafe; color: #1d4ed8; }
.ps-badge-grijs     { background: #f3f4f6; color: #6b7280; }
.ps-badge-antraciet { background: #374151; color: #fff; }

/* ── KNOPPEN ── */
.ps-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 20px; border-radius: 8px; font-size: 14px; font-weight: 600; border: none; cursor: pointer; text-decoration: none; font-family: 'Inter', sans-serif; transition: all .15s; }
.ps-btn-primair { background: var(--oranje); color: #fff; }
.ps-btn-primair:hover { background: var(--oranje-d); }
.ps-btn-secundair { background: var(--blauw); color: #fff; }
.ps-btn-secundair:hover { background: var(--blauw-d); }
.ps-btn-grijs { background: var(--bg); color: var(--muted); border: 1px solid var(--rand); }
.ps-btn-grijs:hover { background: var(--rand); }
.ps-btn-klein { padding: 5px 12px; font-size: 12px; }
.ps-btn-volledig { width: 100%; }
.ps-btn-verwijder-rij { background: none; border: none; color: var(--muted); font-size: 18px; cursor: pointer; padding: 4px 8px; border-radius: 4px; line-height: 1; }
.ps-btn-verwijder-rij:hover { background: #fee2e2; color: #dc2626; }
.ps-btn-icon-verwijder { background: none; border: none; color: var(--muted); font-size: 16px; cursor: pointer; padding: 2px 6px; border-radius: 4px; }
.ps-btn-icon-verwijder:hover { background: #fee2e2; color: #dc2626; }

/* ── FORMULIEREN ── */
.ps-form-rij { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.ps-veld { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.ps-veld-breed { grid-column: 1 / -1; }
.ps-veld label { font-size: 12px; font-weight: 600; color: var(--donker); text-transform: uppercase; letter-spacing: .3px; }
.ps-veld input[type="text"],
.ps-veld input[type="email"],
.ps-veld input[type="date"],
.ps-veld input[type="time"],
.ps-veld select,
.ps-veld textarea,
.ps-form-rij input,
.ps-form-rij select,
.ps-form-rij textarea { padding: 9px 13px; border: 1.5px solid var(--rand); border-radius: 8px; font-size: 14px; font-family: 'Inter', sans-serif; color: var(--tekst); background: var(--wit); width: 100%; transition: border-color .15s; }
.ps-veld input:focus, .ps-veld select:focus, .ps-veld textarea:focus,
.ps-form-rij input:focus, .ps-form-rij select:focus { outline: none; border-color: var(--blauw); box-shadow: 0 0 0 3px rgba(56,113,192,.1); }
.ps-veld textarea { resize: vertical; min-height: 140px; }
.ps-form-acties { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 6px; }

/* ── ROOSTER BUILDER ── */
.ps-rooster-toevoegen { background: var(--bg); border-radius: 8px; padding: 18px; margin-bottom: 16px; }
.ps-checkbox-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; margin-top: 6px; }
.ps-checkbox-item { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border: 1.5px solid var(--rand); border-radius: 7px; cursor: pointer; font-size: 13px; font-weight: 500; transition: all .15s; background: var(--wit); }
.ps-checkbox-item:hover { border-color: var(--blauw); background: #eff6ff; }
.ps-checkbox-item input { accent-color: var(--blauw); width: 15px; height: 15px; }
.ps-dienst-rijen { display: flex; flex-direction: column; gap: 8px; margin: 14px 0; }
.ps-dienst-rij { display: grid; grid-template-columns: 1fr 120px 120px 48px 32px; gap: 10px; align-items: center; background: var(--wit); border: 1px solid var(--rand); border-radius: 8px; padding: 10px 14px; }
.ps-dienst-rij input { padding: 7px 10px; border: 1.5px solid var(--rand); border-radius: 7px; font-size: 13px; font-family: 'Inter', sans-serif; color: var(--tekst); width: 100%; }
.ps-dienst-rij input:focus { outline: none; border-color: var(--blauw); }
.ps-dienst-uren { font-size: 12px; font-weight: 700; color: var(--blauw); text-align: center; }
.ps-rooster-acties { display: flex; gap: 10px; }
.ps-rooster-overzicht { margin-top: 24px; border-top: 1px solid var(--rand); padding-top: 20px; }

/* ── TABELLEN ── */
.ps-tabel { width: 100%; border-collapse: collapse; font-size: 13px; }
.ps-tabel th { background: var(--donker); color: #fff; text-align: left; padding: 10px 14px; font-size: 12px; font-weight: 600; letter-spacing: .3px; }
.ps-tabel td { padding: 10px 14px; border-bottom: 1px solid var(--rand); vertical-align: middle; }
.ps-tabel tr:hover td { background: var(--bg); }
.ps-tabel-klein { width: 100%; border-collapse: collapse; font-size: 13px; margin: 10px 0; }
.ps-tabel-klein th { background: var(--bg); color: var(--muted); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .3px; padding: 6px 10px; border-bottom: 1px solid var(--rand); }
.ps-tabel-klein td { padding: 7px 10px; border-bottom: 1px solid var(--rand); color: var(--tekst); }

/* ── FILTER FORM ── */
.ps-filter-form { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 20px; align-items: center; }
.ps-filter-form select, .ps-filter-form input { padding: 8px 12px; border: 1.5px solid var(--rand); border-radius: 8px; font-size: 13px; font-family: 'Inter', sans-serif; color: var(--tekst); background: var(--wit); }

/* ── LEEG ── */
.ps-leeg { text-align: center; padding: 48px 20px; color: var(--muted); font-size: 14px; background: var(--wit); border: 1px dashed var(--rand); border-radius: var(--radius); margin-bottom: 20px; }

/* ── RESPONSIVE ── */
@media (max-width: 640px) {
  .ps-form-rij { grid-template-columns: 1fr; }
  .ps-grid { grid-template-columns: 1fr; }
  .ps-inhoud { padding: 20px 16px 48px; }
  .ps-header { padding: 0 16px; }
  .ps-header-midden { display: none; }
  .ps-nav { padding: 0 16px; overflow-x: auto; }
  .ps-dienst-rij { grid-template-columns: 1fr 1fr; gap: 8px; }
}

/* ── MEDEWERKER BLOKKEN ── */
.ps-mw-blok { background:#f9fafb; border:1.5px solid #e5e7eb; border-radius:10px; margin-bottom:14px; overflow:hidden; }
.ps-mw-blok-header { display:flex; align-items:center; gap:10px; padding:12px 16px; background:#f3f4f6; border-bottom:1px solid #e5e7eb; }
.ps-mw-select { flex:1; padding:8px 12px; border:1.5px solid #e5e7eb; border-radius:7px; font-size:14px; font-family:'Inter',sans-serif; background:#fff; }
.ps-mw-select:focus { outline:none; border-color:#3871c0; }
.ps-btn-verwijder-mw { background:none; border:none; font-size:20px; color:#9ca3af; cursor:pointer; padding:4px 8px; border-radius:4px; line-height:1; }
.ps-btn-verwijder-mw:hover { background:#fee2e2; color:#dc2626; }
.ps-dienst-lijst { padding:12px 16px; display:flex; flex-direction:column; gap:8px; }
.ps-dienst-rij { display:grid; grid-template-columns:1fr 110px 110px 50px auto; gap:10px; align-items:end; background:#fff; border:1px solid #e5e7eb; border-radius:8px; padding:10px 12px; }
.ps-dienst-rij .ps-veld { margin:0; }
.ps-dienst-rij .ps-veld label { font-size:11px; }
.ps-dienst-rij .ps-veld input { padding:7px 10px; font-size:13px; }
.ps-dienst-uren-label { display:flex; align-items:center; justify-content:center; }
.ps-uren-waarde { font-size:13px; font-weight:700; color:#3871c0; background:#dbeafe; padding:4px 8px; border-radius:5px; }
.ps-dienst-acties { display:flex; gap:4px; align-items:center; }
.ps-btn-kopieer { background:none; border:1.5px solid #d1d5db; border-radius:6px; font-size:14px; color:#6b7280; cursor:pointer; padding:5px 8px; transition:all .15s; }
.ps-btn-kopieer:hover { border-color:#3871c0; color:#3871c0; background:#eff6ff; }
.ps-btn-datum-toevoegen { display:inline-flex; align-items:center; gap:5px; margin:8px 16px 12px; background:none; border:1.5px dashed #3871c0; color:#3871c0; font-size:13px; font-weight:600; padding:6px 14px; border-radius:7px; cursor:pointer; font-family:'Inter',sans-serif; transition:all .15s; }
.ps-btn-datum-toevoegen:hover { background:#3871c0; color:#fff; }
.ps-sectie-blok { background:#f9fafb; border:1px solid #e5e7eb; border-radius:10px; padding:20px; margin-bottom:18px; }
.ps-kaart-titel-groot { font-size:18px; font-weight:700; color:#111827; margin-bottom:20px; }
.ps-leeg-inline { padding:16px; background:#fff3cd; border:1px solid #ffc107; border-radius:7px; font-size:13px; color:#856404; margin:8px 0; }
.ps-uitleg { font-size:13px; color:#6b7280; margin-bottom:16px; line-height:1.6; }
.ps-ps-btn-groot { padding:12px 28px; font-size:15px; }
.ps-uren-samenvatting { display:flex; gap:24px; margin-bottom:14px; font-size:14px; color:#6b7280; }
.ps-uren-samenvatting strong { color:#111827; }
.ps-uren-sub { font-size:12px; font-weight:400; color:#6b7280; display:block; margin-top:2px; }
.ps-rooster-overzicht { margin-top:20px; border-top:1px solid #e5e7eb; padding-top:16px; }

/* ── MEDEWERKER BUILDER JS TEMPLATE ── */
#mw-template { display:none; }

/* ── NAV MET ACTIEKNOP ── */
.ps-nav-wrap { display:flex; align-items:center; justify-content:space-between; background:#fff; border-bottom:1px solid #e5e7eb; padding-right:20px; }
.ps-btn-nieuw-project { background: var(--oranje); color: #fff !important; font-weight: 600; font-size: 14px; padding: 8px 18px; border-radius: 8px; text-decoration: none; white-space: nowrap; transition: background .2s; }
.ps-btn-nieuw-project:hover { background: var(--oranje-d); color: #fff !important; }
.ps-nav-btn { margin:10px 0; font-size:13px; padding:8px 16px; white-space:nowrap; }

/* ── NAV ORANJE ITEM ── */
.ps-nav-oranje { color: var(--oranje) !important; font-weight: 600; }
.ps-nav-oranje:hover { color: var(--oranje-d) !important; }
.ps-nav-oranje.ps-nav-actief { border-bottom-color: var(--oranje); color: var(--oranje) !important; }
.ps-pagina-titel { font-size: 20px; font-weight: 700; color: #111827; margin-bottom: 20px; }
.ps-btn-groot { padding: 12px 28px; font-size: 15px; }
.ps-melding-fout { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }

/* ── CONFLICT MELDING ── */
.ps-conflict-melding {
    background: #fff3cd;
    border: 1px solid #f49110;
    border-left: 4px solid #f49110;
    color: #856404;
    padding: 8px 12px;
    border-radius: 0 6px 6px 0;
    font-size: 13px;
    font-weight: 500;
    margin: 4px 0 8px;
}

/* Rode verwijder knop */
.ps-btn-rood { background: #dc2626; color: #fff; border: none; }
.ps-btn-rood:hover { background: #b91c1c; color: #fff; }
