@charset "UTF-8";
/*
Theme Name: Capalino
Theme URI: http://capalino.com
Description: A custom theme for Capalino.
Version: 2.0
Author: Nick Zlonis
Author URI: http://figureground.com
*/
/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */
/* Document
   ========================================================================== */
html {
  font-family: sans-serif;
  /* 1 */
  line-height: 1.15;
  /* 2 */
  -ms-text-size-adjust: 100%;
  /* 3 */
  -webkit-text-size-adjust: 100%;
  /* 3 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main {
  /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0;
}

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
  /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */
template {
  display: none;
}

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none;
}

/**
 * Animation
 _________________________________________________________________________________________
 */
@-webkit-keyframes appearGrow {
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0, 0, 0);
            transform: scale3d(0, 0, 0);
  }
  80% {
    opacity: 0.8;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
            transform: scale3d(1.1, 1.1, 1.1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
            transform: scale3d(1, 1, 1);
  }
}
@keyframes appearGrow {
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0, 0, 0);
            transform: scale3d(0, 0, 0);
  }
  80% {
    opacity: 0.8;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
            transform: scale3d(1.1, 1.1, 1.1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
            transform: scale3d(1, 1, 1);
  }
}
.appear_grow {
  opacity: 0;
  -webkit-transform: scale3d(0, 0, 0);
          transform: scale3d(0, 0, 0);
  -webkit-animation: appearGrow 0.5s ease-in 0s 1 forwards;
          animation: appearGrow 0.5s ease-in 0s 1 forwards;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.fade_in {
  opacity: 0;
  -webkit-animation: fadeIn 0.5s ease-in 1s forwards;
  animation: fadeIn 0.5s ease-in 1s forwards;
}

@-webkit-keyframes fadeIn80 {
  from {
    opacity: 0;
  }
  to {
    opacity: 0.8;
  }
}

@keyframes fadeIn80 {
  from {
    opacity: 0;
  }
  to {
    opacity: 0.8;
  }
}
.fade_in_80 {
  opacity: 0;
  -webkit-animation: fadeIn80 0.5s ease-in 1s forwards;
          animation: fadeIn80 0.5s ease-in 1s forwards;
}

@-webkit-keyframes spin {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes spin {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.spin {
  -webkit-animation: spin 2s infinite linear;
          animation: spin 2s infinite linear;
  display: inline-block;
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

/**
 * Variables
 _________________________________________________________________________________________
 */
/*
$font-display:-apple-system, BlinkMacSystemFont, San Francisco, Roboto, Segoe UI, Helvetica Neue, sans-serif;
$font-text:-apple-system, BlinkMacSystemFont, San Francisco, Roboto, Segoe UI, Helvetica Neue, sans-serif;
$font-display-bold:-apple-system, BlinkMacSystemFont, San Francisco, Roboto, Segoe UI, Helvetica Neue, sans-serif;
$font-text-bold:-apple-system, BlinkMacSystemFont, San Francisco, Roboto, Segoe UI, Helvetica Neue, sans-serif;
*/
/**
 * Mixins
 _________________________________________________________________________________________
 */
/**
 * Responsive
 _________________________________________________________________________________________
 */
.xs-hidden {
  display: none;
}
@media only screen and (min-width: 375px) {
  .xs-hidden {
    display: initial;
  }
}

.sm-hidden {
  display: none;
}
@media only screen and (min-width: 480px) {
  .sm-hidden {
    display: initial;
  }
}

.md-hidden {
  display: none;
}
@media only screen and (min-width: 768px) {
  .md-hidden {
    display: initial;
  }
}

.lg-hidden {
  display: none;
}
@media only screen and (min-width: 960px) {
  .lg-hidden {
    display: initial;
  }
}

.xl-hidden {
  display: none;
}
@media only screen and (min-width: 1200px) {
  .xl-hidden {
    display: initial;
  }
}

/**
 * Base
 _________________________________________________________________________________________
 */
* {
  box-sizing: border-box;
  line-height: 1.5;
}

a {
  transition: all 0.2s ease-out;
  text-decoration: underline;
  -webkit-text-decoration-color: #94b6d8;
          text-decoration-color: #94b6d8;
  text-decoration-thickness: 0.125em;
  text-underline-offset: 1.5px;
}

a:link {
  color: #0066b3;
}

a:visited {
  color: #662d91;
}

a:hover {
  color: #00a5df;
  cursor: pointer;
}

a:active {
  border: none;
}

a:focus {
  border: none;
}

a img {
  border: none;
}

address {
  font-style: normal;
  font-weight: bold;
  margin: 0 0 1em 0;
}
address a:link,
address a:visited {
  color: #333333;
}

body {
  background-color: #ffffff;
  color: #333333;
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  font-size: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0 auto;
  max-width: 100%;
  min-width: 320px;
  overflow-x: hidden;
}

button {
  cursor: pointer;
}

cite {
  font-style: italic;
}

.clear {
  clear: both;
  display: block;
}

.divider {
  display: inline-block;
  margin: 0 0.5em;
}

em {
  font-style: italic;
}

fieldset {
  border: 0;
  padding: 0;
}

figure {
  margin: 1em 0;
}

h1 {
  color: #662d91;
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  font-size: 1.8em;
  font-weight: 700;
  line-height: 1.2em;
  margin: 0 0 0.5em 0;
}

h2 {
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  font-size: 1.4em;
  font-weight: bold;
  line-height: 1.2;
  margin: 0.5em 0 1em 0;
}
main h2 {
  color: #662d91;
}

h3 {
  color: #ff8400;
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  font-size: 1.25em;
  font-weight: bold;
  margin: 0 0 1em 0;
}

h4 {
  color: #666666;
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  font-size: 1em;
  font-weight: bold;
}

h5 {
  color: #666666;
}

hr {
  border: 0;
  border-top: 1px solid #aaaaaa;
}

html {
  height: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

img {
  height: auto;
  margin: 0 auto 1.5em;
  max-width: 100%;
  width: 100%;
}

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

main,
.main {
  margin: 4vw;
  position: relative;
  z-index: 1;
}
@media only screen and (min-width: 960px) {
  main,
.main {
    margin: 4vw 16vw;
  }
}
@media only screen and (min-width: 1200px) {
  main,
.main {
    margin: 5vw auto;
    max-width: 800px;
  }
}
@media only screen and (min-width: 768px) {
  main.main-sitemap,
.main.main-sitemap {
    display: flex;
  }
}
@media only screen and (min-width: 960px) {
  .page-id-12 main,
.page-id-12 .main {
    margin: 4vw 20vw;
  }
}
.search-results main,
.search-results .main {
  margin-top: 0;
}
main.section-blog,
.main.section-blog {
  margin: 0 4vw 4vw 4vw;
}
@media only screen and (min-width: 1400px) {
  main.section-blog,
.main.section-blog {
    margin: 0 auto 4vw auto;
  }
}
main.main-fony,
.main.main-fony {
  max-width: 1200px;
}
.single-capalino_fony main, .single-post main,
.single-capalino_fony .main,
.single-post .main {
  margin-top: 0;
}

.nav-tabs + main {
  margin-top: 2vw;
}

ol {
  list-style-type: decimal;
  margin: 0 0 2em 1em;
}

ol li {
  font-size: 1.1rem;
  margin: 0 0 1.25em 0;
}

p {
  font-size: 1.1rem;
  line-height: 1.6;
  margin: 0 0 2em 0;
}
@media only screen and (min-width: 768px) {
  p {
    line-height: 1.75;
  }
}
p.p-contributors {
  font-size: 0.9rem;
  margin: 0 0 0.5rem 0;
}
p.p-fony-excerpt {
  font-size: 0.8rem;
}
p.p-search-result-excerpt {
  font-size: 0.9em;
  margin: 0;
}
p.post-date {
  color: #aaaaaa;
  font-size: 0.8em;
  margin: 0;
}

strong {
  font-weight: bold;
}

.subtle {
  color: #bbbbbb;
  display: inline-block;
}

a.subtle:link {
  color: #bbbbbb;
  text-decoration: underline;
}

a.subtle:visited {
  color: #bbbbbb;
}

a.subtle:hover {
  color: #bbbbbb;
}

a.subtle:active {
  color: #333333;
}

sup {
  font-size: 0.6em;
  vertical-align: middle;
}

ul {
  margin: 0 0 2em 0;
  padding: 0 0 0 1.5em;
}
ul ul {
  margin: 1em 0 0 0;
}

ul li {
  font-size: 1.1rem;
  line-height: 1.4;
  margin: 0 0 1.25em 0;
}

/* Typekit classes */
.wf-loading {
  font-family: "helvetica neue", arial, helvetica, sans-serif;
}

.wf-active {
  font-family: proxima-nova;
}

/* Wordpress default classes */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

.wp-block-image .alignleft {
  display: block;
  float: none;
  margin: 0 auto 1.5em auto;
}
@media only screen and (min-width: 768px) {
  .wp-block-image .alignleft {
    display: table;
    float: left;
    margin: 0 1.5em 1.5em 0;
  }
}

.alignright,
.wp-block-image .alignright,
.wp-caption.alignright {
  display: block;
  float: none;
  margin: 0 auto 1em auto;
}
@media only screen and (min-width: 768px) {
  .alignright,
.wp-block-image .alignright,
.wp-caption.alignright {
    display: table;
    float: right;
    margin: 0 0 1.5em 1.5em;
  }
}

.wp-block-image figcaption {
  color: #888888;
  font-size: 0.9rem;
}

.wp-block-separator {
  margin: 1em auto 2.5em auto;
  width: 240px;
}

.wp-caption {
  margin: 0;
  max-width: 100%;
}

.wp-caption img[class*=wp-image-] {
  display: block;
  margin: 0;
}

.wp-caption-text {
  color: #888888;
  font-size: 0.9em;
  line-height: 1.3;
  margin-top: 0.5em;
}

.wp-smiley {
  display: inline;
  margin: 0 0.2em;
  max-width: auto;
  min-width: auto;
  width: auto;
}

/* Google reCAPTCHA */
.grecaptcha-badge {
  visibility: hidden;
}

/**
 * Footer
 _________________________________________________________________________________________
 */
#footer {
  border-bottom: 12px solid #662d91;
  padding: 2em 8vw;
}
@media only screen and (min-width: 768px) {
  #footer {
    background-image: url("img/supergraphic.png");
    background-position: 0 24vw;
    background-repeat: no-repeat;
    background-size: 32vw;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    padding: 2vw 4vw;
    padding-bottom: 2vw;
  }
}
@media only screen and (min-width: 960px) {
  #footer {
    background-position: 0 18vw;
  }
}
@media only screen and (min-width: 1200px) {
  #footer {
    background-position: 0 15vw;
  }
}
#footer address {
  color: #888888;
  font-size: 0.9em;
}
#footer address strong {
  color: #662d91;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
#footer .copyright {
  color: #888888;
  flex-basis: 100%;
  font-size: 0.8em;
  margin: 0;
  padding: 2em 0 0 0;
  text-align: center;
}
@media only screen and (min-width: 480px) {
  #footer .copyright {
    text-align: right;
  }
}

/**
 * Form
 _________________________________________________________________________________________
 */
