/* css/view.dashboard.css - v2.2.5 */
/* Anpassungen für PDF-Einstellungen (Aufgabe 2a, 2c) */

/* Project List Tab */
#search-projects { flex-grow: 1; padding: 0.75rem 1rem; border: 1px solid var(--border-primary); border-radius: calc(var(--radius) - 4px); background-color: var(--surface-primary); color: var(--text-primary); font-size: 1rem; min-width: 200px; }
#project-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; padding: 1.5rem; }
.project-card { position: relative; background: var(--surface-primary); padding: 1.5rem; border-radius: var(--radius); border: 1px solid var(--border-primary); box-shadow: var(--shadow-md); cursor: pointer; transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s; }
.project-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: color-mix(in srgb, var(--accent-color) 50%, transparent); }
.project-card h3 { margin-bottom: 0.5rem; padding-right: 30px; color: var(--text-primary); }
.project-card p { color: var(--text-secondary); font-size: 0.9rem; line-height: 1.5; }
.delete-card-btn { position: absolute; top: 10px; right: 10px; background: none; border: none; cursor: pointer; font-size: 24px; color: var(--text-secondary); padding: 5px; line-height: 1; z-index: 5; transition: color 0.2s, transform 0.2s; }
.delete-card-btn:hover { color: var(--error-color); transform: scale(1.2); }

/* Dashboard Navigation */
.dashboard-nav { display: flex; flex-wrap: wrap; gap: 0.5rem; padding: 1rem 1.5rem 0; border-bottom: 1px solid var(--border-primary); }
.nav-item { background: none; border: none; padding: 0.75rem 1rem; cursor: pointer; color: var(--text-secondary); font-weight: 600; border-bottom: 3px solid transparent; }
.nav-item.active { color: var(--accent-color); border-bottom-color: var(--accent-color); }
#dashboard-content { padding: 0; }
.dashboard-tab-content { display: none; }

/* Anfragen / Gebuchte Termine Tabs */
.anfragen-container { padding: 1.5rem; }
.anfrage-card { background-color: var(--surface-primary); border: 1px solid var(--border-primary); border-radius: var(--radius); padding: 1rem; margin-bottom: 1rem; box-shadow: var(--shadow-md); }
.anfrage-card h4 { margin-bottom: 0.5rem; }
.anfrage-card p { font-size: 0.9rem; color: var(--text-secondary); margin-bottom: 0.25rem; }
.anfrage-actions { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: 0.5rem; }

/* User Management Tab */
.user-management-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; padding: 1.5rem; }
#user-list { list-style: none; padding: 0; margin: 0; }
.user-list-item { display: flex; justify-content: space-between; align-items: center; padding: 1rem; border-bottom: 1px solid var(--border-primary); }
.user-list-item:last-child { border-bottom: none; }
.user-list-item .user-info { display: flex; flex-direction: column; }
.user-list-item .user-info .username { font-weight: 600; }
.user-list-item .user-info .role { font-size: 0.8rem; color: var(--text-secondary); text-transform: capitalize; }
.user-list-item .delete-user-btn { padding: 0.4rem 0.8rem; font-size: 0.8rem; }

/* Termin Kontingente Tab */
.termin-management-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; padding: 1.5rem; }
#termin-liste { max-height: 60vh; overflow-y: auto; padding-right: 10px; margin-top: 1.5rem; }
.termin-card { background-color: var(--surface-primary); border: 1px solid var(--border-primary); border-left: 5px solid var(--success-color); border-radius: var(--radius); padding: 1rem; margin-bottom: 1rem; display: flex; flex-direction: column; gap: 0.5rem; }
.termin-card.gebucht { border-left-color: var(--warning-color); }
.termin-card-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.5rem; }
.termin-card-header h4 { color: var(--text-primary); }
.termin-card-header span { font-weight: 600; font-size: 0.9rem; }
.termin-card p { font-size: 0.9rem; color: var(--text-secondary); }
.termin-card p.status-frei { color: var(--success-color); font-weight: 600; }
.termin-card p.status-gebucht { color: var(--warning-color); font-weight: 600; }
.termin-actions { margin-top: 1rem; display: flex; gap: 0.5rem; align-items: center; justify-content: flex-end; }
.btn-termin-delete, .btn-termin-convert { padding: 0.4rem 0.8rem; font-size: 0.8rem; }

