/* http://meyerweb.com/eric/tools/css/reset/
   v5.0.1 | 20191019
   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, menu, 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,
main, 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, main, menu, nav, section {
  display: block; }

/* HTML5 hidden-attribute fix for newer browsers */
*[hidden] {
  display: none; }

body {
  line-height: 1; }

menu, 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; }

.flex {
  display: flex; }

.flex.col {
  flex-direction: column; }

.flex.row {
  flex-direction: row; }

.flex.reverse-col {
  flex-direction: column-reverse; }

.flex.reverse-row {
  flex-direction: row-reverse; }

.flex.start {
  justify-content: flex-start; }

.flex.end {
  justify-content: flex-end; }

.flex.center {
  justify-content: center; }

.flex.stretch {
  justify-content: stretch; }

.flex.between {
  justify-content: space-between; }

.flex.around {
  justify-content: space-around; }

.flex.evenly {
  justify-content: space-evenly; }

.flex.middle {
  align-items: center; }

.flex.fill {
  align-items: stretch; }

.flex > .grow, .flex-grow {
  flex-grow: 1; }

.flex > .shrink, .flex-shrink {
  flex-shrink: 1; }

/* container */
.flex {
  display: flex; }

/* direction */
/* flex-direction: row | row-reverse | column | column-reverse; */
.flex.col {
  flex-direction: column; }

.flex.row {
  flex-direction: row; }

.flex.col-reverse {
  flex-direction: column-reverse; }

.flex.row-reverse {
  flex-direction: row-reverse; }

/* wrap */
/* flex-wrap: nowrap | wrap | wrap-reverse; */
.flex.nowrap {
  flex-wrap: nowrap; }

.flex.wrap {
  flex-wrap: wrap; }

.flex.wrap-reverse {
  flex-wrap: wrap; }

/* main axis */
/* justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly; */
.flex[class^="start-"], .flex[class*=" start-"] {
  justify-content: flex-start; }

.flex[class^="end-"], .flex[class*=" end-"] {
  justify-content: flex-end; }

.flex[class^="center-"], .flex[class*=" center-"] {
  justify-content: center; }

.flex[class^="between-"], .flex[class*=" between-"] {
  justify-content: space-between; }

.flex[class^="around-"], .flex[class*=" around-"] {
  justify-content: space-around; }

.flex[class^="evenly-"], .flex[class*=" evenly-"] {
  justify-content: space-evenly; }

/* cross axis */
/* align-items: flex-start | flex-end | center | baseline | stretch; */
.flex[class$="-start"], .flex[class*="-start "] {
  align-items: flex-start; }

.flex[class$="-end"], .flex[class*="-end "] {
  align-items: flex-end; }

.flex[class$="-center"], .flex[class*="-center "] {
  align-items: center; }

.flex[class$="-baseline"], .flex[class*="-baseline "] {
  align-items: baseline; }

.flex[class$="-stretch"], .flex[class*="-stretch "] {
  align-items: stretch; }

.flex-inline {
  display: inline-flex; }

.p-xs {
  padding: 4px; }

.p-sm {
  padding: 8px; }

.p {
  padding: 16px; }

.p-md {
  padding: 32px; }

.p-lg {
  padding: 64px; }

.p-x-xs {
  padding-left: 4px;
  padding-right: 4px; }

.p-x-sm {
  padding-left: 8px;
  padding-right: 8px; }

.p-x {
  padding-left: 16px;
  padding-right: 16px; }

.p-x-md {
  padding-left: 32px;
  padding-right: 32px; }

.p-x-lg {
  padding-left: 64px;
  padding-right: 64px; }

.p-y-xs {
  padding-top: 4px;
  padding-bottom: 4px; }

.p-y-sm {
  padding-top: 8px;
  padding-bottom: 8px; }

.p-y {
  padding-top: 16px;
  padding-bottom: 16px; }

.p-y-md {
  padding-top: 32px;
  padding-bottom: 32px; }

.p-y-lg {
  padding-top: 64px;
  padding-bottom: 64px; }

.p-t-xs {
  padding-top: 4px; }

.p-t-sm {
  padding-top: 8px; }

.p-t {
  padding-top: 16px; }

.p-t-md {
  padding-top: 32px; }

.p-t-lg {
  padding-top: 64px; }

.p-b-xs {
  padding-bottom: 4px; }

.p-b-sm {
  padding-bottom: 8px; }

