/* public/css/style.css */

/* ==========================================================================
   Globale Variablen & Basis
   ========================================================================== */
:root {
    --primary:#3b82f6;
    --primary-hover:#2563eb;
    --danger:#ef4444;
    --danger-hover:#dc2828;
    --secondary:#64748b;
    --secondary-hover:#475569;
    --success:#10b981;
    --bg-main:#f1f5f9;
    --bg-card:#ffffff;
    --text-main:#1e293b;
    --text-muted:#64748b;
    --border-color:#cbd5e1;
    --border-radius:1px;
    --text-size-normal:12px;
    --text-size-big:13px;
    --text-size-bigger:14px;
    --shadow-sm:0 0.5px 1px 0 rgba(0, 0, 0, 0.05);
    --shadow-md:0 2px 3px -0.5px rgba(0, 0, 0, 0.1), 0 1px 2px -0.5px rgba(0, 0, 0, 0.06);
}

* {
    box-sizing:border-box;
    margin:0;
    padding:0;
}

body {
    font-family:'Segoe UI', system-ui, -apple-system, sans-serif;
    background-color:var(--bg-main);
    color:var(--text-main);
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
}

/* ==========================================================================
   Header & Navigation
   ========================================================================== */
.app-header {
    background-color:var(--bg-card);
    padding:5px 10px;
    border-bottom:1px solid var(--border-color);
    display:flex;
    justify-content:space-between;
    align-items:center;
    box-shadow:var(--shadow-sm);
    position:sticky;
    top:0;
    z-index:100;
}

.header-left {
    display:flex;
    align-items:center;
    gap:12px;
    flex:0 0 auto; 
}

.app-header h1 {
    font-size: var(--text-size-bigger); 
    font-weight:600;
    color:var(--text-main);
    margin:0;
    white-space:nowrap;
}

.main-nav {
    display:flex;
    gap:3px;
}

.main-nav a {
    text-decoration:none;
    color:var(--text-muted);
    font-weight:500;
    padding:3px 6px; 
    border-radius:3px;
    transition:all 0.2s ease;
    font-size: var(--text-size-big); 
}

.main-nav a:hover {
    background-color: var(--bg-main);
    color:var(--text-main);
}

.main-nav a.active {
    background-color:#eff6ff;
    color:var(--primary-hover);
}

.header-user-info {
    font-size: var(--text-size-normal);
    color:var(--text-muted);
    display:flex;
    align-items:center;
    gap:6px;
}

.header-user-info a {
    color:var(--danger);
    text-decoration:none;
    font-weight:500;
    padding:2px 4px; 
    border-radius:3px;
    transition:background-color 0.2s;
}

.header-user-info a:hover {
    background-color: #fef2f2;
}

/* ==========================================================================
   Layout & Container (Verwaltungsseiten)
   ========================================================================== */
.app-main {
    padding:5px;
    max-width:2500px;
    margin:0 auto;
}

.content-box {
    background:var(--bg-card);
    border-radius:var(--border-radius);
    box-shadow:var(--shadow-md);
    padding:12px;
    border:1px solid #e2e8f0;
}

.content-box h2 {
    font-size: var(--text-size-bigger);
    font-weight:600;
    margin-bottom:10px;
    padding-bottom:6px;
    border-bottom:1px solid var(--border-color);
    color:var(--text-main);
}

/* ==========================================================================
   Tabellen (.data-table)
   ========================================================================== */
.data-table {
    width:100%;
    border-collapse:collapse;
    font-size: var(--text-size-normal);
}

.data-table th {
    text-align:left;
    padding:6px 8px;
    background-color:#f8fafc;
    color:var(--text-muted);
    font-weight:600;
    font-size: var(--text-size-normal);
    text-transform:uppercase;
    letter-spacing:0.05em;
    border-bottom:2px solid var(--border-color);
}

.data-table td {
    padding:8px;
    border-bottom:1px solid #f1f5f9;
    vertical-align:middle;
}

