/*I always have to give props: Thank you Eric Meyer for the reset.*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

body {
  background-color: #ccc;
  background: -webkit-gradient(radial, left top, 0, left top, 300, from(white), to(#cccccc)) no-repeat #cccccc;
  font-family: sans-serif;
  color: #222;
  text-rendering: optimizeLegibility; }

#formal:target .no-pro {
  display: none; }
#formal:target .formal-switch-back {
  left: 0px; }

.formal-mode {
  position: absolute;
  height: 20px;
  top: 30px;
  right: 10px; }

.formal-mode-text {
  margin-right: 60px;
  padding-top: 2px; }

.formal-mode > a, .formal-switch-container {
  position: absolute;
  top: 0;
  right: 0;
  height: 20px;
  width: 50px; }

.formal-switch-container {
  display: inline-block;
  border-radius: 100px;
  overflow: hidden; }
  .formal-switch-container div {
    height: 100%;
    position: absolute; }

.formal-switch-back {
  width: 80px;
  left: -30px;
  -webkit-transition: left 100ms linear;
  -moz-transition: left 100ms linear; }

.formal-switch-on {
  background-color: #afa;
  left: 0;
  width: 26px;
  text-align: right;
  padding: 2px 14px 0 0; }

.formal-switch-off {
  background-color: #faa;
  right: 0;
  width: 27px;
  padding: 2px 0 0 13px; }

.formal-switch-center {
  background-color: #fff;
  width: 20px;
  border-radius: 100px;
  left: 30px; }

.html5container {
  position: fixed;
  top: 60px;
  right: 10px; }

.html5 {
  border-style: solid;
  border-width: 2px;
  border-color: rgba(0, 0, 0, 0);
  border-radius: 3px;
  padding: 3px;
  height: 32px;
  width: 32px;
  overflow: hidden;
  -webkit-transition: height 300ms ease-in-out, border-color 300ms cubic-bezier(0.45, 0.1, 1, 0.1);
  -moz-transition: height 300ms ease-in-out, border-color 300ms ease-in-out; }
  .html5:hover {
    border-color: rgba(0, 0, 0, 0.25);
    height: 106px;
    -webkit-transition: height 300ms ease-in-out, border-color 300ms cubic-bezier(0.1, 0.45, 0.1, 1);
    -moz-transition: height 300ms ease-in-out, border-color 300ms ease-in-out; }
    .html5:hover > img:first-child {
      opacity: 0.8; }
  .html5 > img {
    opacity: 0.4;
    -webkit-transition: opacity 200ms linear;
    -moz-transition: opacity 200ms linear; }
    .html5 > img:not(:last-child) {
      display: block;
      margin-bottom: 5px; }
    .html5 > img:not(:first-child):hover {
      opacity: 0.8;
      -webkit-transition: opacity 200ms linear;
      -moz-transition: opacity 200ms linear; }
    .html5 > img + div {
      position: absolute;
      display: block;
      right: 45px;
      text-align: center;
      border-radius: 10px;
      background-color: rgba(0, 0, 0, 0.7);
      color: #fff;
      font-size: 13px;
      padding: 2px 5px 4px 5px;
      opacity: 0;
      pointer-events: none;
      -webkit-transition: opacity 200ms linear;
      -moz-transition: opacity 200ms linear; }
    .html5 > img:hover + div {
      opacity: 0.4;
      -webkit-transition: opacity 500ms linear;
      -moz-transition: opacity 500ms linear; }
    .html5 > img.html5m + div {
      top: 5px; }
    .html5 > img.html5s + div {
      top: 42px; }
    .html5 > img.css3 + div {
      top: 79px; }

h1, h2.callout {
  margin-left: 10px;
  text-transform: lowercase; }
  h1::after, h2.callout::after {
    content: "."; }

h1 {
  font-size: 64px;
  font-weight: bold; }

h2.callout {
  color: #888;
  font-size: 32px;
  font-weight: bold; }

div.contact-info {
  display: none; }

#printer-friendly {
  margin: 5px 5px 0 0;
  font-size: 12px;
  color: #444;
  float: right; }

#left-bar {
  border-right: 7px solid #fff;
  border-top: 7px solid #fff;
  border-bottom: 7px solid #fff;
  -webkit-border-top-right-radius: 15px;
  -moz-border-radius-topright: 15px;
  -webkit-border-bottom-right-radius: 15px;
  -moz-border-radius-bottomright: 15px;
  border-top-right-radius: 15px;
  border-bottom-right-radius; 15px;
  margin: 50px 0 30px 0;
  width: 100px; }
  #left-bar > .section {
    border-right: 7px solid #fff;
    border-top: 7px solid #fff;
    border-bottom: 7px solid #fff;
    -webkit-border-top-right-radius: 15px;
    -moz-border-radius-topright: 15px;
    -webkit-border-bottom-right-radius: 15px;
    -moz-border-radius-bottomright: 15px;
    border-top-right-radius: 15px;
    border-bottom-right-radius; 15px;
    margin: 20px 0 20px 107px;
    padding: 0 0 20px 0;
    width: 100px;
    position: relative; }
    #left-bar > .section::before {
      position: absolute;
      height: 7px;
      width: 7px;
      border: 7px solid #fff;
      border-radius: 10px;
      content: "";
      /*Otherwise it won't display*/
      top: -14px;
      left: -14px; }
    #left-bar > .section + .section {
      margin-top: 60px; }
    #left-bar > .section > h2.section-indicator {
      font-variant: small-caps;
      position: absolute;
      top: -42px;
      margin-left: 10px;
      width: 9em;
      font-size: 35px;
      font-weight: bold;
      color: #fff;
      border-bottom: 7px solid #fff; }
    #left-bar > .section > div.work-listing {
      margin-left: 120px;
      font-size: 21px;
      padding-top: 20px;
      position: relative; }
      #left-bar > .section > div.work-listing > div.date-start {
        font-weight: bold;
        position: absolute;
        top: 20px;
        left: -115px;
        width: 81px;
        text-align: right; }
      #left-bar > .section > div.work-listing > div.date-end {
        font-weight: bold;
        position: absolute;
        top: 40px;
        left: -115px;
        width: 81px;
        text-align: right; }
      #left-bar > .section > div.work-listing > h3.work-title {
        font-variant: small-caps;
        font-weight: bold;
        width: 500px; }
      #left-bar > .section > div.work-listing > p {
        width: 500px;
        font-size: 14px; }
        #left-bar > .section > div.work-listing > p + p {
          margin-top: 1em; }
      #left-bar > .section > div.work-listing > ul {
        font-size: 14px;
        list-style-type: circle;
        width: 500px;
        font-weight: bold; }
        #left-bar > .section > div.work-listing > ul > li {
          font-weight: normal;
          margin-left: 4em; }
          #left-bar > .section > div.work-listing > ul > li + li {
            margin-top: 1em; }
      #left-bar > .section > div.work-listing > hr {
        display: none; }
      #left-bar > .section > div.work-listing::before {
        position: absolute;
        height: 7px;
        width: 7px;
        border: 7px solid #fff;
        border-radius: 10px;
        content: "";
        /*Otherwise it won't display*/
        left: -27px; }