.p-b {
  padding-bottom: 16px; }

.p-b-md {
  padding-bottom: 32px; }

.p-b-lg {
  padding-bottom: 64px; }

.p-l-xs {
  padding-left: 4px; }

.p-l-sm {
  padding-left: 8px; }

.p-l {
  padding-left: 16px; }

.p-l-md {
  padding-left: 32px; }

.p-l-lg {
  padding-left: 64px; }

.p-r-xs {
  padding-right: 4px; }

.p-r-sm {
  padding-right: 8px; }

.p-r {
  padding-right: 16px; }

.p-r-md {
  padding-right: 32px; }

.p-r-lg {
  padding-right: 64px; }

.m-xs {
  margin: 4px; }

.m-sm {
  margin: 8px; }

.m {
  margin: 16px; }

.m-md {
  margin: 32px; }

.m-lg {
  margin: 64px; }

.m-x-xs {
  margin-left: 4px;
  margin-right: 4px; }

.m-x-sm {
  margin-left: 8px;
  margin-right: 8px; }

.m-x {
  margin-left: 16px;
  margin-right: 16px; }

.m-x-md {
  margin-left: 32px;
  margin-right: 32px; }

.m-x-lg {
  margin-left: 64px;
  margin-right: 64px; }

.m-y-xs {
  margin-top: 4px;
  margin-bottom: 4px; }

.m-y-sm {
  margin-top: 8px;
  margin-bottom: 8px; }

.m-y {
  margin-top: 16px;
  margin-bottom: 16px; }

.m-y-md {
  margin-top: 32px;
  margin-bottom: 32px; }

.m-y-lg {
  margin-top: 64px;
  margin-bottom: 64px; }

.m-t-xs {
  margin-top: 4px; }

.m-t-sm {
  margin-top: 8px; }

.m-t {
  margin-top: 16px; }

.m-t-md {
  margin-top: 32px; }

.m-t-lg {
  margin-top: 64px; }

.m-b-xs {
  margin-bottom: 4px; }

.m-b-sm {
  margin-bottom: 8px; }

.m-b {
  margin-bottom: 16px; }

.m-b-md {
  margin-bottom: 32px; }

.m-b-lg {
  margin-bottom: 64px; }

.m-l-xs {
  margin-left: 4px; }

.m-l-sm {
  margin-left: 8px; }

.m-l {
  margin-left: 16px; }

.m-l-md {
  margin-left: 32px; }

.m-l-lg {
  margin-left: 64px; }

.m-r-xs {
  margin-right: 4px; }

.m-r-sm {
  margin-right: 8px; }

.m-r {
  margin-right: 16px; }

.m-r-md {
  margin-right: 32px; }

.m-r-lg {
  margin-right: 64px; }

@font-face {
  font-family: 'HelveticaWeb';
  src: url("/fonts/Helvetica.woff2") format("truetype");
  font-weight: 500; }

@font-face {
  font-family: 'HelveticaWeb';
  src: url("/fonts/Helvetica-Bold.woff2") format("truetype");
  font-weight: bold; }

html {
  font-size: 16px;
  font-kerning: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }
  @media (max-width: 1280px) {
    html {
      font-size: 16px; } }
  @media (max-width: 1024px) {
    html {
      font-size: 15px; } }
  @media (max-width: 768px) {
    html {
      font-size: 14px; } }
  @media (max-width: 640px) {
    html {
      font-size: 14px; } }

body {
  font-family: 'HelveticaWeb', Helvetica, Arial, sans-serif;
  color: #1D1D1D;
  letter-spacing: -0.1px;
  line-height: 1.5; }

* {
  box-sizing: border-box; }

button {
  cursor: pointer; }

.clickable {
  cursor: pointer; }

