/*
YUI 3.4.1 (build 4118)
Copyright 2011 Yahoo! Inc. All rights reserved.
Licensed under the BSD License.
http://yuilibrary.com/license/
*/
html {
  color: #000;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset, img {
  border: 0;
}

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal;
}

ol, ul {
  list-style: none;
}

caption, th {
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

q:before, q:after {
  content: "";
}

abbr, acronym {
  border: 0;
  font-variant: normal;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
}

input, textarea, select {
  font-size: 100%;
}

legend {
  color: #000;
}

@font-face {
  font-family: "Extended Bold";
  src: url("../fonts/ABCROMExtended-Bold-Trial.woff2") format("woff2"), url("../fonts/ABCROMExtended-Bold-Trial.otf") format("opentype"), url("../fonts/ABCROMExtended-Bold-Trial.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
body.archive .button:hover, .button, .navLinksWrapper.inverted .navLinks .button:hover, .navLinks.inverted .button:hover {
  display: inline-block;
  background-color: white;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: black;
  text-decoration: none;
  border: 1px solid black;
  font-size: 15px;
  line-height: 18px;
  z-index: 1;
}
@media (min-width: 769px) {
  body.archive .button:hover, .button, .navLinksWrapper.inverted .navLinks .button:hover, .navLinks.inverted .button:hover {
    padding: 12px 24px;
  }
}

body.archive .button, .button:hover, .navLinksWrapper.inverted .navLinks .button, .navLinks.inverted .button {
  color: white;
  border-color: white;
  background-color: black;
}

#loadMoreProjects, body {
  font-family: "Extended Bold";
  font-size: 22px;
  line-height: 28px;
}

@keyframes slideRight {
  0% {
    transform: translate3d(-50%, 0, 0);
  }
  100% {
    transform: translate3d(0%, 0, 0);
  }
}
@keyframes slideLeft {
  0% {
    transform: translate3d(0px, 0, 0);
  }
  100% {
    transform: translate3d(-50%, 0, 0);
  }
}
@keyframes loading {
  from {
    filter: invert(0%);
  }
  to {
    filter: invert(100%);
  }
}
*, *:before, *:after {
  box-sizing: border-box;
}

html, body {
  height: 100%;
  background-color: #fff;
}

body {
  position: relative;
  -webkit-text-size-adjust: 100%;
  transition: filter 500ms;
}
body:has(.index) {
  overflow-y: scroll !important;
  overflow-x: hidden;
  height: auto !important;
}

body.inverted {
  background-color: black;
}
body.inverted #contentWrapper, body.inverted #clock-container, body.inverted .navLinksWrapper {
  filter: invert(100%);
}

a {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}

.cn-page-wrap {
  position: absolute;
  overflow: hidden;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

.cn-page-shim-outer {
  height: 100%;
  overflow-y: scroll;
  width: 100vw;
  -webkit-overflow-scrolling: touch;
}

.cn-page-shim-inner {
  position: relative;
  overflow: hidden;
  min-height: 120%;
}

.burger-menu-toggle {
  display: none;
  position: fixed;
  top: 5px;
  right: 5px;
  z-index: 1001;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 10px;
  flex-direction: column;
  justify-content: space-between;
  width: 40px;
  height: 34px;
}
@media (max-width: 768px) {
  .burger-menu-toggle {
    display: flex;
  }
}
.burger-menu-toggle .burger-line {
  width: 100%;
  height: 2px;
  background-color: black;
  position: relative;
}
.burger-menu-toggle.inverted .burger-line, body.inverted .burger-menu-toggle .burger-line, body.archive .burger-menu-toggle .burger-line {
  background-color: white;
}
.burger-menu-toggle[aria-expanded=true] .burger-line {
  position: absolute;
  top: 50%;
  left: 25%;
  width: 50%;
  margin-top: -1px;
  transform-origin: center center;
}
.burger-menu-toggle[aria-expanded=true] .burger-line:nth-child(1) {
  transform: rotate(45deg);
}
.burger-menu-toggle[aria-expanded=true] .burger-line:nth-child(2) {
  opacity: 0;
}
.burger-menu-toggle[aria-expanded=true] .burger-line:nth-child(3) {
  transform: rotate(-45deg);
}

.navLinksWrapper {
  display: flex;
  position: fixed;
  top: 20px;
  right: 50px;
  z-index: 2;
  align-items: center;
}
@media (max-width: 768px) {
  .navLinksWrapper {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    max-width: 260px;
    background: transparent;
    flex-direction: column;
    align-items: flex-start;
    padding: 55px 15px 0;
    transform: translateX(100%);
    transition: transform 0.3s ease;
  }
  .navLinksWrapper.menu-open {
    transform: translateX(0);
  }
}

.navLinks {
  display: flex;
}
@media (max-width: 768px) {
  .navLinks {
    flex-direction: column;
    width: 100%;
    gap: 0;
    border: 1px solid;
  }
}
.navLinksWrapper.inverted .navLinks {
  border-color: white;
}
.navLinksWrapper.inverted .aboutLink {
  background: white;
  color: black;
  border: 1px solid black;
}
.navLinksWrapper.inverted .aboutLink:hover {
  background: black;
  color: white;
  border: 1px solid white;
}

@media (max-width: 768px) {
  .archive .navLinks {
    border: 1px solid white;
  }
}

.navLinks .button {
  float: right;
  border-right: none !important;
}
@media (max-width: 768px) {
  .navLinks .button {
    float: none;
    width: 100%;
    border-top: none !important;
    border-left: none !important;
    text-align: left;
    padding: 15px;
  }
}

.button-about-mobile {
  display: none;
}
@media (max-width: 768px) {
  .button-about-mobile {
    display: block;
  }
}

@media (max-width: 768px) {
  .navLinks .button:last-child {
    border-bottom: none !important;
  }
}
@media (min-width: 769px) {
  .navLinks .button:last-child {
    border-right: 1px solid !important;
  }
}

@media (min-width: 769px) {
  .navLinks .button.border-right {
    border-right: 1px solid !important;
  }
}

.aboutLink {
  background: black;
  color: white;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  font-size: 16px;
  border-radius: 50%;
  padding: 10px;
  margin-left: 20px;
}
@media (max-width: 768px) {
  .aboutLink {
    display: none;
  }
}
.aboutLink:hover {
  background: white;
  color: black;
  border: 1px solid black;
}
.aboutLink.inverted {
  background: white;
  color: black;
  border: 1px solid black;
}
.aboutLink.inverted:hover {
  background: black;
  color: white;
  border: 1px solid white;
}

.topLink {
  display: none;
  position: fixed;
  right: 73px;
  bottom: 20px;
  width: 20px;
  height: 15px;
  background: url("../images/arrow-up.png");
  z-index: 1;
}

.topLink.bottom {
  position: absolute;
  bottom: 120px;
  right: 58px;
  z-index: 1000;
}

#archiveLink.mti_font_element {
  opacity: 1;
}

.navTarget {
  position: absolute;
  cursor: pointer;
  width: 10%;
  height: 100%;
  top: 0px;
}

.navTarget.left {
  left: 0px;
}

.navTarget.right {
  right: 0px;
}

.projectNav {
  position: absolute;
  z-index: 1000;
  height: 100%;
  width: 23px;
  background-color: yellow;
  top: 0px;
  transition: 0.25s;
}

.home .projectNav {
  top: var(--home-swiper-height);
}

.projectNav:hover,
.navTarget:hover .projectNav,
.cn-project-nav:hover .projectNav {
  width: 28px;
}

.projectNav.disabled:hover,
.navTarget:hover .projectNav.disabled {
  width: 23px;
}

.projectNav.left {
  left: 0px;
}

.projectNav.right {
  right: 0px;
}

@media (max-width: 768px) {
  .projectNav,
  .projectNav:hover,
  .navTarget:hover .projectNav,
  .cn-project-nav:hover .projectNav {
    display: none;
  }
}
.bottomNavLink {
  width: 50.1%;
  color: black;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 5px;
  padding: 35px 0px;
  position: absolute;
  bottom: 0px;
  z-index: 1;
}
@media (max-width: 768px) {
  .bottomNavLink {
    padding: 20px 0;
    font-size: 16px;
  }
}

.bottomNavLink.left {
  left: 0px;
  float: left;
}

.bottomNavLink.right {
  float: right;
  right: 0px;
}

#contentWrapper {
  width: 100%;
  overflow: hidden;
  position: relative;
  height: 100%;
}

