/* ==========================================================================
   Author's custom styles
   ========================================================================== */
@font-face {
  font-family: 'Effra-Light';
  src: url('../fonts/Effra-Light.eot?1474105797');
  src: url('../fonts/Effra-Light.eot?&1474105797#iefix') format("embedded-opentype"), url('../fonts/Effra-Light.woff?1474105797') format("woff"), url('../fonts/Effra-Light.ttf?1474105797') format("truetype"), url('../fonts/Effra-Light.svg?1474105797#Effra-Light') format("svg");
  font-weight: 400;
  font-style: normal;
  font-stretch: normal;
  unicode-range: U+000D-FB04;
}
@font-face {
  font-family: 'EffraRegular-Regular';
  src: url('../fonts/EffraRegular-Regular.eot?1474105797');
  src: url('../fonts/EffraRegular-Regular.eot?&1474105797#iefix') format("embedded-opentype"), url('../fonts/EffraRegular-Regular.woff?1474105797') format("woff"), url('../fonts/EffraRegular-Regular.ttf?1474105797') format("truetype"), url('../fonts/EffraRegular-Regular.svg?1474105797#EffraRegular-Regular') format("svg");
  font-weight: 400;
  font-style: normal;
  font-stretch: normal;
  unicode-range: U+0020-FB04;
}
@font-face {
  font-family: 'Effra-Bold';
  src: url('../fonts/Effra-Bold.eot?1474105797');
  src: url('../fonts/Effra-Bold.eot?&1474105797#iefix') format("embedded-opentype"), url('../fonts/Effra-Bold.woff?1474105797') format("woff"), url('../fonts/Effra-Bold.ttf?1474105797') format("truetype"), url('../fonts/Effra-Bold.svg?1474105797#Effra-Bold') format("svg");
  font-weight: 700;
  font-style: normal;
  font-stretch: normal;
  unicode-range: U+0020-FB04;
}
/*======================================================================
    Global Style
========================================================================*/
html {
  height: 100%;
  -webkit-text-size-adjust: none;
  font-size: 10px;
}

body {
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 300;
  color: #000000;
  min-height: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.clearfix {
  clear: both;
}

.useful-widget {
  margin-bottom: 90px;
}
.useful-widget:before, .useful-widget:after {
  content: " ";
  /* 1 */
  display: table;
  /* 2 */
}
.useful-widget:after {
  clear: both;
}
.useful-widget .row div[class*="col"]:nth-child(even) .useful-widget-content .overlay {
  background: #494949;
  mix-blend-mode: multiply;
}
.useful-widget-content {
  position: relative;
  margin-bottom: 25px;
}
.useful-widget-content.simple .overlay,
.useful-widget-content.simple img,
.useful-widget-content.simple p {
  opacity: 0;
}
.useful-widget-content.simple a {
  top: auto;
  left: auto;
  bottom: 0;
  right: 0;
  overflow: auto;
  text-indent: 0;
  width: auto;
  height: auto;
  color: white;
  background: #d92027;
  display: inline-block;
  padding: 25px 20px 25px 45px;
  text-align: center;
  text-decoration: none !important;
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 30px;
  font-size: 3.0rem;
}
.useful-widget-content.simple a:after {
  content: "\f101";
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  text-decoration: inherit;
  display: inline-block;
  margin-left: 25px;
  color: black;
}
.useful-widget-content-text,
.useful-widget-content .overlay,
.useful-widget-content a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  text-indent: -99em;
}
.useful-widget-content .overlay {
  background: #d92027;
  mix-blend-mode: multiply;
}
.useful-widget-content a {
  z-index: 3;
}
.useful-widget-content .logo {
  position: absolute;
  top: 35px;
  left: 25px;
}
.useful-widget-content img.thumb {
  width: 100%;
}
.useful-widget-text p.useful-widget-text-title {
  position: absolute;
  left: 25px;
  bottom: 30px;
  margin: 0;
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 27px;
  font-size: 2.7rem;
  color: white;
  max-width: 270px;
  line-height: 26px !important;
}

