/**
 * DRV Admin - Layout System Styles
 * Datei: 127-drv-admin-layout.css
 * Version: 2.0.0
 * Datum: 2026-01-10
 * 
 * Styling für das Admin-Layout mit horizontaler Navigation oben (fixiert beim Scrollen)
 * 
 * CHANGELOG v2.0.0:
 * - Navigation von Sidebar links zu horizontaler Top-Navigation geändert
 * - Navigation fixiert oben beim Scrollen (position: sticky)
 * - Content-Bereich nimmt volle Breite ein
 * 
 * CHANGELOG v1.1.0:
 * - Responsive Layout verbessert
 * - Content-Bereich scrollbar gemacht
 * - max-width entfernt, damit nichts abgeschnitten wird
 */

/* Layout-Container - einheitliche Schriftart erzwingen */
#drv-admin-layout-content,
#drv-admin-layout-content *,
.drv-admin-layout-main,
.drv-admin-layout-main * {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
}

/* Ausnahmen für Icons und Emojis */
#drv-admin-layout-content .drv-admin-unified-nav-icon,
#drv-admin-layout-content .drv-stat-icon,
#drv-admin-layout-content .drv-fuehrerschein-icon {
    font-family: 'Apple Color Emoji', 'Segoe UI Emoji', 'Noto Color Emoji', sans-serif !important;
}

/* WordPress Container Overrides - verhindert Abschneiden */
#drv-admin-layout-content .wrap,
#drv-admin-layout-content .container,
#drv-admin-layout-content .site-content,
#drv-admin-layout-content .entry-content {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* Verhindert, dass Body oder HTML den Content abschneidet */
body.drv-admin-page,
body.drv-admin-page .site-content,
body.drv-admin-page #content {
    max-width: 100% !important;
    width: 100% !important;
    overflow-x: visible !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* WordPress Container - Abstände oben entfernen */
#drv-admin-layout-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
    margin-bottom: 0 !important;
}

/* Header und Nav Container - kein Margin/Padding oben */
.drv-admin-layout-header,
.drv-admin-layout-nav {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* WordPress Admin Bar könnte oben Platz wegnehmen - berücksichtigen wenn vorhanden */
body.admin-bar #drv-admin-layout-content .drv-admin-layout-header {
    top: 32px; /* WordPress Admin Bar Höhe */
}

@media screen and (max-width: 782px) {
    body.admin-bar #drv-admin-layout-content .drv-admin-layout-header {
        top: 46px; /* Mobile Admin Bar */
    }
    
    body.admin-bar #drv-admin-layout-content .drv-admin-layout-nav {
        top: 106px; /* Header (60px) + Admin Bar (46px) */
    }
}

/* Sicherstellen, dass Tabellen scrollbar sind */
.drv-admin-page-content .drv-table-container,
.drv-admin-page-content table {
    min-width: 100%;
}

.drv-admin-page-content {
    /* Sicherstellen, dass der Content-Bereich die volle Breite nutzen kann */
    position: relative;
}

/* Responsive: Tabellen sollten scrollbar sein bei Überbreite */
@media (max-width: 1400px) {
    .drv-admin-layout-content {
        overflow-x: auto;
    }
    
    .drv-admin-page-content {
        min-width: max-content;
    }
}

/* =============================================================================
   LAYOUT GRID
   ============================================================================= */

.drv-admin-layout-main {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 120px);
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    position: relative;
    /* Wichtig für sticky: kein overflow: hidden auf Parent */
    overflow: visible;
}

/* =============================================================================
   HEADER
   ============================================================================= */

.drv-admin-layout-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1.5rem;
    background: #ffffff;
    border-bottom: 1px solid #e2e8f0;
    margin-bottom: 0;
    margin-top: 0 !important;
    position: sticky;
    top: 0;
    z-index: 101;
}

.drv-admin-layout-header-left {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.drv-admin-layout-title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: #1e293b;
}

.drv-admin-layout-header-right {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

/* =============================================================================
   NAVIGATION (Top - Horizontal)
   ============================================================================= */

.drv-admin-layout-nav {
    background: #ffffff;
    border-bottom: 1px solid #e2e8f0;
    position: -webkit-sticky; /* Safari Support */
    position: sticky; /* Fixiert beim Scrollen */
    top: 60px; /* Direkt unter Header (Header ist etwa 60px hoch mit padding) */
    left: 0;
    right: 0;
    width: 100%;
    max-width: 100%;
    z-index: 100; /* Unter Header (z-index: 101) */
    flex-shrink: 0;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    margin-top: 0;
    margin-bottom: 0;
    overflow: visible;
}

.drv-admin-unified-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    padding: 0;
    overflow-x: visible;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    width: 100%;
}

