<div id="step" class="sleep">1</div>
<form id="hire_us">
  <p id="pin_0" class="click pulse">Hire us</p>
  <p id="pin_1"></p>
  <p>
    <input id="your_name" type="text" class="sleep" autocomplete="off" spellcheck="false" />
  </p>
  <p id="pin_2"></p>
  <p>
    <input id="email_address" type="email" class="sleep" autocomplete="off" spellcheck="false" />
  </p>
  <p id="pin_3"></p>
  <p>
    <input id="your_color" type="text" class="sleep" autocomplete="off" spellcheck="false" />
  </p>
  <p id="pin_4"></p>
  <p id="pin_5"></p>
  <p id="pin_6"></p>
  <p id="type" contenteditable="true" class="sleep">Feel free to use <b>bold (Ctrl-B)</b>, <i>italics (Ctrl-I),</i> even <u>underlines (Ctrl-U)</u> if you must..</p>
  <p id="pin_7"></p>
  <input id="go" class="sleep" type="button" value="send us your pitch" />
  <p id="pin_8"></p>
  <p id="pin_9"></p>
</form>
@import url(https://fonts.googleapis.com/css?family=Montserrat:400,700);
* {
  margin: 0;
  padding: 0;
  cursor: default;
  box-sizing: border-box;
  cursor: default;
  outline: none;
}

*:focus {
  outline: none;
}

::-moz-selection {
  color: hsl(330, 100%, 60%);
}

::selection {
  color: hsl(330, 100%, 60%);
}

body {
  font-family: Montserrat, sans-serif;
  margin: 2rem;
  color: hsl(30, 100%, 75%);
  background: hsl(330, 25%, 10%);
}

#step {
  position: fixed;
  z-index: 0;
  bottom: 0;
  right: 1vw;
  font-size: 60vh;
  font-weight: 700;
  color: hsl(330, 25%, 15%);
  -webkit-transition: 2s;
  transition: 2s;
}

#step::before {
  content: 'Step';
  position: absolute;
  z-index: 1;
  top: 35%;
  right: 2vw;
  font-size: 20vh;
  font-weight: 700;
  color: hsl(330, 25%, 5%);
}

#step::after {
  content: 'of 4';
  position: absolute;
  z-index: 1;
  top: 65%;
  left: -2rem;
  font-size: 10vh;
  font-weight: 700;
  color: hsl(330, 25%, 20%);
}

.sleep {
  opacity: 0;
}

.rest {
  height: 0;
  opacity: 0;
}

.wake {
  opacity: 1;
}

p {
  position: relative;
  z-index: 2;
  font-family: Montserrat, sans-serif;
  font-size: 1.5rem;
  line-height: 2rem;
  height: 5rem;
  -webkit-transition: 1s ease-out .5s;
  transition: 1s ease-out .5s;
}

#type {
  height: auto;
  margin: 2rem 0;
}

.collapsed {
  height: 0;
}

[contenteditable] {
  color: hsl(330, 10%, 50%);
  border: 0 solid hsl(330, 10%, 50%);
  border-width: 0 .1rem;
  padding: 0 1em;
  -webkit-transition: 1s ease-out;
  transition: 1s ease-out;
}

[contenteditable]:focus {
  color: hsl(30, 100%, 75%);
  border-color: hsl(330, 10%, 50%);
}

input[type=button] {
  position: relative;
  top: 0rem;
  font-family: Montserrat, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  color: hsl(330, 10%, 25%);
  background: transparent;
  border: .2rem solid hsl(330, 10%, 25%);
  border-radius: .75rem;
  padding: 0.5rem 1rem;
  box-shadow: 0 0 0 hsl(330, 10%, 5%);
  -webkit-transition: 1s ease-out;
  transition: 1s ease-out;
  cursor: pointer;
}

input[type=button]:hover {
  top: -.5rem;
  color: hsl(30, 100%, 75%);
  border: .2rem solid hsl(30, 100%, 75%);
  box-shadow: 0 .5rem 0.5rem hsl(330, 10%, 5%);
}

input[type=text],
input[type=email] {
  font-family: Montserrat, sans-serif;
  font-size: 1.5rem;
  line-height: 2.5rem;
  color: hsl(30, 100%, 75%);
  background: transparent;
  border: 0 solid hsl(330, 10%, 25%);
  border-width: 0 0 .1rem 0;
  width: 3em;
  -webkit-transition: 1s ease-out;
  transition: 1s ease-out;
}

.click {
  cursor: pointer;
}

body.wait .click {
  cursor: default;
}

.pulse {
  -webkit-animation: pulse 2s infinite linear;
          animation: pulse 2s infinite linear;
}

.pulse:hover {
  -webkit-animation: none;
          animation: none;
}

@-webkit-keyframes pulse {
  0% {
    opacity: .25;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: .25;
  }
}

