/*
Theme Name: Pivot (v4)
Theme URI:
Description: Custom theme for Pivot
Author: Joe Blackburn
Version: 1.0
Tags: custom
*/
/* =============================================================================
   Adapted from HTML5 Boilerplate CSS: h5bp.com/css
   ========================================================================== *

/* !Local Fonts - - - - - */
@font-face {
  font-family: 'Roxborough';
  src: url("fonts/RoxboroughCF-Light.woff2") format("woff2"), url("fonts/RoxboroughCF-Light.woff") format("woff");
  font-style: normal;
  font-weight: 200; }

@font-face {
  font-family: 'Roxborough';
  src: url("fonts/RoxboroughCF-LightItalic.woff2") format("woff2"), url("fonts/RoxboroughCF-Lightitalic.woff") format("woff");
  font-style: italic;
  font-weight: 200; }

@font-face {
  font-family: 'Roxborough';
  src: url("fonts/RoxboroughCF-Regular.woff2") format("woff2"), url("fonts/RoxboroughCF-Regulart.woff") format("woff");
  font-style: normal;
  font-weight: normal; }

@font-face {
  font-family: 'Roxborough';
  src: url("fonts/RoxboroughCF-RegulatItalic.woff2") format("woff2"), url("fonts/RoxboroughCF-RegularItalic.woff") format("woff");
  font-style: italic;
  font-weight: normal; }

/* !Global Styles - - - - - */
* {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale; }

.sans {
  font-family: "adrianna", Arial, Verdana, sans-serif; }

.serif {
  font-family: "Roxborough", Georgia, Times, serif; }