.form-contact button {
  float: right;
}
@media only screen and (min-width: 480px) {
  .form-contact button {
    float: right;
  }
}
.form-contact input,
.form-contact input[text],
.form-contact input[email] {
  background-color: #f6f6f6;
  border: 2px solid #cccccc;
  border-radius: 20px;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.08);
  display: block;
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  line-height: 40px;
  margin: 0 0 1em 0;
  padding: 0 15px;
  width: 100%;
}
.form-contact input:focus,
.form-contact input[text]:focus,
.form-contact input[email]:focus {
  border: 2px solid #ff8400;
  outline: 0;
}
.form-contact input#challenger,
.form-contact input[text]#challenger,
.form-contact input[email]#challenger {
  display: inline-block;
  width: 50px;
}
@media only screen and (min-width: 480px) {
  .form-contact input#challenger,
.form-contact input[text]#challenger,
.form-contact input[email]#challenger {
    padding: 0 15px;
  }
}
@media only screen and (min-width: 480px) {
  .form-contact input,
.form-contact input[text],
.form-contact input[email] {
    display: inline-block;
    margin: 0;
    padding: 0 15px 0 90px;
  }
}
.form-contact label {
  color: #888888;
  display: block;
  font-size: 0.8em;
  font-weight: bold;
  padding: 0 0 4px 10px;
  position: relative;
  text-transform: uppercase;
}
.form-contact label .subtle {
  display: none;
  text-transform: none;
}
@media only screen and (min-width: 768px) {
  .form-contact label .subtle {
    display: inline-block;
  }
}
@media only screen and (min-width: 480px) {
  .form-contact label {
    display: inline-block;
    padding: 0 0 4px 15px;
    pointer-events: none;
    top: 36px;
    width: auto;
  }
  .form-contact label.label-challenger {
    pointer-events: none;
    top: 0;
  }
}
.form-contact textarea {
  background: #f6f6f6;
  border: 2px solid #cccccc;
  border-radius: 20px 20px 0 20px;
  box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.1);
  font-family: "Gotham SSm A", "Gotham SSm B", arial, helvetica, sans-serif;
  margin: 0 0 1em 0;
  min-height: 140px;
  padding: 15px;
  width: 100%;
}
.form-contact textarea:focus {
  border: 2px solid #ff8400;
  outline: none;
}
.form-contact textarea::-webkit-input-placeholder {
  color: #888888;
  font-size: 0.8em;
  font-weight: bold;
  opacity: 1;
  text-transform: uppercase;
}
.form-contact textarea::-moz-placeholder {
  color: #888888;
  font-size: 0.8em;
  font-weight: bold;
  opacity: 1;
  text-transform: uppercase;
}
.form-contact textarea:-ms-input-placeholder {
  color: #888888;
  font-size: 0.8em;
  font-weight: bold;
  opacity: 1;
  text-transform: uppercase;
}
.form-contact textarea::placeholder {
  color: #888888;
  font-size: 0.8em;
  font-weight: bold;
  opacity: 1;
  text-transform: uppercase;
}
@media only screen and (min-width: 480px) {
  .form-contact textarea {
    margin: 1.5em 0 1em 0;
  }
}

.form-contact-modal {
  background-color: #662d91;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.4);
  color: #ffffff;
  display: none;
  min-height: 500px;
  padding: 8vw;
  position: absolute;
  top: 80px;
  z-index: 3;
  width: 100vw;
}
.form-contact-modal.form-contact-modal-active {
  display: block;
}
@media only screen and (min-width: 768px) {
  .form-contact-modal {
    padding: 8vw;
    top: 120px;
  }
}
.form-contact-modal .btn-cancel {
  border: #a87fdd;
  color: #a87fdd;
  text-decoration: underline;
}
@media only screen and (min-width: 768px) {
  .form-contact-modal .btn-cancel {
    float: right;
    margin-right: 1em;
  }
}
.form-contact-modal .btn-close {
  border: #a87fdd;
  color: #a87fdd;
  cursor: pointer;
  display: inline-block;
  font-size: 2em;
  min-height: 44px;
  min-width: 44px;
  padding: 0 0.5em;
  position: absolute;
  right: 3vw;
  top: 3vw;
}
.form-contact-modal .btn-return {
  border: #a87fdd;
  color: #a87fdd;
  margin-left: -1em;
  text-decoration: underline;
}
.form-contact-modal .btn-submit {
  margin-right: 0.5em;
}
@media only screen and (min-width: 768px) {
  .form-contact-modal .btn-submit {
    float: right;
  }
}
.form-contact-modal .cc {
  color: #a87fdd;
  display: block;
  margin: 0 0 1em 0;
}
@media only screen and (min-width: 768px) {
  .form-contact-modal .cc {
    display: inline-block;
  }
}
.form-contact-modal fieldset {
  clear: both;
  display: block;
  margin: 1em 0 0 0;
}
.form-contact-modal h2 {
  color: #ffffff;
  margin: 0;
}
.form-contact-modal h4 {
  color: #ffffff;
}
.form-contact-modal input {
  border: 0;
  border-radius: 4px;
  display: block;
  margin: 0 0 1em 0;
  opacity: 0.8;
  padding: 0.5em;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .form-contact-modal input {
    max-width: 400px;
  }
}
.form-contact-modal input:focus {
  opacity: 1;
}
.form-contact-modal input#email {
  margin-bottom: 1.5em;
}
.form-contact-modal label {
  clear: both;
  color: #d8cedf;
  display: block;
  margin: 0 0 0.25em 0;
}
.form-contact-modal textarea {
  border: 0;
  border-radius: 4px;
  display: block;
  margin: 0 0 1em 0;
  min-height: 240px;
  opacity: 0.8;
  padding: 0.5em;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .form-contact-modal textarea {
    min-height: 200px;
  }
}
.form-contact-modal textarea:focus {
  opacity: 1;
}
.form-contact-modal ul {
  color: #ffffff;
}

@media only screen and (min-width: 768px) {
  .form-search {
    position: absolute;
    right: 0;
  }
}
.form-search div#search-group {
  line-height: 80px;
  height: 80px;
}
@media only screen and (min-width: 768px) {
  .form-search div#search-group {
    display: none;
    margin: 0;
  }
}
.form-search div#search-group.is-active {
  display: inline-block;
}
@media only screen and (min-width: 768px) {
  .form-search div#search-group.is-active {
    width: 62vw;
  }
}
@media only screen and (min-width: 1200px) {
  .form-search div#search-group.is-active {
    width: 54vw;
  }
}
@media only screen and (min-width: 1400px) {
  .form-search div#search-group.is-active {
    width: 50vw;
  }
}
.form-search button[type=submit] {
  background-color: transparent;
  border: 0;
  color: #888888;
  cursor: pointer;
  display: inline-block;
  height: 42px;
  margin: 0 0 0 -45px;
  padding: 0;
  text-align: center;
  transition: all 200ms ease-out;
  vertical-align: middle;
  width: 42px;
}
.form-search button[type=submit]:hover {
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
}
.form-search button#btn-search-toggle {
  background-color: transparent;
  border: 0;
  color: #888888;
  cursor: pointer;
  display: none;
  padding: 0;
  text-align: center;
  transition: all 200ms ease-out;
  vertical-align: middle;
  width: 42px;
}
@media only screen and (min-width: 768px) {
  .form-search button#btn-search-toggle {
    display: inline-block;
    height: 80px;
    position: absolute;
    right: -45px;
    top: 0;
  }
}
.form-search button#btn-search-toggle:hover {
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
}
.form-search button#btn-search-toggle svg {
  position: relative;
  top: 2px;
}
.form-search button#btn-search-toggle svg#search-toggle-icon-close {
  display: none;
}
.form-search input[type=text] {
  background-color: rgba(255, 255, 255, 0.7);
  border: 1px solid #aaaaaa;
  border-radius: 20px;
  font-weight: bold;
  line-height: 40px;
  margin: 0 0 0 5vw;
  padding: 0 40px 0 15px;
  transition: background-color 150ms ease-out;
  width: 90vw;
}
.form-search input[type=text]:focus {
  background-color: #ffffff;
  box-shadow: 0 0 10px #d8cedf;
  outline: none;
}
.form-search input[type=text]::-webkit-input-placeholder {
  font-weight: normal;
}
.form-search input[type=text]::-moz-placeholder {
  font-weight: normal;
}
.form-search input[type=text]:-ms-input-placeholder {
  font-weight: normal;
}
.form-search input[type=text]::placeholder {
  font-weight: normal;
}
@media only screen and (min-width: 768px) {
  .form-search input[type=text] {
    background-color: #ffffff;
    margin: 0;
    width: 100%;
  }
}

.form-search-results {
  margin: 0 0 1em 0;
  position: relative;
}
.form-search-results input[type=text] {
  border: 1px solid #cccccc;
  border-radius: 22px;
  line-height: 44px;
  padding: 0 0 0 20px;
  width: 100%;
}
.form-search-results input[type=text]:focus {
  outline: none;
}

.form-subscribe input[type=email] {
  border: 1px solid #cccccc;
  border-right: 0;
  border-radius: 22px 0 0 22px;
  display: inline-block;
  line-height: 44px;
  margin: 0 -4px 0 0;
  padding: 0 20px;
  transition: all 200ms ease-out;
  width: calc(100% - 150px);
}
.form-subscribe input[type=email]:focus {
  background-color: #ffffff;
  box-shadow: 0 0 10px #d8cedf;
  outline: none;
}
.form-subscribe label {
  color: #888888;
  display: block;
  padding: 0 0 1em 10px;
}
.form-subscribe .subscribe-info {
  color: #888888;
  font-size: 1em;
  padding: 1em 0;
}

/**
 * Header
 _________________________________________________________________________________________
 */
#header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  min-height: 80px;
  padding: 0 0 0 4%;
  position: relative;
  z-index: 2;
}
@media only screen and (min-width: 768px) {
  #header {
    min-height: 120px;
    padding: 0 4%;
  }
}
#header a.logo {
  display: block;
}

.header-careers.header-page .link-careers {
  border-bottom: 4px solid #7a3ec7;
  display: none;
  font-size: 0.8em;
  font-weight: bold;
  padding: 0 0 0.5em 0;
  vertical-align: middle;
}
@media only screen and (min-width: 960px) {
  .header-careers.header-page .link-careers {
    bottom: auto;
    display: inline-block;
    left: 8vw;
    position: absolute;
    right: auto;
    top: 3vw;
  }
}
.header-careers.header-page .link-careers:link, .header-careers.header-page .link-careers:visited {
  color: #a87fdd;
  text-decoration: none;
  text-transform: uppercase;
}
.header-careers.header-page .link-careers:hover, .header-careers.header-page .link-careers:active {
  color: #d8cedf;
  text-decoration: none;
}
.header-careers.header-page .link-careers:hover svg, .header-careers.header-page .link-careers:active svg {
  left: -8px;
  opacity: 1;
}
.header-careers.header-page .link-careers svg {
  left: 0;
  opacity: 0.5;
  position: relative;
  top: 3px;
  transition: left 200ms ease-out;
}

.header-case-study {
  background-blend-mode: normal;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  color: #ffffff;
  min-height: 40vw;
  position: relative;
  z-index: 0;
}
.header-case-study .link-case-studies {
  border-bottom: 4px solid rgba(255, 255, 255, 0.3);
  display: none;
  font-size: 0.8em;
  font-weight: bold;
  padding: 0 0.1em 0.5em 0;
  text-shadow: 0 1px 5px rgba(0, 0, 0, 0.8);
  vertical-align: middle;
}
@media only screen and (min-width: 768px) {
  .header-case-study .link-case-studies {
    bottom: auto;
    display: inline-block;
    left: 8vw;
    position: absolute;
    right: auto;
    top: 2vw;
  }
}
.header-case-study .link-case-studies:link, .header-case-study .link-case-studies:visited {
  color: #ffffff;
  opacity: 0.8;
  text-decoration: none;
  text-transform: uppercase;
}
.header-case-study .link-case-studies:hover, .header-case-study .link-case-studies:active {
  color: #ffffff;
  opacity: 1;
  text-decoration: none;
}
.header-case-study .link-case-studies:hover svg, .header-case-study .link-case-studies:active svg {
  left: -8px;
  opacity: 1;
}
.header-case-study .link-case-studies svg {
  left: 0;
  opacity: 0.5;
  position: relative;
  top: 3px;
  transition: left 200ms ease-out;
}
.header-case-study h1 {
  color: #ffffff;
}
.header-case-study .supergraphic-alt {
  bottom: -18vw;
  height: auto;
  position: absolute;
  right: 0;
  width: 20vw;
}
@media only screen and (min-width: 480px) {
  .header-case-study .supergraphic-alt {
    bottom: -15vw;
  }
}
@media only screen and (min-width: 768px) {
  .header-case-study .supergraphic-alt {
    bottom: -14vw;
  }
}

