:root { 
    --pit-dark-green: #183c1e; 
    --pit-light-green: #4dae3a; 
    --pit-black: #1c1c1c; 
    --font-title: 'Quicksand', sans-serif; 
    --font-subtitle: 'Oxygen', sans-serif; 
    --font-text: 'Open Sans', sans-serif; 
    --bg-color: #f4f7f6; 
    --card-bg: #ffffff; 
    --border-color: #e0e0e0; 
    --color-standard: var(--pit-light-green); 
    --color-config: #007bff; 
    --color-dev: #fd7e14; 
    --color-custom: #6f42c1; 
    --color-no: #dc3545; 
}
body { font-family: var(--font-text); font-weight: 300; background-color: var(--bg-color); color: var(--pit-black); margin: 0; padding: 0; display: flex; height: 100vh; }
.view { display: none; width: 100%; height: 100%; } 
.view.active { display: flex; }

#login-view { justify-content: center; align-items: center; background-color: var(--pit-dark-green); }
.login-card { background: var(--card-bg); padding: 40px; border-radius: 8px; box-shadow: 0 10px 25px rgba(0,0,0,0.2); text-align: center; width: 350px; }
.login-card img { max-width: 150px; margin-bottom: 20px; } 
.login-card h2 { font-family: var(--font-title); color: var(--pit-dark-green); margin-top: 0; margin-bottom: 20px; }
.login-input { width: 100%; padding: 12px; margin-bottom: 20px; border: 1px solid var(--border-color); border-radius: 4px; box-sizing: border-box; font-family: var(--font-text); font-size: 1em; text-align: left; }

