/**
 * Quality Assurance Styling
 * FRED 3 kompatibles Design mit KERN UX Barrierefreiheit
 * 
 * @author Thorsten/Claude
 * @version 2.0.0
 */

/* ==========================================================================
   QS Statistics Widget
   ========================================================================== */

.qs-statistics-widget {
    background: white;
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    margin-bottom: 24px;
}

.qs-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.qs-stat-card {
    background: #f8f9fa;
    border-radius: 6px;
    padding: 16px;
    text-align: center;
    transition: all 0.2s ease;
    border: 2px solid transparent;
}

.qs-stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.qs-stat-card.critical {
    background: #ffebee;
    border-color: #d32f2f;
}

.qs-stat-card.methodical {
    background: #fff3e0;
    border-color: #f57c00;
}

.qs-stat-card.warning {
    background: #e3f2fd;
    border-color: #1976d2;
}

.qs-stat-icon {
    font-size: 32px;
    margin-bottom: 8px;
}

.qs-stat-value {
    font-size: 36px;
    font-weight: bold;
    margin-bottom: 4px;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.qs-stat-card.critical .qs-stat-value {
    color: #d32f2f;
}

.qs-stat-card.methodical .qs-stat-value {
    color: #f57c00;
}

.qs-stat-card.warning .qs-stat-value {
    color: #1976d2;
}

.qs-stat-label {
    font-size: 14px;
    color: #666;
    font-weight: 500;
    margin-bottom: 4px;
}

.qs-stat-hint {
    font-size: 11px;
    color: #999;
    font-style: italic;
    margin-top: 4px;
}

/* ==========================================================================
   Quality Badge
   ========================================================================== */

.qs-quality-badge {
    text-align: center;
    padding: 12px 20px;
    border-radius: 20px;
    font-weight: 600;
    font-size: 16px;
    margin-top: 16px;
}

.qs-quality-badge.excellent {
    background: #e8f5e9;
    color: #2e7d32;
    border: 2px solid #4caf50;
}

.qs-quality-badge.warnings {
    background: #e3f2fd;
    color: #1565c0;
    border: 2px solid #2196f3;
}

.qs-quality-badge.methodical_issues {
    background: #fff3e0;
    color: #e65100;
    border: 2px solid #ff9800;
}

.qs-quality-badge.critical {
    background: #ffebee;
    color: #c62828;
    border: 2px solid #f44336;
}

/* ==========================================================================
   QS Empty State
   ========================================================================== */

.qs-statistics-widget.empty {
    background: #f8f9fa;
    border: 2px dashed #ddd;
}

.qs-empty-state {
    text-align: center;
    padding: 40px 20px;
}

.qs-empty-icon {
    font-size: 64px;
    opacity: 0.3;
    margin-bottom: 16px;
}

.qs-empty-text {
    font-size: 16px;
    color: #999;
}

/* ==========================================================================
   QS Report Container
   ========================================================================== */

.qs-report-container {
    background: white;
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.qs-report-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 2px solid #e0e0e0;
}

.qs-report-title {
    font-size: 24px;
    font-weight: bold;
    color: #333;
}

.qs-report-actions {
    display: flex;
    gap: 12px;
}

.qs-btn {
    padding: 10px 20px;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.qs-btn-primary {
    background: #1976d2;
    color: white;
}

.qs-btn-primary:hover {
    background: #1565c0;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(25, 118, 210, 0.3);
}

.qs-btn-primary:disabled {
    background: #bbb;
    cursor: not-allowed;
    transform: none;
}

.qs-btn-secondary {
    background: white;
    color: #666;
    border: 2px solid #ddd;
}

.qs-btn-secondary:hover {
    background: #f5f5f5;
    border-color: #bbb;
}

/* ==========================================================================
   QS Loading State
   ========================================================================== */

.qs-loading {
    text-align: center;
    padding: 60px 20px;
}

.qs-loading-spinner {
    width: 60px;
    height: 60px;
    border: 4px solid #f3f3f3;
    border-top: 4px solid #1976d2;
    border-radius: 50%;
    animation: qs-spin 1s linear infinite;
    margin: 0 auto 20px;
}

@keyframes qs-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.qs-loading-text {
    font-size: 16px;
    color: #666;
    margin-bottom: 8px;
}

.qs-loading-hint {
    font-size: 13px;
    color: #999;
}

/* ==========================================================================
   FRED 3 Report Styling (Kompatibilität)
   ========================================================================== */

/* Meldungs-Styling aus FRED 3 / Volker Schmitz */

.FehlerKritisch {
    background-color: #ffebee;
    border-left: 4px solid #d32f2f;
    padding: 12px;
    margin: 8px 0;
    border-radius: 4px;
}

.FehlerMethodisch {
    background-color: #fff3e0;
    border-left: 4px solid #f57c00;
    padding: 12px;
    margin: 8px 0;
    border-radius: 4px;
}

.Warnung {
    background-color: #e3f2fd;
    border-left: 4px solid #1976d2;
    padding: 12px;
    margin: 8px 0;
    border-radius: 4px;
}

.Hinweis {
    background-color: #e8f5e9;
    border-left: 4px solid #388e3c;
    padding: 12px;
    margin: 8px 0;
    border-radius: 4px;
}

/* Navigation und Zusammenfassung */

#Zusammenfassungsbereich {
    background: #f8f9fa;
    border: 2px solid #ddd;
    border-radius: 8px;
    padding: 20px;
    margin: 20px 0;
}

#AnzahlFehlerKritisch,
#AnzahlFehlerMethodisch,
#AnzahlWarnungen,
#AnzahlHinweise {
    padding: 12px;
    margin: 8px 0;
    border-radius: 6px;
    font-weight: 600;
}