.header-page {
  background-blend-mode: overlay, normal;
  background-color: #662d91;
  background-image: url("img/headers/header-default.jpg");
  background-position: 0 50%, right top;
  background-repeat: no-repeat, no-repeat;
  background-size: cover, contain;
  color: #ffffff;
  font-weight: bold;
  padding: 10vw 8vw 10vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .header-page {
    padding: 8vw 50vw 8vw 8vw;
  }
}
.header-page h1 {
  font-size: 8vw;
  letter-spacing: -1px;
}
.header-page h1.heading-long {
  font-size: 6vw;
}
.header-page h1.heading-longer {
  font-size: 5vw;
}
.header-page h1, .header-page h2 {
  color: #ffffff;
  position: relative;
}
.category-31 .header-page, .category-32 .header-page, .category-33 .header-page {
  margin-top: calc(-2rem - 1px);
  padding: 8vw;
}
.category-31 .header-page h1, .category-32 .header-page h1, .category-33 .header-page h1 {
  font-size: 6vw;
  text-align: center;
}
.category-31 .header-page .photo-credit, .category-32 .header-page .photo-credit, .category-33 .header-page .photo-credit {
  bottom: 1em;
  color: rgba(255, 255, 255, 0.5);
  font-size: 1vw;
  position: absolute;
  right: 1em;
}
.category-31 .header-page .photo-credit a:link,
.category-31 .header-page .photo-credit a:visited, .category-32 .header-page .photo-credit a:link,
.category-32 .header-page .photo-credit a:visited, .category-33 .header-page .photo-credit a:link,
.category-33 .header-page .photo-credit a:visited {
  color: rgba(255, 255, 255, 0.5);
}
.category-31 .header-page time, .category-32 .header-page time, .category-33 .header-page time {
  display: block;
  font-size: 1.25rem;
  position: relative;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .category-31 .header-page time, .category-32 .header-page time, .category-33 .header-page time {
    font-size: 2vw;
  }
}
.category-31 .header-page time a:link,
.category-31 .header-page time a:visited, .category-32 .header-page time a:link,
.category-32 .header-page time a:visited, .category-33 .header-page time a:link,
.category-33 .header-page time a:visited {
  color: #d8cedf;
  text-decoration: none;
}
.category-31 .header-page:before, .category-32 .header-page:before, .category-33 .header-page:before {
  background-image: none;
}
.category-31 .header-page {
  background-image: url("img/headers/header-rfps.jpg");
}
.category-32 .header-page {
  background-image: url("img/headers/header-nyc-government.jpg");
}
.category-33 .header-page {
  background-image: url("img/headers/header-nys-government.jpg");
}
.post-type-archive-capalino_fony .header-page {
  margin-top: calc(-2rem - 1px);
}
.header-page .link-services {
  border-bottom: 4px solid rgba(255, 255, 255, 0.3);
  display: none;
  font-size: 0.8em;
  font-weight: bold;
  padding: 0 0.1em 0.5em 0;
  vertical-align: middle;
}
@media only screen and (min-width: 768px) {
  .header-page .link-services {
    bottom: auto;
    display: inline-block;
    left: 8vw;
    position: absolute;
    right: auto;
    top: 2vw;
  }
}
.header-page .link-services:link, .header-page .link-services:visited {
  color: #d8cedf;
  text-decoration: none;
  text-transform: uppercase;
}
.header-page .link-services:hover, .header-page .link-services:active {
  color: #ffffff;
  text-decoration: none;
}
.header-page .link-services:hover svg, .header-page .link-services:active svg {
  left: -8px;
  opacity: 1;
}
.header-page .link-services svg {
  left: 0;
  opacity: 0.5;
  position: relative;
  top: 3px;
  transition: left 200ms ease-out;
}
.header-page p {
  font-size: 4vw;
  font-weight: normal;
  margin: 0 5vw 3vw 0;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .header-page p {
    font-size: 1.8vw;
  }
}
.header-page p:last-child {
  margin: 0 10vw 0 0;
}
.header-page h1 + p {
  margin-top: 3vw;
}
.page-id-4 .header-page {
  background-image: url("img/headers/header-the-city.jpg");
}
.page-id-6 .header-page, .page-id-24198 .header-page, .page-id-24625 .header-page {
  background-image: url("img/headers/header-services.jpg");
}
.page-id-8 .header-page {
  background-image: url("img/headers/header-clients.jpg");
}
.page-id-10 .header-page {
  background-image: url("img/headers/header-ethics.jpg");
}
.page-id-12 .header-page {
  background-image: url("img/headers/header-contact.jpg");
}
.page-id-14 .header-page {
  background-image: url("img/headers/header-home.jpg");
  min-height: 50vw;
}
.page-id-14 .header-page h1 {
  font-size: 14vw;
}
@media only screen and (min-width: 768px) {
  .page-id-14 .header-page h1 {
    font-size: 8vw;
  }
}
@media only screen and (min-width: 960px) {
  .page-id-14 .header-page h1 {
    font-size: 6vw;
  }
}
.page-id-14 .header-page p .btn {
  font-size: 0.8em;
}
.page-id-46 .header-page {
  background-image: url("img/headers/header-government.jpg");
}
.page-id-48 .header-page {
  background-image: url("img/headers/header-zoning.jpg");
}
.page-id-50 .header-page {
  background-image: url("img/headers/header-community.jpg");
}
.page-id-52 .header-page {
  background-image: url("img/headers/header-entering-ny.jpg");
}
.page-id-54 .header-page {
  background-image: url("img/headers/header-csr.jpg");
}
.page-id-56 .header-page {
  background-image: url("img/headers/header-govt-contracts.jpg");
}
.page-id-7495 .header-page {
  background-image: url("img/headers/header-csr2.jpg");
}
.page-id-8462 .header-page {
  background-image: url("img/headers/header-agency.jpg");
}
.page-id-8691 .header-page {
  background-image: url("img/headers/header-housing.jpg");
}
.page-id-16526 .header-page {
  background-image: url("img/headers/header-energy.jpg");
}
.page-id-16984 .header-page {
  background-image: url("img/headers/header-real-estate2.jpg");
}
.page-id-17607 .header-page {
  background-image: url("img/headers/header-nonprofit.jpg");
}
.page-id-18992 .header-page {
  background-image: url("img/headers/header-partners.jpg");
}
.page-id-20317 .header-page {
  background-image: url("img/headers/header-business-strategy.jpg");
}
.page-id-20319 .header-page {
  background-image: url("img/headers/header-cannabis.jpg");
}
.page-id-23081 .header-page {
  background-image: url("img/headers/header-covid-19.jpg");
}
.page-id-23193 .header-page {
  background-image: url("img/headers/header-tax-incentives.jpg");
}
.page-id-23235 .header-page {
  background-image: url("img/headers/header-business-recovery.jpg");
}
.page-id-24100 .header-page {
  background-image: url("img/headers/header-post-pandemic.jpg");
}
.page-id-8693 .header-page {
  background-image: url("img/headers/header-mwbe.jpg");
}
.error404 .header-page {
  background-image: url("img/headers/header-404.jpg");
}
.error404 .header-page p {
  font-size: 1.8rem;
}
.post-type-archive-capalino_case_study .header-page {
  background-image: url("img/headers/header-case-studies.jpg");
}
.post-type-archive-capalino_service .header-page, .page-id-24198 .header-page, .page-id-24625 .header-page {
  background-image: url("img/headers/header-services.jpg");
}
.post-type-archive-capalino_service .header-page h1, .page-id-24198 .header-page h1, .page-id-24625 .header-page h1 {
  font-size: 7vw;
}
.post-type-archive-capalino_fony .header-page {
  background-image: url("img/headers/header-post-pandemic.jpg");
  margin: calc(-2em - 1px) 0 2em 0;
}
.post-type-archive-capalino_team_member .header-page {
  background-image: url("img/headers/header-team.jpg");
}
.header-page h1 {
  color: #ffffff;
  letter-spacing: -2px;
  line-height: 1;
  margin: 0;
}
.header-page h1 span {
  line-height: 1;
}
.header-page:before {
  background-color: #355772;
  background-image: url("img/supergraphic_wireframe_100.png");
  background-position: right top;
  background-repeat: no-repeat;
  background-size: contain;
  bottom: 0;
  content: "";
  left: 0;
  opacity: 0.3;
  position: absolute;
  right: 0;
  top: 0;
}

.header-post-inloop .author-block {
  align-items: center;
  display: flex;
  margin: 0 0 0.5rem 0;
}
.header-post-inloop .author-block:first-child {
  margin-right: 2em;
}
.header-post-inloop .author-block em {
  display: block;
}
.header-post-inloop .author-blocks-1,
.header-post-inloop .author-blocks-2 {
  display: flex;
}

