.clear, .horizontal {
  clear: both;
}
.clear:after, .horizontal:after {
  content: " ";
  height: 0;
  clear: both;
  display: block;
  visibility: hidden;
}

/* resets */
html,
body {
  height: 100%;
  width: 100%;
}

body {
  background-color: #fff;
  color: #000;
}

abbr, acronym, address, article, aside, blockquote, body, button, caption, code, dd, del, dfn, dialog, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, iframe, img, input[type=radio], input[type=checkbox], label, legend, li, menu, nav, object, ol, p, pre, q, section, span, table, tbody, textarea, td, tfoot, th, thead, tr, ul, video {
  padding: 0;
  margin: 0;
}

article, aside, button, dialog, embed, fieldset, figcaption, figure, footer, form, header, hgroup, hr, iframe, img, input, label, menu, nav, object, section, select, textarea, video {
  display: block;
  margin: 0;
}

body,
input,
select,
textarea,
table th,
table td {
  font-size: 12px;
  font-family: arial, helvetica, sans-serif;
}

textarea {
  overflow: auto;
}

table {
  border-collapse: collapse;
}

td,
th {
  text-align: left;
  font-weight: normal;
}

hr,
img,
abbr,
iframe,
fieldset {
  border: none;
}

ol {
  padding-left: 15px;
  margin-left: 15px;
}

ul,
ul li {
  list-style: none;
}

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

p + p {
  padding-top: 15px;
}

b,
strong {
  font-weight: bold;
}

i,
em {
  font-style: italic;
}

address {
  font-style: normal;
}

small {
  font-size: 10px;
}

button,
.form-button input {
  border: 0;
  border-style: none;
  background-color: transparent;
}

button::-moz-focus-inner {
  border: none;
}

.form-button {
  display: table;
}

.horizontal > li,
.horizontal > dt,
.horizontal > dd {
  float: left;
}
.horizontal .left {
  float: left;
}
.horizontal .right {
  float: right;
}

.button,
a.button,
.button a {
  display: table;
}

.vertical > li,
.vertical > dt,
.vertical > dd {
  float: none;
}

.fluid > li,
.fluid > dd,
.fluid > dt {
  display: inline;
}

ul.scaffold {
  display: table;
}
ul.scaffold li,
ul.scaffold li > a {
  display: table-cell;
}

.scaffold th,
.scaffold td {
  vertical-align: top;
}

.radio-fields label,
.radio-fields .radio,
.radio-fields .checkbox,
.checkbox-fields label,
.checkbox-fields .radio,
.checkbox-fields .checkbox {
  float: none;
  display: table-cell;
  vertical-align: middle;
}
.radio-fields .radio input,
.checkbox-fields .radio input {
  margin-bottom: -1px;
}

hr,
.spacer {
  width: auto;
  height: 1px;
  font-size: 1px;
}

.hide {
  display: none;
}

.faded {
  opacity: 0;
}

/* mobile safari phone numbers */
a[href^=tel] {
  float: none;
  color: inherit;
}

/* remove iOS link flicker */
* {
  -webkit-tap-highlight-color: transparent;
}

.hide-text,
.hide_text {
  overflow: hidden;
  text-indent: -999em;
}

/* fonts */
/* optimize filesize: */
@font-face {
  font-family: "HelveticaNeueRoman";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/HelveticaNeueLTStd-Roman.woff2") format("woff2"), url("/d47a3234/fonts/HelveticaNeueLTStd-Roman.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueLight";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/HelveticaNeueLTStd-Lt.woff2") format("woff2"), url("/d47a3234/fonts/HelveticaNeueLTStd-Lt.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueBold";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/HelveticaNeueLTStd-Bd.woff2") format("woff2"), url("/d47a3234/fonts/HelveticaNeueLTStd-Bd.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueBlack";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/HelveticaNeueLTStd-Blk.woff2") format("woff2"), url("/d47a3234/fonts/HelveticaNeueLTStd-Blk.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueMedium";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/HelveticaNeueLTStd-Md.woff2") format("woff2"), url("/d47a3234/fonts/HelveticaNeueLTStd-Md.woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueBoldEx";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url(".woff2") format("woff2"), url(".woff") format("woff");
}
@font-face {
  font-family: "HelveticaNeueItalic";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/HelveticaNeueLTStd-It.woff2") format("woff2"), url("/d47a3234/fonts/HelveticaNeueLTStd-It.woff") format("woff");
}
@font-face {
  font-family: "SFProDisplayThin";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/SFProDisplay-Thin.woff2") format("woff2"), url("/d47a3234/fonts/SFProDisplay-Thin.woff") format("woff");
}
@font-face {
  font-family: "SFProDisplayLight";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/SFProDisplay-Light.woff2") format("woff2"), url("/d47a3234/fonts/SFProDisplay-Light.woff") format("woff");
}
@font-face {
  font-family: "SFProDisplayUltralight";
  font-style: normal;
  font-weight: normal;
  src: local(" "), local(" "), url("/d47a3234/fonts/SFProDisplay-Ultralight.woff2") format("woff2"), url("/d47a3234/fonts/SFProDisplay-Ultralight.woff") format("woff");
}
/* style guide fonts */
.font-base, .font-copyright, .font-helvetica {
  font-family: HelveticaNeueRoman, helvetica, arial, sans-serif;
}

