@import url("https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap");
:root {
  --primary-color: #ffffff;
  --secondary-color: rgb(34, 34, 34);
  --secondary-color-faded: rgba(34, 34, 34, 0.25);
  --highlight-color: hsla(214, 86%, 94%, 100%);
  --difference-color: rgba(90, 108, 118, 0.33);
  --difference-color-ring: #dd9446;
  --highlight-color: rgb(218, 233, 255);
  --highlight-hover: rgba(255, 255, 255, 0.5);
  --primary-text-color: #5a6c76;
  --primary-text-hover: #d06b00;
  --body: rgb(241, 241, 241);
  --body-transparent: rgba(241, 241, 241, 0.82);
  --separator: rgb(214, 214, 214);
  --grey-100: hsl(210, 14%, 95%);
  --grey-200: hsl(210, 14%, 87%);
  --grey-300: hsl(210, 14%, 80%);
  --grey-400: hsl(210, 13%, 65%);
  --grey-500: hsl(211, 10%, 55%);
  --grey-600: hsl(210, 8%, 45%);
  --grey-900: hsl(210, 14%, 87%);
  --svg-dark: rgb(34, 34, 34);
  --svg-light: rgb(131, 136, 142);
  --svg-body: rgb(241, 241, 241);
}

.dark-theme {
  --primary-color: #111111;
  --secondary-color: rgb(241, 241, 241);
  --secondary-color-faded: rgba(224, 224, 224, 0.25);
  --difference-color: rgba(174, 179, 183, 0.353);
  --difference-color-ring: rgb(18, 89, 134);
  --highlight-color: rgb(3, 27, 60);
  --highlight-hover: rgba(0, 0, 0, 0.2);
  --primary-text-color: #92a1a9;
  --primary-text-hover: #3786b7;
  --body: rgb(34, 34, 34);
  --body-transparent: rgba(34, 34, 34, 0.82);
  --separator: rgb(55, 55, 55);
  --grey-100: hsl(0, 0%, 5%);
  --grey-200: hsl(210, 3%, 16%);
  --grey-300: hsl(216, 5%, 20%);
  --grey-400: hsl(210, 7%, 44%);
  --grey-500: hsl(211, 10%, 55%);
  --grey-600: hsl(210, 10%, 58%);
  --grey-900: rgb(245, 245, 245);
  --svg-dark: rgb(241, 241, 241);
  --svg-light: rgb(161, 165, 173);
  --svg-body: rgb(34, 34, 34);
}

:root {
  --primary-color: #ffffff;
  --secondary-color: rgb(34, 34, 34);
  --secondary-color-faded: rgba(34, 34, 34, 0.25);
  --highlight-color: hsla(214, 86%, 94%, 100%);
  --difference-color: rgba(90, 108, 118, 0.33);
  --difference-color-ring: #dd9446;
  --highlight-color: rgb(218, 233, 255);
  --highlight-hover: rgba(255, 255, 255, 0.5);
  --primary-text-color: #5a6c76;
  --primary-text-hover: #d06b00;
  --body: rgb(241, 241, 241);
  --body-transparent: rgba(241, 241, 241, 0.82);
  --separator: rgb(214, 214, 214);
  --grey-100: hsl(210, 14%, 95%);
  --grey-200: hsl(210, 14%, 87%);
  --grey-300: hsl(210, 14%, 80%);
  --grey-400: hsl(210, 13%, 65%);
  --grey-500: hsl(211, 10%, 55%);
  --grey-600: hsl(210, 8%, 45%);
  --grey-900: hsl(210, 14%, 87%);
  --svg-dark: rgb(34, 34, 34);
  --svg-light: rgb(131, 136, 142);
  --svg-body: rgb(241, 241, 241);
}

