@font-face {
  font-family: 'icomoon';
  src: url(/fonts/icomoon.eot?uhqgj);
  src: url(/fonts/icomoon.eot?#iefixuhqgjo) format("embedded-opentype"), url(/fonts/icomoon.woff?uhqgzasdajo) format("woff"), url(/fonts/icomoon.ttf?uhqgjo) format("truetype"), url(/fonts/icomoon.svg?uhqgjo#icomoon) format("svg");
  font-weight: normal;
  font-style: normal; }
.about-content {
  position: relative;
  width: 45%;
  left: 39vw;
  top: 20vh;
  font-family: 'europa';
  color: #DAB6B6;
  text-align: justify;
  font-size: 1.7rem; }
  .about-content h2 {
    margin: 0px 0px 6px;
    color: white; }

@media only screen and (max-width: 768px) {
  .about-content {
    width: 100%;
    left: 0px;
    top: 9vh;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 16px;
    font-size: 18px; } }
.photo-content {
  width: 300px;
  top: 30vh;
  position: relative;
  right: 46vw;
  float: right;
  font-size: 3.2rem;
  line-height: 3.4rem;
  text-align: right;
  font-weight: bolder; }
  .photo-content ul {
    list-style-type: none;
    margin: 0; }
  .photo-content a {
    color: #E5ECF3DE;
    text-decoration: none; }
    .photo-content a:hover {
      color: #99433A; }

@media only screen and (max-width: 768px) {
  .photo-content {
    width: 100%;
    text-align: left;
    top: 29vh;
    left: 0px;
    font-size: 2.8rem; } }
.contact-content {
  position: relative;
  top: 15vh; }
  .contact-content .soc-icons {
    position: relative;
    margin: 10px auto 0px;
    width: 58%;
    text-align: right; }
  .contact-content .soc-icons a {
    font-size: 20px;
    width: 32px; }
    .contact-content .soc-icons a:before {
      color: #8FACE5; }

#contact-form {
  max-width: 60%;
  margin: 0 auto;
  text-align: left;
  background: #859DD040;
  padding: 32px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }
  #contact-form label {
    font-weight: 400;
    cursor: pointer; }
  #contact-form p {
    color: #CDD0DF;
    font-size: 1.2rem;
    font-family: 'europa', sans-serif;
    margin: 0px;
    line-height: 2.4rem; }
  #contact-form textarea,
  #contact-form input {
    border: none;
    outline: none;
    background: none;
    font-size: 1.2rem;
    color: white;
    padding: 0 0.3rem;
    border: 2px solid rgba(255, 255, 255, 0);
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    font-family: 'europa', sans-serif; }
  #contact-form textarea {
    text-align: left;
    resize: none;
    width: 100%;
    border-color: rgba(255, 255, 255, 0); }
  #contact-form textarea:focus {
    background-color: rgba(255, 255, 255, 0.2);
    border-bottom: 2px solid white; }
  #contact-form textarea:focus:required:valid {
    border: 2px solid rgba(255, 255, 255, 0);
    border-bottom: 2px solid rgba(255, 255, 255, 0.2); }
  #contact-form textarea:required:valid {
    border-bottom: 2px solid rgba(255, 255, 255, 0.2); }
  #contact-form input {
    border-bottom: 2px solid rgba(255, 255, 255, 0.5);
    margin: 0px 8px;
    line-height: 2.4rem; }
  #contact-form input:required,
  #contact-form textarea:required {
    border-bottom: 2px solid rgba(255, 255, 255, 0.5); }
  #contact-form input:focus {
    border-bottom: 2px solid white;
    background-color: rgba(255, 255, 255, 0.2); }
  #contact-form input:required:valid {
    border-bottom: 2px solid rgba(255, 255, 255, 0.2); }
  #contact-form input:required:invalid {
    color: rgba(255, 255, 255, 0.5); }
  #contact-form ::-webkit-input-placeholder {
    text-align: center;
    color: rgba(255, 255, 255, 0.4);
    font-style: italic;
    font-weight: 400; }
  #contact-form :-moz-placeholder {
    /* Firefox 18- */
    text-align: center;
    color: rgba(255, 255, 255, 0.4);
    font-style: italic;
    font-weight: 400; }
  #contact-form ::-moz-placeholder {
    /* Firefox 19+ */
    text-align: center;
    color: rgba(255, 255, 255, 0.4);
    font-style: italic;
    font-weight: 400; }
  #contact-form :-ms-input-placeholder {
    text-align: center;
    color: rgba(255, 255, 255, 0.4);
    font-style: italic;
    font-weight: 400; }
  #contact-form .expanding {
    vertical-align: top; }
  #contact-form .send-icn {
    fill: white; }
  #contact-form .send-icn:hover {
    fill: black;
    cursor: pointer; }
  #contact-form button {
    background: none;
    border: none;
    outline: none;
    cursor: pointer;
    margin: 28px 0px 0px;
    width: 200px;
    line-height: 40px;
    border-radius: 3px;
    background-color: #DA7E62;
    color: #C04D2A;
    font-family: 'europa', sans-serif;
    font-size: 1.2rem;
    font-weight: 800; }
  #contact-form button:hover {
    background-color: #D67152; }
  #contact-form #msg-conf {
    display: inline;
    font-size: 1rem;
    margin-left: 10px;
    font-weight: 800;
    color: #f3a891; }

