/* Atlas Talent — Career Growth page styles */

.layout { display: grid; grid-template-columns: 1fr 320px; gap: 16px; padding: 16px 24px 40px; }
[data-density="compact"] .layout { padding: 10px 18px 24px; }

/* Career track ladder */
.track {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  padding: 18px 18px 22px;
  background: var(--surface);
}
.track-step {
  border-right: 1px solid var(--line);
  padding: 8px 12px 12px;
  position: relative;
  min-height: 130px;
  cursor: pointer;
}
.track-step:last-child { border-right: 0; }
.track-step .lvl { font-family: var(--font-mono); font-size: 10.5px; color: var(--ink-4); letter-spacing: 0.06em; }
.track-step .ttl { font-size: 13px; font-weight: 500; margin-top: 4px; letter-spacing: -0.005em; }
.track-step .meta { font-size: 11px; color: var(--ink-4); margin-top: 4px; line-height: 1.4; }
.track-step.past { background: var(--accent-tint-2); }
.track-step.past .ttl { color: var(--ink-2); }
.track-step.current { background: var(--accent-tint); }
.track-step.current .ttl { color: var(--accent); font-weight: 600; }
.track-step.target {
  background: var(--surface);
  box-shadow: inset 0 -3px 0 var(--accent);
}
.track-step.target .ttl { color: var(--accent); }
.track-step .marker {
  position: absolute; top: -1px; left: 0; right: 0; height: 3px;
  background: transparent;
}
.track-step.past .marker, .track-step.current .marker { background: var(--accent); }
.track-progress {
  height: 4px; background: var(--bg-3); border-radius: 999px; overflow: hidden;
  margin: 8px 0 0;
}
.track-progress .fill { height: 100%; background: var(--accent); border-radius: 999px; }

/* Roadmap milestones */
.roadmap { padding: 14px 16px 18px; }
.road-row { display: grid; grid-template-columns: 90px 14px 1fr auto; gap: 14px; padding: 12px 0; border-bottom: 1px dashed var(--line); align-items: flex-start; cursor: pointer; }
.road-row:last-child { border-bottom: 0; }
.road-q { font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); padding-top: 2px; }
.road-rail { position: relative; height: 100%; }
.road-rail::before { content:""; position:absolute; left:6px; top:10px; bottom:-60px; width:1px; background:var(--line); }
.road-row:last-child .road-rail::before { display:none; }
.road-dot { width:12px; height:12px; border-radius:50%; background: var(--surface); border:2px solid var(--ink-4); margin-top:4px; position:relative; z-index:1; }
.road-dot.done { background: var(--accent); border-color: var(--accent); }
.road-dot.current { background: var(--surface); border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-tint); }
.road-content .ttl { font-size: 12.5px; font-weight: 500; }
.road-content .body { font-size: 11.5px; color: var(--ink-3); margin-top: 4px; line-height: 1.5; }
.road-content .meta { display:flex; gap:8px; margin-top:6px; }
.road-action { font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); padding-top: 2px; white-space: nowrap; }

/* Goals */
.goal { padding: 14px 18px; border-bottom: 1px solid var(--line); cursor: pointer; }
.goal:last-child { border-bottom: 0; }
.goal-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.goal-title { font-size: 13.5px; font-weight: 500; letter-spacing: -0.005em; }
.goal-body { font-size: 12px; color: var(--ink-3); margin-top: 4px; line-height: 1.5; }
.goal-meta { display:flex; gap:14px; align-items:center; margin-top:10px; font-size: 11px; color: var(--ink-4); font-family: var(--font-mono); }
.goal-bar { height: 6px; background: var(--bg-3); border-radius: 999px; overflow: hidden; margin-top: 10px; }
.goal-bar .fill { height: 100%; background: var(--accent); }

/* Promotion criteria */
.crit-list { padding: 4px 0 8px; }
.crit { display: grid; grid-template-columns: 22px 1fr auto; gap: 12px; padding: 10px 16px; border-bottom: 1px dashed var(--line); align-items: center; cursor: pointer; }
.crit:last-child { border-bottom: 0; }
.crit-check {
  width: 18px; height: 18px; border-radius: 4px; display: grid; place-items: center;
  font-size: 10px; color: #fff;
}
.crit-check.ok { background: var(--accent); }
.crit-check.partial { background: #A6791E; }
.crit-check.no { background: var(--bg-3); border: 1px solid var(--line-strong); color: transparent; }
.crit-name { font-size: 12.5px; font-weight: 500; }
.crit-name small { display: block; font-size: 10.5px; color: var(--ink-4); margin-top: 2px; line-height: 1.4; }
.crit-meta { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); }