.blip-red::before {
  background-color: #d00; }

.blip-orange::before {
  background-color: #f80; }

.blip-yellow::before {
  background-color: #ee0; }

.blip-green::before {
  background-color: #0d0; }

.blip-blue::before {
  background-color: #08f; }

.blip-purple::before {
  background-color: #a0e; }

.strong {
  font-weight: bold; }

.clear-fix {
  clear: both; }

@media only screen and (max-device-width: 720px) {
  .formal-mode {
    display: none; }

  .html5container {
    display: none; }

  #printer-friendly {
    display: none; }

  h1, h2.callout {
    margin-left: 0; }

  h1 {
    width: 100%;
    text-align: center; }
    h1::after {
      content: ""; }

  h2.callout {
    font-size: 1em;
    margin-left: 5px; }

  #left-bar {
    border: 0;
    width: 100%;
    margin: 10px 0 0 0; }
    #left-bar > .section {
      border: 0;
      margin: 0;
      width: 100%;
      padding: 0; }
      #left-bar > .section > h2.section-indicator {
        position: initial;
        margin-left: 0;
        width: 100%;
        text-align: center;
        border: 0;
        color: #222;
        font-size: 1.5em;
        text-transform: uppercase; }
      #left-bar > .section > .work-listing {
        margin: 0 !important;
        padding: 5px 20px 5px 10px !important;
        font-size: 1em !important;
        box-sizing: border-box;
        background-color: #ddd;
        border-top: 1px solid #aaa;
        border-bottom: 1px solid #aaa; }
        #left-bar > .section > .work-listing > div.date-start {
          position: relative !important;
          display: inline-block;
          top: 0 !important;
          left: 0 !important;
          width: auto !important; }
        #left-bar > .section > .work-listing > div.date-end {
          position: relative !important;
          display: inline-block;
          top: 0 !important;
          left: 0 !important;
          width: auto !important; }
          #left-bar > .section > .work-listing > div.date-end::before {
            content: " - "; }
        #left-bar > .section > .work-listing > h3.work-title {
          position: relative !important;
          display: block;
          width: auto !important;
          text-transform: uppercase !important; }
        #left-bar > .section > .work-listing > p {
          margin-top: 1em;
          width: auto !important;
          display: none; }
        #left-bar > .section > .work-listing > ul {
          width: auto !important;
          display: none; }
        #left-bar > .section > .work-listing > hr {
          border: 0;
          border-top: 1px solid #aaa;
          width: 100vw;
          margin: 5px 0 -5px -10px;
          display: none; }
        #left-bar > .section > .work-listing + .work-listing {
          border-top: 0; }
        #left-bar > .section > .work-listing.has-content::after {
          font-weight: bold;
          content: "+";
          position: absolute;
          top: 0;
          right: 5px; }
        #left-bar > .section > .work-listing.open > p {
          display: inherit; }
        #left-bar > .section > .work-listing.open > ul {
          display: inherit; }
        #left-bar > .section > .work-listing.open > hr {
          display: inherit; }
        #left-bar > .section > .work-listing.open::after {
          content: "-"; }
        #left-bar > .section > .work-listing::before {
          height: 100% !important;
          width: 5px !important;
          left: 0 !important;
          top: 0 !important;
          border: 0 !important;
          border-radius: 0 !important; }
      #left-bar > .section + .section {
        margin-top: 10px; }
      #left-bar > .section::before {
        display: none; } }