.services-listing {
  position: relative;
}
.services-listing-link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.services-listing .overlay, .services-listing-content {
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.services-listing .overlay h4, .services-listing-content h4 {
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 40px;
  font-size: 4.0rem;
  font-weight: 400;
  color: white;
  letter-spacing: 0.1em;
  margin: 0;
}
.services-listing-content {
  display: none;
}
.services-listing .overlay {
  background: #d92027;
  mix-blend-mode: multiply;
  height: 80px;
  top: auto;
  bottom: 0;
}
.services-listing h4.title-close {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 40px;
  font-size: 4.0rem;
  font-weight: 400;
  color: white;
  letter-spacing: 0.1em;
  margin: 0;
  text-align: center;
  padding: 20px 0 10px;
}

.services-list {
  display: inline-block;
  position: relative;
}
.services-list p {
  margin: 0;
}
.services-list-caption {
  position: absolute;
  top: 0;
  left: 0;
  width: 60%;
  height: 100%;
  background: rgba(156, 0, 0, 0.7);
  text-align: left;
  transition: all ease-in-out 0.1s;
}
.services-list-caption img {
  display: block;
  margin-top: 25px;
  margin-left: 15px;
  margin-bottom: 20px;
  width: 84px;
  transition: all ease-in-out 0.1s;
}
.services-list-caption p {
  margin-left: 15px;
  transition: all ease-in-out 0.1s;
}
.services-list-caption p,
.services-list-caption p a {
  font-size: 20px;
  font-size: 2.0rem;
  color: white;
  text-transform: uppercase;
  text-decoration: none;
}
.services-list:hover .services-list-caption {
  width: 100%;
}
.services-list:hover .services-list-caption img {
  margin-left: auto;
  margin-right: auto;
  width: auto;
}
.services-list:hover .services-list-caption p {
  text-align: center;
  font-size: 27px;
  font-size: 2.7rem;
  padding: 0 70px;
}

/*======================================================================
    Wordpress Default Styles
========================================================================*/
/*======================================================================
    Wordpress Base Styles
========================================================================*/
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section {
  display: block;
}

audio, canvas, video {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}

audio:not([controls]) {
  display: none;
}

[hidden] {
  display: none;
}

:focus {
  /* remember to define focus styles! */
  outline: 0;
}

table, caption, tbody, tfoot, thead, tr, th, td {
  border: 0;
  font-family: inherit;
  font-size: 100%;
  font-style: inherit;
  font-weight: inherit;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
}

::-moz-selection {
  background: #333;
  color: #fff;
  text-shadow: none;
}

::selection {
  background: #333;
  color: #fff;
  text-shadow: none;
}

/**
 * Embedded content
 * -----------------------------------------------------------------------------
 */
img {
  border: 0;
  vertical-align: middle;
  -ms-interpolation-mode: bicubic;
}

svg:not(:root) {
  overflow: hidden;
}

/*=== Figures ===*/
figure {
  margin: 0;
}

/**
 * Chrome Frame Styles
 * -----------------------------------------------------------------------------
 */
.chromeframe {
  margin: 0.2em 0;
  padding: 0.2em 0;
  background: #ccc;
  color: black;
}

/*======================================================================
    Wordpress Comments Styles
========================================================================*/
#contents {
  word-wrap: break-word;
  -ms-word-wrap: break-word;
}
#contents .sticky {
  text-decoration: none;
}
#contents .bypostauthor {
  text-decoration: none;
}
#contents .entry .entry-content h1 {
  font-size: 26px;
}
#contents .entry .entry-content h2 {
  font-size: 24px;
}
#contents .entry .entry-content h3 {
  font-size: 20px;
}
#contents .entry .entry-content h4 {
  font-size: 18px;
}
#contents .entry .entry-content h5 {
  font-size: 16px;
}
#contents .entry .entry-content h6 {
  font-size: 14px;
}
#contents .entry .entry-content h1,
#contents .entry .entry-content h2,
#contents .entry .entry-content h3,
#contents .entry .entry-content h4,
#contents .entry .entry-content h5,
#contents .entry .entry-content h6 {
  margin: 10px 0;
  font-family: "EffraRegular-Regular", sans-serif;
}
#contents .entry table {
  border: 1px solid #ddd;
  margin: 0 0 1.625em;
  width: 100%;
}
#contents .entry table th {
  color: #666;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2.6em;
  text-transform: uppercase;
  padding: 6px 0;
  text-indent: 10px;
}
#contents .entry table td {
  border-top: 1px solid #ddd;
  padding: 6px 10px;
}
#contents .entry pre {
  border: 1px solid #e2e2e2;
  padding: 20px;
}

/*======================================================================
    Wordpress Form Styles
========================================================================*/
form {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
}

label {
  cursor: pointer;
}

legend {
  padding: 0;
  border: 0;
  white-space: normal;
  *margin-left: -7px;
}

button, input, select, textarea {
  margin: 0;
  vertical-align: baseline;
  font-size: 100%;
  *vertical-align: middle;
}

button, input {
  line-height: normal;
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
  cursor: pointer;
  -webkit-appearance: button;
  *overflow: visible;
}

button[disabled],
input[disabled] {
  cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
  *width: 13px;
  *height: 13px;
}

input[type="search"] {
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  -webkit-appearance: textfield;
}

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}

textarea {
  overflow: auto;
  vertical-align: top;
  resize: vertical;
}

input:invalid,
textarea:invalid {
  background-color: #f0dddd;
}

/*======================================================================
    Wordpress Gallery Styles
========================================================================*/
.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em;
}

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em;
}

.aligncenter {
  display: block;
  clear: both;
  margin-right: auto;
  margin-left: auto;
}

img.alignnone,
img.alignleft,
img.alignright,
img.aligncenter {
  margin-bottom: 1.5em;
}