#content {
  margin: 0px auto 0px auto;
  position: relative;
  left: 0px;
  overflow: hidden;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.sectionTitle {
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 5px;
  font-size: 22px;
  padding: 80px 0px 73px 0;
}

.footer {
  font-size: 15px;
  line-height: 20px;
  text-align: center;
  padding: 20px 0px;
  clear: both;
}

/* Individual Project */
/* 
==============	
Info page
==============
*/
/* 
==============	
Default page template
==============
*/
/*.page-template-default #content {
	width: auto;
	padding: 0px 15%;
	}

.page-template-default #contentWrapper {
	overflow: auto;
	-webkit-overflow-scrolling:touch;
}

.page-template-default .infoWrapper a {
	border-bottom: 1px solid black;
	}

.page-template-default .infoWrapper a:hover {
	border-bottom: none;
	}	

.page-template-default .projectNav {
	background-color: black;
	-webkit-transform: translate3d(0,0,0);
	}

.page-template-default .infoWrapper {
	margin: 0 auto;
	padding-bottom: 150px;
	overflow: auto;
}*/
/* 
==============	
Archive page
==============
*/
.projectCont {
  display: block;
  float: left;
  margin: 0px 10px;
}

#archived-projects {
  padding-bottom: 150px;
}

#loadMoreProjectsContainer {
  position: absolute;
  left: 0;
  width: 100%;
  bottom: 0;
  z-index: 1001;
}