@media only screen and (max-width: 768px) {
  .contact-content {
    top: 12vh; }
    .contact-content .soc-icons {
      width: 100%;
      text-align: center; }

  #contact-form {
    width: 100%;
    max-width: unset;
    padding: 21px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    font-size: 10px;
    overflow: auto; }
    #contact-form p {
      font-size: 1.1rem;
      line-height: 2rem; }
    #contact-form .submit-btn {
      text-align: center; } }
.work-content {
  background: #F8F8F7;
  width: 80%;
  margin: 0px auto;
  height: 65vh;
  -webkit-box-shadow: 1px 1px 7px -1px rgba(0, 0, 0, 0.33);
  box-shadow: 1px 1px 7px -1px rgba(0, 0, 0, 0.33);
  display: block;
  top: 14vh;
  position: relative; }
  .work-content .panel {
    height: 100%;
    width: 100%;
    display: table; }
  .work-content .panel-wrap {
    max-height: 62vh;
    overflow: auto; }
  .work-content .thumb {
    position: relative;
    height: 100%;
    max-width: 68%;
    overflow: hidden;
    display: table-cell; }
  .work-content .thumb img {
    height: 65vh;
    width: auto;
    left: 0; }
  .work-content .description {
    display: table-cell;
    color: #6E6A7E;
    padding: 16px 24px;
    vertical-align: top;
    text-align: justify;
    line-height: 1.8rem; }
  .work-content h2 {
    border-bottom: 4px solid #D7D7D1;
    color: #4C3632; }

.slick-dots li button:before {
  font-size: 11px;
  line-height: 20px;
  color: white;
  opacity: 0.5; }

.slick-dots li.slick-active button:before {
  color: white;
  opacity: 0.9; }

@media only screen and (max-width: 768px) {
  .work-content {
    width: 100%;
    height: auto; }
    .work-content .panel-wrap {
      max-height: unset;
      height: auto; }
    .work-content .panel {
      display: block; }
    .work-content .description {
      display: block;
      height: 30vh;
      overflow: auto; }
    .work-content .thumb img {
      width: 100%;
      height: auto; } }
body {
  color: #333;
  font-family: 'europa', sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", "Lucida Grande", "Helvetica Neue", "Helvetica", "Fira Sans", "Roboto", "Noto", "Droid Sans", "Cantarell", "Oxygen", "Ubuntu", "Franklin Gothic Medium", "Century Gothic", "Liberation Sans", sans-serif;
  padding: 0;
  margin: 0;
  text-align: center;
  background-color: #222; }

h1, h2, h3, h4 {
  margin: 0px; }

.pagenav {
  position: absolute;
  pointer-events: none;
  top: 10px;
  left: 10px;
  right: 10px;
  bottom: 10px;
  z-index: 1000; }

.pagenav-item {
  position: absolute; }
  .pagenav-item.top, .pagenav-item.bottom {
    left: calc(50% - 1.5em); }
  .pagenav-item.left, .pagenav-item.right {
    top: calc(50% - 1.5em); }
  .pagenav-item.right {
    right: 0; }
  .pagenav-item.bottom {
    bottom: 0; }
  .pagenav-item span {
    color: white;
    font-family: 'soleil', sans-serif;
    font-weight: 600;
    display: inline-block;
    letter-spacing: 0.06rem;
    text-shadow: 1px 1px 3px #272727b3; }
  .pagenav-item.top span {
    display: block;
    margin-top: 4px; }
  .pagenav-item.right span {
    margin-right: -6px;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg); }
  .pagenav-item.left span {
    -webkit-transform: rotate(270deg);
            transform: rotate(270deg);
    margin-left: -40px; }
  .pagenav-item.bottom span {
    display: block;
    margin-bottom: 8px; }

.pagenav-btn {
  border: 0;
  background: white;
  color: transparent;
  padding: 0;
  margin: 0;
  width: 2.2em;
  height: 2.2em;
  cursor: pointer;
  pointer-events: auto;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  display: inline-block; }
  .pagenav-btn:hover, .pagenav-btn:focus {
    width: 2.4em;
    height: 2.4em;
    color: transparent;
    -webkit-transition: 0.2s ease-in-out;
    transition: 0.2s ease-in-out; }
  .pagenav-btn.btn-top {
    -webkit-clip-path: polygon(51% 53%, 0% 100%, 100% 100%);
    clip-path: polygon(51% 53%, 0% 100%, 100% 100%); }
  .pagenav-btn.btn-right {
    top: 50%;
    right: 0;
    -webkit-clip-path: polygon(51% 53%, 0 0, 0 100%);
    clip-path: polygon(51% 53%, 0 0, 0 100%); }
  .pagenav-btn.btn-left {
    top: 50%;
    left: 0;
    -webkit-clip-path: polygon(51% 53%, 100% 100%, 100% 0);
    clip-path: polygon(51% 53%, 100% 100%, 100% 0); }
  .pagenav-btn.btn-bottom {
    bottom: 0px;
    -webkit-clip-path: polygon(51% 53%, 100% 0, 0 0);
    clip-path: polygon(51% 53%, 100% 0, 0 0); }

.barba-container {
  width: 100%;
  height: 100vh;
  background-size: cover;
  background-position: center;
  position: relative; }
  .barba-container.homie {
    background-image: url(/images/bg.jpg); }
  .barba-container.about {
    background-image: url(/images/bg_about.jpg); }
  .barba-container.photo {
    background-image: url(/images/bg_photo.jpg); }
  .barba-container.contact {
    background-image: url(/images/bg_contact.jpg); }
  .barba-container.work {
    background-image: url(/images/bg_work.jpg); }

.home-link {
  display: none;
  position: absolute;
  top: 18px;
  left: 18px;
  font-size: 1.8rem;
  font-weight: 800;
  font-family: 'europa', sans-serif;
  z-index: 100; }
  .home-link h3 {
    margin: 0; }
  .home-link a {
    color: #F1E2CE;
    text-decoration: none;
    text-shadow: 1px 1px 3px #2727272e; }

h1 {
  top: 39vh;
  font-size: 6.2rem;
  font-family: 'europa', sans-serif;
  color: white;
  position: relative;
  margin: 0px !important;
  font-weight: 700; }
  h1 .invert {
    color: #464040; }
  @media screen and (max-width: 768px) {
    h1 {
      font-size: 3.6rem; } }

a {
  color: rgba(0, 0, 0, 0.7); }
  a:focus, a:hover {
    color: rgba(0, 0, 0, 0.6); }

.subtitle {
  position: relative;
  top: calc(39vh + 16px);
  font-family: 'europa', sans-serif;
  font-size: 19px; }
  .subtitle h3 {
    margin: 5px 0px; }

.soc-icons a {
  text-decoration: none;
  color: transparent;
  width: 26px;
  display: inline-block; }
  .soc-icons a:before {
    font-family: 'icomoon';
    color: #222;
    line-height: 19px;
    display: block; }
  .soc-icons a:hover:before {
    color: #7198b6;
    -webkit-transition: 0.2s ease;
    transition: 0.2s ease; }
.soc-icons .email-soc:before {
  content: '\e603'; }
.soc-icons .insta-soc:before {
  content: '\e600'; }
.soc-icons .github-soc:before {
  content: '\e605'; }
.soc-icons .linkedin-soc:before {
  content: '\e606'; }
.soc-icons .fb-soc:before {
  content: '\e604'; }
.soc-icons .linkedin-soc:before, .soc-icons .fb-soc:before {
  line-height: 22px; }
.soc-icons .resume-soc {
  background-image: url(/images/profile.svg); }

@media only screen and (max-width: 768px) {
  .barba-container.about {
    background-size: 145vw;
    background-position: 0px 100%;
    background-repeat: no-repeat;
    background-color: #592221; }
  .barba-container.contact {
    background-size: 180vw;
    background-position: center 100%;
    background-repeat: no-repeat;
    background-color: #356ad0; }
  .barba-container.photo {
    background-size: 140vw;
    background-position: 80% 100%;
    background-color: #bf9139;
    background-repeat: no-repeat; }
  .barba-container.work {
    background-size: 150vw; }

  .pagenav {
    top: 0px;
    left: unset;
    right: 0px;
    bottom: unset;
    width: 40%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    padding: 24px 6px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    overflow: hidden; }

  .pagenav-item {
    position: relative;
    left: unset !important;
    top: unset !important; }
    .pagenav-item span {
      display: none; }
    .pagenav-item.top span, .pagenav-item.bottom span {
      display: none; }
    .pagenav-item.top {
      -webkit-box-ordinal-group: 1;
          -ms-flex-order: 0;
              order: 0; }
    .pagenav-item.bottom {
      -webkit-box-ordinal-group: 2;
          -ms-flex-order: 1;
              order: 1;
      bottom: -9px; }
    .pagenav-item.left {
      -webkit-box-ordinal-group: 3;
          -ms-flex-order: 2;
              order: 2;
      bottom: -4px;
      right: 6px; }
    .pagenav-item.right {
      -webkit-box-ordinal-group: 4;
          -ms-flex-order: 3;
              order: 3;
      bottom: -4px; }

  .pagenav-btn {
    width: 1.3em;
    height: 1.3em; }
    .pagenav-btn:hover, .pagenav-btn:focus {
      width: 1.3em;
      height: 1.3em; } }