.wp-caption {
  margin-bottom: 1.5em;
  padding: 8px;
  max-width: 96%;
  background: #efefef;
}

.wp-caption img {
  display: block;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0 auto;
}

.wp-caption-text {
  position: relative;
  margin-bottom: 0.6em;
  padding: 10px 5px 5px;
  color: #7a7a7a;
  text-align: center;
  font-style: italic;
  font-size: 13px;
  font-family: Georgia, serif;
}

img[class*="wp-image-"] {
  padding: 5px;
  border: 0px solid #ddd;
  background: none;
}

/* Responsive images */
#contents img,
.comment-content img,
.widget img {
  max-width: 100%;
  /* Fluid images for posts, comments, and widgets */
}

img[class*="align"],
img[class*="wp-image-"],
img[class*="attachment-"] {
  height: auto;
  /* Make sure images with WordPress-added height and width attributes are scaled correctly */
}

/* Make sure videos and embeds fit their containers */
embed,
iframe,
object,
video {
  max-width: 100%;
}

/**
 * Wordpress Gallery Styles
 * -----------------------------------------------------------------------------
 */
.gallery {
  margin: auto;
}

.gallery dl {
  margin: 0;
}

.gallery-item {
  float: left;
  margin-top: 10px;
  text-align: center;
  width: 33%;
  margin: 0;
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}

.gallery-item img {
  border: 2px solid #cfcfcf;
  max-width: 100%;
}

.gallery-item .gallery-caption {
  margin-left: 0;
}

.gallery-columns-1 .gallery-item {
  width: 100%;
  margin: 0 5px;
}

.gallery-columns-2 .gallery-item {
  width: 48%;
  margin: 0 5px;
}

.gallery-columns-3 .gallery-item {
  width: 30%;
  margin: 0 10px;
}

.gallery-columns-3 .gallery-item img {
  width: 100%;
}

.gallery-columns-4 .gallery-item {
  width: 22%;
  margin: 0 9px;
}

.gallery-columns-5 .gallery-item {
  width: 17%;
  margin: 0 9px;
}

.gallery-columns-6 .gallery-item {
  width: 15%;
  margin: 0 5px;
}

.gallery-columns-7 .gallery-item {
  width: 12%;
  margin: 0 7px;
}

.gallery-columns-8 .gallery-item {
  width: 10%;
  margin: 0 8px;
}

.gallery-columns-9 .gallery-item {
  width: 9%;
  margin: 0 6px;
}

.gallery-columns-10 .gallery-item {
  width: 8%;
  margin: 0 5px;
}

/*======================================================================
    Wordpress Typography Styles
========================================================================*/
/**
 * Links Styles
 * -----------------------------------------------------------------------------
 */
a {
  color: #00e;
}

a:visited {
  color: #551a8b;
}

a:hover {
  color: #06e;
}

a:focus {
  outline: thin dotted;
}

a:hover, a:active {
  outline: 0;
}

/**
 * Typography Styles
 * -----------------------------------------------------------------------------
 */
abbr[title] {
  border-bottom: 1px dotted;
}

b, strong {
  font-weight: bold;
}

blockquote {
  margin: 1em 40px;
}

dfn {
  font-style: italic;
}

hr {
  display: block;
  margin: 1em 0;
  padding: 0;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
}

ins {
  background: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background: #ff0;
  color: #000;
  font-weight: bold;
  font-style: italic;
}

pre, code, kbd, samp {
  font-size: 1em;
  font-family: monospace, serif;
  _font-family: 'courier new', monospace;
}

pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
}

blockquote, q {
  quotes: "" "";
}

small {
  font-size: 85%;
}

sub, sup {
  position: relative;
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/*======================================================================
    Wordpress Widgets Styles
========================================================================*/
.widget {
  margin: 0 0 30px 0;
}
.widget h3 {
  margin: 20px 0;
  padding: 0;
  text-transform: uppercase;
}
.widget p {
  margin-bottom: 15px;
}
.widget ul {
  clear: both;
  padding-left: 10px;
  list-style-position: inside;
  list-style-type: disc;
}
.widget ul li a {
  padding: 0 0 0 5px;
  line-height: 22px;
  text-decoration: none;
  word-break: break-all;
}
.widget ul li a:hover {
  text-decoration: underline;
}
.widget ul li ul {
  padding: 0 0 0 15px;
  border-top: none;
}

/**
 * Calenday Styles Widget
 * -----------------------------------------------------------------------------
 */
#wp-calendar {
  width: 100%;
  margin-bottom: 15px;
  clear: both;
  padding: 0;
}
#wp-calendar caption {
  padding: 0 0 10px;
}
#wp-calendar th,
#wp-calendar td {
  text-align: center;
  background: rgba(0, 0, 0, 0.05);
  padding: 5px;
}
#wp-calendar td {
  background: transparent;
}
#wp-calendar a {
  color: #000;
  font-weight: bold;
}

/**
 * Comment Threaded Styles
 * -----------------------------------------------------------------------------
 */