/* Filter Controls (Shared in Dashboard) */
.filter-controls { display: flex; flex-wrap: wrap; gap: 1rem; width: 100%; }
.filter-controls input, .filter-controls select { padding: 0.75rem 1rem; border: 1px solid var(--border-primary); border-radius: calc(var(--radius) - 4px); background-color: var(--surface-primary); color: var(--text-primary); font-size: 1rem; }
.filter-controls input { flex-grow: 1; min-width: 150px; }

/* E-Mail Template Editor Tab */
#email-templates-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; padding: 1.5rem; }
#template-list-container, #template-editor-container { background-color: var(--surface-primary); border: 1px solid var(--border-primary); border-radius: var(--radius); padding: 1.5rem; }
#template-list { list-style: none; padding: 0; margin: 1rem 0 0 0; }
#template-list li { padding: 0.75rem; border-radius: calc(var(--radius) - 4px); cursor: pointer; font-weight: 500; border: 1px solid transparent; }
#template-list li:hover { background-color: var(--background-secondary); }
#template-list li.active { background-color: var(--accent-color); color: white; border-color: var(--accent-color); }
#template-list li p { font-size: 0.8rem; color: var(--text-secondary); font-weight: 400; margin-top: 0.25rem; }
#template-list li.active p { color: rgba(255, 255, 255, 0.8); }
#editor-description { color: var(--text-secondary); margin-bottom: 1.5rem; font-style: italic; }
#template-editor-container .form-group { margin-bottom: 1.5rem; }
#quill-editor { height: 300px; background-color: var(--surface-primary); color: var(--text-primary); border: 1px solid var(--border-primary); border-radius: calc(var(--radius) - 4px); }
.ql-toolbar, .ql-container { border-color: var(--border-primary) !important; }
.ql-snow .ql-stroke { stroke: var(--text-secondary) !important; }
.ql-snow .ql-picker-label { color: var(--text-secondary) !important; }
.ql-editor { color: var(--text-primary); }
.dark-mode .ql-snow .ql-picker-options { background-color: var(--background-secondary); border-color: var(--border-primary) !important; }
#editor-placeholders { background-color: var(--background-secondary); border: 1px solid var(--border-primary); border-radius: var(--radius); padding: 1rem; font-family: monospace; color: var(--text-secondary); display: flex; flex-wrap: wrap; gap: 0.5rem; }
#save-template-status { min-height: 20px; margin-top: 1rem; }
.status-message.success { color: var(--success-color); }


/* --- V2.2.5: PDF-Einstellungen Layout (Aufgabe 2a, 2c) --- */
.pdf-settings-layout {
    padding: 1.5rem;
}
.pdf-settings-container {
    max-width: 800px;
    margin: 0 auto;
    background-color: var(--surface-primary);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius);
    padding: 1.5rem;
}
#pdf-settings-form fieldset {
    border: 1px solid var(--border-primary);
    border-radius: var(--radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    background-color: var(--background-secondary);
}
#pdf-settings-form legend {
    font-weight: 600;
    font-size: 1.1rem;
    color: var(--text-primary);
    padding: 0 0.5rem;
    margin-left: 0.5rem;
}
/* Verbessertes Layout für Farbauswahl */
.color-picker-group {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 1rem;
}
.color-picker-group .form-group {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.color-picker-group label {
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}
.color-picker-group input[type="color"] {
    width: 100%; /* Füllt den Grid-Bereich */
    height: 40px;
    padding: 0;
    border: none;
    background: none;
    border-radius: calc(var(--radius) - 4px);
    overflow: hidden;
    cursor: pointer;
}
/* Styling für die neuen Felder (Footer, Checkbox) */
.pdf-settings-layout textarea {
    min-height: 60px;
    resize: vertical;
}
.checkbox-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.checkbox-group input[type="checkbox"] {
    width: 1.2em;
    height: 1.2em;
    accent-color: var(--accent-color);
}
.checkbox-group label {
    margin-bottom: 0; /* Überschreibt Standard-Form-Group-Label */
    font-weight: 400;
}
/* --- Ende V2.2.5 --- */


/* Responsive Media Queries */
@media (min-width: 768px) {
    #project-list { padding: 0 2rem 2rem 2rem; }
    .user-management-layout { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 992px) { 
    .termin-management-layout { grid-template-columns: 1fr 1fr; } 
    #email-templates-layout { grid-template-columns: 300px 1fr; }
}
