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,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-family: inherit;
  font-size: 100%;
  vertical-align: baseline;
}
body {
  line-height: 1;
  color: #000;
  background: #fff;
}
ol,
ul {
  list-style: none;
}
table {
  border-collapse: separate;
  border-spacing: 0;
  vertical-align: middle;
}
caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}
a img {
  border: none;
}
@font-face {
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  src: url("/assets/fonts/fontawesome-webfont.eot?v=#4.0.3");
  src: url("/assets/fonts/fontawesome-webfont.eot?#iefix&v=#4.0.3") format("embedded-opentype"), url("/assets/fonts/fontawesome-webfont.woff?v=#4.0.3") format("woff"), url("/assets/fonts/fontawesome-webfont.ttf?v=#4.0.3") format("truetype"), url("/assets/fonts/fontawesome-webfont.svg#fontawesomeregular?v=#4.0.3") format("svg");
}
@font-face {
  font-family: BebasNeueReg;
  font-style: normal;
  font-weight: normal;
  src: url("/assets/fonts/TypoPRO-BebasNeue-Regular.eot"), url("/assets/fonts/TypoPRO-BebasNeue-Regular.ttf") format("truetype"), url("/assets/fonts/TypoPRO-BebasNeue-Regular.woff") format("woff");
}
html,
body {
  height: 100%;
  font-family: Arial, sans-serif;
  word-wrap: break-word;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: bold;
  color: #444;
}
h1 {
  font-family: BebasNeueReg;
  color: #d40000;
  font-size: 2em;
  letter-spacing: 0.08em;
  margin: 1em 0;
}
h2 {
  color: #d40000;
  font-size: 1.5em;
  margin: 0.75em 0;
}
h2 a {
  color: #d40000 !important;
}
h3 {
  font-size: 1.3em;
  margin: 0.65em 0;
}
h4 {
  font-size: 1em;
  margin: 0.5em 0;
}
h5 {
  font-size: 0.9em;
  margin: 0.5em 0;
}
h6 {
  font-size: 0.8em;
  margin: 0.5em 0;
  color: #808080;
  font-style: italic;
}
ul li {
  padding-left: 15px;
  line-height: 1.5em;
}
em {
  font-style: italic;
}
p {
  line-height: 1.3em;
  letter-spacing: 0.08em;
  margin-bottom: 2em;
  color: #444;
}
a {
  color: #d40000;
}
a:visited {
  color: #800;
}
article {
  margin-bottom: 80px;
}
article .article-content {
  margin-top: 25px;
}
article ul li {
  list-style-type: square;
}
input {
  padding: 10px;
  border: 1px solid #999;
  margin-bottom: 10px;
}
.one-col .col-1 {
  width: 900px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 1234px) {
  .one-col .col-1 {
    width: 100%;
    padding-left: 30px;
    padding-right: 30px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
}
.one-col img,
.one-col video {
  display: block;
  max-width: 90%;
  margin: 50px auto 50px auto;
  -webkit-box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
  box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
}
.two-col .col-1 {
  width: 710px;
  float: left;
  padding-right: 30px;
}
@media screen and (max-width: 1234px) {
  .two-col .col-1 {
    width: 100%;
    padding-left: 30px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
}
.two-col .col-2 {
  width: 430px;
  padding: 20px 0;
  margin-left: 30px;
  border-top: 3px solid #d40000;
  border-bottom: 3px solid #d40000;
  float: right;
  border-top: 3px solid #d40000;
  border-bottom: 3px solid #d40000;
}
.two-col .col-2.no-top-border {
  border-top: none;
  margin-top: 0;
}
@media screen and (max-width: 1234px) {
  .two-col .col-2 {
    margin-left: 0px;
    margin-top: 50px;
    padding: 20px 30px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    float: left;
    width: 100%;
  }
}
.two-col .col-2 input,
.two-col .col-2 textarea {
  width: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  color: #444;
  font-family: Arial, sans-serif;
  font-size: 1em;
}
.two-col .col-2 textarea {
  padding: 15px;
  min-height: 200px;
}
.two-col .col-2 img {
  max-width: 100%;
  display: block;
  margin: 0px auto;
}
.msg {
  display: none;
  width: 100%;
  padding: 20px 30px 20px 30px;
  margin: 10px 0;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
  box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
}
.msg .msg-closer {
  display: block;
  position: absolute;
  right: -2px;
  top: 0px;
  width: 20px;
  height: 20px;
  line-height: 20px;
  cursor: pointer;
  color: inherit;
}
.msg .msg-closer::after {
  font-family: FontAwesome;
  content: "\f00d";
}
.msg.msg-error {
  background-color: #d9534f;
  color: #fff;
}
.msg.msg-warning {
  background-color: #f0ad4e;
  color: #802546;
}
.msg.msg-success {
  background-color: #5cb85c;
  color: #543004;
}
input.mce_inline_error {
  border: 1px solid #999;
}
div.mce_inline_error {
  display: none;
  width: 100% !important;
  font-weight: normal !important;
  padding: 20px 30px 20px 30px !important;
  margin: 10px 0 !important;
  position: relative !important;
  -webkit-box-sizing: border-box !important;
  -moz-box-sizing: border-box !important;
  box-sizing: border-box !important;
  -webkit-box-shadow: 5px 5px 5px rgba(0,0,0,0.3) !important;
  box-shadow: 5px 5px 5px rgba(0,0,0,0.3) !important;
  background-color: #d9534f !important;
  color: #fff !important;
}
.form-btns {
  margin-top: 10px;
  text-align: right;
}
.form-btns .btn:last-child {
  margin-right: 0;
}
.btn {
  padding: 10px 30px;
  display: inline-block;
  margin: 0px 10px;
  font-size: 1em;
  outline: none;
  cursor: pointer;
  width: auto !important;
}
.btn.btn-primary {
  background-color: #d40000;
  border: 1px solid #d40000;
  color: #fff !important;
  font-weight: bold;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
.btn.btn-primary:hover {
  background-color: #e00;
}
.btn.btn-secondary {
  background-color: #fff;
  color: #d40000;
  border: 1px solid #d40000;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
.btn.btn-secondary:hover {
  background-color: #f2f2f2;
}
#container {
  min-height: 100%;
  padding-bottom: 92px;
  padding-top: 57px;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
strong {
  font-weight: bold;
}
a {
  text-decoration: none;
}
.cta-container {
  text-align: center;
  zoom: 1;
}
.cta-container:before,
.cta-container:after {
  content: "";
  display: table;
}
.cta-container:after {
  clear: both;
}
.content {
  margin: auto;
  max-width: 1200px;
  zoom: 1;
}
.content:before,
.content:after {
  content: "";
  display: table;
}
.content:after {
  clear: both;
}
.content #banner-margin {
  zoom: 1;
}
.content #banner-margin:before,
.content #banner-margin:after {
  content: "";
  display: table;
}
.content #banner-margin:after {
  clear: both;
}
.content #banner-margin #attract-points {
  text-align: left;
}
.profile-links {
  font-family: FontAwesome;
  color: #f00;
}
.profile-links a.github-link:before {
  content: "\f09b";
}
.profile-links a.linkedin-link:before {
  content: "\f0e1";
}
.profile-links a.rss-link:before {
  content: "\f09e";
}
#banner {
  height: 600px;
  width: 100%;
  margin-bottom: 50px;
  border-bottom: 5px solid #d40000;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  cursor: default;
  background: -webkit-linear-gradient(top, #f2f2f2, #f4dfdf);
  background: -moz-linear-gradient(top, #f2f2f2, #f4dfdf);
  background: -o-linear-gradient(top, #f2f2f2, #f4dfdf);
  background: -ms-linear-gradient(top, #f2f2f2, #f4dfdf);
  background: linear-gradient(to bottom, #f2f2f2, #f4dfdf);
  background-image: url("/assets/img/site_bg.png");
  -webkit-background-size: auto 100%;
  -moz-background-size: auto 100%;
  background-size: auto 100%;
  background-position: center top;
  background-color: #ddd;
  background-repeat: no-repeat;
}
@media screen and (max-width: 1030px) {
  #banner {
    height: auto;
  }
}
#banner .content {
  height: 100%;
}
#banner .content #banner-margin {
  margin: 0 25px 0 25px;
}
#banner .content #banner-margin #logo {
  display: block;
  width: 300px;
  height: 300px;
  margin: 100px 100px 100px 0;
  padding-right: 100px;
  border-right: 2px solid #d40000;
  float: left;
}
@media screen and (max-width: 1030px) {
  #banner .content #banner-margin #logo {
    float: none;
    border-right: none;
    border-bottom: 2px solid #d40000;
    padding-right: 0px;
    padding-bottom: 100px;
    margin: 100px auto;
  }
}
#banner .content #banner-margin #attract-points {
  font-family: BebasNeueReg;
  color: #777;
  font-size: 2em;
  margin: 100px 100px 100px 0;
  float: left;
}
@media screen and (max-width: 1030px) {
  #banner .content #banner-margin #attract-points {
    float: none;
    display: block;
    margin: 0px auto 100px auto;
    text-align: center;
  }
}
#banner .content #banner-margin #attract-points li {
  line-height: 100px;
}
#banner .content #banner-margin #skills {
  font-family: BebasNeueReg;
  color: #777;
  text-align: right;
  float: right;
  margin: 100px 0px 100px 0;
}
@media screen and (max-width: 1030px) {
  #banner .content #banner-margin #skills {
    display: none;
  }
}
#banner .content #banner-margin #skills li {
  letter-spacing: 0.07em;
  line-height: 42.857142857142854px;
}
#intro ul {
  width: 100%;
  zoom: 1;
}
#intro ul:before,
#intro ul:after {
  content: "";
  display: table;
}
#intro ul:after {
  clear: both;
}
#intro li {
  letter-spacing: 0.1em;
  display: block;
  float: left;
  width: 50%;
  padding-right: 62px;
  padding-left: 100px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  min-height: 300px;
  color: #444;
}
@media screen and (max-width: 1030px) {
  #intro li {
    width: 100%;
  }
}
#intro li h1 {
  margin-top: 50px;
  margin-left: 0px;
}
#intro li h1 i {
  margin-left: -62px;
  display: inline-block;
  width: 32px;
  height: 32px;
  font-style: normal;
  font-family: FontAwesome;
  margin-right: 30px;
  color: #999;
}
#intro li h1 i.site-map-icon:before {
  content: "\f0e8";
}
#intro li h1 i.puzzle-piece-icon:before {
  content: "\f12e";
}
#intro li h1 i.pencil-square-icon:before {
  content: "\f044";
}
#intro li h1 i.briefcase-icon:before {
  content: "\f0b1";
}
#call-to-action {
  width: 100%;
  padding: 80px 0;
  margin-top: 100px;
  border-top: 3px solid #d40000;
  border-bottom: 3px solid #d40000;
  background: -webkit-linear-gradient(bottom, #f2f2f2, #f4dfdf);
  background: -moz-linear-gradient(bottom, #f2f2f2, #f4dfdf);
  background: -o-linear-gradient(bottom, #f2f2f2, #f4dfdf);
  background: -ms-linear-gradient(bottom, #f2f2f2, #f4dfdf);
  background: linear-gradient(to top, #f2f2f2, #f4dfdf);
  text-align: center;
}
#call-to-action p {
  padding: 0 20px;
}
#call-to-action .btn {
  margin-bottom: 10px;
  width: 100px;
}
#header {
  background-color: #fff;
  border-bottom: 5px solid #d40000;
  padding: 10px 0px;
  margin-top: -57px;
}
@media screen and (max-width: 1030px) {
  #header {
    display: none;
  }
}
#header .content a {
  display: block;
  height: 52px;
  line-height: 52px;
  text-align: center;
  float: left;
  color: #777;
  width: 130px;
  margin: 0px;
  margin-top: -10px;
  margin-bottom: -10px;
  padding: 0px;
  background-color: #fff;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