#comments {
  position: relative;
  margin: 20px 0 0;
  padding: 20px 0 0 0;
  clear: both;
}
#comments h3 {
  color: #333;
  font-weight: normal;
  margin-bottom: 20px;
}
#comments .comment {
  margin-top: 10px;
  width: 100%;
  list-style-type: none;
}
#comments .comment.thread-even {
  background: #fafafa;
  background: rgba(0, 0, 0, 0.02);
  border-bottom: 1px solid #e6e6e6;
  border-bottom: 1px solid rgba(0, 0, 0, 0.07);
}
#comments .comment article.comment {
  padding: 20px;
  width: auto;
}
#comments .comment .comment-container {
  position: relative;
  padding: 20px;
}
#comments .comment .comment-head {
  margin: 0 0 15px 0;
}
#comments .avatar {
  float: left;
  margin: 0 15px 10px 0;
}
#comments .avatar img {
  margin: 0;
  vertical-align: middle;
  border: 1px solid #ddd;
  padding: 3px;
  background: #fff;
}
#comments .comment-head .name {
  margin: 0;
  font-weight: bold;
  font-size: 15px;
}
#comments .comment-head .date,
#comments .comment-head .edit,
#comments .comment-head .perma {
  font-size: 11px;
}
#comments .comment-entry p {
  margin: 0 0 10px 0;
}
#comments .comment-entry .reply {
  padding-top: 10px;
}
#comments .comment-entry .reply a {
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  background: #FFFFFF;
  color: #555555 !important;
  text-shadow: none;
}
#comments .comment-entry .reply a:hover {
  background: #fafafa;
}
#comments ul.children {
  margin: 10px 10px 0 25px;
  padding: 0;
}
#comments ul.children li {
  border-top: 1px solid #e6e6e6;
}
#comments .cancel-comment-reply {
  margin: 10px 0;
}
#comments .navigation {
  padding: 20px 0;
}
#comments .navigation a {
  display: block;
  margin: 15px 0 0 0;
  text-decoration: none;
}
#comments .navigation .nav-previous {
  float: left;
}
#comments .navigation .nav-next {
  float: right;
}
#comments .navigation h3#pings {
  margin-top: 25px;
}
#comments .pingbacks li .pingback {
  margin: 10px 0;
}
#comments .pingbacks li .pingback .reply {
  display: none;
}

/**
 * Comment Form Styles
 * -----------------------------------------------------------------------------
 */
#respond {
  margin: 40px 0 0;
  clear: both;
}
#respond h3 {
  color: #333;
  font-weight: normal;
  margin-bottom: 20px;
}
#respond #reply-title small {
  display: block;
  font-size: 14px;
  margin-top: 5px;
}
#respond .left {
  float: left;
  width: 200px;
  margin-right: 15px;
}
#respond .right {
  float: left;
  width: 380px;
}
#respond label {
  font-size: 11px;
  color: #777;
}

#commentform {
  margin: 15px 0 0 0;
}
#commentform input.txt,
#commentform textarea {
  font: 14px/14px Arial, Helvetica, sans-serif;
  border-color: #ccc #efefef #efefef #ccc;
  border-width: 1px;
  border-style: solid;
}
#commentform input.txt {
  color: #666;
  background: #fcfcfc;
  width: 170px;
  margin: 0 5px 10px 0;
  padding: 5px 7px;
}
#commentform textarea {
  color: #666;
  background: #fcfcfc;
  width: 95% !important;
  padding: 5px 7px;
}
#commentform #submit {
  margin: 15px 0 0 0;
}

/**
 * Comment Form Styles
 * -----------------------------------------------------------------------------
 */
h3#pings {
  margin: 25px 0 10px 0;
}

.pinglist li {
  margin: 0 0 0 20px;
  list-style-type: decimal;
}
.pinglist li .author {
  font-weight: bold;
  font-size: 15px;
}
.pinglist li .date {
  font-size: 11px;
}
.pinglist li .pingcontent {
  display: block;
  margin: 10px 0;
}

/*======================================================================
    Helper Styles
========================================================================*/
/*
 * Image replacement
 */
.ir {
  background-color: transparent;
  border: 0;
  overflow: hidden;
  /* IE 6/7 fallback */
  *text-indent: -9999px;
}

.ir:before {
  content: "";
  display: block;
  width: 0;
  height: 150%;
}

/*
 * Hide from both screenreaders and browsers: h5bp.com/u
 */
.hidden {
  display: none !important;
  visibility: hidden;
}

/*
 * Hide only visually, but have it available for screenreaders: h5bp.com/v
 */
.visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element to be focusable
 * when navigated to via the keyboard: h5bp.com/p
 */
.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
  clip: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  width: auto;
}

/*
 * Hide visually and from screenreaders, but maintain layout
 */