#loadMoreProjects {
  margin: 0 auto;
  padding: 35px 0;
  display: block;
  background: #fff;
  color: black;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 5px;
}
@media (max-width: 768px) {
  #loadMoreProjects {
    font-size: 16px;
    line-height: 22px;
  }
}
#loadMoreProjects.loading-more-projects {
  animation: loading 1.5s infinite linear alternate;
}

/* 
==============	
Archive Page
==============
*/
body.archive {
  background-color: black;
}
body.archive .project {
  color: white;
}
body.archive .project .description a,
body.archive .project .caption a {
  border-bottom: 1px solid white;
}
body.archive .arrow.left {
  border-right-color: white;
}
body.archive .arrow.right {
  border-left-color: white;
}
body.archive .topLink {
  background: url("../images/arrow-up-white.png");
}
body.archive .aboutLink {
  background: white;
  color: black;
}
body.archive .aboutLink:hover {
  background: black;
  color: white;
  border: 1px solid white;
}

/* 
==============	
Single Page
==============
*/
/* 
==============	
Animations
==============
*/
#content.beforeSlide {
  width: 200%;
  position: relative;
  -webkit-animation-duration: 700ms;
  -webkit-animation-fill-mode: both;
  -webkit-animation-timing-function: ease-in-out;
  -moz-animation-duration: 700ms;
  -moz-animation-fill-mode: both;
  -moz-animation-timing-function: ease-in-out;
}

#content.beforeSlide .project {
  width: 50%;
  display: block;
  position: static;
}

#content.beforeSlideLeft .project {
  float: left;
}

#content.slideLeft {
  -webkit-animation-name: slideLeft; /* Safari 5, Chrome */
  -moz-animation-name: slideLeft; /* Firefox 5-15 */
}

#content.beforeSlideRight .project {
  float: right;
}

#content.slideRight {
  -webkit-animation-name: slideRight;
  -moz-animation-name: slideRight; /* Firefox 5-15 */
}

/* 
==============	
iOS Styling
==============
*/
@media screen and (device-width: 480px), screen and (device-width: 320px) {
  body,
  .about .h1 {
    font-size: 36px;
    line-height: 44px;
  }
  .about .bottomText,
  .about .widget_twitter .time-meta a,
  .footer,
  .button, body.archive .button:hover,
  .index,
  .about .contact {
    font-size: 22px;
    line-height: 30px;
  }
  .project .caption p,
  .index p {
    font-size: 21px;
    line-height: 28px;
  }
  .button {
    width: 220px;
  }
}
@media screen and (max-width: 1024px), screen and (max-width: 770px), screen and (max-width: 480px), screen and (max-width: 320px) {
  .projectNav:hover {
    width: 23px !important;
  }
}
/**
 * Index page styles
 * Home swiper fixed at top, projects overview scrolls below
 */