@keyframes pulse {
  0% {
    opacity: .25;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: .25;
  }
}
String.prototype.has = function() {
  for (var i = 0; i < arguments.length; i++) {
    if (arguments[i] != '' && this.indexOf(arguments[i]) != -1) return true;
  }
  return false;
};

String.prototype.is = function() {
  for (var i = 0; i < arguments.length; i++) {
    if (this == arguments[i]) return true;
  }
  return false;
};

String.prototype.toTitleCase = function() {
  return this.replace(/([^\W_]+[^\s-]*) */g, function(txt) {
    return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();
  });
};

/**Things to collect**/
var yourname, emailaddress, yourcolor, pitch, stepnumber = 1;
var pitch_cleared = false;
/**
  Text to type.
  Reserved characters:
  "^", "<", ">", "|"
**/
var si = 0;
var sts = [
  /*[0]*/
  'So, you want to hire us?... All right then, let\'s start.^',
  /*[1]*/
  'How about you tell us your name?>',
  /*[2]*/
  '',
  /*[3]*/
  '',
  /*[4]*/
  '',
  /*[5]*/
  'What we actually need is for you to tell us what you want._^',
  /*[6]*/
  'Please use the space below to express yourself>. The more specific you are, the better we will understand your needs. Type away.',
  /*[7]*/
  '',
  /*[8]*/
  '...but just in case... don\'t leave the city... :-|_^',
  /*[9]*/
  ''
];

/* Where to type them */
var ii = 0;
var ids = ['pin_0', 'pin_1', 'pin_2', 'pin_3', 'pin_4', 'pin_5', 'pin_6', 'pin_7', 'pin_8', 'pin_9'];

/* Functions to call from "script" */
_set_cursor = function(s) {
  document.body.className = s;
  console.log(document.body.className)
};

_show_name = function() {
  your_name.className = 'wake pulse';
  your_name.focus();
};

_show_email = function() {
  var ename = yourname.replace(/\s/g, '');
  email_address.value = ename + '@';
  email_address.className = 'wake pulse';
  email_address.focus();
};

_show_color = function() {
  your_color.className = 'wake pulse';
  your_color.focus();
};

_show_pitch = function() {
  type.className = 'wake pulse';
  type.addEventListener('focus', _show_submit, false);
};

_show_submit = function() {
  if (!pitch_cleared) {
    pitch_cleared = true;
    type.innerHTML = '';
    type.focus();
  }
  type.className = 'wake';
  go.className = 'wake';
};

var fi = 3;
var funcs = [
  /*[0] - toggle cursor state*/
  _set_cursor,
  /*[1]*/
  function() {
    console.log('f1')
  },
  /*[2]*/
  function() {
    console.log('f2')
  },
  /* Functions to run consecutively: fi 3+ */
  /*[3]*/
  _show_name,
  /*[4]*/
  _show_email,
  /*[5]*/
  _show_color,
  /*[6]*/
  _show_pitch,
  /*[7]*/
  _show_submit,
  /*[8]*/
  function() {
    console.log('f8')
  },
  /*[9]*/
  function() {
    console.log('f9')
  }
];

/* A little engine that typed */
var textHolder, textTarget, letter, li, typeSpeed = 25,
  shortPause = 250,
  longPause = 500,
  tenseSilence = 2000,
  waiting = false;

_type = function() {
  if (waiting == false) {
    li = 0;
    waiting = true;
    textTarget = document.getElementById('pin_' + ii);
    textTarget.removeEventListener('click', _type, false);
    textTarget.innerHTML = '';
    textTarget.className = '';
    textHolder = sts[si].split('');
    _get();
    funcs[0]('wait');
  }
};

_get = function() {
  if (li < textHolder.length) {
    setTimeout(
      function() {
        letter = document.createTextNode(textHolder[li]);
        _print(textTarget, letter);
      }, typeSpeed);

  } else {
    waiting = false;
    funcs[0]('');
  }
};

_print = function(textTarget, letter) {
  li++;
  if (letter.nodeValue == ',' || letter.nodeValue == ';' || letter.nodeValue == ':') {
    setTimeout(_get, shortPause);
  } else if (letter.nodeValue == '.' || letter.nodeValue == '!' || letter.nodeValue == '?') {
    setTimeout(_get, longPause);
  } else if (letter.nodeValue == '_') {
    letter.nodeValue = ' ';
    setTimeout(_get, tenseSilence);
  } else if (letter.nodeValue == '^') {
    /* interrupt typing, advance to the next string and the next spot and continue*/
    letter.nodeValue = '';
    waiting = false;
    funcs[0]('');
    document.getElementById('pin_' + ii).className = 'rest';
    si++;
    ii++;
    if ((sts[si] != 'undefined') && (ids[ii] != 'undefined')) _type();
  } else if (letter.nodeValue == '>') {
    /* run next function */
    fi = Math.min(fi, (funcs.length - 1));
    funcs[fi]();
    console.log('function' + fi + 'called');
    letter.nodeValue = '';
    fi++;
    _get();
  } else if (letter.nodeValue == '<') {
    /* run previous function - do I need this? */
    fi = Math.max(fi, 3);
    funcs[fi]();
    console.log('function' + fi + 'called');
    letter.nodeValue = '';
    fi--;
    _get();
  } else {
    _get();
  }
  textTarget.appendChild(letter);
};