.invisible {
  visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */
.clearfix:before,
.clearfix:after {
  content: " ";
  /* 1 */
  display: table;
  /* 2 */
}

.clearfix:after {
  clear: both;
}

/*
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.clearfix {
  *zoom: 1;
}

/*======================================================================
    Template Sections Styles
========================================================================*/
/*======================================================================
    Header Styles
========================================================================*/
.site-header {
  background: url('../images/bg-header.jpg?1474115314') top center no-repeat;
  height: 224px;
}
@media (max-width: 1200px) {
  .site-header {
    background: none;
  }
}
.site-header-logo {
  margin-top: 49px;
  margin-left: -15px;
  margin-bottom: 44px;
}
@media (max-width: 1200px) {
  .site-header-logo {
    text-align: center;
    margin-left: 0;
  }
}
@media (max-width: 1200px) {
  .site-header .navigation {
    display: none;
  }
}
.site-header .navigation-main {
  margin-top: 95px;
}
.site-header .navigation-main ul {
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: right;
}
.site-header .navigation-main ul > li {
  display: inline-block;
  position: relative;
}
.site-header .navigation-main ul > li > a {
  display: block;
  color: #1b1b1b;
  font-family: "Effra-Light", sans-serif;
  font-size: 20px;
  font-size: 2.0rem;
  margin-left: 65px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 50px 0;
  transition: all ease-in-out;
}
.site-header .navigation-main ul > li > a:hover {
  color: #d92027;
}
.site-header .navigation-main ul > li.current_page_item > a, .site-header .navigation-main ul > li.current-menu-item > a {
  font-family: "EffraRegular-Regular", sans-serif;
  color: #d92027;
}
.site-header .navigation-main ul > li.menu-item-has-children > a:after {
  content: "\f103";
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  margin-left: 14px;
  display: inline-block;
}
.site-header .navigation-main ul > li:hover .sub-menu {
  display: block;
}
.site-header .navigation-main ul > li > .sub-menu {
  display: none;
  position: absolute;
  top: 129px;
  right: 0;
  z-index: 999;
}
.site-header .navigation-main ul > li .sub-menu li {
  display: block;
}
.site-header .navigation-main ul > li .sub-menu li a {
  background: #d8d8d8;
  padding: 20px 50px;
  margin-left: 0;
  transition: background ease-in-out 0.3s;
}
.site-header .navigation-main ul > li .sub-menu li a:hover {
  color: #1b1b1b;
  background: #f4f4f4;
}
.site-header .navigation-main ul > li .sub-menu li.current-menu-item a, .site-header .navigation-main ul > li .sub-menu li.current_page_item a {
  color: #1b1b1b;
  background: #f4f4f4;
}

.mobile-nav {
  display: none;
}
@media (max-width: 1200px) {
  .mobile-nav {
    display: block;
  }
  .site-header {
      height: 100%;
  }
  .mobile-nav ul ul li a {
    font-size: 14px;
    padding: 9px;
    border-bottom: 1px solid #bbbcbe;
    background: rgba(187, 188, 190, 0.71);
    }
}
.mobile-nav p {
  font-size: 30px;
  font-size: 3.0rem;
  background: #bbbcbe;
  color: black;
  text-align: center;
  margin: 0;
  padding: 25px 0;
  cursor: pointer;
}
.mobile-nav p i {
  color: white;
  margin-left: 15px;
}
.mobile-nav ul {
  display: none;
  margin: 0;
  padding: 0;
  list-style: none;
}
.mobile-nav ul li a {
  text-align: center;
  display: block;
  background: #bbbcbe;
  color: black;
  border-bottom: 1px solid white;
  text-decoration: none;
  transition: all ease-in-out 0.5s;
  font-size: 20px;
  font-size: 2.0rem;
  padding: 15px;
}
.mobile-nav ul li a:hover {
  background: #f4f4f4;
}

/*======================================================================
    Footer Styles
========================================================================*/
.site-footer {
  background: url('../images/bg-footer.jpg?1474102219') top center no-repeat;
  padding-bottom: 289px;
}
@media (max-width: 768px) {
  .site-footer {
    background: url('../images/bg-footer-mobile.jpg?1474340655') top center no-repeat;
    background-size: cover;
    padding-bottom: 0;
  }
}
.site-footer-widget > div .overlay {
  display: none;
}
@media (max-width: 768px) {
  .site-footer-widget {
    text-align: center;
    position: relative;
  }
  .site-footer-widget > div {
    background: rgba(0, 0, 0, 0.5);
    position: relative;
  }
  .site-footer-widget > div * {
    position: relative;
    z-index: 2;
  }
  .site-footer-widget > div .overlay {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    background: #d92027;
    mix-blend-mode: multiply;
  }
  .site-footer-widget .second {
    padding-bottom: 80px;
  }
}
.site-footer-widget-title {
  font-family: "Effra-Bold", sans-serif;
  font-size: 35px;
  font-size: 3.5rem;
  font-weight: 400;
  text-transform: uppercase;
  color: black;
  margin: 100px 0 55px;
}
@media (max-width: 768px) {
  .site-footer-widget-title {
    color: white;
  }
}
.site-footer-widget ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.site-footer-widget ul li {
  font-size: 16px;
  font-size: 1.6rem;
  color: white;
  line-height: 36px;
  text-transform: uppercase;
}
.site-footer-widget ul li a {
  color: white;
  text-decoration: none;
}
.site-footer-widget-contact .site-footer-widget-title {
  color: white;
}
.site-footer-widget-contact p {
  margin: 0;
  color: white;
}
.site-footer-widget-contact p a {
  font-family: "Effra-Bold", sans-serif;
  font-size: 25px;
  font-size: 2.5rem;
  font-weight: 400;
  color: white;
  text-decoration: none;
}
@media (max-width: 768px) {
  .site-footer-widget-contact {
    text-align: center !important;
    padding-bottom: 70px;
  }
}

@media (max-width: 768px) {
  .site-notes {
    padding-top: 20px;
  }
}
.site-notes p {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 20px 0;
}
.site-notes p img {
  margin-top: -3px;
}
@media (max-width: 768px) {
  .site-notes p {
    text-align: center;
    padding: 0;
    margin: 5px 0;
  }
  .site-notes p img {
    float: none;
  }
}
.site-notes-copy {
  color: #505050;
}
.site-notes-copy img {
  float: left;
  margin-right: 20px;
}
.site-notes-dev {
  color: #020202;
}
.site-notes-dev img {
  float: right;
  margin-left: 20px;
}

/*======================================================================
    Banner Styles
========================================================================*/
.banner {
  position: relative;
  background: url('../images/bg-banner-default.jpg?1474117845') top center no-repeat;
}
.banner-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('../images/bg-section-overlay.png?1474304154') top center no-repeat;
}
.banner-heading {
  display: inline-block;
  font-family: "Effra-Bold", sans-serif;
  font-size: 45px;
  font-size: 4.5rem;
  margin: 100px 0 0;
}
.banner-heading:after {
  content: "\f103";
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  font-size: 20px;
  font-size: 2.0rem;
  text-decoration: inherit;
  color: #d92027;
  margin-left: 14px;
  display: inline-block;
}
.banner .display-table {
  display: table;
  width: 100%;
  height: 297px;
}
.banner .display-table-cell {
  display: table-cell;
  vertical-align: middle;
}