.index {
  --home-swiper-height: 100vh;
}
@media (orientation: portrait) {
  .index {
    --home-swiper-height: 100vw;
  }
}
.index .home-swiper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--home-swiper-height);
  z-index: 1;
  pointer-events: none;
}
.index .home-swiper .swiper-slide {
  height: var(--home-swiper-height);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  pointer-events: auto;
  position: relative;
  z-index: 10;
}
.index .home-swiper .swiper-slide > div {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}
.index .home-swiper .swiper-slide a {
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}
.index .home-swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  margin: 0;
  padding: 0;
}
.index .home-swiper .swiper-slide .title,
.index .home-swiper .swiper-slide .client {
  position: absolute;
  z-index: 20;
}
.index .home-swiper .swiper-slide .title {
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px 65px;
  color: white;
  z-index: 25;
  position: absolute;
}
.index .home-swiper .swiper-slide .title::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  top: calc(-1 * var(--home-swiper-height));
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.4) 100px, transparent 100%);
  pointer-events: none;
  z-index: -1;
}
@media (max-width: 768px) {
  .index .home-swiper .swiper-slide .title {
    bottom: 0;
    padding: 15px 5%;
    font-size: 14px;
    line-height: 20px;
  }
}
.index .home-swiper .swiper-slide .client {
  bottom: 30px;
  left: 0;
  right: 0;
}
.index .home-swiper .swiper-button-next,
.index .home-swiper .swiper-button-prev {
  pointer-events: auto;
  width: 0;
  height: 0;
  margin-top: 0;
  background: none;
  border: none;
  position: fixed;
  top: calc(var(--home-swiper-height) / 2);
  transform: translateY(-50%);
  z-index: 1000;
}
.index .home-swiper .swiper-button-next::after,
.index .home-swiper .swiper-button-prev::after {
  display: none;
}
.index .home-swiper .swiper-button-prev {
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-right: 20px solid black;
  left: 35px;
}
@media (max-width: 768px) {
  .index .home-swiper .swiper-button-prev {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-right-width: 12px;
    left: 1%;
  }
}
.index .home-swiper .swiper-button-next {
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid black;
  right: 35px;
}
@media (max-width: 768px) {
  .index .home-swiper .swiper-button-next {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-left-width: 12px;
    right: 1%;
  }
}
.index .home-swiper .swiper-pagination {
  pointer-events: auto;
}
.index.cn-page-wrap {
  position: relative !important;
  overflow: visible !important;
  height: auto !important;
  min-height: 200vh;
}
.index .cn-page-shim-outer {
  overflow: visible !important;
  height: auto !important;
  position: relative;
}
.index .cn-page-shim-inner {
  min-height: 200vh;
  overflow: visible;
}

body.home .cn-page-shim-inner {
  padding-top: var(--home-swiper-height);
}

/**
 * Project view template (home page, archives)
 */
body.tpl-project-view.page-archive {
  background-color: #000;
  color: #fff;
}

/**
 * Project list template (projects index)
 */
body.page-template-page-index,
body.home {
  font-size: 15px;
  line-height: 20px;
}
body.page-template-page-index img,
body.home img {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 12px;
}
body.page-template-page-index p,
body.home p {
  margin: 0px;
  padding: 0px;
}
body.page-template-page-index .project,
body.home .project {
  display: block;
  position: static;
  padding: 0;
}
body.page-template-page-index .cn-page-shim-outer,
body.home .cn-page-shim-outer {
  position: static;
}
body.page-template-page-index .projectNav,
body.home .projectNav {
  background-color: black;
  background-image: url("../images/archive-bg.png");
}
body.page-template-page-index .projectNav:hover,
body.home .projectNav:hover {
  width: 23px;
}
body.page-template-page-index .projectNav.right,
body.home .projectNav.right {
  background-image: url("../images/archive-bg-small.png");
}
body.page-template-page-index .projects-section,
body.home .projects-section {
  padding: 0px 125px;
}
@media (max-width: 768px) {
  body.page-template-page-index .projects-section,
  body.home .projects-section {
    padding: 0px 5%;
  }
}
body.page-template-page-index .project-list,
body.home .project-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  row-gap: 45px;
  -moz-column-gap: 20px;
       column-gap: 20px;
}
@media (max-width: 768px) {
  body.page-template-page-index .project-list,
  body.home .project-list {
    row-gap: 30px;
  }
}
@media (max-width: 768px) {
  body.page-template-page-index .project-thumbnail .title,
  body.page-template-page-index .project-thumbnail .client,
  body.home .project-thumbnail .title,
  body.home .project-thumbnail .client {
    font-size: 13px;
    line-height: 18px;
  }
}
body.page-template-page-index #featured-projects,
body.home #featured-projects {
  position: relative;
  z-index: 1000;
  background-color: #fff;
  padding-top: 45px;
  padding-bottom: 75px;
  filter: drop-shadow(0 0 25px rgba(0, 0, 0, 0.3));
}
body.page-template-page-index #featured-projects .project,
body.home #featured-projects .project {
  flex: 0 0 calc((100% - 20px) / 2);
  min-width: 0;
}
body.page-template-page-index #archived-projects,
body.home #archived-projects {
  position: relative;
  z-index: 1000;
  background-color: black;
  color: white;
  padding-bottom: 150px;
}
body.page-template-page-index #archived-projects h2,
body.home #archived-projects h2 {
  padding: 75px 0 73px 0;
  color: white;
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: 5px;
  text-align: center;
}
@media (max-width: 768px) {
  body.page-template-page-index #archived-projects h2,
  body.home #archived-projects h2 {
    font-size: 16px;
    padding: 50px 0 40px 0;
  }
}
body.page-template-page-index #archived-projects .project-thumbnail,
body.home #archived-projects .project-thumbnail {
  flex: 0 0 calc((100% - 20px) / 2);
  min-width: 0;
}
body.page-template-page-index #archived-projects .project-thumbnail a,
body.home #archived-projects .project-thumbnail a {
  background-color: rgb(34, 34, 34);
}
body.page-template-page-index .footer,
body.home .footer {
  position: relative;
  z-index: 1000;
  color: white;
  background-color: black;
}

