/* Gantt legend */
.gantt-legend{display:flex;gap:16px;flex-wrap:wrap;padding:4px 34px 6px;font-size:12px;color:var(--gray)}
.gantt-legend .grp{display:flex;gap:7px;align-items:center}
.gantt-legend b{color:var(--ink)}
.gantt-legend .dot{width:14px;height:10px;border-radius:3px;display:inline-block}

/* Gantt frame */
.gantt-wrap{padding:6px 34px 30px;overflow-x:auto}
.gantt{position:relative;min-width:900px;font-size:12px;border:1px solid var(--line);border-radius:10px;overflow:hidden}

/* header (month scale) */
.g-head{display:flex;position:sticky;top:0;z-index:5;background:#fff;border-bottom:1px solid var(--line)}
.g-head .g-corner{flex:0 0 var(--labelw,270px);padding:8px 12px;font-weight:800;color:var(--navy);border-right:1px solid var(--line);background:var(--lgray)}
.g-scale{position:relative;flex:1 1 auto;height:38px;overflow:hidden}
.g-month{position:absolute;top:0;height:100%;border-left:1px solid var(--line);font-weight:700;color:var(--gray);padding:6px 6px;font-size:11px;white-space:nowrap}

/* body */
.g-body{position:relative}
.g-row{display:flex;align-items:stretch;border-bottom:1px solid #f0f2f4;min-height:30px}
.g-row:hover{background:#fafcfd}
.g-label{flex:0 0 var(--labelw,270px);padding:6px 12px;border-right:1px solid var(--line);display:flex;align-items:center;gap:7px;overflow:hidden}
.g-label .lt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.g-track{position:relative;flex:1 1 auto}

/* group headers */
.g-row.milestone .g-label{background:linear-gradient(90deg,var(--navy),var(--blue));color:#fff;font-weight:800;font-size:13px}
.g-row.milestone{background:#f4f9fc}
.g-row.epic .g-label{font-weight:800;color:var(--navy);padding-left:20px}
.g-row.epic{background:#fbfdfe}
.g-row.issue .g-label{padding-left:30px;color:var(--ink)}
.g-mono{font-family:'Source Code Pro',monospace;font-size:10.5px;color:var(--gray)}
.g-label .lt{flex:1 1 auto}
.g-count{flex:0 0 auto;background:var(--lgray);color:var(--gray);border-radius:9px;padding:0 7px;font-size:10.5px;font-weight:800}
.g-row.milestone .g-count{background:rgba(255,255,255,.28);color:#fff}

/* milestone band shading behind tracks */
.g-band{position:absolute;top:0;bottom:0;background:rgba(5,172,200,.05);border-left:1px dashed rgba(13,60,114,.25);pointer-events:none}
.g-band .lbl{position:absolute;top:2px;left:6px;font-size:10px;font-weight:800;color:rgba(13,60,114,.5)}

/* today marker */
.g-today{position:absolute;top:0;bottom:0;width:2px;background:var(--ruby);z-index:4;pointer-events:none}
.g-today .lbl{position:absolute;top:-16px;left:-16px;font-size:9.5px;font-weight:800;color:var(--ruby);background:#fff;padding:0 3px}

/* bars */
.g-bar{position:absolute;top:5px;height:18px;border-radius:5px;cursor:pointer;display:flex;align-items:center;box-shadow:0 1px 2px rgba(0,0,0,.15);transition:filter .12s;min-width:5px}
.g-bar:hover{filter:brightness(1.08)}
.g-bar .bt{font-size:10px;font-weight:700;color:#fff;padding:0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.g-bar.backlog{background:var(--st-backlog)}
.g-bar.unstarted{background:var(--st-planned)}
.g-bar.started{background:var(--st-inflight)}
.g-bar.completed{background:var(--st-done)}
.g-bar.gate{background:var(--ruby);border-radius:3px;height:14px;top:7px}
.g-bar.epicbar{height:10px;top:9px;border-radius:3px;background:var(--navy);opacity:.55}
.g-bar.msbar{background:var(--blue);opacity:.85}

/* priority accent (left edge) */
.g-bar.p-urgent{outline:2px solid var(--ruby);outline-offset:-2px}

.g-filtered{display:none !important}