.header-single {
  margin: 0 0 2em 0;
}
.header-single .author-block {
  align-items: center;
  display: flex;
  margin: 0 0 0.5rem 0;
}
.header-single .author-block:first-child {
  margin-right: 2rem;
}
.header-single .author-blocks {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.header-team-member {
  background-clip: border-box;
  background-color: #662d91;
  background-image: url("img/supergraphic_wireframe_20.png");
  background-position: 66% top;
  background-repeat: no-repeat;
  background-size: contain;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .header-team-member {
    align-items: center;
    box-shadow: 0 15px 20px rgba(0, 0, 0, 0.1);
    display: flex;
  }
}
.header-team-member div.contact {
  color: #72bc26;
  text-align: center;
}
@media only screen and (min-width: 480px) {
  .header-team-member div.contact {
    text-align: left;
  }
}
.header-team-member div.overview {
  background-color: #662d91;
  flex-shrink: 2;
  padding: 6vw 6vw 4vw 8vw;
  position: relative;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .header-team-member div.overview {
    background-color: transparent;
  }
}
.header-team-member h1 {
  color: #ffffff;
  margin: 0 0 0.25em 0;
  text-align: left;
}
@media only screen and (min-width: 768px) {
  .header-team-member h1 {
    font-size: 3vw;
  }
}
.header-team-member h2 {
  color: #a87fdd;
  font-size: 1.4em;
  font-style: italic;
  font-weight: normal;
  margin: 0 0 5vw 0;
  text-align: left;
}
@media only screen and (min-width: 768px) {
  .header-team-member h2 {
    margin: 0 0 2vw 0;
  }
}
.header-team-member .headshot {
  margin-bottom: -50vw;
}
@media only screen and (min-width: 768px) {
  .header-team-member .headshot {
    margin: 0;
    order: 2;
  }
  .header-team-member .headshot img {
    display: block;
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 768px) {
  .header-team-member .headshot {
    background-color: #ffffff;
  }
}
@media only screen and (min-width: 960px) {
  .header-team-member .headshot {
    flex-basis: 50vw;
    padding: 0 0 0 4vw;
  }
}
.header-team-member .intro {
  font-weight: bold;
  margin: 0;
  padding: 0;
  text-align: left;
}
@media only screen and (min-width: 960px) {
  .header-team-member .intro {
    font-size: 1.5vw;
  }
}
.header-team-member .link-team {
  border-bottom: 4px solid #7a3ec7;
  display: none;
  font-size: 0.8em;
  font-weight: bold;
  padding: 0 0 0.5em 0;
  vertical-align: middle;
}
@media only screen and (min-width: 960px) {
  .header-team-member .link-team {
    bottom: auto;
    display: inline-block;
    left: 8vw;
    position: absolute;
    right: auto;
    top: 3vw;
  }
}
.header-team-member .link-team:link, .header-team-member .link-team:visited {
  color: #a87fdd;
  text-decoration: none;
  text-transform: uppercase;
}
.header-team-member .link-team:hover, .header-team-member .link-team:active {
  color: #d8cedf;
  text-decoration: none;
}
.header-team-member .link-team:hover svg, .header-team-member .link-team:active svg {
  left: -8px;
  opacity: 1;
}
.header-team-member .link-team svg {
  left: 0;
  opacity: 0.5;
  position: relative;
  top: 3px;
  transition: left 200ms ease-out;
}
.header-team-member .tel {
  color: #72bc26;
  font-weight: bold;
  text-decoration: none;
}

/**
 * Navigation
 _________________________________________________________________________________________
 */
.nav-blog {
  margin: 0 4vw;
  padding-bottom: 2rem;
}
.nav-blog a {
  display: block;
  line-height: 50px;
  padding: 0 1rem;
  white-space: nowrap;
}
.nav-blog a:link, .nav-blog a:visited {
  color: #333333;
  text-decoration: none;
}
.nav-blog a:hover, .nav-blog a:active {
  color: #662d91;
}
.nav-blog li {
  font-size: 0.9rem;
  margin: 0;
}
.nav-blog li:first-child {
  font-size: 1.1rem;
  font-weight: bold;
}
.nav-blog li:first-child a,
.nav-blog li:first-child strong {
  color: #000000;
  padding: 0 1rem 0 0;
}
.nav-blog li:first-child strong::after {
  right: 1rem;
}
.nav-blog strong {
  color: #662d91;
  display: block;
  line-height: 50px;
  padding: 0 1rem;
  position: relative;
  white-space: nowrap;
}
.nav-blog strong::after {
  background-color: #662d91;
  bottom: 0;
  content: "";
  height: 4px;
  left: 0;
  position: absolute;
  right: 0;
}
.nav-blog ul {
  border: 1px solid #bbbbbb;
  border-left: 0;
  border-right: 0;
  display: flex;
  list-style: none;
  margin: 0;
  overflow-x: scroll;
  padding: 0;
  position: relative;
}
.nav-blog ul::-webkit-scrollbar {
  display: none;
}
@media only screen and (min-width: 768px) {
  .nav-blog ul {
    overflow-x: hidden;
  }
}

.nav-breadcrumb a {
  display: inline-block;
  line-height: 44px;
  padding: 0 0.5em;
}
.nav-breadcrumb a:link, .nav-breadcrumb a:visited {
  color: #888888;
}
.nav-breadcrumb .divider {
  color: #bbbbbb;
}
.nav-breadcrumb li {
  color: #888888;
  display: inline-block;
  font-size: 0.9em;
  margin: 0;
  padding: 0;
}
.nav-breadcrumb ul {
  list-style: none;
  margin: 0 4vw;
  padding: 0;
}

@media only screen and (min-width: 480px) {
  .nav-footer {
    display: inline-block;
    width: 49%;
  }
}
@media only screen and (min-width: 768px) {
  .nav-footer {
    display: block;
    border-left: 4px solid #f6f6f6;
    width: auto;
  }
}
.nav-footer a {
  line-height: 24px;
}
.nav-footer a:link,
.nav-footer a:visited {
  color: #888888;
  -webkit-text-decoration-color: #f6f6f6;
          text-decoration-color: #f6f6f6;
}
.nav-footer a:hover,
.nav-footer a:active {
  color: #662d91;
}
.nav-footer li {
  font-size: 0.8rem;
  margin: 0 0 0.25em 0;
}
.nav-footer ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
@media only screen and (min-width: 768px) {
  .nav-footer ul {
    padding: 0 1.5em;
  }
}
.nav-footer ul ul {
  padding-top: 0.25em;
}

.nav-pagination {
  display: flex;
  justify-content: space-between;
  line-height: 50px;
}
@media only screen and (min-width: 768px) {
  .nav-pagination {
    justify-content: space-evenly;
  }
}
.section-blog .nav-pagination {
  flex-basis: 100%;
  margin-top: 2em;
}
.nav-pagination a {
  border-radius: 25px;
  display: inline-block;
  line-height: 50px;
  padding: 0 2.5vw;
  text-decoration: none;
}
@media only screen and (min-width: 960px) {
  .nav-pagination a {
    padding: 0 1vw;
  }
}
.nav-pagination a:link,
.nav-pagination a:visited {
  color: #662d91;
}
.nav-pagination a:hover,
.nav-pagination a:active {
  background-color: #d8cedf;
  text-decoration: none;
}
.nav-pagination .current {
  border-bottom: 3px solid #72bc26;
  color: #72bc26;
  display: none;
  font-weight: bold;
  line-height: 50px;
  padding: 0 1em;
}
@media only screen and (min-width: 768px) {
  .nav-pagination .current {
    display: inline-block;
  }
}
.nav-pagination .inactive {
  display: none;
}
@media only screen and (min-width: 768px) {
  .nav-pagination .inactive {
    display: inline-block;
  }
}
.nav-pagination .pagecount {
  color: #aaaaaa;
  display: inline-block;
  flex-grow: 1;
  line-height: 50px;
}
.nav-pagination .first,
.nav-pagination .last {
  display: none;
}
@media only screen and (min-width: 960px) {
  .nav-pagination .first,
.nav-pagination .last {
    display: inline-block;
  }
}
@media only screen and (min-width: 768px) {
  .nav_primary {
    margin-right: 42px;
  }
}

html.js .nav_primary #menu-primary-navigation {
  height: 0;
  left: 0;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 80px;
  transition: all 200mss ease-out;
}
html.js .nav_primary #menu-primary-navigation.is-active {
  height: auto;
  opacity: 1;
  overflow: visible;
}
@media only screen and (min-width: 768px) {
  html.js .nav_primary #menu-primary-navigation {
    display: flex;
    bottom: auto;
    height: auto;
    left: auto;
    opacity: 1;
    overflow: visible;
    position: relative;
    right: auto;
    top: 0;
    transition: none;
  }
}

#menu-primary-navigation {
  background: #662d91;
  box-shadow: 0 3px 5px;
  color: rgba(0, 0, 0, 0.6);
  left: 0;
  list-style-type: none;
  margin: 0 0 80px 0;
  padding: 0;
  position: relative;
  top: 80px;
  right: 0;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation {
    background-color: transparent;
    box-shadow: none;
    left: 50%;
    margin: 0;
    position: absolute;
  }
}
#menu-primary-navigation::before {
  border-bottom: 14px solid #662d91;
  border-left: 14px solid transparent;
  border-right: 14px solid transparent;
  content: "";
  height: 0;
  position: absolute;
  right: 26px;
  top: -12px;
  width: 0;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation::before {
    border: 0;
    display: none;
  }
}
#menu-primary-navigation a {
  display: block;
  line-height: 44px;
  padding: 0 1.2em;
  text-decoration: none;
}
#menu-primary-navigation a:link, #menu-primary-navigation a:visited {
  color: #ffffff;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation a:link, #menu-primary-navigation a:visited {
    color: #662d91;
  }
}
#menu-primary-navigation a:hover, #menu-primary-navigation a:active {
  background-color: #7a3ec7;
  color: #ffffff;
  text-decoration: none;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation a:hover, #menu-primary-navigation a:active {
    background-color: transparent;
    color: #662d91;
  }
}
#menu-primary-navigation a:active {
  background-color: #7a3ec7;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation a:active {
    background-color: transparent;
  }
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation a {
    padding: 0 1.6vw;
  }
}
@media only screen and (min-width: 960px) {
  #menu-primary-navigation a {
    padding: 0 1.9vw;
  }
}
#menu-primary-navigation > li {
  border-top: 1px solid #7a3ec7;
  font-size: 1.1em;
  font-weight: bold;
  margin: 0;
  padding: 0;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li {
    border-top: 0;
    cursor: pointer;
    font-size: 0.8rem;
    display: inline-block;
    position: relative;
    vertical-align: top;
  }
  #menu-primary-navigation > li:hover, #menu-primary-navigation > li:active {
    cursor: pointer;
  }
  #menu-primary-navigation > li:hover ul, #menu-primary-navigation > li:active ul {
    opacity: 1;
    -webkit-transform: rotateX(0) scale(1) translateX(0);
            transform: rotateX(0) scale(1) translateX(0);
  }
  #menu-primary-navigation > li:first-child {
    display: inline-block;
  }
  #menu-primary-navigation > li.current-menu-item > a {
    overflow: hidden;
  }
}
@media only screen and (min-width: 768px) and (min-width: 768px) {
  #menu-primary-navigation > li.current-menu-item > a::after {
    background-color: #d8cedf;
    border-radius: 2px;
    bottom: 1.5em;
    content: "";
    display: block;
    height: 4px;
    left: 20%;
    position: absolute;
    right: 20%;
    transition: all 0.2s ease-out;
    width: 60%;
  }
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li.menu-item-has-children > a {
    background-image: url("img/icons/icon_dropdown.png");
    background-size: 8px 5px;
    background-position: 98% 50%;
    background-repeat: no-repeat;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1200px) {
  #menu-primary-navigation > li.menu-item-has-children > a {
    background-position: 90% 50%;
  }
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li a {
    line-height: 80px;
  }
}
@media only screen and (min-width: 960px) {
  #menu-primary-navigation > li {
    font-size: 0.9rem;
  }
}
#menu-primary-navigation > li ul {
  background-color: rgba(0, 0, 0, 0.1);
  margin: 0 0 0.25em 0;
  padding: 0.25em;
  list-style-type: none;
  margin: 0;
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li ul {
    background-color: #662d91;
    border: 1px solid #662d91;
    border-radius: 24px;
    box-shadow: 0 0.15em 0.25em rgba(0, 0, 0, 0.3);
    cursor: pointer;
    left: 0;
    min-width: 150px;
    opacity: 0.3;
    padding: 8px 4px;
    position: absolute;
    top: calc(100% - 0.5rem);
    -webkit-transform: rotateX(-90deg) translateX(0);
            transform: rotateX(-90deg) translateX(0);
    -webkit-transform-origin: top left;
            transform-origin: top left;
    transition: all 120ms ease-out;
  }
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li ul::before {
    border-bottom: 12px solid #662d91;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    content: "";
    height: 0;
    position: absolute;
    left: 32px;
    top: -12px;
    width: 0;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1200px) {
  #menu-primary-navigation > li ul::before {
    left: 40px;
  }
}
#menu-primary-navigation > li ul a {
  border-radius: 20px;
  cursor: pointer;
  line-height: 40px;
  padding-left: 2em;
}
#menu-primary-navigation > li ul a::before {
  color: #d8cedf;
  content: "• ";
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li ul a::before {
    content: none;
  }
}
@media only screen and (min-width: 768px) {
  #menu-primary-navigation > li ul a {
    color: #ffffff;
    padding: 0 1.2em;
    transition: all 200ms ease-out;
  }
  #menu-primary-navigation > li ul a:link, #menu-primary-navigation > li ul a:visited {
    color: #ffffff;
  }
  #menu-primary-navigation > li ul a:hover {
    color: #ffffff;
    background-color: #7a3ec7;
  }
  #menu-primary-navigation > li ul a:active {
    background-color: #a87fdd;
  }
}
#menu-primary-navigation > li ul li {
  display: block;
  font-size: 0.9em;
  margin: 0;
  padding: 0 0.25em;
  white-space: nowrap;
}