#AnzahlFehlerKritisch {
    background: #ffebee;
}

#AnzahlFehlerMethodisch {
    background: #fff3e0;
}

#AnzahlWarnungen {
    background: #e3f2fd;
}

#AnzahlHinweise {
    background: #e8f5e9;
}

/* Links zu FITKO-Dokumentation */

a[href*='docs.fitko.de'] {
    color: #1976d2;
    text-decoration: none;
    font-weight: 600;
    margin-left: 8px;
}

a[href*='docs.fitko.de']:hover {
    text-decoration: underline;
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media (max-width: 768px) {
    .qs-stats-grid {
        grid-template-columns: 1fr;
    }
    
    .qs-report-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .qs-report-actions {
        width: 100%;
        flex-direction: column;
    }
    
    .qs-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ==========================================================================
   Print Styling
   ========================================================================== */

@media print {
    .qs-btn,
    .qs-report-actions {
        display: none;
    }
    
    .qs-stat-card {
        break-inside: avoid;
    }
    
    .FehlerKritisch,
    .FehlerMethodisch,
    .Warnung,
    .Hinweis {
        break-inside: avoid;
    }
}

/* ==========================================================================
   Accessibility (WCAG 2.1 AA)
   ========================================================================== */

/* Fokus-Indikatoren */
.qs-btn:focus,
a:focus {
    outline: 3px solid #1976d2;
    outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    .qs-stat-card {
        border-width: 3px;
    }
    
    .FehlerKritisch,
    .FehlerMethodisch,
    .Warnung,
    .Hinweis {
        border-left-width: 6px;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    .qs-stat-card,
    .qs-btn,
    .qs-loading-spinner {
        animation: none;
        transition: none;
    }
}

/* Dark Mode Support (optional) */
@media (prefers-color-scheme: dark) {
    .qs-statistics-widget,
    .qs-report-container {
        background: #1e1e1e;
        color: #e0e0e0;
    }
    
    .qs-stat-card {
        background: #2d2d2d;
    }
    
    .qs-stat-label {
        color: #b0b0b0;
    }
    
    .qs-btn-secondary {
        background: #2d2d2d;
        color: #e0e0e0;
        border-color: #444;
    }
}

/* ==========================================================================
   QS Options Panel (erweiterte Parameter)
   ========================================================================== */

.qs-options-panel {
    margin-bottom: 24px;
    background: #f8f9fa;
    border-radius: 8px;
    overflow: hidden;
    border: 2px solid #e0e0e0;
}

/* Summary (Klickbarer Header) */
.qs-options-summary {
    cursor: pointer;
    user-select: none;
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    font-weight: 600;
    transition: all 0.3s ease;
}

.qs-options-summary:hover {
    background: linear-gradient(135deg, #5568d3 0%, #6a4091 100%);
}

/* Details offen */
#qs-options-details[open] .qs-options-summary {
    background: linear-gradient(135deg, #5568d3 0%, #6a4091 100%);
    border-bottom: 2px solid rgba(255, 255, 255, 0.2);
}

.qs-options-icon {
    font-size: 20px;
}

.qs-options-title {
    font-size: 16px;
    flex-grow: 1;
}

.qs-options-hint {
    font-size: 13px;
    opacity: 0.9;
    font-weight: normal;
}

/* Content Area */
.qs-options-content {
    padding: 24px;
    background: white;
}

/* Sections */
.qs-options-section {
    margin-bottom: 28px;
    padding-bottom: 24px;
    border-bottom: 1px solid #e0e0e0;
}

.qs-options-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.qs-options-section-title {
    font-size: 15px;
    font-weight: 700;
    color: #333;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Options Grid */
.qs-options-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 12px;
}

/* Checkbox Labels */
.qs-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    background: #f8f9fa;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.qs-checkbox-label:hover {
    background: #e3f2fd;
    border-color: #90caf9;
}

.qs-checkbox-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    cursor: pointer;
    accent-color: #1976d2;
}

.qs-checkbox-label span {
    font-size: 14px;
    color: #333;
    line-height: 1.5;
}

/* Main Options (wichtigere Optionen) */
.qs-checkbox-label.qs-main-option {
    background: #e3f2fd;
    border: 2px solid #90caf9;
}

.qs-checkbox-label.qs-main-option:hover {
    background: #bbdefb;
    border-color: #64b5f6;
}

/* Sub-Options (Unter-Optionen, visuell eingerückt) */
.qs-checkbox-label.qs-sub-option {
    margin-left: 20px;
    background: #fafafa;
}

.qs-checkbox-label.qs-sub-option span {
    font-size: 13px;
    color: #666;
}

/* Warning Labels */
.qs-warning {
    font-size: 12px;
    color: #f57c00;
    font-weight: 600;
}

/* Debug Level Selector */
.qs-debug-level {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #fff3e0;
    border-radius: 6px;
    border: 1px solid #ffcc80;
}

.qs-debug-level label {
    font-size: 14px;
    font-weight: 600;
    color: #e65100;
}

.qs-select {
    padding: 8px 12px;
    border: 2px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
    background: white;
    cursor: pointer;
    transition: border-color 0.2s ease;
}

.qs-select:hover {
    border-color: #90caf9;
}

.qs-select:focus {
    outline: none;
    border-color: #1976d2;
    box-shadow: 0 0 0 3px rgba(25, 118, 210, 0.1);
}

/* Preset Buttons */
.qs-options-presets {
    display: flex;
    gap: 12px;
    margin-top: 24px;
    padding-top: 20px;
    border-top: 2px solid #e0e0e0;
    flex-wrap: wrap;
}

.qs-preset-btn {
    flex: 1;
    min-width: 200px;
    padding: 12px 20px;
    border: 2px solid #ddd;
    background: white;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.qs-preset-btn:hover {
    background: #f5f5f5;
    border-color: #1976d2;
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.qs-preset-btn:active {
    transform: translateY(0);
}

#qs-preset-minimal {
    border-color: #4caf50;
    color: #2e7d32;
}

#qs-preset-minimal:hover {
    background: #e8f5e9;
    border-color: #4caf50;
}

#qs-preset-standard {
    border-color: #1976d2;
    color: #1565c0;
}

#qs-preset-standard:hover {
    background: #e3f2fd;
    border-color: #1976d2;
}