#header .content a:hover {
  background-color: #ddd;
}
#header .content .menu-home {
  width: 52px;
  height: 52px;
}
#header .content .menu-home img {
  width: 32px;
  height: 32px;
  margin: 10px;
}
#header .content .profile-links {
  float: right;
  background-color: #d40000;
  height: 10px;
}
#header .content .profile-links a {
  width: 52px;
}
#mobile-header {
  background-color: #fff;
  border-bottom: 5px solid #d40000;
  padding: 10px 0px;
  margin-top: -57px;
  position: relative;
}
@media screen and (min-width: 1031px) {
  #mobile-header {
    display: none;
  }
}
#mobile-header .content .menu-home {
  display: block;
  float: left;
  width: 52px;
  height: 52px;
  line-height: 32px;
  margin: -10px 0 -10px 0;
  padding: 0;
  cursor: pointer;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
#mobile-header .content .menu-home:hover {
  background-color: #ddd;
}
#mobile-header .content .menu-home img {
  height: 32px;
  width: 32px;
  margin: 10px;
}
#mobile-header .content .menu-icon {
  display: block;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  border: none;
  text-align: center;
  float: right;
  font-family: FontAwesome;
  font-size: 32px;
  line-height: 52px;
  color: #777;
  height: 52px;
  width: 52px;
  margin: -10px 0px -10px 0;
  padding: 0;
  cursor: pointer;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
