/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
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; }

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

button:focus, textarea:focus {
  outline: none; }

img {
  max-width: 100%;
  width: 100%; }

@keyframes write-v {
  0% {
    stroke-dashoffset: 311; }
  15% {
    stroke-dashoffset: 0; } }
@keyframes write-ally {
  0%, 15% {
    stroke-dashoffset: 960; }
  41% {
    stroke-dashoffset: 0; } }
@keyframes write-re {
  0%, 41% {
    stroke-dashoffset: 324; }
  55% {
    stroke-dashoffset: 0; } }
@keyframes write-Hleft {
  0%, 60% {
    stroke-dashoffset: 158; }
  65% {
    stroke-dashoffset: 0; } }
@keyframes write-Hright {
  0%, 65% {
    stroke-dashoffset: 198; }
  70% {
    stroke-dashoffset: 0; } }
@keyframes write-yers {
  0%, 70% {
    stroke-dashoffset: 1074; }
  100% {
    stroke-dashoffset: 0; } }
body {
  background: #7bbfc6;
  font: 300 16px/1.6 "Montserrat", sans-serif;
  margin: 0 auto;
  width: 100%; }

a {
  color: #550000;
  text-decoration: none; }
  a:hover {
    color: #142c2e; }

header {
  height: 60vh;
  min-height: 300px;
  position: relative;
  color: white;
  background: url("../img/vrhhalf.jpg") no-repeat right top fixed;
  background-size: cover; }
  header .sig {
    text-align: left;
    min-width: 300px;
    max-width: 500px; }
    header .sig svg {
      margin-top: 17vh;
      margin-left: 30px; }
  header path {
    fill: none;
    stroke: rgba(66, 145, 153, 0.8);
    stroke-width: 4;
    stroke-linecap: round;
    stroke-linejoin: round; }
  header .v {
    animation: write-v 7s 1 ease-in;
    stroke-dasharray: 311; }
  header .ally {
    animation: write-ally 7s 1 ease;
    stroke-dasharray: 960; }
  header .re {
    animation: write-re 7s 1 ease;
    stroke-dasharray: 324; }
  header .H-left {
    animation: write-Hleft 7s 1 ease;
    stroke-dasharray: 158; }
  header .H-right {
    animation: write-Hright 7s 1 ease;
    stroke-dasharray: 198; }
  header .yers {
    stroke-dasharray: 1074;
    animation: write-yers 7s 1 ease-in; }
  header .title {
    position: absolute;
    bottom: 0;
    left: 20px; }
    header .title h1 {
      font: 3rem/1 "Julius Sans One", sans-serif;
      text-shadow: 5px 5px 10px black; }
      @media screen and (max-width: 540px) {
        header .title h1 {
          font-size: 2rem; } }
      @media screen and (max-width: 355px) {
        header .title h1 {
          font-size: 1.5rem; } }
      header .title h1 span {
        font: 2rem/1 sans-serif;
        color: #bbb; }
        @media screen and (max-width: 540px) {
          header .title h1 span {
            font-size: 1.2rem; } }
    header .title h2 {
      font: 1.8rem/1.8 "Montserrat", sans-serif;
      color: #9fd0d5;
      border-bottom: none; }
      @media screen and (max-width: 540px) {
        header .title h2 {
          font-size: 1.2rem; } }
      @media screen and (max-width: 355px) {
        header .title h2 {
          font-size: 1rem; } }
      header .title h2 span {
        font: 2rem/1 sans-serif;
        color: #999; }
        @media screen and (max-width: 540px) {
          header .title h2 span {
            font-size: 1.2rem; } }

.stick {
  position: fixed;
  background-color: #8b6f48;
  width: 100%;
  height: 5vh;
  left: 0;
  padding: 50px 50px 50px 20px;
  top: -40px;
  z-index: 100;
  transition: all 1s ease;
  font-size: 1.4rem; }
  .stick h1 {
    font: 3rem/1 "Julius Sans One", sans-serif;
    text-shadow: 5px 5px 10px black; }
    @media screen and (max-width: 540px) {
      .stick h1 {
        font: 3rem/1 "Julius Sans One", sans-serif; } }
    @media screen and (max-width: 355px) {
      .stick h1 {
        font-size: 1.5rem; } }
    .stick h1 span {
      font: 2rem/1 sans-serif;
      color: #bbb; }
      @media screen and (max-width: 540px) {
        .stick h1 span {
          font-size: 1.2rem; } }

.top {
  width: 100%;
  display: flex;
  align-items: stretch; }
  @media screen and (max-width: 760px) {
    .top {
      display: inherit;
      font-size: 1rem; } }

.skills {
  width: 60%; }
  @media screen and (max-width: 760px) {
    .skills {
      width: 100%;
      font-size: 0.8rem; } }
  @media screen and (max-width: 540px) {
    .skills {
      width: 95%;
      font-size: 0.9rem; } }
  .skills ul {
    list-style: square inside none; }
    @media screen and (max-width: 540px) {
      .skills ul {
        column-count: 1; } }
    .skills ul li {
      margin-bottom: 10px; }

aside {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  width: 40%;
  height: 100%; }
  @media screen and (max-width: 760px) {
    aside {
      width: 100%;
      font-size: 0.8rem; } }
  @media screen and (max-width: 540px) {
    aside {
      display: inherit;
      font-size: 1rem;
      width: 100%; } }
  aside blockquote {
    background: #336f75;
    color: #fff;
    border-left: 15px solid #1c3d40;
    padding: 20px;
    margin: 10px;
    border-radius: 5px; }
    aside blockquote h3 {
      background-color: inherit;
      text-transform: lowercase; }
  aside blockquote p {
    display: inline; }

section {
  border: 3px solid #234d52;
  background-color: #e6f3f4;
  margin: 10px;
  padding: 20px;
  border-radius: 5px; }

h2 {
  font: 2rem/0.7 "Julius Sans One", sans-serif;
  color: #142c2e;
  border-bottom: 0.5px solid #429199;
  margin-bottom: 10px; }

h3 {
  font: 400 1.2rem/1 "Montserrat", sans-serif;
  text-transform: uppercase;
  background-color: white;
  padding: 5px 5px 0; }

.resume .contact-details {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .resume .contact-details a {
    transition: all 0.5s ease;
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 1.3rem; }
    @media screen and (max-width: 978px) {
      .resume .contact-details a {
        font-size: 1rem; } }
    .resume .contact-details a:hover {
      background-color: #7bbfc6; }

.contacts {
  display: flex;
  align-items: stretch;
  justify-content: space-between; }
  .contacts li {
    margin: 8px;
    transition: all 0.5s ease;
    filter: invert(50%); }
    .contacts li:hover {
      transform: scale(1.2);
      filter: invert(10%);
      z-index: 10; }
    .contacts li a {
      padding: none; }
      .contacts li a:hover {
        background-color: none; }

.portfolio-items {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .portfolio-items li {
    display: block;
    border: 1px solid #429199;
    margin: 5px auto;
    background-color: rgba(255, 255, 255, 0.6);
    border-radius: 5px;
    text-decoration: none;
    color: #234d52;
    min-width: 210px;
    padding: 10px;
    position: relative;
    width: 33%;
    transition: all 0.5s ease; }
    @media screen and (max-width: 760px) {
      .portfolio-items li {
        width: 48%; } }
    @media screen and (max-width: 540px) {
      .portfolio-items li {
        width: 100%; } }
  .portfolio-items a {
    margin: 0 auto;
    display: block;
    padding: 20px; }
    .portfolio-items a img {
      transition: all 0.5s ease;
      padding: 10px;
      margin: 0 auto; }
      .portfolio-items a img:hover {
        transform: scale(1.05); }
  .portfolio-items .ribbontag {
    position: absolute;
    right: -5px;
    top: -5px;
    z-index: 1;
    overflow: hidden;
    width: 75px;
    height: 75px;
    text-align: right; }
  .portfolio-items .ribbontag span {
    font-size: 0.7rem;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    text-align: center;
    line-height: 20px;
    transform: rotate(45deg);
    width: 100px;
    display: block;
    background: #336f75;
    box-shadow: 0 3px 10px -5px black;
    position: absolute;
    top: 19px;
    right: -21px; }
  .portfolio-items .ribbontag span::after,
  .portfolio-items .ribbontag span::before {
    content: '';
    position: absolute;
    left: 0;
    top: 100%;
    z-index: -1;
    border-left: 3px solid #429199;
    border-right: 3px solid transparent;
    border-bottom: 3px solid transparent;
    border-top: 3px solid #429199; }
  .portfolio-items .ribbontag span::after {
    left: 100%;
    right: 0; }
  .portfolio-items .portfolio-other {
    margin: 15px 0 15px 10px;
    background-color: rgba(255, 255, 255, 0.6);
    border-radius: 5px;
    padding: 10px;
    box-shadow: 1px 1px 10px black; }
    @media screen and (min-width: 760px) {
      .portfolio-items .portfolio-other {
        flex-grow: 3; } }
    @media screen and (max-width: 760px) {
      .portfolio-items .portfolio-other {
        width: 100%; } }
    @media screen and (max-width: 540px) {
      .portfolio-items .portfolio-other {
        width: 100%; } }
    .portfolio-items .portfolio-other h3 {
      background-color: white; }
    .portfolio-items .portfolio-other li {
      border: none; }
  .portfolio-items ul {
    column-count: 1;
    margin-top: 10px;
    margin-left: 10px; }
    @media screen and (max-width: 760px) {
      .portfolio-items ul {
        font-size: 0.8rem; } }
    @media screen and (min-width: 760px) {
      .portfolio-items ul {
        column-count: 2;
        font-size: 1rem; } }
    @media screen and (min-width: 978px) {
      .portfolio-items ul {
        column-count: 3;
        font-size: 1rem; } }
    .portfolio-items ul .portfolio-other-item {
      box-shadow: none;
      padding: 0;
      width: 100%; }
      .portfolio-items ul .portfolio-other-item:hover {
        background-color: rgba(255, 255, 255, 0.6);
        color: #000; }

.bold {
  font-weight: 600;
  color: #336f75; }

footer {
  text-align: center; }
  footer h3 {
    background-color: #8b6f48;
    color: #fff;
    padding: 20px; }

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