/**
 * About template
 */
body.page-template-page-about #contentWrapper {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
body.page-template-page-about #content {
  height: auto;
  padding: 0 15%;
  width: auto;
}
@media (max-width: 768px) {
  body.page-template-page-about #content {
    padding: 0 5%;
  }
}
body.page-template-page-about .infoWrapper {
  margin: 0 auto;
  padding-bottom: 150px;
  overflow: auto;
}
body.page-template-page-about .infoWrapper a {
  border-bottom: 1px solid black;
}
body.page-template-page-about .infoWrapper a:hover {
  border-bottom: none;
}
body.page-template-page-about .projectNav {
  background-color: black;
  transform: translate3d(0, 0, 0);
}
body.page-template-page-about .projectNav:hover {
  width: 23px;
}
body.page-template-page-about .contact {
  font-family: "Extended Bold";
  font-size: 15px;
  line-height: 20px;
  overflow: auto;
}
body.page-template-page-about .contact p {
  float: left;
  margin-right: 55px;
}
body.page-template-page-about .about,
body.page-template-page-about .feed,
body.page-template-page-about .secondaryInfo,
body.page-template-page-about .cn-social {
  clear: both;
  margin-bottom: 58px;
}
body.page-template-page-about .header,
body.page-template-page-about .feed .header {
  margin-left: 36px;
  margin-bottom: 30px;
}
body.page-template-page-about .widget_twitter {
  list-style: none;
}
body.page-template-page-about .widget_twitter .twitterwidget-title {
  display: none;
}
body.page-template-page-about .widget_twitter li {
  position: relative;
  margin-bottom: 10px;
}
body.page-template-page-about .widget_twitter .from-meta {
  display: none;
}
body.page-template-page-about .widget_twitter .time-meta {
  display: block;
  margin-bottom: 5px;
}
body.page-template-page-about .widget_twitter .time-meta a {
  font-family: "Extended Bold";
  margin-top: 58px;
  font-size: 15px;
  line-height: 20px;
  color: black;
  text-decoration: none;
}
body.page-template-page-about .bottomText {
  font-family: "Extended Bold";
  margin-top: 58px;
  font-size: 15px;
  line-height: 20px;
  color: black;
  text-decoration: none;
}
body.page-template-page-about .bottomText .header {
  margin-bottom: 10px;
}
body.page-template-page-about .selectedClients,
body.page-template-page-about .biographies {
  float: left;
  width: 47%;
  box-sizing: border-box;
}
@media (max-width: 768px) {
  body.page-template-page-about .selectedClients,
  body.page-template-page-about .biographies {
    float: none;
    width: 100%;
    margin-right: 0;
  }
}
body.page-template-page-about .selectedClients {
  margin-right: 6%;
}
@media (max-width: 768px) {
  body.page-template-page-about .selectedClients {
    margin-right: 0;
    margin-bottom: 30px;
  }
}
body.page-template-page-about .biographies div {
  margin-bottom: 15px;
}