.sidebar { width: 280px; background-color: var(--card-bg); border-right: 1px solid var(--border-color); display: flex; flex-direction: column; flex-shrink: 0; }
.sidebar-header { padding: 25px 20px; border-bottom: 1px solid var(--border-color); margin-bottom: 10px; text-align: center; }
.sidebar-title { font-family: var(--font-title); color: var(--pit-dark-green); font-weight: 600; font-size: 1.1em; margin: 0; }
.user-info { font-size: 0.85em; color: #666; margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--border-color); }
.tab-btn { display: flex; align-items: center; width: 100%; box-sizing: border-box; padding: 15px 20px; border: none; background: none; text-align: left; font-family: var(--font-text); font-size: 1em; color: var(--pit-black); cursor: pointer; transition: all 0.2s ease; }
.tab-btn:hover { background-color: #f0f0f0; } 
.tab-btn.active { background-color: rgba(77, 174, 58, 0.1); color: var(--pit-dark-green); border-right: 4px solid var(--pit-light-green); font-weight: 600; }

.main-content { flex: 1; padding: 40px; overflow-y: auto; }
.header-actions { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
h1 { font-family: var(--font-title); color: var(--pit-dark-green); margin: 0; font-size: 2em; font-weight: 700; }

.btn { font-family: var(--font-text); padding: 10px 20px; border: none; border-radius: 4px; cursor: pointer; font-size: 0.95em; font-weight: 600; transition: background-color 0.2s; }
.btn-primary { background-color: var(--pit-light-green); color: white; } 
.btn-primary:hover { background-color: var(--pit-dark-green); }
.btn-primary .ms-Icon { color: white !important; }
.btn-secondary { background-color: #e0e0e0; color: var(--pit-black); } 
.btn-secondary:hover { background-color: #d0d0d0; }
.btn-logout { background-color: transparent; color: var(--color-no); border: 1px solid var(--color-no); padding: 5px 10px; font-size: 0.8em; margin-top: 10px; }

.legend { background-color: var(--card-bg); border: 1px solid var(--border-color); border-radius: 8px; padding: 15px 20px; margin-bottom: 30px; display: flex; flex-wrap: wrap; gap: 20px; align-items: center; font-size: 0.9em; }
.legend-item { display: flex; align-items: center; gap: 8px; } 
.legend-icon { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; font-size: 1.1em; }

.section { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 8px; margin-bottom: 30px; padding: 25px; box-shadow: 0 2px 8px rgba(0,0,0,0.04); }
.section h2 { font-family: var(--font-subtitle); font-weight: 300; margin-top: 0; border-bottom: 1px solid var(--border-color); padding-bottom: 12px; color: var(--pit-dark-green); font-size: 1.5em; }
.question-block { border-bottom: 1px solid var(--border-color); } 
.question-block:last-child { border-bottom: none; }
.question-row { display: flex; align-items: center; justify-content: space-between; padding: 15px 0; gap: 20px; }
.question-text { flex: 1; font-size: 0.95em; line-height: 1.5; } 
.question-id { color: var(--pit-light-green); font-family: var(--font-title); font-size: 0.9em; margin-right: 8px; font-weight: 600; }
.question-controls { display: flex; align-items: center; gap: 15px; flex-shrink: 0; }

.status-group { display: flex; gap: 8px; background-color: #f9f9f9; padding: 6px 10px; border-radius: 20px; border: 1px solid #ebebeb; }
.status-btn { width: 32px; height: 32px; border: none; border-radius: 50%; background-color: transparent; color: #b0b0b0; font-size: 1.2em; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s ease; }
.status-btn:hover { background-color: #e8e8e8; color: #666; } 
.status-btn.active { color: white; }
.status-btn.active[data-val="Standaard functie"] { background-color: var(--color-standard); } 
.status-btn.active[data-val="Kan met standaard functionaliteit worden gerealiseerd"] { background-color: var(--color-config); }
.status-btn.active[data-val="Wordt ontwikkeld"] { background-color: var(--color-dev); } 
.status-btn.active[data-val="Kan maatwerk ontwikkeld worden"] { background-color: var(--color-custom); } 
.status-btn.active[data-val="Kan niet"] { background-color: var(--color-no); }

input[type="date"], textarea { padding: 8px 12px; border: 1px solid #ccc; border-radius: 4px; font-family: var(--font-text); } 
input[type="date"] { width: 130px; } 
input[type="date"]:disabled { background-color: #eee; color: #aaa; cursor: not-allowed; }

.icon-btn { background: none; border: 1px solid transparent; font-size: 1.2em; cursor: pointer; padding: 5px; border-radius: 4px; color: #b0b0b0; transition: all 0.2s ease; }
.icon-btn:hover { color: var(--pit-dark-green); background-color: #f0f0f0; } 
.icon-btn.active { color: var(--pit-light-green); background-color: rgba(77, 174, 58, 0.1); }

.remark-row { display: none; padding: 0 0 15px 20px; } 
.remark-row.show { display: block; } 
textarea { width: 100%; min-height: 70px; resize: vertical; background-color: #fafafa; }

/* KLANT BEOORDELING (STERREN UI MOBIEL) */
.star-rating { display: inline-flex; flex-direction: row-reverse; gap: 10px; font-size: 2.2em; margin-bottom: 10px; }
.star-rating input { display: none; }
.star-rating label { color: #ddd; cursor: pointer; transition: color 0.2s; }
.star-rating label:hover, .star-rating label:hover ~ label, .star-rating input:checked ~ label { color: #FFD700; }
.eval-card { background: #fff; border: 1px solid var(--border-color); border-left: 4px solid var(--pit-light-green); border-radius: 8px; padding: 15px; margin-bottom: 15px; box-shadow: 0 2px 5px rgba(0,0,0,0.05); cursor: pointer; transition: transform 0.1s; }
.eval-card:active { transform: scale(0.98); }

/* ADMIN DASHBOARD SPECIFIEKE CSS */
.dashboard-stats { display: flex; gap: 20px; margin-bottom: 30px; }
.stat-card { background: var(--card-bg); padding: 20px; border-radius: 8px; border: 1px solid var(--border-color); flex: 1; text-align: center; }
.stat-card .number { font-size: 2em; font-weight: bold; color: var(--pit-dark-green); font-family: var(--font-title); }

.comparison-table-wrapper { overflow-x: auto; background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 8px; }
.comparison-table { width: 100%; border-collapse: collapse; text-align: left; font-size: 0.9em; }
.comparison-table th, .comparison-table td { padding: 12px 15px; border-bottom: 1px solid var(--border-color); }
.comparison-table th { background-color: var(--pit-dark-green); color: white; position: sticky; top: 0; font-family: var(--font-title); font-weight: 400; }
.comparison-table th:first-child { width: 100px; }
.comparison-table th:nth-child(2) { width: 40%; }
.comparison-table td.center { text-align: center; }
.comparison-table tr:hover { background-color: #f9f9f9; }

.admin-icon { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; color: white; font-size: 1.2em; }
.notification { padding: 12px 25px; background-color: var(--pit-light-green); color: white; border-radius: 4px; position: fixed; top: 20px; right: 20px; display: none; z-index: 1000; }

/* UITKLAP-KAART DETAILS & BEWIJSLAST */
.details-row { display: none; background-color: #fafafa; border-top: 1px dashed var(--border-color); padding: 20px; gap: 20px; box-shadow: inset 0 2px 4px rgba(0,0,0,0.02); } 
.details-row.show { display: flex; } 
.details-remark { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.details-attachment { width: 300px; display: flex; flex-direction: column; flex-shrink: 0; }
.details-label { font-size: 0.75em; font-weight: 700; color: var(--pit-dark-green); letter-spacing: 1px; margin-bottom: 8px; }

.attachment-dropzone { border: 2px dashed #ccc; border-radius: 6px; padding: 20px 10px; text-align: center; cursor: pointer; color: #888; transition: all 0.2s; background: white; height: 100%; display: flex; flex-direction: column; justify-content: center; box-sizing: border-box;}
.attachment-dropzone:hover { border-color: var(--pit-light-green); color: var(--pit-light-green); background-color: rgba(77,174,58,0.02); }

.attachment-pill { display: flex; align-items: center; justify-content: space-between; background-color: white; border: 1px solid var(--pit-light-green); border-radius: 6px; padding: 10px 15px; box-shadow: 0 2px 5px rgba(0,0,0,0.05); }
.attachment-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 0.9em; margin: 0 10px; color: var(--pit-dark-green); text-decoration: none; font-weight: 600; }
.attachment-name:hover { text-decoration: underline; }

.btn-delete-attachment { color: var(--color-no); background: rgba(220,53,69,0.1); border: none; cursor: pointer; font-size: 1.1em; padding: 6px; border-radius: 4px; display: flex; align-items: center; justify-content: center; transition: background 0.2s;}
.btn-delete-attachment:hover { background: rgba(220,53,69,0.2); }

/* ==========================================
   HET NIEUWE BEHEER SIDE-PANEL
   ========================================== */

/* De animatie voor het soepel inschuiven vanaf rechts */
@keyframes slideInRight {
    from { transform: translateX(100%); }
    to { transform: translateX(0); }
}

/* We overschrijven het standaard blok, en maken er een zwevend paneel van */
#manage-form-container {
    position: fixed !important;
    top: 0;
    right: 0;
    width: 600px;          /* Mooi breed voor de Markdown editor */
    max-width: 90vw;       /* Zorgt dat hij op mobiel niet buiten beeld valt */
    height: 100vh;
    background-color: #ffffff !important;
    box-shadow: -5px 0 30px rgba(0,0,0,0.15) !important;
    z-index: 10000;
    overflow-y: auto;
    padding: 40px 30px !important;
    border-radius: 0 !important;
    border: none !important;
    margin: 0 !important;
    animation: slideInRight 0.3s ease-out; /* Activeert de animatie bij het openen */
}

/* Een klein beetje extra styling voor de knoppen onderin het paneel */
#manage-form-container .btn {
    margin-top: 20px;
    padding: 12px 20px;
    font-size: 1.05em;
}

/* =========================================
   NIEUWE COMPONENT CLASSES (Schoonmaak)
   ========================================= */

/* 1. Algemene "Card" layout (Witte blokken met randjes en schaduw) */
.pit-card {
    background: white;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 20px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

/* 2. Formulier Inputs (Uitbreiding op .login-input) */
.pit-input-group {
    margin-bottom: 15px;
    text-align: left;
}
.pit-input-group label {
    font-weight: 600;
    font-size: 0.9em;
    color: var(--pit-dark-green);
    display: block;
    margin-bottom: 5px;
}
.pit-input {
    width: 100%;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: inherit;
    box-sizing: border-box;
    transition: border-color 0.2s;
}
.pit-input:focus {
    border-color: var(--pit-light-green);
    outline: none;
}

/* 3. Notificatie / Status Banners */
.pit-banner {
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
    font-weight: 600;
    display: flex;
    align-items: center;
}
.pit-banner-success {
    background-color: #eef2ef;
    border: 1px solid var(--pit-light-green);
    color: var(--pit-dark-green);
}
.pit-banner-warning {
    background-color: #fff3cd;
    border: 1px solid #ffeeba;
    color: #856404;
}

/* 4. Badges (De kleine labeltjes zoals 'Gepubliceerd' of 'Gesloten') */
.pit-badge {
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 0.75em;
    font-weight: bold;
    display: inline-block;
}
.pit-badge-red { background: #dc3545; color: white; }
.pit-badge-green { background: var(--pit-light-green); color: white; }
.pit-badge-blue { background: #007bff; color: white; }
.pit-badge-yellow { background: #ffc107; color: #333; }