/* Gantt-styling — gedeeld door /planning?view=gantt en /calendar?view=gantt.
   Toolbar/knoppen/selects gebruiken de globale `.button` en
   `select:not(.theme-toggle)` regels uit app.css. */

.gantt-toolbar {
    display: flex; flex-wrap: wrap; gap: 14px; align-items: flex-end;
    justify-content: space-between; margin-bottom: 14px;
}
.gantt-tabs { display: flex; gap: 6px; }
.gantt-controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-end; }
.gantt-zoom { display: inline-flex; gap: 6px; }
.gantt-filter { display: flex; flex-direction: column; gap: 5px; min-width: 200px; }

.gantt-shell {
    display: flex;
    border: 1px solid var(--border, rgba(255,255,255,0.08));
    border-radius: 10px; overflow: hidden;
    background: var(--surface-1);
}
.gantt-labels {
    flex: 0 0 320px;
    border-right: 1px solid var(--border, rgba(255,255,255,0.08));
    background: var(--surface-2, rgba(255,255,255,0.03));
}
.gantt-label-header {
    padding: 14px 16px; font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.8px;
    color: var(--muted, #6a7383); height: 78px;
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.08));
    display: flex; align-items: flex-end; box-sizing: border-box;
}
.gantt-label {
    padding: 14px 16px; height: 64px; box-sizing: border-box;
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.05));
    overflow: hidden;
    display: flex; flex-direction: column; justify-content: center; gap: 3px;
}
.gantt-label-title {
    font-size: 14.5px; font-weight: 600; line-height: 1.25;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.gantt-label-meta {
    font-size: 12px; color: var(--muted, #6a7383);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.gantt-pill {
    padding: 1px 8px; border-radius: 10px; font-size: 11px; font-weight: 600;
    background: var(--surface-1);
}

.gantt-track-wrap { flex: 1 1 auto; overflow-x: auto; }
.gantt-time-axis {
    position: sticky; top: 0; z-index: 2;
    background: var(--surface-1);
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.08));
    user-select: none;
}
.gantt-week-row { display: flex; height: 34px; }
.gantt-week {
    font-size: 12px; font-weight: 700; color: var(--muted, #6a7383);
    padding: 9px 10px;
    border-right: 1px solid var(--border, rgba(255,255,255,0.08));
    text-transform: uppercase; letter-spacing: 0.5px; box-sizing: border-box;
}
.gantt-day-row { display: flex; height: 44px; }
.gantt-day {
    font-size: 11.5px; text-align: center; padding: 6px 0; line-height: 1.15;
    border-right: 1px solid var(--border, rgba(255,255,255,0.04));
    color: var(--muted, #6a7383); box-sizing: border-box; font-weight: 500;
}
.gantt-day.weekend { background: rgba(0,0,0,0.08); color: var(--muted, #6a7383); }

.gantt-rows {}
.gantt-row {
    position: relative; height: 64px; display: flex;
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.05));
}
.gantt-cell {
    border-right: 1px solid var(--border, rgba(255,255,255,0.03));
    box-sizing: border-box;
}
.gantt-cell.weekend { background: rgba(0,0,0,0.05); }

.gantt-bar {
    position: absolute; top: 11px; height: 42px;
    border-radius: 8px; padding: 0 12px;
    display: flex; align-items: center;
    font-size: 13px; font-weight: 600; color: #fff;
    text-decoration: none; cursor: grab;
    box-shadow: 0 1px 0 rgba(0,0,0,0.18);
    min-width: 18px; box-sizing: border-box;
    transition: transform .08s ease, box-shadow .12s ease;
}
.gantt-bar:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.3); transform: translateY(-1px); }
.gantt-bar.dragging {
    cursor: grabbing; opacity: 0.85;
    box-shadow: 0 4px 14px rgba(0,0,0,0.4); transition: none;
}
.gantt-bar-label {
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Kleur per kind / pijler — gedeelde palette voor planning + calendar. */
.gantt-bar.kind-personal { background: #6a73ff; }
.gantt-bar.kind-planning { background: #1f87ff; }
.gantt-bar.kind-planning.pillar-0 { background: #1f87ff; }
.gantt-bar.kind-planning.pillar-1 { background: #3aa37e; }
.gantt-bar.kind-planning.pillar-2 { background: #d65a86; }
.gantt-bar.kind-planning.pillar-3 { background: #c9803a; }
.gantt-bar.kind-event-planned   { background: #8b95ff; cursor: pointer; }
.gantt-bar.kind-event-scheduled { background: #f0a93a; cursor: pointer; }
.gantt-bar.kind-event-published { background: #3aa37e; cursor: pointer; }
.gantt-bar.status-in_progress {
    box-shadow: 0 0 0 1px rgba(255,255,255,0.5) inset, 0 1px 0 rgba(0,0,0,0.18);
}
.gantt-bar.status-todo {}