@media print {
  body {
    background-color: #fff;
    background: #fff;
    color: #000;
    text-rendering: optimizeSpeed; }

  .formal-mode {
    display: none; }

  .html5container {
    display: none; }

  .no-print {
    display: none; }

  a {
    color: inherit;
    text-decoration: none; }

  h1, h2.callout {
    margin: 0;
    text-transform: lowercase;
    width: 50%; }

  h1 {
    float: left; }
    h1::after {
      content: ""; }

  h2.callout {
    float: right;
    color: #444;
    font-size: 24px;
    text-align: right; }
    h2.callout::after {
      content: "."; }

  h2.flavor {
    display: none; }

  div.contact-info {
    float: left;
    width: 25%;
    text-align: center;
    display: block;
    font-weight: bold;
    font-size: 14px;
    margin: 1em 0 1em 0;
    border-top: 1px solid #888;
    border-bottom: 1px solid #888;
    padding: 3px 0 3px 0; }

  div.contact-info.mid {
    width: 34%; }

  #printer-friendly {
    display: none; }

  #left-bar {
    border: 0;
    margin: 0;
    width: 100%; }
    #left-bar > .section {
      border: 0;
      margin: 0;
      width: 100%;
      padding: 0; }
      #left-bar > .section::before {
        display: none; }
      #left-bar > .section + .section {
        margin: 1em 0 0 0; }
      #left-bar > .section > h2.section-indicator {
        position: relative;
        top: 0;
        margin: 0;
        border: 0;
        color: #222;
        width: 100%; }
      #left-bar > .section > div.work-listing {
        margin: 0;
        padding: 0; }
        #left-bar > .section > div.work-listing > h3.work-title {
          width: auto; }
        #left-bar > .section > div.work-listing > p {
          width: 100%; }
          #left-bar > .section > div.work-listing > p + p {
            margin-top: 1em; }
        #left-bar > .section > div.work-listing > ul {
          list-style-type: circle; }
          #left-bar > .section > div.work-listing > ul > li {
            margin-left: 4em; }
            #left-bar > .section > div.work-listing > ul > li + li {
              margin-top: 1em; }
        #left-bar > .section > div.work-listing::before {
          display: none;
          left: 0; }
    #left-bar > div.work > div.work-listing + div.work-listing {
      margin-top: 1em; }
    #left-bar > div.work > div.work-listing > div.date-start {
      position: inherit;
      top: 0;
      left: 0;
      width: auto;
      display: inline-block;
      float: left; }
      #left-bar > div.work > div.work-listing > div.date-start::after {
        content: "-";
        margin: 0 0.25em 0 0.25em; }
    #left-bar > div.work > div.work-listing > div.date-end {
      position: inherit;
      top: 0;
      left: 0;
      width: auto;
      display: inline-block;
      float: left; }
    #left-bar > div.work > div.work-listing > h3.work-title {
      width: auto;
      float: right; }
    #left-bar > div.proficiencies > div.work-listing > h3.work-title {
      font-size: 14px; }
    #left-bar > div.stuff {
      display: none; }
    #left-bar > div.contact {
      display: none; }
    #left-bar > div.info {
      display: none; } }