.data-table tbody tr:hover {
    background-color: #f8fafc;
}

.data-table tbody tr:last-child td {
    border-bottom: none;
}

/* ==========================================================================
   Formulare (.form-group)
   ========================================================================== */
.form-group label {
    display:block;
    font-weight:500;
    margin-bottom:3px;
    color:var(--text-main);
    font-size:var(--text-size-normal) !important;
}

input[type="text"],
input[type="number"],
input[type="password"],
input[type="datetime-local"],
select,
textarea {
    width:100%;
    padding:5px 6px;
    border:1px solid var(--border-color);
    border-radius:3px;
    font-family:inherit;
    font-size: var(--text-size-normal);
    color:var(--text-main);
    background-color:#fff;
    transition:all 0.2s ease;
    box-shadow:0 1px 2px 0 rgba(0,0,0,0.02) inset;
}

input:focus,
select:focus,
textarea:focus {
    outline: none;
    border-color:var(--primary);
    box-shadow:0 0 0 3px rgba(59, 130, 246, 0.15);
}

input[type="color"] {
    padding:1px;
    border:1px solid var(--border-color);
    border-radius:3px;
    width:100%;
}

.token-input {
    background-color:#f8fafc !important;
    color:var(--text-muted) !important;
    cursor:copy !important;
}

.token-input:hover {
    border-color: var(--primary);
}

/* ==========================================================================
   Buttons
   ========================================================================== */
button, .btn {
    align-items:center;
    justify-content:center;
    padding:2.5px 5px;
    font-size: var(--text-size-normal);
    font-weight:500;
    border:none;
    border-radius:3px;
    cursor:pointer;
    transition:all 0.2s ease;
    text-decoration:none;
}

.btn-primary {
    background-color:var(--primary);
    color:#fff;
    box-shadow:0 1px 2px rgba(0,0,0,0.1);
}

.btn-primary:hover {
    background-color: var(--primary-hover);
}

.btn-secondary {
    background-color:var(--secondary);
    color:#fff;
}

.btn-secondary:hover {
    background-color: var(--secondary-hover);
}

.btn-danger {
    background-color:var(--danger);
    color:#fff;
}

.btn-danger:hover {
    background-color: var(--danger-hover);
}

button:disabled {
    opacity: 0.5;
    cursor:not-allowed;
}

/* ==========================================================================
   Badges (Benutzerrollen) & UI Elemente
   ========================================================================== */
.badge {
    display:inline-block;
    padding:2px 5px;
    border-radius:9999px;
    font-size: var(--text-size-normal);
    font-weight:600;
    letter-spacing:0.025em;
    text-transform:uppercase;
}