.content-area {
  padding-top: 80px;
}

/*======================================================================
    Pages Styles
========================================================================*/
/*======================================================================
    Default Page Template
========================================================================*/
/*======================================================================
    Default Page Template
========================================================================*/
/*======================================================================
    Default Home Template
========================================================================*/
.section-holder {
  position: relative;
  background: url('../images/bg-section-default.jpg?1474303628') top center no-repeat;
  padding-bottom: 30px;
}
@media (max-width: 768px) {
  .section-holder {
    background-size: cover;
  }
}
.section-holder .content-area {
  padding-top: 0;
}
.section-holder-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('../images/bg-section-overlay.png?1474304154') top center no-repeat;
}
@media (max-width: 768px) {
  .section-holder-overlay {
    background: rgba(255, 255, 255, 0.7);
  }
}
.section-holder .section-title {
  font-family: "Effra-Bold", sans-serif;
  font-size: 45px;
  font-size: 4.5rem;
  font-weight: 400;
  color: #010101;
  margin: 190px 0 50px;
  letter-spacing: 0.1em;
}
.section-holder .section-title span {
  color: #d92027;
}
@media (max-width: 768px) {
  .section-holder .section-title {
    text-align: center;
    font-size: 40px;
    font-size: 4.0rem;
    margin-top: 70px;
  }
}
@media (max-width: 480px) {
  .section-holder .section-title {
    font-size: 30px;
    font-size: 3.0rem;
  }
}
.section-holder p {
  letter-spacing: 0.1em;
  line-height: 34px;
}
@media (max-width: 768px) {
  .section-holder p {
    text-align: center;
  }
}
.section-holder.details-banner .section-title {
  margin-top: 155px;
}
@media (max-width: 768px) {
  .section-holder.details-banner .section-title {
    margin-top: 70px;
  }
}