_your_name_react = function() {
  if (your_name.value != '' && si == 1) {
    document.getElementById('pin_' + ii).className = 'rest';
    yourname = your_name.value.toTitleCase();
    sts[2] = 'All right, ' + yourname + '. let\'s think what else we need... oh, how about your email address?>'
    si = 2;
    ii = 2;
    your_name.removeEventListener('blur', _your_name_react, false);
    your_name.className = 'sleep';
    your_name.parentNode.className = 'collapsed';
    _update_step();
    _type();
  }
};

_email_address_react = function() {
  if (email_address.value != '' && si == 2) {
    document.getElementById('pin_' + ii).className = 'rest';
    emailaddress = email_address.value;
    sts[3] = 'Excellent, ' + yourname + '. We are going to use ' + emailaddress + ' to send you our quote. Now. This is very important. What is your favorite color?>'
    si = 3;
    ii = 3;
    email_address.removeEventListener('blur', _your_name_react, false);
    email_address.className = 'sleep';
    email_address.parentNode.className = 'collapsed';
    _update_step();
    _type();
  }
};

_your_color_react = function() {
  if (your_color.value != '' && si == 3) {
    document.getElementById('pin_' + ii).className = 'rest';
    yourcolor = your_color.value.replace(/\s/g, '');
    yourcolor = yourcolor.toTitleCase();
    sts[4] = 'Terrific. ' + yourcolor + ' will be a dominating hue in our design._You do realize we are kidding, right?_^'
    si = 4;
    ii = 4;
    document.getElementById('pin_' + ii).style.color = yourcolor;
    your_color.removeEventListener('blur', _your_name_react, false);
    your_color.className = 'sleep';
    your_color.parentNode.className = 'collapsed';
    _type();
  }
};

_check_form = function(e) {
  var key = e.charCode || e.keyCode || 0;
  if (key == 13) {
    if (si < 9) e.preventDefault();
    _your_name_react();
    _email_address_react();
    _your_color_react();
  }
};

_send_pitch = function() {
  if (type.innerHTML.length == 0) {
    sts[6] = 'Really, ' + yourname + '? Nothing?';
    _type();
  } else if (type.innerHTML.length < 50 && type.innerHTML.length > 0) {
    sts[6] = 'You can\'t be serious, ' + yourname + '. Your pitch is shorter than a tweet. Give us at least 140 characters.';
    _type();
  } else if (type.innerHTML.length < 100 && type.innerHTML.length >= 50) {
    sts[6] = 'Keep working, ' + yourname + '. You are still ' + (140 - type.innerHTML.length) + ' characters short.';
    _type();
  } else if (type.innerHTML.length < 140 && type.innerHTML.length >= 100) {
    sts[6] = 'Just a little more, ' + yourname + '. Give us ' + (140 - type.innerHTML.length) + ' characters more.';
    _type();
  } else if (type.innerHTML.length > 140) {
    type.contentEditable = false;
    document.getElementById('pin_' + ii).className = 'rest';
    go.className = 'rest';
    setTimeout(function() {
      type.className = 'rest';
      step.className = 'sleep';
    }, 10000);
    sts[7] = 'All right, ' + yourname + '. I think we have everything we need. We will be in touch. Soon.^';
    si = 7;
    ii = 7;
    _update_step();
    _type();
  }
};

_stretch_field = function() {
  this.style.width = Math.max(3, this.value.length * .75) + 'em';
};

_update_step = function() {
  step.className = 'sleep';
  setTimeout(function() {
    step.innerText = stepnumber;
    stepnumber++;
    setTimeout(function() {
      step.className = 'wake';
    }, 2000);
  }, 2000);
};

pin_0.addEventListener('click', _type, false);
pin_0.addEventListener('click', _update_step, false);
hire_us.addEventListener('keypress', _check_form, false);
your_name.addEventListener('keyup', _stretch_field, false);
your_name.addEventListener('blur', _your_name_react, false);
email_address.addEventListener('focus', _stretch_field, false);
email_address.addEventListener('keyup', _stretch_field, false);
email_address.addEventListener('blur', _email_address_react, false);
your_color.addEventListener('keyup', _stretch_field, false);
your_color.addEventListener('blur', _your_color_react, false);
go.addEventListener('click', _send_pitch, false);
/* end */

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.