.nav-tabs {
  margin: 2em 4vw 1em 4vw;
  text-align: center;
}
@media only screen and (min-width: 960px) {
  .nav-tabs {
    margin: 2em 16vw 1em 16vw;
  }
}
@media only screen and (min-width: 1200px) {
  .nav-tabs {
    margin: 2em auto 1em auto;
    max-width: 800px;
  }
}
.nav-tabs a {
  display: block;
  line-height: 50px;
  padding: 0 4vw;
  text-decoration: none;
}
@media only screen and (min-width: 480px) {
  .nav-tabs a {
    padding: 0 2vw;
  }
}
.nav-tabs a:link, .nav-tabs a:visited {
  background-color: #b9a5c8;
  color: #ffffff;
}
.nav-tabs a:hover, .nav-tabs a:active {
  background-color: rgba(102, 45, 145, 0.5);
  color: #ffffff;
}
.nav-tabs a:active {
  background-color: rgba(102, 45, 145, 0.8);
}
.nav-tabs li {
  border-right: 1px solid rgba(255, 255, 255, 0.2);
  display: inline-block;
  flex-grow: 1;
  font-size: 1em;
  font-weight: bold;
  margin: 0;
  padding: 0;
}
.nav-tabs li:first-child a, .nav-tabs li:first-child strong {
  border-radius: 25px 0 0 25px;
}
.nav-tabs li:last-child {
  border-right: 0;
}
.nav-tabs li:last-child a,
.nav-tabs li:last-child strong {
  border-radius: 0 25px 25px 0;
}
.nav-tabs li.current-menu-item strong {
  color: #ffffff;
  background-color: #662d91;
  display: block;
  line-height: 50px;
  padding: 0 4vw;
  text-decoration: none;
}
@media only screen and (min-width: 480px) {
  .nav-tabs li.current-menu-item strong {
    padding: 0 2vw;
  }
}
.nav-tabs ul {
  background-color: #d8cedf;
  border-radius: 25px;
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-team {
  margin: 0 0 1em 0;
  text-align: center;
}
.nav-team a {
  display: block;
  line-height: 44px;
  padding: 0 1vw;
}
.nav-team h3 {
  margin-top: 1em;
}
.nav-team li {
  display: inline-block;
}
.nav-team strong {
  background-color: #cccccc;
  color: #ffffff;
  display: inline-block;
  border-radius: 22px;
  line-height: 44px;
  padding: 0 2vw;
}
.nav-team ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/**
 * Section
 _________________________________________________________________________________________
 */
section {
  z-index: 1;
}

section.section-apply {
  background-color: #662d91;
  color: #ffffff;
  padding: 4vw 8vw;
}
@media only screen and (min-width: 960px) {
  section.section-apply {
    padding: 4vw 16vw;
  }
}
@media only screen and (min-width: 1200px) {
  section.section-apply {
    padding: 5vw 20vw;
  }
}
section.section-apply h4 {
  color: #ffffff;
}
section.section-apply h4 a:link,
section.section-apply h4 a:visited {
  color: #d8cedf;
}
section.section-apply h4 a:hover,
section.section-apply h4 a:active {
  color: #ffffff;
}

section.section-approach {
  display: flex;
  flex-wrap: wrap;
  padding: 8vw;
}

@media only screen and (min-width: 768px) {
  .section-approach-stage {
    flex-basis: 33%;
    padding: 0 4vw 0 0;
  }
  .section-approach-stage:last-child {
    padding: 0;
  }
}

.section-blm {
  background-color: #f6f6f6;
  background-image: url("img/blm.jpg");
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  color: #ffffff;
  padding: 8vw 8vw 8vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .section-blm {
    padding: 8vw 40vw 8vw 8vw;
  }
}
.section-blm:before {
  background-color: black;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  right: 0;
  opacity: 0.6;
  position: absolute;
  top: 0;
}
.section-blm .btn, .section-blm h2, .section-blm p {
  position: relative;
}

.section-blockquote {
  background-color: #f6f6f6;
  margin: 0;
  padding: 4vw 8vw 8vw 8vw;
}

@media only screen and (min-width: 768px) {
  .section-blog {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 4vw 4vw 4vw;
    max-width: 1300px;
  }
}
@media only screen and (min-width: 1400px) {
  .section-blog {
    margin: 4vw auto;
  }
}

@media only screen and (min-width: 768px) {
  .section-fony-past {
    align-items: flex-start;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}

@media only screen and (min-width: 768px) {
  .section-fony-upcoming {
    align-items: flex-start;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}

.section-blog-intro {
  display: flex;
  flex-wrap: wrap;
  padding: 2vw 4vw;
}
@media only screen and (min-width: 768px) {
  .section-blog-intro {
    flex-wrap: nowrap;
  }
}

section.bg-stairs {
  background-blend-mode: overlay;
  background-image: url("img/stairs.jpg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100%;
}
@media only screen and (min-width: 768px) {
  section.bg-stairs {
    background-position: 60vw 50%;
    background-size: cover;
  }
}

section.bg-subway {
  background-image: url("img/subway.jpg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100%;
}
@media only screen and (min-width: 768px) {
  section.bg-subway {
    background-position: 60vw 50%;
    background-size: cover;
  }
}

section.bg-wireframe {
  background-image: url("img/supergraphic_wireframe.png");
  background-position: top right;
  background-repeat: no-repeat;
  background-size: contain;
}

@media only screen and (min-width: 480px) {
  section.capalino_team {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 4vw auto 0 auto;
  }
}

section.section-case-studies {
  padding: 20vw 8vw 2vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  section.section-case-studies {
    display: flex;
    padding: 4vw 8vw;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
@media only screen and (min-width: 1200px) {
  section.section-case-studies {
    padding: 4vw 8vw 4vw 8vw;
  }
}
@media only screen and (min-width: 768px) {
  .home section.section-case-studies, .single-capalino_service section.section-case-studies {
    justify-content: space-between;
    padding: 8vw 8vw 4vw 8vw;
  }
}
.page-id-8 section.section-case-studies {
  padding: 8vw 8vw 4vw 8vw;
}
section.section-case-studies article {
  flex-basis: 47%;
  margin-right: 3%;
}
@media only screen and (min-width: 1200px) {
  section.section-case-studies article {
    flex-basis: 30%;
    margin-right: 3.3333%;
  }
  .single-capalino_service section.section-case-studies article {
    flex-basis: 45%;
    margin: 0 2.5%;
  }
}
.post-type-archive-capalino_case_study section.section-case-studies h2 {
  border-top: 4px solid #f6f6f6;
  flex-basis: 100%;
  padding-top: 2vw;
}
.post-type-archive-capalino_case_study section.section-case-studies h2.heading-blue {
  border-top: 4px solid #dbe4ef;
}
.post-type-archive-capalino_case_study section.section-case-studies h2.heading-green {
  border-top: 4px solid #d0e2bd;
}
.post-type-archive-capalino_case_study section.section-case-studies h2.heading-orange {
  border-top: 4px solid #fbdcbb;
}
.post-type-archive-capalino_case_study section.section-case-studies h2.heading-purple {
  border-top: 4px solid #d8cedf;
}

.section-covid {
  background-color: #f6f6f6;
  background-image: url("img/covid-19.jpg");
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  color: #ffffff;
  padding: 8vw 8vw 8vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .section-covid {
    padding: 8vw 40vw 8vw 8vw;
  }
}
.section-covid:before {
  background-color: darkred;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  right: 0;
  opacity: 0.8;
  position: absolute;
  top: 0;
}
.section-covid .btn, .section-covid h2, .section-covid p {
  position: relative;
}

.section-feature {
  background-blend-mode: overlay;
  background-color: #555;
  background-image: url("img/blm.jpg");
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  color: #ffffff;
  padding: 8vw 8vw 8vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .section-feature {
    padding: 8vw 40vw 8vw 8vw;
  }
}
.section-feature:before {
  background-color: black;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  right: 0;
  opacity: 0.4;
  position: absolute;
  top: 0;
}
.section-feature .btn, .section-feature h2, .section-feature p {
  position: relative;
}

.section-feature-black:before {
  background-color: #000;
}

.section-feature-blue:before {
  background-color: #243a4c;
}

.section-feature-purple:before {
  background-color: #36154f;
}

.section-feature-gray:before {
  background-color: #555;
}

.section-feature-green:before {
  background-color: #145a15;
}

section.section-from-blog {
  background-color: #f6f6f6;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 15vw 4vw 4vw 4vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  section.section-from-blog {
    padding: 10vw 4vw 4vw 4vw;
  }
}

section.gray {
  background-color: #888888;
  color: #ffffff;
}

section.green {
  background-color: #46895a;
  background-image: url("img/supergraphic_wireframe.png");
  background-position: top right;
  background-repeat: no-repeat;
  background-size: contain;
  color: #ffffff;
  font-size: 4vw;
  font-weight: bold;
  overflow: hidden;
  padding: 12vw 8vw;
  position: relative;
}
section.green p {
  font-size: 2.75rem;
  line-height: 1.2;
  margin-bottom: 0;
}

section.section-industries {
  background-color: #662d91;
  display: flex;
  flex-wrap: wrap;
}
section.section-industries h2 {
  background-color: #481e68;
  color: #a87fdd;
  flex-basis: 100%;
  margin: 0;
  padding: 2vw;
  text-align: center;
}

section.section-logos {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  padding: 20vw 8vw 8vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  section.section-logos {
    padding: 12vw 8vw 6vw 8vw;
  }
}

section.section-more {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 4vw;
  position: relative;
}

section.orange {
  background-color: #ff8400;
  color: #ffffff;
}

section.section-other-case-studies {
  padding: 15vw 4vw 4vw 4vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  section.section-other-case-studies {
    display: flex;
    padding: 10vw 4vw 4vw 4vw;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
section.section-other-case-studies article {
  flex-basis: 30%;
}

section.section-partners {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  padding: 0 4vw 4vw 4vw;
}
section.section-partners a {
  display: block;
  text-align: center;
}
section.section-partners div {
  padding: 2vw 4vw;
}
@media only screen and (min-width: 768px) {
  section.section-partners div {
    flex-basis: 50%;
  }
}
section.section-partners p {
  font-size: 0.9em;
  margin: 0;
}
section.section-partners strong {
  background-image: url("img/supergraphic_bullet.png");
  background-position: right 2px;
  background-repeat: no-repeat;
  background-size: 20px 15px;
  color: #ff8400;
  display: inline-block;
  padding: 0 24px 0 0;
  text-transform: uppercase;
}

section.section-service-groups {
  display: flex;
  flex-wrap: wrap;
}
section.section-service-groups .heading-service-groups {
  flex-basis: 100%;
  padding: 2vw 4vw;
}

section.section-services {
  background-color: #f6f6f6;
  background-image: url("img/supergraphic_wireframe_100.png");
  background-position: right top;
  background-repeat: no-repeat;
  background-size: contain;
  display: flex;
  flex-wrap: wrap;
  padding: 4vw 8vw 2vw 8vw;
}
section.section-services .heading-services {
  flex-basis: 100%;
}

section.split {
  background-color: #662d91;
  color: #72bc26;
  font-size: 1.5em;
  font-weight: bold;
  overflow: hidden;
  padding: 70vw 8vw 2vw 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  section.split {
    font-size: 2em;
    padding: 3em 50vw 3em 8vw;
  }
}
section.split .hero {
  display: block;
  height: auto;
  left: 0;
  margin: 0;
  opacity: 0.5;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  section.split .hero {
    bottom: 0;
    left: 60vw;
    right: auto;
    width: 100vw;
  }
}
section.split .highlight {
  color: #ffffff;
}
section.split p {
  font-size: 1.75rem;
  line-height: 1.4;
  margin-bottom: 1em;
}
section.split p span {
  line-height: 1.2;
}

section.section-subscribe {
  background-color: #f6f6f6;
  padding: 4vw 8vw;
}
@media only screen and (min-width: 960px) {
  section.section-subscribe {
    padding: 4vw 16vw;
  }
}
@media only screen and (min-width: 1200px) {
  section.section-subscribe {
    padding: 5vw 20vw;
  }
}

section.section-subservices {
  background-color: #f6f6f6;
  position: relative;
  padding: 12vw 8vw 2vw 8vw;
}
@media only screen and (min-width: 768px) {
  section.section-subservices {
    padding: 8vw 8vw 2vw 8vw;
  }
}

.section-team-cta {
  background-color: #f6f6f6;
  color: #888888;
  overflow: hidden;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .section-team-cta {
    align-items: center;
    display: flex;
  }
  .child-count-2 .section-team-cta, .child-count-4 .section-team-cta {
    align-items: flex-start;
    flex-basis: 50%;
  }
}
.section-team-cta .call {
  display: inline-block;
}
.section-team-cta .tel:link,
.section-team-cta .tel:visited {
  color: #888888;
  font-weight: bold;
  text-decoration: none;
}
.section-team-cta .contact .btn {
  margin: 0 0.5em 0.5em 0;
}
.section-team-cta div.overview {
  background-color: #f6f6f6;
  flex-shrink: 2;
  padding: 8%;
  position: relative;
}
.section-team-ctas .section-team-cta div.overview {
  padding: 5%;
}
@media only screen and (min-width: 768px) {
  .section-team-cta div.overview {
    flex-basis: 75%;
  }
  .child-count-3 .section-team-cta div.overview, .child-count-4 .section-team-cta div.overview,
.section-team-cta div.overview .child-count-5 {
    flex-basis: 85%;
  }
}
.section-team-cta h1 {
  color: #ffffff;
  margin: 0 0 0.25em 0;
}
@media only screen and (min-width: 768px) {
  .section-team-cta h1 {
    font-size: 3vw;
  }
}
.section-team-cta h3 a:link,
.section-team-cta h3 a:visited {
  color: #ff8400;
  text-decoration: none;
}
.section-team-cta h3 a:hover,
.section-team-cta h3 a:active {
  color: #662d91;
}
.section-team-cta .headshot {
  margin-bottom: -50vw;
}
@media only screen and (min-width: 768px) {
  .section-team-cta .headshot {
    flex-basis: 25%;
    margin: 0 0 0 8%;
  }
  .child-count-3 .section-team-cta .headshot, .child-count-4 .section-team-cta .headshot, .child-count-5 .section-team-cta .headshot {
    flex-basis: 15%;
  }
  .section-team-ctas .section-team-cta .headshot {
    margin: 5% 0 0 5%;
  }
}
.section-team-cta .headshot a img {
  transition: border 0.2s;
}
.section-team-cta .headshot a:hover img,
.section-team-cta .headshot a:active img {
  border: 1px solid #7a3ec7;
}
.section-team-cta .headshot img {
  display: block;
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .section-team-cta .headshot img {
    border: 1px solid #cccccc;
    border-radius: 1vw;
    max-width: 290px;
  }
}
.section-team-cta .intro {
  font-weight: bold;
  margin: 0;
  padding: 0;
}
@media only screen and (min-width: 960px) {
  .section-team-cta .intro {
    font-size: 1.5vw;
  }
}
.section-team-cta .link-team {
  border-bottom: 4px solid #7a3ec7;
  display: none;
  font-size: 0.8em;
  font-weight: bold;
  padding: 0 0 0.5em 0;
  vertical-align: middle;
}
@media only screen and (min-width: 768px) {
  .section-team-cta .link-team {
    bottom: auto;
    display: inline-block;
    left: 8vw;
    position: absolute;
    right: auto;
    top: 4vw;
  }
}
.section-team-cta .link-team:link, .section-team-cta .link-team:visited {
  color: #a87fdd;
  text-decoration: none;
  text-transform: uppercase;
}
.section-team-cta .link-team:hover, .section-team-cta .link-team:active {
  color: #d8cedf;
  text-decoration: none;
}
.section-team-cta .link-team:hover svg, .section-team-cta .link-team:active svg {
  left: -8px;
  opacity: 1;
}
.section-team-cta .link-team svg {
  left: 0;
  opacity: 0.5;
  position: relative;
  top: 3px;
  transition: left 200ms ease-out;
}
.section-team-cta p {
  color: #888888;
}

.section-team-ctas {
  background-color: #f6f6f6;
  padding: 3% 0;
}
@media only screen and (min-width: 960px) {
  .section-team-ctas {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
  }
}
.section-team-ctas p {
  font-size: 0.9rem;
}

/*
.group-leaders.leader-count-2,
.group-leaders.leader-count-4,
.section-authors.author-count-2,
.section-authors.author-count-4 {
	.section-author,
	.section-group-leader {
		@include breakpoint-lg {
			flex-basis:50%;
		}
	}
}
.group-leaders.leader-count-3,
.seciton-authors.author-count-3 {
	.section-author,
	.section-group-leader {
		@include breakpoint-lg {
			flex-basis:33.3333%;
		}
	}
} */
section.section-team-posts {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-evenly;
  padding: 4vw;
}

section.section-thought-leadership {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media only screen and (min-width: 768px) {
  section.section-thought-leadership article {
    flex-basis: 30%;
  }
}
section.section-thought-leadership h2 {
  flex-basis: 100%;
}
section.section-thought-leadership img {
  height: auto;
  width: 100%;
}

section.white {
  background-color: #f6f6f6;
  color: #72bc26;
  font-size: 1.5em;
  font-weight: bold;
  overflow: hidden;
  padding: 8vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  section.white {
    font-size: 2.6vw;
  }
}
section.white p {
  background-image: url("img/supergraphic_bullet.png");
  background-position: 0 5px;
  background-repeat: no-repeat;
  background-size: 30px 22px;
  font-size: 2rem;
  line-height: 1.4;
  margin-bottom: 0;
  text-indent: 38px;
}

/**
 * Article
 _________________________________________________________________________________________
 */
.article-case-study a,
.article-other-case-study a {
  display: block;
}
.article-case-study h3,
.article-other-case-study h3 {
  background-image: url("img/supergraphic_check.png");
  background-repeat: no-repeat;
  background-size: 14px 20px;
  background-position: 0 5px;
  color: #0066b3;
  margin: 0 0 1.5em 0;
  text-indent: 20px;
}

.article-industry {
  background-blend-mode: multiply;
  background-color: #7a3ec7;
  color: #ffffff;
  flex-basis: 100%;
  font-size: 1.3rem;
  font-weight: bold;
  padding: 6vw 1vw 5vw 1vw;
  text-align: center;
  text-shadow: 0 0 5px black;
}
@media only screen and (min-width: 768px) {
  .article-industry {
    flex-basis: 33.3333%;
  }
}
@media only screen and (min-width: 960px) {
  .article-industry {
    flex-basis: 25%;
  }
}
.article-industry > a {
  display: block;
}
.article-industry a:link,
.article-industry a:visited {
  color: #ffffff;
  -webkit-text-decoration-color: #a87fdd;
          text-decoration-color: #a87fdd;
}
.article-industry a:hover,
.article-industry a:active {
  -webkit-text-decoration-color: #d8cedf;
          text-decoration-color: #d8cedf;
}
.article-industry > span {
  display: block;
}
.article-industry.article-industry-cannabis {
  background-image: url("img/industry-bg-cannabis.jpg");
}
.article-industry.article-industry-energy {
  background-image: url("img/industry-bg-energy.jpg");
}
.article-industry.article-industry-entertainment {
  background-image: url("img/industry-bg-entertainment.jpg");
}
.article-industry.article-industry-health {
  background-image: url("img/industry-bg-health.jpg");
}
.article-industry.article-industry-public {
  background-image: url("img/industry-bg-public.jpg");
}
.article-industry.article-industry-realestate {
  background-image: url("img/industry-bg-realestate.jpg");
}
.article-industry.article-industry-tech {
  background-image: url("img/industry-bg-tech.jpg");
}

.article-latest {
  flex-basis: 100%;
  flex-grow: 1;
}
@media only screen and (min-width: 768px) {
  .article-latest {
    flex-basis: auto;
  }
}

.article-post {
  margin: 0 0 1em 0;
}
@media only screen and (min-width: 768px) {
  .section-blog .article-post {
    flex-basis: 47.5%;
  }
}
@media only screen and (min-width: 960px) {
  .section-blog .article-post {
    flex-basis: 30%;
  }
}
@media only screen and (min-width: 1400px) {
  .section-blog .article-post {
    flex-basis: 22.5%;
  }
}
@media only screen and (min-width: 768px) {
  .section-fony-past .article-post, .section-fony-upcoming .article-post {
    flex-basis: 47.5%;
  }
  .section-fony-past .article-post:not(:nth-child(2n+1)), .section-fony-upcoming .article-post:not(:nth-child(2n+1)) {
    margin-left: 5%;
  }
}
@media only screen and (min-width: 1200px) {
  .section-fony-past .article-post, .section-fony-upcoming .article-post {
    flex-basis: 30%;
  }
  .section-fony-past .article-post:not(:nth-child(2n+1)), .section-fony-upcoming .article-post:not(:nth-child(2n+1)) {
    margin-left: 0;
  }
  .section-fony-past .article-post:not(:nth-child(3n+1)), .section-fony-upcoming .article-post:not(:nth-child(3n+1)) {
    margin-left: 5%;
  }
}
@media only screen and (min-width: 768px) {
  .section-from-blog .article-post, .section-more .article-post, .section-team-posts .article-post {
    flex-basis: 30%;
  }
}
.article-post.article-sticky {
  background-color: #662d91;
  margin: calc(-2rem - 1px) -4vw 4vw -4vw;
  position: relative;
}
.article-post.article-sticky + .article-sticky {
  margin-top: -4vw;
}
@media only screen and (min-width: 768px) {
  .article-post.article-sticky {
    flex-basis: 100vw;
  }
}
.article-post.article-sticky a img {
  text-decoration: none;
}
.article-post.article-sticky a:link,
.article-post.article-sticky a:visited {
  color: rgba(255, 255, 255, 0.6);
  -webkit-text-decoration-color: rgba(255, 255, 255, 0.3);
          text-decoration-color: rgba(255, 255, 255, 0.3);
}
.article-post.article-sticky a:hover,
.article-post.article-sticky a:active {
  color: rgba(255, 255, 255, 0.6);
  -webkit-text-decoration-color: rgba(255, 255, 255, 0.6);
          text-decoration-color: rgba(255, 255, 255, 0.6);
}
.article-post.article-sticky header {
  background-color: #662d91;
  color: #ffffff;
  opacity: 0.8;
  padding: 4vw;
}
@media only screen and (min-width: 768px) {
  .article-post.article-sticky header {
    bottom: 0;
    position: absolute;
    left: 0;
    right: 0;
  }
}

.article-search-result {
  margin-bottom: 1.5em;
}

.article-service {
  margin: 0 0 2vw 0;
}
@media only screen and (min-width: 768px) {
  .article-service {
    flex-basis: 50%;
    padding-right: 4vw;
  }
}
@media only screen and (min-width: 1200px) {
  .article-service {
    flex-basis: 33.3333%;
  }
}
.article-service p {
  color: #888888;
}

.article-service-group {
  padding: 2vw 4vw;
}
.article-service-group:nth-child(2) {
  border-top: 14px solid #0066b3;
}
.article-service-group:nth-child(2) a:link {
  color: #0066b3;
  -webkit-text-decoration-color: #94b6d8;
          text-decoration-color: #94b6d8;
}
.article-service-group:nth-child(2) a:visited {
  color: #00a5df;
  -webkit-text-decoration-color: #dbe4ef;
          text-decoration-color: #dbe4ef;
}
.article-service-group:nth-child(2) a:hover,
.article-service-group:nth-child(2) a:active {
  -webkit-text-decoration-color: #0066b3;
          text-decoration-color: #0066b3;
}
.article-service-group:nth-child(3) {
  border-top: 14px solid #ff8400;
}
.article-service-group:nth-child(3) a:link {
  color: #ff8400;
  -webkit-text-decoration-color: #ffc885;
          text-decoration-color: #ffc885;
}
.article-service-group:nth-child(3) a:visited {
  color: #ff9f33;
  -webkit-text-decoration-color: #fbdcbb;
          text-decoration-color: #fbdcbb;
}
.article-service-group:nth-child(3) a:hover,
.article-service-group:nth-child(3) a:active {
  -webkit-text-decoration-color: #ff8400;
          text-decoration-color: #ff8400;
}
.article-service-group:nth-child(4) {
  border-top: 14px solid #46895a;
}
.article-service-group:nth-child(4) a:link {
  color: #46895a;
  -webkit-text-decoration-color: #a2cf73;
          text-decoration-color: #a2cf73;
}
.article-service-group:nth-child(4) a:visited {
  color: #72bc26;
  -webkit-text-decoration-color: #d0e2bd;
          text-decoration-color: #d0e2bd;
}
.article-service-group:nth-child(4) a:hover,
.article-service-group:nth-child(4) a:active {
  -webkit-text-decoration-color: #46895a;
          text-decoration-color: #46895a;
}
@media only screen and (min-width: 768px) {
  .article-service-group {
    flex-basis: 50%;
  }
  .article-service-group:nth-child(4) {
    flex-basis: 100%;
  }
}
@media only screen and (min-width: 1200px) {
  .article-service-group {
    flex-basis: 33.3333%;
    padding: 2vw;
  }
  .article-service-group:nth-child(4) {
    flex-basis: 33.3333%;
  }
}
.article-service-group p {
  color: #888888;
  font-size: 1rem;
}

article.team_member {
  border-bottom: 1px solid #ddd;
  overflow: hidden;
  position: relative;
}
@media only screen and (min-width: 480px) {
  article.team_member {
    border: 1px solid #ddd;
    border-radius: 20px;
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.1);
    flex-basis: 40%;
    margin: 0 2vw 4vw 2vw;
    transition: all 0.2s ease-out;
  }
}
@media only screen and (min-width: 768px) {
  article.team_member {
    flex-basis: 29%;
  }
}
@media only screen and (min-width: 960px) {
  article.team_member {
    flex-basis: 21%;
    max-width: 250px;
  }
}
@media only screen and (min-width: 480px) {
  article.team_member:hover {
    border: 1px solid #aaa;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2);
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}
article.team_member a {
  display: block;
  min-height: 64px;
  padding: 4vw;
}
@media only screen and (min-width: 480px) {
  article.team_member a {
    padding: 0;
  }
}
article.team_member a:link,
article.team_member a:visited,
article.team_member a:hover,
article.team_member a:active {
  text-decoration: none;
}
article.team_member h2 {
  font-size: 1.1em;
  margin: 0 0 0.25em 0;
  padding: 0;
}
@media only screen and (min-width: 480px) {
  article.team_member h2 {
    font-size: 1em;
  }
}
article.team_member h3 {
  color: #777;
  font-size: 0.8em;
  font-style: italic;
  font-weight: normal;
  line-height: 1.2;
  margin: 0;
  padding: 0;
}
@media only screen and (min-width: 480px) {
  article.team_member h3 {
    color: #444;
  }
}
article.team_member hgroup {
  width: 80%;
}
@media only screen and (min-width: 480px) {
  article.team_member hgroup {
    background-color: rgba(250, 250, 250, 0.92);
    border: 1px solid #ddd;
    border-radius: 0 0 20px 20px;
    bottom: 0;
    left: 0;
    padding: 0.6em 5%;
    position: absolute;
    right: 0;
    width: 100%;
  }
}
article.team_member img.headshot {
  display: block;
  margin: 0;
  position: absolute;
  right: 0;
  top: 0;
  width: 20%;
}
@media only screen and (min-width: 480px) {
  article.team_member img.headshot {
    border-radius: 20px;
    position: relative;
    width: 100%;
  }
}

/**
 * Button
 _________________________________________________________________________________________
 */
.btn {
  background-color: transparent;
  border: 1px solid #72bc26;
  border-radius: 22px;
  color: #72bc26;
  cursor: pointer;
  display: inline-block;
  font-weight: bold;
  line-height: 44px;
  margin: 0 1em 1em 0;
  padding: 0 1.5em;
  text-decoration: none;
  transition: all 200ms ease-out;
}
.btn:link, .btn:visited {
  color: #72bc26;
}
.btn:hover, .btn:active {
  background-color: #72bc26;
  color: #ffffff;
  -webkit-transform: scale(1.07);
          transform: scale(1.07);
  text-decoration: none;
}

.btn-email {
  margin: 1.5em 0.5em 1em 0;
}

#btn_nav_primary {
  background-color: transparent;
  background-image: url("img/icons/icon_close.png");
  background-position: -9999px -9999px;
  background-repeat: no-repeat;
  background-size: 30px 30px;
  border: 0;
  display: none;
  height: 80px;
  overflow: hidden;
  padding: 0;
  width: 80px;
}
#btn_nav_primary:focus {
  outline: none;
}
#btn_nav_primary.close {
  background-image: url("img/icons/icon_close.png");
  background-position: 50% 50%;
}
#btn_nav_primary.hamburger {
  background-image: url("img/icons/icon_hamburger.png");
  background-position: 50% 50%;
}
html.js #btn_nav_primary {
  display: block;
}
@media only screen and (min-width: 768px) {
  html.js #btn_nav_primary {
    display: none;
  }
}
#btn_nav_primary span {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.btn-share {
  border: 0;
  padding: 0 0.5em;
}
.btn-share:hover {
  background-color: transparent;
}

.btn-subscribe {
  background-color: transparent;
  border: 1px solid #72bc26;
  border-radius: 0 22px 22px 0;
  color: #72bc26;
  cursor: pointer;
  display: inline-block;
  font-weight: bold;
  line-height: 44px;
  padding: 0 1.5em;
  text-decoration: none;
  transition: all 200ms ease-out;
}
.btn-subscribe:link, .btn-subscribe:visited {
  color: #72bc26;
}
.btn-subscribe:hover, .btn-subscribe:active {
  background-color: #72bc26;
  color: #ffffff;
  text-decoration: none;
}

.wp-block-button__link:link,
.wp-block-button__link:visited {
  background-color: transparent !important;
  border: 2px solid #72bc26 !important;
  color: #72bc26 !important;
  text-decoration: none !important;
  transition: all 200ms ease-out;
}

.wp-block-button__link:hover,
.wp-block-button__link:active {
  background-color: #72bc26 !important;
  color: #ffffff !important;
  -webkit-transform: scale(1.07);
          transform: scale(1.07);
  text-decoration: none !important;
}

/**
 * Article
 _________________________________________________________________________________________
 */
.blockquote-blue {
  color: #0066b3;
}
.blockquote-blue svg.quotation-mark path {
  fill: #94b6d8;
}

.blockquote-case-study {
  font-size: 1.3em;
  font-weight: bold;
  margin: 0;
  padding: 0 0 0 7vw;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .blockquote-case-study {
    font-size: 1.6em;
  }
}
.blockquote-case-study cite {
  color: #333333;
  display: inline-block;
  font-size: 0.8em;
  font-weight: normal;
}
.blockquote-case-study svg.quotation-mark {
  height: auto;
  left: 0;
  position: absolute;
  top: 8px;
  width: 5vw;
}

.blockquote-green {
  color: #72bc26;
}
.blockquote-green svg.quotation-mark path {
  fill: #d0e2bd;
}

.blockquote-orange {
  color: #ff8400;
}
.blockquote-orange svg.quotation-mark path {
  fill: #fbdcbb;
}

.blockquote-purple {
  color: #662d91;
}
.blockquote-purple svg.quotation-mark path {
  fill: #d8cedf;
}

/**
 * Heading
 _________________________________________________________________________________________
 */
.heading-404 {
  background-color: rgba(255, 255, 255, 0.2);
  border: 4px solid #ffffff;
  border-radius: 20px;
  display: inline-block;
  font-size: 1em;
  padding: 0.25em;
}

.heading-about-author {
  color: #aaaaaa;
  display: inline-block;
  flex-basis: 100%;
  font-size: 0.8rem;
  text-transform: uppercase;
}
.heading-about-author span {
  border-bottom: 4px solid #cccccc;
  display: inline-block;
  padding: 0 0 1.5em 0;
}

.heading-about-authors {
  color: #aaaaaa;
  display: inline-block;
  flex-basis: 100%;
  font-size: 0.8rem;
  margin: 0 0 0 5vw;
  text-transform: uppercase;
}
.child-count-2 .heading-about-authors {
  margin: 0 0 0 2.5%;
}
.heading-about-authors span {
  display: inline-block;
  padding: 0 0 1.5em 0;
}
@media only screen and (min-width: 768px) {
  .heading-about-authors span {
    border-bottom: 4px solid #cccccc;
  }
}

.heading-approach {
  color: #ff8400;
  flex-basis: 100%;
  font-size: 2.2em;
  margin: 0;
}

.heading-assist {
  text-transform: uppercase;
  letter-spacing: -1px;
  margin: 0 0 0.5em 0;
}

.heading-approach-section-stage {
  color: #ff8400;
  font-size: 1.2em;
  line-height: 1.2;
  margin: 0 0 0.5em 0;
  text-transform: uppercase;
}
@media only screen and (min-width: 768px) {
  .heading-approach-section-stage {
    background-image: url("img/supergraphic_bullet.png");
    background-position: 100% 0;
    background-repeat: no-repeat;
    background-size: 30px 22px;
    min-height: 50px;
    padding: 0 40px 0 0;
  }
  .section-approach-stage:nth-child(5) .heading-approach-section-stage {
    background-image: none;
    padding: 0;
  }
}

.heading-approach-strategy {
  color: #72bc26;
  flex-basis: 100%;
  font-weight: normal;
  margin: 0 0 1em 0;
}
@media only screen and (min-width: 768px) {
  .heading-approach-strategy {
    margin: 0 0 1em 0;
  }
}

.heading-author {
  font-size: 1rem;
  margin: 0.5em 0 0.5em 0;
}
.heading-author a {
  font-weight: bold;
  text-decoration: none;
}
.heading-author em {
  display: inline-block;
}
.heading-author em.block {
  display: block;
}

.heading-blue {
  color: #0066b3;
}
a:link .heading-blue, a:visited .heading-blue {
  color: #0066b3;
}

.heading-case-study {
  background-color: rgba(0, 0, 0, 0.4);
  bottom: 4vw;
  color: #ffffff;
  font-size: 5vw;
  left: 0;
  margin: 0;
  padding: 0 2vw 0 4vw;
  position: absolute;
  text-shadow: 0 1px 20px rgba(0, 0, 0, 0.9);
  text-transform: uppercase;
}
.heading-case-study.heading-long {
  font-size: 3.2vw;
}
.heading-case-study.heading-longer {
  font-size: 2.8vw;
}
.heading-case-study small {
  border-bottom: 4px solid #ffffff;
  display: inline-block;
  font-size: 14px;
  margin: 0 0 2vw 0;
  padding-bottom: 16px;
}
.heading-case-study span {
  display: block;
}

.heading-case-studies {
  color: #cccccc;
  display: inline-block;
  font-size: 0.8em;
  left: 50%;
  position: absolute;
  text-align: center;
  text-transform: uppercase;
  top: 2vw;
}
.heading-case-studies div {
  border-bottom: 4px solid #f6f6f6;
  left: -50%;
  padding: 0 0 1em 0;
  position: relative;
}
.heading-case-studies svg {
  position: relative;
  top: 4px;
}

.heading-category {
  display: inline-block;
  font-size: 0.9em;
  font-weight: bold;
  margin: 0 0 1em 0;
  padding: 0 0 1em 0;
  position: relative;
}
.heading-category::after {
  background-color: #cccccc;
  bottom: 0;
  content: "";
  display: inline-block;
  height: 4px;
  left: 0;
  position: absolute;
  right: 0;
}
.heading-category a:link,
.heading-category a:visited {
  color: #0066b3;
  text-decoration: none;
}

.heading-challenges {
  letter-spacing: -1px;
  margin: 0 0 0.5em 0;
  text-transform: uppercase;
}
.heading-challenges small {
  display: inline-block;
  font-size: 16px;
}

.heading-contact {
  background-image: url("img/supergraphic_bullet.png");
  background-position: 100% 4px;
  background-repeat: no-repeat;
  background-size: 30px 22px;
  color: #ff8400;
  display: inline-block;
  font-weight: bold;
  letter-spacing: -1px;
  margin: 0;
  min-height: 50px;
  padding: 0 40px 0 15px;
  text-transform: uppercase;
}

.heading-contact-modal {
  align-items: center;
  display: flex;
}

.heading-covid {
  color: #ff8400;
  font-size: 1.4em;
  text-transform: uppercase;
}

.heading-done {
  text-transform: uppercase;
  letter-spacing: -1px;
  margin: 0 0 0.5em 0;
}

.heading-fony-past {
  flex-basis: 100%;
}

.heading-fony-upcoming {
  flex-basis: 100%;
}

.heading-from-blog {
  color: #cccccc;
  flex-basis: 100%;
  font-size: 0.8em;
  left: 50%;
  margin: 0 0 2em 0;
  padding: 0 0 1em 0;
  position: absolute;
  text-align: center;
  text-transform: uppercase;
  top: 4vw;
}
.heading-from-blog div {
  border-bottom: 4px solid #f6f6f6;
  left: -50%;
  padding: 0 0 1em 0;
  position: relative;
}
.heading-from-blog svg {
  position: relative;
  top: 4px;
}

.heading-goal {
  font-size: 2.5em;
  letter-spacing: -1px;
  line-height: 1.1;
  margin: 0 16vw 0.5em 0;
  text-transform: uppercase;
}
.heading-goal small {
  display: inline-block;
  font-size: 16px;
}

.heading-green {
  color: #72bc26;
}
a:link .heading-green, a:visited .heading-green {
  color: #72bc26;
}

.heading-group-leader {
  border-bottom: 4px solid #cccccc;
  color: #aaaaaa;
  display: inline-block;
  font-size: 0.8rem;
  padding: 0 0 1.5em 0;
  text-transform: uppercase;
}

.heading-meta {
  color: #888888;
  font-size: 0.8em;
  line-height: 20px;
  margin: 0 0 1.5em 0;
}
.heading-meta a {
  display: inline-block;
}
.heading-meta a + a {
  margin-right: 1em;
}
.heading-meta a:link,
.heading-meta a:visited {
  color: #888888;
  -webkit-text-decoration-color: #cccccc;
          text-decoration-color: #cccccc;
}
.heading-meta a:hover,
.heading-meta a:active {
  color: #555;
  -webkit-text-decoration-color: #888888;
          text-decoration-color: #888888;
}
.article-sticky .heading-meta {
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
}
.heading-meta .date {
  margin-right: 1em;
}
.heading-meta svg {
  position: relative;
  top: -2px;
  vertical-align: middle;
}

.heading-more {
  color: #cccccc;
  flex-basis: 100%;
  font-size: 0.8em;
  margin: 0 0 2em 0;
  padding: 0 0 1em 0;
  position: relative;
  text-align: center;
  text-transform: uppercase;
}
.heading-more::after {
  background-color: #f6f6f6;
  bottom: 0;
  content: "";
  height: 4px;
  left: 50%;
  margin-left: -85px;
  position: absolute;
  right: auto;
  width: 170px;
}

.heading-nav-footer {
  color: #662d91;
  font-size: 1rem;
  padding-left: 0;
}
@media only screen and (min-width: 768px) {
  .heading-nav-footer {
    padding-left: 1.5em;
  }
}

.heading-orange {
  color: #ff8400;
}
a:link .heading-orange, a:visited .heading-orange {
  color: #ff8400;
}

.heading-other-case-studies {
  border-bottom: 4px solid #f6f6f6;
  color: #cccccc;
  display: inline-block;
  font-size: 0.8em;
  padding: 0 0 0.5em 0;
  text-transform: uppercase;
}
@media only screen and (min-width: 768px) {
  .heading-other-case-studies {
    position: absolute;
    top: 4vw;
  }
}

.heading-purple {
  color: #662d91;
}
a:link .heading-purple, a:visited .heading-purple {
  color: #662d91;
}

.heading-search-result {
  font-size: 1.1em;
  font-weight: normal;
  line-height: 1;
  margin: 0;
}

.heading-search-results {
  color: #888888;
  font-size: 1.1em;
  font-weight: normal;
}

.heading-select-clients {
  bottom: auto;
  color: #cccccc;
  display: inline-block;
  font-size: 0.8em;
  font-weight: bold;
  left: 50%;
  letter-spacing: 1px;
  margin: 0 0 1em 0;
  padding: 0 0 1em 0;
  position: absolute;
  right: auto;
  text-align: center;
  text-transform: uppercase;
  top: 3vw;
}
.heading-select-clients div {
  border-bottom: 4px solid #f6f6f6;
  left: -50%;
  padding: 1em 0;
  position: relative;
}
.heading-select-clients svg {
  position: relative;
  top: 4px;
}

.heading-service {
  background-image: url("img/supergraphic_bullet.png");
  background-position: 0 5px;
  background-repeat: no-repeat;
  background-size: 30px 22px;
  font-size: 1.4em;
  margin: 0 0 0.5em 0;
  text-indent: 38px;
}
.heading-service a:link,
.heading-service a:visited {
  color: #355772;
}
.heading-service a:hover,
.heading-service a:active {
  color: #72bc26;
  -webkit-text-decoration-color: #d0e2bd;
          text-decoration-color: #d0e2bd;
}

.heading-service-group {
  background-image: url("img/supergraphic_check.png");
  background-position: 0 2px;
  background-repeat: no-repeat;
  background-size: 20px 28px;
  font-size: 1.4em;
  text-indent: 32px;
}

.heading-service-groups {
  background-color: #481e68;
  color: #72bc26;
  margin: 0;
}

.heading-services {
  color: #72bc26;
  font-weight: normal;
  margin-bottom: 2em;
}

.heading-single {
  display: flex;
  justify-content: space-between;
}

.heading-subscribe {
  color: #662d91;
  font-size: 1em;
  padding: 0 10px;
  text-transform: uppercase;
}

.heading-subservice {
  color: #72bc26;
  font-size: 1.2rem;
  margin: 0;
}
.heading-subservice:after {
  color: #cccccc;
  content: "/";
  display: inline-block;
  margin: 0 1em;
}
li:last-child .heading-subservice:after {
  display: none;
}
.heading-subservice a:link {
  color: #72bc26;
  -webkit-text-decoration-color: #a2cf73;
          text-decoration-color: #a2cf73;
}
.heading-subservice a:visited {
  color: #a2cf73;
  -webkit-text-decoration-color: #a2cf73;
          text-decoration-color: #a2cf73;
}
.heading-subservice a:hover,
.heading-subservice a:active {
  color: #187e36;
}

.heading-subservices {
  border-bottom: 4px solid rgba(0, 0, 0, 0.1);
  color: #cccccc;
  display: inline-block;
  font-size: 0.8em;
  left: calc(50% - 90px);
  padding: 0 0 1em 0;
  position: absolute;
  text-transform: uppercase;
  top: 2vw;
}

.heading-team-posts {
  color: #cccccc;
  flex-basis: 100%;
  font-size: 0.8em;
  margin: 0 0 2em 0;
  padding: 0 0 1em 0;
  position: relative;
  text-align: center;
  text-transform: uppercase;
}
.heading-team-posts::after {
  background-color: #f6f6f6;
  bottom: 0;
  content: "";
  height: 4px;
  left: 50%;
  margin-left: -100px;
  position: absolute;
  right: auto;
  width: 200px;
}

h2.heading-team-rank {
  background-color: #ccc;
  color: #fff;
  font-size: 0.8em;
  margin: 0;
  padding: 0.5em 4vw;
  text-align: center;
  text-transform: uppercase;
}
@media only screen and (min-width: 480px) {
  h2.heading-team-rank {
    flex-basis: 100%;
    margin: 0 0 1em 0;
    padding: 1em 2%;
  }
}
@media only screen and (min-width: 480px) {
  h2.heading-team-rank:first-child {
    margin-top: -4vw;
  }
}

.heading-testimonial {
  border-bottom: 3px solid rgba(0, 0, 0, 0.08);
  color: #cccccc;
  display: inline-block;
  font-size: 0.8em;
  margin-bottom: 3vw;
  padding: 0 0 0.5em 0;
  text-transform: uppercase;
}

.heading-title {
  color: #333333;
}
.heading-title a:link,
.heading-title a:visited {
  color: #333333;
  line-height: 1.1;
}
.heading-title a:hover,
.heading-title a:active {
  color: #00a5df;
}
.article-sticky .heading-title a:link, .article-sticky .heading-title a:visited {
  color: rgba(255, 255, 255, 0.8);
  font-size: 1.5rem;
}
.article-sticky .heading-title a:hover, .article-sticky .heading-title a:active {
  color: #ffffff;
}
.section-blog .heading-title, .section-fony-past .heading-title {
  font-size: 1.1rem;
  margin: 0 0 0.5em 0;
}
.heading-title a {
  text-decoration: none;
}

h1.heading-title {
  font-size: 1.6em;
}
@media only screen and (min-width: 768px) {
  h1.heading-title {
    font-size: 2em;
  }
}

h3.heading-title {
  font-size: 1em;
  margin: 0 0 0.5em 0;
}

/**
 * Icon
 _________________________________________________________________________________________
 */
.icon-social {
  height: 24px;
  margin: 0 0.5em;
  vertical-align: middle;
  width: 24px;
}

.icons-social {
  display: inline-block;
  margin-top: 1em;
}
@media only screen and (min-width: 480px) {
  .icons-social {
    margin-top: 0;
  }
}

/**
 * Images
 _________________________________________________________________________________________
 */
a img {
  text-decoration: none;
}

.img-headshot-badge {
  background-blend-mode: multiply;
  background-color: #f6f6f6;
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 120% auto;
  border: 2px solid #cccccc;
  border-radius: 50%;
  height: 70px;
  margin: 0 1em 0 0;
  min-width: 70px;
  width: 70px;
}

.img-logo {
  display: block;
  height: auto;
  margin: 0;
  width: 160px;
}
@media only screen and (min-width: 960px) {
  .img-logo {
    width: 200px;
  }
}
#footer .img-logo {
  width: 100px;
}

.img-logo-tagline {
  display: block;
  height: 51px;
  margin: 0;
  width: 200px;
}

.img-logo-client {
  color: #662d91;
  flex-basis: 25%;
  heigh: auto;
  margin: 0 0 1vw 0;
  max-width: 160px;
  min-width: 100px;
  opacity: 0.7;
}
@media only screen and (min-width: 768px) {
  .img-logo-client {
    flex-basis: auto;
  }
}

.img-logo-partner {
  margin: 0 auto;
  width: 50%;
}

.img-case-study,
.img-other-case-study {
  margin: 0 0 0.25em 0;
}

img.img-thumbnail {
  display: block;
}
.section-blog img.img-thumbnail {
  margin-bottom: 0.5em;
}
.article-sticky img.img-thumbnail {
  margin-bottom: 0;
}

.img-thumbnail-wrap {
  border: 1px solid #cccccc;
  height: 0;
  margin: 0 0 0.5em 0;
  overflow: hidden;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}
.article-sticky .img-thumbnail-wrap {
  border: 0;
  height: auto;
  padding-top: 0;
}
.img-thumbnail-wrap .img-thumbnail {
  margin: 0;
  position: absolute;
  top: 0;
  transition: all 2s ease-in;
}
.article-sticky .img-thumbnail-wrap .img-thumbnail {
  position: relative;
}
a:hover .img-thumbnail-wrap .img-thumbnail {
  -webkit-transform: scale(1.2, 1.2);
          transform: scale(1.2, 1.2);
}
.article-sticky a:hover .img-thumbnail-wrap .img-thumbnail {
  -webkit-transform: none;
          transform: none;
}

/**
 * List
 _________________________________________________________________________________________
 */
.list-blue-lighter {
  list-style: none;
}
.list-blue-lighter li:before {
  color: #94b6d8;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-green {
  list-style: none;
}
.list-green li:before {
  color: #72bc26;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-green-lighter {
  list-style: none;
}
.list-green-lighter li:before {
  color: #a2cf73;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-orange {
  list-style: none;
}
.list-orange li:before {
  color: #ff8400;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-orange-light {
  list-style: none;
}
.list-orange-light li:before {
  color: #ff9f33;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-orange-lighter {
  list-style: none;
}
.list-orange-lighter li:before {
  color: #ffc885;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-orange-lightest {
  list-style: none;
}
.list-orange-lightest li:before {
  color: #fbdcbb;
  content: "•";
  display: inline-block;
  font-weight: bold;
  margin-left: -1em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  width: 1em;
}

.list-service-links {
  color: #555;
}

@media only screen and (min-width: 768px) {
  .list-services {
    -webkit-column-count: 2;
       -moz-column-count: 2;
            column-count: 2;
    -webkit-column-width: 300px;
       -moz-column-width: 300px;
            column-width: 300px;
  }
}
.list-services li {
  margin: 0 0 1vw 1vw;
}

.list-subservices {
  list-style: none;
  margin: 0 0 1em 0;
  padding: 0;
  text-align: center;
}
.list-subservices li {
  display: inline-block;
  padding: 0;
}

.list-strategy {
  font-size: 0.9em;
  margin: 0;
  padding: 0 0 0 1em;
}