#qs-preset-vollstaendig {
    border-color: #f57c00;
    color: #e65100;
}

#qs-preset-vollstaendig:hover {
    background: #fff3e0;
    border-color: #f57c00;
}

/* Responsive Anpassungen */
@media (max-width: 768px) {
    .qs-options-grid {
        grid-template-columns: 1fr;
    }
    
    .qs-checkbox-label.qs-sub-option {
        margin-left: 10px;
    }
    
    .qs-options-presets {
        flex-direction: column;
    }
    
    .qs-preset-btn {
        min-width: 100%;
    }
}

/* Accessibility */
.qs-checkbox-label:focus-within {
    outline: 3px solid #1976d2;
    outline-offset: 2px;
}

.qs-options-summary:focus {
    outline: 3px solid #ffffff;
    outline-offset: -3px;
}

/* Animation für das Öffnen/Schließen */
@keyframes qs-options-slide-in {
    from {
        opacity: 0;
        max-height: 0;
    }
    to {
        opacity: 1;
        max-height: 2000px;
    }
}

#qs-options-details[open] .qs-options-content {
    animation: qs-options-slide-in 0.3s ease-out;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
    #qs-options-details[open] .qs-options-content {
        animation: none;
    }
    
    .qs-preset-btn:hover {
        transform: none;
    }
}
/**
 * QS Report Wrapper Styles - Ergänzung
 * 
 * Diese Styles stellen sicher, dass der FRED3-Report korrekt
 * innerhalb unserer App angezeigt wird.
 * 
 * @author Thorsten/Claude
 * @version 2.2.0
 */