.badge-primary { background-color:#dbeafe; color:#1e40af; }
.badge-danger { background-color:#fee2e2; color:#991b1b; }
.badge-secondary { background-color:#f1f5f9; color:#475569; }

.color-preview {
    display:inline-block;
    width:8px;
    height:8px;
    border-radius:2px;
    vertical-align:middle;
    margin-right:4px;
    border:1px solid rgba(0,0,0,0.1);
    box-shadow:var(--shadow-sm);
}

/* ==========================================================================
   NEU v0.5.1: Drei-Zonen Layout & Kanban Board
   ========================================================================== */
.toolbar { display:flex; gap:8px; align-items:center; }
.week-nav {
    display:flex;
    align-items:center;
    gap:6px;
    background:#f8fafc;
    border-radius:4px;
    border:1px solid var(--border-color);
}
#current-week-label { font-weight:600; font-size: var(--text-size-normal); min-width:100px; text-align:center; }

.status-badge { 
    padding:3px 7px; border-radius:10px; font-size: var(--text-size-normal); font-weight:600;
}
.lock-active { background-color:#dcfce7; color:#166534; border:1px solid #bbf7d0; }
.lock-readonly { background-color:#fef08a; color:#854d0e; border:1px solid #fde047; }

/* Obere Reihe (Kalender & Board) */
.schedule-top-row {
    display:flex;
    gap:5px;
    margin-bottom:5px;
    align-items:stretch;
    height:400px; 
    min-width: 1200px;
}

/* Zone A:Kalender */
.zone-calendar {
    flex-shrink: 0;
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--border-radius);
    padding:2.5px;
    box-shadow:var(--shadow-sm);
    display:flex;
    flex-direction:column;
}

.zone-calendar .flatpickr-calendar.inline {
    width:100% !important;
    max-width:100% !important;
    box-shadow:none !important;
    border:none !important;
    background:transparent;
}
.zone-calendar .flatpickr-months {
    width:100% !important;
}
.zone-calendar .flatpickr-days, 
.zone-calendar .dayContainer {
    width:100% !important;
    min-width:100% !important;
    max-width:100% !important;
}
.zone-calendar .flatpickr-day {
    max-width:100% !important;
    border-radius:2px;
    height: 30px;
    line-height: 30px;
}
.flatpickr-calendar {
    font-size: var(--text-size-normal) !important;
}

/* Zone B:Kanban Board */
.zone-board {
    flex-grow: 1;
    overflow-x:auto;
    overflow-y:hidden;
}

.kanban-grid {
    display:grid;
    gap:4px; 
    height:100%;
    min-width:800px; 
}

.kanban-col {
    background:#f8fafc;
    border:1px solid #e2e8f0;
    border-radius:3px;
    display:flex;
    flex-direction:column;
    overflow:hidden;
}

.kanban-col-header {
    padding:2.5px 2.5px;
    text-align:center;
    background:#fff;
    border-bottom:2px solid var(--border-color);
    font-size: var(--text-size-normal);
    font-weight:600;
}

.kanban-col-body {
    padding:2.5px;
    flex-grow:1;
    overflow-y:auto;
}

.kanban-col-body::-webkit-scrollbar { width: 2px; }
.kanban-col-body::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius:2px; }

/* Das Item selbst in der Kanban Spalte */
.board-item {
    background:#fff;
    border:1px solid var(--border-color);
    border-left:4px solid var(--primary);
    border-radius:0px;
    padding:1.5px;
    margin-bottom:1.5px;
    cursor:pointer;
    box-shadow:0 1px 2px rgba(0,0,0,0.05);
    transition:transform 0.1s, box-shadow 0.1s;
}

.board-item:hover {
    transform: translateY(-1px);
    box-shadow:0 4px 6px rgba(0,0,0,0.1);
}

.board-item.is-unassigned {
    border-left-color:var(--danger) !important; 
}

.board-item-time { font-size: var(--text-size-normal); font-weight:700; color:var(--text-muted); margin-bottom:1px; }
.board-item-title { font-size: var(--text-size-normal); font-weight:600; color:var(--text-main); line-height:1.2; margin-bottom:2px;}
.board-item-driver { font-size: var(--text-size-normal); color:var(--text-muted); }
.board-item-meta {display:flex;justify-content:space-between;flex-direction:row;flex-wrap:nowrap;align-content:center;align-items:center;}

.add-event-btn {
    width:100%;
    padding:3px;
    background:transparent;
    border:1px dashed var(--border-color);
    color:var(--text-muted);
    border-radius:2px;
    cursor:pointer;
    margin-bottom:4px;
    transition:background 0.2s;
}
.add-event-btn:hover { background: #e2e8f0; color:var(--text-main); }


@media (min-width:1200px) {
    .zone-board {
        overflow-x: hidden;
    }
    .kanban-grid {
        min-width:0;
    }
    .kanban-col-header {
        font-size: var(--text-size-normal);
    }
    .board-item-title {
        font-size: var(--text-size-big);
    }
}


/* Zone C:vis.js Timeline Anpassungen */
.zone-gantt {
    background: var(--bg-card);
    border-radius:var(--border-radius);
    box-shadow:var(--shadow-sm);
}

#visualization {
    overflow:hidden;
}

.vis-item { 
    border-radius:2px; 
    box-shadow:0 1px 2px rgba(0,0,0,0.1); 
    border:1px solid rgba(0,0,0,0.1); 
}
.vis-item .vis-item-content { padding:3px 2.5px; font-size: var(--text-size-normal); }
.ev-title { line-height:1.3; font-weight:600; }

.ev-remarks { font-size: var(--text-size-normal); color:inherit; opacity:0.8; border-top:1px solid rgba(0,0,0,0.1); margin-top:2px; padding-top:2px; }
.compact-view .ev-remarks { display:none !important; }
.compact-view .ev-title { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-size: var(--text-size-normal); }

.vis-item.vis-selected {
    outline:1px solid var(--primary) !important;
    outline-offset:-2px !important;
    box-shadow:none !important;
    border-color:transparent !important;
    z-index:2; 
}

.vis-item.is-dirty { 
    outline:1px dashed #eab308 !important; 
    outline-offset:-2px !important;
    background-color:#fef9c3 !important; 
    color:#854d0e !important; 
    border-color:transparent !important;
}
.vis-item .vis-delete {
    right: -24px !important;
    z-index: 999;
}
.vis-labelset .vis-label {
    border-bottom:1px solid #bfbfbf;
    /* color:#4d4d4d; WURDE ENTFERNT, DAMIT DIE INLINE-FARBE VON PHP VERERBT WIRD */
    left:0;
    top:0;
    width:100%;
    min-height:30.5px;
    font-size: var(--text-size-normal);
}
.vis-labelset .vis-label .vis-inner {
    display:inline-block;
    padding:2.5px;
    min-height:31px;
}
.vis-time-axis .vis-text {
    font-size: var(--text-size-normal);
}
.vis-timeline {
    border:1px solid #cbd5e1 !important;
}

/* Stylings für die Fahrer-Spalte links im Gantt */
.driver-group-info { font-size: var(--text-size-normal); line-height:1.3; padding:2.5px; }

/* MODIFIZIERT: color ist nun 'inherit', damit bei dunklem Hintergrund die weiße Schrift erhalten bleibt */
.driver-stats { font-size: var(--text-size-normal); color:inherit; opacity:0.8; margin-top:2px; }

/* ==========================================================================
   Modals
   ========================================================================== */
.modal-overlay {
    position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(15, 23, 42, 0.6); display:flex; justify-content:center; align-items:center; z-index:9999;
}
.modal-content {
    background:var(--bg-card); width:100%; max-width:500px; border-radius:6px; box-shadow:0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}
.modal-header {
    padding:5px 5px; border-bottom:1px solid var(--border-color); display:flex; justify-content:space-between; align-items:center;
}
.modal-header h2 { font-size: var(--text-size-bigger); font-weight:600; margin:0; }
.close-btn { background:none; border:none; font-size: var(--text-size-normal); color:var(--text-muted); padding:0; }
.close-btn:hover { color: var(--danger); }
.modal-body { padding:12px; display:flex; flex-direction:column; gap:8px; }
.modal-footer {
    padding:8px 12px; border-top:1px solid var(--border-color); display:flex; justify-content:space-between; background-color:#f8fafc; border-bottom-left-radius:6px; border-bottom-right-radius:6px;
}
.form-row { display:flex; gap:8px; }
.border-top { border-top:1px dashed var(--border-color); padding-top:8px; }

@keyframes blink-blue {
    0% { outline:1px solid var(--primary); outline-offset:-2px; opacity:1; transform:scale(1); }
    50% { outline:none; opacity:0.5; transform:scale(1.02); }
    100% { outline:1px solid var(--primary); outline-offset:-2px; opacity:1; transform:scale(1); }
}
.blink-active { animation:blink-blue 0.4s linear 3 !important; z-index:9999 !important; }