.grey {
  color: #C7C7C7; }

.lt-grey {
  color: #F5F3F1; }

.dk-grey {
  color: #3A3E3D; }

.vdk-grey {
  color: #231F20; }

.border {
  color: #AEAEAE; }

.red {
  color: #b50000; }

.white {
  color: #fff; }

.grey-bg {
  background: #C7C7C7; }

.lt-grey-bg {
  background: #F5F3F1; }

.dk-grey-bg {
  background: #3A3E3D; }

.vdk-grey-bg {
  background: #231F20; }

.border-bg {
  background: #AEAEAE; }

.red-bg {
  background: #b50000; }

.white-bg {
  background: #fff; }

.italic {
  font-style: italic; }

.normal {
  font-weight: normal; }

.bold {
  font-weight: bold; }

.light {
  font-weight: 300; }

.center {
  text-align: center; }

.upper {
  text-transform: uppercase; }

.lower {
  text-transform: lowercase; }

.space {
  letter-spacing: .05em; }

.xspace {
  letter-spacing: .1em; }

.fleft {
  float: left; }

.fright {
  float: right; }

.plain a, a.plain {
  text-decoration: none; }

a {
  color: #C7C7C7;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a:hover {
  color: #3A3E3D; }

.rel {
  position: relative; }

ul.clean {
  list-style: none;
  margin: 0;
  padding: 0; }

ul.inline {
  display: inline-block; }

ul.inline > li {
  display: inline;
  float: left; }

ul.ilb > li,
.ilb {
  display: inline-block;
  vertical-align: top; }

ul.ilb {
  display: block; }

li.vmiddle,
.vmiddle {
  vertical-align: middle; }

.vbottom,
li.vbottom {
  vertical-align: bottom; }

.reverse {
  direction: rtl; }

.dfix {
  direction: ltr; }

img.full {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto; }

.screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 11; }

.flex-wrap {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center; }

.flex-wrap .flex-item:nth-child(1) {
  -webkit-order: 0;
  -ms-flex-order: 0;
  order: 0;
  -webkit-flex: 0 1 auto;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  -webkit-align-self: auto;
  -ms-flex-item-align: auto;
  align-self: auto;
  width: 100% !important; }

.cover {
  background: url(images/trans.png) no-repeat center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover; }

.flex-bottom {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end; }

.flex-bottom .flex-item:nth-child(1) {
  -webkit-order: 0;
  -ms-flex-order: 0;
  order: 0;
  -webkit-flex: 0 1 auto;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  -webkit-align-self: auto;
  -ms-flex-item-align: auto;
  align-self: auto;
  width: 100% !important; }

.teeth-top,
.teeth-bottom {
  position: relative; }

.teeth-top:before,
.teeth-top:after {
  content: "";
  width: 100%;
  height: 10px;
  position: absolute;
  top: -10px;
  left: 0;
  background: url(images/tooth-top.svg) repeat-x center bottom;
  z-index: 5; }

.teeth-top:after {
  top: auto;
  bottom: -10px;
  background-image: url(images/tooth-bottom.svg); }

.hang {
  position: relative; }

/*
.hang:before {
content: open-quote;
position: absolute;
top: 0;
left: -60px;
color: $dk-grey;
font-size: inherit;
z-index: 1;
font-family: $serif;
}

.hang.small-callout-text:before { left: -35px;}

.hang:after {
content: close-quote;
color: $dk-grey;
font-size: inherit;
position: relative;
z-index: 1;
font-family: $serif;
}
*/
/* !Font Size Functions - - - - - */
/* !Page Defaults - - - - - */
.text {
  line-height: 1.7em;
  font-size: 1.4285714286em; }

.text.small-text {
  font-size: 1em; }

.text.large-text {
  font-size: 1.5714285714em; }

.text.vlarge-text {
  font-size: 2.1428571429em;
  font-weight: 200;
  font-family: "Roxborough", Georgia, Times, serif; }

.text a {
  text-decoration: underline; }

.text p {
  margin: 15px 0; }

.header-text p:first-child,
.text p:first-child {
  margin-top: 0; }

.header-text p:last-child,
.text p:last-child {
  margin-bottom: 0; }

h1,
h2,
h3,
h4 {
  margin: 0;
  font-weight: normal; }

.text img {
  display: block;
  margin: 10px auto;
  width: auto;
  height: auto;
  max-width: 100%; }

.text img.alignleft {
  float: left;
  margin: 0 30px 30px 0;
  display: inline-block; }

.text img.alignright {
  float: right;
  margin: 0 0 30px 30px;
  display: inline-block; }

.text ul {
  list-style: none;
  margin: 30px 0;
  padding: 0; }

.text ul li {
  padding-left: 15px;
  position: relative;
  margin-top: 8px;
  display: block; }

.text ul li:before {
  content: "";
  width: 5px;
  height: 5px;
  position: absolute;
  top: 12px;
  left: 0;
  z-index: 1;
  border-radius: 120%;
  overflow: hidden;
  background: #3A3E3D; }

.text.white ul li:before {
  background: #fff; }

.text h1,
.text h2,
.text h3,
.text h4 {
  margin: 30px 0 10px 0;
  font-weight: normal;
  color: #3A3E3D;
  font-family: "Roxborough", Georgia, Times, serif;
  line-height: 1.4em; }

.text h3 {
  font-weight: 200; }

.text h4 {
  font-weight: bold;
  font-family: "adrianna", Arial, Verdana, sans-serif; }

.text h1:first-child,
.text h2:first-child,
.text h3:first-child,
.text h4:first-child,
.text ul:first-child {
  margin-top: 0; }

.text h1:last-child,
.text h2:last-child,
.text h3:last-child,
.text h4:last-child,
.text ul:last-child {
  margin-bottom: 0; }

.text blockquote {
  margin: 50px 0;
  padding: 10px 0 10px 30px;
  border-left: 2px solid #C7C7C7;
  color: #3A3E3D;
  font-size: 1.4285714286em;
  line-height: 1.5em;
  text-align: left;
  font-family: "Roxborough", Georgia, Times, serif; }

/* !Body - - - - - */
body {
  min-width: 320px;
  font-size: 14px;
  font-family: "adrianna", Arial, Verdana, sans-serif;
  color: #3A3E3D;
  line-height: 1.6em;
  background: #fff;
  overflow-x: hidden; }

#container {
  background: #fff;
  padding-top: 80px; }

#container.no-top-pad {
  padding-top: 0; }

/* !Page Blocks - - - - - */
.inner {
  padding: 0 130px;
  max-width: 1320px;
  display: block;
  margin: 0 auto; }

.inner.mid {
  max-width: 1590px; }

.inner.wide {
  max-width: 1860px; }

.inner.skinny {
  max-width: 1200px; }

.max {
  max-width: 1600px;
  margin: 0 auto; }

.wide-max {
  max-width: 1920px;
  margin: 0 auto; }

.small-section-pad {
  padding: 45px 0; }

.section-pad {
  padding: 90px 0; }

.mid-section-pad {
  padding: 130px 0; }

.pad-bottom {
  padding-bottom: 130px; }

.pad-top {
  padding-top: 130px; }

.big-section-pad {
  padding: 180px 0; }

.vbig-section-pad {
  padding: 240px 0; }

.spacer-small {
  height: 20px; }

.spacer-medium {
  height: 90px; }

.spacer-large {
  height: 180px; }

.spacer-xlarge {
  height: 240px; }

.offset-right {
  max-width: 1060px;
  margin: 0 0 0 auto; }

.offset-left {
  max-width: 1060px;
  margin: 0 auto 0 0; }

.page-block {
  position: relative;
  z-index: 10; }

.page-block.block-margin + .page-block.block-margin {
  margin-top: 20px; }

/* !Headlines - - - - - */
.small-label,
.small-sans-headline,
.vsmall-label {
  font-size: 1.1428571429em;
  line-height: 1.4em;
  font-family: "adrianna", Arial, Verdana, sans-serif;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: .05em; }

.small-sans-headline {
  font-size: 2.8571428571em; }

.small-label.lined {
  border-bottom: 1px solid #C7C7C7;
  padding-bottom: 5px;
  margin-bottom: 55px; }

.vsmall-label {
  font-size: 1em; }

.small-serif-headline,
.grid-serif-headline,
.big-serif-headline,
.vbig-serif-headline,
.vvbig-serif-headline,
.mid-serif-headline,
.serif-headline,
.callout-text,
.small-callout-text,
.vert-title,
.serif-subhead,
.person-name,
.vert-title,
.mobile-studio-headline,
.studio-headline {
  font-family: "Roxborough", Georgia, Times, serif;
  font-weight: 200;
  font-size: 1.4285714286em;
  line-height: 1.4em; }

.grid-serif-headline {
  font-size: 2.5714285714em; }

.mid-serif-headline {
  font-size: 2.8571428571em;
  line-height: 1.3em; }

.serif-subhead {
  font-size: 3.8571428571em;
  line-height: 1.3em; }

.big-serif-headline,
.small-callout-text {
  font-size: 4.8571428571em;
  line-height: 1.2em; }

.person-name {
  font-size: 6.7857142857em;
  line-height: 1em; }

.vbig-serif-headline {
  font-size: 9.2857142857em;
  line-height: 1em; }

.studio-headline {
  font-size: 7.8571428571em;
  line-height: 1em; }

.vvbig-serif-headline,
.vert-title {
  font-size: 11.4285714286em;
  line-height: 1em;
  font-weight: normal; }

.callout-text {
  font-size: 10em;
  line-height: 1em;
  font-weight: normal; }

.serif-headline {
  font-size: 4.5714285714em;
  line-height: 1.2em; }

.mobile-studio-headline {
  font-size: 2.5714285714em;
  margin-bottom: 30px;
  display: none; }

.small-sans-headline.margin-bottom,
.vbig-serif-headline.margin-bottom,
.small-label.margin-bottom,
.small-sans-headline.margin-bottom,
.vvbig-serif-headline {
  margin-bottom: 30px; }

.big-serif-headline.big-margin-bottom,
.small-label.big-margin-bottom,
.serif-headline.margin-bottom {
  margin-bottom: 50px; }

/* !Buttons + Links - - - - - */
a.button,
input.gform_button {
  -moz-appearance: none;
  -webkit-appearance: none;
  border-radius: 0;
  border: 1px solid #3A3E3D;
  color: #3A3E3D;
  font-family: "adrianna", Arial, Verdana, sans-serif;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: bold;
  font-size: 1.4285714286em;
  line-height: 1.3em;
  padding: 15px 30px;
  display: inline-block;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a.button:hover {
  background: #F5F3F1;
  border-color: #F5F3F1;
  color: #3A3E3D; }

a.text-link {
  font-size: 1.1428571429em;
  line-height: 1.4em;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #3A3E3D;
  display: inline-block;
  position: relative;
  background-image: linear-gradient(#C7C7C7, #C7C7C7);
  background-position: 0% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a.text-link:hover,
a.text-link:focus {
  color: #C7C7C7;
  background-size: 100% 1px; }

a.button.margin-top,
a.text-link.margin-top {
  margin-top: 35px; }

/* !Header - - - - - */
header {
  height: 80px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 110000;
  padding-top: 30px;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

a.logo {
  width: 78px;
  height: 21px;
  display: block;
  margin: 0 auto;
  position: relative;
  z-index: 101;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

a.logo path,
a.logo rect,
a.logo polygon {
  fill: #3A3E3D;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.swap-header a.logo path,
.swap-header a.logo rect,
.swap-header a.logo polygon,
.nav-active a.logo path,
.nav-active a.logo rect,
.nav-active a.logo polygon {
  fill: #fff; }

.search-active .swap-header a.logo path,
.search-active .swap-header a.logo rect,
.search-active .swap-header a.logo polygon,
.search-active a.logo path,
.search-active a.logo rect,
.search-active a.logo polygon {
  fill: #3A3E3D; }

a.search-toggle {
  width: 22px;
  height: 80px;
  position: fixed;
  top: 0;
  right: 110px;
  z-index: 101;
  padding-top: 29px; }

a.search-toggle path {
  fill: #3A3E3D;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.nav-active a.search-toggle path,
.swap-header a.search-toggle path {
  fill: #fff; }

.search-active a.search-toggle path,
.search-active .swap-header a.search-toggle path {
  fill: #3A3E3D; }

a.nav-toggle {
  width: 80px;
  height: 80px;
  position: fixed;
  top: 0;
  right: 30px;
  cursor: pointer;
  z-index: 100500;
  display: block;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

a.nav-toggle div {
  width: 28px;
  height: 3px;
  background: #3A3E3D;
  position: absolute;
  right: 26px;
  text-indent: -9999px;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

a.nav-toggle.active div,
.swap-header a.nav-toggle div {
  background: #fff; }

.search-active a.nav-toggle div,
.search-active a.nav-toggle.active div,
.search-active .swap-header a.nav-toggle div {
  background: #3A3E3D; }

a.nav-toggle div:nth-child(1) {
  top: 33px; }

a.nav-toggle div:nth-child(2) {
  bottom: 33px; }

a.nav-toggle.active div:nth-child(1) {
  top: 38px;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg); }

a.nav-toggle.active div:nth-child(2) {
  bottom: 39px;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg); }

.nav-wrap,
.search-wrap {
  display: block;
  width: 100vw;
  position: fixed;
  top: 0;
  left: 101%;
  bottom: 0;
  background: #231F20;
  z-index: 10100;
  padding: 80px 60px 130px 120px;
  overflow-y: scroll;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.search-wrap {
  padding-left: 60px; }

.nav-active .nav-wrap,
.search-active .search-wrap {
  left: 0; }

.nav-wrap .flex-wrap,
.search-wrap .flex-wrap {
  min-height: calc(100vh - 160px);
  position: relative;
  opacity: 0;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -webkit-transition-delay: .25s;
  /* Safari */
  transition-delay: .25s; }

.search-wrap {
  background: #F5F3F1; }

.nav-active .nav-wrap .flex-wrap,
.search-active .search-wrap .flex-wrap {
  opacity: 1; }

ul.nav a {
  display: block;
  font-size: 9.2857142857em;
  line-height: 1em;
  color: #fff; }

ul.nav li + li {
  margin-top: 30px; }

ul.nav a:hover,
ul.nav li#current a {
  color: #C7C7C7; }

.nav-bottom {
  margin-top: 90px; }

.nav-left {
  width: calc(100% - 350px); }

.nav-right {
  width: 350px; }

.info-block + .info-block {
  margin-top: 30px; }

.info-block {
  font-size: 1.4285714286em;
  line-height: 1.4em;
  font-weight: bold; }

.info-block a {
  color: #3A3E3D; }

.info-block a:hover {
  color: #C7C7C7; }

.info-block.white a {
  color: #fff; }

.info-block.white a:hover {
  color: #C7C7C7; }

/* !Vertical Text - - - - - */
.vert-text-wrap {
  position: absolute;
  top: 40px;
  left: 30px;
  height: calc(100% - 40px);
  z-index: 1;
  width: 60px;
  padding-bottom: 30px; }

.vert-text {
  font-style: italic;
  font-size: 0.9285714286em;
  line-height: 1.3em;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: .05em;
  writing-mode: vertical-lr;
  position: sticky;
  position: -webkit-sticky;
  top: 30vh;
  right: 0; }

.vert-text span {
  transform-origin: center;
  transform: rotate(180deg);
  display: inline-block;
  padding: 5px 0; }

.nav-wrap .vert-text {
  position: static; }

.nav-wrap .vert-text-wrap,
.nav-wrap .vert-tex {
  display: flex;
  text-align: center; }

/* !Work Landing - - - - - */
ul.work-list {
  max-width: 1600px;
  margin: 0 auto; }

ul.work-list li {
  width: 50%; }

ul.work-list li + li {
  padding-top: 20px; }

ul.work-list li:nth-child(7n + 1) {
  width: 100%; }

ul.work-list li:nth-child(7n + 2),
ul.work-list li:nth-child(7n + 4),
ul.work-list li:nth-child(7n + 6) {
  padding-right: 10px; }

ul.work-list li:nth-child(7n + 3),
ul.work-list li:nth-child(7n + 5),
ul.work-list li:nth-child(7n + 7) {
  padding-left: 10px; }

.image-hover:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background: #3A3E3D;
  mix-blend-mode: multiply;
  opacity: 0;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.grid-screen {
  padding: 40px;
  opacity: 0; }

a:hover .grid-screen,
a:hover .image-hover:after {
  opacity: 1; }

.grid-screen .small-label {
  margin-bottom: 20px; }

ul.work-list li:nth-child(7n + 1) .grid-screen .small-label {
  margin-bottom: 30px; }

.grid-screen .flex-item {
  position: relative;
  z-index: 10; }

ul.work-list a {
  display: block;
  color: #fff; }

.grid-screen-title {
  font-size: 2em;
  line-height: 1.3em;
  font-family: "Roxborough", Georgia, Times, serif;
  font-weight: 200; }

ul.work-list li:nth-child(7n + 1) .grid-screen-title {
  font-size: 4.8571428571em;
  line-height: 1.1em; }

.screen-max {
  max-width: 550px;
  margin: 0 auto; }

ul.work-list li:nth-child(7n + 1) .screen-max {
  max-width: 900px; }

.grid-screen-title:after,
.home-insights a .text:after {
  content: "";
  width: 0;
  height: 48px;
  background: url(images/small-white-arrow.svg) no-repeat right 1px center;
  position: absolute;
  bottom: -70px;
  left: 50%;
  transform: translate(-50%, 0);
  z-index: 1;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a:hover .grid-screen-title:after,
.home-insights a:hover .text:after {
  width: 50px; }

ul.work-list li:nth-child(7n + 1) .grid-screen-title:after {
  display: none; }

/* !Form Fields - - - - - */
input.small-search-box {
  font-family: "Roxborough", Georgia, Times, serif;
  color: #C7C7C7;
  border: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: none;
  height: 60px;
  font-size: 2.7142857143em;
  line-height: 1.3em;
  padding: 0;
  width: 100%; }

input.small-search-box::-webkit-input-placeholder {
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.small-search-box:-moz-placeholder {
  /* Firefox 18- */
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.small-search-box::-moz-placeholder {
  /* Firefox 19+ */
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.small-search-box:-ms-input-placeholder {
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.small-search-box:focus::-webkit-input-placeholder {
  color: transparent; }

input.small-search-box:focus:-moz-placeholder {
  /* Firefox 18- */
  color: transparent; }

input.small-search-box:focus::-moz-placeholder {
  /* Firefox 19+ */
  color: transparent; }

input.small-search-box:focus:-ms-input-placeholder {
  color: transparent; }

input.search-box {
  font-family: "Roxborough", Georgia, Times, serif;
  color: #C7C7C7;
  border: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: none;
  height: 225px;
  font-size: 10em;
  line-height: 1.3em;
  padding: 0;
  width: 100%;
  text-align: center; }

input.search-box::-webkit-input-placeholder {
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.search-box:-moz-placeholder {
  /* Firefox 18- */
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.search-box::-moz-placeholder {
  /* Firefox 19+ */
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.search-box:-ms-input-placeholder {
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

input.search-box:focus::-webkit-input-placeholder {
  color: transparent; }

input.search-box:focus:-moz-placeholder {
  /* Firefox 18- */
  color: transparent; }

input.search-box:focus::-moz-placeholder {
  /* Firefox 19+ */
  color: transparent; }

input.search-box:focus:-ms-input-placeholder {
  color: transparent; }

#bigsearch {
  padding: 30px 0 130px 0; }

input.search-button {
  width: 34px;
  height: 34px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0);
  background: url(images/search-icon.svg) no-repeat center bottom;
  background-size: 100% auto;
  border: none;
  text-indent: -9999px; }

/* !Social - - - - - */
a.social {
  display: inline-block;
  vertical-align: middle; }

a.social + a.social {
  margin-left: 20px; }

a.social path {
  fill: #3A3E3D;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.nav-wrap a.social path,
.post-share.white a.social path {
  fill: #fff; }

a.social:hover path,
.nav-wrap a.social:hover path {
  fill: #C7C7C7; }

.post-share.white a.social:hover path {
  fill: #3A3E3D; }

.nav-social {
  margin-top: 40px; }

/* !Scroll Bottom - - - - - */
a.scroll-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 40px;
  height: 40px;
  z-index: 10001;
  display: none; }

a.scroll-top path,
a.scroll-top polygon {
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a.scroll-top:hover path,
a.scroll-top:hover polygon {
  fill: #C7C7C7; }

/* !Footer - - - - - */
.over {
  position: relative;
  z-index: 10; }

.footer-bg:before {
  content: "";
  width: 100%;
  height: 80px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background: #fff; }

.footer-bg {
  padding-bottom: 60px; }

.footer-newsletter {
  margin-top: 50px; }

.footer-left {
  width: 50%;
  padding-right: 60px; }

.footer-right {
  width: 50%; }

.footer-bottom {
  margin-top: 40px; }

.footer-bottom .footer-right {
  text-align: right; }

.footer-social {
  display: inline-block;
  margin: 0 0 0 auto; }

.signup-form input[type=email] {
  font-family: "adrianna", Arial, Verdana, sans-serif;
  color: #3A3E3D;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 1.4285714286em;
  border: none;
  border-bottom: 2px solid #3A3E3D;
  padding: 5px 35px 5px 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  border-radius: 0;
  background: url(images/email-icon.svg) no-repeat right 5px center;
  width: 100%; }

.footer-sign-form {
  max-width: 500px; }

.signup-form input[type=submit] {
  position: absolute;
  top: 0;
  left: -9999px; }

.signup-form ::-webkit-input-placeholder {
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.signup-form :-moz-placeholder {
  /* Firefox 18- */
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.signup-form ::-moz-placeholder {
  /* Firefox 19+ */
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.signup-form :-ms-input-placeholder {
  opacity: 1;
  color: #C7C7C7;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.signup-form :focus::-webkit-input-placeholder {
  color: transparent; }

.signup-form :focus:-moz-placeholder {
  /* Firefox 18- */
  color: transparent; }

.signup-form :focus::-moz-placeholder {
  /* Firefox 19+ */
  color: transparent; }

.signup-form :focus:-ms-input-placeholder {
  color: transparent; }

.gform_footer {
  text-align: center;
  padding-top: 25px; }

.gform_footer img {
  width: 24px;
  height: 24px;
  margin: 0 auto; }

.gfield_label {
  display: none; }

.gform_ajax_spinner {
  margin: 20px auto 0 auto;
  border: 4px solid rgba(58, 62, 61, 0.2);
  border-left: 4px solid #3A3E3D;
  animation: spinner 1.1s infinite linear;
  border-radius: 50%;
  width: 30px;
  height: 30px; }

@keyframes spinner {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }

.gform_submission_error {
  color: #b50000;
  font-weight: bold;
  line-height: 1.4em;
  padding-bottom: 25px; }

.validation_message {
  color: #b50000;
  font-style: italic;
  padding-top: 5px; }

.mobile-footer-text {
  display: none; }

/* !Contact - - - - - */
ul.contact-links {
  margin-top: 60px; }

ul.contact-links li {
  padding: 30px; }

/* !Blog Landing - - - - - */
ul.post-grid li {
  width: 33.33%;
  padding: 30px 30px 120px 30px; }

ul.post-grid {
  max-width: 1660px;
  margin: 0 auto; }

.grid-post-info {
  margin-top: 50px; }

.small-label.post-category {
  margin-bottom: 15px; }

.grid-post-info .grid-serif-headline,
.featured-post-left .mid-serif-headline {
  margin-bottom: 10px; }

.grid-serif-headline a,
.big-serif-headline a {
  color: #3A3E3D; }

.grid-serif-headline a:hover,
.big-serif-headline a:hover {
  color: #C7C7C7; }

.featured-post-right {
  width: calc(100% - 400px); }

.featured-post-left {
  width: 400px;
  padding-right: 50px; }

li.grid-post a.small-arrow-link,
.featured-post a.small-arrow-link {
  display: none; }

.cat-title {
  margin-bottom: 50px; }

.cat-title .small-label.post-category {
  margin-bottom: 5px; }

/* !Single Work - - - - - */
.work-header {
  padding-top: 240px; }

.work-intro {
  padding-bottom: 130px;
  background: url(images/small-arrow-down.svg) no-repeat center bottom; }

.work-intro.white {
  background-image: url(images/small-white-arrow-down.svg); }

.block-margin + .block-margin {
  margin-top: 20px; }

video {
  width: 100%;
  height: auto;
  display: block; }

.client-intro-right {
  width: calc(100% - 380px);
  padding-left: 10px; }

.client-intro-left {
  width: 380px;
  padding-right: 10px; }

.work-social {
  margin-top: 30px; }

.service-text {
  font-size: 1.1428571429em;
  line-height: 1.5em;
  padding-top: 5px; }

/* !Callout - - - - - */
.callout-names {
  margin-top: 50px; }

/* !Gallery - - - - - */
a.slick-prev,
a.slick-next {
  position: absolute;
  top: 50%;
  width: 60px;
  height: 60px;
  padding: 12px 20px;
  transform: translate(0, -50%);
  z-index: 101; }

a.slick-prev {
  left: 0; }

a.slick-next {
  right: 0; }

a.slick-prev polygon,
a.slick-next polygon {
  fill: #fff;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a.slick-prev:hover polygon,
a.slick-next:hover polygon {
  fill: rgba(255, 255, 255, 0.5); }

/* !Half Block - - - - - */
.half-block {
  width: 50%; }

.half-block:nth-child(odd) {
  padding-right: 10px; }

.half-block:nth-child(even) {
  padding-left: 10px; }

/* !Website - - - - - */
ul.web-list li {
  width: 33.33%;
  padding: 0 30px; }

ul.web-list {
  max-width: 1050px;
  margin: 0 auto;
  text-align: center; }

.web-wrap {
  border: 4px solid #3A3E3D;
  overflow: scroll;
  background: #3A3E3D;
  height: 640px;
  border-radius: 20px;
  width: calc(100% + 8px);
  margin-left: -8px; }

/* !CTA - - - - - */
.cta-wrap {
  padding-right: 250px;
  position: relative; }

a.arrow-link {
  width: 102px;
  height: 102px;
  position: relative;
  display: block; }

a.arrow-link polygon,
a.small-arrow-link polygon {
  fill: #3A3E3D;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a.arrow-link:hover polygon,
a.small-arrow-link:hover polygon {
  fill: #C7C7C7; }

.cta-wrap .arrow-link {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(0, -50%); }

.arrow-vert {
  font-size: 1em;
  line-height: 1.4em;
  position: absolute;
  top: 50%;
  left: -10px;
  z-index: 1;
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #3A3E3D;
  transform-origin: center bottom;
  transform: translate(-50%, -100%) rotate(-90deg);
  text-align: center;
  font-weight: bold;
  width: 102px; }

a.small-arrow-link {
  font-size: 1em;
  line-height: 1.4em;
  font-style: italic;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #3A3E3D;
  display: block; }

a.small-arrow-link.margin-top {
  margin-top: 35px; }

a.small-arrow-link:hover {
  color: #C7C7C7; }

a.small-arrow-link svg {
  display: inline-block;
  vertical-align: middle;
  margin-left: 15px; }

/* !Side Block - - - - - */
.side-wrap {
  width: 82.5%; }

.side-block a.arrow-link {
  position: absolute;
  bottom: 0;
  left: calc(82.5% + 90px); }

/* !Single Post - - - - - */
.post-header {
  padding: 290px 0 0 0; }

.post-header-top {
  position: sticky;
  position: -webkit-sticky;
  top: 290px;
  left: 0;
  z-index: 100; }

.post-header-max {
  max-width: 700px;
  padding-bottom: 80px; }

.post-header-max .small-label {
  margin-top: 30px; }

.post-share.small-label {
  margin-bottom: 40px;
  margin-top: 0; }

.post-header-image {
  width: 92.2%;
  display: block;
  margin: 0 0 0 auto; }

.post-header-cover:before {
  content: "";
  width: 100%;
  height: 10px;
  position: absolute;
  bottom: 200px;
  left: 0;
  z-index: 1;
  background: url(images/tooth-top-white.svg) repeat-x center; }

.post-header-cover:after {
  content: "";
  width: 100%;
  height: 200px;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #fff;
  z-index: 1; }

/* !Homepage - - - - - */
a.home-arrow-link {
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translate(0, -50%);
  z-index: 10; }

.home-work-pad {
  padding-bottom: 120px;
  margin-top: -95px; }

.home-work-pad .vvbig-serif-headline {
  max-width: 900px; }

.home-work-pad .text {
  max-width: 750px; }

.vert-title-wrap {
  position: absolute;
  top: 130px;
  right: 0;
  z-index: 1;
  height: calc(100% - 190px); }

.vert-title {
  position: sticky;
  position: -webkit-sticky;
  top: 30px;
  right: 0; }

.home-studio-top-image {
  width: 59.4%; }

.home-studio-top-text {
  width: 40.6%;
  padding-left: 90px; }

.home-studio-top-text a.arrow-link {
  margin: 45px 0 0 auto; }

.home-studio-bottom-image {
  width: 81.5%;
  display: block;
  margin: 0 0 0 auto; }

.home-studio-bottom {
  text-align: right;
  margin-top: 20px; }

.home-insights-top-image {
  width: 69.2%; }

.home-insights-top-text {
  width: 30.8%;
  padding-left: 60px; }

.insight-screen {
  padding: 40px;
  text-align: center; }

a.block {
  display: block; }

.small-screen-max {
  max-width: 350px;
  margin: 0 auto; }

.mid-serif-headline a {
  color: #3A3E3D; }

.mid-serif-headline a:hover {
  color: #C7C7C7; }

.home-insights-bottom {
  margin-top: 30px; }

.home-insights-bottom-image {
  width: 48.9%; }

.home-insights-bottom-text {
  width: 51.1%;
  padding-right: 50px;
  margin: 0 0 0 auto;
  max-width: 400px; }

.home-insights .text {
  text-align: left;
  position: relative; }

.home-work-bottom {
  margin-top: 20px; }

.home-work-max {
  max-width: 54.1%;
  margin: 0 0 0 auto;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.home-work-top {
  padding-right: 15%; }

.home-work-top .small-label {
  margin-bottom: 20px; }

.mobile-work-label,
.mobile-work-link {
  display: none; }

.mobile-work-link {
  width: 164px;
  display: none;
  margin: 35px 0 0 auto; }

.mobile-work-label .small-label {
  margin-top: 20px;
  display: block !important; }

.home-work-bottom-left {
  max-width: 55%;
  width: 100%;
  padding-right: 10px;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.home-work-bottom-right {
  max-width: 45%;
  width: 100%;
  padding-left: 10px;
  text-align: right;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

.home-work-max:hover {
  max-width: 70%; }

.home-work-bottom:hover .home-work-bottom-right {
  max-width: 55%; }

.home-work-bottom:hover .home-work-bottom-left {
  max-width: 45%; }

.home-work-bottom-left:hover {
  max-width: 62% !important; }

.home-work-bottom-left:hover + .home-work-bottom-right {
  max-width: 38%; }

.home-work-bottom .small-label {
  margin-top: 20px; }

/* !Studio - - - - - */
ul.studio-nav {
  padding: 0 30px;
  text-align: center; }

.studio-pad {
  padding-top: 40px; }

ul.studio-nav li + li {
  margin-left: 50px; }

ul.studio-nav a {
  display: block;
  font-size: 1em;
  line-height: 1.3em;
  position: relative;
  color: #3A3E3D;
  font-style: italic; }

ul.studio-nav a:before {
  content: "";
  width: 0;
  height: 2px;
  position: absolute;
  bottom: -8px;
  left: 0;
  background: #3A3E3D;
  z-index: 1;
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

ul.studio-nav a:hover:before {
  width: 100%; }

.leader-middle {
  display: none;
  text-align: left; }

.leader-left {
  width: 395px;
  padding-right: 10px; }

.leader-right {
  width: 395px;
  padding-left: 10px;
  padding-top: 130px; }

.person-name {
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 10;
  margin-top: -60px; }

.also-header {
  padding: 0 30px;
  max-width: 1660px;
  margin: 0 auto; }

.also-header .small-sans-headline {
  border-bottom: 1px solid #C7C7C7;
  padding-bottom: 5px;
  margin-bottom: 15px; }

.disc-wrap {
  border-bottom: 1px solid #C7C7C7;
  padding-bottom: 45px; }

.disc-right {
  width: 49.4%; }

.disc-left {
  width: 50.6%;
  padding-right: 40px; }

ul.disc-list li {
  width: 25%;
  padding: 10px 45px 0 0; }

ul.disc-list {
  padding-top: 35px;
  max-width: 1060px;
  display: block;
  margin: 0 0 0 auto;
  font-size: 1.1428571429em;
  line-height: 1.4em; }

.who-block a.arrow-link {
  position: absolute;
  top: 50%;
  right: 70px;
  transform: translate(0, -50%);
  z-index: 101; }

.layout-bottom .text {
  max-width: 385px;
  margin-left: -135px; }

.layout1-right {
  width: 61.3%; }

.layout-bottom .layout1-right {
  margin: 0 0 0 auto; }

.layout1-left {
  width: 38.7%;
  padding-right: 50px; }

.layout-bottom {
  margin-top: 45px; }

.layout-top .layout1-left {
  text-align: right; }

.who-block + .who-block {
  margin-top: 350px; }

.layout2-left {
  width: 48.9%; }

.layout2-right {
  width: 51.1%;
  padding-left: 50px; }

.layout2 .text,
.layout3 .text {
  padding-left: 90px; }

.layout3-right {
  width: 37.3%; }

.layout3-left {
  width: 62.7%;
  padding-right: 50px; }

/* !Search Results - - - - - */
.search-block {
  margin-top: 90px; }

.search-cycle {
  width: calc(100% + 60px); }

.search-result {
  padding-right: 60px; }

.search-cycle-wrap button.slick-prev {
  display: none !important; }

.search-cycle-wrap .slick-next {
  width: 130px;
  height: 100%;
  position: absolute;
  top: 50%;
  right: -130px;
  z-index: 101;
  background: url(images/slide-arrow-right.svg) no-repeat center #fff;
  z-index: 10;
  transform: translate(0, -50%);
  border: none;
  padding: 0;
  margin: 0;
  text-indent: -9999px; }

.search-form-wrap #bigsearch {
  padding-bottom: 0; }

.search-form-wrap #bigsearch input[type=submit] {
  position: absolute;
  left: -9999px; }

/* !Video Block (Full Screen) - - - - - */
.video-block .inner,
.video-block.flex-wrap {
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.video-block.active {
  min-height: 100vh;
  background: #231F20; }

.video-block.active .inner {
  padding: 0;
  max-width: none; }

.video-block {
  cursor: none !important; }

.cursor {
  display: none;
  cursor: none !important;
  width: 86px;
  height: 42px;
  background: url(images/play.svg) no-repeat center;
  position: fixed; }

.cursor:focus,
.video-block:focus {
  cursor: none !important; }

.video-block.active .cursor {
  background: url(images/big-close.svg) no-repeat center; }

/* !Scrollback Header - - - - - */
header,
a.search-toggle {
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

header.hide,
header.hide a.nav-toggle,
header.hide a.search-toggle {
  top: -100px; }

.nav-active header.hide,
.nav-active header.hide a.nav-toggle,
.nav-active header.hide a.search-toggle,
.search-active header.hide,
.search-active header.hide a.nav-toggle,
.search-active header.hide a.search-toggle {
  top: 0; }

.scrolled header {
  background: #fff; }

.nav-active.scrolled header,
.seacrch-active.scrolled header {
  background: rgba(255, 255, 255, 0); }

/* !Blog Cats - - - - - */
.blog-filters {
  font-size: 1.4285714286em;
  line-height: 1.4em; }

.blog-filter-wrap {
  border-top: 1px solid #AEAEAE;
  padding: 90px 0 100px 0;
  display: none; }

.cats-left {
  width: 250px; }

.cats-right {
  width: calc(100% - 250px); }

ul.cat-list li {
  width: 33.33%;
  padding-left: 60px;
  padding-bottom: 10px; }

ul.cat-list a {
  color: #3A3E3D; }

ul.cat-list a:hover,
ul.cat-list a.active {
  color: #C7C7C7; }

a.filter-toggle {
  color: #3A3E3D;
  display: block; }

a.filter-toggle span {
  position: relative;
  padding-right: 40px;
  display: inline-block; }

a.filter-toggle span:before {
  content: "";
  width: 22px;
  height: 12px;
  position: absolute;
  top: 7px;
  right: 0;
  z-index: 1;
  background: url(images/sort-arrow.svg) no-repeat center;
  transform-origin: center;
  transform: rotate(-90deg);
  -webkit-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.35s cubic-bezier(0.86, 0, 0.07, 1); }

a.filter-toggle.active span:before {
  transform: rotate(0); }

.filter-pad {
  padding-bottom: 40px; }

/* !Studio Page (v2) - - - - - */
.studio-cta-text {
  font-size: 1.4285714286em;
  line-height: 1.4em; }

.studio-cta-text a {
  border-bottom: 1px solid #3A3E3D;
  color: #3A3E3D; }

.studio-cta-text a:hover {
  color: #C7C7C7;
  border-color: #C7C7C7; }

ul.studio-ctas {
  margin-top: 60px; }

ul.studio-ctas li + li {
  margin-top: 30px; }

.studio-left {
  width: 46.9%; }

.studio-right {
  width: 53.1%;
  padding: 170px 90px 0 90px; }

.studio-image {
  margin-top: 40px; }

.studio-left-pad {
  padding: 0 40px 0 130px; }

.new-studio-pad {
  padding: 160px 0; }

/* !Signup Block - - - - - */
.signup-border {
  padding: 90px 0;
  margin: 40px 0;
  border-top: 1px solid #AEAEAE;
  border-bottom: 1px solid #AEAEAE; }

.signup-text {
  margin-top: 25px; }

.post-signup-form {
  margin-top: 40px; }

.signup-max {
  max-width: 520px;
  margin: 0 auto; }

/* !Pagination - - - - - */
.load-status {
  border-top: 1px solid #AEAEAE;
  padding-top: 30px; }

.post-nav a {
  display: block;
  font-family: "adrianna", Arial, Verdana, sans-serif;
  text-transform: uppercase;
  font-style: italic;
  color: #3A3E3D;
  font-size: 1.1428571429em;
  line-height: 1.4em;
  padding-bottom: 35px;
  background: url(images/sort-arrow.svg) no-repeat center bottom;
  font-weight: bold;
  letter-spacing: .05em; }

.post-nav a:hover {
  color: #C7C7C7; }

/* !Embed Fix - - - - - */
.embed-block iframe {
  max-width: 100%;
  width: 100%; }

/* !Block Effects - - - - - */
.fade {
  opacity: 0;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.shift-left {
  position: relative;
  left: -100px;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.shift-right {
  position: relative;
  right: -100px;
  -webkit-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  -moz-transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.5s cubic-bezier(0.86, 0, 0.07, 1); }

.delay1 {
  transition-delay: .25s;
  -moz-transition-delay: .25s;
  -webkit-transition-delay: .25s; }

.delay2 {
  transition-delay: .5s;
  -moz-transition-delay: .5s;
  -webkit-transition-delay: .5s; }

.delay3 {
  transition-delay: .75s;
  -moz-transition-delay: .75s;
  -webkit-transition-delay: .75s; }

.inview.fade,
.inview .fade {
  opacity: 1; }

.inview .shift-left {
  left: 0; }

.inview .shift-right {
  right: 0; }

/* !Load Next Post - - - - - */
.more-wrap {
  padding: 40px 0;
  color: #3A3E3D; }

.more-wrap a {
  color: #3A3E3D; }

a.next-load {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 0;
  left: -99999px; }

/* - - - Media Queries - - - */
@media only screen and (max-width: 1350px) {
  .featured-post-right {
    width: 60%; }
  .featured-post-left {
    width: 40%;
    padding-right: 50px; }
  .grid-serif-headline {
    font-size: 2.1428571429em; }
  .mid-serif-headline {
    font-size: 2.5714285714em; }
  .featured-post .inner.wide {
    max-width: 1220px;
    padding-right: 30px; }
  .studio-headline {
    font-size: 6.4285714286em; } }

@media only screen and (max-width: 1250px) {
  input.search-box,
  .callout-text {
    font-size: 7.1428571429em; }
  input.search-box {
    height: 180px; }
  .footer-bg:before {
    height: 60px; }
  .studio-headline {
    font-size: 5.7142857143em; }
  .studio-right {
    padding-top: 80px; }
  .inner {
    padding: 0 80px; }
  .vert-title-wrap .vert-title {
    width: 70px; }
  .home-insights-top-text {
    padding-left: 40px; }
  a.home-arrow-link {
    right: 20px; }
  .vvbig-serif-headline {
    font-size: 8.5714285714em; }
  .home-work-pad {
    margin-top: -85px; } }

@media only screen and (max-width: 1140px) {
  .grid-screen-title:after {
    display: none; }
  .nav-wrap {
    padding-left: 0;
    padding-right: 0; }
  input.search-box {
    font-size: 6.4285714286em; }
  input.search-box {
    height: 120px; }
  .callout-text {
    font-size: 5.7142857143em; }
  .footer-bg:before {
    height: 45px; }
  .mid-serif-headline,
  .grid-serif-headline {
    font-size: 1.8571428571em; }
  .small-label {
    font-size: 1em; }
  .text {
    font-size: 1.1428571429em; }
  .text.small-text {
    font-size: 0.9285714286em; }
  .text.large-text {
    font-size: 1.2857142857em; }
  .text.vlarge-text {
    font-size: 1.2857142857em; }
  .blog-filters {
    font-size: 1.1428571429em; }
  a.filter-toggle span:before {
    top: 5px; }
  ul.cat-list li {
    padding-left: 40px;
    width: 50%; }
  ul.post-grid li {
    padding: 15px 15px 80px 15px; }
  .search-result {
    padding-right: 30px; }
  .search-cycle {
    width: calc(100% + 30px); }
  ul.post-grid {
    padding: 0 15px; }
  .small-section-pad {
    padding: 40px 0; }
  .section-pad {
    padding: 65px 0; }
  .mid-section-pad {
    padding: 90px 0; }
  .pad-bottom {
    padding-bottom: 90px; }
  .pad-top {
    padding-top: 65px; }
  .big-section-pad {
    padding: 90px 0; }
  .vbig-section-pad {
    padding: 160px 0; }
  .spacer-medium {
    height: 50px; }
  .spacer-large {
    height: 90px; }
  .spacer-xlarge {
    height: 120px; }
  .studio-headline {
    font-size: 5em; }
  .studio-right {
    padding-top: 60px;
    padding-left: 50px; }
  .studio-cta-text {
    font-size: 1.1428571429em; }
  .post-header {
    padding-top: 190px; }
  .post-header-top {
    top: 190px; }
  .text ul li:before {
    top: 9px; }
  ul.work-list li:nth-child(7n + 1) .grid-screen-title {
    font-size: 3.5714285714em; }
  .grid-screen-title {
    font-size: 1.5714285714em; }
  .grid-screen {
    padding: 25px 30px; }
  .web-wrap {
    height: 500px; }
  .client-intro-left {
    width: 280px; }
  .client-intro-right {
    width: calc(100% - 280px); }
  .small-sans-headline {
    font-size: 2.1428571429em; }
  .vvbig-serif-headline {
    font-size: 6.4285714286em; }
  .home-work-pad {
    margin-top: -65px; } }

@media only screen and (max-height: 1000px) {
  ul.nav a {
    font-size: 5.7142857143em; }
  .nav-bottom {
    margin-top: 60px; } }

@media only screen and (max-height: 768px) {
  ul.nav a {
    font-size: 4.2857142857em; }
  .info-block {
    font-size: 1.1428571429em; }
  ul.nav li + li {
    margin-top: 20px; }
  .nav-bottom {
    margin-top: 45px; } }

@media only screen and (max-width: 1023px) {
  .vert-text-wrap,
  .vert-title-wrap {
    display: none !important; }
  .footer-signup-text,
  .studio-left .studio-left-pad,
  a.home-arrow-link {
    display: none; }
  .vbig-serif-headline {
    font-size: 4.2857142857em; }
  .studio-headline {
    font-size: 3.5714285714em; }
  .inner {
    padding: 0 30px; }
  a.scroll-top {
    width: 30px;
    height: 30px;
    bottom: 15px;
    right: 15px; }
  a.scroll-top svg {
    width: 30px;
    height: 30px; }
  .footer-bg {
    padding-bottom: 70px; }
  .footer-left,
  .footer-right {
    width: 100%;
    display: block;
    padding: 0;
    text-align: center; }
  .footer-sign-form {
    text-align: left;
    margin-left: auto;
    margin-right: auto; }
  .callout-text {
    font-size: 4.2857142857em; }
  .footer-bottom .footer-right {
    text-align: center;
    margin-top: 45px; }
  .footer-signup-text.mobile-footer-text {
    display: block;
    margin-bottom: 45px; }
  footer .callout-text {
    text-align: center; }
  .footer-bg:before {
    height: 40px; }
  a.button,
  input.gform_button {
    font-size: 1.0714285714em;
    padding: 12px 20px; }
  ul.contact-links li {
    padding: 15px; }
  .blog-filter-wrap {
    padding: 45px 0 50px 0; }
  ul.post-grid li {
    width: 50%; }
  .featured-post-left,
  .featured-post-right,
  .studio-left,
  .studio-right {
    width: 100%;
    display: block; }
  .featured-post-left {
    margin-top: 50px; }
  .section-pad {
    padding: 50px 0; }
  .mid-section-pad {
    padding: 70px 0; }
  .pad-bottom {
    padding-bottom: 70px; }
  .pad-top {
    padding-top: 50px; }
  .big-section-pad {
    padding: 70px 0; }
  .vbig-section-pad {
    padding: 80px 0; }
  .spacer-medium {
    height: 40px; }
  .spacer-large {
    height: 60px; }
  .spacer-xlarge {
    height: 80px; }
  .search-cycle-wrap {
    padding-right: 30px; }
  .search-cycle-wrap .slick-next {
    right: -30px;
    width: 60px; }
  .new-studio-pad {
    padding-top: 0; }
  .studio-image {
    margin-top: 0; }
  .mobile-studio-headline {
    display: block; }
  .studio-right {
    padding: 45px 30px 0 30px; }
  ul.studio-ctas {
    margin-top: 45px; }
  .post-header-image {
    width: calc(100% - 30px); }
  .post-header-max {
    padding-left: 30px; }
  .signup-border {
    padding: 50px 0;
    margin: 30px 0; }
  .side-wrap {
    width: calc(100% - 200px); }
  .side-block a.arrow-link {
    right: 0;
    left: auto; }
  ul.work-list li:nth-child(7n + 1) .grid-screen-title {
    font-size: 2.8571428571em; }
  ul.web-list {
    padding: 0 30px; }
  ul.web-list li {
    padding: 0 15px; }
  a.nav-toggle {
    right: 5px; }
  a.search-toggle {
    right: 85px; }
  .vvbig-serif-headline {
    font-size: 5em; }
  .home-work-pad {
    margin-top: -45px; } }

@media only screen and (max-width: 900px) {
  .nav-right .nav-search,
  .nav-wrap .vert-text-wrap,
  .home-insights-bottom .grid-screen,
  .home-work-top .small-label {
    display: none; }
  .nav-left,
  .nav-right,
  .client-intro-right,
  .client-intro-left {
    width: 100%;
    padding: 0;
    display: block; }
  ul.nav a {
    font-size: 2.8571428571em; }
  .info-block {
    font-size: 1em; }
  ul.nav li + li {
    margin-top: 10px; }
  .nav-bottom,
  .nav-social,
  ul.contact-links,
  .client-intro-left {
    margin-top: 45px; }
  .nav-wrap .inner {
    padding: 0 45px; }
  .nav-wrap {
    padding: 120px 0 45px 0; }
  input.search-box {
    font-size: 4.2857142857em; }
  input.search-box {
    height: 80px; }
  .search-wrap {
    padding: 125px 45px 45px 45px; }
  .callout-text {
    font-size: 2.8571428571em; }
  .footer-bg:before {
    height: 25px; }
  .signup-form input[type=email] {
    font-size: 1.1428571429em; }
  .small-sans-headline {
    font-size: 1.7142857143em; }
  .small-label.lined {
    margin-bottom: 25px;
    border: none;
    padding-bottom: 0; }
  .home-work-pad {
    margin-top: 0;
    padding: 45px 0 60px 0; }
  .home-work-pad .inner {
    padding: 0; }
  .home-insights-top-image,
  .home-insights-top-text,
  .home-insights-bottom-image,
  .home-insights-bottom-text {
    width: 100%;
    display: block;
    padding: 0; }
  .home-insights-top-text,
  .home-insights-bottom-text {
    margin-top: 25px;
    text-align: left; }
  .home-insights-bottom {
    margin-top: 50px; }
  .home-insights-bottom-text {
    max-width: none; }
  .home-work-top {
    padding: 0; }
  .home-work-max,
  .home-work-max:hover,
  .home-work-bottom-left,
  .home-work-bottom-left:hover,
  .home-work-bottom-right,
  .home-work-bottom-right:hover,
  .home-studio-top-image,
  .home-studio-top-text,
  .home-studio-bottom-image {
    max-width: none !important;
    width: 100% !important;
    display: block; }
  .home-work-bottom-left,
  .home-work-bottom-right {
    padding: 0;
    margin-top: 50px;
    text-align: left; }
  .home-studio-top-text {
    padding: 0;
    margin-top: 35px;
    text-align: left; }
  .mobile-work-label,
  .mobile-work-link {
    display: block; } }

@media only screen and (max-width: 790px) {
  /* Style adjustments for viewports that meet the condition */
  ul.work-list li:nth-child(7n + 2),
  ul.work-list li:nth-child(7n + 4),
  ul.work-list li:nth-child(7n + 6),
  ul.work-list li:nth-child(7n + 3),
  ul.work-list li:nth-child(7n + 5),
  ul.work-list li:nth-child(7n + 7) {
    width: 100%;
    padding-left: 0;
    padding-right: 0; }
  ul.work-list li {
    padding-top: 10px; }
  .cats-left,
  .cats-right {
    width: 100%;
    display: block;
    padding: 0; }
  .cats-right {
    margin-top: 25px; }
  .blog-filters {
    font-size: 1em; }
  a.filter-toggle span:before {
    top: 4px; }
  ul.cat-list li {
    padding-left: 0;
    padding-right: 30px; }
  ul.work-list li:nth-child(7n + 1) .grid-screen-title {
    font-size: 1.5714285714em; }
  .web-wrap {
    height: 450px; } }

@media only screen and (max-width: 768px) {
  /* Style adjustments for viewports that meet the condition */
  .text img.alignleft,
  .text img.alignright {
    margin: 10px auto;
    float: none;
    display: block;
    max-width: 100%;
    width: auto;
    height: auto; }
  .vbig-serif-headline,
  .studio-headline,
  .small-callout-text {
    font-size: 3.5714285714em; }
  .post-header {
    padding-top: 120px; }
  .post-header-top {
    top: 120px; }
  .post-header-cover:after {
    height: 100px; }
  .post-header-cover:before {
    bottom: 100px; }
  .post-header-max {
    padding-bottom: 40px; }
  .half-block,
  .half-block:nth-child(odd),
  .half-block:nth-child(even) {
    width: 100%;
    display: block;
    padding: 0; }
  .half-block:nth-child(even) {
    margin-top: 10px; }
  .cta-wrap {
    padding-right: 0; }
  .cta-wrap .arrow-link,
  .side-block a.arrow-link {
    position: static;
    margin-top: 30px;
    transform: translate(0, 0); }
  a.arrow-link {
    transform: translate(0, 0);
    padding-left: 58px;
    width: 164px; }
  .arrow-link .arrow-vert {
    transform: translate(0, -100%) rotate(-90deg); }
  .side-wrap {
    width: 100%; }
  .web-wrap {
    height: 400px; }
  .vvbig-serif-headline {
    font-size: 3.5714285714em; } }

@media only screen and (max-width: 600px) {
  /* Style adjustments for viewports that meet the condition */
  .image-hover:after {
    display: none; }
  input.search-box,
  .big-serif-headline,
  .small-callout-text {
    font-size: 2.8571428571em; }
  input.search-box {
    height: 60px; }
  .info-block {
    font-size: 1em; }
  .grid-screen {
    position: static;
    padding: 25px 0 35px 0;
    text-align: left;
    opacity: 1; }
  .grid-screen .white {
    color: #3A3E3D; }
  .grid-screen .small-label {
    margin-bottom: 15px !important; }
  .web-wrap {
    height: 300px;
    border-width: 2px; } }

@media only screen and (max-width: 560px) {
  /* Style adjustments for viewports that meet the condition */
  ul.cat-list li,
  ul.post-grid li {
    width: 100%;
    display: block; }
  ul.cat-list li {
    padding-right: 0; }
  .grid-post-info,
  .featured-post-left {
    margin-top: 40px; }
  ul.post-grid li {
    padding-bottom: 45px; }
  li.grid-post a.small-arrow-link,
  .featured-post a.small-arrow-link {
    display: block; }
  .search-cycle-wrap {
    padding-right: 0; }
  .small-callout-text {
    font-size: 2.1428571429em; }
  .text blockquote {
    padding-left: 20px;
    font-size: 1.2857142857em; }
  a.slick-prev svg,
  a.slick-next svg {
    width: 16px;
    height: 29px; }
  a.slick-next,
  a.slick-prev {
    padding: 15px 7px;
    width: 30px; }
  .vvbig-serif-headline {
    font-size: 2.8571428571em; } }

@media only screen and (max-width: 400px) {
  /* Style adjustments for viewports that meet the condition */
  .web-wrap {
    height: 250px; } }

@media only screen and (max-width: 320px) {
  /* Style adjustments for viewports that meet the condition */ }

/* - - - Non-Semantic Helper Classes - - - */
.ir {
  display: block;
  border: 0;
  text-indent: -999em;
  overflow: hidden;
  background-color: transparent;
  background-repeat: no-repeat;
  text-align: left;
  direction: ltr;
  *line-height: 0; }

.ir br {
  display: none; }

.hidden {
  display: none !important;
  visibility: hidden; }

.visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px; }

.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus {
  clip: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  width: auto; }

.invisible {
  visibility: hidden; }

.clearfix:before, .clearfix:after {
  content: "";
  display: table; }

.clearfix:after {
  clear: both; }

.clearfix {
  *zoom: 1; }

/* - - - Print Styles - - - */
@media print {
  * {
    background: transparent !important;
    color: black !important;
    box-shadow: none !important;
    text-shadow: none !important;
    filter: none !important;
    -ms-filter: none !important; }
  /* Black prints faster: h5bp.com/s */
  a, a:visited {
    text-decoration: underline; }
  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid; }
  thead {
    display: table-header-group; }
  /* h5bp.com/t */
  tr, img {
    page-break-inside: avoid; }
  img {
    max-width: 100% !important; }
  @page {
    margin: 0.5cm; }
  p, h2, h3 {
    orphans: 3;
    widows: 3; }
  h2, h3 {
    page-break-after: avoid; } }
