/* ============================================================================================== */
/* !nflynn - MARCH 2019 */
/* ============================================================================================== */
/* !CSS 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; }

/* HTML5 display-role reset for older browsers */
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; }

html { -webkit-box-sizing: border-box; box-sizing: border-box; }

*, *:before, *:after { -webkit-box-sizing: inherit; box-sizing: inherit; }

IMG { vertical-align: bottom; }

.group:after { content: ""; display: table; clear: both; }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); border: 0; }

.img-responsive { height: auto; max-width: 100%; }

/* ============================================================================================== */
/* !VARIABLES */
/* ============================================================================================== */
/* !MIXINS */
/* ============================================================================================== */
/* !FONTS */
@font-face { font-family: InterstateBlack; src: url(fonts/black/interstate-black.eot); src: url(fonts/black/interstate-black.eot?#iefix) format("embedded-opentype"), url(fonts/black/interstate-black.woff) format("woff"), url(fonts/black/interstate-black.ttf) format("truetype"), url(fonts/black/interstate-black.svg#InterstateMazdaBold) format("svg"); font-weight: 900; font-style: normal; }
@font-face { font-family: InterstateLight; src: url(fonts/light/interstate-light.eot); src: url(fonts/light/interstate-light.eot?#iefix) format("embedded-opentype"), url(fonts/light/interstate-light.woff) format("woff"), url(fonts/light/interstate-light.ttf) format("truetype"); font-weight: 100; font-style: normal; }
/* ============================================================================================== */
/* !COLORS */
.grey { color: #555555; }

.white { color: #fff; }

/* ============================================================================================== */
/* !TYPOGRAPHY */
h1, h2 { font-size: 2.8rem; line-height: 28px; font-family: "InterstateBlack", sans-serif; text-transform: uppercase; color: #6b478c; position: relative; margin: 0px auto 5px; max-width: 330px; left: 0px; letter-spacing: -1px; display: block; background: -webkit-linear-gradient(-62deg, #3b4294 0%, #6b478c 50%, #8c4787 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

h3 { font-size: 2.2rem; font-family: "InterstateBlack", sans-serif; text-transform: uppercase; color: #6b478c; position: relative; margin: 0px auto 5px; max-width: 330px; line-height: 22px; left: 0px; letter-spacing: -1px; display: block; background: -webkit-linear-gradient(-62deg, #e67361 0%, #d94f80 50%, #b04a82 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

h4 { font-size: 2.0rem; }

h5 { font-size: 1.2rem; }

h6 { font-size: 1.2rem; }

@media only screen and (min-width: 480px) { h1, h2 { font-size: 3.3rem; line-height: 33px; }
  h3 { font-size: 2.2rem; } }
/* ============================================================================================== */
/* !GLOBAL */
html { font-size: 62.5%; }

html * { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

*, *:after, *:before { -webkit-box-sizing: border-box; box-sizing: border-box; }

body { font-size: 1.4rem; font-family: "InterstateLight", sans-serif; font-weight: 400; color: #555555; background: #fff; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
@media only screen and (min-width: 768px) { body { font-size: 1.4rem; } }

p { font-size: 1.4rem; margin-bottom: 10px; line-height: 1.6; padding: 0 15px; color: #555555; }

img { height: auto; width: 100%; }
img.normal { width: auto; max-width: 100%; }

hr { border: none; background: #555555; height: 1px; }

a { color: #555555; text-decoration: none; }
a:hover { color: black; }

strong { font-weight: 600; }

sup { top: -.4em; }

sub, sup { font-size: 60%; line-height: 0; vertical-align: baseline; position: relative; }

button { outline: none; }

td { line-height: 1.2; }

video { width: 100%; max-width: 1200px; height: auto; }

*:focus { outline: none; }

@media only screen and (max-width: 767px) { .hide-mobile { display: none; } }

.show-mobile { display: none; }
@media only screen and (max-width: 767px) { .show-mobile { display: block; } }

.nowrap { white-space: nowrap !important; }

.itemName { padding: 10px; font-size: 1.8rem; color: black; }
.itemName span { font-size: 1.4rem; color: #555555; }

.wrapper { position: relative; max-width: 860px; margin: auto; }

/* ============================================================================================== */
/* !TIMELINE */
/* -------------------------------- 

Modules - reusable parts of our design

-------------------------------- */
.cd-container { /* this class is used to give a max-width to the element it is applied to, and center it horizontally when it reaches that max-width */ width: 90%; max-width: 900px; margin: 0 auto; }
.cd-container::after { /* clearfix */ content: ''; display: table; clear: both; }

/* -------------------------------- 

Main components 

-------------------------------- */
.section-experience { position: relative; margin: 100px auto 0; max-width: 900px; padding: 0 20px; }
.section-experience .timeline { position: relative; padding: 2em 0 0; margin-top: 2em; margin-bottom: 3em; }
.section-experience .timeline::before { /* this is the vertical line */ content: ''; position: absolute; top: 0; left: 18px; height: 100%; width: 4px; background: #d7e4ed; }
@media only screen and (min-width: 900px) { .section-experience .timeline { margin-top: 3em; margin-bottom: 5em; }
  .section-experience .timeline::before { left: 50%; margin-left: -2px; } }

.timeline-block { position: relative; margin: 2em 0; }
.timeline-block::after { clear: both; content: ""; display: block; }
.timeline-block:first-child { margin-top: 0; }
.timeline-block:last-child { margin-bottom: 0; }
@media only screen and (min-width: 900px) { .timeline-block:first-child { margin-top: 0; }
  .timeline-block:last-child { margin-bottom: 0; } }

.timeline-dot { position: absolute; top: 0; left: 0; width: 40px; height: 40px; border-radius: 50%; background: #3b4294; background: -webkit-linear-gradient(-62deg, #3b4294, #6b478c, #8c4787); -webkit-box-shadow: 0 0 0 4px #ffffff, inset 0 2px 0 rgba(0, 0, 0, 0.08), 0 3px 0 4px rgba(0, 0, 0, 0.05); box-shadow: 0 0 0 4px #ffffff, inset 0 2px 0 rgba(0, 0, 0, 0.08), 0 3px 0 4px rgba(0, 0, 0, 0.05); }
.timeline-dot.timeline-dot-short { background: #b04a82; background: -webkit-linear-gradient(-62deg, #b04a82, #d94f80, #e67361); width: 24px; height: 24px; margin-left: 8px; margin-top: 10px; }
@media only screen and (min-width: 900px) { .timeline-dot { left: 50%; margin-left: -20px; margin-top: 10px; /* Force Hardware Acceleration in WebKit */ -webkit-transform: translateZ(0); -webkit-backface-visibility: hidden; }
  .timeline-dot.timeline-dot-short { background: #b04a82; background: -webkit-linear-gradient(-62deg, #b04a82, #d94f80, #e67361); margin-left: -13px; margin-top: 16px; } }

.timeline-content { position: relative; margin-left: 60px; max-width: 450px; padding: 1em; -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2); box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2); }
.timeline-content .itemName { padding: 0; margin-bottom: 4px; }
.timeline-content .itemName span { float: right; }
.timeline-content p { padding: 0; margin-bottom: 6px; line-height: 1.4; }
.timeline-content::after { clear: both; content: ""; display: block; }
.timeline-content .timeline-date { display: inline-block; float: left; padding: 0.5em 0 0; font-size: 1.8rem; width: 100%; color: black; }
.timeline-content .timeline-date span { font-size: 1.3rem; color: #555555; }
.timeline-content img { width: 140px; margin-top: 10px; }
.timeline-content::before { content: ''; position: absolute; top: 16px; right: 100%; height: 0; width: 0; border: 7px solid transparent; border-right: 7px solid #ffffff; }
@media only screen and (min-width: 900px) { .timeline-content { margin-left: 0; padding: 1.6em; width: 46%; }
  .timeline-content::before { top: 24px; left: 100%; border-color: transparent; border-left-color: #ffffff; }
  .timeline-content .timeline-date { position: absolute; width: 100%; left: 122%; top: 13px; }
  .timeline-block:nth-child(even) .timeline-content { float: right; }
  .timeline-block:nth-child(even) .timeline-content::before { top: 24px; left: auto; right: 100%; border-color: transparent; border-right-color: #ffffff; }
  .timeline-block:nth-child(even) .timeline-content .timeline-date { left: auto; right: 122%; text-align: right; } }

/* ============================================================================================== */
/* !TRACEABILITY */
.section-header { padding: 20px 15px; position: fixed; top: 0; z-index: 10; width: 100%; background-color: white; -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2); box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2); }
.section-header .wrapper .section-header-inner { display: -webkit-inline-box; display: -ms-inline-flexbox; display: inline-flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: baseline; -ms-flex-align: baseline; align-items: baseline; width: 100%; -ms-flex-wrap: nowrap; flex-wrap: nowrap; }

.section-intro { margin-top: 100px; }
.section-intro .wrapper { padding: 30px; }
.section-intro .logo-image { max-width: 330px; margin: 0 auto; }

.section-projects { margin: 20px auto 0; max-width: 1600px; }
.section-projects h2 { text-align: center; color: #b04a82; background: #3b4294; background: -webkit-linear-gradient(-62deg, #3b4294, #6b478c, #8c4787); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.section-projects .items { display: -webkit-inline-box; display: -ms-inline-flexbox; display: inline-flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; margin-top: 60px; }
.section-projects .items .item { -webkit-box-flex: 0; -ms-flex: 0 1 auto; flex: 0 1 auto; width: 100%; max-width: 400px; border: 6px solid white; }
@media only screen and (min-width: 1200px) { .section-projects .items .item { width: 25%; } }
@media only screen and (min-width: 768px) { .section-projects .items .item { width: 33.33%; } }
@media only screen and (min-width: 480px) { .section-projects .items .item { width: 50%; } }
.section-projects .items .item .image { border: 10px solid white; position: relative; -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2); box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.2); }
.section-projects .items .item .image .background { position: absolute; display: none; bottom: 0; opacity: 0.9; top: 0; width: 100%; background: #b04a82; background: -webkit-linear-gradient(-62deg, #b04a82, #d94f80, #e67361); }
.section-projects .items .item .image .description { position: absolute; -ms-flex-line-pack: center; align-content: center; -ms-flex-wrap: wrap; flex-wrap: wrap; display: none; text-align: center; bottom: 0; top: 0; width: 100%; padding: 10px; color: white; }
.section-projects .items .item .image .description p { font-weight: 600; letter-spacing: 0.4px; font-size: 1.5rem; width: 100%; color: white; }
.section-projects .items .item .image .description p.techUsed { opacity: 0.8; font-size: 1.3rem; margin-bottom: 0; }
.section-projects .items .item .image .description a { color: white; font-weight: 600; letter-spacing: 0.4px; text-decoration: none; padding: 6px 12px 7px; background-color: #b04a82; border-radius: 3px; margin: 15px auto; }
.section-projects .items .item .image .description a:hover { color: white; background-color: #e67361; }
.section-projects .items .item:hover .image .description { display: -webkit-box; display: -ms-flexbox; display: flex; }
.section-projects .items .item:hover .image .background { display: block; }

.section-contact { margin-top: 40px; margin-bottom: 100px; text-align: center; }
.section-contact h2 { color: #e67361; background: -webkit-linear-gradient(-62deg, #e67361 0%, #f9ab5f 50%, #f9ab5f 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; margin-bottom: 30px; }
.section-contact p { text-align: center; }
.section-contact p a { text-decoration: underline; }

/*# sourceMappingURL=main.css.map */