<div class="player-container">
  <div class="player-wrap">
    <div class="play-pause"></div>
    <section class="song-meta">
      <div class="artist">Led Zeppelin</div>
      <div class="song">Stairway to Heaven</div>
      <div class="timeline"></div>  
      <progress class="pcast-progress" value="0"></progress>
      <span class="pcast-currenttime pcast-time">0:00</span>
    </section> 
   <audio id="main-audio" preload="none" width="100%" src="http://www.buzzsprout.com/15939/109759-live-from-front-end-conf.mp3">
            <source src="http://www.buzzsprout.com/15939/109759-live-from-front-end-conf.mp3" type="audio/mpeg">
          </audio>
  </div>
</div>

@import "compass/css3";

$rich-grey: #423939;
$cream: #ded6d6;
*       { box-sizing:border-box; }
body    { background-color:$cream; font-family:"Montserrat", sans-serif;
}
@import url(https://fonts.googleapis.com/css?family=Montserrat);

%circle-corner {
  content:"";
    background-color:$rich-grey;
    border-radius:50%;
    height:91px;
    width:100px;
    position:absolute;
    display:block;
  
    top:0;
  z-index:-1;
}
.player-container {
  display:block;
  width:422px;
  height:300px;
  margin-top:200px;
  padding-top:91px;
  padding-left:15px;
  margin:0 auto; 
  
  background-image: url('http://dev.steelehouse.com/codepen/audio-shadow.jpg');
  background-repeat:no-repeat;
  background-position:21px -14px;
}
.player-wrap {
  background-color:$rich-grey;
  display:block;
  z-index:1;
  width:230px;
  height:91px;
  margin:0 auto;
  color:white;
  position:relative;
              
  &:before {
    @extend %circle-corner;
    left:-45px;/*
    border-bottom: 2px solid white;*/
  }
  &:after {
    @extend %circle-corner;
    right:-45px;
  }
}

.play-pause {
  width:100px; 
  height:100px;
  display:inline-block;
  position:absolute; 
  left:-33px; 
  top:7px;
  background-image: url('http://dev.steelehouse.com/codepen/play-dark.gif');
  border-radius:20%; 
  background-repeat:no-repeat;
  cursor:pointer;

  // This doesn't actually refresh the gif cache, wish it did, but it doesn't
  &.paused  { background-image: url('http://dev.steelehouse.com/codepen/pause-dark.gif');}
  &.pausing  { background-image: url('http://dev.steelehouse.com/codepen/play-to-pause-dark.gif');}
  &.playing  { 
      background-image: url('http://dev.steelehouse.com/codepen/pause-to-play-dark.gif');
  }
}
  progress {
    height: 7px;
    border-radius:7px;
    width:100%;
    background-color:white;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  }

  progress[value]::-webkit-progress-bar {
    background-color: white;
    border-radius: 50%;
    padding: 2px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.25);
  }
  
  progress[value]::-webkit-progress-value  {
    background: #c34747; 
    padding-left:6px;
  }
.song-meta {
  margin-left:55px;
  z-index:5;
  width:100%;
  padding-right:40px;
  padding-top:11px;
}

.artist,.pcast-time {font-size:11px;font-weight:lighter;text-transform:uppercase;letter-spacing:.15em;opacity:.6}
.pcast-time {letter-spacing:0;}

.player-wrap, %circle-corner { background-image: url();}
View Compiled
// Most of this is all Dave Rupert
// See https://codepen.io/davatron5000/pen/uqktG

(function(){
  $(".play-pause").click(function() {

   if($(this).hasClass('pausing')){
      $(this).removeClass('pausing');
      $(this).addClass('playing');
      $(this).css("background-image", "url(http://dev.steelehouse.com/codepen/play-to-pause-faster.gif)");
      audio.play();
  }
  else if($(this).hasClass('playing')){
      $(this).removeClass('playing');
      $(this).addClass('pausing');
      $(this).css("background-image", "url(http://dev.steelehouse.com/codepen/pause-to-play-faster.gif)");
      audio.pause();
  }
  else {
    $(this).addClass('playing');
    $(this).css("background-image", "url(http://dev.steelehouse.com/codepen/play-to-pause-faster.gif)");
    audio.play();
  }
  
});



  var pcastPlayers = document.querySelectorAll('.player-container');
  var speeds = [ 1, 1.5, 2, 2.5, 3, 0.5 ]    
  
  for(i=0;i<pcastPlayers.length;i++) {
    var player = pcastPlayers[i];
    var audio = player.querySelector('audio');/*
    var play = player.querySelector('.play-pause.playing');
    var pause = player.querySelector('.play-pause.pausing');*/
    

    
    var progress = player.querySelector('.pcast-progress');

    var currentTime = player.querySelector('.pcast-currenttime');
    
    var currentSpeedIdx = 0;

    
    var toHHMMSS = function ( totalsecs ) {
        var sec_num = parseInt(totalsecs, 10); // don't forget the second param
        var hours   = Math.floor(sec_num / 3600);
        var minutes = Math.floor((sec_num - (hours * 3600)) / 60);
        var seconds = sec_num - (hours * 3600) - (minutes * 60);

        if (hours   < 10) {hours   = "0"+hours; }
        if (minutes < 10) {minutes = ""+minutes;}
        if (seconds < 10) {seconds = "0"+seconds;}
        
        var time = hours+':'+minutes+':'+seconds;
        if (hours   <= 1) { var time = minutes+':'+seconds; }
      
        return time;
    }
    
    audio.addEventListener('loadedmetadata', function(){
      progress.setAttribute('max', Math.floor(audio.duration));
      duration.textContent  = toHHMMSS(audio.duration);
    });
    
    audio.addEventListener('timeupdate', function(){
      progress.setAttribute('value', audio.currentTime);
      currentTime.textContent  = toHHMMSS(audio.currentTime);
    });
    
/*    play.addEventListener('click', function(){
      this.style.display = 'none';
      pause.style.display = 'inline-block';
      pause.focus();
      audio.play();
    }, false);

    pause.addEventListener('click', function(){
      this.style.display = 'none';
      play.style.display = 'inline-block';
      play.focus();
      audio.pause();
    }, false);
*/
    
    progress.addEventListener('click', function(e){
      audio.currentTime = Math.floor(audio.duration) * (e.offsetX / e.target.offsetWidth);
    }, false);

  
    
  }
})(this);


Rerun