.drv-admin-unified-nav::-webkit-scrollbar {
    height: 4px;
}

.drv-admin-unified-nav::-webkit-scrollbar-track {
    background: #f1f5f9;
}

.drv-admin-unified-nav::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 2px;
}

.drv-admin-unified-nav::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* =============================================================================
   CONTENT AREA
   ============================================================================= */

.drv-admin-layout-content {
    background: #f8fafc;
    position: relative;
    overflow-x: auto;
    overflow-y: visible;
    min-height: calc(100vh - 200px);
    width: 100%;
    flex: 1; /* Nimmt verbleibenden Platz ein */
    box-sizing: border-box;
    padding: 0;
}

.drv-admin-page-content {
    padding: 1rem 1.5rem !important;
    max-width: 100% !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    overflow-x: auto;
    min-width: 0; /* Wichtig für Grid: erlaubt shrinking */
}

/* WordPress Container Overrides für page-content - verhindert Padding-Überschreibung */
#drv-admin-layout-content .drv-admin-page-content,
#drv-admin-layout-content .drv-admin-page-content * {
    box-sizing: border-box;
}

/* Sicherstellen, dass WordPress-Container das Padding nicht überschreiben */
#drv-admin-layout-content .entry-content,
#drv-admin-layout-content .content-area,
#drv-admin-layout-content .site-content,
#drv-admin-layout-content .post-content {
    padding: 0 !important;
}

/* Padding für page-content - höchste Spezifität */
#drv-admin-layout-content .drv-admin-page-content,
#drv-admin-layout-content main.drv-admin-layout-content .drv-admin-page-content,
body #drv-admin-layout-content .drv-admin-page-content {
    padding: 1rem 1.5rem !important;
}

/* Sicherstellen, dass WordPress-Container das Padding nicht überschreiben - auch für direkte Kinder */
#drv-admin-layout-content .drv-admin-page-content > * {
    box-sizing: border-box;
}

/* Spezielle Styles für Buchungen-Layout - werden in PHP-Datei definiert */

/* Overlay wird nicht mehr benötigt bei Top-Navigation */
.drv-admin-sidebar-overlay {
    display: none !important;
}

/* Alte Navigation verstecken wenn neues Layout-System aktiv ist */
#drv-admin-layout-content[style*="display: block"] ~ * .drv-admin-va-nav,
#drv-admin-layout-content[style*="display:block"] ~ * .drv-admin-va-nav,
#drv-admin-layout-content:not([style*="display: none"]) ~ * .drv-admin-va-nav,
#drv-admin-layout-content[style*="display: block"] ~ * .drv-admin-nav-container,
#drv-admin-layout-content[style*="display:block"] ~ * .drv-admin-nav-container,
#drv-admin-layout-content:not([style*="display: none"]) ~ * .drv-admin-nav-container {
    display: none !important;
}

/* Alte Nav-Container innerhalb des Layout-Contents verstecken */
#drv-admin-layout-content .drv-admin-va-nav,
#drv-admin-layout-content .drv-admin-nav-container:not(#drv-admin-unified-nav-container),
#drv-admin-layout-content .drv-admin-drv-nav,
#drv-admin-layout-content .drv-admin-tr-nav {
    display: none !important;
}

/* =============================================================================
   ROLE SWITCHER
   ============================================================================= */

.drv-admin-role-switcher {
    display: flex;
    gap: 0.25rem;
    background: #f1f5f9;
    padding: 0.25rem;
    border-radius: 8px;
}

.drv-admin-role-switcher-btn {
    padding: 0.5rem 1rem;
    border: none;
    background: transparent;
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #64748b;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.drv-admin-role-switcher-btn:hover {
    background: #ffffff;
    color: #334155;
}

.drv-admin-role-switcher-btn.active {
    background: #ffffff;
    color: #1e293b;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

/* Sicherstellen, dass Role-Switcher-Styles nicht überschrieben werden */
#drv-admin-layout-content .drv-admin-role-switcher-btn {
    padding: 0.5rem 1rem;
    border: none;
    background: transparent;
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #64748b;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

#drv-admin-layout-content .drv-admin-role-switcher-btn.active.drv-role-drv {
    background: #FF6600 !important;
    color: #ffffff !important;
}

#drv-admin-layout-content .drv-admin-role-switcher-btn.active.drv-role-veranstalter {
    background: #047857 !important;
    color: #ffffff !important;
}