p {
  color: #929292; }

strong {
  font-weight: bold; }

a {
  color: #1D1D1D;
  text-decoration: none; }

::-moz-selection {
  /* Code for Firefox */
  color: #1D1D1D;
  background: #FFF700; }

::selection {
  color: #1D1D1D;
  background: #FFF700; }

/* width */
::-webkit-scrollbar {
  width: 5px; }

/* Track */
::-webkit-scrollbar-track {
  background: #ebebeb; }

/* Handle */
::-webkit-scrollbar-thumb {
  background: #C4C4C4;
  border-radius: 15px; }

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #929292; }

.splash-page {
  background-image: url("/images/index/c4f99128-5112-444e-8003-38d1d6dc676c.jpg");
  background-size: cover;
  background-position: left;
  height: 100vh;
  background-color: #1D1D1D; }
  @media screen and (max-width: 768px) {
    .splash-page {
      height: 300px;
      flex-shrink: 0; } }
  .splash-page__date {
    margin-top: 16px;
    font-size: 1rem;
    color: #929292; }

.full-photo {
  position: fixed;
  top: 0;
  left: 0; }
  .full-photo__overlay {
    background: white;
    width: 100vw;
    height: 100vh;
    z-index: 10;
    animation: fadeIn 0.1s ease-out; }
  .full-photo__content {
    text-align: center;
    text-align: center;
    position: relative; }
  .full-photo__photo {
    max-height: 85vh;
    max-width: 95vw;
    vertical-align: middle; }
  .full-photo__header {
    position: absolute;
    top: 2vh;
    right: 2vh; }
    .full-photo__header button {
      font-size: 25px;
      border: none;
      border-radius: 100%;
      width: 32px;
      height: 32px;
      display: flex;
      align-items: center;
      justify-content: center; }

.full-photo-server {
  margin: 64px;
  margin-left: 0;
  max-width: 1440px; }
  @media (max-width: 1024px) {
    .full-photo-server {
      margin: 32px;
      margin-left: 0; } }
  @media (max-width: 768px) {
    .full-photo-server {
      margin: 0; }
      .full-photo-server img {
        width: 100%;
        max-height: auto; } }
  .full-photo-server img {
    max-width: 100%;
    max-height: 85vh; }

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: scale(0.7); } }

.sidemenu {
  height: 100vh;
  min-width: 450px;
  width: 450px;
  padding: 64px; }
  .sidemenu__header {
    width: 100%;
    background: red; }
    .sidemenu__header h1 {
      font-weight: bold; }
  .sidemenu__content {
    margin: 64px 0; }
    @media (max-width: 768px) {
      .sidemenu__content {
        margin: 0; } }
  @media (max-width: 1024px) {
    .sidemenu {
      padding: 32px;
      width: 330px;
      min-width: 330px; } }
  @media (max-width: 768px) {
    .sidemenu {
      height: auto;
      width: 100%;
      min-width: auto;
      flex: 1;
      padding: 32px; } }

.header a {
  margin-right: 10px;
  color: #929292;
  text-decoration: none;
  font-size: 0.69444rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-bottom: 1px solid #ebebeb;
  transition: border 0.5s, color 0.5s;
  margin-bottom: 2px; }
  .header a:last-child {
    margin-right: 0; }
  .header a:hover {
    color: #1D1D1D;
    border-bottom: 1px solid #C4C4C4; }

.header h1 {
  font-size: 1.728rem;
  font-weight: 600;
  color: #1D1D1D;
  letter-spacing: -1.5px;
  line-height: 1; }

@media (max-width: 768px) {
  .header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(255, 255, 255, 0.9);
    width: 100%;
    padding: 0 32px;
    height: 70px; }
    .header h1 {
      font-size: 1.44rem;
      letter-spacing: -1.5px; } }

.footer {
  font-size: 0.83333rem;
  color: #929292; }
  .footer .social-icon {
    width: 20px;
    margin-right: 15px;
    fill: #1D1D1D;
    transition: fill 0.3s; }
  .footer__copyright {
    margin-top: 8px;
    color: #C4C4C4; }

.vertical-layout {
  height: 100vh;
  overflow-y: auto;
  position: relative; }
  .vertical-layout__content {
    width: 100%; }
  @media (max-width: 768px) {
    .vertical-layout {
      padding-top: 70px; } }
  .vertical-layout .header {
    margin: 64px; }
    @media (max-width: 1024px) {
      .vertical-layout .header {
        margin: 32px; } }
    @media (max-width: 768px) {
      .vertical-layout .header {
        margin: 0; } }
  .vertical-layout .footer {
    padding: 64px; }
    @media (max-width: 1024px) {
      .vertical-layout .footer {
        padding: 32px; } }
    @media (max-width: 768px) {
      .vertical-layout .footer {
        padding: 32px; } }
  .vertical-layout__padded {
    padding: 0 64px; }
    @media (max-width: 1024px) {
      .vertical-layout__padded {
        padding: 0 32px; } }
    @media (max-width: 768px) {
      .vertical-layout__padded {
        padding: 0 32px; } }

.about-page {
  flex-direction: row; }
  .about-page .col {
    width: 320px;
    margin-right: 64px; }
    @media (max-width: 768px) {
      .about-page .col {
        width: 50%;
        margin-right: 16px; } }
    @media (max-width: 640px) {
      .about-page .col {
        width: 100%;
        margin-right: 0; } }
    .about-page .col:last-child {
      margin-right: 0; }
  .about-page__group {
    margin-bottom: 16px; }
    .about-page__group:last-child {
      margin-bottom: 0; }
  .about-page p {
    font-size: 1rem; }
  .about-page__spacer {
    margin-top: 32px; }
    @media (max-width: 640px) {
      .about-page__spacer {
        margin-top: 16px; } }
  .about-page__black {
    color: #1D1D1D; }
  .about-page__email {
    display: inline-block; }
  .about-page h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 8px; }
    @media (max-width: 640px) {
      .about-page h3 {
        margin-bottom: 4px; } }
  .about-page a {
    color: #1D1D1D;
    text-decoration: none;
    border-bottom: 1px solid #ebebeb; }
    .about-page a:hover {
      border-color: #C4C4C4; }
  .about-page h4 {
    color: #1D1D1D;
    line-height: 15px; }
  .about-page small {
    font-size: 0.83333rem;
    color: #929292;
    line-height: 15px; }
  @media (max-width: 640px) {
    .about-page {
      flex-direction: column; } }
  @media (max-width: 640px) {
    .about-page--mobile-hidden {
      display: none; } }
  .about-page--mobile-show {
    display: none; }
    @media (max-width: 640px) {
      .about-page--mobile-show {
        display: block; } }

.about-interviews {
  display: flex;
  line-height: 1.7; }
  .about-interviews__col {
    min-width: 170px;
    margin-right: 10px; }
  @media (max-width: 768px) {
    .about-interviews {
      flex-direction: column; } }

.horizontal-layout {
  height: 100vh; }
  @media (max-width: 768px) {
    .horizontal-layout {
      flex-direction: column-reverse;
      height: auto;
      min-height: 100vh;
      padding-top: 70px; } }
  @media (max-width: 768px) {
    .horizontal-layout .footer {
      margin-top: 64px; } }
  .horizontal-layout__content {
    height: 100vh;
    overflow-y: auto;
    flex-grow: 1; }
    @media (max-width: 768px) {
      .horizontal-layout__content {
        height: auto;
        width: 100%;
        flex-grow: 0; } }

.photo {
  background-color: rgba(255, 255, 255, 0.8);
  width: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center; }



.layout-comp.reel-comp *:first-child {
  margin-left: 0; }

.layout-comp.reel-comp *:last-child {
  margin-right: 0; }

.layout-comp .m-b, .layout-comp.m-b {
  margin-bottom: 16px; }

.layout-comp .m-b-sm, .layout-comp.m-b-sm {
  margin-bottom: 8px; }

.layout-comp .m-t, .layout-comp.m-t {
  margin-top: 16px; }

.layout-comp .m-t-sm, .layout-comp.m-t-sm {
  margin-top: 8px; }

.layout-comp .m-l, .layout-comp.m-l {
  margin-left: 16px; }

.layout-comp .m-l-sm, .layout-comp.m-l-sm {
  margin-left: 8px; }

.layout-comp .m-r, .layout-comp.m-r {
  margin-right: 16px; }

.layout-comp .m-r-sm, .layout-comp.m-r-sm {
  margin-right: 8px; }

@media (max-width: 1280px) {
  .layout-comp .m-b, .layout-comp.m-b {
    margin-bottom: 16px; }
  .layout-comp .m-b-sm, .layout-comp.m-b-sm {
    margin-bottom: 8px; }
  .layout-comp .m-t, .layout-comp.m-t {
    margin-top: 16px; }
  .layout-comp .m-t-sm, .layout-comp.m-t-sm {
    margin-top: 8px; }
  .layout-comp .m-l, .layout-comp.m-l {
    margin-left: 16px; }
  .layout-comp .m-l-sm, .layout-comp.m-l-sm {
    margin-left: 8px; }
  .layout-comp .m-r, .layout-comp.m-r {
    margin-right: 16px; }
  .layout-comp .m-r-sm, .layout-comp.m-r-sm {
    margin-right: 8px; } }

@media (max-width: 1024px) {
  .layout-comp .m-b, .layout-comp.m-b {
    margin-bottom: 16px; }
  .layout-comp .m-b-sm, .layout-comp.m-b-sm {
    margin-bottom: 8px; }
  .layout-comp .m-t, .layout-comp.m-t {
    margin-top: 16px; }
  .layout-comp .m-t-sm, .layout-comp.m-t-sm {
    margin-top: 8px; }
  .layout-comp .m-l, .layout-comp.m-l {
    margin-left: 16px; }
  .layout-comp .m-l-sm, .layout-comp.m-l-sm {
    margin-left: 8px; }
  .layout-comp .m-r, .layout-comp.m-r {
    margin-right: 16px; }
  .layout-comp .m-r-sm, .layout-comp.m-r-sm {
    margin-right: 8px; } }

@media (max-width: 768px) {
  .layout-comp .m-b, .layout-comp.m-b {
    margin-bottom: 8px; }
  .layout-comp .m-b-sm, .layout-comp.m-b-sm {
    margin-bottom: 4px; }
  .layout-comp .m-t, .layout-comp.m-t {
    margin-top: 8px; }
  .layout-comp .m-t-sm, .layout-comp.m-t-sm {
    margin-top: 4px; }
  .layout-comp .m-l, .layout-comp.m-l {
    margin-left: 8px; }
  .layout-comp .m-l-sm, .layout-comp.m-l-sm {
    margin-left: 4px; }
  .layout-comp .m-r, .layout-comp.m-r {
    margin-right: 8px; }
  .layout-comp .m-r-sm, .layout-comp.m-r-sm {
    margin-right: 4px; } }

@media (max-width: 640px) {
  .layout-comp .m-b, .layout-comp.m-b {
    margin-bottom: 8px; }
  .layout-comp .m-b-sm, .layout-comp.m-b-sm {
    margin-bottom: 4px; }
  .layout-comp .m-t, .layout-comp.m-t {
    margin-top: 8px; }
  .layout-comp .m-t-sm, .layout-comp.m-t-sm {
    margin-top: 4px; }
  .layout-comp .m-l, .layout-comp.m-l {
    margin-left: 8px; }
  .layout-comp .m-l-sm, .layout-comp.m-l-sm {
    margin-left: 4px; }
  .layout-comp .m-r, .layout-comp.m-r {
    margin-right: 8px; }
  .layout-comp .m-r-sm, .layout-comp.m-r-sm {
    margin-right: 4px; } }

.post .layout-comp {
  margin-bottom: 16px; }
  .post .layout-comp:last-child {
    margin-bottom: 0; }
  @media (max-width: 1280px) {
    .post .layout-comp {
      margin-bottom: 16px; } }
  @media (max-width: 1024px) {
    .post .layout-comp {
      margin-bottom: 16px; } }
  @media (max-width: 768px) {
    .post .layout-comp {
      margin-bottom: 8px; } }
  @media (max-width: 640px) {
    .post .layout-comp {
      margin-bottom: 8px; } }

.post-description {
  line-height: 1.5; }
  .post-description__title {
    font-size: 1rem; }
  .post-description__description {
    letter-spacing: -0.1px;
    color: #929292;
    font-size: 0.83333rem; }
    .post-description__description a {
      color: #1D1D1D;
      text-decoration: none;
      border-bottom: 1px solid #ebebeb; }
      .post-description__description a:hover {
        border-color: #C4C4C4; }
  .post-description__separator {
    color: #ebebeb; }
  .post-description__info {
    color: black;
    letter-spacing: 0.3px;
    font-size: 0.83333rem; }
  .post-description__date {
    display: inline-block;
    color: rgba(0, 0, 0, 0.5);
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 2px; }
    .post-description__date sup {
      display: inline-block;
      transform: translateY(-3px);
      font-size: 0.4rem;
      letter-spacing: 1px; }

.project-title {
  color: #1D1D1D;
  font-size: 1.2rem;
  margin-bottom: 16px; }
  .project-title small {
    font-size: 0.69444rem;
    color: #C4C4C4; }

.post-page {
  margin: 64px;
  margin-left: 0;
  max-width: 1440px; }
  @media (max-width: 1024px) {
    .post-page {
      margin: 32px;
      margin-left: 0; } }
  @media (max-width: 768px) {
    .post-page {
      margin: 0; } }

