html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}
article, aside, details, figcaption, figure, footer, header, hgroup,
main, menu, nav, section, summary {
  display: block;
}
audio, canvas, progress, video {
  display: inline-block;
  vertical-align: baseline;
}
audio:not([controls]) {
  display: none;
  height: 0;
}
[hidden], template {
  display: none;
}
a {
  background-color: transparent;
}
a:active, a:hover {
  outline: 0;
}
abbr[title] {
  border-bottom: 1px dotted;
}
b, strong {
  font-weight: 700;
}
dfn {
  font-style: italic;
}
h1 {
  font-size: 2em;
  margin: .67em 0;
}
mark {
  background: #ff0;
  color: #000;
}
small {
  font-size: 80%;
}
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -.5em;
}
sub {
  bottom: -.25em;
}
img {
  border: 0;
}
svg:not(:root) {
  overflow: hidden;
}
figure {
  margin: 1em 40px;
}
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
pre {
  overflow: auto;
}
code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
button, input, optgroup, select, textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}
button {
  overflow: visible;
}
button, select {
  text-transform: none;
}
button, html input[type=button], input[type=reset], input[type=submit] {
  -webkit-appearance: button;
  cursor: pointer;
}
button[disabled], html input[disabled] {
  cursor: default;
}
button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
input {
  line-height: normal;
}
input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
  padding: 0;
}
input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button {
  height: auto;
}
input[type=search] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}
input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: .35em .625em .75em;
}
legend {
  border: 0;
  padding: 0;
}
textarea {
  overflow: auto;
}
optgroup {
  font-weight: 700;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td, th {
  padding: 0;
}
header, footer, article, section, hgroup, nav, figure {
  display: block;
}
input, textarea, select, button {
  -webkit-appearance: none;
  -moz-appearance: none;
  border-radius: 0;
}
* , * ::before, * ::after {
  box-sizing: border-box;
  outline: none;
  font-weight: inherit;
}
html {
  -ms-touch-action: none;
  font-size: 10px;
  font-weight: 100;
  text-align: center;
  line-height: 2rem;
  color: white;
}
body {
  font-size: 1.8rem;
  /*
  background-image: url(../img/bg.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
  */
  background: #131313;
	font-family: 'Hiragino Sans','ヒラギノ角ゴシック','Hiragino Kaku Gothic','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  margin: 0;
}
ul {
  margin: 0;
  padding: 0;
}
ul li {
  list-style: none;
}
h1, h2, h3, h4 {
  font-size: 5.4rem;
  line-height: 6.6rem;
  margin: 0;
  font-weight: 100;
  color: white;
}
h1:first-letter,
h2:first-letter,
h3:first-letter,
h4:first-letter {
  color:red;
}
h2 + .button, h2 + button {
  margin-top: 6rem;
}
p + .button, p + button {
  margin-top: 2.4rem;
}
h1 {
  font-size: 11.2rem;
  line-height: 12rem;
  font-weight: 300;
  text-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
}
a {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: color;
  color: red;
  text-decoration: none;
}
a:hover {
  color: white;
}
b, strong {
  font-weight: normal;
}
p {
  margin: 1.8rem 0;
}
.noselect {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}
#offset-element {
  position: fixed;
  width: 0;
  height: 9.6rem;
  right: 0;
}
.unvisible {
  opacity: 0;
  z-index: -1;
  height: 0;
  overflow: hidden;
}
.button, button {
  transition-duration: 200ms;
  transition-timing-function: ease;
  transition-property: color, border, background;
  border: 0.5px solid red;
  min-width: 24rem;
  text-align: center;
  padding: 0 4.8rem;
  line-height: 5.4rem;
  background: #333;
  position: relative;
  color: white;
  display: inline-block;
  border-radius: 3rem;
}
.button:after, button:after {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  content: '';
  border: .1rem solid rgba(0, 0, 0, 0.18);
  border-radius: 3rem;
}
.button:hover, button:hover {
  color: #16a085;
  -webkit-transform: scale(1.05);
  -moz-transform: scale(1.05);
  -o-transform: scale(1.05);
  transform: scale(1.05);
}
.button:active, button:active {
  background: #fff;
}
.button.theme-button, button.theme-button {
  color: red;
  background: rgba(255, 255, 255, 0.8);
}
.button.theme-button:after, button.theme-button:after {
  opacity: .8;
  border-color: #16a085;
}
#bars {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: transform;
  position: fixed;
  width: 6rem;
  height: 6rem;
  z-index: 1;
  top: 4.3rem;
  left: 6rem;
  cursor: pointer;
  background-image: url(../img/nav.png);
  background-size: 40px auto;
  background-position: center center;
  background-repeat: no-repeat;
}
#bars:hover {
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  transform: scale(1.1);
}
.close {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: background;
  position: absolute;
  line-height: 3.2rem;
  font-size: 2.4rem;
  width: 4.2rem;
  height: 4.2rem;
  right: 3.3rem;
  top: 3.3rem;
  border-radius: 50%;
  cursor: pointer;
  z-index: 1;
  background: rgba(0, 0, 0, 0.12);
}
.close svg {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: opacity;
  opacity: 1;
  width: 2.4rem;
  height: 2.4rem;
  margin: .9rem;
}
.close:hover {
  background: rgba(0, 0, 0, 0.16);
}
.close:hover svg {
  opacity: 1;
}
.close:active {
  background: rgba(0, 0, 0, 0.2);
}
#page {
  padding-left: 250px;
  width: 100%;
  overflow: hidden;
}
.section {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  position: relative;
  z-index: 1;
}
.header {
  height: 100vh !important;
  position: relative;
  overflow: hidden;
  width: 100vw !important;
  margin-left: -250px;
}
#arrow {
  position: absolute;
  bottom: 3.6rem;
  left: 50%;
  margin-left: -1.2rem;
  width: 4.2rem;
  height: 4.2rem;
  cursor: pointer;
}
#arrow svg {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: opacity, background;
  -webkit-animation: bounceAnimation 2s infinite;
  -moz-animation: bounceAnimation 2s infinite;
  animation: bounceAnimation 2s infinite;
  background: rgba(242, 242, 242, 0.2);
  padding: .9rem;
  width: 4.2rem;
  height: 4.2rem;
  opacity: .8;
  border-radius: 50%;
}
#arrow:hover svg {
  opacity: .8;
  background: rgba(242, 242, 242, 0.3);
}
#arrow:active svg {
  opacity: 1;
  background: rgba(242, 242, 242, 0.4);
}
#arrow.hidden {
  opacity: 0 !important;
  cursor: default;
}
@keyframes bounceAnimation {
  0%, 20%, 50%, 80%, 100% {
    -webkit-transform: translateY(0) ;
    -moz-transform: translateY(0) ;
    -o-transform: translateY(0) ;
    transform: translateY(0) ;
  }
  40% {
    -webkit-transform: translateY(-3rem) ;
    -moz-transform: translateY(-3rem) ;
    -o-transform: translateY(-3rem) ;
    transform: translateY(-3rem) ;
  }
  60% {
    -webkit-transform: translateY(-1.5rem) ;
    -moz-transform: translateY(-1.5rem) ;
    -o-transform: translateY(-1.5rem) ;
    transform: translateY(-1.5rem) ;
  }
}
#background {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-attachment: fixed;
}
#background:after {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-image: url(../images/presentation.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: center center;
  content: ' ';
}
#background #player {
  width: 100%;
  height: 100%;
}
#background .copy {
  position: absolute;
  z-index: 2;
  right: 15px;
  bottom: 10px;
  margin: 0;
  font-size: 1.3rem;
}
.header-center {
  position: absolute;
  top: 50%;
  margin-top: -9.199999999999999rem;
  width: 100%;
  color: #16a085;
  text-align: center;
  left: 0;
  padding: 0 10%;
}
.header-center h1 {
  color: #fff;
}
.header-center h3 {
  font-size: 3.4rem;
  line-height: 4.2rem;
  letter-spacing: 0.12em;
  margin-top: 1.8rem;
  font-weight: 300;
  color: #fff;
  font-style: normal;
  text-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
}
#social-links {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  font-size: 0;
  position: absolute;
  bottom: 2.4rem;
  left: 0;
  width: 100%;
  line-height: 0;
  padding: 0 10%;
}
#social-links a {
  display: inline-block;
  margin: 0 .6rem;
  width: 3rem;
  height: 3rem;
  margin-top: 1.2rem;
  background: rgba(0, 0, 0, 0.12);
}
#social-links a:hover {
  background: rgba(0, 0, 0, 0.16);
}
#social-links a:active {
  background: rgba(0, 0, 0, 0.2);
}
#nav {
  -webkit-transform: translateX(-250px) ;
  -moz-transform: translateX(-250px) ;
  -o-transform: translateX(-250px) ;
  transform: translateX(-250px) ;
  background-color: #1A1A1A;
  background-image: url(../images/sidebar.png);
  background-size: auto 94%;
  background-position: center;
  background-repeat: no-repeat;
  height: 100%;
  min-height: 100vh;
  left: 0;
  top: 0;
  position: fixed;
  width: 250px;
  z-index: 9999;
}
#nav:before {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  content: '';
  background: #000;
  opacity: .05;
}
#nav > * {
  z-index: 1;
}
#nav .close {
  display: none;
}
#nav .nav-center {
  height: 100vh;
  position: relative;
  width: 250px;
  display: table-cell;
  vertical-align: middle;
}
#nav ul {
  width: 100%;
  font-size: 2rem;
}
#nav ul li a {
  cursor: pointer;
  display: block;
  padding: .6rem 0;
  color: #fff;
  text-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
}
#nav ul li a span {
  position: relative;
  display: inline-block;
  padding-bottom: 8px;
}
#nav ul li a span:after {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: opacity;
  content: ' ';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 45px;
  margin: auto;
  border-bottom: 0.5px solid #666;
}
#nav ul li a:hover span:after,
#nav ul li a.active span:after {
  /* border-color: red; */
}
#nav.show {
  -webkit-transform: translateX(0) !important;
  -moz-transform: translateX(0) !important;
  -o-transform: translateX(0) !important;
  transform: translateX(0) !important;
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: transform;
}
.section-about {
  padding: 50vh 20% 15rem;
  text-align: center;
  position: relative;
}
.picture {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  display: inline-block;
  border-radius: 50%;
  width: 25vw;
  height: 25vw;
  margin: 0 auto 3.6rem auto;
}
.section-video {
  padding: 9.6rem 20%;
  position: relative;
}
.section-video .button, .section-video button {
  margin-top: 6rem;
}
.section-video div {
  z-index: 1;
  position: relative;
}
.section-video:after {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  height: 101%;
  content: '';
  opacity: .8;
}
.grid:before, .grid:after {
  content: " ";
  display: table;
}
.grid:after {
  clear: both;
}
.grid-2[data-columns]::before {
  content: '2 .column.size-1of2';
}
.grid-headshots[data-columns]::before {
  content: '4 .column.size-1of4';
}
.column {
  float: left;
}
.size-1of1 {
  width: 100%;
}
.size-1of2 {
  width: 50%;
}
.size-1of3 {
  width: 33.333%;
}
.size-1of4 {
  width: 25%;
}
.figure {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  overflow: hidden;
  padding-bottom: 50%;
  font-size: 0;
  line-height: 0;
  margin: 0;
  position: relative;
}
.figure.figure-200 {
  padding-bottom: 200%;
}
.figure.figure-150 {
  padding-bottom: 150%;
}
.figure.figure-100 {
  padding-bottom: 100%;
}
.figure.figure-66 {
  padding-bottom: 66%;
}
.figure:before, .figure:after {
  content: '';
  position: absolute;
  z-index: 1;
}
.figure:before {
  left: 0;
  width: 100%;
  height: .1rem;
  bottom: 0;
}
.figure:after {
  left: 0;
  width: .1rem;
  height: 100%;
  top: 0;
}
.section-contact {
  padding: 6rem 0 9rem;
}
form {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: opacity;
  width: 40%;
  min-width: 500px;
  margin: 3rem auto 0;
}
form input, form textarea {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: border, background;
  width: 100%;
  background: rgba(255, 255, 255, 0.66);
  border: 0;
  text-align: center;
  font-size: 1.8rem;
  border: .1rem solid rgba(0, 0, 0, 0.16);
  color: rgba(0, 0, 0, 0.6);
}
form input::-webkit-input-placeholder, form textarea::-webkit-input-placeholder {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: color;
  color: rgba(0, 0, 0, 0.4);
}
form input:-moz-placeholder, form textarea:-moz-placeholder {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: color;
  color: rgba(0, 0, 0, 0.4);
}
form input::-moz-placeholder, form textarea::-moz-placeholder {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: color;
  color: rgba(0, 0, 0, 0.4);
}
form input:-ms-input-placeholder, form textarea:-ms-input-placeholder {
  transition-duration: 200ms;
  transition-timing-function: ease-in-out;
  transition-property: color;
  color: rgba(0, 0, 0, 0.4);
}
form input:focus, form textarea:focus {
  background: rgba(255, 255, 255, 0.66);
  border-color: rgba(0, 0, 0, 0.32);
}
form input:focus::-webkit-input-placeholder, form textarea:focus::-webkit-input-placeholder {
  color: transparent;
}
form input:focus:-moz-placeholder, form textarea:focus:-moz-placeholder {
  color: transparent;
}
form input:focus::-moz-placeholder, form textarea:focus::-moz-placeholder {
  color: transparent;
}
form input:focus:-ms-input-placeholder, form textarea:focus:-ms-input-placeholder {
  color: transparent;
}
form input.error, form textarea.error {
  border-color: #f4d03f;
}
form input {
  margin-bottom: 2rem;
  height: 5.4rem;
}
form textarea {
  margin-bottom: 1.8rem;
  height: 10.8rem;
  resize: none;
  padding: 1.2rem 5.4rem;
}
.message-send {
  margin-top: 6rem;
  display: none;
  padding: 0 20%;
}
footer {
  font-size: 1.6rem;
  position: absolute;
  width: 100%;
  left: 0;
}
.ellipsis {
  margin: 0 .3rem;
  opacity: 0;
  -webkit-animation: ellipsisAnimation 1800ms ease infinite;
  -moz-animation: ellipsisAnimation 1800ms ease infinite;
  animation: ellipsisAnimation 1800ms ease infinite;
}
.ellipsis + .ellipsis {
  -webkit-animation-delay: 200ms;
  animation-delay: 200ms;
}
.ellipsis + .ellipsis + .ellipsis {
  -webkit-animation-delay: 400ms;
  animation-delay: 400ms;
}
@keyframes ellipsisAnimation {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@media only screen and (max-width: 1439px) {
  .section-video {
    border-bottom-width: 1px;
  }
  .figure:before {
    height: 1px;
  }
  .figure:after {
    width: 1px;
  }
  .button:after, button:after {
    border-width: 1px;
  }
  form input, form textarea {
    border-width: 1px;
  }
}
@media only screen and (max-width: 1050px) {
  #background {
    background-attachment: inherit;
  }
}
@media only screen and (max-width: 1000px) {
  h1, h2, h3, h4 {
    font-size: 4.2rem;
    line-height: 5.4rem;
  }
  h1 {
    font-size: 8.4rem;
    line-height: 10rem;
  }
  .header-center {
    margin-top: -7.5rem;
  }
  .header-center h3 {
    font-size: 2.9rem;
    line-height: 3.6rem;
  }
  .picture {
    width: 33vw;
    height: 33vw;
    margin-bottom: 4rem;
  }
  .section-video {
    padding: 10rem 10%;
  }
  .section-video .button, .section-video button {
    margin-top: 4rem;
  }
  .section-contact {
    padding: 10rem 0;
  }
  .grid-headshots[data-columns]::before {
    content: '2 .column.size-1of2';
  }
}
@media only screen and (max-width: 750px) {
  html {
    font-size: 9px;
    -webkit-font-smoothing: antialiased;
  }
  h1, h2, h3, h4 {
    font-size: 4.2rem;
    line-height: 5.4rem;
    font-family: 'HelveticaNeue-UltraLight';
  }
  h1 {
    font-size: 6rem;
    line-height: 7.8rem;
  }
  .header-center {
    margin-top: -11.1rem;
  }
  .header-center h1 {
    padding: 0 6%;
  }
  .header-center h3 {
    padding: 0 6%;
    font-size: 2.4rem;
    line-height: 3.6rem;
    margin-top: 1.5rem;
  }
  #background:after {
    background-size: auto 100%;
  }
  #page {
    padding-left: 0;
  }
  .header {
    margin-left: 0;
  }
  .picture {
    width: 50vw;
    height: 50vw;
  }
  form {
    min-width: 0;
    width: 88%;
  }
  .section-about {
    padding: 20rem 0 8rem !important;
  }
  .section-about > div:last-child {
    left: 6%;
    right: 6%;
  }
  .section-contact {
    padding: 6rem 0;
  }
  #bars {
    top: .8rem;
    left: 1.4rem;
    z-index: 10;
  }
  #nav {
    width: 100%;
    z-index: 11;
    -webkit-transform: translateX(-100%) !important;
    -moz-transform: translateX(-100%) !important;
    -o-transform: translateX(-100%) !important;
    transform: translateX(-100%) !important;
  }
  #nav .close {
    display: block;
  }
  #nav .nav-center {
    width: 200px !important;
    margin: auto !important;
    left: 0;
    right: 0;
    display: block;
    height: 411px !important;
    top: 0;
    bottom: 0;
    position: absolute !important;
  }
  #nav ul {
    width: 200px;
    margin: auto;
  }
  #nav ul li {
    line-height: 8.33333333vh;
  }
  #nav ul li a {
    font-size: 2.4rem;
  }
  #nav.show {
    -webkit-transform: translateX(-100%) !important;
    -moz-transform: translateX(-100%) !important;
    -o-transform: translateX(-100%) !important;
    transform: translateX(-100%) !important;
  }
  #nav.show-mobile {
    -webkit-transform: translateX(0) !important;
    -moz-transform: translateX(0) !important;
    -o-transform: translateX(0) !important;
    transform: translateX(0) !important;
  }
  #social-links {
    height: 4.2rem;
    overflow: hidden;
    bottom: auto;
    margin-top: 3.6rem;
    margin-bottom: 3.6rem;
    padding: 0 6%;
    position: relative;
  }
  #social-links a {
    margin: 0 1.2rem;
    width: 4.2rem;
    height: 4.2rem;
  }
  #social-links a svg {
    margin: 1rem;
    width: 2.2rem;
    height: 2.2rem;
  }
  .section-video {
    padding: 10rem 6%;
  }
  footer {
    padding-left: 0;
  }
}
@media only screen and (max-width: 750px) and (orientation: landscape) {
  #social-links {
    display: none;
  }
}