@media (max-width: 768px) {
  body {
    font-size: 18px;
    line-height: 24px;
  }
  .sectionTitle {
    font-size: 16px;
    padding: 50px 0px 40px 0;
  }
  .footer {
    font-size: 13px;
    line-height: 18px;
  }
  .project .caption p,
  .index p {
    font-size: 18px;
    line-height: 24px;
  }
  .about .h1 {
    font-size: 28px;
    line-height: 34px;
  }
  .about .bottomText,
  .about .contact {
    font-size: 18px;
    line-height: 24px;
  }
}
.project p.client {
  position: relative;
  padding-bottom: 0px;
}
.project p.client .year {
  display: block;
  position: absolute;
  top: 0;
  left: 0px;
}
.project .title {
  text-transform: uppercase;
  margin-top: 10px;
}
.project.project-thumbnail img, .project.project-thumbnail a {
  display: block;
}
.project.project-thumbnail a {
  position: relative;
  background: rgb(245, 245, 245);
  overflow: hidden;
  height: 0;
  padding-top: 66.66%;
}
.project.project-thumbnail img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  transition: opacity 200ms;
}
.project.project-thumbnail img.is-loaded {
  opacity: 1;
}
.project.project-view[data-featured="0"] {
  background: black !important;
}
.project.project-view.loading {
  display: none;
}
.project.project-view.current {
  display: block;
}
.project.project-view .inner {
  width: 100%;
  padding: 0 12%;
  padding-top: 45px;
  padding-bottom: 150px;
  position: relative;
  transform: translate3d(0, 0, 0);
}
@media (max-width: 768px) {
  .project.project-view .inner {
    padding: 50px 5% 12%;
  }
}
.project.project-view .inner p.image {
  width: 100%;
}
.project.project-view .caption {
  padding: 10px 0px 0px 0px;
  margin-bottom: 50px;
}
.project.project-view .description a,
.project.project-view .caption a {
  border-bottom: 1px solid black;
}
.project.project-view .description a:hover,
.project.project-view .caption a:hover {
  border-bottom: none;
}
.project.project-view img:first-child {
  margin-top: 0px;
}
.project.project-view .caption p {
  font-family: "Extended Bold";
  font-size: 18px;
  line-height: 24px;
  margin-bottom: 25px;
}
.project.project-view p.image {
  margin-top: 45px;
  margin-bottom: 15px;
  margin-left: 0px;
  padding: 0px;
  padding-bottom: 25px;
}
.project.project-view .description {
  padding-top: 20px;
  padding-bottom: 50px;
}
.project.project-view .imgSet {
  cursor: pointer;
  cursor: s-resize;
}
.project.project-view .imgSet img {
  display: block;
  height: auto;
  width: 100%;
  transform: translate3d(0, 0, 0);
  transition: opacity 200ms;
}
.project.project-view .imgSet img.is-loaded {
  transition: opacity 500ms;
  opacity: 1;
}
.project.project-view .imgSet:last-child, .project.project-view .imgSet:last-of-type {
  cursor: pointer;
  cursor: n-resize;
}

/**
 * arrow prompts
 */
#arrow-prompts {
  position: fixed;
  display: block;
  top: 50vh;
  width: 100%;
  height: 40px;
  transform: translate(0, -50%);
  z-index: 1;
  pointer-events: none;
  opacity: 1;
  transition: opacity 1s ease;
}
#arrow-prompts.fade-out {
  opacity: 0;
}
#arrow-prompts .arrow {
  position: absolute;
  top: 0;
}
#arrow-prompts .arrow.left {
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-right: 20px solid black;
  left: 35px;
}
@media (max-width: 768px) {
  #arrow-prompts .arrow.left {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-right-width: 12px;
    left: 6px;
  }
}
#arrow-prompts .arrow.right {
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid black;
  right: 35px;
}
@media (max-width: 768px) {
  #arrow-prompts .arrow.right {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-left-width: 12px;
    right: 6px;
  }
}

body.archive #arrow-prompts .arrow.left {
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-right: 20px solid white;
  left: 35px;
}
@media (max-width: 768px) {
  body.archive #arrow-prompts .arrow.left {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-right-width: 12px;
    left: 10px;
  }
}
body.archive #arrow-prompts .arrow.right {
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid white;
  right: 35px;
}
@media (max-width: 768px) {
  body.archive #arrow-prompts .arrow.right {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-left-width: 12px;
    right: 10px;
  }
}

/**
 * cnsocial shortcode
 */