#mobile-header .content .menu-icon:hover {
  background-color: #ddd;
}
#mobile-header .content .menu-icon:before {
  content: "\f0c9";
}
#mobile-header .content #menu-toggle {
  display: none;
}
#mobile-header .content #menu-toggle:checked ~ label.menu-icon {
  background-color: #ddd !important;
}
#mobile-header .content #menu-toggle:checked ~ .floating-container a {
  display: block;
}
#mobile-header .content .floating-container {
  width: 300px;
  background-color: #fff;
  position: absolute;
  right: 0px;
  top: 57px;
  border-left: 1px solid #999;
}
#mobile-header .content .floating-container a {
  color: #777;
  display: none;
  height: 52px;
  line-height: 52px;
  border-bottom: 1px solid #999;
  padding: 0px 15px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
#mobile-header .content .floating-container a:hover {
  background-color: #ddd;
}
#mobile-header .content .floating-container a.external-link {
  font-weight: bold;
}
#content {
  background-color: none;
  padding: 40px 10px 100px 10px;
}
.blog-nav {
  zoom: 1;
}
.blog-nav:before,
.blog-nav:after {
  content: "";
  display: table;
}
.blog-nav:after {
  clear: both;
}
.blog-nav a {
  display: block;
  width: 49%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  cursor: pointer;
}
.blog-nav a.nav-prev {
  padding: 10px 20px 10px 10px;
  float: left;
  text-align: left;
}
.blog-nav a.nav-prev i.nav-prev-icon {
  font-style: normal;
  font-family: FontAwesome;
  margin-right: 12px;
}
.blog-nav a.nav-prev i.nav-prev-icon:before {
  content: "\f0d9";
}
.blog-nav a.nav-next {
  padding-left: 20px;
  padding: 10px 10px 10px 20px;
  float: right;
  text-align: right;
}
.blog-nav a.nav-next i.nav-next-icon {
  font-style: normal;
  font-family: FontAwesome;
  margin-left: 12px;
}
.blog-nav a.nav-next i.nav-next-icon:before {
  content: "\f0da";
}
.blog-nav a .nav-label {
  font-weight: bold;
  margin-bottom: 10px;
  padding-bottom: 10px;
}
.blog-nav a .nav-post-title {
  font-size: 0.9em;
  color: #999;
}
.archive-year {
  padding-top: 30px;
}
.archive-month {
  padding-left: 15px;
}
.archive-link {
  display: block;
  padding: 10px 0 10px 30px;
}
.archive-date {
  width: 20px;
  padding-right: 10px;
  font-size: 0.8em;
  color: #777;
}
#contact-form {
  position: relative;
}
#contact-form-overlay {
  display: none;
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #fff;
  opacity: 0.7;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
  filter: alpha(opacity=70);
}
.msg {
  display: none;
  width: 100%;
  padding: 20px 30px 20px 30px;
  margin: 10px 0;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
  box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
}
.msg .msg-closer {
  display: block;
  position: absolute;
  right: -2px;
  top: 0px;
  width: 20px;
  height: 20px;
  line-height: 20px;
  cursor: pointer;
  color: inherit;
}
.msg .msg-closer::after {
  font-family: FontAwesome;
  content: "\f00d";
}
.msg.msg-error {
  background-color: #d9534f;
  color: #fff;
}
.msg.msg-warning {
  background-color: #f0ad4e;
  color: #802546;
}
.msg.msg-success {
  background-color: #5cb85c;
  color: #543004;
}
#footer {
  background-color: #d40000;
  padding: 20px 15px;
  width: 100%;
  position: absolute;
  bottom: 0px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 1030px) {
  #footer {
    padding: 0 15px;
  }
}
#footer .content {
  color: #fff;
}
#footer .content #copyright {
  float: left;
  line-height: 52px;
  font-size: 0.9em;
}
#footer .content .profile-links {
  font-size: 1.2em;
  float: right;
  background-color: #d40000;
}
#footer .content .profile-links a {
  float: left;
  display: block;
  line-height: 52px;
  text-align: center;
  height: 52px;
  width: 52px;
  color: #fff;
  transition: background-color 0.1s ease-in-out;
  moz-transition: background-color 0.1s ease-in-out;
  webkit-transition: background-color 0.1s ease-in-out;
}
#footer .content .profile-links a:hover {
  background-color: #e00;
}