.contact-section {
  background: url('../images/bg-contact.jpg?1474211612') top center no-repeat;
}
@media (max-width: 768px) {
  .contact-section {
    background: none;
  }
  .contact-section h1 {
    text-align: center;
  }
  .contact-section .hide-on-mobile {
    display: none !important;
  }
}
.contact-section .call-pane {
  background: #bbbcbe;
  padding: 20px 50px;
  margin-bottom: 41px;
  margin-top: 700px;
  float: right;
}
.contact-section .call-pane a {
  color: white;
  font-size: 35px;
  font-size: 3.5rem;
  text-decoration: none;
}
.contact-section .call-pane a i {
  font-size: 40px;
  font-size: 4.0rem;
  color: black;
  margin-right: 25px;
}
.contact-section p {
  line-height: 34px;
  letter-spacing: 0.1em;
}
@media (max-width: 768px) {
  .contact-section p {
    text-align: center;
  }
}
.contact-section form {
  margin-top: 30px;
}
.contact-section form br {
  display: none;
}
.contact-section form input,
.contact-section form textarea {
  border: 0;
  margin-bottom: 10px;
  background: #d8d8d8;
  font-size: 20px;
  font-size: 2.0rem;
  display: block;
  border-radius: 0;
  width: 100%;
  padding: 15px 20px;
}
.contact-section form input::-webkit-input-placeholder,
.contact-section form textarea::-webkit-input-placeholder {
  color: black;
}
.contact-section form input::-moz-placeholder,
.contact-section form textarea::-moz-placeholder {
  color: black;
}
.contact-section form input:-moz-placeholder,
.contact-section form textarea:-moz-placeholder {
  color: black;
}
.contact-section form textarea {
  height: 230px;
}
.contact-section form label.btn {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
  line-height: normal !important;
}
.contact-section form .wpcf7-submit {
  display: none;
}
.contact-section form .send-button {
  padding-top: 300px;
}

/*======================================================================
    Default Home Template
========================================================================*/
.page-template-template-contact .content-area {
  padding-top: 115px;
}
.page-template-template-contact .container-contact {
  background: url('../images/bg-contact.jpg?1474211612') top center no-repeat;
}
.page-template-template-contact .call-pane {
  background: #bbbcbe;
  padding: 20px 50px;
  margin-bottom: 41px;
}
.page-template-template-contact .call-pane a {
  color: white;
  font-size: 35px;
  font-size: 3.5rem;
  text-decoration: none;
}
.page-template-template-contact .call-pane a i {
  font-size: 40px;
  font-size: 4.0rem;
  color: black;
  margin-right: 25px;
}
.page-template-template-contact p {
  line-height: 34px !important;
}
.page-template-template-contact form {
  margin-top: 30px;
}
.page-template-template-contact form br {
  display: none;
}
.page-template-template-contact form input,
.page-template-template-contact form textarea {
  border: 0;
  margin-bottom: 10px;
  background: #d8d8d8;
  font-size: 20px;
  font-size: 2.0rem;
  display: block;
  border-radius: 0;
  width: 100%;
  padding: 15px 20px;
}
.page-template-template-contact form input::-webkit-input-placeholder,
.page-template-template-contact form textarea::-webkit-input-placeholder {
  color: black;
}
.page-template-template-contact form input::-moz-placeholder,
.page-template-template-contact form textarea::-moz-placeholder {
  color: black;
}
.page-template-template-contact form input:-moz-placeholder,
.page-template-template-contact form textarea:-moz-placeholder {
  color: black;
}
.page-template-template-contact form textarea {
  height: 230px;
}
.page-template-template-contact form label.btn {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
  line-height: normal !important;
}
.page-template-template-contact form .wpcf7-submit {
  display: none;
}
.page-template-template-contact form .send-button {
  padding-top: 300px;
}

.single-our_services #primary .site-main .entry-content p {
  line-height: 34px;
}
.single-our_services #primary .site-main .entry-content ul li {
  line-height: 34px;
}
.single-our_services #primary .site-main .entry-content ul ul {
  margin-top: 35px;
  margin-bottom: 35px;
}
.single-our_services #primary .site-main .entry-content .small,
.single-our_services #primary .site-main .entry-content small {
  line-height: 20px;
}

.services-listing {
  margin-bottom: 40px;
}