.cn-social {
  margin-top: 2.5em;
  display: flex;
  /* social links */
}
.cn-social .subscribeSignup {
  display: inline-block;
  flex-grow: 2;
}
@media (min-width: 961px) {
  .cn-social .subscribeSignup {
    padding-right: 5%;
  }
}
.cn-social .subscribeSignup form {
  height: 51px;
}
.cn-social .subscribeSignup .subscribed {
  background-color: white;
  border: 1px solid black;
  color: black;
  display: inline-block;
  text-decoration: none;
  padding: 11px 0px 10px 15px;
  position: relative;
  width: 390px;
  z-index: 1;
  box-sizing: border-box;
  vertical-align: text-top;
}
.cn-social .subscribeSignup #subForm {
  position: relative;
}
.cn-social .subscribeSignup .subscribeEmail {
  background-color: white;
  border: 1px solid black;
  color: black;
  outline: none;
  text-decoration: none;
  padding: 12px 0px 10px 15px;
  position: absolute;
  width: 100%;
  height: 51px;
  top: 0;
  z-index: 1;
  box-sizing: border-box;
  vertical-align: text-top;
}
.cn-social .subscribeSignup input:focus {
  outline: none;
}
.cn-social .subscribeSignup .subscribeEmail:focus {
  border: 1px dashed black;
}
.cn-social .subscribeSignup ::-webkit-input-placeholder {
  color: black;
}
.cn-social .subscribeSignup :-moz-placeholder { /* Firefox 18- */
  color: black;
}
.cn-social .subscribeSignup ::-moz-placeholder { /* Firefox 19+ */
  color: black;
}
.cn-social .subscribeSignup :-ms-input-placeholder {
  color: black;
}
.cn-social .subscribeSignup .subscribeSubmit {
  position: absolute;
  background: url("../images/arrow-right.png");
  background-color: white;
  background-repeat: no-repeat;
  background-position: center center;
  box-sizing: border-box;
  color: transparent;
  cursor: pointer;
  overflow: hidden;
  height: 51px;
  width: 51px;
  top: 0;
  right: 0;
  z-index: 20;
  border: 1px solid #000;
  transform: none;
}
.cn-social .subscribeSignup .subscribeSubmit:hover,
.cn-social .subscribeSignup .subscribeSubmit:active,
.cn-social .subscribeSignup .subscribeSubmit:focus {
  background: black url("../images/arrow-right-white.png");
  background-repeat: no-repeat;
  background-position: center center;
  border: solid 1px black;
  border-left: 0;
  outline: none;
}
.cn-social .socialLink {
  border: solid black 1px;
  height: 51px;
  line-height: 53px;
  margin-right: 1em;
  padding: 0 15px;
  text-align: center;
  vertical-align: text-top;
  box-sizing: border-box;
}
.cn-social .socialLink:hover {
  border: solid black 1px;
  border-bottom: solid black 1px;
  background-color: black;
  color: white;
}
.cn-social #subForm, .cn-social .socialLink {
  margin-bottom: 0.5em;
}
.cn-social .socialLink.noSignup {
  margin-left: 0;
  margin-right: 1em;
}
@media only screen and (max-width: 960px) {
  .cn-social {
    flex-wrap: wrap;
  }
  .cn-social .subscribeSignup {
    flex-grow: 1;
    width: 100%;
  }
  .cn-social .socialLink {
    width: 100%;
  }
  .cn-social .subscribeSignup, .cn-social .socialLink {
    flex-shrink: 0;
    flex-basis: 100%;
  }
}

/**
 * Image loader
 */
.imgLoader {
  transform: translate3d(0, 0, 0);
  background-color: rgb(245, 245, 245);
  transition: background-color 133.3333333333ms;
  width: 100%;
  position: relative;
  overflow: hidden;
}
.imgLoader img {
  display: block;
  width: 100%;
  height: auto;
}
.imgLoader.has-ratio {
  padding-bottom: var(--img-loader-padding, 0);
}
@supports (aspect-ratio: 1/1) {
  .imgLoader.has-ratio {
    padding-bottom: 0;
    aspect-ratio: var(--img-aspect-ratio, 1/1);
  }
}
.imgLoader.has-ratio img {
  position: absolute;
  inset: 0;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.imgLoader.image-loaded {
  background-color: transparent;
}

.cn-lazy-img {
  opacity: 0;
  transition: opacity 133.3333333333ms;
}
.cn-lazy-img.is-loaded {
  opacity: 1;
}

body.archive .imgLoader {
  background: rgb(34, 34, 34);
}

/**
 * Project Swiper
 */
.project-swiper {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.project-swiper .swiper-wrapper {
  display: flex;
  width: 100%;
  height: 100%;
}
.project-swiper .swiper-slide {
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  position: relative;
}
.project-swiper .swiper-slide.is-unloaded {
  pointer-events: none;
}
.project-swiper .swiper-slide .slide-placeholder {
  width: 100%;
  height: 100%;
  background: transparent;
}

#clock-container, #clock-container * {
  box-sizing: border-box;
}

#clock-container {
  position: fixed;
  z-index: 999;
  border-radius: 50%;
  width: 200px;
  height: 200px;
  padding: 10px;
  top: 25px;
  left: 65px;
  margin: 0 auto;
}
@media (max-width: 960px) {
  #clock-container {
    display: none;
  }
}

#clock-container.inverted .tic-container .tic, #clock-container.inverted .hand-container .hand, #clock-container.inverted .hub-container .hub, body.archive #clock-container .tic-container .tic, body.archive #clock-container .hand-container .hand, body.archive #clock-container .hub-container .hub {
  background-color: white;
}
#clock-container.inverted .hub-container .hub, body.archive #clock-container .hub-container .hub {
  box-shadow: 0px 0px 1px 0px rgb(255, 255, 255);
}
#clock-container.inverted .tic-container.double .tic, body.archive #clock-container .tic-container.double .tic {
  border-color: white !important;
}