.dark-theme {
  --primary-color: #111111;
  --secondary-color: rgb(241, 241, 241);
  --secondary-color-faded: rgba(224, 224, 224, 0.25);
  --difference-color: rgba(174, 179, 183, 0.353);
  --difference-color-ring: rgb(18, 89, 134);
  --highlight-color: rgb(3, 27, 60);
  --highlight-hover: rgba(0, 0, 0, 0.2);
  --primary-text-color: #92a1a9;
  --primary-text-hover: #3786b7;
  --body: rgb(34, 34, 34);
  --body-transparent: rgba(34, 34, 34, 0.82);
  --separator: rgb(55, 55, 55);
  --grey-100: hsl(0, 0%, 5%);
  --grey-200: hsl(210, 3%, 16%);
  --grey-300: hsl(216, 5%, 20%);
  --grey-400: hsl(210, 7%, 44%);
  --grey-500: hsl(211, 10%, 55%);
  --grey-600: hsl(210, 10%, 58%);
  --grey-900: rgb(245, 245, 245);
  --svg-dark: rgb(241, 241, 241);
  --svg-light: rgb(161, 165, 173);
  --svg-body: rgb(34, 34, 34);
}

@font-face {
  font-family: "wulkan";
  src: url("../fonts/wulkan_display_light-webfont.woff2") format("woff2"), url("../fonts/wulkan_display_light-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
body {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  color: var(--primary-text-color);
}

h1 {
  margin-bottom: 2.5rem;
}

h3 {
  color: var(--primary-text-color);
  font-size: 2rem;
  font-weight: 250;
  line-height: 1.75;
  margin-bottom: 1.2rem;
}
h3 a {
  transition: transform 0.25s ease;
  text-decoration: none;
  color: var(--primary-text-color);
}
h3 a:hover {
  color: var(--primary-text-hover);
  text-decoration: none;
}

@media only screen and (max-width: 767px) {
  h3 {
    font-size: 1.4rem;
  }
}
.link a {
  display: inline-block;
  margin-block: 2px;
  text-decoration: none;
  color: var(--primary-text-color);
  position: relative;
  /* hover underline animation */
  background-image: linear-gradient(transparent 0%, transparent 97%, var(--primary-text-hover) 97%, var(--primary-text-hover) 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%;
  background-position-x: right;
  transition: background-size 300ms;
  /* end hover underline animation */
}
.link a:hover {
  background-size: 100% 100%;
  background-position-x: left;
}

h4 {
  font-family: "wulkan", sans-serif;
  font-weight: 100;
  letter-spacing: 0px;
  font-size: clamp(3.75rem, 5vw, 8rem);
  line-height: 0.8;
  position: relative;
}
h4 a {
  text-decoration: none;
  color: var(--secondary-color);
}

h5 {
  color: var(--primary-color);
  text-transform: uppercase;
  font-size: 0.85rem;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: 0.05rem;
  margin-bottom: 1.2rem;
  text-align: center;
}

p {
  font-size: 1rem;
  font-weight: 300;
  letter-spacing: 0.5px;
  line-height: 1.75;
}

.work p,
.work span {
  font-size: 1.25rem;
  font-weight: 250;
  letter-spacing: 0.5px;
}

html,
body {
  height: 100%;
  box-sizing: border-box;
}
@media (min-width: 1024px) {
  html,
  body {
    cursor: none;
  }
}

body {
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  background: #eee;
  margin: 0;
  color: var(--secondary-color);
  font-family: "Inter", sans-serif;
  display: grid;
  place-content: top;
  height: 100vh;
  font-size: 1rem;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

::-moz-selection {
  /* Code for Firefox */
  color: var(--primary-text-color);
}

::selection {
  color: rgba(0, 107, 167, 0.74);
  background: rgb(231, 244, 255);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  height: 100%;
  background-color: var(--body);
  transition: background-color 0.33s, color 0.33s;
  overflow-x: hidden;
}

img {
  max-width: 100%;
}

video {
  width: 100% !important;
  height: auto !important;
}

@media (min-width: 1024px) {
  .cursor {
    position: fixed;
    z-index: 9999;
    width: 0.6rem;
    height: 0.6rem;
    margin: 0.66rem;
    background: var(--grey-900);
    mix-blend-mode: difference;
    border-radius: 50%;
    transform-origin: center;
    pointer-events: none;
  }
}
/* cursor */
@media (min-width: 1024px) {
  .cursors > div {
    width: 6rem;
    height: 6rem;
    margin: -3rem;
    box-sizing: border-box;
    border-radius: 50%;
    position: absolute;
    display: flex;
    justify-content: center;
    pointer-events: none;
    transition: transform 0.2s ease;
    z-index: 9998;
    transform-origin: center;
    transform: scale(0);
  }
  .cursors > div:first-child {
    border: none;
    background: var(--secondary-color-faded);
    mix-blend-mode: difference;
  }
  .link-center-grow {
    transform: scale(1.25) !important;
  }
  .hide {
    opacity: 0;
  }
}
/* head */
.brand {
  position: relative;
}
.brand .myname {
  position: absolute;
  top: 0.633rem;
  left: 1.75rem;
  display: block;
  color: var(--primary-text-color);
  overflow: hidden;
}
.brand .myname p {
  font-weight: 500;
  transition: transform 1s cubic-bezier(0.075, 0.82, 0.165, 1);
}

.brand-animation {
  position: relative;
}
.brand-animation p {
  transform: translateX(-96.5%);
}

nav {
  position: fixed;
  width: 100%;
  top: 0;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: var(--body-transparent);
  z-index: 999;
  transition: all 0.33s;
}
nav ul {
  list-style: none;
  display: flex;
  justify-content: space-between;
  margin: 0 2rem;
}
@media (min-width: 767px) {
  nav ul {
    margin: 0 3rem;
  }
}
nav ul li {
  flex-grow: 1;
  justify-self: flex-end;
  text-align: right;
}
nav ul li a {
  display: block;
  color: var(--primary-text-color);
  text-decoration: none;
  padding: 1rem 2rem 1rem 1rem;
  transition: all 0.33s;
  border-bottom: 1px solid var(--separator);
}
nav ul li:first-child {
  flex-grow: 7;
  text-align: left;
  font-weight: 500;
}
nav ul li a:hover {
  color: var(--primary-text-color);
  border-bottom: 1px solid var(--primary-text-hover);
}
nav ul li:last-child {
  max-width: 108px;
  min-width: 108px;
}
nav .toggle {
  position: relative;
  /* & svg {
    position: absolute;
    padding: 0.6rem;
    margin-bottom: 0;
    right: 0;
    top: 0.45rem;
  }
  & svg > path {
    fill: var(--secondary-color);
  } */
}
nav .toggle .toggle-btn {
  display: block;
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-top: 0;
}
nav .toggle .toggle-btn p {
  visibility: hidden;
  position: relative;
  height: 3rem;
}
nav .toggle .toggle-btn p:after {
  visibility: visible;
  position: absolute;
  top: 0;
  left: 0;
  content: "Switch to dark";
  font-size: 80%;
  padding: 0.9rem 0;
}
nav .toggle .flipped {
  /* transform: scaleX(-1); */
}
nav .toggle .flipped p:after {
  content: "Switch to light";
}

/* main */
main {
  width: 100%;
}

.head {
  position: relative;
  top: 0;
}
.head .title-container {
  position: relative;
  min-height: 75vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 15vh 10vw 10vh;
}
.head .title-item-wrap {
  font-family: "wulkan", sans-serif;
  perspective: 150px;
  perspective-origin: center bottom;
  display: inline-block;
  position: relative;
  padding: 0.2rem;
}
@media (min-width: 767px) {
  .head .title-item-wrap:nth-child(1) {
    position: absolute;
    top: 10vh;
    left: 20vw;
  }
  .head .title-item-wrap:nth-child(2) {
    position: absolute;
    top: 10vh;
    right: 5vw;
  }
  .head .title-item-wrap:nth-child(3) {
    position: absolute;
    top: 30vh;
    left: 5vw;
  }
  .head .title-item-wrap:nth-child(4) {
    position: absolute;
    top: 30vh;
    left: 45vw;
  }
  .head .title-item-wrap:nth-child(5) {
    position: absolute;
    top: 50vh;
    left: 25vw;
  }
  .head .title-item-wrap:nth-child(6) {
    position: absolute;
    top: 50vh;
    right: 5vw;
  }
}
@keyframes titleReveal {
  0% {
    opacity: 0;
    transform: rotateX(90deg);
  }
  20% {
    opacity: 0;
    transform: rotateX(90deg) translate3d(0, 90px, 0);
  }
  100% {
    opacity: 1;
    transform: rotateX(0deg);
  }
}
.head .title-item {
  display: inline-block;
  letter-spacing: 0px;
  font-size: clamp(4.5rem, 10vw, 12rem);
  line-height: 1;
  margin-bottom: 0.25rem;
  opacity: 0;
  transform-origin: center bottom;
  animation: 0.75s cubic-bezier(0.15, 0.685, 0.32, 1.05) calc(0.33s * var(--index)) 1 forwards titleReveal;
}
@keyframes introReveal {
  0% {
    opacity: 0;
    transform: rotateX(90deg);
  }
  20% {
    opacity: 0;
    transform: rotateX(90deg) translate3d(0, 90px, 0);
  }
  100% {
    opacity: 1;
    transform: rotateX(0deg);
  }
}
.head .intro {
  position: relative;
  max-width: 80vw;
  left: 10vw;
  opacity: 0;
  animation: 0.75s cubic-bezier(0.15, 0.685, 0.32, 1.05) 1.75s 1 forwards introReveal;
}
@media (min-width: 767px) {
  .head .intro {
    max-width: 30vw;
    left: 20vw;
  }
}

.about {
  transition: background-color 0.33s, color 0.33s;
  display: grid;
  background: var(--body);
  width: 100%;
  grid-template-columns: [full-start] minmax(2rem, 1fr) [main-start] repeat(8, 1fr) [main-end] minmax(2rem, 1fr) [full-end];
  grid-auto-rows: auto;
  row-gap: 5vh;
}
@media (min-width: 767px) {
  .about {
    row-gap: 10vh;
    grid-template-columns: [full-start] minmax(4rem, 1fr) [main-start] repeat(8, 1fr) [main-end] minmax(4rem, 1fr) [full-end];
  }
}
.about .me {
  position: relative;
  text-decoration: none;
  overflow: hidden;
  opacity: 1;
  grid-column: main;
  margin: 10vh auto;
}
.about .me img {
  border-radius: 50%;
}
@media (min-width: 767px) {
  .about .me {
    display: block;
    margin: 20vh 0 5vh 2rem;
    grid-column: 7/main-end;
  }
}

.section {
  display: grid;
  width: 100%;
  grid-template-columns: [full-start] minmax(2rem, 1fr) [main-start] repeat(8, 1fr) [main-end] minmax(2rem, 1fr) [full-end];
  grid-auto-rows: auto;
  row-gap: 5vh;
}
@media (min-width: 767px) {
  .section {
    row-gap: 10vh;
    grid-template-columns: [full-start] minmax(4rem, 1fr) [main-start] repeat(8, 1fr) [main-end] minmax(4rem, 1fr) [full-end];
  }
}
.section.current {
  grid-column: main;
  border-top: 1px solid var(--separator);
  border-bottom: 1px solid var(--separator);
  background-color: var(--highlight-hover);
  padding: 10vh 0;
}
.section.current .img-wrap {
  perspective: 200px;
  perspective-origin: center top;
  display: inline-block;
  max-width: 100%;
  width: 160px;
  grid-column: main;
}
@media (min-width: 1024px) {
  .section.current .img-wrap {
    max-width: 250px;
    grid-column: main-start/5;
  }
}
.section.current .img-wrap img {
  opacity: 0;
  margin: 0 0 1rem;
  transform-origin: center bottom;
}
@media (min-width: 1024px) {
  .section.current .img-wrap img {
    margin: 0 4rem 0 0;
    max-width: 100%;
  }
}
.section.current p {
  max-width: 100%;
  font-family: "wulkan", sans-serif;
  font-weight: 600;
  font-size: 1.5rem;
  grid-column: main;
  color: var(--secondary-color);
}
@media (min-width: 1024px) {
  .section.current p {
    grid-column: 6/10;
    font-size: 1.5rem;
  }
}
.section.current p a {
  color: var(--secondary-color);
}
@media (min-width: 1024px) {
  .section.current {
    justify-content: space-around;
  }
}
.section.showcase {
  position: relative;
  margin-bottom: 6vh;
}
@media (min-width: 767px) {
  .section.showcase {
    margin-bottom: 16vh;
  }
}
.section.showcase .intro {
  transition: background-color 0.33s, color 0.33s;
  text-align: center;
  z-index: 2;
  grid-column: main;
  margin: 20vh 0;
  background: var(--body-transparent);
  padding: 1rem 0;
  font-family: "wulkan", sans-serif;
  font-weight: 600;
  font-size: 1.2rem;
}
@media (min-width: 767px) {
  .section.showcase .intro {
    font-family: "wulkan", sans-serif;
    font-weight: 600;
    font-size: 1.2rem;
    text-align: left;
    grid-column: 6/10;
  }
}
.section.showcase .wrapper {
  z-index: 1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  position: absolute;
}
@media (min-width: 767px) {
  .section.showcase .wrapper {
    grid-column: 8/full-end;
  }
}
.section.showcase .circle {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  display: table-cell;
}
.section .hidden {
  display: none !important;
}
.section .work {
  grid-column: full;
}
.section .work .work-item-row {
  grid-column: full;
  width: 100%;
  margin-inline: auto;
  padding: 0 0.5rem;
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-start;
}
.section .work .work-item-row:nth-child(even) {
  flex-direction: column;
}
@media (min-width: 1024px) {
  .section .work .work-item-row:nth-child(even) {
    flex-direction: row;
  }
}
@media (min-width: 1024px) {
  .section .work .work-item-row {
    flex-direction: row;
  }
}
.section .work .item {
  aspect-ratio: 1/1;
  background: transparent;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  width: 100%;
}
@media (min-width: 1024px) {
  .section .work .item {
    aspect-ratio: 1/1;
  }
}
.section .work .item .block-content {
  width: 60%;
}
.section .work .item .block-content a {
  text-decoration: none;
  color: var(--secondary-color);
  position: relative;
  display: flex;
  justify-content: space-between;
}
.section .work .item .block-content a svg {
  float: right;
  background: no-repeat center right;
  background-size: contain;
  opacity: 0;
  width: 1.25rem;
  height: 1.25rem;
  margin-right: 1rem;
  transition: all 0.2s;
}
.section .work .item .block-content a:hover svg {
  opacity: 1;
  margin-right: 0rem;
}
.section .work .item.brand {
  aspect-ratio: 1.5/1;
  background: #ccc;
}
@media (min-width: 1024px) {
  .section .work .item.brand {
    aspect-ratio: 1/1;
  }
}
.section .work .item.brand img {
  opacity: 0;
}
.section .work .item.brand.mf {
  background: #f6e303;
}
.section .work .item.brand.pjc {
  background: #fff;
}
.section .work .item.brand.nbc {
  background: #e41c23;
}
.section .work .item.brand.wl {
  background: #2445ff;
}
.section .work .item.brand.kns {
  background: #e89f5b;
}
.section .work .item.brand.fos {
  background: #f5e3cd;
}
.section .work .item.brand.rvo {
  background: #055b61;
}
.section .work .item ul {
  list-style-type: none;
  margin: 0;
  padding: 2rem 0 0;
}
.section .work .item ul li {
  padding: 1rem 0.25rem;
  border-top: solid 1px var(--separator);
}
.section .work .item ul li:last-child {
  border-bottom: solid 1px var(--separator);
}
.section .work .item + .item {
  background-color: transparent;
}
.section .work-more {
  grid-column: main;
}
.section .work-more .intro {
  position: relative;
  max-width: 100%;
  left: 0vw;
  margin-top: 10vh;
  margin-bottom: 10vh;
}
@media (min-width: 767px) {
  .section .work-more .intro {
    max-width: 40%;
    left: 10vw;
  }
}
.section .work-more .work-list {
  grid-template-columns: [full-start] minmax(2rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(2rem, 1fr) [full-end];
  grid-auto-rows: auto;
  row-gap: 7vh;
  overflow: hidden;
}
@media (min-width: 1024px) {
  .section .work-more .work-list {
    grid-template-columns: [full-start] minmax(4rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(4rem, 1fr) [full-end];
    row-gap: 10vh;
  }
}
.section .work-more .work-list ul {
  display: flex;
  flex-wrap: wrap;
  grid-column: full;
}
.section .work-more .work-list li {
  font-size: 1.5rem;
  font-weight: 200;
  border-top: 1px solid var(--grey-300);
  padding: 2rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.3s cubic-bezier(0.77, 0, 0.175, 1);
  padding: 5rem 2rem;
  margin: 0 1rem;
  flex-basis: calc(100% - 2rem);
}
@media (min-width: 768px) {
  .section .work-more .work-list li {
    font-size: 2rem;
    padding: 5rem 2rem;
    flex-basis: calc(50% - 2rem);
  }
}
@media (min-width: 1024px) {
  .section .work-more .work-list li {
    font-size: 2rem;
    padding: 5rem 2rem;
    flex-basis: calc(31.5% - 2rem);
  }
}
.section .work-more .work-list li span svg .svg-dark {
  fill: var(--svg-dark);
}
.section .work-more .work-list li span svg .svg-light {
  fill: var(--svg-light);
}
.section .work-more .work-list li span svg .svg-body {
  fill: var(--svg-body);
}
.section .work-more .work-list li span:last-child {
  margin: 0 0 0 0;
}
.section .work-more .work-list li:hover {
  background: var(--highlight-hover);
}

.experience {
  display: grid;
  grid-column: main;
  grid-template-columns: [full-start] minmax(2rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(2rem, 1fr) [full-end];
  grid-auto-rows: auto;
  row-gap: 7vh;
  overflow: hidden;
}
@media (min-width: 767px) {
  .experience {
    grid-template-columns: [full-start] minmax(4rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(4rem, 1fr) [full-end];
    row-gap: 10vh;
  }
}
.experience h4 {
  grid-column: 2;
  grid-row: 1;
  padding: 20vh 0 0;
  perspective: 150px;
  perspective-origin: center bottom;
  display: inline-block;
}
@media (min-width: 767px) {
  .experience h4 {
    grid-column: 3;
  }
}
.experience h4 a {
  opacity: 0;
  display: inline-block;
  transform-origin: center bottom;
}
.experience .jobs {
  grid-column: full;
  grid-row: 2;
}
.experience .job {
  border-top: 1px solid var(--grey-300);
  padding: 2rem 0.5rem;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0 2rem;
  transition: all 0.3s cubic-bezier(0.77, 0, 0.175, 1);
}
@media (min-width: 767px) {
  .experience .job {
    flex-direction: row;
    padding: 3rem 2rem;
  }
}
.experience .job span {
  text-transform: uppercase;
  margin: 0.5rem 0;
  font-weight: 200;
}
.experience .job span:last-child {
  flex-grow: 3;
  margin: 0.5rem 0;
  line-height: 1.25;
  text-transform: none;
  font-weight: 400;
}
@media (min-width: 767px) {
  .experience .job span {
    flex: 1 1 0px;
    margin: 0 4rem 0 0;
  }
  .experience .job span:last-child {
    flex-grow: 1;
    margin: 0;
  }
}
.experience .job:last-child {
  border-bottom: 1px solid var(--grey-300);
}
.experience .job:hover {
  background: var(--highlight-hover);
}

.aboutMe {
  display: grid;
  grid-template-columns: [full-start] minmax(2rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(2rem, 1fr) [full-end];
  grid-auto-rows: auto;
  row-gap: 7vh;
  overflow: hidden;
}
@media (min-width: 767px) {
  .aboutMe {
    row-gap: 10vh;
    grid-template-columns: [full-start] minmax(4rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(4rem, 1fr) [full-end];
  }
}
.aboutMe h4 {
  margin-left: 0;
  grid-column: 2;
  grid-row: 1;
  padding: 20vh 0 0;
  perspective: 150px;
  perspective-origin: center bottom;
  display: inline-block;
}
@media (min-width: 767px) {
  .aboutMe h4 {
    grid-column: 6;
  }
}
.aboutMe h4 a {
  opacity: 0;
  display: inline-block;
  transform-origin: center bottom;
}
.aboutMe .aboutTitle {
  grid-column: main;
  grid-row: 3;
}
@media (min-width: 767px) {
  .aboutMe .aboutTitle {
    grid-column: 3/5;
    grid-row: 2;
  }
}
.aboutMe .aboutTitle .title-container {
  position: relative;
  display: flex;
  flex-direction: column;
}
.aboutMe .aboutTitle .title-item-wrap {
  font-family: "wulkan", sans-serif;
  perspective: 150px;
  padding: 0.2rem;
  perspective-origin: center bottom;
  display: inline-block;
  position: relative;
}
@media (min-width: 767px) {
  .aboutMe .aboutTitle .title-item-wrap:nth-child(1) {
    position: absolute;
    top: -2vh;
    left: -7vw;
  }
  .aboutMe .aboutTitle .title-item-wrap:nth-child(2) {
    position: absolute;
    top: 5vh;
    right: -2vw;
  }
  .aboutMe .aboutTitle .title-item-wrap:nth-child(3) {
    position: absolute;
    top: 12vh;
    left: 1vw;
  }
}
.aboutMe .aboutTitle .title-item-wrap .title-item {
  display: inline-block;
  letter-spacing: 0px;
  font-size: clamp(3.75rem, 4vw, 8rem);
  line-height: 0.8;
  margin-bottom: 0.25rem;
  opacity: 0;
  transform-origin: center bottom;
}
.aboutMe .aboutContent {
  grid-column: main;
  grid-row: 2;
  margin-bottom: 0rem;
}
@media (min-width: 767px) {
  .aboutMe .aboutContent {
    grid-column: 6/10;
    margin-bottom: 4rem;
  }
}
.aboutMe .aboutContent .strike {
  text-decoration: line-through;
}

.contact {
  display: grid;
  grid-template-columns: [full-start] minmax(2rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(2rem, 1fr) [full-end];
  grid-auto-rows: auto;
  row-gap: 5vh;
  overflow: hidden;
  padding: 0 0 20vh 0;
  position: relative;
}
@media (min-width: 767px) {
  .contact {
    row-gap: 10vh;
    grid-template-columns: [full-start] minmax(4rem, 1fr) [main-start] repeat(9, 1fr) [main-end] minmax(4rem, 1fr) [full-end];
  }
}
.contact .emailme {
  grid-column: main;
  grid-row: 3;
}
@media (min-width: 767px) {
  .contact .emailme {
    grid-column: 3;
  }
}
.contact ul {
  padding: 5vh 0 0;
  grid-column: main;
  flex-direction: column;
  grid-row: 2;
  position: relative;
  display: flex;
  justify-content: space-between;
}
@media (min-width: 767px) {
  .contact ul {
    padding: 10vh 0 0;
    flex-direction: row;
    grid-column: 3/10;
  }
}
.contact ul li {
  padding: 1rem 0;
  margin: 2rem 0;
  position: relative;
  display: inline-block;
  font-size: 1.2rem;
}
@media (min-width: 767px) {
  .contact ul li {
    padding: 1rem 0;
  }
}
.contact ul li span {
  position: absolute;
  font-size: 50%;
  top: 0;
  left: 0.1rem;
  text-align: center;
}
.contact ul li a {
  transition: all 0.3s cubic-bezier(0.77, 0, 0.175, 1);
  padding: 0;
  text-decoration: none;
}
.contact ul li.social__linkedin a {
  color: #007bb5;
}
.contact ul li.social__twitter a {
  color: var(--secondary-color);
}
.contact ul li.social__pinterest a {
  color: #cb2027;
}
.contact ul li.social__instagram a {
  color: #da27b6;
}
.contact ul li.social__linkedin a:hover {
  color: var(--secondary-color);
}
.contact ul li.social__twitter a:hover {
  color: var(--secondary-color);
}
.contact ul li.social__pinterest a:hover {
  color: var(--secondary-color);
}
.contact ul li.social__instagram a:hover {
  color: var(--secondary-color);
}
.contact ul .awards li:last-child, .contact ul .social li:last-child {
  border-bottom: none;
}

@keyframes ctaReveal {
  0% {
    opacity: 0;
    transform: rotateX(90deg);
  }
  20% {
    opacity: 0;
    transform: rotateX(90deg) translate3d(0, 90px, 0);
  }
  100% {
    opacity: 1;
    transform: rotateX(0deg);
  }
}
.inView {
  /*animation: 0.75s cubic-bezier(0.15, 0.685, 0.32, 1.05) 0.5s 1 forwards
      ctaReveal;
  */
  animation: 0.75s cubic-bezier(0.15, 0.685, 0.32, 1.05) calc(0.33s * var(--index)) 1 forwards ctaReveal;
}