/* ==========================================================================
   Report Wrapper - Container für den XSLT-generierten Report
   ========================================================================== */

.qs-report-wrapper {
    font-family: Arial, sans-serif;
    font-size: 13px;
    color: #333;
    line-height: 1.5;
}

/* Überschriften innerhalb des Reports */
.qs-report-wrapper h1 {
    font-weight: bold;
    font-size: 200%;
    margin-top: 18px;
    margin-bottom: 6px;
    page-break-after: avoid;
    color: #333;
}

.qs-report-wrapper h2 {
    font-weight: bold;
    font-size: 140%;
    margin-top: 9px;
    margin-bottom: 3px;
    page-break-after: avoid;
    color: #333;
    padding-bottom: 8px;
    border-bottom: 2px solid #e0e0e0;
}

.qs-report-wrapper h3 {
    font-weight: bold;
    font-size: 120%;
    margin-top: 9px;
    margin-bottom: 3px;
    page-break-after: avoid;
    color: #333;
}

.qs-report-wrapper h4 {
    font-weight: bold;
    color: #333;
}

/* Tabellen innerhalb des Reports */
.qs-report-wrapper table {
    border-collapse: collapse;
    width: 100%;
    margin: 12px 0;
}

.qs-report-wrapper th,
.qs-report-wrapper td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
}

.qs-report-wrapper th {
    background: #f5f5f5;
    font-weight: 600;
    color: #333;
}

.qs-report-wrapper tr:nth-child(odd) {
    background: #fafafa;
}

.qs-report-wrapper tr:nth-child(even) {
    background: #ffffff;
}

.qs-report-wrapper tr:hover {
    background: #f0f7ff;
}

/* Links */
.qs-report-wrapper a {
    color: #1976d2;
    text-decoration: underline;
}

.qs-report-wrapper a:hover {
    color: #1565c0;
    background: #e3f2fd;
    padding: 2px 4px;
    margin: -2px -4px;
    border-radius: 3px;
}

/* FRED3-spezifische Klassen */
.qs-report-wrapper .ElementName,
.qs-report-wrapper .SteckbriefName,
.qs-report-wrapper .SDSName,
.qs-report-wrapper .RegelName {
    font-weight: bold;
}

.qs-report-wrapper .ElementID,
.qs-report-wrapper .SteckbriefID,
.qs-report-wrapper .SDSID,
.qs-report-wrapper .RegelID {
    font-family: 'Consolas', monospace;
    background: #f5f5f5;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 12px;
}

.qs-report-wrapper .Regel {
    font-style: italic;
    color: #666;
}

.qs-report-wrapper .SehrKlein {
    font-weight: lighter;
    font-size: 70%;
    color: #888;
}

/* Zusammenfassung im Report */
.qs-report-wrapper .Zusammenfassung {
    font-weight: bold;
    font-size: 110%;
    padding: 10px;
    border-radius: 6px;
    margin: 8px 0;
}

.qs-report-wrapper .ZusammenfassungHilfe {
    font-weight: normal;
    font-size: 80%;
    color: #666;
    display: block;
    margin-top: 4px;
}

/* Einrückung für hierarchische Strukturen */
.qs-report-wrapper .Einrueckung {
    font-style: normal;
}

/* Baumstruktur-Symbole */
.qs-report-wrapper td:first-child {
    white-space: nowrap;
}

/* Unterelemente-Tabelle */
.qs-report-wrapper table table {
    margin: 0;
    width: 100%;
}

.qs-report-wrapper table table th,
.qs-report-wrapper table table td {
    padding: 6px 8px;
    font-size: 12px;
}

/* Meldungs-Texte */
.qs-report-wrapper .HinweisText {
    color: #388e3c;
}

.qs-report-wrapper .WarnungText {
    color: #1976d2;
}

.qs-report-wrapper .FehlerMethodischText {
    color: #f57c00;
}

.qs-report-wrapper .FehlerKritischText {
    color: #d32f2f;
}

/* Navigation im Report (fixiert, falls vorhanden) */
.qs-report-wrapper #fixiert {
    position: sticky;
    top: 0;
    background: white;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 20px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    max-height: 400px;
    overflow-y: auto;
}

.qs-report-wrapper #fixiert h2 {
    margin-top: 0;
    font-size: 16px;
    border-bottom: none;
}

.qs-report-wrapper #fixiert p {
    margin: 4px 0;
}

.qs-report-wrapper #fixiert ul {
    margin: 4px 0 4px 20px;
    padding: 0;
}