.font-helvetica-light {
  font-family: HelveticaNeueLight, helvetica, arial, sans-serif;
}

.font-helvetica-bold, b,
strong,
.bold {
  font-family: HelveticaNeueBold, helvetica, arial, sans-serif;
}

.font-helvetica-black {
  font-family: HelveticaNeueBlack, helvetica, arial, sans-serif;
}

.font-helvetica-medium {
  font-family: HelveticaNeueMedium, helvetica, arial, sans-serif;
}

.font-helvetica-bold-ex {
  font-family: HelveticaNeueBoldEx, helvetica, arial, sans-serif;
}

.font-helvetica-italic, i,
em,
.italic {
  font-family: HelveticaNeueItalic, helvetica, arial, sans-serif;
}

.font-courier {
  font-family: "Courier New", Courier, helvetica, arial, sans-serif;
}

.font-sfpro-thin {
  font-family: SFProDisplayThin, helvetica, arial, sans-serif;
}

.font-sfpro-light {
  font-family: SFProDisplayLight, helvetica, arial, sans-serif;
}

.font-sfpro-ultralight {
  font-family: SFProDisplayUltralight, helvetica, arial, sans-serif;
}

.tm,
.reg,
.sup,
.footnote, .h1, .h3 {
  line-height: 1;
}

.font-base {
  letter-spacing: 0.2px;
}

.font-copyright {
  line-height: 1;
  font-size: 9px;
  letter-spacing: 0.2px;
  text-transform: uppercase;
}

.font-size-11-16 {
  font-size: 11px;
  line-height: 16px;
}

.font-size-12-14 {
  font-size: 12px;
  line-height: 14px;
}

.font-size-14-16 {
  font-size: 14px;
  line-height: 16px;
}

.font-size-16-18 {
  font-size: 16px;
  line-height: 18px;
}

.font-size-18-20 {
  font-size: 18px;
  line-height: 20px;
}

.font-size-18-22 {
  font-size: 18px;
  line-height: 22px;
}

.font-size-18-1 {
  font-size: 18px;
  line-height: 1;
}

.font-size-20-1 {
  font-size: 20px;
  line-height: 1;
}

.font-size-22-1 {
  font-size: 22px;
  line-height: 1;
}

.font-size-28-1 {
  font-size: 28px;
  line-height: 1;
}

.font-size-30-1 {
  font-size: 30px;
  line-height: 1;
}

.font-size-32-1 {
  font-size: 32px;
  line-height: 1;
}

.font-size-34-1 {
  font-size: 34px;
  line-height: 1;
}

.font-size-36-1 {
  font-size: 36px;
  line-height: 1;
}

.font-size-38-1 {
  font-size: 38px;
  line-height: 1;
}

.font-size-40-1 {
  font-size: 40px;
  line-height: 1;
  text-transform: uppercase;
}

.font-size-12 {
  font-size: 12px;
}

.font-size-14 {
  font-size: 14px;
}

.font-size-10-1 {
  font-size: 10px;
  line-height: 1;
}

.font-size-11-1 {
  font-size: 11px;
  line-height: 1;
}

.font-size-12-1 {
  font-size: 12px;
  line-height: 1;
}

.font-size-14-1 {
  font-size: 14px;
  line-height: 1;
}

.font-size-16-1 {
  font-size: 16px;
  line-height: 1;
}

.font-size-16-22 {
  font-size: 16px;
  line-height: 22px;
}

.font-size-18-26 {
  font-size: 18px;
  line-height: 26px;
}

.font-size-18-30 {
  font-size: 18px;
  line-height: 30px;
  letter-spacing: -0.012em;
}

.font-size-19-27 {
  font-size: 19px;
  line-height: 27px;
  letter-spacing: -0.012em;
}

.font-size-20-24 {
  font-size: 20px;
  line-height: 24px;
}

.font-size-22-26 {
  font-size: 22px;
  line-height: 26px;
}

.font-size-24-1 {
  font-size: 24px;
  line-height: 1;
  letter-spacing: -0.012em;
}

.font-size-24-28 {
  font-size: 24px;
  line-height: 28px;
  letter-spacing: -0.012em;
}

.font-size-24-30 {
  font-size: 24px;
  line-height: 30px;
  letter-spacing: -0.012em;
}

