У меня есть индикатор выполнения, в котором есть двое детей (части). Всякий раз, когда каждый из этих детей парит, общая высота прогресса и его дети будут меняться. Мне удалось решить для первых детей использование next sibling selector, но я не могу найти решение для вторых детей (желтая часть). До сих пор я решил это с помощью jQuery, но я хочу сделать это в чистом CSS.
скрипт: https://jsfiddle.net/zfh263r6/5/
$('#start').on({
  mouseenter: function () {
	  //$(this).css('height', '4px');
      //$( 'progress' ).css('height', '4px');
  },
  mouseleave: function () {
	  //$(this).css('height', '');
     // $( 'progress' ).css('height', '');
  }
});#progress_wrap {
    position: relative;
    height: 4px; /*max height of progress*/
    background: #f3f3f3;
}
progress {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    width: 100%;
    border:none;
    height: 2px;
    transition:all .25s ease-in;
    cursor: pointer;
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
}
progress:hover, progress:hover + #start {height: 4px}
progress[value]  {
    /* Reset the default appearance */
    -webkit-appearance: none;
     -moz-appearance: none;
    	  appearance: none;
    /* Get rid of default border in Firefox. */
    border: none;
    /* For IE10 */
    color: #f8008c;
}
progress[value]::-webkit-progress-bar {
    background-color: #fff;
    border:none;
}
progress[value]::-webkit-progress-value {background:#f8008c}
progress::-ms-progress-value {background:#f8008c}
progress::-moz-progress-bar {background:#f8008c}
progress::-ms-fill {border: none}
#start {
    height: 2px;
    transition: all .25s ease-in;
    cursor: pointer;
    background-color: #ffe232;
    position: absolute;
    top: 0;
    left: 0px;
    width: 30px;
}<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="progress_wrap">
  <progress min="0" max="1" value="0.66" id="progress"></progress> 
  <div id="start" style="display: inline-block; left: 50px;"></div>
</div>