.service-items {
  padding-bottom: 120px;
}
.service-items h1 {
  font-family: "Effra-Bold", sans-serif;
  font-size: 45px;
  font-size: 4.5rem;
  font-weight: normal;
  margin: 95px 0 55px;
}
@media (max-width: 768px) {
  .service-items h1 {
    text-align: center;
  }
}
.service-items .service-item {
  position: relative;
  margin-bottom: 30px;
  max-height: 210px;
  overflow: hidden;
}
.service-items .service-item-content,
.service-items .service-item .overlay, .service-items .service-item-fixed,
.service-items .service-item a {
  position: absolute;
}
.service-items .service-item-content,
.service-items .service-item .overlay, .service-items .service-item-fixed,
.service-items .service-item a {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.service-items .service-item a {
  z-index: 10;
}
.service-items .service-item .overlay {
  width: 65%;
  background: #d92027;
  mix-blend-mode: multiply;
}
.service-items .service-item-content {
  display: none;
}
.service-items .service-item-content .logo {
  margin-bottom: 20px;
}
.service-items .service-item .display-table {
  display: table;
  width: 100%;
  height: 100%;
}
.service-items .service-item .display-table-cell {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
.service-items .service-item h3 {
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 30px;
  font-size: 3.0rem;
  font-weight: normal !important;
  letter-spacing: 0.1em;
  color: white !important;
  margin: 0;
}
.service-items .service-item h3 a {
  color: white !important;
}
.service-items .service-item-fixed {
  text-align: left;
}
.service-items .service-item-fixed .logo {
  position: absolute;
  top: 35px;
  left: 25px;
}
.service-items .service-item-fixed h3 {
  position: absolute;
  bottom: 25px;
  left: 25px;
  font-size: 25px;
  font-weight: normal !important;
  max-width: 300px;
}
@media (max-width: 480px) {
  .service-items .service-item-fixed h3 {
    font-size: 20px;
    font-size: 17px;
    max-width: 100px;
  }
  .service-items .service-item-fixed .logo {
      top: 22px;
  }
}
.service-items .service-item .thumb img {
  width: 100%;
}

.service-page-partial {
  display: none;
}
@media (max-width: 768px) {
  .service-page-partial {
    display: block;
  }
}

@media (max-width: 768px) {
  .service-page-full {
    display: none;
  }
}

/*======================================================================
    Partials
========================================================================*/
.btn {
  display: inline-block;
  padding: 25px 20px 25px 45px;
  text-align: center;
  text-decoration: none !important;
  font-family: "EffraRegular-Regular", sans-serif;
  font-size: 30px;
  font-size: 3.0rem;
}
.btn-red {
  background: #d92027;
  color: white !important;
}
.btn-grey {
  background: #d8d8d8;
  color: #1d1d1d !important;
}

.btn:after {
  content: "\f101";
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  text-decoration: inherit;
  display: inline-block;
  margin-left: 25px;
}

.btn-red:after {
  color: #1d1d1d !important;
}

.btn-grey:after {
  color: white !important;
}

#primary .site-main .entry-content h1,
#primary .site-main .entry-content h2,
#primary .site-main .entry-content h3,
#primary .site-main .entry-content h4,
#primary .site-main .entry-content h5,
#primary .site-main .entry-content h6 {
  font-family: "Effra-Bold", sans-serif;
  color: #d92027;
}
#primary .site-main .entry-content h1 {
  font-size: 60px;
  font-size: 6.0rem;
}
#primary .site-main .entry-content h2 {
  font-size: 45px;
  font-size: 4.5rem;
}
#primary .site-main .entry-content h3 {
  font-size: 30px;
  font-size: 3.0rem;
}
#primary .site-main .entry-content h4 {
  font-size: 25px;
  font-size: 2.5rem;
}
#primary .site-main .entry-content h5 {
  font-size: 16px;
  font-size: 1.6rem;
}
#primary .site-main .entry-content li,
#primary .site-main .entry-content p {
  line-height: 26px;
  letter-spacing: 0.1em;
}
#primary .site-main .entry-content b,
#primary .site-main .entry-content strong {
  font-family: "Effra-Bold", sans-serif;
}
#primary .site-main .entry-content .light {
  font-family: "Effra-Light", sans-serif;
}
#primary .site-main .entry-content .pane {
  background: #f4f4f4;
  padding: 30px;
}
#primary .site-main .entry-content ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
#primary .site-main .entry-content ul li {
  background: url('../images/bg-bullet.png?1474126146') 0 10px no-repeat;
  padding-left: 40px;
  line-height: 34px;
}
#primary .site-main .entry-content ul li ul {
  margin-top: 10px;
}
#primary .site-main .entry-content ul li ul li {
  background: url('../images/bg-bullet-sub.png?1474126169') 0 10px no-repeat;
}
#primary .site-main .entry-content small {
  font-size: 13px;
}

.u-uppercase {
  text-transform: uppercase;
}

.u-align-left {
  text-align: left;
}

.u-align-right {
  text-align: right;
}

.u-align-center {
  text-align: center;
}

.u-display-inline-block {
  display: inline-block !important;
}

.u-display-table {
  display: table;
  width: 100%;
  height: 100%;
}
.u-display-table-cell {
  display: table-cell;
  vertical-align: middle;
}

/*======================================================================
    Print Styles
========================================================================*/
/*=== Print Styles ===*/
@media print {
  * {
    background: transparent !important;
    box-shadow: none !important;
    color: black !important;
    text-shadow: none !important;
    -ms-filter: none !important;
    filter: none !important;
  }

  /* Black prints faster: h5bp.com/s */
  a,
  a:visited {
    text-decoration: underline;
  }

  a[href]:after {
    content: " (" attr(href) ")";
  }

  abbr[title]:after {
    content: " (" attr(title) ")";
  }

  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after {
    content: "";
  }

  /* Don't show links for images, or javascript/internal links */
  pre,
  blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }

  thead {
    display: table-header-group;
  }

  /* h5bp.com/t */
  tr, img {
    page-break-inside: avoid;
  }

  img {
    max-width: 100% !important;
  }

  @page {
    margin: 0.5cm;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }

  h2, h3 {
    page-break-after: avoid;
  }
}
/*======================================================================
    Override Styles here
========================================================================*/
/**/
.page-content, .entry-content, .entry-summary {
  margin-top: 0;
}