.font-size-28-32 {
  font-size: 28px;
  line-height: 32px;
  letter-spacing: -0.012em;
}

.font-size-36-40 {
  font-size: 36px;
  line-height: 40px;
  letter-spacing: -0.015em;
}

.font-size-38-42 {
  font-size: 38px;
  line-height: 42px;
  letter-spacing: -0.015em;
}

.font-size-42-46 {
  font-size: 42px;
  line-height: 46px;
  letter-spacing: -0.015em;
}
@media (max-width: 900px), (max-height: 500px) {
  .font-size-42-46 {
    font-size: 32px;
    line-height: 36px;
  }
}

.font-size-46-50 {
  font-size: 46px;
  line-height: 50px;
  letter-spacing: -0.015em;
}
@media (max-width: 1380px) {
  .font-size-46-50 {
    font-size: 36px;
    line-height: 40px;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .font-size-46-50 {
    font-size: 26px;
    line-height: 30px;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .font-size-46-50.menu-title {
    font-size: 36px;
    line-height: 40px;
  }
}

.font-size-48-1 {
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.015em;
}

.font-size-48-52 {
  font-size: 48px;
  line-height: 52px;
  letter-spacing: -0.015em;
}
@media (max-width: 900px), (max-height: 500px) {
  .font-size-48-52 {
    font-size: 38px;
    line-height: 42px;
  }
}

.font-size-56-60 {
  font-size: 56px;
  line-height: 60px;
  letter-spacing: -0.012em;
}

.font-size-80-84 {
  font-size: 80px;
  line-height: 84px;
  letter-spacing: -0.015em;
}
@media (max-width: 1380px) {
  .font-size-80-84 {
    font-size: 60px;
    line-height: 64px;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .font-size-80-84 {
    font-size: 46px;
    line-height: 50px;
  }
}

.letter-spaced-150 {
  letter-spacing: 0.15em;
}

.letter-spaced-350 {
  letter-spacing: 0.35em;
}

.font-size-62-1 {
  font-size: 62px;
  line-height: 1;
}

.font-size-78-1 {
  font-size: 78px;
  line-height: 1;
}

.uppercase {
  text-transform: uppercase;
}

i,
em,
.italic {
  font-style: normal;
}

b,
strong,
.bold {
  font-weight: normal;
}

/* superscript elements */
.tm,
.reg,
.sup,
.footnote {
  position: relative;
  vertical-align: baseline;
}

/* headers */
.h1 {
  margin: 0 0 13px;
}

.h2 {
  line-height: 20px;
  margin: 0 0 6px;
}

/* copy */
.copy-1 p + p {
  padding: 15px 0 0;
}

/* colors */
.color-000 {
  color: #000;
}

.white,
.color-fff {
  color: #fff;
}

.color-ccc {
  color: #ccc;
}

.color-ddd {
  color: #ddd;
}

.color-333 {
  color: #333;
}

.color-666 {
  color: #666;
}

.color-999 {
  color: #999;
}

.color-60ffff {
  color: #60ffff;
}

.color-1d1d1d {
  color: #1d1d1d;
}

.color-f5f5f5 {
  color: #f5f5f5;
}

.color-868686 {
  color: #868686;
}

/* site-specific resets */
html,
body {
  width: 100%;
  height: 100%;
}

body {
  background-color: #fff;
  color: #000;
}

*:focus {
  outline: 0;
}

a {
  text-decoration: none;
}
a:focus {
  outline: 0;
}

.hover,
.hover.active:hover {
  color: #000;
}
.color-f5f5f5 .hover, .color-f5f5f5
.hover.active:hover {
  color: #f5f5f5;
  text-decoration-color: #f5f5f5;
  -webkit-text-decoration-color: #f5f5f5;
  -moz-text-decoration-color: #f5f5f5;
}

.hover {
  text-decoration: underline;
  transition: all 0.2s;
  text-underline-offset: 0.1em;
  text-decoration-color: #000;
  -webkit-text-decoration-color: #000;
  -moz-text-decoration-color: #000;
}
.hover:hover {
  color: #999;
  text-decoration-color: transparent;
  -webkit-text-decoration-color: transparent;
  -moz-text-decoration-color: transparent;
}
.hover.white {
  color: #fff;
  text-decoration-color: #fff;
  -webkit-text-decoration-color: #fff;
  -moz-text-decoration-color: #fff;
}

p + p {
  padding-top: 15px;
}

.center {
  text-align: center;
}

.table {
  display: table;
}

.row {
  display: table-row;
}

.cell {
  display: table-cell;
  vertical-align: top;
}
.cell.valign-middle {
  vertical-align: middle;
}
.cell.valign-bottom {
  vertical-align: bottom;
}
.cell.main-cell {
  width: 999em;
}

.deck {
  margin: 0 auto;
  min-width: 375px;
  max-width: 1680px;
}

.page {
  background-color: #fff;
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px), (max-height: 500px) {
  .page {
    height: auto;
  }
}
.page.mobile-page {
  height: 100vh;
}
.page.black {
  background-color: #000;
}
.page .spacer {
  width: 160px;
}

@media (orientation: landscape) {
  .fit-landscape {
    height: 100vh !important;
  }
}

@media (max-width: 900px), (max-height: 500px) {
  .mobile-flow > .cell,
  .mobile-flow > .row > .cell,
  .page:not(.mobile-table) > .cell,
  .page:not(.mobile-table) > .row > .cell {
    display: block;
    width: auto;
  }
}

.mobile-show {
  display: none;
}
@media (max-width: 900px), (max-height: 500px) {
  .mobile-show {
    display: block !important;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .mobile-show.row {
    display: table-row !important;
  }
}

@media (max-width: 900px), (max-height: 500px) {
  .mobile-hide {
    display: none !important;
  }
}

@media (max-width: 900px), (max-height: 500px) {
  .mobile-flow {
    height: auto;
  }
}

.content {
  margin: 0 auto;
  padding: 60px 15px;
  max-width: 526px;
}

.contact-nav {
  display: none;
}
@media (max-width: 900px), (max-height: 500px) {
  .contact-nav {
    display: block;
  }
}

.header {
  text-transform: uppercase;
}
.header.first {
  margin-bottom: 2px;
}

@media (max-width: 900px), (max-height: 500px) {
  .main-content.main-cell {
    min-width: 306px;
    width: auto;
  }
}
@media (max-width: 375px) {
  .main-content.main-cell {
    min-width: 0;
    width: auto;
  }
}

.sidebar {
  text-align: right;
}
.sidebar .block {
  margin-left: auto;
}

.parens {
  color: #999;
}

.footer {
  padding: 60px 15px 30px;
}
@media (max-width: 900px), (max-height: 500px) {
  .footer {
    padding-top: 0;
  }
}

.deck-hero {
  background: transparent url("/d47a3234/images/poster-eddie.jpg") no-repeat 0 0;
  background-size: cover;
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  z-index: 1;
}

#hero-video {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;
}

.hero-content {
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 3;
}

.deck-credits {
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px), (max-height: 500px) {
  .deck-credits {
    height: 50vh;
  }
}
@media (orientation: landscape) {
  .fit-landscape .deck-credits {
    height: 100vh;
  }
}

.deck-stamp,
.deck-caption {
  color: #fff;
  position: absolute;
  bottom: 15px;
  z-index: 3;
}
.deck-stamp .delimit,
.deck-caption .delimit {
  font-size: 8px;
}
.deck-stamp.black, .deck-stamp.black a,
.deck-caption.black,
.deck-caption.black a {
  color: #000 !important;
}
.deck-stamp.black a:hover,
.deck-caption.black a:hover {
  text-decoration: underline;
}

.deck-stamp {
  right: 20px;
  text-align: right;
}

.deck-caption {
  font-size: 12px;
  line-height: 15px;
  bottom: 19px;
  right: 20px;
  text-align: right;
}
.deck-caption.text-shadow {
  text-shadow: -1px 0px 2px #000, 1px 0px 2px #000, 0px -1px 2px #000, 0px 1px 2px #000;
}
.deck-caption.copyright {
  left: 20px;
  right: auto;
  white-space: nowrap;
  text-align: left;
}

.deck-stamp {
  line-height: 1;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  white-space: nowrap;
}

.deck-title-bg {
  display: none;
  background: transparent url("/d47a3234/images/deck-title-logo-bg.png") no-repeat 0 0;
  background-repeat: repeat;
  position: absolute;
  z-index: 3;
  top: 50%;
  left: 0;
  right: 0;
  margin-top: -42px;
  width: 100%;
  height: 109px;
}

.iframe-content {
  z-index: 1;
}
.iframe-content iframe {
  z-index: 1;
}

.video-overlay video {
  margin: 0 auto;
}

.content-page .spacer {
  width: 300px;
}

.content-33 {
  width: 33%;
}

.content-50 {
  width: 50%;
}

.content-main {
  width: 999em;
}

.content-secondary {
  width: 320px;
}
@media (max-width: 900px), (max-height: 500px) {
  .content-secondary {
    width: auto;
    max-width: 500px;
  }
}
@media (max-width: 1200px) {
  .mobile-gehry .content-secondary {
    width: auto;
    max-width: 500px;
  }
}

.content-33-copy,
.content-50-copy,
.content-100-copy {
  padding: 60px 60px 60px 60px;
}
.content-33-copy.collapse-top,
.content-50-copy.collapse-top,
.content-100-copy.collapse-top {
  padding-top: 0;
}
.content-33-copy.collapse-bottom,
.content-50-copy.collapse-bottom,
.content-100-copy.collapse-bottom {
  padding-bottom: 0;
}
@media (max-width: 900px), (max-height: 500px) {
  .content-33-copy,
  .content-50-copy,
  .content-100-copy {
    padding: 30px 30px 30px 30px;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .content-33-copy.mobile-collapse-top,
  .content-50-copy.mobile-collapse-top,
  .content-100-copy.mobile-collapse-top {
    padding-top: 0;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .content-33-copy.mobile-collapse-bottom,
  .content-50-copy.mobile-collapse-bottom,
  .content-100-copy.mobile-collapse-bottom {
    padding-bottom: 0;
  }
}

.content-50-copy {
  max-width: 500px;
}
.content-50-copy.align-left {
  float: left;
}
.content-50-copy.align-right {
  float: right;
}
@media (max-width: 900px), (max-height: 500px) {
  .content-50-copy {
    margin: 0 auto;
  }
}

@media (max-width: 900px), (max-height: 500px) {
  .content-50-copy.align-left,
  .content-50-copy.align-right {
    float: none;
    margin: 0 auto;
  }
}

@media (max-width: 1200px) {
  .mobile-gehry .content-50-copy.align-left,
  .mobile-gehry .content-50-copy.align-right {
    float: none;
    margin: 0 auto;
  }
}

.content-100-copy {
  margin: 0 auto;
}

.content-50-image {
  max-width: 500px;
  width: 999em;
}

.content-50-rows {
  width: 100%;
  height: 100vh;
}

.content-50-row {
  height: 50%;
}
.content-50-row.delimit-top {
  border-top: 15px solid #fff;
}
.content-50-row.delimit-bottom {
  border-bottom: 15px solid #fff;
}

.content-columns-header {
  max-width: 860px;
  min-width: 660px;
  margin: 0 auto;
  padding-right: 30px;
  padding-left: 30px;
}

.content-columns {
  max-width: 980px;
  min-width: 780px;
  margin: 0 auto;
}
.content-columns .content-50-copy {
  padding-top: 0;
}
.content-columns .content-left {
  padding-right: 30px;
}
.content-columns .content-right {
  padding-left: 30px;
}

.content-header {
  margin-bottom: 20px;
}

.content-subheader-hr {
  width: 100%;
  border-bottom: 1px solid #000;
  margin: 0 0 2px;
}

.content-fpo,
.content-image-placeholder {
  background: transparent url("/d47a3234/images/content-fpo.png") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 50%;
}

@media (max-width: 900px), (max-height: 500px) {
  .content-image-nyc {
    height: 50vh;
  }
}

.content-image-hawaii {
  background: transparent url("/d47a3234/images/content-hawaii.jpg") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 0%;
}
@media (min-width: 1200px) {
  .content-image-hawaii {
    background-position: 50% 0%;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .content-image-hawaii {
    background-position: 50% 100%;
  }
}

.content-image-nyc {
  background: transparent url("/d47a3234/images/content-nyc-grayscale.jpg") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 100%;
}

.feature-header {
  margin-bottom: 3px;
}

.feature-copy {
  margin-bottom: 20px;
}
.feature-copy.last {
  margin-bottom: 0;
}

.features-columns .content-left {
  padding-right: 0;
}
.features-columns .content-right {
  padding-left: 30px;
}

.sub-columns {
  width: 100%;
}

.nowrap {
  white-space: nowrap;
}

.video-bg-black {
  background-color: #000;
}

.copy-bg-black {
  background-color: #000;
}

.video-load {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 100;
}

.bg-000000,
.video-load-000,
.bg-000000 iframe {
  background-color: #000000;
}

.bg-ffffff,
.video-load-fff,
.bg-ffffff iframe {
  background-color: #ffffff;
}

.bg-1d92d8,
.video-load-bbdo,
.bg-1d92d8 iframe {
  background: transparent url("/d47a3234/images/bg-1d92d8.png") repeat;
}

.bg-bacad0,
.video-load-bacad0,
.bg-bacad0 iframe {
  background: transparent url("/d47a3234/images/bg-bacad0.png") repeat;
}

.bg-a2b6bd,
.video-load-a2b6bd,
.bg-a2b6bd iframe {
  background: transparent url("/d47a3234/images/bg-a2b6bd.png") repeat;
}

.bg-d9d9d9,
.video-load-d9d9d9 {
  background-color: #d9d9d9;
}

.bg-f2f2f2 {
  background-color: #f2f2f2;
}

.bg-cbcbd2 {
  background: transparent url("/d47a3234/images/bg-cbcbd2.png") repeat;
}

.bg-321a3d {
  background: transparent url("/d47a3234/images/bg-321a3d.png") repeat;
}

.video-poster-hero {
  background: transparent url("/d47a3234/images/poster-eddie.jpg") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 50%;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 4;
}

.vertical-cells .header-cell-copy {
  height: 100px;
}
.vertical-cells .content-cell {
  height: 99%;
}

.desktop-br {
  display: inline;
}
@media (max-width: 900px), (max-height: 500px) {
  .desktop-br {
    display: none;
  }
}

.mobile-br {
  display: none;
}
@media (max-width: 900px), (max-height: 500px) {
  .mobile-br {
    display: inline;
  }
}

.services {
  display: table;
}
.services .service {
  float: left;
  margin: 0 6px 6px 0;
  white-space: nowrap;
}

.box {
  border: 1px solid #666;
  display: table;
  height: 20px;
  line-height: 20px;
  padding: 0px 6px 0px;
}

.fixed-header {
  position: absolute;
  top: 60px;
  left: 0;
  width: 100%;
  z-index: 100;
}
@media (max-width: 900px), (max-height: 500px) {
  .fixed-header {
    position: static;
    width: auto;
    padding: 60px 30px 20px;
  }
}

.inline-header {
  padding: 60px 30px 20px;
}
@media (max-width: 900px), (max-height: 500px) {
  .inline-header {
    text-align: left;
    max-width: 500px;
    margin: 0 auto;
    padding-bottom: 0;
  }
}

.fade,
.anim-hide,
.batch-fade {
  opacity: 0;
}

.contents-menu {
  white-space: nowrap;
}

.nav {
  clear: both;
  margin: 0 auto;
}

.menu-links a {
  text-decoration: none;
  border-bottom: 1px solid transparent;
  line-height: 18px;
  text-transform: uppercase;
  display: table;
  margin-bottom: 8px;
}
.menu-links a.active {
  color: #000;
}
.menu-links a.active:hover {
  color: #000;
}
.menu-links a:hover {
  color: #000;
  border-bottom: 1px solid #000;
}
.menu-links br {
  display: none;
}

.menu-links-center a {
  margin-left: auto;
  margin-right: auto;
}

.menu-links-right a {
  margin-left: auto;
}

.table-of-contents {
  padding-left: 20px;
  margin-bottom: 20px;
}
@media (max-width: 900px), (max-height: 500px) {
  .table-of-contents {
    border: 1px solid #999;
    padding: 6px 2px 7px 14px;
    border-width: 1px 0 0 1px;
    min-width: 258px;
  }
}
@media (max-width: 1380px) {
  .table-of-contents .break-1 > .cell {
    display: block;
    border-width: 0 !important;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .table-of-contents .break-1 > .cell {
    padding-left: 0 !important;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .table-of-contents.break-2 > .cell {
    display: block;
    border-width: 0 !important;
    padding-left: 0 !important;
  }
}
@media (max-width: 1380px) {
  .table-of-contents .break-1-hide {
    display: none;
  }
}
@media (max-width: 1380px) {
  .table-of-contents .break-1-show {
    display: block;
  }
}
.table-of-contents .break-1-hide.mobile-show {
  display: block !important;
}
@media (max-width: 1380px) {
  .table-of-contents .break-1-hide.mobile-show {
    display: none !important;
  }
}
@media (max-width: 1380px) {
  .table-of-contents .break-1-hide.mobile-show {
    display: none !important;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .table-of-contents .break-1-hide.mobile-show {
    display: block !important;
  }
}
.table-of-contents .delimit-left {
  border-left: 1px solid #999;
}
.table-of-contents .delimit-right {
  padding: 0 0 0 30px;
}
.table-of-contents .delimit-right.border {
  padding: 0 30px 0 30px;
  border-right: 1px solid #999;
}
.table-of-contents .delimit-left-30 {
  padding-left: 30px;
}
.table-of-contents .delimit-right-30 {
  padding-right: 30px;
}
.table-of-contents .menu-subitems {
  padding-left: 20px;
}

.menu-links-new a {
  text-decoration: underline;
  text-decoration-color: transparent;
  -webkit-text-decoration-color: transparent;
  -moz-text-decoration-color: transparent;
  line-height: 1;
  white-space: nowrap;
  display: table;
  padding: 6px 0;
}
.menu-links-new a.active {
  color: #000;
}
.menu-links-new a.active:hover {
  color: #000;
}
.menu-links-new a:hover {
  color: #868686;
  text-decoration-color: #868686;
  -webkit-text-decoration-color: #868686;
  -moz-text-decoration-color: #868686;
}

.menu-header {
  padding: 4px 0;
}

.menu-title {
  padding: 10px 0 30px;
}
@media (max-width: 900px), (max-height: 500px) {
  .menu-title {
    padding: 10px 0 11px;
  }
}

.no-break {
  white-space: nowrap;
}

.highlight {
  background-color: #def;
  padding: 0 5px;
}

@media (orientation: landscape) {
  .strengths .mobile-br {
    display: none;
  }
}

.mobile-graphic-content {
  padding: 60px 0 60px;
}

.grid {
  display: grid;
  width: 100%;
}

.deck-title-uncle {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -276px;
  z-index: 4;
}
@media (max-width: 900px), (max-height: 500px) {
  .deck-title-uncle {
    margin-left: -225px;
  }
}
@media (max-width: 470px) {
  .deck-title-uncle {
    margin-left: -177px;
  }
}

.deck-header-uncle {
  background: transparent url("/d47a3234/images/hero-logo.svg") no-repeat 0 0;
  background-size: cover;
  overflow: hidden;
  text-indent: -999em;
  display: block;
  position: relative;
  z-index: 5;
  width: 552px;
  height: 90px;
  margin-top: -60px;
}
@media (max-width: 900px), (max-height: 500px) {
  .deck-header-uncle {
    width: 450px;
    height: 73px;
    margin-top: -49px;
  }
}
@media (max-width: 470px) {
  .deck-header-uncle {
    width: 355px;
    height: 58px;
    margin-top: -41px;
  }
}

.deck-subheader-uncle {
  background: transparent url("/d47a3234/images/hero-tagline.svg") no-repeat 0 0;
  background-size: cover;
  overflow: hidden;
  text-indent: -999em;
  width: 285px;
  height: 15px;
  margin: 16px auto 0;
  position: relative;
  z-index: 5;
}
@media (max-width: 900px), (max-height: 500px) {
  .deck-subheader-uncle {
    width: 250px;
    height: 13px;
    margin-top: 12px;
  }
}

@media (max-width: 900px), (max-height: 500px) {
  .fit-portrait {
    height: 100vh;
  }
}

.site-menu {
  display: table;
  margin: 0px 0 0 auto;
  text-transform: uppercase;
}
.site-menu a:hover {
  color: #000;
  background-color: #fff;
}

.site-menu-top {
  margin-top: 0;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 1000;
}
.site-menu-top .toggle {
  color: #000;
  float: left;
  padding: 6px 10px 6px 10px;
  width: 101px;
  background-color: #fff;
  border: 1px solid #000;
  border-width: 0px 0 1px 1px;
  -webkit-border-bottom-left-radius: 4px;
  -moz-border-radius-bottomleft: 4px;
  border-bottom-left-radius: 4px;
}

.menu-item {
  color: #fff;
  display: block;
  width: 101px;
  text-decoration: none;
  padding: 6px 10px 6px 10px;
  border: 1px solid #fff;
  border-width: 0px 0 1px 1px;
}
.menu-item:last-child {
  -webkit-border-bottom-left-radius: 4px;
  -moz-border-radius-bottomleft: 4px;
  border-bottom-left-radius: 4px;
}
.black .menu-item {
  color: #000;
  border-color: #000;
}

.ios-header {
  color: #fff;
  margin: 0 auto;
  padding: 0 0 45px;
}
.ios-header .delimit {
  margin-bottom: 7px;
}

#ios-time {
  font-size: 78px;
}

#ios-date {
  font-size: 21px;
}

.ios-layout {
  padding: 30px 10px 40px;
  margin: 0 auto;
  max-width: 400px;
}

.ios-screenshots {
  background: transparent url("/d47a3234/images/content-testimony.v12.png") no-repeat 0 0;
  background-position: 0 0;
  background-size: contain;
  max-width: 400px;
  aspect-ratio: 1078/1528;
  margin: 0 auto;
}
@supports not (aspect-ratio: 1078/1528) {
  .ios-screenshots {
    height: 0;
    padding-top: 141.74397%;
  }
}
@media (max-width: 1400px) {
  .ios-screenshots {
    max-width: 355px;
  }
}

.content-image-testimony {
  background: transparent url("/d47a3234/images/content-testimony-bg.v18.png") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 50%;
}

.content-image-nyc-color {
  background: transparent url("/d47a3234/images/content-nyc.jpg") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 100%;
}

.content-image-cafe {
  background: transparent url("/d47a3234/images/content-cafe.jpg") no-repeat 0 0;
  background-size: cover;
  background-position: 0 100%;
}
@media (max-width: 900px), (max-height: 500px) {
  .content-image-cafe {
    background-position: 33% 100%;
  }
}

.content-image-ski {
  background: transparent url("/d47a3234/images/content-ski.jpg") no-repeat 0 0;
  background-size: cover;
  background-position: 50% 50%;
}
@media (max-width: 900px), (max-height: 500px) {
  .content-image-ski {
    background-position: 50% 47%;
  }
}

.our-focus {
  display: table;
  padding: 60px 35px 60px 15px;
  margin: 0 auto;
  max-width: 1015px;
}
@media (max-width: 1470px) {
  .our-focus {
    font-size: 40px;
    line-height: 46px;
    max-width: 878px;
    padding-right: 30px;
  }
}
@media (max-width: 1380px) {
  .our-focus {
    font-size: 36px;
    line-height: 40px;
    max-width: 445px;
  }
}
@media (max-width: 1200px) {
  .our-focus {
    font-size: 32px;
    line-height: 36px;
    max-width: 400px;
  }
}
@media (max-width: 900px), (max-height: 500px) {
  .our-focus {
    font-size: 26px;
    line-height: 30px;
    max-width: 330px;
  }
}

.focus-header {
  padding: 60px 30px 0;
  text-align: center;
}

.focus,
.focus-first {
  float: left;
  position: relative;
  padding: 0 0 11px 20px;
  z-index: 1;
}
@media (max-width: 1470px) {
  .focus,
  .focus-first {
    padding-left: 15px;
  }
}
.focus .input,
.focus-first .input {
  color: #fff;
  visibility: hidden;
}
.focus .output,
.focus-first .output {
  position: absolute;
  top: 0;
  left: 20px;
  width: 100%;
  z-index: 2;
}
@media (max-width: 1470px) {
  .focus .output,
  .focus-first .output {
    left: 15px;
  }
}

.focus {
  color: #000;
  white-space: nowrap;
}
.focus .cursor {
  color: #0cf;
  visibility: hidden;
}
.focus .cursor.first {
  visibility: visible;
}

.focus.last .container {
  background-color: #fff;
}

.focus-complete {
  color: #999;
}
.last .focus-complete {
  color: #000;
}

.cta {
  background-color: #0cf;
}

.rates-table {
  max-width: 470px;
  white-space: nowrap;
}
.rates-table .cell {
  border: 1px solid #ccc;
  border-width: 0 0 1px;
  padding: 4px 6px 4px 6px;
}
.rates-table .cell:first-child {
  border-left-width: 1px;
}
.rates-table .cell:last-child {
  border-right-width: 1px;
}
.rates-table .thead {
  background-color: #def;
}
.rates-table .thead .cell {
  border: 1px solid #0cf;
  border-width: 1px 0 1px;
}
.rates-table .thead .cell:first-child {
  border-left-width: 1px;
}
.rates-table .thead .cell:last-child {
  border-right-width: 1px;
}

.rates-rate,
.rates-zoom,
.rates-messages {
  width: 80px;
}
@media (max-width: 900px), (max-height: 500px) {
  .rates-rate,
  .rates-zoom,
  .rates-messages {
    width: auto;
  }
}

.rates-cta {
  padding: 20px 0 15px;
}

.cta-button {
  cursor: pointer;
  background-color: #def;
  border: 1px solid #0cf;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  white-space: nowrap;
  color: #000;
  display: table;
  padding: 5px 8px 3px 8px;
  text-decoration: none;
}
.cta-button:hover, .cta-button.clicked {
  color: #999;
  border: 1px solid #ccc;
  background-color: transparent;
}
.cta-button:hover {
  color: #000;
}
.cta-button.clicked {
  color: #999;
}
.cta-button.clicked:hover {
  color: #000;
  border: 1px solid #0cf;
}
.cta-button:focus {
  border: 1px solid #09f;
}
.cta-button.clicked.error {
  color: #999;
  border: 1px solid #ccc;
  cursor: default;
}

.cta-button-prompt {
  opacity: 0;
}

.overlay-contact {
  padding: 57px 60px 57px;
  max-width: 400px;
  margin: 0 auto;
}
@media (max-width: 900px), (max-height: 500px) {
  .overlay-contact {
    padding: 30px;
    max-width: 270px;
  }
}

.contact-email .cta-button {
  margin: 0 auto;
}

.contact-email-block {
  padding: 0 0 0 30px;
  white-space: nowrap;
}
@media (max-width: 900px), (max-height: 500px) {
  .contact-email-block {
    padding: 0;
  }
}

.contact-email-address-block {
  padding: 0 0 3px 0;
}

.contact-email-copy-block {
  padding: 0 0 0 10px;
}
@media (max-width: 900px), (max-height: 500px) {
  .contact-email-copy-block {
    padding-left: 5px;
  }
}

.contact-email-message-block {
  padding: 0 0 0 10px;
}
@media (max-width: 900px), (max-height: 500px) {
  .contact-email-message-block {
    padding-left: 5px;
  }
}

html.flat-layout,
.flat-layout body {
  background-color: #fff;
  color: #000;
}

.flat-page {
  max-width: 800px;
  padding: 60px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px), (max-height: 500px) {
  .flat-page {
    padding: 60px 30px;
  }
}

.flat-close-button {
  font-size: 30px;
  line-height: 1;
  position: absolute;
  z-index: 2;
  top: 30px;
  right: 30px;
}
.flat-close-button a {
  float: left;
  border: 1px solid #000;
}