#drv-admin-layout-content .drv-admin-role-switcher-btn.active.drv-role-trainer {
    background: #3b82f6 !important;
    color: #ffffff !important;
}

/* Role-spezifische Farben */
.drv-admin-role-switcher-btn.active.drv-role-drv {
    background: #FF6600;
    color: #ffffff;
}

.drv-admin-role-switcher-btn.active.drv-role-veranstalter {
    background: #047857;
    color: #ffffff;
}

.drv-admin-role-switcher-btn.active.drv-role-trainer {
    background: #3b82f6;
    color: #ffffff;
}

/* =============================================================================
   UNIFIED NAVIGATION (Top - Horizontal)
   ============================================================================= */

.drv-admin-unified-nav-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    color: #475569;
    text-decoration: none;
    transition: all 0.15s;
    border-bottom: 3px solid transparent;
    border-right: 1px solid #f1f5f9;
    white-space: nowrap;
    position: relative;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.drv-admin-unified-nav-item:last-child {
    border-right: none;
}

.drv-admin-unified-nav-item:hover {
    background: #f8fafc;
    color: #334155;
    border-bottom-color: #cbd5e1;
}

.drv-admin-unified-nav-item.active {
    background: #fff7ed;
    color: #FF6600;
    border-bottom-color: #FF6600;
    font-weight: 500;
}

.drv-admin-unified-nav-icon {
    font-size: 1rem;
    width: 1.25rem;
    text-align: center;
    flex-shrink: 0;
    display: inline-block;
    line-height: 1;
}

.drv-admin-unified-nav-label {
    font-size: 0.9375rem;
    line-height: 1.5;
}

.drv-admin-unified-nav-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.375rem;
    background: #ef4444;
    color: #ffffff;
    border-radius: 10px;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1;
    margin-left: 0.25rem;
    flex-shrink: 0;
}

.drv-admin-unified-nav-item.active .drv-admin-unified-nav-badge {
    background: #ffffff;
    color: #FF6600;
}

/* =============================================================================
   USER INFO
   ============================================================================= */

#drv-admin-user-info {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
}

.drv-user-greeting {
    font-weight: 600;
    color: #334155;
    font-size: 0.9375rem;
}

.drv-user-role {
    font-size: 0.8125rem;
    color: #64748b;
    margin-top: 0.125rem;
}

/* =============================================================================
   RESPONSIVE
   ============================================================================= */

/* Tablet */
@media (max-width: 1024px) {
    .drv-admin-layout-header {
        padding: 0.625rem 1.25rem;
    }
    
    .drv-admin-page-content {
        padding: 1rem 1.25rem;
        max-width: 100%;
    }
    
    .drv-admin-unified-nav-item {
        padding: 0.75rem 0.875rem;
    }
    
    .drv-admin-unified-nav-label {
        font-size: 0.875rem;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .drv-admin-layout-nav {
        position: sticky;
        top: 0;
    }
    
    .drv-admin-unified-nav {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .drv-admin-unified-nav-item {
        padding: 0.875rem 1rem;
        min-width: fit-content;
    }
    
    .drv-admin-layout-header {
        padding: 0.625rem 1rem;
        flex-wrap: wrap;
        gap: 0.75rem;
        width: 100%;
        box-sizing: border-box;
    }
    
    .drv-admin-layout-header-right {
        flex-wrap: wrap;
        gap: 0.75rem;
    }
    
    .drv-admin-layout-title {
        font-size: 1.25rem;
    }
    
    .drv-admin-page-content {
        padding: 0.75rem 1rem;
        max-width: 100%;
        overflow-x: auto;
    }
    
    .drv-admin-layout-content {
        overflow-x: auto;
        width: 100%;
    }
    
    .drv-admin-role-switcher {
        width: 100%;
        justify-content: center;
    }
    
    .drv-admin-role-switcher-btn {
        flex: 1;
        padding: 0.5rem 0.75rem;
        font-size: 0.8125rem;
    }
    
    #drv-admin-user-info {
        width: 100%;
        align-items: flex-start;
        text-align: left;
    }
}

/* Small Mobile */
@media (max-width: 480px) {
    .drv-admin-unified-nav-item {
        padding: 0.75rem 0.875rem;
    }
    
    .drv-admin-unified-nav-label {
        font-size: 0.8125rem;
    }
    
    .drv-admin-unified-nav-icon {
        font-size: 0.9375rem;
        width: 1rem;
    }
    
    .drv-admin-role-switcher-btn {
        font-size: 0.75rem;
        padding: 0.5rem 0.5rem;
    }
}