#clock {
  border-radius: 50%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: calc(100% - 20px);
  height: calc(100% - 20px);
}

#clock .tic-container, #clock .hand-container {
  /*background-color: rgba(0,255,0,0.25);*/
  height: 100%;
  width: 3px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

#clock #tic-1 {
  transform: rotate(30deg);
  transition-delay: 30ms;
}

#clock #tic-2 {
  transform: rotate(60deg);
  transition-delay: 60ms;
}

#clock #tic-3 {
  transform: rotate(90deg);
  transition-delay: 90ms;
}

#clock #tic-4 {
  transform: rotate(120deg);
  transition-delay: 120ms;
}

#clock #tic-5 {
  transform: rotate(150deg);
  transition-delay: 150ms;
}

#clock #tic-6 {
  transform: rotate(180deg);
  transition-delay: 180ms;
}

#clock #tic-7 {
  transform: rotate(210deg);
  transition-delay: 210ms;
}

#clock #tic-8 {
  transform: rotate(240deg);
  transition-delay: 240ms;
}

#clock #tic-9 {
  transform: rotate(270deg);
  transition-delay: 270ms;
}

#clock #tic-10 {
  transform: rotate(300deg);
  transition-delay: 300ms;
}

#clock #tic-11 {
  transform: rotate(330deg);
  transition-delay: 330ms;
}

#clock .tic-container.double {
  width: 9px;
}

#clock .tic-container .tic, #clock .hand-container .hand {
  width: 100%;
  height: 8%;
  background-color: black;
  position: absolute;
}

#clock .tic-container.double .tic:first-child {
  border-left: 3px solid black;
  border-right: 3px solid black;
  background-color: transparent;
}

#clock .tic-container.double .tic:last-child {
  display: none;
}

#clock .hub-container {
  width: 8%;
  height: 8%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

#clock .hub {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: black;
  transform: rotate(0) translate(0, 0);
  /* to ease the appearance of straight edges */
  box-shadow: 0px 0px 1px 0px rgb(0, 0, 0);
}

/*#clock .hand-container { background-color: rgba(255,0,255,0.25); }*/
#clock .hand-container .hand {
  bottom: 50%;
}

#clock #hour {
  width: 4px;
}

#clock #hour .hand {
  height: 30%;
  width: 4px;
  transform: rotate(0) translate(0, 0);
}

#clock #minute {
  width: 3px;
}

#clock #minute .hand {
  height: 38%;
  width: 3px;
  transform: rotate(0) translate(0, 0);
}

#clock #second {
  width: 1px;
}

#clock #second .hand {
  height: 40%;
  width: 1px;
  transform: rotate(0) translate(0, 0);
}

#clock.facetime #hub-01 .hub {
  /*left: 22%;
  top: 35%;*/
  transform: translate(-40px, -22px);
}

#clock.facetime #hub-02 .hub {
  /*top: 28%;
  left: 55%;*/
  transform: translate(16px, -30px);
}

#clock.facetime #hour .hand {
  /*top: 34%;
  left: 44px;
  transform: rotate(20deg);*/
  transform: rotate(20deg) translate(52px, 10px);
}

#clock.facetime #minute .hand {
  /*top: 27%;
  left: -12px;
  transform: rotate(5deg);*/
  transform: rotate(5deg) translate(-10px, 25px);
}

#clock.facetime #second .hand {
  /*top: 55%;
  left: -5px;
  transform: rotate(85deg);*/
  transform: rotate(87deg) translate(79px, 10px);
}

#clock.facetime .hand, #clock.facetime .hub {
  /*background-color: blue; */
  margin: 0;
}

#clock:hover {
  cursor: pointer;
}

#clock #second {
  transition: transform 0.6 ease;
}

#clock:hover .hand-container, #clock.facetime .hand-container, body.inverted #clock .hand-container {
  transform: rotate(360deg) !important;
}

#clock .tic-container {
  opacity: 0;
  transition: opacity 30ms;
}

#clock-container.initialized .tic-container {
  opacity: 1;
}

#clock-container #clock-parts {
  opacity: 0;
}

#clock-container.initialized #clock-parts {
  opacity: 1;
  transition: opacity 30ms 360ms;
}

#clock-container:hover {
  /*box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.3);*/
}

/*#clock.facetime .hand, #clock.facetime .hand-container, #clock.facetime .hub {
  transition: transform 5s ease;
}*/
#clock .hand, #clock .hub {
  transition: transform 5s ease;
}