.qs-report-wrapper #fixiert li {
    margin: 2px 0;
}

/* Hauptinhalt */
.qs-report-wrapper #Inhalt {
    margin-left: 0 !important;
    border: none !important;
    padding: 0 !important;
}

/* Zusammenfassungsbereich */
.qs-report-wrapper #Zusammenfassungsbereich {
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border: 2px solid #dee2e6;
    border-radius: 12px;
    padding: 24px;
    margin: 24px 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.qs-report-wrapper #Zusammenfassungsbereich h2 {
    margin-top: 0;
    color: #495057;
    font-size: 18px;
    border-bottom: 2px solid #dee2e6;
    padding-bottom: 12px;
    margin-bottom: 16px;
}

/* Anzahl-Felder in der Zusammenfassung */
.qs-report-wrapper #AnzahlFehlerKritisch,
.qs-report-wrapper #AnzahlFehlerMethodisch,
.qs-report-wrapper #AnzahlWarnungen,
.qs-report-wrapper #AnzahlHinweise {
    padding: 14px 18px;
    margin: 10px 0;
    border-radius: 8px;
    font-weight: 600;
    font-size: 15px;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

.qs-report-wrapper #AnzahlFehlerKritisch {
    background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
    border-color: #ef9a9a;
}

.qs-report-wrapper #AnzahlFehlerMethodisch {
    background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
    border-color: #ffcc80;
}

.qs-report-wrapper #AnzahlWarnungen {
    background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
    border-color: #90caf9;
}

.qs-report-wrapper #AnzahlHinweise {
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    border-color: #a5d6a7;
}

/* Listen der Meldungen */
.qs-report-wrapper #ListeFehlerKritisch,
.qs-report-wrapper #ListeFehlerMethodisch,
.qs-report-wrapper #ListeWarnungen,
.qs-report-wrapper #ListeHinweise {
    font-size: 13px;
    padding: 8px 16px;
    margin-left: 8px;
    border-left: 3px solid #ddd;
}

.qs-report-wrapper #ListeFehlerKritisch {
    border-left-color: #d32f2f;
}

.qs-report-wrapper #ListeFehlerMethodisch {
    border-left-color: #f57c00;
}

.qs-report-wrapper #ListeWarnungen {
    border-left-color: #1976d2;
}

.qs-report-wrapper #ListeHinweise {
    border-left-color: #388e3c;
}

/* Meldungs-DIVs im Report */
.qs-report-wrapper .FehlerKritisch,
.qs-report-wrapper .FehlerMethodisch,
.qs-report-wrapper .Warnung,
.qs-report-wrapper .Hinweis {
    padding: 14px 16px;
    margin: 10px 0;
    border-radius: 6px;
    font-size: 13px;
    line-height: 1.5;
}

.qs-report-wrapper .FehlerKritisch {
    background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
    border-left: 5px solid #d32f2f;
    color: #b71c1c;
}

.qs-report-wrapper .FehlerMethodisch {
    background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
    border-left: 5px solid #f57c00;
    color: #e65100;
}

.qs-report-wrapper .Warnung {
    background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
    border-left: 5px solid #1976d2;
    color: #0d47a1;
}

.qs-report-wrapper .Hinweis {
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    border-left: 5px solid #388e3c;
    color: #1b5e20;
}

/* Horizontale Trennlinien */
.qs-report-wrapper hr {
    border: none;
    border-top: 2px solid #e0e0e0;
    margin: 24px 0;
}

/* Statistik-Bereich */
.qs-report-wrapper #Statistik,
.qs-report-wrapper [id^="Statistik"] {
    margin-top: 24px;
}

/* Fußzeile */
.qs-report-wrapper p.SehrKlein {
    margin-top: 32px;
    padding-top: 16px;
    border-top: 1px solid #ddd;
    color: #999;
}

/* Print-spezifisch */
@media print {
    .qs-report-wrapper #fixiert {
        position: static;
        page-break-after: always;
    }
    
    .qs-report-wrapper .FehlerKritisch,
    .qs-report-wrapper .FehlerMethodisch,
    .qs-report-wrapper .Warnung,
    .qs-report-wrapper .Hinweis {
        break-inside: avoid;
    }
}

/* Responsive */
@media (max-width: 768px) {
    .qs-report-wrapper table {
        display: block;
        overflow-x: auto;
    }
    
    .qs-report-wrapper th,
    .qs-report-wrapper td {
        padding: 8px;
        font-size: 12px;
    }
}
